@xanui/ui 1.1.9 → 1.1.10

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 (344) hide show
  1. package/Accordion/{index.js → index.cjs} +17 -3
  2. package/Accordion/index.cjs.map +1 -0
  3. package/Accordion/index.mjs +14 -2
  4. package/Accordion/index.mjs.map +1 -1
  5. package/Alert/{index.js → index.cjs} +23 -5
  6. package/Alert/index.cjs.map +1 -0
  7. package/Alert/index.mjs +18 -2
  8. package/Alert/index.mjs.map +1 -1
  9. package/Avatar/{index.js → index.cjs} +13 -2
  10. package/Avatar/index.cjs.map +1 -0
  11. package/Avatar/index.mjs +11 -2
  12. package/Avatar/index.mjs.map +1 -1
  13. package/Badge/{index.js → index.cjs} +12 -2
  14. package/Badge/index.cjs.map +1 -0
  15. package/Badge/index.mjs +10 -2
  16. package/Badge/index.mjs.map +1 -1
  17. package/Box/index.cjs +14 -0
  18. package/Box/index.cjs.map +1 -0
  19. package/Box/index.mjs +10 -2
  20. package/Box/index.mjs.map +1 -1
  21. package/Button/{index.js → index.cjs} +16 -4
  22. package/Button/index.cjs.map +1 -0
  23. package/Button/index.mjs +12 -2
  24. package/Button/index.mjs.map +1 -1
  25. package/ButtonGroup/{index.js → index.cjs} +12 -2
  26. package/ButtonGroup/index.cjs.map +1 -0
  27. package/ButtonGroup/index.mjs +10 -2
  28. package/ButtonGroup/index.mjs.map +1 -1
  29. package/Calendar/{index.js → index.cjs} +34 -16
  30. package/Calendar/index.cjs.map +1 -0
  31. package/Calendar/index.mjs +18 -2
  32. package/Calendar/index.mjs.map +1 -1
  33. package/CalendarInput/index.cjs +29 -0
  34. package/CalendarInput/index.cjs.map +1 -0
  35. package/CalendarInput/index.mjs +18 -2
  36. package/CalendarInput/index.mjs.map +1 -1
  37. package/Checkbox/{index.js → index.cjs} +15 -2
  38. package/Checkbox/index.cjs.map +1 -0
  39. package/Checkbox/index.mjs +13 -2
  40. package/Checkbox/index.mjs.map +1 -1
  41. package/Chip/{index.js → index.cjs} +14 -3
  42. package/Chip/index.cjs.map +1 -0
  43. package/Chip/index.mjs +11 -2
  44. package/Chip/index.mjs.map +1 -1
  45. package/CircleProgress/{index.js → index.cjs} +12 -2
  46. package/CircleProgress/index.cjs.map +1 -0
  47. package/CircleProgress/index.mjs +10 -2
  48. package/CircleProgress/index.mjs.map +1 -1
  49. package/ClickOutside/{index.js → index.cjs} +12 -2
  50. package/ClickOutside/index.cjs.map +1 -0
  51. package/ClickOutside/index.mjs +10 -2
  52. package/ClickOutside/index.mjs.map +1 -1
  53. package/Collaps/{index.js → index.cjs} +12 -2
  54. package/Collaps/index.cjs.map +1 -0
  55. package/Collaps/index.mjs +10 -2
  56. package/Collaps/index.mjs.map +1 -1
  57. package/Container/{index.js → index.cjs} +12 -2
  58. package/Container/index.cjs.map +1 -0
  59. package/Container/index.mjs +10 -2
  60. package/Container/index.mjs.map +1 -1
  61. package/Datatable/FilterBox.cjs +33 -0
  62. package/Datatable/FilterBox.cjs.map +1 -0
  63. package/Datatable/FilterBox.mjs +14 -2
  64. package/Datatable/FilterBox.mjs.map +1 -1
  65. package/Datatable/{Row.js → Row.cjs} +24 -7
  66. package/Datatable/Row.cjs.map +1 -0
  67. package/Datatable/Row.mjs +17 -2
  68. package/Datatable/Row.mjs.map +1 -1
  69. package/Datatable/SelectedBox.cjs +22 -0
  70. package/Datatable/SelectedBox.cjs.map +1 -0
  71. package/Datatable/SelectedBox.mjs +11 -2
  72. package/Datatable/SelectedBox.mjs.map +1 -1
  73. package/Datatable/Table.cjs +22 -0
  74. package/Datatable/Table.cjs.map +1 -0
  75. package/Datatable/Table.mjs +11 -2
  76. package/Datatable/Table.mjs.map +1 -1
  77. package/Datatable/{TableHead.js → TableHead.cjs} +18 -5
  78. package/Datatable/TableHead.cjs.map +1 -0
  79. package/Datatable/TableHead.mjs +13 -2
  80. package/Datatable/TableHead.mjs.map +1 -1
  81. package/Datatable/index.cjs +50 -0
  82. package/Datatable/index.cjs.map +1 -0
  83. package/Datatable/index.mjs +15 -2
  84. package/Datatable/index.mjs.map +1 -1
  85. package/Divider/{index.js → index.cjs} +12 -2
  86. package/Divider/index.cjs.map +1 -0
  87. package/Divider/index.mjs +10 -2
  88. package/Divider/index.mjs.map +1 -1
  89. package/Drawer/{index.js → index.cjs} +15 -4
  90. package/Drawer/index.cjs.map +1 -0
  91. package/Drawer/index.mjs +11 -2
  92. package/Drawer/index.mjs.map +1 -1
  93. package/Form/{index.js → index.cjs} +12 -2
  94. package/Form/index.cjs.map +1 -0
  95. package/Form/index.mjs +10 -2
  96. package/Form/index.mjs.map +1 -1
  97. package/GridContainer/{index.js → index.cjs} +12 -2
  98. package/GridContainer/index.cjs.map +1 -0
  99. package/GridContainer/index.mjs +10 -2
  100. package/GridContainer/index.mjs.map +1 -1
  101. package/GridItem/{index.js → index.cjs} +12 -2
  102. package/GridItem/index.cjs.map +1 -0
  103. package/GridItem/index.mjs +10 -2
  104. package/GridItem/index.mjs.map +1 -1
  105. package/IconButton/{index.js → index.cjs} +14 -3
  106. package/IconButton/index.cjs.map +1 -0
  107. package/IconButton/index.mjs +11 -2
  108. package/IconButton/index.mjs.map +1 -1
  109. package/Image/{index.js → index.cjs} +12 -2
  110. package/Image/index.cjs.map +1 -0
  111. package/Image/index.mjs +10 -2
  112. package/Image/index.mjs.map +1 -1
  113. package/Input/{index.js → index.cjs} +17 -6
  114. package/Input/index.cjs.map +1 -0
  115. package/Input/index.mjs +14 -5
  116. package/Input/index.mjs.map +1 -1
  117. package/Label/{index.js → index.cjs} +12 -2
  118. package/Label/index.cjs.map +1 -0
  119. package/Label/index.mjs +10 -2
  120. package/Label/index.mjs.map +1 -1
  121. package/Layer/{index.js → index.cjs} +16 -4
  122. package/Layer/index.cjs.map +1 -0
  123. package/Layer/index.mjs +12 -2
  124. package/Layer/index.mjs.map +1 -1
  125. package/LineProgress/{index.js → index.cjs} +12 -2
  126. package/LineProgress/index.cjs.map +1 -0
  127. package/LineProgress/index.mjs +10 -2
  128. package/LineProgress/index.mjs.map +1 -1
  129. package/List/{index.js → index.cjs} +12 -2
  130. package/List/index.cjs.map +1 -0
  131. package/List/index.mjs +10 -2
  132. package/List/index.mjs.map +1 -1
  133. package/ListItem/{index.js → index.cjs} +14 -3
  134. package/ListItem/index.cjs.map +1 -0
  135. package/ListItem/index.mjs +11 -2
  136. package/ListItem/index.mjs.map +1 -1
  137. package/LoadingBox/{index.js → index.cjs} +14 -3
  138. package/LoadingBox/index.cjs.map +1 -0
  139. package/LoadingBox/index.mjs +11 -2
  140. package/LoadingBox/index.mjs.map +1 -1
  141. package/Menu/{index.js → index.cjs} +15 -3
  142. package/Menu/index.cjs.map +1 -0
  143. package/Menu/index.mjs +12 -2
  144. package/Menu/index.mjs.map +1 -1
  145. package/Modal/{index.js → index.cjs} +14 -3
  146. package/Modal/index.cjs.map +1 -0
  147. package/Modal/index.mjs +11 -2
  148. package/Modal/index.mjs.map +1 -1
  149. package/NoSSR/index.cjs +14 -0
  150. package/NoSSR/index.cjs.map +1 -0
  151. package/NoSSR/index.mjs +7 -2
  152. package/NoSSR/index.mjs.map +1 -1
  153. package/Option/index.cjs +14 -0
  154. package/Option/index.cjs.map +1 -0
  155. package/Option/index.mjs +10 -2
  156. package/Option/index.mjs.map +1 -1
  157. package/Paper/{index.js → index.cjs} +12 -2
  158. package/Paper/index.cjs.map +1 -0
  159. package/Paper/index.mjs +10 -2
  160. package/Paper/index.mjs.map +1 -1
  161. package/Portal/{index.js → index.cjs} +12 -2
  162. package/Portal/index.cjs.map +1 -0
  163. package/Portal/index.mjs +10 -2
  164. package/Portal/index.mjs.map +1 -1
  165. package/Radio/index.cjs +16 -0
  166. package/Radio/index.cjs.map +1 -0
  167. package/Radio/index.mjs +12 -2
  168. package/Radio/index.mjs.map +1 -1
  169. package/Scrollbar/{index.js → index.cjs} +12 -2
  170. package/Scrollbar/index.cjs.map +1 -0
  171. package/Scrollbar/index.mjs +10 -2
  172. package/Scrollbar/index.mjs.map +1 -1
  173. package/Select/{index.js → index.cjs} +21 -5
  174. package/Select/index.cjs.map +1 -0
  175. package/Select/index.mjs +16 -2
  176. package/Select/index.mjs.map +1 -1
  177. package/Stack/index.cjs +17 -0
  178. package/Stack/index.cjs.map +1 -0
  179. package/Stack/index.mjs +10 -2
  180. package/Stack/index.mjs.map +1 -1
  181. package/Switch/{index.js → index.cjs} +12 -2
  182. package/Switch/index.cjs.map +1 -0
  183. package/Switch/index.mjs +10 -2
  184. package/Switch/index.mjs.map +1 -1
  185. package/Tab/index.cjs +16 -0
  186. package/Tab/index.cjs.map +1 -0
  187. package/Tab/index.mjs +11 -2
  188. package/Tab/index.mjs.map +1 -1
  189. package/Table/{index.js → index.cjs} +14 -3
  190. package/Table/index.cjs.map +1 -0
  191. package/Table/index.mjs +11 -2
  192. package/Table/index.mjs.map +1 -1
  193. package/TableBody/index.cjs +14 -0
  194. package/TableBody/index.cjs.map +1 -0
  195. package/TableBody/index.mjs +10 -2
  196. package/TableBody/index.mjs.map +1 -1
  197. package/TableCell/{index.js → index.cjs} +12 -2
  198. package/TableCell/index.cjs.map +1 -0
  199. package/TableCell/index.mjs +10 -2
  200. package/TableCell/index.mjs.map +1 -1
  201. package/TableFooter/index.cjs +14 -0
  202. package/TableFooter/index.cjs.map +1 -0
  203. package/TableFooter/index.mjs +10 -2
  204. package/TableFooter/index.mjs.map +1 -1
  205. package/TableHead/index.cjs +14 -0
  206. package/TableHead/index.cjs.map +1 -0
  207. package/TableHead/index.mjs +10 -2
  208. package/TableHead/index.mjs.map +1 -1
  209. package/TablePagination/{index.js → index.cjs} +22 -6
  210. package/TablePagination/index.cjs.map +1 -0
  211. package/TablePagination/index.mjs +16 -2
  212. package/TablePagination/index.mjs.map +1 -1
  213. package/TableRow/index.cjs +14 -0
  214. package/TableRow/index.cjs.map +1 -0
  215. package/TableRow/index.mjs +10 -2
  216. package/TableRow/index.mjs.map +1 -1
  217. package/Tabs/{index.js → index.cjs} +13 -3
  218. package/Tabs/index.cjs.map +1 -0
  219. package/Tabs/index.mjs +11 -3
  220. package/Tabs/index.mjs.map +1 -1
  221. package/Text/{index.js → index.cjs} +12 -2
  222. package/Text/index.cjs.map +1 -0
  223. package/Text/index.mjs +10 -2
  224. package/Text/index.mjs.map +1 -1
  225. package/Toast/{index.js → index.cjs} +17 -4
  226. package/Toast/index.cjs.map +1 -0
  227. package/Toast/index.mjs +13 -2
  228. package/Toast/index.mjs.map +1 -1
  229. package/Tooltip/{index.js → index.cjs} +14 -4
  230. package/Tooltip/index.cjs.map +1 -0
  231. package/Tooltip/index.mjs +11 -3
  232. package/Tooltip/index.mjs.map +1 -1
  233. package/ViewBox/{index.js → index.cjs} +14 -3
  234. package/ViewBox/index.cjs.map +1 -0
  235. package/ViewBox/index.mjs +11 -2
  236. package/ViewBox/index.mjs.map +1 -1
  237. package/index.cjs +116 -0
  238. package/index.cjs.map +1 -0
  239. package/index.mjs +56 -1
  240. package/index.mjs.map +1 -1
  241. package/package.json +4 -14
  242. package/readme.md +104 -104
  243. package/useAlert/{index.js → index.cjs} +18 -5
  244. package/useAlert/index.cjs.map +1 -0
  245. package/useAlert/index.d.ts +2 -2
  246. package/useAlert/index.mjs +13 -2
  247. package/useAlert/index.mjs.map +1 -1
  248. package/useBlurCss/{index.js → index.cjs} +10 -2
  249. package/useBlurCss/index.cjs.map +1 -0
  250. package/useBlurCss/index.mjs +8 -2
  251. package/useBlurCss/index.mjs.map +1 -1
  252. package/useCorner/{index.js → index.cjs} +7 -2
  253. package/useCorner/index.cjs.map +1 -0
  254. package/useCorner/index.mjs +4 -1
  255. package/useCorner/index.mjs.map +1 -1
  256. package/useLayer/{index.js → index.cjs} +13 -3
  257. package/useLayer/index.cjs.map +1 -0
  258. package/useLayer/index.mjs +10 -2
  259. package/useLayer/index.mjs.map +1 -1
  260. package/useModal/{index.js → index.cjs} +13 -3
  261. package/useModal/index.cjs.map +1 -0
  262. package/useModal/index.mjs +10 -2
  263. package/useModal/index.mjs.map +1 -1
  264. package/Accordion/index.js.map +0 -1
  265. package/Alert/index.js.map +0 -1
  266. package/Avatar/index.js.map +0 -1
  267. package/Badge/index.js.map +0 -1
  268. package/Box/index.js +0 -4
  269. package/Box/index.js.map +0 -1
  270. package/Button/index.js.map +0 -1
  271. package/ButtonGroup/index.js.map +0 -1
  272. package/Calendar/index.js.map +0 -1
  273. package/CalendarInput/index.js +0 -11
  274. package/CalendarInput/index.js.map +0 -1
  275. package/Checkbox/index.js.map +0 -1
  276. package/Chip/index.js.map +0 -1
  277. package/CircleProgress/index.js.map +0 -1
  278. package/ClickOutside/index.js.map +0 -1
  279. package/Collaps/index.js.map +0 -1
  280. package/Container/index.js.map +0 -1
  281. package/Datatable/FilterBox.js +0 -19
  282. package/Datatable/FilterBox.js.map +0 -1
  283. package/Datatable/Row.js.map +0 -1
  284. package/Datatable/SelectedBox.js +0 -11
  285. package/Datatable/SelectedBox.js.map +0 -1
  286. package/Datatable/Table.js +0 -11
  287. package/Datatable/Table.js.map +0 -1
  288. package/Datatable/TableHead.js.map +0 -1
  289. package/Datatable/index.js +0 -35
  290. package/Datatable/index.js.map +0 -1
  291. package/Divider/index.js.map +0 -1
  292. package/Drawer/index.js.map +0 -1
  293. package/Form/index.js.map +0 -1
  294. package/GridContainer/index.js.map +0 -1
  295. package/GridItem/index.js.map +0 -1
  296. package/IconButton/index.js.map +0 -1
  297. package/Image/index.js.map +0 -1
  298. package/Input/index.js.map +0 -1
  299. package/Label/index.js.map +0 -1
  300. package/Layer/index.js.map +0 -1
  301. package/LineProgress/index.js.map +0 -1
  302. package/List/index.js.map +0 -1
  303. package/ListItem/index.js.map +0 -1
  304. package/LoadingBox/index.js.map +0 -1
  305. package/Menu/index.js.map +0 -1
  306. package/Modal/index.js.map +0 -1
  307. package/NoSSR/index.js +0 -7
  308. package/NoSSR/index.js.map +0 -1
  309. package/Option/index.js +0 -4
  310. package/Option/index.js.map +0 -1
  311. package/Paper/index.js.map +0 -1
  312. package/Portal/index.js.map +0 -1
  313. package/Radio/index.js +0 -4
  314. package/Radio/index.js.map +0 -1
  315. package/Scrollbar/index.js.map +0 -1
  316. package/Select/index.js.map +0 -1
  317. package/Stack/index.js +0 -7
  318. package/Stack/index.js.map +0 -1
  319. package/Switch/index.js.map +0 -1
  320. package/Tab/index.js +0 -5
  321. package/Tab/index.js.map +0 -1
  322. package/Table/index.js.map +0 -1
  323. package/TableBody/index.js +0 -4
  324. package/TableBody/index.js.map +0 -1
  325. package/TableCell/index.js.map +0 -1
  326. package/TableFooter/index.js +0 -4
  327. package/TableFooter/index.js.map +0 -1
  328. package/TableHead/index.js +0 -4
  329. package/TableHead/index.js.map +0 -1
  330. package/TablePagination/index.js.map +0 -1
  331. package/TableRow/index.js +0 -4
  332. package/TableRow/index.js.map +0 -1
  333. package/Tabs/index.js.map +0 -1
  334. package/Text/index.js.map +0 -1
  335. package/Toast/index.js.map +0 -1
  336. package/Tooltip/index.js.map +0 -1
  337. package/ViewBox/index.js.map +0 -1
  338. package/index.js +0 -1
  339. package/index.js.map +0 -1
  340. package/useAlert/index.js.map +0 -1
  341. package/useBlurCss/index.js.map +0 -1
  342. package/useCorner/index.js.map +0 -1
  343. package/useLayer/index.js.map +0 -1
  344. package/useModal/index.js.map +0 -1
