@xanui/ui 1.1.37 → 1.1.40

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 (310) hide show
  1. package/Accordion/index.cjs +96 -0
  2. package/Accordion/index.cjs.map +1 -0
  3. package/Accordion/index.js +19 -21
  4. package/Accordion/index.js.map +1 -1
  5. package/Alert/index.cjs +121 -0
  6. package/Alert/index.cjs.map +1 -0
  7. package/Alert/index.js +33 -35
  8. package/Alert/index.js.map +1 -1
  9. package/Autocomplete/index.cjs +136 -0
  10. package/Autocomplete/index.cjs.map +1 -0
  11. package/Autocomplete/index.js +23 -25
  12. package/Autocomplete/index.js.map +1 -1
  13. package/Avatar/index.cjs +50 -0
  14. package/Avatar/index.cjs.map +1 -0
  15. package/Avatar/index.js +15 -17
  16. package/Avatar/index.js.map +1 -1
  17. package/Badge/index.cjs +109 -0
  18. package/Badge/index.cjs.map +1 -0
  19. package/Badge/index.js +12 -14
  20. package/Badge/index.js.map +1 -1
  21. package/Box/index.cjs +14 -0
  22. package/Box/index.cjs.map +1 -0
  23. package/Box/index.js +7 -9
  24. package/Box/index.js.map +1 -1
  25. package/Button/index.cjs +94 -0
  26. package/Button/index.cjs.map +1 -0
  27. package/Button/index.js +17 -19
  28. package/Button/index.js.map +1 -1
  29. package/ButtonGroup/index.cjs +58 -0
  30. package/ButtonGroup/index.cjs.map +1 -0
  31. package/ButtonGroup/index.js +12 -14
  32. package/ButtonGroup/index.js.map +1 -1
  33. package/Calendar/index.cjs +174 -0
  34. package/Calendar/index.cjs.map +1 -0
  35. package/Calendar/index.js +39 -41
  36. package/Calendar/index.js.map +1 -1
  37. package/CalendarInput/index.cjs +34 -0
  38. package/CalendarInput/index.cjs.map +1 -0
  39. package/CalendarInput/index.js +19 -21
  40. package/CalendarInput/index.js.map +1 -1
  41. package/Checkbox/index.cjs +58 -0
  42. package/Checkbox/index.cjs.map +1 -0
  43. package/Checkbox/index.js +14 -16
  44. package/Checkbox/index.js.map +1 -1
  45. package/Chip/index.cjs +76 -0
  46. package/Chip/index.cjs.map +1 -0
  47. package/Chip/index.js +12 -14
  48. package/Chip/index.js.map +1 -1
  49. package/CircleProgress/index.cjs +129 -0
  50. package/CircleProgress/index.cjs.map +1 -0
  51. package/CircleProgress/index.js +13 -15
  52. package/CircleProgress/index.js.map +1 -1
  53. package/ClickOutside/index.cjs +37 -0
  54. package/ClickOutside/index.cjs.map +1 -0
  55. package/ClickOutside/index.js +9 -11
  56. package/ClickOutside/index.js.map +1 -1
  57. package/Collaps/index.cjs +26 -0
  58. package/Collaps/index.cjs.map +1 -0
  59. package/Collaps/index.js +9 -11
  60. package/Collaps/index.js.map +1 -1
  61. package/Container/index.cjs +29 -0
  62. package/Container/index.cjs.map +1 -0
  63. package/Container/index.js +9 -11
  64. package/Container/index.js.map +1 -1
  65. package/DataFilter/index.cjs +78 -0
  66. package/DataFilter/index.cjs.map +1 -0
  67. package/DataFilter/index.js +30 -41
  68. package/DataFilter/index.js.map +1 -1
  69. package/DataFilter/options/DateFilter.cjs +32 -0
  70. package/DataFilter/options/DateFilter.cjs.map +1 -0
  71. package/DataFilter/options/DateFilter.js +16 -18
  72. package/DataFilter/options/DateFilter.js.map +1 -1
  73. package/DataFilter/options/DateRangeFilter.cjs +27 -0
  74. package/DataFilter/options/DateRangeFilter.cjs.map +1 -0
  75. package/DataFilter/options/DateRangeFilter.js +12 -14
  76. package/DataFilter/options/DateRangeFilter.js.map +1 -1
  77. package/DataFilter/options/MultiSelectFilter.cjs +38 -0
  78. package/DataFilter/options/MultiSelectFilter.cjs.map +1 -0
  79. package/DataFilter/options/MultiSelectFilter.js +20 -22
  80. package/DataFilter/options/MultiSelectFilter.js.map +1 -1
  81. package/DataFilter/options/NumberFilter.cjs +24 -0
  82. package/DataFilter/options/NumberFilter.cjs.map +1 -0
  83. package/DataFilter/options/NumberFilter.js +11 -13
  84. package/DataFilter/options/NumberFilter.js.map +1 -1
  85. package/DataFilter/options/NumberRangeFilter.cjs +29 -0
  86. package/DataFilter/options/NumberRangeFilter.cjs.map +1 -0
  87. package/DataFilter/options/NumberRangeFilter.js +12 -14
  88. package/DataFilter/options/NumberRangeFilter.js.map +1 -1
  89. package/DataFilter/options/SelectFilter.cjs +34 -0
  90. package/DataFilter/options/SelectFilter.cjs.map +1 -0
  91. package/DataFilter/options/SelectFilter.js +18 -20
  92. package/DataFilter/options/SelectFilter.js.map +1 -1
  93. package/DataFilter/options/TextFilter.cjs +24 -0
  94. package/DataFilter/options/TextFilter.cjs.map +1 -0
  95. package/DataFilter/options/TextFilter.js +11 -13
  96. package/DataFilter/options/TextFilter.js.map +1 -1
  97. package/Datatable/FilterBox.cjs +39 -0
  98. package/Datatable/FilterBox.cjs.map +1 -0
  99. package/Datatable/FilterBox.js +21 -23
  100. package/Datatable/FilterBox.js.map +1 -1
  101. package/Datatable/Row.cjs +59 -0
  102. package/Datatable/Row.cjs.map +1 -0
  103. package/Datatable/Row.js +19 -21
  104. package/Datatable/Row.js.map +1 -1
  105. package/Datatable/SelectedBox.cjs +21 -0
  106. package/Datatable/SelectedBox.cjs.map +1 -0
  107. package/Datatable/SelectedBox.js +10 -12
  108. package/Datatable/SelectedBox.js.map +1 -1
  109. package/Datatable/Table.cjs +23 -0
  110. package/Datatable/Table.cjs.map +1 -0
  111. package/Datatable/Table.js +8 -10
  112. package/Datatable/Table.js.map +1 -1
  113. package/Datatable/TableHead.cjs +61 -0
  114. package/Datatable/TableHead.cjs.map +1 -0
  115. package/Datatable/TableHead.js +18 -20
  116. package/Datatable/TableHead.js.map +1 -1
  117. package/Datatable/index.cjs +93 -0
  118. package/Datatable/index.cjs.map +1 -0
  119. package/Datatable/index.js +21 -23
  120. package/Datatable/index.js.map +1 -1
  121. package/Divider/index.cjs +31 -0
  122. package/Divider/index.cjs.map +1 -0
  123. package/Divider/index.js +8 -10
  124. package/Divider/index.js.map +1 -1
  125. package/Drawer/index.cjs +78 -0
  126. package/Drawer/index.cjs.map +1 -0
  127. package/Drawer/index.js +12 -14
  128. package/Drawer/index.js.map +1 -1
  129. package/Form/index.cjs +45 -0
  130. package/Form/index.cjs.map +1 -0
  131. package/Form/index.js +8 -10
  132. package/Form/index.js.map +1 -1
  133. package/GridContainer/index.cjs +19 -0
  134. package/GridContainer/index.cjs.map +1 -0
  135. package/GridContainer/index.js +7 -9
  136. package/GridContainer/index.js.map +1 -1
  137. package/GridItem/index.cjs +20 -0
  138. package/GridItem/index.cjs.map +1 -0
  139. package/GridItem/index.js +7 -9
  140. package/GridItem/index.js.map +1 -1
  141. package/IconButton/index.cjs +64 -0
  142. package/IconButton/index.cjs.map +1 -0
  143. package/IconButton/index.js +12 -14
  144. package/IconButton/index.js.map +1 -1
  145. package/Image/index.cjs +27 -0
  146. package/Image/index.cjs.map +1 -0
  147. package/Image/index.js +9 -11
  148. package/Image/index.js.map +1 -1
  149. package/Input/index.cjs +144 -0
  150. package/Input/index.cjs.map +1 -0
  151. package/Input/index.js +18 -20
  152. package/Input/index.js.map +1 -1
  153. package/InputNumber/index.cjs +32 -0
  154. package/InputNumber/index.cjs.map +1 -0
  155. package/InputNumber/index.js +6 -8
  156. package/InputNumber/index.js.map +1 -1
  157. package/Label/index.cjs +24 -0
  158. package/Label/index.cjs.map +1 -0
  159. package/Label/index.js +7 -9
  160. package/Label/index.js.map +1 -1
  161. package/Layer/index.cjs +62 -0
  162. package/Layer/index.cjs.map +1 -0
  163. package/Layer/index.js +19 -21
  164. package/Layer/index.js.map +1 -1
  165. package/LineProgress/index.cjs +59 -0
  166. package/LineProgress/index.cjs.map +1 -0
  167. package/LineProgress/index.js +11 -13
  168. package/LineProgress/index.js.map +1 -1
  169. package/List/ListContext.cjs +11 -0
  170. package/List/ListContext.cjs.map +1 -0
  171. package/List/ListContext.js +2 -5
  172. package/List/ListContext.js.map +1 -1
  173. package/List/index.cjs +63 -0
  174. package/List/index.cjs.map +1 -0
  175. package/List/index.js +12 -14
  176. package/List/index.js.map +1 -1
  177. package/ListItem/index.cjs +54 -0
  178. package/ListItem/index.cjs.map +1 -0
  179. package/ListItem/index.js +12 -14
  180. package/ListItem/index.js.map +1 -1
  181. package/LoadingBox/index.cjs +32 -0
  182. package/LoadingBox/index.cjs.map +1 -0
  183. package/LoadingBox/index.js +11 -13
  184. package/LoadingBox/index.js.map +1 -1
  185. package/Menu/index.cjs +150 -0
  186. package/Menu/index.cjs.map +1 -0
  187. package/Menu/index.js +18 -20
  188. package/Menu/index.js.map +1 -1
  189. package/Modal/index.cjs +59 -0
  190. package/Modal/index.cjs.map +1 -0
  191. package/Modal/index.js +15 -17
  192. package/Modal/index.js.map +1 -1
  193. package/NoSSR/index.cjs +15 -0
  194. package/NoSSR/index.cjs.map +1 -0
  195. package/NoSSR/index.js +4 -6
  196. package/NoSSR/index.js.map +1 -1
  197. package/Option/index.cjs +14 -0
  198. package/Option/index.cjs.map +1 -0
  199. package/Option/index.js +7 -9
  200. package/Option/index.js.map +1 -1
  201. package/Paper/index.cjs +15 -0
  202. package/Paper/index.cjs.map +1 -0
  203. package/Paper/index.js +8 -10
  204. package/Paper/index.js.map +1 -1
  205. package/Portal/index.cjs +27 -0
  206. package/Portal/index.cjs.map +1 -0
  207. package/Portal/index.js +9 -11
  208. package/Portal/index.js.map +1 -1
  209. package/Radio/index.cjs +16 -0
  210. package/Radio/index.cjs.map +1 -0
  211. package/Radio/index.js +9 -11
  212. package/Radio/index.js.map +1 -1
  213. package/Scrollbar/index.cjs +59 -0
  214. package/Scrollbar/index.cjs.map +1 -0
  215. package/Scrollbar/index.js +10 -12
  216. package/Scrollbar/index.js.map +1 -1
  217. package/Select/index.cjs +59 -0
  218. package/Select/index.cjs.map +1 -0
  219. package/Select/index.js +22 -24
  220. package/Select/index.js.map +1 -1
  221. package/Skeleton/index.cjs +60 -0
  222. package/Skeleton/index.cjs.map +1 -0
  223. package/Skeleton/index.js +7 -9
  224. package/Skeleton/index.js.map +1 -1
  225. package/Stack/index.cjs +17 -0
  226. package/Stack/index.cjs.map +1 -0
  227. package/Stack/index.js +7 -9
  228. package/Stack/index.js.map +1 -1
  229. package/Switch/index.cjs +79 -0
  230. package/Switch/index.cjs.map +1 -0
  231. package/Switch/index.js +12 -14
  232. package/Switch/index.js.map +1 -1
  233. package/Tab/index.cjs +17 -0
  234. package/Tab/index.cjs.map +1 -0
  235. package/Tab/index.js +9 -11
  236. package/Tab/index.js.map +1 -1
  237. package/Table/index.cjs +88 -0
  238. package/Table/index.cjs.map +1 -0
  239. package/Table/index.js +13 -15
  240. package/Table/index.js.map +1 -1
  241. package/TableBody/index.cjs +14 -0
  242. package/TableBody/index.cjs.map +1 -0
  243. package/TableBody/index.js +7 -9
  244. package/TableBody/index.js.map +1 -1
  245. package/TableCell/index.cjs +14 -0
  246. package/TableCell/index.cjs.map +1 -0
  247. package/TableCell/index.js +7 -9
  248. package/TableCell/index.js.map +1 -1
  249. package/TableFooter/index.cjs +14 -0
  250. package/TableFooter/index.cjs.map +1 -0
  251. package/TableFooter/index.js +7 -9
  252. package/TableFooter/index.js.map +1 -1
  253. package/TableHead/index.cjs +14 -0
  254. package/TableHead/index.cjs.map +1 -0
  255. package/TableHead/index.js +7 -9
  256. package/TableHead/index.js.map +1 -1
  257. package/TablePagination/index.cjs +59 -0
  258. package/TablePagination/index.cjs.map +1 -0
  259. package/TablePagination/index.js +21 -23
  260. package/TablePagination/index.js.map +1 -1
  261. package/TableRow/index.cjs +14 -0
  262. package/TableRow/index.cjs.map +1 -0
  263. package/TableRow/index.js +7 -9
  264. package/TableRow/index.js.map +1 -1
  265. package/Tabs/index.cjs +201 -0
  266. package/Tabs/index.cjs.map +1 -0
  267. package/Tabs/index.js +19 -21
  268. package/Tabs/index.js.map +1 -1
  269. package/Text/index.cjs +25 -0
  270. package/Text/index.cjs.map +1 -0
  271. package/Text/index.js +8 -10
  272. package/Text/index.js.map +1 -1
  273. package/Toast/index.cjs +120 -0
  274. package/Toast/index.cjs.map +1 -0
  275. package/Toast/index.js +18 -20
  276. package/Toast/index.js.map +1 -1
  277. package/Tooltip/index.cjs +40 -0
  278. package/Tooltip/index.cjs.map +1 -0
  279. package/Tooltip/index.js +11 -13
  280. package/Tooltip/index.js.map +1 -1
  281. package/ViewBox/index.cjs +32 -0
  282. package/ViewBox/index.cjs.map +1 -0
  283. package/ViewBox/index.js +11 -13
  284. package/ViewBox/index.js.map +1 -1
  285. package/index.cjs +134 -0
  286. package/index.cjs.map +1 -0
  287. package/index.js +64 -133
  288. package/index.js.map +1 -1
  289. package/package.json +3 -3
  290. package/readme.md +4 -4
  291. package/useAlert/index.cjs +94 -0
  292. package/useAlert/index.cjs.map +1 -0
  293. package/useAlert/index.js +12 -14
  294. package/useAlert/index.js.map +1 -1
  295. package/useBlurCss/index.cjs +19 -0
  296. package/useBlurCss/index.cjs.map +1 -0
  297. package/useBlurCss/index.js +5 -7
  298. package/useBlurCss/index.js.map +1 -1
  299. package/useCorner/index.cjs +22 -0
  300. package/useCorner/index.cjs.map +1 -0
  301. package/useCorner/index.js +1 -3
  302. package/useCorner/index.js.map +1 -1
  303. package/useLayer/index.cjs +38 -0
  304. package/useLayer/index.cjs.map +1 -0
  305. package/useLayer/index.js +7 -9
  306. package/useLayer/index.js.map +1 -1
  307. package/useModal/index.cjs +37 -0
  308. package/useModal/index.cjs.map +1 -0
  309. package/useModal/index.js +8 -10
  310. package/useModal/index.js.map +1 -1
