@infomaximum/ui-kit 0.17.0 → 0.17.2

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.
Files changed (84) hide show
  1. package/dist/components/BaseTooltip/BaseTooltip.js +19 -5
  2. package/dist/components/BaseTooltip/BaseTooltip.types.d.ts +1 -0
  3. package/dist/components/BaseTooltip/BaseTooltip.utils.d.ts +3 -1
  4. package/dist/components/BaseTooltip/BaseTooltip.utils.js +32 -2
  5. package/dist/components/BaseTooltip/hooks/useCustomFloating.js +5 -4
  6. package/dist/components/BaseTooltip/hooks/useShowTooltipController.d.ts +2 -1
  7. package/dist/components/BaseTooltip/hooks/useShowTooltipController.js +56 -42
  8. package/dist/components/Dropdown/Dropdown.js +14 -8
  9. package/dist/components/Dropdown/Dropdown.types.d.ts +56 -19
  10. package/dist/components/Dropdown/Dropdown.utils.js +6 -2
  11. package/dist/components/Dropdown/components/Divider/Divider.d.ts +2 -1
  12. package/dist/components/Dropdown/components/Divider/Divider.js +5 -2
  13. package/dist/components/Dropdown/components/Divider/Divider.types.d.ts +3 -0
  14. package/dist/components/Dropdown/components/Group/Group.js +9 -6
  15. package/dist/components/Dropdown/components/Group/Group.types.d.ts +7 -3
  16. package/dist/components/Dropdown/components/Item/Item.js +17 -11
  17. package/dist/components/Dropdown/components/Item/Item.types.d.ts +1 -1
  18. package/dist/components/Dropdown/components/Menu/Menu.js +37 -13
  19. package/dist/components/Dropdown/components/Menu/Menu.styles.d.ts +1 -0
  20. package/dist/components/Dropdown/components/Menu/Menu.styles.js +2 -1
  21. package/dist/components/Dropdown/components/Menu/Menu.types.d.ts +0 -1
  22. package/dist/components/Dropdown/components/SubMenu/SubMenu.js +13 -6
  23. package/dist/components/Dropdown/components/SubMenu/SubMenu.types.d.ts +2 -2
  24. package/dist/components/Dropdown/components/SubMenu/SubMenu.utils.d.ts +2 -2
  25. package/dist/components/Dropdown/contexts/dropdownContext.d.ts +13 -10
  26. package/dist/components/Dropdown/hooks/useSelectedKeysController.d.ts +20 -17
  27. package/dist/components/Dropdown/hooks/useSelectedKeysController.js +7 -6
  28. package/dist/components/Dropdown/hooks/useSubMenusController.d.ts +5 -4
  29. package/dist/components/Dropdown/index.d.ts +2 -1
  30. package/dist/components/Empty/components/images/BookmarkImg.js +8 -4
  31. package/dist/components/Empty/components/images/DefaultImg.js +8 -4
  32. package/dist/components/Empty/components/images/FilterImg.js +8 -4
  33. package/dist/components/Empty/components/images/LockedImg.js +8 -4
  34. package/dist/components/Empty/components/images/SearchImg.js +8 -4
  35. package/dist/components/Empty/components/images/TestingImg.js +8 -4
  36. package/dist/components/Empty/components/images/_404Img.js +8 -4
  37. package/dist/components/Spin/Spin.js +19 -32
  38. package/dist/components/Table/Table.js +23 -17
  39. package/dist/components/Table/Table.types.d.ts +4 -1
  40. package/dist/components/Table/components/Body/Body.js +18 -9
  41. package/dist/components/Table/components/Body/Body.types.d.ts +1 -0
  42. package/dist/components/Table/components/Body/components/BodyCell/BodyCell.js +22 -16
  43. package/dist/components/Table/components/Body/components/MeasureCell/MeasureCell.js +2 -1
  44. package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.js +24 -18
  45. package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.utils.d.ts +1 -0
  46. package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.utils.js +3 -1
  47. package/dist/components/Table/components/Cell/Cell.d.ts +1 -2
  48. package/dist/components/Table/components/Cell/Cell.js +4 -3
  49. package/dist/components/Table/components/Cell/Cell.styles.d.ts +6 -0
  50. package/dist/components/Table/components/Cell/Cell.styles.js +6 -0
  51. package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.styles.d.ts +1 -0
  52. package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.styles.js +1 -0
  53. package/dist/components/Table/components/Footer/FooterWrapper.d.ts +3 -0
  54. package/dist/components/Table/components/Footer/FooterWrapper.js +36 -0
  55. package/dist/components/Table/components/Footer/FooterWrapper.types.d.ts +5 -0
  56. package/dist/components/Table/features/tableRowSelection/components/CheckboxCellContentWrapper/CheckboxCellContentWrapper.js +3 -2
  57. package/dist/components/Table/features/tableRowSelection/components/RadioCellContentWrapper/RadioCellContentWrapper.js +3 -2
  58. package/dist/components/Table/features/tableRowSelection/hooks/useTransformColumns/useTransformColumns.js +51 -40
  59. package/dist/components/Table/features/tableRowSelection/types.d.ts +3 -2
  60. package/dist/components/Table/features/tableStaticContext/contexts/tableStaticContext/TableStaticContext.d.ts +1 -0
  61. package/dist/components/Table/features/tableStaticContext/contexts/tableStaticContext/TableStaticContext.js +2 -1
  62. package/dist/components/Table/features/tableStaticContext/contexts/tableStaticContext/TableStaticContext.types.d.ts +2 -0
  63. package/dist/components/Table/features/tableStaticContext/hocs/withTableStaticContext.js +6 -1
  64. package/dist/components/Table/hooks/useBodyCellRender/useBodyCellRender.js +5 -2
  65. package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.js +20 -22
  66. package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.styles.d.ts +4 -2
  67. package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.styles.js +4 -3
  68. package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.utils.d.ts +12 -1
  69. package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.utils.js +43 -1
  70. package/dist/components/Table/hooks/useCellHover/useCellHover.d.ts +0 -4
  71. package/dist/components/Table/hooks/useCellHover/useCellHover.js +2 -4
  72. package/dist/components/Table/hooks/useTableVisualParamsChange/useTableVisualParamsChange.js +8 -4
  73. package/dist/components/Tabs/Tabs.js +1 -1
  74. package/dist/components/Tabs/Tabs.types.d.ts +5 -4
  75. package/dist/components/Tabs/Tabs.utils.d.ts +3 -2
  76. package/dist/components/Tabs/components/TabBar/TabBar.types.d.ts +3 -2
  77. package/dist/components/Tabs/components/TabItem/TabItem.types.d.ts +8 -7
  78. package/dist/components/Tabs/hooks/useMoreTabsController.d.ts +5 -5
  79. package/dist/components/Tabs/hooks/useTabsDndController.d.ts +2 -1
  80. package/dist/index.d.ts +2 -2
  81. package/dist/index.js +5 -0
  82. package/dist/utils/eventBus/eventBus.d.ts +2 -1
  83. package/dist/utils/eventBus/eventBus.js +3 -0
  84. package/package.json +1 -1
@@ -1,5 +1,5 @@
1
1
  import { jsx, jsxs, Fragment } from "@emotion/react/jsx-runtime";
2
- import { memo, forwardRef, useMemo, Fragment as Fragment$1 } from "react";
2
+ import { memo, forwardRef, useMemo, useCallback } from "react";
3
3
  import { Header } from "./components/Header/Header.js";
4
4
  import { Body } from "./components/Body/Body.js";
5
5
  import { useStatic } from "../../hooks/useStatic/useStatic.js";
@@ -8,9 +8,11 @@ import { FixedHeader } from "./components/FixedHeader/FixedHeader.js";
8
8
  import { BodyColGroup } from "./components/Body/components/BodyColGroup/BodyColGroup.js";
9
9
  import { withEventBus } from "../../utils/eventBus/hocs/withEventBus/withEventBus.js";
10
10
  import { useFirstMount } from "../../hooks/useFirstMount/useFirstMount.js";
11
- import { isNil, isObject, isUndefined, isBoolean } from "lodash-es";
11
+ import { isNil, isObject, isBoolean, isUndefined } from "lodash-es";
12
12
  import { getTableComponentWrapperStyle, getTableComponentStyle, tableStyle } from "./Table.styles.js";
13
13
  import { getTableTokens } from "./Table.tokens.js";
14
+ import { usePrevious } from "../../hooks/usePrevious.js";
15
+ import { FooterWrapper } from "./components/Footer/FooterWrapper.js";
14
16
  import { withTableStaticContext } from "./features/tableStaticContext/hocs/withTableStaticContext.js";
15
17
  import { useTheme } from "../../hooks/useTheme/useTheme.js";
16
18
  import { useTableComponents } from "./hooks/useTableComponents/useTableComponents.js";
