This video tutorial explains how you can send form data from Google Docs in an email message using the very useful Send Mail function of Google Docs.
Whether you are looking to add a basic “Contact Me” form to your website or need to create a complex online poll with conditional branching, Google Docs is an excellent tool for you. It offers a variety of themes, data can be easily exported and, unlike other polling software, your Google Docs forms can accept any number of responses without the fee.
There’s one limitation though. Google Docs can send email notifications as soon as people submit your online form but, as shown in the above screenshot, there’s no form data included in that email message. You’ll have to open the corresponding Google Docs spreadsheet to see that actual form data which is not always a very convenient option.
From Google Docs Form to your Email Inbox
Should you wish to receive Google Docs form data in an email message as soon as a user submits the form, there’s an easy workaround as explained in the following video.
The trick is that you associate a send mail routine with your Google Docs form that triggers as soon as a “form submit” action happens. And this routine, written using Google Apps Script, does all the magic – it reads the form values that were just submitted and sends them all in one message to a pre-defined address.
Here’s how you can add email capabilities to your Google Forms step by step:
- Create a new form in Google Docs (or use any of your existing forms) and switch to the Spreadsheet view.
- Go to Tools –> Script Editor and copy-paste the following code in that code editor window. Replace the value of variable “email” with your own email address.
- Next go to Triggers –> Current Script’s Triggers and associate the Send Mail function with “On Form Submit” event.
- Save the Google script, authorize Google Docs to access your Gmail account (for sending email) and you’re done.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | function sendFormByEmail(e) { // Remember to replace XYZ with your own email address var email = "XYZ" ; // Optional but change the following variable // to have a custom subject for Google Docs emails var subject = "Google Docs Form Submitted" ; // The variable e holds all the form values in an array. // Loop through the array and append values to the body. var message = "" ; for ( var field in e.namedValues) { message += field + ' :: ' + e.namedValues[field].toString() + "\n\n" ; } // This is the MailApp service of Google Apps Script // that sends the email. You can also use GmailApp here. MailApp.sendEmail(email, subject, message); // Watch the following video for details // http://youtu.be/z6klwUxRwQI // By Amit Agarwal - www.labnol.org } |
Advanced users can further customize the script to have custom email subject lines that match one of the form fields. Alternatively, you can specify the form submitter’s email address as the replyto address and thus you can directly respond to the user by replying to that email notification.
0 comments:
Post a Comment