@@ -0,0 +1,37 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var tslib = require('tslib');
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var core = require('@xanui/core');
7
+ var React = require('react');
8
+
9
+ const ClickOutside = React.forwardRef((_a, forwardedRef) => {
10
+ var { children, onClickOutside } = _a, props = tslib.__rest(_a, ["children", "onClickOutside"]);
11
+ const innerRef = React.useRef(null);
12
+ // merge refs
13
+ const setRefs = (el) => {
14
+ innerRef.current = el;
15
+ if (typeof forwardedRef === "function") {
16
+ forwardedRef(el);
17
+ }
18
+ else if (forwardedRef) {
19
+ forwardedRef.current = el;
20
+ }
21
+ };
22
+ React.useEffect(() => {
23
+ const handler = (e) => {
24
+ if (!innerRef.current)
25
+ return;
26
+ if (!innerRef.current.contains(e.target)) {
27
+ onClickOutside(e);
28
+ }
29
+ };
30
+ document.addEventListener("mousedown", handler);
31
+ return () => document.removeEventListener("mousedown", handler);
32
+ }, [onClickOutside]);
33
+ return (jsxRuntime.jsx(core.Tag, Object.assign({ component: "div", display: "inline-block" }, props, { baseClass: 'click-outside', ref: setRefs, children: children })));
34
+ });
35
+
36
+ module.exports = ClickOutside;
37
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","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;;"}
@@ -1,14 +1,12 @@
1
1
  "use client";
