Widgets

Um widget é um elemento da interface que oferece uma ou mais das seguintes opções:

  • Estrutura para outros widgets, como cards e seções,
  • Informações para o usuário, como texto e imagens, ou
  • Affordances para ação, como botões, campos de entrada de texto ou caixas de seleção.

Conjuntos de widgets adicionados às seções de cards definem a interface geral do complemento. Os widgets têm a mesma aparência e função em dispositivos da Web e móveis. A documentação de referência descreve vários métodos para criar conjuntos de widgets.

Os widgets complementares geralmente são categorizados em três grupos: estruturais, de informação e de interação com o usuário.

Widgets estruturais

Os widgets estruturais fornecem contêineres e organização para os outros widgets usados na interface.

  • Conjunto de botões: uma coleção de um ou mais botões de texto ou imagem agrupados em uma linha horizontal.
  • Card: um único card de contexto que contém uma ou mais seções de card. Você define como os usuários podem se mover entre cards configurando a navegação de cards.
  • Cabeçalho do card: o cabeçalho de um determinado card. Os cabeçalhos dos cards podem ter títulos, subtítulos e uma imagem. As ações do card e as ações universais aparecem no cabeçalho do card se o complemento as usar.
  • Seção do card: um grupo coletado de widgets, dividido das outras seções do card por uma regra horizontal e, opcionalmente, com um cabeçalho de seção. Cada cartão precisa ter pelo menos uma seção. Não é possível adicionar cards ou cabeçalhos de cards a uma seção de cards.

Widgets estruturais

Além desses widgets estruturais básicos, em um complemento do Google Workspace, você pode usar o serviço de cartão para criar estruturas que se sobrepõem ao cartão atual: rodapés fixos e cards de visualização:

É possível adicionar uma linha fixa de botões na parte de baixo do card. Essa linha não se move nem rola com o restante do conteúdo do card.

Exemplo de widget de rodapé fixo

O exemplo de código abaixo mostra como definir um exemplo de rodapé fixo e adicioná-lo a um card:

var fixedFooter = CardService.newFixedFooter()
    .setPrimaryButton(
        CardService.newTextButton()
            .setText("Primary")
            .setOpenLink(CardService.newOpenLink()
                .setUrl("https://www.google.com")))
    .setSecondaryButton(
        CardService.newTextButton()
            .setText("Secondary")
            .setOnClickAction(
                CardService.newAction()
                    .setFunctionName(
                        "secondaryCallback")));

var card = CardService.newCardBuilder()
    // (...)
    .setFixedFooter(fixedFooter)
    .build();

Exibir card

Exemplo de card de exibição

Quando um novo conteúdo contextual é acionado por uma ação do usuário, como abrir uma mensagem do Gmail, você pode mostrar o novo conteúdo contextual imediatamente (comportamento padrão) ou exibir uma notificação de card de visualização na parte de baixo da barra lateral. Se um usuário clicar em "Voltar" para retornar à página inicial enquanto um gatilho contextual estiver ativo, um card de visualização vai aparecer para ajudar os usuários a encontrar o conteúdo contextual novamente.

Para mostrar um card de visualização quando um novo conteúdo contextual estiver disponível, em vez de exibir o novo conteúdo contextual imediatamente, adicione .setDisplayStyle(CardService.DisplayStyle.PEEK) à sua classe CardBuilder. Um card de visualização só aparece se um único objeto de card for retornado com seu gatilho contextual. Caso contrário, os cards retornados vão substituir imediatamente o card atual.

Para personalizar o cabeçalho do card de visualização, adicione o método .setPeekCardHeader() com um objeto CardHeader padrão ao criar o card contextual. Por padrão, o cabeçalho de um card de visualização contém apenas o nome do seu complemento.

Exemplo de cartão de visualização personalizado

O código abaixo, baseado no Guia de início rápido do complemento Cats para o Google Workspace, notifica os usuários sobre novos conteúdos contextuais com um card Peek e personaliza o cabeçalho do card Peek para mostrar o assunto da conversa de mensagem do Gmail selecionada.

