@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.
Files changed (45) hide show
  1. package/dist/components/Empty/Empty.js +5 -5
  2. package/dist/components/Empty/Empty.types.d.ts +3 -0
  3. package/dist/components/Empty/index.d.ts +1 -1
  4. package/dist/components/Spin/Spin.js +4 -2
  5. package/dist/components/Spin/Spin.styles.d.ts +8 -8
  6. package/dist/components/Spin/Spin.types.d.ts +5 -0
  7. package/dist/components/Table/Table.js +16 -6
  8. package/dist/components/Table/Table.types.d.ts +6 -4
  9. package/dist/components/Table/components/Body/Body.d.ts +1 -1
  10. package/dist/components/Table/components/Body/Body.js +5 -1
  11. package/dist/components/Table/components/Body/Body.types.d.ts +1 -0
  12. package/dist/components/Table/components/Body/components/BodyRow/BodyRow.js +1 -1
  13. package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.js +1 -1
  14. package/dist/components/Table/components/Body/components/MeasureRow/MeasureRow.utils.d.ts +1 -1
  15. package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.d.ts +1 -2
  16. package/dist/components/Table/components/EmptyDataRow/EmptyDataRow.js +4 -4
  17. package/dist/components/Table/components/FixedHeader/components/FixedHeaderColGroup/FixedHeaderColGroup.js +1 -1
  18. package/dist/components/Table/features/tableExpand/hooks/useBodyExpand/useBodyExpand.d.ts +2 -2
  19. package/dist/components/Table/features/tableExpand/hooks/useTableExpand/useTableExpand.d.ts +1 -1
  20. package/dist/components/Table/features/tableExpand/hooks/useTableExpand/useTableExpand.js +1 -1
  21. package/dist/components/Table/features/tableRowSelection/components/CheckboxCellContentWrapper/CheckboxCellContentWrapper.js +3 -1
  22. package/dist/components/Table/features/tableRowSelection/components/CheckboxCellContentWrapper/CheckboxCellContentWrapper.utils.d.ts +2 -2
  23. package/dist/components/Table/features/tableRowSelection/components/HeaderCheckboxCellContentWrapper/HeaderCheckboxCellContentWrapper.js +4 -2
  24. package/dist/components/Table/features/tableRowSelection/components/HeaderCheckboxCellContentWrapper/HeaderCheckboxCellContentWrapper.types.d.ts +1 -1
  25. package/dist/components/Table/features/tableRowSelection/components/RadioCellContentWrapper/RadioCellContentWrapper.js +3 -1
  26. package/dist/components/Table/features/tableRowSelection/hooks/useTableRowSelection/useTableRowSelection.d.ts +7 -7
  27. package/dist/components/Table/features/tableRowSelection/hooks/useTableRowSelection/useTableRowSelection.js +2 -2
  28. package/dist/components/Table/features/tableRowSelection/hooks/useTransformColumns/useTransformColumns.js +2 -1
  29. package/dist/components/Table/features/tableRowSelection/types.d.ts +6 -2
  30. package/dist/components/Table/features/tableSort/hooks/useSortState/useSortState.js +1 -1
  31. package/dist/components/Table/features/tableSort/hooks/useTableSort/useTableSort.js +2 -2
  32. package/dist/components/Table/features/tableStaticContext/contexts/tableStaticContext/TableStaticContext.d.ts +2 -2
  33. package/dist/components/Table/features/tableStaticContext/contexts/tableStaticContext/TableStaticContext.js +1 -1
  34. package/dist/components/Table/features/tableStaticContext/hocs/withTableStaticContext.js +6 -3
  35. package/dist/components/Table/features/typedEventBus/hooks.d.ts +2 -2
  36. package/dist/components/Table/hooks/useBodyCellRender/useBodyCellRender.js +2 -0
  37. package/dist/components/Table/hooks/useCellFixedInfo/useCellFixedInfo.js +1 -1
  38. package/dist/components/Table/hooks/useCellHover/useCellHover.js +1 -1
  39. package/dist/components/Table/hooks/useTableColumns/useTableColumns.d.ts +2 -2
  40. package/dist/components/Table/hooks/useTableVisualParamsChange/useTableVisualParamsChange.js +1 -1
  41. package/dist/components/Table/index.d.ts +2 -1
  42. package/dist/components/Table/interfaces/tableColumns.types.d.ts +17 -13
  43. package/dist/components/Table/utils/getRowKey/getRowKey.d.ts +1 -1
  44. package/dist/index.d.ts +2 -2
  45. 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+e2ltYWdlfTwvZGl2PlxuICAgICAge3RpdGxlICYmIDxkaXYgY3NzPXt0aXRsZVN0eWxlKGVtcHR5VG9rZW5zKSh0aGVtZSl9Pnt0aXRsZX08L2Rpdj59XG4gICAgICB7Y2FwdGlvbiAmJiA8ZGl2IGNzcz17Y2FwdGlvblN0eWxlKGVtcHR5VG9rZW5zKSh0aGVtZSl9PntjYXB0aW9ufTwvZGl2Pn1cbiAgICAgIHtjaGlsZHJlbiAmJiA8ZGl2IGNzcz17Zm9vdGVyU3R5bGUoZW1wdHlUb2tlbnMpfT57Y2hpbGRyZW59PC9kaXY+fVxuICAgIDwvZGl2PlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IEVtcHR5ID0gbWVtbyhFbXB0eUNvbXBvbmVudCkgYXMgTmFtZWRFeG90aWNDb21wb25lbnQ8RW1wdHlQcm9wcz4gJiBXaXRoSW1hZ2VzO1xuXG5FbXB0eS5ERUZBVUxUID0gPERlZmF1bHRJbWcgLz47XG5FbXB0eS5GSUxURVIgPSA8RmlsdGVySW1nIC8+O1xuRW1wdHkuU0VBUkNIID0gPFNlYXJjaEltZyAvPjtcbkVtcHR5LkxPQ0tFRCA9IDxMb2NrZWRJbWcgLz47XG5FbXB0eS5CT09LTUFSSyA9IDxCb29rbWFya0ltZyAvPjtcbkVtcHR5LlRFU1RJTkcgPSA8VGVzdGluZ0ltZyAvPjtcbkVtcHR5WzQwNF0gPSA8XzQwNEltZyAvPjtcbiJdfQ== */"], children: [
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: string;
43
- zIndex: number;
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, jsx } from "@emotion/react/jsx-runtime";
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, Key as ReactKey, ReactNode, UIEventHandler } from 'react';
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
- export type Key = ReactKey;
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: readonly Record[];
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,4 +1,4 @@
1
1
  import { Key } from 'components/Table/Table.types';
