Configuration for columns ColDef<TData, TValue>
and column groups ColGroupDef<TData>
.
Columns
field | The field of the row object to get the cell's data from.
Deep references into a row object is supported via dot notation, i.e 'address.firstLine' . |
col | The unique ID to give the column. This is optional. If missing, the ID will default to the field.
If both field and colId are missing, a unique ID will be generated.
This ID is used to identify the column in the API for sorting, filtering etc. |
type | A comma separated string or array of strings containing ColumnType keys which can be used as a template for a column.
This helps to reduce duplication of properties when you have a lot of common column properties.See: Column Types |
cell | The data type of the cell values for this column.
Can either infer the data type from the row data ( true - the default behaviour),
define a specific data type (string ), or have no data type (false ).
If setting a specific data type (string value),
this can either be one of the pre-defined data types
'text' , 'number' , 'boolean' , 'date' , 'dateString' or 'object' ,
or a custom data type that has been defined in the dataTypeDefinitions grid option.
Data type inference only works for the Client-Side Row Model, and requires non-null data.
It will also not work if the valueGetter , valueParser or refData properties are defined,
or if this column is a sparkline.See: Cell Data Types |
value | Function or expression. Gets the value from your data for display. See: Value Getters |
value | A function or expression to format a value, should return a string. See: Value Formatters |
ref | Provided a reference data map to be used to map column values to their respective value from the map. |
key | Function to return a string key for a value.
This string is used for grouping, Set filtering, and searching within cell editor dropdowns.
When filtering and searching the string is exposed to the user, so make sure to return a human-readable value. |
equals | Custom comparator for values, used by renderer to know if values have changed. Cells whose values have not changed don't get refreshed.
By default the grid uses === which should work for most use cases. |
checkbox | Set to true (or return true from function) to render a selection checkbox in the column. |
show | Set to true to display a disabled checkbox when row is not selectable and checkboxes are enabled. |
tool | CSS class to use for the tool panel cell. Can be a string, array of strings, or function. |
suppress | Set to true if you do not want this column or group to appear in the Columns Tool Panel. |
column | Whether to only show the column when the group is open / closed. If not set the column is always displayed as part of the group. |
icons | Icons to use inside the column instead of the grid's default icons. Leave undefined to use defaults. See: Custom Icons |
suppress | Set to true if this column is not navigable (i.e. cannot be tabbed into), otherwise false .
Can also be a callback function to have different rows navigable. |
suppress | Allows the user to suppress certain keyboard events in the grid cell. |
suppress | Pasting is on by default as long as cells are editable (non-editable cells cannot be modified, even with a paste operation).
Set to true turn paste operations off. |
suppress | Set to true to prevent the fillHandle from being rendered in any cell that belongs to this column |
context | Customise the list of menu items available in the context menu. |
context | Context property that can be used to associate arbitrary application data with this column definition. |
Columns: Accessibility
cell | Used for screen reader announcements - the role property of the cells that belong to this column. |
Columns: Display
Columns: Editing
See Cell Editing for more information.
editable | Set to true if this column is editable, otherwise false . Can also be a function to have different rows editable. |
value | Function or expression. Custom function to modify your data based off the new value for saving. Return true if the data changed.See: Saving Values |
value | Function or expression. Parses the value for saving. See: Parsing Values |
cell | Provide your own cell editor component for this column's cells. See: Cell Editors |
cell | Params to be passed to the cellEditor component. |
cell | Callback to select which cell editor to be used for a given row within the same column. |
cell | Set to true , to have the cell editor appear in a popup. |
cell | Set the position for the popup cell editor. Possible values are over Popup will be positioned over the cell under Popup will be positioned below the cell leaving the cell value visible. |
single | Set to true to have cells under this column enter edit mode after single click. |
use | By default, values are parsed using the column's valueParser when importing data to the grid.
This applies to clipboard operations and the fill handle.
Set to false to prevent values from being parsed for these operations.
Regardless of this option, if custom handling is provided for the import operation, the value parser will not be used. |
Columns: Events
Columns: Filter
See Filtering for more information.
filter | Filter component to use for this column. Set to true to use the default filter. Set to the name of a Provided Filter or set to a IFilterComp .See: Column Filters |
filter | Params to be passed to the filter component specified in filter .See: Filter Parameters |
filter | Function or expression. Gets the value for filtering purposes. |
get | A function to tell the grid what Quick Filter text to use for this column if you don't want to use the default (which is calling toString on the value). |
floating | Whether to display a floating filter for this column. See: Floating Filter |
floating | The custom component to be used for rendering the floating filter.
If none is specified the default AG Grid is used. |
floating | Params to be passed to floatingFilterComponent . |
suppress | Set to true if you do not want this column (filter) or group (filter group) to appear in the Filters Tool Panel. |
Columns: Header
See Column Headers for more information.
header | The name to render in the column header. If not specified and field is specified, the field name will be used as the header name. |
header | Function or expression. Gets the value for display in the header. |
header | Tooltip for the column header |
header | CSS class to use for the header cell. Can be a string, array of strings, or function. |
header | The custom header group component to be used for rendering the component header. If none specified the default AG Grid is used. See: Header Component |
header | The parameters to be passed to the headerComponent . |
wrap | If enabled then column header names that are too long for the column width will wrap onto the next line. Default false |
auto | If enabled then the column header row will automatically adjust height to accommodate the size of the header cell.
This can be useful when using your own headerComponent or long header names in conjunction with wrapHeaderText .See: Auto Header Height |
menu | Set to an array containing zero, one or many of the following options: 'filterMenuTab' | 'generalMenuTab' | 'columnsMenuTab' .
This is used to figure out which menu tabs are present and in which order the tabs are shown. |
column | Params used to change the behaviour and appearance of the Column Chooser/Columns Menu tab. |
main | Customise the list of menu items available in the column menu. |
suppress | Set to true if no menu button should be shown for this column header. |
suppress | Set to true to not display the filter button in the column header.
Doesn't apply when columnMenu = 'legacy' . |
suppress | Set to true to not display the column menu when the column header is right-clicked.
Doesn't apply when columnMenu = 'legacy' . |
suppress | Suppress the grid taking action for the relevant keyboard event when a header is focused. |
header | If true or the callback returns true , a 'select all' checkbox will be put into the header. |
header | If true , the header checkbox selection will only select filtered items. |
header | If true , the header checkbox selection will only select nodes on the current page. |
suppress | If true , the button in the floating filter that opens the parent filter in a popup will not be displayed.
Only applies if floatingFilter = true .See: Floating Filters |
Columns: Integrated Charts
(Enterprise only) See Integrated Charts
chart | Defines the chart data type that should be used for a column. |
Columns: Pinned
See Column Pinning for more information.
Columns: Pivoting
(Enterprise only) See Pivoting
pivot | Set to true to pivot by this column. |
initial | Same as pivot , except only applied when creating a new column. Not applied when updating column definitions. |
pivot | Set this in columns you want to pivot by.
If only pivoting by one column, set this to any number (e.g. 0 ).
If pivoting by multiple columns, set this to where you want this column to be in the order of pivots (e.g. 0 for first, 1 for second, and so on). |
initial | Same as pivotIndex , except only applied when creating a new column. Not applied when updating column definitions. |
pivot | Only for CSRM, see SSRM Pivoting.
Comparator to use when ordering the pivot columns, when this column is used to pivot on.
The values will always be strings, as the pivot service uses strings as keys for the pivot groups. |
enable | Set to true if you want to be able to pivot by this column via the GUI. This will not block the API or properties being used to achieve pivot. |
Columns: Rendering and Styling
cell | An object of css values / or function returning an object of css values for a particular cell. See: Cell Style |
cell | Class to use for the cell. Can be string, array of strings, or function that returns a string or array of strings. See: Cell Class |
cell | Rules which can be applied to include certain CSS classes. See: Cell Class Rules |
cell | Provide your own cell Renderer component for this column's cells. See: Cell Renderer |
cell | Params to be passed to the cellRenderer component.See: Cell Renderer Params |
cell | Callback to select which cell renderer to be used for a given row within the same column. |
loading | Provide your own cell loading Renderer component for this column's cells when using SSRM. See: SSRM Cell Loading |
loading | Params to be passed to the loadingCellRenderer component.See: SSRM Cell Loading |
loading | Callback to select which loading renderer to be used for a given row within the same column. See: SSRM Cell Loading |
auto | Set to true to have the grid calculate the height of a row based on contents of this column. |
wrap | Set to true to have the text wrap inside the cell - typically used with autoHeight . |
enable | Set to true to flash a cell when it's refreshed. |
Columns: Row Dragging
See Row Dragging for more information.
Columns: Row Grouping
(Enterprise only) See Row Grouping
row | Set to true to row group by this column. |
initial | Same as rowGroup , except only applied when creating a new column. Not applied when updating column definitions. |
row | Set this in columns you want to group by.
If only grouping by one column, set this to any number (e.g. 0 ).
If grouping by multiple columns, set this to where you want this column to be in the group (e.g. 0 for first, 1 for second, and so on). |
initial | Same as rowGroupIndex , except only applied when creating a new column. Not applied when updating column definitions. |
enable | Set to true if you want to be able to row group by this column via the GUI.
This will not block the API or properties being used to achieve row grouping. |
show | Set to true to have the grid place the values for the group into the cell, or put the name of a grouped column to just show that group. See: Custom Group Columns |
enable | Set to true if you want to be able to aggregate by this column via the GUI.
This will not block the API or properties being used to achieve aggregation. |
agg | Name of function to use for aggregation. In-built options are: sum , min , max , count , avg , first , last . Also accepts a custom aggregation name or an aggregation function. |
initial | Same as aggFunc , except only applied when creating a new column. Not applied when updating column definitions. |
allowed | Aggregation functions allowed on this column e.g. ['sum', 'avg'] .
If missing, all installed functions are allowed.
This will only restrict what the GUI allows a user to select, it does not impact when you set a function via the API. |
default | The name of the aggregation function to use for this column when it is enabled via the GUI.
Note that this does not immediately apply the aggregation function like aggFunc |
Columns: Sort
See Row Sorting for more information.
Columns: Spanning
Columns: Tooltips
tooltip | The field of the tooltip to apply to the cell. |
tooltip | Callback that should return the string to use for a tooltip, tooltipField takes precedence if set.
If using a custom tooltipComponent you may return any custom value to be passed to your tooltip component.See: Tooltip Component |
tooltip | Provide your own tooltip component for the column. See: Tooltip Component |
tooltip | The params used to configure tooltipComponent . |
Columns: Width
See Column Sizing for more information.
width | Initial width in pixels for the cell. |
initial | Same as width , except only applied when creating a new column. Not applied when updating column definitions. |
min | Minimum width in pixels for the cell. |
max | Maximum width in pixels for the cell. |
flex | Used instead of width when the goal is to fill the remaining empty space of the grid.See: Column Flex |
initial | Same as flex , except only applied when creating a new column. Not applied when updating column definitions. |
resizable | Set to false to disable resizing which is enabled by default. |
suppress | Set to true if you want this column's width to be fixed during 'size to fit' operations. |
suppress | Set to true if you do not want this column to be auto-resizable by double clicking it's edge. |
Groups
For column groups, the property children
is mandatory. When the grid sees children
it knows it's a column group.
See Column Groups for more information.
children * | A list containing a mix of columns and column groups. |
group | The unique ID to give the column. This is optional. If missing, a unique ID will be generated. This ID is used to identify the column group in the API. |
marry | Set to true to keep columns in this group beside each other in the grid. Moving the columns outside of the group (and hence breaking the group) is not allowed. |
open | Set to true if this group should be opened by default. |
column | Whether to only show the column when the group is open / closed. If not set the column is always displayed as part of the group. |
tool | CSS class to use for the tool panel cell. Can be a string, array of strings, or function. |
suppress | Set to true if you do not want this column or group to appear in the Columns Tool Panel. |
suppress | Set to true if you do not want this column (filter) or group (filter group) to appear in the Filters Tool Panel. |
tooltip | Provide your own tooltip component for the column group. See: Tooltip Component |
tooltip | The params used to configure tooltipComponent . |
context | Context property that can be used to associate arbitrary application data with this column definition. |
Groups: Header
See Column Headers for more information.
header | The name to render in the column header. If not specified and field is specified, the field name will be used as the header name. |
header | CSS class to use for the header cell. Can be a string, array of strings, or function. |
header | Tooltip for the column header |
auto | If enabled then the column header row will automatically adjust height to accommodate the size of the header cell.
This can be useful when using your own headerComponent or long header names in conjunction with wrapHeaderText .See: Auto Header Height |
header | The custom header group component to be used for rendering the component header. If none specified the default AG Grid is used. |
header | The params used to configure the headerGroupComponent . |
suppress | Set to true if you don't want the column header for this column to span the whole height of the header container. |
suppress | If true the label of the Column Group will not scroll alongside the grid to always remain visible. |