Bu sayfada, kullanıcıların Google Chat uygulamanızla etkileşime geçebilmesi (ör. bir düğmeyi tıklayarak veya bilgi göndererek) için kartlara widget'ların ve kullanıcı arayüzü öğelerinin nasıl ekleneceği açıklanmaktadır.
Chat uygulamaları, etkileşimli kartlar oluşturmak için aşağıdaki Chat arayüzlerini kullanabilir:
- Bir veya daha fazla kart içeren mesajlar
- Chat uygulamasındaki doğrudan mesajlarda Ana Sayfa sekmesinde görünen bir kart olan Ana sayfalar.
- Mesajlardan ve ana sayfalardan yeni bir pencerede açılan kartlar olan iletişim kutuları.
Kullanıcılar kartlarla etkileşimde bulunduğunda, Chat uygulamaları aldıkları verileri kullanarak bilgileri uygun şekilde işleyip yanıt verebilir. Ayrıntılı bilgi için Google Chat kullanıcılarından bilgi toplama ve işleme başlıklı makaleyi inceleyin.
Chat uygulamaları için mesajlaşma ve kullanıcı arayüzlerini tasarlamak ve önizlemek üzere Kart Oluşturucu'yu kullanın:
Kart Oluşturucu'yu açmaÖn koşullar
Etkileşimli özellikler için etkinleştirilmiş bir Google Chat uygulaması. Etkileşimli bir Chat uygulaması oluşturmak için kullanmak istediğiniz uygulama mimarisine göre aşağıdaki hızlı başlangıç kılavuzlarından birini tamamlayın:
- Google Cloud Functions ile HTTP hizmeti
- Google Apps Komut Dosyası
- Google Cloud Dialogflow CX
- Google Cloud Pub/Sub
Düğme ekleme
ButtonList
widget'ı bir dizi düğme gösterir. Düğmelerde metin, simge veya hem metin hem de simge gösterilebilir. Her Button
, kullanıcılar düğmeyi tıkladığında gerçekleşen bir OnClick
işlemini destekler. Örneğin:
- Kullanıcılara ek bilgi sağlamak için
OpenLink
ile köprü açın. - API çağırma gibi özel bir işlev çalıştıran bir
action
çalıştırın.
Düğmeler, erişilebilirlik için alternatif metni destekler.
Özel işlev çalıştıran bir düğme ekleme
Aşağıda, iki düğmeli bir ButtonList
widget'ından oluşan bir kart gösterilmektedir.
Bir düğmeyle Google Chat geliştirici dokümanlarını yeni bir sekmede açabilirsiniz. Diğer düğme, goToView()
adlı özel bir işlevi çalıştırır ve viewType="BIRD EYE VIEW"
parametresini iletir.
Materyal Tasarım stilinde bir düğme ekleme
Aşağıda, farklı Materyal Tasarım düğme stillerinde bir dizi düğme gösterilmektedir.
Materyal Tasarım stilini uygulamak için "renk" özelliğini eklemeyin.
Özel renk ve devre dışı bırakılmış düğme ekleme
"disabled": "true"
değerini ayarlayarak kullanıcıların bir düğmeyi tıklamasını engelleyebilirsiniz.
Aşağıda, iki düğmeli ButtonList
widget'ından oluşan bir kart görüntülenmektedir. Bir düğme, düğmenin arka plan rengini özelleştirmek için Color
alanını kullanır. Diğer düğme, Disabled
alanıyla devre dışı bırakıldı. Bu durum, kullanıcının düğmeyi tıklamasını ve işlevi yürütmesini engeller.
Simge içeren bir düğme ekleyin
Aşağıda, iki simge Button
widget'ı içeren bir ButtonList
widget'ından oluşan bir kart gösterilmektedir. Bir düğme, Google Chat'in yerleşik e-posta simgesini görüntülemek için knownIcon
alanını kullanır. Diğer düğme, özel simge widget'ı görüntülemek için iconUrl
alanını kullanır.
Simge ve metin içeren bir düğme ekleme
Aşağıda, kullanıcıdan e-posta göndermesini isteyen bir ButtonList
widget'ından oluşan bir kart gösterilmektedir. İlk düğmede e-posta simgesi, ikinci düğmede ise metin gösterilir. Kullanıcı, sendEmail
işlevini çalıştırmak için simgeyi veya metin düğmesini tıklayabilir.
Katlanabilir bir bölüm için düğmeyi özelleştirme
Karttaki bölümleri daraltan ve genişleten kontrol düğmesini özelleştirin. Bölümün içeriğini görsel olarak temsil etmek için çeşitli simgeler veya resimler arasından seçim yaparak kullanıcıların bilgileri daha kolay anlamasını ve bunlarla etkileşim kurmasını sağlayın.
Taşma Menüsü Ekle
Overflow menu
, ek seçenekler ve işlemler sunmak için Chat kartlarında kullanılabilir. Kartın arayüzünü karmaşık hale getirmeden daha fazla seçenek eklemenize olanak tanır ve temiz ve düzenli bir tasarım sağlar.
Çip listesi ekleme
ChipList
widget'ı, bilgileri görüntülemek için çok yönlü ve görsel açıdan ilgi çekici bir yöntem sunar.
Etiketleri, kategorileri veya diğer alakalı verileri temsil etmek için çip listeleri kullanın. Böylece kullanıcıların içeriğinizde gezinmesini ve içeriğinizle etkileşim kurmasını kolaylaştırabilirsiniz.
Kullanıcılardan bilgi toplama
Bu bölümde, metin veya seçimler gibi bilgi toplayan widget'ları nasıl ekleyeceğiniz açıklanmaktadır.
Kullanıcıların girdiği bilgileri nasıl işleyeceğinizi öğrenmek için Google Chat kullanıcılarından bilgi toplama ve işleme başlıklı makaleyi inceleyin.
Metin toplama
TextInput
widget'ı, kullanıcıların metin girebileceği bir alan sağlar. Widget, kullanıcıların tek tip veri girmesine yardımcı olan önerileri ve metin giriş alanında bir değişiklik olduğunda (kullanıcının metin eklemesi veya silmesi gibi) çalıştırılan Actions
işlemlerini destekler.
Kullanıcılardan soyut veya bilinmeyen veriler toplamanız gerektiğinde bu TextInput
widget'ını kullanın. Kullanıcılardan tanımlanmış verileri toplamak için bunun yerine SelectionInput
widget'ını kullanın.
Aşağıda, TextInput
widget'ından oluşan bir kart gösterilmektedir:
Tarih veya saat toplama
DateTimePicker
widget'ı, kullanıcıların tarih, saat veya hem tarih hem de saat girmelerine olanak tanır. Kullanıcılar, tarih ve saat seçmek için seçiciyi de kullanabilir. Kullanıcılar geçersiz bir tarih veya saat girerse seçici, kullanıcıları bilgileri doğru şekilde girmeye teşvik eden bir hata gösterir.
Aşağıda, üç farklı DateTimePicker
widget türünden oluşan bir kart gösterilmektedir:
Kullanıcıların öğe seçmesine izin ver
SelectionInput
widget'ı, onay kutuları, radyo düğmeleri, anahtarlar veya açılır menü gibi seçilebilir öğeler sunar. Bu widget'ı, kullanıcılardan tanımlanmış ve standartlaştırılmış veriler toplamak için kullanabilirsiniz. Kullanıcılardan tanımlanmamış veriler toplamak için bunun yerine TextInput
widget'ını kullanın.
SelectionInput
widget'ı, kullanıcıların tek tip veri girmesine yardımcı olan önerileri ve bir seçim giriş alanında değişiklik yapıldığında (ör. kullanıcı bir öğeyi seçtiğinde veya seçmeyi kaldırdığında) çalışan değişiklikle ilgili işlemleri destekler.Actions
Sohbet uygulamaları, seçili öğelerin değerini alıp işleyebilir. Form girişleriyle çalışma hakkında ayrıntılı bilgi için Kullanıcılar tarafından girilen bilgileri işleme başlıklı makaleyi inceleyin.
Bu bölümde, SelectionInput
widget'ını kullanan kart örnekleri verilmiştir.
Örneklerde farklı türde bölüm girişleri kullanılmaktadır:
Onay kutusu ekleme
Aşağıda, kullanıcıdan bir kişinin profesyonel, kişisel veya her ikisi olduğunu belirtmesini isteyen ve onay kutuları kullanan bir SelectionInput
widget'ı içeren bir kart gösterilmektedir:
Radyo düğmesi ekleme
Aşağıdakiler, radyo düğmeleri kullanan bir SelectionInput
widget'ı ile kullanıcıdan bir kişinin profesyonel mi yoksa kişisel mi olduğunu belirtmesini isteyen bir kart görüntüler:
Anahtar ekle
Aşağıda, kullanıcıdan bir kişinin profesyonel, kişisel veya her ikisi olduğunu belirtmesini isteyen bir kart gösterilmektedir. Bu kartta, anahtarları kullanan bir SelectionInput
widget'ı yer alır:
Açılır menü ekleme
Aşağıdakiler, açılır menü kullanan bir SelectionInput
widget'ı ile kullanıcıdan bir kişinin profesyonel mi yoksa kişisel mi olduğunu belirtmesini isteyen bir kart görüntüler:
Çoklu seçim menüsü ekleme
Aşağıda, kullanıcıdan çoklu seçim menüsünden kişileri seçmesini isteyen bir kart gösterilmektedir:
Google Workspace'te aşağıdaki veri kaynaklarından çoklu seçim menüsü öğelerini doldurabilirsiniz:
- Google Workspace kullanıcıları: Yalnızca aynı Google Workspace kuruluşundaki kullanıcıları doldurabilirsiniz.
- Chat alanları: Çoklu seçim menüsüne öğe giren kullanıcı, yalnızca Google Workspace kuruluşunda ait olduğu alanları görüntüleyebilir ve seçebilir.
Google Workspace veri kaynaklarını kullanmak için platformDataSource
alanını belirtirsiniz. Diğer seçim giriş türlerinin aksine, SectionItem
nesneleri dinamik olarak Google Workspace kaynaklı olduğu için hariç tutulur.
Aşağıdaki kodda, Google Workspace kullanıcılarının çoklu seçim menüsü gösterilmektedir.
Kullanıcıları doldurmak için seçim girişi commonDataSource
değerini USER
olarak ayarlar:
JSON
{
"selectionInput": {
"name": "contacts",
"type": "MULTI_SELECT",
"label": "Selected contacts",
"multiSelectMaxSelectedItems": 5,
"multiSelectMinQueryLength": 1,
"platformDataSource": {
"commonDataSource": "USER"
}
}
}
Aşağıdaki kodda, Sohbet alanlarını içeren bir çoklu seçim menüsü gösterilmektedir. Boşlukları doldurmak için seçim girişi hostAppDataSource
alanını belirtir. Çoklu seçim menüsü, mevcut alanı menüdeki varsayılan seçim haline getiren defaultToCurrentSpace
değerini de true
olarak ayarlar:
JSON
{
"selectionInput": {
"name": "spaces",
"type": "MULTI_SELECT",
"label": "Selected contacts",
"multiSelectMaxSelectedItems": 3,
"multiSelectMinQueryLength": 1,
"platformDataSource": {
"hostAppDataSource": {
"chatDataSource": {
"spaceDataSource": {
"defaultToCurrentSpace": true
}
}
}
}
}
}
Çoklu seçim menüleri, öğeleri üçüncü taraf veya harici bir veri kaynağından da doldurabilir. Örneğin, bir kullanıcının bir müşteri ilişkileri yönetimi (CRM) sistemindeki potansiyel müşteriler listesinden seçim yapmasına yardımcı olmak için çoklu seçim menülerini kullanabilirsiniz.
Harici bir veri kaynağı kullanmak için externalDataSource
alanını kullanarak veri kaynağından öğe döndüren bir işlev belirtirsiniz.
Harici bir veri kaynağına yapılan istekleri azaltmak için kullanıcılar menüye yazmadan önce çoklu seçim menüsünde görünen önerilen öğeleri ekleyebilirsiniz. Örneğin, kullanıcı için son aranan kişileri doldurabilirsiniz. Harici bir veri kaynağından önerilen öğeleri doldurmak için SelectionItem
nesneleri belirtin.
Aşağıdaki kodda, kullanıcının harici bir kişi grubundaki öğelerin yer aldığı çoklu seçim menüsü gösterilmektedir. Menüde varsayılan olarak bir kişi gösterilir ve harici veri kaynağından öğe alıp doldurmak için getContacts
işlevi çalıştırılır:
Node.js
Python
Java
Apps Komut Dosyası
Harici veri kaynakları için, kullanıcıların çoklu seçim menüsünde yazmaya başladığı öğeleri de otomatik olarak tamamlayabilirsiniz. Örneğin, bir kullanıcı ABD'deki şehirlerin doldurulduğu bir menü için Atl
yazmaya başlarsa Chat uygulamanız, kullanıcı yazmayı tamamlamadan Atlanta
önce otomatik olarak öneride bulunabilir. En fazla 100 öğeyi otomatik olarak tamamlayabilirsiniz.
Öğeleri otomatik olarak tamamlamak için harici veri kaynağını sorgulayan ve kullanıcı çoklu seçim menüsüne her yazdığında öğeleri döndüren bir işlev oluşturursunuz. İşlev aşağıdakileri yapmalıdır:
- Kullanıcının menüyle etkileşimini temsil eden bir etkinlik nesnesi iletin.
- Etkileşim etkinliğinin
invokedFunction
değerininexternalDataSource
alanındaki işlevle eşleştiğini belirleyin. - İşlevler eşleştiğinde, harici veri kaynağından önerilen öğeleri döndürün. Kullanıcının yazdıklarına göre öğe önermek için
autocomplete_widget_query
anahtarının değerini alın. Bu değer, kullanıcının menüde yazdığı şeyi temsil eder.
Aşağıdaki kod, harici bir veri kaynağındaki öğeleri otomatik olarak tamamlar. Önceki örneğe göre Chat uygulaması, getContacts
işlevinin tetiklendiği zamana göre öğeler önerir:
Node.js
Python
Java
Apps Komut Dosyası
Kartlara girilen verileri doğrulama
Bu sayfada, kartın action
ve widget'larına girilen verilerin nasıl doğrulanacağı açıklanmaktadır.
Örneğin, bir metin giriş alanının kullanıcı tarafından girilen metin içerdiğini veya belirli sayıda karakter içerdiğini doğrulayabilirsiniz.
İşlemler için gerekli widget'ları ayarlama
Kartın action
parçası olarak bir işlemin ihtiyaç duyduğu widget'ların adlarını requiredWidgets
listesine ekleyin.
Bu işlem çağrıldığında burada listelenen widget'ların hiçbirinde değer yoksa form işlemi gönderimi iptal edilir.
Bir işlem için "all_widgets_are_required": "true"
ayarlandığında, karttaki tüm widget'lar bu işlem için gereklidir.
Çoklu seçimde all_widgets_are_required
işlemi ayarlama
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
}
]
}
}
]
}
]
}
dateTimePicker'da all_widgets_are_required
işlemi ayarlama
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"
}
}
]
}
]
}
Açılır menüde all_widgets_are_required
işlemi ayarlama
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
}
]
}
}
]
}
]
}
Metin girişi widget'ı için doğrulamayı ayarlama
textInput
widget'ının doğrulama alanında, bu metin giriş widget'ı için karakter sınırını ve giriş türünü belirtebilirsiniz.
Metin girişi widget'ı için karakter sınırı belirleme
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
}
}
}
]
}
]
}
Metin girişi widget'ının giriş türünü ayarlama
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"
}
}
}
]
}
]
}
Sorun giderme
Bir Google Chat uygulaması veya kartı hata döndürdüğünde Chat arayüzünde "Bir hata oluştu" mesajı gösterilir. veya "İsteğiniz işlenemiyor." Bazı durumlarda Chat kullanıcı arayüzünde herhangi bir hata mesajı gösterilmez ancak Chat uygulaması veya kartı beklenmedik bir sonuç verir. Örneğin, kart mesajı görünmeyebilir.
Chat kullanıcı arayüzünde hata mesajı gösterilmeyebilir ancak Chat uygulamaları için hata günlüğü etkinleştirildiğinde hataları düzeltmenize yardımcı olacak açıklayıcı hata mesajları ve günlük verileri kullanılabilir. Hataları görüntüleme, hata ayıklama ve düzeltme hakkında yardım için Google Chat hatalarını giderme başlıklı makaleyi inceleyin.