Class Columns

Columns

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

MethodReturn typeBrief description
addColumn(column)ColumnsAdds a Column to the Columns widget.
setWrapStyle(wrapStyle)ColumnsSets 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

NameTypeDescription
columnColumnA 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

NameTypeDescription
wrapStyleWrapStyleThe wrap style to set for the columns.

Return

Columns — This object, for chaining.