@xanui/ui 1.0.0

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 (320) hide show
  1. package/Accordion/index.d.ts +32 -0
  2. package/Accordion/index.js +82 -0
  3. package/Accordion/index.js.map +1 -0
  4. package/Accordion/index.mjs +82 -0
  5. package/Accordion/index.mjs.map +1 -0
  6. package/Alert/index.d.ts +41 -0
  7. package/Alert/index.js +137 -0
  8. package/Alert/index.js.map +1 -0
  9. package/Alert/index.mjs +137 -0
  10. package/Alert/index.mjs.map +1 -0
  11. package/Avatar/index.d.ts +10 -0
  12. package/Avatar/index.js +34 -0
  13. package/Avatar/index.js.map +1 -0
  14. package/Avatar/index.mjs +34 -0
  15. package/Avatar/index.mjs.map +1 -0
  16. package/Badge/index.d.ts +16 -0
  17. package/Badge/index.js +68 -0
  18. package/Badge/index.js.map +1 -0
  19. package/Badge/index.mjs +68 -0
  20. package/Badge/index.mjs.map +1 -0
  21. package/Box/index.d.ts +8 -0
  22. package/Box/index.js +4 -0
  23. package/Box/index.js.map +1 -0
  24. package/Box/index.mjs +4 -0
  25. package/Box/index.mjs.map +1 -0
  26. package/Button/index.d.ts +22 -0
  27. package/Button/index.js +77 -0
  28. package/Button/index.js.map +1 -0
  29. package/Button/index.mjs +77 -0
  30. package/Button/index.mjs.map +1 -0
  31. package/ButtonGroup/index.d.ts +14 -0
  32. package/ButtonGroup/index.js +47 -0
  33. package/ButtonGroup/index.js.map +1 -0
  34. package/ButtonGroup/index.mjs +47 -0
  35. package/ButtonGroup/index.mjs.map +1 -0
  36. package/Calendar/index.d.ts +14 -0
  37. package/Calendar/index.js +140 -0
  38. package/Calendar/index.js.map +1 -0
  39. package/Calendar/index.mjs +140 -0
  40. package/Calendar/index.mjs.map +1 -0
  41. package/CalendarInput/index.d.ts +18 -0
  42. package/CalendarInput/index.js +11 -0
  43. package/CalendarInput/index.js.map +1 -0
  44. package/CalendarInput/index.mjs +11 -0
  45. package/CalendarInput/index.mjs.map +1 -0
  46. package/Checkbox/index.d.ts +15 -0
  47. package/Checkbox/index.js +44 -0
  48. package/Checkbox/index.js.map +1 -0
  49. package/Checkbox/index.mjs +44 -0
  50. package/Checkbox/index.mjs.map +1 -0
  51. package/Chip/index.d.ts +17 -0
  52. package/Chip/index.js +59 -0
  53. package/Chip/index.js.map +1 -0
  54. package/Chip/index.mjs +59 -0
  55. package/Chip/index.mjs.map +1 -0
  56. package/CircleProgress/index.d.ts +20 -0
  57. package/CircleProgress/index.js +118 -0
  58. package/CircleProgress/index.js.map +1 -0
  59. package/CircleProgress/index.mjs +118 -0
  60. package/CircleProgress/index.mjs.map +1 -0
  61. package/ClickOutside/index.d.ts +10 -0
  62. package/ClickOutside/index.js +16 -0
  63. package/ClickOutside/index.js.map +1 -0
  64. package/ClickOutside/index.mjs +16 -0
  65. package/ClickOutside/index.mjs.map +1 -0
  66. package/Collaps/index.d.ts +8 -0
  67. package/Collaps/index.js +18 -0
  68. package/Collaps/index.js.map +1 -0
  69. package/Collaps/index.mjs +18 -0
  70. package/Collaps/index.mjs.map +1 -0
  71. package/Container/index.d.ts +10 -0
  72. package/Container/index.js +19 -0
  73. package/Container/index.js.map +1 -0
  74. package/Container/index.mjs +19 -0
  75. package/Container/index.mjs.map +1 -0
  76. package/Datatable/FilterBox.js +19 -0
  77. package/Datatable/FilterBox.js.map +1 -0
  78. package/Datatable/FilterBox.mjs +19 -0
  79. package/Datatable/FilterBox.mjs.map +1 -0
  80. package/Datatable/Row.js +41 -0
  81. package/Datatable/Row.js.map +1 -0
  82. package/Datatable/Row.mjs +41 -0
  83. package/Datatable/Row.mjs.map +1 -0
  84. package/Datatable/SelectedBox.js +11 -0
  85. package/Datatable/SelectedBox.js.map +1 -0
  86. package/Datatable/SelectedBox.mjs +11 -0
  87. package/Datatable/SelectedBox.mjs.map +1 -0
  88. package/Datatable/Table.js +11 -0
  89. package/Datatable/Table.js.map +1 -0
  90. package/Datatable/Table.mjs +11 -0
  91. package/Datatable/Table.mjs.map +1 -0
  92. package/Datatable/TableHead.js +35 -0
  93. package/Datatable/TableHead.js.map +1 -0
  94. package/Datatable/TableHead.mjs +35 -0
  95. package/Datatable/TableHead.mjs.map +1 -0
  96. package/Datatable/index.d.ts +71 -0
  97. package/Datatable/index.js +35 -0
  98. package/Datatable/index.js.map +1 -0
  99. package/Datatable/index.mjs +35 -0
  100. package/Datatable/index.mjs.map +1 -0
  101. package/Divider/index.d.ts +12 -0
  102. package/Divider/index.js +21 -0
  103. package/Divider/index.js.map +1 -0
  104. package/Divider/index.mjs +21 -0
  105. package/Divider/index.mjs.map +1 -0
  106. package/Drawer/index.d.ts +25 -0
  107. package/Drawer/index.js +57 -0
  108. package/Drawer/index.js.map +1 -0
  109. package/Drawer/index.mjs +57 -0
  110. package/Drawer/index.mjs.map +1 -0
  111. package/Form/index.d.ts +8 -0
  112. package/Form/index.js +34 -0
  113. package/Form/index.js.map +1 -0
  114. package/Form/index.mjs +34 -0
  115. package/Form/index.mjs.map +1 -0
  116. package/GridContainer/index.d.ts +8 -0
  117. package/GridContainer/index.js +9 -0
  118. package/GridContainer/index.js.map +1 -0
  119. package/GridContainer/index.mjs +9 -0
  120. package/GridContainer/index.mjs.map +1 -0
  121. package/GridItem/index.d.ts +14 -0
  122. package/GridItem/index.js +10 -0
  123. package/GridItem/index.js.map +1 -0
  124. package/GridItem/index.mjs +10 -0
  125. package/GridItem/index.mjs.map +1 -0
  126. package/IconButton/index.d.ts +13 -0
  127. package/IconButton/index.js +48 -0
  128. package/IconButton/index.js.map +1 -0
  129. package/IconButton/index.mjs +48 -0
  130. package/IconButton/index.mjs.map +1 -0
  131. package/Image/index.d.ts +10 -0
  132. package/Image/index.js +16 -0
  133. package/Image/index.js.map +1 -0
  134. package/Image/index.mjs +16 -0
  135. package/Image/index.mjs.map +1 -0
  136. package/Input/index.d.ts +26 -0
  137. package/Input/index.js +149 -0
  138. package/Input/index.js.map +1 -0
  139. package/Input/index.mjs +149 -0
  140. package/Input/index.mjs.map +1 -0
  141. package/Label/index.d.ts +8 -0
  142. package/Label/index.js +10 -0
  143. package/Label/index.js.map +1 -0
  144. package/Label/index.mjs +10 -0
  145. package/Label/index.mjs.map +1 -0
  146. package/Layer/index.d.ts +34 -0
  147. package/Layer/index.js +73 -0
  148. package/Layer/index.js.map +1 -0
  149. package/Layer/index.mjs +73 -0
  150. package/Layer/index.mjs.map +1 -0
  151. package/LineProgress/index.d.ts +15 -0
  152. package/LineProgress/index.js +48 -0
  153. package/LineProgress/index.js.map +1 -0
  154. package/LineProgress/index.mjs +48 -0
  155. package/LineProgress/index.mjs.map +1 -0
  156. package/List/index.d.ts +13 -0
  157. package/List/index.js +51 -0
  158. package/List/index.js.map +1 -0
  159. package/List/index.mjs +51 -0
  160. package/List/index.mjs.map +1 -0
  161. package/ListItem/index.d.ts +13 -0
  162. package/ListItem/index.js +26 -0
  163. package/ListItem/index.js.map +1 -0
  164. package/ListItem/index.mjs +26 -0
  165. package/ListItem/index.mjs.map +1 -0
  166. package/LoadingBox/index.d.ts +15 -0
  167. package/LoadingBox/index.js +22 -0
  168. package/LoadingBox/index.js.map +1 -0
  169. package/LoadingBox/index.mjs +22 -0
  170. package/LoadingBox/index.mjs.map +1 -0
  171. package/Menu/getOrigin.js +42 -0
  172. package/Menu/getOrigin.js.map +1 -0
  173. package/Menu/getOrigin.mjs +42 -0
  174. package/Menu/getOrigin.mjs.map +1 -0
  175. package/Menu/index.d.ts +22 -0
  176. package/Menu/index.js +47 -0
  177. package/Menu/index.js.map +1 -0
  178. package/Menu/index.mjs +47 -0
  179. package/Menu/index.mjs.map +1 -0
  180. package/Menu/placedMenu.d.ts +5 -0
  181. package/Menu/placedMenu.js +95 -0
  182. package/Menu/placedMenu.js.map +1 -0
  183. package/Menu/placedMenu.mjs +95 -0
  184. package/Menu/placedMenu.mjs.map +1 -0
  185. package/Modal/index.d.ts +19 -0
  186. package/Modal/index.js +38 -0
  187. package/Modal/index.js.map +1 -0
  188. package/Modal/index.mjs +38 -0
  189. package/Modal/index.mjs.map +1 -0
  190. package/NoSSR/index.d.ts +3 -0
  191. package/NoSSR/index.js +7 -0
  192. package/NoSSR/index.js.map +1 -0
  193. package/NoSSR/index.mjs +7 -0
  194. package/NoSSR/index.mjs.map +1 -0
  195. package/Option/index.d.ts +10 -0
  196. package/Option/index.js +4 -0
  197. package/Option/index.js.map +1 -0
  198. package/Option/index.mjs +4 -0
  199. package/Option/index.mjs.map +1 -0
  200. package/Paper/index.d.ts +8 -0
  201. package/Paper/index.js +5 -0
  202. package/Paper/index.js.map +1 -0
  203. package/Paper/index.mjs +5 -0
  204. package/Paper/index.mjs.map +1 -0
  205. package/Portal/index.d.ts +11 -0
  206. package/Portal/index.js +26 -0
  207. package/Portal/index.js.map +1 -0
  208. package/Portal/index.mjs +26 -0
  209. package/Portal/index.mjs.map +1 -0
  210. package/Radio/index.d.ts +6 -0
  211. package/Radio/index.js +4 -0
  212. package/Radio/index.js.map +1 -0
  213. package/Radio/index.mjs +4 -0
  214. package/Radio/index.mjs.map +1 -0
  215. package/Scrollbar/index.d.ts +14 -0
  216. package/Scrollbar/index.js +65 -0
  217. package/Scrollbar/index.js.map +1 -0
  218. package/Scrollbar/index.mjs +65 -0
  219. package/Scrollbar/index.mjs.map +1 -0
  220. package/Select/index.d.ts +24 -0
  221. package/Select/index.js +35 -0
  222. package/Select/index.js.map +1 -0
  223. package/Select/index.mjs +35 -0
  224. package/Select/index.mjs.map +1 -0
  225. package/Stack/index.d.ts +8 -0
  226. package/Stack/index.js +7 -0
  227. package/Stack/index.js.map +1 -0
  228. package/Stack/index.mjs +7 -0
  229. package/Stack/index.mjs.map +1 -0
  230. package/Switch/index.d.ts +19 -0
  231. package/Switch/index.js +68 -0
  232. package/Switch/index.js.map +1 -0
  233. package/Switch/index.mjs +68 -0
  234. package/Switch/index.mjs.map +1 -0
  235. package/Tab/index.d.ts +11 -0
  236. package/Tab/index.js +5 -0
  237. package/Tab/index.js.map +1 -0
  238. package/Tab/index.mjs +5 -0
  239. package/Tab/index.mjs.map +1 -0
  240. package/Table/index.d.ts +14 -0
  241. package/Table/index.js +77 -0
  242. package/Table/index.js.map +1 -0
  243. package/Table/index.mjs +77 -0
  244. package/Table/index.mjs.map +1 -0
  245. package/TableBody/index.d.ts +8 -0
  246. package/TableBody/index.js +4 -0
  247. package/TableBody/index.js.map +1 -0
  248. package/TableBody/index.mjs +4 -0
  249. package/TableBody/index.mjs.map +1 -0
  250. package/TableCell/index.d.ts +10 -0
  251. package/TableCell/index.js +4 -0
  252. package/TableCell/index.js.map +1 -0
  253. package/TableCell/index.mjs +4 -0
  254. package/TableCell/index.mjs.map +1 -0
  255. package/TableFooter/index.d.ts +8 -0
  256. package/TableFooter/index.js +4 -0
  257. package/TableFooter/index.js.map +1 -0
  258. package/TableFooter/index.mjs +4 -0
  259. package/TableFooter/index.mjs.map +1 -0
  260. package/TableHead/index.d.ts +8 -0
  261. package/TableHead/index.js +4 -0
  262. package/TableHead/index.js.map +1 -0
  263. package/TableHead/index.mjs +4 -0
  264. package/TableHead/index.mjs.map +1 -0
  265. package/TablePagination/index.d.ts +26 -0
  266. package/TablePagination/index.js +51 -0
  267. package/TablePagination/index.js.map +1 -0
  268. package/TablePagination/index.mjs +51 -0
  269. package/TablePagination/index.mjs.map +1 -0
  270. package/TableRow/index.d.ts +8 -0
  271. package/TableRow/index.js +4 -0
  272. package/TableRow/index.js.map +1 -0
  273. package/TableRow/index.mjs +4 -0
  274. package/TableRow/index.mjs.map +1 -0
  275. package/Tabs/index.d.ts +24 -0
  276. package/Tabs/index.js +188 -0
  277. package/Tabs/index.js.map +1 -0
  278. package/Tabs/index.mjs +188 -0
  279. package/Tabs/index.mjs.map +1 -0
  280. package/Text/index.d.ts +10 -0
  281. package/Text/index.js +10 -0
  282. package/Text/index.js.map +1 -0
  283. package/Text/index.mjs +10 -0
  284. package/Text/index.mjs.map +1 -0
  285. package/ThemeProvider/RenderRoot.js +22 -0
  286. package/ThemeProvider/RenderRoot.js.map +1 -0
  287. package/ThemeProvider/RenderRoot.mjs +22 -0
  288. package/ThemeProvider/RenderRoot.mjs.map +1 -0
  289. package/ThemeProvider/index.d.ts +8 -0
  290. package/ThemeProvider/index.js +4 -0
  291. package/ThemeProvider/index.js.map +1 -0
  292. package/ThemeProvider/index.mjs +4 -0
  293. package/ThemeProvider/index.mjs.map +1 -0
  294. package/Toast/index.d.ts +20 -0
  295. package/Toast/index.js +145 -0
  296. package/Toast/index.js.map +1 -0
  297. package/Toast/index.mjs +145 -0
  298. package/Toast/index.mjs.map +1 -0
  299. package/Tooltip/index.d.ts +16 -0
  300. package/Tooltip/index.js +29 -0
  301. package/Tooltip/index.js.map +1 -0
  302. package/Tooltip/index.mjs +29 -0
  303. package/Tooltip/index.mjs.map +1 -0
  304. package/ViewBox/index.d.ts +16 -0
  305. package/ViewBox/index.js +21 -0
  306. package/ViewBox/index.js.map +1 -0
  307. package/ViewBox/index.mjs +21 -0
  308. package/ViewBox/index.mjs.map +1 -0
  309. package/index.d.ts +56 -0
  310. package/index.js +1 -0
  311. package/index.js.map +1 -0
  312. package/index.mjs +1 -0
  313. package/index.mjs.map +1 -0
  314. package/package.json +41 -0
  315. package/readme.md +0 -0
  316. package/useCorner/index.d.ts +5 -0
  317. package/useCorner/index.js +17 -0
  318. package/useCorner/index.js.map +1 -0
  319. package/useCorner/index.mjs +17 -0
  320. package/useCorner/index.mjs.map +1 -0