@@ -67,9 +69,10 @@ const TableComponent = (props, ref) => {
67
69
  const scrollY = scroll == null ? void 0 : scroll.y;
68
70
  const fixHeader = !isNil(scrollY);
69
71
  const horizonScroll = !isNil(scrollX);
70
- const fixColumn = horizonScroll && flattedColumns.some(({
72
+ const hasFixedColumn = flattedColumns.some(({
71
73
  fixed
72
74
  }) => fixed);
75
+ const fixColumn = horizonScroll && hasFixedColumn;
73
76
  const {
74
77
  expandIconColumnIndex,
75
78
  indentSize,
@@ -192,12 +195,20 @@ const TableComponent = (props, ref) => {
192
195
  sortState,
193
196
  isTableFirstMount
194
197
  });
198
+ const spinProps = (() => {
199
+ if (isBoolean(loading)) {
200
+ return {
201
+ spinning: loading
202
+ };
203
+ }
204
+ return loading;
205
+ })();
195
206
  const TableComponent2 = getComponent(["table"], "table");
196
207
  const bodyColGroup = /* @__PURE__ */ jsx(BodyColGroup, {});
197
- const bodyTable = /* @__PURE__ */ jsx(Body, { expandable, sortedData, needMeasureColumnWidth: fixHeader || fixColumn, renderNullifyBody: isUndefined(dataSource) });
208
+ const bodyTable = /* @__PURE__ */ jsx(Body, { expandable, sortedData, needMeasureColumnWidth: fixHeader || fixColumn, renderNullifyBody: isUndefined(dataSource), spinning: spinProps.spinning });
198
209
  const groupTableNode = fixHeader ? /* @__PURE__ */ jsxs(Fragment, { children: [
199
210
  showHeader && /* @__PURE__ */ jsx(FixedHeader, { ref: tableHeaderRef, scrollX, onScroll: onTableHeaderScroll }),
200
- /* @__PURE__ */ jsx("div", { className: "rc-table-body", css: [getTableComponentWrapperStyle("body", fixHeader, hasData, scrollY, horizonScroll), (_a = styles == null ? void 0 : styles.tableBodyComponentWrapper) == null ? void 0 : _a.call(styles, tableTokens, theme), process.env.NODE_ENV === "production" ? "" : ";label:groupTableNode;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx"],"names":[],"mappings":"AAsPQ","file":"/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx","sourcesContent":["import { forwardRef, memo, useMemo, type ForwardedRef, Fragment } from \"react\";\nimport type { BorderedConfig, DefaultRecord, TableLayout, TableProps } from \"./Table.types\";\nimport { Header } from \"./components/Header/Header\";\nimport { Body } from \"./components/Body/Body\";\nimport { useTableComponents } from \"./hooks/useTableComponents\";\nimport { useTableColumns } from \"./hooks/useTableColumns\";\nimport { useTableExpand } from \"./features/tableExpand\";\nimport { defaultSortDirections, useTableSort } from \"./features/tableSort\";\nimport { useStatic } from \"hooks/useStatic\";\nimport ResizeObserver from \"rc-resize-observer\";\nimport { FixedHeader } from \"./components/FixedHeader/FixedHeader\";\nimport { BodyColGroup } from \"./components/Body/components/BodyColGroup/BodyColGroup\";\nimport { updateRefValue } from \"./utils\";\nimport { withEventBus } from \"utils/eventBus/hocs/withEventBus\";\nimport { useFirstMount } from \"hooks/useFirstMount\";\nimport { useTableVisualParamsChange } from \"./hooks/useTableVisualParamsChange\";\nimport { isBoolean, isNil, isObject, isUndefined } from \"lodash-es\";\nimport { getTableComponentStyle, getTableComponentWrapperStyle, tableStyle } from \"./Table.styles\";\nimport { useTableStaticContext, withTableStaticContext } from \"./features/tableStaticContext\";\nimport { createTableContext, type TableContextValue } from \"./contexts\";\nimport {\n  useTableRowSelection,\n  TableRowSelectionContext,\n  type TableRowSelectionContextValue,\n} from \"./features/tableRowSelection\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { getTableTokens } from \"./Table.tokens\";\nimport { Spin, type SpinProps } from \"components/Spin\";\n\nconst TableComponent = <Record extends DefaultRecord>(\n  props: TableProps<Record>,\n  ref: ForwardedRef<HTMLDivElement>\n) => {\n  const {\n    columns: columnsProp,\n    dataSource,\n    components: componentsProp,\n    expandable,\n    rowSelection,\n    sortDirections = defaultSortDirections,\n    scroll,\n    showHeader = true,\n    loading = false,\n    tableLayout: tableLayoutProp,\n    bordered: borderedProp,\n    styles,\n    footer,\n    onHeaderRow,\n    onRow,\n    onChange,\n    onScroll,\n  } = props;\n  const theme = useTheme();\n  const tableTokens = useMemo(() => getTableTokens(theme), [theme]);\n  const isTableFirstMount = useFirstMount();\n  const { getComponent } = useTableComponents({ components: componentsProp });\n  const staticContextRef = useTableStaticContext<Record>();\n\n  const { columns, flattedColumns, isAllColumnsFixedStart } = useTableColumns({\n    columns: columnsProp,\n    rowSelection,\n  });\n\n  const scrollX = scroll?.x;\n  const scrollY = scroll?.y;\n  const fixHeader = !isNil(scrollY);\n  const horizonScroll = !isNil(scrollX);\n  const fixColumn = horizonScroll && flattedColumns.some(({ fixed }) => fixed);\n\n  const { expandIconColumnIndex, indentSize, ExpandIcon, isSomeRecordHasChildren } =\n    useTableExpand<Record>({ expandable, dataSource, rowSelection });\n\n  const { sortState, sortedData, hasData, triggerSorter } = useTableSort<Record>({\n    dataSource,\n    onChange,\n  });\n\n  const {\n    keySet,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    flattedData,\n    checkboxPropsMap,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    derivedHalfSelectedKeySet,\n    recordKeys,\n    triggerSingleSelection,\n    setSelectedKeys,\n    multipleSelect,\n    updatePrevSelectedIndex,\n  } = useTableRowSelection<Record>({\n    rowSelection,\n    dataSource,\n    sortedData,\n  });\n  const {\n    tableHeaderRef,\n    scrollableTableSectionRef,\n    onTableContentScroll,\n    onTableHeaderScroll,\n    onTableBodyScroll,\n    onResize,\n  } = useTableVisualParamsChange({\n    fixColumn,\n    onScroll,\n  });\n\n  const tableLayout = useMemo<TableLayout>(() => {\n    if (tableLayoutProp) {\n      return tableLayoutProp;\n    }\n\n    if (fixColumn) {\n      return scrollX === \"max-content\" ? \"auto\" : \"fixed\";\n    }\n\n    if (fixHeader || flattedColumns.some(({ ellipsis }) => ellipsis)) {\n      return \"fixed\";\n    }\n\n    return \"auto\";\n  }, [fixColumn, fixHeader, flattedColumns, scrollX, tableLayoutProp]);\n\n  const bordered = useMemo(() => {\n    if (borderedProp === true || isObject(borderedProp)) {\n      const defaultBorderedConfig: Required<BorderedConfig> = {\n        emptyBlockEnd: true,\n        emptyInline: true,\n        firstColumnCellInlineStart: true,\n        lastColumnCellInlineEnd: true,\n      };\n\n      return {\n        ...defaultBorderedConfig,\n        ...(isObject(borderedProp) ? borderedProp : {}),\n      };\n    }\n\n    return borderedProp;\n  }, [borderedProp]);\n\n  const TableContext = useStatic(() => createTableContext<Record>());\n  const tableContextValue = useMemo<TableContextValue<Record>>(() => {\n    return {\n      showHeader,\n\n      tableTokens,\n\n      getComponent,\n\n      columns,\n      flattedColumns,\n      isAllColumnsFixedStart,\n\n      expandIconColumnIndex,\n      ExpandIcon,\n      indentSize,\n      isSomeRecordHasChildren,\n\n      sortDirections,\n\n      onHeaderRow,\n      onRow,\n\n      tableLayout,\n\n      bordered,\n      horizonScroll,\n    };\n  }, [\n    ExpandIcon,\n    bordered,\n    columns,\n    expandIconColumnIndex,\n    flattedColumns,\n    getComponent,\n    horizonScroll,\n    indentSize,\n    isAllColumnsFixedStart,\n    isSomeRecordHasChildren,\n    onHeaderRow,\n    onRow,\n    showHeader,\n    sortDirections,\n    tableLayout,\n    tableTokens,\n  ]);\n\n  const tableRowSelectionContextValue = useMemo<TableRowSelectionContextValue>(() => {\n    return {\n      keySet,\n      checkedCurrentAll,\n      checkedCurrentSome,\n      flattedData,\n      checkboxPropsMap,\n      derivedHalfSelectedKeySet,\n      derivedSelectedKeySet,\n      derivedSelectedKeys,\n      recordKeys,\n      setSelectedKeys,\n      triggerSingleSelection,\n      multipleSelect,\n      updatePrevSelectedIndex,\n    };\n  }, [\n    checkboxPropsMap,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    derivedHalfSelectedKeySet,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    flattedData,\n    keySet,\n    multipleSelect,\n    recordKeys,\n    setSelectedKeys,\n    triggerSingleSelection,\n    updatePrevSelectedIndex,\n  ]);\n\n  updateRefValue(staticContextRef, {\n    staticSelectedKeySet: derivedSelectedKeySet,\n    triggerSorter,\n    sortState,\n    isTableFirstMount,\n  });\n\n  const TableComponent = getComponent([\"table\"], \"table\");\n  const bodyColGroup = <BodyColGroup />;\n  const bodyTable = (\n    <Body<Record>\n      expandable={expandable}\n      sortedData={sortedData}\n      needMeasureColumnWidth={fixHeader || fixColumn}\n      renderNullifyBody={isUndefined(dataSource)}\n    />\n  );\n\n  const groupTableNode = fixHeader ? (\n    <>\n      {showHeader && (\n        <FixedHeader ref={tableHeaderRef} scrollX={scrollX} onScroll={onTableHeaderScroll} />\n      )}\n      <div\n        className=\"rc-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, hasData, scrollY, horizonScroll),\n          styles?.tableBodyComponentWrapper?.(tableTokens, theme),\n        ]}\n        onScroll={onTableBodyScroll}\n        ref={scrollableTableSectionRef}\n      >\n        <TableComponent css={getTableComponentStyle(\"body\", tableLayout, scrollX, horizonScroll)}>\n          {bodyColGroup}\n          {bodyTable}\n        </TableComponent>\n      </div>\n    </>\n  ) : (\n    <div\n      className=\"rc-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, hasData, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent css={getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll)}>\n        {bodyColGroup}\n        {showHeader && <Header />}\n        {bodyTable}\n      </TableComponent>\n    </div>\n  );\n\n  const TableWrapper = horizonScroll ? ResizeObserver : Fragment;\n\n  const spinProps = ((): SpinProps => {\n    if (isBoolean(loading)) {\n      return { spinning: loading };\n    }\n\n    return loading;\n  })();\n\n  return (\n    <TableContext.Provider value={tableContextValue}>\n      <TableRowSelectionContext.Provider value={tableRowSelectionContextValue}>\n        <TableWrapper {...(horizonScroll ? { onResize } : {})}>\n          <Spin {...spinProps}>\n            <div\n              className=\"rc-table\"\n              css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}\n            >\n              <div\n                ref={ref}\n                className=\"rc-table-container\"\n                css={styles?.tableContainer?.(tableTokens, theme)}\n              >\n                {groupTableNode}\n              </div>\n              {footer?.(sortedData)}\n            </div>\n          </Spin>\n        </TableWrapper>\n      </TableRowSelectionContext.Provider>\n    </TableContext.Provider>\n  );\n};\n\nexport const Table = withEventBus(withTableStaticContext(memo(forwardRef(TableComponent)))) as <\n  Record extends DefaultRecord,\n>(\n  props: TableProps<Record> & { ref?: ForwardedRef<HTMLDivElement> }\n) => ReturnType<typeof TableComponent>;\n"]} */"], onScroll: onTableBodyScroll, ref: scrollableTableSectionRef, children: /* @__PURE__ */ jsxs(TableComponent2, { css: getTableComponentStyle("body", tableLayout, scrollX, horizonScroll), children: [
211
+ /* @__PURE__ */ jsx("div", { className: "rc-table-body", css: [getTableComponentWrapperStyle("body", fixHeader, hasData, scrollY, horizonScroll), (_a = styles == null ? void 0 : styles.tableBodyComponentWrapper) == null ? void 0 : _a.call(styles, tableTokens, theme), process.env.NODE_ENV === "production" ? "" : ";label:groupTableNode;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx"],"names":[],"mappings":"AAkQQ","file":"/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx","sourcesContent":["import { forwardRef, memo, useMemo, type ForwardedRef, useCallback } from \"react\";\nimport type { BorderedConfig, DefaultRecord, TableLayout, TableProps } from \"./Table.types\";\nimport { Header } from \"./components/Header/Header\";\nimport { Body } from \"./components/Body/Body\";\nimport { useTableComponents } from \"./hooks/useTableComponents\";\nimport { useTableColumns } from \"./hooks/useTableColumns\";\nimport { useTableExpand } from \"./features/tableExpand\";\nimport { defaultSortDirections, useTableSort } from \"./features/tableSort\";\nimport { useStatic } from \"hooks/useStatic\";\nimport ResizeObserver, { type OnResize } from \"rc-resize-observer\";\nimport { FixedHeader } from \"./components/FixedHeader/FixedHeader\";\nimport { BodyColGroup } from \"./components/Body/components/BodyColGroup/BodyColGroup\";\nimport { updateRefValue } from \"./utils\";\nimport { withEventBus } from \"utils/eventBus/hocs/withEventBus\";\nimport { useFirstMount } from \"hooks/useFirstMount\";\nimport { useTableVisualParamsChange } from \"./hooks/useTableVisualParamsChange\";\nimport { isBoolean, isNil, isObject, isUndefined } from \"lodash-es\";\nimport { getTableComponentStyle, getTableComponentWrapperStyle, tableStyle } from \"./Table.styles\";\nimport { useTableStaticContext, withTableStaticContext } from \"./features/tableStaticContext\";\nimport { createTableContext, type TableContextValue } from \"./contexts\";\nimport {\n  useTableRowSelection,\n  TableRowSelectionContext,\n  type TableRowSelectionContextValue,\n} from \"./features/tableRowSelection\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { getTableTokens } from \"./Table.tokens\";\nimport { Spin, type SpinProps } from \"components/Spin\";\nimport { usePrevious } from \"hooks/usePrevious\";\nimport { FooterWrapper } from \"./components/Footer/FooterWrapper\";\n\nconst TableComponent = <Record extends DefaultRecord>(\n  props: TableProps<Record>,\n  ref: ForwardedRef<HTMLDivElement>\n) => {\n  const {\n    columns: columnsProp,\n    dataSource,\n    components: componentsProp,\n    expandable,\n    rowSelection,\n    sortDirections = defaultSortDirections,\n    scroll,\n    showHeader = true,\n    loading = false,\n    tableLayout: tableLayoutProp,\n    bordered: borderedProp,\n    styles,\n    footer,\n    onHeaderRow,\n    onRow,\n    onChange,\n    onScroll,\n  } = props;\n  const theme = useTheme();\n  const tableTokens = useMemo(() => getTableTokens(theme), [theme]);\n  const isTableFirstMount = useFirstMount();\n  const { getComponent } = useTableComponents({ components: componentsProp });\n  const staticContextRef = useTableStaticContext<Record>();\n\n  const { columns, flattedColumns, isAllColumnsFixedStart } = useTableColumns({\n    columns: columnsProp,\n    rowSelection,\n  });\n\n  const scrollX = scroll?.x;\n  const scrollY = scroll?.y;\n  const fixHeader = !isNil(scrollY);\n  const horizonScroll = !isNil(scrollX);\n  const hasFixedColumn = flattedColumns.some(({ fixed }) => fixed);\n  const fixColumn = horizonScroll && hasFixedColumn;\n\n  const { expandIconColumnIndex, indentSize, ExpandIcon, isSomeRecordHasChildren } =\n    useTableExpand<Record>({ expandable, dataSource, rowSelection });\n\n  const { sortState, sortedData, hasData, triggerSorter } = useTableSort<Record>({\n    dataSource,\n    onChange,\n  });\n\n  const {\n    keySet,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    flattedData,\n    checkboxPropsMap,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    derivedHalfSelectedKeySet,\n    recordKeys,\n    triggerSingleSelection,\n    setSelectedKeys,\n    multipleSelect,\n    updatePrevSelectedIndex,\n  } = useTableRowSelection<Record>({\n    rowSelection,\n    dataSource,\n    sortedData,\n  });\n  const {\n    tableHeaderRef,\n    scrollableTableSectionRef,\n    onTableContentScroll,\n    onTableHeaderScroll,\n    onTableBodyScroll,\n    onResize,\n  } = useTableVisualParamsChange({\n    fixColumn,\n    onScroll,\n  });\n\n  const tableLayout = useMemo<TableLayout>(() => {\n    if (tableLayoutProp) {\n      return tableLayoutProp;\n    }\n\n    if (fixColumn) {\n      return scrollX === \"max-content\" ? \"auto\" : \"fixed\";\n    }\n\n    if (fixHeader || flattedColumns.some(({ ellipsis }) => ellipsis)) {\n      return \"fixed\";\n    }\n\n    return \"auto\";\n  }, [fixColumn, fixHeader, flattedColumns, scrollX, tableLayoutProp]);\n\n  const bordered = useMemo(() => {\n    if (borderedProp === true || isObject(borderedProp)) {\n      const defaultBorderedConfig: Required<BorderedConfig> = {\n        emptyBlockEnd: true,\n        emptyInline: true,\n        firstColumnCellInlineStart: true,\n        lastColumnCellInlineEnd: true,\n      };\n\n      return {\n        ...defaultBorderedConfig,\n        ...(isObject(borderedProp) ? borderedProp : {}),\n      };\n    }\n\n    return borderedProp;\n  }, [borderedProp]);\n\n  const TableContext = useStatic(() => createTableContext<Record>());\n  const tableContextValue = useMemo<TableContextValue<Record>>(() => {\n    return {\n      showHeader,\n\n      tableTokens,\n\n      getComponent,\n\n      columns,\n      flattedColumns,\n      isAllColumnsFixedStart,\n\n      expandIconColumnIndex,\n      ExpandIcon,\n      indentSize,\n      isSomeRecordHasChildren,\n\n      sortDirections,\n\n      onHeaderRow,\n      onRow,\n\n      tableLayout,\n\n      bordered,\n      horizonScroll,\n    };\n  }, [\n    ExpandIcon,\n    bordered,\n    columns,\n    expandIconColumnIndex,\n    flattedColumns,\n    getComponent,\n    horizonScroll,\n    indentSize,\n    isAllColumnsFixedStart,\n    isSomeRecordHasChildren,\n    onHeaderRow,\n    onRow,\n    showHeader,\n    sortDirections,\n    tableLayout,\n    tableTokens,\n  ]);\n\n  const tableRowSelectionContextValue = useMemo<TableRowSelectionContextValue>(() => {\n    return {\n      keySet,\n      checkedCurrentAll,\n      checkedCurrentSome,\n      flattedData,\n      checkboxPropsMap,\n      derivedHalfSelectedKeySet,\n      derivedSelectedKeySet,\n      derivedSelectedKeys,\n      recordKeys,\n      setSelectedKeys,\n      triggerSingleSelection,\n      multipleSelect,\n      updatePrevSelectedIndex,\n    };\n  }, [\n    checkboxPropsMap,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    derivedHalfSelectedKeySet,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    flattedData,\n    keySet,\n    multipleSelect,\n    recordKeys,\n    setSelectedKeys,\n    triggerSingleSelection,\n    updatePrevSelectedIndex,\n  ]);\n\n  updateRefValue(staticContextRef, {\n    staticSelectedKeySet: derivedSelectedKeySet,\n    triggerSorter,\n    sortState,\n    isTableFirstMount,\n  });\n\n  const spinProps = ((): SpinProps => {\n    if (isBoolean(loading)) {\n      return { spinning: loading };\n    }\n\n    return loading;\n  })();\n\n  const TableComponent = getComponent([\"table\"], \"table\");\n  const bodyColGroup = <BodyColGroup />;\n  const bodyTable = (\n    <Body<Record>\n      expandable={expandable}\n      sortedData={sortedData}\n      needMeasureColumnWidth={fixHeader || fixColumn}\n      renderNullifyBody={isUndefined(dataSource)}\n      spinning={spinProps.spinning}\n    />\n  );\n\n  const groupTableNode = fixHeader ? (\n    <>\n      {showHeader && (\n        <FixedHeader ref={tableHeaderRef} scrollX={scrollX} onScroll={onTableHeaderScroll} />\n      )}\n      <div\n        className=\"rc-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, hasData, scrollY, horizonScroll),\n          styles?.tableBodyComponentWrapper?.(tableTokens, theme),\n        ]}\n        onScroll={onTableBodyScroll}\n        ref={scrollableTableSectionRef}\n      >\n        <TableComponent css={getTableComponentStyle(\"body\", tableLayout, scrollX, horizonScroll)}>\n          {bodyColGroup}\n          {bodyTable}\n        </TableComponent>\n      </div>\n    </>\n  ) : (\n    <div\n      className=\"rc-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, hasData, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent css={getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll)}>\n        {bodyColGroup}\n        {showHeader && <Header />}\n        {bodyTable}\n      </TableComponent>\n    </div>\n  );\n\n  const prevHorizonScroll = usePrevious(horizonScroll);\n\n  const handleLostHorizonScrollResize = useCallback<OnResize>(\n    (size, element) => {\n      if (hasFixedColumn && prevHorizonScroll && !horizonScroll) {\n        onResize(size, element);\n      }\n    },\n    [hasFixedColumn, horizonScroll, onResize, prevHorizonScroll]\n  );\n\n  return (\n    <TableContext.Provider value={tableContextValue}>\n      <TableRowSelectionContext.Provider value={tableRowSelectionContextValue}>\n        <ResizeObserver onResize={horizonScroll ? onResize : handleLostHorizonScrollResize}>\n          <Spin {...spinProps}>\n            <div\n              className=\"rc-table\"\n              css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}\n            >\n              <div\n                ref={ref}\n                className=\"rc-table-container\"\n                css={styles?.tableContainer?.(tableTokens, theme)}\n              >\n                {groupTableNode}\n              </div>\n              {footer && <FooterWrapper footer={footer} sortedData={sortedData} />}\n            </div>\n          </Spin>\n        </ResizeObserver>\n      </TableRowSelectionContext.Provider>\n    </TableContext.Provider>\n  );\n};\n\nexport const Table = withEventBus(withTableStaticContext(memo(forwardRef(TableComponent)))) as <\n  Record extends DefaultRecord,\n>(\n  props: TableProps<Record> & { ref?: ForwardedRef<HTMLDivElement> }\n) => ReturnType<typeof TableComponent>;\n"]} */"], onScroll: onTableBodyScroll, ref: scrollableTableSectionRef, children: /* @__PURE__ */ jsxs(TableComponent2, { css: getTableComponentStyle("body", tableLayout, scrollX, horizonScroll), children: [
201
212
  bodyColGroup,
202
213
  bodyTable
203
214
  ] }) })
@@ -206,20 +217,15 @@ const TableComponent = (props, ref) => {
206
217
  showHeader && /* @__PURE__ */ jsx(Header, {}),
207
218
  bodyTable
208
219
  ] }) });
