@infomaximum/ui-kit 0.16.0 → 0.16.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Empty/Empty.js +5 -5
- package/dist/components/Empty/Empty.types.d.ts +3 -0
- package/dist/components/Empty/index.d.ts +1 -1
- package/dist/components/Spin/Spin.js +4 -2
- package/dist/components/Spin/Spin.styles.d.ts +8 -8
- package/dist/components/Spin/Spin.types.d.ts +5 -0
- package/dist/components/Table/Table.js +16 -6
- package/dist/components/Table/Table.types.d.ts +6 -4
- package/dist/components/Table/components/Body/Body.d.ts +1 -1
- package/dist/components/Table/components/Body/Body.js +5 -1
- package/dist/components/Table/components/Body/Body.types.d.ts +1 -0
- package/dist/components/Table/components/Body/components/BodyRow/BodyRow.js +1 -1
- package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.js +1 -1
- package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.utils.d.ts +1 -1
- package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.d.ts +1 -2
- package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.js +4 -4
- package/dist/components/Table/components/FixedHeader/components/FixedHeaderColGroup/FixedHeaderColGroup.js +1 -1
- package/dist/components/Table/features/tableExpand/hooks/useBodyExpand/useBodyExpand.d.ts +2 -2
- package/dist/components/Table/features/tableExpand/hooks/useTableExpand/useTableExpand.d.ts +1 -1
- package/dist/components/Table/features/tableExpand/hooks/useTableExpand/useTableExpand.js +1 -1
- package/dist/components/Table/features/tableRowSelection/components/CheckboxCellContentWrapper/CheckboxCellContentWrapper.js +3 -1
- package/dist/components/Table/features/tableRowSelection/components/CheckboxCellContentWrapper/CheckboxCellContentWrapper.utils.d.ts +2 -2
- package/dist/components/Table/features/tableRowSelection/components/HeaderCheckboxCellContentWrapper/HeaderCheckboxCellContentWrapper.js +4 -2
- package/dist/components/Table/features/tableRowSelection/components/HeaderCheckboxCellContentWrapper/HeaderCheckboxCellContentWrapper.types.d.ts +1 -1
- package/dist/components/Table/features/tableRowSelection/components/RadioCellContentWrapper/RadioCellContentWrapper.js +3 -1
- package/dist/components/Table/features/tableRowSelection/hooks/useTableRowSelection/useTableRowSelection.d.ts +7 -7
- package/dist/components/Table/features/tableRowSelection/hooks/useTableRowSelection/useTableRowSelection.js +2 -2
- package/dist/components/Table/features/tableRowSelection/hooks/useTransformColumns/useTransformColumns.js +2 -1
- package/dist/components/Table/features/tableRowSelection/types.d.ts +6 -2
- package/dist/components/Table/features/tableSort/hooks/useSortState/useSortState.js +1 -1
- package/dist/components/Table/features/tableSort/hooks/useTableSort/useTableSort.js +2 -2
- package/dist/components/Table/features/tableStaticContext/contexts/tableStaticContext/TableStaticContext.d.ts +2 -2
- package/dist/components/Table/features/tableStaticContext/contexts/tableStaticContext/TableStaticContext.js +1 -1
- package/dist/components/Table/features/tableStaticContext/hocs/withTableStaticContext.js +6 -3
- package/dist/components/Table/features/typedEventBus/hooks.d.ts +2 -2
- package/dist/components/Table/hooks/useBodyCellRender/useBodyCellRender.js +2 -0
- package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.js +1 -1
- package/dist/components/Table/hooks/useCellHover/useCellHover.js +1 -1
- package/dist/components/Table/hooks/useTableColumns/useTableColumns.d.ts +2 -2
- package/dist/components/Table/hooks/useTableVisualParamsChange/useTableVisualParamsChange.js +1 -1
- package/dist/components/Table/index.d.ts +2 -1
- package/dist/components/Table/interfaces/tableColumns.types.d.ts +17 -13
- package/dist/components/Table/utils/getRowKey/getRowKey.d.ts +1 -1
- package/dist/index.d.ts +2 -2
- package/package.json +2 -2
|
@@ -13,7 +13,7 @@ import { TestingImg } from "./components/images/TestingImg.js";
|
|
|
13
13
|
import { _404Img } from "./components/images/_404Img.js";
|
|
14
14
|
import { useTheme } from "../../hooks/useTheme/useTheme.js";
|
|
15
15
|
const EmptyComponent = (props) => {
|
|
16
|
-
var _a;
|
|
16
|
+
var _a, _b, _c, _d;
|
|
17
17
|
const {
|
|
18
18
|
title,
|
|
19
19
|
caption,
|
|
@@ -29,11 +29,11 @@ const EmptyComponent = (props) => {
|
|
|
29
29
|
}
|
|
30
30
|
return /* @__PURE__ */ jsx("img", { src: imageProp, alt: isString(title) && title || isString(caption) && caption || emptyString });
|
|
31
31
|
})();
|
|
32
|
-
return /* @__PURE__ */ jsxs("div", { css: [emptyStyle(emptyTokens), (_a = styles == null ? void 0 : styles.empty) == null ? void 0 : _a.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:EmptyComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvRW1wdHkvRW1wdHkudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBDUyIsImZpbGUiOiIvYnVpbGRzL2Zyb250ZW5kL2xpYnMvdWkta2l0L3NyYy9jb21wb25lbnRzL0VtcHR5L0VtcHR5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IG1lbW8sIHR5cGUgRkMsIHR5cGUgTmFtZWRFeG90aWNDb21wb25lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW1wdHlQcm9wcywgV2l0aEltYWdlcyB9IGZyb20gXCIuL0VtcHR5LnR5cGVzXCI7XG5pbXBvcnQge1xuICBfNDA0SW1nLFxuICBCb29rbWFya0ltZyxcbiAgRGVmYXVsdEltZyxcbiAgRmlsdGVySW1nLFxuICBMb2NrZWRJbWcsXG4gIFNlYXJjaEltZyxcbiAgVGVzdGluZ0ltZyxcbn0gZnJvbSBcIi4vY29tcG9uZW50cy9pbWFnZXNcIjtcbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSBcIi4uLy4uL2hvb2tzL3VzZVRoZW1lXCI7XG5pbXBvcnQgeyBnZXRFbXB0eVRva2VucyB9IGZyb20gXCIuL0VtcHR5LnRva2Vuc1wiO1xuaW1wb3J0IHtcbiAgY2FwdGlvblN0eWxlLFxuICBlbXB0eVN0eWxlLFxuICBmb290ZXJTdHlsZSxcbiAgaW1hZ2VXcmFwcGVyU3R5bGUsXG4gIHRpdGxlU3R5bGUsXG59IGZyb20gXCIuL0VtcHR5LnN0eWxlc1wiO1xuaW1wb3J0IHsgaXNTdHJpbmcgfSBmcm9tIFwibG9kYXNoLWVzXCI7XG5pbXBvcnQgeyBlbXB0eVN0cmluZyB9IGZyb20gXCIuLi8uLi91dGlsc1wiO1xuXG5jb25zdCBFbXB0eUNvbXBvbmVudDogRkM8RW1wdHlQcm9wcz4gPSAocHJvcHMpID0+IHtcbiAgY29uc3QgeyB0aXRsZSwgY2FwdGlvbiwgaW1hZ2U6IGltYWdlUHJvcCA9IEVtcHR5LkRFRkFVTFQsIHN0eWxlcywgY2hpbGRyZW4gfSA9IHByb3BzO1xuICBjb25zdCB0aGVtZSA9IHVzZVRoZW1lKCk7XG4gIGNvbnN0IGVtcHR5VG9rZW5zID0gZ2V0RW1wdHlUb2tlbnModGhlbWUpO1xuXG4gIGNvbnN0IGltYWdlID0gKCgpID0+IHtcbiAgICBpZiAoIWlzU3RyaW5nKGltYWdlUHJvcCkpIHtcbiAgICAgIHJldHVybiBpbWFnZVByb3A7XG4gICAgfVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxpbWdcbiAgICAgICAgc3JjPXtpbWFnZVByb3B9XG4gICAgICAgIGFsdD17KGlzU3RyaW5nKHRpdGxlKSAmJiB0aXRsZSkgfHwgKGlzU3RyaW5nKGNhcHRpb24pICYmIGNhcHRpb24pIHx8IGVtcHR5U3RyaW5nfVxuICAgICAgLz5cbiAgICApO1xuICB9KSgpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdiBjc3M9e1tlbXB0eVN0eWxlKGVtcHR5VG9rZW5zKSwgc3R5bGVzPy5lbXB0eT8uKHRoZW1lKV19PlxuICAgICAgPGRpdiBjc3M9e2ltYWdlV3JhcHBlclN0eWxlKHRoZW1lKX0+
|
|
32
|
+
return /* @__PURE__ */ jsxs("div", { css: [emptyStyle(emptyTokens), (_a = styles == null ? void 0 : styles.empty) == null ? void 0 : _a.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:EmptyComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvRW1wdHkvRW1wdHkudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBDUyIsImZpbGUiOiIvYnVpbGRzL2Zyb250ZW5kL2xpYnMvdWkta2l0L3NyYy9jb21wb25lbnRzL0VtcHR5L0VtcHR5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IG1lbW8sIHR5cGUgRkMsIHR5cGUgTmFtZWRFeG90aWNDb21wb25lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW1wdHlQcm9wcywgV2l0aEltYWdlcyB9IGZyb20gXCIuL0VtcHR5LnR5cGVzXCI7XG5pbXBvcnQge1xuICBfNDA0SW1nLFxuICBCb29rbWFya0ltZyxcbiAgRGVmYXVsdEltZyxcbiAgRmlsdGVySW1nLFxuICBMb2NrZWRJbWcsXG4gIFNlYXJjaEltZyxcbiAgVGVzdGluZ0ltZyxcbn0gZnJvbSBcIi4vY29tcG9uZW50cy9pbWFnZXNcIjtcbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSBcIi4uLy4uL2hvb2tzL3VzZVRoZW1lXCI7XG5pbXBvcnQgeyBnZXRFbXB0eVRva2VucyB9IGZyb20gXCIuL0VtcHR5LnRva2Vuc1wiO1xuaW1wb3J0IHtcbiAgY2FwdGlvblN0eWxlLFxuICBlbXB0eVN0eWxlLFxuICBmb290ZXJTdHlsZSxcbiAgaW1hZ2VXcmFwcGVyU3R5bGUsXG4gIHRpdGxlU3R5bGUsXG59IGZyb20gXCIuL0VtcHR5LnN0eWxlc1wiO1xuaW1wb3J0IHsgaXNTdHJpbmcgfSBmcm9tIFwibG9kYXNoLWVzXCI7XG5pbXBvcnQgeyBlbXB0eVN0cmluZyB9IGZyb20gXCIuLi8uLi91dGlsc1wiO1xuXG5jb25zdCBFbXB0eUNvbXBvbmVudDogRkM8RW1wdHlQcm9wcz4gPSAocHJvcHMpID0+IHtcbiAgY29uc3QgeyB0aXRsZSwgY2FwdGlvbiwgaW1hZ2U6IGltYWdlUHJvcCA9IEVtcHR5LkRFRkFVTFQsIHN0eWxlcywgY2hpbGRyZW4gfSA9IHByb3BzO1xuICBjb25zdCB0aGVtZSA9IHVzZVRoZW1lKCk7XG4gIGNvbnN0IGVtcHR5VG9rZW5zID0gZ2V0RW1wdHlUb2tlbnModGhlbWUpO1xuXG4gIGNvbnN0IGltYWdlID0gKCgpID0+IHtcbiAgICBpZiAoIWlzU3RyaW5nKGltYWdlUHJvcCkpIHtcbiAgICAgIHJldHVybiBpbWFnZVByb3A7XG4gICAgfVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxpbWdcbiAgICAgICAgc3JjPXtpbWFnZVByb3B9XG4gICAgICAgIGFsdD17KGlzU3RyaW5nKHRpdGxlKSAmJiB0aXRsZSkgfHwgKGlzU3RyaW5nKGNhcHRpb24pICYmIGNhcHRpb24pIHx8IGVtcHR5U3RyaW5nfVxuICAgICAgLz5cbiAgICApO1xuICB9KSgpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdiBjc3M9e1tlbXB0eVN0eWxlKGVtcHR5VG9rZW5zKSwgc3R5bGVzPy5lbXB0eT8uKHRoZW1lKV19PlxuICAgICAgPGRpdiBjc3M9e2ltYWdlV3JhcHBlclN0eWxlKHRoZW1lKX0+e2ltYWdlfTwvZGl2PlxuICAgICAge3RpdGxlICYmIDxkaXYgY3NzPXtbdGl0bGVTdHlsZShlbXB0eVRva2VucykodGhlbWUpLCBzdHlsZXM/LnRpdGxlPy4odGhlbWUpXX0+e3RpdGxlfTwvZGl2Pn1cbiAgICAgIHtjYXB0aW9uICYmIChcbiAgICAgICAgPGRpdiBjc3M9e1tjYXB0aW9uU3R5bGUoZW1wdHlUb2tlbnMpKHRoZW1lKSwgc3R5bGVzPy5jYXB0aW9uPy4odGhlbWUpXX0+e2NhcHRpb259PC9kaXY+XG4gICAgICApfVxuICAgICAge2NoaWxkcmVuICYmIDxkaXYgY3NzPXtbZm9vdGVyU3R5bGUoZW1wdHlUb2tlbnMpLCBzdHlsZXM/LmZvb3Rlcj8uKHRoZW1lKV19PntjaGlsZHJlbn08L2Rpdj59XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgY29uc3QgRW1wdHkgPSBtZW1vKEVtcHR5Q29tcG9uZW50KSBhcyBOYW1lZEV4b3RpY0NvbXBvbmVudDxFbXB0eVByb3BzPiAmIFdpdGhJbWFnZXM7XG5cbkVtcHR5LkRFRkFVTFQgPSA8RGVmYXVsdEltZyAvPjtcbkVtcHR5LkZJTFRFUiA9IDxGaWx0ZXJJbWcgLz47XG5FbXB0eS5TRUFSQ0ggPSA8U2VhcmNoSW1nIC8+O1xuRW1wdHkuTE9DS0VEID0gPExvY2tlZEltZyAvPjtcbkVtcHR5LkJPT0tNQVJLID0gPEJvb2ttYXJrSW1nIC8+O1xuRW1wdHkuVEVTVElORyA9IDxUZXN0aW5nSW1nIC8+O1xuRW1wdHlbNDA0XSA9IDxfNDA0SW1nIC8+O1xuIl19 */"], children: [
|
|
33
33
|
/* @__PURE__ */ jsx("div", { css: imageWrapperStyle(theme), children: image }),
|
|
34
|
-
title && /* @__PURE__ */ jsx("div", { css: titleStyle(emptyTokens)(theme), children: title }),
|
|
35
|
-
caption && /* @__PURE__ */ jsx("div", { css: captionStyle(emptyTokens)(theme), children: caption }),
|
|
36
|
-
children && /* @__PURE__ */ jsx("div", { css: footerStyle(emptyTokens), children })
|
|
34
|
+
title && /* @__PURE__ */ jsx("div", { css: [titleStyle(emptyTokens)(theme), (_b = styles == null ? void 0 : styles.title) == null ? void 0 : _b.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:EmptyComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvRW1wdHkvRW1wdHkudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRDcUIiLCJmaWxlIjoiL2J1aWxkcy9mcm9udGVuZC9saWJzL3VpLWtpdC9zcmMvY29tcG9uZW50cy9FbXB0eS9FbXB0eS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBtZW1vLCB0eXBlIEZDLCB0eXBlIE5hbWVkRXhvdGljQ29tcG9uZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEVtcHR5UHJvcHMsIFdpdGhJbWFnZXMgfSBmcm9tIFwiLi9FbXB0eS50eXBlc1wiO1xuaW1wb3J0IHtcbiAgXzQwNEltZyxcbiAgQm9va21hcmtJbWcsXG4gIERlZmF1bHRJbWcsXG4gIEZpbHRlckltZyxcbiAgTG9ja2VkSW1nLFxuICBTZWFyY2hJbWcsXG4gIFRlc3RpbmdJbWcsXG59IGZyb20gXCIuL2NvbXBvbmVudHMvaW1hZ2VzXCI7XG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gXCIuLi8uLi9ob29rcy91c2VUaGVtZVwiO1xuaW1wb3J0IHsgZ2V0RW1wdHlUb2tlbnMgfSBmcm9tIFwiLi9FbXB0eS50b2tlbnNcIjtcbmltcG9ydCB7XG4gIGNhcHRpb25TdHlsZSxcbiAgZW1wdHlTdHlsZSxcbiAgZm9vdGVyU3R5bGUsXG4gIGltYWdlV3JhcHBlclN0eWxlLFxuICB0aXRsZVN0eWxlLFxufSBmcm9tIFwiLi9FbXB0eS5zdHlsZXNcIjtcbmltcG9ydCB7IGlzU3RyaW5nIH0gZnJvbSBcImxvZGFzaC1lc1wiO1xuaW1wb3J0IHsgZW1wdHlTdHJpbmcgfSBmcm9tIFwiLi4vLi4vdXRpbHNcIjtcblxuY29uc3QgRW1wdHlDb21wb25lbnQ6IEZDPEVtcHR5UHJvcHM+ID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdGl0bGUsIGNhcHRpb24sIGltYWdlOiBpbWFnZVByb3AgPSBFbXB0eS5ERUZBVUxULCBzdHlsZXMsIGNoaWxkcmVuIH0gPSBwcm9wcztcbiAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpO1xuICBjb25zdCBlbXB0eVRva2VucyA9IGdldEVtcHR5VG9rZW5zKHRoZW1lKTtcblxuICBjb25zdCBpbWFnZSA9ICgoKSA9PiB7XG4gICAgaWYgKCFpc1N0cmluZyhpbWFnZVByb3ApKSB7XG4gICAgICByZXR1cm4gaW1hZ2VQcm9wO1xuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICA8aW1nXG4gICAgICAgIHNyYz17aW1hZ2VQcm9wfVxuICAgICAgICBhbHQ9eyhpc1N0cmluZyh0aXRsZSkgJiYgdGl0bGUpIHx8IChpc1N0cmluZyhjYXB0aW9uKSAmJiBjYXB0aW9uKSB8fCBlbXB0eVN0cmluZ31cbiAgICAgIC8+XG4gICAgKTtcbiAgfSkoKTtcblxuICByZXR1cm4gKFxuICAgIDxkaXYgY3NzPXtbZW1wdHlTdHlsZShlbXB0eVRva2VucyksIHN0eWxlcz8uZW1wdHk/Lih0aGVtZSldfT5cbiAgICAgIDxkaXYgY3NzPXtpbWFnZVdyYXBwZXJTdHlsZSh0aGVtZSl9PntpbWFnZX08L2Rpdj5cbiAgICAgIHt0aXRsZSAmJiA8ZGl2IGNzcz17W3RpdGxlU3R5bGUoZW1wdHlUb2tlbnMpKHRoZW1lKSwgc3R5bGVzPy50aXRsZT8uKHRoZW1lKV19Pnt0aXRsZX08L2Rpdj59XG4gICAgICB7Y2FwdGlvbiAmJiAoXG4gICAgICAgIDxkaXYgY3NzPXtbY2FwdGlvblN0eWxlKGVtcHR5VG9rZW5zKSh0aGVtZSksIHN0eWxlcz8uY2FwdGlvbj8uKHRoZW1lKV19PntjYXB0aW9ufTwvZGl2PlxuICAgICAgKX1cbiAgICAgIHtjaGlsZHJlbiAmJiA8ZGl2IGNzcz17W2Zvb3RlclN0eWxlKGVtcHR5VG9rZW5zKSwgc3R5bGVzPy5mb290ZXI/Lih0aGVtZSldfT57Y2hpbGRyZW59PC9kaXY+fVxuICAgIDwvZGl2PlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IEVtcHR5ID0gbWVtbyhFbXB0eUNvbXBvbmVudCkgYXMgTmFtZWRFeG90aWNDb21wb25lbnQ8RW1wdHlQcm9wcz4gJiBXaXRoSW1hZ2VzO1xuXG5FbXB0eS5ERUZBVUxUID0gPERlZmF1bHRJbWcgLz47XG5FbXB0eS5GSUxURVIgPSA8RmlsdGVySW1nIC8+O1xuRW1wdHkuU0VBUkNIID0gPFNlYXJjaEltZyAvPjtcbkVtcHR5LkxPQ0tFRCA9IDxMb2NrZWRJbWcgLz47XG5FbXB0eS5CT09LTUFSSyA9IDxCb29rbWFya0ltZyAvPjtcbkVtcHR5LlRFU1RJTkcgPSA8VGVzdGluZ0ltZyAvPjtcbkVtcHR5WzQwNF0gPSA8XzQwNEltZyAvPjtcbiJdfQ== */"], children: title }),
|
|
35
|
+
caption && /* @__PURE__ */ jsx("div", { css: [captionStyle(emptyTokens)(theme), (_c = styles == null ? void 0 : styles.caption) == null ? void 0 : _c.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:EmptyComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvRW1wdHkvRW1wdHkudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThDYSIsImZpbGUiOiIvYnVpbGRzL2Zyb250ZW5kL2xpYnMvdWkta2l0L3NyYy9jb21wb25lbnRzL0VtcHR5L0VtcHR5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IG1lbW8sIHR5cGUgRkMsIHR5cGUgTmFtZWRFeG90aWNDb21wb25lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgRW1wdHlQcm9wcywgV2l0aEltYWdlcyB9IGZyb20gXCIuL0VtcHR5LnR5cGVzXCI7XG5pbXBvcnQge1xuICBfNDA0SW1nLFxuICBCb29rbWFya0ltZyxcbiAgRGVmYXVsdEltZyxcbiAgRmlsdGVySW1nLFxuICBMb2NrZWRJbWcsXG4gIFNlYXJjaEltZyxcbiAgVGVzdGluZ0ltZyxcbn0gZnJvbSBcIi4vY29tcG9uZW50cy9pbWFnZXNcIjtcbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSBcIi4uLy4uL2hvb2tzL3VzZVRoZW1lXCI7XG5pbXBvcnQgeyBnZXRFbXB0eVRva2VucyB9IGZyb20gXCIuL0VtcHR5LnRva2Vuc1wiO1xuaW1wb3J0IHtcbiAgY2FwdGlvblN0eWxlLFxuICBlbXB0eVN0eWxlLFxuICBmb290ZXJTdHlsZSxcbiAgaW1hZ2VXcmFwcGVyU3R5bGUsXG4gIHRpdGxlU3R5bGUsXG59IGZyb20gXCIuL0VtcHR5LnN0eWxlc1wiO1xuaW1wb3J0IHsgaXNTdHJpbmcgfSBmcm9tIFwibG9kYXNoLWVzXCI7XG5pbXBvcnQgeyBlbXB0eVN0cmluZyB9IGZyb20gXCIuLi8uLi91dGlsc1wiO1xuXG5jb25zdCBFbXB0eUNvbXBvbmVudDogRkM8RW1wdHlQcm9wcz4gPSAocHJvcHMpID0+IHtcbiAgY29uc3QgeyB0aXRsZSwgY2FwdGlvbiwgaW1hZ2U6IGltYWdlUHJvcCA9IEVtcHR5LkRFRkFVTFQsIHN0eWxlcywgY2hpbGRyZW4gfSA9IHByb3BzO1xuICBjb25zdCB0aGVtZSA9IHVzZVRoZW1lKCk7XG4gIGNvbnN0IGVtcHR5VG9rZW5zID0gZ2V0RW1wdHlUb2tlbnModGhlbWUpO1xuXG4gIGNvbnN0IGltYWdlID0gKCgpID0+IHtcbiAgICBpZiAoIWlzU3RyaW5nKGltYWdlUHJvcCkpIHtcbiAgICAgIHJldHVybiBpbWFnZVByb3A7XG4gICAgfVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxpbWdcbiAgICAgICAgc3JjPXtpbWFnZVByb3B9XG4gICAgICAgIGFsdD17KGlzU3RyaW5nKHRpdGxlKSAmJiB0aXRsZSkgfHwgKGlzU3RyaW5nKGNhcHRpb24pICYmIGNhcHRpb24pIHx8IGVtcHR5U3RyaW5nfVxuICAgICAgLz5cbiAgICApO1xuICB9KSgpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdiBjc3M9e1tlbXB0eVN0eWxlKGVtcHR5VG9rZW5zKSwgc3R5bGVzPy5lbXB0eT8uKHRoZW1lKV19PlxuICAgICAgPGRpdiBjc3M9e2ltYWdlV3JhcHBlclN0eWxlKHRoZW1lKX0+e2ltYWdlfTwvZGl2PlxuICAgICAge3RpdGxlICYmIDxkaXYgY3NzPXtbdGl0bGVTdHlsZShlbXB0eVRva2VucykodGhlbWUpLCBzdHlsZXM/LnRpdGxlPy4odGhlbWUpXX0+e3RpdGxlfTwvZGl2Pn1cbiAgICAgIHtjYXB0aW9uICYmIChcbiAgICAgICAgPGRpdiBjc3M9e1tjYXB0aW9uU3R5bGUoZW1wdHlUb2tlbnMpKHRoZW1lKSwgc3R5bGVzPy5jYXB0aW9uPy4odGhlbWUpXX0+e2NhcHRpb259PC9kaXY+XG4gICAgICApfVxuICAgICAge2NoaWxkcmVuICYmIDxkaXYgY3NzPXtbZm9vdGVyU3R5bGUoZW1wdHlUb2tlbnMpLCBzdHlsZXM/LmZvb3Rlcj8uKHRoZW1lKV19PntjaGlsZHJlbn08L2Rpdj59XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgY29uc3QgRW1wdHkgPSBtZW1vKEVtcHR5Q29tcG9uZW50KSBhcyBOYW1lZEV4b3RpY0NvbXBvbmVudDxFbXB0eVByb3BzPiAmIFdpdGhJbWFnZXM7XG5cbkVtcHR5LkRFRkFVTFQgPSA8RGVmYXVsdEltZyAvPjtcbkVtcHR5LkZJTFRFUiA9IDxGaWx0ZXJJbWcgLz47XG5FbXB0eS5TRUFSQ0ggPSA8U2VhcmNoSW1nIC8+O1xuRW1wdHkuTE9DS0VEID0gPExvY2tlZEltZyAvPjtcbkVtcHR5LkJPT0tNQVJLID0gPEJvb2ttYXJrSW1nIC8+O1xuRW1wdHkuVEVTVElORyA9IDxUZXN0aW5nSW1nIC8+O1xuRW1wdHlbNDA0XSA9IDxfNDA0SW1nIC8+O1xuIl19 */"], children: caption }),
|
|
36
|
+
children && /* @__PURE__ */ jsx("div", { css: [footerStyle(emptyTokens), (_d = styles == null ? void 0 : styles.footer) == null ? void 0 : _d.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:EmptyComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvRW1wdHkvRW1wdHkudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEd0IiLCJmaWxlIjoiL2J1aWxkcy9mcm9udGVuZC9saWJzL3VpLWtpdC9zcmMvY29tcG9uZW50cy9FbXB0eS9FbXB0eS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBtZW1vLCB0eXBlIEZDLCB0eXBlIE5hbWVkRXhvdGljQ29tcG9uZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEVtcHR5UHJvcHMsIFdpdGhJbWFnZXMgfSBmcm9tIFwiLi9FbXB0eS50eXBlc1wiO1xuaW1wb3J0IHtcbiAgXzQwNEltZyxcbiAgQm9va21hcmtJbWcsXG4gIERlZmF1bHRJbWcsXG4gIEZpbHRlckltZyxcbiAgTG9ja2VkSW1nLFxuICBTZWFyY2hJbWcsXG4gIFRlc3RpbmdJbWcsXG59IGZyb20gXCIuL2NvbXBvbmVudHMvaW1hZ2VzXCI7XG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gXCIuLi8uLi9ob29rcy91c2VUaGVtZVwiO1xuaW1wb3J0IHsgZ2V0RW1wdHlUb2tlbnMgfSBmcm9tIFwiLi9FbXB0eS50b2tlbnNcIjtcbmltcG9ydCB7XG4gIGNhcHRpb25TdHlsZSxcbiAgZW1wdHlTdHlsZSxcbiAgZm9vdGVyU3R5bGUsXG4gIGltYWdlV3JhcHBlclN0eWxlLFxuICB0aXRsZVN0eWxlLFxufSBmcm9tIFwiLi9FbXB0eS5zdHlsZXNcIjtcbmltcG9ydCB7IGlzU3RyaW5nIH0gZnJvbSBcImxvZGFzaC1lc1wiO1xuaW1wb3J0IHsgZW1wdHlTdHJpbmcgfSBmcm9tIFwiLi4vLi4vdXRpbHNcIjtcblxuY29uc3QgRW1wdHlDb21wb25lbnQ6IEZDPEVtcHR5UHJvcHM+ID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdGl0bGUsIGNhcHRpb24sIGltYWdlOiBpbWFnZVByb3AgPSBFbXB0eS5ERUZBVUxULCBzdHlsZXMsIGNoaWxkcmVuIH0gPSBwcm9wcztcbiAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpO1xuICBjb25zdCBlbXB0eVRva2VucyA9IGdldEVtcHR5VG9rZW5zKHRoZW1lKTtcblxuICBjb25zdCBpbWFnZSA9ICgoKSA9PiB7XG4gICAgaWYgKCFpc1N0cmluZyhpbWFnZVByb3ApKSB7XG4gICAgICByZXR1cm4gaW1hZ2VQcm9wO1xuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICA8aW1nXG4gICAgICAgIHNyYz17aW1hZ2VQcm9wfVxuICAgICAgICBhbHQ9eyhpc1N0cmluZyh0aXRsZSkgJiYgdGl0bGUpIHx8IChpc1N0cmluZyhjYXB0aW9uKSAmJiBjYXB0aW9uKSB8fCBlbXB0eVN0cmluZ31cbiAgICAgIC8+XG4gICAgKTtcbiAgfSkoKTtcblxuICByZXR1cm4gKFxuICAgIDxkaXYgY3NzPXtbZW1wdHlTdHlsZShlbXB0eVRva2VucyksIHN0eWxlcz8uZW1wdHk/Lih0aGVtZSldfT5cbiAgICAgIDxkaXYgY3NzPXtpbWFnZVdyYXBwZXJTdHlsZSh0aGVtZSl9PntpbWFnZX08L2Rpdj5cbiAgICAgIHt0aXRsZSAmJiA8ZGl2IGNzcz17W3RpdGxlU3R5bGUoZW1wdHlUb2tlbnMpKHRoZW1lKSwgc3R5bGVzPy50aXRsZT8uKHRoZW1lKV19Pnt0aXRsZX08L2Rpdj59XG4gICAgICB7Y2FwdGlvbiAmJiAoXG4gICAgICAgIDxkaXYgY3NzPXtbY2FwdGlvblN0eWxlKGVtcHR5VG9rZW5zKSh0aGVtZSksIHN0eWxlcz8uY2FwdGlvbj8uKHRoZW1lKV19PntjYXB0aW9ufTwvZGl2PlxuICAgICAgKX1cbiAgICAgIHtjaGlsZHJlbiAmJiA8ZGl2IGNzcz17W2Zvb3RlclN0eWxlKGVtcHR5VG9rZW5zKSwgc3R5bGVzPy5mb290ZXI/Lih0aGVtZSldfT57Y2hpbGRyZW59PC9kaXY+fVxuICAgIDwvZGl2PlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IEVtcHR5ID0gbWVtbyhFbXB0eUNvbXBvbmVudCkgYXMgTmFtZWRFeG90aWNDb21wb25lbnQ8RW1wdHlQcm9wcz4gJiBXaXRoSW1hZ2VzO1xuXG5FbXB0eS5ERUZBVUxUID0gPERlZmF1bHRJbWcgLz47XG5FbXB0eS5GSUxURVIgPSA8RmlsdGVySW1nIC8+O1xuRW1wdHkuU0VBUkNIID0gPFNlYXJjaEltZyAvPjtcbkVtcHR5LkxPQ0tFRCA9IDxMb2NrZWRJbWcgLz47XG5FbXB0eS5CT09LTUFSSyA9IDxCb29rbWFya0ltZyAvPjtcbkVtcHR5LlRFU1RJTkcgPSA8VGVzdGluZ0ltZyAvPjtcbkVtcHR5WzQwNF0gPSA8XzQwNEltZyAvPjtcbiJdfQ== */"], children })
|
|
37
37
|
] });
|
|
38
38
|
};
|
|
39
39
|
const Empty = memo(EmptyComponent);
|
|
@@ -7,6 +7,9 @@ export interface EmptyProps extends PropsWithChildren {
|
|
|
7
7
|
image?: ReactNode;
|
|
8
8
|
styles?: {
|
|
9
9
|
empty?: (theme: Theme) => Interpolation;
|
|
10
|
+
title?: (theme: Theme) => Interpolation;
|
|
11
|
+
caption?: (theme: Theme) => Interpolation;
|
|
12
|
+
footer?: (theme: Theme) => Interpolation;
|
|
10
13
|
};
|
|
11
14
|
}
|
|
12
15
|
export interface WithImages<T = ReactNode> {
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export { Empty } from './Empty';
|
|
2
|
-
export type { EmptyProps } from './Empty.types';
|
|
2
|
+
export type { EmptyProps, WithImages } from './Empty.types';
|
|
@@ -13,7 +13,8 @@ const SpinComponent = (props) => {
|
|
|
13
13
|
variant = "base",
|
|
14
14
|
spinning: spinningProp = true,
|
|
15
15
|
tip,
|
|
16
|
-
children
|
|
16
|
+
children,
|
|
17
|
+
styles
|
|
17
18
|
} = props;
|
|
18
19
|
const clipPathUniqId = uniqueId("spinner_clip_path_");
|
|
19
20
|
const theme = useTheme();
|
|
@@ -53,6 +54,7 @@ const SpinComponent = (props) => {
|
|
|
53
54
|
};
|
|
54
55
|
})();
|
|
55
56
|
const wrapperProps = (() => {
|
|
57
|
+
var _a;
|
|
56
58
|
if (!(tip || children || fullscreen)) {
|
|
57
59
|
return {};
|
|
58
60
|
}
|
|
@@ -63,7 +65,7 @@ const SpinComponent = (props) => {
|
|
|
63
65
|
}
|
|
64
66
|
if (children) {
|
|
65
67
|
return {
|
|
66
|
-
css: withChildrenPropWrapperStyle(theme)
|
|
68
|
+
css: [withChildrenPropWrapperStyle(theme), (_a = styles == null ? void 0 : styles.withChildrenPropWrapperStyle) == null ? void 0 : _a.call(styles, theme)]
|
|
67
69
|
};
|
|
68
70
|
}
|
|
69
71
|
return {
|
|
@@ -33,14 +33,14 @@ export declare const getWithFullscreenPropWrapperStyle: (spinning: boolean) => (
|
|
|
33
33
|
zIndex: number;
|
|
34
34
|
};
|
|
35
35
|
export declare const withChildrenPropWrapperStyle: (theme: Theme) => {
|
|
36
|
-
justifyContent: string;
|
|
37
|
-
display: "inline-flex";
|
|
38
|
-
flexDirection: "column";
|
|
39
|
-
alignItems: "center";
|
|
40
|
-
rowGap: 4;
|
|
41
|
-
inset: number;
|
|
42
|
-
position:
|
|
43
|
-
zIndex:
|
|
36
|
+
readonly justifyContent: string;
|
|
37
|
+
readonly display: "inline-flex";
|
|
38
|
+
readonly flexDirection: "column";
|
|
39
|
+
readonly alignItems: "center";
|
|
40
|
+
readonly rowGap: 4;
|
|
41
|
+
readonly inset: number;
|
|
42
|
+
readonly position: "absolute";
|
|
43
|
+
readonly zIndex: 1;
|
|
44
44
|
};
|
|
45
45
|
export declare const getSpinWrapperStyle: (spinTokens: SpinTokens, size: SpinSize) => {
|
|
46
46
|
display: string;
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import { PropsWithChildren, ReactNode } from 'react';
|
|
2
|
+
import { Theme } from '../../themes';
|
|
3
|
+
import { Interpolation } from '@emotion/react';
|
|
2
4
|
export interface SpinProps extends PropsWithChildren {
|
|
3
5
|
delay?: number;
|
|
4
6
|
fullscreen?: boolean;
|
|
@@ -6,6 +8,9 @@ export interface SpinProps extends PropsWithChildren {
|
|
|
6
8
|
variant?: "base" | "white";
|
|
7
9
|
spinning?: boolean;
|
|
8
10
|
tip?: ReactNode;
|
|
11
|
+
styles?: {
|
|
12
|
+
withChildrenPropWrapperStyle?: (theme: Theme) => Interpolation;
|
|
13
|
+
};
|
|
9
14
|
}
|
|
10
15
|
export type SpinVariant = "base" | "white";
|
|
11
16
|
export type SpinSize = "small" | "middle" | "large";
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { jsxs, Fragment
|
|
1
|
+
import { jsx, jsxs, Fragment } from "@emotion/react/jsx-runtime";
|
|
2
2
|
import { memo, forwardRef, useMemo, Fragment as Fragment$1 } from "react";
|
|
3
3
|
import { Header } from "./components/Header/Header.js";
|
|
4
4
|
import { Body } from "./components/Body/Body.js";
|
|
@@ -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, isObject } from "lodash-es";
|
|
11
|
+
import { isNil, isObject, isUndefined, isBoolean } from "lodash-es";
|
|
12
12
|
import { getTableComponentWrapperStyle, getTableComponentStyle, tableStyle } from "./Table.styles.js";
|
|
13
13
|
import { getTableTokens } from "./Table.tokens.js";
|
|
14
14
|
import { withTableStaticContext } from "./features/tableStaticContext/hocs/withTableStaticContext.js";
|
|
@@ -22,6 +22,7 @@ import { useTableRowSelection } from "./features/tableRowSelection/hooks/useTabl
|
|
|
22
22
|
import { useTableVisualParamsChange } from "./hooks/useTableVisualParamsChange/useTableVisualParamsChange.js";
|
|
23
23
|
import { updateRefValue } from "./utils/ref/ref.js";
|
|
24
24
|
import { TableRowSelectionContext } from "./features/tableRowSelection/contexts/tableRowSelectionContext/TableRowSelectionContext.js";
|
|
25
|
+
import { Spin } from "../Spin/Spin.js";
|
|
25
26
|
import { defaultSortDirections } from "./features/tableSort/utils/const.js";
|
|
26
27
|
import { createTableContext } from "./contexts/tableContext/TableContext.js";
|
|
27
28
|
const TableComponent = (props, ref) => {
|
|
@@ -35,6 +36,7 @@ const TableComponent = (props, ref) => {
|
|
|
35
36
|
sortDirections = defaultSortDirections,
|
|
36
37
|
scroll,
|
|
37
38
|
showHeader = true,
|
|
39
|
+
loading = false,
|
|
38
40
|
tableLayout: tableLayoutProp,
|
|
39
41
|
bordered: borderedProp,
|
|
40
42
|
styles,
|
|
@@ -192,10 +194,10 @@ const TableComponent = (props, ref) => {
|
|
|
192
194
|
});
|
|
193
195
|
const TableComponent2 = getComponent(["table"], "table");
|
|
194
196
|
const bodyColGroup = /* @__PURE__ */ jsx(BodyColGroup, {});
|
|
195
|
-
const bodyTable = /* @__PURE__ */ jsx(Body, { expandable, sortedData, needMeasureColumnWidth: fixHeader || fixColumn });
|
|
197
|
+
const bodyTable = /* @__PURE__ */ jsx(Body, { expandable, sortedData, needMeasureColumnWidth: fixHeader || fixColumn, renderNullifyBody: isUndefined(dataSource) });
|
|
196
198
|
const groupTableNode = fixHeader ? /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
197
199
|
showHeader && /* @__PURE__ */ jsx(FixedHeader, { ref: tableHeaderRef, scrollX, onScroll: onTableHeaderScroll }),
|
|
198
|
-
/* @__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":"AAmPQ","file":"/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx","sourcesContent":["import { forwardRef, memo, useMemo, type ForwardedRef, Fragment } from \"react\";\nimport type { BorderedConfig, DefaultRecord, TableLayout, TableProps } from \"./Table.types\";\nimport { Header } from \"./components/Header/Header\";\nimport { Body } from \"./components/Body/Body\";\nimport { useTableComponents } from \"./hooks/useTableComponents\";\nimport { useTableColumns } from \"./hooks/useTableColumns\";\nimport { useTableExpand } from \"./features/tableExpand\";\nimport { defaultSortDirections, useTableSort } from \"./features/tableSort\";\nimport { useStatic } from \"hooks/useStatic\";\nimport ResizeObserver from \"rc-resize-observer\";\nimport { FixedHeader } from \"./components/FixedHeader/FixedHeader\";\nimport { BodyColGroup } from \"./components/Body/components/BodyColGroup/BodyColGroup\";\nimport { updateRefValue } from \"./utils\";\nimport { withEventBus } from \"utils/eventBus/hocs/withEventBus\";\nimport { useFirstMount } from \"hooks/useFirstMount\";\nimport { useTableVisualParamsChange } from \"./hooks/useTableVisualParamsChange\";\nimport { isNil, isObject } 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\";\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    tableLayout: tableLayoutProp,\n    bordered: borderedProp,\n    styles,\n    footer,\n    onHeaderRow,\n    onRow,\n    onChange,\n    onScroll,\n  } = props;\n  const theme = useTheme();\n  const tableTokens = useMemo(() => getTableTokens(theme), [theme]);\n  const isTableFirstMount = useFirstMount();\n  const { getComponent } = useTableComponents({ components: componentsProp });\n  const staticContextRef = useTableStaticContext<Record>();\n\n  const { columns, flattedColumns, isAllColumnsFixedStart } = useTableColumns({\n    columns: columnsProp,\n    rowSelection,\n  });\n\n  const scrollX = scroll?.x;\n  const scrollY = scroll?.y;\n  const fixHeader = !isNil(scrollY);\n  const horizonScroll = !isNil(scrollX);\n  const fixColumn = horizonScroll && flattedColumns.some(({ fixed }) => fixed);\n\n  const { expandIconColumnIndex, indentSize, ExpandIcon, isSomeRecordHasChildren } =\n    useTableExpand<Record>({ expandable, dataSource, rowSelection });\n\n  const { sortState, sortedData, hasData, triggerSorter } = useTableSort<Record>({\n    dataSource,\n    onChange,\n  });\n\n  const {\n    keySet,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    flattedData,\n    checkboxPropsMap,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    derivedHalfSelectedKeySet,\n    recordKeys,\n    triggerSingleSelection,\n    setSelectedKeys,\n    multipleSelect,\n    updatePrevSelectedIndex,\n  } = useTableRowSelection<Record>({\n    rowSelection,\n    dataSource,\n    sortedData,\n  });\n  const {\n    tableHeaderRef,\n    scrollableTableSectionRef,\n    onTableContentScroll,\n    onTableHeaderScroll,\n    onTableBodyScroll,\n    onResize,\n  } = useTableVisualParamsChange({\n    fixColumn,\n    onScroll,\n  });\n\n  const tableLayout = useMemo<TableLayout>(() => {\n    if (tableLayoutProp) {\n      return tableLayoutProp;\n    }\n\n    if (fixColumn) {\n      return scrollX === \"max-content\" ? \"auto\" : \"fixed\";\n    }\n\n    if (fixHeader || flattedColumns.some(({ ellipsis }) => ellipsis)) {\n      return \"fixed\";\n    }\n\n    return \"auto\";\n  }, [fixColumn, fixHeader, flattedColumns, scrollX, tableLayoutProp]);\n\n  const bordered = useMemo(() => {\n    if (borderedProp === true || isObject(borderedProp)) {\n      const defaultBorderedConfig: Required<BorderedConfig> = {\n        emptyBlockEnd: true,\n        emptyInline: true,\n        firstColumnCellInlineStart: true,\n        lastColumnCellInlineEnd: true,\n      };\n\n      return {\n        ...defaultBorderedConfig,\n        ...(isObject(borderedProp) ? borderedProp : {}),\n      };\n    }\n\n    return borderedProp;\n  }, [borderedProp]);\n\n  const TableContext = useStatic(() => createTableContext<Record>());\n  const tableContextValue = useMemo<TableContextValue<Record>>(() => {\n    return {\n      showHeader,\n\n      tableTokens,\n\n      getComponent,\n\n      columns,\n      flattedColumns,\n      isAllColumnsFixedStart,\n\n      expandIconColumnIndex,\n      ExpandIcon,\n      indentSize,\n      isSomeRecordHasChildren,\n\n      sortDirections,\n\n      onHeaderRow,\n      onRow,\n\n      tableLayout,\n\n      bordered,\n      horizonScroll,\n    };\n  }, [\n    ExpandIcon,\n    bordered,\n    columns,\n    expandIconColumnIndex,\n    flattedColumns,\n    getComponent,\n    horizonScroll,\n    indentSize,\n    isAllColumnsFixedStart,\n    isSomeRecordHasChildren,\n    onHeaderRow,\n    onRow,\n    showHeader,\n    sortDirections,\n    tableLayout,\n    tableTokens,\n  ]);\n\n  const tableRowSelectionContextValue = useMemo<TableRowSelectionContextValue>(() => {\n    return {\n      keySet,\n      checkedCurrentAll,\n      checkedCurrentSome,\n      flattedData,\n      checkboxPropsMap,\n      derivedHalfSelectedKeySet,\n      derivedSelectedKeySet,\n      derivedSelectedKeys,\n      recordKeys,\n      setSelectedKeys,\n      triggerSingleSelection,\n      multipleSelect,\n      updatePrevSelectedIndex,\n    };\n  }, [\n    checkboxPropsMap,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    derivedHalfSelectedKeySet,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    flattedData,\n    keySet,\n    multipleSelect,\n    recordKeys,\n    setSelectedKeys,\n    triggerSingleSelection,\n    updatePrevSelectedIndex,\n  ]);\n\n  updateRefValue(staticContextRef, {\n    staticSelectedKeySet: derivedSelectedKeySet,\n    triggerSorter,\n    sortState,\n    isTableFirstMount,\n  });\n\n  const TableComponent = getComponent([\"table\"], \"table\");\n  const bodyColGroup = <BodyColGroup />;\n  const bodyTable = (\n    <Body<Record>\n      expandable={expandable}\n      sortedData={sortedData}\n      needMeasureColumnWidth={fixHeader || fixColumn}\n    />\n  );\n\n  const groupTableNode = fixHeader ? (\n    <>\n      {showHeader && (\n        <FixedHeader ref={tableHeaderRef} scrollX={scrollX} onScroll={onTableHeaderScroll} />\n      )}\n      <div\n        className=\"rc-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, hasData, scrollY, horizonScroll),\n          styles?.tableBodyComponentWrapper?.(tableTokens, theme),\n        ]}\n        onScroll={onTableBodyScroll}\n        ref={scrollableTableSectionRef}\n      >\n        <TableComponent css={getTableComponentStyle(\"body\", tableLayout, scrollX, horizonScroll)}>\n          {bodyColGroup}\n          {bodyTable}\n        </TableComponent>\n      </div>\n    </>\n  ) : (\n    <div\n      className=\"rc-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, hasData, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent css={getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll)}>\n        {bodyColGroup}\n        {showHeader && <Header />}\n        {bodyTable}\n      </TableComponent>\n    </div>\n  );\n\n  const TableWrapper = horizonScroll ? ResizeObserver : Fragment;\n\n  return (\n    <TableContext.Provider value={tableContextValue}>\n      <TableRowSelectionContext.Provider value={tableRowSelectionContextValue}>\n        <TableWrapper {...(horizonScroll ? { onResize } : {})}>\n          <div className=\"rc-table\" css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}>\n            <div\n              ref={ref}\n              className=\"rc-table-container\"\n              css={styles?.tableContainer?.(tableTokens, theme)}\n            >\n              {groupTableNode}\n            </div>\n            {footer?.(sortedData)}\n          </div>\n        </TableWrapper>\n      </TableRowSelectionContext.Provider>\n    </TableContext.Provider>\n  );\n};\n\nexport const Table = withEventBus(withTableStaticContext(memo(forwardRef(TableComponent)))) as <\n  Record extends DefaultRecord,\n>(\n  props: TableProps<Record> & { ref?: ForwardedRef<HTMLDivElement> }\n) => ReturnType<typeof TableComponent>;\n"]} */"], onScroll: onTableBodyScroll, ref: scrollableTableSectionRef, children: /* @__PURE__ */ jsxs(TableComponent2, { css: getTableComponentStyle("body", tableLayout, scrollX, horizonScroll), children: [
|
|
200
|
+
/* @__PURE__ */ jsx("div", { className: "rc-table-body", css: [getTableComponentWrapperStyle("body", fixHeader, hasData, scrollY, horizonScroll), (_a = styles == null ? void 0 : styles.tableBodyComponentWrapper) == null ? void 0 : _a.call(styles, tableTokens, theme), process.env.NODE_ENV === "production" ? "" : ";label:groupTableNode;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx"],"names":[],"mappings":"AAsPQ","file":"/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx","sourcesContent":["import { forwardRef, memo, useMemo, type ForwardedRef, Fragment } from \"react\";\nimport type { BorderedConfig, DefaultRecord, TableLayout, TableProps } from \"./Table.types\";\nimport { Header } from \"./components/Header/Header\";\nimport { Body } from \"./components/Body/Body\";\nimport { useTableComponents } from \"./hooks/useTableComponents\";\nimport { useTableColumns } from \"./hooks/useTableColumns\";\nimport { useTableExpand } from \"./features/tableExpand\";\nimport { defaultSortDirections, useTableSort } from \"./features/tableSort\";\nimport { useStatic } from \"hooks/useStatic\";\nimport ResizeObserver from \"rc-resize-observer\";\nimport { FixedHeader } from \"./components/FixedHeader/FixedHeader\";\nimport { BodyColGroup } from \"./components/Body/components/BodyColGroup/BodyColGroup\";\nimport { updateRefValue } from \"./utils\";\nimport { withEventBus } from \"utils/eventBus/hocs/withEventBus\";\nimport { useFirstMount } from \"hooks/useFirstMount\";\nimport { useTableVisualParamsChange } from \"./hooks/useTableVisualParamsChange\";\nimport { isBoolean, isNil, isObject, isUndefined } from \"lodash-es\";\nimport { getTableComponentStyle, getTableComponentWrapperStyle, tableStyle } from \"./Table.styles\";\nimport { useTableStaticContext, withTableStaticContext } from \"./features/tableStaticContext\";\nimport { createTableContext, type TableContextValue } from \"./contexts\";\nimport {\n  useTableRowSelection,\n  TableRowSelectionContext,\n  type TableRowSelectionContextValue,\n} from \"./features/tableRowSelection\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { getTableTokens } from \"./Table.tokens\";\nimport { Spin, type SpinProps } from \"components/Spin\";\n\nconst TableComponent = <Record extends DefaultRecord>(\n  props: TableProps<Record>,\n  ref: ForwardedRef<HTMLDivElement>\n) => {\n  const {\n    columns: columnsProp,\n    dataSource,\n    components: componentsProp,\n    expandable,\n    rowSelection,\n    sortDirections = defaultSortDirections,\n    scroll,\n    showHeader = true,\n    loading = false,\n    tableLayout: tableLayoutProp,\n    bordered: borderedProp,\n    styles,\n    footer,\n    onHeaderRow,\n    onRow,\n    onChange,\n    onScroll,\n  } = props;\n  const theme = useTheme();\n  const tableTokens = useMemo(() => getTableTokens(theme), [theme]);\n  const isTableFirstMount = useFirstMount();\n  const { getComponent } = useTableComponents({ components: componentsProp });\n  const staticContextRef = useTableStaticContext<Record>();\n\n  const { columns, flattedColumns, isAllColumnsFixedStart } = useTableColumns({\n    columns: columnsProp,\n    rowSelection,\n  });\n\n  const scrollX = scroll?.x;\n  const scrollY = scroll?.y;\n  const fixHeader = !isNil(scrollY);\n  const horizonScroll = !isNil(scrollX);\n  const fixColumn = horizonScroll && flattedColumns.some(({ fixed }) => fixed);\n\n  const { expandIconColumnIndex, indentSize, ExpandIcon, isSomeRecordHasChildren } =\n    useTableExpand<Record>({ expandable, dataSource, rowSelection });\n\n  const { sortState, sortedData, hasData, triggerSorter } = useTableSort<Record>({\n    dataSource,\n    onChange,\n  });\n\n  const {\n    keySet,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    flattedData,\n    checkboxPropsMap,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    derivedHalfSelectedKeySet,\n    recordKeys,\n    triggerSingleSelection,\n    setSelectedKeys,\n    multipleSelect,\n    updatePrevSelectedIndex,\n  } = useTableRowSelection<Record>({\n    rowSelection,\n    dataSource,\n    sortedData,\n  });\n  const {\n    tableHeaderRef,\n    scrollableTableSectionRef,\n    onTableContentScroll,\n    onTableHeaderScroll,\n    onTableBodyScroll,\n    onResize,\n  } = useTableVisualParamsChange({\n    fixColumn,\n    onScroll,\n  });\n\n  const tableLayout = useMemo<TableLayout>(() => {\n    if (tableLayoutProp) {\n      return tableLayoutProp;\n    }\n\n    if (fixColumn) {\n      return scrollX === \"max-content\" ? \"auto\" : \"fixed\";\n    }\n\n    if (fixHeader || flattedColumns.some(({ ellipsis }) => ellipsis)) {\n      return \"fixed\";\n    }\n\n    return \"auto\";\n  }, [fixColumn, fixHeader, flattedColumns, scrollX, tableLayoutProp]);\n\n  const bordered = useMemo(() => {\n    if (borderedProp === true || isObject(borderedProp)) {\n      const defaultBorderedConfig: Required<BorderedConfig> = {\n        emptyBlockEnd: true,\n        emptyInline: true,\n        firstColumnCellInlineStart: true,\n        lastColumnCellInlineEnd: true,\n      };\n\n      return {\n        ...defaultBorderedConfig,\n        ...(isObject(borderedProp) ? borderedProp : {}),\n      };\n    }\n\n    return borderedProp;\n  }, [borderedProp]);\n\n  const TableContext = useStatic(() => createTableContext<Record>());\n  const tableContextValue = useMemo<TableContextValue<Record>>(() => {\n    return {\n      showHeader,\n\n      tableTokens,\n\n      getComponent,\n\n      columns,\n      flattedColumns,\n      isAllColumnsFixedStart,\n\n      expandIconColumnIndex,\n      ExpandIcon,\n      indentSize,\n      isSomeRecordHasChildren,\n\n      sortDirections,\n\n      onHeaderRow,\n      onRow,\n\n      tableLayout,\n\n      bordered,\n      horizonScroll,\n    };\n  }, [\n    ExpandIcon,\n    bordered,\n    columns,\n    expandIconColumnIndex,\n    flattedColumns,\n    getComponent,\n    horizonScroll,\n    indentSize,\n    isAllColumnsFixedStart,\n    isSomeRecordHasChildren,\n    onHeaderRow,\n    onRow,\n    showHeader,\n    sortDirections,\n    tableLayout,\n    tableTokens,\n  ]);\n\n  const tableRowSelectionContextValue = useMemo<TableRowSelectionContextValue>(() => {\n    return {\n      keySet,\n      checkedCurrentAll,\n      checkedCurrentSome,\n      flattedData,\n      checkboxPropsMap,\n      derivedHalfSelectedKeySet,\n      derivedSelectedKeySet,\n      derivedSelectedKeys,\n      recordKeys,\n      setSelectedKeys,\n      triggerSingleSelection,\n      multipleSelect,\n      updatePrevSelectedIndex,\n    };\n  }, [\n    checkboxPropsMap,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    derivedHalfSelectedKeySet,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    flattedData,\n    keySet,\n    multipleSelect,\n    recordKeys,\n    setSelectedKeys,\n    triggerSingleSelection,\n    updatePrevSelectedIndex,\n  ]);\n\n  updateRefValue(staticContextRef, {\n    staticSelectedKeySet: derivedSelectedKeySet,\n    triggerSorter,\n    sortState,\n    isTableFirstMount,\n  });\n\n  const TableComponent = getComponent([\"table\"], \"table\");\n  const bodyColGroup = <BodyColGroup />;\n  const bodyTable = (\n    <Body<Record>\n      expandable={expandable}\n      sortedData={sortedData}\n      needMeasureColumnWidth={fixHeader || fixColumn}\n      renderNullifyBody={isUndefined(dataSource)}\n    />\n  );\n\n  const groupTableNode = fixHeader ? (\n    <>\n      {showHeader && (\n        <FixedHeader ref={tableHeaderRef} scrollX={scrollX} onScroll={onTableHeaderScroll} />\n      )}\n      <div\n        className=\"rc-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, hasData, scrollY, horizonScroll),\n          styles?.tableBodyComponentWrapper?.(tableTokens, theme),\n        ]}\n        onScroll={onTableBodyScroll}\n        ref={scrollableTableSectionRef}\n      >\n        <TableComponent css={getTableComponentStyle(\"body\", tableLayout, scrollX, horizonScroll)}>\n          {bodyColGroup}\n          {bodyTable}\n        </TableComponent>\n      </div>\n    </>\n  ) : (\n    <div\n      className=\"rc-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, hasData, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent css={getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll)}>\n        {bodyColGroup}\n        {showHeader && <Header />}\n        {bodyTable}\n      </TableComponent>\n    </div>\n  );\n\n  const TableWrapper = horizonScroll ? ResizeObserver : Fragment;\n\n  const spinProps = ((): SpinProps => {\n    if (isBoolean(loading)) {\n      return { spinning: loading };\n    }\n\n    return loading;\n  })();\n\n  return (\n    <TableContext.Provider value={tableContextValue}>\n      <TableRowSelectionContext.Provider value={tableRowSelectionContextValue}>\n        <TableWrapper {...(horizonScroll ? { onResize } : {})}>\n          <Spin {...spinProps}>\n            <div\n              className=\"rc-table\"\n              css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}\n            >\n              <div\n                ref={ref}\n                className=\"rc-table-container\"\n                css={styles?.tableContainer?.(tableTokens, theme)}\n              >\n                {groupTableNode}\n              </div>\n              {footer?.(sortedData)}\n            </div>\n          </Spin>\n        </TableWrapper>\n      </TableRowSelectionContext.Provider>\n    </TableContext.Provider>\n  );\n};\n\nexport const Table = withEventBus(withTableStaticContext(memo(forwardRef(TableComponent)))) as <\n  Record extends DefaultRecord,\n>(\n  props: TableProps<Record> & { ref?: ForwardedRef<HTMLDivElement> }\n) => ReturnType<typeof TableComponent>;\n"]} */"], onScroll: onTableBodyScroll, ref: scrollableTableSectionRef, children: /* @__PURE__ */ jsxs(TableComponent2, { css: getTableComponentStyle("body", tableLayout, scrollX, horizonScroll), children: [
|
|
199
201
|
bodyColGroup,
|
|
200
202
|
bodyTable
|
|
201
203
|
] }) })
|
|
@@ -205,12 +207,20 @@ const TableComponent = (props, ref) => {
|
|
|
205
207
|
bodyTable
|
|
206
208
|
] }) });
|
|
207
209
|
const TableWrapper = horizonScroll ? ResizeObserver : Fragment$1;
|
|
210
|
+
const spinProps = (() => {
|
|
211
|
+
if (isBoolean(loading)) {
|
|
212
|
+
return {
|
|
213
|
+
spinning: loading
|
|
214
|
+
};
|
|
215
|
+
}
|
|
216
|
+
return loading;
|
|
217
|
+
})();
|
|
208
218
|
return /* @__PURE__ */ jsx(TableContext.Provider, { value: tableContextValue, children: /* @__PURE__ */ jsx(TableRowSelectionContext.Provider, { value: tableRowSelectionContextValue, children: /* @__PURE__ */ jsx(TableWrapper, { ...horizonScroll ? {
|
|
209
219
|
onResize
|
|
210
|
-
} : {}, 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":"AAqRoC","file":"/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx","sourcesContent":["import { forwardRef, memo, useMemo, type ForwardedRef, Fragment } from \"react\";\nimport type { BorderedConfig, DefaultRecord, TableLayout, TableProps } from \"./Table.types\";\nimport { Header } from \"./components/Header/Header\";\nimport { Body } from \"./components/Body/Body\";\nimport { useTableComponents } from \"./hooks/useTableComponents\";\nimport { useTableColumns } from \"./hooks/useTableColumns\";\nimport { useTableExpand } from \"./features/tableExpand\";\nimport { defaultSortDirections, useTableSort } from \"./features/tableSort\";\nimport { useStatic } from \"hooks/useStatic\";\nimport ResizeObserver from \"rc-resize-observer\";\nimport { FixedHeader } from \"./components/FixedHeader/FixedHeader\";\nimport { BodyColGroup } from \"./components/Body/components/BodyColGroup/BodyColGroup\";\nimport { updateRefValue } from \"./utils\";\nimport { withEventBus } from \"utils/eventBus/hocs/withEventBus\";\nimport { useFirstMount } from \"hooks/useFirstMount\";\nimport { useTableVisualParamsChange } from \"./hooks/useTableVisualParamsChange\";\nimport { isNil, isObject } 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\";\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    tableLayout: tableLayoutProp,\n    bordered: borderedProp,\n    styles,\n    footer,\n    onHeaderRow,\n    onRow,\n    onChange,\n    onScroll,\n  } = props;\n  const theme = useTheme();\n  const tableTokens = useMemo(() => getTableTokens(theme), [theme]);\n  const isTableFirstMount = useFirstMount();\n  const { getComponent } = useTableComponents({ components: componentsProp });\n  const staticContextRef = useTableStaticContext<Record>();\n\n  const { columns, flattedColumns, isAllColumnsFixedStart } = useTableColumns({\n    columns: columnsProp,\n    rowSelection,\n  });\n\n  const scrollX = scroll?.x;\n  const scrollY = scroll?.y;\n  const fixHeader = !isNil(scrollY);\n  const horizonScroll = !isNil(scrollX);\n  const fixColumn = horizonScroll && flattedColumns.some(({ fixed }) => fixed);\n\n  const { expandIconColumnIndex, indentSize, ExpandIcon, isSomeRecordHasChildren } =\n    useTableExpand<Record>({ expandable, dataSource, rowSelection });\n\n  const { sortState, sortedData, hasData, triggerSorter } = useTableSort<Record>({\n    dataSource,\n    onChange,\n  });\n\n  const {\n    keySet,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    flattedData,\n    checkboxPropsMap,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    derivedHalfSelectedKeySet,\n    recordKeys,\n    triggerSingleSelection,\n    setSelectedKeys,\n    multipleSelect,\n    updatePrevSelectedIndex,\n  } = useTableRowSelection<Record>({\n    rowSelection,\n    dataSource,\n    sortedData,\n  });\n  const {\n    tableHeaderRef,\n    scrollableTableSectionRef,\n    onTableContentScroll,\n    onTableHeaderScroll,\n    onTableBodyScroll,\n    onResize,\n  } = useTableVisualParamsChange({\n    fixColumn,\n    onScroll,\n  });\n\n  const tableLayout = useMemo<TableLayout>(() => {\n    if (tableLayoutProp) {\n      return tableLayoutProp;\n    }\n\n    if (fixColumn) {\n      return scrollX === \"max-content\" ? \"auto\" : \"fixed\";\n    }\n\n    if (fixHeader || flattedColumns.some(({ ellipsis }) => ellipsis)) {\n      return \"fixed\";\n    }\n\n    return \"auto\";\n  }, [fixColumn, fixHeader, flattedColumns, scrollX, tableLayoutProp]);\n\n  const bordered = useMemo(() => {\n    if (borderedProp === true || isObject(borderedProp)) {\n      const defaultBorderedConfig: Required<BorderedConfig> = {\n        emptyBlockEnd: true,\n        emptyInline: true,\n        firstColumnCellInlineStart: true,\n        lastColumnCellInlineEnd: true,\n      };\n\n      return {\n        ...defaultBorderedConfig,\n        ...(isObject(borderedProp) ? borderedProp : {}),\n      };\n    }\n\n    return borderedProp;\n  }, [borderedProp]);\n\n  const TableContext = useStatic(() => createTableContext<Record>());\n  const tableContextValue = useMemo<TableContextValue<Record>>(() => {\n    return {\n      showHeader,\n\n      tableTokens,\n\n      getComponent,\n\n      columns,\n      flattedColumns,\n      isAllColumnsFixedStart,\n\n      expandIconColumnIndex,\n      ExpandIcon,\n      indentSize,\n      isSomeRecordHasChildren,\n\n      sortDirections,\n\n      onHeaderRow,\n      onRow,\n\n      tableLayout,\n\n      bordered,\n      horizonScroll,\n    };\n  }, [\n    ExpandIcon,\n    bordered,\n    columns,\n    expandIconColumnIndex,\n    flattedColumns,\n    getComponent,\n    horizonScroll,\n    indentSize,\n    isAllColumnsFixedStart,\n    isSomeRecordHasChildren,\n    onHeaderRow,\n    onRow,\n    showHeader,\n    sortDirections,\n    tableLayout,\n    tableTokens,\n  ]);\n\n  const tableRowSelectionContextValue = useMemo<TableRowSelectionContextValue>(() => {\n    return {\n      keySet,\n      checkedCurrentAll,\n      checkedCurrentSome,\n      flattedData,\n      checkboxPropsMap,\n      derivedHalfSelectedKeySet,\n      derivedSelectedKeySet,\n      derivedSelectedKeys,\n      recordKeys,\n      setSelectedKeys,\n      triggerSingleSelection,\n      multipleSelect,\n      updatePrevSelectedIndex,\n    };\n  }, [\n    checkboxPropsMap,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    derivedHalfSelectedKeySet,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    flattedData,\n    keySet,\n    multipleSelect,\n    recordKeys,\n    setSelectedKeys,\n    triggerSingleSelection,\n    updatePrevSelectedIndex,\n  ]);\n\n  updateRefValue(staticContextRef, {\n    staticSelectedKeySet: derivedSelectedKeySet,\n    triggerSorter,\n    sortState,\n    isTableFirstMount,\n  });\n\n  const TableComponent = getComponent([\"table\"], \"table\");\n  const bodyColGroup = <BodyColGroup />;\n  const bodyTable = (\n    <Body<Record>\n      expandable={expandable}\n      sortedData={sortedData}\n      needMeasureColumnWidth={fixHeader || fixColumn}\n    />\n  );\n\n  const groupTableNode = fixHeader ? (\n    <>\n      {showHeader && (\n        <FixedHeader ref={tableHeaderRef} scrollX={scrollX} onScroll={onTableHeaderScroll} />\n      )}\n      <div\n        className=\"rc-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, hasData, scrollY, horizonScroll),\n          styles?.tableBodyComponentWrapper?.(tableTokens, theme),\n        ]}\n        onScroll={onTableBodyScroll}\n        ref={scrollableTableSectionRef}\n      >\n        <TableComponent css={getTableComponentStyle(\"body\", tableLayout, scrollX, horizonScroll)}>\n          {bodyColGroup}\n          {bodyTable}\n        </TableComponent>\n      </div>\n    </>\n  ) : (\n    <div\n      className=\"rc-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, hasData, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent css={getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll)}>\n        {bodyColGroup}\n        {showHeader && <Header />}\n        {bodyTable}\n      </TableComponent>\n    </div>\n  );\n\n  const TableWrapper = horizonScroll ? ResizeObserver : Fragment;\n\n  return (\n    <TableContext.Provider value={tableContextValue}>\n      <TableRowSelectionContext.Provider value={tableRowSelectionContextValue}>\n        <TableWrapper {...(horizonScroll ? { onResize } : {})}>\n          <div className=\"rc-table\" css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}>\n            <div\n              ref={ref}\n              className=\"rc-table-container\"\n              css={styles?.tableContainer?.(tableTokens, theme)}\n            >\n              {groupTableNode}\n            </div>\n            {footer?.(sortedData)}\n          </div>\n        </TableWrapper>\n      </TableRowSelectionContext.Provider>\n    </TableContext.Provider>\n  );\n};\n\nexport const Table = withEventBus(withTableStaticContext(memo(forwardRef(TableComponent)))) as <\n  Record extends DefaultRecord,\n>(\n  props: TableProps<Record> & { ref?: ForwardedRef<HTMLDivElement> }\n) => ReturnType<typeof TableComponent>;\n"]} */"], children: [
|
|
220
|
+
} : {}, children: /* @__PURE__ */ jsx(Spin, { ...spinProps, children: /* @__PURE__ */ jsxs("div", { className: "rc-table", css: [tableStyle(theme), (_b = styles == null ? void 0 : styles.table) == null ? void 0 : _b.call(styles, tableTokens, theme), process.env.NODE_ENV === "production" ? "" : ";label:TableComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx"],"names":[],"mappings":"AAmSc","file":"/builds/frontend/libs/ui-kit/src/components/Table/Table.tsx","sourcesContent":["import { forwardRef, memo, useMemo, type ForwardedRef, Fragment } from \"react\";\nimport type { BorderedConfig, DefaultRecord, TableLayout, TableProps } from \"./Table.types\";\nimport { Header } from \"./components/Header/Header\";\nimport { Body } from \"./components/Body/Body\";\nimport { useTableComponents } from \"./hooks/useTableComponents\";\nimport { useTableColumns } from \"./hooks/useTableColumns\";\nimport { useTableExpand } from \"./features/tableExpand\";\nimport { defaultSortDirections, useTableSort } from \"./features/tableSort\";\nimport { useStatic } from \"hooks/useStatic\";\nimport ResizeObserver from \"rc-resize-observer\";\nimport { FixedHeader } from \"./components/FixedHeader/FixedHeader\";\nimport { BodyColGroup } from \"./components/Body/components/BodyColGroup/BodyColGroup\";\nimport { updateRefValue } from \"./utils\";\nimport { withEventBus } from \"utils/eventBus/hocs/withEventBus\";\nimport { useFirstMount } from \"hooks/useFirstMount\";\nimport { useTableVisualParamsChange } from \"./hooks/useTableVisualParamsChange\";\nimport { isBoolean, isNil, isObject, isUndefined } from \"lodash-es\";\nimport { getTableComponentStyle, getTableComponentWrapperStyle, tableStyle } from \"./Table.styles\";\nimport { useTableStaticContext, withTableStaticContext } from \"./features/tableStaticContext\";\nimport { createTableContext, type TableContextValue } from \"./contexts\";\nimport {\n  useTableRowSelection,\n  TableRowSelectionContext,\n  type TableRowSelectionContextValue,\n} from \"./features/tableRowSelection\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { getTableTokens } from \"./Table.tokens\";\nimport { Spin, type SpinProps } from \"components/Spin\";\n\nconst TableComponent = <Record extends DefaultRecord>(\n  props: TableProps<Record>,\n  ref: ForwardedRef<HTMLDivElement>\n) => {\n  const {\n    columns: columnsProp,\n    dataSource,\n    components: componentsProp,\n    expandable,\n    rowSelection,\n    sortDirections = defaultSortDirections,\n    scroll,\n    showHeader = true,\n    loading = false,\n    tableLayout: tableLayoutProp,\n    bordered: borderedProp,\n    styles,\n    footer,\n    onHeaderRow,\n    onRow,\n    onChange,\n    onScroll,\n  } = props;\n  const theme = useTheme();\n  const tableTokens = useMemo(() => getTableTokens(theme), [theme]);\n  const isTableFirstMount = useFirstMount();\n  const { getComponent } = useTableComponents({ components: componentsProp });\n  const staticContextRef = useTableStaticContext<Record>();\n\n  const { columns, flattedColumns, isAllColumnsFixedStart } = useTableColumns({\n    columns: columnsProp,\n    rowSelection,\n  });\n\n  const scrollX = scroll?.x;\n  const scrollY = scroll?.y;\n  const fixHeader = !isNil(scrollY);\n  const horizonScroll = !isNil(scrollX);\n  const fixColumn = horizonScroll && flattedColumns.some(({ fixed }) => fixed);\n\n  const { expandIconColumnIndex, indentSize, ExpandIcon, isSomeRecordHasChildren } =\n    useTableExpand<Record>({ expandable, dataSource, rowSelection });\n\n  const { sortState, sortedData, hasData, triggerSorter } = useTableSort<Record>({\n    dataSource,\n    onChange,\n  });\n\n  const {\n    keySet,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    flattedData,\n    checkboxPropsMap,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    derivedHalfSelectedKeySet,\n    recordKeys,\n    triggerSingleSelection,\n    setSelectedKeys,\n    multipleSelect,\n    updatePrevSelectedIndex,\n  } = useTableRowSelection<Record>({\n    rowSelection,\n    dataSource,\n    sortedData,\n  });\n  const {\n    tableHeaderRef,\n    scrollableTableSectionRef,\n    onTableContentScroll,\n    onTableHeaderScroll,\n    onTableBodyScroll,\n    onResize,\n  } = useTableVisualParamsChange({\n    fixColumn,\n    onScroll,\n  });\n\n  const tableLayout = useMemo<TableLayout>(() => {\n    if (tableLayoutProp) {\n      return tableLayoutProp;\n    }\n\n    if (fixColumn) {\n      return scrollX === \"max-content\" ? \"auto\" : \"fixed\";\n    }\n\n    if (fixHeader || flattedColumns.some(({ ellipsis }) => ellipsis)) {\n      return \"fixed\";\n    }\n\n    return \"auto\";\n  }, [fixColumn, fixHeader, flattedColumns, scrollX, tableLayoutProp]);\n\n  const bordered = useMemo(() => {\n    if (borderedProp === true || isObject(borderedProp)) {\n      const defaultBorderedConfig: Required<BorderedConfig> = {\n        emptyBlockEnd: true,\n        emptyInline: true,\n        firstColumnCellInlineStart: true,\n        lastColumnCellInlineEnd: true,\n      };\n\n      return {\n        ...defaultBorderedConfig,\n        ...(isObject(borderedProp) ? borderedProp : {}),\n      };\n    }\n\n    return borderedProp;\n  }, [borderedProp]);\n\n  const TableContext = useStatic(() => createTableContext<Record>());\n  const tableContextValue = useMemo<TableContextValue<Record>>(() => {\n    return {\n      showHeader,\n\n      tableTokens,\n\n      getComponent,\n\n      columns,\n      flattedColumns,\n      isAllColumnsFixedStart,\n\n      expandIconColumnIndex,\n      ExpandIcon,\n      indentSize,\n      isSomeRecordHasChildren,\n\n      sortDirections,\n\n      onHeaderRow,\n      onRow,\n\n      tableLayout,\n\n      bordered,\n      horizonScroll,\n    };\n  }, [\n    ExpandIcon,\n    bordered,\n    columns,\n    expandIconColumnIndex,\n    flattedColumns,\n    getComponent,\n    horizonScroll,\n    indentSize,\n    isAllColumnsFixedStart,\n    isSomeRecordHasChildren,\n    onHeaderRow,\n    onRow,\n    showHeader,\n    sortDirections,\n    tableLayout,\n    tableTokens,\n  ]);\n\n  const tableRowSelectionContextValue = useMemo<TableRowSelectionContextValue>(() => {\n    return {\n      keySet,\n      checkedCurrentAll,\n      checkedCurrentSome,\n      flattedData,\n      checkboxPropsMap,\n      derivedHalfSelectedKeySet,\n      derivedSelectedKeySet,\n      derivedSelectedKeys,\n      recordKeys,\n      setSelectedKeys,\n      triggerSingleSelection,\n      multipleSelect,\n      updatePrevSelectedIndex,\n    };\n  }, [\n    checkboxPropsMap,\n    checkedCurrentAll,\n    checkedCurrentSome,\n    derivedHalfSelectedKeySet,\n    derivedSelectedKeySet,\n    derivedSelectedKeys,\n    flattedData,\n    keySet,\n    multipleSelect,\n    recordKeys,\n    setSelectedKeys,\n    triggerSingleSelection,\n    updatePrevSelectedIndex,\n  ]);\n\n  updateRefValue(staticContextRef, {\n    staticSelectedKeySet: derivedSelectedKeySet,\n    triggerSorter,\n    sortState,\n    isTableFirstMount,\n  });\n\n  const TableComponent = getComponent([\"table\"], \"table\");\n  const bodyColGroup = <BodyColGroup />;\n  const bodyTable = (\n    <Body<Record>\n      expandable={expandable}\n      sortedData={sortedData}\n      needMeasureColumnWidth={fixHeader || fixColumn}\n      renderNullifyBody={isUndefined(dataSource)}\n    />\n  );\n\n  const groupTableNode = fixHeader ? (\n    <>\n      {showHeader && (\n        <FixedHeader ref={tableHeaderRef} scrollX={scrollX} onScroll={onTableHeaderScroll} />\n      )}\n      <div\n        className=\"rc-table-body\"\n        css={[\n          getTableComponentWrapperStyle(\"body\", fixHeader, hasData, scrollY, horizonScroll),\n          styles?.tableBodyComponentWrapper?.(tableTokens, theme),\n        ]}\n        onScroll={onTableBodyScroll}\n        ref={scrollableTableSectionRef}\n      >\n        <TableComponent css={getTableComponentStyle(\"body\", tableLayout, scrollX, horizonScroll)}>\n          {bodyColGroup}\n          {bodyTable}\n        </TableComponent>\n      </div>\n    </>\n  ) : (\n    <div\n      className=\"rc-table-content\"\n      css={getTableComponentWrapperStyle(\"content\", fixHeader, hasData, scrollY, horizonScroll)}\n      onScroll={onTableContentScroll}\n      ref={scrollableTableSectionRef}\n    >\n      <TableComponent css={getTableComponentStyle(\"content\", tableLayout, scrollX, horizonScroll)}>\n        {bodyColGroup}\n        {showHeader && <Header />}\n        {bodyTable}\n      </TableComponent>\n    </div>\n  );\n\n  const TableWrapper = horizonScroll ? ResizeObserver : Fragment;\n\n  const spinProps = ((): SpinProps => {\n    if (isBoolean(loading)) {\n      return { spinning: loading };\n    }\n\n    return loading;\n  })();\n\n  return (\n    <TableContext.Provider value={tableContextValue}>\n      <TableRowSelectionContext.Provider value={tableRowSelectionContextValue}>\n        <TableWrapper {...(horizonScroll ? { onResize } : {})}>\n          <Spin {...spinProps}>\n            <div\n              className=\"rc-table\"\n              css={[tableStyle(theme), styles?.table?.(tableTokens, theme)]}\n            >\n              <div\n                ref={ref}\n                className=\"rc-table-container\"\n                css={styles?.tableContainer?.(tableTokens, theme)}\n              >\n                {groupTableNode}\n              </div>\n              {footer?.(sortedData)}\n            </div>\n          </Spin>\n        </TableWrapper>\n      </TableRowSelectionContext.Provider>\n    </TableContext.Provider>\n  );\n};\n\nexport const Table = withEventBus(withTableStaticContext(memo(forwardRef(TableComponent)))) as <\n  Record extends DefaultRecord,\n>(\n  props: TableProps<Record> & { ref?: ForwardedRef<HTMLDivElement> }\n) => ReturnType<typeof TableComponent>;\n"]} */"], children: [
|
|
211
221
|
/* @__PURE__ */ jsx("div", { ref, className: "rc-table-container", css: (_c = styles == null ? void 0 : styles.tableContainer) == null ? void 0 : _c.call(styles, tableTokens, theme), children: groupTableNode }),
|
|
212
222
|
footer == null ? void 0 : footer(sortedData)
|
|
213
|
-
] }) }) }) });
|
|
223
|
+
] }) }) }) }) });
|
|
214
224
|
};
|
|
215
225
|
const Table = withEventBus(withTableStaticContext(memo(forwardRef(TableComponent))));
|
|
216
226
|
export {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ComponentProps, CSSProperties,
|
|
1
|
+
import { ComponentProps, CSSProperties, ReactNode, UIEventHandler } 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';
|
|
@@ -7,7 +7,8 @@ import { ExpandableConfig } from './features/tableExpand';
|
|
|
7
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
|
+
export type Key = string | number;
|
|
11
12
|
export interface BorderedConfig {
|
|
12
13
|
emptyInline?: boolean;
|
|
13
14
|
emptyBlockEnd?: boolean;
|
|
@@ -19,8 +20,8 @@ export interface DefaultRecord<R extends DefaultRecord<R> = any> extends Record<
|
|
|
19
20
|
key: Key;
|
|
20
21
|
children?: R[];
|
|
21
22
|
}
|
|
22
|
-
export interface TableProps<Record extends DefaultRecord = DefaultRecord> {
|
|
23
|
-
dataSource
|
|
23
|
+
export interface TableProps<Record extends DefaultRecord | null = DefaultRecord> {
|
|
24
|
+
dataSource?: readonly Record[];
|
|
24
25
|
columns: Columns<Record>;
|
|
25
26
|
components?: TableComponents;
|
|
26
27
|
expandable?: ExpandableConfig<Record>;
|
|
@@ -43,6 +44,7 @@ export interface TableProps<Record extends DefaultRecord = DefaultRecord> {
|
|
|
43
44
|
tableBodyComponentWrapper?: GetStyle;
|
|
44
45
|
};
|
|
45
46
|
footer?: (data: readonly Record[]) => ReactNode;
|
|
47
|
+
loading?: boolean | Omit<SpinProps, "children" | "fullscreen">;
|
|
46
48
|
}
|
|
47
49
|
export type TableLayout = "auto" | "fixed";
|
|
48
50
|
export {};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { BodyProps } from './Body.types';
|
|
2
2
|
import { DefaultRecord } from '../../Table.types';
|
|
3
|
-
declare const BodyComponent: <Record extends DefaultRecord>(props: BodyProps<Record>) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
3
|
+
declare const BodyComponent: <Record extends DefaultRecord>(props: BodyProps<Record>) => import("@emotion/react/jsx-runtime").JSX.Element | undefined;
|
|
4
4
|
export declare const Body: <Record extends DefaultRecord>(props: BodyProps<Record>) => ReturnType<typeof BodyComponent>;
|
|
5
5
|
export {};
|
|
@@ -13,7 +13,8 @@ const BodyComponent = (props) => {
|
|
|
13
13
|
const {
|
|
14
14
|
sortedData,
|
|
15
15
|
needMeasureColumnWidth,
|
|
16
|
-
expandable
|
|
16
|
+
expandable,
|
|
17
|
+
renderNullifyBody
|
|
17
18
|
} = props;
|
|
18
19
|
const theme = useTheme();
|
|
19
20
|
const {
|
|
@@ -36,6 +37,9 @@ const BodyComponent = (props) => {
|
|
|
36
37
|
onTriggerExpand
|
|
37
38
|
}), [expandedKeys, onTriggerExpand]);
|
|
38
39
|
const BodyWrapperComponent = getComponent(["body", "wrapper"], "tbody");
|
|
40
|
+
if (renderNullifyBody) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
39
43
|
const rows = flattedData.length ? flattedData.map((item, idx) => {
|
|
40
44
|
const {
|
|
41
45
|
record,
|
|
@@ -3,4 +3,5 @@ import { DefaultRecord, TableProps } from 'components/Table/Table.types';
|
|
|
3
3
|
export interface BodyProps<Record extends DefaultRecord> extends Pick<TableProps<Record>, "expandable"> {
|
|
4
4
|
sortedData: ReturnType<typeof useTableSort<Record>>["sortedData"];
|
|
5
5
|
needMeasureColumnWidth?: boolean;
|
|
6
|
+
renderNullifyBody: boolean;
|
|
6
7
|
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
2
|
import { memo, useState } from "react";
|
|
3
3
|
import { BodyCell } from "../BodyCell/BodyCell.js";
|
|
4
|
+
import { useSubscribe } from "../../../../features/typedEventBus/hooks.js";
|
|
4
5
|
import { useTableContext } from "../../../../contexts/tableContext/useTableContext/useTableContext.js";
|
|
5
6
|
import { useTableStaticContext } from "../../../../features/tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
|
|
6
7
|
import { getRefValue } from "../../../../utils/ref/ref.js";
|
|
7
|
-
import { useSubscribe } from "../../../../features/typedEventBus/hooks.js";
|
|
8
8
|
const BodyRowComponent = (props) => {
|
|
9
9
|
const {
|
|
10
10
|
record,
|
|
@@ -3,10 +3,10 @@ import { useMemo, useCallback, useLayoutEffect, useRef } from "react";
|
|
|
3
3
|
import { MeasureCell } from "../MeasureCell/MeasureCell.js";
|
|
4
4
|
import ResizeObserver from "rc-resize-observer";
|
|
5
5
|
import { useEvent } from "../../../../../../hooks/useEvent/useEvent.js";
|
|
6
|
+
import { useEmitter } from "../../../../features/typedEventBus/hooks.js";
|
|
6
7
|
import { getColumnsKeys } from "./MeasureRow.utils.js";
|
|
7
8
|
import { useTableContext } from "../../../../contexts/tableContext/useTableContext/useTableContext.js";
|
|
8
9
|
import { useTableStaticContext } from "../../../../features/tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
|
|
9
|
-
import { useEmitter } from "../../../../features/typedEventBus/hooks.js";
|
|
10
10
|
import { getRefValue, updateRefValue } from "../../../../utils/ref/ref.js";
|
|
11
11
|
const MeasureRowComponent = () => {
|
|
12
12
|
const {
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
-
import { useContext, useState, useMemo } from "react";
|
|
2
|
+
import { memo, useContext, useState, useMemo } from "react";
|
|
3
|
+
import { useSubscribe } from "../../features/typedEventBus/hooks.js";
|
|
3
4
|
import { isUndefined, isObject, isNumber } from "lodash-es";
|
|
4
5
|
import { getCellStyle, getBorderedCellStyle, emptyWrapperStyle } from "./EmptyDataRow.styles.js";
|
|
5
6
|
import { getEndRangeInfo } from "./EmptyDataRow.utils.js";
|
|
@@ -7,7 +8,6 @@ import { ConfigContext } from "../../../ConfigProvider/contexts/ConfigContext.js
|
|
|
7
8
|
import { useTableContext } from "../../contexts/tableContext/useTableContext/useTableContext.js";
|
|
8
9
|
import { useTableStaticContext } from "../../features/tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
|
|
9
10
|
import { getRefValue } from "../../utils/ref/ref.js";
|
|
10
|
-
import { useSubscribe } from "../../features/typedEventBus/hooks.js";
|
|
11
11
|
import { Empty } from "../../../Empty/Empty.js";
|
|
12
12
|
const EmptyDataRowComponent = () => {
|
|
13
13
|
const {
|
|
@@ -58,12 +58,12 @@ const EmptyDataRowComponent = () => {
|
|
|
58
58
|
const hasBlockEndBorder = !isObject(bordered) || Boolean(bordered && bordered.emptyBlockEnd);
|
|
59
59
|
return /* @__PURE__ */ jsx("tr", { children: /* @__PURE__ */ jsx("td", { css: [cellOverflowX ? {
|
|
60
60
|
overflowX: cellOverflowX
|
|
61
|
-
} : void 0, getCellStyle(tableTokens, hasBlockEndBorder), bordered ? getBorderedCellStyle(hasInlineBorder) : void 0, process.env.NODE_ENV === "production" ? "" : ";label:EmptyDataRowComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
61
|
+
} : void 0, getCellStyle(tableTokens, hasBlockEndBorder), bordered ? getBorderedCellStyle(hasInlineBorder) : void 0, process.env.NODE_ENV === "production" ? "" : ";label:EmptyDataRowComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvY29tcG9uZW50cy9FbXB0eURhdGFSb3cvRW1wdHlEYXRhUm93LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRVEiLCJmaWxlIjoiL2J1aWxkcy9mcm9udGVuZC9saWJzL3VpLWtpdC9zcmMvY29tcG9uZW50cy9UYWJsZS9jb21wb25lbnRzL0VtcHR5RGF0YVJvdy9FbXB0eURhdGFSb3cudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgbWVtbywgdXNlQ29udGV4dCwgdXNlTWVtbywgdXNlU3RhdGUsIHR5cGUgQ1NTUHJvcGVydGllcywgdHlwZSBGQyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBFbXB0eURhdGFSb3dQcm9wcyB9IGZyb20gXCIuL0VtcHR5RGF0YVJvdy50eXBlc1wiO1xuaW1wb3J0IHsgdXNlU3Vic2NyaWJlIH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdHlwZWRFdmVudEJ1c1wiO1xuaW1wb3J0IHsgaXNOdW1iZXIsIGlzT2JqZWN0LCBpc1VuZGVmaW5lZCB9IGZyb20gXCJsb2Rhc2gtZXNcIjtcbmltcG9ydCB7IEVtcHR5IH0gZnJvbSBcImNvbXBvbmVudHMvRW1wdHlcIjtcbmltcG9ydCB7IHVzZVRhYmxlU3RhdGljQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2ZlYXR1cmVzL3RhYmxlU3RhdGljQ29udGV4dFwiO1xuaW1wb3J0IHsgZ2V0UmVmVmFsdWUgfSBmcm9tIFwiY29tcG9uZW50cy9UYWJsZS91dGlsc1wiO1xuaW1wb3J0IHsgdXNlVGFibGVDb250ZXh0IH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvY29udGV4dHNcIjtcbmltcG9ydCB7IGdldEJvcmRlcmVkQ2VsbFN0eWxlLCBnZXRDZWxsU3R5bGUsIGVtcHR5V3JhcHBlclN0eWxlIH0gZnJvbSBcIi4vRW1wdHlEYXRhUm93LnN0eWxlc1wiO1xuaW1wb3J0IHsgQ29uZmlnQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL0NvbmZpZ1Byb3ZpZGVyXCI7XG5pbXBvcnQgeyBnZXRFbmRSYW5nZUluZm8gfSBmcm9tIFwiLi9FbXB0eURhdGFSb3cudXRpbHNcIjtcblxuY29uc3QgRW1wdHlEYXRhUm93Q29tcG9uZW50OiBGQzxFbXB0eURhdGFSb3dQcm9wcz4gPSAoKSA9PiB7XG4gIGNvbnN0IHsgcmVuZGVyRW1wdHkgfSA9IHVzZUNvbnRleHQoQ29uZmlnQ29udGV4dCk7XG4gIGNvbnN0IHsgZmxhdHRlZENvbHVtbnMsIGJvcmRlcmVkLCB0YWJsZVRva2VucywgaG9yaXpvblNjcm9sbCB9ID0gdXNlVGFibGVDb250ZXh0KCk7XG4gIGNvbnN0IHN0YXRpY0NvbnRleHRSZWYgPSB1c2VUYWJsZVN0YXRpY0NvbnRleHQoKTtcblxuICBjb25zdCBbY2xpZW50V2lkdGgsIHNldENsaWVudFdpZHRoXSA9IHVzZVN0YXRlKCgpID0+IHtcbiAgICBjb25zdCBjbGllbnRXaWR0aCA9IGdldFJlZlZhbHVlKHN0YXRpY0NvbnRleHRSZWYsIFwic2Nyb2xsYWJsZVRhYmxlU2VjdGlvbkluZm8uY2xpZW50V2lkdGhcIik7XG4gICAgY29uc3QgdmVydGljYWxTY3JvbGxCYXJXaWR0aCA9IGdldFJlZlZhbHVlKFxuICAgICAgc3RhdGljQ29udGV4dFJlZixcbiAgICAgIFwic2Nyb2xsYWJsZVRhYmxlU2VjdGlvbkluZm8udmVydGljYWxTY3JvbGxCYXJXaWR0aFwiXG4gICAgKTtcbiAgICBjb25zdCB7IGhhc0VuZFJhbmdlIH0gPSBnZXRFbmRSYW5nZUluZm8oc3RhdGljQ29udGV4dFJlZik7XG5cbiAgICByZXR1cm4gaGFzRW5kUmFuZ2UgPyBjbGllbnRXaWR0aCArIHZlcnRpY2FsU2Nyb2xsQmFyV2lkdGggOiB1bmRlZmluZWQ7XG4gIH0pO1xuICBjb25zdCBbY2VsbE92ZXJmbG93WCwgc2V0Q2VsbE92ZXJmbG93WF0gPSB1c2VTdGF0ZTxDU1NQcm9wZXJ0aWVzW1wib3ZlcmZsb3dYXCJdPigoKSA9PiB7XG4gICAgY29uc3QgeyBoYXNFbmRSYW5nZSB9ID0gZ2V0RW5kUmFuZ2VJbmZvKHN0YXRpY0NvbnRleHRSZWYpO1xuXG4gICAgcmV0dXJuIGhhc0VuZFJhbmdlID8gdW5kZWZpbmVkIDogXCJoaWRkZW5cIjtcbiAgfSk7XG5cbiAgdXNlU3Vic2NyaWJlKFxuICAgIFwidGFibGUtdmlzdWFsLXBhcmFtczpjaGFuZ2VcIixcbiAgICAodmFsdWUpID0+IHtcbiAgICAgIGNvbnN0IHsgY2xpZW50V2lkdGgsIGhvcml6b250YWxTY3JvbGxQb3NpdGlvblJhbmdlIH0gPSB2YWx1ZTtcblxuICAgICAgaWYgKGlzVW5kZWZpbmVkKGNsaWVudFdpZHRoKSB8fCAhaG9yaXpvbnRhbFNjcm9sbFBvc2l0aW9uUmFuZ2UpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBjb25zdCB7IGhhc0VuZFJhbmdlIH0gPSBnZXRFbmRSYW5nZUluZm8oaG9yaXpvbnRhbFNjcm9sbFBvc2l0aW9uUmFuZ2UpO1xuXG4gICAgICBzZXRDbGllbnRXaWR0aChoYXNFbmRSYW5nZSA/IGNsaWVudFdpZHRoIDogdW5kZWZpbmVkKTtcbiAgICAgIHNldENlbGxPdmVyZmxvd1goaGFzRW5kUmFuZ2UgPyB1bmRlZmluZWQgOiBcImhpZGRlblwiKTtcbiAgICB9LFxuICAgIGZhbHNlLFxuICAgIFtdLFxuICAgIHRydWVcbiAgKTtcblxuICBjb25zdCBlbXB0eSA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIGlmIChyZW5kZXJFbXB0eSkge1xuICAgICAgcmV0dXJuIHJlbmRlckVtcHR5KCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIDxFbXB0eSAvPjtcbiAgfSwgW3JlbmRlckVtcHR5XSk7XG5cbiAgY29uc3QgaGFzSW5saW5lQm9yZGVyID0gQm9vbGVhbihib3JkZXJlZCAmJiBib3JkZXJlZC5lbXB0eUlubGluZSk7XG4gIGNvbnN0IGhhc0Jsb2NrRW5kQm9yZGVyID0gIWlzT2JqZWN0KGJvcmRlcmVkKSB8fCBCb29sZWFuKGJvcmRlcmVkICYmIGJvcmRlcmVkLmVtcHR5QmxvY2tFbmQpO1xuXG4gIHJldHVybiAoXG4gICAgPHRyPlxuICAgICAgPHRkXG4gICAgICAgIGNzcz17W1xuICAgICAgICAgIGNlbGxPdmVyZmxvd1ggPyB7IG92ZXJmbG93WDogY2VsbE92ZXJmbG93WCB9IDogdW5kZWZpbmVkLFxuICAgICAgICAgIGdldENlbGxTdHlsZSh0YWJsZVRva2VucywgaGFzQmxvY2tFbmRCb3JkZXIpLFxuICAgICAgICAgIGJvcmRlcmVkID8gZ2V0Qm9yZGVyZWRDZWxsU3R5bGUoaGFzSW5saW5lQm9yZGVyKSA6IHVuZGVmaW5lZCxcbiAgICAgICAgXX1cbiAgICAgICAgY29sU3Bhbj17ZmxhdHRlZENvbHVtbnMubGVuZ3RofVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgc3R5bGU9e1xuICAgICAgICAgICAgaG9yaXpvblNjcm9sbFxuICAgICAgICAgICAgICA/IHtcbiAgICAgICAgICAgICAgICAgIHdpZHRoOlxuICAgICAgICAgICAgICAgICAgICBpc051bWJlcihjbGllbnRXaWR0aCkgJiYgY2xpZW50V2lkdGggPiAwICYmIGhhc0lubGluZUJvcmRlclxuICAgICAgICAgICAgICAgICAgICAgID8gY2xpZW50V2lkdGggLSAyXG4gICAgICAgICAgICAgICAgICAgICAgOiBjbGllbnRXaWR0aCxcbiAgICAgICAgICAgICAgICAgIGxlZnQ6IGhhc0lubGluZUJvcmRlciA/IDEgOiAwLFxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgOiB1bmRlZmluZWRcbiAgICAgICAgICB9XG4gICAgICAgICAgY3NzPXtob3Jpem9uU2Nyb2xsID8gZW1wdHlXcmFwcGVyU3R5bGUgOiB1bmRlZmluZWR9XG4gICAgICAgID5cbiAgICAgICAgICB7ZW1wdHl9XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC90ZD5cbiAgICA8L3RyPlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IEVtcHR5RGF0YVJvdyA9IG1lbW8oRW1wdHlEYXRhUm93Q29tcG9uZW50KTtcbiJdfQ== */"], colSpan: flattedColumns.length, children: /* @__PURE__ */ jsx("div", { style: horizonScroll ? {
|
|
62
62
|
width: isNumber(clientWidth) && clientWidth > 0 && hasInlineBorder ? clientWidth - 2 : clientWidth,
|
|
63
63
|
left: hasInlineBorder ? 1 : 0
|
|
64
64
|
} : void 0, css: horizonScroll ? emptyWrapperStyle : void 0, children: empty }) }) });
|
|
65
65
|
};
|
|
66
|
-
const EmptyDataRow = EmptyDataRowComponent;
|
|
66
|
+
const EmptyDataRow = memo(EmptyDataRowComponent);
|
|
67
67
|
export {
|
|
68
68
|
EmptyDataRow
|
|
69
69
|
};
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
2
|
import { useState } from "react";
|
|
3
|
+
import { useSubscribe } from "../../../../features/typedEventBus/hooks.js";
|
|
3
4
|
import { isNumber } from "lodash-es";
|
|
4
5
|
import { useTableStaticContext } from "../../../../features/tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
|
|
5
6
|
import { getRefValue } from "../../../../utils/ref/ref.js";
|
|
6
|
-
import { useSubscribe } from "../../../../features/typedEventBus/hooks.js";
|
|
7
7
|
const FixedHeaderColGroupComponent = () => {
|
|
8
8
|
const staticContextRef = useTableStaticContext();
|
|
9
9
|
const [widths, setWidths] = useState(() => getRefValue(staticContextRef, "measureCellsInfo.widths"));
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { DefaultRecord } from 'components/Table/Table.types';
|
|
1
|
+
import { DefaultRecord, Key } from 'components/Table/Table.types';
|
|
2
2
|
import { UseBodyExpandOptions } from './useBodyExpand.types';
|
|
3
3
|
export declare const useBodyExpand: <Record extends DefaultRecord>(options: UseBodyExpandOptions<Record>) => {
|
|
4
|
-
expandedKeys: Set<
|
|
4
|
+
expandedKeys: Set<Key>;
|
|
5
5
|
onTriggerExpand: <Record_1 extends DefaultRecord>(record: Record_1) => void;
|
|
6
6
|
};
|
|
@@ -2,7 +2,7 @@ import { UseTableExpandOptions } from './useTableExpand.types';
|
|
|
2
2
|
import { DefaultRecord } from '../../../../Table.types';
|
|
3
3
|
export declare const useTableExpand: <Record extends DefaultRecord>(options: UseTableExpandOptions<Record>) => {
|
|
4
4
|
expandIconColumnIndex: number;
|
|
5
|
-
isSomeRecordHasChildren: boolean;
|
|
5
|
+
isSomeRecordHasChildren: boolean | undefined;
|
|
6
6
|
indentSize: number;
|
|
7
7
|
ExpandIcon: import('react').MemoExoticComponent<(<Record_1 extends DefaultRecord>(props: import('../../components/DefaultExpandIcon/DefaultExpandIcon.types').DefaultExpandIconProps<Record_1>) => import("@emotion/react/jsx-runtime").JSX.Element)> | import('react').ComponentType<import('../..').ExpandIconProps<Record>>;
|
|
8
8
|
};
|
|
@@ -13,7 +13,7 @@ const useTableExpand = (options) => {
|
|
|
13
13
|
} = expandable || {};
|
|
14
14
|
const expandIconColumnIndex = rowSelection ? 1 : 0;
|
|
15
15
|
const ExpandIcon = ExpandIconProp || DefaultExpandIcon;
|
|
16
|
-
const isSomeRecordHasChildren = useMemo(() => dataSource.some((record) => "children" in record && Array.isArray(record.children)), [dataSource]);
|
|
16
|
+
const isSomeRecordHasChildren = useMemo(() => dataSource == null ? void 0 : dataSource.some((record) => "children" in record && Array.isArray(record.children)), [dataSource]);
|
|
17
17
|
return {
|
|
18
18
|
expandIconColumnIndex,
|
|
19
19
|
isSomeRecordHasChildren,
|
|
@@ -70,7 +70,9 @@ const CheckboxCellContentWrapperComponent = (props) => {
|
|
|
70
70
|
(_a = checkboxProps == null ? void 0 : checkboxProps.onChange) == null ? void 0 : _a.call(checkboxProps, event);
|
|
71
71
|
});
|
|
72
72
|
const Wrapper = RenderCell ?? Fragment;
|
|
73
|
-
return /* @__PURE__ */ jsx("div", { css: [selectionItemContainerStyle, bordered ? getBorderedSelectionItemContainerStyle() : void 0, process.env.NODE_ENV === "production" ? "" : ";label:CheckboxCellContentWrapperComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9DaGVja2JveENlbGxDb250ZW50V3JhcHBlci9DaGVja2JveENlbGxDb250ZW50V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUZNIiwiZmlsZSI6Ii9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9DaGVja2JveENlbGxDb250ZW50V3JhcHBlci9DaGVja2JveENlbGxDb250ZW50V3JhcHBlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGcmFnbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBDaGVja2JveENlbGxDb250ZW50V3JhcHBlclByb3BzIH0gZnJvbSBcIi4vQ2hlY2tib3hDZWxsQ29udGVudFdyYXBwZXIudHlwZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2NvbnRleHRzXCI7XG5pbXBvcnQgeyB1c2VFdmVudCB9IGZyb20gXCJob29rcy91c2VFdmVudFwiO1xuaW1wb3J0IHsgZ2V0Um93S2V5IH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvdXRpbHNcIjtcbmltcG9ydCB7IGFyckFkZCwgYXJyRGVsIH0gZnJvbSBcIi4vQ2hlY2tib3hDZWxsQ29udGVudFdyYXBwZXIudXRpbHNcIjtcbmltcG9ydCB7IENoZWNrYm94LCB0eXBlIENoZWNrYm94UHJvcHMgfSBmcm9tIFwiY29tcG9uZW50cy9DaGVja2JveFwiO1xuaW1wb3J0IHsgZ2V0Qm9yZGVyZWRTZWxlY3Rpb25JdGVtQ29udGFpbmVyU3R5bGUsIHNlbGVjdGlvbkl0ZW1Db250YWluZXJTdHlsZSB9IGZyb20gXCIuLi8uLi9zdHlsZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlUm93U2VsZWN0aW9uQ29udGV4dCB9IGZyb20gXCIuLi8uLi9jb250ZXh0c1wiO1xuaW1wb3J0IHR5cGUgeyBEZWZhdWx0UmVjb3JkIH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvVGFibGUudHlwZXNcIjtcblxuY29uc3QgQ2hlY2tib3hDZWxsQ29udGVudFdyYXBwZXJDb21wb25lbnQgPSA8UmVjb3JkIGV4dGVuZHMgRGVmYXVsdFJlY29yZD4oXG4gIHByb3BzOiBDaGVja2JveENlbGxDb250ZW50V3JhcHBlclByb3BzPFJlY29yZD5cbikgPT4ge1xuICBjb25zdCB7IHJlbmRlckNlbGw6IFJlbmRlckNlbGwsIHJlY29yZCB9ID0gcHJvcHM7XG4gIGNvbnN0IHtcbiAgICBjaGVja2JveFByb3BzTWFwLFxuICAgIGRlcml2ZWRTZWxlY3RlZEtleVNldCxcbiAgICBkZXJpdmVkU2VsZWN0ZWRLZXlzLFxuICAgIGRlcml2ZWRIYWxmU2VsZWN0ZWRLZXlTZXQsXG4gICAgcmVjb3JkS2V5cyxcbiAgICBzZXRTZWxlY3RlZEtleXMsXG4gICAgdHJpZ2dlclNpbmdsZVNlbGVjdGlvbixcbiAgICBtdWx0aXBsZVNlbGVjdCxcbiAgICB1cGRhdGVQcmV2U2VsZWN0ZWRJbmRleCxcbiAgfSA9IHVzZVRhYmxlUm93U2VsZWN0aW9uQ29udGV4dCgpO1xuICBjb25zdCB7IGlzU29tZVJlY29yZEhhc0NoaWxkcmVuLCBib3JkZXJlZCB9ID0gdXNlVGFibGVDb250ZXh0KCk7XG4gIGNvbnN0IGtleSA9IGdldFJvd0tleShyZWNvcmQpO1xuXG4gIGNvbnN0IGNoZWNrZWQgPSBkZXJpdmVkU2VsZWN0ZWRLZXlTZXQuaGFzKGtleSk7XG4gIGNvbnN0IGluZGV0ZXJtaW5hdGUgPSBkZXJpdmVkSGFsZlNlbGVjdGVkS2V5U2V0LmhhcyhrZXkpO1xuICBjb25zdCBjaGVja2JveFByb3BzID0gY2hlY2tib3hQcm9wc01hcC5nZXQoa2V5KTtcblxuICBsZXQgbWVyZ2VkSW5kZXRlcm1pbmF0ZTogYm9vbGVhbjtcblxuICBpZiAoaXNTb21lUmVjb3JkSGFzQ2hpbGRyZW4pIHtcbiAgICBtZXJnZWRJbmRldGVybWluYXRlID0gaW5kZXRlcm1pbmF0ZTtcbiAgfSBlbHNlIHtcbiAgICBtZXJnZWRJbmRldGVybWluYXRlID0gY2hlY2tib3hQcm9wcz8uaW5kZXRlcm1pbmF0ZSA/PyBpbmRldGVybWluYXRlO1xuICB9XG5cbiAgY29uc3QgaGFuZGxlQ2xpY2sgPSB1c2VFdmVudCgoKGUpID0+IHtcbiAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIGNoZWNrYm94UHJvcHM/Lm9uQ2xpY2s/LihlKTtcbiAgfSkgc2F0aXNmaWVzIENoZWNrYm94UHJvcHNbXCJvbkNsaWNrXCJdKTtcblxuICBjb25zdCBoYW5kbGVDaGFuZ2UgPSB1c2VFdmVudCgoKGV2ZW50KSA9PiB7XG4gICAgY29uc3QgeyBuYXRpdmVFdmVudCB9ID0gZXZlbnQ7XG4gICAgY29uc3QgeyBzaGlmdEtleSB9ID0gbmF0aXZlRXZlbnQ7XG5cbiAgICBjb25zdCBjdXJyZW50U2VsZWN0ZWRJbmRleCA9IHJlY29yZEtleXMuaW5kZXhPZihrZXkpO1xuICAgIGNvbnN0IGlzTXVsdGlwbGUgPSBkZXJpdmVkU2VsZWN0ZWRLZXlzLnNvbWUoKGl0ZW0pID0+IHJlY29yZEtleXMuaW5jbHVkZXMoaXRlbSkpO1xuXG4gICAgaWYgKHNoaWZ0S2V5ICYmIGlzTXVsdGlwbGUpIHtcbiAgICAgIGNvbnN0IGtleVNldCA9IG5ldyBTZXQoZGVyaXZlZFNlbGVjdGVkS2V5U2V0KTtcbiAgICAgIG11bHRpcGxlU2VsZWN0KGN1cnJlbnRTZWxlY3RlZEluZGV4LCByZWNvcmRLZXlzLCBrZXlTZXQpO1xuXG4gICAgICBjb25zdCBrZXlzID0gQXJyYXkuZnJvbShrZXlTZXQpO1xuXG4gICAgICBzZXRTZWxlY3RlZEtleXMoa2V5cywgXCJtdWx0aXBsZVwiKTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3Qgb3JpZ2luQ2hlY2tlZEtleXMgPSBkZXJpdmVkU2VsZWN0ZWRLZXlzO1xuXG4gICAgICBjb25zdCBjaGVja2VkS2V5cyA9IGNoZWNrZWQgPyBhcnJEZWwob3JpZ2luQ2hlY2tlZEtleXMsIGtleSkgOiBhcnJBZGQob3JpZ2luQ2hlY2tlZEtleXMsIGtleSk7XG5cbiAgICAgIHRyaWdnZXJTaW5nbGVTZWxlY3Rpb24oa2V5LCAhY2hlY2tlZCwgY2hlY2tlZEtleXMsIG5hdGl2ZUV2ZW50KTtcbiAgICB9XG5cbiAgICBpZiAoY2hlY2tlZCkge1xuICAgICAgdXBkYXRlUHJldlNlbGVjdGVkSW5kZXgobnVsbCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHVwZGF0ZVByZXZTZWxlY3RlZEluZGV4KGN1cnJlbnRTZWxlY3RlZEluZGV4KTtcbiAgICB9XG5cbiAgICBjaGVja2JveFByb3BzPy5vbkNoYW5nZT8uKGV2ZW50KTtcbiAgfSkgc2F0aXNmaWVzIENoZWNrYm94UHJvcHNbXCJvbkNoYW5nZVwiXSk7XG5cbiAgY29uc3QgV3JhcHBlciA9IFJlbmRlckNlbGwgPz8gRnJhZ21lbnQ7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e1tcbiAgICAgICAgc2VsZWN0aW9uSXRlbUNvbnRhaW5lclN0eWxlLFxuICAgICAgICBib3JkZXJlZCA/
|
|
73
|
+
return /* @__PURE__ */ jsx("div", { css: [selectionItemContainerStyle, bordered ? getBorderedSelectionItemContainerStyle() : void 0, process.env.NODE_ENV === "production" ? "" : ";label:CheckboxCellContentWrapperComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9DaGVja2JveENlbGxDb250ZW50V3JhcHBlci9DaGVja2JveENlbGxDb250ZW50V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUZNIiwiZmlsZSI6Ii9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9DaGVja2JveENlbGxDb250ZW50V3JhcHBlci9DaGVja2JveENlbGxDb250ZW50V3JhcHBlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGcmFnbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBDaGVja2JveENlbGxDb250ZW50V3JhcHBlclByb3BzIH0gZnJvbSBcIi4vQ2hlY2tib3hDZWxsQ29udGVudFdyYXBwZXIudHlwZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2NvbnRleHRzXCI7XG5pbXBvcnQgeyB1c2VFdmVudCB9IGZyb20gXCJob29rcy91c2VFdmVudFwiO1xuaW1wb3J0IHsgZ2V0Um93S2V5IH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvdXRpbHNcIjtcbmltcG9ydCB7IGFyckFkZCwgYXJyRGVsIH0gZnJvbSBcIi4vQ2hlY2tib3hDZWxsQ29udGVudFdyYXBwZXIudXRpbHNcIjtcbmltcG9ydCB7IENoZWNrYm94LCB0eXBlIENoZWNrYm94UHJvcHMgfSBmcm9tIFwiY29tcG9uZW50cy9DaGVja2JveFwiO1xuaW1wb3J0IHsgZ2V0Qm9yZGVyZWRTZWxlY3Rpb25JdGVtQ29udGFpbmVyU3R5bGUsIHNlbGVjdGlvbkl0ZW1Db250YWluZXJTdHlsZSB9IGZyb20gXCIuLi8uLi9zdHlsZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlUm93U2VsZWN0aW9uQ29udGV4dCB9IGZyb20gXCIuLi8uLi9jb250ZXh0c1wiO1xuaW1wb3J0IHR5cGUgeyBEZWZhdWx0UmVjb3JkIH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvVGFibGUudHlwZXNcIjtcblxuY29uc3QgQ2hlY2tib3hDZWxsQ29udGVudFdyYXBwZXJDb21wb25lbnQgPSA8UmVjb3JkIGV4dGVuZHMgRGVmYXVsdFJlY29yZD4oXG4gIHByb3BzOiBDaGVja2JveENlbGxDb250ZW50V3JhcHBlclByb3BzPFJlY29yZD5cbikgPT4ge1xuICBjb25zdCB7IHJlbmRlckNlbGw6IFJlbmRlckNlbGwsIHJlY29yZCB9ID0gcHJvcHM7XG4gIGNvbnN0IHtcbiAgICBjaGVja2JveFByb3BzTWFwLFxuICAgIGRlcml2ZWRTZWxlY3RlZEtleVNldCxcbiAgICBkZXJpdmVkU2VsZWN0ZWRLZXlzLFxuICAgIGRlcml2ZWRIYWxmU2VsZWN0ZWRLZXlTZXQsXG4gICAgcmVjb3JkS2V5cyxcbiAgICBzZXRTZWxlY3RlZEtleXMsXG4gICAgdHJpZ2dlclNpbmdsZVNlbGVjdGlvbixcbiAgICBtdWx0aXBsZVNlbGVjdCxcbiAgICB1cGRhdGVQcmV2U2VsZWN0ZWRJbmRleCxcbiAgfSA9IHVzZVRhYmxlUm93U2VsZWN0aW9uQ29udGV4dCgpO1xuICBjb25zdCB7IGlzU29tZVJlY29yZEhhc0NoaWxkcmVuLCBib3JkZXJlZCB9ID0gdXNlVGFibGVDb250ZXh0KCk7XG4gIGNvbnN0IGtleSA9IGdldFJvd0tleShyZWNvcmQpO1xuXG4gIGNvbnN0IGNoZWNrZWQgPSBkZXJpdmVkU2VsZWN0ZWRLZXlTZXQuaGFzKGtleSk7XG4gIGNvbnN0IGluZGV0ZXJtaW5hdGUgPSBkZXJpdmVkSGFsZlNlbGVjdGVkS2V5U2V0LmhhcyhrZXkpO1xuICBjb25zdCBjaGVja2JveFByb3BzID0gY2hlY2tib3hQcm9wc01hcC5nZXQoa2V5KTtcblxuICBsZXQgbWVyZ2VkSW5kZXRlcm1pbmF0ZTogYm9vbGVhbjtcblxuICBpZiAoaXNTb21lUmVjb3JkSGFzQ2hpbGRyZW4pIHtcbiAgICBtZXJnZWRJbmRldGVybWluYXRlID0gaW5kZXRlcm1pbmF0ZTtcbiAgfSBlbHNlIHtcbiAgICBtZXJnZWRJbmRldGVybWluYXRlID0gY2hlY2tib3hQcm9wcz8uaW5kZXRlcm1pbmF0ZSA/PyBpbmRldGVybWluYXRlO1xuICB9XG5cbiAgY29uc3QgaGFuZGxlQ2xpY2sgPSB1c2VFdmVudCgoKGUpID0+IHtcbiAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIGNoZWNrYm94UHJvcHM/Lm9uQ2xpY2s/LihlKTtcbiAgfSkgc2F0aXNmaWVzIENoZWNrYm94UHJvcHNbXCJvbkNsaWNrXCJdKTtcblxuICBjb25zdCBoYW5kbGVDaGFuZ2UgPSB1c2VFdmVudCgoKGV2ZW50KSA9PiB7XG4gICAgY29uc3QgeyBuYXRpdmVFdmVudCB9ID0gZXZlbnQ7XG4gICAgY29uc3QgeyBzaGlmdEtleSB9ID0gbmF0aXZlRXZlbnQ7XG5cbiAgICBjb25zdCBjdXJyZW50U2VsZWN0ZWRJbmRleCA9IHJlY29yZEtleXMuaW5kZXhPZihrZXkpO1xuICAgIGNvbnN0IGlzTXVsdGlwbGUgPSBkZXJpdmVkU2VsZWN0ZWRLZXlzLnNvbWUoKGl0ZW0pID0+IHJlY29yZEtleXMuaW5jbHVkZXMoaXRlbSkpO1xuXG4gICAgaWYgKHNoaWZ0S2V5ICYmIGlzTXVsdGlwbGUpIHtcbiAgICAgIGNvbnN0IGtleVNldCA9IG5ldyBTZXQoZGVyaXZlZFNlbGVjdGVkS2V5U2V0KTtcbiAgICAgIG11bHRpcGxlU2VsZWN0KGN1cnJlbnRTZWxlY3RlZEluZGV4LCByZWNvcmRLZXlzLCBrZXlTZXQpO1xuXG4gICAgICBjb25zdCBrZXlzID0gQXJyYXkuZnJvbShrZXlTZXQpO1xuXG4gICAgICBzZXRTZWxlY3RlZEtleXMoa2V5cywgXCJtdWx0aXBsZVwiKTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3Qgb3JpZ2luQ2hlY2tlZEtleXMgPSBkZXJpdmVkU2VsZWN0ZWRLZXlzO1xuXG4gICAgICBjb25zdCBjaGVja2VkS2V5cyA9IGNoZWNrZWQgPyBhcnJEZWwob3JpZ2luQ2hlY2tlZEtleXMsIGtleSkgOiBhcnJBZGQob3JpZ2luQ2hlY2tlZEtleXMsIGtleSk7XG5cbiAgICAgIHRyaWdnZXJTaW5nbGVTZWxlY3Rpb24oa2V5LCAhY2hlY2tlZCwgY2hlY2tlZEtleXMsIG5hdGl2ZUV2ZW50KTtcbiAgICB9XG5cbiAgICBpZiAoY2hlY2tlZCkge1xuICAgICAgdXBkYXRlUHJldlNlbGVjdGVkSW5kZXgobnVsbCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHVwZGF0ZVByZXZTZWxlY3RlZEluZGV4KGN1cnJlbnRTZWxlY3RlZEluZGV4KTtcbiAgICB9XG5cbiAgICBjaGVja2JveFByb3BzPy5vbkNoYW5nZT8uKGV2ZW50KTtcbiAgfSkgc2F0aXNmaWVzIENoZWNrYm94UHJvcHNbXCJvbkNoYW5nZVwiXSk7XG5cbiAgY29uc3QgV3JhcHBlciA9IFJlbmRlckNlbGwgPz8gRnJhZ21lbnQ7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e1tcbiAgICAgICAgc2VsZWN0aW9uSXRlbUNvbnRhaW5lclN0eWxlLFxuICAgICAgICBib3JkZXJlZCA/IGdldEJvcmRlcmVkU2VsZWN0aW9uSXRlbUNvbnRhaW5lclN0eWxlKCkgOiB1bmRlZmluZWQsXG4gICAgICBdfVxuICAgID5cbiAgICAgIDxXcmFwcGVyIHsuLi4oUmVuZGVyQ2VsbCA/IHsgc2VsZWN0aW9uVHlwZTogXCJjaGVja2JveFwiIH0gOiB7fSl9PlxuICAgICAgICA8Q2hlY2tib3hcbiAgICAgICAgICB7Li4uY2hlY2tib3hQcm9wc31cbiAgICAgICAgICBjaGVja2VkPXtjaGVja2VkfVxuICAgICAgICAgIGluZGV0ZXJtaW5hdGU9e21lcmdlZEluZGV0ZXJtaW5hdGV9XG4gICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2t9XG4gICAgICAgICAgb25DaGFuZ2U9e2hhbmRsZUNoYW5nZX1cbiAgICAgICAgLz5cbiAgICAgIDwvV3JhcHBlcj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBDaGVja2JveENlbGxDb250ZW50V3JhcHBlciA9IENoZWNrYm94Q2VsbENvbnRlbnRXcmFwcGVyQ29tcG9uZW50O1xuIl19 */"], children: /* @__PURE__ */ jsx(Wrapper, { ...RenderCell ? {
|
|
74
|
+
selectionType: "checkbox"
|
|
75
|
+
} : {}, children: /* @__PURE__ */ jsx(Checkbox, { ...checkboxProps, checked, indeterminate: mergedIndeterminate, onClick: handleClick, onChange: handleChange }) }) });
|
|
74
76
|
};
|
|
75
77
|
const CheckboxCellContentWrapper = CheckboxCellContentWrapperComponent;
|
|
76
78
|
export {
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { Key } from 'components/Table/Table.types';
|
|
2
|
-
export declare function arrDel(list: Key[], value: Key):
|
|
3
|
-
export declare function arrAdd(list: Key[], value: Key):
|
|
2
|
+
export declare function arrDel(list: Key[], value: Key): Key[];
|
|
3
|
+
export declare function arrAdd(list: Key[], value: Key): Key[];
|
|
@@ -8,7 +8,8 @@ import { getRowKey } from "../../../../utils/getRowKey/getRowKey.js";
|
|
|
8
8
|
const HeaderCheckboxCellContentWrapperComponent = (props) => {
|
|
9
9
|
const {
|
|
10
10
|
columnTitle: ColumnTitle,
|
|
11
|
-
getTitleCheckboxProps
|
|
11
|
+
getTitleCheckboxProps,
|
|
12
|
+
onSelectAll
|
|
12
13
|
} = props;
|
|
13
14
|
const {
|
|
14
15
|
bordered
|
|
@@ -58,11 +59,12 @@ const HeaderCheckboxCellContentWrapperComponent = (props) => {
|
|
|
58
59
|
});
|
|
59
60
|
}
|
|
60
61
|
const keys = Array.from(keySet);
|
|
62
|
+
onSelectAll == null ? void 0 : onSelectAll(!checkedCurrentAll);
|
|
61
63
|
setSelectedKeys(keys, "all");
|
|
62
64
|
updatePrevSelectedIndex(null);
|
|
63
65
|
};
|
|
64
66
|
const Wrapper = ColumnTitle ?? Fragment;
|
|
65
|
-
return /* @__PURE__ */ jsx("div", { css: [selectionItemContainerStyle, bordered ? getBorderedSelectionItemContainerStyle(true) : void 0, process.env.NODE_ENV === "production" ? "" : ";label:HeaderCheckboxCellContentWrapperComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
67
|
+
return /* @__PURE__ */ jsx("div", { css: [selectionItemContainerStyle, bordered ? getBorderedSelectionItemContainerStyle(true) : void 0, process.env.NODE_ENV === "production" ? "" : ";label:HeaderCheckboxCellContentWrapperComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9IZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlci9IZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0VNIiwiZmlsZSI6Ii9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9IZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlci9IZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGcmFnbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBIZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlclByb3BzIH0gZnJvbSBcIi4vSGVhZGVyQ2hlY2tib3hDZWxsQ29udGVudFdyYXBwZXIudHlwZXNcIjtcbmltcG9ydCB0eXBlIHsgS2V5IH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvVGFibGUudHlwZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2NvbnRleHRzXCI7XG5pbXBvcnQgeyBnZXRSb3dLZXkgfSBmcm9tIFwiY29tcG9uZW50cy9UYWJsZS91dGlsc1wiO1xuaW1wb3J0IHsgQ2hlY2tib3ggfSBmcm9tIFwiY29tcG9uZW50cy9DaGVja2JveFwiO1xuaW1wb3J0IHsgZ2V0Qm9yZGVyZWRTZWxlY3Rpb25JdGVtQ29udGFpbmVyU3R5bGUsIHNlbGVjdGlvbkl0ZW1Db250YWluZXJTdHlsZSB9IGZyb20gXCIuLi8uLi9zdHlsZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlUm93U2VsZWN0aW9uQ29udGV4dCB9IGZyb20gXCIuLi8uLi9jb250ZXh0c1wiO1xuXG5jb25zdCBIZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlckNvbXBvbmVudCA9IDxSZWNvcmQsPihcbiAgcHJvcHM6IEhlYWRlckNoZWNrYm94Q2VsbENvbnRlbnRXcmFwcGVyUHJvcHM8UmVjb3JkPlxuKSA9PiB7XG4gIGNvbnN0IHsgY29sdW1uVGl0bGU6IENvbHVtblRpdGxlLCBnZXRUaXRsZUNoZWNrYm94UHJvcHMsIG9uU2VsZWN0QWxsIH0gPSBwcm9wcztcbiAgY29uc3QgeyBib3JkZXJlZCB9ID0gdXNlVGFibGVDb250ZXh0KCk7XG4gIGNvbnN0IHtcbiAgICBjaGVja2JveFByb3BzTWFwLFxuICAgIGZsYXR0ZWREYXRhLFxuICAgIGNoZWNrZWRDdXJyZW50QWxsLFxuICAgIGNoZWNrZWRDdXJyZW50U29tZSxcbiAgICBrZXlTZXQsXG4gICAgcmVjb3JkS2V5cyxcbiAgICBzZXRTZWxlY3RlZEtleXMsXG4gICAgdXBkYXRlUHJldlNlbGVjdGVkSW5kZXgsXG4gIH0gPSB1c2VUYWJsZVJvd1NlbGVjdGlvbkNvbnRleHQoKTtcblxuICBjb25zdCBhbGxEaXNhYmxlZERhdGEgPSBmbGF0dGVkRGF0YVxuICAgIC5tYXAoKHJlY29yZCkgPT4ge1xuICAgICAgY29uc3Qga2V5ID0gZ2V0Um93S2V5KHJlY29yZCk7XG4gICAgICBjb25zdCBjaGVja2JveFByb3BzID0gY2hlY2tib3hQcm9wc01hcC5nZXQoa2V5KSB8fCB7fTtcblxuICAgICAgcmV0dXJuIHsgY2hlY2tlZDoga2V5U2V0LmhhcyhrZXkpLCAuLi5jaGVja2JveFByb3BzIH07XG4gICAgfSlcbiAgICAuZmlsdGVyKCh7IGRpc2FibGVkIH0pID0+IGRpc2FibGVkKTtcblxuICBjb25zdCBhbGxEaXNhYmxlZCA9ICEhYWxsRGlzYWJsZWREYXRhLmxlbmd0aCAmJiBhbGxEaXNhYmxlZERhdGEubGVuZ3RoID09PSBmbGF0dGVkRGF0YS5sZW5ndGg7XG5cbiAgY29uc3QgYWxsRGlzYWJsZWRBbmRDaGVja2VkID0gYWxsRGlzYWJsZWQgJiYgYWxsRGlzYWJsZWREYXRhLmV2ZXJ5KCh7IGNoZWNrZWQgfSkgPT4gY2hlY2tlZCk7XG4gIGNvbnN0IGFsbERpc2FibGVkU29tZUNoZWNrZWQgPSBhbGxEaXNhYmxlZCAmJiBhbGxEaXNhYmxlZERhdGEuc29tZSgoeyBjaGVja2VkIH0pID0+IGNoZWNrZWQpO1xuICBjb25zdCBjdXN0b21DaGVja2JveFByb3BzID0gZ2V0VGl0bGVDaGVja2JveFByb3BzPy4oKSB8fCB7fTtcbiAgY29uc3QgeyBvbkNoYW5nZSwgZGlzYWJsZWQgfSA9IGN1c3RvbUNoZWNrYm94UHJvcHM7XG5cbiAgY29uc3Qgb25TZWxlY3RBbGxDaGFuZ2UgPSAoKSA9PiB7XG4gICAgY29uc3QgY2hhbmdlS2V5czogS2V5W10gPSBbXTtcblxuICAgIGlmIChjaGVja2VkQ3VycmVudEFsbCkge1xuICAgICAgcmVjb3JkS2V5cy5mb3JFYWNoKChrZXkpID0+IHtcbiAgICAgICAga2V5U2V0LmRlbGV0ZShrZXkpO1xuICAgICAgICBjaGFuZ2VLZXlzLnB1c2goa2V5KTtcbiAgICAgIH0pO1xuICAgIH0gZWxzZSB7XG4gICAgICByZWNvcmRLZXlzLmZvckVhY2goKGtleSkgPT4ge1xuICAgICAgICBpZiAoIWtleVNldC5oYXMoa2V5KSkge1xuICAgICAgICAgIGtleVNldC5hZGQoa2V5KTtcbiAgICAgICAgICBjaGFuZ2VLZXlzLnB1c2goa2V5KTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfVxuXG4gICAgY29uc3Qga2V5cyA9IEFycmF5LmZyb20oa2V5U2V0KTtcblxuICAgIG9uU2VsZWN0QWxsPy4oIWNoZWNrZWRDdXJyZW50QWxsKTtcblxuICAgIHNldFNlbGVjdGVkS2V5cyhrZXlzLCBcImFsbFwiKTtcbiAgICB1cGRhdGVQcmV2U2VsZWN0ZWRJbmRleChudWxsKTtcbiAgfTtcblxuICBjb25zdCBXcmFwcGVyID0gQ29sdW1uVGl0bGUgPz8gRnJhZ21lbnQ7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e1tcbiAgICAgICAgc2VsZWN0aW9uSXRlbUNvbnRhaW5lclN0eWxlLFxuICAgICAgICBib3JkZXJlZCA/IGdldEJvcmRlcmVkU2VsZWN0aW9uSXRlbUNvbnRhaW5lclN0eWxlKHRydWUpIDogdW5kZWZpbmVkLFxuICAgICAgXX1cbiAgICA+XG4gICAgICA8V3JhcHBlcj5cbiAgICAgICAgPENoZWNrYm94XG4gICAgICAgICAgYXJpYS1sYWJlbD1cIlNlbGVjdCBhbGxcIlxuICAgICAgICAgIHsuLi5jdXN0b21DaGVja2JveFByb3BzfVxuICAgICAgICAgIGNoZWNrZWQ9eyFhbGxEaXNhYmxlZCA/ICEhZmxhdHRlZERhdGEubGVuZ3RoICYmIGNoZWNrZWRDdXJyZW50QWxsIDogYWxsRGlzYWJsZWRBbmRDaGVja2VkfVxuICAgICAgICAgIGluZGV0ZXJtaW5hdGU9e1xuICAgICAgICAgICAgIWFsbERpc2FibGVkXG4gICAgICAgICAgICAgID8gIWNoZWNrZWRDdXJyZW50QWxsICYmIGNoZWNrZWRDdXJyZW50U29tZVxuICAgICAgICAgICAgICA6ICFhbGxEaXNhYmxlZEFuZENoZWNrZWQgJiYgYWxsRGlzYWJsZWRTb21lQ2hlY2tlZFxuICAgICAgICAgIH1cbiAgICAgICAgICBvbkNoYW5nZT17KGUpID0+IHtcbiAgICAgICAgICAgIG9uU2VsZWN0QWxsQ2hhbmdlKCk7XG4gICAgICAgICAgICBvbkNoYW5nZT8uKGUpO1xuICAgICAgICAgIH19XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkID8/IChmbGF0dGVkRGF0YS5sZW5ndGggPT09IDAgfHwgYWxsRGlzYWJsZWQpfVxuICAgICAgICAvPlxuICAgICAgPC9XcmFwcGVyPlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IEhlYWRlckNoZWNrYm94Q2VsbENvbnRlbnRXcmFwcGVyID0gSGVhZGVyQ2hlY2tib3hDZWxsQ29udGVudFdyYXBwZXJDb21wb25lbnQ7XG4iXX0= */"], children: /* @__PURE__ */ jsx(Wrapper, { children: /* @__PURE__ */ jsx(Checkbox, { "aria-label": "Select all", ...customCheckboxProps, checked: !allDisabled ? !!flattedData.length && checkedCurrentAll : allDisabledAndChecked, indeterminate: !allDisabled ? !checkedCurrentAll && checkedCurrentSome : !allDisabledAndChecked && allDisabledSomeChecked, onChange: (e) => {
|
|
66
68
|
onSelectAllChange();
|
|
67
69
|
onChange == null ? void 0 : onChange(e);
|
|
68
70
|
}, disabled: disabled ?? (flattedData.length === 0 || allDisabled) }) }) });
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ComponentType } from 'react';
|
|
2
2
|
import { TableRowSelection } from '../../types';
|
|
3
|
-
export interface HeaderCheckboxCellContentWrapperProps<Record> extends Pick<TableRowSelection<Record>, "getTitleCheckboxProps"> {
|
|
3
|
+
export interface HeaderCheckboxCellContentWrapperProps<Record> extends Pick<TableRowSelection<Record>, "getTitleCheckboxProps" | "onSelectAll"> {
|
|
4
4
|
columnTitle?: Extract<TableRowSelection<Record>["columnTitle"], ComponentType>;
|
|
5
5
|
}
|
|
@@ -35,7 +35,9 @@ const RadioCellContentWrapperComponent = (props) => {
|
|
|
35
35
|
(_a = radioProps == null ? void 0 : radioProps.onChange) == null ? void 0 : _a.call(radioProps, e);
|
|
36
36
|
});
|
|
37
37
|
const Wrapper = RenderCell ?? Fragment;
|
|
38
|
-
return /* @__PURE__ */ jsx("div", { css: [selectionItemContainerStyle, bordered ? getBorderedSelectionItemContainerStyle() : void 0, process.env.NODE_ENV === "production" ? "" : ";label:RadioCellContentWrapperComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9SYWRpb0NlbGxDb250ZW50V3JhcHBlci9SYWRpb0NlbGxDb250ZW50V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0NNIiwiZmlsZSI6Ii9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9SYWRpb0NlbGxDb250ZW50V3JhcHBlci9SYWRpb0NlbGxDb250ZW50V3JhcHBlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGcmFnbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBSYWRpb0NlbGxDb250ZW50V3JhcHBlclByb3BzIH0gZnJvbSBcIi4vUmFkaW9DZWxsQ29udGVudFdyYXBwZXIudHlwZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2NvbnRleHRzXCI7XG5pbXBvcnQgeyB1c2VFdmVudCB9IGZyb20gXCJob29rcy91c2VFdmVudFwiO1xuaW1wb3J0IHsgZ2V0Um93S2V5IH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvdXRpbHNcIjtcbmltcG9ydCB7IFJhZGlvLCB0eXBlIFJhZGlvUHJvcHMgfSBmcm9tIFwiY29tcG9uZW50cy9SYWRpb1wiO1xuaW1wb3J0IHsgdXNlVGFibGVSb3dTZWxlY3Rpb25Db250ZXh0IH0gZnJvbSBcIi4uLy4uL2NvbnRleHRzXCI7XG5pbXBvcnQgdHlwZSB7IFJvd1NlbGVjdGlvbkl0ZW1Qcm9wcyB9IGZyb20gXCIuLi8uLi9ob29rc1wiO1xuaW1wb3J0IHsgZ2V0Qm9yZGVyZWRTZWxlY3Rpb25JdGVtQ29udGFpbmVyU3R5bGUsIHNlbGVjdGlvbkl0ZW1Db250YWluZXJTdHlsZSB9IGZyb20gXCIuLi8uLi9zdHlsZXNcIjtcbmltcG9ydCB0eXBlIHsgRGVmYXVsdFJlY29yZCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL1RhYmxlLnR5cGVzXCI7XG5cbmNvbnN0IFJhZGlvQ2VsbENvbnRlbnRXcmFwcGVyQ29tcG9uZW50ID0gPFJlY29yZCBleHRlbmRzIERlZmF1bHRSZWNvcmQ+KFxuICBwcm9wczogUmFkaW9DZWxsQ29udGVudFdyYXBwZXJQcm9wczxSZWNvcmQ+XG4pID0+IHtcbiAgY29uc3QgeyByZW5kZXJDZWxsOiBSZW5kZXJDZWxsLCByZWNvcmQgfSA9IHByb3BzO1xuICBjb25zdCB7IGJvcmRlcmVkIH0gPSB1c2VUYWJsZUNvbnRleHQoKTtcbiAgY29uc3QgeyBjaGVja2JveFByb3BzTWFwLCBkZXJpdmVkU2VsZWN0ZWRLZXlTZXQsIHRyaWdnZXJTaW5nbGVTZWxlY3Rpb24gfSA9XG4gICAgdXNlVGFibGVSb3dTZWxlY3Rpb25Db250ZXh0KCk7XG4gIGNvbnN0IGtleSA9IGdldFJvd0tleShyZWNvcmQpO1xuXG4gIGNvbnN0IGNoZWNrZWQgPSBkZXJpdmVkU2VsZWN0ZWRLZXlTZXQuaGFzKGtleSk7XG4gIGNvbnN0IHJhZGlvUHJvcHMgPSBjaGVja2JveFByb3BzTWFwLmdldChrZXkpIGFzIFJvd1NlbGVjdGlvbkl0ZW1Qcm9wczxSYWRpb1Byb3BzPjtcblxuICBjb25zdCBoYW5kbGVDbGljayA9IHVzZUV2ZW50KCgoZSkgPT4ge1xuICAgIGUuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgcmFkaW9Qcm9wcz8ub25DbGljaz8uKGUpO1xuICB9KSBzYXRpc2ZpZXMgUmFkaW9Qcm9wc1tcIm9uQ2xpY2tcIl0pO1xuXG4gIGNvbnN0IGhhbmRsZUNoYW5nZSA9IHVzZUV2ZW50KCgoZSkgPT4ge1xuICAgIGlmICghZGVyaXZlZFNlbGVjdGVkS2V5U2V0LmhhcyhrZXkpKSB7XG4gICAgICB0cmlnZ2VyU2luZ2xlU2VsZWN0aW9uKGtleSwgdHJ1ZSwgW2tleV0sIGUubmF0aXZlRXZlbnQpO1xuICAgIH1cblxuICAgIHJhZGlvUHJvcHM/Lm9uQ2hhbmdlPy4oZSk7XG4gIH0pIHNhdGlzZmllcyBSYWRpb1Byb3BzW1wib25DaGFuZ2VcIl0pO1xuXG4gIGNvbnN0IFdyYXBwZXIgPSBSZW5kZXJDZWxsID8/IEZyYWdtZW50O1xuXG4gIHJldHVybiAoXG4gICAgPGRpdlxuICAgICAgY3NzPXtbXG4gICAgICAgIHNlbGVjdGlvbkl0ZW1Db250YWluZXJTdHlsZSxcbiAgICAgICAgYm9yZGVyZWQgPyBnZXRCb3JkZXJlZFNlbGVjdGlvbkl0ZW1Db250YWluZXJTdHlsZSgpIDogdW5kZWZpbmVkLFxuICAgICAgXX1cbiAgICA+
|
|
38
|
+
return /* @__PURE__ */ jsx("div", { css: [selectionItemContainerStyle, bordered ? getBorderedSelectionItemContainerStyle() : void 0, process.env.NODE_ENV === "production" ? "" : ";label:RadioCellContentWrapperComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9SYWRpb0NlbGxDb250ZW50V3JhcHBlci9SYWRpb0NlbGxDb250ZW50V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0NNIiwiZmlsZSI6Ii9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9SYWRpb0NlbGxDb250ZW50V3JhcHBlci9SYWRpb0NlbGxDb250ZW50V3JhcHBlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGcmFnbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBSYWRpb0NlbGxDb250ZW50V3JhcHBlclByb3BzIH0gZnJvbSBcIi4vUmFkaW9DZWxsQ29udGVudFdyYXBwZXIudHlwZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2NvbnRleHRzXCI7XG5pbXBvcnQgeyB1c2VFdmVudCB9IGZyb20gXCJob29rcy91c2VFdmVudFwiO1xuaW1wb3J0IHsgZ2V0Um93S2V5IH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvdXRpbHNcIjtcbmltcG9ydCB7IFJhZGlvLCB0eXBlIFJhZGlvUHJvcHMgfSBmcm9tIFwiY29tcG9uZW50cy9SYWRpb1wiO1xuaW1wb3J0IHsgdXNlVGFibGVSb3dTZWxlY3Rpb25Db250ZXh0IH0gZnJvbSBcIi4uLy4uL2NvbnRleHRzXCI7XG5pbXBvcnQgdHlwZSB7IFJvd1NlbGVjdGlvbkl0ZW1Qcm9wcyB9IGZyb20gXCIuLi8uLi9ob29rc1wiO1xuaW1wb3J0IHsgZ2V0Qm9yZGVyZWRTZWxlY3Rpb25JdGVtQ29udGFpbmVyU3R5bGUsIHNlbGVjdGlvbkl0ZW1Db250YWluZXJTdHlsZSB9IGZyb20gXCIuLi8uLi9zdHlsZXNcIjtcbmltcG9ydCB0eXBlIHsgRGVmYXVsdFJlY29yZCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL1RhYmxlLnR5cGVzXCI7XG5cbmNvbnN0IFJhZGlvQ2VsbENvbnRlbnRXcmFwcGVyQ29tcG9uZW50ID0gPFJlY29yZCBleHRlbmRzIERlZmF1bHRSZWNvcmQ+KFxuICBwcm9wczogUmFkaW9DZWxsQ29udGVudFdyYXBwZXJQcm9wczxSZWNvcmQ+XG4pID0+IHtcbiAgY29uc3QgeyByZW5kZXJDZWxsOiBSZW5kZXJDZWxsLCByZWNvcmQgfSA9IHByb3BzO1xuICBjb25zdCB7IGJvcmRlcmVkIH0gPSB1c2VUYWJsZUNvbnRleHQoKTtcbiAgY29uc3QgeyBjaGVja2JveFByb3BzTWFwLCBkZXJpdmVkU2VsZWN0ZWRLZXlTZXQsIHRyaWdnZXJTaW5nbGVTZWxlY3Rpb24gfSA9XG4gICAgdXNlVGFibGVSb3dTZWxlY3Rpb25Db250ZXh0KCk7XG4gIGNvbnN0IGtleSA9IGdldFJvd0tleShyZWNvcmQpO1xuXG4gIGNvbnN0IGNoZWNrZWQgPSBkZXJpdmVkU2VsZWN0ZWRLZXlTZXQuaGFzKGtleSk7XG4gIGNvbnN0IHJhZGlvUHJvcHMgPSBjaGVja2JveFByb3BzTWFwLmdldChrZXkpIGFzIFJvd1NlbGVjdGlvbkl0ZW1Qcm9wczxSYWRpb1Byb3BzPjtcblxuICBjb25zdCBoYW5kbGVDbGljayA9IHVzZUV2ZW50KCgoZSkgPT4ge1xuICAgIGUuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgcmFkaW9Qcm9wcz8ub25DbGljaz8uKGUpO1xuICB9KSBzYXRpc2ZpZXMgUmFkaW9Qcm9wc1tcIm9uQ2xpY2tcIl0pO1xuXG4gIGNvbnN0IGhhbmRsZUNoYW5nZSA9IHVzZUV2ZW50KCgoZSkgPT4ge1xuICAgIGlmICghZGVyaXZlZFNlbGVjdGVkS2V5U2V0LmhhcyhrZXkpKSB7XG4gICAgICB0cmlnZ2VyU2luZ2xlU2VsZWN0aW9uKGtleSwgdHJ1ZSwgW2tleV0sIGUubmF0aXZlRXZlbnQpO1xuICAgIH1cblxuICAgIHJhZGlvUHJvcHM/Lm9uQ2hhbmdlPy4oZSk7XG4gIH0pIHNhdGlzZmllcyBSYWRpb1Byb3BzW1wib25DaGFuZ2VcIl0pO1xuXG4gIGNvbnN0IFdyYXBwZXIgPSBSZW5kZXJDZWxsID8/IEZyYWdtZW50O1xuXG4gIHJldHVybiAoXG4gICAgPGRpdlxuICAgICAgY3NzPXtbXG4gICAgICAgIHNlbGVjdGlvbkl0ZW1Db250YWluZXJTdHlsZSxcbiAgICAgICAgYm9yZGVyZWQgPyBnZXRCb3JkZXJlZFNlbGVjdGlvbkl0ZW1Db250YWluZXJTdHlsZSgpIDogdW5kZWZpbmVkLFxuICAgICAgXX1cbiAgICA+XG4gICAgICA8V3JhcHBlciB7Li4uKFJlbmRlckNlbGwgPyB7IHNlbGVjdGlvblR5cGU6IFwicmFkaW9cIiB9IDoge30pfT5cbiAgICAgICAgPFJhZGlvIHsuLi5yYWRpb1Byb3BzfSBjaGVja2VkPXtjaGVja2VkfSBvbkNsaWNrPXtoYW5kbGVDbGlja30gb25DaGFuZ2U9e2hhbmRsZUNoYW5nZX0gLz5cbiAgICAgIDwvV3JhcHBlcj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBSYWRpb0NlbGxDb250ZW50V3JhcHBlciA9IFJhZGlvQ2VsbENvbnRlbnRXcmFwcGVyQ29tcG9uZW50O1xuIl19 */"], children: /* @__PURE__ */ jsx(Wrapper, { ...RenderCell ? {
|
|
39
|
+
selectionType: "radio"
|
|
40
|
+
} : {}, children: /* @__PURE__ */ jsx(Radio, { ...radioProps, checked, onClick: handleClick, onChange: handleChange }) }) });
|
|
39
41
|
};
|
|
40
42
|
const RadioCellContentWrapper = RadioCellContentWrapperComponent;
|
|
41
43
|
export {
|
|
@@ -6,14 +6,14 @@ export declare const useTableRowSelection: <Record extends DefaultRecord<Record>
|
|
|
6
6
|
checkedCurrentAll: boolean;
|
|
7
7
|
checkedCurrentSome: boolean;
|
|
8
8
|
flattedData: Record[];
|
|
9
|
-
checkboxPropsMap: Map<
|
|
10
|
-
derivedSelectedKeySet: Set<
|
|
11
|
-
derivedSelectedKeys:
|
|
12
|
-
derivedHalfSelectedKeySet: Set<
|
|
13
|
-
recordKeys:
|
|
14
|
-
keySet: Set<
|
|
9
|
+
checkboxPropsMap: Map<Key, Partial<Omit<import('../../../../../Checkbox').CheckboxProps, "defaultChecked" | "checked">>>;
|
|
10
|
+
derivedSelectedKeySet: Set<Key>;
|
|
11
|
+
derivedSelectedKeys: Key[];
|
|
12
|
+
derivedHalfSelectedKeySet: Set<Key>;
|
|
13
|
+
recordKeys: Key[];
|
|
14
|
+
keySet: Set<Key>;
|
|
15
15
|
triggerSingleSelection: (key: Key, selected: boolean, keys: Key[], event: Event) => void;
|
|
16
16
|
setSelectedKeys: (keys: Key[], method: RowSelectMethod) => void;
|
|
17
|
-
multipleSelect: (currentSelectedIndex: number, data:
|
|
17
|
+
multipleSelect: (currentSelectedIndex: number, data: Key[], selectedKeys: Set<Key>) => Key[];
|
|
18
18
|
updatePrevSelectedIndex: import('react').Dispatch<import('react').SetStateAction<import('../useMultipleSelect/useMultipleSelect.types').PrevSelectedIndex>>;
|
|
19
19
|
};
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { useMemo, useCallback } from "react";
|
|
2
|
+
import { useEmitter } from "../../../typedEventBus/hooks.js";
|
|
2
3
|
import { useEvent } from "../../../../../../hooks/useEvent/useEvent.js";
|
|
3
4
|
import { compact } from "lodash-es";
|
|
4
5
|
import { useMultipleSelect } from "../useMultipleSelect/useMultipleSelect.js";
|
|
5
6
|
import { flattenData } from "./useTableRowSelection.utils.js";
|
|
6
7
|
import { useControlledState } from "../../../../../../hooks/useControlledState/useControlledState.js";
|
|
7
8
|
import { getRowKey } from "../../../../utils/getRowKey/getRowKey.js";
|
|
8
|
-
import { useEmitter } from "../../../typedEventBus/hooks.js";
|
|
9
9
|
import { useFirstMountLayoutEffect } from "../../../../../../hooks/useFirstMountLayoutEffect/useFirstMountLayoutEffect.js";
|
|
10
10
|
const useTableRowSelection = (options) => {
|
|
11
11
|
const {
|
|
@@ -38,7 +38,7 @@ const useTableRowSelection = (options) => {
|
|
|
38
38
|
}
|
|
39
39
|
});
|
|
40
40
|
}
|
|
41
|
-
dig(dataSource);
|
|
41
|
+
dig(dataSource || []);
|
|
42
42
|
const getRecordByKey2 = (key) => {
|
|
43
43
|
return map.get(key);
|
|
44
44
|
};
|
|
@@ -22,6 +22,7 @@ const useTransformColumns = (options) => {
|
|
|
22
22
|
hideSelectAll,
|
|
23
23
|
onCell,
|
|
24
24
|
getTitleCheckboxProps,
|
|
25
|
+
onSelectAll,
|
|
25
26
|
renderCell,
|
|
26
27
|
type = "checkbox"
|
|
27
28
|
} = rowSelection;
|
|
@@ -31,7 +32,7 @@ const useTransformColumns = (options) => {
|
|
|
31
32
|
if (Title === Fragment) {
|
|
32
33
|
return;
|
|
33
34
|
}
|
|
34
|
-
return /* @__PURE__ */ jsx(Title, { columnTitle, getTitleCheckboxProps });
|
|
35
|
+
return /* @__PURE__ */ jsx(Title, { columnTitle, getTitleCheckboxProps, onSelectAll });
|
|
35
36
|
}
|
|
36
37
|
return columnTitle;
|
|
37
38
|
})();
|
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import { CheckboxProps } from 'components/Checkbox';
|
|
2
2
|
import { GetComponentProps } from 'components/Table/interfaces/tableComponents.types';
|
|
3
3
|
import { DefaultRecord, Key } from 'components/Table/Table.types';
|
|
4
|
-
import { AriaAttributes, ComponentType, ReactNode } from 'react';
|
|
4
|
+
import { AriaAttributes, ComponentType, PropsWithChildren, ReactNode } from 'react';
|
|
5
5
|
type RowSelectionType = "checkbox" | "radio";
|
|
6
6
|
export type RowSelectMethod = "all" | "none" | "invert" | "single" | "multiple";
|
|
7
7
|
type SelectionSelectFn<T = DefaultRecord> = (record: T, selected: boolean, selectedRows: T[], nativeEvent: Event) => void;
|
|
8
|
+
interface RenderCellProps extends PropsWithChildren {
|
|
9
|
+
selectionType?: RowSelectionType;
|
|
10
|
+
}
|
|
8
11
|
export interface TableRowSelection<T = DefaultRecord> {
|
|
9
12
|
type?: RowSelectionType;
|
|
10
13
|
defaultSelectedRowKeys?: Key[];
|
|
@@ -15,10 +18,11 @@ export interface TableRowSelection<T = DefaultRecord> {
|
|
|
15
18
|
getTitleCheckboxProps?: () => Partial<Omit<CheckboxProps, "checked" | "defaultChecked">> & AriaAttributes;
|
|
16
19
|
getCheckboxProps?: (record: T) => Partial<Omit<CheckboxProps, "checked" | "defaultChecked">>;
|
|
17
20
|
onSelect?: SelectionSelectFn<T>;
|
|
21
|
+
onSelectAll?: (selected: boolean) => void;
|
|
18
22
|
hideSelectAll?: boolean;
|
|
19
23
|
columnWidth?: string | number;
|
|
20
24
|
columnTitle?: ReactNode | ComponentType;
|
|
21
|
-
renderCell?: ComponentType
|
|
25
|
+
renderCell?: ComponentType<RenderCellProps>;
|
|
22
26
|
onCell?: GetComponentProps<T>;
|
|
23
27
|
}
|
|
24
28
|
export {};
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { useState } from "react";
|
|
2
|
+
import { useSubscribe } from "../../../typedEventBus/hooks.js";
|
|
2
3
|
import { useTableContext } from "../../../../contexts/tableContext/useTableContext/useTableContext.js";
|
|
3
4
|
import { useTableStaticContext } from "../../../tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
|
|
4
5
|
import { getRefValue } from "../../../../utils/ref/ref.js";
|
|
5
|
-
import { useSubscribe } from "../../../typedEventBus/hooks.js";
|
|
6
6
|
const useSortState = (options) => {
|
|
7
7
|
const {
|
|
8
8
|
column
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { useState, useMemo } from "react";
|
|
2
|
+
import { useEmitter } from "../../../typedEventBus/hooks.js";
|
|
2
3
|
import { useEvent } from "../../../../../../hooks/useEvent/useEvent.js";
|
|
3
4
|
import { useTableStaticContext } from "../../../tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
|
|
4
5
|
import { getRefValue } from "../../../../utils/ref/ref.js";
|
|
5
|
-
import { useEmitter } from "../../../typedEventBus/hooks.js";
|
|
6
6
|
import { useFirstMountLayoutEffect } from "../../../../../../hooks/useFirstMountLayoutEffect/useFirstMountLayoutEffect.js";
|
|
7
7
|
import { getSortedData } from "../../utils/getSortedData/getSortedData.js";
|
|
8
8
|
const useTableSort = (options) => {
|
|
@@ -21,7 +21,7 @@ const useTableSort = (options) => {
|
|
|
21
21
|
sortState
|
|
22
22
|
});
|
|
23
23
|
}, [emitSort, sortState]);
|
|
24
|
-
const sortedData = useMemo(() => getSortedData(dataSource, sortState), [dataSource, sortState]);
|
|
24
|
+
const sortedData = useMemo(() => getSortedData(dataSource || [], sortState), [dataSource, sortState]);
|
|
25
25
|
const hasData = Boolean(sortedData.length);
|
|
26
26
|
const triggerSorter = (sortState2) => {
|
|
27
27
|
setSortState(sortState2);
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { TableStaticContextValue } from './TableStaticContext.types';
|
|
2
|
-
import { DefaultRecord } from 'components/Table/Table.types';
|
|
2
|
+
import { DefaultRecord, Key } from 'components/Table/Table.types';
|
|
3
3
|
export declare const initialTableStaticContextValue: {
|
|
4
|
-
readonly staticSelectedKeySet: Set<
|
|
4
|
+
readonly staticSelectedKeySet: Set<Key>;
|
|
5
5
|
readonly triggerSorter: (...args: any[]) => void;
|
|
6
6
|
readonly sortState: undefined;
|
|
7
7
|
readonly colsWidthsMap: Map<any, any>;
|
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
-
import { forwardRef
|
|
2
|
+
import { forwardRef } from "react";
|
|
3
3
|
import { useStatic } from "../../../../../hooks/useStatic/useStatic.js";
|
|
4
|
-
import {
|
|
4
|
+
import { createTableStaticContext, initialTableStaticContextValue } from "../contexts/tableStaticContext/TableStaticContext.js";
|
|
5
|
+
import { cloneDeep } from "lodash-es";
|
|
5
6
|
const withTableStaticContext = (Component) => {
|
|
6
7
|
const WithTableStaticContext = forwardRef((props, ref) => {
|
|
7
8
|
const TableStaticContext = useStatic(() => createTableStaticContext());
|
|
8
|
-
const tableStaticContextValueRef =
|
|
9
|
+
const tableStaticContextValueRef = useStatic(() => ({
|
|
10
|
+
current: cloneDeep(initialTableStaticContextValue)
|
|
11
|
+
}));
|
|
9
12
|
return /* @__PURE__ */ jsx(TableStaticContext.Provider, { value: tableStaticContextValueRef, children: /* @__PURE__ */ jsx(Component, { ref, ...props }) });
|
|
10
13
|
});
|
|
11
14
|
return WithTableStaticContext;
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { TableEventMap } from './types';
|
|
2
|
-
export declare const useEmitter: <K extends keyof TableEventMap<import('
|
|
3
|
-
export declare const useSubscribe: <K extends keyof TableEventMap<import('
|
|
2
|
+
export declare const useEmitter: <K extends keyof TableEventMap<import('../..').DefaultRecord<any>>>(event: K) => (payload: TableEventMap<import('../..').DefaultRecord<any>>[K]) => void;
|
|
3
|
+
export declare const useSubscribe: <K extends keyof TableEventMap<import('../..').DefaultRecord<any>>>(event: K, callback: (payload: TableEventMap<import('../..').DefaultRecord<any>>[K]) => void, skipSubscribe?: boolean, deps?: import('react').DependencyList, layoutEffect?: boolean) => void;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { useState, useRef } from "react";
|
|
2
2
|
import { isNumber } from "lodash-es";
|
|
3
|
+
import { useSubscribe } from "../../features/typedEventBus/hooks.js";
|
|
3
4
|
import { getCellFixedMinimalInfo, getCellFixedInfo } from "./useCellFixedInfo.utils.js";
|
|
4
5
|
import { useTableContext } from "../../contexts/tableContext/useTableContext/useTableContext.js";
|
|
5
|
-
import { useSubscribe } from "../../features/typedEventBus/hooks.js";
|
|
6
6
|
import { updateRefValue, getRefValue } from "../../utils/ref/ref.js";
|
|
7
7
|
const useCellFixedInfo = (options) => {
|
|
8
8
|
const {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { useRef, useState } from "react";
|
|
2
|
-
import { isInHoverRange } from "./useCellHover.utils.js";
|
|
3
2
|
import { useSubscribe, useEmitter } from "../../features/typedEventBus/hooks.js";
|
|
3
|
+
import { isInHoverRange } from "./useCellHover.utils.js";
|
|
4
4
|
const useCellHover = (options) => {
|
|
5
5
|
const {
|
|
6
6
|
index,
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { UseTableColumnsOptions } from './useTableColumns.types';
|
|
2
2
|
import { DefaultRecord } from 'components/Table/Table.types';
|
|
3
3
|
export declare const useTableColumns: <Record extends DefaultRecord>(options: UseTableColumnsOptions<Record>) => {
|
|
4
|
-
columns: (import('../../interfaces/tableColumns.types').
|
|
5
|
-
flattedColumns: import('
|
|
4
|
+
columns: (import('../..').ColumnWithChildren<Record, import('../../interfaces/tableColumns.types').Columns<Record>> | import('../..').Column<Record>)[];
|
|
5
|
+
flattedColumns: import('../..').Column<Record>[];
|
|
6
6
|
isAllColumnsFixedStart: boolean;
|
|
7
7
|
};
|
package/dist/components/Table/hooks/useTableVisualParamsChange/useTableVisualParamsChange.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { useRef, useLayoutEffect, useCallback } from "react";
|
|
2
2
|
import { useEvent } from "../../../../hooks/useEvent/useEvent.js";
|
|
3
|
+
import { useEmitter } from "../../features/typedEventBus/hooks.js";
|
|
3
4
|
import "rc-resize-observer";
|
|
4
5
|
import { getVerticalScrollBarWidth, forceScroll, getHorizontalScrollPositionRange } from "./utils.js";
|
|
5
6
|
import { useTableStaticContext } from "../../features/tableStaticContext/contexts/tableStaticContext/useTableStaticContext/useTableStaticContext.js";
|
|
6
|
-
import { useEmitter } from "../../features/typedEventBus/hooks.js";
|
|
7
7
|
import { updateRefValue, getRefValue } from "../../utils/ref/ref.js";
|
|
8
8
|
const useTableVisualParamsChange = (options) => {
|
|
9
9
|
const {
|
|
@@ -7,36 +7,40 @@ export type ColScopeType = "col" | "colgroup";
|
|
|
7
7
|
export type RowScopeType = "row" | "rowgroup";
|
|
8
8
|
export type ScopeType = ColScopeType | RowScopeType;
|
|
9
9
|
export type AlignType = "start" | "end" | "left" | "right" | "center" | "justify" | "match-parent";
|
|
10
|
-
|
|
10
|
+
export type RenderFn<V, R> = (value: V, record: R, index: number) => ReactNode;
|
|
11
|
+
type BaseColumn<Record> = {
|
|
11
12
|
key: Key;
|
|
12
|
-
dataIndex?: PropertyPath;
|
|
13
13
|
title?: ReactNode;
|
|
14
14
|
fixed?: "start" | "end";
|
|
15
15
|
onHeaderCell?: GetSingleComponentProps<Columns<Record>[number]>;
|
|
16
16
|
rowScope?: RowScopeType;
|
|
17
17
|
align?: CSSProperties["textAlign"];
|
|
18
18
|
ellipsis?: CellEllipsisType;
|
|
19
|
-
render?: (value: any, record: Record, index: number) => ReactNode;
|
|
20
19
|
sorter?: boolean | CompareFn<Record>;
|
|
21
20
|
defaultSortOrder?: SortOrder;
|
|
22
21
|
sortDirections?: SortOrder[];
|
|
23
22
|
colSpan?: number;
|
|
24
23
|
rowSpan?: number;
|
|
25
|
-
|
|
24
|
+
width?: number | string;
|
|
25
|
+
minWidth?: number | string;
|
|
26
|
+
} & ({
|
|
27
|
+
dataIndex: PropertyPath;
|
|
28
|
+
render?: RenderFn<any, Record>;
|
|
29
|
+
} | {
|
|
30
|
+
dataIndex?: never;
|
|
31
|
+
render?: RenderFn<Record, Record>;
|
|
32
|
+
});
|
|
26
33
|
export type CellEllipsisType = {
|
|
27
34
|
showTitle?: boolean;
|
|
28
35
|
} | boolean;
|
|
29
|
-
|
|
36
|
+
export type ColumnWithChildren<Record, C extends Columns<Record> = Columns<Record>> = BaseColumn<Record> & {
|
|
30
37
|
onCell?: never;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
export interface Column<Record> extends BaseColumn<Record> {
|
|
38
|
+
} & {
|
|
39
|
+
children: C;
|
|
40
|
+
};
|
|
41
|
+
export type Column<Record> = BaseColumn<Record> & {
|
|
36
42
|
onCell?: GetComponentProps<Record>;
|
|
37
|
-
|
|
38
|
-
minWidth?: number | string;
|
|
39
|
-
}
|
|
43
|
+
};
|
|
40
44
|
export type Columns<Record> = readonly (ColumnWithChildren<Record> | Column<Record>)[];
|
|
41
45
|
export type Writable<T> = {
|
|
42
46
|
-readonly [P in keyof T]: T[P];
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { DefaultRecord } from '../../Table.types';
|
|
2
|
-
export declare const getRowKey: <T extends DefaultRecord>(record: T) => import('
|
|
2
|
+
export declare const getRowKey: <T extends DefaultRecord>(record: T) => import('../../Table.types').Key;
|
package/dist/index.d.ts
CHANGED
|
@@ -45,9 +45,9 @@ export { type FormProps, type FormItemProps, Form } from './components/Form';
|
|
|
45
45
|
export { type PopconfirmProps, Popconfirm } from './components/Popconfirm';
|
|
46
46
|
export { TreeSelect } from './components/TreeSelect';
|
|
47
47
|
export type { TreeSelectProps } from './components/TreeSelect';
|
|
48
|
-
export { type EmptyProps, Empty } from './components/Empty';
|
|
48
|
+
export { type EmptyProps, type WithImages, Empty } from './components/Empty';
|
|
49
49
|
export { type SegmentedProps, type SegmentedLabeledOption, Segmented, } from './components/Segmented';
|
|
50
50
|
export { ContextIsolator } from './components/ContextIsolator';
|
|
51
51
|
export { type SpinProps, Spin } from './components/Spin';
|
|
52
|
-
export { type TableProps, Table } from './components/Table';
|
|
52
|
+
export { type TableProps, type DefaultRecord, type RenderFn, type Column, type ColumnWithChildren, Table, } from './components/Table';
|
|
53
53
|
export * from 'react-intersection-observer/test-utils';
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@infomaximum/ui-kit",
|
|
3
3
|
"license": "Apache-2.0",
|
|
4
|
-
"version": "0.16.
|
|
4
|
+
"version": "0.16.2",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
7
7
|
"module": "dist/index.js",
|
|
@@ -41,6 +41,7 @@
|
|
|
41
41
|
"@floating-ui/react": "^0.27.6",
|
|
42
42
|
"@infomaximum/icons": "^1.3.3",
|
|
43
43
|
"@tanstack/react-virtual": "^3.13.6",
|
|
44
|
+
"@types/lodash-es": "^4.17.12",
|
|
44
45
|
"lodash-es": "^4.17.21",
|
|
45
46
|
"rc-picker": "^4.11.3",
|
|
46
47
|
"rc-resize-observer": "^1.4.3",
|
|
@@ -70,7 +71,6 @@
|
|
|
70
71
|
"@storybook/react-vite": "^8.5.0",
|
|
71
72
|
"@storybook/test": "^8.5.0",
|
|
72
73
|
"@testing-library/react": "^16.2.0",
|
|
73
|
-
"@types/lodash-es": "^4.17.12",
|
|
74
74
|
"@types/node": "^22.10.7",
|
|
75
75
|
"@types/react": "^18.3.18",
|
|
76
76
|
"@types/react-dom": "^18.3.5",
|