Auf dieser Seite wird beschrieben, wie Sie Karten Widgets und UI-Elemente hinzufügen, damit Nutzer mit Ihrer Google Chat-App interagieren können, z. B. durch Klicken auf eine Schaltfläche oder Einreichen von Informationen.
Chat-Apps können die folgenden Chatoberflächen verwenden, um interaktive Karten zu erstellen:
- Nachrichten, die eine oder mehrere Karten enthalten.
- Startseiten: Eine Karte, die auf dem Tab Startseite in Direktnachrichten in der Chat App angezeigt wird.
- Dialogfelder: Das sind Karten, die in Nachrichten und auf Startseiten in einem neuen Fenster geöffnet werden.
Wenn Nutzer mit Karten interagieren, können Chat-Apps die empfangenen Daten verwenden, um sie zu verarbeiten und entsprechend zu reagieren. Weitere Informationen finden Sie unter Informationen von Google Chat-Nutzern erheben und verarbeiten.
Mit dem Card Builder können Sie Nachrichten und Benutzeroberflächen für Chat-Apps entwerfen und in der Vorschau ansehen:
Karten-Tool öffnenVorbereitung
Eine Google Chat-App, für die interaktive Funktionen aktiviert sind. Wenn Sie eine interaktive Chat-App erstellen möchten, führen Sie einen der folgenden Schnellstarts aus, der auf der gewünschten App-Architektur basiert:
- HTTP-Dienst mit Google Cloud Functions
- Google Apps Script
- Google Cloud Dialogflow CX
- Cloud Pub/Sub
Schaltfläche hinzufügen
Im ButtonList
-Widget werden mehrere Schaltflächen angezeigt. Schaltflächen können Text, ein Symbol oder sowohl Text als auch ein Symbol enthalten. Jede Button
unterstützt eine OnClick
-Aktion, die ausgeführt wird, wenn Nutzer auf die Schaltfläche klicken. Beispiel:
- Öffnen Sie einen Hyperlink mit
OpenLink
, um Nutzern zusätzliche Informationen zur Verfügung zu stellen. - Führen Sie einen
action
aus, mit dem eine benutzerdefinierte Funktion ausgeführt wird, z. B. ein API-Aufruf.
Aus Gründen der Barrierefreiheit unterstützen Schaltflächen alternativen Text.
Schaltfläche hinzufügen, die eine benutzerdefinierte Funktion ausführt
Im Folgenden sehen Sie eine Karte mit einem ButtonList
-Widget mit zwei Schaltflächen.
Über eine Schaltfläche wird die Google Chat-Entwicklerdokumentation in einem neuen Tab geöffnet. Die andere Schaltfläche führt eine benutzerdefinierte Funktion namens goToView()
aus und übergibt den Parameter viewType="BIRD EYE VIEW"
.
Schaltfläche im Material Design-Stil hinzufügen
Im Folgenden sind mehrere Schaltflächen in verschiedenen Material Design-Schaltflächenstilen zu sehen.
Wenn Sie den Material Design-Stil anwenden möchten, geben Sie das Attribut „color“ nicht an.
Schaltfläche mit benutzerdefinierter Farbe und deaktivierte Schaltfläche hinzufügen
Sie können verhindern, dass Nutzer auf eine Schaltfläche klicken, indem Sie "disabled": "true"
festlegen.
Im Folgenden sehen Sie eine Karte mit einem ButtonList
-Widget mit zwei Schaltflächen. Bei einer Schaltfläche wird das Feld Color
verwendet, um die Hintergrundfarbe der Schaltfläche anzupassen. Die andere Schaltfläche wird mit dem Feld Disabled
deaktiviert, sodass der Nutzer nicht auf die Schaltfläche klicken und die Funktion ausführen kann.
Schaltfläche mit Symbol hinzufügen
Im Folgenden sehen Sie eine Karte mit einem ButtonList
-Widget mit zwei Symbol-Button
-Widgets. Auf einer Schaltfläche wird das integrierte E-Mail-Symbol von Google Chat mit dem Feld knownIcon
angezeigt. Bei der anderen Schaltfläche wird das Feld iconUrl
verwendet, um ein benutzerdefiniertes Symbol-Widget anzuzeigen.
Schaltfläche mit Symbol und Text hinzufügen
Im Folgenden sehen Sie eine Karte mit einem ButtonList
-Widget, über das der Nutzer aufgefordert wird, eine E-Mail zu senden. Die erste Schaltfläche zeigt ein E-Mail-Symbol und die zweite Schaltfläche Text an. Der Nutzer kann entweder auf das Symbol oder auf die Textschaltfläche klicken, um die Funktion sendEmail
auszuführen.
Schaltfläche für einen minimierbaren Bereich anpassen
Passen Sie die Schaltfläche an, mit der Bereiche innerhalb einer Karte minimiert und maximiert werden. Wählen Sie aus einer Reihe von Symbolen oder Bildern, um die Inhalte des Abschnitts visuell darzustellen. So können Nutzer die Informationen leichter verstehen und mit ihnen interagieren.
Dreipunkt-Menü hinzufügen
Das Dreipunkt-Menü Overflow menu
kann in Google Chat-Karten verwendet werden, um zusätzliche Optionen und Aktionen anzubieten. So können Sie mehr Optionen einbinden, ohne die Benutzeroberfläche der Karte zu überladen. Das sorgt für ein sauberes und übersichtliches Design.
Chipsliste hinzufügen
Das Widget ChipList
bietet eine vielseitige und visuell ansprechende Möglichkeit, Informationen darzustellen.
Verwenden Sie Chiplisten, um Tags, Kategorien oder andere relevante Daten darzustellen. So können Nutzer sich leichter in Ihren Inhalten zurechtfinden und mit ihnen interagieren.
Informationen von Nutzern erheben
In diesem Abschnitt wird erläutert, wie Sie Widgets hinzufügen, mit denen Informationen wie Text oder Auswahlen erfasst werden.
Informationen zum Verarbeiten von Nutzereingaben finden Sie unter Informationen von Google Chat-Nutzern erheben und verarbeiten.
Text erfassen
Das TextInput
-Widget bietet ein Feld, in das Nutzer Text eingeben können. Das Widget unterstützt Vorschläge, die Nutzern helfen, einheitliche Daten einzugeben, und Änderungsaktionen,Actions
die ausgeführt werden, wenn sich das Textfeld ändert, z. B. wenn ein Nutzer Text hinzufügt oder löscht.
Wenn Sie abstrakte oder unbekannte Daten von Nutzern erheben möchten, verwenden Sie dieses TextInput
-Widget. Wenn Sie definierte Daten von Nutzern erheben möchten, verwenden Sie stattdessen das SelectionInput
-Widget.
Hier sehen Sie eine Karte mit einem TextInput
-Widget:
Datumsangaben oder Uhrzeiten erfassen
Mit dem DateTimePicker
-Widget können Nutzer ein Datum, eine Uhrzeit oder sowohl ein Datum als auch eine Uhrzeit eingeben. Alternativ können Nutzer Datum und Uhrzeit über die Auswahl auswählen. Wenn Nutzer ein ungültiges Datum oder eine ungültige Uhrzeit eingeben, wird in der Auswahl ein Fehler angezeigt, der sie auffordert, die Informationen korrekt einzugeben.
Im Folgenden sehen Sie eine Karte mit drei verschiedenen Arten von DateTimePicker
-Widgets:
Nutzern das Auswählen von Elementen ermöglichen
Das SelectionInput
-Widget bietet eine Reihe von auswählbaren Elementen wie Kästchen, Optionsfelder, Schalter oder ein Drop-down-Menü. Mit diesem Widget können Sie definierte und standardisierte Daten von Nutzern erheben. Wenn Sie nicht definierte Daten von Nutzern erheben möchten, verwenden Sie stattdessen das Widget TextInput
.
Das SelectionInput
-Widget unterstützt Vorschläge, die Nutzern helfen, einheitliche Daten einzugeben, und On-Change-Aktionen, die Actions
ausgeführt werden, wenn sich ein Auswahleingabefeld ändert, z. B. wenn ein Nutzer einen Artikel auswählt oder die Auswahl aufhebt.
Chat-Apps können den Wert ausgewählter Elemente empfangen und verarbeiten. Weitere Informationen zur Arbeit mit Formularinputs finden Sie unter Von Nutzern eingegebene Informationen verarbeiten.
In diesem Abschnitt finden Sie Beispiele für Karten, in denen das SelectionInput
-Widget verwendet wird.
In den Beispielen werden verschiedene Arten von Abschnittseingaben verwendet:
Kästchen hinzufügen
Im Folgenden wird eine Karte mit einem SelectionInput
-Widget mit Kästchen angezeigt, über das der Nutzer angeben kann, ob ein Kontakt geschäftlich, privat oder beides ist:
Optionsfeld hinzufügen
Im Folgenden sehen Sie eine Karte, auf der der Nutzer mithilfe eines SelectionInput
-Widgets mit Optionsschaltflächen angeben soll, ob ein Kontakt geschäftlich oder privat ist:
Schalter hinzufügen
Im Folgenden wird eine Karte mit einem SelectionInput
-Widget mit Schaltern angezeigt, über das der Nutzer angeben kann, ob ein Kontakt geschäftlich, privat oder beides ist:
Drop-down-Menü hinzufügen
Im Folgenden sehen Sie eine Karte, auf der der Nutzer mit einem SelectionInput
-Widget mit Drop-down-Menü gefragt wird, ob ein Kontakt geschäftlich oder privat ist:
Mehrfachauswahl-Menü hinzufügen
Im Folgenden wird eine Karte angezeigt, auf der der Nutzer Kontakte aus einem Mehrfachauswahlmenü auswählen soll:
Sie können Elemente für ein Mehrfachauswahlmenü aus den folgenden Datenquellen in Google Workspace einfügen:
- Google Workspace-Nutzer: Sie können nur Nutzer innerhalb derselben Google Workspace-Organisation einfügen.
- Chatgruppen: Der Nutzer, der Elemente in das Mehrfachauswahlmenü eingibt, kann nur Gruppenbereiche in seiner Google Workspace-Organisation aufrufen und auswählen, zu denen er gehört.
Wenn Sie Google Workspace-Datenquellen verwenden möchten, geben Sie das Feld platformDataSource
an. Im Gegensatz zu anderen Auswahleingaben lassen Sie SelectionItem
-Objekte aus, da diese Auswahlelemente dynamisch aus Google Workspace abgerufen werden.
Der folgende Code zeigt ein Mehrfachauswahlmenü mit Google Workspace-Nutzern.
Um Nutzer einzufügen, wird in der Auswahleingabe commonDataSource
auf USER
gesetzt:
JSON
{
"selectionInput": {
"name": "contacts",
"type": "MULTI_SELECT",
"label": "Selected contacts",
"multiSelectMaxSelectedItems": 5,
"multiSelectMinQueryLength": 1,
"platformDataSource": {
"commonDataSource": "USER"
}
}
}
Der folgende Code zeigt ein Mehrfachauswahlmenü für Gruppenbereiche. Für die Befüllung von Bereichen wird in der Auswahleingabe das Feld hostAppDataSource
angegeben. Im Menü für die Mehrfachauswahl wird außerdem defaultToCurrentSpace
auf true
gesetzt, wodurch der aktuelle Gruppenbereich die Standardauswahl im Menü wird:
JSON
{
"selectionInput": {
"name": "spaces",
"type": "MULTI_SELECT",
"label": "Selected contacts",
"multiSelectMaxSelectedItems": 3,
"multiSelectMinQueryLength": 1,
"platformDataSource": {
"hostAppDataSource": {
"chatDataSource": {
"spaceDataSource": {
"defaultToCurrentSpace": true
}
}
}
}
}
}
In Menüs mit Mehrfachauswahl können auch Elemente aus einer Drittanbieter- oder externen Datenquelle eingefügt werden. Mithilfe von Mehrfachauswahlmenüs können Sie Nutzern beispielsweise die Auswahl aus einer Liste von Leads in einem CRM-System (Customer Relationship Management) erleichtern.
Wenn Sie eine externe Datenquelle verwenden möchten, geben Sie im Feld externalDataSource
eine Funktion an, die Elemente aus der Datenquelle zurückgibt.
Um die Anzahl der Anfragen an eine externe Datenquelle zu reduzieren, können Sie Vorschläge einfügen, die im Mehrfachauswahlmenü angezeigt werden, bevor Nutzer etwas eingeben. Sie können beispielsweise die zuletzt gesuchten Kontakte für den Nutzer einblenden. Wenn Sie vorgeschlagene Artikel aus einer externen Datenquelle einfügen möchten, geben Sie SelectionItem
-Objekte an.
Der folgende Code zeigt ein Mehrfachauswahlmenü mit Elementen aus einer externen Kontaktliste für den Nutzer. Im Menü wird standardmäßig ein Kontakt angezeigt und die Funktion getContacts
wird ausgeführt, um Elemente aus der externen Datenquelle abzurufen und einzufügen:
Node.js
Python
Java
Apps Script
Bei externen Datenquellen können Sie auch Elemente automatisch vervollständigen, die Nutzer im Menü für die Mehrfachauswahl eingeben. Wenn ein Nutzer beispielsweise Atl
für ein Menü eingibt, in dem Städte in den USA angezeigt werden, kann Ihre Chat-App Atlanta
automatisch vorschlagen, bevor der Nutzer fertig ist. Sie können bis zu 100 Elemente automatisch vervollständigen.
Wenn Sie Elemente automatisch vervollständigen möchten, erstellen Sie eine Funktion, die die externe Datenquelle abfragt und Elemente zurückgibt, wenn ein Nutzer etwas in das Mehrfachauswahlmenü eingibt. Die Funktion muss Folgendes tun:
- Übergeben Sie ein Ereignisobjekt, das die Nutzerinteraktion mit dem Menü darstellt.
- Prüfen Sie, ob der Wert
invokedFunction
des Interaktionsereignisses mit der Funktion im FeldexternalDataSource
übereinstimmt. - Wenn die Funktionen übereinstimmen, werden Vorschläge aus der externen Datenquelle zurückgegeben. Wenn Sie Elemente basierend auf dem eingebetteten Text vorschlagen möchten, rufen Sie den Wert für den Schlüssel
autocomplete_widget_query
ab. Dieser Wert entspricht dem, was der Nutzer in das Menü eingibt.
Im folgenden Code werden Elemente aus einer externen Datenressource automatisch vervollständigt. Im vorherigen Beispiel schlägt die Chat-App Elemente vor, je nachdem, wann die Funktion getContacts
ausgelöst wird:
Node.js
Python
Java
Apps Script
Auf Karten eingegebene Daten validieren
Auf dieser Seite wird beschrieben, wie Sie Daten validieren, die in die action
und Widgets einer Karte eingegeben wurden.
So können Sie beispielsweise prüfen, ob ein Textfeld vom Nutzer ausgefüllt wurde oder eine bestimmte Anzahl von Zeichen enthält.
Erforderliche Widgets für Aktionen festlegen
Fügen Sie unter action
der Karte die Namen der Widgets zur Liste requiredWidgets
hinzu, die für eine Aktion erforderlich sind.
Wenn eines der hier aufgeführten Widgets keinen Wert hat, wenn diese Aktion aufgerufen wird, wird die Formularaktion abgebrochen.
Wenn "all_widgets_are_required": "true"
für eine Aktion festgelegt ist, sind alle Widgets auf der Karte für diese Aktion erforderlich.
all_widgets_are_required
-Aktion für die Mehrfachauswahl festlegen
JSON
{
"sections": [
{
"header": "Select contacts",
"widgets": [
{
"selectionInput": {
"type": "MULTI_SELECT",
"label": "Selected contacts",
"name": "contacts",
"multiSelectMaxSelectedItems": 3,
"multiSelectMinQueryLength": 1,
"onChangeAction": {
"all_widgets_are_required": true
},
"items": [
{
"value": "contact-1",
"startIconUri": "https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png",
"text": "Contact 1",
"bottomText": "Contact one description",
"selected": false
},
{
"value": "contact-2",
"startIconUri": "https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png",
"text": "Contact 2",
"bottomText": "Contact two description",
"selected": false
},
{
"value": "contact-3",
"startIconUri": "https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png",
"text": "Contact 3",
"bottomText": "Contact three description",
"selected": false
},
{
"value": "contact-4",
"startIconUri": "https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png",
"text": "Contact 4",
"bottomText": "Contact four description",
"selected": false
},
{
"value": "contact-5",
"startIconUri": "https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png",
"text": "Contact 5",
"bottomText": "Contact five description",
"selected": false
}
]
}
}
]
}
]
}
all_widgets_are_required
-Aktion in der Datumsauswahl festlegen
JSON
{
"sections": [
{
"widgets": [
{
"textParagraph": {
"text": "A datetime picker widget with both date and time:"
}
},
{
"divider": {}
},
{
"dateTimePicker": {
"name": "date_time_picker_date_and_time",
"label": "meeting",
"type": "DATE_AND_TIME"
}
},
{
"textParagraph": {
"text": "A datetime picker widget with just date:"
}
},
{
"divider": {}
},
{
"dateTimePicker": {
"name": "date_time_picker_date_only",
"label": "Choose a date",
"type": "DATE_ONLY",
"onChangeAction":{
"all_widgets_are_required": true
}
}
},
{
"textParagraph": {
"text": "A datetime picker widget with just time:"
}
},
{
"divider": {}
},
{
"dateTimePicker": {
"name": "date_time_picker_time_only",
"label": "Select a time",
"type": "TIME_ONLY"
}
}
]
}
]
}
all_widgets_are_required
-Aktion im Drop-down-Menü festlegen
JSON
{
"sections": [
{
"header": "Section Header",
"collapsible": true,
"uncollapsibleWidgetsCount": 1,
"widgets": [
{
"selectionInput": {
"name": "location",
"label": "Select Color",
"type": "DROPDOWN",
"onChangeAction": {
"all_widgets_are_required": true
},
"items": [
{
"text": "Red",
"value": "red",
"selected": false
},
{
"text": "Green",
"value": "green",
"selected": false
},
{
"text": "White",
"value": "white",
"selected": false
},
{
"text": "Blue",
"value": "blue",
"selected": false
},
{
"text": "Black",
"value": "black",
"selected": false
}
]
}
}
]
}
]
}
Validierung für ein Texteingabe-Widget festlegen
Im Validierungsfeld des Widgets textInput
können die Zeichenbeschränkung und der Eingabetyp für dieses Widget für die Texteingabe angegeben werden.
Zeichenlimit für ein Texteingabe-Widget festlegen
JSON
{
"sections": [
{
"header": "Tell us about yourself",
"collapsible": true,
"uncollapsibleWidgetsCount": 2,
"widgets": [
{
"textInput": {
"name": "favoriteColor",
"label": "Favorite color",
"type": "SINGLE_LINE",
"validation": {"character_limit":15},
"onChangeAction":{
"all_widgets_are_required": true
}
}
}
]
}
]
}
Eingabetyp für ein Widget für die Texteingabe festlegen
JSON
{
"sections": [
{
"header": "Validate text inputs by input types",
"collapsible": true,
"uncollapsibleWidgetsCount": 2,
"widgets": [
{
"textInput": {
"name": "mailing_address",
"label": "Please enter a valid email address",
"type": "SINGLE_LINE",
"validation": {
"input_type": "EMAIL"
},
"onChangeAction": {
"all_widgets_are_required": true
}
}
},
{
"textInput": {
"name": "validate_integer",
"label": "Please enter a number",
"type": "SINGLE_LINE",
"validation": {
"input_type": "INTEGER"
}
}
},
{
"textInput": {
"name": "validate_float",
"label": "Please enter a number with a decimal",
"type": "SINGLE_LINE",
"validation": {
"input_type": "FLOAT"
}
}
}
]
}
]
}
Fehlerbehebung
Wenn eine Google Chat-App oder Karte einen Fehler zurückgibt, wird in der Chat-Benutzeroberfläche die Meldung „Ein Fehler ist aufgetreten“ angezeigt. oder „Ihre Anfrage konnte nicht verarbeitet werden“ Manchmal wird in der Chat-Benutzeroberfläche keine Fehlermeldung angezeigt, aber die Chat-App oder -Karte führt zu einem unerwarteten Ergebnis. Beispielsweise wird möglicherweise keine Kartennachricht angezeigt.
Auch wenn in der Chat-Benutzeroberfläche keine Fehlermeldung angezeigt wird, sind beschreibende Fehlermeldungen und Protokolldaten verfügbar, die Ihnen bei der Fehlerbehebung helfen, wenn die Fehlerprotokollierung für Chat-Apps aktiviert ist. Informationen zum Ansehen, Entfernen und Beheben von Fehlern finden Sie unter Google Chat-Fehler beheben.