构建 Google Chat 界面

本页面概述了如何为扩展 Google Chat 的 Google Workspace 插件构建界面 (UI)。

如需为 Chat 应用构建界面,您可以使用以下插件组件:

  • 触发器:Google Chat 用户调用 Chat 应用的方式,例如将其添加到聊天室或向其发送消息。
  • 事件对象:Chat 应用从触发器或界面互动接收的数据。
  • 操作:Chat 应用响应互动的方式,例如发送消息或返回基于卡片的界面。
Chat 应用从“已添加到聊天室”触发器接收事件对象
图 1:当用户将 Chat 应用添加到聊天室时,添加到聊天室触发器会触发并发送事件对象。如需使用消息进行回复,Chat 应用会处理事件对象并返回一个用于创建消息的操作。

聊天应用可以在以下界面中构建和显示卡片:

  • 可以包含文字、静态或互动卡片以及按钮的消息
  • 对话框:在新窗口中打开的卡片,通常会提示用户提交信息。
  • 链接预览,即用于预览外部服务相关信息的卡片。

触发器

本部分介绍 Google Workspace 加载项在 Chat 中使用的触发器。

触发器是指用户通过 Chat 界面调用 Chat 应用的具体方式,例如使用 @提及或应用命令。

下表显示了 Chat 触发器、说明以及 Chat 应用通常如何响应:

触发器 说明 典型回答
已添加到聊天室

用户将 Chat 应用添加到聊天室,或者 Google Workspace 管理员为组织中的用户在私信聊天室中安装 Chat 应用。如需了解管理员安装的聊天应用,请参阅 Google Workspace 管理员帮助文档中的在您的网域中安装 Marketplace 中的应用

Chat 应用会发送一条引导消息,说明其用途以及聊天室中的用户如何与其互动。
短信

用户可以通过以下任一方式在消息中与 Chat 应用互动:

  • 在私信 (DM) 聊天室中使用 Chat 应用发送消息。
  • 在任何类型的聊天室中 @提及 Chat 应用。
  • 发送包含与链接预览的网址格式匹配的链接的消息。
  • selectionInput widget 的多选菜单中输入文本。
聊天应用会根据消息内容做出回答。例如,聊天应用会回复斜杠命令 /about,并发送一条消息来解释该聊天应用可以执行的任务。
已从聊天室中移除

用户从聊天室中移除 Chat 应用,或者 Google Workspace 管理员为其组织中的用户卸载 Chat 应用。

用户无法移除由管理员安装的 Chat 扩展应用。如果用户之前已安装 Chat 应用,则无论 Google Workspace 管理员是否尝试卸载,Chat 应用都会保持已安装状态。

Chat 应用会移除为聊天室配置的所有入站通知(例如删除 Webhook),并清理所有内部存储空间。聊天应用无法通过消息响应此触发器,因为它们不再是相应聊天室的成员。
应用命令

用户使用 Chat 应用命令

聊天应用会响应该指令。例如,回复包含消息或打开对话框。

与其他 Google Workspace 插件不同,您必须使用 Google Chat API 为这些触发器配置任何回调函数。如需获取指导,请参阅配置 Google Chat 应用

如需响应触发器,请参阅以下指南:

事件对象

当 Chat 触发器触发时,或者当 Chat 用户与 Chat 应用中的界面(例如点击按钮)互动时,Chat 应用会收到事件对象。事件对象包含有关互动的数据,Chat 应用可以使用这些数据来做出响应或更新界面。

如需了解如何处理事件对象,请参阅以下指南:

如需了解 Chat 和其他 Google Workspace 应用中的插件事件对象,请参阅事件对象

聊天操作

本部分将介绍 Chat 应用如何使用插件操作来响应用户互动。

如需通过插件操作进行响应,Chat 应用必须在 30 秒内做出响应,并且响应必须发布在发生互动的对话空间中。否则,Chat 应用必须设置身份验证并调用 Google Chat API 才能做出响应。

聊天应用可以通过多种方式处理互动并做出回应。 在许多情况下,Chat 应用会回复一条消息。 聊天应用还可以从数据源中查找某些信息、记录事件对象信息,或者执行其他任何操作。 这种处理行为从本质上定义了 Google Chat 应用。

为了响应用户互动,Chat 应用必须处理相应的事件对象,并返回以下 JSON 对象之一:

聊天应用回复 退货所需操作
发送或更新消息 DataActions
打开、更新或关闭对话框 RenderActions
为了从卡片或对话框中收集信息,根据用户在多选菜单中输入的内容建议选择项。 RenderActions
Chat 用户在聊天室中发送的消息中的链接预览 DataActions

使用 Google Chat API 进行回复

Chat 应用可能需要使用 Google Chat API 来响应互动,而不是返回加购项操作。例如,Chat 应用必须调用 Google Chat API 才能执行以下任何操作:

  • 在 30 秒后响应互动。
  • 在互动发生的聊天室之外执行任务。
  • 在 Chat 中执行无法作为插件操作执行的任务。例如,列出用户或 Chat 应用所属的聊天室,或将用户添加到聊天室。
  • 代表 Chat 用户执行任务(需要用户身份验证)。

如需了解如何对 Chat API 进行身份验证和调用,请参阅 Chat API 概览