209
- const TableWrapper = horizonScroll ? ResizeObserver : Fragment$1;
210
- const spinProps = (() => {
211
- if (isBoolean(loading)) {
212
- return {
213
- spinning: loading
214
- };
220
+ const prevHorizonScroll = usePrevious(horizonScroll);
221
+ const handleLostHorizonScrollResize = useCallback((size, element) => {
222
+ if (hasFixedColumn && prevHorizonScroll && !horizonScroll) {
223
+ onResize(size, element);
215
224
  }
216
- return loading;
217
- })();
218
- return /* @__PURE__ */ jsx(TableContext.Provider, { value: tableContextValue, children: /* @__PURE__ */ jsx(TableRowSelectionContext.Provider, { value: tableRowSelectionContextValue, children: /* @__PURE__ */ jsx(TableWrapper, { ...horizonScroll ? {
219
- onResize
220
- } : {}, children: /* @__PURE__ */ jsx(Spin, { ...spinProps, children: /* @__PURE__ */ jsxs("div", { className: "rc-table", css: [tableStyle(theme), (_b = styles == null ? void 0 : styles.table) == null ? void 0 : _b.call(styles, tableTokens, theme), process.env.NODE_ENV === "production" ? "" : ";label:TableComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx"],"names":[],"mappings":"AAmSc","file":"/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx","sourcesContent":["import { forwardRef, memo, useMemo, type ForwardedRef, Fragment } from \"react\";\nimport type { BorderedConfig, DefaultRecord, TableLayout, TableProps } from \"./Table.types\";\nimport { Header } from \"./components/Header/Header\";\nimport { Body } from \"./components/Body/Body\";\nimport { useTableComponents } from \"./hooks/useTableComponents\";\nimport { useTableColumns } from \"./hooks/useTableColumns\";\nimport { useTableExpand } from \"./features/tableExpand\";\nimport { defaultSortDirections, useTableSort } from \"./features/tableSort\";\nimport { useStatic } from \"hooks/useStatic\";\nimport ResizeObserver from \"rc-resize-observer\";\nimport { FixedHeader } from \"./components/FixedHeader/FixedHeader\";\nimport { BodyColGroup } from \"./components/Body/components/BodyColGroup/BodyColGroup\";\nimport { updateRefValue } from \"./utils\";\nimport { withEventBus } from \"utils/eventBus/hocs/withEventBus\";\nimport { useFirstMount } from \"hooks/useFirstMount\";\nimport { useTableVisualParamsChange } from \"./hooks/useTableVisualParamsChange\";\nimport { isBoolean, isNil, isObject, isUndefined } from \"lodash-es\";\nimport { getTableComponentStyle, getTableComponentWrapperStyle, tableStyle } from \"./Table.styles\";\nimport { useTableStaticContext, withTableStaticContext } from \"./features/tableStaticContext\";\nimport { createTableContext, type TableContextValue } from \"./contexts\";\nimport {\n  useTableRowSelection,\n  TableRowSelectionContext,\n  type TableRowSelectionContextValue,\n} from \"./features/tableRowSelection\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { getTableTokens } from \"./Table.tokens\";\nimport { Spin, type SpinProps } from \"components/Spin\";\n\nconst TableComponent = <Record extends DefaultRecord>(\n  props: TableProps<Record>,\n  ref: ForwardedRef<HTMLDivElement>\n) => {\n  const {\n    columns: columnsProp,\n    dataSource,\n    components: componentsProp,\n    expandable,\n    rowSelection,\n    sortDirections = defaultSortDirections,\n    scroll,\n    showHeader = true,\n    loading = false,\n    tableLayout: tableLayoutProp,\n    bordered: borderedProp,\n    styles,\n    footer,\n    onHeaderRow,\n    onRow,\n    onChange,\n    onScroll,\n  } = props;\n  const theme = useTheme();\n  const tableTokens = useMemo(() => getTableTokens(theme), [theme]);\n  const isTableFirstMount = useFirstMount();\n  const { getComponent } = useTableComponents({ components: componentsProp });\n  const staticContextRef = useTableStaticContext<Record>();\n\n  const { columns, flattedColumns, isAllColumnsFixedStart } = useTableColumns({\n    columns: columnsProp,\n    rowSelection,\n  });\n\n  const scrollX = scroll?.x;\n  const scrollY = scroll?.y;\n  const fixHeader = !isNil(scrollY);\n  const horizonScroll = !isNil(scrollX);\n  const fixColumn = horizonScroll && flattedColumns.some(({ fixed }) => fixed);\n\n  const { expandIconColumnIndex, indentSize, ExpandIcon, isSomeRecordHasChildren } =\n    useTableExpand<Record>({ expandable, dataSource, rowSelection });\n\n  const { sortState, sortedData, hasData, triggerSorter } = useTableSort<Record>({\n    dataSource,\n    onChange,\n  });\n\n  const {\n    keySet,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    flattedData,\n    checkboxPropsMap,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    derivedHalfSelectedKeySet,\n    recordKeys,\n    triggerSingleSelection,\n    setSelectedKeys,\n    multipleSelect,\n    updatePrevSelectedIndex,\n  } = useTableRowSelection<Record>({\n    rowSelection,\n    dataSource,\n    sortedData,\n  });\n  const {\n    tableHeaderRef,\n    scrollableTableSectionRef,\n    onTableContentScroll,\n    onTableHeaderScroll,\n    onTableBodyScroll,\n    onResize,\n  } = useTableVisualParamsChange({\n    fixColumn,\n    onScroll,\n  });\n\n  const tableLayout = useMemo<TableLayout>(() => {\n    if (tableLayoutProp) {\n      return tableLayoutProp;\n    }\n\n    if (fixColumn) {\n      return scrollX === \"max-content\" ? \"auto\" : \"fixed\";\n    }\n\n    if (fixHeader || flattedColumns.some(({ ellipsis }) => ellipsis)) {\n      return \"fixed\";\n    }\n\n    return \"auto\";\n  }, [fixColumn, fixHeader, flattedColumns, scrollX, tableLayoutProp]);\n\n  const bordered = useMemo(() => {\n    if (borderedProp === true || isObject(borderedProp)) {\n      const defaultBorderedConfig: Required<BorderedConfig> = {\n        emptyBlockEnd: true,\n        emptyInline: true,\n        firstColumnCellInlineStart: true,\n        lastColumnCellInlineEnd: true,\n      };\n\n      return {\n        ...defaultBorderedConfig,\n        ...(isObject(borderedProp) ? borderedProp : {}),\n      };\n    }\n\n    return borderedProp;\n  }, [borderedProp]);\n\n  const TableContext = useStatic(() => createTableContext<Record>());\n  const tableContextValue = useMemo<TableContextValue<Record>>(() => {\n    return {\n      showHeader,\n\n      tableTokens,\n\n      getComponent,\n\n      columns,\n      flattedColumns,\n      isAllColumnsFixedStart,\n\n      expandIconColumnIndex,\n      ExpandIcon,\n      indentSize,\n      isSomeRecordHasChildren,\n\n      sortDirections,\n\n      onHeaderRow,\n      onRow,\n\n      tableLayout,\n\n      bordered,\n      horizonScroll,\n    };\n  }, [\n    ExpandIcon,\n    bordered,\n    columns,\n    expandIconColumnIndex,\n    flattedColumns,\n    getComponent,\n    horizonScroll,\n    indentSize,\n    isAllColumnsFixedStart,\n    isSomeRecordHasChildren,\n    onHeaderRow,\n    onRow,\n    showHeader,\n    sortDirections,\n    tableLayout,\n    tableTokens,\n  ]);\n\n  const tableRowSelectionContextValue = useMemo<TableRowSelectionContextValue>(() => {\n    return {\n      keySet,\n      checkedCurrentAll,\n      checkedCurrentSome,\n      flattedData,\n      checkboxPropsMap,\n      derivedHalfSelectedKeySet,\n      derivedSelectedKeySet,\n      derivedSelectedKeys,\n      recordKeys,\n      setSelectedKeys,\n      triggerSingleSelection,\n      multipleSelect,\n      updatePrevSelectedIndex,\n    };\n  }, [\n    checkboxPropsMap,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    derivedHalfSelectedKeySet,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    flattedData,\n    keySet,\n    multipleSelect,\n    recordKeys,\n    setSelectedKeys,\n    triggerSingleSelection,\n    updatePrevSelectedIndex,\n  ]);\n\n  updateRefValue(staticContextRef, {\n    staticSelectedKeySet: derivedSelectedKeySet,\n    triggerSorter,\n    sortState,\n    isTableFirstMount,\n  });\n\n  const TableComponent = getComponent([\"table\"], \"table\");\n  const bodyColGroup = <BodyColGroup />;\n  const bodyTable = (\n    <Body<Record>\n      expandable={expandable}\n      sortedData={sortedData}\n      needMeasureColumnWidth={fixHeader || fixColumn}\n      renderNullifyBody={isUndefined(dataSource)}\n    />\n  );\n\n  const groupTableNode = fixHeader ? (\n    <>\n      {showHeader && (\n        <FixedHeader ref={tableHeaderRef} scrollX={scrollX} onScroll={onTableHeaderScroll} />\n      )}\n      <div\n        className=\"rc-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, hasData, scrollY, horizonScroll),\n          styles?.tableBodyComponentWrapper?.(tableTokens, theme),\n        ]}\n        onScroll={onTableBodyScroll}\n        ref={scrollableTableSectionRef}\n      >\n        <TableComponent css={getTableComponentStyle(\"body\", tableLayout, scrollX, horizonScroll)}>\n          {bodyColGroup}\n          {bodyTable}\n        </TableComponent>\n      </div>\n    </>\n  ) : (\n    <div\n      className=\"rc-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, hasData, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent css={getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll)}>\n        {bodyColGroup}\n        {showHeader && <Header />}\n        {bodyTable}\n      </TableComponent>\n    </div>\n  );\n\n  const TableWrapper = horizonScroll ? ResizeObserver : Fragment;\n\n  const spinProps = ((): SpinProps => {\n    if (isBoolean(loading)) {\n      return { spinning: loading };\n    }\n\n    return loading;\n  })();\n\n  return (\n    <TableContext.Provider value={tableContextValue}>\n      <TableRowSelectionContext.Provider value={tableRowSelectionContextValue}>\n        <TableWrapper {...(horizonScroll ? { onResize } : {})}>\n          <Spin {...spinProps}>\n            <div\n              className=\"rc-table\"\n              css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}\n            >\n              <div\n                ref={ref}\n                className=\"rc-table-container\"\n                css={styles?.tableContainer?.(tableTokens, theme)}\n              >\n                {groupTableNode}\n              </div>\n              {footer?.(sortedData)}\n            </div>\n          </Spin>\n        </TableWrapper>\n      </TableRowSelectionContext.Provider>\n    </TableContext.Provider>\n  );\n};\n\nexport const Table = withEventBus(withTableStaticContext(memo(forwardRef(TableComponent)))) as <\n  Record extends DefaultRecord,\n>(\n  props: TableProps<Record> & { ref?: ForwardedRef<HTMLDivElement> }\n) => ReturnType<typeof TableComponent>;\n"]} */"], children: [
225
+ }, [hasFixedColumn, horizonScroll, onResize, prevHorizonScroll]);
226
+ return /* @__PURE__ */ jsx(TableContext.Provider, { value: tableContextValue, children: /* @__PURE__ */ jsx(TableRowSelectionContext.Provider, { value: tableRowSelectionContextValue, children: /* @__PURE__ */ jsx(ResizeObserver, { onResize: horizonScroll ? onResize : handleLostHorizonScrollResize, children: /* @__PURE__ */ jsx(Spin, { ...spinProps, children: /* @__PURE__ */ jsxs("div", { className: "rc-table", css: [tableStyle(theme), (_b = styles == null ? void 0 : styles.table) == null ? void 0 : _b.call(styles, tableTokens, theme), process.env.NODE_ENV === "production" ? "" : ";label:TableComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx"],"names":[],"mappings":"AAgTc","file":"/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx","sourcesContent":["import { forwardRef, memo, useMemo, type ForwardedRef, useCallback } from \"react\";\nimport type { BorderedConfig, DefaultRecord, TableLayout, TableProps } from \"./Table.types\";\nimport { Header } from \"./components/Header/Header\";\nimport { Body } from \"./components/Body/Body\";\nimport { useTableComponents } from \"./hooks/useTableComponents\";\nimport { useTableColumns } from \"./hooks/useTableColumns\";\nimport { useTableExpand } from \"./features/tableExpand\";\nimport { defaultSortDirections, useTableSort } from \"./features/tableSort\";\nimport { useStatic } from \"hooks/useStatic\";\nimport ResizeObserver, { type OnResize } from \"rc-resize-observer\";\nimport { FixedHeader } from \"./components/FixedHeader/FixedHeader\";\nimport { BodyColGroup } from \"./components/Body/components/BodyColGroup/BodyColGroup\";\nimport { updateRefValue } from \"./utils\";\nimport { withEventBus } from \"utils/eventBus/hocs/withEventBus\";\nimport { useFirstMount } from \"hooks/useFirstMount\";\nimport { useTableVisualParamsChange } from \"./hooks/useTableVisualParamsChange\";\nimport { isBoolean, isNil, isObject, isUndefined } from \"lodash-es\";\nimport { getTableComponentStyle, getTableComponentWrapperStyle, tableStyle } from \"./Table.styles\";\nimport { useTableStaticContext, withTableStaticContext } from \"./features/tableStaticContext\";\nimport { createTableContext, type TableContextValue } from \"./contexts\";\nimport {\n  useTableRowSelection,\n  TableRowSelectionContext,\n  type TableRowSelectionContextValue,\n} from \"./features/tableRowSelection\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { getTableTokens } from \"./Table.tokens\";\nimport { Spin, type SpinProps } from \"components/Spin\";\nimport { usePrevious } from \"hooks/usePrevious\";\nimport { FooterWrapper } from \"./components/Footer/FooterWrapper\";\n\nconst TableComponent = <Record extends DefaultRecord>(\n  props: TableProps<Record>,\n  ref: ForwardedRef<HTMLDivElement>\n) => {\n  const {\n    columns: columnsProp,\n    dataSource,\n    components: componentsProp,\n    expandable,\n    rowSelection,\n    sortDirections = defaultSortDirections,\n    scroll,\n    showHeader = true,\n    loading = false,\n    tableLayout: tableLayoutProp,\n    bordered: borderedProp,\n    styles,\n    footer,\n    onHeaderRow,\n    onRow,\n    onChange,\n    onScroll,\n  } = props;\n  const theme = useTheme();\n  const tableTokens = useMemo(() => getTableTokens(theme), [theme]);\n  const isTableFirstMount = useFirstMount();\n  const { getComponent } = useTableComponents({ components: componentsProp });\n  const staticContextRef = useTableStaticContext<Record>();\n\n  const { columns, flattedColumns, isAllColumnsFixedStart } = useTableColumns({\n    columns: columnsProp,\n    rowSelection,\n  });\n\n  const scrollX = scroll?.x;\n  const scrollY = scroll?.y;\n  const fixHeader = !isNil(scrollY);\n  const horizonScroll = !isNil(scrollX);\n  const hasFixedColumn = flattedColumns.some(({ fixed }) => fixed);\n  const fixColumn = horizonScroll && hasFixedColumn;\n\n  const { expandIconColumnIndex, indentSize, ExpandIcon, isSomeRecordHasChildren } =\n    useTableExpand<Record>({ expandable, dataSource, rowSelection });\n\n  const { sortState, sortedData, hasData, triggerSorter } = useTableSort<Record>({\n    dataSource,\n    onChange,\n  });\n\n  const {\n    keySet,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    flattedData,\n    checkboxPropsMap,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    derivedHalfSelectedKeySet,\n    recordKeys,\n    triggerSingleSelection,\n    setSelectedKeys,\n    multipleSelect,\n    updatePrevSelectedIndex,\n  } = useTableRowSelection<Record>({\n    rowSelection,\n    dataSource,\n    sortedData,\n  });\n  const {\n    tableHeaderRef,\n    scrollableTableSectionRef,\n    onTableContentScroll,\n    onTableHeaderScroll,\n    onTableBodyScroll,\n    onResize,\n  } = useTableVisualParamsChange({\n    fixColumn,\n    onScroll,\n  });\n\n  const tableLayout = useMemo<TableLayout>(() => {\n    if (tableLayoutProp) {\n      return tableLayoutProp;\n    }\n\n    if (fixColumn) {\n      return scrollX === \"max-content\" ? \"auto\" : \"fixed\";\n    }\n\n    if (fixHeader || flattedColumns.some(({ ellipsis }) => ellipsis)) {\n      return \"fixed\";\n    }\n\n    return \"auto\";\n  }, [fixColumn, fixHeader, flattedColumns, scrollX, tableLayoutProp]);\n\n  const bordered = useMemo(() => {\n    if (borderedProp === true || isObject(borderedProp)) {\n      const defaultBorderedConfig: Required<BorderedConfig> = {\n        emptyBlockEnd: true,\n        emptyInline: true,\n        firstColumnCellInlineStart: true,\n        lastColumnCellInlineEnd: true,\n      };\n\n      return {\n        ...defaultBorderedConfig,\n        ...(isObject(borderedProp) ? borderedProp : {}),\n      };\n    }\n\n    return borderedProp;\n  }, [borderedProp]);\n\n  const TableContext = useStatic(() => createTableContext<Record>());\n  const tableContextValue = useMemo<TableContextValue<Record>>(() => {\n    return {\n      showHeader,\n\n      tableTokens,\n\n      getComponent,\n\n      columns,\n      flattedColumns,\n      isAllColumnsFixedStart,\n\n      expandIconColumnIndex,\n      ExpandIcon,\n      indentSize,\n      isSomeRecordHasChildren,\n\n      sortDirections,\n\n      onHeaderRow,\n      onRow,\n\n      tableLayout,\n\n      bordered,\n      horizonScroll,\n    };\n  }, [\n    ExpandIcon,\n    bordered,\n    columns,\n    expandIconColumnIndex,\n    flattedColumns,\n    getComponent,\n    horizonScroll,\n    indentSize,\n    isAllColumnsFixedStart,\n    isSomeRecordHasChildren,\n    onHeaderRow,\n    onRow,\n    showHeader,\n    sortDirections,\n    tableLayout,\n    tableTokens,\n  ]);\n\n  const tableRowSelectionContextValue = useMemo<TableRowSelectionContextValue>(() => {\n    return {\n      keySet,\n      checkedCurrentAll,\n      checkedCurrentSome,\n      flattedData,\n      checkboxPropsMap,\n      derivedHalfSelectedKeySet,\n      derivedSelectedKeySet,\n      derivedSelectedKeys,\n      recordKeys,\n      setSelectedKeys,\n      triggerSingleSelection,\n      multipleSelect,\n      updatePrevSelectedIndex,\n    };\n  }, [\n    checkboxPropsMap,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    derivedHalfSelectedKeySet,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    flattedData,\n    keySet,\n    multipleSelect,\n    recordKeys,\n    setSelectedKeys,\n    triggerSingleSelection,\n    updatePrevSelectedIndex,\n  ]);\n\n  updateRefValue(staticContextRef, {\n    staticSelectedKeySet: derivedSelectedKeySet,\n    triggerSorter,\n    sortState,\n    isTableFirstMount,\n  });\n\n  const spinProps = ((): SpinProps => {\n    if (isBoolean(loading)) {\n      return { spinning: loading };\n    }\n\n    return loading;\n  })();\n\n  const TableComponent = getComponent([\"table\"], \"table\");\n  const bodyColGroup = <BodyColGroup />;\n  const bodyTable = (\n    <Body<Record>\n      expandable={expandable}\n      sortedData={sortedData}\n      needMeasureColumnWidth={fixHeader || fixColumn}\n      renderNullifyBody={isUndefined(dataSource)}\n      spinning={spinProps.spinning}\n    />\n  );\n\n  const groupTableNode = fixHeader ? (\n    <>\n      {showHeader && (\n        <FixedHeader ref={tableHeaderRef} scrollX={scrollX} onScroll={onTableHeaderScroll} />\n      )}\n      <div\n        className=\"rc-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, hasData, scrollY, horizonScroll),\n          styles?.tableBodyComponentWrapper?.(tableTokens, theme),\n        ]}\n        onScroll={onTableBodyScroll}\n        ref={scrollableTableSectionRef}\n      >\n        <TableComponent css={getTableComponentStyle(\"body\", tableLayout, scrollX, horizonScroll)}>\n          {bodyColGroup}\n          {bodyTable}\n        </TableComponent>\n      </div>\n    </>\n  ) : (\n    <div\n      className=\"rc-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, hasData, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent css={getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll)}>\n        {bodyColGroup}\n        {showHeader && <Header />}\n        {bodyTable}\n      </TableComponent>\n    </div>\n  );\n\n  const prevHorizonScroll = usePrevious(horizonScroll);\n\n  const handleLostHorizonScrollResize = useCallback<OnResize>(\n    (size, element) => {\n      if (hasFixedColumn && prevHorizonScroll && !horizonScroll) {\n        onResize(size, element);\n      }\n    },\n    [hasFixedColumn, horizonScroll, onResize, prevHorizonScroll]\n  );\n\n  return (\n    <TableContext.Provider value={tableContextValue}>\n      <TableRowSelectionContext.Provider value={tableRowSelectionContextValue}>\n        <ResizeObserver onResize={horizonScroll ? onResize : handleLostHorizonScrollResize}>\n          <Spin {...spinProps}>\n            <div\n              className=\"rc-table\"\n              css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}\n            >\n              <div\n                ref={ref}\n                className=\"rc-table-container\"\n                css={styles?.tableContainer?.(tableTokens, theme)}\n              >\n                {groupTableNode}\n              </div>\n              {footer && <FooterWrapper footer={footer} sortedData={sortedData} />}\n            </div>\n          </Spin>\n        </ResizeObserver>\n      </TableRowSelectionContext.Provider>\n    </TableContext.Provider>\n  );\n};\n\nexport const Table = withEventBus(withTableStaticContext(memo(forwardRef(TableComponent)))) as <\n  Record extends DefaultRecord,\n>(\n  props: TableProps<Record> & { ref?: ForwardedRef<HTMLDivElement> }\n) => ReturnType<typeof TableComponent>;\n"]} */"], children: [
221
227
  /* @__PURE__ */ jsx("div", { ref, className: "rc-table-container", css: (_c = styles == null ? void 0 : styles.tableContainer) == null ? void 0 : _c.call(styles, tableTokens, theme), children: groupTableNode }),
222
- footer == null ? void 0 : footer(sortedData)
228
+ footer && /* @__PURE__ */ jsx(FooterWrapper, { footer, sortedData })
223
229
  ] }) }) }) }) });
224
230
  };
225
231
  const Table = withEventBus(withTableStaticContext(memo(forwardRef(TableComponent))));
@@ -43,7 +43,10 @@ export interface TableProps<Record extends DefaultRecord | null = DefaultRecord>
43
43
  tableContainer?: GetStyle;
44
44
  tableBodyComponentWrapper?: GetStyle;
45
45
  };
46
- footer?: (data: readonly Record[]) => ReactNode;
46
+ footer?: (data: readonly Record[], info: {
47
+ verticalScrollBarWidth: number;
48
+ hasHorizontalScroll: boolean;
49
+ }) => ReactNode;
47
50
  loading?: boolean | Omit<SpinProps, "children" | "fullscreen">;
48
51
  }
49
52
  export type TableLayout = "auto" | "fixed";
@@ -14,6 +14,7 @@ const BodyComponent = (props) => {
14
14
  sortedData,
15
15
  needMeasureColumnWidth,
16
16
  expandable,
17
+ spinning,
17
18
  renderNullifyBody
18
19
  } = props;
19
20
  const theme = useTheme();
@@ -40,15 +41,23 @@ const BodyComponent = (props) => {
40
41
  if (renderNullifyBody) {
41
42
  return;
42
43
  }
43
- const rows = flattedData.length ? flattedData.map((item, idx) => {
44
- const {
45
- record,
46
- indent,
47
- index: renderIndex,
48
- rowKey
49
- } = item;
50
- return /* @__PURE__ */ jsx(BodyRow, { index: idx, renderIndex, intent: indent, rowKey, record }, rowKey);
51
- }) : /* @__PURE__ */ jsx(EmptyDataRow, {});
44
+ const rows = (() => {
45
+ if (flattedData.length === 0 && spinning) {
46
+ return null;
47
+ }
48
+ if (flattedData.length) {
49
+ return flattedData.map((item, idx) => {
50
+ const {
51
+ record,
52
+ indent,
53
+ index: renderIndex,
54
+ rowKey
55
+ } = item;
56
+ return /* @__PURE__ */ jsx(BodyRow, { index: idx, renderIndex, intent: indent, rowKey, record }, rowKey);
57
+ });
58
+ }
59
+ return /* @__PURE__ */ jsx(EmptyDataRow, {});
60
+ })();
52
61
  return /* @__PURE__ */ jsx(TableExpandedContext.Provider, { value: tableExpandedContextValue, children: /* @__PURE__ */ jsxs(BodyWrapperComponent, { css: tBodyStyle(theme), className: "rc-table-tbody", children: [
53
62
  needMeasureColumnWidth && /* @__PURE__ */ jsx(MeasureRow, {}),
54
63
  rows
@@ -4,4 +4,5 @@ export interface BodyProps<Record extends DefaultRecord> extends Pick<TableProps
4
4
  sortedData: ReturnType<typeof useTableSort<Record>>["sortedData"];
5
5
  needMeasureColumnWidth?: boolean;
6
6
  renderNullifyBody: boolean;
7
+ spinning?: boolean;
7
8
  }
@@ -1,14 +1,17 @@
1
1
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
2
- import { Fragment } from "react";
2
+ import { useMemo, Fragment } from "react";
3
3
  import { Cell } from "../../../Cell/Cell.js";
4
4
  import { useCellHover } from "../../../../hooks/useCellHover/useCellHover.js";
5
5
  import { useBodyCellRender } from "../../../../hooks/useBodyCellRender/useBodyCellRender.js";
6
6
  import { useCellFixedInfo } from "../../../../hooks/useCellFixedInfo/useCellFixedInfo.js";
7
7
  import { getFixedCellStyle } from "../../../../hooks/useCellFixedInfo/useCellFixedInfo.styles.js";
8
- import { bodyCellStyle, getBorderedBodyCellStyle, nonHeaderBorderedBodyCellStyle, getCellInnerWrapperStyle } from "./BodyCell.styles.js";
8
+ import { getCellInnerWrapperStyle, bodyCellStyle, getBorderedBodyCellStyle, nonHeaderBorderedBodyCellStyle } from "./BodyCell.styles.js";
9
+ import { useEvent } from "../../../../../../hooks/useEvent/useEvent.js";
9
10
  import { useTheme } from "../../../../../../hooks/useTheme/useTheme.js";
10
11
  import { useTableContext } from "../../../../contexts/tableContext/useTableContext/useTableContext.js";
12
+ import { useTableStaticContext } from "../../../../features/tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
11
13
  import { ExpandIconWrapper } from "../../../../features/tableExpand/components/ExpandIconWrapper/ExpandIconWrapper.js";
14
+ import { getRefValue } from "../../../../utils/ref/ref.js";
12
15
  const BodyCellComponent = (props) => {
13
16
  var _a;
14
17
  const {
@@ -36,6 +39,7 @@ const BodyCellComponent = (props) => {
36
39
  tableTokens,
37
40
  showHeader
38
41
  } = useTableContext();
42
+ const staticContextRef = useTableStaticContext();
39
43
  const {
40
44
  isFixStart,
41
45
  isFixEnd,
@@ -60,10 +64,9 @@ const BodyCellComponent = (props) => {
60
64
  } = ((_a = column.onCell) == null ? void 0 : _a.call(column, record, index)) || {};
61
65
  const notRenderedCell = cellColSpan === 0 || cellRowSpan === 0;
62
66
  const rowSpan = cellRowSpan ?? 1;
63
- const prefixNode = colIndex === expandIconColumnIndex && isSomeRecordHasChildren && /* @__PURE__ */ jsx(ExpandIconWrapper, { rowKey, record, expandable: record && Boolean(record.children) });
67
+ const prefixNode = useMemo(() => colIndex === expandIconColumnIndex && isSomeRecordHasChildren && /* @__PURE__ */ jsx(ExpandIconWrapper, { rowKey, record, expandable: record && Boolean(record.children) }), [colIndex, expandIconColumnIndex, isSomeRecordHasChildren, record, rowKey]);
64
68
  const {
65
- isHovered,
66
- emitCellHover
69
+ isHovered
67
70
  } = useCellHover({
68
71
  index,
69
72
  rowSpan,
@@ -77,21 +80,30 @@ const BodyCellComponent = (props) => {
77
80
  renderIndex,
78
81
  render
79
82
  });
80
- const handleMouseEnter = (e) => {
83
+ const handleMouseEnter = useEvent((e) => {
84
+ const emitCellHover = getRefValue(staticContextRef, "emitCellHover");
81
85
  emitCellHover({
82
86
  start: index,
83
87
  end: index + rowSpan - 1
84
88
  });
85
89
  cellOnMouseEnter == null ? void 0 : cellOnMouseEnter(e);
86
- };
87
- const handleMouseLeave = (e) => {
90
+ });
91
+ const handleMouseLeave = useEvent((e) => {
92
+ const emitCellHover = getRefValue(staticContextRef, "emitCellHover");
88
93
  emitCellHover({
89
94
  start: -1,
90
95
  end: -1
91
96
  });
92
97
  cellOnMouseLeave == null ? void 0 : cellOnMouseLeave(e);
93
- };
98
+ });
94
99
  const CellInnerWrapper = prefixNode ? "div" : Fragment;
100
+ const content = useMemo(() => /* @__PURE__ */ jsxs(CellInnerWrapper, { ...prefixNode ? {
101
+ "data-indent-level": intent,
102
+ css: getCellInnerWrapperStyle(indentSize, intent)(theme)
103
+ } : {}, children: [
104
+ prefixNode,
105
+ children
106
+ ] }), [CellInnerWrapper, children, indentSize, intent, prefixNode, theme]);
95
107
  return /* @__PURE__ */ jsx(Cell, { component: rowScope ? getComponent(["body", "cell"], "th") : getComponent(["body", "cell"], "td"), align: column.align, ellipsis: column.ellipsis, bordered, tableTokens, css: [bodyCellStyle(tableTokens), bordered ? getBorderedBodyCellStyle(bordered) : void 0, bordered && !showHeader ? nonHeaderBorderedBodyCellStyle(tableTokens) : void 0, ...getFixedCellStyle({
96
108
  columnKey: column.key,
97
109
  isFixStart,
@@ -103,13 +115,7 @@ const BodyCellComponent = (props) => {
103
115
  fixedEndShadow,
104
116
  showFixStartShadow,
105
117
  showFixEndShadow
106
- }), cellCss, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvY29tcG9uZW50cy9Cb2R5L2NvbXBvbmVudHMvQm9keUNlbGwvQm9keUNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRHTSIsImZpbGUiOiIvYnVpbGRzL2Zyb250ZW5kL2xpYnMvdWkta2l0L3NyYy9jb21wb25lbnRzL1RhYmxlL2NvbXBvbmVudHMvQm9keS9jb21wb25lbnRzL0JvZHlDZWxsL0JvZHlDZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZyYWdtZW50LCB0eXBlIE1vdXNlRXZlbnRIYW5kbGVyIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEJvZHlDZWxsUHJvcHMgfSBmcm9tIFwiLi9Cb2R5Q2VsbC50eXBlc1wiO1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gXCIuLi8uLi8uLi9DZWxsL0NlbGxcIjtcbmltcG9ydCB7IHVzZUNlbGxIb3ZlciB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2hvb2tzL3VzZUNlbGxIb3ZlclwiO1xuaW1wb3J0IHsgdXNlQm9keUNlbGxSZW5kZXIgfSBmcm9tIFwiY29tcG9uZW50cy9UYWJsZS9ob29rcy91c2VCb2R5Q2VsbFJlbmRlclwiO1xuaW1wb3J0IHR5cGUgeyBEZWZhdWx0UmVjb3JkIH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvVGFibGUudHlwZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2NvbnRleHRzXCI7XG5pbXBvcnQgeyB1c2VDZWxsRml4ZWRJbmZvLCBnZXRGaXhlZENlbGxTdHlsZSB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2hvb2tzL3VzZUNlbGxGaXhlZEluZm9cIjtcbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSBcImhvb2tzL3VzZVRoZW1lXCI7XG5pbXBvcnQge1xuICBib2R5Q2VsbFN0eWxlLFxuICBnZXRCb3JkZXJlZEJvZHlDZWxsU3R5bGUsXG4gIGdldENlbGxJbm5lcldyYXBwZXJTdHlsZSxcbiAgbm9uSGVhZGVyQm9yZGVyZWRCb2R5Q2VsbFN0eWxlLFxufSBmcm9tIFwiLi9Cb2R5Q2VsbC5zdHlsZXNcIjtcbmltcG9ydCB7IEV4cGFuZEljb25XcmFwcGVyIH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVFeHBhbmRcIjtcblxuY29uc3QgQm9keUNlbGxDb21wb25lbnQgPSA8UmVjb3JkIGV4dGVuZHMgRGVmYXVsdFJlY29yZD4ocHJvcHM6IEJvZHlDZWxsUHJvcHM8UmVjb3JkPikgPT4ge1xuICBjb25zdCB7IGNvbHVtbiwgcmVjb3JkLCBpbmRleCwgY29sSW5kZXgsIHJvd0tleSwgaW50ZW50LCByZW5kZXJJbmRleCwgaXNSb3dTZWxlY3RlZCB9ID0gcHJvcHM7XG4gIGNvbnN0IHsgcm93U2NvcGUsIGRhdGFJbmRleCwgcmVuZGVyIH0gPSBjb2x1bW47XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKTtcbiAgY29uc3Qge1xuICAgIGdldENvbXBvbmVudCxcbiAgICBpc1NvbWVSZWNvcmRIYXNDaGlsZHJlbixcbiAgICBpbmRlbnRTaXplLFxuICAgIGV4cGFuZEljb25Db2x1bW5JbmRleCxcbiAgICBib3JkZXJlZCxcbiAgICB0YWJsZVRva2VucyxcbiAgICBzaG93SGVhZGVyLFxuICB9ID0gdXNlVGFibGVDb250ZXh0KCk7XG5cbiAgY29uc3Qge1xuICAgIGlzRml4U3RhcnQsXG4gICAgaXNGaXhFbmQsXG4gICAgZml4U3RhcnQsXG4gICAgZml4RW5kLFxuICAgIHpJbmRleFJldmVyc2UsXG4gICAgZml4ZWRTdGFydFNoYWRvdyxcbiAgICBmaXhlZEVuZFNoYWRvdyxcbiAgICBzaG93Rml4U3RhcnRTaGFkb3csXG4gICAgc2hvd0ZpeEVuZFNoYWRvdyxcbiAgfSA9IHVzZUNlbGxGaXhlZEluZm8oe1xuICAgIGNvbFN0YXJ0OiBjb2xJbmRleCxcbiAgICBjb2xFbmQ6IGNvbEluZGV4LFxuICB9KTtcblxuICBjb25zdCB7XG4gICAgcm93U3BhbjogY2VsbFJvd1NwYW4sXG4gICAgY29sU3BhbjogY2VsbENvbFNwYW4sXG4gICAgb25Nb3VzZUVudGVyOiBjZWxsT25Nb3VzZUVudGVyLFxuICAgIG9uTW91c2VMZWF2ZTogY2VsbE9uTW91c2VMZWF2ZSxcbiAgICBjc3M6IGNlbGxDc3MsXG4gICAgLi4ucmVzdEFkZGl0aW9uYWxDZWxsUHJvcHNcbiAgfSA9IGNvbHVtbi5vbkNlbGw/LihyZWNvcmQsIGluZGV4KSB8fCB7fTtcblxuICBjb25zdCBub3RSZW5kZXJlZENlbGwgPSBjZWxsQ29sU3BhbiA9PT0gMCB8fCBjZWxsUm93U3BhbiA9PT0gMDtcbiAgY29uc3Qgcm93U3BhbiA9IGNlbGxSb3dTcGFuID8/IDE7XG5cbiAgY29uc3QgcHJlZml4Tm9kZSA9IGNvbEluZGV4ID09PSBleHBhbmRJY29uQ29sdW1uSW5kZXggJiYgaXNTb21lUmVjb3JkSGFzQ2hpbGRyZW4gJiYgKFxuICAgIDxFeHBhbmRJY29uV3JhcHBlclxuICAgICAgcm93S2V5PXtyb3dLZXl9XG4gICAgICByZWNvcmQ9e3JlY29yZH1cbiAgICAgIGV4cGFuZGFibGU9e3JlY29yZCAmJiBCb29sZWFuKHJlY29yZC5jaGlsZHJlbil9XG4gICAgLz5cbiAgKTtcblxuICBjb25zdCB7IGlzSG92ZXJlZCwgZW1pdENlbGxIb3ZlciB9ID0gdXNlQ2VsbEhvdmVyKHtcbiAgICBpbmRleCxcbiAgICByb3dTcGFuLFxuICAgIHNraXBTdWJzY3JpYmU6IG5vdFJlbmRlcmVkQ2VsbCxcbiAgfSk7XG5cbiAgY29uc3QgeyBjaGlsZHJlbiB9ID0gdXNlQm9keUNlbGxSZW5kZXIoe1xuICAgIHJlY29yZCxcbiAgICBkYXRhSW5kZXgsXG4gICAgcmVuZGVySW5kZXgsXG4gICAgcmVuZGVyLFxuICB9KTtcblxuICBjb25zdCBoYW5kbGVNb3VzZUVudGVyOiBNb3VzZUV2ZW50SGFuZGxlcjxIVE1MVGFibGVDZWxsRWxlbWVudD4gPSAoZSkgPT4ge1xuICAgIGVtaXRDZWxsSG92ZXIoe1xuICAgICAgc3RhcnQ6IGluZGV4LFxuICAgICAgZW5kOiBpbmRleCArIHJvd1NwYW4gLSAxLFxuICAgIH0pO1xuXG4gICAgY2VsbE9uTW91c2VFbnRlcj8uKGUpO1xuICB9O1xuXG4gIGNvbnN0IGhhbmRsZU1vdXNlTGVhdmU6IE1vdXNlRXZlbnRIYW5kbGVyPEhUTUxUYWJsZUNlbGxFbGVtZW50PiA9IChlKSA9PiB7XG4gICAgZW1pdENlbGxIb3Zlcih7XG4gICAgICBzdGFydDogLTEsXG4gICAgICBlbmQ6IC0xLFxuICAgIH0pO1xuXG4gICAgY2VsbE9uTW91c2VMZWF2ZT8uKGUpO1xuICB9O1xuXG4gIGNvbnN0IENlbGxJbm5lcldyYXBwZXIgPSBwcmVmaXhOb2RlID8gXCJkaXZcIiA6IEZyYWdtZW50O1xuXG4gIHJldHVybiAoXG4gICAgPENlbGxcbiAgICAgIGNvbXBvbmVudD17XG4gICAgICAgIHJvd1Njb3BlID8gZ2V0Q29tcG9uZW50KFtcImJvZHlcIiwgXCJjZWxsXCJdLCBcInRoXCIpIDogZ2V0Q29tcG9uZW50KFtcImJvZHlcIiwgXCJjZWxsXCJdLCBcInRkXCIpXG4gICAgICB9XG4gICAgICBhbGlnbj17Y29sdW1uLmFsaWdufVxuICAgICAgZWxsaXBzaXM9e2NvbHVtbi5lbGxpcHNpc31cbiAgICAgIGJvcmRlcmVkPXtib3JkZXJlZH1cbiAgICAgIHRhYmxlVG9rZW5zPXt0YWJsZVRva2Vuc31cbiAgICAgIGNzcz17W1xuICAgICAgICBib2R5Q2VsbFN0eWxlKHRhYmxlVG9rZW5zKSxcbiAgICAgICAgYm9yZGVyZWQgPyBnZXRCb3JkZXJlZEJvZHlDZWxsU3R5bGUoYm9yZGVyZWQpIDogdW5kZWZpbmVkLFxuICAgICAgICBib3JkZXJlZCAmJiAhc2hvd0hlYWRlciA/IG5vbkhlYWRlckJvcmRlcmVkQm9keUNlbGxTdHlsZSh0YWJsZVRva2VucykgOiB1bmRlZmluZWQsXG4gICAgICAgIC4uLmdldEZpeGVkQ2VsbFN0eWxlKHtcbiAgICAgICAgICBjb2x1bW5LZXk6IGNvbHVtbi5rZXksXG4gICAgICAgICAgaXNGaXhTdGFydCxcbiAgICAgICAgICBpc0ZpeEVuZCxcbiAgICAgICAgICBmaXhTdGFydCxcbiAgICAgICAgICBmaXhFbmQsXG4gICAgICAgICAgekluZGV4UmV2ZXJzZSxcbiAgICAgICAgICBmaXhlZFN0YXJ0U2hhZG93LFxuICAgICAgICAgIGZpeGVkRW5kU2hhZG93LFxuICAgICAgICAgIHNob3dGaXhTdGFydFNoYWRvdyxcbiAgICAgICAgICBzaG93Rml4RW5kU2hhZG93LFxuICAgICAgICB9KSxcbiAgICAgICAgY2VsbENzcyxcbiAgICAgIF19XG4gICAgICByb3dTcGFuPXtjZWxsUm93U3Bhbn1cbiAgICAgIGNvbFNwYW49e2NlbGxDb2xTcGFufVxuICAgICAgb25Nb3VzZUVudGVyPXtoYW5kbGVNb3VzZUVudGVyfVxuICAgICAgb25Nb3VzZUxlYXZlPXtoYW5kbGVNb3VzZUxlYXZlfVxuICAgICAgey4uLnJlc3RBZGRpdGlvbmFsQ2VsbFByb3BzfVxuICAgICAgc2NvcGU9e3Jvd1Njb3BlfVxuICAgICAgaXNIb3ZlcmVkPXtpc0hvdmVyZWR9XG4gICAgICBpc1Jvd1NlbGVjdGVkPXtpc1Jvd1NlbGVjdGVkfVxuICAgID5cbiAgICAgIDxDZWxsSW5uZXJXcmFwcGVyXG4gICAgICAgIHsuLi4ocHJlZml4Tm9kZVxuICAgICAgICAgID8ge1xuICAgICAgICAgICAgICBcImRhdGEtaW5kZW50LWxldmVsXCI6IGludGVudCxcbiAgICAgICAgICAgICAgY3NzOiBnZXRDZWxsSW5uZXJXcmFwcGVyU3R5bGUoaW5kZW50U2l6ZSwgaW50ZW50KSh0aGVtZSksXG4gICAgICAgICAgICB9XG4gICAgICAgICAgOiB7fSl9XG4gICAgICA+XG4gICAgICAgIHtwcmVmaXhOb2RlfVxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L0NlbGxJbm5lcldyYXBwZXI+XG4gICAgPC9DZWxsPlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IEJvZHlDZWxsID0gQm9keUNlbGxDb21wb25lbnQ7XG4iXX0= */"], rowSpan: cellRowSpan, colSpan: cellColSpan, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, ...restAdditionalCellProps, scope: rowScope, isHovered, isRowSelected, children: /* @__PURE__ */ jsxs(CellInnerWrapper, { ...prefixNode ? {
107
- "data-indent-level": intent,
108
- css: getCellInnerWrapperStyle(indentSize, intent)(theme)
109
- } : {}, children: [
110
- prefixNode,
111
- children
112
- ] }) });
118
+ }), cellCss, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvY29tcG9uZW50cy9Cb2R5L2NvbXBvbmVudHMvQm9keUNlbGwvQm9keUNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBJTSIsImZpbGUiOiIvYnVpbGRzL2Zyb250ZW5kL2xpYnMvdWkta2l0L3NyYy9jb21wb25lbnRzL1RhYmxlL2NvbXBvbmVudHMvQm9keS9jb21wb25lbnRzL0JvZHlDZWxsL0JvZHlDZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZyYWdtZW50LCB1c2VNZW1vLCB0eXBlIE1vdXNlRXZlbnRIYW5kbGVyIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEJvZHlDZWxsUHJvcHMgfSBmcm9tIFwiLi9Cb2R5Q2VsbC50eXBlc1wiO1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gXCIuLi8uLi8uLi9DZWxsL0NlbGxcIjtcbmltcG9ydCB7IHVzZUNlbGxIb3ZlciB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2hvb2tzL3VzZUNlbGxIb3ZlclwiO1xuaW1wb3J0IHsgdXNlQm9keUNlbGxSZW5kZXIgfSBmcm9tIFwiY29tcG9uZW50cy9UYWJsZS9ob29rcy91c2VCb2R5Q2VsbFJlbmRlclwiO1xuaW1wb3J0IHR5cGUgeyBEZWZhdWx0UmVjb3JkIH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvVGFibGUudHlwZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2NvbnRleHRzXCI7XG5pbXBvcnQgeyB1c2VDZWxsRml4ZWRJbmZvLCBnZXRGaXhlZENlbGxTdHlsZSB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2hvb2tzL3VzZUNlbGxGaXhlZEluZm9cIjtcbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSBcImhvb2tzL3VzZVRoZW1lXCI7XG5pbXBvcnQge1xuICBib2R5Q2VsbFN0eWxlLFxuICBnZXRCb3JkZXJlZEJvZHlDZWxsU3R5bGUsXG4gIGdldENlbGxJbm5lcldyYXBwZXJTdHlsZSxcbiAgbm9uSGVhZGVyQm9yZGVyZWRCb2R5Q2VsbFN0eWxlLFxufSBmcm9tIFwiLi9Cb2R5Q2VsbC5zdHlsZXNcIjtcbmltcG9ydCB7IEV4cGFuZEljb25XcmFwcGVyIH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVFeHBhbmRcIjtcbmltcG9ydCB7IHVzZVRhYmxlU3RhdGljQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2ZlYXR1cmVzL3RhYmxlU3RhdGljQ29udGV4dFwiO1xuaW1wb3J0IHsgZ2V0UmVmVmFsdWUgfSBmcm9tIFwiY29tcG9uZW50cy9UYWJsZS91dGlsc1wiO1xuaW1wb3J0IHsgdXNlRXZlbnQgfSBmcm9tIFwiaG9va3MvdXNlRXZlbnRcIjtcblxuY29uc3QgQm9keUNlbGxDb21wb25lbnQgPSA8UmVjb3JkIGV4dGVuZHMgRGVmYXVsdFJlY29yZD4ocHJvcHM6IEJvZHlDZWxsUHJvcHM8UmVjb3JkPikgPT4ge1xuICBjb25zdCB7IGNvbHVtbiwgcmVjb3JkLCBpbmRleCwgY29sSW5kZXgsIHJvd0tleSwgaW50ZW50LCByZW5kZXJJbmRleCwgaXNSb3dTZWxlY3RlZCB9ID0gcHJvcHM7XG4gIGNvbnN0IHsgcm93U2NvcGUsIGRhdGFJbmRleCwgcmVuZGVyIH0gPSBjb2x1bW47XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKTtcbiAgY29uc3Qge1xuICAgIGdldENvbXBvbmVudCxcbiAgICBpc1NvbWVSZWNvcmRIYXNDaGlsZHJlbixcbiAgICBpbmRlbnRTaXplLFxuICAgIGV4cGFuZEljb25Db2x1bW5JbmRleCxcbiAgICBib3JkZXJlZCxcbiAgICB0YWJsZVRva2VucyxcbiAgICBzaG93SGVhZGVyLFxuICB9ID0gdXNlVGFibGVDb250ZXh0KCk7XG4gIGNvbnN0IHN0YXRpY0NvbnRleHRSZWYgPSB1c2VUYWJsZVN0YXRpY0NvbnRleHQoKTtcblxuICBjb25zdCB7XG4gICAgaXNGaXhTdGFydCxcbiAgICBpc0ZpeEVuZCxcbiAgICBmaXhTdGFydCxcbiAgICBmaXhFbmQsXG4gICAgekluZGV4UmV2ZXJzZSxcbiAgICBmaXhlZFN0YXJ0U2hhZG93LFxuICAgIGZpeGVkRW5kU2hhZG93LFxuICAgIHNob3dGaXhTdGFydFNoYWRvdyxcbiAgICBzaG93Rml4RW5kU2hhZG93LFxuICB9ID0gdXNlQ2VsbEZpeGVkSW5mbyh7XG4gICAgY29sU3RhcnQ6IGNvbEluZGV4LFxuICAgIGNvbEVuZDogY29sSW5kZXgsXG4gIH0pO1xuXG4gIGNvbnN0IHtcbiAgICByb3dTcGFuOiBjZWxsUm93U3BhbixcbiAgICBjb2xTcGFuOiBjZWxsQ29sU3BhbixcbiAgICBvbk1vdXNlRW50ZXI6IGNlbGxPbk1vdXNlRW50ZXIsXG4gICAgb25Nb3VzZUxlYXZlOiBjZWxsT25Nb3VzZUxlYXZlLFxuICAgIGNzczogY2VsbENzcyxcbiAgICAuLi5yZXN0QWRkaXRpb25hbENlbGxQcm9wc1xuICB9ID0gY29sdW1uLm9uQ2VsbD8uKHJlY29yZCwgaW5kZXgpIHx8IHt9O1xuXG4gIGNvbnN0IG5vdFJlbmRlcmVkQ2VsbCA9IGNlbGxDb2xTcGFuID09PSAwIHx8IGNlbGxSb3dTcGFuID09PSAwO1xuICBjb25zdCByb3dTcGFuID0gY2VsbFJvd1NwYW4gPz8gMTtcblxuICBjb25zdCBwcmVmaXhOb2RlID0gdXNlTWVtbyhcbiAgICAoKSA9PlxuICAgICAgY29sSW5kZXggPT09IGV4cGFuZEljb25Db2x1bW5JbmRleCAmJlxuICAgICAgaXNTb21lUmVjb3JkSGFzQ2hpbGRyZW4gJiYgKFxuICAgICAgICA8RXhwYW5kSWNvbldyYXBwZXJcbiAgICAgICAgICByb3dLZXk9e3Jvd0tleX1cbiAgICAgICAgICByZWNvcmQ9e3JlY29yZH1cbiAgICAgICAgICBleHBhbmRhYmxlPXtyZWNvcmQgJiYgQm9vbGVhbihyZWNvcmQuY2hpbGRyZW4pfVxuICAgICAgICAvPlxuICAgICAgKSxcbiAgICBbY29sSW5kZXgsIGV4cGFuZEljb25Db2x1bW5JbmRleCwgaXNTb21lUmVjb3JkSGFzQ2hpbGRyZW4sIHJlY29yZCwgcm93S2V5XVxuICApO1xuXG4gIGNvbnN0IHsgaXNIb3ZlcmVkIH0gPSB1c2VDZWxsSG92ZXIoe1xuICAgIGluZGV4LFxuICAgIHJvd1NwYW4sXG4gICAgc2tpcFN1YnNjcmliZTogbm90UmVuZGVyZWRDZWxsLFxuICB9KTtcblxuICBjb25zdCB7IGNoaWxkcmVuIH0gPSB1c2VCb2R5Q2VsbFJlbmRlcih7XG4gICAgcmVjb3JkLFxuICAgIGRhdGFJbmRleCxcbiAgICByZW5kZXJJbmRleCxcbiAgICByZW5kZXIsXG4gIH0pO1xuXG4gIGNvbnN0IGhhbmRsZU1vdXNlRW50ZXIgPSB1c2VFdmVudCgoZSkgPT4ge1xuICAgIGNvbnN0IGVtaXRDZWxsSG92ZXIgPSBnZXRSZWZWYWx1ZShzdGF0aWNDb250ZXh0UmVmLCBcImVtaXRDZWxsSG92ZXJcIik7XG5cbiAgICBlbWl0Q2VsbEhvdmVyKHtcbiAgICAgIHN0YXJ0OiBpbmRleCxcbiAgICAgIGVuZDogaW5kZXggKyByb3dTcGFuIC0gMSxcbiAgICB9KTtcblxuICAgIGNlbGxPbk1vdXNlRW50ZXI/LihlKTtcbiAgfSkgc2F0aXNmaWVzIE1vdXNlRXZlbnRIYW5kbGVyPEhUTUxUYWJsZUNlbGxFbGVtZW50PjtcblxuICBjb25zdCBoYW5kbGVNb3VzZUxlYXZlID0gdXNlRXZlbnQoKGUpID0+IHtcbiAgICBjb25zdCBlbWl0Q2VsbEhvdmVyID0gZ2V0UmVmVmFsdWUoc3RhdGljQ29udGV4dFJlZiwgXCJlbWl0Q2VsbEhvdmVyXCIpO1xuXG4gICAgZW1pdENlbGxIb3Zlcih7XG4gICAgICBzdGFydDogLTEsXG4gICAgICBlbmQ6IC0xLFxuICAgIH0pO1xuXG4gICAgY2VsbE9uTW91c2VMZWF2ZT8uKGUpO1xuICB9KSBzYXRpc2ZpZXMgTW91c2VFdmVudEhhbmRsZXI8SFRNTFRhYmxlQ2VsbEVsZW1lbnQ+O1xuXG4gIGNvbnN0IENlbGxJbm5lcldyYXBwZXIgPSBwcmVmaXhOb2RlID8gXCJkaXZcIiA6IEZyYWdtZW50O1xuXG4gIGNvbnN0IGNvbnRlbnQgPSB1c2VNZW1vKFxuICAgICgpID0+IChcbiAgICAgIDxDZWxsSW5uZXJXcmFwcGVyXG4gICAgICAgIHsuLi4ocHJlZml4Tm9kZVxuICAgICAgICAgID8ge1xuICAgICAgICAgICAgICBcImRhdGEtaW5kZW50LWxldmVsXCI6IGludGVudCxcbiAgICAgICAgICAgICAgY3NzOiBnZXRDZWxsSW5uZXJXcmFwcGVyU3R5bGUoaW5kZW50U2l6ZSwgaW50ZW50KSh0aGVtZSksXG4gICAgICAgICAgICB9XG4gICAgICAgICAgOiB7fSl9XG4gICAgICA+XG4gICAgICAgIHtwcmVmaXhOb2RlfVxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L0NlbGxJbm5lcldyYXBwZXI+XG4gICAgKSxcbiAgICBbQ2VsbElubmVyV3JhcHBlciwgY2hpbGRyZW4sIGluZGVudFNpemUsIGludGVudCwgcHJlZml4Tm9kZSwgdGhlbWVdXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8Q2VsbFxuICAgICAgY29tcG9uZW50PXtcbiAgICAgICAgcm93U2NvcGUgPyBnZXRDb21wb25lbnQoW1wiYm9keVwiLCBcImNlbGxcIl0sIFwidGhcIikgOiBnZXRDb21wb25lbnQoW1wiYm9keVwiLCBcImNlbGxcIl0sIFwidGRcIilcbiAgICAgIH1cbiAgICAgIGFsaWduPXtjb2x1bW4uYWxpZ259XG4gICAgICBlbGxpcHNpcz17Y29sdW1uLmVsbGlwc2lzfVxuICAgICAgYm9yZGVyZWQ9e2JvcmRlcmVkfVxuICAgICAgdGFibGVUb2tlbnM9e3RhYmxlVG9rZW5zfVxuICAgICAgY3NzPXtbXG4gICAgICAgIGJvZHlDZWxsU3R5bGUodGFibGVUb2tlbnMpLFxuICAgICAgICBib3JkZXJlZCA/IGdldEJvcmRlcmVkQm9keUNlbGxTdHlsZShib3JkZXJlZCkgOiB1bmRlZmluZWQsXG4gICAgICAgIGJvcmRlcmVkICYmICFzaG93SGVhZGVyID8gbm9uSGVhZGVyQm9yZGVyZWRCb2R5Q2VsbFN0eWxlKHRhYmxlVG9rZW5zKSA6IHVuZGVmaW5lZCxcbiAgICAgICAgLi4uZ2V0Rml4ZWRDZWxsU3R5bGUoe1xuICAgICAgICAgIGNvbHVtbktleTogY29sdW1uLmtleSxcbiAgICAgICAgICBpc0ZpeFN0YXJ0LFxuICAgICAgICAgIGlzRml4RW5kLFxuICAgICAgICAgIGZpeFN0YXJ0LFxuICAgICAgICAgIGZpeEVuZCxcbiAgICAgICAgICB6SW5kZXhSZXZlcnNlLFxuICAgICAgICAgIGZpeGVkU3RhcnRTaGFkb3csXG4gICAgICAgICAgZml4ZWRFbmRTaGFkb3csXG4gICAgICAgICAgc2hvd0ZpeFN0YXJ0U2hhZG93LFxuICAgICAgICAgIHNob3dGaXhFbmRTaGFkb3csXG4gICAgICAgIH0pLFxuICAgICAgICBjZWxsQ3NzLFxuICAgICAgXX1cbiAgICAgIHJvd1NwYW49e2NlbGxSb3dTcGFufVxuICAgICAgY29sU3Bhbj17Y2VsbENvbFNwYW59XG4gICAgICBvbk1vdXNlRW50ZXI9e2hhbmRsZU1vdXNlRW50ZXJ9XG4gICAgICBvbk1vdXNlTGVhdmU9e2hhbmRsZU1vdXNlTGVhdmV9XG4gICAgICB7Li4ucmVzdEFkZGl0aW9uYWxDZWxsUHJvcHN9XG4gICAgICBzY29wZT17cm93U2NvcGV9XG4gICAgICBpc0hvdmVyZWQ9e2lzSG92ZXJlZH1cbiAgICAgIGlzUm93U2VsZWN0ZWQ9e2lzUm93U2VsZWN0ZWR9XG4gICAgPlxuICAgICAge2NvbnRlbnR9XG4gICAgPC9DZWxsPlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IEJvZHlDZWxsID0gQm9keUNlbGxDb21wb25lbnQ7XG4iXX0= */"], rowSpan: cellRowSpan, colSpan: cellColSpan, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, ...restAdditionalCellProps, scope: rowScope, isHovered, isRowSelected, children: content });
113
119
  };
114
120
  const BodyCell = BodyCellComponent;
115
121
  export {
@@ -2,6 +2,7 @@ import { jsx } from "@emotion/react/jsx-runtime";
2
2
  import { useRef, useLayoutEffect } from "react";
3
3
  import ResizeObserver from "rc-resize-observer";
4
4
  import { measureCellStyle, titleWrapperStyle } from "./MeasureCell.styles.js";
5
+ import { roundToHundredths } from "../MeasureRow/MeasureRow.utils.js";
5
6
  import { useTableStaticContext } from "../../../../features/tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
6
7
  import { getRefValue } from "../../../../utils/ref/ref.js";
7
8
  const MeasureCellComponent = (props) => {
@@ -20,7 +21,7 @@ const MeasureCellComponent = (props) => {
20
21
  const {
21
22
  width
22
23
  } = td.getBoundingClientRect();
23
- colsWidthsMap.set(columnKey, width);
24
+ colsWidthsMap.set(columnKey, roundToHundredths(width));
24
25
  return () => {
25
26
  colsWidthsMap.delete(columnKey);
26
27
  };
@@ -4,10 +4,12 @@ import { MeasureCell } from "../MeasureCell/MeasureCell.js";
4
4
  import ResizeObserver from "rc-resize-observer";
5
5
  import { useEvent } from "../../../../../../hooks/useEvent/useEvent.js";
6
6
  import { useEmitter } from "../../../../features/typedEventBus/hooks.js";
7
- import { getColumnsKeys } from "./MeasureRow.utils.js";
7
+ import { getColumnsKeys, roundToHundredths } from "./MeasureRow.utils.js";
8
+ import { isNumber } from "lodash-es";
8
9
  import { useTableContext } from "../../../../contexts/tableContext/useTableContext/useTableContext.js";
9
10
  import { useTableStaticContext } from "../../../../features/tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
10
11
  import { getRefValue, updateRefValue } from "../../../../utils/ref/ref.js";
12
+ import { selectionColumnKey } from "../../../../features/tableRowSelection/utils/const.js";
11
13
  const MeasureRowComponent = () => {
12
14
  const {
13
15
  flattedColumns
@@ -24,11 +26,12 @@ const MeasureRowComponent = () => {
24
26
  const {
25
27
  offsetWidth
26
28
  } = size;
29
+ const roundedOffsetWidth = roundToHundredths(offsetWidth);
27
30
  if (!colsWidthsMap.has(data)) {
28
- colsWidthsMap.set(data, offsetWidth);
31
+ colsWidthsMap.set(data, roundedOffsetWidth);
29
32
  }
30
- if (offsetWidth !== colsWidthsMap.get(data)) {
31
- colsWidthsMap.set(data, offsetWidth);
33
+ if (roundedOffsetWidth !== colsWidthsMap.get(data)) {
34
+ colsWidthsMap.set(data, roundedOffsetWidth);
32
35
  }
33
36
  });
34
37
  const colWidths = colsKeys.map((columnKey) => colsWidthsMap.get(columnKey) ?? -1);
@@ -57,28 +60,31 @@ const MeasureRowComponent = () => {
57
60
  return measureCellsInfo;
58
61
  }, [colsKeys, flattedColumns, staticContextRef]);
59
62
  useLayoutEffect(() => {
60
- const isTableFirstMount = getRefValue(staticContextRef, "isTableFirstMount");
61
- const measureCellsInfo = updateMeasureCellsInfo([]);
62
- if (isTableFirstMount) {
63
- return;
64
- }
65
- emitTableVisualParamsChange({
66
- measureCellsInfo
67
- });
68
- }, [emitTableVisualParamsChange, staticContextRef, updateMeasureCellsInfo]);
63
+ updateMeasureCellsInfo([]);
64
+ }, [updateMeasureCellsInfo]);
69
65
  const firstCallRef = useRef(true);
70
66
  const handleBatchResize = useCallback((resizeInfo) => {
67
+ const measureCellsInfo = updateMeasureCellsInfo(resizeInfo);
68
+ const isTableFirstMount = getRefValue(staticContextRef, "isTableFirstMount");
69
+ const horizontalScrollPositionRange = getRefValue(staticContextRef, "scrollableTableSectionInfo.horizontalScrollPositionRange");
70
+ if (!isTableFirstMount) {
71
+ firstCallRef.current = false;
72
+ }
71
73
  if (firstCallRef.current) {
72
74
  firstCallRef.current = false;
73
75
  return;
74
76
  }
75
- const measureCellsInfo = updateMeasureCellsInfo(resizeInfo);
76
77
  emitTableVisualParamsChange({
77
- measureCellsInfo
78
+ measureCellsInfo,
79
+ horizontalScrollPositionRange
78
80
  });
79
- }, [emitTableVisualParamsChange, updateMeasureCellsInfo]);
80
- return /* @__PURE__ */ jsx("tr", { "aria-hidden": "true", children: /* @__PURE__ */ jsx(ResizeObserver.Collection, { onBatchResize: handleBatchResize, children: flattedColumns.map((flattedColumn) => {
81
- return /* @__PURE__ */ jsx(MeasureCell, { columnKey: flattedColumn.key, title: flattedColumn.title }, flattedColumn.key);
81
+ }, [emitTableVisualParamsChange, staticContextRef, updateMeasureCellsInfo]);
82
+ return /* @__PURE__ */ jsx("tr", { "aria-hidden": "true", children: /* @__PURE__ */ jsx(ResizeObserver.Collection, { onBatchResize: handleBatchResize, children: flattedColumns.map(({
83
+ key,
84
+ title,
85
+ colSpan
86
+ }) => {
87
+ return /* @__PURE__ */ jsx(MeasureCell, { columnKey: key, title: key === selectionColumnKey || isNumber(colSpan) && colSpan !== 1 ? void 0 : title }, key);
82
88
  }) }) });
83
89
  };
84
90
  const MeasureRow = MeasureRowComponent;
@@ -2,3 +2,4 @@ import { Key } from 'components/Table/Table.types';
2
2
  export declare function getColumnsKeys(columns: readonly {
3
3
  key: Key;
4
4
  }[]): Key[];
5
+ export declare const roundToHundredths: (number: number) => number;
@@ -8,6 +8,8 @@ function getColumnsKeys(columns) {
8
8
  });
9
9
  return columnKeys;
10
10
  }
11
+ const roundToHundredths = (number) => Math.round((number + Number.EPSILON) * 100) / 100;
11
12
  export {
12
- getColumnsKeys
13
+ getColumnsKeys,
14
+ roundToHundredths
13
15
  };
@@ -1,3 +1,2 @@
1
- import { FC } from 'react';
2
1
  import { CellProps } from './Cell.types';
3
- export declare const Cell: FC<CellProps>;
2
+ export declare const Cell: import('react').NamedExoticComponent<CellProps>;
@@ -1,5 +1,6 @@
1
1
  import { jsx } from "@emotion/react/jsx-runtime";
2
- import { getCellStyle, getCellBackgroundStyle, ellipsisStyle } from "./Cell.styles.js";
2
+ import { memo } from "react";
3
+ import { getCellStyle, getCellBackgroundStyle, ellipsisStyle, getAlignStyle } from "./Cell.styles.js";
3
4
  const CellComponent = (props) => {
4
5
  const {
5
6
  component: Component,
@@ -17,9 +18,9 @@ const CellComponent = (props) => {
17
18
  if (colSpan === 0 || rowSpan === 0) {
18
19
  return null;
19
20
  }
20
- return /* @__PURE__ */ jsx(Component, { colSpan: colSpan === 1 ? void 0 : colSpan, rowSpan: rowSpan === 1 ? void 0 : rowSpan, ...rest, css: [getCellStyle(tableTokens, bordered), getCellBackgroundStyle(tableTokens, isRowSelected, isHovered), ellipsis ? ellipsisStyle : void 0, process.env.NODE_ENV === "production" ? "" : ";label:CellComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvY29tcG9uZW50cy9DZWxsL0NlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCTSIsImZpbGUiOiIvYnVpbGRzL2Zyb250ZW5kL2xpYnMvdWkta2l0L3NyYy9jb21wb25lbnRzL1RhYmxlL2NvbXBvbmVudHMvQ2VsbC9DZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRkMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgQ2VsbFByb3BzIH0gZnJvbSBcIi4vQ2VsbC50eXBlc1wiO1xuaW1wb3J0IHsgZ2V0Q2VsbFN0eWxlLCBnZXRDZWxsQmFja2dyb3VuZFN0eWxlLCBlbGxpcHNpc1N0eWxlIH0gZnJvbSBcIi4vQ2VsbC5zdHlsZXNcIjtcblxuY29uc3QgQ2VsbENvbXBvbmVudDogRkM8Q2VsbFByb3BzPiA9IChwcm9wcykgPT4ge1xuICBjb25zdCB7XG4gICAgY29tcG9uZW50OiBDb21wb25lbnQsXG4gICAgY29sU3BhbixcbiAgICByb3dTcGFuLFxuICAgIGNoaWxkcmVuLFxuICAgIGlzSG92ZXJlZCxcbiAgICBpc1Jvd1NlbGVjdGVkLFxuICAgIGFsaWduLFxuICAgIGJvcmRlcmVkLFxuICAgIHRhYmxlVG9rZW5zLFxuICAgIGVsbGlwc2lzLFxuICAgIC4uLnJlc3RcbiAgfSA9IHByb3BzO1xuXG4gIGlmIChjb2xTcGFuID09PSAwIHx8IHJvd1NwYW4gPT09IDApIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPENvbXBvbmVudFxuICAgICAgY29sU3Bhbj17Y29sU3BhbiA9PT0gMSA/IHVuZGVmaW5lZCA6IGNvbFNwYW59XG4gICAgICByb3dTcGFuPXtyb3dTcGFuID09PSAxID8gdW5kZWZpbmVkIDogcm93U3Bhbn1cbiAgICAgIHsuLi5yZXN0fVxuICAgICAgY3NzPXtbXG4gICAgICAgIGdldENlbGxTdHlsZSh0YWJsZVRva2VucywgYm9yZGVyZWQpLFxuICAgICAgICBnZXRDZWxsQmFja2dyb3VuZFN0eWxlKHRhYmxlVG9rZW5zLCBpc1Jvd1NlbGVjdGVkLCBpc0hvdmVyZWQpLFxuICAgICAgICBlbGxpcHNpcyA/IGVsbGlwc2lzU3R5bGUgOiB1bmRlZmluZWQsXG4gICAgICBdfVxuICAgID5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L0NvbXBvbmVudD5cbiAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBDZWxsID0gQ2VsbENvbXBvbmVudDtcbiJdfQ== */"], children });
21
+ return /* @__PURE__ */ jsx(Component, { colSpan: colSpan === 1 ? void 0 : colSpan, rowSpan: rowSpan === 1 ? void 0 : rowSpan, ...rest, css: [getCellStyle(tableTokens, bordered), getCellBackgroundStyle(tableTokens, isRowSelected, isHovered), ellipsis ? ellipsisStyle : void 0, getAlignStyle(align), process.env.NODE_ENV === "production" ? "" : ";label:CellComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvY29tcG9uZW50cy9DZWxsL0NlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCTSIsImZpbGUiOiIvYnVpbGRzL2Zyb250ZW5kL2xpYnMvdWkta2l0L3NyYy9jb21wb25lbnRzL1RhYmxlL2NvbXBvbmVudHMvQ2VsbC9DZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IG1lbW8sIHR5cGUgRkMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgQ2VsbFByb3BzIH0gZnJvbSBcIi4vQ2VsbC50eXBlc1wiO1xuaW1wb3J0IHsgZ2V0QWxpZ25TdHlsZSwgZ2V0Q2VsbFN0eWxlLCBnZXRDZWxsQmFja2dyb3VuZFN0eWxlLCBlbGxpcHNpc1N0eWxlIH0gZnJvbSBcIi4vQ2VsbC5zdHlsZXNcIjtcblxuY29uc3QgQ2VsbENvbXBvbmVudDogRkM8Q2VsbFByb3BzPiA9IChwcm9wcykgPT4ge1xuICBjb25zdCB7XG4gICAgY29tcG9uZW50OiBDb21wb25lbnQsXG4gICAgY29sU3BhbixcbiAgICByb3dTcGFuLFxuICAgIGNoaWxkcmVuLFxuICAgIGlzSG92ZXJlZCxcbiAgICBpc1Jvd1NlbGVjdGVkLFxuICAgIGFsaWduLFxuICAgIGJvcmRlcmVkLFxuICAgIHRhYmxlVG9rZW5zLFxuICAgIGVsbGlwc2lzLFxuICAgIC4uLnJlc3RcbiAgfSA9IHByb3BzO1xuXG4gIGlmIChjb2xTcGFuID09PSAwIHx8IHJvd1NwYW4gPT09IDApIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPENvbXBvbmVudFxuICAgICAgY29sU3Bhbj17Y29sU3BhbiA9PT0gMSA/IHVuZGVmaW5lZCA6IGNvbFNwYW59XG4gICAgICByb3dTcGFuPXtyb3dTcGFuID09PSAxID8gdW5kZWZpbmVkIDogcm93U3Bhbn1cbiAgICAgIHsuLi5yZXN0fVxuICAgICAgY3NzPXtbXG4gICAgICAgIGdldENlbGxTdHlsZSh0YWJsZVRva2VucywgYm9yZGVyZWQpLFxuICAgICAgICBnZXRDZWxsQmFja2dyb3VuZFN0eWxlKHRhYmxlVG9rZW5zLCBpc1Jvd1NlbGVjdGVkLCBpc0hvdmVyZWQpLFxuICAgICAgICBlbGxpcHNpcyA/IGVsbGlwc2lzU3R5bGUgOiB1bmRlZmluZWQsXG4gICAgICAgIGdldEFsaWduU3R5bGUoYWxpZ24pLFxuICAgICAgXX1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9Db21wb25lbnQ+XG4gICk7XG59O1xuXG5leHBvcnQgY29uc3QgQ2VsbCA9IG1lbW8oQ2VsbENvbXBvbmVudCk7XG4iXX0= */"], children });
21
22
  };
22
- const Cell = CellComponent;
23
+ const Cell = memo(CellComponent);
23
24
  export {
24
25
  Cell
25
26
  };
@@ -1,5 +1,6 @@
1
1
  import { TableTokens } from 'components/Table/Table.tokens';
2
2
  import { BorderedConfig } from 'components/Table/Table.types';
3
+ import { CellProps } from './Cell.types';
3
4
  export declare const getCellStyle: (tableTokens: TableTokens, bordered?: false | Required<BorderedConfig>) => {
4
5
  readonly boxSizing: "border-box";
5
6
  readonly padding: 0;
@@ -26,3 +27,8 @@ export declare const ellipsisStyle: {
26
27
  whiteSpace: string;
27
28
  overflow: string;
28
29
  };
30
+ export declare const getAlignStyle: (align: CellProps["align"]) => {
31
+ "&": {
32
+ textAlign: import("csstype").Property.TextAlign | undefined;
33
+ };
34
+ };
@@ -24,8 +24,14 @@ const ellipsisStyle = {
24
24
  whiteSpace: "nowrap",
25
25
  overflow: "hidden"
26
26
  };
27
+ const getAlignStyle = (align) => ({
28
+ "&": {
29
+ textAlign: align
30
+ }
31
+ });
27
32
  export {
28
33
  ellipsisStyle,
34
+ getAlignStyle,
29
35
  getCellBackgroundStyle,
30
36
  getCellStyle
31
37
  };
@@ -5,6 +5,7 @@ export declare const getCellStyle: (tableTokens: TableTokens, hasBlockEndBorder:
5
5
  borderStyle: string;
6
6
  borderColor: "#E5E5E5";
7
7
  borderWidth: number;
8
+ backgroundColor: "#FFFFFF";
8
9
  };
9
10
  export declare const getBorderedCellStyle: (hasInlineBorder: boolean) => {
10
11
  borderInlineStartWidth: number;
@@ -3,6 +3,7 @@ const getCellStyle = (tableTokens, hasBlockEndBorder) => ({
3
3
  borderStyle: "solid",
4
4
  borderColor: tableTokens.tableRowBorder,
5
5
  borderWidth: 0,
6
+ backgroundColor: tableTokens.tableRowBg,
6
7
  ...hasBlockEndBorder ? {
7
8
  borderBlockEndWidth: 1
8
9
  } : {}
@@ -0,0 +1,3 @@
1
+ import { DefaultRecord } from 'components/Table/Table.types';
2
+ import { FooterWrapperProps } from './FooterWrapper.types';
3
+ export declare const FooterWrapper: <T extends DefaultRecord>(props: FooterWrapperProps<T>) => import('react').ReactNode;
@@ -0,0 +1,36 @@
1
+ import { useState, useMemo } from "react";
2
+ import { useSubscribe } from "../../features/typedEventBus/hooks.js";
3
+ import { isNumber } from "lodash-es";
4
+ import { getEndRangeInfo } from "../EmptyDataRow/EmptyDataRow.utils.js";
5
+ import { useTableStaticContext } from "../../features/tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
6
+ import { getRefValue } from "../../utils/ref/ref.js";
7
+ const FooterWrapperComponent = (props) => {
8
+ const {
9
+ footer: footerProp,
10
+ sortedData
11
+ } = props;
12
+ const staticContextRef = useTableStaticContext();
13
+ const [verticalScrollBarWidth, setVerticalScrollBarWidth] = useState(() => getRefValue(staticContextRef, "scrollableTableSectionInfo.verticalScrollBarWidth"));
14
+ const [hasHorizontalScroll, setHorizontalScroll] = useState(() => getEndRangeInfo(staticContextRef).hasEndRange);
15
+ useSubscribe("table-visual-params:change", (value) => {
16
+ const {
17
+ verticalScrollBarWidth: verticalScrollBarWidth2,
18
+ horizontalScrollPositionRange
19
+ } = value;
20
+ if (isNumber(verticalScrollBarWidth2)) {
21
+ setVerticalScrollBarWidth(verticalScrollBarWidth2);
22
+ }
23
+ if (horizontalScrollPositionRange) {
24
+ setHorizontalScroll(getEndRangeInfo(horizontalScrollPositionRange).hasEndRange);
25
+ }
26
+ }, false, [], true);
27
+ const footer = useMemo(() => footerProp(sortedData, {
28
+ verticalScrollBarWidth,
29
+ hasHorizontalScroll
30
+ }), [footerProp, hasHorizontalScroll, sortedData, verticalScrollBarWidth]);
31
+ return footer;
32
+ };
33
+ const FooterWrapper = FooterWrapperComponent;
34
+ export {
35
+ FooterWrapper
36
+ };