2
2
  export declare function getColumnsKeys(columns: readonly {
3
3
  key: Key;
4
- }[]): import('react').Key[];
4
+ }[]): Key[];
@@ -1,3 +1,2 @@
1
- import { FC } from 'react';
2
1
  import { EmptyDataRowProps } from './EmptyDataRow.types';
3
- export declare const EmptyDataRow: FC<EmptyDataRowProps>;
2
+ export declare const EmptyDataRow: import('react').NamedExoticComponent<EmptyDataRowProps>;
@@ -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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvY29tcG9uZW50cy9FbXB0eURhdGFSb3cvRW1wdHlEYXRhUm93LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRVEiLCJmaWxlIjoiL2J1aWxkcy9mcm9udGVuZC9saWJzL3VpLWtpdC9zcmMvY29tcG9uZW50cy9UYWJsZS9jb21wb25lbnRzL0VtcHR5RGF0YVJvdy9FbXB0eURhdGFSb3cudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlQ29udGV4dCwgdXNlTWVtbywgdXNlU3RhdGUsIHR5cGUgQ1NTUHJvcGVydGllcywgdHlwZSBGQyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBFbXB0eURhdGFSb3dQcm9wcyB9IGZyb20gXCIuL0VtcHR5RGF0YVJvdy50eXBlc1wiO1xuaW1wb3J0IHsgdXNlU3Vic2NyaWJlIH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdHlwZWRFdmVudEJ1c1wiO1xuaW1wb3J0IHsgaXNOdW1iZXIsIGlzT2JqZWN0LCBpc1VuZGVmaW5lZCB9IGZyb20gXCJsb2Rhc2gtZXNcIjtcbmltcG9ydCB7IEVtcHR5IH0gZnJvbSBcImNvbXBvbmVudHMvRW1wdHlcIjtcbmltcG9ydCB7IHVzZVRhYmxlU3RhdGljQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2ZlYXR1cmVzL3RhYmxlU3RhdGljQ29udGV4dFwiO1xuaW1wb3J0IHsgZ2V0UmVmVmFsdWUgfSBmcm9tIFwiY29tcG9uZW50cy9UYWJsZS91dGlsc1wiO1xuaW1wb3J0IHsgdXNlVGFibGVDb250ZXh0IH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvY29udGV4dHNcIjtcbmltcG9ydCB7IGdldEJvcmRlcmVkQ2VsbFN0eWxlLCBnZXRDZWxsU3R5bGUsIGVtcHR5V3JhcHBlclN0eWxlIH0gZnJvbSBcIi4vRW1wdHlEYXRhUm93LnN0eWxlc1wiO1xuaW1wb3J0IHsgQ29uZmlnQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL0NvbmZpZ1Byb3ZpZGVyXCI7XG5pbXBvcnQgeyBnZXRFbmRSYW5nZUluZm8gfSBmcm9tIFwiLi9FbXB0eURhdGFSb3cudXRpbHNcIjtcblxuY29uc3QgRW1wdHlEYXRhUm93Q29tcG9uZW50OiBGQzxFbXB0eURhdGFSb3dQcm9wcz4gPSAoKSA9PiB7XG4gIGNvbnN0IHsgcmVuZGVyRW1wdHkgfSA9IHVzZUNvbnRleHQoQ29uZmlnQ29udGV4dCk7XG4gIGNvbnN0IHsgZmxhdHRlZENvbHVtbnMsIGJvcmRlcmVkLCB0YWJsZVRva2VucywgaG9yaXpvblNjcm9sbCB9ID0gdXNlVGFibGVDb250ZXh0KCk7XG4gIGNvbnN0IHN0YXRpY0NvbnRleHRSZWYgPSB1c2VUYWJsZVN0YXRpY0NvbnRleHQoKTtcblxuICBjb25zdCBbY2xpZW50V2lkdGgsIHNldENsaWVudFdpZHRoXSA9IHVzZVN0YXRlKCgpID0+IHtcbiAgICBjb25zdCBjbGllbnRXaWR0aCA9IGdldFJlZlZhbHVlKHN0YXRpY0NvbnRleHRSZWYsIFwic2Nyb2xsYWJsZVRhYmxlU2VjdGlvbkluZm8uY2xpZW50V2lkdGhcIik7XG4gICAgY29uc3QgdmVydGljYWxTY3JvbGxCYXJXaWR0aCA9IGdldFJlZlZhbHVlKFxuICAgICAgc3RhdGljQ29udGV4dFJlZixcbiAgICAgIFwic2Nyb2xsYWJsZVRhYmxlU2VjdGlvbkluZm8udmVydGljYWxTY3JvbGxCYXJXaWR0aFwiXG4gICAgKTtcbiAgICBjb25zdCB7IGhhc0VuZFJhbmdlIH0gPSBnZXRFbmRSYW5nZUluZm8oc3RhdGljQ29udGV4dFJlZik7XG5cbiAgICByZXR1cm4gaGFzRW5kUmFuZ2UgPyBjbGllbnRXaWR0aCArIHZlcnRpY2FsU2Nyb2xsQmFyV2lkdGggOiB1bmRlZmluZWQ7XG4gIH0pO1xuICBjb25zdCBbY2VsbE92ZXJmbG93WCwgc2V0Q2VsbE92ZXJmbG93WF0gPSB1c2VTdGF0ZTxDU1NQcm9wZXJ0aWVzW1wib3ZlcmZsb3dYXCJdPigoKSA9PiB7XG4gICAgY29uc3QgeyBoYXNFbmRSYW5nZSB9ID0gZ2V0RW5kUmFuZ2VJbmZvKHN0YXRpY0NvbnRleHRSZWYpO1xuXG4gICAgcmV0dXJuIGhhc0VuZFJhbmdlID8gdW5kZWZpbmVkIDogXCJoaWRkZW5cIjtcbiAgfSk7XG5cbiAgdXNlU3Vic2NyaWJlKFxuICAgIFwidGFibGUtdmlzdWFsLXBhcmFtczpjaGFuZ2VcIixcbiAgICAodmFsdWUpID0+IHtcbiAgICAgIGNvbnN0IHsgY2xpZW50V2lkdGgsIGhvcml6b250YWxTY3JvbGxQb3NpdGlvblJhbmdlIH0gPSB2YWx1ZTtcblxuICAgICAgaWYgKGlzVW5kZWZpbmVkKGNsaWVudFdpZHRoKSB8fCAhaG9yaXpvbnRhbFNjcm9sbFBvc2l0aW9uUmFuZ2UpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBjb25zdCB7IGhhc0VuZFJhbmdlIH0gPSBnZXRFbmRSYW5nZUluZm8oaG9yaXpvbnRhbFNjcm9sbFBvc2l0aW9uUmFuZ2UpO1xuXG4gICAgICBzZXRDbGllbnRXaWR0aChoYXNFbmRSYW5nZSA/IGNsaWVudFdpZHRoIDogdW5kZWZpbmVkKTtcbiAgICAgIHNldENlbGxPdmVyZmxvd1goaGFzRW5kUmFuZ2UgPyB1bmRlZmluZWQgOiBcImhpZGRlblwiKTtcbiAgICB9LFxuICAgIGZhbHNlLFxuICAgIFtdLFxuICAgIHRydWVcbiAgKTtcblxuICBjb25zdCBlbXB0eSA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIGlmIChyZW5kZXJFbXB0eSkge1xuICAgICAgcmV0dXJuIHJlbmRlckVtcHR5KCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIDxFbXB0eSAvPjtcbiAgfSwgW3JlbmRlckVtcHR5XSk7XG5cbiAgY29uc3QgaGFzSW5saW5lQm9yZGVyID0gQm9vbGVhbihib3JkZXJlZCAmJiBib3JkZXJlZC5lbXB0eUlubGluZSk7XG4gIGNvbnN0IGhhc0Jsb2NrRW5kQm9yZGVyID0gIWlzT2JqZWN0KGJvcmRlcmVkKSB8fCBCb29sZWFuKGJvcmRlcmVkICYmIGJvcmRlcmVkLmVtcHR5QmxvY2tFbmQpO1xuXG4gIHJldHVybiAoXG4gICAgPHRyPlxuICAgICAgPHRkXG4gICAgICAgIGNzcz17W1xuICAgICAgICAgIGNlbGxPdmVyZmxvd1ggPyB7IG92ZXJmbG93WDogY2VsbE92ZXJmbG93WCB9IDogdW5kZWZpbmVkLFxuICAgICAgICAgIGdldENlbGxTdHlsZSh0YWJsZVRva2VucywgaGFzQmxvY2tFbmRCb3JkZXIpLFxuICAgICAgICAgIGJvcmRlcmVkID8gZ2V0Qm9yZGVyZWRDZWxsU3R5bGUoaGFzSW5saW5lQm9yZGVyKSA6IHVuZGVmaW5lZCxcbiAgICAgICAgXX1cbiAgICAgICAgY29sU3Bhbj17ZmxhdHRlZENvbHVtbnMubGVuZ3RofVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgc3R5bGU9e1xuICAgICAgICAgICAgaG9yaXpvblNjcm9sbFxuICAgICAgICAgICAgICA/IHtcbiAgICAgICAgICAgICAgICAgIHdpZHRoOlxuICAgICAgICAgICAgICAgICAgICBpc051bWJlcihjbGllbnRXaWR0aCkgJiYgY2xpZW50V2lkdGggPiAwICYmIGhhc0lubGluZUJvcmRlclxuICAgICAgICAgICAgICAgICAgICAgID8gY2xpZW50V2lkdGggLSAyXG4gICAgICAgICAgICAgICAgICAgICAgOiBjbGllbnRXaWR0aCxcbiAgICAgICAgICAgICAgICAgIGxlZnQ6IGhhc0lubGluZUJvcmRlciA/IDEgOiAwLFxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgOiB1bmRlZmluZWRcbiAgICAgICAgICB9XG4gICAgICAgICAgY3NzPXtob3Jpem9uU2Nyb2xsID8gZW1wdHlXcmFwcGVyU3R5bGUgOiB1bmRlZmluZWR9XG4gICAgICAgID5cbiAgICAgICAgICB7ZW1wdHl9XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC90ZD5cbiAgICA8L3RyPlxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IEVtcHR5RGF0YVJvdyA9IEVtcHR5RGF0YVJvd0NvbXBvbmVudDtcbiJdfQ== */"], colSpan: flattedColumns.length, children: /* @__PURE__ */ jsx("div", { style: horizonScroll ? {
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<import('react').Key>;
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/IGdldEJvcmRlcmVkU2VsZWN0aW9uSXRlbUNvbnRhaW5lclN0eWxlKCkgOiB1bmRlZmluZWQsXG4gICAgICBdfVxuICAgID5cbiAgICAgIDxXcmFwcGVyPlxuICAgICAgICA8Q2hlY2tib3hcbiAgICAgICAgICB7Li4uY2hlY2tib3hQcm9wc31cbiAgICAgICAgICBjaGVja2VkPXtjaGVja2VkfVxuICAgICAgICAgIGluZGV0ZXJtaW5hdGU9e21lcmdlZEluZGV0ZXJtaW5hdGV9XG4gICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2t9XG4gICAgICAgICAgb25DaGFuZ2U9e2hhbmRsZUNoYW5nZX1cbiAgICAgICAgLz5cbiAgICAgIDwvV3JhcHBlcj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBDaGVja2JveENlbGxDb250ZW50V3JhcHBlciA9IENoZWNrYm94Q2VsbENvbnRlbnRXcmFwcGVyQ29tcG9uZW50O1xuIl19 */"], children: /* @__PURE__ */ jsx(Wrapper, { children: /* @__PURE__ */ jsx(Checkbox, { ...checkboxProps, checked, indeterminate: mergedIndeterminate, onClick: handleClick, onChange: handleChange }) }) });
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): import('react').Key[];
3
- export declare function arrAdd(list: Key[], value: Key): import('react').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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9IZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlci9IZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0VNIiwiZmlsZSI6Ii9idWlsZHMvZnJvbnRlbmQvbGlicy91aS1raXQvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvdGFibGVSb3dTZWxlY3Rpb24vY29tcG9uZW50cy9IZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlci9IZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGcmFnbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBIZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlclByb3BzIH0gZnJvbSBcIi4vSGVhZGVyQ2hlY2tib3hDZWxsQ29udGVudFdyYXBwZXIudHlwZXNcIjtcbmltcG9ydCB0eXBlIHsgS2V5IH0gZnJvbSBcImNvbXBvbmVudHMvVGFibGUvVGFibGUudHlwZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlQ29udGV4dCB9IGZyb20gXCJjb21wb25lbnRzL1RhYmxlL2NvbnRleHRzXCI7XG5pbXBvcnQgeyBnZXRSb3dLZXkgfSBmcm9tIFwiY29tcG9uZW50cy9UYWJsZS91dGlsc1wiO1xuaW1wb3J0IHsgQ2hlY2tib3ggfSBmcm9tIFwiY29tcG9uZW50cy9DaGVja2JveFwiO1xuaW1wb3J0IHsgZ2V0Qm9yZGVyZWRTZWxlY3Rpb25JdGVtQ29udGFpbmVyU3R5bGUsIHNlbGVjdGlvbkl0ZW1Db250YWluZXJTdHlsZSB9IGZyb20gXCIuLi8uLi9zdHlsZXNcIjtcbmltcG9ydCB7IHVzZVRhYmxlUm93U2VsZWN0aW9uQ29udGV4dCB9IGZyb20gXCIuLi8uLi9jb250ZXh0c1wiO1xuXG5jb25zdCBIZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlckNvbXBvbmVudCA9IDxSZWNvcmQsPihcbiAgcHJvcHM6IEhlYWRlckNoZWNrYm94Q2VsbENvbnRlbnRXcmFwcGVyUHJvcHM8UmVjb3JkPlxuKSA9PiB7XG4gIGNvbnN0IHsgY29sdW1uVGl0bGU6IENvbHVtblRpdGxlLCBnZXRUaXRsZUNoZWNrYm94UHJvcHMgfSA9IHByb3BzO1xuICBjb25zdCB7IGJvcmRlcmVkIH0gPSB1c2VUYWJsZUNvbnRleHQoKTtcbiAgY29uc3Qge1xuICAgIGNoZWNrYm94UHJvcHNNYXAsXG4gICAgZmxhdHRlZERhdGEsXG4gICAgY2hlY2tlZEN1cnJlbnRBbGwsXG4gICAgY2hlY2tlZEN1cnJlbnRTb21lLFxuICAgIGtleVNldCxcbiAgICByZWNvcmRLZXlzLFxuICAgIHNldFNlbGVjdGVkS2V5cyxcbiAgICB1cGRhdGVQcmV2U2VsZWN0ZWRJbmRleCxcbiAgfSA9IHVzZVRhYmxlUm93U2VsZWN0aW9uQ29udGV4dCgpO1xuXG4gIGNvbnN0IGFsbERpc2FibGVkRGF0YSA9IGZsYXR0ZWREYXRhXG4gICAgLm1hcCgocmVjb3JkKSA9PiB7XG4gICAgICBjb25zdCBrZXkgPSBnZXRSb3dLZXkocmVjb3JkKTtcbiAgICAgIGNvbnN0IGNoZWNrYm94UHJvcHMgPSBjaGVja2JveFByb3BzTWFwLmdldChrZXkpIHx8IHt9O1xuXG4gICAgICByZXR1cm4geyBjaGVja2VkOiBrZXlTZXQuaGFzKGtleSksIC4uLmNoZWNrYm94UHJvcHMgfTtcbiAgICB9KVxuICAgIC5maWx0ZXIoKHsgZGlzYWJsZWQgfSkgPT4gZGlzYWJsZWQpO1xuXG4gIGNvbnN0IGFsbERpc2FibGVkID0gISFhbGxEaXNhYmxlZERhdGEubGVuZ3RoICYmIGFsbERpc2FibGVkRGF0YS5sZW5ndGggPT09IGZsYXR0ZWREYXRhLmxlbmd0aDtcblxuICBjb25zdCBhbGxEaXNhYmxlZEFuZENoZWNrZWQgPSBhbGxEaXNhYmxlZCAmJiBhbGxEaXNhYmxlZERhdGEuZXZlcnkoKHsgY2hlY2tlZCB9KSA9PiBjaGVja2VkKTtcbiAgY29uc3QgYWxsRGlzYWJsZWRTb21lQ2hlY2tlZCA9IGFsbERpc2FibGVkICYmIGFsbERpc2FibGVkRGF0YS5zb21lKCh7IGNoZWNrZWQgfSkgPT4gY2hlY2tlZCk7XG4gIGNvbnN0IGN1c3RvbUNoZWNrYm94UHJvcHMgPSBnZXRUaXRsZUNoZWNrYm94UHJvcHM/LigpIHx8IHt9O1xuICBjb25zdCB7IG9uQ2hhbmdlLCBkaXNhYmxlZCB9ID0gY3VzdG9tQ2hlY2tib3hQcm9wcztcblxuICBjb25zdCBvblNlbGVjdEFsbENoYW5nZSA9ICgpID0+IHtcbiAgICBjb25zdCBjaGFuZ2VLZXlzOiBLZXlbXSA9IFtdO1xuXG4gICAgaWYgKGNoZWNrZWRDdXJyZW50QWxsKSB7XG4gICAgICByZWNvcmRLZXlzLmZvckVhY2goKGtleSkgPT4ge1xuICAgICAgICBrZXlTZXQuZGVsZXRlKGtleSk7XG4gICAgICAgIGNoYW5nZUtleXMucHVzaChrZXkpO1xuICAgICAgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJlY29yZEtleXMuZm9yRWFjaCgoa2V5KSA9PiB7XG4gICAgICAgIGlmICgha2V5U2V0LmhhcyhrZXkpKSB7XG4gICAgICAgICAga2V5U2V0LmFkZChrZXkpO1xuICAgICAgICAgIGNoYW5nZUtleXMucHVzaChrZXkpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG5cbiAgICBjb25zdCBrZXlzID0gQXJyYXkuZnJvbShrZXlTZXQpO1xuXG4gICAgc2V0U2VsZWN0ZWRLZXlzKGtleXMsIFwiYWxsXCIpO1xuICAgIHVwZGF0ZVByZXZTZWxlY3RlZEluZGV4KG51bGwpO1xuICB9O1xuXG4gIGNvbnN0IFdyYXBwZXIgPSBDb2x1bW5UaXRsZSA/PyBGcmFnbWVudDtcblxuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W1xuICAgICAgICBzZWxlY3Rpb25JdGVtQ29udGFpbmVyU3R5bGUsXG4gICAgICAgIGJvcmRlcmVkID8gZ2V0Qm9yZGVyZWRTZWxlY3Rpb25JdGVtQ29udGFpbmVyU3R5bGUodHJ1ZSkgOiB1bmRlZmluZWQsXG4gICAgICBdfVxuICAgID5cbiAgICAgIDxXcmFwcGVyPlxuICAgICAgICA8Q2hlY2tib3hcbiAgICAgICAgICBhcmlhLWxhYmVsPVwiU2VsZWN0IGFsbFwiXG4gICAgICAgICAgey4uLmN1c3RvbUNoZWNrYm94UHJvcHN9XG4gICAgICAgICAgY2hlY2tlZD17IWFsbERpc2FibGVkID8gISFmbGF0dGVkRGF0YS5sZW5ndGggJiYgY2hlY2tlZEN1cnJlbnRBbGwgOiBhbGxEaXNhYmxlZEFuZENoZWNrZWR9XG4gICAgICAgICAgaW5kZXRlcm1pbmF0ZT17XG4gICAgICAgICAgICAhYWxsRGlzYWJsZWRcbiAgICAgICAgICAgICAgPyAhY2hlY2tlZEN1cnJlbnRBbGwgJiYgY2hlY2tlZEN1cnJlbnRTb21lXG4gICAgICAgICAgICAgIDogIWFsbERpc2FibGVkQW5kQ2hlY2tlZCAmJiBhbGxEaXNhYmxlZFNvbWVDaGVja2VkXG4gICAgICAgICAgfVxuICAgICAgICAgIG9uQ2hhbmdlPXsoZSkgPT4ge1xuICAgICAgICAgICAgb25TZWxlY3RBbGxDaGFuZ2UoKTtcbiAgICAgICAgICAgIG9uQ2hhbmdlPy4oZSk7XG4gICAgICAgICAgfX1cbiAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWQgPz8gKGZsYXR0ZWREYXRhLmxlbmd0aCA9PT0gMCB8fCBhbGxEaXNhYmxlZCl9XG4gICAgICAgIC8+XG4gICAgICA8L1dyYXBwZXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgY29uc3QgSGVhZGVyQ2hlY2tib3hDZWxsQ29udGVudFdyYXBwZXIgPSBIZWFkZXJDaGVja2JveENlbGxDb250ZW50V3JhcHBlckNvbXBvbmVudDtcbiJdfQ== */"], 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) => {
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+XG4gICAgICA8V3JhcHBlcj5cbiAgICAgICAgPFJhZGlvIHsuLi5yYWRpb1Byb3BzfSBjaGVja2VkPXtjaGVja2VkfSBvbkNsaWNrPXtoYW5kbGVDbGlja30gb25DaGFuZ2U9e2hhbmRsZUNoYW5nZX0gLz5cbiAgICAgIDwvV3JhcHBlcj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBSYWRpb0NlbGxDb250ZW50V3JhcHBlciA9IFJhZGlvQ2VsbENvbnRlbnRXcmFwcGVyQ29tcG9uZW50O1xuIl19 */"], children: /* @__PURE__ */ jsx(Wrapper, { children: /* @__PURE__ */ jsx(Radio, { ...radioProps, checked, onClick: handleClick, onChange: handleChange }) }) });
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<import('react').Key, Partial<Omit<import('../../../../../Checkbox').CheckboxProps, "defaultChecked" | "checked">>>;
10
- derivedSelectedKeySet: Set<import('react').Key>;
11
- derivedSelectedKeys: import('react').Key[];
12
- derivedHalfSelectedKeySet: Set<import('react').Key>;
13
- recordKeys: import('react').Key[];
14
- keySet: Set<import('react').Key>;
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: import('react').Key[], selectedKeys: Set<import('react').Key>) => import('react').Key[];
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<import('react').Key>;
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,5 +1,5 @@
1
1
  import { createContext } from "react";