2
- 'use strict';
3
-
4
- var tslib = require('tslib');
5
- var jsxRuntime = require('react/jsx-runtime');
6
- var core = require('@xanui/core');
7
- var React = require('react');
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';
8
6
 
9
7
  const ClickOutside = React.forwardRef((_a, forwardedRef) => {
10
- var { children, onClickOutside } = _a, props = tslib.__rest(_a, ["children", "onClickOutside"]);
11
- const innerRef = React.useRef(null);
8
+ var { children, onClickOutside } = _a, props = __rest(_a, ["children", "onClickOutside"]);
9
+ const innerRef = useRef(null);
12
10
  // merge refs
13
11
  const setRefs = (el) => {
14
12
  innerRef.current = el;
@@ -19,7 +17,7 @@ const ClickOutside = React.forwardRef((_a, forwardedRef) => {
19
17
  forwardedRef.current = el;
20
18
  }
21
19
  };
22
- React.useEffect(() => {
20
+ useEffect(() => {
23
21
  const handler = (e) => {
24
22
  if (!innerRef.current)
25
23
  return;
@@ -30,8 +28,8 @@ const ClickOutside = React.forwardRef((_a, forwardedRef) => {
30
28
  document.addEventListener("mousedown", handler);
31
29
  return () => document.removeEventListener("mousedown", handler);
32
30
  }, [onClickOutside]);
33
- return (jsxRuntime.jsx(core.Tag, Object.assign({ component: "div", display: "inline-block" }, props, { baseClass: 'click-outside', ref: setRefs, children: children })));
31
+ return (jsx(Tag, Object.assign({ component: "div", display: "inline-block" }, props, { baseClass: 'click-outside', ref: setRefs, children: children })));
34
32
  });
35
33
 
36
- module.exports = ClickOutside;
34
+ export { ClickOutside as default };
37
35
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","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;;"}
1
+ {"version":3,"file":"index.js","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;;"}
@@ -0,0 +1,26 @@
1
+ 'use strict';
2
+
3
+ var tslib = require('tslib');
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var React = require('react');
6
+ var core = require('@xanui/core');
7
+
8
+ const Collaps = React.forwardRef((_a, ref) => {
9
+ var { children, open } = _a, props = tslib.__rest(_a, ["children", "open"]);
10
+ let [_b] = core.useInterface("Collaps", props, {}), { ease, easing, duration, delay, onStart, onFinish, onOpen, onOpened, onClose, onClosed } = _b, rest = tslib.__rest(_b, ["ease", "easing", "duration", "delay", "onStart", "onFinish", "onOpen", "onOpened", "onClose", "onClosed"]);
11
+ open !== null && open !== void 0 ? open : (open = false);
12
+ easing !== null && easing !== void 0 ? easing : (easing = "standard");
13
+ return (jsxRuntime.jsx(core.Transition, { ease,
14
+ easing,
15
+ duration,
16
+ delay,
17
+ onStart,
18
+ onFinish,
19
+ onOpen,
20
+ onOpened,
21
+ onClose,
22
+ onClosed, disableInitialTransition: true, variant: "collapseVertical", open: open, children: jsxRuntime.jsx(core.Tag, Object.assign({}, rest, { baseClass: 'collaps', ref: ref, children: children })) }));
23
+ });
24
+
25
+ module.exports = Collaps;
26
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","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":["__rest","useInterface","_jsx","Transition","Tag"],"mappings":";;;;;;;AAOA,MAAM,OAAO,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,EAA6C,EAAE,GAAQ,KAAI;QAA3D,EAAE,QAAQ,EAAE,IAAI,EAAA,GAAA,EAA6B,EAAxB,KAAK,GAAAA,YAAA,CAAA,EAAA,EAA1B,oBAA4B,CAAF;AAC5F,IAAA,IAAI,OAYCC,iBAAY,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,GAAAD,YAAA,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,QACIE,cAAA,CAACC,eAAU,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,EAEVD,cAAA,CAACE,QAAG,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/Collaps/index.js CHANGED
@@ -1,16 +1,14 @@
1
- 'use strict';
2
-
3
- var tslib = require('tslib');
4
- var jsxRuntime = require('react/jsx-runtime');
5
- var React = require('react');
6
- var core = require('@xanui/core');
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';
7
5
 
8
6
  const Collaps = React.forwardRef((_a, ref) => {
9
- var { children, open } = _a, props = tslib.__rest(_a, ["children", "open"]);
10
- let [_b] = core.useInterface("Collaps", props, {}), { ease, easing, duration, delay, onStart, onFinish, onOpen, onOpened, onClose, onClosed } = _b, rest = tslib.__rest(_b, ["ease", "easing", "duration", "delay", "onStart", "onFinish", "onOpen", "onOpened", "onClose", "onClosed"]);
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"]);
11
9
  open !== null && open !== void 0 ? open : (open = false);
12
10
  easing !== null && easing !== void 0 ? easing : (easing = "standard");
13
- return (jsxRuntime.jsx(core.Transition, { ease,
11
+ return (jsx(Transition, { ease,
14
12
  easing,
15
13
  duration,
16
14
  delay,
@@ -19,8 +17,8 @@ const Collaps = React.forwardRef((_a, ref) => {
19
17
  onOpen,
20
18
  onOpened,
21
19
  onClose,
22
- onClosed, disableInitialTransition: true, variant: "collapseVertical", open: open, children: jsxRuntime.jsx(core.Tag, Object.assign({}, rest, { baseClass: 'collaps', ref: ref, children: children })) }));
20
+ onClosed, disableInitialTransition: true, variant: "collapseVertical", open: open, children: jsx(Tag, Object.assign({}, rest, { baseClass: 'collaps', ref: ref, children: children })) }));
23
21
  });
24
22
 
25
- module.exports = Collaps;
23
+ export { Collaps as default };
26
24
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","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":["__rest","useInterface","_jsx","Transition","Tag"],"mappings":";;;;;;;AAOA,MAAM,OAAO,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,EAA6C,EAAE,GAAQ,KAAI;QAA3D,EAAE,QAAQ,EAAE,IAAI,EAAA,GAAA,EAA6B,EAAxB,KAAK,GAAAA,YAAA,CAAA,EAAA,EAA1B,oBAA4B,CAAF;AAC5F,IAAA,IAAI,OAYCC,iBAAY,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,GAAAD,YAAA,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,QACIE,cAAA,CAACC,eAAU,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,EAEVD,cAAA,CAACE,QAAG,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
+ {"version":3,"file":"index.js","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;;;;"}
@@ -0,0 +1,29 @@
1
+ 'use strict';
2
+
3
+ var tslib = require('tslib');
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var React = require('react');
6
+ var core = require('@xanui/core');
7
+
8
+ const Container = React.forwardRef((_a, ref) => {
9
+ var { children, maxWidth } = _a, rest = tslib.__rest(_a, ["children", "maxWidth"]);
10
+ const _p = {};
11
+ if (maxWidth)
12
+ _p.maxWidth = maxWidth;
13
+ const p = core.useBreakpointProps(_p);
14
+ maxWidth = p.maxWidth;
15
+ const { breakpoints } = core.useTheme();
16
+ maxWidth = maxWidth || "lg";
17
+ return (jsxRuntime.jsx(core.Tag, Object.assign({}, rest, { sxr: {
18
+ width: "100%",
19
+ maxWidth: {
20
+ xs: "100%",
21
+ [maxWidth]: breakpoints[maxWidth]
22
+ },
23
+ mx: "auto",
24
+ px: 2,
25
+ }, baseClass: "container", ref: ref, children: children })));
26
+ });
27
+
28
+ module.exports = Container;
29
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","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":["__rest","useBreakpointProps","useTheme","_jsx","Tag"],"mappings":";;;;;;;AAQA,MAAM,SAAS,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,EAAkD,EAAE,GAAoB,KAAI;QAA5E,EAAE,QAAQ,EAAE,QAAQ,EAAA,GAAA,EAA8B,EAAzB,IAAI,GAAAA,YAAA,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,GAAQC,uBAAkB,CAAC,EAAE,CAAC;AACrC,IAAA,QAAQ,GAAG,CAAC,CAAC,QAAQ;AAErB,IAAA,MAAM,EAAE,WAAW,EAAE,GAAGC,aAAQ,EAAE;AAClC,IAAA,QAAQ,GAAG,QAAQ,IAAI,IAAI;AAC3B,IAAA,QACIC,cAAA,CAACC,QAAG,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,20 +1,18 @@
1
- 'use strict';
2
-
3
- var tslib = require('tslib');
4
- var jsxRuntime = require('react/jsx-runtime');
5
- var React = require('react');
6
- var core = require('@xanui/core');
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';
7
5
 
8
6
  const Container = React.forwardRef((_a, ref) => {
9
- var { children, maxWidth } = _a, rest = tslib.__rest(_a, ["children", "maxWidth"]);
7
+ var { children, maxWidth } = _a, rest = __rest(_a, ["children", "maxWidth"]);
10
8
  const _p = {};
11
9
  if (maxWidth)
12
10
  _p.maxWidth = maxWidth;
13
- const p = core.useBreakpointProps(_p);
11
+ const p = useBreakpointProps(_p);
14
12
  maxWidth = p.maxWidth;
15
- const { breakpoints } = core.useTheme();
13
+ const { breakpoints } = useTheme();
16
14
  maxWidth = maxWidth || "lg";
17
- return (jsxRuntime.jsx(core.Tag, Object.assign({}, rest, { sxr: {
15
+ return (jsx(Tag, Object.assign({}, rest, { sxr: {
18
16
  width: "100%",
19
17
  maxWidth: {
20
18
  xs: "100%",
@@ -25,5 +23,5 @@ const Container = React.forwardRef((_a, ref) => {
25
23
  }, baseClass: "container", ref: ref, children: children })));
26
24
  });
27
25
 
28
- module.exports = Container;
26
+ export { Container as default };
29
27
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","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":["__rest","useBreakpointProps","useTheme","_jsx","Tag"],"mappings":";;;;;;;AAQA,MAAM,SAAS,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,EAAkD,EAAE,GAAoB,KAAI;QAA5E,EAAE,QAAQ,EAAE,QAAQ,EAAA,GAAA,EAA8B,EAAzB,IAAI,GAAAA,YAAA,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,GAAQC,uBAAkB,CAAC,EAAE,CAAC;AACrC,IAAA,QAAQ,GAAG,CAAC,CAAC,QAAQ;AAErB,IAAA,MAAM,EAAE,WAAW,EAAE,GAAGC,aAAQ,EAAE;AAClC,IAAA,QAAQ,GAAG,QAAQ,IAAI,IAAI;AAC3B,IAAA,QACIC,cAAA,CAACC,QAAG,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
+ {"version":3,"file":"index.js","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;;;;"}
@@ -0,0 +1,78 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, '__esModule', { value: true });
5
+
6
+ var tslib = require('tslib');
7
+ var jsxRuntime = require('react/jsx-runtime');
8
+ var index = require('../Stack/index.cjs');
9
+ var SelectFilter = require('./options/SelectFilter.cjs');
10
+ var MultiSelectFilter = require('./options/MultiSelectFilter.cjs');
11
+ var NumberFilter = require('./options/NumberFilter.cjs');
12
+ var TextFilter = require('./options/TextFilter.cjs');
13
+ var NumberRangeFilter = require('./options/NumberRangeFilter.cjs');
14
+ var DateFilter = require('./options/DateFilter.cjs');
15
+ var DateRangeFilter = require('./options/DateRangeFilter.cjs');
16
+ var React = require('react');
17
+ var core = require('@xanui/core');
18
+
19
+ const DataFilter$1 = (_a, ref) => {
20
+ var { inline, options, onChange, value } = _a, props = tslib.__rest(_a, ["inline", "options", "onChange", "value"]);
21
+ inline !== null && inline !== void 0 ? inline : (inline = false);
22
+ value !== null && value !== void 0 ? value : (value = {});
23
+ onChange !== null && onChange !== void 0 ? onChange : (onChange = () => { });
24
+ return (jsxRuntime.jsx(core.Tag, Object.assign({}, props, { sxr: {
25
+ flexBox: true,
26
+ flexDirection: inline ? 'row' : 'column',
27
+ alignItems: inline ? 'center' : 'stretch',
28
+ flexWrap: inline ? 'wrap' : 'nowrap',
29
+ gap: 1,
30
+ p: 2,
31
+ radius: 1,
32
+ }, baseClass: 'data-filter', ref: ref, children: options.map((option, index$1) => {
33
+ var _a, _b, _c, _d, _e, _f, _g;
34
+ switch (option.type) {
35
+ case "text":
36
+ return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(TextFilter, { option: option, value: (_a = value[option.key]) !== null && _a !== void 0 ? _a : null, onChange: (v) => {
37
+ onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
38
+ } }) }, index$1));
39
+ case "number":
40
+ return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(NumberFilter, { option: option, value: (_b = value[option.key]) !== null && _b !== void 0 ? _b : null, onChange: (v) => {
41
+ onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
42
+ } }) }, index$1));
43
+ case "number-range":
44
+ return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(NumberRangeFilter, { option: option, value: (_c = value[option.key]) !== null && _c !== void 0 ? _c : null, onChange: (v) => {
45
+ onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
46
+ } }) }, index$1));
47
+ case "select":
48
+ return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(SelectFilter, { option: option, value: (_d = value[option.key]) !== null && _d !== void 0 ? _d : null, onChange: (v) => {
49
+ onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
50
+ } }) }, index$1));
51
+ case "multi-select":
52
+ return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(MultiSelectFilter, { option: option, value: (_e = value[option.key]) !== null && _e !== void 0 ? _e : [], onChange: (v) => {
53
+ onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
54
+ } }) }, index$1));
55
+ case "date":
56
+ return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(DateFilter, { option: option, value: (_f = value[option.key]) !== null && _f !== void 0 ? _f : null, onChange: (v) => {
57
+ onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
58
+ } }) }, index$1));
59
+ case "date-range":
60
+ return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(DateRangeFilter, { option: option, value: (_g = value[option.key]) !== null && _g !== void 0 ? _g : null, onChange: (v) => {
61
+ onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
62
+ } }) }, index$1));
63
+ default:
64
+ return null;
65
+ }
66
+ }) })));
67
+ };
68
+ var DataFilter = React.forwardRef(DataFilter$1);
69
+
70
+ exports.SelectFilter = SelectFilter;
71
+ exports.MultiSelectFilter = MultiSelectFilter;
72
+ exports.NumberFilter = NumberFilter;
73
+ exports.TextFilter = TextFilter;
74
+ exports.NumberRangeFilter = NumberRangeFilter;
75
+ exports.DateFilter = DateFilter;
76
+ exports.DateRangeFilter = DateRangeFilter;
77
+ exports.default = DataFilter;
78
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","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,27 +1,23 @@
1
1
  "use client";
