輸入欄位,可讓使用者從一組預先定義的選項中選擇。
僅支援 Selection
和 Selection
選單的表單提交驗證。如果 Action.setAllWidgetsAreRequired(allWidgetsAreRequired)
設為 true
,或是透過 Action.addRequiredWidget(requiredWidget)
指定此小工具,則除非選取值,否則提交動作會遭到封鎖。
適用於 Google Workspace 外掛程式和 Google Chat 應用程式。
const checkboxGroup = CardService.newSelectionInput() .setType(CardService.SelectionInputType.CHECK_BOX) .setTitle('A group of checkboxes. Multiple selections are allowed.') .setFieldName('checkbox_field') .addItem('checkbox one title', 'checkbox_one_value', false) .addItem('checkbox two title', 'checkbox_two_value', true) .addItem('checkbox three title', 'checkbox_three_value', true) .setOnChangeAction( CardService.newAction().setFunctionName('handleCheckboxChange'), ); const radioGroup = CardService.newSelectionInput() .setType(CardService.SelectionInputType.RADIO_BUTTON) .setTitle( 'A group of radio buttons. Only a single selection is allowed.') .setFieldName('checkbox_field') .addItem('radio button one title', 'radio_one_value', true) .addItem('radio button two title', 'radio_two_value', false) .addItem('radio button three title', 'radio_three_value', false); const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('multiselect') .setTitle('A multi select input example.') .addMultiSelectItem( 'Contact 1', 'contact-1', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact one description', ) .addMultiSelectItem( 'Contact 2', 'contact-2', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact two description', ) .addMultiSelectItem( 'Contact 3', 'contact-3', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact three description', ) .addMultiSelectItem( 'Contact 4', 'contact-4', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact four description', ) .addMultiSelectItem( 'Contact 5', 'contact-5', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact five description', ) .setMultiSelectMaxSelectedItems(3) .setMultiSelectMinQueryLength(1);
方法
方法 | 傳回類型 | 簡短說明 |
---|---|---|
add | Selection | 新增可選取的新項目。 |
add | Selection | 為多重選取選單新增可選取的項目。 |
set | Selection | 設定外部資料來源,例如關聯式資料庫。 |
set | Selection | 設定事件物件中可識別此選取輸入內容的鍵,該事件物件是在發生 UI 互動時產生。 |
set | Selection | 設定使用者可選取的項目數量上限。 |
set | Selection | 設定使用者輸入的文字字元數,應用程式會在達到這個數量後查詢自動完成功能,並在資訊卡上顯示建議項目。 |
set | Selection | 設定 Action ,以便在選取輸入內容變更時執行。 |
set | Selection | 設定 Google Workspace 的資料來源。 |
set | Selection | 設定在輸入欄位前方顯示的標題。 |
set | Selection | 設定此輸入內容的類型。 |
內容詳盡的說明文件
add Item(text, value, selected)
新增可選取的新項目。
參數
名稱 | 類型 | 說明 |
---|---|---|
text | Object | 要顯示在這個項目的文字。非字串原始引數會自動轉換為字串。 |
value | Object | 透過回呼傳送的表單輸入值。非字串原始引數會自動轉換為字串。 |
selected | Boolean | 該項目是否預設為選取。如果選取輸入內容只接受一個值 (例如圓形按鈕或下拉式選單),請只為一個項目設定這個欄位。 |
回攻員
Selection
:這個物件用於鏈結。
add Multi Select Item(text, value, selected, startIconUri, bottomText)
為多重選取選單新增可選取的項目。
const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('multiselect') .setTitle('A multi select input example.') .addMultiSelectItem( 'Contact 1', 'contact-1', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact one description', ) .addMultiSelectItem( 'Contact 2', 'contact-2', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact two description', ) .addMultiSelectItem( 'Contact 3', 'contact-3', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact three description', ) .addMultiSelectItem( 'Contact 4', 'contact-4', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact four description', ) .addMultiSelectItem( 'Contact 5', 'contact-5', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact five description', );
參數
名稱 | 類型 | 說明 |
---|---|---|
text | Object | 要顯示在這個項目的文字。非字串原始引數會自動轉換為字串。 |
value | Object | 透過回呼傳送的表單輸入值。非字串原始引數會自動轉換為字串。 |
selected | Boolean | 該項目是否預設為選取。如果選取輸入內容只接受一個值 (例如圓形按鈕或下拉式選單),請只為一個項目設定這個欄位。 |
start | Object | 對於多重選取選單,項目文字欄位旁邊顯示的圖示網址。支援 PNG 和 JPEG 檔案。 |
bottom | Object | 對於多重選取選單,則是顯示在項目文字欄位下方的文字說明或標籤。 |
回攻員
Selection
:這個物件用於鏈結。
set External Data Source(action)
設定外部資料來源,例如關聯式資料庫。
const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('contacts') .setTitle('Selected contacts') .addMultiSelectItem( 'Contact 3', 'contact-3', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact three description', ) .setMultiSelectMaxSelectedItems(5) .setMultiSelectMinQueryLength(2) .setExternalDataSource( CardService.newAction().setFunctionName('getContacts'), );
參數
名稱 | 類型 | 說明 |
---|---|---|
action | Action | 外部資料來源。 |
回攻員
Selection
:這個物件用於鏈結。
set Field Name(fieldName)
設定事件物件中可識別此選取輸入內容的鍵,該事件物件是在發生 UI 互動時產生。使用者看不到。必要,且不得重複。
參數
名稱 | 類型 | 說明 |
---|---|---|
field | String | 要指派給此輸入內容的名稱。 |
回攻員
Selection
:這個物件用於鏈結。
set Multi Select Max Selected Items(maxSelectedItems)
設定使用者可選取的項目數量上限。
const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('multiselect') .setTitle('A multi select input example.') .setMultiSelectMaxSelectedItems(3) .addMultiSelectItem( 'Contact 1', 'contact-1', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact one description', ) .addMultiSelectItem( 'Contact 2', 'contact-2', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact two description', ) .addMultiSelectItem( 'Contact 3', 'contact-3', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact three description', ) .addMultiSelectItem( 'Contact 4', 'contact-4', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact four description', ) .addMultiSelectItem( 'Contact 5', 'contact-5', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact five description', );
參數
名稱 | 類型 | 說明 |
---|---|---|
max | Integer | 項目數量上限。 |
回攻員
Selection
:這個物件用於鏈結。
set Multi Select Min Query Length(queryLength)
設定使用者輸入的文字字元數,應用程式會在達到這個數量後查詢自動完成功能,並在資訊卡上顯示建議項目。
const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('multiselect') .setTitle('A multi select input example.') .setMultiSelectMinQueryLength(1) .addMultiSelectItem( 'Contact 1', 'contact-1', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact one description', ) .addMultiSelectItem( 'Contact 2', 'contact-2', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact two description', ) .addMultiSelectItem( 'Contact 3', 'contact-3', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact three description', ) .addMultiSelectItem( 'Contact 4', 'contact-4', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact four description', ) .addMultiSelectItem( 'Contact 5', 'contact-5', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact five description', );
參數
名稱 | 類型 | 說明 |
---|---|---|
query | Integer | 文字字元的數量。 |
回攻員
Selection
:這個物件用於鏈結。
set On Change Action(action)
set Platform Data Source(platformDataSource)
設定 Google Workspace 的資料來源。用於在多重選取選單中填入項目。
const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('contacts') .setTitle('Selected contacts') .setPlatformDataSource( CardService.newPlatformDataSource().setCommonDataSource( CardService.CommonDataSource.USER, ), );
參數
名稱 | 類型 | 說明 |
---|---|---|
platform | Platform | 資料來源。 |
回攻員
Selection
:這個物件用於鏈結。