@xanui/ui 1.1.38 → 1.1.40

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (191) hide show
  1. package/Accordion/index.cjs +96 -0
  2. package/Accordion/index.cjs.map +1 -0
  3. package/Accordion/index.js.map +1 -1
  4. package/Alert/index.cjs +121 -0
  5. package/Alert/index.cjs.map +1 -0
  6. package/Alert/index.js.map +1 -1
  7. package/Autocomplete/index.cjs +136 -0
  8. package/Autocomplete/index.cjs.map +1 -0
  9. package/Avatar/index.cjs +50 -0
  10. package/Avatar/index.cjs.map +1 -0
  11. package/Badge/index.cjs +109 -0
  12. package/Badge/index.cjs.map +1 -0
  13. package/Box/index.cjs +14 -0
  14. package/Box/index.cjs.map +1 -0
  15. package/Button/index.cjs +94 -0
  16. package/Button/index.cjs.map +1 -0
  17. package/Button/index.js.map +1 -1
  18. package/ButtonGroup/index.cjs +58 -0
  19. package/ButtonGroup/index.cjs.map +1 -0
  20. package/Calendar/index.cjs +174 -0
  21. package/Calendar/index.cjs.map +1 -0
  22. package/Calendar/index.js.map +1 -1
  23. package/CalendarInput/index.cjs +34 -0
  24. package/CalendarInput/index.cjs.map +1 -0
  25. package/CalendarInput/index.js.map +1 -1
  26. package/Checkbox/index.cjs +58 -0
  27. package/Checkbox/index.cjs.map +1 -0
  28. package/Checkbox/index.js.map +1 -1
  29. package/Chip/index.cjs +76 -0
  30. package/Chip/index.cjs.map +1 -0
  31. package/CircleProgress/index.cjs +129 -0
  32. package/CircleProgress/index.cjs.map +1 -0
  33. package/CircleProgress/index.js.map +1 -1
  34. package/ClickOutside/index.cjs +37 -0
  35. package/ClickOutside/index.cjs.map +1 -0
  36. package/ClickOutside/index.js.map +1 -1
  37. package/Collaps/index.cjs +26 -0
  38. package/Collaps/index.cjs.map +1 -0
  39. package/Container/index.cjs +29 -0
  40. package/Container/index.cjs.map +1 -0
  41. package/DataFilter/index.cjs +78 -0
  42. package/DataFilter/index.cjs.map +1 -0
  43. package/DataFilter/options/DateFilter.cjs +32 -0
  44. package/DataFilter/options/DateFilter.cjs.map +1 -0
  45. package/DataFilter/options/DateRangeFilter.cjs +27 -0
  46. package/DataFilter/options/DateRangeFilter.cjs.map +1 -0
  47. package/DataFilter/options/MultiSelectFilter.cjs +38 -0
  48. package/DataFilter/options/MultiSelectFilter.cjs.map +1 -0
  49. package/DataFilter/options/NumberFilter.cjs +24 -0
  50. package/DataFilter/options/NumberFilter.cjs.map +1 -0
  51. package/DataFilter/options/NumberRangeFilter.cjs +29 -0
  52. package/DataFilter/options/NumberRangeFilter.cjs.map +1 -0
  53. package/DataFilter/options/SelectFilter.cjs +34 -0
  54. package/DataFilter/options/SelectFilter.cjs.map +1 -0
  55. package/DataFilter/options/TextFilter.cjs +24 -0
  56. package/DataFilter/options/TextFilter.cjs.map +1 -0
  57. package/Datatable/FilterBox.cjs +39 -0
  58. package/Datatable/FilterBox.cjs.map +1 -0
  59. package/Datatable/FilterBox.js.map +1 -1
  60. package/Datatable/Row.cjs +59 -0
  61. package/Datatable/Row.cjs.map +1 -0
  62. package/Datatable/Row.js.map +1 -1
  63. package/Datatable/SelectedBox.cjs +21 -0
  64. package/Datatable/SelectedBox.cjs.map +1 -0
  65. package/Datatable/Table.cjs +23 -0
  66. package/Datatable/Table.cjs.map +1 -0
  67. package/Datatable/Table.js.map +1 -1
  68. package/Datatable/TableHead.cjs +61 -0
  69. package/Datatable/TableHead.cjs.map +1 -0
  70. package/Datatable/TableHead.js.map +1 -1
  71. package/Datatable/index.cjs +93 -0
  72. package/Datatable/index.cjs.map +1 -0
  73. package/Datatable/index.js.map +1 -1
  74. package/Divider/index.cjs +31 -0
  75. package/Divider/index.cjs.map +1 -0
  76. package/Drawer/index.cjs +78 -0
  77. package/Drawer/index.cjs.map +1 -0
  78. package/Drawer/index.js.map +1 -1
  79. package/Form/index.cjs +45 -0
  80. package/Form/index.cjs.map +1 -0
  81. package/Form/index.js.map +1 -1
  82. package/GridContainer/index.cjs +19 -0
  83. package/GridContainer/index.cjs.map +1 -0
  84. package/GridItem/index.cjs +20 -0
  85. package/GridItem/index.cjs.map +1 -0
  86. package/IconButton/index.cjs +64 -0
  87. package/IconButton/index.cjs.map +1 -0
  88. package/IconButton/index.js.map +1 -1
  89. package/Image/index.cjs +27 -0
  90. package/Image/index.cjs.map +1 -0
  91. package/Image/index.js.map +1 -1
  92. package/Input/index.cjs +144 -0
  93. package/Input/index.cjs.map +1 -0
  94. package/Input/index.js.map +1 -1
  95. package/InputNumber/index.cjs +32 -0
  96. package/InputNumber/index.cjs.map +1 -0
  97. package/Label/index.cjs +24 -0
  98. package/Label/index.cjs.map +1 -0
  99. package/Layer/index.cjs +62 -0
  100. package/Layer/index.cjs.map +1 -0
  101. package/Layer/index.js.map +1 -1
  102. package/LineProgress/index.cjs +59 -0
  103. package/LineProgress/index.cjs.map +1 -0
  104. package/LineProgress/index.js.map +1 -1
  105. package/List/ListContext.cjs +11 -0
  106. package/List/ListContext.cjs.map +1 -0
  107. package/List/index.cjs +63 -0
  108. package/List/index.cjs.map +1 -0
  109. package/ListItem/index.cjs +54 -0
  110. package/ListItem/index.cjs.map +1 -0
  111. package/LoadingBox/index.cjs +32 -0
  112. package/LoadingBox/index.cjs.map +1 -0
  113. package/Menu/index.cjs +150 -0
  114. package/Menu/index.cjs.map +1 -0
  115. package/Menu/index.js.map +1 -1
  116. package/Modal/index.cjs +59 -0
  117. package/Modal/index.cjs.map +1 -0
  118. package/Modal/index.js.map +1 -1
  119. package/NoSSR/index.cjs +15 -0
  120. package/NoSSR/index.cjs.map +1 -0
  121. package/NoSSR/index.js.map +1 -1
  122. package/Option/index.cjs +14 -0
  123. package/Option/index.cjs.map +1 -0
  124. package/Paper/index.cjs +15 -0
  125. package/Paper/index.cjs.map +1 -0
  126. package/Portal/index.cjs +27 -0
  127. package/Portal/index.cjs.map +1 -0
  128. package/Portal/index.js.map +1 -1
  129. package/Radio/index.cjs +16 -0
  130. package/Radio/index.cjs.map +1 -0
  131. package/Scrollbar/index.cjs +59 -0
  132. package/Scrollbar/index.cjs.map +1 -0
  133. package/Scrollbar/index.js.map +1 -1
  134. package/Select/index.cjs +59 -0
  135. package/Select/index.cjs.map +1 -0
  136. package/Select/index.js.map +1 -1
  137. package/Skeleton/index.cjs +60 -0
  138. package/Skeleton/index.cjs.map +1 -0
  139. package/Stack/index.cjs +17 -0
  140. package/Stack/index.cjs.map +1 -0
  141. package/Switch/index.cjs +79 -0
  142. package/Switch/index.cjs.map +1 -0
  143. package/Switch/index.js.map +1 -1
  144. package/Tab/index.cjs +17 -0
  145. package/Tab/index.cjs.map +1 -0
  146. package/Tab/index.js.map +1 -1
  147. package/Table/index.cjs +88 -0
  148. package/Table/index.cjs.map +1 -0
  149. package/TableBody/index.cjs +14 -0
  150. package/TableBody/index.cjs.map +1 -0
  151. package/TableCell/index.cjs +14 -0
  152. package/TableCell/index.cjs.map +1 -0
  153. package/TableFooter/index.cjs +14 -0
  154. package/TableFooter/index.cjs.map +1 -0
  155. package/TableHead/index.cjs +14 -0
  156. package/TableHead/index.cjs.map +1 -0
  157. package/TablePagination/index.cjs +59 -0
  158. package/TablePagination/index.cjs.map +1 -0
  159. package/TablePagination/index.js.map +1 -1
  160. package/TableRow/index.cjs +14 -0
  161. package/TableRow/index.cjs.map +1 -0
  162. package/Tabs/index.cjs +201 -0
  163. package/Tabs/index.cjs.map +1 -0
  164. package/Tabs/index.js.map +1 -1
  165. package/Text/index.cjs +25 -0
  166. package/Text/index.cjs.map +1 -0
  167. package/Toast/index.cjs +120 -0
  168. package/Toast/index.cjs.map +1 -0
  169. package/Toast/index.js.map +1 -1
  170. package/Tooltip/index.cjs +40 -0
  171. package/Tooltip/index.cjs.map +1 -0
  172. package/Tooltip/index.js.map +1 -1
  173. package/ViewBox/index.cjs +32 -0
  174. package/ViewBox/index.cjs.map +1 -0
  175. package/index.cjs +134 -0
  176. package/index.cjs.map +1 -0
  177. package/package.json +3 -3
  178. package/readme.md +4 -4
  179. package/useAlert/index.cjs +94 -0
  180. package/useAlert/index.cjs.map +1 -0
  181. package/useAlert/index.js.map +1 -1
  182. package/useBlurCss/index.cjs +19 -0
  183. package/useBlurCss/index.cjs.map +1 -0
  184. package/useCorner/index.cjs +22 -0
  185. package/useCorner/index.cjs.map +1 -0
  186. package/useLayer/index.cjs +38 -0
  187. package/useLayer/index.cjs.map +1 -0
  188. package/useLayer/index.js.map +1 -1
  189. package/useModal/index.cjs +37 -0
  190. package/useModal/index.cjs.map +1 -0
  191. package/useModal/index.js.map +1 -1