2
- 'use strict';
3
-
4
- Object.defineProperty(exports, '__esModule', { value: true });
5
-
6
- var tslib = require('tslib');
7
- var jsxRuntime = require('react/jsx-runtime');
8
- var index = require('../Stack/index.js');
9
- var SelectFilter = require('./options/SelectFilter.js');
10
- var MultiSelectFilter = require('./options/MultiSelectFilter.js');
11
- var NumberFilter = require('./options/NumberFilter.js');
12
- var TextFilter = require('./options/TextFilter.js');
13
- var NumberRangeFilter = require('./options/NumberRangeFilter.js');
14
- var DateFilter = require('./options/DateFilter.js');
15
- var DateRangeFilter = require('./options/DateRangeFilter.js');
16
- var React = require('react');
17
- var core = require('@xanui/core');
2
+ import { __rest } from 'tslib';
3
+ import { jsx } from 'react/jsx-runtime';
4
+ import Stack from '../Stack/index.js';
5
+ import SelectFilter from './options/SelectFilter.js';
6
+ import MultiSelectFilter from './options/MultiSelectFilter.js';
7
+ import NumberFilter from './options/NumberFilter.js';
8
+ import TextFilter from './options/TextFilter.js';
9
+ import NumberRangeFilter from './options/NumberRangeFilter.js';
10
+ import DateFilter from './options/DateFilter.js';
11
+ import DateRangeFilter from './options/DateRangeFilter.js';
12
+ import React from 'react';
13
+ import { Tag } from '@xanui/core';
18
14
 
