Esta página descreve como criar os componentes e a estrutura de um card. Os cards são interfaces de usuário que os apps do Google Chat podem usar para apresentar e coletar informações dos usuários do Chat. Os apps de chat podem criar e mostrar cards nas seguintes interfaces:
- Mensagens que contêm um ou mais cards.
- Páginas iniciais, que é um card que aparece na guia Início em mensagens diretas com o app Chat.
- Caixas de diálogo, que são cards que são abertos em uma nova janela de mensagens e páginas iniciais.
Nesta página, você vai aprender sobre os seguintes componentes de um card:
- Cabeçalhos, que geralmente contêm o título de um card ou de uma seção de card.
- Seções, que formam o corpo principal do card, incluindo widgets e outros elementos interativos. Em uma seção de cards, você pode adicionar mais estrutura ao card, incluindo colunas e grades.
- Rodapés fixos, que aparecem na parte de baixo das caixas de diálogo para mostrar elementos de interface persistentes, como botões.
Pré-requisitos
Um app do Google Chat com recursos interativos ativados. Para criar um app de chat interativo, conclua um dos guias de início rápido a seguir com base na arquitetura do app que você quer usar:
- Serviço HTTP com o Google Cloud Functions
- Google Apps Script
- Google Cloud Dialogflow CX
- Google Cloud Pub/Sub
Use o Card Builder para criar e visualizar interfaces do usuário e mensagens de apps de chat:
Abrir o criador de cardsAdicionar um cabeçalho
O widget CardHeader
representa o cabeçalho de um card. Os cabeçalhos podem incluir um
título, um subtítulo e uma imagem de avatar para o card.
Confira abaixo um exemplo de CardHeader
:
Adicionar uma ou mais seções de card
O widget CardSection
é um contêiner de alto nível em um card. Use as seções
de cards para agrupar widgets em um card. Para cada seção de card, é possível incluir
um cabeçalho e um ou mais widgets.
Confira abaixo um exemplo de CardSection
que contém dois widgets textParagraph
:
Adicionar um divisor horizontal entre widgets
O
widget divider
mostra uma linha horizontal que abrange a largura de um card
entre widgets empilhados verticalmente. A linha é um divisor visual que ajuda
os usuários a distinguir um widget de outro, facilitando a leitura
e a compreensão dos cards.
Confira a seguir um card que consiste no widget divider
entre outros tipos de
widgets:
Adicionar colunas
O
widget columns
mostra até duas colunas em um card. É possível adicionar widgets a cada coluna. Eles aparecem na ordem em que são especificados.
Para incluir mais de duas colunas ou usar linhas, use o widget grid
.
A altura de cada coluna é determinada pela coluna mais alta. Por exemplo, se a primeira coluna for mais alta que a segunda, ambas terão a altura da primeira. Como cada coluna pode conter um número diferente de widgets, não é possível definir linhas ou alinhar widgets entre as colunas.
O exemplo a seguir mostra um card com um widget columns
que tem
duas colunas de texto. Para conferir apenas o layout de colunas e recolher o exemplo
de código, clique em Recolher.
Quando o espaço é limitado, como no exemplo abaixo, a
segunda coluna é agrupada abaixo da primeira.
Definir a largura da coluna
As colunas são mostradas lado a lado. É possível personalizar a largura de cada coluna
usando o
campo horizontalSizeStyle
.
Se a largura da tela do usuário for muito estreita, a segunda coluna será exibida abaixo da
primeira:
- Na Web, a segunda coluna é recolhida se a largura da tela for menor ou igual a 480 pixels.
- Em dispositivos iOS, a segunda coluna é recolhida se a largura da tela for menor ou igual a 300 pt.
- Em dispositivos Android, a segunda coluna é recolhida se a largura da tela for menor ou igual a 320 dp.
O exemplo a seguir mostra um card com um widget columns
que tem
duas colunas de texto com quatro itens. Cada item nas colunas tem
horizontalSizeStyle
aplicado para manipular a quantidade de espaço que o texto
preenche em cada coluna:
- O primeiro parágrafo de texto usa
FILL_MINIMUM_SPACE
para preencher no máximo 30% da largura do card. - O segundo parágrafo de texto usa
FILL_AVAILABLE_SPACE
para preencher o espaço disponível na largura do card. Neste exemplo, ele preenche 70% da largura do card. - O terceiro parágrafo de texto não define
horizontalSizeStyle
, então ele é padrão para preencher o espaço disponível do card. - O quarto parágrafo de texto usa
FILL_MINIMUM_SPACE
para preencher no máximo 30% da largura do card.
Definir o alinhamento horizontal de uma coluna
É possível alinhar os widgets horizontalmente à esquerda, à direita ou ao centro de uma coluna definindo o
campo horizontalAligment
.
Se o campo horizontalAlignment
estiver indefinido, os widgets serão alinhados à
esquerda em uma coluna.
O exemplo a seguir alinha horizontalmente o texto em uma coluna à esquerda:
O exemplo a seguir alinha horizontalmente o texto em uma coluna no centro:
O exemplo a seguir alinha horizontalmente o texto em uma coluna à direita:
Definir o alinhamento vertical de uma coluna
É possível alinhar widgets verticalmente na parte de cima, de baixo ou no centro de uma coluna
definindo o
campo verticalAlignment
.
Se o campo verticalAlignment
não estiver definido, os widgets em uma coluna serão alinhados
à parte de cima.
O exemplo a seguir alinha verticalmente o texto em uma coluna para a parte de cima:
O exemplo a seguir alinha verticalmente o texto em uma coluna no centro:
O exemplo a seguir alinha verticalmente o texto em uma coluna na parte de baixo:
Adicionar uma grade para mostrar uma coleção de itens
O
widget grid
mostra uma grade com uma coleção de itens. Uma grade oferece suporte a qualquer número de
colunas e itens. O número de linhas é determinado pelos itens divididos por colunas.
Uma grade com 10 itens e 2 colunas tem 5 linhas. Uma grade com 11 itens e 2
colunas tem 6 linhas.
O widget oferece suporte a sugestões, que ajudam os usuários a inserir dados uniformes, e
ações de mudança, que são
Actions
e são executadas quando ocorre uma mudança no campo de entrada de texto, como um usuário que adiciona ou
remove texto.
O exemplo a seguir é uma grade de duas colunas com um único item:
Para definir onde o texto aparece com uma imagem em uma grade, especifique o
campo gridItemLayout
.
Esse campo permite definir se o texto aparece acima ou abaixo
do item na grade. Se gridItemLayout
não estiver definido, o texto vai aparecer
abaixo do item na grade.
O exemplo a seguir é uma grade de três colunas com texto e uma imagem em cada uma. A primeira grade define o texto que aparece acima da imagem, a segunda define o texto que aparece abaixo da imagem e a terceira não define a posição do texto.
Adicionar uma borda a uma grade ou coluna
Para itens que aparecem em um widget column
ou grid
, é possível adicionar uma borda a
esses elementos de IU definindo um
campo borderType
e um
campo borderStyle
.
Se nenhum campo borderStyle
for definido, o padrão será mostrar nenhuma borda. É possível
definir um borderType
para aplicar a todos os itens de um widget ou aplicar o estilo
a cada item individual em um widget.
O exemplo a seguir é uma grade de duas colunas com uma imagem em cada uma, em que o tipo, o estilo e a cor da borda foram definidos para serem aplicados a todos os itens na grade.
O exemplo a seguir é uma grade de três colunas com uma imagem em cada uma e o
estilo e o tipo de borda definidos individualmente. A primeira
imagem tem uma borda definida como STROKE
. A segunda imagem tem uma borda definida como
NO_BORDER
. A terceira imagem não tem borda definida.
Adicionar um rodapé permanente
O widget CardFixedFooter
representa o rodapé de uma mensagem de caixa de diálogo enviada por
um app de chat.
Os rodapés podem incluir um botão principal e um secundário.
O widget CardFixedFooter
só está disponível para
caixas de diálogo.
Confira a seguir um exemplo de widget CardFixedFooter
com dois botões:
Resolver problemas
Quando um app do Google Chat ou um card retorna um erro, a interface do Chat mostra uma mensagem informando que "Ocorreu um erro". ou "Não foi possível processar sua solicitação". Às vezes, a interface do Chat não mostra nenhuma mensagem de erro, mas o app ou o card do Chat produz um resultado inesperado. Por exemplo, uma mensagem de card pode não aparecer.
Embora uma mensagem de erro possa não aparecer na interface do Chat, mensagens de erro descritivas e dados de registro estão disponíveis para ajudar a corrigir erros quando o registro de erros para apps de chat estiver ativado. Para saber como visualizar, depurar e corrigir erros, consulte Resolver e corrigir erros do Google Chat.