@@ -1,4 +1,13 @@
1
- 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var tslib=require('tslib'),jsxRuntime=require('react/jsx-runtime'),React=require('react'),core=require('@xanui/core'),index$1=require('../useCorner/index.js'),index=require('../CircleProgress/index.js');const Button = React.forwardRef((_a, ref) => {
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
+ var index$1 = require('../useCorner/index.cjs');
8
+ var index = require('../CircleProgress/index.cjs');
9
+
10
+ const Button = React.forwardRef((_a, ref) => {
2
11
  var _b;
3
12
  var { children } = _a, rest = tslib.__rest(_a, ["children"]);
4
13
  let [_c] = core.useInterface('Button', rest, {
@@ -31,7 +40,7 @@
31
40
  size = p.size;
32
41
  direction = p.direction || "row";
33
42
  const template = core.useColorTemplate(color, variant);
34
- const cornerCss = index$1.default(corner);
43
+ const cornerCss = index$1(corner);
35
44
  const sizes = {
36
45
  small: {
37
46
  height: 40,
@@ -73,5 +82,8 @@
73
82
  display: "flex",
74
83
  justifyContent: "center",
75
84
  alignItems: "center",
76
- }, children: jsxRuntime.jsx(index.default, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.loading, { color: color === 'default' ? `brand` : "default", size: progressSizes[size], className: 'button-loading-progress' })) }), startIcon && jsxRuntime.jsx(core.Tag, { baseClass: 'button-start-icon', component: 'span', display: "inline-block", flexShrink: 0, children: startIcon }), children, endIcon && jsxRuntime.jsx(core.Tag, { baseClass: 'button-end-icon', component: 'span', display: "inline-block", flexShrink: 0, children: endIcon })] })));
77
- });exports.default=Button;//# sourceMappingURL=index.js.map
85
+ }, children: jsxRuntime.jsx(index, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.loading, { color: color === 'default' ? `brand` : "default", size: progressSizes[size], className: 'button-loading-progress' })) }), startIcon && jsxRuntime.jsx(core.Tag, { baseClass: 'button-start-icon', component: 'span', display: "inline-block", flexShrink: 0, children: startIcon }), children, endIcon && jsxRuntime.jsx(core.Tag, { baseClass: 'button-end-icon', component: 'span', display: "inline-block", flexShrink: 0, children: endIcon })] })));
86
+ });
87
+
88
+ module.exports = Button;
89
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Button/index.tsx"],"sourcesContent":["\r\nimport 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\nimport CircleProgress, { CircleProgressProps } from '../CircleProgress'\r\n\r\n\r\nexport type ButtonProps<T extends TagComponentType = 'button'> = Omit<TagProps<T>, \"color\" | \"size\" | \"direction\"> & {\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 direction?: useBreakpointPropsType<\"row\" | \"column\">;\r\n loading?: boolean;\r\n slotProps?: {\r\n loading?: Omit<CircleProgressProps, \"color\" | \"hideTrack\" | \"size\">\r\n }\r\n}\r\n\r\n\r\nconst Button = React.forwardRef(<T extends TagComponentType = 'button'>({ children, ...rest }: ButtonProps<T>, ref: React.Ref<any>) => {\r\n let [{ variant, startIcon, endIcon, color, corner, size, loading, direction, slotProps, ..._props }] = useInterface<any>('Button', rest, {\r\n variant: \"fill\",\r\n color: \"brand\",\r\n corner: \"rounded\",\r\n size: \"medium\"\r\n })\r\n\r\n const _p: any = {}\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 if (direction) _p.direction = direction\r\n const p: any = useBreakpointProps(_p)\r\n\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n color = p.color\r\n variant = p.variant\r\n corner = p.corner\r\n size = p.size\r\n direction = p.direction || \"row\"\r\n\r\n const template = useColorTemplate(color, variant)\r\n const cornerCss = useCorner(corner)\r\n\r\n const sizes: any = {\r\n small: {\r\n height: 40,\r\n px: (startIcon || endIcon) ? 1 : 1.5,\r\n gap: .5,\r\n fontSize: 'button'\r\n },\r\n medium: {\r\n height: 46,\r\n px: (startIcon || endIcon) ? 1.5 : 2,\r\n gap: 1,\r\n fontSize: 'button'\r\n },\r\n large: {\r\n height: 52,\r\n px: (startIcon || endIcon) ? 2 : 3,\r\n gap: 1,\r\n fontSize: \"text\"\r\n }\r\n }\r\n\r\n const progressSizes: any = {\r\n small: 20,\r\n medium: 25,\r\n large: 30\r\n }\r\n\r\n let _size = (sizes[size as any] || {})\r\n if (direction === 'column') {\r\n delete _size.height\r\n _size.gap = .5\r\n _size.py = 1\r\n }\r\n\r\n return (\r\n <Tag\r\n component='button'\r\n baseClass='button'\r\n {..._props}\r\n sxr={{\r\n flexShrink: \"0\",\r\n whiteSpace: \"nowrap\",\r\n cursor: \"pointer\",\r\n display: \"flex\",\r\n textTransform: \"uppercase\",\r\n flexDirection: direction,\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n position: \"relative\",\r\n overflow: \"hidden\",\r\n userSelect: \"none\",\r\n fontWeight: 500,\r\n ..._size,\r\n ...cornerCss,\r\n ...template.primary,\r\n\r\n }}\r\n hover={{\r\n ...template.secondary,\r\n ...((_props as any)?.hover || {})\r\n }}\r\n disabled={loading ?? _props.disabled ?? false}\r\n ref={ref}\r\n >\r\n {loading && <Tag\r\n baseClass='button-loading-container'\r\n sxr={{\r\n position: \"absolute\",\r\n top: 0,\r\n left: 0,\r\n right: 0,\r\n bottom: 0,\r\n zIndex: 1,\r\n display: \"flex\",\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n <CircleProgress\r\n {...slotProps?.loading}\r\n color={color === 'default' ? `brand` : \"default\"}\r\n size={progressSizes[size]}\r\n className='button-loading-progress'\r\n />\r\n </Tag>}\r\n {startIcon && <Tag\r\n baseClass='button-start-icon'\r\n component='span'\r\n display=\"inline-block\"\r\n flexShrink={0}\r\n >{startIcon}</Tag>}\r\n {children}\r\n {endIcon && <Tag\r\n baseClass='button-end-icon'\r\n component='span'\r\n display=\"inline-block\"\r\n flexShrink={0}\r\n >{endIcon}</Tag>}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default Button\r\n"],"names":["__rest","useInterface","useBreakpointProps","useColorTemplate","useCorner","_jsxs","Tag","_jsx","CircleProgress"],"mappings":";;;;;;;;;AAsBA,MAAM,MAAM,GAAG,KAAK,CAAC,UAAU,CAAC,CAAwC,EAAqC,EAAE,GAAmB,KAAI;;AAA9D,IAAA,IAAA,EAAE,QAAQ,EAAA,GAAA,EAA2B,EAAtB,IAAI,GAAAA,YAAA,CAAA,EAAA,EAAnB,YAAqB,CAAF;AACvF,IAAA,IAAI,OAAmGC,iBAAY,CAAM,QAAQ,EAAE,IAAI,EAAE;AACrI,QAAA,OAAO,EAAE,MAAM;AACf,QAAA,KAAK,EAAE,OAAO;AACd,QAAA,MAAM,EAAE,SAAS;AACjB,QAAA,IAAI,EAAE;KACT,CAAC,EALG,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAA,GAAA,EAAa,EAAR,MAAM,GAAAD,YAAA,CAAA,EAAA,EAA5F,CAAA,SAAA,EAAA,WAAA,EAAA,SAAA,EAAA,OAAA,EAAA,QAAA,EAAA,MAAA,EAAA,SAAA,EAAA,WAAA,EAAA,WAAA,CAA8F,CAKjG;IAEF,MAAM,EAAE,GAAQ,EAAE;AAClB,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,IAAI,SAAS;AAAE,QAAA,EAAE,CAAC,SAAS,GAAG,SAAS;AACvC,IAAA,MAAM,CAAC,GAAQE,uBAAkB,CAAC,EAAE,CAAC;AAErC,IAAA,SAAS,GAAG,CAAC,CAAC,SAAS;AACvB,IAAA,OAAO,GAAG,CAAC,CAAC,OAAO;AACnB,IAAA,KAAK,GAAG,CAAC,CAAC,KAAK;AACf,IAAA,OAAO,GAAG,CAAC,CAAC,OAAO;AACnB,IAAA,MAAM,GAAG,CAAC,CAAC,MAAM;AACjB,IAAA,IAAI,GAAG,CAAC,CAAC,IAAI;AACb,IAAA,SAAS,GAAG,CAAC,CAAC,SAAS,IAAI,KAAK;IAEhC,MAAM,QAAQ,GAAGC,qBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC;AACjD,IAAA,MAAM,SAAS,GAAGC,OAAS,CAAC,MAAM,CAAC;AAEnC,IAAA,MAAM,KAAK,GAAQ;AACf,QAAA,KAAK,EAAE;AACH,YAAA,MAAM,EAAE,EAAE;AACV,YAAA,EAAE,EAAE,CAAC,SAAS,IAAI,OAAO,IAAI,CAAC,GAAG,GAAG;AACpC,YAAA,GAAG,EAAE,EAAE;AACP,YAAA,QAAQ,EAAE;AACb,SAAA;AACD,QAAA,MAAM,EAAE;AACJ,YAAA,MAAM,EAAE,EAAE;AACV,YAAA,EAAE,EAAE,CAAC,SAAS,IAAI,OAAO,IAAI,GAAG,GAAG,CAAC;AACpC,YAAA,GAAG,EAAE,CAAC;AACN,YAAA,QAAQ,EAAE;AACb,SAAA;AACD,QAAA,KAAK,EAAE;AACH,YAAA,MAAM,EAAE,EAAE;AACV,YAAA,EAAE,EAAE,CAAC,SAAS,IAAI,OAAO,IAAI,CAAC,GAAG,CAAC;AAClC,YAAA,GAAG,EAAE,CAAC;AACN,YAAA,QAAQ,EAAE;AACb;KACJ;AAED,IAAA,MAAM,aAAa,GAAQ;AACvB,QAAA,KAAK,EAAE,EAAE;AACT,QAAA,MAAM,EAAE,EAAE;AACV,QAAA,KAAK,EAAE;KACV;IAED,IAAI,KAAK,IAAI,KAAK,CAAC,IAAW,CAAC,IAAI,EAAE,CAAC;AACtC,IAAA,IAAI,SAAS,KAAK,QAAQ,EAAE;QACxB,OAAO,KAAK,CAAC,MAAM;AACnB,QAAA,KAAK,CAAC,GAAG,GAAG,EAAE;AACd,QAAA,KAAK,CAAC,EAAE,GAAG,CAAC;IAChB;IAEA,QACIC,eAAA,CAACC,QAAG,EAAA,MAAA,CAAA,MAAA,CAAA,EACA,SAAS,EAAC,QAAQ,EAClB,SAAS,EAAC,QAAQ,EAAA,EACd,MAAM,EAAA,EACV,GAAG,EAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EACC,UAAU,EAAE,GAAG,EACf,UAAU,EAAE,QAAQ,EACpB,MAAM,EAAE,SAAS,EACjB,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,WAAW,EAC1B,aAAa,EAAE,SAAS,EACxB,UAAU,EAAE,QAAQ,EACpB,cAAc,EAAE,QAAQ,EACxB,QAAQ,EAAE,UAAU,EACpB,QAAQ,EAAE,QAAQ,EAClB,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,GAAG,EAAA,EACZ,KAAK,CAAA,EACL,SAAS,CAAA,EACT,QAAQ,CAAC,OAAO,CAAA,EAGvB,KAAK,EAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACE,QAAQ,CAAC,SAAS,CAAA,GACjB,CAAC,MAAc,KAAA,IAAA,IAAd,MAAM,KAAA,MAAA,GAAA,MAAA,GAAN,MAAM,CAAU,KAAK,KAAI,EAAE,EAAC,EAErC,QAAQ,EAAE,CAAA,EAAA,GAAA,OAAO,KAAA,IAAA,IAAP,OAAO,KAAA,MAAA,GAAP,OAAO,GAAI,MAAM,CAAC,QAAQ,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,KAAK,EAC7C,GAAG,EAAE,GAAG,EAAA,QAAA,EAAA,CAEP,OAAO,IAAIC,cAAA,CAACD,QAAG,EAAA,EACZ,SAAS,EAAC,0BAA0B,EACpC,GAAG,EAAE;AACD,oBAAA,QAAQ,EAAE,UAAU;AACpB,oBAAA,GAAG,EAAE,CAAC;AACN,oBAAA,IAAI,EAAE,CAAC;AACP,oBAAA,KAAK,EAAE,CAAC;AACR,oBAAA,MAAM,EAAE,CAAC;AACT,oBAAA,MAAM,EAAE,CAAC;AACT,oBAAA,OAAO,EAAE,MAAM;AACf,oBAAA,cAAc,EAAE,QAAQ;AACxB,oBAAA,UAAU,EAAE,QAAQ;AACvB,iBAAA,EAAA,QAAA,EAEDC,eAACC,KAAc,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACP,SAAS,KAAA,IAAA,IAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,EAAA,EACtB,KAAK,EAAE,KAAK,KAAK,SAAS,GAAG,CAAA,KAAA,CAAO,GAAG,SAAS,EAChD,IAAI,EAAE,aAAa,CAAC,IAAI,CAAC,EACzB,SAAS,EAAC,yBAAyB,IACrC,EAAA,CACA,EACL,SAAS,IAAID,cAAA,CAACD,QAAG,EAAA,EACd,SAAS,EAAC,mBAAmB,EAC7B,SAAS,EAAC,MAAM,EAChB,OAAO,EAAC,cAAc,EACtB,UAAU,EAAE,CAAC,YACf,SAAS,EAAA,CAAO,EACjB,QAAQ,EACR,OAAO,IAAIC,cAAA,CAACD,QAAG,EAAA,EACZ,SAAS,EAAC,iBAAiB,EAC3B,SAAS,EAAC,MAAM,EAChB,OAAO,EAAC,cAAc,EACtB,UAAU,EAAE,CAAC,EAAA,QAAA,EACf,OAAO,EAAA,CAAO,CAAA,EAAA,CAAA,CACd;AAEd,CAAC;;;;"}
package/Button/index.mjs CHANGED
@@ -1,4 +1,11 @@
1
- import {__rest}from'tslib';import {jsxs,jsx}from'react/jsx-runtime';import React from'react';import {useInterface,useBreakpointProps,useColorTemplate,Tag}from'@xanui/core';import useCorner from'../useCorner/index.mjs';import CircleProgress from'../CircleProgress/index.mjs';const Button = React.forwardRef((_a, ref) => {
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
+ import CircleProgress from '../CircleProgress/index.mjs';
7
+
8
+ const Button = React.forwardRef((_a, ref) => {
2
9
  var _b;
3
10
  var { children } = _a, rest = __rest(_a, ["children"]);
4
11
  let [_c] = useInterface('Button', rest, {
@@ -74,4 +81,7 @@ import {__rest}from'tslib';import {jsxs,jsx}from'react/jsx-runtime';import React
74
81
  justifyContent: "center",
75
82
  alignItems: "center",
76
83
  }, children: jsx(CircleProgress, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.loading, { color: color === 'default' ? `brand` : "default", size: progressSizes[size], className: 'button-loading-progress' })) }), startIcon && jsx(Tag, { baseClass: 'button-start-icon', component: 'span', display: "inline-block", flexShrink: 0, children: startIcon }), children, endIcon && jsx(Tag, { baseClass: 'button-end-icon', component: 'span', display: "inline-block", flexShrink: 0, children: endIcon })] })));