19
15
  const DataFilter = (_a, ref) => {
20
- var { inline, options, onChange, value } = _a, props = tslib.__rest(_a, ["inline", "options", "onChange", "value"]);
16
+ var { inline, options, onChange, value } = _a, props = __rest(_a, ["inline", "options", "onChange", "value"]);
21
17
  inline !== null && inline !== void 0 ? inline : (inline = false);
22
18
  value !== null && value !== void 0 ? value : (value = {});
23
19
  onChange !== null && onChange !== void 0 ? onChange : (onChange = () => { });
24
- return (jsxRuntime.jsx(core.Tag, Object.assign({}, props, { sxr: {
20
+ return (jsx(Tag, Object.assign({}, props, { sxr: {
25
21
  flexBox: true,
26
22
  flexDirection: inline ? 'row' : 'column',
27
23
  alignItems: inline ? 'center' : 'stretch',
@@ -29,37 +25,37 @@ const DataFilter = (_a, ref) => {
29
25
  gap: 1,
30
26
  p: 2,
31
27
  radius: 1,
32
- }, baseClass: 'data-filter', ref: ref, children: options.map((option, index$1) => {
28
+ }, baseClass: 'data-filter', ref: ref, children: options.map((option, index) => {
33
29
  var _a, _b, _c, _d, _e, _f, _g;
34
30
  switch (option.type) {
35
31
  case "text":
36
- return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(TextFilter, { option: option, value: (_a = value[option.key]) !== null && _a !== void 0 ? _a : null, onChange: (v) => {
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) => {
37
33
  onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
38
- } }) }, index$1));
34
+ } }) }, index));
39
35
  case "number":
40
- return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(NumberFilter, { option: option, value: (_b = value[option.key]) !== null && _b !== void 0 ? _b : null, onChange: (v) => {
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) => {
41
37
  onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
42
- } }) }, index$1));
38
+ } }) }, index));
43
39
  case "number-range":
