@xanui/ui 1.1.27 → 1.1.29

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 (152) hide show
  1. package/Alert/index.js +2 -2
  2. package/Alert/index.mjs +2 -2
  3. package/Autocomplete/index.d.ts +40 -0
  4. package/Autocomplete/index.js +136 -0
  5. package/Autocomplete/index.js.map +1 -0
  6. package/Autocomplete/index.mjs +134 -0
  7. package/Autocomplete/index.mjs.map +1 -0
  8. package/Avatar/index.d.ts +5 -0
  9. package/Avatar/index.js +7 -2
  10. package/Avatar/index.js.map +1 -1
  11. package/Avatar/index.mjs +7 -2
  12. package/Avatar/index.mjs.map +1 -1
  13. package/Button/index.d.ts +3 -0
  14. package/Button/index.js +13 -9
  15. package/Button/index.js.map +1 -1
  16. package/Button/index.mjs +12 -8
  17. package/Button/index.mjs.map +1 -1
  18. package/Calendar/index.js +35 -20
  19. package/Calendar/index.js.map +1 -1
  20. package/Calendar/index.mjs +27 -12
  21. package/Calendar/index.mjs.map +1 -1
  22. package/CalendarInput/index.js +6 -2
  23. package/CalendarInput/index.js.map +1 -1
  24. package/CalendarInput/index.mjs +6 -2
  25. package/CalendarInput/index.mjs.map +1 -1
  26. package/DataFilter/index.d.ts +7 -0
  27. package/DataFilter/index.js +78 -0
  28. package/DataFilter/index.js.map +1 -0
  29. package/DataFilter/index.mjs +67 -0
  30. package/DataFilter/index.mjs.map +1 -0
  31. package/DataFilter/options/DateFilter.d.ts +11 -0
  32. package/DataFilter/options/DateFilter.js +32 -0
  33. package/DataFilter/options/DateFilter.js.map +1 -0
  34. package/DataFilter/options/DateFilter.mjs +30 -0
  35. package/DataFilter/options/DateFilter.mjs.map +1 -0
  36. package/DataFilter/options/DateRangeFilter.d.ts +11 -0
  37. package/DataFilter/options/DateRangeFilter.js +27 -0
  38. package/DataFilter/options/DateRangeFilter.js.map +1 -0
  39. package/DataFilter/options/DateRangeFilter.mjs +25 -0
  40. package/DataFilter/options/DateRangeFilter.mjs.map +1 -0
  41. package/DataFilter/options/MultiSelectFilter.d.ts +11 -0
  42. package/DataFilter/options/MultiSelectFilter.js +38 -0
  43. package/DataFilter/options/MultiSelectFilter.js.map +1 -0
  44. package/DataFilter/options/MultiSelectFilter.mjs +36 -0
  45. package/DataFilter/options/MultiSelectFilter.mjs.map +1 -0
  46. package/DataFilter/options/NumberFilter.d.ts +11 -0
  47. package/DataFilter/options/NumberFilter.js +24 -0
  48. package/DataFilter/options/NumberFilter.js.map +1 -0
  49. package/DataFilter/options/NumberFilter.mjs +22 -0
  50. package/DataFilter/options/NumberFilter.mjs.map +1 -0
  51. package/DataFilter/options/NumberRangeFilter.d.ts +11 -0
  52. package/DataFilter/options/NumberRangeFilter.js +29 -0
  53. package/DataFilter/options/NumberRangeFilter.js.map +1 -0
  54. package/DataFilter/options/NumberRangeFilter.mjs +27 -0
  55. package/DataFilter/options/NumberRangeFilter.mjs.map +1 -0
  56. package/DataFilter/options/SelectFilter.d.ts +11 -0
  57. package/DataFilter/options/SelectFilter.js +34 -0
  58. package/DataFilter/options/SelectFilter.js.map +1 -0
  59. package/DataFilter/options/SelectFilter.mjs +32 -0
  60. package/DataFilter/options/SelectFilter.mjs.map +1 -0
  61. package/DataFilter/options/TextFilter.d.ts +11 -0
  62. package/DataFilter/options/TextFilter.js +24 -0
  63. package/DataFilter/options/TextFilter.js.map +1 -0
  64. package/DataFilter/options/TextFilter.mjs +22 -0
  65. package/DataFilter/options/TextFilter.mjs.map +1 -0
  66. package/DataFilter/types.d.ts +58 -0
  67. package/Datatable/FilterBox.js +21 -13
  68. package/Datatable/FilterBox.js.map +1 -1
  69. package/Datatable/FilterBox.mjs +20 -12
  70. package/Datatable/FilterBox.mjs.map +1 -1
  71. package/Datatable/Row.js +15 -14
  72. package/Datatable/Row.js.map +1 -1
  73. package/Datatable/Row.mjs +16 -15
  74. package/Datatable/Row.mjs.map +1 -1
  75. package/Datatable/Table.js +2 -2
  76. package/Datatable/Table.js.map +1 -1
  77. package/Datatable/Table.mjs +2 -2
  78. package/Datatable/Table.mjs.map +1 -1
  79. package/Datatable/TableHead.js +5 -4
  80. package/Datatable/TableHead.js.map +1 -1
  81. package/Datatable/TableHead.mjs +5 -4
  82. package/Datatable/TableHead.mjs.map +1 -1
  83. package/Datatable/index.d.ts +1 -1
  84. package/Datatable/index.js +51 -11
  85. package/Datatable/index.js.map +1 -1
  86. package/Datatable/index.mjs +50 -10
  87. package/Datatable/index.mjs.map +1 -1
  88. package/Datatable/types.d.ts +13 -9
  89. package/Drawer/index.js +3 -3
  90. package/Drawer/index.js.map +1 -1
  91. package/Drawer/index.mjs +3 -3
  92. package/Drawer/index.mjs.map +1 -1
  93. package/IconButton/index.js +1 -7
  94. package/IconButton/index.js.map +1 -1
  95. package/IconButton/index.mjs +1 -7
  96. package/IconButton/index.mjs.map +1 -1
  97. package/Input/index.d.ts +7 -7
  98. package/Input/index.js +35 -66
  99. package/Input/index.js.map +1 -1
  100. package/Input/index.mjs +35 -66
  101. package/Input/index.mjs.map +1 -1
  102. package/InputNumber/index.js +32 -0
  103. package/InputNumber/index.js.map +1 -0
  104. package/InputNumber/index.mjs +30 -0
  105. package/InputNumber/index.mjs.map +1 -0
  106. package/List/ListContext.js +11 -0
  107. package/List/ListContext.js.map +1 -0
  108. package/List/ListContext.mjs +8 -0
  109. package/List/ListContext.mjs.map +1 -0
  110. package/List/index.d.ts +2 -1
  111. package/List/index.js +23 -19
  112. package/List/index.js.map +1 -1
  113. package/List/index.mjs +23 -19
  114. package/List/index.mjs.map +1 -1
  115. package/ListItem/index.d.ts +1 -0
  116. package/ListItem/index.js +30 -13
  117. package/ListItem/index.js.map +1 -1
  118. package/ListItem/index.mjs +30 -13
  119. package/ListItem/index.mjs.map +1 -1
  120. package/Menu/index.js +2 -0
  121. package/Menu/index.js.map +1 -1
  122. package/Menu/index.mjs +2 -0
  123. package/Menu/index.mjs.map +1 -1
  124. package/Paper/index.js +2 -2
  125. package/Paper/index.js.map +1 -1
  126. package/Paper/index.mjs +2 -2
  127. package/Paper/index.mjs.map +1 -1
  128. package/Select/index.d.ts +2 -10
  129. package/Select/index.js +3 -3
  130. package/Select/index.js.map +1 -1
  131. package/Select/index.mjs +3 -3
  132. package/Select/index.mjs.map +1 -1
  133. package/Skeleton/index.d.ts +8 -0
  134. package/Skeleton/index.js +60 -0
  135. package/Skeleton/index.js.map +1 -0
  136. package/Skeleton/index.mjs +58 -0
  137. package/Skeleton/index.mjs.map +1 -0
  138. package/Table/index.js +3 -3
  139. package/Table/index.js.map +1 -1
  140. package/Table/index.mjs +3 -3
  141. package/Table/index.mjs.map +1 -1
  142. package/TablePagination/index.d.ts +2 -2
  143. package/TablePagination/index.js +2 -7
  144. package/TablePagination/index.js.map +1 -1
  145. package/TablePagination/index.mjs +2 -7
  146. package/TablePagination/index.mjs.map +1 -1
  147. package/index.d.ts +65 -55
  148. package/index.js +126 -108
  149. package/index.js.map +1 -1
  150. package/index.mjs +9 -0
  151. package/index.mjs.map +1 -1
  152. package/package.json +2 -7