2
- import { noop, once } from "lodash-es";
2
+ import { once, noop } from "lodash-es";
3
3
  const initialTableStaticContextValue = {
4
4
  staticSelectedKeySet: /* @__PURE__ */ new Set(),
5
5
  triggerSorter: noop,
@@ -1,11 +1,14 @@
1
1
  import { jsx } from "@emotion/react/jsx-runtime";
2
- import { forwardRef, useRef } from "react";
2
+ import { forwardRef } from "react";
3
3
  import { useStatic } from "../../../../../hooks/useStatic/useStatic.js";
4
- import { initialTableStaticContextValue, createTableStaticContext } from "../contexts/tableStaticContext/TableStaticContext.js";
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 = useRef(initialTableStaticContextValue);
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('../../Table.types').DefaultRecord<any>>>(event: K) => (payload: TableEventMap<import('../../Table.types').DefaultRecord<any>>[K]) => void;
3
- export declare const useSubscribe: <K extends keyof TableEventMap<import('../../Table.types').DefaultRecord<any>>>(event: K, callback: (payload: TableEventMap<import('../../Table.types').DefaultRecord<any>>[K]) => void, skipSubscribe?: boolean, deps?: import('react').DependencyList, layoutEffect?: boolean) => void;
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;
@@ -11,6 +11,8 @@ const useBodyCellRender = (options) => {
11
11
  let value;
12
12
  if (dataIndex) {
13
13
  value = get(record, dataIndex);
14
+ } else {
15
+ value = record;
14
16
  }
15
17
  let result = value;
16
18
  if (render) {
@@ -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').ColumnWithChildren<Record> | import('../../interfaces/tableColumns.types').Column<Record>)[];
5
- flattedColumns: import('../../interfaces/tableColumns.types').Column<Record>[];
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
  };
@@ -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 {
@@ -1,2 +1,3 @@
1
1
  export { Table } from './Table';
2
- export type { TableProps } from './Table.types';
2
+ export type { TableProps, DefaultRecord } from './Table.types';
3
+ export type { Column, ColumnWithChildren, RenderFn } from './interfaces/tableColumns.types';
@@ -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
- interface BaseColumn<Record> {
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
- interface ColumnWithChildrenForbidden {
36
+ export type ColumnWithChildren<Record, C extends Columns<Record> = Columns<Record>> = BaseColumn<Record> & {
30
37
  onCell?: never;
31
- }
32
- export interface ColumnWithChildren<Record> extends BaseColumn<Record>, ColumnWithChildrenForbidden {
33
- children: Columns<Record>;
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
- width?: number | string;
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('react').Key;
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.0",
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",