44
- return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(NumberRangeFilter, { option: option, value: (_c = value[option.key]) !== null && _c !== void 0 ? _c : null, onChange: (v) => {
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) => {
45
41
  onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
46
- } }) }, index$1));
42
+ } }) }, index));
47
43
  case "select":
48
- return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(SelectFilter, { option: option, value: (_d = value[option.key]) !== null && _d !== void 0 ? _d : null, onChange: (v) => {
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) => {
49
45
  onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
50
- } }) }, index$1));
46
+ } }) }, index));
51
47
  case "multi-select":
52
- return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(MultiSelectFilter, { option: option, value: (_e = value[option.key]) !== null && _e !== void 0 ? _e : [], onChange: (v) => {
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) => {
53
49
  onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
54
- } }) }, index$1));
50
+ } }) }, index));
55
51
  case "date":
56
- return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(DateFilter, { option: option, value: (_f = value[option.key]) !== null && _f !== void 0 ? _f : null, onChange: (v) => {
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) => {
57
53
  onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
58
- } }) }, index$1));
54
+ } }) }, index));
59
55
  case "date-range":
60
- return (jsxRuntime.jsx(index, { width: inline ? 300 : "100%", children: jsxRuntime.jsx(DateRangeFilter, { option: option, value: (_g = value[option.key]) !== null && _g !== void 0 ? _g : null, onChange: (v) => {
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) => {
61
57
  onChange(Object.assign(Object.assign({}, value), { [option.key]: v }));
62
- } }) }, index$1));
58
+ } }) }, index));
63
59
  default:
