DEV Community

Cover image for Enviando e-mails condicionais a partir do Google Forms
Bianca Pereira for Comunidade Cafeína

Posted on

Enviando e-mails condicionais a partir do Google Forms

Eu tenho um formulário no Google Forms e precisava enviar e-mails diferentes de acordo com a resposta do meu usuário.

Como não achei nenhum app pronto e gratuito, resolvi criar uma função bem simples em Javascript para resolver meu problema.

Nesse post, conto o passo a passo de como esse script foi feito.

1) Criando um formulário de testes

Primeiro, crie um formulário simples para usarmos como testes.

Formulário simples

Nesse formulário, estou simulando a inscrição para uma vaga de desenvolvimento web. Conforme a vaga que o usuário selecionar (frontend ou backend), ele vai receber um desafio diferente.

Eu selecionei a opção para coletar e-mails do usuário também.

2) Abrindo a planilha de respostas

A nossa integração não acontece diretamente no Google Forms, mas sim no Google Sheets. Podemos criar uma planilha para qualquer formulário.

Respostas do formulário

Para isso, clique em respostas do formulário e selecione o ícone do Google Sheets. Depois disso é só escolher a opção para criar uma planilha com suas respostas.

Planilha no Google Sheets

Feito isso, todas as respostas que chegarem no seu formulário, serão direcionadas para essa planilha.

3) Criando um script simples

Para criar um novo script, com a janela da planilha aberta clique em Extensões e depois em Apps Scripts.

Menu de extensões no Google Sheets

Será aberta uma nova janela com uma função já criada, onde iremos adicionar nosso script.

Apps Scripts

4) Criando nosso script

Vamos começar com uma informação importante: App Scripts utiliza Javascript para a criação de scripts.

Dito isso, podemos seguir adiante. Nomeei a função de checkResponses e atribui a variável respostas os valores que vamos receber do evento de submeter o formulário.

function checkResponses(e) {
  var respostas = e.namedValues;
}
Enter fullscreen mode Exit fullscreen mode

Para receber os valores conforme o nome da coluna, eu usei esse laço for que percorreu as respostas que recebemos do nosso form.

  var email = "";
  var vaga = "";

  for (Key in respostas) {
    if (Key == 'Que vaga você gostaria de se inscrever?') {
      vaga = respostas[Key];
    }

    if (Key == 'Endereço de e-mail') {
      email = respostas[Key];
    }
  }
Enter fullscreen mode Exit fullscreen mode

Antes de seguir para o próximo passo, salve seu script com um nome que desejar.

5) Ativando um acionador (trigger)

Agora, precisamos de um acionador que irá ativar nosso script toda vez que alguém enviar uma resposta para o nosso formulário.

Para isso, clique na barra lateral a opção Acionadores. Clique em adicionar um novo acionador e depois selecione a opção de evento Ao enviar o formulário e salve.

Opções do acionador

É necessário autorizar seu script para rodar corretamente. Para isso, volte no Editor clique no botão de Executar. Depois é só autorizar com sua conta do Google. Esse processo só é necessário ser feito uma vez por autorização.

Botão executar

Feito isso, toda vez que alguém enviar uma resposta no nosso formulário, a função checkResponses será ativada.

6) Logando valores recebidos e erros

Uma ferramenta muito importante para debuggar nosso código é o log de respostas. Como não podemos testar nossa função sem o acionador ser ativado, analisar os logs é a forma perfeita de encontrar erros no nosso script.

Para logar o email e a vaga que o usuário enviou através do form, adicione o código abaixo no fim do script.

  Logger.log(email);
  Logger.log(vaga);
Enter fullscreen mode Exit fullscreen mode

Para visualizar os logs, clique em Execuções na barra lateral.

Logs na aba Execuções

7) Enviando e-mails

Por fim, queremos enviar e-mails de acordo com a resposta que recebemos.

Para isso, iremos utilizar um método do Gmail que está prontinho para ser usado. A estrutura dele é bem simples: o primeiro parâmetro é o endereço que vai receber o e-mail, depois o assunto do e-mail e por fim o conteúdo do e-mail.

GmailApp.sendEmail(enderecoDestino, assuntoEmail, conteudoEmail);
Enter fullscreen mode Exit fullscreen mode

Para finalizar esse script, fiz esse if else para enviar os e-mails de acordo com a vaga selecionada pelo meu usuário.

Repita o processo de autorização da etapa 5 para autorizar seu script a enviar e-mails.

  if (vaga == "Frontend"){
    Logger.log("Frontend");
    GmailApp.sendEmail(email, "Vaga frontend", "Desafio frontend");
  }
  else {
    Logger.log("Backend");
    GmailApp.sendEmail(email, "Vaga backend", "Desafio backend");
  }
Enter fullscreen mode Exit fullscreen mode

Dica: para o código ficar mais organizado, você pode colocar o corpo do e-mail numa variável a parte usando Template strings.


E aí, o que acharam? Eu achei bem simples e repleto de possibilidades de uso.

Espero que tenha ajudado e qualquer dúvida é só chamar. 😊

Top comments (0)