Skip to content

Column Resizing

Maya edited this page Jun 16, 2020 · 14 revisions

Column Resizing Specification

Contents

  1. Overview
  2. User Stories
  3. Functionality
  4. User Interface
  5. API
  6. ARIA support
  7. Test Plan

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.

Objectives

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.

Resize 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.

Auto-size column

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.

Resizing/Auto-sizing columns with percentage width

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.

resizeUI

Column Options

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%'

Column Methods

Name Description Return type Parameters
autoSize Auto-sizes the column to the longest currently visible cell value, including the header cell. void null

Grid Events

Name Description Cancelable Parameters
onColumnResized Emitted when column is resized. No IColumnResizeEventArgs
Clone this wiki locally