I am just starting Google Forms. I need to email the form owner (myself and some others) a response as soon the the user submit the data. I need the data in the email which would include fields and their values that were submitted by the user as soon as they submit the form.
I am unable to use add-on as per my google account settings via my employer where add-on are blocked.
I am exploring app scripts but with little success as I am very new. As there some sample codes to help me get started with create a basic script to send email.
I have the following Code:
function sendFormByEmail(e) 
{    
  var email = "[email protected]"; 
  var s = SpreadsheetApp.getActiveSheet();
  var headers = s.getRange(1,1,1,s.getLastColumn()).getValues()[0];    
  var message = "";
  var subject = "New Hire: ";
  for(var i in headers) 
    message += headers[i] + ': '+ e.namedValues[headers[i]].toString() + "\n\n";     
  subject += e.namedValues[headers[2]].toString() + " - starts " + e.namedValues[headers[15]].toString();
  MailApp.sendEmail(email, subject, message); 
}
Then I added this script in the form trigger like so:
I tried submitting the form but nothings heppens. How do I know that the script ran or there was a problem?
If I try to run this in the script editor :
It gives me an error : TypeError: Cannot call method "getRange" of null. (line 7, file "Code")
Update
I tested the email functionality and it worked. So the problem has to be in Spread Sheet value retrieval.
function sendFormByEmail(e) 
{    
  var email = "[email protected]"; 
  MailApp.sendEmail(email, "Test", "Test"); 
}
I also created a excel file on my google drive that holds these response from google form
Final Solution
function testExcel() {
  var email = "[email protected]"; 
  var s = SpreadsheetApp.openById("GoogleDocsID");
  var sheet = s.getSheets()[0];
  var headers = sheet.getRange(1,1,1,sheet.getLastColumn()).getValues()[0]; 
  var datarow = sheet.getRange(sheet.getLastRow(),1,1,sheet.getLastColumn()).getValues()[0];
  var message = "";
  for(var i in headers)
  {
    message += "" + headers[i] + " : " + datarow[i] + "\n\n";
    //Logger.log(message);
  }
  MailApp.sendEmail(email, "Submitted Data Test", message); 
}