@@ -0,0 +1,109 @@
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 Badge = React.forwardRef((_a, ref) => {
9
+ var { children, content, refs } = _a, rest = tslib.__rest(_a, ["children", "content", "refs"]);
10
+ let [_b] = core.useInterface("Badge", rest, {}), { color, placement, visible, slotProps, disableTransition, disableSpace } = _b, props = tslib.__rest(_b, ["color", "placement", "visible", "slotProps", "disableTransition", "disableSpace"]);
11
+ color !== null && color !== void 0 ? color : (color = "danger");
12
+ visible !== null && visible !== void 0 ? visible : (visible = true);
13
+ placement !== null && placement !== void 0 ? placement : (placement = "right-top");
14
+ disableTransition !== null && disableTransition !== void 0 ? disableTransition : (disableTransition = false);
15
+ disableSpace !== null && disableSpace !== void 0 ? disableSpace : (disableSpace = false);
16
+ const _p = {};
17
+ _p.content = content;
18
+ _p.color = color;
19
+ _p.placement = placement;
20
+ _p.visible = visible;
21
+ _p.disableTransition = disableTransition !== null && disableTransition !== void 0 ? disableTransition : false;
22
+ const p = core.useBreakpointProps(_p);
23
+ content = p.content;
24
+ color = p.color;
25
+ placement = p.placement;
26
+ visible = p.visible;
27
+ disableTransition = p.disableTransition;
28
+ const isReactElement = React.isValidElement(content);
29
+ let template = core.useColorTemplate(color, "fill");
30
+ let _css = {
31
+ position: "absolute",
32
+ };
33
+ let translate = '';
34
+ switch (placement) {
35
+ case "right-top":
36
+ _css.top = 0;
37
+ _css.right = 0;
38
+ if (!disableSpace) {
39
+ translate = "translate(50%, -50%)";
40
+ }
41
+ break;
42
+ case "right-bottom":
43
+ _css.bottom = 0;
44
+ _css.right = 0;
45
+ if (!disableSpace) {
46
+ translate = "translate(50%, 50%)";
47
+ }
48
+ break;
49
+ case "left-top":
50
+ _css.top = 0;
51
+ _css.left = 0;
52
+ if (!disableSpace) {
53
+ translate = "translate(-50%, -50%)";
54
+ }
55
+ break;
56
+ case "left-bottom":
57
+ _css.bottom = 0;
58
+ _css.left = 0;
59
+ if (!disableSpace) {
60
+ translate = "translate(-50%, 50%)";
61
+ }
62
+ break;
63
+ }
64
+ if (disableTransition) {
65
+ _css.transform = translate;
66
+ }
67
+ if (!isReactElement) {
68
+ _css.userSelect = "none";
69
+ _css.pointerEvents = "none";
70
+ _css.fontSize = "small";
71
+ _css.lineHeight = 1;
72
+ _css.fontWeight = 500;
73
+ _css.radius = 2;
74
+ if (typeof content === 'number') {
75
+ if (content > 99) {
76
+ content = "99+";
77
+ }
78
+ }
79
+ if (content !== undefined) {
80
+ _css.minWidth = 16;
81
+ _css.height = 16;
82
+ _css.p = .8;
83
+ _css.px = .4;
84
+ }
85
+ else {
86
+ _css.width = 8;
87
+ _css.height = 8;
88
+ }
89
+ }
90
+ else {
91
+ template = {};
92
+ }
93
+ const _badge = jsxRuntime.jsx(core.Tag, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.content, { ref: refs === null || refs === void 0 ? void 0 : refs.content, component: 'span', baseClass: 'badge-content', sxr: Object.assign(Object.assign({ position: "absolute", zIndex: 1, display: 'flex', justifyContent: "center", alignItems: 'center' }, template.primary), _css), children: content }));
94
+ return (jsxRuntime.jsxs(core.Tag, Object.assign({}, props, { position: "relative", display: "inline-block", baseClass: 'badge', ref: ref, children: [!disableTransition ? (jsxRuntime.jsx(core.Transition, Object.assign({ open: content !== undefined && visible }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.transition, { variant: () => {
95
+ return {
96
+ from: {
97
+ opacity: 0,
98
+ transform: `scale(0) ${translate}`.trim(),
99
+ },
100
+ to: {
101
+ opacity: 1,
102
+ transform: `scale(1) ${translate}`.trim(),
103
+ },
104
+ };
105
+ }, ref: refs === null || refs === void 0 ? void 0 : refs.transition, children: _badge }))) : jsxRuntime.jsx(jsxRuntime.Fragment, { children: _badge }), children] })));
106
+ });
107
+
108
+ module.exports = Badge;
109
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Badge/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\r\nimport { Tag, TagProps, TagComponentType, Transition, useInterface, UseColorTemplateColor, useColorTemplate, useBreakpointPropsType, useBreakpointProps, TransitionProps } from '@xanui/core';\r\n\r\nexport type BadgeProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, \"baseClass\" | \"content\"> & {\r\n content?: useBreakpointPropsType<number | string | ReactElement>;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n placement?: useBreakpointPropsType<\"left-top\" | \"left-bottom\" | \"right-top\" | \"right-bottom\">;\r\n visible?: useBreakpointPropsType<boolean>;\r\n disableTransition?: boolean;\r\n disableSpace?: boolean;\r\n slotProps?: {\r\n transition?: Omit<TransitionProps, \"open\">;\r\n content?: Omit<TagProps<\"span\">, \"children\">;\r\n },\r\n refs?: {\r\n content?: React.Ref<any>;\r\n transition?: React.Ref<any>;\r\n };\r\n}\r\n\r\nconst Badge = React.forwardRef(<T extends TagComponentType = \"div\">({ children, content, refs, ...rest }: BadgeProps<T>, ref: React.Ref<any>) => {\r\n let [{ color, placement, visible, slotProps, disableTransition, disableSpace, ...props }] = useInterface<any>(\"Badge\", rest, {})\r\n color ??= \"danger\"\r\n visible ??= true\r\n placement ??= \"right-top\"\r\n disableTransition ??= false\r\n disableSpace ??= false\r\n\r\n const _p: any = {}\r\n\r\n _p.content = content\r\n _p.color = color\r\n _p.placement = placement\r\n _p.visible = visible\r\n _p.disableTransition = disableTransition ?? false\r\n\r\n const p: any = useBreakpointProps(_p)\r\n\r\n content = p.content\r\n color = p.color\r\n placement = p.placement\r\n visible = p.visible\r\n disableTransition = p.disableTransition\r\n\r\n const isReactElement = React.isValidElement(content);\r\n\r\n let template: any = useColorTemplate(color, \"fill\")\r\n let _css: any = {\r\n position: \"absolute\",\r\n }\r\n\r\n let translate = ''\r\n\r\n switch (placement) {\r\n case \"right-top\":\r\n _css.top = 0;\r\n _css.right = 0;\r\n if (!disableSpace) {\r\n translate = \"translate(50%, -50%)\";\r\n }\r\n break;\r\n case \"right-bottom\":\r\n _css.bottom = 0;\r\n _css.right = 0;\r\n if (!disableSpace) {\r\n translate = \"translate(50%, 50%)\";\r\n }\r\n break;\r\n case \"left-top\":\r\n _css.top = 0;\r\n _css.left = 0;\r\n if (!disableSpace) {\r\n translate = \"translate(-50%, -50%)\";\r\n }\r\n break;\r\n case \"left-bottom\":\r\n _css.bottom = 0;\r\n _css.left = 0;\r\n if (!disableSpace) {\r\n translate = \"translate(-50%, 50%)\";\r\n }\r\n break;\r\n }\r\n\r\n if (disableTransition) {\r\n _css.transform = translate\r\n }\r\n\r\n if (!isReactElement) {\r\n _css.userSelect = \"none\"\r\n _css.pointerEvents = \"none\"\r\n _css.fontSize = \"small\"\r\n _css.lineHeight = 1\r\n _css.fontWeight = 500\r\n _css.radius = 2\r\n\r\n if (typeof content === 'number') {\r\n if (content > 99) {\r\n content = \"99+\"\r\n }\r\n }\r\n\r\n if (content !== undefined) {\r\n _css.minWidth = 16\r\n _css.height = 16\r\n _css.p = .8\r\n _css.px = .4\r\n } else {\r\n _css.width = 8\r\n _css.height = 8\r\n }\r\n } else {\r\n template = {}\r\n }\r\n\r\n const _badge = <Tag\r\n {...slotProps?.content}\r\n ref={refs?.content}\r\n component='span'\r\n baseClass='badge-content'\r\n sxr={{\r\n position: \"absolute\",\r\n zIndex: 1,\r\n display: 'flex',\r\n justifyContent: \"center\",\r\n alignItems: 'center',\r\n ...template.primary,\r\n ..._css,\r\n }}\r\n >\r\n {content}\r\n </Tag>\r\n\r\n return (\r\n <Tag\r\n {...props}\r\n position=\"relative\"\r\n display=\"inline-block\"\r\n baseClass='badge'\r\n ref={ref}\r\n >\r\n {\r\n !disableTransition ? (<Transition\r\n open={content !== undefined && visible}\r\n {...slotProps?.transition}\r\n variant={() => {\r\n return {\r\n from: {\r\n opacity: 0,\r\n transform: `scale(0) ${translate}`.trim(),\r\n },\r\n to: {\r\n opacity: 1,\r\n transform: `scale(1) ${translate}`.trim(),\r\n },\r\n }\r\n }}\r\n ref={refs?.transition}\r\n >\r\n {_badge}\r\n </Transition>) : <>{_badge}</>\r\n }\r\n\r\n {children}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default Badge\r\n\r\n"],"names":["__rest","useInterface","useBreakpointProps","useColorTemplate","_jsx","Tag","_jsxs","Transition","_Fragment"],"mappings":"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"}
package/Box/index.cjs ADDED
@@ -0,0 +1,14 @@
1
+ 'use strict';
2
+
3
+ var tslib = require('tslib');
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var React = require('react');
6
+ var core = require('@xanui/core');
7
+
8
+ const Box = React.forwardRef((_a, ref) => {
9
+ var { children } = _a, props = tslib.__rest(_a, ["children"]);
10
+ return (jsxRuntime.jsx(core.Tag, Object.assign({}, props, { baseClass: 'box', ref: ref, children: children })));
11
+ });
12
+
13
+ module.exports = Box;
14
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Box/index.tsx"],"sourcesContent":["import React from 'react';\r\nimport { Tag, TagProps, TagComponentType } from '@xanui/core';\r\n\r\nexport type BoxProps<T extends TagComponentType = \"div\"> = TagProps<T>\r\n\r\nconst Box = React.forwardRef(<T extends TagComponentType = \"div\">({ children, ...props }: BoxProps<T>, ref: React.Ref<any>) => {\r\n return (\r\n <Tag\r\n {...props}\r\n baseClass='box'\r\n ref={ref}\r\n >{children}</Tag>\r\n )\r\n})\r\n\r\nexport default Box\r\n\r\n"],"names":["__rest","_jsx","Tag"],"mappings":";;;;;;;AAKA,MAAM,GAAG,GAAG,KAAK,CAAC,UAAU,CAAC,CAAqC,EAAmC,EAAE,GAAmB,KAAI;AAA5D,IAAA,IAAA,EAAE,QAAQ,EAAA,GAAA,EAAyB,EAApB,KAAK,GAAAA,YAAA,CAAA,EAAA,EAApB,YAAsB,CAAF;AAClF,IAAA,QACIC,cAAA,CAACC,QAAG,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACI,KAAK,IACT,SAAS,EAAC,KAAK,EACf,GAAG,EAAE,GAAG,YACV,QAAQ,EAAA,CAAA,CAAO;AAEzB,CAAC;;;;"}
@@ -0,0 +1,94 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var tslib = require('tslib');
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var core = require('@xanui/core');
8
+ var index$1 = require('../useCorner/index.cjs');
9
+ var index$2 = require('../CircleProgress/index.cjs');
10
+ var index = require('../Skeleton/index.cjs');
11
+
12
+ const Button = React.forwardRef((_a, ref) => {
13
+ var _b, _c;
14
+ var { children, skeleton } = _a, rest = tslib.__rest(_a, ["children", "skeleton"]);
15
+ let [_d] = core.useInterface('Button', rest, {
16
+ variant: "fill",
17
+ color: "brand",
18
+ corner: "rounded",
19
+ size: "medium"
20
+ }), { variant, startIcon, endIcon, color, corner, size, loading, direction, slotProps } = _d, _props = tslib.__rest(_d, ["variant", "startIcon", "endIcon", "color", "corner", "size", "loading", "direction", "slotProps"]);
21
+ const _p = {};
22
+ if (startIcon)
23
+ _p.startIcon = startIcon;
24
+ if (endIcon)
25
+ _p.endIcon = endIcon;
26
+ if (color)
27
+ _p.color = color;
28
+ if (variant)
29
+ _p.variant = variant;
30
+ if (corner)
31
+ _p.corner = corner;
32
+ if (size)
33
+ _p.size = size;
34
+ if (direction)
35
+ _p.direction = direction;
36
+ const p = core.useBreakpointProps(_p);
37
+ startIcon = p.startIcon;
38
+ endIcon = p.endIcon;
39
+ color = p.color;
40
+ variant = p.variant;
41
+ corner = p.corner;
42
+ size = p.size;
43
+ direction = p.direction || "row";
44
+ const template = core.useColorTemplate(color, variant);
45
+ const cornerCss = index$1(corner);
46
+ const sizes = {
47
+ small: {
48
+ height: 38,
49
+ px: (startIcon || endIcon) ? 1 : 1.5,
50
+ gap: .5,
51
+ fontSize: 'button'
52
+ },
53
+ medium: {
54
+ height: 44,
55
+ px: (startIcon || endIcon) ? 1.5 : 2,
56
+ gap: 1,
57
+ fontSize: 'button'
58
+ },
59
+ large: {
60
+ height: 52,
61
+ px: (startIcon || endIcon) ? 2 : 3,
62
+ gap: 1,
63
+ fontSize: "text"
64
+ }
65
+ };
66
+ const progressSizes = {
67
+ small: 20,
68
+ medium: 25,
69
+ large: 30
70
+ };
71
+ let _size = (sizes[size] || {});
72
+ if (direction === 'column') {
73
+ delete _size.height;
74
+ _size.gap = .5;
75
+ _size.py = 1;
76
+ }
77
+ if (skeleton) {
78
+ return jsxRuntime.jsx(index, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.skeleton, { height: _size.height, animation: "wave", sx: Object.assign(Object.assign(Object.assign({}, (_b = slotProps === null || slotProps === void 0 ? void 0 : slotProps.skeleton) === null || _b === void 0 ? void 0 : _b.sx), _size), cornerCss) }));
79
+ }
80
+ return (jsxRuntime.jsxs(core.Tag, Object.assign({ component: 'button', baseClass: 'button' }, _props, { sxr: Object.assign(Object.assign(Object.assign({ flexShrink: "0", whiteSpace: "nowrap", cursor: "pointer", display: "flex", textTransform: "uppercase", flexDirection: direction, alignItems: "center", justifyContent: "center", position: "relative", overflow: "hidden", userSelect: "none", fontWeight: 500 }, _size), cornerCss), template.primary), hover: Object.assign(Object.assign({}, template.secondary), ((_props === null || _props === void 0 ? void 0 : _props.hover) || {})), disabled: (_c = loading !== null && loading !== void 0 ? loading : _props.disabled) !== null && _c !== void 0 ? _c : false, ref: ref, children: [loading && jsxRuntime.jsx(core.Tag, { baseClass: 'button-loading-container', sxr: {
81
+ position: "absolute",
82
+ top: 0,
83
+ left: 0,
84
+ right: 0,
85
+ bottom: 0,
86
+ zIndex: 1,
87
+ display: "flex",
88
+ justifyContent: "center",
89
+ alignItems: "center",
90
+ }, children: jsxRuntime.jsx(index$2, 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 })] })));
91
+ });
92
+
93
+ module.exports = Button;
94
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Button/index.tsx"],"sourcesContent":["'use client'\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\nimport Skeleton, { SkeletonProps } from '../Skeleton';\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 skeleton?: boolean;\r\n slotProps?: {\r\n loading?: Omit<CircleProgressProps, \"color\" | \"hideTrack\" | \"size\">;\r\n skeleton?: Omit<SkeletonProps, \"height\" | \"width\" | \"loading\" | \"children\">\r\n }\r\n}\r\n\r\n\r\nconst Button = React.forwardRef(<T extends TagComponentType = 'button'>({ children, skeleton, ...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: 38,\r\n px: (startIcon || endIcon) ? 1 : 1.5,\r\n gap: .5,\r\n fontSize: 'button'\r\n },\r\n medium: {\r\n height: 44,\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 if (skeleton) {\r\n return <Skeleton\r\n {...slotProps?.skeleton}\r\n height={_size.height}\r\n animation={\"wave\"}\r\n sx={{\r\n ...slotProps?.skeleton?.sx,\r\n ..._size,\r\n ...cornerCss,\r\n }}\r\n />\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":[],"mappings":";;;;;;;;;;;AAyBA;;;AACI;AACI;AACA;AACA;AACA;;;AAIJ;AAAe;AACf;AAAa;AACb;AAAW;AACX;AAAa;AACb;AAAY;AACZ;AAAU;AACV;AAAe;AACf;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAGA;AAEA;AACI;AACI;AACA;AACA;AACA;AACH;AACD;AACI;AACA;AACA;AACA;AACH;AACD;AACI;AACA;AACA;AACA;AACH;;AAGL;AACI;AACA;AACA;;;AAIJ;;AAEI;AACA;;;AAIA;;;AA6CY;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACH;AAwBjB;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/Button/index.tsx"],"sourcesContent":["\"use client\";\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\nimport Skeleton, { SkeletonProps } from '../Skeleton';\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 skeleton?: boolean;\r\n slotProps?: {\r\n loading?: Omit<CircleProgressProps, \"color\" | \"hideTrack\" | \"size\">;\r\n skeleton?: Omit<SkeletonProps, \"height\" | \"width\" | \"loading\" | \"children\">\r\n }\r\n}\r\n\r\n\r\nconst Button = React.forwardRef(<T extends TagComponentType = 'button'>({ children, skeleton, ...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: 38,\r\n px: (startIcon || endIcon) ? 1 : 1.5,\r\n gap: .5,\r\n fontSize: 'button'\r\n },\r\n medium: {\r\n height: 44,\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 if (skeleton) {\r\n return <Skeleton\r\n {...slotProps?.skeleton}\r\n height={_size.height}\r\n animation={\"wave\"}\r\n sx={{\r\n ...slotProps?.skeleton?.sx,\r\n ..._size,\r\n ...cornerCss,\r\n }}\r\n />\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":[],"mappings":";;;;;;;;;AAyBA;;;AACI;AACI;AACA;AACA;AACA;;;AAIJ;AAAe;AACf;AAAa;AACb;AAAW;AACX;AAAa;AACb;AAAY;AACZ;AAAU;AACV;AAAe;AACf;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAGA;AAEA;AACI;AACI;AACA;AACA;AACA;AACH;AACD;AACI;AACA;AACA;AACA;AACH;AACD;AACI;AACA;AACA;AACA;AACH;;AAGL;AACI;AACA;AACA;;;AAIJ;;AAEI;AACA;;;AAIA;;;AA6CY;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACH;AAwBjB;;"}
1
+ {"version":3,"file":"index.js","sources":["../../src/Button/index.tsx"],"sourcesContent":["'use client'\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\nimport Skeleton, { SkeletonProps } from '../Skeleton';\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 skeleton?: boolean;\r\n slotProps?: {\r\n loading?: Omit<CircleProgressProps, \"color\" | \"hideTrack\" | \"size\">;\r\n skeleton?: Omit<SkeletonProps, \"height\" | \"width\" | \"loading\" | \"children\">\r\n }\r\n}\r\n\r\n\r\nconst Button = React.forwardRef(<T extends TagComponentType = 'button'>({ children, skeleton, ...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: 38,\r\n px: (startIcon || endIcon) ? 1 : 1.5,\r\n gap: .5,\r\n fontSize: 'button'\r\n },\r\n medium: {\r\n height: 44,\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 if (skeleton) {\r\n return <Skeleton\r\n {...slotProps?.skeleton}\r\n height={_size.height}\r\n animation={\"wave\"}\r\n sx={{\r\n ...slotProps?.skeleton?.sx,\r\n ..._size,\r\n ...cornerCss,\r\n }}\r\n />\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":[],"mappings":";;;;;;;;;AAyBA;;;AACI;AACI;AACA;AACA;AACA;;;AAIJ;AAAe;AACf;AAAa;AACb;AAAW;AACX;AAAa;AACb;AAAY;AACZ;AAAU;AACV;AAAe;AACf;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAGA;AAEA;AACI;AACI;AACA;AACA;AACA;AACH;AACD;AACI;AACA;AACA;AACA;AACH;AACD;AACI;AACA;AACA;AACA;AACH;;AAGL;AACI;AACA;AACA;;;AAIJ;;AAEI;AACA;;;AAIA;;;AA6CY;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACH;AAwBjB;;"}
@@ -0,0 +1,58 @@
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) => {
9
+ var { children } = _a, rest = tslib.__rest(_a, ["children"]);
10
+ let [_b] = core.useInterface("ButtonGroup", rest, {
11
+ size: "medium",
12
+ variant: "outline",
13
+ color: "default"
14
+ }), { color, variant, size } = _b, props = tslib.__rest(_b, ["color", "variant", "size"]);
15
+ const _p = {};
16
+ if (color)
17
+ _p.color = color;
18
+ const p = core.useBreakpointProps(_p);
19
+ color = p.color;
20
+ const sizes = {
21
+ small: {
22
+ height: 40,
23
+ },
24
+ medium: {
25
+ height: 46,
26
+ },
27
+ large: {
28
+ height: 52,
29
+ }
30
+ };
31
+ let borderColor = color === 'default' ? 'divider.secondary' : `${color}.secondary`;
32
+ return (jsxRuntime.jsx(core.Tag, Object.assign({}, props, sizes[size], { sxr: {
33
+ display: "inline-flex",
34
+ flexWrap: "nowrap",
35
+ overflow: "hidden",
36
+ radius: 1,
37
+ border: "1px solid",
38
+ borderColor: borderColor,
39
+ '& button, & button:hover': {
40
+ borderRight: "1px solid",
41
+ borderColor: borderColor
42
+ },
43
+ "& button:last-child, & button:last-child:hover": {
44
+ borderRight: "none"
45
+ }
46
+ }, baseClass: 'button-group', ref: ref, children: React.Children.map(children, (child) => {
47
+ return React.cloneElement(child, {
48
+ flex: "0 0 auto",
49
+ color,
50
+ variant,
51
+ size,
52
+ corner: "squar",
53
+ });
54
+ }) })));
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":["import 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":";;;;;;;AAWA,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;;;;"}
@@ -0,0 +1,174 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var tslib = require('tslib');
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var index$1 = require('../Stack/index.cjs');
8
+ var index$3 = require('../IconButton/index.cjs');
9
+ var IconKeyboardArrowRight = require('@xanui/icons/KeyboardArrowRight');
10
+ var IconKeyboardArrowLeft = require('@xanui/icons/KeyboardArrowLeft');
11
+ var index$2 = require('../Text/index.cjs');
12
+ var index$4 = require('../Button/index.cjs');
13
+ var ResetIcon = require('@xanui/icons/Replay');
14
+ var index = require('../ViewBox/index.cjs');
15
+ var core = require('@xanui/core');
16
+
17
+ const ShowYears = ({ color, year, today, onClick }) => {
18
+ let years = [];
19
+ const selectedRef = React.useRef(null);
20
+ for (let y = 1900; y < today.getFullYear() + 40; y++) {
21
+ const selected = year == y;
22
+ years.push(jsxRuntime.jsx(index$1, { sx: {
23
+ width: 50,
24
+ p: .1
25
+ }, 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));
26
+ }
27
+ React.useEffect(() => {
28
+ if (selectedRef === null || selectedRef === void 0 ? void 0 : selectedRef.current) {
29
+ selectedRef === null || selectedRef === void 0 ? void 0 : selectedRef.current.scrollIntoView({ behavior: "smooth", block: "center", inline: "nearest" });
30
+ }
31
+ }, []);
32
+ return (jsxRuntime.jsx(index$1, { sx: {
33
+ flexWrap: "wrap",
34
+ flexDirection: "row",
35
+ overflow: "hidden",
36
+ overflowY: "auto"
37
+ }, className: 'calender-years', children: years }));
38
+ };
39
+ const Calendar = (_a) => {
40
+ var { value } = _a, rest = tslib.__rest(_a, ["value"]);
41
+ let [{ onChange, viewMode: VMode, onButtonClick, color }] = core.useInterface("Calender", rest, {});
42
+ const _p = {};
43
+ if (VMode)
44
+ _p.VMode = VMode;
45
+ if (color)
46
+ _p.color = color;
47
+ const p = core.useBreakpointProps(_p);
48
+ color = p.color || "brand";
49
+ let [viewMode, setViewMode] = React.useState(p.VMode || "day");
50
+ let [selectedDate, setSelectedDate] = React.useState(new Date());
51
+ selectedDate = value instanceof Date ? value : selectedDate;
52
+ const [currentDate, setCurrentDate] = React.useState(selectedDate);
53
+ const year = currentDate.getFullYear();
54
+ const month = currentDate.getMonth();
55
+ const daysInMonth = 32 - new Date(year, month, 32).getDate();
56
+ const today = new Date();
57
+ const btnWidth = 36;
58
+ const boxWidth = btnWidth * 7;
59
+ const showCalendar = () => {
60
+ let firstDay = (new Date(year, month)).getDay();
61
+ let rows = [];
62
+ let row = [];
63
+ const dayNames = ['S', 'M', 'T', 'W', 'T', 'F', 'S'];
64
+ for (let i = 0; i < dayNames.length; i++) {
65
+ const k = dayNames[i];
66
+ row.push(jsxRuntime.jsx(index$1, { sx: {
67
+ width: btnWidth,
68
+ height: btnWidth,
69
+ alignItems: "center",
70
+ justifyContent: "center"
71
+ }, children: jsxRuntime.jsx(index$3, { variant: "text", color: "default", disabled: true, children: k }) }, "dayname-" + i));
72
+ }
73
+ rows.push(jsxRuntime.jsx(index$1, { flexRow: true, className: 'calender-day-row', children: row }, "header"));
74
+ let date = 1;
75
+ for (let i = 0; i < 6; i++) {
76
+ let row = [];
77
+ for (let j = 0; j < 7; j++) {
78
+ if (i === 0 && j < firstDay) {
79
+ row.push(jsxRuntime.jsx(index$1, { alignItems: "center", justifyContent: "center", sx: {
80
+ width: btnWidth,
81
+ height: btnWidth,
82
+ alignItems: "center",
83
+ justifyContent: "center"
84
+ } }, date + j + i));
85
+ }
86
+ else if (date > daysInMonth) {
87
+ break;
88
+ }
89
+ else {
90
+ let isToday = date === today.getDate() && year === today.getFullYear() && month === today.getMonth();
91
+ let isSelected = date === selectedDate.getDate() && year === selectedDate.getFullYear() && month === selectedDate.getMonth();
92
+ let css = {};
93
+ if (isToday) {
94
+ css = {
95
+ variant: "fill",
96
+ color: "default"
97
+ };
98
+ }
99
+ if (isSelected) {
100
+ css = {
101
+ variant: "fill",
102
+ color: color
103
+ };
104
+ }
105
+ row.push(jsxRuntime.jsx(index$1, { sx: {
106
+ width: btnWidth,
107
+ height: btnWidth,
108
+ alignItems: "center",
109
+ justifyContent: "center"
110
+ }, 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) => {
111
+ let d = e.target.getAttribute("data-value");
112
+ if (!d)
113
+ return;
114
+ let selectedDate = new Date(year, month, parseInt(d));
115
+ onChange ? onChange(selectedDate) : setSelectedDate(selectedDate);
116
+ onButtonClick && onButtonClick("day", selectedDate);
117
+ }, children: date })) }, date + j + i));
118
+ date++;
119
+ }
120
+ }
121
+ rows.push(jsxRuntime.jsx(index$1, { flexRow: true, className: 'calender-day-row', children: row }, "row" + i));
122
+ }
123
+ return rows;
124
+ };
125
+ const showMonth = () => {
126
+ let months = [];
127
+ const monthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];
128
+ for (let m = 0; m < monthNames.length; m++) {
129
+ const selected = currentDate.getMonth() === m;
130
+ months.push(jsxRuntime.jsx(index$1, { width: "50%", 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: () => {
131
+ const v = new Date(currentDate.getFullYear(), m);
132
+ setCurrentDate(v);
133
+ setViewMode("day");
134
+ onButtonClick && onButtonClick("month", v);
135
+ }, sx: {
136
+ color: selected ? "brand.text" : "text.primary"
137
+ }, children: monthNames[m] }) }, m));
138
+ }
139
+ return (jsxRuntime.jsx(index$1, { className: 'calender-months', sx: {
140
+ flexWrap: "wrap",
141
+ overflow: "hidden",
142
+ overflowY: "auto",
143
+ flexDirection: "row"
144
+ }, children: months }));
145
+ };
146
+ let view = null;
147
+ switch (viewMode) {
148
+ case "year":
149
+ view = jsxRuntime.jsx(ShowYears, { color: color, today: today, year: year, boxWidth: boxWidth, onClick: (y) => {
150
+ currentDate.setFullYear(y);
151
+ setCurrentDate(currentDate);
152
+ setViewMode("month");
153
+ onButtonClick && onButtonClick("year", currentDate);
154
+ } });
155
+ break;
156
+ case "month":
157
+ view = showMonth();
158
+ break;
159
+ default:
160
+ view = (jsxRuntime.jsx(jsxRuntime.Fragment, { children: showCalendar() }));
161
+ break;
162
+ }
163
+ return (jsxRuntime.jsx(index, { className: 'calender-root', maxHeight: 308, width: 250, radius: 1, bgcolor: "background.secondary", startContent: jsxRuntime.jsxs(index$1, { className: 'calender-header', flexRow: true, alignItems: "center", justifyContent: "space-between", p: 1, children: [jsxRuntime.jsx(index$2, { 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: () => {
164
+ setCurrentDate(new Date());
165
+ onChange ? onChange(new Date()) : setSelectedDate(new Date());
166
+ }, children: jsxRuntime.jsx(ResetIcon, { fontSize: 20 }) }), jsxRuntime.jsx(index$3, { color: "default", variant: 'text', size: 28, onClick: () => {
167
+ setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() - 1, 1));
168
+ }, children: jsxRuntime.jsx(IconKeyboardArrowLeft, {}) }), jsxRuntime.jsx(index$3, { color: "default", variant: 'text', size: 28, onClick: () => {
169
+ setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() + 1, 1));
170
+ }, children: jsxRuntime.jsx(IconKeyboardArrowRight, {}) })] }), children: jsxRuntime.jsx(index$1, { height: "100%", p: .5, className: 'calender-container', children: view }) }));
171
+ };
172
+
173
+ module.exports = Calendar;
174
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Calendar/index.tsx"],"sourcesContent":["'use client'\r\nimport { 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, 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: 50,\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 = 36\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 let row = []\r\n\r\n const dayNames = ['S', 'M', 'T', 'W', 'T', 'F', 'S'];\r\n for (let i = 0; i < dayNames.length; i++) {\r\n const k = dayNames[i];\r\n row.push(<Stack\r\n key={\"dayname-\" + i}\r\n sx={{\r\n width: btnWidth,\r\n height: btnWidth,\r\n alignItems: \"center\",\r\n justifyContent: \"center\"\r\n }}\r\n >\r\n <IconButton\r\n variant={\"text\"}\r\n color=\"default\"\r\n disabled\r\n >\r\n {k}\r\n </IconButton>\r\n </Stack>)\r\n }\r\n\r\n rows.push(<Stack flexRow key={\"header\"} className='calender-day-row'>\r\n {row}\r\n </Stack>);\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 alignItems=\"center\"\r\n justifyContent=\"center\"\r\n key={date + j + i}\r\n sx={{\r\n width: btnWidth,\r\n height: btnWidth,\r\n alignItems: \"center\",\r\n justifyContent: \"center\"\r\n }}\r\n >\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: \"fill\",\r\n color: \"default\"\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={\"50%\"}\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\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.secondary\"\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":[],"mappings":";;;;;;;;;;;;;;;;AAqBA;;AAEI;AACA;AACI;AACA;AAGQ;AACA;AACH;;;;;;;AAuBT;AAGY;AACA;AACA;AACA;AACH;AAMb;AAGA;AAAkB;;;AAGd;AAAW;AACX;AAAW;AACX;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAII;;;AAIA;AACA;AACI;AACA;AAGQ;AACA;AACA;AACA;;;AAaZ;;AAKA;;AAEI;;AAEQ;AAKQ;AACA;AACA;AACA;AACH;;AAIF;;;;;;;;AAQC;AACI;AACA;;;;AAKJ;AACI;AACA;;;AAIR;AAEQ;AACA;AACA;AACA;;;AAaI;;AACA;AACA;AACA;;AAMZ;;;AAGR;;AAIJ;AACJ;;;;AAKI;;AAGI;AAeY;;;AAGA;;;;;;AAeJ;AACA;AACA;AACA;;AAMhB;;;AAII;;AAOY;;;AAGA;AACJ;;AAGR;;;AAGA;AACI;;;;AA8BgB;AACA;AACJ;AASI;;AAUA;;AAa5B;;"}