@xanui/ui 1.1.35 → 1.1.37

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 (156) hide show
  1. package/DataFilter/index.js +3 -3
  2. package/package.json +4 -4
  3. package/Accordion/index.mjs +0 -94
  4. package/Accordion/index.mjs.map +0 -1
  5. package/Alert/index.mjs +0 -119
  6. package/Alert/index.mjs.map +0 -1
  7. package/Autocomplete/index.mjs +0 -134
  8. package/Autocomplete/index.mjs.map +0 -1
  9. package/Avatar/index.mjs +0 -48
  10. package/Avatar/index.mjs.map +0 -1
  11. package/Badge/index.mjs +0 -107
  12. package/Badge/index.mjs.map +0 -1
  13. package/Box/index.mjs +0 -12
  14. package/Box/index.mjs.map +0 -1
  15. package/Button/index.mjs +0 -92
  16. package/Button/index.mjs.map +0 -1
  17. package/ButtonGroup/index.mjs +0 -56
  18. package/ButtonGroup/index.mjs.map +0 -1
  19. package/Calendar/index.mjs +0 -172
  20. package/Calendar/index.mjs.map +0 -1
  21. package/CalendarInput/index.mjs +0 -32
  22. package/CalendarInput/index.mjs.map +0 -1
  23. package/Checkbox/index.mjs +0 -56
  24. package/Checkbox/index.mjs.map +0 -1
  25. package/Chip/index.mjs +0 -74
  26. package/Chip/index.mjs.map +0 -1
  27. package/CircleProgress/index.mjs +0 -127
  28. package/CircleProgress/index.mjs.map +0 -1
  29. package/ClickOutside/index.mjs +0 -35
  30. package/ClickOutside/index.mjs.map +0 -1
  31. package/Collaps/index.mjs +0 -24
  32. package/Collaps/index.mjs.map +0 -1
  33. package/Container/index.mjs +0 -27
  34. package/Container/index.mjs.map +0 -1
  35. package/DataFilter/index.mjs +0 -67
  36. package/DataFilter/index.mjs.map +0 -1
  37. package/DataFilter/options/DateFilter.mjs +0 -30
  38. package/DataFilter/options/DateFilter.mjs.map +0 -1
  39. package/DataFilter/options/DateRangeFilter.mjs +0 -25
  40. package/DataFilter/options/DateRangeFilter.mjs.map +0 -1
  41. package/DataFilter/options/MultiSelectFilter.mjs +0 -36
  42. package/DataFilter/options/MultiSelectFilter.mjs.map +0 -1
  43. package/DataFilter/options/NumberFilter.mjs +0 -22
  44. package/DataFilter/options/NumberFilter.mjs.map +0 -1
  45. package/DataFilter/options/NumberRangeFilter.mjs +0 -27
  46. package/DataFilter/options/NumberRangeFilter.mjs.map +0 -1
  47. package/DataFilter/options/SelectFilter.mjs +0 -32
  48. package/DataFilter/options/SelectFilter.mjs.map +0 -1
  49. package/DataFilter/options/TextFilter.mjs +0 -22
  50. package/DataFilter/options/TextFilter.mjs.map +0 -1
  51. package/Datatable/FilterBox.mjs +0 -37
  52. package/Datatable/FilterBox.mjs.map +0 -1
  53. package/Datatable/Row.mjs +0 -57
  54. package/Datatable/Row.mjs.map +0 -1
  55. package/Datatable/SelectedBox.mjs +0 -19
  56. package/Datatable/SelectedBox.mjs.map +0 -1
  57. package/Datatable/Table.mjs +0 -21
  58. package/Datatable/Table.mjs.map +0 -1
  59. package/Datatable/TableHead.mjs +0 -59
  60. package/Datatable/TableHead.mjs.map +0 -1
  61. package/Datatable/index.mjs +0 -91
  62. package/Datatable/index.mjs.map +0 -1
  63. package/Divider/index.mjs +0 -29
  64. package/Divider/index.mjs.map +0 -1
  65. package/Drawer/index.mjs +0 -76
  66. package/Drawer/index.mjs.map +0 -1
  67. package/Form/index.mjs +0 -43
  68. package/Form/index.mjs.map +0 -1
  69. package/GridContainer/index.mjs +0 -17
  70. package/GridContainer/index.mjs.map +0 -1
  71. package/GridItem/index.mjs +0 -18
  72. package/GridItem/index.mjs.map +0 -1
  73. package/IconButton/index.mjs +0 -62
  74. package/IconButton/index.mjs.map +0 -1
  75. package/Image/index.mjs +0 -25
  76. package/Image/index.mjs.map +0 -1
  77. package/Input/index.mjs +0 -142
  78. package/Input/index.mjs.map +0 -1
  79. package/InputNumber/index.mjs +0 -30
  80. package/InputNumber/index.mjs.map +0 -1
  81. package/Label/index.mjs +0 -22
  82. package/Label/index.mjs.map +0 -1
  83. package/Layer/index.mjs +0 -60
  84. package/Layer/index.mjs.map +0 -1
  85. package/LineProgress/index.mjs +0 -57
  86. package/LineProgress/index.mjs.map +0 -1
  87. package/List/ListContext.mjs +0 -8
  88. package/List/ListContext.mjs.map +0 -1
  89. package/List/index.mjs +0 -61
  90. package/List/index.mjs.map +0 -1
  91. package/ListItem/index.mjs +0 -52
  92. package/ListItem/index.mjs.map +0 -1
  93. package/LoadingBox/index.mjs +0 -30
  94. package/LoadingBox/index.mjs.map +0 -1
  95. package/Menu/index.mjs +0 -148
  96. package/Menu/index.mjs.map +0 -1
  97. package/Modal/index.mjs +0 -57
  98. package/Modal/index.mjs.map +0 -1
  99. package/NoSSR/index.mjs +0 -13
  100. package/NoSSR/index.mjs.map +0 -1
  101. package/Option/index.mjs +0 -12
  102. package/Option/index.mjs.map +0 -1
  103. package/Paper/index.mjs +0 -13
  104. package/Paper/index.mjs.map +0 -1
  105. package/Portal/index.mjs +0 -25
  106. package/Portal/index.mjs.map +0 -1
  107. package/Radio/index.mjs +0 -14
  108. package/Radio/index.mjs.map +0 -1
  109. package/Scrollbar/index.mjs +0 -57
  110. package/Scrollbar/index.mjs.map +0 -1
  111. package/Select/index.mjs +0 -57
  112. package/Select/index.mjs.map +0 -1
  113. package/Skeleton/index.mjs +0 -58
  114. package/Skeleton/index.mjs.map +0 -1
  115. package/Stack/index.mjs +0 -15
  116. package/Stack/index.mjs.map +0 -1
  117. package/Switch/index.mjs +0 -77
  118. package/Switch/index.mjs.map +0 -1
  119. package/Tab/index.mjs +0 -15
  120. package/Tab/index.mjs.map +0 -1
  121. package/Table/index.mjs +0 -86
  122. package/Table/index.mjs.map +0 -1
  123. package/TableBody/index.mjs +0 -12
  124. package/TableBody/index.mjs.map +0 -1
  125. package/TableCell/index.mjs +0 -12
  126. package/TableCell/index.mjs.map +0 -1
  127. package/TableFooter/index.mjs +0 -12
  128. package/TableFooter/index.mjs.map +0 -1
  129. package/TableHead/index.mjs +0 -12
  130. package/TableHead/index.mjs.map +0 -1
  131. package/TablePagination/index.mjs +0 -57
  132. package/TablePagination/index.mjs.map +0 -1
  133. package/TableRow/index.mjs +0 -12
  134. package/TableRow/index.mjs.map +0 -1
  135. package/Tabs/index.mjs +0 -199
  136. package/Tabs/index.mjs.map +0 -1
  137. package/Text/index.mjs +0 -23
  138. package/Text/index.mjs.map +0 -1
  139. package/Toast/index.mjs +0 -118
  140. package/Toast/index.mjs.map +0 -1
  141. package/Tooltip/index.mjs +0 -38
  142. package/Tooltip/index.mjs.map +0 -1
  143. package/ViewBox/index.mjs +0 -30
  144. package/ViewBox/index.mjs.map +0 -1
  145. package/index.mjs +0 -65
  146. package/index.mjs.map +0 -1
  147. package/useAlert/index.mjs +0 -92
  148. package/useAlert/index.mjs.map +0 -1
  149. package/useBlurCss/index.mjs +0 -17
  150. package/useBlurCss/index.mjs.map +0 -1
  151. package/useCorner/index.mjs +0 -20
  152. package/useCorner/index.mjs.map +0 -1
  153. package/useLayer/index.mjs +0 -36
  154. package/useLayer/index.mjs.map +0 -1
  155. package/useModal/index.mjs +0 -35
  156. package/useModal/index.mjs.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/Checkbox/index.tsx"],"sourcesContent":["\"use client\";\r\nimport React, { useState, ReactElement } from 'react';\r\nimport { Tag, useInterface, UseColorTemplateColor, TagProps, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport CheckIcon from '@xanui/icons/CheckBox'\r\nimport UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank'\r\nimport IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';\r\n\r\n\r\nexport type CheckboxProps = Omit<TagProps<\"input\">, \"color\" | \"size\" | \"component\" | \"type\" | \"checked\"> & {\r\n checkIcon?: useBreakpointPropsType<ReactElement>;\r\n uncheckIcon?: useBreakpointPropsType<ReactElement>;\r\n indeterminate?: useBreakpointPropsType<boolean>;\r\n checked?: boolean;\r\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n}\r\n\r\nconst Checkbox = React.forwardRef((props: CheckboxProps, ref?: React.Ref<any>) => {\r\n let [{ color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange, ...rest }] = useInterface<any>(\"Checkbox\", props, {})\r\n const _p: any = {}\r\n if (checkIcon) _p.checkIcon = checkIcon\r\n if (uncheckIcon) _p.uncheckIcon = uncheckIcon\r\n if (indeterminate) _p.indeterminate = indeterminate\r\n if (size) _p.size = size\r\n if (color) _p.color = color\r\n const p: any = useBreakpointProps(_p)\r\n\r\n checkIcon = p.checkIcon\r\n uncheckIcon = p.uncheckIcon\r\n indeterminate = p.indeterminate\r\n size = p.size\r\n color = p.color\r\n\r\n const [c, set] = useState(false)\r\n checked ??= c\r\n size ??= \"medium\"\r\n color ??= \"brand\"\r\n\r\n onChange = onChange || (() => set(!c));\r\n if (indeterminate) {\r\n checked = true\r\n checkIcon = <IndeterminateCheckBoxIcon />\r\n }\r\n\r\n let sizes: any = {\r\n small: 22,\r\n medium: 24,\r\n large: 32\r\n }\r\n\r\n if (typeof size === 'string' && sizes[size]) {\r\n size = sizes[size]\r\n }\r\n\r\n return (\r\n <>\r\n <Tag\r\n baseClass='checkbox'\r\n onClick={() => {\r\n onChange && onChange()\r\n }}\r\n sxr={{\r\n height: size,\r\n width: size,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n color: checked ? color : \"text.secondary\",\r\n cursor: \"pointer\",\r\n disabled: disabled,\r\n \"& svg\": {\r\n fontSize: size\r\n },\r\n ...rest?.sx\r\n }}\r\n >\r\n {checked ? (checkIcon || <CheckIcon />) : (uncheckIcon || <UnCheckIcon />)}\r\n </Tag>\r\n <Tag\r\n {...rest}\r\n component='input'\r\n ref={ref}\r\n readOnly\r\n type=\"checkbox\"\r\n checked={checked}\r\n sxr={{\r\n display: \"none!important\"\r\n }}\r\n />\r\n </>\r\n )\r\n})\r\n\r\nexport default Checkbox\r\n"],"names":[],"mappings":";;;;;;;;;AAiBA;AACI;;AAEA;AAAe;AACf;AAAiB;AACjB;AAAmB;AACnB;AAAU;AACV;AAAW;AACX;AAEA;AACA;AACA;AACA;AACA;;;;;AAOA;;;AAGI;;AAGJ;AACI;AACA;AACA;;;AAIA;;AAGJ;;;AAiBoB;;AAeJ;;AAKpB;;"}
