@xanui/ui 1.1.35 → 1.1.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/DataFilter/index.js +3 -3
- package/package.json +3 -3
- package/Accordion/index.mjs +0 -94
- package/Accordion/index.mjs.map +0 -1
- package/Alert/index.mjs +0 -119
- package/Alert/index.mjs.map +0 -1
- package/Autocomplete/index.mjs +0 -134
- package/Autocomplete/index.mjs.map +0 -1
- package/Avatar/index.mjs +0 -48
- package/Avatar/index.mjs.map +0 -1
- package/Badge/index.mjs +0 -107
- package/Badge/index.mjs.map +0 -1
- package/Box/index.mjs +0 -12
- package/Box/index.mjs.map +0 -1
- package/Button/index.mjs +0 -92
- package/Button/index.mjs.map +0 -1
- package/ButtonGroup/index.mjs +0 -56
- package/ButtonGroup/index.mjs.map +0 -1
- package/Calendar/index.mjs +0 -172
- package/Calendar/index.mjs.map +0 -1
- package/CalendarInput/index.mjs +0 -32
- package/CalendarInput/index.mjs.map +0 -1
- package/Checkbox/index.mjs +0 -56
- package/Checkbox/index.mjs.map +0 -1
- package/Chip/index.mjs +0 -74
- package/Chip/index.mjs.map +0 -1
- package/CircleProgress/index.mjs +0 -127
- package/CircleProgress/index.mjs.map +0 -1
- package/ClickOutside/index.mjs +0 -35
- package/ClickOutside/index.mjs.map +0 -1
- package/Collaps/index.mjs +0 -24
- package/Collaps/index.mjs.map +0 -1
- package/Container/index.mjs +0 -27
- package/Container/index.mjs.map +0 -1
- package/DataFilter/index.mjs +0 -67
- package/DataFilter/index.mjs.map +0 -1
- package/DataFilter/options/DateFilter.mjs +0 -30
- package/DataFilter/options/DateFilter.mjs.map +0 -1
- package/DataFilter/options/DateRangeFilter.mjs +0 -25
- package/DataFilter/options/DateRangeFilter.mjs.map +0 -1
- package/DataFilter/options/MultiSelectFilter.mjs +0 -36
- package/DataFilter/options/MultiSelectFilter.mjs.map +0 -1
- package/DataFilter/options/NumberFilter.mjs +0 -22
- package/DataFilter/options/NumberFilter.mjs.map +0 -1
- package/DataFilter/options/NumberRangeFilter.mjs +0 -27
- package/DataFilter/options/NumberRangeFilter.mjs.map +0 -1
- package/DataFilter/options/SelectFilter.mjs +0 -32
- package/DataFilter/options/SelectFilter.mjs.map +0 -1
- package/DataFilter/options/TextFilter.mjs +0 -22
- package/DataFilter/options/TextFilter.mjs.map +0 -1
- package/Datatable/FilterBox.mjs +0 -37
- package/Datatable/FilterBox.mjs.map +0 -1
- package/Datatable/Row.mjs +0 -57
- package/Datatable/Row.mjs.map +0 -1
- package/Datatable/SelectedBox.mjs +0 -19
- package/Datatable/SelectedBox.mjs.map +0 -1
- package/Datatable/Table.mjs +0 -21
- package/Datatable/Table.mjs.map +0 -1
- package/Datatable/TableHead.mjs +0 -59
- package/Datatable/TableHead.mjs.map +0 -1
- package/Datatable/index.mjs +0 -91
- package/Datatable/index.mjs.map +0 -1
- package/Divider/index.mjs +0 -29
- package/Divider/index.mjs.map +0 -1
- package/Drawer/index.mjs +0 -76
- package/Drawer/index.mjs.map +0 -1
- package/Form/index.mjs +0 -43
- package/Form/index.mjs.map +0 -1
- package/GridContainer/index.mjs +0 -17
- package/GridContainer/index.mjs.map +0 -1
- package/GridItem/index.mjs +0 -18
- package/GridItem/index.mjs.map +0 -1
- package/IconButton/index.mjs +0 -62
- package/IconButton/index.mjs.map +0 -1
- package/Image/index.mjs +0 -25
- package/Image/index.mjs.map +0 -1
- package/Input/index.mjs +0 -142
- package/Input/index.mjs.map +0 -1
- package/InputNumber/index.mjs +0 -30
- package/InputNumber/index.mjs.map +0 -1
- package/Label/index.mjs +0 -22
- package/Label/index.mjs.map +0 -1
- package/Layer/index.mjs +0 -60
- package/Layer/index.mjs.map +0 -1
- package/LineProgress/index.mjs +0 -57
- package/LineProgress/index.mjs.map +0 -1
- package/List/ListContext.mjs +0 -8
- package/List/ListContext.mjs.map +0 -1
- package/List/index.mjs +0 -61
- package/List/index.mjs.map +0 -1
- package/ListItem/index.mjs +0 -52
- package/ListItem/index.mjs.map +0 -1
- package/LoadingBox/index.mjs +0 -30
- package/LoadingBox/index.mjs.map +0 -1
- package/Menu/index.mjs +0 -148
- package/Menu/index.mjs.map +0 -1
- package/Modal/index.mjs +0 -57
- package/Modal/index.mjs.map +0 -1
- package/NoSSR/index.mjs +0 -13
- package/NoSSR/index.mjs.map +0 -1
- package/Option/index.mjs +0 -12
- package/Option/index.mjs.map +0 -1
- package/Paper/index.mjs +0 -13
- package/Paper/index.mjs.map +0 -1
- package/Portal/index.mjs +0 -25
- package/Portal/index.mjs.map +0 -1
- package/Radio/index.mjs +0 -14
- package/Radio/index.mjs.map +0 -1
- package/Scrollbar/index.mjs +0 -57
- package/Scrollbar/index.mjs.map +0 -1
- package/Select/index.mjs +0 -57
- package/Select/index.mjs.map +0 -1
- package/Skeleton/index.mjs +0 -58
- package/Skeleton/index.mjs.map +0 -1
- package/Stack/index.mjs +0 -15
- package/Stack/index.mjs.map +0 -1
- package/Switch/index.mjs +0 -77
- package/Switch/index.mjs.map +0 -1
- package/Tab/index.mjs +0 -15
- package/Tab/index.mjs.map +0 -1
- package/Table/index.mjs +0 -86
- package/Table/index.mjs.map +0 -1
- package/TableBody/index.mjs +0 -12
- package/TableBody/index.mjs.map +0 -1
- package/TableCell/index.mjs +0 -12
- package/TableCell/index.mjs.map +0 -1
- package/TableFooter/index.mjs +0 -12
- package/TableFooter/index.mjs.map +0 -1
- package/TableHead/index.mjs +0 -12
- package/TableHead/index.mjs.map +0 -1
- package/TablePagination/index.mjs +0 -57
- package/TablePagination/index.mjs.map +0 -1
- package/TableRow/index.mjs +0 -12
- package/TableRow/index.mjs.map +0 -1
- package/Tabs/index.mjs +0 -199
- package/Tabs/index.mjs.map +0 -1
- package/Text/index.mjs +0 -23
- package/Text/index.mjs.map +0 -1
- package/Toast/index.mjs +0 -118
- package/Toast/index.mjs.map +0 -1
- package/Tooltip/index.mjs +0 -38
- package/Tooltip/index.mjs.map +0 -1
- package/ViewBox/index.mjs +0 -30
- package/ViewBox/index.mjs.map +0 -1
- package/index.mjs +0 -65
- package/index.mjs.map +0 -1
- package/useAlert/index.mjs +0 -92
- package/useAlert/index.mjs.map +0 -1
- package/useBlurCss/index.mjs +0 -17
- package/useBlurCss/index.mjs.map +0 -1
- package/useCorner/index.mjs +0 -20
- package/useCorner/index.mjs.map +0 -1
- package/useLayer/index.mjs +0 -36
- package/useLayer/index.mjs.map +0 -1
- package/useModal/index.mjs +0 -35
- package/useModal/index.mjs.map +0 -1
package/CircleProgress/index.mjs
DELETED
|
@@ -1,127 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import { __rest } from 'tslib';
|
|
3
|
-
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
4
|
-
import React, { useId } from 'react';
|
|
5
|
-
import { useInterface, useBreakpointProps, Tag } from '@xanui/core';
|
|
6
|
-
|
|
7
|
-
const CircleProgress = React.forwardRef((_a, ref) => {
|
|
8
|
-
var _b, _c, _d, _e;
|
|
9
|
-
var { children } = _a, props = __rest(_a, ["children"]);
|
|
10
|
-
let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface("CircleProgress", props, {});
|
|
11
|
-
const _p = {};
|
|
12
|
-
if (color)
|
|
13
|
-
_p.color = color;
|
|
14
|
-
if (trackColor)
|
|
15
|
-
_p.trackColor = trackColor;
|
|
16
|
-
if (thumbColor)
|
|
17
|
-
_p.thumbColor = thumbColor;
|
|
18
|
-
if (size)
|
|
19
|
-
_p.size = size;
|
|
20
|
-
if (thumbSize)
|
|
21
|
-
_p.thumbSize = thumbSize;
|
|
22
|
-
if (trackSize)
|
|
23
|
-
_p.trackSize = trackSize;
|
|
24
|
-
if (value)
|
|
25
|
-
_p.value = value;
|
|
26
|
-
if (hideTrack)
|
|
27
|
-
_p.hideTrack = hideTrack;
|
|
28
|
-
if (showPercentage)
|
|
29
|
-
_p.showPercentage = showPercentage;
|
|
30
|
-
if (speed)
|
|
31
|
-
_p.speed = speed;
|
|
32
|
-
const p = useBreakpointProps(_p);
|
|
33
|
-
color = (_b = p.color) !== null && _b !== void 0 ? _b : "brand";
|
|
34
|
-
trackColor = p.trackColor;
|
|
35
|
-
thumbColor = p.thumbColor;
|
|
36
|
-
size = (_c = p.size) !== null && _c !== void 0 ? _c : "medium";
|
|
37
|
-
thumbSize = (_d = p.thumbSize) !== null && _d !== void 0 ? _d : 4;
|
|
38
|
-
trackSize = p.trackSize;
|
|
39
|
-
value = p.value;
|
|
40
|
-
hideTrack = p.hideTrack;
|
|
41
|
-
showPercentage = p.showPercentage;
|
|
42
|
-
speed = (_e = p.speed) !== null && _e !== void 0 ? _e : 1.3;
|
|
43
|
-
if (trackColor === 'default') {
|
|
44
|
-
trackColor = "divider";
|
|
45
|
-
}
|
|
46
|
-
if (thumbColor === 'default') {
|
|
47
|
-
thumbColor = "divider.secondary";
|
|
48
|
-
}
|
|
49
|
-
let sizes = {
|
|
50
|
-
small: 24,
|
|
51
|
-
medium: 32,
|
|
52
|
-
large: 44
|
|
53
|
-
};
|
|
54
|
-
if (typeof size === 'string' && sizes[size]) {
|
|
55
|
-
size = sizes[size];
|
|
56
|
-
}
|
|
57
|
-
let isVal = typeof value === 'number';
|
|
58
|
-
const animrotate = "anim" + useId().replace(":", "");
|
|
59
|
-
const animdash = "anim" + useId().replace(":", "");
|
|
60
|
-
if (isVal && value > 100)
|
|
61
|
-
value = 100;
|
|
62
|
-
const circumference = 125.66370614359172; //radius * 2 * Math.PI
|
|
63
|
-
const percent = circumference - ((value || 0) / 100) * circumference;
|
|
64
|
-
if (showPercentage && !children) {
|
|
65
|
-
children = jsxs(Tag, { sxr: {
|
|
66
|
-
color: color === 'default' ? "text.primary" : `${color}.primary`,
|
|
67
|
-
fontSize: size / 4
|
|
68
|
-
}, children: [value, "%"] });
|
|
69
|
-
}
|
|
70
|
-
return (jsxs(Tag, { baseClass: 'circle-progress', sxr: {
|
|
71
|
-
display: "inline-flex",
|
|
72
|
-
alignItems: "center",
|
|
73
|
-
justifyContent: "center",
|
|
74
|
-
"& svg[class='circle-progress-svg']": {
|
|
75
|
-
zIndex: 1,
|
|
76
|
-
position: "absolute",
|
|
77
|
-
top: 0,
|
|
78
|
-
left: 0,
|
|
79
|
-
width: "100%",
|
|
80
|
-
height: "100%",
|
|
81
|
-
transform: isVal ? "rotate(-90deg)" : "none",
|
|
82
|
-
transformOrigin: isVal ? "center" : "initial",
|
|
83
|
-
animation: isVal ? "none" : `${animrotate} ${speed}s linear infinite`,
|
|
84
|
-
[`@keyframes ${animrotate}`]: {
|
|
85
|
-
"100%": {
|
|
86
|
-
transform: "rotate(360deg)"
|
|
87
|
-
}
|
|
88
|
-
},
|
|
89
|
-
"& circle.circle-progress-thumb": {
|
|
90
|
-
strokeDasharray: circumference,
|
|
91
|
-
strokeDashoffset: percent,
|
|
92
|
-
stroke: thumbColor || (color === 'default' ? `divider` : `${color}.primary`),
|
|
93
|
-
fill: "none",
|
|
94
|
-
strokeWidth: thumbSize,
|
|
95
|
-
strokeLinecap: "round",
|
|
96
|
-
animation: isVal ? "none" : `${animdash} ${speed}s ease-in-out infinite`,
|
|
97
|
-
[`@keyframes ${animdash}`]: {
|
|
98
|
-
"0%": { strokeDasharray: "1, 150", strokeDashoffset: 0 },
|
|
99
|
-
"50%": { strokeDasharray: "90, 150", strokeDashoffset: -35 },
|
|
100
|
-
"100%": { strokeDasharray: "90, 150", strokeDashoffset: -124 }
|
|
101
|
-
}
|
|
102
|
-
},
|
|
103
|
-
"& circle.circle-progress-track": {
|
|
104
|
-
fill: "none",
|
|
105
|
-
stroke: trackColor || (color === 'default' ? `text.primary` : `${color}.soft.secondary`),
|
|
106
|
-
strokeWidth: trackSize !== null && trackSize !== void 0 ? trackSize : thumbSize,
|
|
107
|
-
}
|
|
108
|
-
},
|
|
109
|
-
width: size,
|
|
110
|
-
height: size,
|
|
111
|
-
position: "relative"
|
|
112
|
-
}, ref: ref, children: [jsxs("svg", { viewBox: "0 0 50 50", className: "circle-progress-svg", children: [!hideTrack && jsx("circle", { className: "circle-progress-track", cx: "25", cy: "25", r: 20 }), jsx("circle", { className: "circle-progress-thumb", cx: "25", cy: "25", r: 20 })] }), !!children && jsx(Tag, { baseClass: "circle-progress-content", sxr: {
|
|
113
|
-
zIndex: 2,
|
|
114
|
-
width: size - thumbSize,
|
|
115
|
-
height: size - thumbSize,
|
|
116
|
-
display: "flex",
|
|
117
|
-
alignItems: "center",
|
|
118
|
-
justifyContent: "center",
|
|
119
|
-
'& *': {
|
|
120
|
-
maxWidth: size - (thumbSize + 8),
|
|
121
|
-
maxHeight: size - (thumbSize + 8),
|
|
122
|
-
}
|
|
123
|
-
}, children: children })] }));
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
export { CircleProgress as default };
|
|
127
|
-
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../src/CircleProgress/index.tsx"],"sourcesContent":["\"use client\";\r\nimport React, { ReactElement, useId } from \"react\"\r\nimport { Tag, UseColorTemplateColor, useInterface, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\n\r\nexport type CircleProgressProps = {\r\n children?: ReactElement;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n trackColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n thumbColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\r\n thumbSize?: useBreakpointPropsType<number>;\r\n trackSize?: useBreakpointPropsType<number>;\r\n value?: useBreakpointPropsType<number>;\r\n hideTrack?: useBreakpointPropsType<boolean>;\r\n showPercentage?: useBreakpointPropsType<boolean>;\r\n speed?: useBreakpointPropsType<number>;\r\n}\r\n\r\nconst CircleProgress = React.forwardRef(({ children, ...props }: CircleProgressProps, ref: React.Ref<any>) => {\r\n let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface<any>(\"CircleProgress\", props, {})\r\n const _p: any = {}\r\n if (color) _p.color = color\r\n if (trackColor) _p.trackColor = trackColor\r\n if (thumbColor) _p.thumbColor = thumbColor\r\n if (size) _p.size = size\r\n if (thumbSize) _p.thumbSize = thumbSize\r\n if (trackSize) _p.trackSize = trackSize\r\n if (value) _p.value = value\r\n if (hideTrack) _p.hideTrack = hideTrack\r\n if (showPercentage) _p.showPercentage = showPercentage\r\n if (speed) _p.speed = speed\r\n const p: any = useBreakpointProps(_p)\r\n\r\n color = p.color ?? \"brand\"\r\n trackColor = p.trackColor\r\n thumbColor = p.thumbColor\r\n size = p.size ?? \"medium\"\r\n thumbSize = p.thumbSize ?? 4\r\n trackSize = p.trackSize\r\n value = p.value\r\n hideTrack = p.hideTrack\r\n showPercentage = p.showPercentage\r\n speed = p.speed ?? 1.3\r\n\r\n if (trackColor === 'default') {\r\n trackColor = \"divider\"\r\n }\r\n\r\n if (thumbColor === 'default') {\r\n thumbColor = \"divider.secondary\"\r\n }\r\n\r\n\r\n let sizes: any = {\r\n small: 24,\r\n medium: 32,\r\n large: 44\r\n }\r\n if (typeof size === 'string' && sizes[size]) {\r\n size = sizes[size]\r\n }\r\n\r\n let isVal = typeof value === 'number'\r\n const animrotate = \"anim\" + useId().replace(\":\", \"\")\r\n const animdash = \"anim\" + useId().replace(\":\", \"\")\r\n if (isVal && (value as number) > 100) value = 100\r\n const circumference = 125.66370614359172 //radius * 2 * Math.PI\r\n const percent = circumference - ((value || 0) / 100) * circumference\r\n\r\n if (showPercentage && !children) {\r\n children = <Tag\r\n sxr={{\r\n color: color === 'default' ? \"text.primary\" : `${color}.primary`,\r\n fontSize: size / 4\r\n }}\r\n >{value}%</Tag>\r\n }\r\n\r\n return (\r\n <Tag\r\n baseClass='circle-progress'\r\n sxr={{\r\n display: \"inline-flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n \"& svg[class='circle-progress-svg']\": {\r\n zIndex: 1,\r\n position: \"absolute\",\r\n top: 0,\r\n left: 0,\r\n width: \"100%\",\r\n height: \"100%\",\r\n transform: isVal ? \"rotate(-90deg)\" : \"none\",\r\n transformOrigin: isVal ? \"center\" : \"initial\",\r\n animation: isVal ? \"none\" : `${animrotate} ${speed}s linear infinite`,\r\n [`@keyframes ${animrotate}`]: {\r\n \"100%\": {\r\n transform: \"rotate(360deg)\"\r\n }\r\n },\r\n \"& circle.circle-progress-thumb\": {\r\n\r\n strokeDasharray: circumference,\r\n strokeDashoffset: percent,\r\n stroke: thumbColor || (color === 'default' ? `divider` : `${color}.primary`),\r\n fill: \"none\",\r\n strokeWidth: thumbSize,\r\n strokeLinecap: \"round\",\r\n animation: isVal ? \"none\" : `${animdash} ${speed}s ease-in-out infinite`,\r\n [`@keyframes ${animdash}`]: {\r\n \"0%\": { strokeDasharray: \"1, 150\", strokeDashoffset: 0 },\r\n \"50%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -35 },\r\n \"100%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -124 }\r\n }\r\n },\r\n \"& circle.circle-progress-track\": {\r\n fill: \"none\",\r\n stroke: trackColor || (color === 'default' ? `text.primary` : `${color}.soft.secondary`),\r\n strokeWidth: trackSize ?? thumbSize,\r\n }\r\n },\r\n width: size,\r\n height: size,\r\n position: \"relative\"\r\n }}\r\n ref={ref}\r\n >\r\n <svg viewBox=\"0 0 50 50\" className=\"circle-progress-svg\">\r\n {!hideTrack && <circle className=\"circle-progress-track\" cx=\"25\" cy=\"25\" r={20} />}\r\n <circle className=\"circle-progress-thumb\" cx=\"25\" cy=\"25\" r={20} />\r\n </svg>\r\n {!!children && <Tag\r\n baseClass=\"circle-progress-content\"\r\n sxr={{\r\n zIndex: 2,\r\n width: size - thumbSize,\r\n height: size - thumbSize,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n '& *': {\r\n maxWidth: size - (thumbSize + 8),\r\n maxHeight: size - (thumbSize + 8),\r\n }\r\n }}\r\n >\r\n {children}\r\n </Tag>}\r\n </Tag >\r\n )\r\n})\r\n\r\nexport default CircleProgress\r\n\r\n"],"names":[],"mappings":";;;;;;AAkBA;;AAAyC;AACrC;;AAEA;AAAW;AACX;AAAgB;AAChB;AAAgB;AAChB;AAAU;AACV;AAAe;AACf;AAAe;AACf;AAAW;AACX;AAAe;AACf;AAAoB;AACpB;AAAW;AACX;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAIA;;;AAKA;AACI;AACA;AACA;;;AAGA;;AAGJ;AACA;AACA;AACA;;AACA;AACA;AAEA;AACI;AAEQ;;;;;AAUA;AACA;AACA;AACA;AACI;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACI;AACI;AACH;AACJ;AACD;AAEI;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AAIC;AACJ;AACD;AACI;AACA;AACA;AACH;AACJ;AACD;AACA;AACA;AACH;AAUO;;;AAGA;AACA;AACA;AACA;AACI;AACA;AACH;AACJ;AAMjB;;"}
|
package/ClickOutside/index.mjs
DELETED
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import { __rest } from 'tslib';
|
|
3
|
-
import { jsx } from 'react/jsx-runtime';
|
|
4
|
-
import { Tag } from '@xanui/core';
|
|
5
|
-
import React, { useRef, useEffect } from 'react';
|
|
6
|
-
|
|
7
|
-
const ClickOutside = React.forwardRef((_a, forwardedRef) => {
|
|
8
|
-
var { children, onClickOutside } = _a, props = __rest(_a, ["children", "onClickOutside"]);
|
|
9
|
-
const innerRef = useRef(null);
|
|
10
|
-
// merge refs
|
|
11
|
-
const setRefs = (el) => {
|
|
12
|
-
innerRef.current = el;
|
|
13
|
-
if (typeof forwardedRef === "function") {
|
|
14
|
-
forwardedRef(el);
|
|
15
|
-
}
|
|
16
|
-
else if (forwardedRef) {
|
|
17
|
-
forwardedRef.current = el;
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
useEffect(() => {
|
|
21
|
-
const handler = (e) => {
|
|
22
|
-
if (!innerRef.current)
|
|
23
|
-
return;
|
|
24
|
-
if (!innerRef.current.contains(e.target)) {
|
|
25
|
-
onClickOutside(e);
|
|
26
|
-
}
|
|
27
|
-
};
|
|
28
|
-
document.addEventListener("mousedown", handler);
|
|
29
|
-
return () => document.removeEventListener("mousedown", handler);
|
|
30
|
-
}, [onClickOutside]);
|
|
31
|
-
return (jsx(Tag, Object.assign({ component: "div", display: "inline-block" }, props, { baseClass: 'click-outside', ref: setRefs, children: children })));
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
export { ClickOutside as default };
|
|
35
|
-
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../src/ClickOutside/index.tsx"],"sourcesContent":["\"use client\";\r\nimport { Tag, TagComponentType, TagProps } from '@xanui/core';\r\nimport React, { useEffect, useRef } from 'react';\r\n\r\nexport type ClickOutsideProps<T extends TagComponentType = \"div\"> = TagProps<T> & {\r\n onClickOutside: (e: MouseEvent) => void;\r\n children: React.ReactElement\r\n};\r\n\r\nconst ClickOutside = React.forwardRef(<T extends TagComponentType = \"div\">({ children, onClickOutside, ...props }: ClickOutsideProps<T>, forwardedRef: any) => {\r\n\r\n const innerRef = useRef<HTMLElement | null>(null);\r\n\r\n // merge refs\r\n const setRefs = (el: HTMLElement) => {\r\n innerRef.current = el;\r\n if (typeof forwardedRef === \"function\") {\r\n forwardedRef(el);\r\n } else if (forwardedRef) {\r\n forwardedRef.current = el;\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n const handler = (e: MouseEvent) => {\r\n if (!innerRef.current) return;\r\n if (!innerRef.current.contains(e.target as Node)) {\r\n onClickOutside(e);\r\n }\r\n };\r\n\r\n document.addEventListener(\"mousedown\", handler);\r\n return () => document.removeEventListener(\"mousedown\", handler);\r\n }, [onClickOutside]);\r\n\r\n return (\r\n <Tag\r\n component=\"div\"\r\n display=\"inline-block\"\r\n {...props}\r\n baseClass='click-outside'\r\n ref={setRefs}\r\n >\r\n {children}\r\n </Tag>\r\n )\r\n});\r\n\r\nexport default ClickOutside;\r\n"],"names":[],"mappings":";;;;;;AASA;;AAEI;;AAGA;AACI;AACA;;;;AAGI;;AAER;;AAGI;;;AAEI;;;AAGJ;AAEA;;AAEJ;;AAaJ;;"}
|
package/Collaps/index.mjs
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { __rest } from 'tslib';
|
|
2
|
-
import { jsx } from 'react/jsx-runtime';
|
|
3
|
-
import React from 'react';
|
|
4
|
-
import { useInterface, Transition, Tag } from '@xanui/core';
|
|
5
|
-
|
|
6
|
-
const Collaps = React.forwardRef((_a, ref) => {
|
|
7
|
-
var { children, open } = _a, props = __rest(_a, ["children", "open"]);
|
|
8
|
-
let [_b] = useInterface("Collaps", props, {}), { ease, easing, duration, delay, onStart, onFinish, onOpen, onOpened, onClose, onClosed } = _b, rest = __rest(_b, ["ease", "easing", "duration", "delay", "onStart", "onFinish", "onOpen", "onOpened", "onClose", "onClosed"]);
|
|
9
|
-
open !== null && open !== void 0 ? open : (open = false);
|
|
10
|
-
easing !== null && easing !== void 0 ? easing : (easing = "standard");
|
|
11
|
-
return (jsx(Transition, { ease,
|
|
12
|
-
easing,
|
|
13
|
-
duration,
|
|
14
|
-
delay,
|
|
15
|
-
onStart,
|
|
16
|
-
onFinish,
|
|
17
|
-
onOpen,
|
|
18
|
-
onOpened,
|
|
19
|
-
onClose,
|
|
20
|
-
onClosed, disableInitialTransition: true, variant: "collapseVertical", open: open, children: jsx(Tag, Object.assign({}, rest, { baseClass: 'collaps', ref: ref, children: children })) }));
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
export { Collaps as default };
|
|
24
|
-
//# sourceMappingURL=index.mjs.map
|
package/Collaps/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../src/Collaps/index.tsx"],"sourcesContent":["import React from 'react';\r\nimport { Tag, TagProps, TagComponentType, useInterface, TransitionProps, Transition } from '@xanui/core';\r\n\r\nexport type CollapsProps<T extends TagComponentType = \"div\"> = TagProps<T> & Omit<TransitionProps, \"variant\" | \"children\"> & {\r\n\r\n}\r\n\r\nconst Collaps = React.forwardRef(<T extends TagComponentType = \"div\">({ children, open, ...props }: CollapsProps<T>, ref: any) => {\r\n let [{\r\n ease,\r\n easing,\r\n duration,\r\n delay,\r\n onStart,\r\n onFinish,\r\n onOpen,\r\n onOpened,\r\n onClose,\r\n onClosed,\r\n ...rest\r\n }] = useInterface<any>(\"Collaps\", props, {})\r\n\r\n open ??= false\r\n easing ??= \"standard\"\r\n\r\n return (\r\n <Transition\r\n {...{\r\n ease,\r\n easing,\r\n duration,\r\n delay,\r\n onStart,\r\n onFinish,\r\n onOpen,\r\n onOpened,\r\n onClose,\r\n onClosed\r\n }}\r\n disableInitialTransition\r\n variant=\"collapseVertical\"\r\n open={open}\r\n >\r\n <Tag\r\n {...rest}\r\n baseClass='collaps'\r\n ref={ref}\r\n >{children}</Tag>\r\n </Transition>\r\n )\r\n})\r\n\r\nexport default Collaps\r\n\r\n\r\n"],"names":["_jsx"],"mappings":";;;;;AAOA,MAAM,OAAO,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,EAA6C,EAAE,GAAQ,KAAI;QAA3D,EAAE,QAAQ,EAAE,IAAI,EAAA,GAAA,EAA6B,EAAxB,KAAK,GAAA,MAAA,CAAA,EAAA,EAA1B,oBAA4B,CAAF;AAC5F,IAAA,IAAI,OAYC,YAAY,CAAM,SAAS,EAAE,KAAK,EAAE,EAAE,CAAC,EAZvC,EACD,IAAI,EACJ,MAAM,EACN,QAAQ,EACR,KAAK,EACL,OAAO,EACP,QAAQ,EACR,MAAM,EACN,QAAQ,EACR,OAAO,EACP,QAAQ,OAEX,EADM,IAAI,GAAA,MAAA,CAAA,EAAA,EAXN,CAAA,MAAA,EAAA,QAAA,EAAA,UAAA,EAAA,OAAA,EAAA,SAAA,EAAA,UAAA,EAAA,QAAA,EAAA,UAAA,EAAA,SAAA,EAAA,UAAA,CAYJ,CAA2C;IAE5C,IAAI,KAAA,IAAA,IAAJ,IAAI,KAAA,MAAA,GAAJ,IAAI,IAAJ,IAAI,GAAK,KAAK,CAAA;IACd,MAAM,KAAA,IAAA,IAAN,MAAM,KAAA,MAAA,GAAN,MAAM,IAAN,MAAM,GAAK,UAAU,CAAA;AAErB,IAAA,QACIA,GAAA,CAAC,UAAU,EAAA,EAEH,IAAI;QACJ,MAAM;QACN,QAAQ;QACR,KAAK;QACL,OAAO;QACP,QAAQ;QACR,MAAM;QACN,QAAQ;QACR,OAAO;AACP,QAAA,QAAQ,EAEZ,wBAAwB,EAAA,IAAA,EACxB,OAAO,EAAC,kBAAkB,EAC1B,IAAI,EAAE,IAAI,EAAA,QAAA,EAEVA,GAAA,CAAC,GAAG,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACI,IAAI,EAAA,EACR,SAAS,EAAC,SAAS,EACnB,GAAG,EAAE,GAAG,EAAA,QAAA,EACV,QAAQ,EAAA,CAAA,CAAO,EAAA,CACR;AAErB,CAAC;;;;"}
|
package/Container/index.mjs
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { __rest } from 'tslib';
|
|
2
|
-
import { jsx } from 'react/jsx-runtime';
|
|
3
|
-
import React from 'react';
|
|
4
|
-
import { useBreakpointProps, useTheme, Tag } from '@xanui/core';
|
|
5
|
-
|
|
6
|
-
const Container = React.forwardRef((_a, ref) => {
|
|
7
|
-
var { children, maxWidth } = _a, rest = __rest(_a, ["children", "maxWidth"]);
|
|
8
|
-
const _p = {};
|
|
9
|
-
if (maxWidth)
|
|
10
|
-
_p.maxWidth = maxWidth;
|
|
11
|
-
const p = useBreakpointProps(_p);
|
|
12
|
-
maxWidth = p.maxWidth;
|
|
13
|
-
const { breakpoints } = useTheme();
|
|
14
|
-
maxWidth = maxWidth || "lg";
|
|
15
|
-
return (jsx(Tag, Object.assign({}, rest, { sxr: {
|
|
16
|
-
width: "100%",
|
|
17
|
-
maxWidth: {
|
|
18
|
-
xs: "100%",
|
|
19
|
-
[maxWidth]: breakpoints[maxWidth]
|
|
20
|
-
},
|
|
21
|
-
mx: "auto",
|
|
22
|
-
px: 2,
|
|
23
|
-
}, baseClass: "container", ref: ref, children: children })));
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
export { Container as default };
|
|
27
|
-
//# sourceMappingURL=index.mjs.map
|
package/Container/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../src/Container/index.tsx"],"sourcesContent":["import React from 'react';\r\nimport { Tag, TagProps, TagComponentType, useTheme, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\n\r\n\r\nexport type ContainerProps<T extends TagComponentType = \"div\"> = TagProps<T> & {\r\n maxWidth?: useBreakpointPropsType<'lg' | 'md' | \"sm\" | 'xs'>\r\n}\r\n\r\nconst Container = React.forwardRef(<T extends TagComponentType = \"div\">({ children, maxWidth, ...rest }: ContainerProps<T>, ref?: React.Ref<any>) => {\r\n const _p: any = {}\r\n if (maxWidth) _p.maxWidth = maxWidth\r\n const p: any = useBreakpointProps(_p)\r\n maxWidth = p.maxWidth\r\n\r\n const { breakpoints } = useTheme()\r\n maxWidth = maxWidth || \"lg\"\r\n return (\r\n <Tag\r\n {...rest}\r\n sxr={{\r\n width: \"100%\",\r\n maxWidth: {\r\n xs: \"100%\",\r\n [maxWidth as any]: (breakpoints as any)[maxWidth as any]\r\n },\r\n mx: \"auto\",\r\n px: 2,\r\n }}\r\n baseClass=\"container\"\r\n ref={ref}\r\n >{children}</Tag>\r\n )\r\n})\r\n\r\nexport default Container\r\n\r\n\r\n"],"names":["_jsx"],"mappings":";;;;;AAQA,MAAM,SAAS,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,EAAkD,EAAE,GAAoB,KAAI;QAA5E,EAAE,QAAQ,EAAE,QAAQ,EAAA,GAAA,EAA8B,EAAzB,IAAI,GAAA,MAAA,CAAA,EAAA,EAA7B,wBAA+B,CAAF;IACjG,MAAM,EAAE,GAAQ,EAAE;AAClB,IAAA,IAAI,QAAQ;AAAE,QAAA,EAAE,CAAC,QAAQ,GAAG,QAAQ;AACpC,IAAA,MAAM,CAAC,GAAQ,kBAAkB,CAAC,EAAE,CAAC;AACrC,IAAA,QAAQ,GAAG,CAAC,CAAC,QAAQ;AAErB,IAAA,MAAM,EAAE,WAAW,EAAE,GAAG,QAAQ,EAAE;AAClC,IAAA,QAAQ,GAAG,QAAQ,IAAI,IAAI;AAC3B,IAAA,QACIA,GAAA,CAAC,GAAG,oBACI,IAAI,EAAA,EACR,GAAG,EAAE;AACD,YAAA,KAAK,EAAE,MAAM;AACb,YAAA,QAAQ,EAAE;AACN,gBAAA,EAAE,EAAE,MAAM;AACV,gBAAA,CAAC,QAAe,GAAI,WAAmB,CAAC,QAAe;AAC1D,aAAA;AACD,YAAA,EAAE,EAAE,MAAM;AACV,YAAA,EAAE,EAAE,CAAC;SACR,EACD,SAAS,EAAC,WAAW,EACrB,GAAG,EAAE,GAAG,EAAA,QAAA,EACV,QAAQ,EAAA,CAAA,CAAO;AAEzB,CAAC;;;;"}
|
package/DataFilter/index.mjs
DELETED
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import { __rest } from 'tslib';
|
|
3
|
-
import { jsx } from 'react/jsx-runtime';
|
|
4
|
-
import Stack from '../Stack/index.mjs';
|
|
5
|
-
import SelectFilter from './options/SelectFilter.mjs';
|
|
6
|
-
import MultiSelectFilter from './options/MultiSelectFilter.mjs';
|
|
7
|
-
import NumberFilter from './options/NumberFilter.mjs';
|
|
8
|
-
import TextFilter from './options/TextFilter.mjs';
|
|
9
|
-
import NumberRangeFilter from './options/NumberRangeFilter.mjs';
|
|
10
|
-
import DateFilter from './options/DateFilter.mjs';
|
|
11
|
-
import DateRangeFilter from './options/DateRangeFilter.mjs';
|
|
12
|
-
import React from 'react';
|
|
13
|
-
import { Tag } from '@xanui/core';
|
|
14
|
-
|
|
15
|
-
const DataFilter = (_a, ref) => {
|
|
16
|
-
var { inline, options, onChange, value } = _a, props = __rest(_a, ["inline", "options", "onChange", "value"]);
|
|
17
|
-
inline !== null && inline !== void 0 ? inline : (inline = false);
|
|
18
|
-
value !== null && value !== void 0 ? value : (value = {});
|
|
19
|
-
onChange !== null && onChange !== void 0 ? onChange : (onChange = () => { });
|
|
20
|
-
return (jsx(Tag, Object.assign({}, props, { sxr: {
|
|
21
|
-
flexBox: true,
|
|
22
|
-
flexDirection: inline ? 'row' : 'column',
|
|
23
|
-
alignItems: inline ? 'center' : 'stretch',
|
|
24
|
-
flexWrap: inline ? 'wrap' : 'nowrap',
|
|
25
|
-
gap: 1,
|
|
26
|
-
p: 2,
|
|
27
|
-
radius: 1,
|
|
28
|
-
}, baseClass: 'data-filter', ref: ref, children: options.map((option, index) => {
|
|
29
|
-
var _a, _b, _c, _d, _e, _f, _g;
|
|
30
|
-
switch (option.type) {
|
|
31
|
-
case "text":
|
|
32
|
-
return (jsx(Stack, { width: inline ? 300 : "100%", children: jsx(TextFilter, { option: option, value: (_a = value[option.key]) !== null && _a !== void 0 ? _a : null, onChange: (v) => {
|
|
33
|
-
onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
|
|
34
|
-
} }) }, index));
|
|
35
|
-
case "number":
|
|
36
|
-
return (jsx(Stack, { width: inline ? 300 : "100%", children: jsx(NumberFilter, { option: option, value: (_b = value[option.key]) !== null && _b !== void 0 ? _b : null, onChange: (v) => {
|
|
37
|
-
onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
|
|
38
|
-
} }) }, index));
|
|
39
|
-
case "number-range":
|
|
40
|
-
return (jsx(Stack, { width: inline ? 300 : "100%", children: jsx(NumberRangeFilter, { option: option, value: (_c = value[option.key]) !== null && _c !== void 0 ? _c : null, onChange: (v) => {
|
|
41
|
-
onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
|
|
42
|
-
} }) }, index));
|
|
43
|
-
case "select":
|
|
44
|
-
return (jsx(Stack, { width: inline ? 300 : "100%", children: jsx(SelectFilter, { option: option, value: (_d = value[option.key]) !== null && _d !== void 0 ? _d : null, onChange: (v) => {
|
|
45
|
-
onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
|
|
46
|
-
} }) }, index));
|
|
47
|
-
case "multi-select":
|
|
48
|
-
return (jsx(Stack, { width: inline ? 300 : "100%", children: jsx(MultiSelectFilter, { option: option, value: (_e = value[option.key]) !== null && _e !== void 0 ? _e : [], onChange: (v) => {
|
|
49
|
-
onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
|
|
50
|
-
} }) }, index));
|
|
51
|
-
case "date":
|
|
52
|
-
return (jsx(Stack, { width: inline ? 300 : "100%", children: jsx(DateFilter, { option: option, value: (_f = value[option.key]) !== null && _f !== void 0 ? _f : null, onChange: (v) => {
|
|
53
|
-
onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
|
|
54
|
-
} }) }, index));
|
|
55
|
-
case "date-range":
|
|
56
|
-
return (jsx(Stack, { width: inline ? 300 : "100%", children: jsx(DateRangeFilter, { option: option, value: (_g = value[option.key]) !== null && _g !== void 0 ? _g : null, onChange: (v) => {
|
|
57
|
-
onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
|
|
58
|
-
} }) }, index));
|
|
59
|
-
default:
|
|
60
|
-
return null;
|
|
61
|
-
}
|
|
62
|
-
}) })));
|
|
63
|
-
};
|
|
64
|
-
var DataFilter$1 = React.forwardRef(DataFilter);
|
|
65
|
-
|
|
66
|
-
export { DateFilter, DateRangeFilter, MultiSelectFilter, NumberFilter, NumberRangeFilter, SelectFilter, TextFilter, DataFilter$1 as default };
|
|
67
|
-
//# sourceMappingURL=index.mjs.map
|
package/DataFilter/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../src/DataFilter/index.tsx"],"sourcesContent":["\"use client\"\r\nimport Stack from '../Stack'\r\nimport { DataFilterProps } from './types'\r\nimport SelectFilter from './options/SelectFilter'\r\nimport MultiSelectFilter from './options/MultiSelectFilter'\r\nimport NumberFilter from './options/NumberFilter'\r\nimport TextFilter from './options/TextFilter'\r\nimport NumberRangeFilter from './options/NumberRangeFilter'\r\nimport DateFilter from './options/DateFilter'\r\nimport DateRangeFilter from './options/DateRangeFilter'\r\nimport React from 'react'\r\nimport { Tag } from '@xanui/core'\r\n\r\nexport {\r\n SelectFilter,\r\n MultiSelectFilter,\r\n NumberFilter,\r\n TextFilter,\r\n NumberRangeFilter,\r\n DateFilter,\r\n DateRangeFilter,\r\n}\r\n\r\nexport * from './types'\r\n\r\nconst DataFilter = ({ inline, options, onChange, value, ...props }: DataFilterProps, ref: React.Ref<HTMLDivElement>) => {\r\n inline ??= false\r\n value ??= {}\r\n onChange ??= () => { }\r\n\r\n return (\r\n <Tag\r\n {...props}\r\n sxr={{\r\n flexBox: true,\r\n flexDirection: inline ? 'row' : 'column',\r\n alignItems: inline ? 'center' : 'stretch',\r\n flexWrap: inline ? 'wrap' : 'nowrap',\r\n gap: 1,\r\n p: 2,\r\n radius: 1,\r\n }}\r\n baseClass='data-filter'\r\n ref={ref}\r\n >\r\n {\r\n options.map((option, index) => {\r\n switch (option.type) {\r\n case \"text\":\r\n return (<Stack\r\n width={inline ? 300 : \"100%\"}\r\n key={index}\r\n >\r\n <TextFilter\r\n option={option as any}\r\n value={value[option.key] ?? null}\r\n onChange={(v) => {\r\n onChange({\r\n ...value,\r\n [option.key]: v\r\n })\r\n }}\r\n />\r\n </Stack>\r\n )\r\n case \"number\":\r\n return (<Stack\r\n width={inline ? 300 : \"100%\"}\r\n key={index}\r\n >\r\n <NumberFilter\r\n option={option as any}\r\n value={value[option.key] ?? null}\r\n onChange={(v) => {\r\n onChange({\r\n ...value,\r\n [option.key]: v\r\n })\r\n }}\r\n />\r\n </Stack>\r\n )\r\n case \"number-range\":\r\n return (<Stack\r\n width={inline ? 300 : \"100%\"}\r\n key={index}\r\n >\r\n <NumberRangeFilter\r\n option={option as any}\r\n value={value[option.key] ?? null}\r\n onChange={(v) => {\r\n onChange({\r\n ...value,\r\n [option.key]: v\r\n })\r\n }}\r\n />\r\n </Stack>\r\n )\r\n case \"select\":\r\n return (<Stack\r\n width={inline ? 300 : \"100%\"}\r\n key={index}\r\n >\r\n <SelectFilter\r\n option={option as any}\r\n value={value[option.key] ?? null}\r\n onChange={(v) => {\r\n onChange({\r\n ...value,\r\n [option.key]: v\r\n })\r\n }}\r\n />\r\n </Stack>\r\n )\r\n case \"multi-select\":\r\n return (<Stack\r\n width={inline ? 300 : \"100%\"}\r\n key={index}\r\n >\r\n <MultiSelectFilter\r\n option={option as any}\r\n value={value[option.key] ?? []}\r\n onChange={(v) => {\r\n onChange({\r\n ...value,\r\n [option.key]: v\r\n })\r\n }}\r\n />\r\n </Stack>\r\n )\r\n case \"date\":\r\n return (<Stack\r\n width={inline ? 300 : \"100%\"}\r\n key={index}\r\n >\r\n <DateFilter\r\n option={option as any}\r\n value={value[option.key] ?? null}\r\n onChange={(v) => {\r\n onChange({\r\n ...value,\r\n [option.key]: v\r\n })\r\n }}\r\n />\r\n </Stack>\r\n )\r\n case \"date-range\":\r\n return (<Stack\r\n width={inline ? 300 : \"100%\"}\r\n key={index}\r\n >\r\n <DateRangeFilter\r\n option={option as any}\r\n value={value[option.key] ?? null}\r\n onChange={(v) => {\r\n onChange({\r\n ...value,\r\n [option.key]: v\r\n })\r\n }}\r\n />\r\n </Stack>\r\n )\r\n default:\r\n return null\r\n\r\n }\r\n })\r\n }\r\n </Tag>\r\n )\r\n}\r\n\r\nexport default React.forwardRef(DataFilter);\r\n"],"names":[],"mappings":";;;;;;;;;;;;;;AAyBA;AAAoB;;;;AAKjB;AAIS;;;;AAIA;AACA;AACA;AACF;;AAMK;AACG;AACG;;AAYM;AAIT;AACG;;AAYM;AAIT;AACG;;AAYM;AAIT;AACG;;AAYM;AAIT;AACG;;AAYM;AAIT;AACG;;AAYM;AAIT;AACG;;AAYM;AAIT;AACG;;;AAOrB;AAEA;;"}
|
|
@@ -1,30 +0,0 @@
|
|
|
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 IconButton from '../../IconButton/index.mjs';
|
|
6
|
-
import Stack from '../../Stack/index.mjs';
|
|
7
|
-
import Text from '../../Text/index.mjs';
|
|
8
|
-
import Close from '@xanui/icons/Close';
|
|
9
|
-
import Add from '@xanui/icons/Add';
|
|
10
|
-
import ClearAll from '@xanui/icons/ClearAll';
|
|
11
|
-
import Chip from '../../Chip/index.mjs';
|
|
12
|
-
import Calendar from '../../Calendar/index.mjs';
|
|
13
|
-
|
|
14
|
-
const DateFilter = ({ option, onChange, value }) => {
|
|
15
|
-
const [target, setTarget] = React.useState();
|
|
16
|
-
const isValue = value !== null && value !== undefined && value !== "";
|
|
17
|
-
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: (e) => {
|
|
18
|
-
setTarget(e.currentTarget);
|
|
19
|
-
}, children: jsx(Add, {}) }), isValue && jsx(IconButton, { size: "small", variant: "soft", color: "danger", onClick: () => {
|
|
20
|
-
onChange(null);
|
|
21
|
-
}, children: jsx(ClearAll, {}) })] })] }), jsx(Stack, { direction: "row", gap: 0.5, flexWrap: "wrap", children: isValue && jsx(Chip, { size: "small", color: "default", label: new Date(value).toLocaleDateString("en-US"), endIcon: jsx(IconButton, { size: 16, variant: "text", color: "default", onClick: () => {
|
|
22
|
-
onChange(null);
|
|
23
|
-
}, children: jsx(Close, {}) }) }) }), jsx(Menu, { target: target, onClickOutside: () => setTarget(undefined), placement: "bottom-right", children: jsx(Calendar, { value: value ? new Date(value) : null, onChange: (date) => {
|
|
24
|
-
onChange((date === null || date === void 0 ? void 0 : date.toISOString()) || null);
|
|
25
|
-
setTarget(undefined);
|
|
26
|
-
} }) })] }));
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
export { DateFilter as default };
|
|
30
|
-
//# sourceMappingURL=DateFilter.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"DateFilter.mjs","sources":["../../../src/DataFilter/options/DateFilter.tsx"],"sourcesContent":["\"use client\"\r\n\r\nimport React from \"react\";\r\nimport { DataFilterDate } from \"../types\";\r\nimport Menu from \"../../Menu\";\r\nimport IconButton from \"../../IconButton\";\r\nimport Stack from \"../../Stack\";\r\nimport Text from \"../../Text\";\r\nimport Close from \"@xanui/icons/Close\";\r\nimport Add from \"@xanui/icons/Add\";\r\nimport ClearAll from \"@xanui/icons/ClearAll\";\r\nimport Chip from \"../../Chip\";\r\nimport Calendar from \"../../Calendar\";\r\n\r\n\r\ntype Props = {\r\n option: DataFilterDate;\r\n value: string | null;\r\n onChange: (value: string | null) => void;\r\n}\r\n\r\nconst DateFilter = ({ option, onChange, value }: Props) => {\r\n const [target, setTarget] = React.useState<HTMLElement | undefined>()\r\n const isValue = value !== null && value !== undefined && value !== \"\"\r\n\r\n return (\r\n <Stack\r\n width={\"100%\"}\r\n bgcolor=\"background.secondary\"\r\n p={1}\r\n radius={1}\r\n >\r\n <Stack\r\n direction=\"row\"\r\n alignItems=\"center\"\r\n justifyContent={\"space-between\"}\r\n gap={0.5}\r\n mb={isValue ? .5 : 0}\r\n >\r\n <Text>{option.label}</Text>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n >\r\n <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"default\"}\r\n onClick={(e: any) => {\r\n setTarget(e.currentTarget)\r\n }}\r\n >\r\n <Add />\r\n </IconButton>\r\n {\r\n isValue && <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"danger\"}\r\n onClick={() => {\r\n onChange(null);\r\n }}\r\n >\r\n <ClearAll />\r\n </IconButton>\r\n }\r\n </Stack>\r\n </Stack>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n flexWrap=\"wrap\"\r\n >\r\n {\r\n isValue && <Chip\r\n size=\"small\"\r\n color=\"default\"\r\n label={new Date(value).toLocaleDateString(\"en-US\")}\r\n endIcon={<IconButton\r\n size={16}\r\n variant={\"text\"}\r\n color=\"default\"\r\n onClick={() => {\r\n onChange(null);\r\n }}\r\n >\r\n <Close />\r\n </IconButton>}\r\n />\r\n }\r\n </Stack>\r\n <Menu\r\n target={target}\r\n onClickOutside={() => setTarget(undefined)}\r\n placement={\"bottom-right\"}\r\n >\r\n <Calendar\r\n value={value ? new Date(value) : null}\r\n onChange={(date) => {\r\n onChange(date?.toISOString() || null);\r\n setTarget(undefined);\r\n }}\r\n />\r\n </Menu>\r\n </Stack>\r\n )\r\n}\r\n\r\nexport default DateFilter"],"names":[],"mappings":";;;;;;;;;;;;;AAqBA;;AAEG;AAEA;AAwBkB;;;AAYA;;;AAsCH;;AAEH;AAKf;;"}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import { jsxs, jsx, Fragment } 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 CalenderInput from '../../CalendarInput/index.mjs';
|
|
9
|
-
|
|
10
|
-
const DateRangeFilter = ({ option, onChange, value }) => {
|
|
11
|
-
const isValue = value !== null && value !== undefined && value.length === 2;
|
|
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
|
-
const d = new Date();
|
|
14
|
-
onChange([d.toISOString(), d.toISOString()]);
|
|
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 && jsx(Fragment, { children: jsxs(Stack, { p: 1, gap: 1, width: "100%", children: [jsx(CalenderInput, { fullWidth: true, variant: "outline", value: value[0] ? new Date(value[0]) : null, onChange: (date) => {
|
|
18
|
-
onChange([date ? date.toISOString() : "", value ? value[1] : ""]);
|
|
19
|
-
} }), jsx(CalenderInput, { fullWidth: true, variant: "outline", value: value[1] ? new Date(value[1]) : null, onChange: (date) => {
|
|
20
|
-
onChange([value ? value[0] : "", date ? date.toISOString() : ""]);
|
|
21
|
-
} })] }) }) })] }));
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
export { DateRangeFilter as default };
|
|
25
|
-
//# sourceMappingURL=DateRangeFilter.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"DateRangeFilter.mjs","sources":["../../../src/DataFilter/options/DateRangeFilter.tsx"],"sourcesContent":["\"use client\"\r\n\r\nimport { DataFilterDate } from \"../types\";\r\nimport IconButton from \"../../IconButton\";\r\nimport Stack from \"../../Stack\";\r\nimport Text from \"../../Text\";\r\nimport Add from \"@xanui/icons/Add\";\r\nimport ClearAll from \"@xanui/icons/ClearAll\";\r\nimport CalenderInput from \"../../CalendarInput\";\r\n\r\n\r\ntype Props = {\r\n option: DataFilterDate;\r\n value: [string, string] | null;\r\n onChange: (value: [string, string] | null) => void;\r\n}\r\n\r\nconst DateRangeFilter = ({ option, onChange, value }: Props) => {\r\n const isValue = value !== null && value !== undefined && value.length === 2\r\n\r\n return (\r\n <Stack\r\n width={\"100%\"}\r\n bgcolor=\"background.secondary\"\r\n p={1}\r\n radius={1}\r\n >\r\n <Stack\r\n direction=\"row\"\r\n alignItems=\"center\"\r\n justifyContent={\"space-between\"}\r\n gap={0.5}\r\n mb={isValue ? .5 : 0}\r\n >\r\n <Text>{option.label}</Text>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n >\r\n <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"default\"}\r\n onClick={() => {\r\n const d = new Date();\r\n onChange([d.toISOString(), d.toISOString()]);\r\n }}\r\n >\r\n <Add />\r\n </IconButton>\r\n {\r\n isValue && <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"danger\"}\r\n onClick={() => {\r\n onChange(null);\r\n }}\r\n >\r\n <ClearAll />\r\n </IconButton>\r\n }\r\n </Stack>\r\n </Stack>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n flexWrap=\"wrap\"\r\n >\r\n {\r\n isValue && <>\r\n <Stack\r\n p={1}\r\n gap={1}\r\n width={\"100%\"}\r\n >\r\n <CalenderInput\r\n fullWidth\r\n variant={\"outline\"}\r\n value={value![0] ? new Date(value[0]) : null}\r\n onChange={(date) => {\r\n onChange([date ? date.toISOString() : \"\", value ? value[1] : \"\"])\r\n }}\r\n />\r\n\r\n <CalenderInput\r\n fullWidth\r\n variant={\"outline\"}\r\n value={value![1] ? new Date(value[1]) : null}\r\n onChange={(date) => {\r\n onChange([value ? value[0] : \"\", date ? date.toISOString() : \"\"])\r\n }}\r\n />\r\n </Stack>\r\n </>\r\n }\r\n </Stack>\r\n\r\n </Stack>\r\n )\r\n}\r\n\r\nexport default DateRangeFilter"],"names":[],"mappings":";;;;;;;;;AAiBA;AACG;AAEA;AAwBkB;AACA;;;AAYA;AAwBM;AACH;AAQG;AACH;AASxB;;"}
|
|
@@ -1,36 +0,0 @@
|
|
|
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 Add from '@xanui/icons/Add';
|
|
12
|
-
import ClearAll from '@xanui/icons/ClearAll';
|
|
13
|
-
import Chip from '../../Chip/index.mjs';
|
|
14
|
-
import Close from '@xanui/icons/Close';
|
|
15
|
-
|
|
16
|
-
const MultiSelectFilter = ({ option, onChange, value }) => {
|
|
17
|
-
var _a;
|
|
18
|
-
const ref = React.useRef(null);
|
|
19
|
-
const [target, setTarget] = React.useState();
|
|
20
|
-
const isValue = value && value.length > 0;
|
|
21
|
-
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: (e) => {
|
|
22
|
-
setTarget(e.currentTarget);
|
|
23
|
-
}, children: jsx(Add, {}) }), isValue && jsx(IconButton, { size: "small", variant: "soft", color: "danger", onClick: () => {
|
|
24
|
-
onChange([]);
|
|
25
|
-
}, children: jsx(ClearAll, {}) })] })] }), jsx(Stack, { direction: "row", gap: 0.5, flexWrap: "wrap", children: isValue && value.map((val, index) => {
|
|
26
|
-
return (jsx(Chip, { size: "small", color: "default", label: val, endIcon: jsx(IconButton, { size: 16, variant: "text", color: "default", onClick: () => {
|
|
27
|
-
onChange(value.filter(v => v !== val));
|
|
28
|
-
}, children: jsx(Close, {}) }) }, index));
|
|
29
|
-
}) }), 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 === null || value === void 0 ? void 0 : value.includes(opt.value) }), onClick: () => {
|
|
30
|
-
const has = value === null || value === void 0 ? void 0 : value.includes(opt.value);
|
|
31
|
-
onChange(has ? value === null || value === void 0 ? void 0 : value.filter(v => v !== opt.value) : [...value || [], opt.value]);
|
|
32
|
-
}, children: opt.label }, index))) }) })] }));
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
export { MultiSelectFilter as default };
|
|
36
|
-
//# sourceMappingURL=MultiSelectFilter.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MultiSelectFilter.mjs","sources":["../../../src/DataFilter/options/MultiSelectFilter.tsx"],"sourcesContent":["\"use client\"\r\n\r\nimport React from \"react\";\r\nimport { DataFilterSelect } from \"../types\";\r\nimport Menu from \"../../Menu\";\r\nimport List from \"../../List\";\r\nimport ListItem from \"../../ListItem\";\r\nimport Checkbox from \"../../Checkbox\";\r\nimport IconButton from \"../../IconButton\";\r\nimport Stack from \"../../Stack\";\r\nimport Text from \"../../Text\";\r\nimport Add from \"@xanui/icons/Add\";\r\nimport ClearAll from \"@xanui/icons/ClearAll\";\r\nimport Chip from \"../../Chip\";\r\nimport Close from \"@xanui/icons/Close\";\r\n\r\n\r\ntype Props = {\r\n option: DataFilterSelect;\r\n value: string[];\r\n onChange: (value: string[]) => void;\r\n}\r\n\r\nconst MultiSelectFilter = ({ option, onChange, value }: Props) => {\r\n const ref: any = React.useRef(null)\r\n const [target, setTarget] = React.useState<HTMLElement | undefined>()\r\n const isValue = value && value.length > 0;\r\n return (\r\n <Stack\r\n width={\"100%\"}\r\n bgcolor=\"background.secondary\"\r\n p={1}\r\n radius={1}\r\n >\r\n <Stack\r\n direction=\"row\"\r\n alignItems=\"center\"\r\n justifyContent={\"space-between\"}\r\n gap={0.5}\r\n mb={isValue ? .5 : 0}\r\n >\r\n <Text>{option.label}</Text>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n >\r\n <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"default\"}\r\n onClick={(e: any) => {\r\n setTarget(e.currentTarget)\r\n }}\r\n >\r\n <Add />\r\n </IconButton>\r\n {\r\n isValue && <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"danger\"}\r\n onClick={() => {\r\n onChange([]);\r\n }}\r\n >\r\n <ClearAll />\r\n </IconButton>\r\n }\r\n </Stack>\r\n </Stack>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n flexWrap=\"wrap\"\r\n >\r\n {\r\n isValue && value.map((val, index) => {\r\n return (\r\n <Chip\r\n key={index}\r\n size=\"small\"\r\n color=\"default\"\r\n label={val}\r\n endIcon={<IconButton\r\n size={16}\r\n variant={\"text\"}\r\n color=\"default\"\r\n onClick={() => {\r\n onChange(value.filter(v => v !== val));\r\n }}\r\n >\r\n <Close />\r\n </IconButton>}\r\n />\r\n )\r\n })\r\n }\r\n </Stack>\r\n <Menu\r\n target={target}\r\n onClickOutside={() => setTarget(undefined)}\r\n placement={\"bottom-right\"}\r\n >\r\n <List width={ref?.current?.offsetWidth || 200} size=\"small\">\r\n {\r\n option.options.map((opt, index) => (\r\n <ListItem\r\n key={index}\r\n startIcon={<Checkbox checked={value?.includes(opt.value)} />}\r\n onClick={() => {\r\n const has = value?.includes(opt.value)\r\n onChange(has ? value?.filter(v => v !== opt.value) : [...value || [], opt.value]);\r\n }}\r\n >\r\n {opt.label}\r\n </ListItem>\r\n ))\r\n }\r\n </List>\r\n </Menu>\r\n </Stack>\r\n )\r\n}\r\n\r\nexport default MultiSelectFilter"],"names":[],"mappings":";;;;;;;;;;;;;;;AAuBA;;;;;AAIG;AAwBkB;;;AAYA;AAcH;AAWY;;AAOf;AAeY;AACA;AACH;AAUxB;;"}
|
|
@@ -1,22 +0,0 @@
|
|
|
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 NumberFilter = ({ 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(0);
|
|
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(InputNumber, { variant: "outline", value: value.toString(), onChange: (e) => {
|
|
17
|
-
onChange(e.target.value);
|
|
18
|
-
}, fullWidth: true }) })] }));
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
export { NumberFilter as default };
|
|
22
|
-
//# sourceMappingURL=NumberFilter.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"NumberFilter.mjs","sources":["../../../src/DataFilter/options/NumberFilter.tsx"],"sourcesContent":["\"use client\"\r\n\r\nimport { DataFilterSelect } from \"../types\";\r\nimport IconButton from \"../../IconButton\";\r\nimport Stack from \"../../Stack\";\r\nimport Text from \"../../Text\";\r\nimport Add from \"@xanui/icons/Add\";\r\nimport ClearAll from \"@xanui/icons/ClearAll\";\r\nimport InputNumber from \"../../InputNumber\";\r\n\r\ntype Props = {\r\n option: DataFilterSelect;\r\n value: number | null;\r\n onChange: (value: number | null) => void;\r\n}\r\n\r\nconst NumberFilter = ({ option, onChange, value }: Props) => {\r\n\r\n const isValue = value !== null && value !== undefined;\r\n\r\n return (\r\n <Stack\r\n width={\"100%\"}\r\n bgcolor=\"background.secondary\"\r\n p={1}\r\n radius={1}\r\n >\r\n <Stack\r\n direction=\"row\"\r\n alignItems=\"center\"\r\n justifyContent={\"space-between\"}\r\n gap={0.5}\r\n mb={isValue ? .5 : 0}\r\n >\r\n <Text>{option.label}</Text>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n >\r\n <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"default\"}\r\n onClick={() => {\r\n onChange(0);\r\n }}\r\n >\r\n <Add />\r\n </IconButton>\r\n {\r\n isValue && <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"danger\"}\r\n onClick={() => {\r\n onChange(null);\r\n }}\r\n >\r\n <ClearAll />\r\n </IconButton>\r\n }\r\n </Stack>\r\n </Stack>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n flexWrap=\"wrap\"\r\n >\r\n {\r\n isValue && <InputNumber\r\n variant={\"outline\"}\r\n value={value.toString()}\r\n onChange={(e: any) => {\r\n onChange(e.target.value);\r\n }}\r\n fullWidth\r\n />\r\n }\r\n </Stack>\r\n </Stack>\r\n )\r\n}\r\n\r\nexport default NumberFilter"],"names":[],"mappings":";;;;;;;;;AAgBA;;AAIG;;;;;AAqDkB;AACH;AAOlB;;"}
|
|
@@ -1,27 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"NumberRangeFilter.mjs","sources":["../../../src/DataFilter/options/NumberRangeFilter.tsx"],"sourcesContent":["\"use client\"\r\n\r\nimport { DataFilterSelect } from \"../types\";\r\nimport IconButton from \"../../IconButton\";\r\nimport Stack from \"../../Stack\";\r\nimport Text from \"../../Text\";\r\nimport Add from \"@xanui/icons/Add\";\r\nimport ClearAll from \"@xanui/icons/ClearAll\";\r\nimport InputNumber from \"../../InputNumber\";\r\n\r\ntype Props = {\r\n option: DataFilterSelect;\r\n value: [number, number] | null;\r\n onChange: (value: [number, number] | null) => void;\r\n}\r\n\r\nconst NumberRangeFilter = ({ option, onChange, value }: Props) => {\r\n\r\n const isValue = value !== null && value !== undefined && Array.isArray(value) && value.length === 2;\r\n\r\n return (\r\n <Stack\r\n width={\"100%\"}\r\n bgcolor=\"background.secondary\"\r\n p={1}\r\n radius={1}\r\n >\r\n <Stack\r\n direction=\"row\"\r\n alignItems=\"center\"\r\n justifyContent={\"space-between\"}\r\n gap={0.5}\r\n mb={isValue ? .5 : 0}\r\n >\r\n <Text>{option.label}</Text>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n >\r\n <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"default\"}\r\n onClick={() => {\r\n onChange([0, 0]);\r\n }}\r\n >\r\n <Add />\r\n </IconButton>\r\n {\r\n isValue && <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"danger\"}\r\n onClick={() => {\r\n onChange(null);\r\n }}\r\n >\r\n <ClearAll />\r\n </IconButton>\r\n }\r\n </Stack>\r\n </Stack>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n flexWrap=\"wrap\"\r\n >\r\n {\r\n isValue && <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n flex={1}\r\n >\r\n <InputNumber\r\n flex={1}\r\n variant={\"outline\"}\r\n size=\"small\"\r\n placeholder=\"Min\"\r\n value={value[0] as any ?? ''}\r\n onChange={(e) => {\r\n const val = e.target.value === '' ? 0 : Number(e.target.value);\r\n onChange([val, value ? value[1] : 0]);\r\n }}\r\n />\r\n <InputNumber\r\n variant={\"outline\"}\r\n flex={1}\r\n size=\"small\"\r\n placeholder=\"Max\"\r\n value={value[1] as any ?? undefined}\r\n onChange={(e) => {\r\n const val = e.target.value === '' ? 0 : Number(e.target.value);\r\n onChange([value ? value[0] : 0, val]);\r\n }}\r\n />\r\n </Stack>\r\n }\r\n </Stack>\r\n </Stack>\r\n )\r\n}\r\n\r\nexport default NumberRangeFilter"],"names":[],"mappings":";;;;;;;;;AAgBA;;;AAIG;AAwBkB;;;AAYA;;AA0BG;AACH;;AAUG;AACH;AAOrB;;"}
|
|
@@ -1,32 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SelectFilter.mjs","sources":["../../../src/DataFilter/options/SelectFilter.tsx"],"sourcesContent":["\"use client\"\r\n\r\nimport React from \"react\";\r\nimport { DataFilterSelect } from \"../types\";\r\nimport Menu from \"../../Menu\";\r\nimport List from \"../../List\";\r\nimport ListItem from \"../../ListItem\";\r\nimport Checkbox from \"../../Checkbox\";\r\nimport IconButton from \"../../IconButton\";\r\nimport Stack from \"../../Stack\";\r\nimport Text from \"../../Text\";\r\nimport Close from \"@xanui/icons/Close\";\r\nimport Add from \"@xanui/icons/Add\";\r\nimport ClearAll from \"@xanui/icons/ClearAll\";\r\nimport Chip from \"../../Chip\";\r\n\r\n\r\ntype Props = {\r\n option: DataFilterSelect;\r\n value: string | null;\r\n onChange: (value: string | null) => void;\r\n}\r\n\r\nconst SelectFilter = ({ option, onChange, value }: Props) => {\r\n const ref: any = React.useRef(null)\r\n const [target, setTarget] = React.useState<HTMLElement | undefined>()\r\n return (\r\n <Stack\r\n width={\"100%\"}\r\n bgcolor=\"background.secondary\"\r\n p={1}\r\n radius={1}\r\n >\r\n <Stack\r\n direction=\"row\"\r\n alignItems=\"center\"\r\n justifyContent={\"space-between\"}\r\n gap={0.5}\r\n mb={value ? .5 : 0}\r\n >\r\n <Text>{option.label}</Text>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n >\r\n <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"default\"}\r\n onClick={(e: any) => {\r\n setTarget(e.currentTarget)\r\n }}\r\n >\r\n <Add />\r\n </IconButton>\r\n {\r\n !!value && <IconButton\r\n size=\"small\"\r\n variant=\"soft\"\r\n color={\"danger\"}\r\n onClick={() => {\r\n onChange(null);\r\n }}\r\n >\r\n <ClearAll />\r\n </IconButton>\r\n }\r\n </Stack>\r\n </Stack>\r\n <Stack\r\n direction=\"row\"\r\n gap={0.5}\r\n flexWrap=\"wrap\"\r\n >\r\n {\r\n !!value && <Chip\r\n size=\"small\"\r\n color=\"default\"\r\n label={value}\r\n endIcon={<IconButton\r\n size={16}\r\n variant={\"text\"}\r\n color=\"default\"\r\n onClick={() => {\r\n onChange(null);\r\n }}\r\n >\r\n <Close />\r\n </IconButton>}\r\n />\r\n }\r\n </Stack>\r\n <Menu\r\n target={target}\r\n onClickOutside={() => setTarget(undefined)}\r\n placement={\"bottom-right\"}\r\n >\r\n <List width={ref?.current?.offsetWidth || 200} size=\"small\">\r\n {\r\n option.options.map((opt, index) => (\r\n <ListItem\r\n key={index}\r\n startIcon={<Checkbox checked={value === opt.value} />}\r\n onClick={() => {\r\n onChange(opt.value);\r\n }}\r\n >\r\n {opt.label}\r\n </ListItem>\r\n ))\r\n }\r\n </List>\r\n </Menu>\r\n </Stack>\r\n )\r\n}\r\n\r\nexport default SelectFilter"],"names":[],"mappings":";;;;;;;;;;;;;;;AAuBA;;;;AAGG;AAwBkB;AACH;;AAWG;;AAuBA;AAmBM;AACH;AAUxB;;"}
|