Os gatilhos do Apps Script fazem com que uma função de script especificada (a função de gatilho) seja executada sempre que um evento especificado ocorre. Somente alguns eventos podem acionar gatilhos, e cada aplicativo do Google Workspace é compatível com um conjunto diferente de eventos.
Quando um gatilho é acionado, um objeto de evento é criado. Essa estrutura JSON contém detalhes sobre o evento que ocorreu. As informações na estrutura do objeto de evento são organizadas de maneira diferente com base no tipo de gatilho.
Depois que o objeto de evento é criado, o Apps Script o transmite como um parâmetro para a
função de acionamento. A função de gatilho é uma função de callback que você deve implementar para realizar as ações adequadas em resposta ao evento. Por exemplo, em um complemento do Editor, um gatilho
é usado para criar itens de menu do complemento quando um documento é aberto. Nesse caso, você
implementa uma função de acionamento onOpen(e) para criar os itens de menu que o complemento
precisa, possivelmente usando os dados no objeto de evento.
Nesta página, fornecemos diretrizes sobre como usar gatilhos em projetos de complementos do editor.
Tipos de acionadores do complemento do editor
Você pode usar a maioria dos tipos de acionadores genéricos disponíveis para projetos do Google Apps Script nos complementos do Editor, incluindo acionadores simples e a maioria dos acionadores instaláveis. O conjunto exato de tipos de acionadores disponíveis depende do aplicativo que está sendo estendido.
Ao contrário dos complementos do editor, os complementos do Google Workspace não podem usar gatilhos simples ou instaláveis genéricos do Apps Script. Em vez disso, eles usam acionadores projetados especificamente para complementos do Google Workspace. Para mais informações, consulte Acionadores de complementos do Google Workspace.
A tabela a seguir mostra os tipos de gatilhos simples e instaláveis que os complementos do editor podem usar e fornece links para os objetos de evento correspondentes:
| Evento | Objeto de evento | Gatilhos simples | Gatilhos instaláveis |
|---|---|---|---|
| Abrir Um arquivo do editor é aberto. |
Objeto de evento onOpen do Documentos Objeto de evento onOpen do Formulários Objeto de evento onOpen das Planilhas Objeto de evento onOpen das Apresentações |
Documentos
Formulários*
Planilhas
Apresentações
|
Documentos
Formulários
Planilhas
|
| Instalar O complemento é instalado. |
Objeto de evento onInstall |
Documentos
Formulários
Planilhas
Apresentações
|
|
| Editar O conteúdo da célula da planilha é alterado. |
Objeto de evento onEdit do Google Sheets |
Planilhas
|
Planilhas |
| Change O conteúdo de uma página é editado ou formatado. |
Objeto de evento onChange das Planilhas |
Planilhas |
|
| Form-submit Um formulário do Google é enviado. |
Objeto de evento form-submit do Formulários Objeto de evento form-submit do Planilhas |
Formulários
Planilhas
|
|
| Acionado por tempo (relógio) O gatilho é acionado em um horário ou intervalo especificado. |
Objeto de evento baseado em tempo |
Documentos
Formulários
Planilhas
Apresentações
|
* O evento de abertura dos Formulários Google não ocorre quando um usuário abre um formulário para responder, mas quando um editor abre o formulário para modificá-lo.
Acionadores simples em complementos
Os gatilhos simples usam um conjunto de nomes de funções reservadas, não podem usar serviços que exigem autorização e são ativados automaticamente para uso. Em alguns casos, um evento de acionamento simples pode ser processado por um acionador instalável.
Para adicionar um gatilho simples a um complemento, implemente uma função com um dos seguintes nomes reservados:
onOpené executado quando um usuário abre um documento, uma planilha ou uma apresentação.onOpentambém pode ser executado quando um formulário é aberto no editor (mas não ao responder ao formulário). Ele só é executado se o usuário tiver permissão para editar o arquivo em questão e é usado com mais frequência para criar itens de menu.onInstallé executado quando um usuário instala um complemento. Normalmente,onInstallé usado apenas para chamaronOpen. Isso garante que os menus de complementos apareçam imediatamente após a instalação sem exigir que o usuário atualize a página.onEdité executado quando um usuário muda o valor de uma célula em uma planilha. Esse gatilho não é acionado em resposta a movimentos de células, formatação ou outras mudanças que não alteram os valores das células.
Restrições
Os acionadores simples em complementos estão sujeitos às mesmas restrições que regem os acionadores simples em outros tipos de projetos do Apps Script. Preste atenção especial a estas restrições ao projetar complementos:
- Os acionadores simples não são executados se um arquivo for aberto no modo somente leitura (visualização ou comentário). Esse comportamento impede que os menus de complementos sejam preenchidos.
- Em determinadas circunstâncias, os complementos do Editor executam os acionadores simples
onOpeneonEditem um modo sem autorização. Esse modo apresenta complicações, conforme descrito no modelo de autorização de complemento. - Os acionadores simples não podem usar serviços nem realizar outras ações que exijam autorização, exceto conforme descrito no modelo de autorização de complemento.
- Os gatilhos simples não podem ser executados por mais de 30 segundos. Minimize a quantidade de processamento feito em uma função de acionador simples.
- Os acionadores simples estão sujeitos aos limites de cota dos acionadores do Apps Script.
Gatilhos instaláveis em complementos
Os complementos podem
criar e modificar acionadores instaláveis de maneira programática
com o serviço Script
do Apps Script. Os acionadores instaláveis de complementos não podem ser criados
manualmente. Ao contrário dos gatilhos simples, os gatilhos instaláveis podem usar serviços que
exigem autorização.
Os gatilhos instaláveis em complementos não enviam e-mails de erro para o usuário quando encontram erros, já que, na maioria dos casos, o usuário não consegue resolver o problema. Por isso, projete seu complemento para lidar com erros de maneira prática em nome do usuário sempre que possível.
Os complementos podem usar os seguintes gatilhos instaláveis:
- Os gatilhos instaláveis Open são executados quando um usuário abre um documento, uma planilha ou um formulário no editor (mas não ao responder ao formulário).
- Os gatilhos instaláveis são executados quando um usuário muda o valor de uma célula em uma planilha. Esse gatilho não é acionado em resposta a formatação ou outras mudanças que não alteram os valores das células.
- Os gatilhos instaláveis de mudança são executados quando um usuário faz qualquer alteração em uma planilha, incluindo edições de formatação e modificações na própria planilha (como adicionar uma linha).
Os acionadores instaláveis de envio de formulário são executados quando uma resposta do formulário do Google é enviada.
Há duas versões de acionadores de envio de formulário: uma para o Planilhas (onde as respostas são coletadas) e outra para o Google Formulários. O objeto de evento transmitido a uma função de acionamento de envio de formulário das Planilhas é mais simples e retorna os valores de resposta em matrizes simples. O objeto de evento transmitido a uma função de acionamento de envio de formulário do Google Forms fornece mais informações, contidas em um objeto
FormResponse.Acionadores baseados em tempo (também chamados de acionadores de relógio) são disparados em um horário específico ou repetidamente em um intervalo de tempo regular.
Autorizar acionadores instaláveis
Normalmente, se um desenvolvedor atualiza um complemento para usar novos serviços que exigem autorização adicional, os usuários são solicitados a autorizar novamente o complemento na próxima vez que o usarem.
No entanto, os complementos que usam acionadores enfrentam desafios especiais de autorização. Imagine um complemento que usa um gatilho para monitorar o envio de formulários: um criador de formulários pode autorizar o complemento na primeira vez que o usa e deixá-lo em execução por meses ou anos sem nunca mais abrir o formulário. Se o desenvolvedor do complemento atualizasse o complemento para usar novos serviços que exigem autorização adicional, o criador do formulário nunca veria a caixa de diálogo de reautorização porque nunca reabriu o formulário, e o complemento pararia de funcionar.
Ao contrário dos gatilhos em projetos regulares do Apps Script, os gatilhos em complementos continuam sendo acionados mesmo que precisem de nova autorização.
No entanto, o script ainda falha se atingir uma linha de código que exige
autorização que ele não tem. Para evitar isso, use
ScriptApp.getAuthorizationInfo
para restringir o acesso a partes do código que mudaram entre as versões do
complemento.
Os exemplos a seguir mostram a estrutura recomendada para usar em funções de acionamento e evitar problemas de autorização. A função de acionamento de exemplo responde a um evento de envio de formulário em um complemento do Google Planilhas e, se for necessária uma nova autorização, envia ao usuário do complemento um e-mail de alerta usando HTML com modelo.
Code.gs
authorizationemail.html
Restrições
Os acionadores instaláveis em complementos estão sujeitos às mesmas restrições que regem os acionadores instaláveis em outros tipos de projetos do Apps Script.
Além dessas restrições, várias outras se aplicam especificamente a acionadores instaláveis em complementos:
- Cada complemento pode ter apenas um gatilho de cada tipo por usuário e por documento. Por exemplo, em uma determinada planilha, um usuário só pode ter um gatilho de edição, embora também possa ter um gatilho de envio de formulário ou um gatilho acionado por tempo na mesma planilha. Um usuário diferente com acesso à mesma planilha pode ter um conjunto separado de acionadores.
- Os complementos só podem criar gatilhos para o arquivo em que são usados. Ou seja, um complemento usado no Documento Google A não pode criar um gatilho para monitorar quando o Documento Google B é aberto.
- Os gatilhos baseados em tempo não podem ser executados com mais frequência do que uma vez por hora.
- Os complementos não enviam um e-mail automaticamente ao usuário quando o código executado por um gatilho instalável gera uma exceção. É responsabilidade do desenvolvedor verificar e processar casos de falha.
- Os acionadores de complementos param de ser disparados em qualquer uma das seguintes situações:
- Se o usuário desinstalar o complemento,
- Se o complemento estiver desativado em um documento (se ele for reativado, o gatilho voltará a funcionar) ou
- Se o desenvolvedor cancelar a publicação do complemento ou enviar uma versão corrompida para a loja de complementos.
- As funções de acionamento de complementos são executadas até atingirem um código que usa um serviço não autorizado, momento em que são interrompidas. Isso só é verdade se o complemento for publicado. O mesmo gatilho em um projeto normal do Apps Script ou em um complemento não publicado não será executado se qualquer parte do script precisar de autorização.
- Os gatilhos instaláveis estão sujeitos aos limites de cota dos gatilhos do Apps Script.
Documentos
Formulários*
Planilhas
Apresentações