var peekHeader = CardService.newCardHeader()
    .setTitle('Contextual Cat')
    .setImageUrl('https://www.gstatic.com/images/
        icons/material/system/1x/pets_black_48dp.png')
    .setSubtitle(text);

. . .

var card = CardService.newCardBuilder()
    .setDisplayStyle(CardService.DisplayStyle.PEEK)
    .setPeekCardHeader(peekHeader);

Widgets informativos

Os widgets informativos apresentam informações ao usuário.

  • Imagem: uma imagem indicada por um URL hospedado e acessível publicamente fornecido por você.
  • DecoratedText: uma string de conteúdo de texto que pode ser combinada com outros elementos, como rótulos de texto superior e inferior e uma imagem ou ícone. Os widgets DecoratedText também podem incluir um widget Button ou Switch. Os interruptores adicionados podem ser alternados ou caixas de seleção. O texto do conteúdo do widget DecoratedText pode usar formatação HTML. Os rótulos de cima e de baixo precisam usar texto simples.
  • Parágrafo de texto: um parágrafo de texto que pode incluir elementos formatados em HTML.

Widgets informativos

Widgets de interação do usuário

Os widgets de interação do usuário permitem que o complemento responda a ações realizadas pelos usuários. É possível configurar esses widgets com respostas de ação para mostrar cards diferentes, abrir URLs, mostrar notificações, escrever e-mails de rascunho ou executar outras funções do Apps Script. Consulte o guia Como criar cards interativos para mais detalhes.

  • Ação do card: um item de menu colocado no menu da barra de cabeçalho do complemento. O menu da barra de cabeçalho também pode conter itens definidos como ações universais, que aparecem em todos os cards definidos pelo complemento.
  • Seletores de data/hora: widgets que permitem que os usuários selecionem uma data, hora ou ambos. Consulte Seletores de data e hora abaixo para mais informações.
  • Botão de imagem: um botão que usa uma imagem em vez de texto. Você pode usar um dos vários ícones predefinidos ou uma imagem hospedada publicamente indicada pelo URL.
  • Entrada de seleção: um campo de entrada que representa um conjunto de opções. Os widgets de entrada de seleção são apresentados como caixas de seleção, botões de opção ou menus suspensos.
  • Alternar: um widget de alternância. Só é possível usar as chaves em conjunto com um widget DecoratedText. Por padrão, elas aparecem como um botão de alternância, mas você pode fazer com que elas apareçam como uma caixa de seleção.
  • Botão de texto: um botão com um rótulo de texto. É possível especificar um preenchimento de cor de plano de fundo para botões de texto (o padrão é transparente). Você também pode desativar o botão conforme necessário.
  • Entrada de texto: um campo de entrada de texto. O widget pode ter texto de título, texto de sugestão e texto de várias linhas. O widget pode acionar ações quando o valor do texto muda.
  • Grade: um layout de várias colunas que representa uma coleção de itens. É possível representar itens com uma imagem, título, subtítulo e uma variedade de opções de personalização, como bordas e estilos de corte.
Widget de ação do card Widgets de interação do usuário

Caixas de seleção DecoratedText

É possível definir um widget DecoratedText com uma caixa de seleção anexada, em vez de um botão ou um interruptor binário. Assim como nos switches, o valor da caixa de seleção é incluído no objeto de evento de ação que é transmitido para o Action anexado a esse DecoratedText pelo método setOnClickAction(action).

Exemplo de widget de caixa de seleção com texto decorado

O trecho de código a seguir mostra como definir um widget de caixa de seleção DecoratedText, que pode ser adicionado a um card:

var decoratedText = CardService.newDecoratedText()
    // (...)
    .setSwitch(CardService.newSwitch()
        .setFieldName('form_input_switch_key')
        .setValue('switch_is_on')
        .setControlType(
            CardService.SwitchControlType.CHECK_BOX));

Seletores de data e hora

É possível definir widgets que permitem que os usuários selecionem uma hora, uma data ou ambos. É possível usar setOnChangeAction() para atribuir uma função de gerenciador de widgets para execução quando o valor do seletor mudar.

Exemplo de cartão de visualização personalizado

O trecho de código a seguir mostra como definir um seletor de data, um seletor de hora e um seletor de data e hora, que podem ser adicionados a um card:

var dateOnlyPicker = CardService.newDatePicker()
    .setTitle("Enter a date")
    .setFieldName("date_field")
    // Set default value as May 24 2019. Either a
    // number or string is acceptable.
    .setValueInMsSinceEpoch(1558668600000)
    .setOnChangeAction(CardService.newAction()
        .setFunctionName("handleDateChange"));

var timeOnlyPicker = CardService.newTimePicker()
    .setTitle("Enter a time")
    .setFieldName("time_field")
    // Set default value as 23:30.
    .setHours(23)
    .setMinutes(30)
    .setOnChangeAction(CardService.newAction()
        .setFunctionName("handleTimeChange"));

var dateTimePicker = CardService.newDateTimePicker()
    .setTitle("Enter a date and time")
    .setFieldName("date_time_field")
    // Set default value as May 24 2019 03:30 AM UTC.
    // Either a number or string is acceptable.
    .setValueInMsSinceEpoch(1558668600000)
    // EDT time is 4 hours behind UTC.
    .setTimeZoneOffsetInMins(-4 * 60)
    .setOnChangeAction(CardService.newAction()
        .setFunctionName("handleDateTimeChange"));

Confira a seguir um exemplo de função de gerenciador de widget de seletor de data e hora. Esse gerenciador formata e registra uma string que representa a data e a hora escolhidas pelo usuário em um widget de seletor de data e hora com o ID "myDateTimePickerWidgetID":

function handleDateTimeChange(event) {
  var dateTimeInput =
    event.commonEventObject.formInputs["myDateTimePickerWidgetID"];
  var msSinceEpoch = dateTimeInput.msSinceEpoch;
  var hasDate = dateTimeInput.hasDate;
  var hasTime = dateTimeInput.hadTime;

  // The following requires you to configure the add-on to read user locale
  // and timezone.
  // See https://developers.google.com/workspace/add-ons/how-tos/access-user-locale
  var userTimezoneId = event.userTimezone.id;

  // Format and log the date-time selected using the user's timezone.
  var formattedDateTime;
  if (hasDate && hasTime) {
    formattedDateTime = Utilities.formatDate(
      new Date(msSinceEpoch), userTimezoneId, "yyy/MM/dd hh:mm:ss");
  } else if (hasDate) {
    formattedDateTime = Utilities.formatDate(
      new Date(msSinceEpoch), userTimezoneId, "yyy/MM/dd")
      + ", Time unspecified";
  } else if (hasTime) {
    formattedDateTime = "Date unspecified, "
      + Utilities.formatDate(
          new Date(msSinceEpoch), userTimezoneId, "hh:mm a");
  }

  if (formattedDateTime) {
    console.log(formattedDateTime);
  }
}

 

A tabela a seguir mostra exemplos das interfaces de seleção do seletor em dispositivos móveis e computadores. Quando selecionado, o seletor de data abre uma interface de agenda mensal para permitir que o usuário selecione rapidamente uma nova data.

Quando o usuário seleciona o seletor de horário em dispositivos de área de trabalho, um menu suspenso é aberto com uma lista de horários separados em incrementos de 30 minutos que o usuário pode selecionar. O usuário também pode digitar um horário específico. Em dispositivos móveis, selecionar um seletor de horário abre o "relógio" integrado do dispositivo móvel.

Computador Dispositivo móvel
exemplo de seleção do seletor de data Exemplo de seleção do seletor de datas para dispositivos móveis
exemplo de seleção do seletor de horário Exemplo de seleção do seletor de horário para dispositivos móveis

Grade

Mostre itens em um layout de várias colunas com o widget de grade. Cada item pode mostrar uma imagem, um título e um subtítulo. Use outras opções de configuração para definir o posicionamento do texto em relação à imagem em um item de grade.

É possível configurar um item de grade com um identificador que é retornado como um parâmetro para a ação definida na grade.

Exemplo de widget de grade

var gridItem = CardService.newGridItem()
  .setIdentifier("item_001")
  .setTitle("Lucian R.")
  .setSubtitle("Chief Information Officer")
  .setImage(imageComponent);

var cropStyle = CardService.newImageCropStyle()
  .setImageCropType(CardService.ImageCropType.RECTANGLE_4_3);

var imageComponent = CardService.newImageComponent()
  .setImageUrl("https://developers.google.com/workspace/
      images/cymbal/people/person1.jpeg")
  .setCropStyle(cropStyle)

var grid = CardService.newGrid()
  .setTitle("Recently viewed")
  .addItem(gridItem)
  .setNumColumns(2)
  .setOnClickAction(CardService.newAction()
    .setFunctionName("handleGridItemClick"));

Formatação do texto

Alguns widgets baseados em texto podem oferecer suporte à formatação HTML de texto simples. Ao definir o conteúdo de texto desses widgets, basta incluir as tags HTML correspondentes.

As tags compatíveis e a finalidade delas são mostradas na tabela a seguir:

Formato Exemplo Resultado renderizado
Negrito "This is <b>bold</b>." Isso está em negrito.
Itálico "This is <i>italics</i>." Isso é itálico.
Sublinhado "This is <u>underline</u>." Isso é sublinhado.
Tachado "This is <s>strikethrough</s>." Isso é tachado.
Cor da fonte "This is <font color=\"#FF0000\">red font</font>." Esta é uma fonte vermelha.
Hiperlink "This is a <a href=\"https://www.google.com\">hyperlink</a>." Este é um hiperlink.
Tempo "This is a time format: <time>2023-02-16 15:00</time>." Este é um formato de hora: .
Nova linha "This is the first line. <br> This is a new line." Esta é a primeira linha.
Esta é uma nova linha.