package/Chip/index.mjs DELETED
@@ -1,74 +0,0 @@
1
- import { __rest } from 'tslib';
2
- import { jsxs, jsx } from 'react/jsx-runtime';
3
- import React from 'react';
4
- import { useInterface, useBreakpointProps, useColorTemplate, Tag } from '@xanui/core';
5
- import useCorner from '../useCorner/index.mjs';
6
-
7
- const Chip = React.forwardRef((props, ref) => {
8
- let [_a] = useInterface("Chip", props, {}), { label, variant, startIcon, endIcon, color, corner, size } = _a, rest = __rest(_a, ["label", "variant", "startIcon", "endIcon", "color", "corner", "size"]);
9
- const _p = {};
10
- if (label)
11
- _p.label = label;
12
- if (startIcon)
13
- _p.startIcon = startIcon;
14
- if (endIcon)
15
- _p.endIcon = endIcon;
16
- if (color)
17
- _p.color = color;
18
- if (variant)
19
- _p.variant = variant;
20
- if (corner)
21
- _p.corner = corner;
22
- if (size)
23
- _p.size = size;
24
- const p = useBreakpointProps(_p);
25
- label = p.label;
26
- startIcon = p.startIcon;
27
- endIcon = p.endIcon;
28
- color = p.color || "brand";
29
- variant = p.variant || "fill";
30
- corner = p.corner || "circle";
31
- size = p.size || "medium";
32
- rest.sx = rest.sx || {};
33
- const cornerCss = useCorner(corner);
34
- const template = useColorTemplate(color, variant);
35
- const sizes = {
36
- small: {
37
- height: 24,
38
- gap: .5,
39
- px: startIcon || endIcon ? .8 : 1,
40
- fontSize: "small"
41
- },
42
- medium: {
43
- height: 32,
44
- gap: 1,
45
- px: startIcon || endIcon ? .8 : 1.5,
46
- fontSize: 'button',
47
- },
48
- large: {
49
- height: 40,
50
- fontSize: 'text',
51
- gap: 1,
52
- px: startIcon || endIcon ? .8 : 1.5,
53
- }
54
- };
55
- return (jsxs(Tag, Object.assign({}, cornerCss, template.primary, (sizes[size] || {}), rest, { sxr: {
56
- display: "inline-flex",
57
- flexDirection: "row",
58
- alignItems: "center",
59
- transition: "background .3s",
60
- overflow: "hidden",
61
- "& > *": {
62
- flex: "0 0 auto",
63
- textOverflow: "ellipsis",
64
- whiteSpace: "nowrap",
65
- overflow: "hidden",
66
- },
67
- }, baseClass: 'chip', ref: ref, children: [startIcon, jsx(Tag, { sxr: {
68
- alignItems: "center",
69
- flexBox: true
70
- }, children: label }), endIcon] })));
71
- });
72
-
73
- export { Chip as default };
74
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/Chip/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\r\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, UseColorTemplateColor, UseColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport useCorner, { UseCornerTypes } from '../useCorner'\r\n\r\n\r\n\r\nexport type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, \"color\" | \"children\" | \"size\"> & {\r\n label: useBreakpointPropsType<string | ReactElement>;\r\n startIcon?: useBreakpointPropsType<ReactElement>;\r\n endIcon?: useBreakpointPropsType<ReactElement>;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n corner?: useBreakpointPropsType<UseCornerTypes>;\r\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\r\n}\r\n\r\n\r\nconst Chip = React.forwardRef(<T extends TagComponentType = 'div'>(props: ChipProps<T>, ref: React.Ref<any>) => {\r\n let [{ label, variant, startIcon, endIcon, color, corner, size, ...rest }] = useInterface<any>(\"Chip\", props, {})\r\n const _p: any = {}\r\n if (label) _p.label = label\r\n if (startIcon) _p.startIcon = startIcon\r\n if (endIcon) _p.endIcon = endIcon\r\n if (color) _p.color = color\r\n if (variant) _p.variant = variant\r\n if (corner) _p.corner = corner\r\n if (size) _p.size = size\r\n const p: any = useBreakpointProps(_p)\r\n\r\n label = p.label\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n color = p.color || \"brand\"\r\n variant = p.variant || \"fill\"\r\n corner = p.corner || \"circle\"\r\n size = p.size || \"medium\"\r\n rest.sx = (rest as any).sx || {};\r\n\r\n const cornerCss = useCorner(corner)\r\n const template = useColorTemplate(color, variant)\r\n\r\n const sizes: any = {\r\n small: {\r\n height: 24,\r\n gap: .5,\r\n px: startIcon || endIcon ? .8 : 1,\r\n fontSize: \"small\"\r\n },\r\n medium: {\r\n height: 32,\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n fontSize: 'button',\r\n },\r\n large: {\r\n height: 40,\r\n fontSize: 'text',\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n }\r\n }\r\n\r\n return (\r\n <Tag\r\n {...cornerCss}\r\n {...template.primary}\r\n {...(sizes[size as any] || {})}\r\n {...rest}\r\n sxr={{\r\n display: \"inline-flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n transition: \"background .3s\",\r\n overflow: \"hidden\",\r\n\r\n \"& > *\": {\r\n flex: \"0 0 auto\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n overflow: \"hidden\",\r\n },\r\n }}\r\n baseClass='chip'\r\n ref={ref}\r\n >\r\n {startIcon}\r\n <Tag\r\n sxr={{\r\n alignItems: \"center\",\r\n flexBox: true\r\n }}\r\n >{label}</Tag>\r\n {endIcon}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default Chip\r\n"],"names":["_jsxs","_jsx"],"mappings":";;;;;;AAiBA,MAAM,IAAI,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,KAAmB,EAAE,GAAmB,KAAI;AAC3G,IAAA,IAAI,CAAA,EAAA,CAAA,GAAyE,YAAY,CAAM,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,EAA5G,EAAE,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAA,GAAA,EAAW,EAAN,IAAI,GAAA,MAAA,CAAA,EAAA,EAAlE,CAAA,OAAA,EAAA,SAAA,EAAA,WAAA,EAAA,SAAA,EAAA,OAAA,EAAA,QAAA,EAAA,MAAA,CAAoE,CAAwC;IACjH,MAAM,EAAE,GAAQ,EAAE;AAClB,IAAA,IAAI,KAAK;AAAE,QAAA,EAAE,CAAC,KAAK,GAAG,KAAK;AAC3B,IAAA,IAAI,SAAS;AAAE,QAAA,EAAE,CAAC,SAAS,GAAG,SAAS;AACvC,IAAA,IAAI,OAAO;AAAE,QAAA,EAAE,CAAC,OAAO,GAAG,OAAO;AACjC,IAAA,IAAI,KAAK;AAAE,QAAA,EAAE,CAAC,KAAK,GAAG,KAAK;AAC3B,IAAA,IAAI,OAAO;AAAE,QAAA,EAAE,CAAC,OAAO,GAAG,OAAO;AACjC,IAAA,IAAI,MAAM;AAAE,QAAA,EAAE,CAAC,MAAM,GAAG,MAAM;AAC9B,IAAA,IAAI,IAAI;AAAE,QAAA,EAAE,CAAC,IAAI,GAAG,IAAI;AACxB,IAAA,MAAM,CAAC,GAAQ,kBAAkB,CAAC,EAAE,CAAC;AAErC,IAAA,KAAK,GAAG,CAAC,CAAC,KAAK;AACf,IAAA,SAAS,GAAG,CAAC,CAAC,SAAS;AACvB,IAAA,OAAO,GAAG,CAAC,CAAC,OAAO;AACnB,IAAA,KAAK,GAAG,CAAC,CAAC,KAAK,IAAI,OAAO;AAC1B,IAAA,OAAO,GAAG,CAAC,CAAC,OAAO,IAAI,MAAM;AAC7B,IAAA,MAAM,GAAG,CAAC,CAAC,MAAM,IAAI,QAAQ;AAC7B,IAAA,IAAI,GAAG,CAAC,CAAC,IAAI,IAAI,QAAQ;IACzB,IAAI,CAAC,EAAE,GAAI,IAAY,CAAC,EAAE,IAAI,EAAE;AAEhC,IAAA,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC;IACnC,MAAM,QAAQ,GAAG,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC;AAEjD,IAAA,MAAM,KAAK,GAAQ;AACf,QAAA,KAAK,EAAE;AACH,YAAA,MAAM,EAAE,EAAE;AACV,YAAA,GAAG,EAAE,EAAE;YACP,EAAE,EAAE,SAAS,IAAI,OAAO,GAAG,EAAE,GAAG,CAAC;AACjC,YAAA,QAAQ,EAAE;AACb,SAAA;AACD,QAAA,MAAM,EAAE;AACJ,YAAA,MAAM,EAAE,EAAE;AACV,YAAA,GAAG,EAAE,CAAC;YACN,EAAE,EAAE,SAAS,IAAI,OAAO,GAAG,EAAE,GAAG,GAAG;AACnC,YAAA,QAAQ,EAAE,QAAQ;AACrB,SAAA;AACD,QAAA,KAAK,EAAE;AACH,YAAA,MAAM,EAAE,EAAE;AACV,YAAA,QAAQ,EAAE,MAAM;AAChB,YAAA,GAAG,EAAE,CAAC;YACN,EAAE,EAAE,SAAS,IAAI,OAAO,GAAG,EAAE,GAAG,GAAG;AACtC;KACJ;IAED,QACIA,KAAC,GAAG,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACI,SAAS,EACT,QAAQ,CAAC,OAAO,GACf,KAAK,CAAC,IAAW,CAAC,IAAI,EAAE,GACzB,IAAI,EAAA,EACR,GAAG,EAAE;AACD,YAAA,OAAO,EAAE,aAAa;AACtB,YAAA,aAAa,EAAE,KAAK;AACpB,YAAA,UAAU,EAAE,QAAQ;AACpB,YAAA,UAAU,EAAE,gBAAgB;AAC5B,YAAA,QAAQ,EAAE,QAAQ;AAElB,YAAA,QAAQ,EAAE;AACN,gBAAA,IAAI,EAAE,UAAU;AAChB,gBAAA,YAAY,EAAE,UAAU;AACxB,gBAAA,UAAU,EAAE,QAAQ;AACpB,gBAAA,QAAQ,EAAE,QAAQ;AACrB,aAAA;AACJ,SAAA,EACD,SAAS,EAAC,MAAM,EAChB,GAAG,EAAE,GAAG,EAAA,QAAA,EAAA,CAEP,SAAS,EACVC,GAAA,CAAC,GAAG,EAAA,EACA,GAAG,EAAE;AACD,oBAAA,UAAU,EAAE,QAAQ;AACpB,oBAAA,OAAO,EAAE;AACZ,iBAAA,EAAA,QAAA,EACH,KAAK,EAAA,CAAO,EACb,OAAO,CAAA,EAAA,CAAA,CACN;AAEd,CAAC;;;;"}
@@ -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;;"}
@@ -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
@@ -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;;;;"}
@@ -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
@@ -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;;;;"}
@@ -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
@@ -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;;"}