77
- });export{Button as default};//# sourceMappingURL=index.mjs.map
84
+ });
85
+
86
+ export { Button as default };
87
+ //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/Button/index.tsx"],"sourcesContent":["\nimport React, { ReactElement } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, UseColorTemplateColor, UseColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\nimport useCorner, { UseCornerTypes } from '../useCorner'\nimport CircleProgress, { CircleProgressProps } from '../CircleProgress'\n\n\nexport type ButtonProps<T extends TagComponentType = 'button'> = Omit<TagProps<T>, \"color\" | \"size\" | \"direction\"> & {\n startIcon?: useBreakpointPropsType<ReactElement>;\n endIcon?: useBreakpointPropsType<ReactElement>;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n variant?: useBreakpointPropsType<UseColorTemplateType>;\n corner?: useBreakpointPropsType<UseCornerTypes>;\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\n direction?: useBreakpointPropsType<\"row\" | \"column\">;\n loading?: boolean;\n slotProps?: {\n loading?: Omit<CircleProgressProps, \"color\" | \"hideTrack\" | \"size\">\n }\n}\n\n\nconst Button = React.forwardRef(<T extends TagComponentType = 'button'>({ children, ...rest }: ButtonProps<T>, ref: React.Ref<any>) => {\n let [{ variant, startIcon, endIcon, color, corner, size, loading, direction, slotProps, ..._props }] = useInterface<any>('Button', rest, {\n variant: \"fill\",\n color: \"brand\",\n corner: \"rounded\",\n size: \"medium\"\n })\n\n const _p: any = {}\n if (startIcon) _p.startIcon = startIcon\n if (endIcon) _p.endIcon = endIcon\n if (color) _p.color = color\n if (variant) _p.variant = variant\n if (corner) _p.corner = corner\n if (size) _p.size = size\n if (direction) _p.direction = direction\n const p: any = useBreakpointProps(_p)\n\n startIcon = p.startIcon\n endIcon = p.endIcon\n color = p.color\n variant = p.variant\n corner = p.corner\n size = p.size\n direction = p.direction || \"row\"\n\n const template = useColorTemplate(color, variant)\n const cornerCss = useCorner(corner)\n\n const sizes: any = {\n small: {\n height: 40,\n px: (startIcon || endIcon) ? 1 : 1.5,\n gap: .5,\n fontSize: 'button'\n },\n medium: {\n height: 46,\n px: (startIcon || endIcon) ? 1.5 : 2,\n gap: 1,\n fontSize: 'button'\n },\n large: {\n height: 52,\n px: (startIcon || endIcon) ? 2 : 3,\n gap: 1,\n fontSize: \"text\"\n }\n }\n\n const progressSizes: any = {\n small: 20,\n medium: 25,\n large: 30\n }\n\n let _size = (sizes[size as any] || {})\n if (direction === 'column') {\n delete _size.height\n _size.gap = .5\n _size.py = 1\n }\n\n return (\n <Tag\n component='button'\n baseClass='button'\n {..._props}\n sxr={{\n flexShrink: \"0\",\n whiteSpace: \"nowrap\",\n cursor: \"pointer\",\n display: \"flex\",\n textTransform: \"uppercase\",\n flexDirection: direction,\n alignItems: \"center\",\n justifyContent: \"center\",\n position: \"relative\",\n overflow: \"hidden\",\n userSelect: \"none\",\n fontWeight: 500,\n ..._size,\n ...cornerCss,\n ...template.primary,\n\n }}\n hover={{\n ...template.secondary,\n ...((_props as any)?.hover || {})\n }}\n disabled={loading ?? _props.disabled ?? false}\n ref={ref}\n >\n {loading && <Tag\n baseClass='button-loading-container'\n sxr={{\n position: \"absolute\",\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n zIndex: 1,\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n }}\n >\n <CircleProgress\n {...slotProps?.loading}\n color={color === 'default' ? `brand` : \"default\"}\n size={progressSizes[size]}\n className='button-loading-progress'\n />\n </Tag>}\n {startIcon && <Tag\n baseClass='button-start-icon'\n component='span'\n display=\"inline-block\"\n flexShrink={0}\n >{startIcon}</Tag>}\n {children}\n {endIcon && <Tag\n baseClass='button-end-icon'\n component='span'\n display=\"inline-block\"\n flexShrink={0}\n >{endIcon}</Tag>}\n </Tag>\n )\n})\n\nexport default Button\n"],"names":["_jsxs","_jsx"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/Button/index.tsx"],"sourcesContent":["\r\nimport 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\nimport CircleProgress, { CircleProgressProps } from '../CircleProgress'\r\n\r\n\r\nexport type ButtonProps<T extends TagComponentType = 'button'> = Omit<TagProps<T>, \"color\" | \"size\" | \"direction\"> & {\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 direction?: useBreakpointPropsType<\"row\" | \"column\">;\r\n loading?: boolean;\r\n slotProps?: {\r\n loading?: Omit<CircleProgressProps, \"color\" | \"hideTrack\" | \"size\">\r\n }\r\n}\r\n\r\n\r\nconst Button = React.forwardRef(<T extends TagComponentType = 'button'>({ children, ...rest }: ButtonProps<T>, ref: React.Ref<any>) => {\r\n let [{ variant, startIcon, endIcon, color, corner, size, loading, direction, slotProps, ..._props }] = useInterface<any>('Button', rest, {\r\n variant: \"fill\",\r\n color: \"brand\",\r\n corner: \"rounded\",\r\n size: \"medium\"\r\n })\r\n\r\n const _p: any = {}\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 if (direction) _p.direction = direction\r\n const p: any = useBreakpointProps(_p)\r\n\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n color = p.color\r\n variant = p.variant\r\n corner = p.corner\r\n size = p.size\r\n direction = p.direction || \"row\"\r\n\r\n const template = useColorTemplate(color, variant)\r\n const cornerCss = useCorner(corner)\r\n\r\n const sizes: any = {\r\n small: {\r\n height: 40,\r\n px: (startIcon || endIcon) ? 1 : 1.5,\r\n gap: .5,\r\n fontSize: 'button'\r\n },\r\n medium: {\r\n height: 46,\r\n px: (startIcon || endIcon) ? 1.5 : 2,\r\n gap: 1,\r\n fontSize: 'button'\r\n },\r\n large: {\r\n height: 52,\r\n px: (startIcon || endIcon) ? 2 : 3,\r\n gap: 1,\r\n fontSize: \"text\"\r\n }\r\n }\r\n\r\n const progressSizes: any = {\r\n small: 20,\r\n medium: 25,\r\n large: 30\r\n }\r\n\r\n let _size = (sizes[size as any] || {})\r\n if (direction === 'column') {\r\n delete _size.height\r\n _size.gap = .5\r\n _size.py = 1\r\n }\r\n\r\n return (\r\n <Tag\r\n component='button'\r\n baseClass='button'\r\n {..._props}\r\n sxr={{\r\n flexShrink: \"0\",\r\n whiteSpace: \"nowrap\",\r\n cursor: \"pointer\",\r\n display: \"flex\",\r\n textTransform: \"uppercase\",\r\n flexDirection: direction,\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n position: \"relative\",\r\n overflow: \"hidden\",\r\n userSelect: \"none\",\r\n fontWeight: 500,\r\n ..._size,\r\n ...cornerCss,\r\n ...template.primary,\r\n\r\n }}\r\n hover={{\r\n ...template.secondary,\r\n ...((_props as any)?.hover || {})\r\n }}\r\n disabled={loading ?? _props.disabled ?? false}\r\n ref={ref}\r\n >\r\n {loading && <Tag\r\n baseClass='button-loading-container'\r\n sxr={{\r\n position: \"absolute\",\r\n top: 0,\r\n left: 0,\r\n right: 0,\r\n bottom: 0,\r\n zIndex: 1,\r\n display: \"flex\",\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n <CircleProgress\r\n {...slotProps?.loading}\r\n color={color === 'default' ? `brand` : \"default\"}\r\n size={progressSizes[size]}\r\n className='button-loading-progress'\r\n />\r\n </Tag>}\r\n {startIcon && <Tag\r\n baseClass='button-start-icon'\r\n component='span'\r\n display=\"inline-block\"\r\n flexShrink={0}\r\n >{startIcon}</Tag>}\r\n {children}\r\n {endIcon && <Tag\r\n baseClass='button-end-icon'\r\n component='span'\r\n display=\"inline-block\"\r\n flexShrink={0}\r\n >{endIcon}</Tag>}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default Button\r\n"],"names":["_jsxs","_jsx"],"mappings":"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"}
@@ -1,4 +1,11 @@
1
- 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var tslib=require('tslib'),jsxRuntime=require('react/jsx-runtime'),React=require('react'),core=require('@xanui/core');const ButtonGroup = React.forwardRef((_a, ref) => {
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 ButtonGroup = React.forwardRef((_a, ref) => {
2
9
  var { children } = _a, rest = tslib.__rest(_a, ["children"]);
3
10
  let [_b] = core.useInterface("ButtonGroup", rest, {
4
11
  size: "medium",
@@ -45,4 +52,7 @@
45
52
  corner: "squar",
46
53
  });
47
54
  }) })));
