I have a container bound Script and a htmlService Sidebar.
The sheet contains 2 columns B, C.
B contains a ID, C contains a item name.
You enter the ID into the html input and submit, if theres a ID matching the one you enter the row gets deleted.
Now i want to use the confirm() method to confirm the deletion like so:
"Are sure that you want to delete " itemName " form your Inventory"
My problem is that im struggling to get the to the ID adjacent Item name cell value.
JS
var adjacentName = ??????
function showDeleteElectronics() {
const ui = SpreadsheetApp.getUi();
var deleteElectronicsForm = HtmlService.createTemplateFromFile('DeleteElectronicsHTML')
deleteElectronicsForm.itemName = adjacentName;
var html = deleteElectronicsForm.evaluate();
html.setTitle("Elektronik Entfernen")
ui.showSidebar(html);
}
function deleteElectronics(formObject) {
var electronicsID = formObject.electronicsLocalID
var SS = SpreadsheetApp.openById("1GSzlzj7nHPIUt-RIJfsPFobtnLbuoXedtJk1x11BdT0");
var SHEET = SS.getSheetByName("ElektronikBestand");
var RANGE = SHEET.getDataRange();
var DELETE_VAL = electronicsID;
var LOCAL_ID = 1;
function deleteItem(){
var rangeVals = RANGE.getValues();
//Reverse the 'for' loop.
for(var i = rangeVals.length-1; i >= 0; i--){
if(rangeVals[i][LOCAL_ID] === DELETE_VAL){
SHEET.deleteRow(i 1);
};
};
};
deleteItem();
}
HTML
<div >
<div >
<button onclick="google.script.host.close()">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 212.982 212.982" style="enable-background:new 0 0 212.982 212.982" xml:space="preserve"><path style="fill-rule:evenodd;clip-rule:evenodd" d="m131.804 106.491 75.936-75.936c6.99-6.99 6.99-18.323 0-25.312-6.99-6.99-18.322-6.99-25.312 0L106.491 81.18 30.554 5.242c-6.99-6.99-18.322-6.99-25.312 0-6.989 6.99-6.989 18.323 0 25.312l75.937 75.936-75.937 75.937c-6.989 6.99-6.989 18.323 0 25.312 6.99 6.99 18.322 6.99 25.312 0l75.937-75.937 75.937 75.937c6.989 6.99 18.322 6.99 25.312 0 6.99-6.99 6.99-18.322 0-25.312l-75.936-75.936z"/><g/><g/><g/><g/><g/><g/><g/><g/><g/><g/><g/><g/><g/><g/><g/></svg>
</button>
</div>
<div >
<img src="https://i.imgur.com/d1VMjvs.png">
<h1 >Elektronik <br> Entfernen</h1>
</div>
<div ></div>
<form id="removeElectronicsFrom">
<div >
<div >
<label for="electronicsLocalID">Lokale ID</label>
</div>
<input
type="text"
placeholder="PREF00000001..."
minlength="12"
maxlength="12"
id="electronicsLocalID"
name="electronicsLocalID"
required>
</div>
<div >
<input
type="submit"
value="Entfernen"
id="removeElectronics">
</div>
</form>
</div>
<script>
document.querySelector("#removeElectronicsFrom").addEventListener("submit", function (e) {
let confirmString = "Are you sure that you want to delete " itemName "?";
e.preventDefault();
if (confirm(confirmString)) {
google.script.run.deleteElectronics(this);
$('#removeElectronicsFrom').trigger("reset");
} else {
$('#removeElectronicsFrom').trigger("reset");
}
});
</script>
Column B | Column C |
---|---|
ID | itemName |
-- | -- |
MUCH00000001 | Item1 |
MUCH00000002 | Item2 |
MUCH00000003 | Item3 |
MUCH00000004 | Item4 |
MUCH00000005 | Item5 |
MUCH00000006 | Item6 |
MUCH00000007 | Item7 |
MUCH00000008 | Item8 |
MUCH00000009 | Item9 |
MUCH00000010 | Item10 |
CodePudding user response:
You have to call the function twice. First to get itemname and then to delete:
Server side:
function getItemName(formObject) {
const electronicsID = formObject.electronicsLocalID;
const SHEET = getSheet();
const RANGE = SHEET.getDataRange();
const DELETE_VAL = electronicsID;
const ITEMNAMECOL = 2;
const LOCAL_ID = 1;
const rangeVals = RANGE.getValues();
//Reverse the 'for' loop.
for (var i = rangeVals.length - 1; i >= 0; i--) {
if (rangeVals[i][LOCAL_ID] === DELETE_VAL) {
return {
i,
//id: rangeVals[i][LOCAL_ID],
itemName: rangeVals[i][ITEMNAMECOL],
};
}
}
return {i, itemName: "not found"};
}
function getSheet() {
const SS = SpreadsheetApp.openById(
'1GSzlzj7nHPIUt-RIJfsPFobtnLbuoXedtJk1x11BdT0'
);
const SHEET = SS.getSheetByName('ElektronikBestand');
return SHEET;
}
function deleteElectronics(i) {
getSheet().deleteRow(i 1);
}
Client side:
document.querySelector("#removeElectronicsFrom").addEventListener("submit", function (e) {
e.preventDefault();
google.script.run.withSuccessHandler(({i, itemName}) => {
const confirmString = "Are you sure that you want to delete " itemName "?";
if (confirm(confirmString)) {
google.script.run.deleteElectronics(i);
$('#removeElectronicsFrom').trigger("reset");
} else {
$('#removeElectronicsFrom').trigger("reset");
}
}).getItemName(this)
});