@infomaximum/ui-kit 0.17.1 → 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.
- package/dist/components/BaseTooltip/BaseTooltip.js +14 -4
- package/dist/components/BaseTooltip/BaseTooltip.utils.d.ts +2 -1
- package/dist/components/BaseTooltip/BaseTooltip.utils.js +15 -2
- package/dist/components/Dropdown/Dropdown.js +2 -1
- package/dist/components/Dropdown/components/Menu/Menu.js +10 -7
- package/dist/components/Dropdown/contexts/dropdownContext.d.ts +0 -1
- package/dist/components/Dropdown/hooks/useSelectedKeysController.d.ts +0 -1
- package/dist/components/Dropdown/hooks/useSelectedKeysController.js +0 -4
- package/dist/components/Empty/components/images/BookmarkImg.js +8 -4
- package/dist/components/Empty/components/images/DefaultImg.js +8 -4
- package/dist/components/Empty/components/images/FilterImg.js +8 -4
- package/dist/components/Empty/components/images/LockedImg.js +8 -4
- package/dist/components/Empty/components/images/SearchImg.js +8 -4
- package/dist/components/Empty/components/images/TestingImg.js +8 -4
- package/dist/components/Empty/components/images/_404Img.js +8 -4
- package/dist/components/Spin/Spin.js +19 -32
- package/dist/components/Table/Table.js +23 -17
- package/dist/components/Table/Table.types.d.ts +4 -1
- package/dist/components/Table/components/Body/Body.js +18 -9
- package/dist/components/Table/components/Body/Body.types.d.ts +1 -0
- package/dist/components/Table/components/Body/components/BodyCell/BodyCell.js +22 -16
- package/dist/components/Table/components/Body/components/MeasureCell/MeasureCell.js +2 -1
- package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.js +24 -18
- package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.utils.d.ts +1 -0
- package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.utils.js +3 -1
- package/dist/components/Table/components/Cell/Cell.d.ts +1 -2
- package/dist/components/Table/components/Cell/Cell.js +4 -3
- package/dist/components/Table/components/Cell/Cell.styles.d.ts +6 -0
- package/dist/components/Table/components/Cell/Cell.styles.js +6 -0
- package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.styles.d.ts +1 -0
- package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.styles.js +1 -0
- package/dist/components/Table/components/Footer/FooterWrapper.d.ts +3 -0
- package/dist/components/Table/components/Footer/FooterWrapper.js +36 -0
- package/dist/components/Table/components/Footer/FooterWrapper.types.d.ts +5 -0
- package/dist/components/Table/features/tableRowSelection/components/CheckboxCellContentWrapper/CheckboxCellContentWrapper.js +3 -2
- package/dist/components/Table/features/tableRowSelection/components/RadioCellContentWrapper/RadioCellContentWrapper.js +3 -2
- package/dist/components/Table/features/tableRowSelection/hooks/useTransformColumns/useTransformColumns.js +51 -40
- package/dist/components/Table/features/tableRowSelection/types.d.ts +3 -2
- package/dist/components/Table/features/tableStaticContext/contexts/tableStaticContext/TableStaticContext.d.ts +1 -0
- package/dist/components/Table/features/tableStaticContext/contexts/tableStaticContext/TableStaticContext.js +2 -1
- package/dist/components/Table/features/tableStaticContext/contexts/tableStaticContext/TableStaticContext.types.d.ts +2 -0
- package/dist/components/Table/features/tableStaticContext/hocs/withTableStaticContext.js +6 -1
- package/dist/components/Table/hooks/useBodyCellRender/useBodyCellRender.js +5 -2
- package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.js +20 -22
- package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.styles.d.ts +4 -2
- package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.styles.js +4 -3
- package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.utils.d.ts +12 -1
- package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.utils.js +43 -1
- package/dist/components/Table/hooks/useCellHover/useCellHover.d.ts +0 -4
- package/dist/components/Table/hooks/useCellHover/useCellHover.js +2 -4
- package/dist/components/Table/hooks/useTableVisualParamsChange/useTableVisualParamsChange.js +8 -4
- package/dist/utils/eventBus/eventBus.d.ts +2 -1
- package/dist/utils/eventBus/eventBus.js +3 -0
- package/package.json +1 -1
|
@@ -1,11 +1,12 @@
|
|
|
1
|
-
import { jsxs, jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
-
import { memo, useState, useEffect, Fragment } from "react";
|
|
1
|
+
import { jsxs, Fragment, jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { memo, useState, useEffect, Fragment as Fragment$1 } from "react";
|
|
3
3
|
import { getSpinTokens } from "./Spin.tokens.js";
|
|
4
4
|
import { shouldDelay } from "./Spin.utils.js";
|
|
5
5
|
import { uniqueId, isUndefined } from "lodash-es";
|
|
6
|
-
import {
|
|
6
|
+
import { getSpinWrapperStyle, getForeignObjectSpinInnerStyle, getTipWrapperStyle, containerStyle, withChildrenPropWrapperStyle, childrenWrapperStyle, getWithFullscreenPropWrapperStyle, baseWrapperStyle } from "./Spin.styles.js";
|
|
7
7
|
import { useTheme } from "../../hooks/useTheme/useTheme.js";
|
|
8
8
|
const SpinComponent = (props) => {
|
|
9
|
+
var _a;
|
|
9
10
|
const {
|
|
10
11
|
delay,
|
|
11
12
|
fullscreen = false,
|
|
@@ -37,25 +38,25 @@ const SpinComponent = (props) => {
|
|
|
37
38
|
}
|
|
38
39
|
setSpinning(false);
|
|
39
40
|
}, [delay, spinningProp]);
|
|
40
|
-
|
|
41
|
-
|
|
41
|
+
const spinContent = /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
42
|
+
/* @__PURE__ */ jsx("span", { css: getSpinWrapperStyle(spinTokens, size), children: /* @__PURE__ */ jsxs("svg", { width: "1em", height: "1em", viewBox: "0 0 32 32", xmlns: "http://www.w3.org/2000/svg", children: [
|
|
43
|
+
/* @__PURE__ */ jsx("g", { clipPath: `url(#${clipPathUniqId})`, children: /* @__PURE__ */ jsx("foreignObject", { width: 32, height: 32, children: /* @__PURE__ */ jsx("div", { css: getForeignObjectSpinInnerStyle(fullscreen, variant)(theme) }) }) }),
|
|
44
|
+
/* @__PURE__ */ jsx("defs", { children: /* @__PURE__ */ jsx("clipPath", { id: clipPathUniqId, children: /* @__PURE__ */ jsx("path", { d: "M30 16.0001C30.0001 14.8955 29.1047 14 28.0001 14C26.8955 13.9999 26.0001 14.8953 26 15.9999L28 16L30 16.0001ZM19.09 6.48877C20.1405 6.83008 21.2688 6.25516 21.6101 5.20465C21.9514 4.15413 21.3765 3.02583 20.326 2.68452L19.708 4.58665L19.09 6.48877ZM28 16L26 15.9999C25.9999 18.1116 25.3313 20.1692 24.0899 21.8776L25.7079 23.0532L27.3259 24.2288C29.0638 21.8371 29.9999 18.9565 30 16.0001L28 16ZM25.7079 23.0532L24.0899 21.8776C22.8486 23.586 21.0983 24.8575 19.0899 25.5101L19.7078 27.4122L20.3258 29.3143C23.1376 28.4008 25.588 26.6206 27.3259 24.2288L25.7079 23.0532ZM19.7078 27.4122L19.0899 25.5101C17.0814 26.1626 14.918 26.1625 12.9096 25.5099L12.2915 27.412L11.6734 29.3141C14.4852 30.2277 17.514 30.2278 20.3258 29.3143L19.7078 27.4122ZM12.2915 27.412L12.9096 25.5099C10.9012 24.8573 9.15098 23.5856 7.90974 21.8771L6.29169 23.0527L4.67363 24.2282C6.41137 26.6201 8.8617 28.4004 11.6734 29.3141L12.2915 27.412ZM6.29169 23.0527L7.90974 21.8771C6.6685 20.1686 5.99998 18.1111 6 15.9993L4 15.9993L2 15.9993C1.99998 18.9558 2.9359 21.8363 4.67363 24.2282L6.29169 23.0527ZM4 15.9993L6 15.9993C6.00002 13.8876 6.66856 11.83 7.90982 10.1215L6.29179 8.94598L4.67375 7.77041C2.93599 10.1622 2.00002 13.0428 2 15.9993L4 15.9993ZM6.29179 8.94598L7.90982 10.1215C9.15109 8.41309 10.9013 7.14144 12.9097 6.48885L12.2917 4.58675L11.6736 2.68464C8.86187 3.59827 6.41152 5.37857 4.67375 7.77041L6.29179 8.94598ZM12.2917 4.58675L12.9097 6.48885C14.9181 5.83626 17.0816 5.83623 19.09 6.48877L19.708 4.58665L20.326 2.68452C17.5142 1.77097 14.4854 1.77101 11.6736 2.68464L12.2917 4.58675Z" }) }) })
|
|
45
|
+
] }) }),
|
|
46
|
+
tip && /* @__PURE__ */ jsx("div", { css: getTipWrapperStyle(fullscreen)(theme), children: tip })
|
|
47
|
+
] });
|
|
48
|
+
if (children) {
|
|
49
|
+
return /* @__PURE__ */ jsxs("div", { css: spinning ? containerStyle : void 0, children: [
|
|
50
|
+
spinning && /* @__PURE__ */ jsx("div", { css: [withChildrenPropWrapperStyle(theme), (_a = styles == null ? void 0 : styles.withChildrenPropWrapperStyle) == null ? void 0 : _a.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SpinComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvU3Bpbi9TcGluLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRlkiLCJmaWxlIjoiL2J1aWxkcy9mcm9udGVuZC9saWJzL3VpLWtpdC9zcmMvY29tcG9uZW50cy9TcGluL1NwaW4udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRnJhZ21lbnQsIG1lbW8sIHVzZUVmZmVjdCwgdXNlU3RhdGUsIHR5cGUgQ29tcG9uZW50UHJvcHMsIHR5cGUgRkMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgU3BpblByb3BzIH0gZnJvbSBcIi4vU3Bpbi50eXBlc1wiO1xuaW1wb3J0IHsgdXNlVGhlbWUgfSBmcm9tIFwiLi4vLi4vaG9va3MvdXNlVGhlbWVcIjtcbmltcG9ydCB7IGdldFNwaW5Ub2tlbnMgfSBmcm9tIFwiLi9TcGluLnRva2Vuc1wiO1xuaW1wb3J0IHsgc2hvdWxkRGVsYXkgfSBmcm9tIFwiLi9TcGluLnV0aWxzXCI7XG5pbXBvcnQgeyBpc1VuZGVmaW5lZCwgdW5pcXVlSWQgfSBmcm9tIFwibG9kYXNoLWVzXCI7XG5pbXBvcnQge1xuICBiYXNlV3JhcHBlclN0eWxlLFxuICBjaGlsZHJlbldyYXBwZXJTdHlsZSxcbiAgY29udGFpbmVyU3R5bGUsXG4gIGdldEZvcmVpZ25PYmplY3RTcGluSW5uZXJTdHlsZSxcbiAgZ2V0U3BpbldyYXBwZXJTdHlsZSxcbiAgZ2V0VGlwV3JhcHBlclN0eWxlLFxuICBnZXRXaXRoRnVsbHNjcmVlblByb3BXcmFwcGVyU3R5bGUsXG4gIHdpdGhDaGlsZHJlblByb3BXcmFwcGVyU3R5bGUsXG59IGZyb20gXCIuL1NwaW4uc3R5bGVzXCI7XG5cbmNvbnN0IFNwaW5Db21wb25lbnQ6IEZDPFNwaW5Qcm9wcz4gPSAocHJvcHMpID0+IHtcbiAgY29uc3Qge1xuICAgIGRlbGF5LFxuICAgIGZ1bGxzY3JlZW4gPSBmYWxzZSxcbiAgICBzaXplID0gXCJtaWRkbGVcIixcbiAgICB2YXJpYW50ID0gXCJiYXNlXCIsXG4gICAgc3Bpbm5pbmc6IHNwaW5uaW5nUHJvcCA9IHRydWUsXG4gICAgdGlwLFxuICAgIGNoaWxkcmVuLFxuICAgIHN0eWxlcyxcbiAgfSA9IHByb3BzO1xuICBjb25zdCBjbGlwUGF0aFVuaXFJZCA9IHVuaXF1ZUlkKFwic3Bpbm5lcl9jbGlwX3BhdGhfXCIpO1xuICBjb25zdCB0aGVtZSA9IHVzZVRoZW1lKCk7XG4gIGNvbnN0IHNwaW5Ub2tlbnMgPSBnZXRTcGluVG9rZW5zKCk7XG5cbiAgY29uc3QgW3NwaW5uaW5nLCBzZXRTcGlubmluZ10gPSB1c2VTdGF0ZSgoKSA9PiBzcGlubmluZ1Byb3AgJiYgIXNob3VsZERlbGF5KHNwaW5uaW5nUHJvcCwgZGVsYXkpKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzcGlubmluZ1Byb3ApIHtcbiAgICAgIGlmIChpc1VuZGVmaW5lZChkZWxheSkpIHtcbiAgICAgICAgc2V0U3Bpbm5pbmcodHJ1ZSk7XG5cbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBjb25zdCB0aW1lcklkID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgIHNldFNwaW5uaW5nKHRydWUpO1xuICAgICAgfSwgZGVsYXkpO1xuXG4gICAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgICBpZiAodGltZXJJZCkge1xuICAgICAgICAgIGNsZWFyVGltZW91dCh0aW1lcklkKTtcbiAgICAgICAgfVxuICAgICAgfTtcbiAgICB9XG5cbiAgICBzZXRTcGlubmluZyhmYWxzZSk7XG4gIH0sIFtkZWxheSwgc3Bpbm5pbmdQcm9wXSk7XG5cbiAgY29uc3Qgc3BpbkNvbnRlbnQgPSAoXG4gICAgPD5cbiAgICAgIDxzcGFuIGNzcz17Z2V0U3BpbldyYXBwZXJTdHlsZShzcGluVG9rZW5zLCBzaXplKX0+XG4gICAgICAgIDxzdmcgd2lkdGg9XCIxZW1cIiBoZWlnaHQ9XCIxZW1cIiB2aWV3Qm94PVwiMCAwIDMyIDMyXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiPlxuICAgICAgICAgIDxnIGNsaXBQYXRoPXtgdXJsKCMke2NsaXBQYXRoVW5pcUlkfSlgfT5cbiAgICAgICAgICAgIDxmb3JlaWduT2JqZWN0IHdpZHRoPXszMn0gaGVpZ2h0PXszMn0+XG4gICAgICAgICAgICAgIDxkaXYgY3NzPXtnZXRGb3JlaWduT2JqZWN0U3BpbklubmVyU3R5bGUoZnVsbHNjcmVlbiwgdmFyaWFudCkodGhlbWUpfSAvPlxuICAgICAgICAgICAgPC9mb3JlaWduT2JqZWN0PlxuICAgICAgICAgIDwvZz5cbiAgICAgICAgICA8ZGVmcz5cbiAgICAgICAgICAgIDxjbGlwUGF0aCBpZD17Y2xpcFBhdGhVbmlxSWR9PlxuICAgICAgICAgICAgICA8cGF0aCBkPVwiTTMwIDE2LjAwMDFDMzAuMDAwMSAxNC44OTU1IDI5LjEwNDcgMTQgMjguMDAwMSAxNEMyNi44OTU1IDEzLjk5OTkgMjYuMDAwMSAxNC44OTUzIDI2IDE1Ljk5OTlMMjggMTZMMzAgMTYuMDAwMVpNMTkuMDkgNi40ODg3N0MyMC4xNDA1IDYuODMwMDggMjEuMjY4OCA2LjI1NTE2IDIxLjYxMDEgNS4yMDQ2NUMyMS45NTE0IDQuMTU0MTMgMjEuMzc2NSAzLjAyNTgzIDIwLjMyNiAyLjY4NDUyTDE5LjcwOCA0LjU4NjY1TDE5LjA5IDYuNDg4NzdaTTI4IDE2TDI2IDE1Ljk5OTlDMjUuOTk5OSAxOC4xMTE2IDI1LjMzMTMgMjAuMTY5MiAyNC4wODk5IDIxLjg3NzZMMjUuNzA3OSAyMy4wNTMyTDI3LjMyNTkgMjQuMjI4OEMyOS4wNjM4IDIxLjgzNzEgMjkuOTk5OSAxOC45NTY1IDMwIDE2LjAwMDFMMjggMTZaTTI1LjcwNzkgMjMuMDUzMkwyNC4wODk5IDIxLjg3NzZDMjIuODQ4NiAyMy41ODYgMjEuMDk4MyAyNC44NTc1IDE5LjA4OTkgMjUuNTEwMUwxOS43MDc4IDI3LjQxMjJMMjAuMzI1OCAyOS4zMTQzQzIzLjEzNzYgMjguNDAwOCAyNS41ODggMjYuNjIwNiAyNy4zMjU5IDI0LjIyODhMMjUuNzA3OSAyMy4wNTMyWk0xOS43MDc4IDI3LjQxMjJMMTkuMDg5OSAyNS41MTAxQzE3LjA4MTQgMjYuMTYyNiAxNC45MTggMjYuMTYyNSAxMi45MDk2IDI1LjUwOTlMMTIuMjkxNSAyNy40MTJMMTEuNjczNCAyOS4zMTQxQzE0LjQ4NTIgMzAuMjI3NyAxNy41MTQgMzAuMjI3OCAyMC4zMjU4IDI5LjMxNDNMMTkuNzA3OCAyNy40MTIyWk0xMi4yOTE1IDI3LjQxMkwxMi45MDk2IDI1LjUwOTlDMTAuOTAxMiAyNC44NTczIDkuMTUwOTggMjMuNTg1NiA3LjkwOTc0IDIxLjg3NzFMNi4yOTE2OSAyMy4wNTI3TDQuNjczNjMgMjQuMjI4MkM2LjQxMTM3IDI2LjYyMDEgOC44NjE3IDI4LjQwMDQgMTEuNjczNCAyOS4zMTQxTDEyLjI5MTUgMjcuNDEyWk02LjI5MTY5IDIzLjA1MjdMNy45MDk3NCAyMS44NzcxQzYuNjY4NSAyMC4xNjg2IDUuOTk5OTggMTguMTExMSA2IDE1Ljk5OTNMNCAxNS45OTkzTDIgMTUuOTk5M0MxLjk5OTk4IDE4Ljk1NTggMi45MzU5IDIxLjgzNjMgNC42NzM2MyAyNC4yMjgyTDYuMjkxNjkgMjMuMDUyN1pNNCAxNS45OTkzTDYgMTUuOTk5M0M2LjAwMDAyIDEzLjg4NzYgNi42Njg1NiAxMS44MyA3LjkwOTgyIDEwLjEyMTVMNi4yOTE3OSA4Ljk0NTk4TDQuNjczNzUgNy43NzA0MUMyLjkzNTk5IDEwLjE2MjIgMi4wMDAwMiAxMy4wNDI4IDIgMTUuOTk5M0w0IDE1Ljk5OTNaTTYuMjkxNzkgOC45NDU5OEw3LjkwOTgyIDEwLjEyMTVDOS4xNTEwOSA4LjQxMzA5IDEwLjkwMTMgNy4xNDE0NCAxMi45MDk3IDYuNDg4ODVMMTIuMjkxNyA0LjU4Njc1TDExLjY3MzYgMi42ODQ2NEM4Ljg2MTg3IDMuNTk4MjcgNi40MTE1MiA1LjM3ODU3IDQuNjczNzUgNy43NzA0MUw2LjI5MTc5IDguOTQ1OThaTTEyLjI5MTcgNC41ODY3NUwxMi45MDk3IDYuNDg4ODVDMTQuOTE4MSA1LjgzNjI2IDE3LjA4MTYgNS44MzYyMyAxOS4wOSA2LjQ4ODc3TDE5LjcwOCA0LjU4NjY1TDIwLjMyNiAyLjY4NDUyQzE3LjUxNDIgMS43NzA5NyAxNC40ODU0IDEuNzcxMDEgMTEuNjczNiAyLjY4NDY0TDEyLjI5MTcgNC41ODY3NVpcIiAvPlxuICAgICAgICAgICAgPC9jbGlwUGF0aD5cbiAgICAgICAgICA8L2RlZnM+XG4gICAgICAgIDwvc3ZnPlxuICAgICAgPC9zcGFuPlxuICAgICAge3RpcCAmJiA8ZGl2IGNzcz17Z2V0VGlwV3JhcHBlclN0eWxlKGZ1bGxzY3JlZW4pKHRoZW1lKX0+e3RpcH08L2Rpdj59XG4gICAgPC8+XG4gICk7XG5cbiAgaWYgKGNoaWxkcmVuKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxkaXYgY3NzPXtzcGlubmluZyA/IGNvbnRhaW5lclN0eWxlIDogdW5kZWZpbmVkfT5cbiAgICAgICAge3NwaW5uaW5nICYmIChcbiAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICBjc3M9e1tcbiAgICAgICAgICAgICAgd2l0aENoaWxkcmVuUHJvcFdyYXBwZXJTdHlsZSh0aGVtZSksXG4gICAgICAgICAgICAgIHN0eWxlcz8ud2l0aENoaWxkcmVuUHJvcFdyYXBwZXJTdHlsZT8uKHRoZW1lKSxcbiAgICAgICAgICAgIF19XG4gICAgICAgICAgPlxuICAgICAgICAgICAge3NwaW5Db250ZW50fVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICApfVxuICAgICAgICA8ZGl2IGNzcz17c3Bpbm5pbmcgPyBjaGlsZHJlbldyYXBwZXJTdHlsZSA6IHVuZGVmaW5lZH0+e2NoaWxkcmVufTwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgKTtcbiAgfVxuXG4gIGlmICghc3Bpbm5pbmcpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBXcmFwcGVyID0gdGlwIHx8IGZ1bGxzY3JlZW4gPyBcImRpdlwiIDogRnJhZ21lbnQ7XG5cbiAgY29uc3Qgd3JhcHBlclByb3BzOiBDb21wb25lbnRQcm9wczx0eXBlb2YgV3JhcHBlcj4gPSAoKCkgPT4ge1xuICAgIGlmICghKHRpcCB8fCBmdWxsc2NyZWVuKSkge1xuICAgICAgcmV0dXJuIHt9O1xuICAgIH1cblxuICAgIGlmIChmdWxsc2NyZWVuKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBjc3M6IGdldFdpdGhGdWxsc2NyZWVuUHJvcFdyYXBwZXJTdHlsZShzcGlubmluZykodGhlbWUpLFxuICAgICAgfTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgY3NzOiBiYXNlV3JhcHBlclN0eWxlKHRoZW1lKSxcbiAgICB9O1xuICB9KSgpO1xuXG4gIHJldHVybiA8V3JhcHBlciB7Li4ud3JhcHBlclByb3BzfT57c3BpbkNvbnRlbnR9PC9XcmFwcGVyPjtcbn07XG5cbmV4cG9ydCBjb25zdCBTcGluID0gbWVtbyhTcGluQ29tcG9uZW50KTtcbiJdfQ== */"], children: spinContent }),
|
|
51
|
+
/* @__PURE__ */ jsx("div", { css: spinning ? childrenWrapperStyle : void 0, children })
|
|
52
|
+
] });
|
|
42
53
|
}
|
|
43
54
|
if (!spinning) {
|
|
44
55
|
return;
|
|
45
56
|
}
|
|
46
|
-
const
|
|
47
|
-
const Wrapper = tip || children || fullscreen ? "div" : Fragment;
|
|
48
|
-
const containerProps = (() => {
|
|
49
|
-
if (!children) {
|
|
50
|
-
return {};
|
|
51
|
-
}
|
|
52
|
-
return {
|
|
53
|
-
css: containerStyle
|
|
54
|
-
};
|
|
55
|
-
})();
|
|
57
|
+
const Wrapper = tip || fullscreen ? "div" : Fragment$1;
|
|
56
58
|
const wrapperProps = (() => {
|
|
57
|
-
|
|
58
|
-
if (!(tip || children || fullscreen)) {
|
|
59
|
+
if (!(tip || fullscreen)) {
|
|
59
60
|
return {};
|
|
60
61
|
}
|
|
61
62
|
if (fullscreen) {
|
|
@@ -63,25 +64,11 @@ const SpinComponent = (props) => {
|
|
|
63
64
|
css: getWithFullscreenPropWrapperStyle(spinning)(theme)
|
|
64
65
|
};
|
|
65
66
|
}
|
|
66
|
-
if (children) {
|
|
67
|
-
return {
|
|
68
|
-
css: [withChildrenPropWrapperStyle(theme), (_a = styles == null ? void 0 : styles.withChildrenPropWrapperStyle) == null ? void 0 : _a.call(styles, theme)]
|
|
69
|
-
};
|
|
70
|
-
}
|
|
71
67
|
return {
|
|
72
68
|
css: baseWrapperStyle(theme)
|
|
73
69
|
};
|
|
74
70
|
})();
|
|
75
|
-
return /* @__PURE__ */
|
|
76
|
-
/* @__PURE__ */ jsxs(Wrapper, { ...wrapperProps, children: [
|
|
77
|
-
/* @__PURE__ */ jsx("span", { css: getSpinWrapperStyle(spinTokens, size), children: /* @__PURE__ */ jsxs("svg", { width: "1em", height: "1em", viewBox: "0 0 32 32", xmlns: "http://www.w3.org/2000/svg", children: [
|
|
78
|
-
/* @__PURE__ */ jsx("g", { clipPath: `url(#${clipPathUniqId})`, children: /* @__PURE__ */ jsx("foreignObject", { width: 32, height: 32, children: /* @__PURE__ */ jsx("div", { css: getForeignObjectSpinInnerStyle(fullscreen, variant)(theme) }) }) }),
|
|
79
|
-
/* @__PURE__ */ jsx("defs", { children: /* @__PURE__ */ jsx("clipPath", { id: clipPathUniqId, children: /* @__PURE__ */ jsx("path", { d: "M30 16.0001C30.0001 14.8955 29.1047 14 28.0001 14C26.8955 13.9999 26.0001 14.8953 26 15.9999L28 16L30 16.0001ZM19.09 6.48877C20.1405 6.83008 21.2688 6.25516 21.6101 5.20465C21.9514 4.15413 21.3765 3.02583 20.326 2.68452L19.708 4.58665L19.09 6.48877ZM28 16L26 15.9999C25.9999 18.1116 25.3313 20.1692 24.0899 21.8776L25.7079 23.0532L27.3259 24.2288C29.0638 21.8371 29.9999 18.9565 30 16.0001L28 16ZM25.7079 23.0532L24.0899 21.8776C22.8486 23.586 21.0983 24.8575 19.0899 25.5101L19.7078 27.4122L20.3258 29.3143C23.1376 28.4008 25.588 26.6206 27.3259 24.2288L25.7079 23.0532ZM19.7078 27.4122L19.0899 25.5101C17.0814 26.1626 14.918 26.1625 12.9096 25.5099L12.2915 27.412L11.6734 29.3141C14.4852 30.2277 17.514 30.2278 20.3258 29.3143L19.7078 27.4122ZM12.2915 27.412L12.9096 25.5099C10.9012 24.8573 9.15098 23.5856 7.90974 21.8771L6.29169 23.0527L4.67363 24.2282C6.41137 26.6201 8.8617 28.4004 11.6734 29.3141L12.2915 27.412ZM6.29169 23.0527L7.90974 21.8771C6.6685 20.1686 5.99998 18.1111 6 15.9993L4 15.9993L2 15.9993C1.99998 18.9558 2.9359 21.8363 4.67363 24.2282L6.29169 23.0527ZM4 15.9993L6 15.9993C6.00002 13.8876 6.66856 11.83 7.90982 10.1215L6.29179 8.94598L4.67375 7.77041C2.93599 10.1622 2.00002 13.0428 2 15.9993L4 15.9993ZM6.29179 8.94598L7.90982 10.1215C9.15109 8.41309 10.9013 7.14144 12.9097 6.48885L12.2917 4.58675L11.6736 2.68464C8.86187 3.59827 6.41152 5.37857 4.67375 7.77041L6.29179 8.94598ZM12.2917 4.58675L12.9097 6.48885C14.9181 5.83626 17.0816 5.83623 19.09 6.48877L19.708 4.58665L20.326 2.68452C17.5142 1.77097 14.4854 1.77101 11.6736 2.68464L12.2917 4.58675Z" }) }) })
|
|
80
|
-
] }) }),
|
|
81
|
-
tip && /* @__PURE__ */ jsx("div", { css: getTipWrapperStyle(fullscreen)(theme), children: tip })
|
|
82
|
-
] }),
|
|
83
|
-
children && /* @__PURE__ */ jsx("div", { css: childrenWrapperStyle, children })
|
|
84
|
-
] });
|
|
71
|
+
return /* @__PURE__ */ jsx(Wrapper, { ...wrapperProps, children: spinContent });
|
|
85
72
|
};
|
|
86
73
|
const Spin = memo(SpinComponent);
|
|
87
74
|
export {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { jsx, jsxs, Fragment } from "@emotion/react/jsx-runtime";
|
|
2
|
-
import { memo, forwardRef, useMemo,
|
|
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,
|
|
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
|
|
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
|
|
210
|
-
const
|
|
211
|
-
if (
|
|
212
|
-
|
|
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
|
-
|
|
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
|
|
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[]
|
|
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 =
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
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
|
|
@@ -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
|
|
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,
|
|
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,
|
|
31
|
+
colsWidthsMap.set(data, roundedOffsetWidth);
|
|
29
32
|
}
|
|
30
|
-
if (
|
|
31
|
-
colsWidthsMap.set(data,
|
|
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
|
-
|
|
61
|
-
|
|
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((
|
|
81
|
-
|
|
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;
|