The Columns
widget displays up to 2 columns in a card or dialog. You can add widgets to
each Column
; the widgets appear in the order that they are specified. For an example in
Google Chat apps, see Columns.
The height of each column is determined by the taller column. For example, if the first column is taller than the second column, both columns have the height of the first column. Because each column can contain a different number of widgets, you can't define rows or align widgets between the columns.
Columns are displayed side-by-side. You can customize the width of each column using the
HorizontalSizeStyle
field. If the user's screen width is too narrow, the second column
wraps below the first:
- On web, the second column wraps if the screen width is less than or equal to 480 pixels.
- On iOS devices, the second column wraps if the screen width is less than or equal to 300 pt.
- On Android devices, the second column wraps if the screen width is less than or equal to 320 dp.
Available for Google Chat apps and Google Workspace Add-ons. The add-on UIs that support columns include:
- The dialog displayed when users open the add-on from an email draft.
- The dialog displayed when users open the add-on from the Add attachment menu in a Google Calendar event.
// Build a column that is aligned in the center and fills the space: const column = CardService.newColumn() .setHorizontalSizeStyle(CardService.HorizontalSizeStyle.FILL_AVAILABLE_SPACE) .setHorizontalAlignment(CardService.HorizontalAlignment.CENTER) .setVerticalAlignment(CardService.VerticalAlignment.CENTER); const columns = CardService.newColumns() .addColumn(column) .setWrapStyle(CardService.WrapStyle.WRAP);
Methods
Method | Return type | Brief description |
---|---|---|
addColumn(column) | Columns | Adds a Column to the Columns widget. |
setWrapStyle(wrapStyle) | Columns | Sets the wrap style of the columns, controls how the column resizes based on screen width. |
Detailed documentation
addColumn(column)
Adds a Column
to the Columns widget. Columns are displayed in the order in which
they're added. You can add up to two columns.
const columns = CardService.newColumns() .addColumn(CardService.newColumn());
Parameters
Name | Type | Description |
---|---|---|
column | Column | A child column to add to the Columns widget. |
Return
Columns
— This object, for chaining.
setWrapStyle(wrapStyle)
Sets the wrap style of the columns, controls how the column resizes based on screen width.
const columns = CardService.newColumns() .addColumn(CardService.newColumn()) .setWrapStyle(CardService.WrapStyle.WRAP);
Parameters
Name | Type | Description |
---|---|---|
wrapStyle | WrapStyle | The wrap style to set for the columns. |
Return
Columns
— This object, for chaining.