Не удается получить данные для перехода на правильный лист при использовании google-apps-scripts для отправки данных формы HTML в документ GoogleSheets.У меня есть данные, записываемые на лист Google, поэтому я уверен, что я правильно обновляю приложение gs, но в любой момент работает только один лист.Я не могу получить данные со своей второй страницы формы для перехода на отдельный лист.
Я студент второго семестра, поэтому я не совсем понимаю все, что использую, некоторые разделыиз учебников другие взяты из материалов моего учителя (ему любопытно посмотреть, смогу ли я заставить это работать), и форма всего за 10 минут с шаблоном начальной загрузки просто для базового тестирования.
Я открыт для всех предложений, чтобы помочь с этим, но я был бы благодарен, если бы его легко было расширить, чтобы иметь возможность включать больше вкладок позже в проект.Спасибо за ваше время.
meetingeventtracker.html - раздел формы fundrasingrequest.html - это одно и то же, но с разными идентификаторами и именами
<div class="col-md-8">
<input type="text" id="orgNameMET" name="orgNameMET" class="form-control-md form-control inputs" placeholder="Enter Organization Name">
<input type="text" id="repNameMET" name="repNameMET" class="form-control-md form-control inputs" placeholder="Enter Name of Representative">
<input type="email" id="repEmailMET" name="repEmailMET" class="form-control-md form-control inputs" placeholder="Enter Email of Representative">
<input type="date" id="dateOfMeeting" name="dateOfMeeting" class="form-control-md form-control inputs" placeholder="Enter Date of Meeting/Event">
<input type="time" id="timeOfEvent" name="timeOfEvent" class="form-control-md form-control inputs" placeholder="Enter Time of Meeting/Event">
<input type="number" id="meetingCosts" name="meetingCosts" class="form-control-md form-control inputs" placeholder="Enter Cost of Meeting">
<input type="text" id="futureEvents" name="futureEvents" class="form-control-md form-control inputs" placeholder="Enter Future Events">
<input type="text" id="ifFund" name="ifFund" class=form-control-md form-control inputs="IF fundraiser" value="meet" style="opacity: 0;">
<button type="submit">Submit Data</button>
</div>
google-sheet.js whatя использую для отправки данных из форм в сценарий
/*jslint browser: true*/
/*global $, jQuery, alert*/
// Variable to hold request
var request;
$("#foo").submit(function(event){
if (request) {
request.abort();
}
var $form = $(this);
var $inputs = $form.find("input, button");
var serializedData = $form.serialize();
$inputs.prop("disabled", true);
request = $.ajax({
url: "https://script.google.com/macros/s/AKfycbzc9hr7HFK10LBVP_UnOvVyUsTDslD4GBq50olyGdP5br6TBkE/exec",
type: "post",
data: serializedData
});
request.done(function (response, textStatus, jqXHR){
console.log("Hooray, it worked!");
console.log(response);
console.log(textStatus);
console.log(jqXHR);
});
request.fail(function (jqXHR, textStatus, errorThrown){
console.error(
"The following error occurred: "+
textStatus, errorThrown
);
});
request.always(function () {
$inputs.prop("disabled", false);
});
event.preventDefault();
});
Code.gs сценарий приложений Google, я не знаю, какой параметр будет для полученияприложение для переключения вкладок в листах в зависимости от того, какая форма была отправлена
var tabs = [
'MeetingEventTracker',
'FundRaisingRequest'
];
//var SHEET_NAME = tabs[1];
var SCRIPT_PROP = PropertiesService.getScriptProperties();
function doGet(e) {
return handleResponse(e);
}
function doPost(e) {
return handleResponse(e);
}
function handleResponse(e) {
var lock = LockService.getPublicLock();
lock.waitLock(30000); // wait 30 seconds before conceding defeat.
try {
var doc = SpreadsheetApp.openById(SCRIPT_PROP.getProperty("key"));
for (i = 0; i < 12; i++ ){
if (e.parameter[i] = "meet") {
var SHEET_NAME = tabs[1];
} else if (e.parameter[i] = "fund") {
var SHEET_NAME = tabs[0];
}
}
var sheet = doc.getSheetByName(SHEET_NAME);
var headRow = e.parameter.header_row || 1;
var headers = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues()[0];
var nextRow = sheet.getLastRow() + 1; // get next row
var row = [];
// loop through the header columns
for (i in headers) {
if (headers[i] == "Timestamp") {
row.push(new Date());
} else {
row.push(e.parameter[headers[i]]);
}
}
sheet.getRange(nextRow, 1, 1, row.length).setValues([row]);
return ContentService
.createTextOutput(JSON.stringify({
"result": "success",
"row": nextRow,
}))
.setMimeType(ContentService.MimeType.JSON);
} catch (e) {
return ContentService
.createTextOutput(JSON.stringify({
"result": "error",
"error": e,
}))
.setMimeType(ContentService.MimeType.JSON);
} finally { //release lock
lock.releaseLock();
}
}
function setup() {
var doc = SpreadsheetApp.getActiveSpreadsheet();
SCRIPT_PROP.setProperty("key", doc.getId());
}