@@ -0,0 +1,15 @@
1
+ import React, { ReactElement } from 'react';
2
+ import { TagProps, useBreakpointPropsType, ColorTemplateColors } from '@xanui/core';
3
+
4
+ type CheckboxProps = Omit<TagProps<"input">, "color" | "size" | "component" | "type" | "checked"> & {
5
+ checkIcon?: useBreakpointPropsType<ReactElement>;
6
+ uncheckIcon?: useBreakpointPropsType<ReactElement>;
7
+ indeterminate?: useBreakpointPropsType<boolean>;
8
+ checked?: boolean;
9
+ size?: useBreakpointPropsType<number | "small" | "medium" | "large">;
10
+ color?: useBreakpointPropsType<ColorTemplateColors>;
11
+ };
12
+ declare const Checkbox: React.ForwardRefExoticComponent<Omit<CheckboxProps, "ref"> & React.RefAttributes<any>>;
13
+
14
+ export { Checkbox as default };
15
+ export type { CheckboxProps };
@@ -0,0 +1,44 @@
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'),CheckIcon=require('@xanui/icons/CheckBox'),UnCheckIcon=require('@xanui/icons/CheckBoxOutlineBlank'),IndeterminateCheckBoxIcon=require('@xanui/icons/IndeterminateCheckBox');const Checkbox = React.forwardRef((props, ref) => {
2
+ let [_a] = core.useInterface("Checkbox", props, {}), { color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange } = _a, rest = tslib.__rest(_a, ["color", "size", "checkIcon", "uncheckIcon", "checked", "indeterminate", "disabled", "onChange"]);
3
+ const _p = {};
4
+ if (checkIcon)
5
+ _p.checkIcon = checkIcon;
6
+ if (uncheckIcon)
7
+ _p.uncheckIcon = uncheckIcon;
8
+ if (indeterminate)
9
+ _p.indeterminate = indeterminate;
10
+ if (size)
11
+ _p.size = size;
12
+ if (color)
13
+ _p.color = color;
14
+ const p = core.useBreakpointProps(_p);
15
+ checkIcon = p.checkIcon;
16
+ uncheckIcon = p.uncheckIcon;
17
+ indeterminate = p.indeterminate;
18
+ size = p.size;
19
+ color = p.color;
20
+ const [c, set] = React.useState(false);
21
+ checked !== null && checked !== void 0 ? checked : (checked = c);
22
+ size !== null && size !== void 0 ? size : (size = "medium");
23
+ color !== null && color !== void 0 ? color : (color = "brand");
24
+ onChange = onChange || (() => set(!c));
25
+ if (indeterminate) {
26
+ checked = true;
27
+ checkIcon = jsxRuntime.jsx(IndeterminateCheckBoxIcon, {});
28
+ }
29
+ let sizes = {
30
+ small: 22,
31
+ medium: 24,
32
+ large: 32
33
+ };
34
+ if (typeof size === 'string' && sizes[size]) {
35
+ size = sizes[size];
36
+ }
37
+ return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(core.Tag, Object.assign({ baseClass: 'checkbox', onClick: () => {
38
+ onChange && onChange();
39
+ }, sxr: Object.assign({ height: size, width: size, display: "flex", alignItems: "center", justifyContent: "center", color: checked ? color : "text.secondary", cursor: "pointer", disabled: disabled, "& svg": {
40
+ fontSize: size
41
+ } }, rest === null || rest === void 0 ? void 0 : rest.sx) }, { children: checked ? (checkIcon || jsxRuntime.jsx(CheckIcon, {})) : (uncheckIcon || jsxRuntime.jsx(UnCheckIcon, {})) })), jsxRuntime.jsx(core.Tag, Object.assign({}, rest, { component: 'input', ref: ref, readOnly: true, type: "checkbox", checked: checked, sxr: {
42
+ display: "none!important"
43
+ } }))] }));
44
+ });exports.default=Checkbox;//# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/Checkbox/index.tsx"],"sourcesContent":["\nimport React, { useState, ReactElement } from 'react';\nimport { Tag, useInterface, ColorTemplateColors, TagProps, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\nimport CheckIcon from '@xanui/icons/CheckBox'\nimport UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank'\nimport IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';\n\n\nexport type CheckboxProps = Omit<TagProps<\"input\">, \"color\" | \"size\" | \"component\" | \"type\" | \"checked\"> & {\n checkIcon?: useBreakpointPropsType<ReactElement>;\n uncheckIcon?: useBreakpointPropsType<ReactElement>;\n indeterminate?: useBreakpointPropsType<boolean>;\n checked?: boolean;\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\n color?: useBreakpointPropsType<ColorTemplateColors>;\n}\n\nconst Checkbox = React.forwardRef((props: CheckboxProps, ref?: React.Ref<any>) => {\n let [{ color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange, ...rest }] = useInterface<any>(\"Checkbox\", props, {})\n const _p: any = {}\n if (checkIcon) _p.checkIcon = checkIcon\n if (uncheckIcon) _p.uncheckIcon = uncheckIcon\n if (indeterminate) _p.indeterminate = indeterminate\n if (size) _p.size = size\n if (color) _p.color = color\n const p: any = useBreakpointProps(_p)\n\n checkIcon = p.checkIcon\n uncheckIcon = p.uncheckIcon\n indeterminate = p.indeterminate\n size = p.size\n color = p.color\n\n const [c, set] = useState(false)\n checked ??= c\n size ??= \"medium\"\n color ??= \"brand\"\n\n onChange = onChange || (() => set(!c));\n if (indeterminate) {\n checked = true\n checkIcon = <IndeterminateCheckBoxIcon />\n }\n\n let sizes: any = {\n small: 22,\n medium: 24,\n large: 32\n }\n\n if (typeof size === 'string' && sizes[size]) {\n size = sizes[size]\n }\n\n return (\n <>\n <Tag\n baseClass='checkbox'\n onClick={() => {\n onChange && onChange()\n }}\n sxr={{\n height: size,\n width: size,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n color: checked ? color : \"text.secondary\",\n cursor: \"pointer\",\n disabled: disabled,\n \"& svg\": {\n fontSize: size\n },\n ...rest?.sx\n }}\n >\n {checked ? (checkIcon || <CheckIcon />) : (uncheckIcon || <UnCheckIcon />)}\n </Tag>\n <Tag\n {...rest}\n component='input'\n ref={ref}\n readOnly\n type=\"checkbox\"\n checked={checked}\n sxr={{\n display: \"none!important\"\n }}\n />\n </>\n )\n})\n\nexport default Checkbox\n"],"names":["useInterface","__rest","useBreakpointProps","useState","_jsx","_jsxs","_Fragment","Tag"],"mappings":"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"}
@@ -0,0 +1,44 @@
1
+ import {__rest}from'tslib';import {jsx,jsxs,Fragment}from'react/jsx-runtime';import React,{useState}from'react';import {useInterface,useBreakpointProps,Tag}from'@xanui/core';import CheckIcon from'@xanui/icons/CheckBox';import UnCheckIcon from'@xanui/icons/CheckBoxOutlineBlank';import IndeterminateCheckBoxIcon from'@xanui/icons/IndeterminateCheckBox';const Checkbox = React.forwardRef((props, ref) => {
2
+ let [_a] = useInterface("Checkbox", props, {}), { color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange } = _a, rest = __rest(_a, ["color", "size", "checkIcon", "uncheckIcon", "checked", "indeterminate", "disabled", "onChange"]);
3
+ const _p = {};
4
+ if (checkIcon)
5
+ _p.checkIcon = checkIcon;
6
+ if (uncheckIcon)
7
+ _p.uncheckIcon = uncheckIcon;
8
+ if (indeterminate)
9
+ _p.indeterminate = indeterminate;
10
+ if (size)
11
+ _p.size = size;
12
+ if (color)
13
+ _p.color = color;
14
+ const p = useBreakpointProps(_p);
15
+ checkIcon = p.checkIcon;
16
+ uncheckIcon = p.uncheckIcon;
17
+ indeterminate = p.indeterminate;
18
+ size = p.size;
19
+ color = p.color;
20
+ const [c, set] = useState(false);
21
+ checked !== null && checked !== void 0 ? checked : (checked = c);
22
+ size !== null && size !== void 0 ? size : (size = "medium");
23
+ color !== null && color !== void 0 ? color : (color = "brand");
24
+ onChange = onChange || (() => set(!c));
25
+ if (indeterminate) {
26
+ checked = true;
27
+ checkIcon = jsx(IndeterminateCheckBoxIcon, {});
28
+ }
29
+ let sizes = {
30
+ small: 22,
31
+ medium: 24,
32
+ large: 32
33
+ };
34
+ if (typeof size === 'string' && sizes[size]) {
35
+ size = sizes[size];
36
+ }
37
+ return (jsxs(Fragment, { children: [jsx(Tag, Object.assign({ baseClass: 'checkbox', onClick: () => {
38
+ onChange && onChange();
39
+ }, sxr: Object.assign({ height: size, width: size, display: "flex", alignItems: "center", justifyContent: "center", color: checked ? color : "text.secondary", cursor: "pointer", disabled: disabled, "& svg": {
40
+ fontSize: size
41
+ } }, rest === null || rest === void 0 ? void 0 : rest.sx) }, { children: checked ? (checkIcon || jsx(CheckIcon, {})) : (uncheckIcon || jsx(UnCheckIcon, {})) })), jsx(Tag, Object.assign({}, rest, { component: 'input', ref: ref, readOnly: true, type: "checkbox", checked: checked, sxr: {
42
+ display: "none!important"
43
+ } }))] }));
44
+ });export{Checkbox as default};//# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../src/Checkbox/index.tsx"],"sourcesContent":["\nimport React, { useState, ReactElement } from 'react';\nimport { Tag, useInterface, ColorTemplateColors, TagProps, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\nimport CheckIcon from '@xanui/icons/CheckBox'\nimport UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank'\nimport IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';\n\n\nexport type CheckboxProps = Omit<TagProps<\"input\">, \"color\" | \"size\" | \"component\" | \"type\" | \"checked\"> & {\n checkIcon?: useBreakpointPropsType<ReactElement>;\n uncheckIcon?: useBreakpointPropsType<ReactElement>;\n indeterminate?: useBreakpointPropsType<boolean>;\n checked?: boolean;\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\n color?: useBreakpointPropsType<ColorTemplateColors>;\n}\n\nconst Checkbox = React.forwardRef((props: CheckboxProps, ref?: React.Ref<any>) => {\n let [{ color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange, ...rest }] = useInterface<any>(\"Checkbox\", props, {})\n const _p: any = {}\n if (checkIcon) _p.checkIcon = checkIcon\n if (uncheckIcon) _p.uncheckIcon = uncheckIcon\n if (indeterminate) _p.indeterminate = indeterminate\n if (size) _p.size = size\n if (color) _p.color = color\n const p: any = useBreakpointProps(_p)\n\n checkIcon = p.checkIcon\n uncheckIcon = p.uncheckIcon\n indeterminate = p.indeterminate\n size = p.size\n color = p.color\n\n const [c, set] = useState(false)\n checked ??= c\n size ??= \"medium\"\n color ??= \"brand\"\n\n onChange = onChange || (() => set(!c));\n if (indeterminate) {\n checked = true\n checkIcon = <IndeterminateCheckBoxIcon />\n }\n\n let sizes: any = {\n small: 22,\n medium: 24,\n large: 32\n }\n\n if (typeof size === 'string' && sizes[size]) {\n size = sizes[size]\n }\n\n return (\n <>\n <Tag\n baseClass='checkbox'\n onClick={() => {\n onChange && onChange()\n }}\n sxr={{\n height: size,\n width: size,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n color: checked ? color : \"text.secondary\",\n cursor: \"pointer\",\n disabled: disabled,\n \"& svg\": {\n fontSize: size\n },\n ...rest?.sx\n }}\n >\n {checked ? (checkIcon || <CheckIcon />) : (uncheckIcon || <UnCheckIcon />)}\n </Tag>\n <Tag\n {...rest}\n component='input'\n ref={ref}\n readOnly\n type=\"checkbox\"\n checked={checked}\n sxr={{\n display: \"none!important\"\n }}\n />\n </>\n )\n})\n\nexport default Checkbox\n"],"names":["_jsx","_jsxs","_Fragment"],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import React, { ReactElement } from 'react';
2
+ import { TagComponentType, TagProps, useBreakpointPropsType, ColorTemplateColors, ColorTemplateType } from '@xanui/core';
3
+ import { UseCornerTypes } from '../useCorner/index.js';
4
+
5
+ type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, "color" | "children" | "size"> & {
6
+ label: useBreakpointPropsType<string | ReactElement>;
7
+ startIcon?: useBreakpointPropsType<ReactElement>;
8
+ endIcon?: useBreakpointPropsType<ReactElement>;
9
+ color?: useBreakpointPropsType<ColorTemplateColors>;
10
+ variant?: useBreakpointPropsType<ColorTemplateType>;
11
+ corner?: useBreakpointPropsType<UseCornerTypes>;
12
+ size?: useBreakpointPropsType<"small" | "medium" | "large">;
13
+ };
14
+ declare const Chip: React.ForwardRefExoticComponent<Omit<ChipProps<TagComponentType>, "ref"> & React.RefAttributes<any>>;
15
+
16
+ export { Chip as default };
17
+ export type { ChipProps };
package/Chip/index.js ADDED
@@ -0,0 +1,59 @@
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=require('../useCorner/index.js');const Chip = React.forwardRef((props, ref) => {
2
+ let [_a] = core.useInterface("Chip", props, {}), { label, variant, startIcon, endIcon, color, corner, size } = _a, rest = tslib.__rest(_a, ["label", "variant", "startIcon", "endIcon", "color", "corner", "size"]);
3
+ const _p = {};
4
+ if (label)
5
+ _p.label = label;
6
+ if (startIcon)
7
+ _p.startIcon = startIcon;
8
+ if (endIcon)
9
+ _p.endIcon = endIcon;
10
+ if (color)
11
+ _p.color = color;
12
+ if (variant)
13
+ _p.variant = variant;
14
+ if (corner)
15
+ _p.corner = corner;
16
+ if (size)
17
+ _p.size = size;
18
+ const p = core.useBreakpointProps(_p);
19
+ label = p.label;
20
+ startIcon = p.startIcon;
21
+ endIcon = p.endIcon;
22
+ color = p.color || "brand";
23
+ variant = p.variant || "fill";
24
+ corner = p.corner || "circle";
25
+ size = p.size || "medium";
26
+ rest.sx = rest.sx || {};
27
+ const cornerCss = index.default(corner);
28
+ const template = core.useColorTemplate(color, variant);
29
+ template === null || template === void 0 ? true : delete template.hover;
30
+ const sizes = {
31
+ small: {
32
+ height: 24,
33
+ gap: .5,
34
+ fontSize: 12
35
+ },
36
+ medium: {
37
+ height: 34,
38
+ gap: 1,
39
+ fontSize: 14,
40
+ },
41
+ large: {
42
+ height: 38,
43
+ fontSize: 15,
44
+ gap: 1,
45
+ }
46
+ };
47
+ return (jsxRuntime.jsxs(core.Tag, Object.assign({}, cornerCss, template, (sizes[size] || {}), rest, { sxr: {
48
+ display: "inline-flex",
49
+ flexDirection: "row",
50
+ alignItems: "center",
51
+ transition: "background .3s",
52
+ fontFamily: "default",
53
+ overflow: "hidden",
54
+ px: startIcon || endIcon ? 1 : 1.5,
55
+ }, baseClass: 'chip', ref: ref }, { children: [startIcon, jsxRuntime.jsx(core.Tag, Object.assign({ sxr: {
56
+ alignItems: "center",
57
+ flexBox: true
58
+ } }, { children: label })), endIcon] })));
59
+ });exports.default=Chip;//# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/Chip/index.tsx"],"sourcesContent":["\nimport React, { ReactElement } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, ColorTemplateColors, ColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\nimport useCorner, { UseCornerTypes } from '../useCorner'\n\n\n\nexport type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, \"color\" | \"children\" | \"size\"> & {\n label: useBreakpointPropsType<string | ReactElement>;\n startIcon?: useBreakpointPropsType<ReactElement>;\n endIcon?: useBreakpointPropsType<ReactElement>;\n color?: useBreakpointPropsType<ColorTemplateColors>;\n variant?: useBreakpointPropsType<ColorTemplateType>;\n corner?: useBreakpointPropsType<UseCornerTypes>;\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\n}\n\n\nconst Chip = React.forwardRef(<T extends TagComponentType = 'div'>(props: ChipProps<T>, ref: React.Ref<any>) => {\n let [{ label, variant, startIcon, endIcon, color, corner, size, ...rest }] = useInterface<any>(\"Chip\", props, {})\n const _p: any = {}\n if (label) _p.label = label\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 const p: any = useBreakpointProps(_p)\n\n label = p.label\n startIcon = p.startIcon\n endIcon = p.endIcon\n color = p.color || \"brand\"\n variant = p.variant || \"fill\"\n corner = p.corner || \"circle\"\n size = p.size || \"medium\"\n rest.sx = (rest as any).sx || {};\n\n const cornerCss = useCorner(corner)\n const template = useColorTemplate(color, variant)\n delete template?.hover\n\n const sizes: any = {\n small: {\n height: 24,\n gap: .5,\n fontSize: 12\n },\n medium: {\n height: 34,\n gap: 1,\n fontSize: 14,\n },\n large: {\n height: 38,\n fontSize: 15,\n gap: 1,\n }\n }\n\n return (\n <Tag\n {...cornerCss}\n {...template}\n {...(sizes[size as any] || {})}\n {...rest}\n sxr={{\n display: \"inline-flex\",\n flexDirection: \"row\",\n alignItems: \"center\",\n transition: \"background .3s\",\n fontFamily: \"default\",\n overflow: \"hidden\",\n px: startIcon || endIcon ? 1 : 1.5,\n }}\n baseClass='chip'\n ref={ref}\n >\n {startIcon}\n <Tag\n sxr={{\n alignItems: \"center\",\n flexBox: true\n }}\n >{label}</Tag>\n {endIcon}\n </Tag>\n )\n})\n\nexport default Chip\n"],"names":["useInterface","__rest","useBreakpointProps","useCorner","useColorTemplate","_jsxs","Tag","_jsx"],"mappings":"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"}
package/Chip/index.mjs ADDED
@@ -0,0 +1,59 @@
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';const Chip = React.forwardRef((props, ref) => {
2
+ let [_a] = useInterface("Chip", props, {}), { label, variant, startIcon, endIcon, color, corner, size } = _a, rest = __rest(_a, ["label", "variant", "startIcon", "endIcon", "color", "corner", "size"]);
3
+ const _p = {};
4
+ if (label)
5
+ _p.label = label;
6
+ if (startIcon)
7
+ _p.startIcon = startIcon;
8
+ if (endIcon)
9
+ _p.endIcon = endIcon;
10
+ if (color)
11
+ _p.color = color;
12
+ if (variant)
13
+ _p.variant = variant;
14
+ if (corner)
15
+ _p.corner = corner;
16
+ if (size)
17
+ _p.size = size;
18
+ const p = useBreakpointProps(_p);
19
+ label = p.label;
20
+ startIcon = p.startIcon;
21
+ endIcon = p.endIcon;
22
+ color = p.color || "brand";
23
+ variant = p.variant || "fill";
24
+ corner = p.corner || "circle";
25
+ size = p.size || "medium";
26
+ rest.sx = rest.sx || {};
27
+ const cornerCss = useCorner(corner);
28
+ const template = useColorTemplate(color, variant);
29
+ template === null || template === void 0 ? true : delete template.hover;
30
+ const sizes = {
31
+ small: {
32
+ height: 24,
33
+ gap: .5,
34
+ fontSize: 12
35
+ },
36
+ medium: {
37
+ height: 34,
38
+ gap: 1,
39
+ fontSize: 14,
40
+ },
41
+ large: {
42
+ height: 38,
43
+ fontSize: 15,
44
+ gap: 1,
45
+ }
46
+ };
47
+ return (jsxs(Tag, Object.assign({}, cornerCss, template, (sizes[size] || {}), rest, { sxr: {
48
+ display: "inline-flex",
49
+ flexDirection: "row",
50
+ alignItems: "center",
51
+ transition: "background .3s",
52
+ fontFamily: "default",
53
+ overflow: "hidden",
54
+ px: startIcon || endIcon ? 1 : 1.5,
55
+ }, baseClass: 'chip', ref: ref }, { children: [startIcon, jsx(Tag, Object.assign({ sxr: {
56
+ alignItems: "center",
57
+ flexBox: true
58
+ } }, { children: label })), endIcon] })));
59
+ });export{Chip as default};//# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../src/Chip/index.tsx"],"sourcesContent":["\nimport React, { ReactElement } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, ColorTemplateColors, ColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\nimport useCorner, { UseCornerTypes } from '../useCorner'\n\n\n\nexport type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, \"color\" | \"children\" | \"size\"> & {\n label: useBreakpointPropsType<string | ReactElement>;\n startIcon?: useBreakpointPropsType<ReactElement>;\n endIcon?: useBreakpointPropsType<ReactElement>;\n color?: useBreakpointPropsType<ColorTemplateColors>;\n variant?: useBreakpointPropsType<ColorTemplateType>;\n corner?: useBreakpointPropsType<UseCornerTypes>;\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\n}\n\n\nconst Chip = React.forwardRef(<T extends TagComponentType = 'div'>(props: ChipProps<T>, ref: React.Ref<any>) => {\n let [{ label, variant, startIcon, endIcon, color, corner, size, ...rest }] = useInterface<any>(\"Chip\", props, {})\n const _p: any = {}\n if (label) _p.label = label\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 const p: any = useBreakpointProps(_p)\n\n label = p.label\n startIcon = p.startIcon\n endIcon = p.endIcon\n color = p.color || \"brand\"\n variant = p.variant || \"fill\"\n corner = p.corner || \"circle\"\n size = p.size || \"medium\"\n rest.sx = (rest as any).sx || {};\n\n const cornerCss = useCorner(corner)\n const template = useColorTemplate(color, variant)\n delete template?.hover\n\n const sizes: any = {\n small: {\n height: 24,\n gap: .5,\n fontSize: 12\n },\n medium: {\n height: 34,\n gap: 1,\n fontSize: 14,\n },\n large: {\n height: 38,\n fontSize: 15,\n gap: 1,\n }\n }\n\n return (\n <Tag\n {...cornerCss}\n {...template}\n {...(sizes[size as any] || {})}\n {...rest}\n sxr={{\n display: \"inline-flex\",\n flexDirection: \"row\",\n alignItems: \"center\",\n transition: \"background .3s\",\n fontFamily: \"default\",\n overflow: \"hidden\",\n px: startIcon || endIcon ? 1 : 1.5,\n }}\n baseClass='chip'\n ref={ref}\n >\n {startIcon}\n <Tag\n sxr={{\n alignItems: \"center\",\n flexBox: true\n }}\n >{label}</Tag>\n {endIcon}\n </Tag>\n )\n})\n\nexport default Chip\n"],"names":["_jsxs","_jsx"],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ import React, { ReactElement } from 'react';
2
+ import { useBreakpointPropsType, ColorTemplateColors } from '@xanui/core';
3
+
4
+ type CircleProgressProps = {
5
+ children?: ReactElement;
6
+ color?: useBreakpointPropsType<ColorTemplateColors>;
7
+ trackColor?: useBreakpointPropsType<ColorTemplateColors>;
8
+ thumbColor?: useBreakpointPropsType<ColorTemplateColors>;
9
+ size?: useBreakpointPropsType<number | "small" | "medium" | "large">;
10
+ thumbSize?: useBreakpointPropsType<number>;
11
+ trackSize?: useBreakpointPropsType<number>;
12
+ value?: useBreakpointPropsType<number>;
13
+ hideTrack?: useBreakpointPropsType<boolean>;
14
+ showPercentage?: useBreakpointPropsType<boolean>;
15
+ speed?: useBreakpointPropsType<number>;
16
+ };
17
+ declare const CircleProgress: React.ForwardRefExoticComponent<CircleProgressProps & React.RefAttributes<any>>;
18
+
19
+ export { CircleProgress as default };
20
+ export type { CircleProgressProps };
@@ -0,0 +1,118 @@
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 CircleProgress = React.forwardRef((_a, ref) => {
2
+ var _b, _c, _d, _e;
3
+ var { children } = _a, props = tslib.__rest(_a, ["children"]);
4
+ let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = core.useInterface("CircleProgress", props, {});
5
+ const _p = {};
6
+ if (color)
7
+ _p.color = color;
8
+ if (trackColor)
9
+ _p.trackColor = trackColor;
10
+ if (thumbColor)
11
+ _p.thumbColor = thumbColor;
12
+ if (size)
13
+ _p.size = size;
14
+ if (thumbSize)
15
+ _p.thumbSize = thumbSize;
16
+ if (trackSize)
17
+ _p.trackSize = trackSize;
18
+ if (value)
19
+ _p.value = value;
20
+ if (hideTrack)
21
+ _p.hideTrack = hideTrack;
22
+ if (showPercentage)
23
+ _p.showPercentage = showPercentage;
24
+ if (speed)
25
+ _p.speed = speed;
26
+ const p = core.useBreakpointProps(_p);
27
+ color = (_b = p.color) !== null && _b !== void 0 ? _b : "brand";
28
+ trackColor = p.trackColor;
29
+ thumbColor = p.thumbColor;
30
+ size = (_c = p.size) !== null && _c !== void 0 ? _c : "medium";
31
+ thumbSize = (_d = p.thumbSize) !== null && _d !== void 0 ? _d : 4;
32
+ trackSize = p.trackSize;
33
+ value = p.value;
34
+ hideTrack = p.hideTrack;
35
+ showPercentage = p.showPercentage;
36
+ speed = (_e = p.speed) !== null && _e !== void 0 ? _e : 1.3;
37
+ if (trackColor === 'default') {
38
+ trackColor = "divider";
39
+ }
40
+ if (thumbColor === 'default') {
41
+ thumbColor = "background.secondary";
42
+ }
43
+ let sizes = {
44
+ small: 24,
45
+ medium: 32,
46
+ large: 44
47
+ };
48
+ if (typeof size === 'string' && sizes[size]) {
49
+ size = sizes[size];
50
+ }
51
+ let isVal = typeof value === 'number';
52
+ const animrotate = "anim" + React.useId().replace(":", "");
53
+ const animdash = "anim" + React.useId().replace(":", "");
54
+ if (isVal && value > 100)
55
+ value = 100;
56
+ const circumference = 125.66370614359172; //radius * 2 * Math.PI
57
+ const percent = circumference - ((value || 0) / 100) * circumference;
58
+ if (showPercentage && !children) {
59
+ children = jsxRuntime.jsxs(core.Tag, Object.assign({ sxr: {
60
+ color: color === 'default' ? "text.primary" : `${color}.primary`,
61
+ fontSize: size / 4
62
+ } }, { children: [value, "%"] }));
63
+ }
64
+ return (jsxRuntime.jsxs(core.Tag, Object.assign({ baseClass: 'circle-progress', sxr: {
65
+ display: "inline-flex",
66
+ alignItems: "center",
67
+ justifyContent: "center",
68
+ "& svg[class='circle-progress-svg']": {
69
+ zIndex: 1,
70
+ position: "absolute",
71
+ top: 0,
72
+ left: 0,
73
+ width: "100%",
74
+ height: "100%",
75
+ transform: isVal ? "rotate(-90deg)" : "none",
76
+ transformOrigin: isVal ? "center" : "initial",
77
+ animation: isVal ? "none" : `${animrotate} ${speed}s linear infinite`,
78
+ [`@keyframes ${animrotate}`]: {
79
+ "100%": {
80
+ transform: "rotate(360deg)"
81
+ }
82
+ },
83
+ "& circle.circle-progress-thumb": {
84
+ strokeDasharray: circumference,
85
+ strokeDashoffset: percent,
86
+ stroke: thumbColor || (color === 'default' ? `background.secondary` : `${color}.primary`),
87
+ fill: "none",
88
+ strokeWidth: thumbSize,
89
+ strokeLinecap: "round",
90
+ animation: isVal ? "none" : `${animdash} ${speed}s ease-in-out infinite`,
91
+ [`@keyframes ${animdash}`]: {
92
+ "0%": { strokeDasharray: "1, 150", strokeDashoffset: 0 },
93
+ "50%": { strokeDasharray: "90, 150", strokeDashoffset: -35 },
94
+ "100%": { strokeDasharray: "90, 150", strokeDashoffset: -124 }
95
+ }
96
+ },
97
+ "& circle.circle-progress-track": {
98
+ fill: "none",
99
+ stroke: trackColor || (color === 'default' ? `divider` : `${color}.alpha`),
100
+ strokeWidth: trackSize !== null && trackSize !== void 0 ? trackSize : thumbSize,
101
+ }
102
+ },
103
+ width: size,
104
+ height: size,
105
+ position: "relative"
106
+ }, ref: ref }, { children: [jsxRuntime.jsxs("svg", Object.assign({ viewBox: "0 0 50 50", className: "circle-progress-svg" }, { children: [!hideTrack && jsxRuntime.jsx("circle", { className: "circle-progress-track", cx: "25", cy: "25", r: 20 }), jsxRuntime.jsx("circle", { className: "circle-progress-thumb", cx: "25", cy: "25", r: 20 })] })), !!children && jsxRuntime.jsx(core.Tag, Object.assign({ baseClass: "circle-progress-content", sxr: {
107
+ zIndex: 2,
108
+ width: size - thumbSize,
109
+ height: size - thumbSize,
110
+ display: "flex",
111
+ alignItems: "center",
112
+ justifyContent: "center",
113
+ '& *': {
114
+ maxWidth: size - (thumbSize + 8),
115
+ maxHeight: size - (thumbSize + 8),
116
+ }
117
+ } }, { children: children }))] })));
118
+ });exports.default=CircleProgress;//# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/CircleProgress/index.tsx"],"sourcesContent":["\nimport React, { ReactElement, useId } from \"react\"\nimport { Tag, ColorTemplateColors, useInterface, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\n\nexport type CircleProgressProps = {\n children?: ReactElement;\n color?: useBreakpointPropsType<ColorTemplateColors>;\n trackColor?: useBreakpointPropsType<ColorTemplateColors>;\n thumbColor?: useBreakpointPropsType<ColorTemplateColors>;\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\n thumbSize?: useBreakpointPropsType<number>;\n trackSize?: useBreakpointPropsType<number>;\n value?: useBreakpointPropsType<number>;\n hideTrack?: useBreakpointPropsType<boolean>;\n showPercentage?: useBreakpointPropsType<boolean>;\n speed?: useBreakpointPropsType<number>;\n}\n\nconst CircleProgress = React.forwardRef(({ children, ...props }: CircleProgressProps, ref: React.Ref<any>) => {\n let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface<any>(\"CircleProgress\", props, {})\n const _p: any = {}\n if (color) _p.color = color\n if (trackColor) _p.trackColor = trackColor\n if (thumbColor) _p.thumbColor = thumbColor\n if (size) _p.size = size\n if (thumbSize) _p.thumbSize = thumbSize\n if (trackSize) _p.trackSize = trackSize\n if (value) _p.value = value\n if (hideTrack) _p.hideTrack = hideTrack\n if (showPercentage) _p.showPercentage = showPercentage\n if (speed) _p.speed = speed\n const p: any = useBreakpointProps(_p)\n\n color = p.color ?? \"brand\"\n trackColor = p.trackColor\n thumbColor = p.thumbColor\n size = p.size ?? \"medium\"\n thumbSize = p.thumbSize ?? 4\n trackSize = p.trackSize\n value = p.value\n hideTrack = p.hideTrack\n showPercentage = p.showPercentage\n speed = p.speed ?? 1.3\n\n if (trackColor === 'default') {\n trackColor = \"divider\"\n }\n\n if (thumbColor === 'default') {\n thumbColor = \"background.secondary\"\n }\n\n let sizes: any = {\n small: 24,\n medium: 32,\n large: 44\n }\n if (typeof size === 'string' && sizes[size]) {\n size = sizes[size]\n }\n\n let isVal = typeof value === 'number'\n const animrotate = \"anim\" + useId().replace(\":\", \"\")\n const animdash = \"anim\" + useId().replace(\":\", \"\")\n if (isVal && (value as number) > 100) value = 100\n const circumference = 125.66370614359172 //radius * 2 * Math.PI\n const percent = circumference - ((value || 0) / 100) * circumference\n\n if (showPercentage && !children) {\n children = <Tag\n sxr={{\n color: color === 'default' ? \"text.primary\" : `${color}.primary`,\n fontSize: size / 4\n }}\n >{value}%</Tag>\n }\n\n return (\n <Tag\n baseClass='circle-progress'\n sxr={{\n display: \"inline-flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n \"& svg[class='circle-progress-svg']\": {\n zIndex: 1,\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: \"100%\",\n transform: isVal ? \"rotate(-90deg)\" : \"none\",\n transformOrigin: isVal ? \"center\" : \"initial\",\n animation: isVal ? \"none\" : `${animrotate} ${speed}s linear infinite`,\n [`@keyframes ${animrotate}`]: {\n \"100%\": {\n transform: \"rotate(360deg)\"\n }\n },\n \"& circle.circle-progress-thumb\": {\n strokeDasharray: circumference,\n strokeDashoffset: percent,\n stroke: thumbColor || (color === 'default' ? `background.secondary` : `${color}.primary`),\n fill: \"none\",\n strokeWidth: thumbSize,\n strokeLinecap: \"round\",\n animation: isVal ? \"none\" : `${animdash} ${speed}s ease-in-out infinite`,\n [`@keyframes ${animdash}`]: {\n \"0%\": { strokeDasharray: \"1, 150\", strokeDashoffset: 0 },\n \"50%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -35 },\n \"100%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -124 }\n }\n },\n \"& circle.circle-progress-track\": {\n fill: \"none\",\n stroke: trackColor || (color === 'default' ? `divider` : `${color}.alpha`),\n strokeWidth: trackSize ?? thumbSize,\n }\n },\n width: size,\n height: size,\n position: \"relative\"\n }}\n ref={ref}\n >\n <svg viewBox=\"0 0 50 50\" className=\"circle-progress-svg\">\n {!hideTrack && <circle className=\"circle-progress-track\" cx=\"25\" cy=\"25\" r={20} />}\n <circle className=\"circle-progress-thumb\" cx=\"25\" cy=\"25\" r={20} />\n </svg>\n {!!children && <Tag\n baseClass=\"circle-progress-content\"\n sxr={{\n zIndex: 2,\n width: size - thumbSize,\n height: size - thumbSize,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n '& *': {\n maxWidth: size - (thumbSize + 8),\n maxHeight: size - (thumbSize + 8),\n }\n }}\n >\n {children}\n </Tag>}\n </Tag >\n )\n})\n\nexport default CircleProgress\n\n"],"names":["__rest","useInterface","useBreakpointProps","useId","_jsxs","Tag","_jsx"],"mappings":"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"}
@@ -0,0 +1,118 @@
1
+ import {__rest}from'tslib';import {jsxs,jsx}from'react/jsx-runtime';import React,{useId}from'react';import {useInterface,useBreakpointProps,Tag}from'@xanui/core';const CircleProgress = React.forwardRef((_a, ref) => {
2
+ var _b, _c, _d, _e;
3
+ var { children } = _a, props = __rest(_a, ["children"]);
4
+ let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface("CircleProgress", props, {});
5
+ const _p = {};
6
+ if (color)
7
+ _p.color = color;
8
+ if (trackColor)
9
+ _p.trackColor = trackColor;
10
+ if (thumbColor)
11
+ _p.thumbColor = thumbColor;
12
+ if (size)
13
+ _p.size = size;
14
+ if (thumbSize)
15
+ _p.thumbSize = thumbSize;
16
+ if (trackSize)
17
+ _p.trackSize = trackSize;
18
+ if (value)
19
+ _p.value = value;
20
+ if (hideTrack)
21
+ _p.hideTrack = hideTrack;
22
+ if (showPercentage)
23
+ _p.showPercentage = showPercentage;
24
+ if (speed)
25
+ _p.speed = speed;
26
+ const p = useBreakpointProps(_p);
27
+ color = (_b = p.color) !== null && _b !== void 0 ? _b : "brand";
28
+ trackColor = p.trackColor;
29
+ thumbColor = p.thumbColor;
30
+ size = (_c = p.size) !== null && _c !== void 0 ? _c : "medium";
31
+ thumbSize = (_d = p.thumbSize) !== null && _d !== void 0 ? _d : 4;
32
+ trackSize = p.trackSize;
33
+ value = p.value;
34
+ hideTrack = p.hideTrack;
35
+ showPercentage = p.showPercentage;
36
+ speed = (_e = p.speed) !== null && _e !== void 0 ? _e : 1.3;
37
+ if (trackColor === 'default') {
38
+ trackColor = "divider";
39
+ }
40
+ if (thumbColor === 'default') {
41
+ thumbColor = "background.secondary";
42
+ }
43
+ let sizes = {
44
+ small: 24,
45
+ medium: 32,
46
+ large: 44
47
+ };
48
+ if (typeof size === 'string' && sizes[size]) {
49
+ size = sizes[size];
50
+ }
51
+ let isVal = typeof value === 'number';
52
+ const animrotate = "anim" + useId().replace(":", "");
53
+ const animdash = "anim" + useId().replace(":", "");
54
+ if (isVal && value > 100)
55
+ value = 100;
56
+ const circumference = 125.66370614359172; //radius * 2 * Math.PI
57
+ const percent = circumference - ((value || 0) / 100) * circumference;
58
+ if (showPercentage && !children) {
59
+ children = jsxs(Tag, Object.assign({ sxr: {
60
+ color: color === 'default' ? "text.primary" : `${color}.primary`,
61
+ fontSize: size / 4
62
+ } }, { children: [value, "%"] }));
63
+ }
64
+ return (jsxs(Tag, Object.assign({ baseClass: 'circle-progress', sxr: {
65
+ display: "inline-flex",
66
+ alignItems: "center",
67
+ justifyContent: "center",
68
+ "& svg[class='circle-progress-svg']": {
69
+ zIndex: 1,
70
+ position: "absolute",
71
+ top: 0,
72
+ left: 0,
73
+ width: "100%",
74
+ height: "100%",
75
+ transform: isVal ? "rotate(-90deg)" : "none",
76
+ transformOrigin: isVal ? "center" : "initial",
77
+ animation: isVal ? "none" : `${animrotate} ${speed}s linear infinite`,
78
+ [`@keyframes ${animrotate}`]: {
79
+ "100%": {
80
+ transform: "rotate(360deg)"
81
+ }
82
+ },
83
+ "& circle.circle-progress-thumb": {
84
+ strokeDasharray: circumference,
85
+ strokeDashoffset: percent,
86
+ stroke: thumbColor || (color === 'default' ? `background.secondary` : `${color}.primary`),
87
+ fill: "none",
88
+ strokeWidth: thumbSize,
89
+ strokeLinecap: "round",
90
+ animation: isVal ? "none" : `${animdash} ${speed}s ease-in-out infinite`,
91
+ [`@keyframes ${animdash}`]: {
92
+ "0%": { strokeDasharray: "1, 150", strokeDashoffset: 0 },
93
+ "50%": { strokeDasharray: "90, 150", strokeDashoffset: -35 },
94
+ "100%": { strokeDasharray: "90, 150", strokeDashoffset: -124 }
95
+ }
96
+ },
97
+ "& circle.circle-progress-track": {
98
+ fill: "none",
99
+ stroke: trackColor || (color === 'default' ? `divider` : `${color}.alpha`),
100
+ strokeWidth: trackSize !== null && trackSize !== void 0 ? trackSize : thumbSize,
101
+ }
102
+ },
103
+ width: size,
104
+ height: size,
105
+ position: "relative"
106
+ }, ref: ref }, { children: [jsxs("svg", Object.assign({ viewBox: "0 0 50 50", className: "circle-progress-svg" }, { children: [!hideTrack && jsx("circle", { className: "circle-progress-track", cx: "25", cy: "25", r: 20 }), jsx("circle", { className: "circle-progress-thumb", cx: "25", cy: "25", r: 20 })] })), !!children && jsx(Tag, Object.assign({ baseClass: "circle-progress-content", sxr: {
107
+ zIndex: 2,
108
+ width: size - thumbSize,
109
+ height: size - thumbSize,
110
+ display: "flex",
111
+ alignItems: "center",
112
+ justifyContent: "center",
113
+ '& *': {
114
+ maxWidth: size - (thumbSize + 8),
115
+ maxHeight: size - (thumbSize + 8),
116
+ }
117
+ } }, { children: children }))] })));
118
+ });export{CircleProgress as default};//# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../src/CircleProgress/index.tsx"],"sourcesContent":["\nimport React, { ReactElement, useId } from \"react\"\nimport { Tag, ColorTemplateColors, useInterface, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\n\nexport type CircleProgressProps = {\n children?: ReactElement;\n color?: useBreakpointPropsType<ColorTemplateColors>;\n trackColor?: useBreakpointPropsType<ColorTemplateColors>;\n thumbColor?: useBreakpointPropsType<ColorTemplateColors>;\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\n thumbSize?: useBreakpointPropsType<number>;\n trackSize?: useBreakpointPropsType<number>;\n value?: useBreakpointPropsType<number>;\n hideTrack?: useBreakpointPropsType<boolean>;\n showPercentage?: useBreakpointPropsType<boolean>;\n speed?: useBreakpointPropsType<number>;\n}\n\nconst CircleProgress = React.forwardRef(({ children, ...props }: CircleProgressProps, ref: React.Ref<any>) => {\n let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface<any>(\"CircleProgress\", props, {})\n const _p: any = {}\n if (color) _p.color = color\n if (trackColor) _p.trackColor = trackColor\n if (thumbColor) _p.thumbColor = thumbColor\n if (size) _p.size = size\n if (thumbSize) _p.thumbSize = thumbSize\n if (trackSize) _p.trackSize = trackSize\n if (value) _p.value = value\n if (hideTrack) _p.hideTrack = hideTrack\n if (showPercentage) _p.showPercentage = showPercentage\n if (speed) _p.speed = speed\n const p: any = useBreakpointProps(_p)\n\n color = p.color ?? \"brand\"\n trackColor = p.trackColor\n thumbColor = p.thumbColor\n size = p.size ?? \"medium\"\n thumbSize = p.thumbSize ?? 4\n trackSize = p.trackSize\n value = p.value\n hideTrack = p.hideTrack\n showPercentage = p.showPercentage\n speed = p.speed ?? 1.3\n\n if (trackColor === 'default') {\n trackColor = \"divider\"\n }\n\n if (thumbColor === 'default') {\n thumbColor = \"background.secondary\"\n }\n\n let sizes: any = {\n small: 24,\n medium: 32,\n large: 44\n }\n if (typeof size === 'string' && sizes[size]) {\n size = sizes[size]\n }\n\n let isVal = typeof value === 'number'\n const animrotate = \"anim\" + useId().replace(\":\", \"\")\n const animdash = \"anim\" + useId().replace(\":\", \"\")\n if (isVal && (value as number) > 100) value = 100\n const circumference = 125.66370614359172 //radius * 2 * Math.PI\n const percent = circumference - ((value || 0) / 100) * circumference\n\n if (showPercentage && !children) {\n children = <Tag\n sxr={{\n color: color === 'default' ? \"text.primary\" : `${color}.primary`,\n fontSize: size / 4\n }}\n >{value}%</Tag>\n }\n\n return (\n <Tag\n baseClass='circle-progress'\n sxr={{\n display: \"inline-flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n \"& svg[class='circle-progress-svg']\": {\n zIndex: 1,\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: \"100%\",\n transform: isVal ? \"rotate(-90deg)\" : \"none\",\n transformOrigin: isVal ? \"center\" : \"initial\",\n animation: isVal ? \"none\" : `${animrotate} ${speed}s linear infinite`,\n [`@keyframes ${animrotate}`]: {\n \"100%\": {\n transform: \"rotate(360deg)\"\n }\n },\n \"& circle.circle-progress-thumb\": {\n strokeDasharray: circumference,\n strokeDashoffset: percent,\n stroke: thumbColor || (color === 'default' ? `background.secondary` : `${color}.primary`),\n fill: \"none\",\n strokeWidth: thumbSize,\n strokeLinecap: \"round\",\n animation: isVal ? \"none\" : `${animdash} ${speed}s ease-in-out infinite`,\n [`@keyframes ${animdash}`]: {\n \"0%\": { strokeDasharray: \"1, 150\", strokeDashoffset: 0 },\n \"50%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -35 },\n \"100%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -124 }\n }\n },\n \"& circle.circle-progress-track\": {\n fill: \"none\",\n stroke: trackColor || (color === 'default' ? `divider` : `${color}.alpha`),\n strokeWidth: trackSize ?? thumbSize,\n }\n },\n width: size,\n height: size,\n position: \"relative\"\n }}\n ref={ref}\n >\n <svg viewBox=\"0 0 50 50\" className=\"circle-progress-svg\">\n {!hideTrack && <circle className=\"circle-progress-track\" cx=\"25\" cy=\"25\" r={20} />}\n <circle className=\"circle-progress-thumb\" cx=\"25\" cy=\"25\" r={20} />\n </svg>\n {!!children && <Tag\n baseClass=\"circle-progress-content\"\n sxr={{\n zIndex: 2,\n width: size - thumbSize,\n height: size - thumbSize,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n '& *': {\n maxWidth: size - (thumbSize + 8),\n maxHeight: size - (thumbSize + 8),\n }\n }}\n >\n {children}\n </Tag>}\n </Tag >\n )\n})\n\nexport default CircleProgress\n\n"],"names":["_jsxs","_jsx"],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import { TagComponentType, TagProps } from '@xanui/core';
2
+ import React from 'react';
3
+
4
+ type ClickOutsideProps<T extends TagComponentType = "div"> = TagProps<T> & {
5
+ onClickOutside: () => void;
6
+ };
7
+ declare const ClickOutside: React.ForwardRefExoticComponent<Omit<ClickOutsideProps<"div">, "ref"> & React.RefAttributes<any>>;
8
+
9
+ export { ClickOutside as default };
10
+ export type { ClickOutsideProps };