@@ -0,0 +1,29 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var index$2 = require('../../IconButton/index.js');
6
+ var index = require('../../Stack/index.js');
7
+ var index$1 = require('../../Text/index.js');
8
+ var Add = require('@xanui/icons/Add');
9
+ var ClearAll = require('@xanui/icons/ClearAll');
10
+ var index$3 = require('../../InputNumber/index.js');
11
+
12
+ const NumberRangeFilter = ({ option, onChange, value }) => {
13
+ var _a, _b;
14
+ const isValue = value !== null && value !== undefined && Array.isArray(value) && value.length === 2;
15
+ return (jsxRuntime.jsxs(index, { width: "100%", bgcolor: "background.secondary", p: 1, radius: 1, children: [jsxRuntime.jsxs(index, { direction: "row", alignItems: "center", justifyContent: "space-between", gap: 0.5, mb: isValue ? .5 : 0, children: [jsxRuntime.jsx(index$1, { children: option.label }), jsxRuntime.jsxs(index, { direction: "row", gap: 0.5, children: [jsxRuntime.jsx(index$2, { size: "small", variant: "soft", color: "default", onClick: () => {
16
+ onChange([0, 0]);
17
+ }, children: jsxRuntime.jsx(Add, {}) }), isValue && jsxRuntime.jsx(index$2, { size: "small", variant: "soft", color: "danger", onClick: () => {
18
+ onChange(null);
19
+ }, children: jsxRuntime.jsx(ClearAll, {}) })] })] }), jsxRuntime.jsx(index, { direction: "row", gap: 0.5, flexWrap: "wrap", children: isValue && jsxRuntime.jsxs(index, { direction: "row", gap: 0.5, flex: 1, children: [jsxRuntime.jsx(index$3, { flex: 1, variant: "outline", size: "small", placeholder: "Min", value: (_a = value[0]) !== null && _a !== void 0 ? _a : '', onChange: (e) => {
20
+ const val = e.target.value === '' ? 0 : Number(e.target.value);
21
+ onChange([val, value ? value[1] : 0]);
22
+ } }), jsxRuntime.jsx(index$3, { variant: "outline", flex: 1, size: "small", placeholder: "Max", value: (_b = value[1]) !== null && _b !== void 0 ? _b : undefined, onChange: (e) => {
23
+ const val = e.target.value === '' ? 0 : Number(e.target.value);
24
+ onChange([value ? value[0] : 0, val]);
25
+ } })] }) })] }));
26
+ };
27
+
28
+ module.exports = NumberRangeFilter;
29
+ //# sourceMappingURL=NumberRangeFilter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NumberRangeFilter.js","sources":["../../../src/DataFilter/options/NumberRangeFilter.tsx"],"sourcesContent":["\"use client\"\n\nimport { DataFilterSelect } from \"../types\";\nimport IconButton from \"../../IconButton\";\nimport Stack from \"../../Stack\";\nimport Text from \"../../Text\";\nimport Add from \"@xanui/icons/Add\";\nimport ClearAll from \"@xanui/icons/ClearAll\";\nimport InputNumber from \"../../InputNumber\";\n\ntype Props = {\n option: DataFilterSelect;\n value: [number, number] | null;\n onChange: (value: [number, number] | null) => void;\n}\n\nconst NumberRangeFilter = ({ option, onChange, value }: Props) => {\n\n const isValue = value !== null && value !== undefined && Array.isArray(value) && value.length === 2;\n\n return (\n <Stack\n width={\"100%\"}\n bgcolor=\"background.secondary\"\n p={1}\n radius={1}\n >\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n justifyContent={\"space-between\"}\n gap={0.5}\n mb={isValue ? .5 : 0}\n >\n <Text>{option.label}</Text>\n <Stack\n direction=\"row\"\n gap={0.5}\n >\n <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"default\"}\n onClick={() => {\n onChange([0, 0]);\n }}\n >\n <Add />\n </IconButton>\n {\n isValue && <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"danger\"}\n onClick={() => {\n onChange(null);\n }}\n >\n <ClearAll />\n </IconButton>\n }\n </Stack>\n </Stack>\n <Stack\n direction=\"row\"\n gap={0.5}\n flexWrap=\"wrap\"\n >\n {\n isValue && <Stack\n direction=\"row\"\n gap={0.5}\n flex={1}\n >\n <InputNumber\n flex={1}\n variant={\"outline\"}\n size=\"small\"\n placeholder=\"Min\"\n value={value[0] as any ?? ''}\n onChange={(e) => {\n const val = e.target.value === '' ? 0 : Number(e.target.value);\n onChange([val, value ? value[1] : 0]);\n }}\n />\n <InputNumber\n variant={\"outline\"}\n flex={1}\n size=\"small\"\n placeholder=\"Max\"\n value={value[1] as any ?? undefined}\n onChange={(e) => {\n const val = e.target.value === '' ? 0 : Number(e.target.value);\n onChange([value ? value[0] : 0, val]);\n }}\n />\n </Stack>\n }\n </Stack>\n </Stack>\n )\n}\n\nexport default NumberRangeFilter"],"names":[],"mappings":";;;;;;;;;;;AAgBA;;;AAIG;AAwBkB;;;AAYA;;AA0BG;AACH;;AAUG;AACH;AAOrB;;"}
@@ -0,0 +1,27 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import IconButton from '../../IconButton/index.mjs';
4
+ import Stack from '../../Stack/index.mjs';
5
+ import Text from '../../Text/index.mjs';
6
+ import Add from '@xanui/icons/Add';
7
+ import ClearAll from '@xanui/icons/ClearAll';
8
+ import InputNumber from '../../InputNumber/index.mjs';
9
+
10
+ const NumberRangeFilter = ({ option, onChange, value }) => {
11
+ var _a, _b;
12
+ const isValue = value !== null && value !== undefined && Array.isArray(value) && value.length === 2;
13
+ return (jsxs(Stack, { width: "100%", bgcolor: "background.secondary", p: 1, radius: 1, children: [jsxs(Stack, { direction: "row", alignItems: "center", justifyContent: "space-between", gap: 0.5, mb: isValue ? .5 : 0, children: [jsx(Text, { children: option.label }), jsxs(Stack, { direction: "row", gap: 0.5, children: [jsx(IconButton, { size: "small", variant: "soft", color: "default", onClick: () => {
14
+ onChange([0, 0]);
15
+ }, children: jsx(Add, {}) }), isValue && jsx(IconButton, { size: "small", variant: "soft", color: "danger", onClick: () => {
16
+ onChange(null);
17
+ }, children: jsx(ClearAll, {}) })] })] }), jsx(Stack, { direction: "row", gap: 0.5, flexWrap: "wrap", children: isValue && jsxs(Stack, { direction: "row", gap: 0.5, flex: 1, children: [jsx(InputNumber, { flex: 1, variant: "outline", size: "small", placeholder: "Min", value: (_a = value[0]) !== null && _a !== void 0 ? _a : '', onChange: (e) => {
18
+ const val = e.target.value === '' ? 0 : Number(e.target.value);
19
+ onChange([val, value ? value[1] : 0]);
20
+ } }), jsx(InputNumber, { variant: "outline", flex: 1, size: "small", placeholder: "Max", value: (_b = value[1]) !== null && _b !== void 0 ? _b : undefined, onChange: (e) => {
21
+ const val = e.target.value === '' ? 0 : Number(e.target.value);
22
+ onChange([value ? value[0] : 0, val]);
23
+ } })] }) })] }));
24
+ };
25
+
26
+ export { NumberRangeFilter as default };
27
+ //# sourceMappingURL=NumberRangeFilter.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NumberRangeFilter.mjs","sources":["../../../src/DataFilter/options/NumberRangeFilter.tsx"],"sourcesContent":["\"use client\"\n\nimport { DataFilterSelect } from \"../types\";\nimport IconButton from \"../../IconButton\";\nimport Stack from \"../../Stack\";\nimport Text from \"../../Text\";\nimport Add from \"@xanui/icons/Add\";\nimport ClearAll from \"@xanui/icons/ClearAll\";\nimport InputNumber from \"../../InputNumber\";\n\ntype Props = {\n option: DataFilterSelect;\n value: [number, number] | null;\n onChange: (value: [number, number] | null) => void;\n}\n\nconst NumberRangeFilter = ({ option, onChange, value }: Props) => {\n\n const isValue = value !== null && value !== undefined && Array.isArray(value) && value.length === 2;\n\n return (\n <Stack\n width={\"100%\"}\n bgcolor=\"background.secondary\"\n p={1}\n radius={1}\n >\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n justifyContent={\"space-between\"}\n gap={0.5}\n mb={isValue ? .5 : 0}\n >\n <Text>{option.label}</Text>\n <Stack\n direction=\"row\"\n gap={0.5}\n >\n <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"default\"}\n onClick={() => {\n onChange([0, 0]);\n }}\n >\n <Add />\n </IconButton>\n {\n isValue && <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"danger\"}\n onClick={() => {\n onChange(null);\n }}\n >\n <ClearAll />\n </IconButton>\n }\n </Stack>\n </Stack>\n <Stack\n direction=\"row\"\n gap={0.5}\n flexWrap=\"wrap\"\n >\n {\n isValue && <Stack\n direction=\"row\"\n gap={0.5}\n flex={1}\n >\n <InputNumber\n flex={1}\n variant={\"outline\"}\n size=\"small\"\n placeholder=\"Min\"\n value={value[0] as any ?? ''}\n onChange={(e) => {\n const val = e.target.value === '' ? 0 : Number(e.target.value);\n onChange([val, value ? value[1] : 0]);\n }}\n />\n <InputNumber\n variant={\"outline\"}\n flex={1}\n size=\"small\"\n placeholder=\"Max\"\n value={value[1] as any ?? undefined}\n onChange={(e) => {\n const val = e.target.value === '' ? 0 : Number(e.target.value);\n onChange([value ? value[0] : 0, val]);\n }}\n />\n </Stack>\n }\n </Stack>\n </Stack>\n )\n}\n\nexport default NumberRangeFilter"],"names":[],"mappings":";;;;;;;;;AAgBA;;;AAIG;AAwBkB;;;AAYA;;AA0BG;AACH;;AAUG;AACH;AAOrB;;"}
@@ -0,0 +1,11 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { DataFilterSelect } from '../types.js';
3
+
4
+ type Props = {
5
+ option: DataFilterSelect;
6
+ value: string | null;
7
+ onChange: (value: string | null) => void;
8
+ };
9
+ declare const SelectFilter: ({ option, onChange, value }: Props) => react_jsx_runtime.JSX.Element;
10
+
11
+ export { SelectFilter as default };
@@ -0,0 +1,34 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var React = require('react');
6
+ var index$4 = require('../../Menu/index.js');
7
+ var index$5 = require('../../List/index.js');
8
+ var index$6 = require('../../ListItem/index.js');
9
+ var index$7 = require('../../Checkbox/index.js');
10
+ var index$2 = require('../../IconButton/index.js');
11
+ var index = require('../../Stack/index.js');
12
+ var index$1 = require('../../Text/index.js');
13
+ var Close = require('@xanui/icons/Close');
14
+ var Add = require('@xanui/icons/Add');
15
+ var ClearAll = require('@xanui/icons/ClearAll');
16
+ var index$3 = require('../../Chip/index.js');
17
+
18
+ const SelectFilter = ({ option, onChange, value }) => {
19
+ var _a;
20
+ const ref = React.useRef(null);
21
+ const [target, setTarget] = React.useState();
22
+ return (jsxRuntime.jsxs(index, { width: "100%", bgcolor: "background.secondary", p: 1, radius: 1, children: [jsxRuntime.jsxs(index, { direction: "row", alignItems: "center", justifyContent: "space-between", gap: 0.5, mb: value ? .5 : 0, children: [jsxRuntime.jsx(index$1, { children: option.label }), jsxRuntime.jsxs(index, { direction: "row", gap: 0.5, children: [jsxRuntime.jsx(index$2, { size: "small", variant: "soft", color: "default", onClick: (e) => {
23
+ setTarget(e.currentTarget);
24
+ }, children: jsxRuntime.jsx(Add, {}) }), !!value && jsxRuntime.jsx(index$2, { size: "small", variant: "soft", color: "danger", onClick: () => {
25
+ onChange(null);
26
+ }, children: jsxRuntime.jsx(ClearAll, {}) })] })] }), jsxRuntime.jsx(index, { direction: "row", gap: 0.5, flexWrap: "wrap", children: !!value && jsxRuntime.jsx(index$3, { size: "small", color: "default", label: value, endIcon: jsxRuntime.jsx(index$2, { size: 16, variant: "text", color: "default", onClick: () => {
27
+ onChange(null);
28
+ }, children: jsxRuntime.jsx(Close, {}) }) }) }), jsxRuntime.jsx(index$4, { target: target, onClickOutside: () => setTarget(undefined), placement: "bottom-right", children: jsxRuntime.jsx(index$5, { width: ((_a = ref === null || ref === void 0 ? void 0 : ref.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) || 200, size: "small", children: option.options.map((opt, index) => (jsxRuntime.jsx(index$6, { startIcon: jsxRuntime.jsx(index$7, { checked: value === opt.value }), onClick: () => {
29
+ onChange(opt.value);
30
+ }, children: opt.label }, index))) }) })] }));
31
+ };
32
+
33
+ module.exports = SelectFilter;
34
+ //# sourceMappingURL=SelectFilter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectFilter.js","sources":["../../../src/DataFilter/options/SelectFilter.tsx"],"sourcesContent":["\"use client\"\n\nimport React from \"react\";\nimport { DataFilterSelect } from \"../types\";\nimport Menu from \"../../Menu\";\nimport List from \"../../List\";\nimport ListItem from \"../../ListItem\";\nimport Checkbox from \"../../Checkbox\";\nimport IconButton from \"../../IconButton\";\nimport Stack from \"../../Stack\";\nimport Text from \"../../Text\";\nimport Close from \"@xanui/icons/Close\";\nimport Add from \"@xanui/icons/Add\";\nimport ClearAll from \"@xanui/icons/ClearAll\";\nimport Chip from \"../../Chip\";\n\n\ntype Props = {\n option: DataFilterSelect;\n value: string | null;\n onChange: (value: string | null) => void;\n}\n\nconst SelectFilter = ({ option, onChange, value }: Props) => {\n const ref: any = React.useRef(null)\n const [target, setTarget] = React.useState<HTMLElement | undefined>()\n return (\n <Stack\n width={\"100%\"}\n bgcolor=\"background.secondary\"\n p={1}\n radius={1}\n >\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n justifyContent={\"space-between\"}\n gap={0.5}\n mb={value ? .5 : 0}\n >\n <Text>{option.label}</Text>\n <Stack\n direction=\"row\"\n gap={0.5}\n >\n <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"default\"}\n onClick={(e: any) => {\n setTarget(e.currentTarget)\n }}\n >\n <Add />\n </IconButton>\n {\n !!value && <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"danger\"}\n onClick={() => {\n onChange(null);\n }}\n >\n <ClearAll />\n </IconButton>\n }\n </Stack>\n </Stack>\n <Stack\n direction=\"row\"\n gap={0.5}\n flexWrap=\"wrap\"\n >\n {\n !!value && <Chip\n size=\"small\"\n color=\"default\"\n label={value}\n endIcon={<IconButton\n size={16}\n variant={\"text\"}\n color=\"default\"\n onClick={() => {\n onChange(null);\n }}\n >\n <Close />\n </IconButton>}\n />\n }\n </Stack>\n <Menu\n target={target}\n onClickOutside={() => setTarget(undefined)}\n placement={\"bottom-right\"}\n >\n <List width={ref?.current?.offsetWidth || 200} size=\"small\">\n {\n option.options.map((opt, index) => (\n <ListItem\n key={index}\n startIcon={<Checkbox checked={value === opt.value} />}\n onClick={() => {\n onChange(opt.value);\n }}\n >\n {opt.label}\n </ListItem>\n ))\n }\n </List>\n </Menu>\n </Stack>\n )\n}\n\nexport default SelectFilter"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAuBA;;;;AAGG;AAwBkB;AACH;;AAWG;;AAuBA;AAmBM;AACH;AAUxB;;"}
@@ -0,0 +1,32 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import React from 'react';
4
+ import Menu from '../../Menu/index.mjs';
5
+ import List from '../../List/index.mjs';
6
+ import ListItem from '../../ListItem/index.mjs';
7
+ import Checkbox from '../../Checkbox/index.mjs';
8
+ import IconButton from '../../IconButton/index.mjs';
9
+ import Stack from '../../Stack/index.mjs';
10
+ import Text from '../../Text/index.mjs';
11
+ import Close from '@xanui/icons/Close';
12
+ import Add from '@xanui/icons/Add';
13
+ import ClearAll from '@xanui/icons/ClearAll';
14
+ import Chip from '../../Chip/index.mjs';
15
+
16
+ const SelectFilter = ({ option, onChange, value }) => {
17
+ var _a;
18
+ const ref = React.useRef(null);
19
+ const [target, setTarget] = React.useState();
20
+ return (jsxs(Stack, { width: "100%", bgcolor: "background.secondary", p: 1, radius: 1, children: [jsxs(Stack, { direction: "row", alignItems: "center", justifyContent: "space-between", gap: 0.5, mb: value ? .5 : 0, children: [jsx(Text, { children: option.label }), jsxs(Stack, { direction: "row", gap: 0.5, children: [jsx(IconButton, { size: "small", variant: "soft", color: "default", onClick: (e) => {
21
+ setTarget(e.currentTarget);
22
+ }, children: jsx(Add, {}) }), !!value && jsx(IconButton, { size: "small", variant: "soft", color: "danger", onClick: () => {
23
+ onChange(null);
24
+ }, children: jsx(ClearAll, {}) })] })] }), jsx(Stack, { direction: "row", gap: 0.5, flexWrap: "wrap", children: !!value && jsx(Chip, { size: "small", color: "default", label: value, endIcon: jsx(IconButton, { size: 16, variant: "text", color: "default", onClick: () => {
25
+ onChange(null);
26
+ }, children: jsx(Close, {}) }) }) }), jsx(Menu, { target: target, onClickOutside: () => setTarget(undefined), placement: "bottom-right", children: jsx(List, { width: ((_a = ref === null || ref === void 0 ? void 0 : ref.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) || 200, size: "small", children: option.options.map((opt, index) => (jsx(ListItem, { startIcon: jsx(Checkbox, { checked: value === opt.value }), onClick: () => {
27
+ onChange(opt.value);
28
+ }, children: opt.label }, index))) }) })] }));
29
+ };
30
+
31
+ export { SelectFilter as default };
32
+ //# sourceMappingURL=SelectFilter.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectFilter.mjs","sources":["../../../src/DataFilter/options/SelectFilter.tsx"],"sourcesContent":["\"use client\"\n\nimport React from \"react\";\nimport { DataFilterSelect } from \"../types\";\nimport Menu from \"../../Menu\";\nimport List from \"../../List\";\nimport ListItem from \"../../ListItem\";\nimport Checkbox from \"../../Checkbox\";\nimport IconButton from \"../../IconButton\";\nimport Stack from \"../../Stack\";\nimport Text from \"../../Text\";\nimport Close from \"@xanui/icons/Close\";\nimport Add from \"@xanui/icons/Add\";\nimport ClearAll from \"@xanui/icons/ClearAll\";\nimport Chip from \"../../Chip\";\n\n\ntype Props = {\n option: DataFilterSelect;\n value: string | null;\n onChange: (value: string | null) => void;\n}\n\nconst SelectFilter = ({ option, onChange, value }: Props) => {\n const ref: any = React.useRef(null)\n const [target, setTarget] = React.useState<HTMLElement | undefined>()\n return (\n <Stack\n width={\"100%\"}\n bgcolor=\"background.secondary\"\n p={1}\n radius={1}\n >\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n justifyContent={\"space-between\"}\n gap={0.5}\n mb={value ? .5 : 0}\n >\n <Text>{option.label}</Text>\n <Stack\n direction=\"row\"\n gap={0.5}\n >\n <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"default\"}\n onClick={(e: any) => {\n setTarget(e.currentTarget)\n }}\n >\n <Add />\n </IconButton>\n {\n !!value && <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"danger\"}\n onClick={() => {\n onChange(null);\n }}\n >\n <ClearAll />\n </IconButton>\n }\n </Stack>\n </Stack>\n <Stack\n direction=\"row\"\n gap={0.5}\n flexWrap=\"wrap\"\n >\n {\n !!value && <Chip\n size=\"small\"\n color=\"default\"\n label={value}\n endIcon={<IconButton\n size={16}\n variant={\"text\"}\n color=\"default\"\n onClick={() => {\n onChange(null);\n }}\n >\n <Close />\n </IconButton>}\n />\n }\n </Stack>\n <Menu\n target={target}\n onClickOutside={() => setTarget(undefined)}\n placement={\"bottom-right\"}\n >\n <List width={ref?.current?.offsetWidth || 200} size=\"small\">\n {\n option.options.map((opt, index) => (\n <ListItem\n key={index}\n startIcon={<Checkbox checked={value === opt.value} />}\n onClick={() => {\n onChange(opt.value);\n }}\n >\n {opt.label}\n </ListItem>\n ))\n }\n </List>\n </Menu>\n </Stack>\n )\n}\n\nexport default SelectFilter"],"names":[],"mappings":";;;;;;;;;;;;;;;AAuBA;;;;AAGG;AAwBkB;AACH;;AAWG;;AAuBA;AAmBM;AACH;AAUxB;;"}
@@ -0,0 +1,11 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { DataFilterSelect } from '../types.js';
3
+
4
+ type Props = {
5
+ option: DataFilterSelect;
6
+ value: string | null;
7
+ onChange: (value: string | null) => void;
8
+ };
9
+ declare const TextFilter: ({ option, onChange, value }: Props) => react_jsx_runtime.JSX.Element;
10
+
11
+ export { TextFilter as default };
@@ -0,0 +1,24 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var index$2 = require('../../IconButton/index.js');
6
+ var index = require('../../Stack/index.js');
7
+ var index$1 = require('../../Text/index.js');
8
+ var Add = require('@xanui/icons/Add');
9
+ var ClearAll = require('@xanui/icons/ClearAll');
10
+ var index$3 = require('../../Input/index.js');
11
+
12
+ const TextFilter = ({ option, onChange, value }) => {
13
+ const isValue = value !== null && value !== undefined;
14
+ return (jsxRuntime.jsxs(index, { width: "100%", bgcolor: "background.secondary", p: 1, radius: 1, children: [jsxRuntime.jsxs(index, { direction: "row", alignItems: "center", justifyContent: "space-between", gap: 0.5, mb: isValue ? .5 : 0, children: [jsxRuntime.jsx(index$1, { children: option.label }), jsxRuntime.jsxs(index, { direction: "row", gap: 0.5, children: [jsxRuntime.jsx(index$2, { size: "small", variant: "soft", color: "default", onClick: () => {
15
+ onChange('');
16
+ }, children: jsxRuntime.jsx(Add, {}) }), isValue && jsxRuntime.jsx(index$2, { size: "small", variant: "soft", color: "danger", onClick: () => {
17
+ onChange(null);
18
+ }, children: jsxRuntime.jsx(ClearAll, {}) })] })] }), jsxRuntime.jsx(index, { direction: "row", gap: 0.5, flexWrap: "wrap", children: isValue && jsxRuntime.jsx(index$3, { variant: "outline", value: value.toString(), onChange: (e) => {
19
+ onChange(e.target.value);
20
+ }, fullWidth: true }) })] }));
21
+ };
22
+
23
+ module.exports = TextFilter;
24
+ //# sourceMappingURL=TextFilter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextFilter.js","sources":["../../../src/DataFilter/options/TextFilter.tsx"],"sourcesContent":["\"use client\"\n\nimport { DataFilterSelect } from \"../types\";\nimport IconButton from \"../../IconButton\";\nimport Stack from \"../../Stack\";\nimport Text from \"../../Text\";\nimport Add from \"@xanui/icons/Add\";\nimport ClearAll from \"@xanui/icons/ClearAll\";\nimport Input from \"../../Input\";\n\ntype Props = {\n option: DataFilterSelect;\n value: string | null;\n onChange: (value: string | null) => void;\n}\n\nconst TextFilter = ({ option, onChange, value }: Props) => {\n\n const isValue = value !== null && value !== undefined;\n\n return (\n <Stack\n width={\"100%\"}\n bgcolor=\"background.secondary\"\n p={1}\n radius={1}\n >\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n justifyContent={\"space-between\"}\n gap={0.5}\n mb={isValue ? .5 : 0}\n >\n <Text>{option.label}</Text>\n <Stack\n direction=\"row\"\n gap={0.5}\n >\n <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"default\"}\n onClick={() => {\n onChange('');\n }}\n >\n <Add />\n </IconButton>\n {\n isValue && <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"danger\"}\n onClick={() => {\n onChange(null);\n }}\n >\n <ClearAll />\n </IconButton>\n }\n </Stack>\n </Stack>\n <Stack\n direction=\"row\"\n gap={0.5}\n flexWrap=\"wrap\"\n >\n {\n isValue && <Input\n variant={\"outline\"}\n value={value.toString()}\n onChange={(e: any) => {\n onChange(e.target.value);\n }}\n fullWidth\n />\n }\n </Stack>\n </Stack>\n )\n}\n\nexport default TextFilter"],"names":[],"mappings":";;;;;;;;;;;AAgBA;;AAIG;;;;;AAqDkB;AACH;AAOlB;;"}
@@ -0,0 +1,22 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import IconButton from '../../IconButton/index.mjs';
4
+ import Stack from '../../Stack/index.mjs';
5
+ import Text from '../../Text/index.mjs';
6
+ import Add from '@xanui/icons/Add';
7
+ import ClearAll from '@xanui/icons/ClearAll';
8
+ import Input from '../../Input/index.mjs';
9
+
10
+ const TextFilter = ({ option, onChange, value }) => {
11
+ const isValue = value !== null && value !== undefined;
12
+ return (jsxs(Stack, { width: "100%", bgcolor: "background.secondary", p: 1, radius: 1, children: [jsxs(Stack, { direction: "row", alignItems: "center", justifyContent: "space-between", gap: 0.5, mb: isValue ? .5 : 0, children: [jsx(Text, { children: option.label }), jsxs(Stack, { direction: "row", gap: 0.5, children: [jsx(IconButton, { size: "small", variant: "soft", color: "default", onClick: () => {
13
+ onChange('');
14
+ }, children: jsx(Add, {}) }), isValue && jsx(IconButton, { size: "small", variant: "soft", color: "danger", onClick: () => {
15
+ onChange(null);
16
+ }, children: jsx(ClearAll, {}) })] })] }), jsx(Stack, { direction: "row", gap: 0.5, flexWrap: "wrap", children: isValue && jsx(Input, { variant: "outline", value: value.toString(), onChange: (e) => {
17
+ onChange(e.target.value);
18
+ }, fullWidth: true }) })] }));
19
+ };
20
+
21
+ export { TextFilter as default };
22
+ //# sourceMappingURL=TextFilter.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextFilter.mjs","sources":["../../../src/DataFilter/options/TextFilter.tsx"],"sourcesContent":["\"use client\"\n\nimport { DataFilterSelect } from \"../types\";\nimport IconButton from \"../../IconButton\";\nimport Stack from \"../../Stack\";\nimport Text from \"../../Text\";\nimport Add from \"@xanui/icons/Add\";\nimport ClearAll from \"@xanui/icons/ClearAll\";\nimport Input from \"../../Input\";\n\ntype Props = {\n option: DataFilterSelect;\n value: string | null;\n onChange: (value: string | null) => void;\n}\n\nconst TextFilter = ({ option, onChange, value }: Props) => {\n\n const isValue = value !== null && value !== undefined;\n\n return (\n <Stack\n width={\"100%\"}\n bgcolor=\"background.secondary\"\n p={1}\n radius={1}\n >\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n justifyContent={\"space-between\"}\n gap={0.5}\n mb={isValue ? .5 : 0}\n >\n <Text>{option.label}</Text>\n <Stack\n direction=\"row\"\n gap={0.5}\n >\n <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"default\"}\n onClick={() => {\n onChange('');\n }}\n >\n <Add />\n </IconButton>\n {\n isValue && <IconButton\n size=\"small\"\n variant=\"soft\"\n color={\"danger\"}\n onClick={() => {\n onChange(null);\n }}\n >\n <ClearAll />\n </IconButton>\n }\n </Stack>\n </Stack>\n <Stack\n direction=\"row\"\n gap={0.5}\n flexWrap=\"wrap\"\n >\n {\n isValue && <Input\n variant={\"outline\"}\n value={value.toString()}\n onChange={(e: any) => {\n onChange(e.target.value);\n }}\n fullWidth\n />\n }\n </Stack>\n </Stack>\n )\n}\n\nexport default TextFilter"],"names":[],"mappings":";;;;;;;;;AAgBA;;AAIG;;;;;AAqDkB;AACH;AAOlB;;"}
@@ -0,0 +1,58 @@
1
+ import { TagProps } from '@xanui/core';
2
+
3
+ type DataFilterText = {
4
+ type: "text";
5
+ key: string;
6
+ label: string;
7
+ };
8
+ type DataFilterNumber = {
9
+ type: "number";
10
+ key: string;
11
+ label: string;
12
+ };
13
+ type DataFilterNumberRange = {
14
+ type: "number-range";
15
+ key: string;
16
+ label: string;
17
+ };
18
+ type DataFilterSelect = {
19
+ type: "select";
20
+ key: string;
21
+ label: string;
22
+ options: ({
23
+ label: string;
24
+ value: string;
25
+ })[];
26
+ };
27
+ type DataFilterMultiSelect = {
28
+ type: "multi-select";
29
+ key: string;
30
+ label: string;
31
+ options: ({
32
+ label: string;
33
+ value: string;
34
+ })[];
35
+ };
36
+ type DataFilterDate = {
37
+ type: "date";
38
+ key: string;
39
+ label: string;
40
+ };
41
+ type DataFilterDateRange = {
42
+ type: "date-range";
43
+ key: string;
44
+ label: string;
45
+ };
46
+ type DataFilterOption = DataFilterText | DataFilterNumber | DataFilterNumberRange | DataFilterSelect | DataFilterMultiSelect | DataFilterDate | DataFilterDateRange;
47
+ type DataFilterProps = Omit<TagProps, "children" | "value"> & {
48
+ options: DataFilterOption[];
49
+ value?: {
50
+ [key: string]: any;
51
+ };
52
+ onChange?: (state: {
53
+ [key: string]: any;
54
+ }) => void;
55
+ inline?: boolean;
56
+ };
57
+
58
+ export type { DataFilterDate, DataFilterDateRange, DataFilterMultiSelect, DataFilterNumber, DataFilterNumberRange, DataFilterOption, DataFilterProps, DataFilterSelect, DataFilterText };
@@ -5,26 +5,34 @@ var jsxRuntime = require('react/jsx-runtime');
5
5
  var index = require('../Stack/index.js');
6
6
  var index$1 = require('../Tabs/index.js');
7
7
  var index$2 = require('../Tab/index.js');
8
- var index$3 = require('../Select/index.js');
9
- var index$4 = require('../Option/index.js');
10
- var index$5 = require('../Input/index.js');
8
+ var index$3 = require('../Input/index.js');
11
9
  var IconSearch = require('@xanui/icons/Search');
10
+ var index$4 = require('../IconButton/index.js');
11
+ var FilterListOutlined = require('@xanui/icons/FilterListOutlined');
12
+ var index$5 = require('../Drawer/index.js');
13
+ var index$8 = require('../Text/index.js');
14
+ var React = require('react');
15
+ var CloseOutlined = require('@xanui/icons/CloseOutlined');
16
+ var index$6 = require('../ViewBox/index.js');
17
+ var index$7 = require('../DataFilter/index.js');
12
18
 
13
19
  const FilterBox = (props) => {
14
- let { tabs, filters, hideSearch, slotProps, state, update, } = props;
20
+ let { tabs, filters, hideSearch, slotProps, skeleton, state, update, } = props;
21
+ const [openFilter, setOpenFilter] = React.useState(false);
15
22
  let checked = state.selectAll || !!state.selected.length;
16
23
  if (checked)
17
24
  return jsxRuntime.jsx(jsxRuntime.Fragment, {});
18
- return (jsxRuntime.jsxs(index, { direction: "row", alignItems: "center", justifyContent: "space-between", zIndex: 1, radius: 1, mb: 1, height: 50, width: "100%", children: [jsxRuntime.jsx(index, { gap: 2.4, flexRow: true, children: tabs && jsxRuntime.jsx(index$1, { onChange: (value) => {
25
+ return (jsxRuntime.jsxs(index, { direction: "row", alignItems: "center", justifyContent: "space-between", zIndex: 1, radius: 1, mb: 1, height: 50, width: "100%", children: [jsxRuntime.jsx(index, { gap: 2.4, flexRow: true, children: tabs && jsxRuntime.jsx(index$1, { disabled: skeleton ? true : false, onChange: (value) => {
19
26
  update({ tab: value });
20
- }, value: state.tab, children: tabs.map(t => jsxRuntime.jsx(index$2, { value: t.value || t.label.toLowerCase(), children: t.label }, t.label)) }) }), jsxRuntime.jsx(index, { className: 'datatable-header-filter-area', flex: 1, flexRow: true, children: filters && jsxRuntime.jsx(index, { flexRow: true, gap: 2, px: 2, children: Object.keys(filters).map(name => {
21
- const items = filters[name];
22
- return (jsxRuntime.jsx(index$3, { placeholder: name.charAt(0).toUpperCase() + name.slice(1), value: state[name] || "", onChange: (value) => {
23
- update({ [name]: value });
24
- }, children: items.map((item) => jsxRuntime.jsx(index$4, { value: item.value, children: item.label }, name + item.value)) }, name));
25
- }) }) }), jsxRuntime.jsx(index, { flexRow: true, gap: 2, className: 'datatable-header-right-area', children: !hideSearch && jsxRuntime.jsx(index$5, Object.assign({ endIcon: jsxRuntime.jsx(IconSearch, {}), p: 1, placeholder: 'Search...' }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.search, { value: state.search, onChange: (e) => {
26
- update({ search: e.target.value });
27
- } })) })] }));
27
+ }, value: state.tab, children: tabs.map(t => jsxRuntime.jsx(index$2, { value: t.value || t.label.toLowerCase(), children: t.label }, t.label)) }) }), jsxRuntime.jsxs(index, { flexRow: true, gap: 2, className: 'datatable-header-right-area', alignItems: "center", children: [!hideSearch && jsxRuntime.jsx(index$3, Object.assign({ disabled: skeleton ? true : false, endIcon: jsxRuntime.jsx(IconSearch, {}), placeholder: 'Search...' }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.search, { value: state.search, onChange: (e) => {
28
+ update({ search: e.target.value });
29
+ } })), filters && jsxRuntime.jsxs(index, { children: [jsxRuntime.jsx(index$4, { color: "default", variant: "text", onClick: () => {
30
+ setOpenFilter(true);
31
+ }, children: jsxRuntime.jsx(FilterListOutlined, {}) }), jsxRuntime.jsx(index$5, { open: openFilter, onClickOutside: () => { }, placement: "right", children: jsxRuntime.jsx(index$6, { height: "100%", p: 1, startContent: jsxRuntime.jsxs(index, { mb: 2, px: 2, flexRow: true, justifyContent: "space-between", alignItems: "center", children: [jsxRuntime.jsx(index$8, { fontWeight: 600, fontSize: "h6", children: "Filters" }), jsxRuntime.jsx(index$4, { size: "small", color: "default", variant: "text", onClick: () => {
32
+ setOpenFilter(false);
33
+ }, children: jsxRuntime.jsx(CloseOutlined, {}) })] }), children: jsxRuntime.jsx(index, { gap: 2, children: jsxRuntime.jsx(index$7.default, { options: filters, value: state.filters, onChange: (s) => {
34
+ update({ filters: s });
35
+ } }) }) }) })] })] })] }));
28
36
  };
29
37
 
30
38
  module.exports = FilterBox;
@@ -1 +1 @@
1
- {"version":3,"file":"FilterBox.js","sources":["../../src/Datatable/FilterBox.tsx"],"sourcesContent":["\"use client\";\nimport Stack from '../Stack'\nimport Tabs from '../Tabs'\nimport Tab from '../Tab'\nimport Select from '../Select'\nimport Option from '../Option'\nimport Input from '../Input'\nimport IconSearch from '@xanui/icons/Search'\nimport { DatatableFilter, DatatablePropsWithState } from './types';\n\n\nconst FilterBox = (props: DatatablePropsWithState) => {\n let {\n tabs,\n filters,\n hideSearch,\n slotProps,\n state,\n update,\n } = props\n\n let checked = state.selectAll || !!state.selected.length\n\n if (checked) return <></>\n\n return (\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n justifyContent=\"space-between\"\n zIndex={1}\n radius={1}\n mb={1}\n height={50}\n width=\"100%\"\n >\n <Stack gap={2.4} flexRow>\n {\n tabs && <Tabs\n onChange={(value: any) => {\n update({ tab: value })\n }}\n value={state.tab}\n >\n {\n tabs.map(t => <Tab key={t.label} value={t.value || t.label.toLowerCase()}>{t.label}</Tab>)\n }\n </Tabs>\n }\n </Stack>\n <Stack className='datatable-header-filter-area' flex={1} flexRow>\n {\n filters && <Stack flexRow gap={2} px={2}>\n {\n Object.keys(filters).map(name => {\n const items: DatatableFilter[] = (filters as any)[name]\n return (\n <Select\n key={name}\n placeholder={name.charAt(0).toUpperCase() + name.slice(1)}\n value={(state as any)[name] || \"\"}\n onChange={(value) => {\n update({ [name]: value } as any)\n }}\n >\n {\n items.map((item) => <Option key={name + item.value} value={item.value}>\n {item.label}\n </Option>)\n }\n </Select>\n )\n })\n }\n </Stack>\n }\n </Stack>\n <Stack flexRow gap={2} className='datatable-header-right-area'>\n {!hideSearch && <Input\n endIcon={<IconSearch />}\n p={1}\n placeholder='Search...'\n {...slotProps?.search}\n value={state.search}\n onChange={(e: any) => {\n update({ search: e.target.value })\n }}\n />}\n </Stack>\n </Stack>\n )\n}\n\nexport default FilterBox"],"names":[],"mappings":";;;;;;;;;;;;AAWA;AACG;AASA;AAEA;AAAa;;AAiBK;AACH;AAcM;AACA;;AAOM;;;AAuBf;AAKf;;"}
1
+ {"version":3,"file":"FilterBox.js","sources":["../../src/Datatable/FilterBox.tsx"],"sourcesContent":["\"use client\";\nimport Stack from '../Stack'\nimport Tabs from '../Tabs'\nimport Tab from '../Tab'\nimport Input from '../Input'\nimport IconSearch from '@xanui/icons/Search'\nimport { DatatablePropsWithState } from './types';\nimport IconButton from '../IconButton';\nimport FilterListOutlined from '@xanui/icons/FilterListOutlined';\nimport Drawer from '../Drawer';\nimport Text from '../Text';\nimport React from 'react';\nimport CloseOutlined from '@xanui/icons/CloseOutlined';\nimport ViewBox from '../ViewBox';\nimport DataFilter from '../DataFilter';\n\nconst FilterBox = (props: DatatablePropsWithState) => {\n let {\n tabs,\n filters,\n hideSearch,\n slotProps,\n skeleton,\n state,\n update,\n } = props\n const [openFilter, setOpenFilter] = React.useState(false)\n let checked = state.selectAll || !!state.selected.length\n\n if (checked) return <></>\n\n return (\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n justifyContent=\"space-between\"\n zIndex={1}\n radius={1}\n mb={1}\n height={50}\n width=\"100%\"\n >\n <Stack gap={2.4} flexRow>\n {\n tabs && <Tabs\n disabled={skeleton ? true : false}\n onChange={(value: any) => {\n update({ tab: value })\n }}\n value={state.tab}\n >\n {\n tabs.map(t => <Tab key={t.label} value={t.value || t.label.toLowerCase()}>{t.label}</Tab>)\n }\n </Tabs>\n }\n </Stack>\n <Stack\n flexRow\n gap={2}\n className='datatable-header-right-area'\n alignItems={\"center\"}\n >\n {!hideSearch && <Input\n disabled={skeleton ? true : false}\n endIcon={<IconSearch />}\n placeholder='Search...'\n {...slotProps?.search}\n value={state.search}\n onChange={(e: any) => {\n update({ search: e.target.value })\n }}\n />}\n {\n filters && <Stack>\n <IconButton\n color=\"default\"\n variant={\"text\"}\n onClick={() => {\n setOpenFilter(true)\n }}\n >\n <FilterListOutlined />\n </IconButton>\n <Drawer\n open={openFilter}\n onClickOutside={() => { }}\n placement={\"right\"}\n >\n <ViewBox\n height=\"100%\"\n p={1}\n startContent={<Stack mb={2} px={2} flexRow justifyContent={\"space-between\"} alignItems=\"center\">\n <Text fontWeight={600} fontSize=\"h6\">Filters</Text>\n <IconButton\n size=\"small\"\n color=\"default\"\n variant=\"text\"\n onClick={() => {\n setOpenFilter(false)\n }}\n >\n <CloseOutlined />\n </IconButton>\n </Stack>}\n >\n <Stack\n gap={2}\n >\n <DataFilter\n options={filters}\n value={state.filters}\n onChange={(s) => {\n update({ filters: s })\n }}\n />\n </Stack>\n </ViewBox>\n </Drawer>\n </Stack>\n }\n </Stack>\n </Stack>\n )\n}\n\nexport default FilterBox"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAgBA;AACG;AASA;AACA;AAEA;AAAa;AAEb;AAgBkB;;;;;AAiCA;;AAoBS;AAaG;;AAWjC;;"}
@@ -3,26 +3,34 @@ import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
3
3
  import Stack from '../Stack/index.mjs';
4
4
  import Tabs from '../Tabs/index.mjs';
5
5
  import Tab from '../Tab/index.mjs';
6
- import Select from '../Select/index.mjs';
7
- import Option from '../Option/index.mjs';
8
6
  import Input from '../Input/index.mjs';
9
7
  import IconSearch from '@xanui/icons/Search';
8
+ import IconButton from '../IconButton/index.mjs';
9
+ import FilterListOutlined from '@xanui/icons/FilterListOutlined';
10
+ import Drawer from '../Drawer/index.mjs';
11
+ import Text from '../Text/index.mjs';
12
+ import React from 'react';
13
+ import CloseOutlined from '@xanui/icons/CloseOutlined';
14
+ import ViewBox from '../ViewBox/index.mjs';
15
+ import DataFilter from '../DataFilter/index.mjs';
10
16
 
11
17
  const FilterBox = (props) => {
12
- let { tabs, filters, hideSearch, slotProps, state, update, } = props;
18
+ let { tabs, filters, hideSearch, slotProps, skeleton, state, update, } = props;
19
+ const [openFilter, setOpenFilter] = React.useState(false);
13
20
  let checked = state.selectAll || !!state.selected.length;
14
21
  if (checked)
15
22
  return jsx(Fragment, {});
16
- return (jsxs(Stack, { direction: "row", alignItems: "center", justifyContent: "space-between", zIndex: 1, radius: 1, mb: 1, height: 50, width: "100%", children: [jsx(Stack, { gap: 2.4, flexRow: true, children: tabs && jsx(Tabs, { onChange: (value) => {
23
+ return (jsxs(Stack, { direction: "row", alignItems: "center", justifyContent: "space-between", zIndex: 1, radius: 1, mb: 1, height: 50, width: "100%", children: [jsx(Stack, { gap: 2.4, flexRow: true, children: tabs && jsx(Tabs, { disabled: skeleton ? true : false, onChange: (value) => {
17
24
  update({ tab: value });
18
- }, value: state.tab, children: tabs.map(t => jsx(Tab, { value: t.value || t.label.toLowerCase(), children: t.label }, t.label)) }) }), jsx(Stack, { className: 'datatable-header-filter-area', flex: 1, flexRow: true, children: filters && jsx(Stack, { flexRow: true, gap: 2, px: 2, children: Object.keys(filters).map(name => {
19
- const items = filters[name];
20
- return (jsx(Select, { placeholder: name.charAt(0).toUpperCase() + name.slice(1), value: state[name] || "", onChange: (value) => {
21
- update({ [name]: value });
22
- }, children: items.map((item) => jsx(Option, { value: item.value, children: item.label }, name + item.value)) }, name));
23
- }) }) }), jsx(Stack, { flexRow: true, gap: 2, className: 'datatable-header-right-area', children: !hideSearch && jsx(Input, Object.assign({ endIcon: jsx(IconSearch, {}), p: 1, placeholder: 'Search...' }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.search, { value: state.search, onChange: (e) => {
24
- update({ search: e.target.value });
25
- } })) })] }));
25
+ }, value: state.tab, children: tabs.map(t => jsx(Tab, { value: t.value || t.label.toLowerCase(), children: t.label }, t.label)) }) }), jsxs(Stack, { flexRow: true, gap: 2, className: 'datatable-header-right-area', alignItems: "center", children: [!hideSearch && jsx(Input, Object.assign({ disabled: skeleton ? true : false, endIcon: jsx(IconSearch, {}), placeholder: 'Search...' }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.search, { value: state.search, onChange: (e) => {
26
+ update({ search: e.target.value });
27
+ } })), filters && jsxs(Stack, { children: [jsx(IconButton, { color: "default", variant: "text", onClick: () => {
28
+ setOpenFilter(true);
29
+ }, children: jsx(FilterListOutlined, {}) }), jsx(Drawer, { open: openFilter, onClickOutside: () => { }, placement: "right", children: jsx(ViewBox, { height: "100%", p: 1, startContent: jsxs(Stack, { mb: 2, px: 2, flexRow: true, justifyContent: "space-between", alignItems: "center", children: [jsx(Text, { fontWeight: 600, fontSize: "h6", children: "Filters" }), jsx(IconButton, { size: "small", color: "default", variant: "text", onClick: () => {
30
+ setOpenFilter(false);
31
+ }, children: jsx(CloseOutlined, {}) })] }), children: jsx(Stack, { gap: 2, children: jsx(DataFilter, { options: filters, value: state.filters, onChange: (s) => {
32
+ update({ filters: s });
33
+ } }) }) }) })] })] })] }));
26
34
  };
27
35
 
28
36
  export { FilterBox as default };
@@ -1 +1 @@
1
- {"version":3,"file":"FilterBox.mjs","sources":["../../src/Datatable/FilterBox.tsx"],"sourcesContent":["\"use client\";\nimport Stack from '../Stack'\nimport Tabs from '../Tabs'\nimport Tab from '../Tab'\nimport Select from '../Select'\nimport Option from '../Option'\nimport Input from '../Input'\nimport IconSearch from '@xanui/icons/Search'\nimport { DatatableFilter, DatatablePropsWithState } from './types';\n\n\nconst FilterBox = (props: DatatablePropsWithState) => {\n let {\n tabs,\n filters,\n hideSearch,\n slotProps,\n state,\n update,\n } = props\n\n let checked = state.selectAll || !!state.selected.length\n\n if (checked) return <></>\n\n return (\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n justifyContent=\"space-between\"\n zIndex={1}\n radius={1}\n mb={1}\n height={50}\n width=\"100%\"\n >\n <Stack gap={2.4} flexRow>\n {\n tabs && <Tabs\n onChange={(value: any) => {\n update({ tab: value })\n }}\n value={state.tab}\n >\n {\n tabs.map(t => <Tab key={t.label} value={t.value || t.label.toLowerCase()}>{t.label}</Tab>)\n }\n </Tabs>\n }\n </Stack>\n <Stack className='datatable-header-filter-area' flex={1} flexRow>\n {\n filters && <Stack flexRow gap={2} px={2}>\n {\n Object.keys(filters).map(name => {\n const items: DatatableFilter[] = (filters as any)[name]\n return (\n <Select\n key={name}\n placeholder={name.charAt(0).toUpperCase() + name.slice(1)}\n value={(state as any)[name] || \"\"}\n onChange={(value) => {\n update({ [name]: value } as any)\n }}\n >\n {\n items.map((item) => <Option key={name + item.value} value={item.value}>\n {item.label}\n </Option>)\n }\n </Select>\n )\n })\n }\n </Stack>\n }\n </Stack>\n <Stack flexRow gap={2} className='datatable-header-right-area'>\n {!hideSearch && <Input\n endIcon={<IconSearch />}\n p={1}\n placeholder='Search...'\n {...slotProps?.search}\n value={state.search}\n onChange={(e: any) => {\n update({ search: e.target.value })\n }}\n />}\n </Stack>\n </Stack>\n )\n}\n\nexport default FilterBox"],"names":[],"mappings":";;;;;;;;;;AAWA;AACG;AASA;AAEA;AAAa;;AAiBK;AACH;AAcM;AACA;;AAOM;;;AAuBf;AAKf;;"}
1
+ {"version":3,"file":"FilterBox.mjs","sources":["../../src/Datatable/FilterBox.tsx"],"sourcesContent":["\"use client\";\nimport Stack from '../Stack'\nimport Tabs from '../Tabs'\nimport Tab from '../Tab'\nimport Input from '../Input'\nimport IconSearch from '@xanui/icons/Search'\nimport { DatatablePropsWithState } from './types';\nimport IconButton from '../IconButton';\nimport FilterListOutlined from '@xanui/icons/FilterListOutlined';\nimport Drawer from '../Drawer';\nimport Text from '../Text';\nimport React from 'react';\nimport CloseOutlined from '@xanui/icons/CloseOutlined';\nimport ViewBox from '../ViewBox';\nimport DataFilter from '../DataFilter';\n\nconst FilterBox = (props: DatatablePropsWithState) => {\n let {\n tabs,\n filters,\n hideSearch,\n slotProps,\n skeleton,\n state,\n update,\n } = props\n const [openFilter, setOpenFilter] = React.useState(false)\n let checked = state.selectAll || !!state.selected.length\n\n if (checked) return <></>\n\n return (\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n justifyContent=\"space-between\"\n zIndex={1}\n radius={1}\n mb={1}\n height={50}\n width=\"100%\"\n >\n <Stack gap={2.4} flexRow>\n {\n tabs && <Tabs\n disabled={skeleton ? true : false}\n onChange={(value: any) => {\n update({ tab: value })\n }}\n value={state.tab}\n >\n {\n tabs.map(t => <Tab key={t.label} value={t.value || t.label.toLowerCase()}>{t.label}</Tab>)\n }\n </Tabs>\n }\n </Stack>\n <Stack\n flexRow\n gap={2}\n className='datatable-header-right-area'\n alignItems={\"center\"}\n >\n {!hideSearch && <Input\n disabled={skeleton ? true : false}\n endIcon={<IconSearch />}\n placeholder='Search...'\n {...slotProps?.search}\n value={state.search}\n onChange={(e: any) => {\n update({ search: e.target.value })\n }}\n />}\n {\n filters && <Stack>\n <IconButton\n color=\"default\"\n variant={\"text\"}\n onClick={() => {\n setOpenFilter(true)\n }}\n >\n <FilterListOutlined />\n </IconButton>\n <Drawer\n open={openFilter}\n onClickOutside={() => { }}\n placement={\"right\"}\n >\n <ViewBox\n height=\"100%\"\n p={1}\n startContent={<Stack mb={2} px={2} flexRow justifyContent={\"space-between\"} alignItems=\"center\">\n <Text fontWeight={600} fontSize=\"h6\">Filters</Text>\n <IconButton\n size=\"small\"\n color=\"default\"\n variant=\"text\"\n onClick={() => {\n setOpenFilter(false)\n }}\n >\n <CloseOutlined />\n </IconButton>\n </Stack>}\n >\n <Stack\n gap={2}\n >\n <DataFilter\n options={filters}\n value={state.filters}\n onChange={(s) => {\n update({ filters: s })\n }}\n />\n </Stack>\n </ViewBox>\n </Drawer>\n </Stack>\n }\n </Stack>\n </Stack>\n )\n}\n\nexport default FilterBox"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAgBA;AACG;AASA;AACA;AAEA;AAAa;AAEb;AAgBkB;;;;;AAiCA;;AAoBS;AAaG;;AAWjC;;"}
package/Datatable/Row.js CHANGED
@@ -13,12 +13,13 @@ var index$6 = require('../ListItem/index.js');
13
13
  var ActionIcon = require('@xanui/icons/MoreVert');
14
14
  var index$4 = require('../Menu/index.js');
15
15
 
16
- const Row = ({ rows, rawRow, row, rowAction, disableRow, hideCheckbox, columns, state, update }) => {
16
+ const Row = ({ rows, rawRow, row, rowAction, disableRow, hideCheckbox, columns, compact, state, update }) => {
17
+ var _a;
17
18
  const selected = row.id ? state.selected.includes(row === null || row === void 0 ? void 0 : row.id) : false;
18
19
  let selectedColor = selected ? "primary.soft" : "transparent";
19
20
  const [target, setTarget] = React.useState();
20
21
  const isDisable = (disableRow ? disableRow(rawRow, state) : false) || false;
21
- return (jsxRuntime.jsxs(index, { disabled: isDisable, children: [!hideCheckbox && jsxRuntime.jsx(index$1, { width: 40, bgcolor: selectedColor, children: !!row.id && jsxRuntime.jsx(index$2, { checked: selected, onChange: () => {
22
+ return (jsxRuntime.jsxs(index, { children: [!hideCheckbox && jsxRuntime.jsx(index$1, { width: 40, bgcolor: selectedColor, children: !!row.id && jsxRuntime.jsx(index$2, { size: compact ? "small" : "medium", checked: selected, onChange: () => {
22
23
  if (isDisable || !row.id)
23
24
  return;
24
25
  let ids = [...state.selected];
@@ -39,19 +40,19 @@ const Row = ({ rows, rawRow, row, rowAction, disableRow, hideCheckbox, columns,
39
40
  if (!row[field])
40
41
  return jsxRuntime.jsx(index$1, {}, idx);
41
42
  return (jsxRuntime.jsx(index$1, Object.assign({ textAlign: "left" }, rest, { bgcolor: selectedColor, children: row[field] }), idx));
42
- }), jsxRuntime.jsx(index$1, { width: 30, bgcolor: selectedColor, borderColor: "divider", children: rowAction && jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(index$3, { disabled: isDisable || selected, onClick: (e) => setTarget(e.currentTarget), variant: "text", color: "default", children: jsxRuntime.jsx(ActionIcon, {}) }), jsxRuntime.jsx(index$4, { target: target, placement: "bottom-right", onClickOutside: () => setTarget(null), children: jsxRuntime.jsx(index$5, { bgcolor: "background.primary", minWidth: 160, sx: {
43
- '& > li': {
44
- borderBottom: 1,
45
- '&:last-child': {
46
- borderBottom: 0
47
- }
43
+ }), !!(rows.length && rowAction && ((_a = rowAction(rows[0])) === null || _a === void 0 ? void 0 : _a.length)) && jsxRuntime.jsxs(index$1, { width: 30, bgcolor: selectedColor, borderColor: "divider", children: [jsxRuntime.jsx(index$3, { disabled: isDisable || selected, onClick: (e) => setTarget(e.currentTarget), variant: "text", color: "default", children: jsxRuntime.jsx(ActionIcon, {}) }), jsxRuntime.jsx(index$4, { target: target, placement: "bottom-right", onClickOutside: () => setTarget(null), children: jsxRuntime.jsx(index$5, { bgcolor: "background.primary", minWidth: 160, sx: {
44
+ '& > li': {
45
+ borderBottom: 1,
46
+ '&:last-child': {
47
+ borderBottom: 0
48
48
  }
49
- }, children: rowAction({ row, state }).map(({ label, icon, onClick }) => {
50
- return (jsxRuntime.jsx(index$6, { startIcon: icon, onClick: (e) => {
51
- onClick && onClick(e);
52
- setTarget(null);
53
- }, children: label }, label));
54
- }) }) })] }) })] }));
49
+ }
50
+ }, children: rowAction({ row, state }).map(({ label, icon, onClick }) => {
51
+ return (jsxRuntime.jsx(index$6, { startIcon: icon, onClick: (e) => {
52
+ onClick && onClick(e);
53
+ setTarget(null);
54
+ }, children: label }, label));
55
+ }) }) })] })] }));
55
56
  };
56
57
 
57
58
  module.exports = Row;
@@ -1 +1 @@
1
- {"version":3,"file":"Row.js","sources":["../../src/Datatable/Row.tsx"],"sourcesContent":["\"use client\";\nimport { useState } from 'react'\nimport TableRow from '../TableRow'\nimport TableCell from '../TableCell'\nimport Checkbox from '../Checkbox'\nimport IconButton from '../IconButton'\nimport List from '../List'\nimport ListItem from '../ListItem'\nimport ActionIcon from '@xanui/icons/MoreVert'\nimport Menu from '../Menu'\nimport { DataTableDefaultRow, DatatablePropsWithState } from './types';\n\n\ntype Props = DatatablePropsWithState & {\n rawRow: DataTableDefaultRow;\n row: DataTableDefaultRow;\n}\n\nconst Row = ({ rows, rawRow, row, rowAction, disableRow, hideCheckbox, columns, state, update }: Props) => {\n const selected = row.id ? state.selected.includes(row?.id) : false\n let selectedColor = selected ? \"primary.soft\" : \"transparent\"\n const [target, setTarget] = useState<any>()\n const isDisable = (disableRow ? disableRow(rawRow, state) : false) || false\n\n return (\n <TableRow disabled={isDisable}>\n {!hideCheckbox && <TableCell width={40} bgcolor={selectedColor}>\n {\n !!row.id && <Checkbox\n checked={selected}\n onChange={() => {\n if (isDisable || !row.id) return\n let ids = [...state.selected]\n ids.includes(row.id) ? ids.splice(ids.indexOf(row.id), 1) : ids.push(row.id)\n let selectedLength = 0\n rows.forEach(r => {\n const isDisable = (disableRow ? disableRow(r, state) : false) || false\n if (!isDisable) selectedLength++\n })\n\n update({\n selectAll: selectedLength === ids.length,\n selected: ids\n })\n }}\n />\n }\n\n </TableCell>}\n {\n columns.map(({ label, field, sortable, ...rest }, idx) => {\n field = field || label\n if (!row[field]) return <TableCell key={idx}></TableCell>\n return (\n <TableCell\n key={idx}\n textAlign=\"left\"\n {...rest}\n bgcolor={selectedColor}\n >\n {row[field]}\n </TableCell>\n )\n })\n }\n <TableCell width={30} bgcolor={selectedColor} borderColor=\"divider\">\n {rowAction && <>\n <IconButton\n disabled={isDisable || selected}\n onClick={(e: any) => setTarget(e.currentTarget)}\n variant=\"text\"\n color=\"default\"\n >\n <ActionIcon />\n </IconButton>\n <Menu target={target} placement=\"bottom-right\" onClickOutside={() => setTarget(null)}>\n <List\n bgcolor=\"background.primary\"\n minWidth={160}\n sx={{\n '& > li': {\n borderBottom: 1,\n '&:last-child': {\n borderBottom: 0\n }\n }\n }}\n >\n {rowAction({ row, state }).map(({ label, icon, onClick }) => {\n return (\n <ListItem\n key={label}\n startIcon={icon}\n onClick={(e: any) => {\n onClick && onClick(e)\n setTarget(null)\n }}\n >{label}</ListItem>\n )\n })}\n </List>\n </Menu>\n </>}\n </TableCell>\n </TableRow>\n )\n}\n\nexport default Row"],"names":[],"mappings":";;;;;;;;;;;;;;;AAkBA;;;;;AAMI;AAOwB;;;AAEA;;AAEA;;AAEI;AAAgB;AACpB;AAEA;AACI;AACA;AACH;AACL;;AAOJ;AACA;AAAiB;;AAWrB;AAiBgB;AACI;AACA;AACI;AACH;AACJ;;AAID;AAKY;;AAEJ;AAGZ;AAO5B;;"}
1
+ {"version":3,"file":"Row.js","sources":["../../src/Datatable/Row.tsx"],"sourcesContent":["\"use client\";\nimport { useState } from 'react'\nimport TableRow from '../TableRow'\nimport TableCell from '../TableCell'\nimport Checkbox from '../Checkbox'\nimport IconButton from '../IconButton'\nimport List from '../List'\nimport ListItem from '../ListItem'\nimport ActionIcon from '@xanui/icons/MoreVert'\nimport Menu from '../Menu'\nimport { DataTableDefaultRow, DatatablePropsWithState } from './types';\n\n\ntype Props = DatatablePropsWithState & {\n rawRow: DataTableDefaultRow;\n row: DataTableDefaultRow;\n}\n\nconst Row = ({ rows, rawRow, row, rowAction, disableRow, hideCheckbox, columns, compact, state, update }: Props) => {\n const selected = row.id ? state.selected.includes(row?.id) : false\n let selectedColor = selected ? \"primary.soft\" : \"transparent\"\n const [target, setTarget] = useState<any>()\n const isDisable = (disableRow ? disableRow(rawRow, state) : false) || false\n\n return (\n <TableRow >\n {!hideCheckbox && <TableCell width={40} bgcolor={selectedColor}>\n {\n !!row.id && <Checkbox\n size={compact ? \"small\" : \"medium\"}\n checked={selected}\n onChange={() => {\n if (isDisable || !row.id) return\n let ids = [...state.selected]\n ids.includes(row.id) ? ids.splice(ids.indexOf(row.id), 1) : ids.push(row.id)\n let selectedLength = 0\n rows.forEach(r => {\n const isDisable = (disableRow ? disableRow(r, state) : false) || false\n if (!isDisable) selectedLength++\n })\n\n update({\n selectAll: selectedLength === ids.length,\n selected: ids\n })\n }}\n />\n }\n\n </TableCell>}\n {\n columns.map(({ label, field, sortable, ...rest }, idx) => {\n field = field || label\n if (!row[field]) return <TableCell key={idx}></TableCell>\n return (\n <TableCell\n key={idx}\n textAlign=\"left\"\n {...rest}\n bgcolor={selectedColor}\n >\n {row[field]}\n </TableCell>\n )\n })\n }\n {!!(rows.length && rowAction && rowAction((rows as any)[0])?.length) && <TableCell width={30} bgcolor={selectedColor} borderColor=\"divider\">\n <IconButton\n disabled={isDisable || selected}\n onClick={(e: any) => setTarget(e.currentTarget)}\n variant=\"text\"\n color=\"default\"\n >\n <ActionIcon />\n </IconButton>\n <Menu target={target} placement=\"bottom-right\" onClickOutside={() => setTarget(null)}>\n <List\n bgcolor=\"background.primary\"\n minWidth={160}\n sx={{\n '& > li': {\n borderBottom: 1,\n '&:last-child': {\n borderBottom: 0\n }\n }\n }}\n >\n {rowAction({ row, state }).map(({ label, icon, onClick }) => {\n return (\n <ListItem\n key={label}\n startIcon={icon}\n onClick={(e: any) => {\n onClick && onClick(e)\n setTarget(null)\n }}\n >{label}</ListItem>\n )\n })}\n </List>\n </Menu>\n </TableCell>\n }\n </TableRow>\n )\n}\n\nexport default Row"],"names":[],"mappings":";;;;;;;;;;;;;;;AAkBA;;;;;;;AAc4B;;;AAEA;;AAEA;;AAEI;AAAgB;AACpB;AAEA;AACI;AACA;AACH;AACL;;AAOJ;AACA;AAAiB;;;AA2BT;AACI;AACA;AACI;AACH;AACJ;;AAID;AAKY;;AAEJ;AAGZ;AAOxB;;"}