td-stylekit 26.25.1 → 27.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,3 +1,15 @@
1
+ # [27.0.0](https://github.com/treasure-data/td-stylekit/compare/v26.25.1...v27.0.0) (2022-09-02)
2
+
3
+
4
+ ### Features
5
+
6
+ * **DataGrid:** Resizable columns ([#1323](https://github.com/treasure-data/td-stylekit/issues/1323)) ([ce69139](https://github.com/treasure-data/td-stylekit/commit/ce69139))
7
+
8
+
9
+ ### BREAKING CHANGES
10
+
11
+ * **DataGrid:** for v5 theme, add `isFirst` prop to any custom cell renderer in the first column to maintain padding.
12
+
1
13
  ## [26.25.1](https://github.com/treasure-data/td-stylekit/compare/v26.25.0...v26.25.1) (2022-09-01)
2
14
 
3
15
 
@@ -6,7 +6,7 @@ import * as Elements from './elements';
6
6
  import * as Renderers from './renderers';
7
7
  import { CollapsibleCell } from './components';
8
8
  import * as dataGridUtils from './utils';
9
- import type { BasicColumnMappedProps } from './components/BasicColumn';
9
+ import type { BasicColumnMappedProps, BasicColumnProps } from './components/BasicColumn';
10
10
  import type { LocaleStrings } from './constants';
11
11
  export declare type onFilterArguments = {
12
12
  filters: {
@@ -40,6 +40,9 @@ export declare type DataGridProps = {
40
40
  contextMenuRenderer?: (contextMenuRendererArguments: contextMenuRendererArguments) => React.ReactNode;
41
41
  /** Called when a column is filtered or sorted. */
42
42
  onFilter: (onFilterArguments: onFilterArguments) => void;
43
+ /** Called when a column is resized by the user. Passing this in enables
44
+ * resize handles on the right edge of the header cells. */
45
+ onResize?: (newSizes: number[]) => void;
43
46
  /** Called when the row selection changes. Receives array of indices. */
44
47
  onSelect: (indexes: number[]) => void;
45
48
  /** Called when the row is double clicked. Receives index. */
@@ -99,7 +102,7 @@ declare type HandleFilterArguments = {
99
102
  *
100
103
  */
101
104
  declare class DataGrid extends Component<DataGridProps, DataGridState> {
102
- static Column: import("lodash").CurriedFunction2<import("./components/BasicColumn").BasicColumnProps, BasicColumnMappedProps, import("@emotion/react/jsx-runtime").JSX.Element | null>;
105
+ static Column: import("lodash").CurriedFunction2<BasicColumnProps, BasicColumnMappedProps, import("@emotion/react/jsx-runtime").JSX.Element | null>;
103
106
  static SortDirection: import("react-virtualized/dist/es/Table").SortDirectionStatic;
104
107
  static Elements: typeof Elements;
105
108
  static InputCell: any;
@@ -107,6 +110,7 @@ declare class DataGrid extends Component<DataGridProps, DataGridState> {
107
110
  static Renderers: typeof Renderers;
108
111
  static SINGLE_SELECT: SelectableType;
109
112
  static MULTI_SELECT: SelectableType;
113
+ static MIN_COL_WIDTH: number;
110
114
  static utils: typeof dataGridUtils;
111
115
  static defaultProps: {
112
116
  loadMoreRows: (...args: any[]) => void;
@@ -122,6 +126,8 @@ declare class DataGrid extends Component<DataGridProps, DataGridState> {
122
126
  static displayName: string;
123
127
  state: DataGridState;
124
128
  infiniteTable: React.RefObject<InfiniteLoader>;
129
+ totalWidth: number;
130
+ columnWidthPercents: number[];
125
131
  columnTransformer: (columns: React.ReactElement<any>[], rowData: any, rowIndex: number) => React.ReactNode[] | null | undefined;
126
132
  select: ({ index, contiguous }: {
127
133
  index: number;
@@ -145,6 +151,10 @@ declare class DataGrid extends Component<DataGridProps, DataGridState> {
145
151
  event: React.MouseEvent<any>;
146
152
  index: number;
147
153
  }) => void>;
154
+ handleResize: ({ x, index }: {
155
+ x: number;
156
+ index: number;
157
+ }) => void;
148
158
  mapChildren: () => React.ReactNode[];
149
159
  isRowLoaded: ({ index }: Index) => boolean;
150
160
  isContextMenuVisible: (index: number) => boolean | null;
@@ -127,6 +127,10 @@ var DataGrid = /*#__PURE__*/function (_Component) {
127
127
 
128
128
  _defineProperty(_assertThisInitialized(_this), "infiniteTable", /*#__PURE__*/_react2["default"].createRef());
129
129
 
130
+ _defineProperty(_assertThisInitialized(_this), "totalWidth", 0);
131
+
132
+ _defineProperty(_assertThisInitialized(_this), "columnWidthPercents", []);
133
+
130
134
  _defineProperty(_assertThisInitialized(_this), "columnTransformer", void 0);
131
135
 
132
136
  _defineProperty(_assertThisInitialized(_this), "select", function (_ref) {
@@ -348,6 +352,45 @@ var DataGrid = /*#__PURE__*/function (_Component) {
348
352
  trailing: false
349
353
  }));
350
354
 
355
+ _defineProperty(_assertThisInitialized(_this), "handleResize", function (_ref6) {
356
+ var x = _ref6.x,
357
+ index = _ref6.index;
358
+
359
+ if (_this.columnWidthPercents.length > 0 && _this.totalWidth) {
360
+ var _this$props$scrollWid;
361
+
362
+ var prevWidths = _this.columnWidthPercents;
363
+
364
+ var newWidths = _toConsumableArray(prevWidths);
365
+
366
+ var parentWidth = (_this$props$scrollWid = _this.props.scrollWidth) !== null && _this$props$scrollWid !== void 0 ? _this$props$scrollWid : _this.props.width; // limit next index from going beyond bounds
367
+
368
+ var nextIndex = Math.min(index + 1, prevWidths.length - 1);
369
+ var percentChange = x / _this.totalWidth;
370
+
371
+ if (_this.props.scrollWidth) {
372
+ // if table is scrollable, we can grow the column without
373
+ // shrinking the others
374
+ var safePercentChange = (prevWidths[index] + percentChange) * parentWidth < DataGrid.MIN_COL_WIDTH ? 0 : percentChange;
375
+ newWidths[index] = prevWidths[index] + safePercentChange;
376
+ } else {
377
+ // if the table is not scrollable, ensure all columns fit by
378
+ // adjusting the current column and the one after it
379
+ var _safePercentChange = (prevWidths[index] + percentChange) * parentWidth < DataGrid.MIN_COL_WIDTH || (prevWidths[nextIndex] - percentChange) * parentWidth < DataGrid.MIN_COL_WIDTH ? 0 : percentChange;
380
+
381
+ newWidths[index] = prevWidths[index] + _safePercentChange;
382
+ newWidths[nextIndex] = prevWidths[nextIndex] - _safePercentChange;
383
+ }
384
+
385
+ if (_this.props.onResize) {
386
+ _this.props.onResize( // multiply by width prop to get correct percentage
387
+ newWidths.map(function (width) {
388
+ return Math.round(width * parentWidth);
389
+ }));
390
+ }
391
+ }
392
+ });
393
+
351
394
  _defineProperty(_assertThisInitialized(_this), "mapChildren", function () {
352
395
  var IsArray = function IsArray(children) {
353
396
  return Array.isArray(children);
@@ -376,10 +419,10 @@ var DataGrid = /*#__PURE__*/function (_Component) {
376
419
 
377
420
  _this.handleFilter(_objectSpread({}, sortArgs));
378
421
  },
379
- onFilter: function onFilter(_ref6) {
380
- var dataKey = _ref6.dataKey,
381
- value = _ref6.value,
382
- operator = _ref6.operator;
422
+ onFilter: function onFilter(_ref7) {
423
+ var dataKey = _ref7.dataKey,
424
+ value = _ref7.value,
425
+ operator = _ref7.operator;
383
426
 
384
427
  _this.setSelectedRows([]);
385
428
 
@@ -389,13 +432,24 @@ var DataGrid = /*#__PURE__*/function (_Component) {
389
432
  operator: operator
390
433
  } : value)
391
434
  });
392
- }
435
+ },
436
+ onResize: // the presence of `onResize` will show drag handles so don't set it
437
+ // if no prop is passed in or for the last column if the table isn't
438
+ // scrollable
439
+ _this.props.onResize && (!_this.props.scrollWidth && index !== validChildren.length - 1 || _this.props.scrollWidth) ? function (_ref8) {
440
+ var x = _ref8.x;
441
+
442
+ _this.handleResize({
443
+ x: x,
444
+ index: index
445
+ });
446
+ } : undefined
393
447
  });
394
448
  });
395
449
  });
396
450
 
397
- _defineProperty(_assertThisInitialized(_this), "isRowLoaded", function (_ref7) {
398
- var index = _ref7.index;
451
+ _defineProperty(_assertThisInitialized(_this), "isRowLoaded", function (_ref9) {
452
+ var index = _ref9.index;
399
453
  var _this$props2 = _this.props,
400
454
  hasMoreRows = _this$props2.hasMoreRows,
401
455
  rowCount = _this$props2.rowCount;
@@ -432,9 +486,9 @@ var DataGrid = /*#__PURE__*/function (_Component) {
432
486
  return null;
433
487
  });
434
488
 
435
- _defineProperty(_assertThisInitialized(_this), "headerRowRenderer", function (_ref8) {
436
- var columns = _ref8.columns,
437
- style = _ref8.style;
489
+ _defineProperty(_assertThisInitialized(_this), "headerRowRenderer", function (_ref10) {
490
+ var columns = _ref10.columns,
491
+ style = _ref10.style;
438
492
  return (0, _jsxRuntime.jsx)(Elements.Row, {
439
493
  "data-gs-c": gsC(columns),
440
494
  "data-gs": gs("src", "datagrid", "datagrid.tsx", "data-grid", "elements-row"),
@@ -446,15 +500,15 @@ var DataGrid = /*#__PURE__*/function (_Component) {
446
500
  });
447
501
  });
448
502
 
449
- _defineProperty(_assertThisInitialized(_this), "rowRenderer", function (_ref9) {
450
- var key = _ref9.key,
451
- style = _ref9.style,
452
- index = _ref9.index,
453
- rowData = _ref9.rowData,
454
- columns = _ref9.columns,
455
- className = _ref9.className,
456
- onRowMouseOver = _ref9.onRowMouseOver,
457
- onRowMouseOut = _ref9.onRowMouseOut;
503
+ _defineProperty(_assertThisInitialized(_this), "rowRenderer", function (_ref11) {
504
+ var key = _ref11.key,
505
+ style = _ref11.style,
506
+ index = _ref11.index,
507
+ rowData = _ref11.rowData,
508
+ columns = _ref11.columns,
509
+ className = _ref11.className,
510
+ onRowMouseOver = _ref11.onRowMouseOver,
511
+ onRowMouseOut = _ref11.onRowMouseOut;
458
512
  return (0, _jsxRuntime.jsxs)(_components.FocusableRow, {
459
513
  "data-gs": gs("src", "datagrid", "datagrid.tsx", "data-grid", "focusable-row"),
460
514
  className: className,
@@ -562,6 +616,17 @@ var DataGrid = /*#__PURE__*/function (_Component) {
562
616
  width: child.props.width,
563
617
  flexGrow: child.props.flexGrow
564
618
  };
619
+ }); // Get the actual width of all the columns. This is independent from the
620
+ // width prop.
621
+
622
+ this.totalWidth = mappedChildren.reduce(function (total, child) {
623
+ return total + child.props.width;
624
+ }, 0); // Convert the widths to percents so we can map them back to the real table
625
+ // width later.
626
+
627
+ this.columnWidthPercents = mappedChildren.map(function (_ref12) {
628
+ var props = _ref12.props;
629
+ return props.width / _this2.totalWidth;
565
630
  });
566
631
 
567
632
  this.columnTransformer = function (columns, rowData, rowIndex) {
@@ -578,13 +643,13 @@ var DataGrid = /*#__PURE__*/function (_Component) {
578
643
  if (span > 1) {
579
644
  var followingColumns = spanData.slice(index, span); // find new width by adding current column width plus columns that are spanned over
580
645
 
581
- var _width = followingColumns.reduce(function (accumulator, _ref10) {
582
- var width = _ref10.width;
646
+ var _width = followingColumns.reduce(function (accumulator, _ref13) {
647
+ var width = _ref13.width;
583
648
  return accumulator + width;
584
649
  }, 0);
585
650
 
586
- var flexGrow = followingColumns.reduce(function (accumulator, _ref11) {
587
- var flexGrow = _ref11.flexGrow;
651
+ var flexGrow = followingColumns.reduce(function (accumulator, _ref14) {
652
+ var flexGrow = _ref14.flexGrow;
588
653
  return accumulator + flexGrow;
589
654
  }, 0);
590
655
  spannedColumns.push( /*#__PURE__*/_react2["default"].cloneElement(column, {
@@ -612,14 +677,14 @@ var DataGrid = /*#__PURE__*/function (_Component) {
612
677
  css: /*#__PURE__*/(0, _react.css)({
613
678
  width: width,
614
679
  height: height
615
- }, process.env.NODE_ENV === "production" ? "" : ";label:render;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/DataGrid.tsx"],"names":[],"mappings":"AAylBQ","file":"../../../src/DataGrid/DataGrid.tsx","sourcesContent":["import React, { Component } from 'react'\nimport ReactDOM from 'react-dom'\nimport {\n  InfiniteLoader,\n  Table,\n  SortDirection,\n  TableRowProps\n} from 'react-virtualized'\nimport type {\n  SortDirectionType,\n  TableProps,\n  IndexRange,\n  Index,\n  RowMouseEventHandlerParams\n} from 'react-virtualized'\nimport * as Elements from './elements'\nimport * as Renderers from './renderers'\nimport {\n  BasicColumn,\n  FocusableRow,\n  InputCell,\n  CollapsibleCell,\n  ScrollableTable\n} from './components'\nimport { CloseWrapper } from '../utils'\nimport curry from 'lodash.curry'\nimport includes from 'lodash.includes'\nimport noop from 'lodash.noop'\nimport range from 'lodash.range'\nimport throttle from 'lodash.throttle'\nimport uniq from 'lodash.uniq'\nimport * as dataGridUtils from './utils'\nimport type { BasicColumnMappedProps } from './components/BasicColumn'\nimport type { LocaleStrings } from './constants'\n\nexport type onFilterArguments = {\n  filters: { [dataKey: string]: any }\n  sortBy?: string\n  sortDirection?: SortDirectionType\n}\n\ntype activeContextMenuState = {\n  top: number\n  left: number\n  index: number\n  rowData: any\n}\n\ntype contextMenuRendererArguments = {\n  top?: number\n  left?: number\n  index?: number\n  rowData?: any\n  selectedRows: Array<number>\n  onClose: () => void\n}\n\nexport type SelectableType = 'single' | 'multi'\n\ntype ColumnFunction = (args: BasicColumnMappedProps) => React.ReactNode\n\nexport type DataGridProps = {\n  /** Functions that create react virtualized Columns. Default column is exposed as DataGrid.Column. */\n  // Can take a single column or an array of columns\n  children: ColumnFunction | Array<ColumnFunction>\n  /** Instrumentation */\n  'data-instrumentation'?: string\n  /** Called during the onContextMenu event of each row. */\n  contextMenuRenderer?: (\n    contextMenuRendererArguments: contextMenuRendererArguments\n  ) => React.ReactNode\n  /** Called when a column is filtered or sorted. */\n  onFilter: (onFilterArguments: onFilterArguments) => void\n  /** Called when the row selection changes. Receives array of indices. */\n  onSelect: (indexes: number[]) => void\n  /** Called when the row is double clicked. Receives index. */\n  onRowDoubleClick?: (info: RowMouseEventHandlerParams) => void\n  /** Infinite loading: Indicates more rows need to be loaded. */\n  hasMoreRows?: boolean\n  /** Infinite loading: Called when more rows need to be loaded. */\n  loadMoreRows?: (props: IndexRange) => Promise<any>\n  /** Count of rows that have already been loaded. */\n  rowCount: number\n  /** Required by react-virtualized table. */\n  rowGetter: (props: { index: number }) => any\n  /** Whether rows can be selected (and how many). */\n  selectable?: SelectableType | false\n  /** Array of indices that should be selected. Only used if `selectable` is set. */\n  selectedRows: Array<number>\n  /** The column you want to sort */\n  sortBy?: string\n  /** The direction sorting should be done */\n  sortDirection?: SortDirectionType\n  /** A map of columns to filter data */\n  filters?: { [dataKey: string]: any }\n  /** Set the width of scrollable content */\n  scrollWidth?: number\n  width: number\n  height: number\n  /** Locale string: ja, de, es, ko, en, etc. */\n  locale?: string\n  /** Locale strings to override en for language in locale */\n  localeStrings?: LocaleStrings\n  /** allow events to propagate to a cell on row select */\n  allowRowEventPassthrough?: boolean\n} & Partial<TableProps>\n\ntype DataGridState = {\n  activeContextMenu: activeContextMenuState | null\n  disableKeyboardShortcuts: boolean\n  focusedRow: number | null\n  selecting: boolean\n  lastSelectedRow: number | null\n}\n\ntype HandleFilterArguments = {\n  sortBy?: string\n  sortDirection?: SortDirectionType\n  filters?: any\n}\n\n/**\n * Component for displaying data in a grid with support for things like\n * filtering, sorting, and context menus.\n *\n * Depends on react-virtualized/styles.css.\n *\n * For react-virtualized Table docs see: https://github.com/bvaughn/react-virtualized/blob/master/docs/Table.md\n *\n */\nclass DataGrid extends Component<DataGridProps, DataGridState> {\n  // expose sub-components\n  static Column = curry(BasicColumn)\n  static SortDirection = SortDirection\n  static Elements = Elements\n  static InputCell = InputCell\n  static CollapsibleCell = CollapsibleCell\n  static Renderers = Renderers\n\n  static SINGLE_SELECT: SelectableType = 'single'\n  static MULTI_SELECT: SelectableType = 'multi'\n\n  static utils = dataGridUtils\n\n  static defaultProps = {\n    loadMoreRows: noop,\n    onSelect: noop,\n    onFilter: noop,\n    'data-instrumentation': 'datagrid',\n    sortBy: '',\n    sortDirection: SortDirection.ASC,\n    filters: {},\n    selectedRows: [],\n    allowRowEventPassthrough: false\n  }\n\n  static displayName = 'DataGrid'\n\n  state: DataGridState = {\n    activeContextMenu: null,\n    disableKeyboardShortcuts: false,\n    focusedRow: null,\n    lastSelectedRow: null,\n    selecting: false\n  }\n\n  infiniteTable = React.createRef<InfiniteLoader>()\n\n  columnTransformer: (\n    columns: React.ReactElement<any>[],\n    rowData: any,\n    rowIndex: number\n  ) => React.ReactNode[] | null | undefined\n\n  select = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const { selectedRows } = this.props\n      let selected = [...selectedRows, index]\n      if (this.props.selectable === DataGrid.SINGLE_SELECT) {\n        selected = [index]\n      } else if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        selected = uniq([...selectedRows, ...range(start, end + 1)])\n      }\n      this.props.onSelect(selected)\n      return { lastSelectedRow: index }\n    })\n  }\n\n  selectAll = () => {\n    const { rowCount } = this.props\n    this.setSelectedRows(Array.from({ length: rowCount }).map((_, idx) => idx))\n  }\n\n  deselect = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const { selectedRows } = this.props\n      let selected = selectedRows.filter(idx => idx !== index)\n      if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        const toDeselect = range(start, end + 1)\n        selected = selectedRows.filter(idx => !includes(toDeselect, idx))\n      }\n      if (\n        this.props.selectable === DataGrid.SINGLE_SELECT &&\n        !selected.length\n      ) {\n        return null\n      }\n      this.props.onSelect(selected)\n      return { lastSelectedRow: index }\n    })\n  }\n\n  deselectAll = () => {\n    this.setSelectedRows([])\n    this.setState({\n      lastSelectedRow: null\n    })\n  }\n\n  toggleSelect = ({\n    index,\n    contiguous\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    if (!this.props.selectedRows.includes(index)) {\n      this.select({ index, contiguous })\n    } else {\n      this.deselect({ index, contiguous })\n    }\n  }\n\n  setSelectedRows = (rows: Array<number>) => {\n    this.props.onSelect(rows)\n  }\n\n  handleFilter = ({\n    sortBy,\n    sortDirection,\n    filters\n  }: HandleFilterArguments) => {\n    const {\n      sortBy: oldSortBy,\n      sortDirection: oldSortDirection,\n      filters: oldFilters\n    } = this.props\n    const newData = {\n      sortBy: sortBy || oldSortBy,\n      sortDirection: sortDirection || oldSortDirection,\n      filters: {\n        ...oldFilters,\n        ...filters\n      }\n    }\n    this.props.onFilter(newData)\n  }\n\n  handleKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'a':\n        if (\n          (event.metaKey || event.ctrlKey) &&\n          this.props.selectable === DataGrid.MULTI_SELECT\n        ) {\n          event.preventDefault()\n          if (this.props.rowCount === this.props.selectedRows.length) {\n            this.deselectAll()\n          } else {\n            this.selectAll()\n          }\n        }\n        break\n      case 'ArrowUp':\n        this.setState(state => ({\n          focusedRow: Math.max((state.focusedRow || 0) - 1, 0)\n        }))\n        event.preventDefault()\n        break\n      case 'ArrowDown':\n        this.setState(state => ({\n          focusedRow:\n            state.focusedRow != null\n              ? Math.min(state.focusedRow + 1, this.props.rowCount - 1)\n              : 0\n        }))\n        event.preventDefault()\n        break\n      case 'Enter':\n      case ' ':\n        if (this.props.selectable) {\n          this.toggleSelect({\n            index: this.state.focusedRow || 0,\n            contiguous: event.shiftKey\n          })\n        }\n        event.preventDefault()\n        break\n      case 'Shift':\n        this.setState({\n          selecting: true\n        })\n        break\n    }\n  }\n\n  handleKeyUp = (event: React.KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'Shift':\n        this.setState({\n          selecting: false\n        })\n        break\n    }\n  }\n\n  // throttling this so a double click behaves like a single click\n  handleRowClick = throttle(\n    ({ event, index }: { event: React.MouseEvent<any>; index: number }) => {\n      if (!this.props.allowRowEventPassthrough) {\n        event.stopPropagation()\n      }\n\n      this.toggleSelect({ index, contiguous: event.shiftKey })\n    },\n    250,\n    { leading: true, trailing: false }\n  )\n\n  mapChildren = () => {\n    const IsArray = (children): children is Array<ColumnFunction> =>\n      Array.isArray(children)\n\n    const children: Array<ColumnFunction> = IsArray(this.props.children)\n      ? this.props.children\n      : [this.props.children]\n\n    const validChildren = children.filter(child => typeof child === 'function')\n\n    return validChildren.map((child, index) =>\n      child({\n        locale: this.props.locale || 'en',\n        localeStrings: this.props.localeStrings || {},\n        columnIndex: index,\n        columnCount: validChildren.length,\n        getFilterValue: dataKey =>\n          this.props.filters && this.props.filters[dataKey],\n        onHeaderPopoverOpen: open =>\n          this.setState({ disableKeyboardShortcuts: open }),\n        onSort: sortArgs => {\n          this.setSelectedRows([])\n          this.handleFilter({ ...sortArgs })\n        },\n        onFilter: ({ dataKey, value, operator }) => {\n          this.setSelectedRows([])\n          this.handleFilter({\n            filters: {\n              [dataKey]: operator\n                ? {\n                    value,\n                    operator\n                  }\n                : value\n            }\n          })\n        }\n      })\n    )\n  }\n\n  isRowLoaded = ({ index }: Index) => {\n    const { hasMoreRows, rowCount } = this.props\n    return !hasMoreRows || index < rowCount\n  }\n\n  isContextMenuVisible = (index: number) =>\n    this.state.activeContextMenu && this.state.activeContextMenu.index === index\n\n  closeContextMenu = () => {\n    this.setState({\n      activeContextMenu: null\n    })\n  }\n\n  contextMenuRenderer = (index: number) => {\n    if (\n      this.props.contextMenuRenderer &&\n      this.isContextMenuVisible(index) &&\n      document.body !== null\n    ) {\n      const contextMenuCloseWrapper = (\n        <CloseWrapper onClose={this.closeContextMenu}>\n          {this.props.contextMenuRenderer({\n            ...this.state.activeContextMenu,\n            selectedRows: this.props.selectedRows,\n            onClose: this.closeContextMenu\n          })}\n        </CloseWrapper>\n      )\n      return ReactDOM.createPortal(contextMenuCloseWrapper, document.body)\n    }\n    return null\n  }\n\n  headerRowRenderer = ({\n    columns,\n    style\n  }: {\n    columns: React.ReactNode[]\n    style: {}\n  }) => (\n    <Elements.Row role=\"row\" header zebra style={style}>\n      {columns}\n    </Elements.Row>\n  )\n\n  rowRenderer = ({\n    key,\n    style,\n    index,\n    rowData,\n    columns,\n    className,\n    onRowMouseOver,\n    onRowMouseOut\n  }: TableRowProps) => (\n    <FocusableRow\n      className={className}\n      aria-rowindex={index + 1}\n      zebra={index % 2 === 1}\n      selected={this.props.selectedRows.includes(index)}\n      selecting={this.state.selecting}\n      focused={index === this.state.focusedRow}\n      key={key}\n      style={style}\n      onMouseLeave={event => {\n        onRowMouseOut && onRowMouseOut({ rowData, index, event })\n      }}\n      onMouseEnter={event => {\n        onRowMouseOver && onRowMouseOver({ rowData, index, event })\n      }}\n      onFocus={() => this.setState({ focusedRow: index })}\n      data-instrumentation={`${this.props['data-instrumentation']}-row${\n        index + 1\n      }`}\n      onClick={\n        this.props.selectable && !this.state.activeContextMenu\n          ? event => this.handleRowClick({ event, index: index })\n          : undefined\n      }\n      onContextMenu={\n        this.props.contextMenuRenderer\n          ? event => {\n              this.setState({\n                activeContextMenu: {\n                  left: event.clientX,\n                  top: event.clientY,\n                  index: index,\n                  rowData: rowData\n                }\n              })\n              if (\n                !this.props.selectedRows.includes(index) &&\n                this.props.selectable\n              ) {\n                this.handleRowClick({ event, index: index })\n              }\n              event.preventDefault()\n            }\n          : undefined\n      }\n      onDoubleClick={event =>\n        this.props.onRowDoubleClick &&\n        this.props.onRowDoubleClick({ index, event, rowData })\n      }\n    >\n      {this.columnTransformer\n        ? this.columnTransformer(columns, rowData, index)\n        : columns}\n      {this.contextMenuRenderer(index)}\n    </FocusableRow>\n  )\n\n  /**\n   *  @typescript-eslint/no-unused-vars is added because even though the props are not used in this component\n   * they are getting destructured into ...props and passed further down the tree\n   */\n  render() {\n    const {\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      children,\n      hasMoreRows,\n      height,\n      loadMoreRows,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      onFilter,\n      rowCount,\n      sortBy = '',\n      sortDirection,\n      width,\n      ...props\n    } = this.props\n\n    // This fixes an issue where the header of the DataGrid doesn't render on page load in Safari\n    const safariStyle = {\n      transform: `translateZ(0)`\n    }\n\n    const mappedChildren = this.mapChildren().filter(child => child !== null)\n    // TODO: Better type signature when accessing children props?\n    const spanData = mappedChildren.map((child: React.ReactElement) => ({\n      colspan: child.props.colspan ? child.props.colspan : () => 1,\n      width: child.props.width,\n      flexGrow: child.props.flexGrow\n    }))\n    this.columnTransformer = (\n      columns: React.ReactElement<any>[],\n      rowData,\n      rowIndex\n    ) => {\n      const spans = spanData.map(item => item.colspan(rowData))\n      const spannedColumns: React.ReactElement[] = []\n      let index = 0\n      while (index < columns.length) {\n        const span = spans[index]\n        const column = columns[index]\n        if (span > 1) {\n          const followingColumns = spanData.slice(index, span)\n          // find new width by adding current column width plus columns that are spanned over\n\n          const width = followingColumns.reduce(\n            (accumulator, { width }: { width: number }) => accumulator + width,\n            0\n          )\n\n          const flexGrow = followingColumns.reduce(\n            (accumulator, { flexGrow }: { flexGrow: number }) =>\n              accumulator + flexGrow,\n            0\n          )\n          spannedColumns.push(\n            React.cloneElement(column, {\n              'data-instrumentation': `${this.props['data-instrumentation']}-row${rowIndex}-col${index}`,\n              style: {\n                ...Elements.cellResetStyle,\n                flex: `0 1 ${width}px`,\n                flexGrow\n              }\n            })\n          )\n          index += span // skip columns that have been spanned over\n        } else {\n          spannedColumns.push(\n            React.cloneElement(column, {\n              'data-instrumentation': `${this.props['data-instrumentation']}-row${rowIndex}-col${index}`\n            })\n          )\n          index++\n        }\n      }\n      return spannedColumns\n    }\n\n    const TableComponent =\n      this.props.scrollWidth !== undefined ? ScrollableTable : Table\n\n    return (\n      <Elements.TableContainer\n        css={{ width, height }}\n        onKeyDown={this.handleKeyDown}\n        onKeyUp={this.handleKeyUp}\n        data-instrumentation={`${this.props['data-instrumentation']}-grid`}\n      >\n        <InfiniteLoader\n          isRowLoaded={this.isRowLoaded}\n          loadMoreRows={loadMoreRows || (() => Promise.resolve(false))}\n          rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n          threshold={5}\n          ref={this.infiniteTable}\n        >\n          {({ onRowsRendered, registerChild }) => (\n            <TableComponent\n              style={safariStyle}\n              gridStyle={{ outline: 'none' }}\n              headerHeight={36}\n              rowHeight={30}\n              sortBy={sortBy}\n              sortDirection={sortDirection}\n              ref={registerChild}\n              noRowsRendered={() => <div>No results</div>}\n              onRowsRendered={onRowsRendered}\n              onScroll={\n                this.state.activeContextMenu\n                  ? () => this.closeContextMenu()\n                  : undefined\n              }\n              rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n              headerRowRenderer={this.headerRowRenderer}\n              rowRenderer={this.rowRenderer}\n              // account for border width of container\n              width={width - 2}\n              height={height - 2}\n              {...props}\n            >\n              {mappedChildren}\n            </TableComponent>\n          )}\n        </InfiniteLoader>\n      </Elements.TableContainer>\n    )\n  }\n}\n\nexport default DataGrid\n"]} */"),
680
+ }, process.env.NODE_ENV === "production" ? "" : ";label:render;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/DataGrid.tsx"],"names":[],"mappings":"AAoqBQ","file":"../../../src/DataGrid/DataGrid.tsx","sourcesContent":["import React, { Component } from 'react'\nimport ReactDOM from 'react-dom'\nimport {\n  InfiniteLoader,\n  Table,\n  SortDirection,\n  TableRowProps\n} from 'react-virtualized'\nimport type {\n  SortDirectionType,\n  TableProps,\n  IndexRange,\n  Index,\n  RowMouseEventHandlerParams\n} from 'react-virtualized'\nimport * as Elements from './elements'\nimport * as Renderers from './renderers'\nimport {\n  BasicColumn,\n  FocusableRow,\n  InputCell,\n  CollapsibleCell,\n  ScrollableTable\n} from './components'\nimport { CloseWrapper } from '../utils'\nimport curry from 'lodash.curry'\nimport includes from 'lodash.includes'\nimport noop from 'lodash.noop'\nimport range from 'lodash.range'\nimport throttle from 'lodash.throttle'\nimport uniq from 'lodash.uniq'\nimport * as dataGridUtils from './utils'\nimport type {\n  BasicColumnMappedProps,\n  BasicColumnProps\n} from './components/BasicColumn'\nimport type { LocaleStrings } from './constants'\n\nexport type onFilterArguments = {\n  filters: { [dataKey: string]: any }\n  sortBy?: string\n  sortDirection?: SortDirectionType\n}\n\ntype activeContextMenuState = {\n  top: number\n  left: number\n  index: number\n  rowData: any\n}\n\ntype contextMenuRendererArguments = {\n  top?: number\n  left?: number\n  index?: number\n  rowData?: any\n  selectedRows: Array<number>\n  onClose: () => void\n}\n\nexport type SelectableType = 'single' | 'multi'\n\ntype ColumnFunction = (args: BasicColumnMappedProps) => React.ReactNode\n\nexport type DataGridProps = {\n  /** Functions that create react virtualized Columns. Default column is exposed as DataGrid.Column. */\n  // Can take a single column or an array of columns\n  children: ColumnFunction | Array<ColumnFunction>\n  /** Instrumentation */\n  'data-instrumentation'?: string\n  /** Called during the onContextMenu event of each row. */\n  contextMenuRenderer?: (\n    contextMenuRendererArguments: contextMenuRendererArguments\n  ) => React.ReactNode\n  /** Called when a column is filtered or sorted. */\n  onFilter: (onFilterArguments: onFilterArguments) => void\n  /** Called when a column is resized by the user. Passing this in enables\n   * resize handles on the right edge of the header cells. */\n  onResize?: (newSizes: number[]) => void\n  /** Called when the row selection changes. Receives array of indices. */\n  onSelect: (indexes: number[]) => void\n  /** Called when the row is double clicked. Receives index. */\n  onRowDoubleClick?: (info: RowMouseEventHandlerParams) => void\n  /** Infinite loading: Indicates more rows need to be loaded. */\n  hasMoreRows?: boolean\n  /** Infinite loading: Called when more rows need to be loaded. */\n  loadMoreRows?: (props: IndexRange) => Promise<any>\n  /** Count of rows that have already been loaded. */\n  rowCount: number\n  /** Required by react-virtualized table. */\n  rowGetter: (props: { index: number }) => any\n  /** Whether rows can be selected (and how many). */\n  selectable?: SelectableType | false\n  /** Array of indices that should be selected. Only used if `selectable` is set. */\n  selectedRows: Array<number>\n  /** The column you want to sort */\n  sortBy?: string\n  /** The direction sorting should be done */\n  sortDirection?: SortDirectionType\n  /** A map of columns to filter data */\n  filters?: { [dataKey: string]: any }\n  /** Set the width of scrollable content */\n  scrollWidth?: number\n  width: number\n  height: number\n  /** Locale string: ja, de, es, ko, en, etc. */\n  locale?: string\n  /** Locale strings to override en for language in locale */\n  localeStrings?: LocaleStrings\n  /** allow events to propagate to a cell on row select */\n  allowRowEventPassthrough?: boolean\n} & Partial<TableProps>\n\ntype DataGridState = {\n  activeContextMenu: activeContextMenuState | null\n  disableKeyboardShortcuts: boolean\n  focusedRow: number | null\n  selecting: boolean\n  lastSelectedRow: number | null\n}\n\ntype HandleFilterArguments = {\n  sortBy?: string\n  sortDirection?: SortDirectionType\n  filters?: any\n}\n\n/**\n * Component for displaying data in a grid with support for things like\n * filtering, sorting, and context menus.\n *\n * Depends on react-virtualized/styles.css.\n *\n * For react-virtualized Table docs see: https://github.com/bvaughn/react-virtualized/blob/master/docs/Table.md\n *\n */\nclass DataGrid extends Component<DataGridProps, DataGridState> {\n  // expose sub-components\n  static Column = curry(BasicColumn)\n  static SortDirection = SortDirection\n  static Elements = Elements\n  static InputCell = InputCell\n  static CollapsibleCell = CollapsibleCell\n  static Renderers = Renderers\n\n  static SINGLE_SELECT: SelectableType = 'single'\n  static MULTI_SELECT: SelectableType = 'multi'\n  static MIN_COL_WIDTH = 50\n\n  static utils = dataGridUtils\n\n  static defaultProps = {\n    loadMoreRows: noop,\n    onSelect: noop,\n    onFilter: noop,\n    'data-instrumentation': 'datagrid',\n    sortBy: '',\n    sortDirection: SortDirection.ASC,\n    filters: {},\n    selectedRows: [],\n    allowRowEventPassthrough: false\n  }\n\n  static displayName = 'DataGrid'\n\n  state: DataGridState = {\n    activeContextMenu: null,\n    disableKeyboardShortcuts: false,\n    focusedRow: null,\n    lastSelectedRow: null,\n    selecting: false\n  }\n\n  infiniteTable = React.createRef<InfiniteLoader>()\n\n  totalWidth = 0\n  columnWidthPercents: number[] = []\n\n  columnTransformer: (\n    columns: React.ReactElement<any>[],\n    rowData: any,\n    rowIndex: number\n  ) => React.ReactNode[] | null | undefined\n\n  select = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const { selectedRows } = this.props\n      let selected = [...selectedRows, index]\n      if (this.props.selectable === DataGrid.SINGLE_SELECT) {\n        selected = [index]\n      } else if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        selected = uniq([...selectedRows, ...range(start, end + 1)])\n      }\n      this.props.onSelect(selected)\n      return { lastSelectedRow: index }\n    })\n  }\n\n  selectAll = () => {\n    const { rowCount } = this.props\n    this.setSelectedRows(Array.from({ length: rowCount }).map((_, idx) => idx))\n  }\n\n  deselect = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const { selectedRows } = this.props\n      let selected = selectedRows.filter(idx => idx !== index)\n      if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        const toDeselect = range(start, end + 1)\n        selected = selectedRows.filter(idx => !includes(toDeselect, idx))\n      }\n      if (\n        this.props.selectable === DataGrid.SINGLE_SELECT &&\n        !selected.length\n      ) {\n        return null\n      }\n      this.props.onSelect(selected)\n      return { lastSelectedRow: index }\n    })\n  }\n\n  deselectAll = () => {\n    this.setSelectedRows([])\n    this.setState({\n      lastSelectedRow: null\n    })\n  }\n\n  toggleSelect = ({\n    index,\n    contiguous\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    if (!this.props.selectedRows.includes(index)) {\n      this.select({ index, contiguous })\n    } else {\n      this.deselect({ index, contiguous })\n    }\n  }\n\n  setSelectedRows = (rows: Array<number>) => {\n    this.props.onSelect(rows)\n  }\n\n  handleFilter = ({\n    sortBy,\n    sortDirection,\n    filters\n  }: HandleFilterArguments) => {\n    const {\n      sortBy: oldSortBy,\n      sortDirection: oldSortDirection,\n      filters: oldFilters\n    } = this.props\n    const newData = {\n      sortBy: sortBy || oldSortBy,\n      sortDirection: sortDirection || oldSortDirection,\n      filters: {\n        ...oldFilters,\n        ...filters\n      }\n    }\n    this.props.onFilter(newData)\n  }\n\n  handleKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'a':\n        if (\n          (event.metaKey || event.ctrlKey) &&\n          this.props.selectable === DataGrid.MULTI_SELECT\n        ) {\n          event.preventDefault()\n          if (this.props.rowCount === this.props.selectedRows.length) {\n            this.deselectAll()\n          } else {\n            this.selectAll()\n          }\n        }\n        break\n      case 'ArrowUp':\n        this.setState(state => ({\n          focusedRow: Math.max((state.focusedRow || 0) - 1, 0)\n        }))\n        event.preventDefault()\n        break\n      case 'ArrowDown':\n        this.setState(state => ({\n          focusedRow:\n            state.focusedRow != null\n              ? Math.min(state.focusedRow + 1, this.props.rowCount - 1)\n              : 0\n        }))\n        event.preventDefault()\n        break\n      case 'Enter':\n      case ' ':\n        if (this.props.selectable) {\n          this.toggleSelect({\n            index: this.state.focusedRow || 0,\n            contiguous: event.shiftKey\n          })\n        }\n        event.preventDefault()\n        break\n      case 'Shift':\n        this.setState({\n          selecting: true\n        })\n        break\n    }\n  }\n\n  handleKeyUp = (event: React.KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'Shift':\n        this.setState({\n          selecting: false\n        })\n        break\n    }\n  }\n\n  // throttling this so a double click behaves like a single click\n  handleRowClick = throttle(\n    ({ event, index }: { event: React.MouseEvent<any>; index: number }) => {\n      if (!this.props.allowRowEventPassthrough) {\n        event.stopPropagation()\n      }\n\n      this.toggleSelect({ index, contiguous: event.shiftKey })\n    },\n    250,\n    { leading: true, trailing: false }\n  )\n\n  handleResize = ({ x, index }: { x: number; index: number }) => {\n    if (this.columnWidthPercents.length > 0 && this.totalWidth) {\n      const prevWidths = this.columnWidthPercents\n      const newWidths = [...prevWidths]\n      const parentWidth = this.props.scrollWidth ?? this.props.width\n      // limit next index from going beyond bounds\n      const nextIndex = Math.min(index + 1, prevWidths.length - 1)\n      const percentChange = x / this.totalWidth\n\n      if (this.props.scrollWidth) {\n        // if table is scrollable, we can grow the column without\n        // shrinking the others\n        const safePercentChange =\n          (prevWidths[index] + percentChange) * parentWidth <\n          DataGrid.MIN_COL_WIDTH\n            ? 0\n            : percentChange\n        newWidths[index] = prevWidths[index] + safePercentChange\n      } else {\n        // if the table is not scrollable, ensure all columns fit by\n        // adjusting the current column and the one after it\n        const safePercentChange =\n          (prevWidths[index] + percentChange) * parentWidth <\n            DataGrid.MIN_COL_WIDTH ||\n          (prevWidths[nextIndex] - percentChange) * parentWidth <\n            DataGrid.MIN_COL_WIDTH\n            ? 0\n            : percentChange\n        newWidths[index] = prevWidths[index] + safePercentChange\n        newWidths[nextIndex] = prevWidths[nextIndex] - safePercentChange\n      }\n\n      if (this.props.onResize) {\n        this.props.onResize(\n          // multiply by width prop to get correct percentage\n          newWidths.map(width => Math.round(width * parentWidth))\n        )\n      }\n    }\n  }\n\n  mapChildren = () => {\n    const IsArray = (children): children is Array<ColumnFunction> =>\n      Array.isArray(children)\n\n    const children: Array<ColumnFunction> = IsArray(this.props.children)\n      ? this.props.children\n      : [this.props.children]\n\n    const validChildren = children.filter(child => typeof child === 'function')\n\n    return validChildren.map((child, index) =>\n      child({\n        locale: this.props.locale || 'en',\n        localeStrings: this.props.localeStrings || {},\n        columnIndex: index,\n        columnCount: validChildren.length,\n        getFilterValue: dataKey =>\n          this.props.filters && this.props.filters[dataKey],\n        onHeaderPopoverOpen: open =>\n          this.setState({ disableKeyboardShortcuts: open }),\n        onSort: sortArgs => {\n          this.setSelectedRows([])\n          this.handleFilter({ ...sortArgs })\n        },\n        onFilter: ({ dataKey, value, operator }) => {\n          this.setSelectedRows([])\n          this.handleFilter({\n            filters: {\n              [dataKey]: operator\n                ? {\n                    value,\n                    operator\n                  }\n                : value\n            }\n          })\n        },\n        onResize:\n          // the presence of `onResize` will show drag handles so don't set it\n          // if no prop is passed in or for the last column if the table isn't\n          // scrollable\n          this.props.onResize &&\n          ((!this.props.scrollWidth && index !== validChildren.length - 1) ||\n            this.props.scrollWidth)\n            ? ({ x }) => {\n                this.handleResize({ x, index })\n              }\n            : undefined\n      })\n    )\n  }\n\n  isRowLoaded = ({ index }: Index) => {\n    const { hasMoreRows, rowCount } = this.props\n    return !hasMoreRows || index < rowCount\n  }\n\n  isContextMenuVisible = (index: number) =>\n    this.state.activeContextMenu && this.state.activeContextMenu.index === index\n\n  closeContextMenu = () => {\n    this.setState({\n      activeContextMenu: null\n    })\n  }\n\n  contextMenuRenderer = (index: number) => {\n    if (\n      this.props.contextMenuRenderer &&\n      this.isContextMenuVisible(index) &&\n      document.body !== null\n    ) {\n      const contextMenuCloseWrapper = (\n        <CloseWrapper onClose={this.closeContextMenu}>\n          {this.props.contextMenuRenderer({\n            ...this.state.activeContextMenu,\n            selectedRows: this.props.selectedRows,\n            onClose: this.closeContextMenu\n          })}\n        </CloseWrapper>\n      )\n      return ReactDOM.createPortal(contextMenuCloseWrapper, document.body)\n    }\n    return null\n  }\n\n  headerRowRenderer = ({\n    columns,\n    style\n  }: {\n    columns: React.ReactNode[]\n    style: {}\n  }) => (\n    <Elements.Row role=\"row\" header zebra style={style}>\n      {columns}\n    </Elements.Row>\n  )\n\n  rowRenderer = ({\n    key,\n    style,\n    index,\n    rowData,\n    columns,\n    className,\n    onRowMouseOver,\n    onRowMouseOut\n  }: TableRowProps) => (\n    <FocusableRow\n      className={className}\n      aria-rowindex={index + 1}\n      zebra={index % 2 === 1}\n      selected={this.props.selectedRows.includes(index)}\n      selecting={this.state.selecting}\n      focused={index === this.state.focusedRow}\n      key={key}\n      style={style}\n      onMouseLeave={event => {\n        onRowMouseOut && onRowMouseOut({ rowData, index, event })\n      }}\n      onMouseEnter={event => {\n        onRowMouseOver && onRowMouseOver({ rowData, index, event })\n      }}\n      onFocus={() => this.setState({ focusedRow: index })}\n      data-instrumentation={`${this.props['data-instrumentation']}-row${\n        index + 1\n      }`}\n      onClick={\n        this.props.selectable && !this.state.activeContextMenu\n          ? event => this.handleRowClick({ event, index: index })\n          : undefined\n      }\n      onContextMenu={\n        this.props.contextMenuRenderer\n          ? event => {\n              this.setState({\n                activeContextMenu: {\n                  left: event.clientX,\n                  top: event.clientY,\n                  index: index,\n                  rowData: rowData\n                }\n              })\n              if (\n                !this.props.selectedRows.includes(index) &&\n                this.props.selectable\n              ) {\n                this.handleRowClick({ event, index: index })\n              }\n              event.preventDefault()\n            }\n          : undefined\n      }\n      onDoubleClick={event =>\n        this.props.onRowDoubleClick &&\n        this.props.onRowDoubleClick({ index, event, rowData })\n      }\n    >\n      {this.columnTransformer\n        ? this.columnTransformer(columns, rowData, index)\n        : columns}\n      {this.contextMenuRenderer(index)}\n    </FocusableRow>\n  )\n\n  /**\n   *  @typescript-eslint/no-unused-vars is added because even though the props are not used in this component\n   * they are getting destructured into ...props and passed further down the tree\n   */\n  render() {\n    const {\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      children,\n      hasMoreRows,\n      height,\n      loadMoreRows,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      onFilter,\n      rowCount,\n      sortBy = '',\n      sortDirection,\n      width,\n      ...props\n    } = this.props\n\n    // This fixes an issue where the header of the DataGrid doesn't render on page load in Safari\n    const safariStyle = {\n      transform: `translateZ(0)`\n    }\n\n    const mappedChildren = this.mapChildren().filter(child => child !== null)\n    // TODO: Better type signature when accessing children props?\n    const spanData = mappedChildren.map((child: React.ReactElement) => ({\n      colspan: child.props.colspan ? child.props.colspan : () => 1,\n      width: child.props.width,\n      flexGrow: child.props.flexGrow\n    }))\n    // Get the actual width of all the columns. This is independent from the\n    // width prop.\n    this.totalWidth = mappedChildren.reduce<number>(\n      (total: number, child: React.ReactElement<BasicColumnProps>) =>\n        total + child.props.width,\n      0\n    )\n    // Convert the widths to percents so we can map them back to the real table\n    // width later.\n    this.columnWidthPercents = mappedChildren.map(\n      ({ props }: React.ReactElement) => props.width / this.totalWidth\n    )\n\n    this.columnTransformer = (\n      columns: React.ReactElement<any>[],\n      rowData,\n      rowIndex\n    ) => {\n      const spans = spanData.map(item => item.colspan(rowData))\n      const spannedColumns: React.ReactElement[] = []\n      let index = 0\n      while (index < columns.length) {\n        const span = spans[index]\n        const column = columns[index]\n        if (span > 1) {\n          const followingColumns = spanData.slice(index, span)\n          // find new width by adding current column width plus columns that are spanned over\n\n          const width = followingColumns.reduce(\n            (accumulator, { width }: { width: number }) => accumulator + width,\n            0\n          )\n\n          const flexGrow = followingColumns.reduce(\n            (accumulator, { flexGrow }: { flexGrow: number }) =>\n              accumulator + flexGrow,\n            0\n          )\n          spannedColumns.push(\n            React.cloneElement(column, {\n              'data-instrumentation': `${this.props['data-instrumentation']}-row${rowIndex}-col${index}`,\n              style: {\n                ...Elements.cellResetStyle,\n                flex: `0 1 ${width}px`,\n                flexGrow\n              }\n            })\n          )\n          index += span // skip columns that have been spanned over\n        } else {\n          spannedColumns.push(\n            React.cloneElement(column, {\n              'data-instrumentation': `${this.props['data-instrumentation']}-row${rowIndex}-col${index}`\n            })\n          )\n          index++\n        }\n      }\n      return spannedColumns\n    }\n\n    const TableComponent =\n      this.props.scrollWidth !== undefined ? ScrollableTable : Table\n\n    return (\n      <Elements.TableContainer\n        css={{ width, height }}\n        onKeyDown={this.handleKeyDown}\n        onKeyUp={this.handleKeyUp}\n        data-instrumentation={`${this.props['data-instrumentation']}-grid`}\n      >\n        <InfiniteLoader\n          isRowLoaded={this.isRowLoaded}\n          loadMoreRows={loadMoreRows || (() => Promise.resolve(false))}\n          rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n          threshold={5}\n          ref={this.infiniteTable}\n        >\n          {({ onRowsRendered, registerChild }) => (\n            <TableComponent\n              style={safariStyle}\n              gridStyle={{ outline: 'none' }}\n              headerHeight={36}\n              rowHeight={30}\n              sortBy={sortBy}\n              sortDirection={sortDirection}\n              ref={registerChild}\n              noRowsRendered={() => <div>No results</div>}\n              onRowsRendered={onRowsRendered}\n              onScroll={\n                this.state.activeContextMenu\n                  ? () => this.closeContextMenu()\n                  : undefined\n              }\n              rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n              headerRowRenderer={this.headerRowRenderer}\n              rowRenderer={this.rowRenderer}\n              // account for border width of container\n              width={width - 2}\n              height={height - 2}\n              {...props}\n            >\n              {mappedChildren}\n            </TableComponent>\n          )}\n        </InfiniteLoader>\n      </Elements.TableContainer>\n    )\n  }\n}\n\nexport default DataGrid\n"]} */"),
616
681
  onKeyDown: this.handleKeyDown,
617
682
  onKeyUp: this.handleKeyUp,
618
683
  "data-instrumentation": "".concat(this.props['data-instrumentation'], "-grid"),
619
684
  children: (0, _jsxRuntime.jsx)(_reactVirtualized.InfiniteLoader, {
620
- "data-gs-c": gsC(function children(_ref12) {
621
- var onRowsRendered = _ref12.onRowsRendered,
622
- registerChild = _ref12.registerChild;
685
+ "data-gs-c": gsC(function children(_ref15) {
686
+ var onRowsRendered = _ref15.onRowsRendered,
687
+ registerChild = _ref15.registerChild;
623
688
  return (0, _jsxRuntime.jsx)(TableComponent, _objectSpread(_objectSpread({
624
689
  "data-gs-c": gsC(mappedChildren),
625
690
  "data-gs": gs("src", "datagrid", "datagrid.tsx", "elements-tablecontainer", "infinite-loader", "table-component"),
@@ -661,9 +726,9 @@ var DataGrid = /*#__PURE__*/function (_Component) {
661
726
  rowCount: hasMoreRows ? rowCount + 1 : rowCount,
662
727
  threshold: 5,
663
728
  ref: this.infiniteTable,
664
- children: function children(_ref12) {
665
- var onRowsRendered = _ref12.onRowsRendered,
666
- registerChild = _ref12.registerChild;
729
+ children: function children(_ref15) {
730
+ var onRowsRendered = _ref15.onRowsRendered,
731
+ registerChild = _ref15.registerChild;
667
732
  return (0, _jsxRuntime.jsx)(TableComponent, _objectSpread(_objectSpread({
668
733
  "data-gs-c": gsC(mappedChildren),
669
734
  "data-gs": gs("src", "datagrid", "datagrid.tsx", "elements-tablecontainer", "infinite-loader", "table-component"),
@@ -720,6 +785,8 @@ _defineProperty(DataGrid, "SINGLE_SELECT", 'single');
720
785
 
721
786
  _defineProperty(DataGrid, "MULTI_SELECT", 'multi');
722
787
 
788
+ _defineProperty(DataGrid, "MIN_COL_WIDTH", 50);
789
+
723
790
  _defineProperty(DataGrid, "utils", dataGridUtils);
724
791
 
725
792
  _defineProperty(DataGrid, "defaultProps", {
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
2
  import { ColumnProps, SortDirection } from 'react-virtualized';
3
- import type { filterRendererArguments, sortRendererArguments } from '../types';
3
+ import type { filterRendererArguments, sortRendererArguments, InternalResizeHandler } from '../types';
4
4
  import type { LocaleStrings } from '../constants';
5
5
  import type { Theme } from '@theme';
6
6
  import type { Interpolation } from '@emotion/react';
@@ -32,6 +32,7 @@ export declare type BasicColumnMappedProps = {
32
32
  sortBy: string;
33
33
  sortDirection: keyof typeof SortDirection;
34
34
  }) => void;
35
+ onResize?: InternalResizeHandler;
35
36
  };
36
37
  /**
37
38
  * Function that accepts two object arguments and returns a react-virtualized Column.
@@ -59,7 +59,8 @@ function BasicColumn(columnProps, mappedProps) {
59
59
  locale = _mappedProps$locale === void 0 ? 'en' : _mappedProps$locale,
60
60
  _mappedProps$localeSt = mappedProps.localeStrings,
61
61
  localeStrings = _mappedProps$localeSt === void 0 ? {} : _mappedProps$localeSt,
62
- onHeaderPopoverOpen = mappedProps.onHeaderPopoverOpen;
62
+ onHeaderPopoverOpen = mappedProps.onHeaderPopoverOpen,
63
+ onResize = mappedProps.onResize;
63
64
 
64
65
  if (columnProps.hideColumn) {
65
66
  return null;
@@ -69,6 +70,7 @@ function BasicColumn(columnProps, mappedProps) {
69
70
  return (0, _jsxRuntime.jsx)(_elements.Cell, {
70
71
  "data-gs": gs("src", "datagrid", "components", "basic-column", "cell"),
71
72
  rightAlign: typeof cellRendererProps.cellData === 'number',
73
+ isFirst: cellRendererProps.columnIndex === 0,
72
74
  isLast: cellRendererProps.columnIndex === columnCount - 1,
73
75
  children: (0, _jsxRuntime.jsx)(_RightTruncatedText["default"], {
74
76
  "data-gs": gs("src", "datagrid", "components", "basic-column", "cell", "right-truncated-text"),
@@ -86,6 +88,7 @@ function BasicColumn(columnProps, mappedProps) {
86
88
  "data-gs": gs("src", "datagrid", "components", "basic-column", "column-header"),
87
89
  dataKey: dataKey,
88
90
  isLast: columnCount - 1 === mappedProps.columnIndex,
91
+ isFirst: mappedProps.columnIndex === 0,
89
92
  label: label,
90
93
  showSortIndicator: !!sortRenderer && sortBy === dataKey,
91
94
  sortDirection: sortDirection,
@@ -109,6 +112,7 @@ function BasicColumn(columnProps, mappedProps) {
109
112
  operator: operator
110
113
  });
111
114
  },
115
+ onResize: onResize,
112
116
  filterRenderer: filterRenderer,
113
117
  sortBy: sortBy,
114
118
  sortRenderer: sortRenderer,
@@ -74,7 +74,7 @@ var CollapsibleIcon = ( /*#__PURE__*/0, _base["default"])(_Icon["default"].Mediu
74
74
  transition: 'transform 300ms',
75
75
  transform: expanded ? 'rotate(0)' : 'rotate(-90deg)'
76
76
  };
77
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.CollapsibleIcon), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9EYXRhR3JpZC9jb21wb25lbnRzL0NvbGxhcHNpYmxlQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYStCIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9EYXRhR3JpZC9jb21wb25lbnRzL0NvbGxhcHNpYmxlQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSB0ZC9pbnN0cnVtZW50YXRpb24gKi9cbi8vIHRoaXMgbGV2ZWwgb2YgZmluZSBncmFpbmVkIGluc3RydW1lbnRhdGlvbiBpcyBub3QgbmVlZGVkXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgSWNvbiBmcm9tICcuLi8uLi9JY29uJ1xuaW1wb3J0IHsgU3BhY2VyLCBDZWxsIH0gZnJvbSAnLi4vZWxlbWVudHMnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCBjbiBmcm9tICdjbGFzc25hbWVzJ1xuaW1wb3J0IHsgZ2V0T3ZlcnJpZGVzLCBPdmVycmlkYWJsZSB9IGZyb20gJy4uLy4uL1RoZW1lUHJvdmlkZXInXG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL0J1dHRvbidcblxudHlwZSBDb2xsYXBzaWJsZUljb25Qcm9wcyA9IHtcbiAgZXhwYW5kZWQ/OiBib29sZWFuXG59XG5leHBvcnQgY29uc3QgQ29sbGFwc2libGVJY29uID0gc3R5bGVkKEljb24uTWVkaXVtLlN5bWJvbEFycm93RG93bik8XG4gIENvbGxhcHNpYmxlSWNvblByb3BzXG4+KFxuICAoeyBleHBhbmRlZCwgdGhlbWUgfSkgPT4gKHtcbiAgICBjb2xvcjogdGhlbWUucGFsZXR0ZS5wcmltYXJ5WzVdLFxuICAgIHRyYW5zaXRpb246ICd0cmFuc2Zvcm0gMzAwbXMnLFxuICAgIHRyYW5zZm9ybTogZXhwYW5kZWQgPyAncm90YXRlKDApJyA6ICdyb3RhdGUoLTkwZGVnKSdcbiAgfSksXG4gIGdldE92ZXJyaWRlcyhPdmVycmlkYWJsZS5EYXRhR3JpZC5Db2xsYXBzaWJsZUljb24pXG4pXG5cbmNvbnN0IENvbGxhcHNpYmxlSWNvbkJ1dHRvbiA9IHN0eWxlZChCdXR0b24pKCgpID0+ICh7XG4gIG1pbldpZHRoOiAxNlxufSkpXG5cbmNvbnN0IENvbGxhcHNpYmxlQ2VsbFdyYXBwZXIgPSBzdHlsZWQoQ2VsbCkoKCkgPT4gKHtcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIGJvcmRlclJpZ2h0OiAwXG59KSlcblxudHlwZSBTeW50aGV0aWNFdmVudCA9IGFueVxudHlwZSBDb2xsYXBzaWJsZUNlbGxQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZVxuICBleHBhbmRlZFJvd3M6IEFycmF5PG51bWJlciB8IHN0cmluZz5cbiAgaGFuZGxlRXhwYW5kUm93czogKGV2ZW50OiBTeW50aGV0aWNFdmVudCkgPT4gdm9pZFxuICBpZDogc3RyaW5nIHwgbnVtYmVyXG4gIG51bWJlck9mQ2hpbGRyZW46IG51bWJlclxufVxuY2xhc3MgQ29sbGFwc2libGVDZWxsIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50PENvbGxhcHNpYmxlQ2VsbFByb3BzPiB7XG4gIGhhbmRsZUV4cGFuZFJvd3MgPSAoZXZlbnQ6IFN5bnRoZXRpY0V2ZW50KSA9PiB7XG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcbiAgICBjb25zdCB7IGlkLCBleHBhbmRlZFJvd3MsIGhhbmRsZUV4cGFuZFJvd3MgfSA9IHRoaXMucHJvcHNcbiAgICBjb25zdCBleHBhbmRlZCA9IGV4cGFuZGVkUm93cy5pbmNsdWRlcyhpZClcbiAgICBjb25zdCBuZXdFeHBhbmRlZFJvd3MgPSBleHBhbmRlZFxuICAgICAgPyBleHBhbmRlZFJvd3MuZmlsdGVyKHJvdyA9PiByb3cgIT09IGlkKVxuICAgICAgOiBbLi4uZXhwYW5kZWRSb3dzLCBpZF1cbiAgICByZXR1cm4gaGFuZGxlRXhwYW5kUm93cyhuZXdFeHBhbmRlZFJvd3MpXG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBpZCwgZXhwYW5kZWRSb3dzLCBudW1iZXJPZkNoaWxkcmVuIH0gPSB0aGlzLnByb3BzXG4gICAgY29uc3QgZXhwYW5kZWQgPSBleHBhbmRlZFJvd3MuaW5jbHVkZXMoaWQpXG4gICAgcmV0dXJuIChcbiAgICAgIDxDb2xsYXBzaWJsZUNlbGxXcmFwcGVyIGtleT17aWR9PlxuICAgICAgICA8Q29sbGFwc2libGVJY29uQnV0dG9uXG4gICAgICAgICAgb25DbGljaz17dGhpcy5oYW5kbGVFeHBhbmRSb3dzfVxuICAgICAgICAgIGljb25cbiAgICAgICAgICBib3JkZXJsZXNzXG4gICAgICAgICAgaWdub3JlRm9jdXNcbiAgICAgICAgPlxuICAgICAgICAgIDxDb2xsYXBzaWJsZUljb25cbiAgICAgICAgICAgIGV4cGFuZGVkPXtleHBhbmRlZCAmJiBudW1iZXJPZkNoaWxkcmVuID4gMH1cbiAgICAgICAgICAgIGNsYXNzTmFtZT17Y24oJ2RhdGEtZ3JpZC1jb2xsYXBzaWJsZS1pY29uJywge1xuICAgICAgICAgICAgICAnZGF0YS1ncmlkLWNvbGxhcHNpYmxlLWljb24tZXhwYW5kZWQnOlxuICAgICAgICAgICAgICAgIGV4cGFuZGVkICYmIG51bWJlck9mQ2hpbGRyZW4gPiAwXG4gICAgICAgICAgICB9KX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L0NvbGxhcHNpYmxlSWNvbkJ1dHRvbj5cbiAgICAgICAgPFNwYWNlciAvPlxuICAgICAgICB7dGhpcy5wcm9wcy5jaGlsZHJlbn1cbiAgICAgICAge2AgKCR7bnVtYmVyT2ZDaGlsZHJlbn0pYH1cbiAgICAgIDwvQ29sbGFwc2libGVDZWxsV3JhcHBlcj5cbiAgICApXG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgQ29sbGFwc2libGVDZWxsXG4iXX0= */");
77
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.CollapsibleIcon), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9EYXRhR3JpZC9jb21wb25lbnRzL0NvbGxhcHNpYmxlQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYStCIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9EYXRhR3JpZC9jb21wb25lbnRzL0NvbGxhcHNpYmxlQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSB0ZC9pbnN0cnVtZW50YXRpb24gKi9cbi8vIHRoaXMgbGV2ZWwgb2YgZmluZSBncmFpbmVkIGluc3RydW1lbnRhdGlvbiBpcyBub3QgbmVlZGVkXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgSWNvbiBmcm9tICcuLi8uLi9JY29uJ1xuaW1wb3J0IHsgU3BhY2VyLCBDZWxsIH0gZnJvbSAnLi4vZWxlbWVudHMnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCBjbiBmcm9tICdjbGFzc25hbWVzJ1xuaW1wb3J0IHsgZ2V0T3ZlcnJpZGVzLCBPdmVycmlkYWJsZSB9IGZyb20gJy4uLy4uL1RoZW1lUHJvdmlkZXInXG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL0J1dHRvbidcblxudHlwZSBDb2xsYXBzaWJsZUljb25Qcm9wcyA9IHtcbiAgZXhwYW5kZWQ/OiBib29sZWFuXG59XG5leHBvcnQgY29uc3QgQ29sbGFwc2libGVJY29uID0gc3R5bGVkKEljb24uTWVkaXVtLlN5bWJvbEFycm93RG93bik8XG4gIENvbGxhcHNpYmxlSWNvblByb3BzXG4+KFxuICAoeyBleHBhbmRlZCwgdGhlbWUgfSkgPT4gKHtcbiAgICBjb2xvcjogdGhlbWUucGFsZXR0ZS5wcmltYXJ5WzVdLFxuICAgIHRyYW5zaXRpb246ICd0cmFuc2Zvcm0gMzAwbXMnLFxuICAgIHRyYW5zZm9ybTogZXhwYW5kZWQgPyAncm90YXRlKDApJyA6ICdyb3RhdGUoLTkwZGVnKSdcbiAgfSksXG4gIGdldE92ZXJyaWRlcyhPdmVycmlkYWJsZS5EYXRhR3JpZC5Db2xsYXBzaWJsZUljb24pXG4pXG5cbmNvbnN0IENvbGxhcHNpYmxlSWNvbkJ1dHRvbiA9IHN0eWxlZChCdXR0b24pKCgpID0+ICh7XG4gIG1pbldpZHRoOiAxNlxufSkpXG5cbmNvbnN0IENvbGxhcHNpYmxlQ2VsbFdyYXBwZXIgPSBzdHlsZWQoQ2VsbCkoKCkgPT4gKHtcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIGJvcmRlclJpZ2h0OiAwXG59KSlcblxudHlwZSBTeW50aGV0aWNFdmVudCA9IGFueVxudHlwZSBDb2xsYXBzaWJsZUNlbGxQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZVxuICBleHBhbmRlZFJvd3M6IEFycmF5PG51bWJlciB8IHN0cmluZz5cbiAgaGFuZGxlRXhwYW5kUm93czogKGV2ZW50OiBTeW50aGV0aWNFdmVudCkgPT4gdm9pZFxuICBpZDogc3RyaW5nIHwgbnVtYmVyXG4gIG51bWJlck9mQ2hpbGRyZW46IG51bWJlclxufVxuY2xhc3MgQ29sbGFwc2libGVDZWxsIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50PENvbGxhcHNpYmxlQ2VsbFByb3BzPiB7XG4gIGhhbmRsZUV4cGFuZFJvd3MgPSAoZXZlbnQ6IFN5bnRoZXRpY0V2ZW50KSA9PiB7XG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcbiAgICBjb25zdCB7IGlkLCBleHBhbmRlZFJvd3MsIGhhbmRsZUV4cGFuZFJvd3MgfSA9IHRoaXMucHJvcHNcbiAgICBjb25zdCBleHBhbmRlZCA9IGV4cGFuZGVkUm93cy5pbmNsdWRlcyhpZClcbiAgICBjb25zdCBuZXdFeHBhbmRlZFJvd3MgPSBleHBhbmRlZFxuICAgICAgPyBleHBhbmRlZFJvd3MuZmlsdGVyKHJvdyA9PiByb3cgIT09IGlkKVxuICAgICAgOiBbLi4uZXhwYW5kZWRSb3dzLCBpZF1cbiAgICByZXR1cm4gaGFuZGxlRXhwYW5kUm93cyhuZXdFeHBhbmRlZFJvd3MpXG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBpZCwgZXhwYW5kZWRSb3dzLCBudW1iZXJPZkNoaWxkcmVuIH0gPSB0aGlzLnByb3BzXG4gICAgY29uc3QgZXhwYW5kZWQgPSBleHBhbmRlZFJvd3MuaW5jbHVkZXMoaWQpXG4gICAgcmV0dXJuIChcbiAgICAgIDxDb2xsYXBzaWJsZUNlbGxXcmFwcGVyIGtleT17aWR9IGlzRmlyc3Q+XG4gICAgICAgIDxDb2xsYXBzaWJsZUljb25CdXR0b25cbiAgICAgICAgICBvbkNsaWNrPXt0aGlzLmhhbmRsZUV4cGFuZFJvd3N9XG4gICAgICAgICAgaWNvblxuICAgICAgICAgIGJvcmRlcmxlc3NcbiAgICAgICAgICBpZ25vcmVGb2N1c1xuICAgICAgICA+XG4gICAgICAgICAgPENvbGxhcHNpYmxlSWNvblxuICAgICAgICAgICAgZXhwYW5kZWQ9e2V4cGFuZGVkICYmIG51bWJlck9mQ2hpbGRyZW4gPiAwfVxuICAgICAgICAgICAgY2xhc3NOYW1lPXtjbignZGF0YS1ncmlkLWNvbGxhcHNpYmxlLWljb24nLCB7XG4gICAgICAgICAgICAgICdkYXRhLWdyaWQtY29sbGFwc2libGUtaWNvbi1leHBhbmRlZCc6XG4gICAgICAgICAgICAgICAgZXhwYW5kZWQgJiYgbnVtYmVyT2ZDaGlsZHJlbiA+IDBcbiAgICAgICAgICAgIH0pfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvQ29sbGFwc2libGVJY29uQnV0dG9uPlxuICAgICAgICA8U3BhY2VyIC8+XG4gICAgICAgIHt0aGlzLnByb3BzLmNoaWxkcmVufVxuICAgICAgICB7YCAoJHtudW1iZXJPZkNoaWxkcmVufSlgfVxuICAgICAgPC9Db2xsYXBzaWJsZUNlbGxXcmFwcGVyPlxuICAgIClcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBDb2xsYXBzaWJsZUNlbGxcbiJdfQ== */");
78
78
  exports.CollapsibleIcon = CollapsibleIcon;
79
79
  var CollapsibleIconButton = ( /*#__PURE__*/0, _base["default"])(_Button["default"], process.env.NODE_ENV === "production" ? {
80
80
  target: "e1prc87v1"
@@ -85,7 +85,7 @@ var CollapsibleIconButton = ( /*#__PURE__*/0, _base["default"])(_Button["default
85
85
  return {
86
86
  minWidth: 16
87
87
  };
88
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9EYXRhR3JpZC9jb21wb25lbnRzL0NvbGxhcHNpYmxlQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0I4QiIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvRGF0YUdyaWQvY29tcG9uZW50cy9Db2xsYXBzaWJsZUNlbGwudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgdGQvaW5zdHJ1bWVudGF0aW9uICovXG4vLyB0aGlzIGxldmVsIG9mIGZpbmUgZ3JhaW5lZCBpbnN0cnVtZW50YXRpb24gaXMgbm90IG5lZWRlZFxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IEljb24gZnJvbSAnLi4vLi4vSWNvbidcbmltcG9ydCB7IFNwYWNlciwgQ2VsbCB9IGZyb20gJy4uL2VsZW1lbnRzJ1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgY24gZnJvbSAnY2xhc3NuYW1lcydcbmltcG9ydCB7IGdldE92ZXJyaWRlcywgT3ZlcnJpZGFibGUgfSBmcm9tICcuLi8uLi9UaGVtZVByb3ZpZGVyJ1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9CdXR0b24nXG5cbnR5cGUgQ29sbGFwc2libGVJY29uUHJvcHMgPSB7XG4gIGV4cGFuZGVkPzogYm9vbGVhblxufVxuZXhwb3J0IGNvbnN0IENvbGxhcHNpYmxlSWNvbiA9IHN0eWxlZChJY29uLk1lZGl1bS5TeW1ib2xBcnJvd0Rvd24pPFxuICBDb2xsYXBzaWJsZUljb25Qcm9wc1xuPihcbiAgKHsgZXhwYW5kZWQsIHRoZW1lIH0pID0+ICh7XG4gICAgY29sb3I6IHRoZW1lLnBhbGV0dGUucHJpbWFyeVs1XSxcbiAgICB0cmFuc2l0aW9uOiAndHJhbnNmb3JtIDMwMG1zJyxcbiAgICB0cmFuc2Zvcm06IGV4cGFuZGVkID8gJ3JvdGF0ZSgwKScgOiAncm90YXRlKC05MGRlZyknXG4gIH0pLFxuICBnZXRPdmVycmlkZXMoT3ZlcnJpZGFibGUuRGF0YUdyaWQuQ29sbGFwc2libGVJY29uKVxuKVxuXG5jb25zdCBDb2xsYXBzaWJsZUljb25CdXR0b24gPSBzdHlsZWQoQnV0dG9uKSgoKSA9PiAoe1xuICBtaW5XaWR0aDogMTZcbn0pKVxuXG5jb25zdCBDb2xsYXBzaWJsZUNlbGxXcmFwcGVyID0gc3R5bGVkKENlbGwpKCgpID0+ICh7XG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBib3JkZXJSaWdodDogMFxufSkpXG5cbnR5cGUgU3ludGhldGljRXZlbnQgPSBhbnlcbnR5cGUgQ29sbGFwc2libGVDZWxsUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVcbiAgZXhwYW5kZWRSb3dzOiBBcnJheTxudW1iZXIgfCBzdHJpbmc+XG4gIGhhbmRsZUV4cGFuZFJvd3M6IChldmVudDogU3ludGhldGljRXZlbnQpID0+IHZvaWRcbiAgaWQ6IHN0cmluZyB8IG51bWJlclxuICBudW1iZXJPZkNoaWxkcmVuOiBudW1iZXJcbn1cbmNsYXNzIENvbGxhcHNpYmxlQ2VsbCBleHRlbmRzIFJlYWN0LkNvbXBvbmVudDxDb2xsYXBzaWJsZUNlbGxQcm9wcz4ge1xuICBoYW5kbGVFeHBhbmRSb3dzID0gKGV2ZW50OiBTeW50aGV0aWNFdmVudCkgPT4ge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXG4gICAgY29uc3QgeyBpZCwgZXhwYW5kZWRSb3dzLCBoYW5kbGVFeHBhbmRSb3dzIH0gPSB0aGlzLnByb3BzXG4gICAgY29uc3QgZXhwYW5kZWQgPSBleHBhbmRlZFJvd3MuaW5jbHVkZXMoaWQpXG4gICAgY29uc3QgbmV3RXhwYW5kZWRSb3dzID0gZXhwYW5kZWRcbiAgICAgID8gZXhwYW5kZWRSb3dzLmZpbHRlcihyb3cgPT4gcm93ICE9PSBpZClcbiAgICAgIDogWy4uLmV4cGFuZGVkUm93cywgaWRdXG4gICAgcmV0dXJuIGhhbmRsZUV4cGFuZFJvd3MobmV3RXhwYW5kZWRSb3dzKVxuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHsgaWQsIGV4cGFuZGVkUm93cywgbnVtYmVyT2ZDaGlsZHJlbiB9ID0gdGhpcy5wcm9wc1xuICAgIGNvbnN0IGV4cGFuZGVkID0gZXhwYW5kZWRSb3dzLmluY2x1ZGVzKGlkKVxuICAgIHJldHVybiAoXG4gICAgICA8Q29sbGFwc2libGVDZWxsV3JhcHBlciBrZXk9e2lkfT5cbiAgICAgICAgPENvbGxhcHNpYmxlSWNvbkJ1dHRvblxuICAgICAgICAgIG9uQ2xpY2s9e3RoaXMuaGFuZGxlRXhwYW5kUm93c31cbiAgICAgICAgICBpY29uXG4gICAgICAgICAgYm9yZGVybGVzc1xuICAgICAgICAgIGlnbm9yZUZvY3VzXG4gICAgICAgID5cbiAgICAgICAgICA8Q29sbGFwc2libGVJY29uXG4gICAgICAgICAgICBleHBhbmRlZD17ZXhwYW5kZWQgJiYgbnVtYmVyT2ZDaGlsZHJlbiA+IDB9XG4gICAgICAgICAgICBjbGFzc05hbWU9e2NuKCdkYXRhLWdyaWQtY29sbGFwc2libGUtaWNvbicsIHtcbiAgICAgICAgICAgICAgJ2RhdGEtZ3JpZC1jb2xsYXBzaWJsZS1pY29uLWV4cGFuZGVkJzpcbiAgICAgICAgICAgICAgICBleHBhbmRlZCAmJiBudW1iZXJPZkNoaWxkcmVuID4gMFxuICAgICAgICAgICAgfSl9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9Db2xsYXBzaWJsZUljb25CdXR0b24+XG4gICAgICAgIDxTcGFjZXIgLz5cbiAgICAgICAge3RoaXMucHJvcHMuY2hpbGRyZW59XG4gICAgICAgIHtgICgke251bWJlck9mQ2hpbGRyZW59KWB9XG4gICAgICA8L0NvbGxhcHNpYmxlQ2VsbFdyYXBwZXI+XG4gICAgKVxuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IENvbGxhcHNpYmxlQ2VsbFxuIl19 */");
88
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9EYXRhR3JpZC9jb21wb25lbnRzL0NvbGxhcHNpYmxlQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0I4QiIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvRGF0YUdyaWQvY29tcG9uZW50cy9Db2xsYXBzaWJsZUNlbGwudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgdGQvaW5zdHJ1bWVudGF0aW9uICovXG4vLyB0aGlzIGxldmVsIG9mIGZpbmUgZ3JhaW5lZCBpbnN0cnVtZW50YXRpb24gaXMgbm90IG5lZWRlZFxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IEljb24gZnJvbSAnLi4vLi4vSWNvbidcbmltcG9ydCB7IFNwYWNlciwgQ2VsbCB9IGZyb20gJy4uL2VsZW1lbnRzJ1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgY24gZnJvbSAnY2xhc3NuYW1lcydcbmltcG9ydCB7IGdldE92ZXJyaWRlcywgT3ZlcnJpZGFibGUgfSBmcm9tICcuLi8uLi9UaGVtZVByb3ZpZGVyJ1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9CdXR0b24nXG5cbnR5cGUgQ29sbGFwc2libGVJY29uUHJvcHMgPSB7XG4gIGV4cGFuZGVkPzogYm9vbGVhblxufVxuZXhwb3J0IGNvbnN0IENvbGxhcHNpYmxlSWNvbiA9IHN0eWxlZChJY29uLk1lZGl1bS5TeW1ib2xBcnJvd0Rvd24pPFxuICBDb2xsYXBzaWJsZUljb25Qcm9wc1xuPihcbiAgKHsgZXhwYW5kZWQsIHRoZW1lIH0pID0+ICh7XG4gICAgY29sb3I6IHRoZW1lLnBhbGV0dGUucHJpbWFyeVs1XSxcbiAgICB0cmFuc2l0aW9uOiAndHJhbnNmb3JtIDMwMG1zJyxcbiAgICB0cmFuc2Zvcm06IGV4cGFuZGVkID8gJ3JvdGF0ZSgwKScgOiAncm90YXRlKC05MGRlZyknXG4gIH0pLFxuICBnZXRPdmVycmlkZXMoT3ZlcnJpZGFibGUuRGF0YUdyaWQuQ29sbGFwc2libGVJY29uKVxuKVxuXG5jb25zdCBDb2xsYXBzaWJsZUljb25CdXR0b24gPSBzdHlsZWQoQnV0dG9uKSgoKSA9PiAoe1xuICBtaW5XaWR0aDogMTZcbn0pKVxuXG5jb25zdCBDb2xsYXBzaWJsZUNlbGxXcmFwcGVyID0gc3R5bGVkKENlbGwpKCgpID0+ICh7XG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBib3JkZXJSaWdodDogMFxufSkpXG5cbnR5cGUgU3ludGhldGljRXZlbnQgPSBhbnlcbnR5cGUgQ29sbGFwc2libGVDZWxsUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVcbiAgZXhwYW5kZWRSb3dzOiBBcnJheTxudW1iZXIgfCBzdHJpbmc+XG4gIGhhbmRsZUV4cGFuZFJvd3M6IChldmVudDogU3ludGhldGljRXZlbnQpID0+IHZvaWRcbiAgaWQ6IHN0cmluZyB8IG51bWJlclxuICBudW1iZXJPZkNoaWxkcmVuOiBudW1iZXJcbn1cbmNsYXNzIENvbGxhcHNpYmxlQ2VsbCBleHRlbmRzIFJlYWN0LkNvbXBvbmVudDxDb2xsYXBzaWJsZUNlbGxQcm9wcz4ge1xuICBoYW5kbGVFeHBhbmRSb3dzID0gKGV2ZW50OiBTeW50aGV0aWNFdmVudCkgPT4ge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXG4gICAgY29uc3QgeyBpZCwgZXhwYW5kZWRSb3dzLCBoYW5kbGVFeHBhbmRSb3dzIH0gPSB0aGlzLnByb3BzXG4gICAgY29uc3QgZXhwYW5kZWQgPSBleHBhbmRlZFJvd3MuaW5jbHVkZXMoaWQpXG4gICAgY29uc3QgbmV3RXhwYW5kZWRSb3dzID0gZXhwYW5kZWRcbiAgICAgID8gZXhwYW5kZWRSb3dzLmZpbHRlcihyb3cgPT4gcm93ICE9PSBpZClcbiAgICAgIDogWy4uLmV4cGFuZGVkUm93cywgaWRdXG4gICAgcmV0dXJuIGhhbmRsZUV4cGFuZFJvd3MobmV3RXhwYW5kZWRSb3dzKVxuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHsgaWQsIGV4cGFuZGVkUm93cywgbnVtYmVyT2ZDaGlsZHJlbiB9ID0gdGhpcy5wcm9wc1xuICAgIGNvbnN0IGV4cGFuZGVkID0gZXhwYW5kZWRSb3dzLmluY2x1ZGVzKGlkKVxuICAgIHJldHVybiAoXG4gICAgICA8Q29sbGFwc2libGVDZWxsV3JhcHBlciBrZXk9e2lkfSBpc0ZpcnN0PlxuICAgICAgICA8Q29sbGFwc2libGVJY29uQnV0dG9uXG4gICAgICAgICAgb25DbGljaz17dGhpcy5oYW5kbGVFeHBhbmRSb3dzfVxuICAgICAgICAgIGljb25cbiAgICAgICAgICBib3JkZXJsZXNzXG4gICAgICAgICAgaWdub3JlRm9jdXNcbiAgICAgICAgPlxuICAgICAgICAgIDxDb2xsYXBzaWJsZUljb25cbiAgICAgICAgICAgIGV4cGFuZGVkPXtleHBhbmRlZCAmJiBudW1iZXJPZkNoaWxkcmVuID4gMH1cbiAgICAgICAgICAgIGNsYXNzTmFtZT17Y24oJ2RhdGEtZ3JpZC1jb2xsYXBzaWJsZS1pY29uJywge1xuICAgICAgICAgICAgICAnZGF0YS1ncmlkLWNvbGxhcHNpYmxlLWljb24tZXhwYW5kZWQnOlxuICAgICAgICAgICAgICAgIGV4cGFuZGVkICYmIG51bWJlck9mQ2hpbGRyZW4gPiAwXG4gICAgICAgICAgICB9KX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L0NvbGxhcHNpYmxlSWNvbkJ1dHRvbj5cbiAgICAgICAgPFNwYWNlciAvPlxuICAgICAgICB7dGhpcy5wcm9wcy5jaGlsZHJlbn1cbiAgICAgICAge2AgKCR7bnVtYmVyT2ZDaGlsZHJlbn0pYH1cbiAgICAgIDwvQ29sbGFwc2libGVDZWxsV3JhcHBlcj5cbiAgICApXG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgQ29sbGFwc2libGVDZWxsXG4iXX0= */");
89
89
  var CollapsibleCellWrapper = ( /*#__PURE__*/0, _base["default"])(_elements.Cell, process.env.NODE_ENV === "production" ? {
90
90
  target: "e1prc87v0"
91
91
  } : {
@@ -96,7 +96,7 @@ var CollapsibleCellWrapper = ( /*#__PURE__*/0, _base["default"])(_elements.Cell,
96
96
  alignItems: 'center',
97
97
  borderRight: 0
98
98
  };
99
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9EYXRhR3JpZC9jb21wb25lbnRzL0NvbGxhcHNpYmxlQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEIrQiIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvRGF0YUdyaWQvY29tcG9uZW50cy9Db2xsYXBzaWJsZUNlbGwudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgdGQvaW5zdHJ1bWVudGF0aW9uICovXG4vLyB0aGlzIGxldmVsIG9mIGZpbmUgZ3JhaW5lZCBpbnN0cnVtZW50YXRpb24gaXMgbm90IG5lZWRlZFxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IEljb24gZnJvbSAnLi4vLi4vSWNvbidcbmltcG9ydCB7IFNwYWNlciwgQ2VsbCB9IGZyb20gJy4uL2VsZW1lbnRzJ1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgY24gZnJvbSAnY2xhc3NuYW1lcydcbmltcG9ydCB7IGdldE92ZXJyaWRlcywgT3ZlcnJpZGFibGUgfSBmcm9tICcuLi8uLi9UaGVtZVByb3ZpZGVyJ1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9CdXR0b24nXG5cbnR5cGUgQ29sbGFwc2libGVJY29uUHJvcHMgPSB7XG4gIGV4cGFuZGVkPzogYm9vbGVhblxufVxuZXhwb3J0IGNvbnN0IENvbGxhcHNpYmxlSWNvbiA9IHN0eWxlZChJY29uLk1lZGl1bS5TeW1ib2xBcnJvd0Rvd24pPFxuICBDb2xsYXBzaWJsZUljb25Qcm9wc1xuPihcbiAgKHsgZXhwYW5kZWQsIHRoZW1lIH0pID0+ICh7XG4gICAgY29sb3I6IHRoZW1lLnBhbGV0dGUucHJpbWFyeVs1XSxcbiAgICB0cmFuc2l0aW9uOiAndHJhbnNmb3JtIDMwMG1zJyxcbiAgICB0cmFuc2Zvcm06IGV4cGFuZGVkID8gJ3JvdGF0ZSgwKScgOiAncm90YXRlKC05MGRlZyknXG4gIH0pLFxuICBnZXRPdmVycmlkZXMoT3ZlcnJpZGFibGUuRGF0YUdyaWQuQ29sbGFwc2libGVJY29uKVxuKVxuXG5jb25zdCBDb2xsYXBzaWJsZUljb25CdXR0b24gPSBzdHlsZWQoQnV0dG9uKSgoKSA9PiAoe1xuICBtaW5XaWR0aDogMTZcbn0pKVxuXG5jb25zdCBDb2xsYXBzaWJsZUNlbGxXcmFwcGVyID0gc3R5bGVkKENlbGwpKCgpID0+ICh7XG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBib3JkZXJSaWdodDogMFxufSkpXG5cbnR5cGUgU3ludGhldGljRXZlbnQgPSBhbnlcbnR5cGUgQ29sbGFwc2libGVDZWxsUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVcbiAgZXhwYW5kZWRSb3dzOiBBcnJheTxudW1iZXIgfCBzdHJpbmc+XG4gIGhhbmRsZUV4cGFuZFJvd3M6IChldmVudDogU3ludGhldGljRXZlbnQpID0+IHZvaWRcbiAgaWQ6IHN0cmluZyB8IG51bWJlclxuICBudW1iZXJPZkNoaWxkcmVuOiBudW1iZXJcbn1cbmNsYXNzIENvbGxhcHNpYmxlQ2VsbCBleHRlbmRzIFJlYWN0LkNvbXBvbmVudDxDb2xsYXBzaWJsZUNlbGxQcm9wcz4ge1xuICBoYW5kbGVFeHBhbmRSb3dzID0gKGV2ZW50OiBTeW50aGV0aWNFdmVudCkgPT4ge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXG4gICAgY29uc3QgeyBpZCwgZXhwYW5kZWRSb3dzLCBoYW5kbGVFeHBhbmRSb3dzIH0gPSB0aGlzLnByb3BzXG4gICAgY29uc3QgZXhwYW5kZWQgPSBleHBhbmRlZFJvd3MuaW5jbHVkZXMoaWQpXG4gICAgY29uc3QgbmV3RXhwYW5kZWRSb3dzID0gZXhwYW5kZWRcbiAgICAgID8gZXhwYW5kZWRSb3dzLmZpbHRlcihyb3cgPT4gcm93ICE9PSBpZClcbiAgICAgIDogWy4uLmV4cGFuZGVkUm93cywgaWRdXG4gICAgcmV0dXJuIGhhbmRsZUV4cGFuZFJvd3MobmV3RXhwYW5kZWRSb3dzKVxuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHsgaWQsIGV4cGFuZGVkUm93cywgbnVtYmVyT2ZDaGlsZHJlbiB9ID0gdGhpcy5wcm9wc1xuICAgIGNvbnN0IGV4cGFuZGVkID0gZXhwYW5kZWRSb3dzLmluY2x1ZGVzKGlkKVxuICAgIHJldHVybiAoXG4gICAgICA8Q29sbGFwc2libGVDZWxsV3JhcHBlciBrZXk9e2lkfT5cbiAgICAgICAgPENvbGxhcHNpYmxlSWNvbkJ1dHRvblxuICAgICAgICAgIG9uQ2xpY2s9e3RoaXMuaGFuZGxlRXhwYW5kUm93c31cbiAgICAgICAgICBpY29uXG4gICAgICAgICAgYm9yZGVybGVzc1xuICAgICAgICAgIGlnbm9yZUZvY3VzXG4gICAgICAgID5cbiAgICAgICAgICA8Q29sbGFwc2libGVJY29uXG4gICAgICAgICAgICBleHBhbmRlZD17ZXhwYW5kZWQgJiYgbnVtYmVyT2ZDaGlsZHJlbiA+IDB9XG4gICAgICAgICAgICBjbGFzc05hbWU9e2NuKCdkYXRhLWdyaWQtY29sbGFwc2libGUtaWNvbicsIHtcbiAgICAgICAgICAgICAgJ2RhdGEtZ3JpZC1jb2xsYXBzaWJsZS1pY29uLWV4cGFuZGVkJzpcbiAgICAgICAgICAgICAgICBleHBhbmRlZCAmJiBudW1iZXJPZkNoaWxkcmVuID4gMFxuICAgICAgICAgICAgfSl9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9Db2xsYXBzaWJsZUljb25CdXR0b24+XG4gICAgICAgIDxTcGFjZXIgLz5cbiAgICAgICAge3RoaXMucHJvcHMuY2hpbGRyZW59XG4gICAgICAgIHtgICgke251bWJlck9mQ2hpbGRyZW59KWB9XG4gICAgICA8L0NvbGxhcHNpYmxlQ2VsbFdyYXBwZXI+XG4gICAgKVxuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IENvbGxhcHNpYmxlQ2VsbFxuIl19 */");
99
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9EYXRhR3JpZC9jb21wb25lbnRzL0NvbGxhcHNpYmxlQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEIrQiIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvRGF0YUdyaWQvY29tcG9uZW50cy9Db2xsYXBzaWJsZUNlbGwudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgdGQvaW5zdHJ1bWVudGF0aW9uICovXG4vLyB0aGlzIGxldmVsIG9mIGZpbmUgZ3JhaW5lZCBpbnN0cnVtZW50YXRpb24gaXMgbm90IG5lZWRlZFxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IEljb24gZnJvbSAnLi4vLi4vSWNvbidcbmltcG9ydCB7IFNwYWNlciwgQ2VsbCB9IGZyb20gJy4uL2VsZW1lbnRzJ1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgY24gZnJvbSAnY2xhc3NuYW1lcydcbmltcG9ydCB7IGdldE92ZXJyaWRlcywgT3ZlcnJpZGFibGUgfSBmcm9tICcuLi8uLi9UaGVtZVByb3ZpZGVyJ1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9CdXR0b24nXG5cbnR5cGUgQ29sbGFwc2libGVJY29uUHJvcHMgPSB7XG4gIGV4cGFuZGVkPzogYm9vbGVhblxufVxuZXhwb3J0IGNvbnN0IENvbGxhcHNpYmxlSWNvbiA9IHN0eWxlZChJY29uLk1lZGl1bS5TeW1ib2xBcnJvd0Rvd24pPFxuICBDb2xsYXBzaWJsZUljb25Qcm9wc1xuPihcbiAgKHsgZXhwYW5kZWQsIHRoZW1lIH0pID0+ICh7XG4gICAgY29sb3I6IHRoZW1lLnBhbGV0dGUucHJpbWFyeVs1XSxcbiAgICB0cmFuc2l0aW9uOiAndHJhbnNmb3JtIDMwMG1zJyxcbiAgICB0cmFuc2Zvcm06IGV4cGFuZGVkID8gJ3JvdGF0ZSgwKScgOiAncm90YXRlKC05MGRlZyknXG4gIH0pLFxuICBnZXRPdmVycmlkZXMoT3ZlcnJpZGFibGUuRGF0YUdyaWQuQ29sbGFwc2libGVJY29uKVxuKVxuXG5jb25zdCBDb2xsYXBzaWJsZUljb25CdXR0b24gPSBzdHlsZWQoQnV0dG9uKSgoKSA9PiAoe1xuICBtaW5XaWR0aDogMTZcbn0pKVxuXG5jb25zdCBDb2xsYXBzaWJsZUNlbGxXcmFwcGVyID0gc3R5bGVkKENlbGwpKCgpID0+ICh7XG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBib3JkZXJSaWdodDogMFxufSkpXG5cbnR5cGUgU3ludGhldGljRXZlbnQgPSBhbnlcbnR5cGUgQ29sbGFwc2libGVDZWxsUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVcbiAgZXhwYW5kZWRSb3dzOiBBcnJheTxudW1iZXIgfCBzdHJpbmc+XG4gIGhhbmRsZUV4cGFuZFJvd3M6IChldmVudDogU3ludGhldGljRXZlbnQpID0+IHZvaWRcbiAgaWQ6IHN0cmluZyB8IG51bWJlclxuICBudW1iZXJPZkNoaWxkcmVuOiBudW1iZXJcbn1cbmNsYXNzIENvbGxhcHNpYmxlQ2VsbCBleHRlbmRzIFJlYWN0LkNvbXBvbmVudDxDb2xsYXBzaWJsZUNlbGxQcm9wcz4ge1xuICBoYW5kbGVFeHBhbmRSb3dzID0gKGV2ZW50OiBTeW50aGV0aWNFdmVudCkgPT4ge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXG4gICAgY29uc3QgeyBpZCwgZXhwYW5kZWRSb3dzLCBoYW5kbGVFeHBhbmRSb3dzIH0gPSB0aGlzLnByb3BzXG4gICAgY29uc3QgZXhwYW5kZWQgPSBleHBhbmRlZFJvd3MuaW5jbHVkZXMoaWQpXG4gICAgY29uc3QgbmV3RXhwYW5kZWRSb3dzID0gZXhwYW5kZWRcbiAgICAgID8gZXhwYW5kZWRSb3dzLmZpbHRlcihyb3cgPT4gcm93ICE9PSBpZClcbiAgICAgIDogWy4uLmV4cGFuZGVkUm93cywgaWRdXG4gICAgcmV0dXJuIGhhbmRsZUV4cGFuZFJvd3MobmV3RXhwYW5kZWRSb3dzKVxuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHsgaWQsIGV4cGFuZGVkUm93cywgbnVtYmVyT2ZDaGlsZHJlbiB9ID0gdGhpcy5wcm9wc1xuICAgIGNvbnN0IGV4cGFuZGVkID0gZXhwYW5kZWRSb3dzLmluY2x1ZGVzKGlkKVxuICAgIHJldHVybiAoXG4gICAgICA8Q29sbGFwc2libGVDZWxsV3JhcHBlciBrZXk9e2lkfSBpc0ZpcnN0PlxuICAgICAgICA8Q29sbGFwc2libGVJY29uQnV0dG9uXG4gICAgICAgICAgb25DbGljaz17dGhpcy5oYW5kbGVFeHBhbmRSb3dzfVxuICAgICAgICAgIGljb25cbiAgICAgICAgICBib3JkZXJsZXNzXG4gICAgICAgICAgaWdub3JlRm9jdXNcbiAgICAgICAgPlxuICAgICAgICAgIDxDb2xsYXBzaWJsZUljb25cbiAgICAgICAgICAgIGV4cGFuZGVkPXtleHBhbmRlZCAmJiBudW1iZXJPZkNoaWxkcmVuID4gMH1cbiAgICAgICAgICAgIGNsYXNzTmFtZT17Y24oJ2RhdGEtZ3JpZC1jb2xsYXBzaWJsZS1pY29uJywge1xuICAgICAgICAgICAgICAnZGF0YS1ncmlkLWNvbGxhcHNpYmxlLWljb24tZXhwYW5kZWQnOlxuICAgICAgICAgICAgICAgIGV4cGFuZGVkICYmIG51bWJlck9mQ2hpbGRyZW4gPiAwXG4gICAgICAgICAgICB9KX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L0NvbGxhcHNpYmxlSWNvbkJ1dHRvbj5cbiAgICAgICAgPFNwYWNlciAvPlxuICAgICAgICB7dGhpcy5wcm9wcy5jaGlsZHJlbn1cbiAgICAgICAge2AgKCR7bnVtYmVyT2ZDaGlsZHJlbn0pYH1cbiAgICAgIDwvQ29sbGFwc2libGVDZWxsV3JhcHBlcj5cbiAgICApXG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgQ29sbGFwc2libGVDZWxsXG4iXX0= */");
100
100
 
101
101
  var CollapsibleCell = /*#__PURE__*/function (_React$Component) {
102
102
  _inherits(CollapsibleCell, _React$Component);
@@ -141,6 +141,7 @@ var CollapsibleCell = /*#__PURE__*/function (_React$Component) {
141
141
  return (0, _jsxRuntime.jsxs)(CollapsibleCellWrapper, {
142
142
  "data-gs-c": gsC("collapsibleiconbutton"),
143
143
  "data-gs": gs("src", "datagrid", "components", "collapsible-cell-wrapper"),
144
+ isFirst: true,
144
145
  children: [(0, _jsxRuntime.jsx)(CollapsibleIconButton, {
145
146
  "data-gs-c": gsC("collapsibleicon"),
146
147
  "data-gs": gs("src", "datagrid", "components", "collapsible-cell-wrapper", "collapsible-icon-button"),
@@ -1,11 +1,12 @@
1
1
  import React, { Component } from 'react';
2
2
  import { SortDirection } from 'react-virtualized';
3
- import type { filterRendererArguments, sortRendererArguments } from '../types';
3
+ import type { filterRendererArguments, sortRendererArguments, InternalResizeHandler } from '../types';
4
4
  import type { LocaleStrings } from '../constants';
5
5
  import type { Theme } from '@theme';
6
6
  import type { Interpolation } from '@emotion/react';
7
7
  declare type ColumnHeaderProps = {
8
8
  dataKey: string;
9
+ isFirst?: boolean;
9
10
  isLast?: boolean;
10
11
  label: string;
11
12
  showSortIndicator?: boolean;
@@ -18,6 +19,7 @@ declare type ColumnHeaderProps = {
18
19
  operator: any;
19
20
  }) => void;
20
21
  onPopoverOpen: (open: boolean) => void;
22
+ onResize?: InternalResizeHandler;
21
23
  filterValue: any;
22
24
  filterRenderer?: ((arg0: filterRendererArguments) => React.ReactNode) | false | null;
23
25
  sortRenderer?: ((arg0: sortRendererArguments) => React.ReactNode) | false | null;
@@ -17,6 +17,8 @@ var _elements = require("../elements");
17
17
 
18
18
  var _ColumnHeaderActions = _interopRequireDefault(require("./ColumnHeaderActions"));
19
19
 
20
+ var _ColumnHeaderDragHandle = _interopRequireDefault(require("./ColumnHeaderDragHandle"));
21
+
20
22
  var _utils = require("../utils");
21
23
 
22
24
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
@@ -107,6 +109,7 @@ var ColumnHeader = /*#__PURE__*/function (_Component) {
107
109
 
108
110
  var _this$props = this.props,
109
111
  dataKey = _this$props.dataKey,
112
+ isFirst = _this$props.isFirst,
110
113
  isLast = _this$props.isLast,
111
114
  label = _this$props.label,
112
115
  _this$props$showSortI = _this$props.showSortIndicator,
@@ -116,6 +119,7 @@ var ColumnHeader = /*#__PURE__*/function (_Component) {
116
119
  sortDescIcon = _this$props.sortDescIcon,
117
120
  onSort = _this$props.onSort,
118
121
  onFilter = _this$props.onFilter,
122
+ onResize = _this$props.onResize,
119
123
  filterValue = _this$props.filterValue,
120
124
  filterRenderer = _this$props.filterRenderer,
121
125
  sortRenderer = _this$props.sortRenderer,
@@ -137,6 +141,7 @@ var ColumnHeader = /*#__PURE__*/function (_Component) {
137
141
  active: isActive,
138
142
  clickable: hasActions,
139
143
  "data-testid": "column-header-container",
144
+ isFirst: isFirst,
140
145
  isLast: isLast,
141
146
  onMouseEnter: function onMouseEnter() {
142
147
  return _this2.setState({
@@ -170,7 +175,10 @@ var ColumnHeader = /*#__PURE__*/function (_Component) {
170
175
  children: (0, _jsxRuntime.jsx)(_Icon["default"].Medium.ToolFilledFilter, {
171
176
  "data-gs": gs("src", "datagrid", "components", "column-header-container", "column-header-icon", "icon-medium-tool-filled-filter")
172
177
  })
173
- })]
178
+ }), onResize ? (0, _jsxRuntime.jsx)(_ColumnHeaderDragHandle["default"], {
179
+ "data-gs": gs("src", "datagrid", "components", "column-header-container", "column-header-drag-handle"),
180
+ onResize: onResize
181
+ }) : null]
174
182
  });
175
183
  var headerOverlay = (0, _jsxRuntime.jsx)(_elements.ColumnHeaderPopover, {
176
184
  "data-gs": gs("src", "datagrid", "components", "column-header-popover"),
@@ -0,0 +1,5 @@
1
+ import type { InternalResizeHandler } from '../types';
2
+ export default function ColumnHeaderDragHandle({ onResize }: {
3
+ onResize: InternalResizeHandler;
4
+ }): import("@emotion/react/jsx-runtime").JSX.Element;
5
+ //# sourceMappingURL=ColumnHeaderDragHandle.d.ts.map