Please click 'App Script' in the 'Extensions' tab of Google Sheets.
data:image/s3,"s3://crabby-images/9c8ca/9c8cafb6085834438f5ddd0bcda375a9f9ab7f12" alt=""
Please add a new script.
data:image/s3,"s3://crabby-images/74c6f/74c6f9c3e8c8db131c233942fe997550c05982c4" alt=""
Please delete all the default content and paste the following code:
function doPost(e) {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet = ss.getSheets()[0];
ss.setSpreadsheetTimeZone('Asia/Seoul');
var data = JSON.parse(e.postData.contents);
var formAnswers = data.form_answers;
var submittedAt = new Date(data.form_response.submitted_at);
var responseId = data.form_response.response_id.slice(0,10);
if (sheet.getLastRow() === 0) {
var fieldLabels = formAnswers.map(function(answer) {
if (answer.type === 'RADIO_GRID' || answer.type === 'CHECKBOX_GRID') {
return answer.response.map(el => `${answer.label} - ${el.lineLabel}`);
}
return answer.label
}).flat();
var headers = ['Response ID', 'Time Submitted', ...fieldLabels]
sheet.appendRow(headers);
}
var rowData = formAnswers.map(field => {
switch (field.type) {
case 'CHECKBOX':
case 'RADIO': {
var isResponseArray = Array.isArray(field.response);
if (isResponseArray) {
return field.response.filter(el => Boolean(el)).join(', ');
}
return field.response || '';
}
case 'CHECKBOX_GRID':
case 'RADIO_GRID': {
var isLineResponseArray = Array.isArray(field.response.lineResponse)
return field.response.map(el => {
if (isLineResponseArray) {
return el.lineResponse.filter(el => Boolean(el)).join(', ');
}
return el.lineResponse || '';
})
}
case 'GEOLOCATION': {
var response = field.response || {};
var responseArray = Object.entries(response).map(el => `${el[0]}: ${el[1]}`);
return responseArray.join(', ');
}
case 'HIDDEN': {
return field.response === undefined || field.response === null
? ''
: field.response;
}
default: {
var response =
field.response === undefined || field.response === null ? '' : field.response;
if (Array.isArray(response)) {
return response.join(', ');
}
return response;
}
}
}).flat();
sheet.appendRow([responseId, submittedAt, ...rowData]);
return ContentService.createTextOutput(JSON.stringify({result: "success"})).setMimeType(ContentService.MimeType.JSON);
}
Please click 'New Deployment'.
data:image/s3,"s3://crabby-images/f69a3/f69a330b62ce91b5a36946ff05da31f702a5e904" alt=""
Set the type to 'Web App' and choose 'Anyone' for who has access.
data:image/s3,"s3://crabby-images/0e22c/0e22c05e2fcb3fa754b8b882f7832b97f23be30b" alt=""
Please approve the access.
data:image/s3,"s3://crabby-images/65d9d/65d9dd799733975369b7434200c99bf005e72711" alt=""
Please copy the URL.
data:image/s3,"s3://crabby-images/1fa0f/1fa0f8c92cd90d259e43f25188ebd157577bd77e" alt=""
Please click the 'Webhook Management' button in the 'Integration' tab of Walla.
data:image/s3,"s3://crabby-images/33f3f/33f3f628baf0190acbb4e4784381378b61e6c176" alt=""
Please paste the URL and add the webhook.
data:image/s3,"s3://crabby-images/04c7f/04c7f368ee5f17c8e65b62a9cf46adb96f48c0fd" alt=""
After saving the changes, please activate it in the 'Webhook Settings'.
data:image/s3,"s3://crabby-images/fbb6d/fbb6de487b4e06b2abba5cbbef3c6efa7059c675" alt=""
When a response arrives, the response details will be recorded in the Google Sheet.
data:image/s3,"s3://crabby-images/a6522/a6522a6fe7f846d41ed8b69e6c1b1fabf1086ea4" alt=""