@infomaximum/ui-kit 0.17.2 → 0.17.3
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/Button/Button.types.d.ts +1 -1
- package/dist/components/ConfigProvider/ConfigProvider.js +11 -4
- package/dist/components/Switch/Switch.js +4 -4
- package/dist/components/Switch/Switch.styles.js +7 -3
- package/dist/components/Switch/Switch.types.d.ts +1 -1
- package/dist/components/Table/Table.js +15 -23
- package/dist/components/Table/Table.styles.d.ts +1 -1
- package/dist/components/Table/Table.styles.js +2 -2
- package/dist/components/Table/Table.types.d.ts +25 -7
- package/dist/components/Table/components/Body/Body.js +1 -1
- package/dist/components/Table/components/Body/components/BodyCell/BodyCell.js +4 -3
- package/dist/components/Table/components/Body/components/BodyCell/BodyCell.styles.d.ts +2 -2
- package/dist/components/Table/components/Body/components/BodyCell/BodyCell.styles.js +3 -3
- package/dist/components/Table/components/Body/components/MeasureCell/MeasureCell.js +11 -3
- package/dist/components/Table/components/Body/components/MeasureCell/MeasureCell.types.d.ts +1 -0
- package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.js +2 -2
- package/dist/components/Table/components/Cell/Cell.styles.d.ts +2 -2
- package/dist/components/Table/components/Cell/Cell.styles.js +3 -3
- package/dist/components/Table/components/Cell/Cell.types.d.ts +2 -2
- package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.js +5 -5
- package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.styles.d.ts +2 -2
- package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.styles.js +4 -9
- package/dist/components/Table/components/FixedHeader/FixedHeader.js +1 -1
- package/dist/components/Table/components/FixedHeader/components/FixedHeaderColGroup/FixedHeaderColGroup.js +18 -12
- package/dist/components/Table/components/Header/Header.js +1 -1
- package/dist/components/Table/components/Header/components/HeaderCell/HeaderCell.js +2 -2
- package/dist/components/Table/components/Header/components/HeaderCell/HeaderCell.styles.d.ts +2 -2
- package/dist/components/Table/components/Header/components/HeaderCell/HeaderCell.styles.js +3 -3
- package/dist/components/Table/contexts/tableContext/TableContext.js +9 -1
- package/dist/components/Table/contexts/tableContext/TableContext.types.d.ts +3 -2
- package/dist/components/Table/features/tableRowSelection/components/CheckboxCellContentWrapper/CheckboxCellContentWrapper.js +1 -1
- package/dist/components/Table/features/tableRowSelection/components/HeaderCheckboxCellContentWrapper/HeaderCheckboxCellContentWrapper.js +1 -1
- package/dist/components/Table/features/tableRowSelection/components/RadioCellContentWrapper/RadioCellContentWrapper.js +1 -1
- package/dist/components/Table/features/tableSort/components/HeaderCellWithSort/HeaderCellWithSort.js +2 -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 +1 -0
- package/dist/components/Table/hooks/useTableBordered/getBorderedInfo.d.ts +3 -0
- package/dist/components/Table/hooks/useTableBordered/getBorderedInfo.js +41 -0
- package/dist/components/Table/hooks/useTableBordered/index.d.ts +1 -0
- package/dist/components/Table/hooks/useTableBordered/useTableBordered.d.ts +4 -0
- package/dist/components/Table/hooks/useTableBordered/useTableBordered.js +14 -0
- package/dist/components/Table/hooks/useTableBordered/useTableBordered.types.d.ts +3 -0
- package/dist/components/Table/hooks/useTableVisualParamsChange/index.d.ts +1 -0
- package/dist/components/Table/hooks/useTableVisualParamsChange/types.d.ts +6 -0
- package/dist/components/Table/hooks/useTableVisualParamsChange/useTableVisualParamsChange.js +17 -4
- package/dist/components/Table/hooks/useTableVisualParamsChange/utils.d.ts +1 -0
- package/dist/components/Table/hooks/useTableVisualParamsChange/utils.js +3 -1
- package/dist/components/Tabs/Tabs.js +2 -2
- package/dist/components/Tabs/Tabs.types.d.ts +3 -1
- package/dist/components/Tabs/Tabs.utils.d.ts +3 -0
- package/dist/components/Tabs/Tabs.utils.js +29 -1
- package/dist/components/Tabs/components/TabBar/TabBar.js +12 -10
- package/dist/components/Tabs/components/TabBar/TabBar.styles.d.ts +1 -1
- package/dist/components/Tabs/components/TabBar/TabBar.styles.js +3 -9
- package/dist/components/Tabs/components/TabItem/TabItem.js +24 -8
- package/dist/components/Tabs/components/TabItem/TabItem.types.d.ts +2 -0
- package/dist/components/Tabs/hooks/useMoreTabsController.d.ts +4 -1
- package/dist/components/Tabs/hooks/useMoreTabsController.js +37 -6
- package/dist/components/Tabs/hooks/useTabsDndController.d.ts +1 -2
- package/dist/components/Tabs/hooks/useTabsDndController.js +7 -4
- package/package.json +1 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Interpolation } from '@emotion/react';
|
|
2
2
|
import { ButtonHTMLAttributes, MouseEvent, ReactNode } from 'react';
|
|
3
3
|
import { Theme } from '../../themes';
|
|
4
|
-
import { TooltipProps } from '
|
|
4
|
+
import { TooltipProps } from '../Tooltip';
|
|
5
5
|
export type ButtonVariant = "solid" | "outlined" | "dashed" | "text" | "link";
|
|
6
6
|
export type ButtonColor = "default" | "primary" | "danger" | "remove";
|
|
7
7
|
export type ButtonIconPosition = "start" | "end";
|
|
@@ -1,16 +1,23 @@
|
|
|
1
1
|
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
-
import { useMemo } from "react";
|
|
2
|
+
import { useContext, useMemo } from "react";
|
|
3
3
|
import { ConfigContext } from "./contexts/ConfigContext.js";
|
|
4
|
+
import { isUndefined } from "lodash-es";
|
|
4
5
|
const ConfigProviderComponent = (props) => {
|
|
5
6
|
const {
|
|
6
7
|
locale,
|
|
7
8
|
renderEmpty,
|
|
8
9
|
children
|
|
9
10
|
} = props;
|
|
11
|
+
const parentContextValue = useContext(ConfigContext);
|
|
10
12
|
const contextValue = useMemo(() => ({
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
13
|
+
...parentContextValue,
|
|
14
|
+
...isUndefined(locale) ? {} : {
|
|
15
|
+
locale
|
|
16
|
+
},
|
|
17
|
+
...isUndefined(renderEmpty) ? {} : {
|
|
18
|
+
renderEmpty
|
|
19
|
+
}
|
|
20
|
+
}), [locale, parentContextValue, renderEmpty]);
|
|
14
21
|
return /* @__PURE__ */ jsx(ConfigContext.Provider, { value: contextValue, children });
|
|
15
22
|
};
|
|
16
23
|
const ConfigProvider = ConfigProviderComponent;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
-
import { memo, useState, useRef,
|
|
2
|
+
import { memo, useState, useRef, useLayoutEffect, useCallback } from "react";
|
|
3
3
|
import { getSwitchDefaultStyle } from "./Switch.styles.js";
|
|
4
4
|
import { isUndefined } from "lodash-es";
|
|
5
5
|
import { withThemeProvider } from "../../hocs/withThemeProvider.js";
|
|
@@ -17,7 +17,7 @@ const SwitchComponent = memo(({
|
|
|
17
17
|
defaultChecked = false,
|
|
18
18
|
onClick,
|
|
19
19
|
onChange,
|
|
20
|
-
testId
|
|
20
|
+
"test-id": testId
|
|
21
21
|
}) => {
|
|
22
22
|
const theme = useTheme();
|
|
23
23
|
const [localChecked, setLocalChecked] = useState(defaultChecked);
|
|
@@ -32,7 +32,7 @@ const SwitchComponent = memo(({
|
|
|
32
32
|
checked: currentChecked.current,
|
|
33
33
|
isMouseDown
|
|
34
34
|
});
|
|
35
|
-
|
|
35
|
+
useLayoutEffect(() => {
|
|
36
36
|
if (isInitialMount.current) {
|
|
37
37
|
isInitialMount.current = false;
|
|
38
38
|
} else {
|
|
@@ -66,7 +66,7 @@ const SwitchComponent = memo(({
|
|
|
66
66
|
}
|
|
67
67
|
onClick == null ? void 0 : onClick(currentChecked.current, event);
|
|
68
68
|
}, [checked, isNotAllowed, onClick]);
|
|
69
|
-
return /* @__PURE__ */ jsx("button", { type: "button", role: "switch", css: [switchDefaultStyle.wrapper(theme), styles == null ? void 0 : styles.wrapper(theme), process.env.NODE_ENV === "production" ? "" : ";label:SwitchComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvU3dpdGNoL1N3aXRjaC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0dRIiwiZmlsZSI6Ii9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvU3dpdGNoL1N3aXRjaC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0eXBlIEZDLCBtZW1vLCB0eXBlIE1vdXNlRXZlbnQsIHVzZUNhbGxiYWNrLCB1c2VFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgU3dpdGNoUHJvcHMgfSBmcm9tIFwiLi9Td2l0Y2gudHlwZXNcIjtcbmltcG9ydCB7IExvYWRpbmdPdXRsaW5lZCB9IGZyb20gXCJpY29ucy9pY29uc1wiO1xuaW1wb3J0IHsgZ2V0U3dpdGNoRGVmYXVsdFN0eWxlIH0gZnJvbSBcIi4vU3dpdGNoLnN0eWxlc1wiO1xuaW1wb3J0IHsgdXNlVGhlbWUgfSBmcm9tIFwiaG9va3MvdXNlVGhlbWVcIjtcbmltcG9ydCB7IGlzVW5kZWZpbmVkIH0gZnJvbSBcImxvZGFzaC1lc1wiO1xuaW1wb3J0IHsgd2l0aFRoZW1lUHJvdmlkZXIgfSBmcm9tIFwiaG9jcy93aXRoVGhlbWVQcm92aWRlclwiO1xuaW1wb3J0IHtcbiAgZGVmYXVsdEhhbmRsZVRlc3RJZCxcbiAgZGVmYXVsdEhhbmRsZVRlc3RJZFN1ZmZpeCxcbiAgZGVmYXVsdFN3aXRjaFRlc3RJZCxcbn0gZnJvbSBcIi4vU3dpdGNoLnV0aWxzXCI7XG5cbmNvbnN0IFN3aXRjaENvbXBvbmVudDogRkM8U3dpdGNoUHJvcHM+ID0gbWVtbyhcbiAgKHtcbiAgICBhdXRvRm9jdXMsXG4gICAgbG9hZGluZyxcbiAgICBjaGVja2VkLFxuICAgIGRpc2FibGVkLFxuICAgIHNpemUsXG4gICAgc3R5bGVzLFxuICAgIGNsYXNzTmFtZSxcbiAgICBkZWZhdWx0Q2hlY2tlZCA9IGZhbHNlLFxuICAgIG9uQ2xpY2ssXG4gICAgb25DaGFuZ2UsXG4gICAgdGVzdElkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpO1xuXG4gICAgY29uc3QgW2xvY2FsQ2hlY2tlZCwgc2V0TG9jYWxDaGVja2VkXSA9IHVzZVN0YXRlKGRlZmF1bHRDaGVja2VkKTtcbiAgICBjb25zdCBbaXNNb3VzZURvd24sIHNldElzTW91c2VEb3duXSA9IHVzZVN0YXRlKGZhbHNlKTtcblxuICAgIGNvbnN0IGlzSW5pdGlhbE1vdW50ID0gdXNlUmVmKHRydWUpO1xuICAgIGNvbnN0IGN1cnJlbnRDaGVja2VkID0gdXNlUmVmKGNoZWNrZWQgPz8gbG9jYWxDaGVja2VkKTtcblxuICAgIGNvbnN0IGlzTm90QWxsb3dlZCA9IGRpc2FibGVkIHx8IGxvYWRpbmc7XG5cbiAgICBjdXJyZW50Q2hlY2tlZC5jdXJyZW50ID0gY2hlY2tlZCA/PyBsb2NhbENoZWNrZWQ7XG4gICAgY29uc3Qgc3dpdGNoRGVmYXVsdFN0eWxlID0gZ2V0U3dpdGNoRGVmYXVsdFN0eWxlKHtcbiAgICAgIHNpemUsXG4gICAgICBpc05vdEFsbG93ZWQsXG4gICAgICBjaGVja2VkOiBjdXJyZW50Q2hlY2tlZC5jdXJyZW50LFxuICAgICAgaXNNb3VzZURvd24sXG4gICAgfSk7XG5cbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgICAgaWYgKGlzSW5pdGlhbE1vdW50LmN1cnJlbnQpIHtcbiAgICAgICAgaXNJbml0aWFsTW91bnQuY3VycmVudCA9IGZhbHNlO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgb25DaGFuZ2U/LihjdXJyZW50Q2hlY2tlZC5jdXJyZW50KTtcbiAgICAgIH1cbiAgICB9LCBbY3VycmVudENoZWNrZWQuY3VycmVudF0pO1xuXG4gICAgY29uc3QgbW91c2VEb3duSGFuZGxlID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgICAgaWYgKGlzTm90QWxsb3dlZCkge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIHNldElzTW91c2VEb3duKHRydWUpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IG1vdXNlVXBIYW5kbGUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICBpZiAoaXNOb3RBbGxvd2VkKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgc2V0SXNNb3VzZURvd24oZmFsc2UpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IGhhbmRsZU1vdXNlTGVhdmUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICBpZiAoaXNOb3RBbGxvd2VkKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgc2V0SXNNb3VzZURvd24oZmFsc2UpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IGNsaWNrSGFuZGxlID0gdXNlQ2FsbGJhY2soXG4gICAgICAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICAgICAgaWYgKGlzTm90QWxsb3dlZCkge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChpc1VuZGVmaW5lZChjaGVja2VkKSkge1xuICAgICAgICAgIHNldExvY2FsQ2hlY2tlZCgocHJldikgPT4gIXByZXYpO1xuICAgICAgICB9XG5cbiAgICAgICAgb25DbGljaz8uKGN1cnJlbnRDaGVja2VkLmN1cnJlbnQsIGV2ZW50KTtcbiAgICAgIH0sXG4gICAgICBbY2hlY2tlZCwgaXNOb3RBbGxvd2VkLCBvbkNsaWNrXVxuICAgICk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgcm9sZT1cInN3aXRjaFwiXG4gICAgICAgIGNzcz17W3N3aXRjaERlZmF1bHRTdHlsZS53cmFwcGVyKHRoZW1lKSwgc3R5bGVzPy53cmFwcGVyKHRoZW1lKV19XG4gICAgICAgIG9uTW91c2VEb3duPXttb3VzZURvd25IYW5kbGV9XG4gICAgICAgIG9uTW91c2VVcD17bW91c2VVcEhhbmRsZX1cbiAgICAgICAgb25DbGljaz17Y2xpY2tIYW5kbGV9XG4gICAgICAgIG9uTW91c2VMZWF2ZT17aGFuZGxlTW91c2VMZWF2ZX1cbiAgICAgICAgYXV0b0ZvY3VzPXthdXRvRm9jdXN9XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICBhcmlhLWNoZWNrZWQ9e2N1cnJlbnRDaGVja2VkLmN1cnJlbnR9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICBhcmlhLWhpZGRlbj17ZmFsc2V9XG4gICAgICAgIHRlc3QtaWQ9e3Rlc3RJZCA/IHRlc3RJZCA6IGRlZmF1bHRTd2l0Y2hUZXN0SWR9XG4gICAgICA+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjc3M9e1tzd2l0Y2hEZWZhdWx0U3R5bGUuaGFuZGxlKHRoZW1lKSwgc3R5bGVzPy5oYW5kbGUodGhlbWUpXX1cbiAgICAgICAgICB0ZXN0LWlkPXt0ZXN0SWQgPyBgJHt0ZXN0SWR9JHtkZWZhdWx0SGFuZGxlVGVzdElkU3VmZml4fWAgOiBkZWZhdWx0SGFuZGxlVGVzdElkfVxuICAgICAgICA+XG4gICAgICAgICAge2xvYWRpbmcgJiYgPExvYWRpbmdPdXRsaW5lZCAvPn1cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2J1dHRvbj5cbiAgICApO1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3dpdGNoID0gd2l0aFRoZW1lUHJvdmlkZXI8U3dpdGNoUHJvcHM+KFN3aXRjaENvbXBvbmVudCk7XG4iXX0= */"], onMouseDown: mouseDownHandle, onMouseUp: mouseUpHandle, onClick: clickHandle, onMouseLeave: handleMouseLeave, autoFocus, className, "aria-checked": currentChecked.current, "aria-disabled": disabled, "aria-hidden": false, "test-id": testId ? testId : defaultSwitchTestId, children: /* @__PURE__ */ jsx("div", { css: [switchDefaultStyle.handle(theme), styles == null ? void 0 : styles.handle(theme), process.env.NODE_ENV === "production" ? "" : ";label:SwitchComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvU3dpdGNoL1N3aXRjaC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkdVIiwiZmlsZSI6Ii9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvU3dpdGNoL1N3aXRjaC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0eXBlIEZDLCBtZW1vLCB0eXBlIE1vdXNlRXZlbnQsIHVzZUNhbGxiYWNrLCB1c2VFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgU3dpdGNoUHJvcHMgfSBmcm9tIFwiLi9Td2l0Y2gudHlwZXNcIjtcbmltcG9ydCB7IExvYWRpbmdPdXRsaW5lZCB9IGZyb20gXCJpY29ucy9pY29uc1wiO1xuaW1wb3J0IHsgZ2V0U3dpdGNoRGVmYXVsdFN0eWxlIH0gZnJvbSBcIi4vU3dpdGNoLnN0eWxlc1wiO1xuaW1wb3J0IHsgdXNlVGhlbWUgfSBmcm9tIFwiaG9va3MvdXNlVGhlbWVcIjtcbmltcG9ydCB7IGlzVW5kZWZpbmVkIH0gZnJvbSBcImxvZGFzaC1lc1wiO1xuaW1wb3J0IHsgd2l0aFRoZW1lUHJvdmlkZXIgfSBmcm9tIFwiaG9jcy93aXRoVGhlbWVQcm92aWRlclwiO1xuaW1wb3J0IHtcbiAgZGVmYXVsdEhhbmRsZVRlc3RJZCxcbiAgZGVmYXVsdEhhbmRsZVRlc3RJZFN1ZmZpeCxcbiAgZGVmYXVsdFN3aXRjaFRlc3RJZCxcbn0gZnJvbSBcIi4vU3dpdGNoLnV0aWxzXCI7XG5cbmNvbnN0IFN3aXRjaENvbXBvbmVudDogRkM8U3dpdGNoUHJvcHM+ID0gbWVtbyhcbiAgKHtcbiAgICBhdXRvRm9jdXMsXG4gICAgbG9hZGluZyxcbiAgICBjaGVja2VkLFxuICAgIGRpc2FibGVkLFxuICAgIHNpemUsXG4gICAgc3R5bGVzLFxuICAgIGNsYXNzTmFtZSxcbiAgICBkZWZhdWx0Q2hlY2tlZCA9IGZhbHNlLFxuICAgIG9uQ2xpY2ssXG4gICAgb25DaGFuZ2UsXG4gICAgdGVzdElkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpO1xuXG4gICAgY29uc3QgW2xvY2FsQ2hlY2tlZCwgc2V0TG9jYWxDaGVja2VkXSA9IHVzZVN0YXRlKGRlZmF1bHRDaGVja2VkKTtcbiAgICBjb25zdCBbaXNNb3VzZURvd24sIHNldElzTW91c2VEb3duXSA9IHVzZVN0YXRlKGZhbHNlKTtcblxuICAgIGNvbnN0IGlzSW5pdGlhbE1vdW50ID0gdXNlUmVmKHRydWUpO1xuICAgIGNvbnN0IGN1cnJlbnRDaGVja2VkID0gdXNlUmVmKGNoZWNrZWQgPz8gbG9jYWxDaGVja2VkKTtcblxuICAgIGNvbnN0IGlzTm90QWxsb3dlZCA9IGRpc2FibGVkIHx8IGxvYWRpbmc7XG5cbiAgICBjdXJyZW50Q2hlY2tlZC5jdXJyZW50ID0gY2hlY2tlZCA/PyBsb2NhbENoZWNrZWQ7XG4gICAgY29uc3Qgc3dpdGNoRGVmYXVsdFN0eWxlID0gZ2V0U3dpdGNoRGVmYXVsdFN0eWxlKHtcbiAgICAgIHNpemUsXG4gICAgICBpc05vdEFsbG93ZWQsXG4gICAgICBjaGVja2VkOiBjdXJyZW50Q2hlY2tlZC5jdXJyZW50LFxuICAgICAgaXNNb3VzZURvd24sXG4gICAgfSk7XG5cbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgICAgaWYgKGlzSW5pdGlhbE1vdW50LmN1cnJlbnQpIHtcbiAgICAgICAgaXNJbml0aWFsTW91bnQuY3VycmVudCA9IGZhbHNlO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgb25DaGFuZ2U/LihjdXJyZW50Q2hlY2tlZC5jdXJyZW50KTtcbiAgICAgIH1cbiAgICB9LCBbY3VycmVudENoZWNrZWQuY3VycmVudF0pO1xuXG4gICAgY29uc3QgbW91c2VEb3duSGFuZGxlID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgICAgaWYgKGlzTm90QWxsb3dlZCkge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIHNldElzTW91c2VEb3duKHRydWUpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IG1vdXNlVXBIYW5kbGUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICBpZiAoaXNOb3RBbGxvd2VkKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgc2V0SXNNb3VzZURvd24oZmFsc2UpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IGhhbmRsZU1vdXNlTGVhdmUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICBpZiAoaXNOb3RBbGxvd2VkKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgc2V0SXNNb3VzZURvd24oZmFsc2UpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IGNsaWNrSGFuZGxlID0gdXNlQ2FsbGJhY2soXG4gICAgICAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICAgICAgaWYgKGlzTm90QWxsb3dlZCkge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChpc1VuZGVmaW5lZChjaGVja2VkKSkge1xuICAgICAgICAgIHNldExvY2FsQ2hlY2tlZCgocHJldikgPT4gIXByZXYpO1xuICAgICAgICB9XG5cbiAgICAgICAgb25DbGljaz8uKGN1cnJlbnRDaGVja2VkLmN1cnJlbnQsIGV2ZW50KTtcbiAgICAgIH0sXG4gICAgICBbY2hlY2tlZCwgaXNOb3RBbGxvd2VkLCBvbkNsaWNrXVxuICAgICk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgcm9sZT1cInN3aXRjaFwiXG4gICAgICAgIGNzcz17W3N3aXRjaERlZmF1bHRTdHlsZS53cmFwcGVyKHRoZW1lKSwgc3R5bGVzPy53cmFwcGVyKHRoZW1lKV19XG4gICAgICAgIG9uTW91c2VEb3duPXttb3VzZURvd25IYW5kbGV9XG4gICAgICAgIG9uTW91c2VVcD17bW91c2VVcEhhbmRsZX1cbiAgICAgICAgb25DbGljaz17Y2xpY2tIYW5kbGV9XG4gICAgICAgIG9uTW91c2VMZWF2ZT17aGFuZGxlTW91c2VMZWF2ZX1cbiAgICAgICAgYXV0b0ZvY3VzPXthdXRvRm9jdXN9XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICBhcmlhLWNoZWNrZWQ9e2N1cnJlbnRDaGVja2VkLmN1cnJlbnR9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICBhcmlhLWhpZGRlbj17ZmFsc2V9XG4gICAgICAgIHRlc3QtaWQ9e3Rlc3RJZCA/IHRlc3RJZCA6IGRlZmF1bHRTd2l0Y2hUZXN0SWR9XG4gICAgICA+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjc3M9e1tzd2l0Y2hEZWZhdWx0U3R5bGUuaGFuZGxlKHRoZW1lKSwgc3R5bGVzPy5oYW5kbGUodGhlbWUpXX1cbiAgICAgICAgICB0ZXN0LWlkPXt0ZXN0SWQgPyBgJHt0ZXN0SWR9JHtkZWZhdWx0SGFuZGxlVGVzdElkU3VmZml4fWAgOiBkZWZhdWx0SGFuZGxlVGVzdElkfVxuICAgICAgICA+XG4gICAgICAgICAge2xvYWRpbmcgJiYgPExvYWRpbmdPdXRsaW5lZCAvPn1cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2J1dHRvbj5cbiAgICApO1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3dpdGNoID0gd2l0aFRoZW1lUHJvdmlkZXI8U3dpdGNoUHJvcHM+KFN3aXRjaENvbXBvbmVudCk7XG4iXX0= */"], "test-id": testId ? `${testId}${defaultHandleTestIdSuffix}` : defaultHandleTestId, children: loading && /* @__PURE__ */ jsx(LoadingOutlined, {}) }) });
|
|
69
|
+
return /* @__PURE__ */ jsx("button", { type: "button", role: "switch", css: [switchDefaultStyle.wrapper(theme), styles == null ? void 0 : styles.wrapper(theme), process.env.NODE_ENV === "production" ? "" : ";label:SwitchComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvU3dpdGNoL1N3aXRjaC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0dRIiwiZmlsZSI6Ii9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvU3dpdGNoL1N3aXRjaC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICB0eXBlIEZDLFxuICBtZW1vLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHVzZUNhbGxiYWNrLFxuICB1c2VMYXlvdXRFZmZlY3QsXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBTd2l0Y2hQcm9wcyB9IGZyb20gXCIuL1N3aXRjaC50eXBlc1wiO1xuaW1wb3J0IHsgTG9hZGluZ091dGxpbmVkIH0gZnJvbSBcImljb25zL2ljb25zXCI7XG5pbXBvcnQgeyBnZXRTd2l0Y2hEZWZhdWx0U3R5bGUgfSBmcm9tIFwiLi9Td2l0Y2guc3R5bGVzXCI7XG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gXCJob29rcy91c2VUaGVtZVwiO1xuaW1wb3J0IHsgaXNVbmRlZmluZWQgfSBmcm9tIFwibG9kYXNoLWVzXCI7XG5pbXBvcnQgeyB3aXRoVGhlbWVQcm92aWRlciB9IGZyb20gXCJob2NzL3dpdGhUaGVtZVByb3ZpZGVyXCI7XG5pbXBvcnQge1xuICBkZWZhdWx0SGFuZGxlVGVzdElkLFxuICBkZWZhdWx0SGFuZGxlVGVzdElkU3VmZml4LFxuICBkZWZhdWx0U3dpdGNoVGVzdElkLFxufSBmcm9tIFwiLi9Td2l0Y2gudXRpbHNcIjtcblxuY29uc3QgU3dpdGNoQ29tcG9uZW50OiBGQzxTd2l0Y2hQcm9wcz4gPSBtZW1vKFxuICAoe1xuICAgIGF1dG9Gb2N1cyxcbiAgICBsb2FkaW5nLFxuICAgIGNoZWNrZWQsXG4gICAgZGlzYWJsZWQsXG4gICAgc2l6ZSxcbiAgICBzdHlsZXMsXG4gICAgY2xhc3NOYW1lLFxuICAgIGRlZmF1bHRDaGVja2VkID0gZmFsc2UsXG4gICAgb25DbGljayxcbiAgICBvbkNoYW5nZSxcbiAgICBcInRlc3QtaWRcIjogdGVzdElkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpO1xuXG4gICAgY29uc3QgW2xvY2FsQ2hlY2tlZCwgc2V0TG9jYWxDaGVja2VkXSA9IHVzZVN0YXRlKGRlZmF1bHRDaGVja2VkKTtcbiAgICBjb25zdCBbaXNNb3VzZURvd24sIHNldElzTW91c2VEb3duXSA9IHVzZVN0YXRlKGZhbHNlKTtcblxuICAgIGNvbnN0IGlzSW5pdGlhbE1vdW50ID0gdXNlUmVmKHRydWUpO1xuICAgIGNvbnN0IGN1cnJlbnRDaGVja2VkID0gdXNlUmVmKGNoZWNrZWQgPz8gbG9jYWxDaGVja2VkKTtcblxuICAgIGNvbnN0IGlzTm90QWxsb3dlZCA9IGRpc2FibGVkIHx8IGxvYWRpbmc7XG5cbiAgICBjdXJyZW50Q2hlY2tlZC5jdXJyZW50ID0gY2hlY2tlZCA/PyBsb2NhbENoZWNrZWQ7XG4gICAgY29uc3Qgc3dpdGNoRGVmYXVsdFN0eWxlID0gZ2V0U3dpdGNoRGVmYXVsdFN0eWxlKHtcbiAgICAgIHNpemUsXG4gICAgICBpc05vdEFsbG93ZWQsXG4gICAgICBjaGVja2VkOiBjdXJyZW50Q2hlY2tlZC5jdXJyZW50LFxuICAgICAgaXNNb3VzZURvd24sXG4gICAgfSk7XG5cbiAgICB1c2VMYXlvdXRFZmZlY3QoKCkgPT4ge1xuICAgICAgaWYgKGlzSW5pdGlhbE1vdW50LmN1cnJlbnQpIHtcbiAgICAgICAgaXNJbml0aWFsTW91bnQuY3VycmVudCA9IGZhbHNlO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgb25DaGFuZ2U/LihjdXJyZW50Q2hlY2tlZC5jdXJyZW50KTtcbiAgICAgIH1cbiAgICB9LCBbY3VycmVudENoZWNrZWQuY3VycmVudF0pO1xuXG4gICAgY29uc3QgbW91c2VEb3duSGFuZGxlID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgICAgaWYgKGlzTm90QWxsb3dlZCkge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIHNldElzTW91c2VEb3duKHRydWUpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IG1vdXNlVXBIYW5kbGUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICBpZiAoaXNOb3RBbGxvd2VkKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgc2V0SXNNb3VzZURvd24oZmFsc2UpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IGhhbmRsZU1vdXNlTGVhdmUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICBpZiAoaXNOb3RBbGxvd2VkKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgc2V0SXNNb3VzZURvd24oZmFsc2UpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IGNsaWNrSGFuZGxlID0gdXNlQ2FsbGJhY2soXG4gICAgICAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICAgICAgaWYgKGlzTm90QWxsb3dlZCkge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChpc1VuZGVmaW5lZChjaGVja2VkKSkge1xuICAgICAgICAgIHNldExvY2FsQ2hlY2tlZCgocHJldikgPT4gIXByZXYpO1xuICAgICAgICB9XG5cbiAgICAgICAgb25DbGljaz8uKGN1cnJlbnRDaGVja2VkLmN1cnJlbnQsIGV2ZW50KTtcbiAgICAgIH0sXG4gICAgICBbY2hlY2tlZCwgaXNOb3RBbGxvd2VkLCBvbkNsaWNrXVxuICAgICk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgcm9sZT1cInN3aXRjaFwiXG4gICAgICAgIGNzcz17W3N3aXRjaERlZmF1bHRTdHlsZS53cmFwcGVyKHRoZW1lKSwgc3R5bGVzPy53cmFwcGVyKHRoZW1lKV19XG4gICAgICAgIG9uTW91c2VEb3duPXttb3VzZURvd25IYW5kbGV9XG4gICAgICAgIG9uTW91c2VVcD17bW91c2VVcEhhbmRsZX1cbiAgICAgICAgb25DbGljaz17Y2xpY2tIYW5kbGV9XG4gICAgICAgIG9uTW91c2VMZWF2ZT17aGFuZGxlTW91c2VMZWF2ZX1cbiAgICAgICAgYXV0b0ZvY3VzPXthdXRvRm9jdXN9XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICBhcmlhLWNoZWNrZWQ9e2N1cnJlbnRDaGVja2VkLmN1cnJlbnR9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICBhcmlhLWhpZGRlbj17ZmFsc2V9XG4gICAgICAgIHRlc3QtaWQ9e3Rlc3RJZCA/IHRlc3RJZCA6IGRlZmF1bHRTd2l0Y2hUZXN0SWR9XG4gICAgICA+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjc3M9e1tzd2l0Y2hEZWZhdWx0U3R5bGUuaGFuZGxlKHRoZW1lKSwgc3R5bGVzPy5oYW5kbGUodGhlbWUpXX1cbiAgICAgICAgICB0ZXN0LWlkPXt0ZXN0SWQgPyBgJHt0ZXN0SWR9JHtkZWZhdWx0SGFuZGxlVGVzdElkU3VmZml4fWAgOiBkZWZhdWx0SGFuZGxlVGVzdElkfVxuICAgICAgICA+XG4gICAgICAgICAge2xvYWRpbmcgJiYgPExvYWRpbmdPdXRsaW5lZCAvPn1cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2J1dHRvbj5cbiAgICApO1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3dpdGNoID0gd2l0aFRoZW1lUHJvdmlkZXI8U3dpdGNoUHJvcHM+KFN3aXRjaENvbXBvbmVudCk7XG4iXX0= */"], onMouseDown: mouseDownHandle, onMouseUp: mouseUpHandle, onClick: clickHandle, onMouseLeave: handleMouseLeave, autoFocus, className, "aria-checked": currentChecked.current, "aria-disabled": disabled, "aria-hidden": false, "test-id": testId ? testId : defaultSwitchTestId, children: /* @__PURE__ */ jsx("div", { css: [switchDefaultStyle.handle(theme), styles == null ? void 0 : styles.handle(theme), process.env.NODE_ENV === "production" ? "" : ";label:SwitchComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvU3dpdGNoL1N3aXRjaC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUhVIiwiZmlsZSI6Ii9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvU3dpdGNoL1N3aXRjaC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICB0eXBlIEZDLFxuICBtZW1vLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHVzZUNhbGxiYWNrLFxuICB1c2VMYXlvdXRFZmZlY3QsXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBTd2l0Y2hQcm9wcyB9IGZyb20gXCIuL1N3aXRjaC50eXBlc1wiO1xuaW1wb3J0IHsgTG9hZGluZ091dGxpbmVkIH0gZnJvbSBcImljb25zL2ljb25zXCI7XG5pbXBvcnQgeyBnZXRTd2l0Y2hEZWZhdWx0U3R5bGUgfSBmcm9tIFwiLi9Td2l0Y2guc3R5bGVzXCI7XG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gXCJob29rcy91c2VUaGVtZVwiO1xuaW1wb3J0IHsgaXNVbmRlZmluZWQgfSBmcm9tIFwibG9kYXNoLWVzXCI7XG5pbXBvcnQgeyB3aXRoVGhlbWVQcm92aWRlciB9IGZyb20gXCJob2NzL3dpdGhUaGVtZVByb3ZpZGVyXCI7XG5pbXBvcnQge1xuICBkZWZhdWx0SGFuZGxlVGVzdElkLFxuICBkZWZhdWx0SGFuZGxlVGVzdElkU3VmZml4LFxuICBkZWZhdWx0U3dpdGNoVGVzdElkLFxufSBmcm9tIFwiLi9Td2l0Y2gudXRpbHNcIjtcblxuY29uc3QgU3dpdGNoQ29tcG9uZW50OiBGQzxTd2l0Y2hQcm9wcz4gPSBtZW1vKFxuICAoe1xuICAgIGF1dG9Gb2N1cyxcbiAgICBsb2FkaW5nLFxuICAgIGNoZWNrZWQsXG4gICAgZGlzYWJsZWQsXG4gICAgc2l6ZSxcbiAgICBzdHlsZXMsXG4gICAgY2xhc3NOYW1lLFxuICAgIGRlZmF1bHRDaGVja2VkID0gZmFsc2UsXG4gICAgb25DbGljayxcbiAgICBvbkNoYW5nZSxcbiAgICBcInRlc3QtaWRcIjogdGVzdElkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpO1xuXG4gICAgY29uc3QgW2xvY2FsQ2hlY2tlZCwgc2V0TG9jYWxDaGVja2VkXSA9IHVzZVN0YXRlKGRlZmF1bHRDaGVja2VkKTtcbiAgICBjb25zdCBbaXNNb3VzZURvd24sIHNldElzTW91c2VEb3duXSA9IHVzZVN0YXRlKGZhbHNlKTtcblxuICAgIGNvbnN0IGlzSW5pdGlhbE1vdW50ID0gdXNlUmVmKHRydWUpO1xuICAgIGNvbnN0IGN1cnJlbnRDaGVja2VkID0gdXNlUmVmKGNoZWNrZWQgPz8gbG9jYWxDaGVja2VkKTtcblxuICAgIGNvbnN0IGlzTm90QWxsb3dlZCA9IGRpc2FibGVkIHx8IGxvYWRpbmc7XG5cbiAgICBjdXJyZW50Q2hlY2tlZC5jdXJyZW50ID0gY2hlY2tlZCA/PyBsb2NhbENoZWNrZWQ7XG4gICAgY29uc3Qgc3dpdGNoRGVmYXVsdFN0eWxlID0gZ2V0U3dpdGNoRGVmYXVsdFN0eWxlKHtcbiAgICAgIHNpemUsXG4gICAgICBpc05vdEFsbG93ZWQsXG4gICAgICBjaGVja2VkOiBjdXJyZW50Q2hlY2tlZC5jdXJyZW50LFxuICAgICAgaXNNb3VzZURvd24sXG4gICAgfSk7XG5cbiAgICB1c2VMYXlvdXRFZmZlY3QoKCkgPT4ge1xuICAgICAgaWYgKGlzSW5pdGlhbE1vdW50LmN1cnJlbnQpIHtcbiAgICAgICAgaXNJbml0aWFsTW91bnQuY3VycmVudCA9IGZhbHNlO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgb25DaGFuZ2U/LihjdXJyZW50Q2hlY2tlZC5jdXJyZW50KTtcbiAgICAgIH1cbiAgICB9LCBbY3VycmVudENoZWNrZWQuY3VycmVudF0pO1xuXG4gICAgY29uc3QgbW91c2VEb3duSGFuZGxlID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgICAgaWYgKGlzTm90QWxsb3dlZCkge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIHNldElzTW91c2VEb3duKHRydWUpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IG1vdXNlVXBIYW5kbGUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICBpZiAoaXNOb3RBbGxvd2VkKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgc2V0SXNNb3VzZURvd24oZmFsc2UpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IGhhbmRsZU1vdXNlTGVhdmUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICBpZiAoaXNOb3RBbGxvd2VkKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgc2V0SXNNb3VzZURvd24oZmFsc2UpO1xuICAgIH0sIFtpc05vdEFsbG93ZWRdKTtcblxuICAgIGNvbnN0IGNsaWNrSGFuZGxlID0gdXNlQ2FsbGJhY2soXG4gICAgICAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICAgICAgaWYgKGlzTm90QWxsb3dlZCkge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChpc1VuZGVmaW5lZChjaGVja2VkKSkge1xuICAgICAgICAgIHNldExvY2FsQ2hlY2tlZCgocHJldikgPT4gIXByZXYpO1xuICAgICAgICB9XG5cbiAgICAgICAgb25DbGljaz8uKGN1cnJlbnRDaGVja2VkLmN1cnJlbnQsIGV2ZW50KTtcbiAgICAgIH0sXG4gICAgICBbY2hlY2tlZCwgaXNOb3RBbGxvd2VkLCBvbkNsaWNrXVxuICAgICk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgcm9sZT1cInN3aXRjaFwiXG4gICAgICAgIGNzcz17W3N3aXRjaERlZmF1bHRTdHlsZS53cmFwcGVyKHRoZW1lKSwgc3R5bGVzPy53cmFwcGVyKHRoZW1lKV19XG4gICAgICAgIG9uTW91c2VEb3duPXttb3VzZURvd25IYW5kbGV9XG4gICAgICAgIG9uTW91c2VVcD17bW91c2VVcEhhbmRsZX1cbiAgICAgICAgb25DbGljaz17Y2xpY2tIYW5kbGV9XG4gICAgICAgIG9uTW91c2VMZWF2ZT17aGFuZGxlTW91c2VMZWF2ZX1cbiAgICAgICAgYXV0b0ZvY3VzPXthdXRvRm9jdXN9XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICBhcmlhLWNoZWNrZWQ9e2N1cnJlbnRDaGVja2VkLmN1cnJlbnR9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICBhcmlhLWhpZGRlbj17ZmFsc2V9XG4gICAgICAgIHRlc3QtaWQ9e3Rlc3RJZCA/IHRlc3RJZCA6IGRlZmF1bHRTd2l0Y2hUZXN0SWR9XG4gICAgICA+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjc3M9e1tzd2l0Y2hEZWZhdWx0U3R5bGUuaGFuZGxlKHRoZW1lKSwgc3R5bGVzPy5oYW5kbGUodGhlbWUpXX1cbiAgICAgICAgICB0ZXN0LWlkPXt0ZXN0SWQgPyBgJHt0ZXN0SWR9JHtkZWZhdWx0SGFuZGxlVGVzdElkU3VmZml4fWAgOiBkZWZhdWx0SGFuZGxlVGVzdElkfVxuICAgICAgICA+XG4gICAgICAgICAge2xvYWRpbmcgJiYgPExvYWRpbmdPdXRsaW5lZCAvPn1cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2J1dHRvbj5cbiAgICApO1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3dpdGNoID0gd2l0aFRoZW1lUHJvdmlkZXI8U3dpdGNoUHJvcHM+KFN3aXRjaENvbXBvbmVudCk7XG4iXX0= */"], "test-id": testId ? `${testId}${defaultHandleTestIdSuffix}` : defaultHandleTestId, children: loading && /* @__PURE__ */ jsx(LoadingOutlined, {}) }) });
|
|
70
70
|
});
|
|
71
71
|
const Switch = withThemeProvider(SwitchComponent);
|
|
72
72
|
export {
|
|
@@ -36,6 +36,11 @@ const getSwitchDefaultStyle = ({
|
|
|
36
36
|
const switchTokens = getSwitchTokens(theme);
|
|
37
37
|
const handleWidth = isDefaultSize ? switchTokens.switchHandleSize : switchTokens.switchHandleSizeS;
|
|
38
38
|
const switchingHandleWidth = isDefaultSize ? switchTokens.switchHandleWidthPressed : switchTokens.switchHandleWidthPressedS;
|
|
39
|
+
const paddingCorrection = switchTokens.switchTrackPadding * 2;
|
|
40
|
+
const trackWidth = isDefaultSize ? switchTokens.switchTrackWidth : switchTokens.switchTrackWidthS;
|
|
41
|
+
const checkedLeftPosition = trackWidth - handleWidth - paddingCorrection;
|
|
42
|
+
const leftPosition = checked ? checkedLeftPosition : 0;
|
|
43
|
+
const switchingLeftPosition = trackWidth - switchingHandleWidth - paddingCorrection;
|
|
39
44
|
return {
|
|
40
45
|
height: isDefaultSize ? switchTokens.switchHandleSize : switchTokens.switchHandleSizeS,
|
|
41
46
|
width: isMouseDown ? switchingHandleWidth : handleWidth,
|
|
@@ -44,15 +49,14 @@ const getSwitchDefaultStyle = ({
|
|
|
44
49
|
color: checked ? switchTokens.switchBgChecked : switchTokens.switchBg,
|
|
45
50
|
fontSize: isDefaultSize ? theme.x3 : theme.x2,
|
|
46
51
|
padding: theme.x1,
|
|
47
|
-
left: checked ?
|
|
48
|
-
transform: `translateX(${checked ? "-100%" : 0})`,
|
|
52
|
+
left: isMouseDown && checked ? switchingLeftPosition : leftPosition,
|
|
49
53
|
position: "relative",
|
|
50
54
|
boxShadow: switchTokens.switchHandleShadow,
|
|
51
55
|
display: "flex",
|
|
52
56
|
justifyContent: "center",
|
|
53
57
|
alignItems: "center",
|
|
54
58
|
boxSizing: "border-box",
|
|
55
|
-
transition: `width ${ANIMATION_DURATION}ms, left ${ANIMATION_DURATION}ms
|
|
59
|
+
transition: `width ${ANIMATION_DURATION}ms, left ${ANIMATION_DURATION}ms`
|
|
56
60
|
};
|
|
57
61
|
}
|
|
58
62
|
};
|
|
@@ -16,7 +16,7 @@ export interface SwitchProps {
|
|
|
16
16
|
wrapper: (theme: Theme) => Interpolation;
|
|
17
17
|
handle: (theme: Theme) => Interpolation;
|
|
18
18
|
};
|
|
19
|
-
|
|
19
|
+
["test-id"]?: string;
|
|
20
20
|
}
|
|
21
21
|
export type SwitchDefaultStylesProps = Pick<SwitchProps, "checked" | "size"> & {
|
|
22
22
|
isMouseDown: boolean;
|
|
@@ -8,7 +8,7 @@ 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,
|
|
11
|
+
import { isNil, isBoolean, isUndefined } from "lodash-es";
|
|
12
12
|
import { getTableComponentWrapperStyle, getTableComponentStyle, tableStyle } from "./Table.styles.js";
|
|
13
13
|
import { getTableTokens } from "./Table.tokens.js";
|
|
14
14
|
import { usePrevious } from "../../hooks/usePrevious.js";
|
|
@@ -22,13 +22,14 @@ import { useTableExpand } from "./features/tableExpand/hooks/useTableExpand/useT
|
|
|
22
22
|
import { useTableSort } from "./features/tableSort/hooks/useTableSort/useTableSort.js";
|
|
23
23
|
import { useTableRowSelection } from "./features/tableRowSelection/hooks/useTableRowSelection/useTableRowSelection.js";
|
|
24
24
|
import { useTableVisualParamsChange } from "./hooks/useTableVisualParamsChange/useTableVisualParamsChange.js";
|
|
25
|
+
import { useTableBordered } from "./hooks/useTableBordered/useTableBordered.js";
|
|
25
26
|
import { updateRefValue } from "./utils/ref/ref.js";
|
|
26
27
|
import { TableRowSelectionContext } from "./features/tableRowSelection/contexts/tableRowSelectionContext/TableRowSelectionContext.js";
|
|
27
28
|
import { Spin } from "../Spin/Spin.js";
|
|
28
29
|
import { defaultSortDirections } from "./features/tableSort/utils/const.js";
|
|
29
30
|
import { createTableContext } from "./contexts/tableContext/TableContext.js";
|
|
30
31
|
const TableComponent = (props, ref) => {
|
|
31
|
-
var _a, _b, _c;
|
|
32
|
+
var _a, _b, _c, _d;
|
|
32
33
|
const {
|
|
33
34
|
columns: columnsProp,
|
|
34
35
|
dataSource,
|
|
@@ -41,6 +42,7 @@ const TableComponent = (props, ref) => {
|
|
|
41
42
|
loading = false,
|
|
42
43
|
tableLayout: tableLayoutProp,
|
|
43
44
|
bordered: borderedProp,
|
|
45
|
+
rowHoverable = true,
|
|
44
46
|
styles,
|
|
45
47
|
footer,
|
|
46
48
|
onHeaderRow,
|
|
@@ -86,7 +88,6 @@ const TableComponent = (props, ref) => {
|
|
|
86
88
|
const {
|
|
87
89
|
sortState,
|
|
88
90
|
sortedData,
|
|
89
|
-
hasData,
|
|
90
91
|
triggerSorter
|
|
91
92
|
} = useTableSort({
|
|
92
93
|
dataSource,
|
|
@@ -136,21 +137,11 @@ const TableComponent = (props, ref) => {
|
|
|
136
137
|
}
|
|
137
138
|
return "auto";
|
|
138
139
|
}, [fixColumn, fixHeader, flattedColumns, scrollX, tableLayoutProp]);
|
|
139
|
-
const
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
firstColumnCellInlineStart: true,
|
|
145
|
-
lastColumnCellInlineEnd: true
|
|
146
|
-
};
|
|
147
|
-
return {
|
|
148
|
-
...defaultBorderedConfig,
|
|
149
|
-
...isObject(borderedProp) ? borderedProp : {}
|
|
150
|
-
};
|
|
151
|
-
}
|
|
152
|
-
return borderedProp;
|
|
153
|
-
}, [borderedProp]);
|
|
140
|
+
const {
|
|
141
|
+
bordered
|
|
142
|
+
} = useTableBordered({
|
|
143
|
+
bordered: borderedProp
|
|
144
|
+
});
|
|
154
145
|
const TableContext = useStatic(() => createTableContext());
|
|
155
146
|
const tableContextValue = useMemo(() => {
|
|
156
147
|
return {
|
|
@@ -168,10 +159,11 @@ const TableComponent = (props, ref) => {
|
|
|
168
159
|
onHeaderRow,
|
|
169
160
|
onRow,
|
|
170
161
|
tableLayout,
|
|
162
|
+
rowHoverable,
|
|
171
163
|
bordered,
|
|
172
164
|
horizonScroll
|
|
173
165
|
};
|
|
174
|
-
}, [ExpandIcon, bordered, columns, expandIconColumnIndex, flattedColumns, getComponent, horizonScroll, indentSize, isAllColumnsFixedStart, isSomeRecordHasChildren, onHeaderRow, onRow, showHeader, sortDirections, tableLayout, tableTokens]);
|
|
166
|
+
}, [ExpandIcon, bordered, columns, expandIconColumnIndex, flattedColumns, getComponent, horizonScroll, indentSize, isAllColumnsFixedStart, isSomeRecordHasChildren, onHeaderRow, onRow, rowHoverable, showHeader, sortDirections, tableLayout, tableTokens]);
|
|
175
167
|
const tableRowSelectionContextValue = useMemo(() => {
|
|
176
168
|
return {
|
|
177
169
|
keySet,
|
|
@@ -208,11 +200,11 @@ const TableComponent = (props, ref) => {
|
|
|
208
200
|
const bodyTable = /* @__PURE__ */ jsx(Body, { expandable, sortedData, needMeasureColumnWidth: fixHeader || fixColumn, renderNullifyBody: isUndefined(dataSource), spinning: spinProps.spinning });
|
|
209
201
|
const groupTableNode = fixHeader ? /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
210
202
|
showHeader && /* @__PURE__ */ jsx(FixedHeader, { ref: tableHeaderRef, scrollX, onScroll: onTableHeaderScroll }),
|
|
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: [
|
|
203
|
+
/* @__PURE__ */ jsx("div", { className: "ui-kit-table-body", css: [getTableComponentWrapperStyle("body", fixHeader, 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, useCallback } from \"react\";\nimport type { 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, 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\";\nimport { useTableBordered } from \"./hooks/useTableBordered\";\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    rowHoverable = true,\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, 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 } = useTableBordered({ bordered: 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      rowHoverable,\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    rowHoverable,\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=\"ui-kit-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, 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=\"ui-kit-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent\n        css={[\n          getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll),\n          styles?.tableContentComponent?.(tableTokens, theme),\n        ]}\n      >\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=\"ui-kit-table\"\n              css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}\n            >\n              <div\n                ref={ref}\n                className=\"ui-kit-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: [
|
|
212
204
|
bodyColGroup,
|
|
213
205
|
bodyTable
|
|
214
206
|
] }) })
|
|
215
|
-
] }) : /* @__PURE__ */ jsx("div", { className: "rc-table-content", css: getTableComponentWrapperStyle("content", fixHeader, hasData, scrollY, horizonScroll), onScroll: onTableContentScroll, ref: scrollableTableSectionRef, children: /* @__PURE__ */ jsxs(TableComponent2, { css: getTableComponentStyle("content", tableLayout, scrollX, horizonScroll), children: [
|
|
207
|
+
] }) : /* @__PURE__ */ jsx("div", { className: "ui-kit-table-content", css: getTableComponentWrapperStyle("content", fixHeader, scrollY, horizonScroll), onScroll: onTableContentScroll, ref: scrollableTableSectionRef, children: /* @__PURE__ */ jsxs(TableComponent2, { css: [getTableComponentStyle("content", tableLayout, scrollX, horizonScroll), (_b = styles == null ? void 0 : styles.tableContentComponent) == null ? void 0 : _b.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":"AA2QQ","file":"/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx","sourcesContent":["import { forwardRef, memo, useMemo, type ForwardedRef, useCallback } from \"react\";\nimport type { 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, 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\";\nimport { useTableBordered } from \"./hooks/useTableBordered\";\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    rowHoverable = true,\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, 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 } = useTableBordered({ bordered: 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      rowHoverable,\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    rowHoverable,\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=\"ui-kit-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, 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=\"ui-kit-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent\n        css={[\n          getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll),\n          styles?.tableContentComponent?.(tableTokens, theme),\n        ]}\n      >\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=\"ui-kit-table\"\n              css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}\n            >\n              <div\n                ref={ref}\n                className=\"ui-kit-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: [
|
|
216
208
|
bodyColGroup,
|
|
217
209
|
showHeader && /* @__PURE__ */ jsx(Header, {}),
|
|
218
210
|
bodyTable
|
|
@@ -223,8 +215,8 @@ const TableComponent = (props, ref) => {
|
|
|
223
215
|
onResize(size, element);
|
|
224
216
|
}
|
|
225
217
|
}, [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: [
|
|
227
|
-
/* @__PURE__ */ jsx("div", { ref, className: "
|
|
218
|
+
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: "ui-kit-table", css: [tableStyle(theme), (_c = styles == null ? void 0 : styles.table) == null ? void 0 : _c.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":"AAySc","file":"/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx","sourcesContent":["import { forwardRef, memo, useMemo, type ForwardedRef, useCallback } from \"react\";\nimport type { 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, 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\";\nimport { useTableBordered } from \"./hooks/useTableBordered\";\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    rowHoverable = true,\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, 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 } = useTableBordered({ bordered: 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      rowHoverable,\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    rowHoverable,\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=\"ui-kit-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, 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=\"ui-kit-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent\n        css={[\n          getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll),\n          styles?.tableContentComponent?.(tableTokens, theme),\n        ]}\n      >\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=\"ui-kit-table\"\n              css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}\n            >\n              <div\n                ref={ref}\n                className=\"ui-kit-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: [
|
|
219
|
+
/* @__PURE__ */ jsx("div", { ref, className: "ui-kit-table-container", css: (_d = styles == null ? void 0 : styles.tableContainer) == null ? void 0 : _d.call(styles, tableTokens, theme), children: groupTableNode }),
|
|
228
220
|
footer && /* @__PURE__ */ jsx(FooterWrapper, { footer, sortedData })
|
|
229
221
|
] }) }) }) }) });
|
|
230
222
|
};
|
|
@@ -9,4 +9,4 @@ export declare const tableStyle: (theme: Theme) => {
|
|
|
9
9
|
};
|
|
10
10
|
export declare const getTableComponentStyle: <T extends "header" | "body" | "content">(type: T, tableLayout: TableLayout, scrollX: NonNullable<TableProps["scroll"]>["x"], horizonScroll: T extends "header" ? undefined : boolean) => CSSObject[];
|
|
11
11
|
export declare function getTableComponentWrapperStyle(type: "header"): CSSObject | CSSObject[];
|
|
12
|
-
export declare function getTableComponentWrapperStyle(type: "body" | "content", fixHeader: boolean,
|
|
12
|
+
export declare function getTableComponentWrapperStyle(type: "body" | "content", fixHeader: boolean, scrollY: NonNullable<TableProps["scroll"]>["y"], horizonScroll: boolean): CSSObject | CSSObject[];
|
|
@@ -31,7 +31,7 @@ const getTableComponentStyle = (type, tableLayout, scrollX, horizonScroll) => {
|
|
|
31
31
|
}
|
|
32
32
|
return styles;
|
|
33
33
|
};
|
|
34
|
-
function getTableComponentWrapperStyle(type, fixHeader,
|
|
34
|
+
function getTableComponentWrapperStyle(type, fixHeader, scrollY, horizonScroll) {
|
|
35
35
|
if (type === "header") {
|
|
36
36
|
return {
|
|
37
37
|
overflow: "hidden"
|
|
@@ -45,7 +45,7 @@ function getTableComponentWrapperStyle(type, fixHeader, hasData, scrollY, horizo
|
|
|
45
45
|
}
|
|
46
46
|
if (fixHeader) {
|
|
47
47
|
styles.push({
|
|
48
|
-
overflowY:
|
|
48
|
+
overflowY: "auto",
|
|
49
49
|
maxHeight: scrollY
|
|
50
50
|
});
|
|
51
51
|
} else if (horizonScroll) {
|
|
@@ -1,19 +1,32 @@
|
|
|
1
|
-
import { ComponentProps, CSSProperties, ReactNode
|
|
1
|
+
import { ComponentProps, CSSProperties, ReactNode } from 'react';
|
|
2
2
|
import { GetComponentProps, TableComponents } from './interfaces/tableComponents.types';
|
|
3
3
|
import { Column, Columns } from './interfaces/tableColumns.types';
|
|
4
4
|
import { SortOrder, SorterResult } from './features/tableSort';
|
|
5
5
|
import { TableRowSelection } from './features/tableRowSelection';
|
|
6
6
|
import { ExpandableConfig } from './features/tableExpand';
|
|
7
|
-
import { Theme } from 'themes';
|
|
7
|
+
import { Theme } from '../../themes';
|
|
8
8
|
import { Interpolation } from '@emotion/react';
|
|
9
9
|
import { TableTokens } from './Table.tokens';
|
|
10
10
|
import { SpinProps } from 'components/Spin';
|
|
11
|
+
import { ScrollParams } from './hooks/useTableVisualParamsChange';
|
|
11
12
|
export type Key = string | number;
|
|
13
|
+
export interface Bordered {
|
|
14
|
+
baseBorder: boolean;
|
|
15
|
+
firstColumnCellInlineStart: boolean;
|
|
16
|
+
lastColumnCellInlineEnd: boolean;
|
|
17
|
+
emptyInline: boolean;
|
|
18
|
+
emptyBlockEnd: boolean;
|
|
19
|
+
}
|
|
12
20
|
export interface BorderedConfig {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
21
|
+
table?: boolean | {
|
|
22
|
+
baseBorder?: boolean;
|
|
23
|
+
firstColumnCellInlineStart?: boolean;
|
|
24
|
+
lastColumnCellInlineEnd?: boolean;
|
|
25
|
+
};
|
|
26
|
+
empty?: boolean | {
|
|
27
|
+
inline?: boolean;
|
|
28
|
+
blockEnd?: boolean;
|
|
29
|
+
};
|
|
17
30
|
}
|
|
18
31
|
type GetStyle = (tableTokens: TableTokens, theme: Theme) => Interpolation;
|
|
19
32
|
export interface DefaultRecord<R extends DefaultRecord<R> = any> extends Record<string | number | symbol, any> {
|
|
@@ -35,19 +48,24 @@ export interface TableProps<Record extends DefaultRecord | null = DefaultRecord>
|
|
|
35
48
|
x?: CSSProperties["width"] | true;
|
|
36
49
|
y?: CSSProperties["maxHeight"];
|
|
37
50
|
};
|
|
51
|
+
/** @default true */
|
|
38
52
|
showHeader?: boolean;
|
|
39
|
-
onScroll?:
|
|
53
|
+
onScroll?: (params: ScrollParams) => void;
|
|
40
54
|
bordered?: boolean | BorderedConfig;
|
|
41
55
|
styles?: {
|
|
42
56
|
table?: GetStyle;
|
|
43
57
|
tableContainer?: GetStyle;
|
|
44
58
|
tableBodyComponentWrapper?: GetStyle;
|
|
59
|
+
tableContentComponent?: GetStyle;
|
|
45
60
|
};
|
|
46
61
|
footer?: (data: readonly Record[], info: {
|
|
47
62
|
verticalScrollBarWidth: number;
|
|
48
63
|
hasHorizontalScroll: boolean;
|
|
49
64
|
}) => ReactNode;
|
|
65
|
+
/** @default false */
|
|
50
66
|
loading?: boolean | Omit<SpinProps, "children" | "fullscreen">;
|
|
67
|
+
/** @default true */
|
|
68
|
+
rowHoverable?: boolean;
|
|
51
69
|
}
|
|
52
70
|
export type TableLayout = "auto" | "fixed";
|
|
53
71
|
export {};
|
|
@@ -58,7 +58,7 @@ const BodyComponent = (props) => {
|
|
|
58
58
|
}
|
|
59
59
|
return /* @__PURE__ */ jsx(EmptyDataRow, {});
|
|
60
60
|
})();
|
|
61
|
-
return /* @__PURE__ */ jsx(TableExpandedContext.Provider, { value: tableExpandedContextValue, children: /* @__PURE__ */ jsxs(BodyWrapperComponent, { css: tBodyStyle(theme), className: "
|
|
61
|
+
return /* @__PURE__ */ jsx(TableExpandedContext.Provider, { value: tableExpandedContextValue, children: /* @__PURE__ */ jsxs(BodyWrapperComponent, { css: tBodyStyle(theme), className: "ui-kit-table-tbody", children: [
|
|
62
62
|
needMeasureColumnWidth && /* @__PURE__ */ jsx(MeasureRow, {}),
|
|
63
63
|
rows
|
|
64
64
|
] }) });
|
|
@@ -37,7 +37,8 @@ const BodyCellComponent = (props) => {
|
|
|
37
37
|
expandIconColumnIndex,
|
|
38
38
|
bordered,
|
|
39
39
|
tableTokens,
|
|
40
|
-
showHeader
|
|
40
|
+
showHeader,
|
|
41
|
+
rowHoverable
|
|
41
42
|
} = useTableContext();
|
|
42
43
|
const staticContextRef = useTableStaticContext();
|
|
43
44
|
const {
|
|
@@ -104,7 +105,7 @@ const BodyCellComponent = (props) => {
|
|
|
104
105
|
prefixNode,
|
|
105
106
|
children
|
|
106
107
|
] }), [CellInnerWrapper, children, indentSize, intent, prefixNode, theme]);
|
|
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({
|
|
108
|
+
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.baseBorder ? getBorderedBodyCellStyle(bordered) : void 0, bordered.baseBorder && !showHeader ? nonHeaderBorderedBodyCellStyle(tableTokens) : void 0, ...getFixedCellStyle({
|
|
108
109
|
columnKey: column.key,
|
|
109
110
|
isFixStart,
|
|
110
111
|
isFixEnd,
|
|
@@ -115,7 +116,7 @@ const BodyCellComponent = (props) => {
|
|
|
115
116
|
fixedEndShadow,
|
|
116
117
|
showFixStartShadow,
|
|
117
118
|
showFixEndShadow
|
|
118
|
-
}), cellCss, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
119
|
+
}), cellCss, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvY29tcG9uZW50cy9Cb2R5L2NvbXBvbmVudHMvQm9keUNlbGwvQm9keUNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJJTSIsImZpbGUiOiIvYnVpbGRzL2Zyb250ZW5kL2xpYnMvdWkta2l0L3NyYy9jb21wb25lbnRzL1RhYmxlL2NvbXBvbmVudHMvQm9keS9jb21wb25lbnRzL0JvZHlDZWxsL0JvZHlDZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZyYWdtZW50LCB1c2VNZW1vLCB0eXBlIE1vdXNlRXZlbnRIYW5kbGVyIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEJvZHlDZWxsUHJvcHMgfSBmcm9tIFwiLi9Cb2R5Q2VsbC50eXBlc1wiO1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gXCIuLi8uLi8uLi9DZWxsL0NlbGxcIjtcbmltcG9ydCB7IHVzZUNlbGxIb3ZlciB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2hvb2tzL3VzZUNlbGxIb3ZlclwiO1xuaW1wb3J0IHsgdXNlQm9keUNlbGxSZW5kZXIgfSBmcm9tIFwiY29tcG9uZW50cy9UYWJsZS9ob29rcy91c2VCb2R5Q2VsbFJlbmRlclwiO1xuaW1wb3J0IHR5cGUgeyBEZWZhdWx0UmVjb3JkIH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvVGFibGUudHlwZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2NvbnRleHRzXCI7XG5pbXBvcnQgeyB1c2VDZWxsRml4ZWRJbmZvLCBnZXRGaXhlZENlbGxTdHlsZSB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2hvb2tzL3VzZUNlbGxGaXhlZEluZm9cIjtcbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSBcImhvb2tzL3VzZVRoZW1lXCI7XG5pbXBvcnQge1xuICBib2R5Q2VsbFN0eWxlLFxuICBnZXRCb3JkZXJlZEJvZHlDZWxsU3R5bGUsXG4gIGdldENlbGxJbm5lcldyYXBwZXJTdHlsZSxcbiAgbm9uSGVhZGVyQm9yZGVyZWRCb2R5Q2VsbFN0eWxlLFxufSBmcm9tIFwiLi9Cb2R5Q2VsbC5zdHlsZXNcIjtcbmltcG9ydCB7IEV4cGFuZEljb25XcmFwcGVyIH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVFeHBhbmRcIjtcbmltcG9ydCB7IHVzZVRhYmxlU3RhdGljQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2ZlYXR1cmVzL3RhYmxlU3RhdGljQ29udGV4dFwiO1xuaW1wb3J0IHsgZ2V0UmVmVmFsdWUgfSBmcm9tIFwiY29tcG9uZW50cy9UYWJsZS91dGlsc1wiO1xuaW1wb3J0IHsgdXNlRXZlbnQgfSBmcm9tIFwiaG9va3MvdXNlRXZlbnRcIjtcblxuY29uc3QgQm9keUNlbGxDb21wb25lbnQgPSA8UmVjb3JkIGV4dGVuZHMgRGVmYXVsdFJlY29yZD4ocHJvcHM6IEJvZHlDZWxsUHJvcHM8UmVjb3JkPikgPT4ge1xuICBjb25zdCB7IGNvbHVtbiwgcmVjb3JkLCBpbmRleCwgY29sSW5kZXgsIHJvd0tleSwgaW50ZW50LCByZW5kZXJJbmRleCwgaXNSb3dTZWxlY3RlZCB9ID0gcHJvcHM7XG4gIGNvbnN0IHsgcm93U2NvcGUsIGRhdGFJbmRleCwgcmVuZGVyIH0gPSBjb2x1bW47XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKTtcbiAgY29uc3Qge1xuICAgIGdldENvbXBvbmVudCxcbiAgICBpc1NvbWVSZWNvcmRIYXNDaGlsZHJlbixcbiAgICBpbmRlbnRTaXplLFxuICAgIGV4cGFuZEljb25Db2x1bW5JbmRleCxcbiAgICBib3JkZXJlZCxcbiAgICB0YWJsZVRva2VucyxcbiAgICBzaG93SGVhZGVyLFxuICAgIHJvd0hvdmVyYWJsZSxcbiAgfSA9IHVzZVRhYmxlQ29udGV4dCgpO1xuICBjb25zdCBzdGF0aWNDb250ZXh0UmVmID0gdXNlVGFibGVTdGF0aWNDb250ZXh0KCk7XG5cbiAgY29uc3Qge1xuICAgIGlzRml4U3RhcnQsXG4gICAgaXNGaXhFbmQsXG4gICAgZml4U3RhcnQsXG4gICAgZml4RW5kLFxuICAgIHpJbmRleFJldmVyc2UsXG4gICAgZml4ZWRTdGFydFNoYWRvdyxcbiAgICBmaXhlZEVuZFNoYWRvdyxcbiAgICBzaG93Rml4U3RhcnRTaGFkb3csXG4gICAgc2hvd0ZpeEVuZFNoYWRvdyxcbiAgfSA9IHVzZUNlbGxGaXhlZEluZm8oe1xuICAgIGNvbFN0YXJ0OiBjb2xJbmRleCxcbiAgICBjb2xFbmQ6IGNvbEluZGV4LFxuICB9KTtcblxuICBjb25zdCB7XG4gICAgcm93U3BhbjogY2VsbFJvd1NwYW4sXG4gICAgY29sU3BhbjogY2VsbENvbFNwYW4sXG4gICAgb25Nb3VzZUVudGVyOiBjZWxsT25Nb3VzZUVudGVyLFxuICAgIG9uTW91c2VMZWF2ZTogY2VsbE9uTW91c2VMZWF2ZSxcbiAgICBjc3M6IGNlbGxDc3MsXG4gICAgLi4ucmVzdEFkZGl0aW9uYWxDZWxsUHJvcHNcbiAgfSA9IGNvbHVtbi5vbkNlbGw/LihyZWNvcmQsIGluZGV4KSB8fCB7fTtcblxuICBjb25zdCBub3RSZW5kZXJlZENlbGwgPSBjZWxsQ29sU3BhbiA9PT0gMCB8fCBjZWxsUm93U3BhbiA9PT0gMDtcbiAgY29uc3Qgcm93U3BhbiA9IGNlbGxSb3dTcGFuID8/IDE7XG5cbiAgY29uc3QgcHJlZml4Tm9kZSA9IHVzZU1lbW8oXG4gICAgKCkgPT5cbiAgICAgIGNvbEluZGV4ID09PSBleHBhbmRJY29uQ29sdW1uSW5kZXggJiZcbiAgICAgIGlzU29tZVJlY29yZEhhc0NoaWxkcmVuICYmIChcbiAgICAgICAgPEV4cGFuZEljb25XcmFwcGVyXG4gICAgICAgICAgcm93S2V5PXtyb3dLZXl9XG4gICAgICAgICAgcmVjb3JkPXtyZWNvcmR9XG4gICAgICAgICAgZXhwYW5kYWJsZT17cmVjb3JkICYmIEJvb2xlYW4ocmVjb3JkLmNoaWxkcmVuKX1cbiAgICAgICAgLz5cbiAgICAgICksXG4gICAgW2NvbEluZGV4LCBleHBhbmRJY29uQ29sdW1uSW5kZXgsIGlzU29tZVJlY29yZEhhc0NoaWxkcmVuLCByZWNvcmQsIHJvd0tleV1cbiAgKTtcblxuICBjb25zdCB7IGlzSG92ZXJlZCB9ID0gdXNlQ2VsbEhvdmVyKHtcbiAgICBpbmRleCxcbiAgICByb3dTcGFuLFxuICAgIHNraXBTdWJzY3JpYmU6IG5vdFJlbmRlcmVkQ2VsbCxcbiAgfSk7XG5cbiAgY29uc3QgeyBjaGlsZHJlbiB9ID0gdXNlQm9keUNlbGxSZW5kZXIoe1xuICAgIHJlY29yZCxcbiAgICBkYXRhSW5kZXgsXG4gICAgcmVuZGVySW5kZXgsXG4gICAgcmVuZGVyLFxuICB9KTtcblxuICBjb25zdCBoYW5kbGVNb3VzZUVudGVyID0gdXNlRXZlbnQoKGUpID0+IHtcbiAgICBjb25zdCBlbWl0Q2VsbEhvdmVyID0gZ2V0UmVmVmFsdWUoc3RhdGljQ29udGV4dFJlZiwgXCJlbWl0Q2VsbEhvdmVyXCIpO1xuXG4gICAgZW1pdENlbGxIb3Zlcih7XG4gICAgICBzdGFydDogaW5kZXgsXG4gICAgICBlbmQ6IGluZGV4ICsgcm93U3BhbiAtIDEsXG4gICAgfSk7XG5cbiAgICBjZWxsT25Nb3VzZUVudGVyPy4oZSk7XG4gIH0pIHNhdGlzZmllcyBNb3VzZUV2ZW50SGFuZGxlcjxIVE1MVGFibGVDZWxsRWxlbWVudD47XG5cbiAgY29uc3QgaGFuZGxlTW91c2VMZWF2ZSA9IHVzZUV2ZW50KChlKSA9PiB7XG4gICAgY29uc3QgZW1pdENlbGxIb3ZlciA9IGdldFJlZlZhbHVlKHN0YXRpY0NvbnRleHRSZWYsIFwiZW1pdENlbGxIb3ZlclwiKTtcblxuICAgIGVtaXRDZWxsSG92ZXIoe1xuICAgICAgc3RhcnQ6IC0xLFxuICAgICAgZW5kOiAtMSxcbiAgICB9KTtcblxuICAgIGNlbGxPbk1vdXNlTGVhdmU/LihlKTtcbiAgfSkgc2F0aXNmaWVzIE1vdXNlRXZlbnRIYW5kbGVyPEhUTUxUYWJsZUNlbGxFbGVtZW50PjtcblxuICBjb25zdCBDZWxsSW5uZXJXcmFwcGVyID0gcHJlZml4Tm9kZSA/IFwiZGl2XCIgOiBGcmFnbWVudDtcblxuICBjb25zdCBjb250ZW50ID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoXG4gICAgICA8Q2VsbElubmVyV3JhcHBlclxuICAgICAgICB7Li4uKHByZWZpeE5vZGVcbiAgICAgICAgICA/IHtcbiAgICAgICAgICAgICAgXCJkYXRhLWluZGVudC1sZXZlbFwiOiBpbnRlbnQsXG4gICAgICAgICAgICAgIGNzczogZ2V0Q2VsbElubmVyV3JhcHBlclN0eWxlKGluZGVudFNpemUsIGludGVudCkodGhlbWUpLFxuICAgICAgICAgICAgfVxuICAgICAgICAgIDoge30pfVxuICAgICAgPlxuICAgICAgICB7cHJlZml4Tm9kZX1cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9DZWxsSW5uZXJXcmFwcGVyPlxuICAgICksXG4gICAgW0NlbGxJbm5lcldyYXBwZXIsIGNoaWxkcmVuLCBpbmRlbnRTaXplLCBpbnRlbnQsIHByZWZpeE5vZGUsIHRoZW1lXVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPENlbGxcbiAgICAgIGNvbXBvbmVudD17XG4gICAgICAgIHJvd1Njb3BlID8gZ2V0Q29tcG9uZW50KFtcImJvZHlcIiwgXCJjZWxsXCJdLCBcInRoXCIpIDogZ2V0Q29tcG9uZW50KFtcImJvZHlcIiwgXCJjZWxsXCJdLCBcInRkXCIpXG4gICAgICB9XG4gICAgICBhbGlnbj17Y29sdW1uLmFsaWdufVxuICAgICAgZWxsaXBzaXM9e2NvbHVtbi5lbGxpcHNpc31cbiAgICAgIGJvcmRlcmVkPXtib3JkZXJlZH1cbiAgICAgIHRhYmxlVG9rZW5zPXt0YWJsZVRva2Vuc31cbiAgICAgIGNzcz17W1xuICAgICAgICBib2R5Q2VsbFN0eWxlKHRhYmxlVG9rZW5zKSxcbiAgICAgICAgYm9yZGVyZWQuYmFzZUJvcmRlciA/IGdldEJvcmRlcmVkQm9keUNlbGxTdHlsZShib3JkZXJlZCkgOiB1bmRlZmluZWQsXG4gICAgICAgIGJvcmRlcmVkLmJhc2VCb3JkZXIgJiYgIXNob3dIZWFkZXJcbiAgICAgICAgICA/IG5vbkhlYWRlckJvcmRlcmVkQm9keUNlbGxTdHlsZSh0YWJsZVRva2VucylcbiAgICAgICAgICA6IHVuZGVmaW5lZCxcbiAgICAgICAgLi4uZ2V0Rml4ZWRDZWxsU3R5bGUoe1xuICAgICAgICAgIGNvbHVtbktleTogY29sdW1uLmtleSxcbiAgICAgICAgICBpc0ZpeFN0YXJ0LFxuICAgICAgICAgIGlzRml4RW5kLFxuICAgICAgICAgIGZpeFN0YXJ0LFxuICAgICAgICAgIGZpeEVuZCxcbiAgICAgICAgICB6SW5kZXhSZXZlcnNlLFxuICAgICAgICAgIGZpeGVkU3RhcnRTaGFkb3csXG4gICAgICAgICAgZml4ZWRFbmRTaGFkb3csXG4gICAgICAgICAgc2hvd0ZpeFN0YXJ0U2hhZG93LFxuICAgICAgICAgIHNob3dGaXhFbmRTaGFkb3csXG4gICAgICAgIH0pLFxuICAgICAgICBjZWxsQ3NzLFxuICAgICAgXX1cbiAgICAgIHJvd1NwYW49e2NlbGxSb3dTcGFufVxuICAgICAgY29sU3Bhbj17Y2VsbENvbFNwYW59XG4gICAgICBvbk1vdXNlRW50ZXI9e3Jvd0hvdmVyYWJsZSA/IGhhbmRsZU1vdXNlRW50ZXIgOiB1bmRlZmluZWR9XG4gICAgICBvbk1vdXNlTGVhdmU9e3Jvd0hvdmVyYWJsZSA/IGhhbmRsZU1vdXNlTGVhdmUgOiB1bmRlZmluZWR9XG4gICAgICB7Li4ucmVzdEFkZGl0aW9uYWxDZWxsUHJvcHN9XG4gICAgICBzY29wZT17cm93U2NvcGV9XG4gICAgICBpc0hvdmVyZWQ9e2lzSG92ZXJlZH1cbiAgICAgIGlzUm93U2VsZWN0ZWQ9e2lzUm93U2VsZWN0ZWR9XG4gICAgPlxuICAgICAge2NvbnRlbnR9XG4gICAgPC9DZWxsPlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IEJvZHlDZWxsID0gQm9keUNlbGxDb21wb25lbnQ7XG4iXX0= */"], rowSpan: cellRowSpan, colSpan: cellColSpan, onMouseEnter: rowHoverable ? handleMouseEnter : void 0, onMouseLeave: rowHoverable ? handleMouseLeave : void 0, ...restAdditionalCellProps, scope: rowScope, isHovered, isRowSelected, children: content });
|
|
119
120
|
};
|
|
120
121
|
const BodyCell = BodyCellComponent;
|
|
121
122
|
export {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { TableTokens } from 'components/Table/Table.tokens';
|
|
2
|
-
import {
|
|
2
|
+
import { Bordered } from 'components/Table/Table.types';
|
|
3
3
|
import { Theme } from 'themes';
|
|
4
4
|
export declare const getCellInnerWrapperStyle: (indentSize: number, intent: number) => (theme: Theme) => {
|
|
5
5
|
display: string;
|
|
@@ -10,7 +10,7 @@ export declare const bodyCellStyle: (tableTokens: TableTokens) => {
|
|
|
10
10
|
borderColor: "#E5E5E5";
|
|
11
11
|
backgroundColor: "#FFFFFF";
|
|
12
12
|
};
|
|
13
|
-
export declare const getBorderedBodyCellStyle: (
|
|
13
|
+
export declare const getBorderedBodyCellStyle: (bordered: Bordered) => {
|
|
14
14
|
":last-of-type": {
|
|
15
15
|
borderInlineEndWidth: number;
|
|
16
16
|
};
|