48
- });exports.default=ButtonGroup;//# sourceMappingURL=index.js.map
55
+ });
56
+
57
+ module.exports = ButtonGroup;
58
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/ButtonGroup/index.tsx"],"sourcesContent":["\r\nimport React, { ReactElement, Children, cloneElement } from 'react';\r\nimport { Tag, TagProps, TagComponentType, useInterface, UseColorTemplateColor, UseColorTemplateType, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\r\nimport { ButtonProps } from '../Button';\r\n\r\nexport type ButtonGroupProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, 'children' | \"size\"> & {\r\n children?: ReactElement<ButtonProps> | ReactElement<ButtonProps>[];\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\r\n}\r\n\r\nconst ButtonGroup = React.forwardRef(<T extends TagComponentType = \"div\">({ children, ...rest }: ButtonGroupProps<T>, ref: React.Ref<any>) => {\r\n let [{ color, variant, size, ...props }] = useInterface<any>(\"ButtonGroup\", rest, {\r\n size: \"medium\",\r\n variant: \"outline\",\r\n color: \"default\"\r\n })\r\n const _p: any = {}\r\n if (color) _p.color = color\r\n const p: any = useBreakpointProps(_p)\r\n color = p.color\r\n\r\n const sizes: any = {\r\n small: {\r\n height: 40,\r\n },\r\n medium: {\r\n height: 46,\r\n },\r\n large: {\r\n height: 52,\r\n }\r\n }\r\n\r\n let borderColor = color === 'default' ? 'divider.secondary' : `${color}.secondary`\r\n\r\n return (\r\n <Tag\r\n {...props}\r\n {...sizes[size]}\r\n sxr={{\r\n display: \"inline-flex\",\r\n flexWrap: \"nowrap\",\r\n overflow: \"hidden\",\r\n radius: 1,\r\n border: \"1px solid\",\r\n borderColor: borderColor,\r\n '& button, & button:hover': {\r\n borderRight: \"1px solid\",\r\n borderColor: borderColor\r\n },\r\n \"& button:last-child, & button:last-child:hover\": {\r\n borderRight: \"none\"\r\n }\r\n }}\r\n baseClass='button-group'\r\n ref={ref}\r\n >\r\n {Children.map(children, (child: any) => {\r\n return cloneElement(child, {\r\n flex: \"0 0 auto\",\r\n color,\r\n variant,\r\n size,\r\n corner: \"squar\",\r\n })\r\n })}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default ButtonGroup\r\n\r\n\r\n"],"names":["__rest","useInterface","useBreakpointProps","_jsx","Tag","Children","cloneElement"],"mappings":";;;;;;;AAYA,MAAM,WAAW,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,EAA0C,EAAE,GAAmB,KAAI;AAAnE,IAAA,IAAA,EAAE,QAAQ,EAAA,GAAA,EAAgC,EAA3B,IAAI,GAAAA,YAAA,CAAA,EAAA,EAAnB,YAAqB,CAAF;AACzF,IAAA,IAAI,OAAuCC,iBAAY,CAAM,aAAa,EAAE,IAAI,EAAE;AAC9E,QAAA,IAAI,EAAE,QAAQ;AACd,QAAA,OAAO,EAAE,SAAS;AAClB,QAAA,KAAK,EAAE;AACV,KAAA,CAAC,EAJG,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAA,GAAA,EAAY,EAAP,KAAK,GAAAD,YAAA,CAAA,EAAA,EAAhC,CAAA,OAAA,EAAA,SAAA,EAAA,MAAA,CAAkC,CAIrC;IACF,MAAM,EAAE,GAAQ,EAAE;AAClB,IAAA,IAAI,KAAK;AAAE,QAAA,EAAE,CAAC,KAAK,GAAG,KAAK;AAC3B,IAAA,MAAM,CAAC,GAAQE,uBAAkB,CAAC,EAAE,CAAC;AACrC,IAAA,KAAK,GAAG,CAAC,CAAC,KAAK;AAEf,IAAA,MAAM,KAAK,GAAQ;AACf,QAAA,KAAK,EAAE;AACH,YAAA,MAAM,EAAE,EAAE;AACb,SAAA;AACD,QAAA,MAAM,EAAE;AACJ,YAAA,MAAM,EAAE,EAAE;AACb,SAAA;AACD,QAAA,KAAK,EAAE;AACH,YAAA,MAAM,EAAE,EAAE;AACb;KACJ;AAED,IAAA,IAAI,WAAW,GAAG,KAAK,KAAK,SAAS,GAAG,mBAAmB,GAAG,CAAA,EAAG,KAAK,YAAY;AAElF,IAAA,QACIC,cAAA,CAACC,QAAG,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACI,KAAK,EACL,KAAK,CAAC,IAAI,CAAC,EAAA,EACf,GAAG,EAAE;AACD,YAAA,OAAO,EAAE,aAAa;AACtB,YAAA,QAAQ,EAAE,QAAQ;AAClB,YAAA,QAAQ,EAAE,QAAQ;AAClB,YAAA,MAAM,EAAE,CAAC;AACT,YAAA,MAAM,EAAE,WAAW;AACnB,YAAA,WAAW,EAAE,WAAW;AACxB,YAAA,0BAA0B,EAAE;AACxB,gBAAA,WAAW,EAAE,WAAW;AACxB,gBAAA,WAAW,EAAE;AAChB,aAAA;AACD,YAAA,gDAAgD,EAAE;AAC9C,gBAAA,WAAW,EAAE;AAChB;AACJ,SAAA,EACD,SAAS,EAAC,cAAc,EACxB,GAAG,EAAE,GAAG,EAAA,QAAA,EAEPC,cAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,KAAU,KAAI;YACnC,OAAOC,kBAAY,CAAC,KAAK,EAAE;AACvB,gBAAA,IAAI,EAAE,UAAU;gBAChB,KAAK;gBACL,OAAO;gBACP,IAAI;AACJ,gBAAA,MAAM,EAAE,OAAO;AAClB,aAAA,CAAC;QACN,CAAC,CAAC,EAAA,CAAA,CACA;AAEd,CAAC;;;;"}
@@ -1,4 +1,9 @@
1
- import {__rest}from'tslib';import {jsx}from'react/jsx-runtime';import React,{Children,cloneElement}from'react';import {useInterface,useBreakpointProps,Tag}from'@xanui/core';const ButtonGroup = React.forwardRef((_a, ref) => {
1
+ import { __rest } from 'tslib';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import React, { Children, cloneElement } from 'react';
4
+ import { useInterface, useBreakpointProps, Tag } from '@xanui/core';
5
+
6
+ const ButtonGroup = React.forwardRef((_a, ref) => {
2
7
  var { children } = _a, rest = __rest(_a, ["children"]);
3
8
  let [_b] = useInterface("ButtonGroup", rest, {
4
9
  size: "medium",
@@ -45,4 +50,7 @@ import {__rest}from'tslib';import {jsx}from'react/jsx-runtime';import React,{Chi
45
50
  corner: "squar",
46
51
  });
47
52
  }) })));
