-
Notifications
You must be signed in to change notification settings - Fork 162
Column Resizing
Allows the user to resize a column via clicking and dragging a resize indicator to a new location. Resizing is deferred until the resize indicator is dropped.
Provides deferred column resizing for the igxGrid - a deferred update shows the user a temporary resize indicator while the drag operation is in effect and only applies the new column size once the drag operation ends.
-
As a developer, I want to mark specific columns as resizable, so that I can allow the end user to resize them interactively.
-
As a developer, I want to be notified when a column is resized, so that I can add custom logic.
-
As a developer, I want to configure minimum and maximum allowable column widths, so that I can restrict the end users to resizing columns to specific sizes.
-
As a developer, I want to enable best fit (auto) sizing via double click – the column will be sized to the longest currently visible cell value, so that the user can see the entire content.
-
As a developer, I want to be able to style the resize indicator.
-
As an end user, I want to be able to resize columns, so that I can adjust the size of the columns.
-
As an end user, I want to have indication that the column can be resized, when the mouse is positioned over the header side border.
-
As an end user, I want to resize the columns by click, then dragging and dropping the visual indicator, so that I can resize interactively.
-
As an end user, I want to have a visual indicator of the initial state of the border that I am resizing while dragging the new location, so that I can resize interactively.
-
As an end user, I want to auto-size a column by double clicking on resize indicator.
-
As an end user, I want to be able to resize columns with multi-column headers, as well as pinned column.
Ends users should be able to resize columns according to their needs. The resizing is done via clicking and then dragging a temporary resize indicator. The new column size is applied only when the drag operation ends. Resizing a certain column affects the overall width of the grid - a horizontal scrollbar appears if necessary.
The resize indicator is constrained within the limits of the specified minWidth
and maxWidth
options and cannot go outside of their bounds.
When resizing a child column, the parent header should also be resized. Same for when resizing the parent column – child column should adjust their sizes proportionally.
Pinned columns – pinned columns can be resized and will affect the size of the pinned area. As there is no constraint on the size of the pinned area it is possible for the pinned area to become bigger than the visible area and to hide the unpinned columns as a result.
Multi-column headers and Multi-Row layouts - when resizing a child column, the parent column should also be resized. Same for when resizing the parent column – child column should adjust their sizes proportionally.
Users should be able to auto-size a column by double clicking on its resize handle, which is located in the right side of the column's header.
When the column is auto-sized it will take the size of the longest currently visible cell or header value.
The new size is constrained within the minWidth
and maxWidth
setting of the column and cannot go outside their bounds. For example, if the new size exceeds maxWidth
it will apply the specified maxWidth
instead.
After resizing completes the column will have an approximate width in percentage so that the column remains responsive. As the new size will be an approximation it may differ slightly from where the user drops the resize indicator.
Resizing is enabled per column, using the column's resizable
input. By default resizing is disabled.
<igx-column [field]="'ID'" width="100px" [resizable]="true"></igx-column>
Additionally, minWidth
and maxWidth
can be set to limit the allowed range within which the column can be resized.
<igx-column [field]="'ID'" width="100px" [resizable]="true" [minWidth]="'60px'" [maxWidth]="'230px'">
</igx-column>
Enabling resizing for a column also allows it to be auto-sized via the UI. Developers can also use the autosize
API method to manually auto-size a column.
All size related options - width
, minWidth
and maxWidth
, allow setting both pixel width, percentage width or a mix of both. For example, width can be set in percentage but have minWidth set in pixels:
<igx-column [field]="'ID'" width="20%" [resizable]="true" [minWidth]="'60px'">
</igx-column>
Resizing should still be limited within the specified bounds.
When resizing is enabled for a column a resize handle is rendered after the related column header. The handle shows a col-resize
style on hover to hint that it is a resizable element. This element can also be double-clicked in order to auto-size the column.
When that element is clicked and dragged a resize indicator is displayed at the current cursor location. This element determines the location to which the column will be resized once dropped.
When dropped, the resize indicator disappears and the column takes its new size.
Name | Description | Type | Default value | Valid values |
---|---|---|---|---|
resizable | Enables/Disables resizing for a column. | boolean | false | true, false |
minWidth | Sets the minimum allowed width when resizing the column. | string | '88px' | '100px', '10%' |
maxWidth | Sets the maximum allowed width when resizing the column. | string | null | '500px', '50%' |
Name | Description | Return type | Parameters |
---|---|---|---|
autoSize | Auto-sizes the column to the longest currently visible cell value, including the header cell. | void | null |
Name | Description | Cancelable | Parameters |
---|---|---|---|
onColumnResized | Emitted when column is resized. | No | IColumnResizeEventArgs |