data:image/s3,"s3://crabby-images/ff245/ff2452daf000eae1ea8ed47337e81e8a36d3523d" alt="When a form is submitted on Google Forms, a GAS script calls Kintone’s REST API to add data into Kintone’s database. Screenshot of the integration image between Google Forms and Kintone."
Introduction
This article introduces how to capture Google Form responses into a Kintone Database, instead of capturing them in a spreadsheet.
Google Forms allows end users to easily create and send questionnaires and event invitations, and store results into a spreadsheet. There are many advantages though of capturing the form responses into Kintone's databases (a.k.a. Kintone Apps) instead:
- Access controls for responses can be set
Kintone allows end users to set granular access controls to the data in its Apps. For example, access controls can be set so that only members of the HR department will be able to view the submitted email addresses.
data:image/s3,"s3://crabby-images/542f3/542f348113ea2309e61aac9aeb6aebb690904c45" alt="Data inside particular fields can be hidden from other team members. GIF of how the access controls can hide sensitive information such as email addresses from other Kintone users."
- Business Process Management for each response can be defined
Workflows can be set for each record in the Kintone App, which makes actions that need to take place after receiving responses become clearer. For example, after receiving a Google Forms response into Kintone, the record can be assigned to a Design team member to work on creating creatives related to the response data.
data:image/s3,"s3://crabby-images/d3f70/d3f701b7f61409d19509fdf38b436ca99be12cef" alt="After a submission is recorded into Kintone, the business process management feature can be used to assign task to other users. GIF of proceeding the status so that a user is assigned a task."
- Communication with team members becomes simple
Each record inside the Kintone App has a feature for posting comments for other team members to read. For example, after receiving a Google Forms response, an Events team member can write a comment in the record, to reach out to a Sales team member who may have some connection with the submitter of the form.
data:image/s3,"s3://crabby-images/65520/655202d82e1accbc81f27472a28f8bb8e61f1923" alt="Users can communicate around the data that has been submitted. GIF of a user posting a comment to a user, so that they will be notified and be able to read the details of the submission."
In this article, we will go through the following 4 steps to complete the integration:
- Preparing a Google Form
- Preparing a Kintone App
- Creating a Google Apps Script program
- Testing the integration
This section goes through the steps on how to build an event invitation form using Google Forms.
Step 1
A Google account will be needed for this step.
Log in to your Google account, select Google Forms from the Google app icon (or directly login from https://docs.google.com/forms/), and create a new blank form.
data:image/s3,"s3://crabby-images/11dfe/11dfe5a8077203f9101057b7005a8c7f411037ab" alt="Click on the blank template to start a new form. Screenshot of the Google Forms home page after logging in."
Step 2
Enter the title and description of your form.
data:image/s3,"s3://crabby-images/f8a46/f8a46a40cca01302468de6ecc6d85a9acc404d20" alt="Enter in the title and description of the new form. Screenshot of a new form where the title and description are entered in."
Step 3
Click the Settings icon, check "Collect email address", uncheck all boxes under "Requires sign in", and save the changes.
data:image/s3,"s3://crabby-images/b430e/b430e7a2a7e9d8a5dcc7e1411a91f65bd2ce96e2" alt="Check the option to collect email addresses. Screenshot of the option in Google Forms to collect email addresses from the form submitters."
Step 4
Set up the contents of the event invitation form by clicking on the "Add Question" icon, and selecting a question type, such as "Multiple choice". Enter your question in the question field, and the response options.
data:image/s3,"s3://crabby-images/56bcd/56bcd7a40709a56abf68c69997274b80f219cba2" alt="Select how you want the questions to be answered by selecting from the various question types. Screenshot of placing various question types into the Google form."
Select "Required" as below if the question is mandatory.
data:image/s3,"s3://crabby-images/8c751/8c75136870312cb71df9d08eb8060440b81d04a8" alt="Set certain questions to be required to be answered Screenshot of making certain questions mandatory in Google Forms."
Step 5
Repeat the process until the event invitation form is completed.
data:image/s3,"s3://crabby-images/1377b/1377bc1aef010341fa932e8686e9f4eb9dc6e670" alt="Add in more questions into the form. Screenshot of adding in more questions in to Google Forms."
As an example, these are the form details used in the sample event invitation form:
Question Type | Question | Options |
Multiple choice | Would you like to participate in this event? | Yes
No
Maybe |
Short answer | The number of participants | |
Long answer | Please enter the names of the participants | |
Google Forms will save every change you make. Finish off your form, and move on to the next step – Preparing a Kintone App.
2. Preparing a Kintone App
This section goes through how to set up a Kintone App instance within your Kintone environment, which will capture the Google Form responses. If you don’t have a Kintone environment, you can apply for a free 1 year Kintone developer license, by joining the Kintone Developer Program.
Step 1
Log in to your Kintone environment, navigate to the portal and create a new Kintone App by clicking the [+] button in the Apps widget. Select “Create an App from Scratch”, and set out the Kintone form with fields similar to the ones placed in your Google Form.
data:image/s3,"s3://crabby-images/df97f/df97f83bab3b557987398e4f401c1f2402f7217d" alt="Drag and drop a field and click on the cog wheel to edit the settings of the field. GIF of placing in a field within a Kintone App and editing the settings."
As reference, this is the Kintone App form layout and settings used in this article.
data:image/s3,"s3://crabby-images/a6b0c/a6b0cd5473cef83b86769c126a576f42dd1009d4" alt="Drag and drop the necessary fields into the Kintone App to match the Google Forms invitation. Screenshot of fields placed into the Kintone App similar to the questions placed into the Google Forms invitation."
Field Type | Field Name | Field Code | Other Settings |
Link | Email | Email | Type: E-mail address |
Radio Button | Would you like to participate in this event? | attend | Options:
Yes
No
Maybe |
Number | The number of participants | number_of_participants | - |
Text Area | The names of the participants | names_of_participants | - |
Click on Save, once the fields in the form have been laid out.
Step 2
Click on the Apps settings tab, and click on "API Token".
data:image/s3,"s3://crabby-images/4f8cd/4f8cd38dd168c1fd70d6fcc5e1978f926b1e0b03" alt="Click on the API Token option in the Kintone App settings. Screenshot of showing where the API Token option is inside the Kintone App settings."
Generate a new API Token for the App, check the "Add records" check-box, and save the settings.
data:image/s3,"s3://crabby-images/e8553/e85539067b53ed2b88e5e6c44113fd0ac604d744" alt="Generate a new API Token and check the Add records permission. Screenshot of generating a new API Token for the Kintone App and selecting the Add records permission."
Click on "Update App" to apply the updates made to your App
3. Create a Google Apps Script Program
This section goes through how to set up a Google Apps Script program to run after a Google Forms submission has been made, so that the responses will be recorded into the Kintone App.
Step 1
Reopen the Google form created in the previous steps and click "Script editor" from the "Other" menu.
data:image/s3,"s3://crabby-images/ee5fe/ee5fec2c30a06d46f377022553f94fb2c5abece1" alt="Select Script editor from the menu in the Event invitation form created in Google Forms. Screenshot of selecting the Script editor option for the Event Invitation form created in Google Forms."
Enter a project name and a file name.
data:image/s3,"s3://crabby-images/4cad5/4cad5e1c995c7275fb55d86f22cae43a1f8ab6e2" alt="Enter in the project name and file name into the Google script editor. Screenshot of entering a Project name and File name into the Google script editor."
Step 2
In this article, we will use the following library: https://github.com/Arahabica/KintoneManager
Copy the Project Key from the link above. On Google Forms, select "Resources" and then "Libraries".
data:image/s3,"s3://crabby-images/e99a3/e99a3a99653da8e94681d33a6db43a9144d2d95c" alt="Click on resources, and then on Libraries. Screenshot of selecting a library to use with the Google script editor."
Paste the project key into the "Add a Library" field. Click "Add" to add the library, select the latest version, and save the settings.
data:image/s3,"s3://crabby-images/2fac8/2fac88b13d49658a58981c92f1d5e4656d4439ca" alt="Paste in the project key of the library, and select the version of the library. Screenshot of adding in the project key of the library and selecting the version of the library."
Step 3
Copy the following code in to your Google Apps Script.
The strings "Email
", "attend
", "number_of_participants
" and "names_of_participants
" that are listed in the code refer to the field codes of the fields in the Kintone App. Make sure that these strings match the field code of the fields in your App form.
Update the code so that the values of the keys "subdomain
", "appid
" and "token
" correspond to your Kintone Environment and Kintone App (navigate to the App via the browser to find the App ID as an integer inside the URL).
function getFormResponse(e) {
'use strict';
var itemResponses = e.response.getItemResponses();
var records = '[';
records += Utilities.formatString('{"Email": { "value": "%s" }', e.response.getRespondentEmail());
for (var i = 0; i < itemResponses.length; i++) {
var itemResponse = itemResponses[i];
switch (itemResponse.getItem().getTitle()) {
case 'Would you like to participate in this event?':
records += Utilities.formatString(',"attend" : { "value": "%s" }',
itemResponse.getResponse());
break;
case 'The number of participants':
records += Utilities.formatString(',"number_of_participants" : { "value": "%s" }',
itemResponse.getResponse());
break;
case 'Please enter the names of the participants':
records += Utilities.formatString(',"names_of_participants" : { "value": "%s" }',
itemResponse.getResponse());
break;
}
}
records += '}]';
Logger.log('Response JSON is "%s"', records);
return records;
}
function sendToKintone(e) {
'use strict';
Logger.log('Form submitted');
var subdomain = '{subdomain}.kintone.com'; // change URL to your kintone domain
var apps = {
YOUR_APPLICATION1: { appid: 1, name: 'Kintone Connect', token: 'xxxxxxxxx' }
};
var manager = new KintoneManager.KintoneManager(subdomain, apps);// Initialize library
var str = getFormResponse(e);
str = str.replace(/\n/g, "\\n").replace(/\r/g, "\\r").replace(/\t/g, "\\t");
var records = JSON.parse(str);// Convert to JSON
var response = manager.create('YOUR_APPLICATION1', records); //Create a record in kintone
// Status code 200 will return for successful requests
var code = response.getResponseCode();
Logger.log('Response code is "%s"', code);
}
Once finished, save your code.
Code Explanation: Sending data to Kintone
The e.response.getItemResponses()
function retrieves the submitted form data:
function getFormResponse(e) {
var itemResponses = e.response.getItemResponses();
// ***
// ***
}
The e.reponse.getRespondentEmail()
function is used to get the email address of the form submitter, and the request data for Kintone is created:
var records = '[';
records += Utilities.formatString('{"Email": { "value": "%s" }', e.response.getRespondentEmail());
for (var i = 0; i < itemResponses.length; i++) {
var itemResponse = itemResponses[i];
switch (itemResponse.getItem().getTitle()) {
case 'Would you like to participate in this event?':
records += Utilities.formatString(',"attend" : { "value": "%s" }',
itemResponse.getResponse());
break;
case 'The number of participants':
records += Utilities.formatString(',"number_of_participants" : { "value": "%s" }',
itemResponse.getResponse());
break;
case 'Please enter the names of the participants':
records += Utilities.formatString(',"names_of_participants" : { "value": "%s" }',
itemResponse.getResponse());
break;
}
}
records += '}]';
Code Explanation: Sending data to Kintone
The information of the Kintone App created above is set with the following:
function sendToKintone(e) {
var subdomain = '{subdomain}.kintone.com'; // change URL to your kintone domain
var apps = {
YOUR_APPLICATION1: { appid: 1, name: 'Kintone Connect', token: 'xxxxxxxxx' }
};
// ***
// ***
}
The imported library is initialized, the request data is JSON formatted, and is then sent to Kintone:
var manager = new KintoneManagerUs(subdomain, apps);// Initialize library
var str = getFormResponse(e);
str = str.replace(/\n/g, "\\n").replace(/\r/g, "\\r").replace(/\t/g, "\\t");
var records = JSON.parse(str);// Convert to JSON
var response = manager.create('YOUR_APPLICATION1', records); //Create a record in kintone
The data post to Kintone succeeds if the response code is "200".
var code = response.getResponseCode();
Step 4
Select "Current project’s triggers" from the Edit menu and select a function to run when a form submission is made on the Google Form. Click Save when done.
data:image/s3,"s3://crabby-images/195b1/195b1a55b546a1bf7960ec8d37a29fb1b4fd9c49" alt="Select Current project’s triggers in the Google Script editor. Screenshot of selecting the Current project’s triggers in the Google Script editor."
data:image/s3,"s3://crabby-images/114f8/114f86c9290ad9101fb38e4b4674c4925cb47b1d" alt="Select the options that will trigger the code when the Event invitation form is submitted. Screenshot of selecting what action will trigger the code to run in the Google Script editor."
The set up for Google Apps Script is now complete.
4. Testing the integration
This section goes through how to test the newly set up integration.
Click the Send button in the upper right corner of the Google form you created, fill out the Send form and click the Send button.
data:image/s3,"s3://crabby-images/7558f/7558f53206f3ade3837a0297f795b2e739785254" alt="Enter in the emails of the recipients of the Event invitation form. Screenshot of sending out the Event invitation form to recipients via Google Forms."
Recipients will receive links to the Google Form.
data:image/s3,"s3://crabby-images/95ce5/95ce558ce4947d80065e40ea6f7f4933b5c8c858" alt="Enter in details into the Event invitation form and click on Submit. Screenshot of filling out the Event invitation form."
Once the form is submitted, the response data should be added to your Kintone App.
data:image/s3,"s3://crabby-images/e2d31/e2d3135cd8b2119ce00066288ab84589dccc6d2e" alt="Check that the data entered into the Event invitation have successfully been posted into the record of the Kintone App. Screenshot of a record inside a Kintone App with the details that were entered in to the Event invitation form of Google Forms."
5. Summary
Using Google form enables you to easily create forms for questionnaires and event invidations, and send them to recipients via email, as well as embedding them on your company website. By managing the responses inside Kintone, you can utilize Kintone’s features to set access controls, define business process management and easily leave notes for other team members for each response.
For more details on how to use Kintone's databases and its APIs, try out the 5-minute Kintone API tutorial from the link below. The tutorial also provides you with a free Kintone developer environment. Enjoy!
data:image/s3,"s3://crabby-images/c6cb7/c6cb76a1479b4f8c239a0070a881bb6126f2c664" alt="Get your free Kintone developer environment! A link to start a 5-minute Kintone API Tutorial on the Kintone Developer Program website."