64
60
  return null;
65
61
  }
@@ -67,12 +63,5 @@ const DataFilter = (_a, ref) => {
67
63
  };
68
64
  var DataFilter$1 = React.forwardRef(DataFilter);
69
65
 
70
- exports.SelectFilter = SelectFilter;
71
- exports.MultiSelectFilter = MultiSelectFilter;
72
- exports.NumberFilter = NumberFilter;
73
- exports.TextFilter = TextFilter;
74
- exports.NumberRangeFilter = NumberRangeFilter;
75
- exports.DateFilter = DateFilter;
76
- exports.DateRangeFilter = DateRangeFilter;
77
- exports.default = DataFilter$1;
66
+ export { DateFilter, DateRangeFilter, MultiSelectFilter, NumberFilter, NumberRangeFilter, SelectFilter, TextFilter, DataFilter$1 as default };
78
67
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","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
+ {"version":3,"file":"index.js","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;;"}
@@ -0,0 +1,32 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var React = require('react');
6
+ var index$4 = require('../../Menu/index.cjs');
7
+ var index$2 = require('../../IconButton/index.cjs');
8
+ var index = require('../../Stack/index.cjs');
9
+ var index$1 = require('../../Text/index.cjs');
10
+ var Close = require('@xanui/icons/Close');
11
+ var Add = require('@xanui/icons/Add');
12
+ var ClearAll = require('@xanui/icons/ClearAll');
13
+ var index$3 = require('../../Chip/index.cjs');
14
+ var index$5 = require('../../Calendar/index.cjs');
15
+
16
+ const DateFilter = ({ option, onChange, value }) => {
17
+ const [target, setTarget] = React.useState();
18
+ const isValue = value !== null && value !== undefined && value !== "";
19
+ return (jsxRuntime.jsxs(index, { width: "100%", bgcolor: "background.secondary", p: 1, radius: 1, children: [jsxRuntime.jsxs(index, { direction: "row", alignItems: "center", justifyContent: "space-between", gap: 0.5, mb: isValue ? .5 : 0, children: [jsxRuntime.jsx(index$1, { children: option.label }), jsxRuntime.jsxs(index, { direction: "row", gap: 0.5, children: [jsxRuntime.jsx(index$2, { size: "small", variant: "soft", color: "default", onClick: (e) => {
20
+ setTarget(e.currentTarget);
21
+ }, children: jsxRuntime.jsx(Add, {}) }), isValue && jsxRuntime.jsx(index$2, { size: "small", variant: "soft", color: "danger", onClick: () => {
22
+ onChange(null);
23
+ }, children: jsxRuntime.jsx(ClearAll, {}) })] })] }), jsxRuntime.jsx(index, { direction: "row", gap: 0.5, flexWrap: "wrap", children: isValue && jsxRuntime.jsx(index$3, { size: "small", color: "default", label: new Date(value).toLocaleDateString("en-US"), endIcon: jsxRuntime.jsx(index$2, { size: 16, variant: "text", color: "default", onClick: () => {
24
+ onChange(null);
25
+ }, children: jsxRuntime.jsx(Close, {}) }) }) }), jsxRuntime.jsx(index$4, { target: target, onClickOutside: () => setTarget(undefined), placement: "bottom-right", children: jsxRuntime.jsx(index$5, { value: value ? new Date(value) : null, onChange: (date) => {
26
+ onChange((date === null || date === void 0 ? void 0 : date.toISOString()) || null);
27
+ setTarget(undefined);
28
+ } }) })] }));
29
+ };
30
+
31
+ module.exports = DateFilter;
32
+ //# sourceMappingURL=DateFilter.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DateFilter.cjs","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;;"}