48
- });export{ButtonGroup as default};//# sourceMappingURL=index.mjs.map
53
+ });
54
+
55
+ export { ButtonGroup as default };
56
+ //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/ButtonGroup/index.tsx"],"sourcesContent":["\nimport React, { ReactElement, Children, cloneElement } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, UseColorTemplateColor, UseColorTemplateType, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\nimport { ButtonProps } from '../Button';\n\nexport type ButtonGroupProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, 'children' | \"size\"> & {\n children?: ReactElement<ButtonProps> | ReactElement<ButtonProps>[];\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n variant?: useBreakpointPropsType<UseColorTemplateType>;\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\n}\n\nconst ButtonGroup = React.forwardRef(<T extends TagComponentType = \"div\">({ children, ...rest }: ButtonGroupProps<T>, ref: React.Ref<any>) => {\n let [{ color, variant, size, ...props }] = useInterface<any>(\"ButtonGroup\", rest, {\n size: \"medium\",\n variant: \"outline\",\n color: \"default\"\n })\n const _p: any = {}\n if (color) _p.color = color\n const p: any = useBreakpointProps(_p)\n color = p.color\n\n const sizes: any = {\n small: {\n height: 40,\n },\n medium: {\n height: 46,\n },\n large: {\n height: 52,\n }\n }\n\n let borderColor = color === 'default' ? 'divider.secondary' : `${color}.secondary`\n\n return (\n <Tag\n {...props}\n {...sizes[size]}\n sxr={{\n display: \"inline-flex\",\n flexWrap: \"nowrap\",\n overflow: \"hidden\",\n radius: 1,\n border: \"1px solid\",\n borderColor: borderColor,\n '& button, & button:hover': {\n borderRight: \"1px solid\",\n borderColor: borderColor\n },\n \"& button:last-child, & button:last-child:hover\": {\n borderRight: \"none\"\n }\n }}\n baseClass='button-group'\n ref={ref}\n >\n {Children.map(children, (child: any) => {\n return cloneElement(child, {\n flex: \"0 0 auto\",\n color,\n variant,\n size,\n corner: \"squar\",\n })\n })}\n </Tag>\n )\n})\n\nexport default ButtonGroup\n\n\n"],"names":["_jsx"],"mappings":"6KAYA,MAAM,WAAW,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,EAA0C,EAAE,GAAmB,KAAI;AAAnE,IAAA,IAAA,EAAE,QAAQ,EAAA,GAAA,EAAgC,EAA3B,IAAI,GAAA,MAAA,CAAA,EAAA,EAAnB,YAAqB,CAAF;AACzF,IAAA,IAAI,OAAuC,YAAY,CAAM,aAAa,EAAE,IAAI,EAAE;AAC9E,QAAA,IAAI,EAAE,QAAQ;AACd,QAAA,OAAO,EAAE,SAAS;AAClB,QAAA,KAAK,EAAE;AACV,KAAA,CAAC,EAJG,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAA,GAAA,EAAY,EAAP,KAAK,GAAA,MAAA,CAAA,EAAA,EAAhC,CAAA,OAAA,EAAA,SAAA,EAAA,MAAA,CAAkC,CAIrC;IACF,MAAM,EAAE,GAAQ,EAAE;AAClB,IAAA,IAAI,KAAK;AAAE,QAAA,EAAE,CAAC,KAAK,GAAG,KAAK;AAC3B,IAAA,MAAM,CAAC,GAAQ,kBAAkB,CAAC,EAAE,CAAC;AACrC,IAAA,KAAK,GAAG,CAAC,CAAC,KAAK;AAEf,IAAA,MAAM,KAAK,GAAQ;AACf,QAAA,KAAK,EAAE;AACH,YAAA,MAAM,EAAE,EAAE;AACb,SAAA;AACD,QAAA,MAAM,EAAE;AACJ,YAAA,MAAM,EAAE,EAAE;AACb,SAAA;AACD,QAAA,KAAK,EAAE;AACH,YAAA,MAAM,EAAE,EAAE;AACb;KACJ;AAED,IAAA,IAAI,WAAW,GAAG,KAAK,KAAK,SAAS,GAAG,mBAAmB,GAAG,CAAA,EAAG,KAAK,YAAY;AAElF,IAAA,QACIA,GAAA,CAAC,GAAG,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACI,KAAK,EACL,KAAK,CAAC,IAAI,CAAC,EAAA,EACf,GAAG,EAAE;AACD,YAAA,OAAO,EAAE,aAAa;AACtB,YAAA,QAAQ,EAAE,QAAQ;AAClB,YAAA,QAAQ,EAAE,QAAQ;AAClB,YAAA,MAAM,EAAE,CAAC;AACT,YAAA,MAAM,EAAE,WAAW;AACnB,YAAA,WAAW,EAAE,WAAW;AACxB,YAAA,0BAA0B,EAAE;AACxB,gBAAA,WAAW,EAAE,WAAW;AACxB,gBAAA,WAAW,EAAE;AAChB,aAAA;AACD,YAAA,gDAAgD,EAAE;AAC9C,gBAAA,WAAW,EAAE;AAChB;AACJ,SAAA,EACD,SAAS,EAAC,cAAc,EACxB,GAAG,EAAE,GAAG,EAAA,QAAA,EAEP,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,KAAU,KAAI;YACnC,OAAO,YAAY,CAAC,KAAK,EAAE;AACvB,gBAAA,IAAI,EAAE,UAAU;gBAChB,KAAK;gBACL,OAAO;gBACP,IAAI;AACJ,gBAAA,MAAM,EAAE,OAAO;AAClB,aAAA,CAAC;QACN,CAAC,CAAC,EAAA,CAAA,CACA;AAEd,CAAC"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/ButtonGroup/index.tsx"],"sourcesContent":["\r\nimport React, { ReactElement, Children, cloneElement } from 'react';\r\nimport { Tag, TagProps, TagComponentType, useInterface, UseColorTemplateColor, UseColorTemplateType, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\r\nimport { ButtonProps } from '../Button';\r\n\r\nexport type ButtonGroupProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, 'children' | \"size\"> & {\r\n children?: ReactElement<ButtonProps> | ReactElement<ButtonProps>[];\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\r\n}\r\n\r\nconst ButtonGroup = React.forwardRef(<T extends TagComponentType = \"div\">({ children, ...rest }: ButtonGroupProps<T>, ref: React.Ref<any>) => {\r\n let [{ color, variant, size, ...props }] = useInterface<any>(\"ButtonGroup\", rest, {\r\n size: \"medium\",\r\n variant: \"outline\",\r\n color: \"default\"\r\n })\r\n const _p: any = {}\r\n if (color) _p.color = color\r\n const p: any = useBreakpointProps(_p)\r\n color = p.color\r\n\r\n const sizes: any = {\r\n small: {\r\n height: 40,\r\n },\r\n medium: {\r\n height: 46,\r\n },\r\n large: {\r\n height: 52,\r\n }\r\n }\r\n\r\n let borderColor = color === 'default' ? 'divider.secondary' : `${color}.secondary`\r\n\r\n return (\r\n <Tag\r\n {...props}\r\n {...sizes[size]}\r\n sxr={{\r\n display: \"inline-flex\",\r\n flexWrap: \"nowrap\",\r\n overflow: \"hidden\",\r\n radius: 1,\r\n border: \"1px solid\",\r\n borderColor: borderColor,\r\n '& button, & button:hover': {\r\n borderRight: \"1px solid\",\r\n borderColor: borderColor\r\n },\r\n \"& button:last-child, & button:last-child:hover\": {\r\n borderRight: \"none\"\r\n }\r\n }}\r\n baseClass='button-group'\r\n ref={ref}\r\n >\r\n {Children.map(children, (child: any) => {\r\n return cloneElement(child, {\r\n flex: \"0 0 auto\",\r\n color,\r\n variant,\r\n size,\r\n corner: \"squar\",\r\n })\r\n })}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default ButtonGroup\r\n\r\n\r\n"],"names":["_jsx"],"mappings":";;;;;AAYA,MAAM,WAAW,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,EAA0C,EAAE,GAAmB,KAAI;AAAnE,IAAA,IAAA,EAAE,QAAQ,EAAA,GAAA,EAAgC,EAA3B,IAAI,GAAA,MAAA,CAAA,EAAA,EAAnB,YAAqB,CAAF;AACzF,IAAA,IAAI,OAAuC,YAAY,CAAM,aAAa,EAAE,IAAI,EAAE;AAC9E,QAAA,IAAI,EAAE,QAAQ;AACd,QAAA,OAAO,EAAE,SAAS;AAClB,QAAA,KAAK,EAAE;AACV,KAAA,CAAC,EAJG,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAA,GAAA,EAAY,EAAP,KAAK,GAAA,MAAA,CAAA,EAAA,EAAhC,CAAA,OAAA,EAAA,SAAA,EAAA,MAAA,CAAkC,CAIrC;IACF,MAAM,EAAE,GAAQ,EAAE;AAClB,IAAA,IAAI,KAAK;AAAE,QAAA,EAAE,CAAC,KAAK,GAAG,KAAK;AAC3B,IAAA,MAAM,CAAC,GAAQ,kBAAkB,CAAC,EAAE,CAAC;AACrC,IAAA,KAAK,GAAG,CAAC,CAAC,KAAK;AAEf,IAAA,MAAM,KAAK,GAAQ;AACf,QAAA,KAAK,EAAE;AACH,YAAA,MAAM,EAAE,EAAE;AACb,SAAA;AACD,QAAA,MAAM,EAAE;AACJ,YAAA,MAAM,EAAE,EAAE;AACb,SAAA;AACD,QAAA,KAAK,EAAE;AACH,YAAA,MAAM,EAAE,EAAE;AACb;KACJ;AAED,IAAA,IAAI,WAAW,GAAG,KAAK,KAAK,SAAS,GAAG,mBAAmB,GAAG,CAAA,EAAG,KAAK,YAAY;AAElF,IAAA,QACIA,GAAA,CAAC,GAAG,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACI,KAAK,EACL,KAAK,CAAC,IAAI,CAAC,EAAA,EACf,GAAG,EAAE;AACD,YAAA,OAAO,EAAE,aAAa;AACtB,YAAA,QAAQ,EAAE,QAAQ;AAClB,YAAA,QAAQ,EAAE,QAAQ;AAClB,YAAA,MAAM,EAAE,CAAC;AACT,YAAA,MAAM,EAAE,WAAW;AACnB,YAAA,WAAW,EAAE,WAAW;AACxB,YAAA,0BAA0B,EAAE;AACxB,gBAAA,WAAW,EAAE,WAAW;AACxB,gBAAA,WAAW,EAAE;AAChB,aAAA;AACD,YAAA,gDAAgD,EAAE;AAC9C,gBAAA,WAAW,EAAE;AAChB;AACJ,SAAA,EACD,SAAS,EAAC,cAAc,EACxB,GAAG,EAAE,GAAG,EAAA,QAAA,EAEP,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,KAAU,KAAI;YACnC,OAAO,YAAY,CAAC,KAAK,EAAE;AACvB,gBAAA,IAAI,EAAE,UAAU;gBAChB,KAAK;gBACL,OAAO;gBACP,IAAI;AACJ,gBAAA,MAAM,EAAE,OAAO;AAClB,aAAA,CAAC;QACN,CAAC,CAAC,EAAA,CAAA,CACA;AAEd,CAAC;;;;"}
@@ -1,21 +1,36 @@
1
- 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var tslib=require('tslib'),jsxRuntime=require('react/jsx-runtime'),React=require('react'),index=require('../Stack/index.js'),index$3=require('../IconButton/index.js'),IconKeyboardArrowRight=require('@xanui/icons/KeyboardArrowRight'),IconKeyboardArrowLeft=require('@xanui/icons/KeyboardArrowLeft'),index$1=require('../Text/index.js'),index$4=require('../Button/index.js'),ResetIcon=require('@xanui/icons/Replay'),index$2=require('../ViewBox/index.js'),core=require('@xanui/core');const ShowYears = ({ color, year, today, boxWidth, onClick }) => {
1
+ 'use strict';
2
+
3
+ var tslib = require('tslib');
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var React = require('react');
6
+ var index = require('../Stack/index.cjs');
7
+ var index$3 = require('../IconButton/index.cjs');
8
+ var IconKeyboardArrowRight = require('@xanui/icons/KeyboardArrowRight');
9
+ var IconKeyboardArrowLeft = require('@xanui/icons/KeyboardArrowLeft');
10
+ var index$1 = require('../Text/index.cjs');
11
+ var index$4 = require('../Button/index.cjs');
12
+ var ResetIcon = require('@xanui/icons/Replay');
13
+ var index$2 = require('../ViewBox/index.cjs');
14
+ var core = require('@xanui/core');
15
+
16
+ const ShowYears = ({ color, year, today, boxWidth, onClick }) => {
2
17
  let years = [];
3
18
  const selectedRef = React.useRef(null);
4
19
  for (let y = 1900; y < today.getFullYear() + 40; y++) {
5
20
  const selected = year == y;
6
- years.push(jsxRuntime.jsx(index.default, { sx: {
21
+ years.push(jsxRuntime.jsx(index, { sx: {
7
22
  width: (boxWidth - 12) / 3,
8
23
  alignItems: "center",
9
24
  justifyContent: "center",
10
25
  p: .1
11
- }, className: 'calender-year-item', children: jsxRuntime.jsx(index$4.default, { color: selected ? color : "default", className: 'calender-year-button', size: 'small', corner: "circle", ref: selected ? selectedRef : null, onClick: () => onClick(y), variant: selected ? "fill" : "text", children: y }) }, y));
26
+ }, className: 'calender-year-item', children: jsxRuntime.jsx(index$4, { color: selected ? color : "default", className: 'calender-year-button', size: 'small', corner: "circle", ref: selected ? selectedRef : null, onClick: () => onClick(y), variant: selected ? "fill" : "text", children: y }) }, y));
12
27
  }
13
28
  React.useEffect(() => {
14
29
  if (selectedRef === null || selectedRef === void 0 ? void 0 : selectedRef.current) {
15
30
  selectedRef === null || selectedRef === void 0 ? void 0 : selectedRef.current.scrollIntoView({ behavior: "smooth", block: "center", inline: "nearest" });
16
31
  }
17
32
  }, []);
18
- return (jsxRuntime.jsx(index.default, { sx: {
33
+ return (jsxRuntime.jsx(index, { sx: {
19
34
  flexWrap: "wrap",
20
35
  flexDirection: "row",
21
36
  overflow: "hidden",
@@ -50,7 +65,7 @@ const Calendar = (_a) => {
50
65
  let row = [];
51
66
  for (let j = 0; j < 7; j++) {
52
67
  if (i === 0 && j < firstDay) {
53
- row.push(jsxRuntime.jsx(index.default, { width: btnWidth, height: btnWidth, alignItems: "center", justifyContent: "center" }, date + j + i));
68
+ row.push(jsxRuntime.jsx(index, { width: btnWidth, height: btnWidth, alignItems: "center", justifyContent: "center" }, date + j + i));
54
69
  }
55
70
  else if (date > daysInMonth) {
56
71
  break;
@@ -71,12 +86,12 @@ const Calendar = (_a) => {
71
86
  color: color
72
87
  };
73
88
  }
74
- row.push(jsxRuntime.jsx(index.default, { sx: {
89
+ row.push(jsxRuntime.jsx(index, { sx: {
75
90
  width: btnWidth,
76
91
  height: btnWidth,
77
92
  alignItems: "center",
78
93
  justifyContent: "center"
79
- }, className: 'calender-day-item', children: jsxRuntime.jsx(index$3.default, Object.assign({ className: 'calender-day-button', variant: isSelected ? "fill" : "text", color: isToday ? color : "default" }, css, { "data-value": date, onClick: (e) => {
94
+ }, className: 'calender-day-item', children: jsxRuntime.jsx(index$3, Object.assign({ className: 'calender-day-button', variant: isSelected ? "fill" : "text", color: isToday ? color : "default" }, css, { "data-value": date, onClick: (e) => {
80
95
  let d = e.target.getAttribute("data-value");
81
96
  if (!d)
82
97
  return;
@@ -87,7 +102,7 @@ const Calendar = (_a) => {
87
102
  date++;
88
103
  }
89
104
  }
90
- rows.push(jsxRuntime.jsx(index.default, { flexRow: true, className: 'calender-day-row', children: row }, "row" + i));
105
+ rows.push(jsxRuntime.jsx(index, { flexRow: true, className: 'calender-day-row', children: row }, "row" + i));
91
106
  }
92
107
  return rows;
93
108
  };
@@ -96,7 +111,7 @@ const Calendar = (_a) => {
96
111
  const monthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];
97
112
  for (let m = 0; m < monthNames.length; m++) {
98
113
  const selected = currentDate.getMonth() === m;
99
- months.push(jsxRuntime.jsx(index.default, { width: (boxWidth - 12) / 2, alignItems: "center", justifyContent: "center", p: .1, className: 'calender-months-item', children: jsxRuntime.jsx(index$4.default, { color: selected ? color : "default", className: 'calender-month-button', size: 'small', corner: "circle", variant: selected ? "fill" : 'text', onClick: () => {
114
+ months.push(jsxRuntime.jsx(index, { width: (boxWidth - 12) / 2, alignItems: "center", justifyContent: "center", p: .1, className: 'calender-months-item', children: jsxRuntime.jsx(index$4, { color: selected ? color : "default", className: 'calender-month-button', size: 'small', corner: "circle", variant: selected ? "fill" : 'text', onClick: () => {
100
115
  const v = new Date(currentDate.getFullYear(), m);
101
116
  setCurrentDate(v);
102
117
  setViewMode("day");
@@ -105,7 +120,7 @@ const Calendar = (_a) => {
105
120
  color: selected ? "brand.text" : "text.primary"
106
121
  }, children: monthNames[m] }) }, m));
107
122
  }
108
- return (jsxRuntime.jsx(index.default, { className: 'calender-months', sx: {
123
+ return (jsxRuntime.jsx(index, { className: 'calender-months', sx: {
109
124
  flexWrap: "wrap",
110
125
  overflow: "hidden",
111
126
  overflowY: "auto",
@@ -126,15 +141,18 @@ const Calendar = (_a) => {
126
141
  view = showMonth();
127
142
  break;
128
143
  default:
129
- view = (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(index.default, { flexRow: true, className: 'calender-week-container', children: ['S', 'M', 'T', 'W', 'T', 'F', 'S'].map((day, idx) => (jsxRuntime.jsx(index.default, { width: btnWidth, height: btnWidth, alignItems: "center", justifyContent: "center", children: jsxRuntime.jsx(index$1.default, { fontWeight: 500, fontSize: "button", color: "text.secondary", children: day }) }, day + idx))) }), showCalendar()] }));
144
+ view = (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(index, { flexRow: true, className: 'calender-week-container', children: ['S', 'M', 'T', 'W', 'T', 'F', 'S'].map((day, idx) => (jsxRuntime.jsx(index, { width: btnWidth, height: btnWidth, alignItems: "center", justifyContent: "center", children: jsxRuntime.jsx(index$1, { fontWeight: 500, fontSize: "button", color: "text.secondary", children: day }) }, day + idx))) }), showCalendar()] }));
130
145
  break;
131
146
  }
132
- return (jsxRuntime.jsx(index$2.default, { className: 'calender-root', maxHeight: 308, width: 250, radius: 1, bgcolor: "background.primary", startContent: jsxRuntime.jsxs(index.default, { className: 'calender-header', flexRow: true, alignItems: "center", justifyContent: "space-between", p: 1, children: [jsxRuntime.jsx(index$1.default, { fontWeight: "bold", cursor: "pointer", onClick: () => setViewMode(viewMode !== 'day' ? "day" : "year"), flex: 1, children: currentDate.toLocaleDateString(undefined, { year: 'numeric', month: 'long' }) }), jsxRuntime.jsx(index$3.default, { color: "default", variant: 'text', size: 28, onClick: () => {
147
+ return (jsxRuntime.jsx(index$2, { className: 'calender-root', maxHeight: 308, width: 250, radius: 1, bgcolor: "background.primary", startContent: jsxRuntime.jsxs(index, { className: 'calender-header', flexRow: true, alignItems: "center", justifyContent: "space-between", p: 1, children: [jsxRuntime.jsx(index$1, { fontWeight: "bold", cursor: "pointer", onClick: () => setViewMode(viewMode !== 'day' ? "day" : "year"), flex: 1, children: currentDate.toLocaleDateString(undefined, { year: 'numeric', month: 'long' }) }), jsxRuntime.jsx(index$3, { color: "default", variant: 'text', size: 28, onClick: () => {
133
148
  setCurrentDate(new Date());
134
149
  onChange ? onChange(new Date()) : setSelectedDate(new Date());
135
- }, children: jsxRuntime.jsx(ResetIcon, { fontSize: 20 }) }), jsxRuntime.jsx(index$3.default, { color: "default", variant: 'text', size: 28, onClick: () => {
150
+ }, children: jsxRuntime.jsx(ResetIcon, { fontSize: 20 }) }), jsxRuntime.jsx(index$3, { color: "default", variant: 'text', size: 28, onClick: () => {
136
151
  setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() - 1, 1));
137
- }, children: jsxRuntime.jsx(IconKeyboardArrowLeft, {}) }), jsxRuntime.jsx(index$3.default, { color: "default", variant: 'text', size: 28, onClick: () => {
152
+ }, children: jsxRuntime.jsx(IconKeyboardArrowLeft, {}) }), jsxRuntime.jsx(index$3, { color: "default", variant: 'text', size: 28, onClick: () => {
138
153
  setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() + 1, 1));
139
- }, children: jsxRuntime.jsx(IconKeyboardArrowRight, {}) })] }), children: jsxRuntime.jsx(index.default, { height: "100%", p: .5, className: 'calender-container', children: view }) }));
140
- };exports.default=Calendar;//# sourceMappingURL=index.js.map
154
+ }, children: jsxRuntime.jsx(IconKeyboardArrowRight, {}) })] }), children: jsxRuntime.jsx(index, { height: "100%", p: .5, className: 'calender-container', children: view }) }));
155
+ };
156
+
157
+ module.exports = Calendar;
158
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Calendar/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\r\nimport Stack from '../Stack'\r\nimport IconButton from '../IconButton';\r\nimport IconKeyboardArrowRight from '@xanui/icons/KeyboardArrowRight';\r\nimport IconKeyboardArrowLeft from '@xanui/icons/KeyboardArrowLeft';\r\nimport Text from '../Text';\r\nimport Button from '../Button';\r\nimport ResetIcon from '@xanui/icons/Replay';\r\nimport ViewBox from '../ViewBox';\r\nimport { UseColorTemplateColor, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\r\n\r\nexport type CalendarProps = {\r\n value?: Date | null;\r\n onChange?: (date: Date | null) => void;\r\n viewMode?: useBreakpointPropsType<\"year\" | \"month\" | \"day\">;\r\n onButtonClick?: (mode: CalendarProps[\"viewMode\"], value: CalendarProps[\"value\"]) => void;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n}\r\n\r\n\r\nconst ShowYears = ({ color, year, today, boxWidth, onClick }: any) => {\r\n let years: any[] = []\r\n const selectedRef: any = useRef(null)\r\n for (let y = 1900; y < today.getFullYear() + 40; y++) {\r\n const selected = year == y\r\n years.push(<Stack\r\n key={y}\r\n sx={{\r\n width: (boxWidth - 12) / 3,\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n p: .1\r\n }}\r\n className='calender-year-item'\r\n >\r\n <Button\r\n color={selected ? color : \"default\"}\r\n className='calender-year-button'\r\n size='small'\r\n corner=\"circle\"\r\n ref={selected ? selectedRef : null}\r\n onClick={() => onClick(y)}\r\n variant={selected ? \"fill\" : \"text\"}\r\n >\r\n {y}\r\n </Button>\r\n </Stack>)\r\n }\r\n\r\n useEffect(() => {\r\n if (selectedRef?.current) {\r\n selectedRef?.current.scrollIntoView({ behavior: \"smooth\", block: \"center\", inline: \"nearest\" })\r\n }\r\n }, [])\r\n\r\n return (\r\n <Stack\r\n sx={{\r\n flexWrap: \"wrap\",\r\n flexDirection: \"row\",\r\n overflow: \"hidden\",\r\n overflowY: \"auto\"\r\n }}\r\n className='calender-years'\r\n >\r\n {years}\r\n </Stack>\r\n )\r\n}\r\n\r\n\r\nconst Calendar = ({ value, ...rest }: CalendarProps) => {\r\n let [{ onChange, viewMode: VMode, onButtonClick, color }] = useInterface<any>(\"Calender\", rest, {})\r\n const _p: any = {}\r\n if (VMode) _p.VMode = VMode\r\n if (color) _p.color = color\r\n const p: any = useBreakpointProps(_p)\r\n color = p.color || \"brand\"\r\n\r\n let [viewMode, setViewMode] = useState<any>(p.VMode || \"day\");\r\n let [selectedDate, setSelectedDate] = useState(new Date());\r\n selectedDate = value instanceof Date ? value : selectedDate\r\n const [currentDate, setCurrentDate] = useState(selectedDate);\r\n const year = currentDate.getFullYear()\r\n const month = currentDate.getMonth()\r\n const daysInMonth = 32 - new Date(year, month, 32).getDate()\r\n const today = new Date();\r\n const btnWidth = 32\r\n const boxWidth = btnWidth * 7\r\n\r\n const showCalendar = () => {\r\n\r\n let firstDay = (new Date(year, month)).getDay();\r\n let rows = []\r\n\r\n let date = 1;\r\n for (let i = 0; i < 6; i++) {\r\n let row = []\r\n for (let j = 0; j < 7; j++) {\r\n if (i === 0 && j < firstDay) {\r\n row.push(<Stack\r\n width={btnWidth}\r\n height={btnWidth}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n key={date + j + i}\r\n >\r\n </Stack>)\r\n } else if (date > daysInMonth) {\r\n break;\r\n } else {\r\n let isToday = date === today.getDate() && year === today.getFullYear() && month === today.getMonth()\r\n let isSelected = date === selectedDate.getDate() && year === selectedDate.getFullYear() && month === selectedDate.getMonth()\r\n\r\n let css: any = {}\r\n if (isToday) {\r\n css = {\r\n variant: \"outline\",\r\n color: color\r\n }\r\n }\r\n\r\n if (isSelected) {\r\n css = {\r\n variant: \"fill\",\r\n color: color\r\n }\r\n }\r\n\r\n row.push(<Stack\r\n sx={{\r\n width: btnWidth,\r\n height: btnWidth,\r\n alignItems: \"center\",\r\n justifyContent: \"center\"\r\n }}\r\n key={date + j + i}\r\n className='calender-day-item'\r\n >\r\n <IconButton\r\n className='calender-day-button'\r\n variant={isSelected ? \"fill\" : \"text\"}\r\n color={isToday ? color : \"default\"}\r\n {...css}\r\n data-value={date}\r\n onClick={(e: any) => {\r\n let d = e.target.getAttribute(\"data-value\")\r\n if (!d) return\r\n let selectedDate = new Date(year, month, parseInt(d))\r\n onChange ? onChange(selectedDate) : setSelectedDate(selectedDate)\r\n onButtonClick && onButtonClick(\"day\", selectedDate)\r\n }}\r\n >\r\n {date}\r\n </IconButton>\r\n </Stack>)\r\n date++;\r\n }\r\n }\r\n rows.push(<Stack flexRow key={\"row\" + i} className='calender-day-row'>\r\n {row}\r\n </Stack>);\r\n }\r\n return rows\r\n }\r\n\r\n const showMonth = () => {\r\n let months: any[] = []\r\n const monthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];\r\n for (let m = 0; m < monthNames.length; m++) {\r\n const selected = currentDate.getMonth() === m\r\n\r\n months.push(<Stack\r\n key={m}\r\n width={(boxWidth - 12) / 2}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n p={.1}\r\n className='calender-months-item'\r\n >\r\n <Button\r\n color={selected ? color : \"default\"}\r\n className='calender-month-button'\r\n size='small'\r\n corner=\"circle\"\r\n variant={selected ? \"fill\" : 'text'}\r\n onClick={() => {\r\n const v = new Date(currentDate.getFullYear(), m)\r\n setCurrentDate(v)\r\n setViewMode(\"day\")\r\n onButtonClick && onButtonClick(\"month\", v)\r\n }}\r\n sx={{\r\n color: selected ? \"brand.text\" : \"text.primary\"\r\n }}\r\n >\r\n {monthNames[m]}\r\n </Button>\r\n </Stack>)\r\n }\r\n\r\n return (\r\n <Stack\r\n className='calender-months'\r\n sx={{\r\n flexWrap: \"wrap\",\r\n overflow: \"hidden\",\r\n overflowY: \"auto\",\r\n flexDirection: \"row\"\r\n }}\r\n >\r\n {months}\r\n </Stack>\r\n )\r\n }\r\n\r\n let view: any = null\r\n switch (viewMode) {\r\n case \"year\":\r\n view = <ShowYears\r\n color={color}\r\n today={today}\r\n year={year}\r\n boxWidth={boxWidth}\r\n onClick={(y: any) => {\r\n currentDate.setFullYear(y)\r\n setCurrentDate(currentDate)\r\n setViewMode(\"month\")\r\n onButtonClick && onButtonClick(\"year\", currentDate)\r\n }}\r\n />\r\n break;\r\n case \"month\":\r\n view = showMonth()\r\n break;\r\n default:\r\n view = (<>\r\n <Stack flexRow className='calender-week-container'>\r\n {\r\n ['S', 'M', 'T', 'W', 'T', 'F', 'S'].map((day, idx) => (\r\n <Stack\r\n key={day + idx}\r\n width={btnWidth}\r\n height={btnWidth}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n >\r\n <Text\r\n fontWeight={500}\r\n fontSize=\"button\"\r\n color=\"text.secondary\"\r\n >\r\n {day}\r\n </Text>\r\n </Stack>\r\n ))\r\n }\r\n </Stack>\r\n {showCalendar()}\r\n </>\r\n )\r\n break;\r\n }\r\n\r\n return (\r\n <ViewBox\r\n className='calender-root'\r\n maxHeight={308}\r\n width={250}\r\n radius={1}\r\n bgcolor=\"background.primary\"\r\n startContent={\r\n <Stack className='calender-header' flexRow alignItems=\"center\" justifyContent=\"space-between\" p={1}>\r\n <Text\r\n fontWeight=\"bold\"\r\n cursor=\"pointer\"\r\n onClick={() => setViewMode(viewMode !== 'day' ? \"day\" : \"year\")}\r\n flex={1}\r\n >\r\n {currentDate.toLocaleDateString(undefined, { year: 'numeric', month: 'long' })}\r\n </Text>\r\n <IconButton\r\n color=\"default\"\r\n variant='text'\r\n size={28}\r\n onClick={() => {\r\n setCurrentDate(new Date())\r\n onChange ? onChange(new Date()) : setSelectedDate(new Date())\r\n }}\r\n >\r\n <ResetIcon fontSize={20} />\r\n </IconButton>\r\n <IconButton\r\n color=\"default\"\r\n variant='text'\r\n size={28}\r\n onClick={() => {\r\n setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() - 1, 1))\r\n }}\r\n >\r\n <IconKeyboardArrowLeft />\r\n </IconButton>\r\n <IconButton\r\n color=\"default\"\r\n variant='text'\r\n size={28}\r\n onClick={() => {\r\n setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() + 1, 1))\r\n }}\r\n >\r\n <IconKeyboardArrowRight />\r\n </IconButton>\r\n </Stack>\r\n }\r\n >\r\n <Stack height=\"100%\" p={.5} className='calender-container'>\r\n {view}\r\n </Stack>\r\n </ViewBox>\r\n );\r\n};\r\n\r\nexport default Calendar;"],"names":["useRef","_jsx","Stack","Button","useEffect","__rest","useInterface","useBreakpointProps","useState","IconButton","_jsxs","_Fragment","Text","ViewBox"],"mappings":"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"}
@@ -1,4 +1,17 @@
1
- import {__rest}from'tslib';import {jsxs,Fragment,jsx}from'react/jsx-runtime';import {useState,useRef,useEffect}from'react';import Stack from'../Stack/index.mjs';import IconButton from'../IconButton/index.mjs';import IconKeyboardArrowRight from'@xanui/icons/KeyboardArrowRight';import IconKeyboardArrowLeft from'@xanui/icons/KeyboardArrowLeft';import Text from'../Text/index.mjs';import Button from'../Button/index.mjs';import ResetIcon from'@xanui/icons/Replay';import ViewBox from'../ViewBox/index.mjs';import {useInterface,useBreakpointProps}from'@xanui/core';const ShowYears = ({ color, year, today, boxWidth, onClick }) => {
1
+ import { __rest } from 'tslib';
2
+ import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
3
+ import { useState, useRef, useEffect } from 'react';
4
+ import Stack from '../Stack/index.mjs';
5
+ import IconButton from '../IconButton/index.mjs';
6
+ import IconKeyboardArrowRight from '@xanui/icons/KeyboardArrowRight';
7
+ import IconKeyboardArrowLeft from '@xanui/icons/KeyboardArrowLeft';
8
+ import Text from '../Text/index.mjs';
9
+ import Button from '../Button/index.mjs';
10
+ import ResetIcon from '@xanui/icons/Replay';
11
+ import ViewBox from '../ViewBox/index.mjs';
12
+ import { useInterface, useBreakpointProps } from '@xanui/core';
13
+
14
+ const ShowYears = ({ color, year, today, boxWidth, onClick }) => {
2
15
  let years = [];
3
16
  const selectedRef = useRef(null);
4
17
  for (let y = 1900; y < today.getFullYear() + 40; y++) {
@@ -137,4 +150,7 @@ const Calendar = (_a) => {
137
150
  }, children: jsx(IconKeyboardArrowLeft, {}) }), jsx(IconButton, { color: "default", variant: 'text', size: 28, onClick: () => {
138
151
  setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() + 1, 1));
139
152
  }, children: jsx(IconKeyboardArrowRight, {}) })] }), children: jsx(Stack, { height: "100%", p: .5, className: 'calender-container', children: view }) }));
140
- };export{Calendar as default};//# sourceMappingURL=index.mjs.map
153
+ };
154
+
155
+ export { Calendar as default };
156
+ //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/Calendar/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\nimport Stack from '../Stack'\nimport IconButton from '../IconButton';\nimport IconKeyboardArrowRight from '@xanui/icons/KeyboardArrowRight';\nimport IconKeyboardArrowLeft from '@xanui/icons/KeyboardArrowLeft';\nimport Text from '../Text';\nimport Button from '../Button';\nimport ResetIcon from '@xanui/icons/Replay';\nimport ViewBox from '../ViewBox';\nimport { UseColorTemplateColor, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\n\nexport type CalendarProps = {\n value?: Date | null;\n onChange?: (date: Date | null) => void;\n viewMode?: useBreakpointPropsType<\"year\" | \"month\" | \"day\">;\n onButtonClick?: (mode: CalendarProps[\"viewMode\"], value: CalendarProps[\"value\"]) => void;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n}\n\n\nconst ShowYears = ({ color, year, today, boxWidth, onClick }: any) => {\n let years: any[] = []\n const selectedRef: any = useRef(null)\n for (let y = 1900; y < today.getFullYear() + 40; y++) {\n const selected = year == y\n years.push(<Stack\n key={y}\n sx={{\n width: (boxWidth - 12) / 3,\n alignItems: \"center\",\n justifyContent: \"center\",\n p: .1\n }}\n className='calender-year-item'\n >\n <Button\n color={selected ? color : \"default\"}\n className='calender-year-button'\n size='small'\n corner=\"circle\"\n ref={selected ? selectedRef : null}\n onClick={() => onClick(y)}\n variant={selected ? \"fill\" : \"text\"}\n >\n {y}\n </Button>\n </Stack>)\n }\n\n useEffect(() => {\n if (selectedRef?.current) {\n selectedRef?.current.scrollIntoView({ behavior: \"smooth\", block: \"center\", inline: \"nearest\" })\n }\n }, [])\n\n return (\n <Stack\n sx={{\n flexWrap: \"wrap\",\n flexDirection: \"row\",\n overflow: \"hidden\",\n overflowY: \"auto\"\n }}\n className='calender-years'\n >\n {years}\n </Stack>\n )\n}\n\n\nconst Calendar = ({ value, ...rest }: CalendarProps) => {\n let [{ onChange, viewMode: VMode, onButtonClick, color }] = useInterface<any>(\"Calender\", rest, {})\n const _p: any = {}\n if (VMode) _p.VMode = VMode\n if (color) _p.color = color\n const p: any = useBreakpointProps(_p)\n color = p.color || \"brand\"\n\n let [viewMode, setViewMode] = useState<any>(p.VMode || \"day\");\n let [selectedDate, setSelectedDate] = useState(new Date());\n selectedDate = value instanceof Date ? value : selectedDate\n const [currentDate, setCurrentDate] = useState(selectedDate);\n const year = currentDate.getFullYear()\n const month = currentDate.getMonth()\n const daysInMonth = 32 - new Date(year, month, 32).getDate()\n const today = new Date();\n const btnWidth = 32\n const boxWidth = btnWidth * 7\n\n const showCalendar = () => {\n\n let firstDay = (new Date(year, month)).getDay();\n let rows = []\n\n let date = 1;\n for (let i = 0; i < 6; i++) {\n let row = []\n for (let j = 0; j < 7; j++) {\n if (i === 0 && j < firstDay) {\n row.push(<Stack\n width={btnWidth}\n height={btnWidth}\n alignItems=\"center\"\n justifyContent=\"center\"\n key={date + j + i}\n >\n </Stack>)\n } else if (date > daysInMonth) {\n break;\n } else {\n let isToday = date === today.getDate() && year === today.getFullYear() && month === today.getMonth()\n let isSelected = date === selectedDate.getDate() && year === selectedDate.getFullYear() && month === selectedDate.getMonth()\n\n let css: any = {}\n if (isToday) {\n css = {\n variant: \"outline\",\n color: color\n }\n }\n\n if (isSelected) {\n css = {\n variant: \"fill\",\n color: color\n }\n }\n\n row.push(<Stack\n sx={{\n width: btnWidth,\n height: btnWidth,\n alignItems: \"center\",\n justifyContent: \"center\"\n }}\n key={date + j + i}\n className='calender-day-item'\n >\n <IconButton\n className='calender-day-button'\n variant={isSelected ? \"fill\" : \"text\"}\n color={isToday ? color : \"default\"}\n {...css}\n data-value={date}\n onClick={(e: any) => {\n let d = e.target.getAttribute(\"data-value\")\n if (!d) return\n let selectedDate = new Date(year, month, parseInt(d))\n onChange ? onChange(selectedDate) : setSelectedDate(selectedDate)\n onButtonClick && onButtonClick(\"day\", selectedDate)\n }}\n >\n {date}\n </IconButton>\n </Stack>)\n date++;\n }\n }\n rows.push(<Stack flexRow key={\"row\" + i} className='calender-day-row'>\n {row}\n </Stack>);\n }\n return rows\n }\n\n const showMonth = () => {\n let months: any[] = []\n const monthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];\n for (let m = 0; m < monthNames.length; m++) {\n const selected = currentDate.getMonth() === m\n\n months.push(<Stack\n key={m}\n width={(boxWidth - 12) / 2}\n alignItems=\"center\"\n justifyContent=\"center\"\n p={.1}\n className='calender-months-item'\n >\n <Button\n color={selected ? color : \"default\"}\n className='calender-month-button'\n size='small'\n corner=\"circle\"\n variant={selected ? \"fill\" : 'text'}\n onClick={() => {\n const v = new Date(currentDate.getFullYear(), m)\n setCurrentDate(v)\n setViewMode(\"day\")\n onButtonClick && onButtonClick(\"month\", v)\n }}\n sx={{\n color: selected ? \"brand.text\" : \"text.primary\"\n }}\n >\n {monthNames[m]}\n </Button>\n </Stack>)\n }\n\n return (\n <Stack\n className='calender-months'\n sx={{\n flexWrap: \"wrap\",\n overflow: \"hidden\",\n overflowY: \"auto\",\n flexDirection: \"row\"\n }}\n >\n {months}\n </Stack>\n )\n }\n\n let view: any = null\n switch (viewMode) {\n case \"year\":\n view = <ShowYears\n color={color}\n today={today}\n year={year}\n boxWidth={boxWidth}\n onClick={(y: any) => {\n currentDate.setFullYear(y)\n setCurrentDate(currentDate)\n setViewMode(\"month\")\n onButtonClick && onButtonClick(\"year\", currentDate)\n }}\n />\n break;\n case \"month\":\n view = showMonth()\n break;\n default:\n view = (<>\n <Stack flexRow className='calender-week-container'>\n {\n ['S', 'M', 'T', 'W', 'T', 'F', 'S'].map((day, idx) => (\n <Stack\n key={day + idx}\n width={btnWidth}\n height={btnWidth}\n alignItems=\"center\"\n justifyContent=\"center\"\n >\n <Text\n fontWeight={500}\n fontSize=\"button\"\n color=\"text.secondary\"\n >\n {day}\n </Text>\n </Stack>\n ))\n }\n </Stack>\n {showCalendar()}\n </>\n )\n break;\n }\n\n return (\n <ViewBox\n className='calender-root'\n maxHeight={308}\n width={250}\n radius={1}\n bgcolor=\"background.primary\"\n startContent={\n <Stack className='calender-header' flexRow alignItems=\"center\" justifyContent=\"space-between\" p={1}>\n <Text\n fontWeight=\"bold\"\n cursor=\"pointer\"\n onClick={() => setViewMode(viewMode !== 'day' ? \"day\" : \"year\")}\n flex={1}\n >\n {currentDate.toLocaleDateString(undefined, { year: 'numeric', month: 'long' })}\n </Text>\n <IconButton\n color=\"default\"\n variant='text'\n size={28}\n onClick={() => {\n setCurrentDate(new Date())\n onChange ? onChange(new Date()) : setSelectedDate(new Date())\n }}\n >\n <ResetIcon fontSize={20} />\n </IconButton>\n <IconButton\n color=\"default\"\n variant='text'\n size={28}\n onClick={() => {\n setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() - 1, 1))\n }}\n >\n <IconKeyboardArrowLeft />\n </IconButton>\n <IconButton\n color=\"default\"\n variant='text'\n size={28}\n onClick={() => {\n setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() + 1, 1))\n }}\n >\n <IconKeyboardArrowRight />\n </IconButton>\n </Stack>\n }\n >\n <Stack height=\"100%\" p={.5} className='calender-container'>\n {view}\n </Stack>\n </ViewBox>\n );\n};\n\nexport default Calendar;"],"names":["_jsx","_jsxs","_Fragment"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/Calendar/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\r\nimport Stack from '../Stack'\r\nimport IconButton from '../IconButton';\r\nimport IconKeyboardArrowRight from '@xanui/icons/KeyboardArrowRight';\r\nimport IconKeyboardArrowLeft from '@xanui/icons/KeyboardArrowLeft';\r\nimport Text from '../Text';\r\nimport Button from '../Button';\r\nimport ResetIcon from '@xanui/icons/Replay';\r\nimport ViewBox from '../ViewBox';\r\nimport { UseColorTemplateColor, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\r\n\r\nexport type CalendarProps = {\r\n value?: Date | null;\r\n onChange?: (date: Date | null) => void;\r\n viewMode?: useBreakpointPropsType<\"year\" | \"month\" | \"day\">;\r\n onButtonClick?: (mode: CalendarProps[\"viewMode\"], value: CalendarProps[\"value\"]) => void;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n}\r\n\r\n\r\nconst ShowYears = ({ color, year, today, boxWidth, onClick }: any) => {\r\n let years: any[] = []\r\n const selectedRef: any = useRef(null)\r\n for (let y = 1900; y < today.getFullYear() + 40; y++) {\r\n const selected = year == y\r\n years.push(<Stack\r\n key={y}\r\n sx={{\r\n width: (boxWidth - 12) / 3,\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n p: .1\r\n }}\r\n className='calender-year-item'\r\n >\r\n <Button\r\n color={selected ? color : \"default\"}\r\n className='calender-year-button'\r\n size='small'\r\n corner=\"circle\"\r\n ref={selected ? selectedRef : null}\r\n onClick={() => onClick(y)}\r\n variant={selected ? \"fill\" : \"text\"}\r\n >\r\n {y}\r\n </Button>\r\n </Stack>)\r\n }\r\n\r\n useEffect(() => {\r\n if (selectedRef?.current) {\r\n selectedRef?.current.scrollIntoView({ behavior: \"smooth\", block: \"center\", inline: \"nearest\" })\r\n }\r\n }, [])\r\n\r\n return (\r\n <Stack\r\n sx={{\r\n flexWrap: \"wrap\",\r\n flexDirection: \"row\",\r\n overflow: \"hidden\",\r\n overflowY: \"auto\"\r\n }}\r\n className='calender-years'\r\n >\r\n {years}\r\n </Stack>\r\n )\r\n}\r\n\r\n\r\nconst Calendar = ({ value, ...rest }: CalendarProps) => {\r\n let [{ onChange, viewMode: VMode, onButtonClick, color }] = useInterface<any>(\"Calender\", rest, {})\r\n const _p: any = {}\r\n if (VMode) _p.VMode = VMode\r\n if (color) _p.color = color\r\n const p: any = useBreakpointProps(_p)\r\n color = p.color || \"brand\"\r\n\r\n let [viewMode, setViewMode] = useState<any>(p.VMode || \"day\");\r\n let [selectedDate, setSelectedDate] = useState(new Date());\r\n selectedDate = value instanceof Date ? value : selectedDate\r\n const [currentDate, setCurrentDate] = useState(selectedDate);\r\n const year = currentDate.getFullYear()\r\n const month = currentDate.getMonth()\r\n const daysInMonth = 32 - new Date(year, month, 32).getDate()\r\n const today = new Date();\r\n const btnWidth = 32\r\n const boxWidth = btnWidth * 7\r\n\r\n const showCalendar = () => {\r\n\r\n let firstDay = (new Date(year, month)).getDay();\r\n let rows = []\r\n\r\n let date = 1;\r\n for (let i = 0; i < 6; i++) {\r\n let row = []\r\n for (let j = 0; j < 7; j++) {\r\n if (i === 0 && j < firstDay) {\r\n row.push(<Stack\r\n width={btnWidth}\r\n height={btnWidth}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n key={date + j + i}\r\n >\r\n </Stack>)\r\n } else if (date > daysInMonth) {\r\n break;\r\n } else {\r\n let isToday = date === today.getDate() && year === today.getFullYear() && month === today.getMonth()\r\n let isSelected = date === selectedDate.getDate() && year === selectedDate.getFullYear() && month === selectedDate.getMonth()\r\n\r\n let css: any = {}\r\n if (isToday) {\r\n css = {\r\n variant: \"outline\",\r\n color: color\r\n }\r\n }\r\n\r\n if (isSelected) {\r\n css = {\r\n variant: \"fill\",\r\n color: color\r\n }\r\n }\r\n\r\n row.push(<Stack\r\n sx={{\r\n width: btnWidth,\r\n height: btnWidth,\r\n alignItems: \"center\",\r\n justifyContent: \"center\"\r\n }}\r\n key={date + j + i}\r\n className='calender-day-item'\r\n >\r\n <IconButton\r\n className='calender-day-button'\r\n variant={isSelected ? \"fill\" : \"text\"}\r\n color={isToday ? color : \"default\"}\r\n {...css}\r\n data-value={date}\r\n onClick={(e: any) => {\r\n let d = e.target.getAttribute(\"data-value\")\r\n if (!d) return\r\n let selectedDate = new Date(year, month, parseInt(d))\r\n onChange ? onChange(selectedDate) : setSelectedDate(selectedDate)\r\n onButtonClick && onButtonClick(\"day\", selectedDate)\r\n }}\r\n >\r\n {date}\r\n </IconButton>\r\n </Stack>)\r\n date++;\r\n }\r\n }\r\n rows.push(<Stack flexRow key={\"row\" + i} className='calender-day-row'>\r\n {row}\r\n </Stack>);\r\n }\r\n return rows\r\n }\r\n\r\n const showMonth = () => {\r\n let months: any[] = []\r\n const monthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];\r\n for (let m = 0; m < monthNames.length; m++) {\r\n const selected = currentDate.getMonth() === m\r\n\r\n months.push(<Stack\r\n key={m}\r\n width={(boxWidth - 12) / 2}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n p={.1}\r\n className='calender-months-item'\r\n >\r\n <Button\r\n color={selected ? color : \"default\"}\r\n className='calender-month-button'\r\n size='small'\r\n corner=\"circle\"\r\n variant={selected ? \"fill\" : 'text'}\r\n onClick={() => {\r\n const v = new Date(currentDate.getFullYear(), m)\r\n setCurrentDate(v)\r\n setViewMode(\"day\")\r\n onButtonClick && onButtonClick(\"month\", v)\r\n }}\r\n sx={{\r\n color: selected ? \"brand.text\" : \"text.primary\"\r\n }}\r\n >\r\n {monthNames[m]}\r\n </Button>\r\n </Stack>)\r\n }\r\n\r\n return (\r\n <Stack\r\n className='calender-months'\r\n sx={{\r\n flexWrap: \"wrap\",\r\n overflow: \"hidden\",\r\n overflowY: \"auto\",\r\n flexDirection: \"row\"\r\n }}\r\n >\r\n {months}\r\n </Stack>\r\n )\r\n }\r\n\r\n let view: any = null\r\n switch (viewMode) {\r\n case \"year\":\r\n view = <ShowYears\r\n color={color}\r\n today={today}\r\n year={year}\r\n boxWidth={boxWidth}\r\n onClick={(y: any) => {\r\n currentDate.setFullYear(y)\r\n setCurrentDate(currentDate)\r\n setViewMode(\"month\")\r\n onButtonClick && onButtonClick(\"year\", currentDate)\r\n }}\r\n />\r\n break;\r\n case \"month\":\r\n view = showMonth()\r\n break;\r\n default:\r\n view = (<>\r\n <Stack flexRow className='calender-week-container'>\r\n {\r\n ['S', 'M', 'T', 'W', 'T', 'F', 'S'].map((day, idx) => (\r\n <Stack\r\n key={day + idx}\r\n width={btnWidth}\r\n height={btnWidth}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n >\r\n <Text\r\n fontWeight={500}\r\n fontSize=\"button\"\r\n color=\"text.secondary\"\r\n >\r\n {day}\r\n </Text>\r\n </Stack>\r\n ))\r\n }\r\n </Stack>\r\n {showCalendar()}\r\n </>\r\n )\r\n break;\r\n }\r\n\r\n return (\r\n <ViewBox\r\n className='calender-root'\r\n maxHeight={308}\r\n width={250}\r\n radius={1}\r\n bgcolor=\"background.primary\"\r\n startContent={\r\n <Stack className='calender-header' flexRow alignItems=\"center\" justifyContent=\"space-between\" p={1}>\r\n <Text\r\n fontWeight=\"bold\"\r\n cursor=\"pointer\"\r\n onClick={() => setViewMode(viewMode !== 'day' ? \"day\" : \"year\")}\r\n flex={1}\r\n >\r\n {currentDate.toLocaleDateString(undefined, { year: 'numeric', month: 'long' })}\r\n </Text>\r\n <IconButton\r\n color=\"default\"\r\n variant='text'\r\n size={28}\r\n onClick={() => {\r\n setCurrentDate(new Date())\r\n onChange ? onChange(new Date()) : setSelectedDate(new Date())\r\n }}\r\n >\r\n <ResetIcon fontSize={20} />\r\n </IconButton>\r\n <IconButton\r\n color=\"default\"\r\n variant='text'\r\n size={28}\r\n onClick={() => {\r\n setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() - 1, 1))\r\n }}\r\n >\r\n <IconKeyboardArrowLeft />\r\n </IconButton>\r\n <IconButton\r\n color=\"default\"\r\n variant='text'\r\n size={28}\r\n onClick={() => {\r\n setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() + 1, 1))\r\n }}\r\n >\r\n <IconKeyboardArrowRight />\r\n </IconButton>\r\n </Stack>\r\n }\r\n >\r\n <Stack height=\"100%\" p={.5} className='calender-container'>\r\n {view}\r\n </Stack>\r\n </ViewBox>\r\n );\r\n};\r\n\r\nexport default Calendar;"],"names":["_jsx","_jsxs","_Fragment"],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ 'use strict';
2
+
3
+ var tslib = require('tslib');
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var index = require('../Input/index.cjs');
6
+ var index$3 = require('../Menu/index.cjs');
7
+ var React = require('react');
8
+ var index$5 = require('../Calendar/index.cjs');
9
+ var index$1 = require('../Stack/index.cjs');
10
+ var index$4 = require('../ClickOutside/index.cjs');
11
+ var CalendarIcon = require('@xanui/icons/CalendarMonth');
12
+ var index$2 = require('../IconButton/index.cjs');
13
+ var ClearIcon = require('@xanui/icons/Clear');
14
+ var core = require('@xanui/core');
15
+
16
+ const CalenderInput = (props) => {
17
+ let [_a] = core.useInterface("CanlendarInput", props, {}), { value, onChange, getInputValue, slotProps, placeholder } = _a, inputProps = tslib.__rest(_a, ["value", "onChange", "getInputValue", "slotProps", "placeholder"]);
18
+ const [target, setTarget] = React.useState();
19
+ const inputRef = React.useRef(null);
20
+ return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(index, Object.assign({ readOnly: true, onClick: () => setTarget(target ? null : inputRef === null || inputRef === void 0 ? void 0 : inputRef.current), startIcon: jsxRuntime.jsx(CalendarIcon, {}) }, inputProps, { endIcon: jsxRuntime.jsx(jsxRuntime.Fragment, { children: value && jsxRuntime.jsx(index$1, { children: jsxRuntime.jsx(index$2, { color: "default", size: 28, variant: "text", onClick: () => {
21
+ onChange && onChange(null);
22
+ }, children: jsxRuntime.jsx(ClearIcon, { fontSize: 20 }) }) }) }), cursor: "pointer", containerRef: inputRef, value: getInputValue ? getInputValue(value) : (value ? value.toLocaleDateString("en-US") : "") })), jsxRuntime.jsx(index$3, Object.assign({ target: target, placement: "bottom-left", bgcolor: "transparent" }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.menu, { children: jsxRuntime.jsx(index$4, { onClickOutside: () => setTarget(null), children: jsxRuntime.jsx(index$5, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.calender, { value: value, onChange: (e) => {
23
+ setTarget(null);
24
+ onChange && onChange(e);
25
+ } })) }) }))] }));
26
+ };
27
+
28
+ module.exports = CalenderInput;
29
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/CalendarInput/index.tsx"],"sourcesContent":["\r\nimport Input, { InputProps } from '../Input'\r\nimport Menu, { MenuProps } from '../Menu'\r\nimport { useRef, useState } from 'react'\r\nimport Calendar, { CalendarProps } from '../Calendar'\r\nimport Stack from '../Stack'\r\nimport ClickOutside from '../ClickOutside'\r\nimport CalendarIcon from '@xanui/icons/CalendarMonth';\r\nimport IconButton from '../IconButton'\r\nimport ClearIcon from '@xanui/icons/Clear';\r\nimport { useInterface } from '@xanui/core'\r\n\r\nexport type CalenderInpurProps = Omit<InputProps, \"value\" | \"onChange\" | \"slotProps\"> & {\r\n value?: CalendarProps[\"value\"];\r\n onChange?: CalendarProps[\"onChange\"];\r\n getInputValue?: (value?: Date | null) => string;\r\n slotProps?: {\r\n input?: InputProps['slotProps'];\r\n calender?: CalendarProps;\r\n menu?: MenuProps;\r\n }\r\n}\r\n\r\nconst CalenderInput = (props: CalenderInpurProps) => {\r\n let [{ value, onChange, getInputValue, slotProps, placeholder, ...inputProps }] = useInterface<any>(\"CanlendarInput\", props, {})\r\n const [target, setTarget] = useState<any>()\r\n const inputRef: any = useRef(null)\r\n\r\n return (\r\n <>\r\n <Input\r\n readOnly\r\n onClick={() => setTarget(target ? null : inputRef?.current)}\r\n startIcon={<CalendarIcon />}\r\n {...inputProps}\r\n endIcon={<>\r\n {value && <Stack>\r\n <IconButton\r\n color=\"default\"\r\n size={28}\r\n variant=\"text\"\r\n onClick={() => {\r\n onChange && onChange(null)\r\n }}\r\n >\r\n <ClearIcon fontSize={20} />\r\n </IconButton>\r\n </Stack>}\r\n </>}\r\n cursor=\"pointer\"\r\n containerRef={inputRef}\r\n value={getInputValue ? getInputValue(value) : (value ? value.toLocaleDateString(\"en-US\") : \"\")}\r\n />\r\n <Menu\r\n target={target}\r\n placement=\"bottom-left\"\r\n bgcolor=\"transparent\"\r\n {...slotProps?.menu}\r\n >\r\n <ClickOutside onClickOutside={() => setTarget(null)}>\r\n <Calendar\r\n {...slotProps?.calender}\r\n value={value}\r\n onChange={(e) => {\r\n setTarget(null)\r\n onChange && onChange(e)\r\n }}\r\n />\r\n </ClickOutside>\r\n </Menu>\r\n </>\r\n )\r\n}\r\n\r\nexport default CalenderInput"],"names":["useInterface","__rest","useState","useRef","_jsxs","_Fragment","_jsx","Input","Stack","IconButton","Menu","ClickOutside","Calendar"],"mappings":";;;;;;;;;;;;;;;AAuBA,MAAM,aAAa,GAAG,CAAC,KAAyB,KAAI;IAChD,IAAI,CAAA,EAAA,CAAA,GAA8EA,iBAAY,CAAM,gBAAgB,EAAE,KAAK,EAAE,EAAE,CAAC,EAA3H,EAAE,KAAK,EAAE,QAAQ,EAAE,aAAa,EAAE,SAAS,EAAE,WAAW,EAAA,GAAA,EAAiB,EAAZ,UAAU,GAAAC,YAAA,CAAA,EAAA,EAAvE,CAAA,OAAA,EAAA,UAAA,EAAA,eAAA,EAAA,WAAA,EAAA,aAAA,CAAyE,CAAkD;IAChI,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAGC,cAAQ,EAAO;AAC3C,IAAA,MAAM,QAAQ,GAAQC,YAAM,CAAC,IAAI,CAAC;AAElC,IAAA,QACIC,eAAA,CAAAC,mBAAA,EAAA,EAAA,QAAA,EAAA,CACIC,cAAA,CAACC,KAAK,EAAA,MAAA,CAAA,MAAA,CAAA,EACF,QAAQ,EAAA,IAAA,EACR,OAAO,EAAE,MAAM,SAAS,CAAC,MAAM,GAAG,IAAI,GAAG,QAAQ,KAAA,IAAA,IAAR,QAAQ,KAAA,MAAA,GAAA,MAAA,GAAR,QAAQ,CAAE,OAAO,CAAC,EAC3D,SAAS,EAAED,cAAA,CAAC,YAAY,EAAA,EAAA,CAAG,EAAA,EACvB,UAAU,EAAA,EACd,OAAO,EAAEA,cAAA,CAAAD,mBAAA,EAAA,EAAA,QAAA,EACJ,KAAK,IAAIC,cAAA,CAACE,OAAK,cACZF,cAAA,CAACG,OAAU,EAAA,EACP,KAAK,EAAC,SAAS,EACf,IAAI,EAAE,EAAE,EACR,OAAO,EAAC,MAAM,EACd,OAAO,EAAE,MAAK;AACV,gCAAA,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC;4BAC9B,CAAC,EAAA,QAAA,EAEDH,eAAC,SAAS,EAAA,EAAC,QAAQ,EAAE,EAAE,EAAA,CAAI,EAAA,CAClB,EAAA,CACT,EAAA,CACT,EACH,MAAM,EAAC,SAAS,EAChB,YAAY,EAAE,QAAQ,EACtB,KAAK,EAAE,aAAa,GAAG,aAAa,CAAC,KAAK,CAAC,IAAI,KAAK,GAAG,KAAK,CAAC,kBAAkB,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,EAAA,CAAA,CAChG,EACFA,cAAA,CAACI,OAAI,kBACD,MAAM,EAAE,MAAM,EACd,SAAS,EAAC,aAAa,EACvB,OAAO,EAAC,aAAa,EAAA,EACjB,SAAS,aAAT,SAAS,KAAA,MAAA,GAAA,MAAA,GAAT,SAAS,CAAE,IAAI,EAAA,EAAA,QAAA,EAEnBJ,eAACK,OAAY,EAAA,EAAC,cAAc,EAAE,MAAM,SAAS,CAAC,IAAI,CAAC,EAAA,QAAA,EAC/CL,cAAA,CAACM,OAAQ,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACD,SAAS,KAAA,IAAA,IAAT,SAAS,KAAA,MAAA,GAAA,MAAA,GAAT,SAAS,CAAE,QAAQ,EAAA,EACvB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,CAAC,CAAC,KAAI;4BACZ,SAAS,CAAC,IAAI,CAAC;AACf,4BAAA,QAAQ,IAAI,QAAQ,CAAC,CAAC,CAAC;AAC3B,wBAAA,CAAC,EAAA,CAAA,CACH,EAAA,CACS,EAAA,CAAA,CACZ,CAAA,EAAA,CACR;AAEX;;;;"}