@economic/taco 2.26.18 → 2.26.20

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.
@@ -9754,7 +9754,7 @@ function configureReactTableOptions(options, props) {
9754
9754
  }
9755
9755
  function useReactTableInitialState(props, columns, persistedSettings, defaults) {
9756
9756
  return React__default.useMemo(() => {
9757
- var _persistedSettings$co, _props$defaultSetting, _ref, _persistedSettings$co2, _props$defaultSetting2, _columnPinning$left, _ref2, _persistedSettings$co3, _props$defaultSetting3, _ref3, _ref4, _persistedSettings$co4, _props$defaultSetting4, _ref5, _ref6, _persistedSettings$co5, _props$defaultSetting5, _persistedSettings$se, _props$defaultSetting6, _props$defaultSetting7, _props$defaultSetting8, _ref7, _persistedSettings$gr, _persistedSettings$gr2, _props$defaultSetting9, _props$defaultSetting10;
9757
+ var _persistedSettings$co, _props$defaultSetting, _ref, _persistedSettings$co2, _props$defaultSetting2, _columnPinning$left, _ref2, _persistedSettings$co3, _props$defaultSetting3, _ref3, _ref4, _persistedSettings$co4, _props$defaultSetting4, _ref5, _ref6, _persistedSettings$co5, _props$defaultSetting5, _persistedSettings$se, _props$defaultSetting6, _props$defaultSetting7, _props$defaultSetting8;
9758
9758
  const ignoreNotDefinedColumns = column => columns.find(definedColumn => definedColumn.id === column.id);
9759
9759
  const columnOrder = ensureOrdering(columns, (_persistedSettings$co = persistedSettings.columnOrder) !== null && _persistedSettings$co !== void 0 ? _persistedSettings$co : (_props$defaultSetting = props.defaultSettings) === null || _props$defaultSetting === void 0 ? void 0 : _props$defaultSetting.columnOrder);
9760
9760
  const columnPinning = (_ref = (_persistedSettings$co2 = persistedSettings.columnPinning) !== null && _persistedSettings$co2 !== void 0 ? _persistedSettings$co2 : (_props$defaultSetting2 = props.defaultSettings) === null || _props$defaultSetting2 === void 0 ? void 0 : _props$defaultSetting2.columnPinning) !== null && _ref !== void 0 ? _ref : {};
@@ -9775,7 +9775,7 @@ function useReactTableInitialState(props, columns, persistedSettings, defaults)
9775
9775
  globalFilter: (_persistedSettings$se = persistedSettings.searchQuery) !== null && _persistedSettings$se !== void 0 ? _persistedSettings$se : (_props$defaultSetting6 = props.defaultSettings) === null || _props$defaultSetting6 === void 0 ? void 0 : _props$defaultSetting6.searchQuery,
9776
9776
  sorting: persistedSettings.sorting ? persistedSettings.sorting.filter(ignoreNotDefinedColumns) : (_props$defaultSetting7 = (_props$defaultSetting8 = props.defaultSettings) === null || _props$defaultSetting8 === void 0 ? void 0 : _props$defaultSetting8.sorting) !== null && _props$defaultSetting7 !== void 0 ? _props$defaultSetting7 : defaults.defaultSorting
9777
9777
  };
9778
- if ((_ref7 = (_persistedSettings$gr = (_persistedSettings$gr2 = persistedSettings.grouping) === null || _persistedSettings$gr2 === void 0 ? void 0 : _persistedSettings$gr2.length) !== null && _persistedSettings$gr !== void 0 ? _persistedSettings$gr : (_props$defaultSetting9 = props.defaultSettings) === null || _props$defaultSetting9 === void 0 ? void 0 : (_props$defaultSetting10 = _props$defaultSetting9.grouping) === null || _props$defaultSetting10 === void 0 ? void 0 : _props$defaultSetting10.length) !== null && _ref7 !== void 0 ? _ref7 : props.defaultRowGroupColumnId) {
9778
+ if (props.defaultRowGroupColumnId) {
9779
9779
  state.grouping = [props.defaultRowGroupColumnId];
9780
9780
  // row groups should (all) always be expanded by default
9781
9781
  state.expanded = true;
@@ -10704,6 +10704,7 @@ function getSettings(table) {
10704
10704
  const meta = table.options.meta;
10705
10705
  const state = table.getState();
10706
10706
  return {
10707
+ // commented out properties are here to highlight things we explicitly don't want them saved
10707
10708
  //columnFilters: table.options.enableColumnFilters ? state.columnFilters : undefined,
10708
10709
  columnOrder: meta.columnOrdering.isEnabled ? state.columnOrder : undefined,
10709
10710
  columnPinning: state.columnPinning,
@@ -10711,7 +10712,7 @@ function getSettings(table) {
10711
10712
  columnVisibility: table.options.enableHiding ? state.columnVisibility : undefined,
10712
10713
  excludeUnmatchedRecordsInSearch: table.options.enableGlobalFilter,
10713
10714
  fontSize: meta.fontSize.isEnabled ? meta.fontSize.size : undefined,
10714
- grouping: table.options.enableGrouping ? state.grouping : undefined,
10715
+ //grouping: table.options.enableGrouping ? state.grouping : undefined,
10715
10716
  rowHeight: meta.rowHeight.isEnabled ? meta.rowHeight.height : undefined,
10716
10717
  //searchQuery: table.options.enableGlobalFilter ? state.globalFilter : undefined,
10717
10718
  sorting: state.sorting
@@ -10732,7 +10733,9 @@ function useTableSettingsListener(table, onChangeSettings) {
10732
10733
  return () => clearTimeout(handler);
10733
10734
  }, [
10734
10735
  //state.columnFilters,
10735
- state.columnOrder, state.columnPinning, state.columnSizing, state.columnVisibility, table.options.enableGlobalFilter, meta.fontSize.size, state.grouping, meta.rowHeight.height,
10736
+ state.columnOrder, state.columnPinning, state.columnSizing, state.columnVisibility, table.options.enableGlobalFilter, meta.fontSize.size,
10737
+ //state.grouping,
10738
+ meta.rowHeight.height,
10736
10739
  //state.globalFilter,
10737
10740
  state.sorting]);
10738
10741
  }
@@ -11240,10 +11243,11 @@ function Row(props) {
11240
11243
  const TABLE_SCROLL_PADDING_BOTTOM = 36;
11241
11244
  const TABLE_PADDING_BOTTOM = 120;
11242
11245
  function useTableRenderer(renderers, table, tableRef, defaultRowActiveIndex) {
11243
- var _table$getState$group, _virtualItems$;
11246
+ var _table$getState$group, _ref, _virtualItems$padding, _virtualItems$padding2, _ref2, _virtualItems;
11244
11247
  const tableMeta = table.options.meta;
11245
11248
  const rows = table.getRowModel().rows;
11246
11249
  const HEADER_OFFSET_TOTAL = HEADER_ROW_HEIGHT_ESTIMATE * table.getHeaderGroups().length;
11250
+ const isTableGrouped = !!((_table$getState$group = table.getState().grouping) !== null && _table$getState$group !== void 0 && _table$getState$group.length);
11247
11251
  // expanded rows
11248
11252
  const {
11249
11253
  createRowMeasurer,
@@ -11257,7 +11261,7 @@ function useTableRenderer(renderers, table, tableRef, defaultRowActiveIndex) {
11257
11261
  getScrollElement: () => tableRef.current,
11258
11262
  overscan: tableMeta.printing.isPrinting ? rows.length : undefined,
11259
11263
  rangeExtractor,
11260
- scrollPaddingStart: (_table$getState$group = table.getState().grouping) !== null && _table$getState$group !== void 0 && _table$getState$group.length ? HEADER_ROW_HEIGHT_ESTIMATE : undefined,
11264
+ scrollPaddingStart: isTableGrouped ? HEADER_ROW_HEIGHT_ESTIMATE : undefined,
11261
11265
  scrollPaddingEnd: HEADER_OFFSET_TOTAL + TABLE_SCROLL_PADDING_BOTTOM,
11262
11266
  paddingEnd: TABLE_PADDING_BOTTOM
11263
11267
  });
@@ -11290,10 +11294,12 @@ function useTableRenderer(renderers, table, tableRef, defaultRowActiveIndex) {
11290
11294
  }
11291
11295
  }
11292
11296
  }, [virtualItems.length, tableRef.current]);
11297
+ // use row 1 not 0, because 0 might be sticky in grouped tables and it's start value will always be 0
11298
+ const paddingStartIndex = isTableGrouped && rows.length > 1 ? 1 : 0;
11293
11299
  // styling for offsetting rows - this "is" the virtualisation
11294
11300
  const [paddingTop, paddingBottom] = virtualItems.length > 0 ? [
11295
11301
  // use row 1 not 0, because 0 might be sticky in grouped tables and it's start value will always be 0
11296
- Math.max(0, ((_virtualItems$ = virtualItems[1]) !== null && _virtualItems$ !== void 0 ? _virtualItems$ : virtualItems[0]).start - virtualiser.options.scrollMargin - virtualItems[0].size), Math.max(0, virtualiser.getTotalSize() - virtualItems[virtualItems.length - 1].end)] : [0, 0];
11302
+ Math.max(0, (_ref = ((_virtualItems$padding = virtualItems[paddingStartIndex]) === null || _virtualItems$padding === void 0 ? void 0 : _virtualItems$padding.start) - virtualiser.options.scrollMargin - ((_virtualItems$padding2 = virtualItems[paddingStartIndex]) === null || _virtualItems$padding2 === void 0 ? void 0 : _virtualItems$padding2.size)) !== null && _ref !== void 0 ? _ref : 0), Math.max(0, (_ref2 = virtualiser.getTotalSize() - ((_virtualItems = virtualItems[virtualItems.length - 1]) === null || _virtualItems === void 0 ? void 0 : _virtualItems.end)) !== null && _ref2 !== void 0 ? _ref2 : 0)] : [0, 0];
11297
11303
  // ensure default active rows are scrolled to
11298
11304
  React__default.useEffect(() => {
11299
11305
  if (defaultRowActiveIndex) {
@@ -11313,6 +11319,10 @@ function useTableRenderer(renderers, table, tableRef, defaultRowActiveIndex) {
11313
11319
  paddingTop
11314
11320
  };
11315
11321
  content = virtualItems.map(virtualRow => {
11322
+ // there appears to be a react-virtual bug where it inserts a single `undefined` item at the end of the row, which crashes here
11323
+ if (!virtualRow) {
11324
+ return null;
11325
+ }
11316
11326
  const row = rows[virtualRow.index];
11317
11327
  const measureRow = createRowMeasurer(virtualiser.resizeItem, virtualRow);
11318
11328
  return /*#__PURE__*/React__default.createElement(Row, {