@xanui/ui 1.2.6 → 1.2.7

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 (327) hide show
  1. package/Accordion/index.cjs +5 -5
  2. package/Accordion/index.cjs.map +1 -1
  3. package/Accordion/index.d.ts +3 -3
  4. package/Accordion/index.js +5 -5
  5. package/Accordion/index.js.map +1 -1
  6. package/Alert/index.cjs +19 -17
  7. package/Alert/index.cjs.map +1 -1
  8. package/Alert/index.d.ts +2 -2
  9. package/Alert/index.js +19 -17
  10. package/Alert/index.js.map +1 -1
  11. package/Autocomplete/index.cjs +2 -2
  12. package/Autocomplete/index.cjs.map +1 -1
  13. package/Autocomplete/index.d.ts +7 -7
  14. package/Autocomplete/index.js +2 -2
  15. package/Autocomplete/index.js.map +1 -1
  16. package/Avatar/index.cjs +2 -2
  17. package/Avatar/index.cjs.map +1 -1
  18. package/Avatar/index.d.ts +2 -2
  19. package/Avatar/index.js +2 -2
  20. package/Avatar/index.js.map +1 -1
  21. package/AvatarBox/index.cjs +19 -0
  22. package/AvatarBox/index.cjs.map +1 -0
  23. package/AvatarBox/index.d.ts +19 -0
  24. package/AvatarBox/index.js +17 -0
  25. package/AvatarBox/index.js.map +1 -0
  26. package/AvatarPicker/index.cjs +80 -0
  27. package/AvatarPicker/index.cjs.map +1 -0
  28. package/AvatarPicker/index.d.ts +27 -0
  29. package/AvatarPicker/index.js +78 -0
  30. package/AvatarPicker/index.js.map +1 -0
  31. package/Badge/index.cjs +1 -1
  32. package/Badge/index.cjs.map +1 -1
  33. package/Badge/index.d.ts +4 -4
  34. package/Badge/index.js +1 -1
  35. package/Badge/index.js.map +1 -1
  36. package/Box/index.d.ts +2 -2
  37. package/Button/index.cjs +5 -3
  38. package/Button/index.cjs.map +1 -1
  39. package/Button/index.d.ts +2 -2
  40. package/Button/index.js +5 -3
  41. package/Button/index.js.map +1 -1
  42. package/ButtonGroup/index.cjs +3 -2
  43. package/ButtonGroup/index.cjs.map +1 -1
  44. package/ButtonGroup/index.d.ts +2 -2
  45. package/ButtonGroup/index.js +3 -2
  46. package/ButtonGroup/index.js.map +1 -1
  47. package/Calendar/index.cjs +10 -10
  48. package/Calendar/index.cjs.map +1 -1
  49. package/Calendar/index.js +10 -10
  50. package/Calendar/index.js.map +1 -1
  51. package/CalendarInput/index.cjs +1 -1
  52. package/CalendarInput/index.cjs.map +1 -1
  53. package/CalendarInput/index.js +1 -1
  54. package/CalendarInput/index.js.map +1 -1
  55. package/Carousel/index.cjs +231 -0
  56. package/Carousel/index.cjs.map +1 -0
  57. package/Carousel/index.d.ts +28 -0
  58. package/Carousel/index.js +229 -0
  59. package/Carousel/index.js.map +1 -0
  60. package/Checkbox/index.cjs +2 -2
  61. package/Checkbox/index.cjs.map +1 -1
  62. package/Checkbox/index.d.ts +2 -2
  63. package/Checkbox/index.js +2 -2
  64. package/Checkbox/index.js.map +1 -1
  65. package/Chip/index.cjs +3 -3
  66. package/Chip/index.cjs.map +1 -1
  67. package/Chip/index.d.ts +2 -2
  68. package/Chip/index.js +3 -3
  69. package/Chip/index.js.map +1 -1
  70. package/CircleProgress/index.cjs +10 -10
  71. package/CircleProgress/index.cjs.map +1 -1
  72. package/CircleProgress/index.d.ts +2 -2
  73. package/CircleProgress/index.js +10 -10
  74. package/CircleProgress/index.js.map +1 -1
  75. package/ClickOutside/index.cjs +3 -12
  76. package/ClickOutside/index.cjs.map +1 -1
  77. package/ClickOutside/index.d.ts +3 -3
  78. package/ClickOutside/index.js +4 -13
  79. package/ClickOutside/index.js.map +1 -1
  80. package/Collaps/index.cjs +5 -5
  81. package/Collaps/index.cjs.map +1 -1
  82. package/Collaps/index.d.ts +2 -2
  83. package/Collaps/index.js +5 -5
  84. package/Collaps/index.js.map +1 -1
  85. package/Container/index.d.ts +2 -2
  86. package/DataFilter/index.d.ts +2 -2
  87. package/DataFilter/options/DateFilter.cjs +3 -3
  88. package/DataFilter/options/DateFilter.cjs.map +1 -1
  89. package/DataFilter/options/DateFilter.js +3 -3
  90. package/DataFilter/options/DateFilter.js.map +1 -1
  91. package/DataFilter/options/DateRangeFilter.cjs +2 -2
  92. package/DataFilter/options/DateRangeFilter.cjs.map +1 -1
  93. package/DataFilter/options/DateRangeFilter.js +2 -2
  94. package/DataFilter/options/DateRangeFilter.js.map +1 -1
  95. package/DataFilter/options/MultiSelectFilter.cjs +3 -3
  96. package/DataFilter/options/MultiSelectFilter.cjs.map +1 -1
  97. package/DataFilter/options/MultiSelectFilter.js +3 -3
  98. package/DataFilter/options/MultiSelectFilter.js.map +1 -1
  99. package/DataFilter/options/NumberFilter.cjs +2 -2
  100. package/DataFilter/options/NumberFilter.cjs.map +1 -1
  101. package/DataFilter/options/NumberFilter.js +2 -2
  102. package/DataFilter/options/NumberFilter.js.map +1 -1
  103. package/DataFilter/options/NumberRangeFilter.cjs +2 -2
  104. package/DataFilter/options/NumberRangeFilter.cjs.map +1 -1
  105. package/DataFilter/options/NumberRangeFilter.js +2 -2
  106. package/DataFilter/options/NumberRangeFilter.js.map +1 -1
  107. package/DataFilter/options/SelectFilter.cjs +3 -3
  108. package/DataFilter/options/SelectFilter.cjs.map +1 -1
  109. package/DataFilter/options/SelectFilter.js +3 -3
  110. package/DataFilter/options/SelectFilter.js.map +1 -1
  111. package/DataFilter/options/TextFilter.cjs +2 -2
  112. package/DataFilter/options/TextFilter.cjs.map +1 -1
  113. package/DataFilter/options/TextFilter.js +2 -2
  114. package/DataFilter/options/TextFilter.js.map +1 -1
  115. package/Datatable/FilterBox.cjs +2 -2
  116. package/Datatable/FilterBox.cjs.map +1 -1
  117. package/Datatable/FilterBox.js +2 -2
  118. package/Datatable/FilterBox.js.map +1 -1
  119. package/Datatable/Row.cjs +2 -2
  120. package/Datatable/Row.cjs.map +1 -1
  121. package/Datatable/Row.js +2 -2
  122. package/Datatable/Row.js.map +1 -1
  123. package/Datatable/SelectedBox.cjs +2 -2
  124. package/Datatable/SelectedBox.cjs.map +1 -1
  125. package/Datatable/SelectedBox.js +2 -2
  126. package/Datatable/SelectedBox.js.map +1 -1
  127. package/Datatable/Table.cjs +1 -1
  128. package/Datatable/Table.cjs.map +1 -1
  129. package/Datatable/Table.js +1 -1
  130. package/Datatable/Table.js.map +1 -1
  131. package/Datatable/TableHead.cjs +3 -3
  132. package/Datatable/TableHead.cjs.map +1 -1
  133. package/Datatable/TableHead.js +3 -3
  134. package/Datatable/TableHead.js.map +1 -1
  135. package/Datatable/index.cjs +1 -1
  136. package/Datatable/index.cjs.map +1 -1
  137. package/Datatable/index.d.ts +2 -2
  138. package/Datatable/index.js +1 -1
  139. package/Datatable/index.js.map +1 -1
  140. package/Divider/index.cjs +3 -3
  141. package/Divider/index.cjs.map +1 -1
  142. package/Divider/index.d.ts +2 -2
  143. package/Divider/index.js +3 -3
  144. package/Divider/index.js.map +1 -1
  145. package/Drawer/index.cjs +2 -2
  146. package/Drawer/index.cjs.map +1 -1
  147. package/Drawer/index.js +2 -2
  148. package/Drawer/index.js.map +1 -1
  149. package/FilePicker/index.cjs +115 -0
  150. package/FilePicker/index.cjs.map +1 -0
  151. package/FilePicker/index.d.ts +23 -0
  152. package/FilePicker/index.js +113 -0
  153. package/FilePicker/index.js.map +1 -0
  154. package/Form/index.cjs +1 -1
  155. package/Form/index.cjs.map +1 -1
  156. package/Form/index.d.ts +2 -2
  157. package/Form/index.js +1 -1
  158. package/Form/index.js.map +1 -1
  159. package/GalleryPicker/index.cjs +88 -0
  160. package/GalleryPicker/index.cjs.map +1 -0
  161. package/GalleryPicker/index.d.ts +26 -0
  162. package/GalleryPicker/index.js +86 -0
  163. package/GalleryPicker/index.js.map +1 -0
  164. package/GridContainer/index.d.ts +2 -2
  165. package/GridItem/index.d.ts +2 -2
  166. package/IconButton/index.cjs +6 -3
  167. package/IconButton/index.cjs.map +1 -1
  168. package/IconButton/index.d.ts +2 -2
  169. package/IconButton/index.js +6 -3
  170. package/IconButton/index.js.map +1 -1
  171. package/Image/index.cjs +2 -14
  172. package/Image/index.cjs.map +1 -1
  173. package/Image/index.d.ts +3 -5
  174. package/Image/index.js +3 -15
  175. package/Image/index.js.map +1 -1
  176. package/Input/index.cjs +10 -10
  177. package/Input/index.cjs.map +1 -1
  178. package/Input/index.d.ts +14 -14
  179. package/Input/index.js +10 -10
  180. package/Input/index.js.map +1 -1
  181. package/InputNumber/index.d.ts +2 -2
  182. package/Label/index.cjs +1 -1
  183. package/Label/index.cjs.map +1 -1
  184. package/Label/index.d.ts +2 -2
  185. package/Label/index.js +1 -1
  186. package/Label/index.js.map +1 -1
  187. package/Layer/index.cjs +12 -13
  188. package/Layer/index.cjs.map +1 -1
  189. package/Layer/index.d.ts +5 -5
  190. package/Layer/index.js +13 -14
  191. package/Layer/index.js.map +1 -1
  192. package/LineProgress/index.cjs +6 -6
  193. package/LineProgress/index.cjs.map +1 -1
  194. package/LineProgress/index.d.ts +2 -2
  195. package/LineProgress/index.js +6 -6
  196. package/LineProgress/index.js.map +1 -1
  197. package/Link/index.cjs +41 -0
  198. package/Link/index.cjs.map +1 -0
  199. package/Link/index.d.ts +17 -0
  200. package/Link/index.js +39 -0
  201. package/Link/index.js.map +1 -0
  202. package/List/index.cjs +1 -1
  203. package/List/index.cjs.map +1 -1
  204. package/List/index.d.ts +2 -2
  205. package/List/index.js +1 -1
  206. package/List/index.js.map +1 -1
  207. package/ListItem/index.cjs +8 -8
  208. package/ListItem/index.cjs.map +1 -1
  209. package/ListItem/index.d.ts +2 -2
  210. package/ListItem/index.js +8 -8
  211. package/ListItem/index.js.map +1 -1
  212. package/LoadingBox/index.cjs +2 -2
  213. package/LoadingBox/index.cjs.map +1 -1
  214. package/LoadingBox/index.d.ts +2 -2
  215. package/LoadingBox/index.js +2 -2
  216. package/LoadingBox/index.js.map +1 -1
  217. package/Menu/index.cjs +6 -21
  218. package/Menu/index.cjs.map +1 -1
  219. package/Menu/index.d.ts +6 -4
  220. package/Menu/index.js +6 -21
  221. package/Menu/index.js.map +1 -1
  222. package/Modal/index.cjs +5 -5
  223. package/Modal/index.cjs.map +1 -1
  224. package/Modal/index.js +5 -5
  225. package/Modal/index.js.map +1 -1
  226. package/Option/index.d.ts +2 -2
  227. package/PasswordInput/index.cjs +21 -0
  228. package/PasswordInput/index.cjs.map +1 -0
  229. package/PasswordInput/index.d.ts +11 -0
  230. package/PasswordInput/index.js +19 -0
  231. package/PasswordInput/index.js.map +1 -0
  232. package/Portal/index.d.ts +3 -3
  233. package/Radio/index.d.ts +2 -2
  234. package/RangeSlider/index.cjs +158 -0
  235. package/RangeSlider/index.cjs.map +1 -0
  236. package/RangeSlider/index.d.ts +24 -0
  237. package/RangeSlider/index.js +156 -0
  238. package/RangeSlider/index.js.map +1 -0
  239. package/Scrollbar/index.cjs +6 -6
  240. package/Scrollbar/index.cjs.map +1 -1
  241. package/Scrollbar/index.d.ts +3 -3
  242. package/Scrollbar/index.js +6 -6
  243. package/Scrollbar/index.js.map +1 -1
  244. package/Select/index.cjs +2 -2
  245. package/Select/index.cjs.map +1 -1
  246. package/Select/index.d.ts +5 -5
  247. package/Select/index.js +2 -2
  248. package/Select/index.js.map +1 -1
  249. package/Skeleton/index.cjs +7 -5
  250. package/Skeleton/index.cjs.map +1 -1
  251. package/Skeleton/index.js +7 -5
  252. package/Skeleton/index.js.map +1 -1
  253. package/Stack/index.d.ts +2 -2
  254. package/Switch/index.cjs +2 -2
  255. package/Switch/index.cjs.map +1 -1
  256. package/Switch/index.d.ts +3 -3
  257. package/Switch/index.js +2 -2
  258. package/Switch/index.js.map +1 -1
  259. package/Tab/index.cjs +23 -2
  260. package/Tab/index.cjs.map +1 -1
  261. package/Tab/index.d.ts +2 -2
  262. package/Tab/index.js +25 -4
  263. package/Tab/index.js.map +1 -1
  264. package/Table/index.cjs +9 -9
  265. package/Table/index.cjs.map +1 -1
  266. package/Table/index.d.ts +2 -2
  267. package/Table/index.js +9 -9
  268. package/Table/index.js.map +1 -1
  269. package/TableBody/index.d.ts +2 -2
  270. package/TableCell/index.cjs +1 -1
  271. package/TableCell/index.cjs.map +1 -1
  272. package/TableCell/index.d.ts +2 -2
  273. package/TableCell/index.js +1 -1
  274. package/TableCell/index.js.map +1 -1
  275. package/TableFooter/index.d.ts +2 -2
  276. package/TableHead/index.d.ts +2 -2
  277. package/TablePagination/index.cjs +2 -2
  278. package/TablePagination/index.cjs.map +1 -1
  279. package/TablePagination/index.d.ts +2 -2
  280. package/TablePagination/index.js +2 -2
  281. package/TablePagination/index.js.map +1 -1
  282. package/TableRow/index.d.ts +2 -2
  283. package/Tabs/context.cjs +11 -0
  284. package/Tabs/context.cjs.map +1 -0
  285. package/Tabs/context.js +8 -0
  286. package/Tabs/context.js.map +1 -0
  287. package/Tabs/index.cjs +83 -168
  288. package/Tabs/index.cjs.map +1 -1
  289. package/Tabs/index.d.ts +4 -22
  290. package/Tabs/index.js +86 -171
  291. package/Tabs/index.js.map +1 -1
  292. package/Tabs/types.d.ts +16 -0
  293. package/Text/index.cjs +1 -1
  294. package/Text/index.cjs.map +1 -1
  295. package/Text/index.d.ts +2 -2
  296. package/Text/index.js +1 -1
  297. package/Text/index.js.map +1 -1
  298. package/Toast/index.cjs +15 -16
  299. package/Toast/index.cjs.map +1 -1
  300. package/Toast/index.js +16 -17
  301. package/Toast/index.js.map +1 -1
  302. package/Tooltip/index.cjs +2 -2
  303. package/Tooltip/index.cjs.map +1 -1
  304. package/Tooltip/index.js +2 -2
  305. package/Tooltip/index.js.map +1 -1
  306. package/ViewBox/index.d.ts +2 -2
  307. package/index.cjs +124 -110
  308. package/index.cjs.map +1 -1
  309. package/index.d.ts +8 -1
  310. package/index.js +8 -1
  311. package/index.js.map +1 -1
  312. package/package.json +2 -2
  313. package/readme.md +1 -1
  314. package/useBlurCss/index.cjs +1 -2
  315. package/useBlurCss/index.cjs.map +1 -1
  316. package/useBlurCss/index.js +1 -2
  317. package/useBlurCss/index.js.map +1 -1
  318. package/useContextMenu/index.cjs +2 -2
  319. package/useContextMenu/index.cjs.map +1 -1
  320. package/useContextMenu/index.d.ts +1 -1
  321. package/useContextMenu/index.js +2 -2
  322. package/useContextMenu/index.js.map +1 -1
  323. package/Paper/index.cjs +0 -16
  324. package/Paper/index.cjs.map +0 -1
  325. package/Paper/index.d.ts +0 -8
  326. package/Paper/index.js +0 -14
  327. package/Paper/index.js.map +0 -1
@@ -1,5 +1,5 @@
1
1
  import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import React, { ReactElement } from 'react';
2
+ import React__default, { ReactElement } from 'react';
3
3
  import { ListItemProps } from '../ListItem/index.js';
4
4
  import { useBreakpointPropsType, UseColorTemplateColor } from '@xanui/core';
5
5
 
@@ -17,11 +17,11 @@ type AutocompleteProps = {
17
17
  autoFocus?: boolean;
18
18
  autoComplete?: string;
19
19
  label?: useBreakpointPropsType<string>;
20
- onFocus?: (e: React.FocusEvent<any>) => void;
21
- onBlur?: (e: React.FocusEvent<any>) => void;
22
- onInput?: (e: React.FormEvent<any>) => void;
23
- onKeyDown?: (e: React.KeyboardEvent<any>) => void;
24
- onKeyUp?: (e: React.KeyboardEvent<any>) => void;
20
+ onFocus?: (e: React__default.FocusEvent<any>) => void;
21
+ onBlur?: (e: React__default.FocusEvent<any>) => void;
22
+ onInput?: (e: React__default.FormEvent<any>) => void;
23
+ onKeyDown?: (e: React__default.KeyboardEvent<any>) => void;
24
+ onKeyUp?: (e: React__default.KeyboardEvent<any>) => void;
25
25
  rows?: useBreakpointPropsType<number>;
26
26
  minRows?: useBreakpointPropsType<number>;
27
27
  maxRows?: useBreakpointPropsType<number>;
@@ -30,7 +30,7 @@ type AutocompleteProps = {
30
30
  endIcon?: useBreakpointPropsType<ReactElement>;
31
31
  iconPlacement?: useBreakpointPropsType<"start" | "center" | "end">;
32
32
  focused?: boolean;
33
- color?: useBreakpointPropsType<Omit<UseColorTemplateColor, "default">>;
33
+ color?: useBreakpointPropsType<Omit<UseColorTemplateColor, 'surface'>>;
34
34
  variant?: useBreakpointPropsType<"fill" | "outline" | "text">;
35
35
  error?: boolean;
36
36
  helperText?: useBreakpointPropsType<string>;
@@ -33,7 +33,7 @@ const Autocomplete = (_a) => {
33
33
  }
34
34
  if (!!value && multiple && Array.isArray(value)) {
35
35
  value.map((v, index) => {
36
- startIcons.push(jsx(Chip, { size: "small", label: getLabel(v), variant: "fill", color: "default", endIcon: jsx(IconButton, { size: 20, variant: "text", color: "default", onClick: (e) => {
36
+ startIcons.push(jsx(Chip, { size: "small", label: getLabel(v), variant: "fill", color: "surface", endIcon: jsx(IconButton, { size: 20, variant: "text", color: "surface", onClick: (e) => {
37
37
  e.stopPropagation();
38
38
  let newValue = Array.isArray(value) ? [...value] : [];
39
39
  newValue = newValue.filter((val) => getLabel(val) !== getLabel(v));
@@ -49,7 +49,7 @@ const Autocomplete = (_a) => {
49
49
  endIcons.push(jsx(CircleProgress, { size: "small" }, "auto-complete-loading-icon"));
50
50
  }
51
51
  else if (!!value && !multiple) {
52
- endIcons.unshift(jsx(IconButton, { variant: "text", color: "default", onClick: (e) => {
52
+ endIcons.unshift(jsx(IconButton, { variant: "text", color: "surface", onClick: (e) => {
53
53
  e.stopPropagation();
54
54
  onChange && onChange(null);
55
55
  setInputValue("");
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/Autocomplete/index.tsx"],"sourcesContent":["\"use client\"\nimport React, { ReactElement, useEffect } from 'react'\nimport Input from '../Input'\nimport Menu from '../Menu'\nimport List from '../List';\nimport ListItem, { ListItemProps } from '../ListItem';\nimport Chip from '../Chip';\nimport IconButton from '../IconButton';\nimport Close from '@xanui/icons/Close';\nimport CircleProgress from '../CircleProgress';\nimport { useBreakpointPropsType, UseColorTemplateColor } from '@xanui/core';\n\nexport type AutocompleteProps = {\n\n options: any[] | ((text: string) => Promise<any[]>)\n getLabel: (option: any) => string;\n onChange?: (value: any) => void;\n value?: any;\n multiple?: boolean;\n renderOption?: (option: any, props: any) => ReactElement<ListItemProps>\n\n // input props customization\n disabled?: boolean;\n name?: string;\n placeholder?: string;\n readOnly?: boolean;\n autoFocus?: boolean;\n autoComplete?: string;\n label?: useBreakpointPropsType<string>;\n\n onFocus?: (e: React.FocusEvent<any>) => void;\n onBlur?: (e: React.FocusEvent<any>) => void;\n onInput?: (e: React.FormEvent<any>) => void;\n onKeyDown?: (e: React.KeyboardEvent<any>) => void;\n onKeyUp?: (e: React.KeyboardEvent<any>) => void;\n\n rows?: useBreakpointPropsType<number>;\n minRows?: useBreakpointPropsType<number>;\n maxRows?: useBreakpointPropsType<number>;\n fullWidth?: boolean;\n\n startIcon?: useBreakpointPropsType<ReactElement>;\n endIcon?: useBreakpointPropsType<ReactElement>;\n iconPlacement?: useBreakpointPropsType<\"start\" | \"center\" | \"end\">;\n focused?: boolean;\n color?: useBreakpointPropsType<Omit<UseColorTemplateColor, \"default\">>;\n variant?: useBreakpointPropsType<\"fill\" | \"outline\" | \"text\">;\n error?: boolean;\n helperText?: useBreakpointPropsType<string>;\n\n}\n\nconst Autocomplete = ({ value, onChange, renderOption, options, getLabel, multiple, ...inputProps }: AutocompleteProps) => {\n const [_options, setOptions] = React.useState<any[]>()\n const [inputValue, setInputValue] = React.useState(value ? getLabel(value) : \"\")\n const [timer, setTimer] = React.useState<any>(null)\n const [loading, setLoading] = React.useState(false)\n const [focused, setFocused] = React.useState(false)\n const [open, setOpen] = React.useState(false)\n const menuRef = React.useRef<any>(null)\n\n useEffect(() => {\n if (!inputValue) {\n setInputValue(value ? getLabel(value) : \"\")\n }\n }, [value])\n\n getLabel ??= (option: any) => option.toString();\n multiple ??= false;\n\n let startIcons = []\n if (inputProps.startIcon) {\n startIcons.push(inputProps.startIcon)\n }\n\n if (!!value && multiple && Array.isArray(value)) {\n value.map((v: any, index: number) => {\n startIcons.push(<Chip\n key={index}\n size=\"small\"\n label={getLabel!(v)}\n variant={\"fill\"}\n color=\"default\"\n endIcon={<IconButton\n size={20}\n variant={\"text\"}\n color=\"default\"\n onClick={(e) => {\n e.stopPropagation();\n let newValue = Array.isArray(value) ? [...value] : []\n newValue = newValue.filter((val: any) => getLabel!(val) !== getLabel!(v))\n onChange && onChange(newValue)\n }}\n >\n <Close />\n </IconButton>}\n />)\n })\n }\n\n let endIcons = []\n if (inputProps.endIcon) {\n endIcons.push(inputProps.endIcon)\n }\n if (loading) {\n endIcons.push(<CircleProgress\n key=\"auto-complete-loading-icon\"\n size=\"small\"\n />)\n } else if (!!value && !multiple) {\n endIcons.unshift(<IconButton\n key=\"auto-complete-clear-button\"\n variant={\"text\"}\n color=\"default\"\n onClick={(e) => {\n e.stopPropagation();\n onChange && onChange(null)\n setInputValue(\"\")\n }}\n >\n <Close />\n </IconButton>)\n }\n\n const loadOptions = async () => {\n setLoading(true)\n setOpen(false)\n let results = []\n if (typeof options === 'function') {\n results = await options(inputValue)\n } else {\n results = options.filter(option => getLabel!(option).toString().toLowerCase().includes(inputValue.toLowerCase()))\n }\n if (!multiple && inputValue) {\n const find = results.find(option => getLabel!(option).toString().toLowerCase() === inputValue.toLowerCase())\n onChange && onChange(find || null)\n }\n setOptions(results)\n setOpen(true)\n setLoading(false)\n }\n\n useEffect(() => {\n if (focused) {\n clearTimeout(timer)\n setTimer(setTimeout(() => {\n loadOptions()\n }, 300))\n } else {\n setOpen(false)\n }\n }, [focused, inputValue])\n\n\n return (\n <>\n <Input\n {...inputProps as any}\n ref={menuRef}\n slotProps={{\n rootContainer: {\n flexWrap: 'wrap',\n ...(multiple ? { height: \"auto\", gap: .5 } : {})\n },\n input: {\n width: multiple ? 'initial' : '100%',\n flex: 1,\n minWidth: 20,\n }\n }}\n startIcon={startIcons.length ? startIcons : undefined}\n endIcon={endIcons}\n value={inputValue}\n onFocus={() => setFocused(true)}\n onKeyDown={(e) => {\n if (inputProps?.onKeyDown) {\n inputProps.onKeyDown(e)\n }\n if (multiple && e.key === 'Backspace' && inputValue === \"\" && Array.isArray(value) && value.length > 0) {\n let newValue = [...value]\n newValue.pop()\n onChange && onChange(newValue)\n }\n }}\n onChange={(e) => {\n const value = e.target.value;\n setInputValue(value)\n }}\n />\n <Menu\n target={open ? menuRef.current : null}\n onClickOutside={() => {\n setFocused(false)\n }}\n slotProps={{\n content: { minWidth: menuRef.current ? menuRef.current.offsetWidth : 'auto' }\n }}\n >\n <List\n maxHeight={400}\n overflow={\"auto\"}\n >\n {_options?.map((option, index) => (\n renderOption ? <div key={\"auto-complete\" + index + getLabel!(option)}>{renderOption(option, {\n onClick: () => {\n if (multiple) {\n let newValue = Array.isArray(value) ? [...value] : []\n const has = newValue.find((v: any) => getLabel!(v) === getLabel!(option))\n if (!has) {\n newValue.push(option)\n } else {\n newValue = newValue.filter((v: any) => getLabel!(v) !== getLabel!(option))\n }\n onChange && onChange(newValue)\n } else {\n setFocused(false)\n onChange && onChange(option)\n setOpen(false)\n setInputValue(getLabel!(option))\n setOptions([])\n }\n }\n })}</div> : <ListItem\n key={index}\n onClick={() => {\n\n if (multiple) {\n let newValue = Array.isArray(value) ? [...value] : []\n const has = newValue.find((v: any) => getLabel!(v) === getLabel!(option))\n if (!has) {\n newValue.push(option)\n } else {\n newValue = newValue.filter((v: any) => getLabel!(v) !== getLabel!(option))\n }\n onChange && onChange(newValue)\n } else {\n setFocused(false)\n onChange && onChange(option)\n setOpen(false)\n setInputValue(getLabel!(option))\n setOptions([])\n }\n }}\n >\n {getLabel!(option)}\n </ListItem>\n ))}\n </List>\n </Menu>\n </>\n )\n}\n\nexport default Autocomplete\n"],"names":[],"mappings":";;;;;;;;;;;;;AAoDA;AAAsB;;;AAGnB;AACA;AACA;AACA;;;;AAKM;;AAEN;AAEA;;;AAIA;AACG;;AAGH;;;;AAce;;AAEA;;AAMZ;;;AAIH;AACG;;;AAGA;;AAII;AACJ;;AAMM;;;;AAQT;;;;AAIG;AACG;;;AAEA;;AAEH;;AAEG;;;;;AAKN;;;;AAKM;AACG;AACH;;;;;AAIN;AAGA;;AAUY;;AAEG;AACA;AACF;AACH;;AAOK;;;AAGA;;AAEA;;AAEN;AAEG;;;;;AAUA;AACF;;;AAUc;;;AAGG;;;;;AAIH;;;;AAGA;;AAEA;;;;AAIR;;AAKQ;;;AAGG;;;;;AAIH;;;;AAGA;;AAEA;;;AAGN;AASrB;;"}
1
+ {"version":3,"file":"index.js","sources":["../../src/Autocomplete/index.tsx"],"sourcesContent":["\"use client\"\nimport React, { ReactElement, useEffect } from 'react'\nimport Input from '../Input'\nimport Menu from '../Menu'\nimport List from '../List';\nimport ListItem, { ListItemProps } from '../ListItem';\nimport Chip from '../Chip';\nimport IconButton from '../IconButton';\nimport Close from '@xanui/icons/Close';\nimport CircleProgress from '../CircleProgress';\nimport { useBreakpointPropsType, UseColorTemplateColor } from '@xanui/core';\n\nexport type AutocompleteProps = {\n\n options: any[] | ((text: string) => Promise<any[]>)\n getLabel: (option: any) => string;\n onChange?: (value: any) => void;\n value?: any;\n multiple?: boolean;\n renderOption?: (option: any, props: any) => ReactElement<ListItemProps>\n\n // input props customization\n disabled?: boolean;\n name?: string;\n placeholder?: string;\n readOnly?: boolean;\n autoFocus?: boolean;\n autoComplete?: string;\n label?: useBreakpointPropsType<string>;\n\n onFocus?: (e: React.FocusEvent<any>) => void;\n onBlur?: (e: React.FocusEvent<any>) => void;\n onInput?: (e: React.FormEvent<any>) => void;\n onKeyDown?: (e: React.KeyboardEvent<any>) => void;\n onKeyUp?: (e: React.KeyboardEvent<any>) => void;\n\n rows?: useBreakpointPropsType<number>;\n minRows?: useBreakpointPropsType<number>;\n maxRows?: useBreakpointPropsType<number>;\n fullWidth?: boolean;\n\n startIcon?: useBreakpointPropsType<ReactElement>;\n endIcon?: useBreakpointPropsType<ReactElement>;\n iconPlacement?: useBreakpointPropsType<\"start\" | \"center\" | \"end\">;\n focused?: boolean;\n color?: useBreakpointPropsType<Omit<UseColorTemplateColor, 'surface'>>;\n variant?: useBreakpointPropsType<\"fill\" | \"outline\" | \"text\">;\n error?: boolean;\n helperText?: useBreakpointPropsType<string>;\n\n}\n\nconst Autocomplete = ({ value, onChange, renderOption, options, getLabel, multiple, ...inputProps }: AutocompleteProps) => {\n const [_options, setOptions] = React.useState<any[]>()\n const [inputValue, setInputValue] = React.useState(value ? getLabel(value) : \"\")\n const [timer, setTimer] = React.useState<any>(null)\n const [loading, setLoading] = React.useState(false)\n const [focused, setFocused] = React.useState(false)\n const [open, setOpen] = React.useState(false)\n const menuRef = React.useRef<any>(null)\n\n useEffect(() => {\n if (!inputValue) {\n setInputValue(value ? getLabel(value) : \"\")\n }\n }, [value])\n\n getLabel ??= (option: any) => option.toString();\n multiple ??= false;\n\n let startIcons = []\n if (inputProps.startIcon) {\n startIcons.push(inputProps.startIcon)\n }\n\n if (!!value && multiple && Array.isArray(value)) {\n value.map((v: any, index: number) => {\n startIcons.push(<Chip\n key={index}\n size=\"small\"\n label={getLabel!(v)}\n variant={\"fill\"}\n color=\"surface\"\n endIcon={<IconButton\n size={20}\n variant={\"text\"}\n color=\"surface\"\n onClick={(e) => {\n e.stopPropagation();\n let newValue = Array.isArray(value) ? [...value] : []\n newValue = newValue.filter((val: any) => getLabel!(val) !== getLabel!(v))\n onChange && onChange(newValue)\n }}\n >\n <Close />\n </IconButton>}\n />)\n })\n }\n\n let endIcons = []\n if (inputProps.endIcon) {\n endIcons.push(inputProps.endIcon)\n }\n if (loading) {\n endIcons.push(<CircleProgress\n key=\"auto-complete-loading-icon\"\n size=\"small\"\n />)\n } else if (!!value && !multiple) {\n endIcons.unshift(<IconButton\n key=\"auto-complete-clear-button\"\n variant={\"text\"}\n color=\"surface\"\n onClick={(e) => {\n e.stopPropagation();\n onChange && onChange(null)\n setInputValue(\"\")\n }}\n >\n <Close />\n </IconButton>)\n }\n\n const loadOptions = async () => {\n setLoading(true)\n setOpen(false)\n let results = []\n if (typeof options === 'function') {\n results = await options(inputValue)\n } else {\n results = options.filter(option => getLabel!(option).toString().toLowerCase().includes(inputValue.toLowerCase()))\n }\n if (!multiple && inputValue) {\n const find = results.find(option => getLabel!(option).toString().toLowerCase() === inputValue.toLowerCase())\n onChange && onChange(find || null)\n }\n setOptions(results)\n setOpen(true)\n setLoading(false)\n }\n\n useEffect(() => {\n if (focused) {\n clearTimeout(timer)\n setTimer(setTimeout(() => {\n loadOptions()\n }, 300))\n } else {\n setOpen(false)\n }\n }, [focused, inputValue])\n\n\n return (\n <>\n <Input\n {...inputProps as any}\n ref={menuRef}\n slotProps={{\n rootContainer: {\n flexWrap: 'wrap',\n ...(multiple ? { height: \"auto\", gap: .5 } : {})\n },\n input: {\n width: multiple ? 'initial' : '100%',\n flex: 1,\n minWidth: 20,\n }\n }}\n startIcon={startIcons.length ? startIcons : undefined}\n endIcon={endIcons}\n value={inputValue}\n onFocus={() => setFocused(true)}\n onKeyDown={(e) => {\n if (inputProps?.onKeyDown) {\n inputProps.onKeyDown(e)\n }\n if (multiple && e.key === 'Backspace' && inputValue === \"\" && Array.isArray(value) && value.length > 0) {\n let newValue = [...value]\n newValue.pop()\n onChange && onChange(newValue)\n }\n }}\n onChange={(e) => {\n const value = e.target.value;\n setInputValue(value)\n }}\n />\n <Menu\n target={open ? menuRef.current : null}\n onClickOutside={() => {\n setFocused(false)\n }}\n slotProps={{\n content: { minWidth: menuRef.current ? menuRef.current.offsetWidth : 'auto' }\n }}\n >\n <List\n maxHeight={400}\n overflow={\"auto\"}\n >\n {_options?.map((option, index) => (\n renderOption ? <div key={\"auto-complete\" + index + getLabel!(option)}>{renderOption(option, {\n onClick: () => {\n if (multiple) {\n let newValue = Array.isArray(value) ? [...value] : []\n const has = newValue.find((v: any) => getLabel!(v) === getLabel!(option))\n if (!has) {\n newValue.push(option)\n } else {\n newValue = newValue.filter((v: any) => getLabel!(v) !== getLabel!(option))\n }\n onChange && onChange(newValue)\n } else {\n setFocused(false)\n onChange && onChange(option)\n setOpen(false)\n setInputValue(getLabel!(option))\n setOptions([])\n }\n }\n })}</div> : <ListItem\n key={index}\n onClick={() => {\n\n if (multiple) {\n let newValue = Array.isArray(value) ? [...value] : []\n const has = newValue.find((v: any) => getLabel!(v) === getLabel!(option))\n if (!has) {\n newValue.push(option)\n } else {\n newValue = newValue.filter((v: any) => getLabel!(v) !== getLabel!(option))\n }\n onChange && onChange(newValue)\n } else {\n setFocused(false)\n onChange && onChange(option)\n setOpen(false)\n setInputValue(getLabel!(option))\n setOptions([])\n }\n }}\n >\n {getLabel!(option)}\n </ListItem>\n ))}\n </List>\n </Menu>\n </>\n )\n}\n\nexport default Autocomplete\n"],"names":[],"mappings":";;;;;;;;;;;;;AAoDA;AAAsB;;;AAGnB;AACA;AACA;AACA;;;;AAKM;;AAEN;AAEA;;;AAIA;AACG;;AAGH;;;;AAce;;AAEA;;AAMZ;;;AAIH;AACG;;;AAGA;;AAII;AACJ;;AAMM;;;;AAQT;;;;AAIG;AACG;;;AAEA;;AAEH;;AAEG;;;;;AAKN;;;;AAKM;AACG;AACH;;;;;AAIN;AAGA;;AAUY;;AAEG;AACA;AACF;AACH;;AAOK;;;AAGA;;AAEA;;AAEN;AAEG;;;;;AAUA;AACF;;;AAUc;;;AAGG;;;;;AAIH;;;;AAGA;;AAEA;;;;AAIR;;AAKQ;;;AAGG;;;;;AAIH;;;;AAGA;;AAEA;;;AAGN;AASrB;;"}
package/Avatar/index.cjs CHANGED
@@ -28,13 +28,13 @@ const Avatar = React.forwardRef((_a, ref) => {
28
28
  display: "inline-flex",
29
29
  justifyContent: "center",
30
30
  alignItems: "center",
31
- bgcolor: "background.secondary",
31
+ bgcolor: "surface.light",
32
32
  radius: size,
33
33
  fontSize: (size / 3) * 2,
34
34
  width: size,
35
35
  height: size,
36
36
  userSelect: "none",
37
- color: "text.primary",
37
+ color: "surface.contrast",
38
38
  '& svg': {
39
39
  fontSize: (size / 3) * 2,
40
40
  opacity: .6
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../../src/Avatar/index.tsx"],"sourcesContent":["\"use client\"\nimport React, { useState } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\nimport PersonIcon from '@xanui/icons/Person'\nimport Skeleton, { SkeletonProps } from '../Skeleton';\n\nexport type AvatarProps<T extends TagComponentType = \"img\"> = TagProps<T> & {\n size?: useBreakpointPropsType<number>;\n skeleton?: boolean;\n slotProps?: {\n skeleton?: Omit<SkeletonProps, \"height\" | \"width\" | \"loading\" | \"children\">\n }\n}\n\nconst Avatar = React.forwardRef(<T extends TagComponentType = \"img\">({ children, src, alt, skeleton, ...rest }: AvatarProps<T>, ref: any) => {\n const [faild, setFaild] = useState<boolean>()\n let [{ size, slotProps, ...props }] = useInterface<any>(\"Avatar\", rest, {})\n size ??= 36\n const _p: any = {}\n if (size) _p.size = size\n const p: any = useBreakpointProps(_p)\n size = p.size\n\n if (skeleton) {\n return <Skeleton\n {...slotProps?.skeleton}\n height={size}\n width={size}\n animation={\"wave\"}\n sx={{\n ...slotProps?.skeleton?.sx,\n borderRadius: size,\n }}\n />\n }\n\n if (faild === false || !src) {\n let t = alt?.charAt(0).toUpperCase() || (children || <PersonIcon />)\n return (\n <Tag\n component=\"div\"\n src={src}\n {...props}\n baseClass='avatar'\n sxr={{\n display: \"inline-flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n bgcolor: \"background.secondary\",\n radius: size,\n fontSize: (size / 3) * 2,\n width: size,\n height: size,\n userSelect: \"none\",\n color: \"text.primary\",\n '& svg': {\n fontSize: (size / 3) * 2,\n opacity: .6\n }\n }}\n ref={ref}\n >{t}</Tag>\n )\n }\n return (\n <Tag\n component=\"img\"\n radius={size}\n width={size}\n height={size}\n objectFit=\"cover\"\n {...props}\n alt={alt}\n src={src}\n baseClass='avatar'\n onError={(e) => {\n setFaild(false)\n props.onError && props.onError(e as any)\n }}\n ref={ref}\n />\n )\n})\n\nexport default Avatar\n\n\n"],"names":[],"mappings":";;;;;;;;;;AAcA;;AAAqE;;;;;AAKjE;AAAU;AACV;AACA;;AAGI;;AAYJ;;AAEI;AAOY;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACI;AACA;AACH;AACJ;;AAKb;;;AAcQ;AAIZ;;"}
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Avatar/index.tsx"],"sourcesContent":["\"use client\"\nimport React, { useState } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\nimport PersonIcon from '@xanui/icons/Person'\nimport Skeleton, { SkeletonProps } from '../Skeleton';\n\nexport type AvatarProps<T extends TagComponentType = \"img\"> = TagProps<T> & {\n size?: useBreakpointPropsType<number>;\n skeleton?: boolean;\n slotProps?: {\n skeleton?: Omit<SkeletonProps, \"height\" | \"width\" | \"loading\" | \"children\">\n }\n}\n\nconst Avatar = React.forwardRef(<T extends TagComponentType = \"img\">({ children, src, alt, skeleton, ...rest }: AvatarProps<T>, ref: any) => {\n const [faild, setFaild] = useState<boolean>()\n let [{ size, slotProps, ...props }] = useInterface<any>(\"Avatar\", rest, {})\n size ??= 36\n const _p: any = {}\n if (size) _p.size = size\n const p: any = useBreakpointProps(_p)\n size = p.size\n\n if (skeleton) {\n return <Skeleton\n {...slotProps?.skeleton}\n height={size}\n width={size}\n animation={\"wave\"}\n sx={{\n ...slotProps?.skeleton?.sx,\n borderRadius: size,\n }}\n />\n }\n\n if (faild === false || !src) {\n let t = alt?.charAt(0).toUpperCase() || (children || <PersonIcon />)\n return (\n <Tag\n component=\"div\"\n src={src}\n {...props}\n baseClass='avatar'\n sxr={{\n display: \"inline-flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n bgcolor: \"surface.light\",\n radius: size,\n fontSize: (size / 3) * 2,\n width: size,\n height: size,\n userSelect: \"none\",\n color: \"surface.contrast\",\n '& svg': {\n fontSize: (size / 3) * 2,\n opacity: .6\n }\n }}\n ref={ref}\n >{t}</Tag>\n )\n }\n return (\n <Tag\n component=\"img\"\n radius={size}\n width={size}\n height={size}\n objectFit=\"cover\"\n {...props}\n alt={alt}\n src={src}\n baseClass='avatar'\n onError={(e) => {\n setFaild(false)\n props.onError && props.onError(e as any)\n }}\n ref={ref}\n />\n )\n})\n\nexport default Avatar\n\n\n"],"names":[],"mappings":";;;;;;;;;;AAcA;;AAAqE;;;;;AAKjE;AAAU;AACV;AACA;;AAGI;;AAYJ;;AAEI;AAOY;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACI;AACA;AACH;AACJ;;AAKb;;;AAcQ;AAIZ;;"}
package/Avatar/index.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import React from 'react';
1
+ import React__default from 'react';
2
2
  import { TagComponentType, TagProps, useBreakpointPropsType } from '@xanui/core';
3
3
  import { SkeletonProps } from '../Skeleton/index.js';
4
4
 
@@ -9,7 +9,7 @@ type AvatarProps<T extends TagComponentType = "img"> = TagProps<T> & {
9
9
  skeleton?: Omit<SkeletonProps, "height" | "width" | "loading" | "children">;
10
10
  };
11
11
  };
12
- declare const Avatar: React.ForwardRefExoticComponent<Omit<AvatarProps<TagComponentType>, "ref"> & React.RefAttributes<unknown>>;
12
+ declare const Avatar: React__default.ForwardRefExoticComponent<Omit<AvatarProps<TagComponentType>, "ref"> & React__default.RefAttributes<unknown>>;
13
13
 
14
14
  export { Avatar as default };
15
15
  export type { AvatarProps };
package/Avatar/index.js CHANGED
@@ -26,13 +26,13 @@ const Avatar = React.forwardRef((_a, ref) => {
26
26
  display: "inline-flex",
27
27
  justifyContent: "center",
28
28
  alignItems: "center",
29
- bgcolor: "background.secondary",
29
+ bgcolor: "surface.light",
30
30
  radius: size,
31
31
  fontSize: (size / 3) * 2,
32
32
  width: size,
33
33
  height: size,
34
34
  userSelect: "none",
35
- color: "text.primary",
35
+ color: "surface.contrast",
36
36
  '& svg': {
37
37
  fontSize: (size / 3) * 2,
38
38
  opacity: .6
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/Avatar/index.tsx"],"sourcesContent":["\"use client\"\nimport React, { useState } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\nimport PersonIcon from '@xanui/icons/Person'\nimport Skeleton, { SkeletonProps } from '../Skeleton';\n\nexport type AvatarProps<T extends TagComponentType = \"img\"> = TagProps<T> & {\n size?: useBreakpointPropsType<number>;\n skeleton?: boolean;\n slotProps?: {\n skeleton?: Omit<SkeletonProps, \"height\" | \"width\" | \"loading\" | \"children\">\n }\n}\n\nconst Avatar = React.forwardRef(<T extends TagComponentType = \"img\">({ children, src, alt, skeleton, ...rest }: AvatarProps<T>, ref: any) => {\n const [faild, setFaild] = useState<boolean>()\n let [{ size, slotProps, ...props }] = useInterface<any>(\"Avatar\", rest, {})\n size ??= 36\n const _p: any = {}\n if (size) _p.size = size\n const p: any = useBreakpointProps(_p)\n size = p.size\n\n if (skeleton) {\n return <Skeleton\n {...slotProps?.skeleton}\n height={size}\n width={size}\n animation={\"wave\"}\n sx={{\n ...slotProps?.skeleton?.sx,\n borderRadius: size,\n }}\n />\n }\n\n if (faild === false || !src) {\n let t = alt?.charAt(0).toUpperCase() || (children || <PersonIcon />)\n return (\n <Tag\n component=\"div\"\n src={src}\n {...props}\n baseClass='avatar'\n sxr={{\n display: \"inline-flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n bgcolor: \"background.secondary\",\n radius: size,\n fontSize: (size / 3) * 2,\n width: size,\n height: size,\n userSelect: \"none\",\n color: \"text.primary\",\n '& svg': {\n fontSize: (size / 3) * 2,\n opacity: .6\n }\n }}\n ref={ref}\n >{t}</Tag>\n )\n }\n return (\n <Tag\n component=\"img\"\n radius={size}\n width={size}\n height={size}\n objectFit=\"cover\"\n {...props}\n alt={alt}\n src={src}\n baseClass='avatar'\n onError={(e) => {\n setFaild(false)\n props.onError && props.onError(e as any)\n }}\n ref={ref}\n />\n )\n})\n\nexport default Avatar\n\n\n"],"names":[],"mappings":";;;;;;;;AAcA;;AAAqE;;;;;AAKjE;AAAU;AACV;AACA;;AAGI;;AAYJ;;AAEI;AAOY;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACI;AACA;AACH;AACJ;;AAKb;;;AAcQ;AAIZ;;"}
1
+ {"version":3,"file":"index.js","sources":["../../src/Avatar/index.tsx"],"sourcesContent":["\"use client\"\nimport React, { useState } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\nimport PersonIcon from '@xanui/icons/Person'\nimport Skeleton, { SkeletonProps } from '../Skeleton';\n\nexport type AvatarProps<T extends TagComponentType = \"img\"> = TagProps<T> & {\n size?: useBreakpointPropsType<number>;\n skeleton?: boolean;\n slotProps?: {\n skeleton?: Omit<SkeletonProps, \"height\" | \"width\" | \"loading\" | \"children\">\n }\n}\n\nconst Avatar = React.forwardRef(<T extends TagComponentType = \"img\">({ children, src, alt, skeleton, ...rest }: AvatarProps<T>, ref: any) => {\n const [faild, setFaild] = useState<boolean>()\n let [{ size, slotProps, ...props }] = useInterface<any>(\"Avatar\", rest, {})\n size ??= 36\n const _p: any = {}\n if (size) _p.size = size\n const p: any = useBreakpointProps(_p)\n size = p.size\n\n if (skeleton) {\n return <Skeleton\n {...slotProps?.skeleton}\n height={size}\n width={size}\n animation={\"wave\"}\n sx={{\n ...slotProps?.skeleton?.sx,\n borderRadius: size,\n }}\n />\n }\n\n if (faild === false || !src) {\n let t = alt?.charAt(0).toUpperCase() || (children || <PersonIcon />)\n return (\n <Tag\n component=\"div\"\n src={src}\n {...props}\n baseClass='avatar'\n sxr={{\n display: \"inline-flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n bgcolor: \"surface.light\",\n radius: size,\n fontSize: (size / 3) * 2,\n width: size,\n height: size,\n userSelect: \"none\",\n color: \"surface.contrast\",\n '& svg': {\n fontSize: (size / 3) * 2,\n opacity: .6\n }\n }}\n ref={ref}\n >{t}</Tag>\n )\n }\n return (\n <Tag\n component=\"img\"\n radius={size}\n width={size}\n height={size}\n objectFit=\"cover\"\n {...props}\n alt={alt}\n src={src}\n baseClass='avatar'\n onError={(e) => {\n setFaild(false)\n props.onError && props.onError(e as any)\n }}\n ref={ref}\n />\n )\n})\n\nexport default Avatar\n\n\n"],"names":[],"mappings":";;;;;;;;AAcA;;AAAqE;;;;;AAKjE;AAAU;AACV;AACA;;AAGI;;AAYJ;;AAEI;AAOY;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACI;AACA;AACH;AACJ;;AAKb;;;AAcQ;AAIZ;;"}
@@ -0,0 +1,19 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var React = require('react');
6
+ var core = require('@xanui/core');
7
+ var index = require('../Avatar/index.cjs');
8
+ var index$1 = require('../Text/index.cjs');
9
+
10
+ const AvatarBox = React.forwardRef(({ src, title, subtitle, slotProps }, ref) => {
11
+ return (jsxRuntime.jsxs(core.Tag, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.root, { baseClass: 'avatar-box', sxr: {
12
+ display: 'flex',
13
+ alignItems: 'center',
14
+ gap: 1.5,
15
+ }, ref: ref, children: [jsxRuntime.jsx(index, Object.assign({ size: 40 }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.avatar, { src: src, flex: "0 0 auto" })), jsxRuntime.jsxs(core.Tag, { children: [title && jsxRuntime.jsx(index$1, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.title, { fontSize: "button", classNames: "avatar-box-title", children: title })), subtitle && jsxRuntime.jsx(index$1, Object.assign({ fontSize: "button", color: "surface.light" }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.subtitle, { classNames: "avatar-box-subtitle", children: subtitle }))] })] })));
16
+ });
17
+
18
+ module.exports = AvatarBox;
19
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/AvatarBox/index.tsx"],"sourcesContent":["\"use client\"\nimport React from 'react';\nimport { Tag, TagProps } from '@xanui/core';\nimport Avatar, { AvatarProps } from '../Avatar'\nimport Text from '../Text';\n\nexport type AvatarBoxProps = {\n src?: string;\n title?: string;\n subtitle?: string;\n slotProps?: {\n root?: TagProps;\n avatar?: Omit<AvatarProps, \"src\">;\n title?: TagProps;\n subtitle?: TagProps;\n };\n}\n\nconst AvatarBox = React.forwardRef(({ src, title, subtitle, slotProps }: AvatarBoxProps, ref: React.Ref<any>) => {\n return (\n <Tag\n {...slotProps?.root}\n baseClass='avatar-box'\n sxr={{\n display: 'flex',\n alignItems: 'center',\n gap: 1.5,\n }}\n ref={ref}\n >\n <Avatar\n size={40}\n {...slotProps?.avatar}\n src={src}\n flex=\"0 0 auto\"\n />\n <Tag>\n {title && <Text\n {...slotProps?.title}\n fontSize={\"button\"}\n classNames=\"avatar-box-title\"\n >\n {title}\n </Text>}\n {subtitle && <Text\n fontSize={\"button\"}\n color=\"surface.light\"\n {...slotProps?.subtitle}\n classNames=\"avatar-box-subtitle\"\n >\n {subtitle}\n </Text>}\n </Tag>\n </Tag>\n )\n})\n\n\nexport default AvatarBox\n"],"names":[],"mappings":";;;;;;;;;AAkBA;AACG;AAKS;AACA;AACA;AACF;AA4BV;;"}
@@ -0,0 +1,19 @@
1
+ import React__default from 'react';
2
+ import { TagProps } from '@xanui/core';
3
+ import { AvatarProps } from '../Avatar/index.js';
4
+
5
+ type AvatarBoxProps = {
6
+ src?: string;
7
+ title?: string;
8
+ subtitle?: string;
9
+ slotProps?: {
10
+ root?: TagProps;
11
+ avatar?: Omit<AvatarProps, "src">;
12
+ title?: TagProps;
13
+ subtitle?: TagProps;
14
+ };
15
+ };
16
+ declare const AvatarBox: React__default.ForwardRefExoticComponent<AvatarBoxProps & React__default.RefAttributes<any>>;
17
+
18
+ export { AvatarBox as default };
19
+ export type { AvatarBoxProps };
@@ -0,0 +1,17 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import React from 'react';
4
+ import { Tag } from '@xanui/core';
5
+ import Avatar from '../Avatar/index.js';
6
+ import Text from '../Text/index.js';
7
+
8
+ const AvatarBox = React.forwardRef(({ src, title, subtitle, slotProps }, ref) => {
9
+ return (jsxs(Tag, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.root, { baseClass: 'avatar-box', sxr: {
10
+ display: 'flex',
11
+ alignItems: 'center',
12
+ gap: 1.5,
13
+ }, ref: ref, children: [jsx(Avatar, Object.assign({ size: 40 }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.avatar, { src: src, flex: "0 0 auto" })), jsxs(Tag, { children: [title && jsx(Text, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.title, { fontSize: "button", classNames: "avatar-box-title", children: title })), subtitle && jsx(Text, Object.assign({ fontSize: "button", color: "surface.light" }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.subtitle, { classNames: "avatar-box-subtitle", children: subtitle }))] })] })));
14
+ });
15
+
16
+ export { AvatarBox as default };
17
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/AvatarBox/index.tsx"],"sourcesContent":["\"use client\"\nimport React from 'react';\nimport { Tag, TagProps } from '@xanui/core';\nimport Avatar, { AvatarProps } from '../Avatar'\nimport Text from '../Text';\n\nexport type AvatarBoxProps = {\n src?: string;\n title?: string;\n subtitle?: string;\n slotProps?: {\n root?: TagProps;\n avatar?: Omit<AvatarProps, \"src\">;\n title?: TagProps;\n subtitle?: TagProps;\n };\n}\n\nconst AvatarBox = React.forwardRef(({ src, title, subtitle, slotProps }: AvatarBoxProps, ref: React.Ref<any>) => {\n return (\n <Tag\n {...slotProps?.root}\n baseClass='avatar-box'\n sxr={{\n display: 'flex',\n alignItems: 'center',\n gap: 1.5,\n }}\n ref={ref}\n >\n <Avatar\n size={40}\n {...slotProps?.avatar}\n src={src}\n flex=\"0 0 auto\"\n />\n <Tag>\n {title && <Text\n {...slotProps?.title}\n fontSize={\"button\"}\n classNames=\"avatar-box-title\"\n >\n {title}\n </Text>}\n {subtitle && <Text\n fontSize={\"button\"}\n color=\"surface.light\"\n {...slotProps?.subtitle}\n classNames=\"avatar-box-subtitle\"\n >\n {subtitle}\n </Text>}\n </Tag>\n </Tag>\n )\n})\n\n\nexport default AvatarBox\n"],"names":[],"mappings":";;;;;;;AAkBA;AACG;AAKS;AACA;AACA;AACF;AA4BV;;"}
@@ -0,0 +1,80 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var tslib = require('tslib');
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var CloseOutlined = require('@xanui/icons/CloseOutlined');
7
+ var CameraAltOutlined = require('@xanui/icons/CameraAltOutlined');
8
+ var index$1 = require('../Avatar/index.cjs');
9
+ var index = require('../Badge/index.cjs');
10
+ var index$4 = require('../IconButton/index.cjs');
11
+ var index$2 = require('../Menu/index.cjs');
12
+ var index$3 = require('../Text/index.cjs');
13
+ var React = require('react');
14
+ var core = require('@xanui/core');
15
+
16
+ const AvatarPicker = React.forwardRef((_a, ref) => {
17
+ var _b;
18
+ var { value, maxSize, changeIcon, onChange, onDelete, onSelect, loading, bgcolor } = _a, rest = tslib.__rest(_a, ["value", "maxSize", "changeIcon", "onChange", "onDelete", "onSelect", "loading", "bgcolor"]);
19
+ let [_c] = core.useInterface("AvaterPicker", rest, {}), { defaultPreview, avatarSize, slotProps } = _c, props = tslib.__rest(_c, ["defaultPreview", "avatarSize", "slotProps"]);
20
+ const _p = {};
21
+ if (defaultPreview)
22
+ _p.defaultPreview = defaultPreview;
23
+ if (avatarSize)
24
+ _p.avatarSize = avatarSize;
25
+ const bp = core.useBreakpointProps(_p);
26
+ maxSize = maxSize || (1024 * 2); // default 2MB
27
+ defaultPreview = bp.defaultPreview;
28
+ avatarSize = (_b = bp.avatarSize) !== null && _b !== void 0 ? _b : 100;
29
+ const [preview, setPreview] = React.useState();
30
+ const [target, setTarget] = React.useState();
31
+ React.useEffect(() => {
32
+ if (!value) {
33
+ setPreview(undefined);
34
+ return;
35
+ }
36
+ if (typeof value === 'string') {
37
+ setPreview(value);
38
+ return;
39
+ }
40
+ const objectUrl = URL.createObjectURL(value);
41
+ setPreview(objectUrl);
42
+ return () => URL.revokeObjectURL(objectUrl);
43
+ }, [value, onChange]);
44
+ return (jsxRuntime.jsx(core.Tag, Object.assign({}, props, { baseClass: "avatar-picker", ref: ref, sxr: {
45
+ display: 'inline-block',
46
+ position: 'relative',
47
+ }, children: jsxRuntime.jsxs(index, Object.assign({ disableSpace: true, disableTransition: true }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.badge, { placement: value ? "right-top" : "right-bottom", content: jsxRuntime.jsx(core.Tag, { children: jsxRuntime.jsx(index$4, { color: value ? "danger" : 'surface', cursor: "pointer", size: value ? 20 : "small", onClick: (be) => {
48
+ if (value) {
49
+ onDelete && onDelete(value);
50
+ onChange && onChange(null);
51
+ return;
52
+ }
53
+ if (target) {
54
+ setTarget(undefined);
55
+ }
56
+ const input = document.createElement('input');
57
+ input.type = 'file';
58
+ input.accept = 'image/*';
59
+ input.onchange = (e) => {
60
+ const selectedFile = e.target.files[0];
61
+ if (maxSize && selectedFile.size > maxSize * 1024) {
62
+ setTarget(be.target);
63
+ setTimeout(() => {
64
+ setTarget(undefined);
65
+ }, 3000);
66
+ return;
67
+ }
68
+ onSelect && onSelect(selectedFile);
69
+ onChange && onChange(selectedFile);
70
+ };
71
+ input.click();
72
+ }, children: value ? jsxRuntime.jsx(CloseOutlined, {}) : (changeIcon || jsxRuntime.jsx(CameraAltOutlined, {})) }) }), children: [jsxRuntime.jsx(index$1, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.avatar, { skeleton: loading, size: avatarSize, src: preview || defaultPreview, border: target ? '1px solid' : 0, borderColor: target ? "danger.main" : "transparent", bgcolor: target ? "danger.ghost" : bgcolor })), jsxRuntime.jsx(index$2, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.menu, { target: target, placement: "bottom", onClickOutside: () => setTarget(undefined), slotProps: {
73
+ content: {
74
+ mt: 2
75
+ }
76
+ }, children: jsxRuntime.jsx(index$3, { bgcolor: "danger.main", color: "danger.contrast", fontSize: "small", p: 1, px: 2, radius: 1, children: `File size exceeds the maximum limit of ${maxSize} KB` }) }))] })) })));
77
+ });
78
+
79
+ module.exports = AvatarPicker;
80
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/AvatarPicker/index.tsx"],"sourcesContent":["\"use client\"\nimport CloseOutlined from \"@xanui/icons/CloseOutlined\";\nimport CameraAltOutlined from \"@xanui/icons/CameraAltOutlined\";\nimport Avatar, { AvatarProps } from \"../Avatar\"\nimport Badge, { BadgeProps } from \"../Badge\"\nimport IconButton from \"../IconButton\"\nimport Menu, { MenuProps } from \"../Menu\"\nimport Text from \"../Text\"\nimport React from \"react\";\nimport { Tag, TagComponentType, TagProps, useBreakpointProps, useBreakpointPropsType, useInterface } from \"@xanui/core\";\n\n\nexport type AvataPickerValue = File | string | null;\n\nexport type AvatarPickerProps<T extends TagComponentType = \"div\"> = TagProps<T> & {\n value?: AvataPickerValue\n defaultPreview?: string;\n maxSize?: number; // in kb\n changeIcon?: React.ReactNode;\n loading?: boolean;\n avatarSize?: useBreakpointPropsType<number>;\n onChange?: (file: AvataPickerValue) => void;\n onDelete?: (file: File | string) => void\n onSelect?: (file: File | string) => void\n slotProps?: {\n Avatar?: Omit<AvatarProps, \"src\">;\n badge?: Omit<BadgeProps, \"placement\" | \"content\">;\n menu?: Omit<MenuProps, \"target\" | \"onClickOutside\">\n }\n};\n\nconst AvatarPicker = React.forwardRef(<T extends TagComponentType = \"div\">({ value, maxSize, changeIcon, onChange, onDelete, onSelect, loading, bgcolor, ...rest }: AvatarPickerProps, ref: React.Ref<T>) => {\n let [{ defaultPreview, avatarSize, slotProps, ...props }]: any = useInterface(\"AvaterPicker\", rest, {})\n\n const _p: any = {}\n if (defaultPreview) _p.defaultPreview = defaultPreview\n if (avatarSize) _p.avatarSize = avatarSize\n const bp = useBreakpointProps(_p)\n maxSize = maxSize || (1024 * 2); // default 2MB\n defaultPreview = bp.defaultPreview\n avatarSize = bp.avatarSize ?? 100\n\n const [preview, setPreview] = React.useState<string | undefined>();\n const [target, setTarget] = React.useState<HTMLElement | undefined>();\n\n React.useEffect(() => {\n if (!value) {\n setPreview(undefined);\n return;\n } if (typeof value === 'string') {\n setPreview(value);\n return;\n }\n const objectUrl = URL.createObjectURL(value);\n setPreview(objectUrl);\n return () => URL.revokeObjectURL(objectUrl);\n }, [value, onChange]);\n\n return (\n <Tag\n {...props}\n baseClass=\"avatar-picker\"\n ref={ref}\n sxr={{\n display: 'inline-block',\n position: 'relative',\n }}\n >\n <Badge\n disableSpace\n disableTransition\n {...slotProps?.badge}\n placement={value ? \"right-top\" : \"right-bottom\"}\n content={<Tag>\n <IconButton\n color={value ? \"danger\" : 'surface'}\n cursor={\"pointer\"}\n size={value ? 20 : \"small\"}\n onClick={(be: any) => {\n if (value) {\n onDelete && onDelete(value)\n onChange && onChange(null);\n return\n }\n if (target) {\n setTarget(undefined);\n }\n const input = document.createElement('input');\n input.type = 'file';\n input.accept = 'image/*';\n input.onchange = (e: any) => {\n const selectedFile = e.target.files[0];\n if (maxSize && selectedFile.size > maxSize * 1024) {\n setTarget(be.target);\n setTimeout(() => {\n setTarget(undefined);\n }, 3000);\n return;\n }\n onSelect && onSelect(selectedFile)\n onChange && onChange(selectedFile);\n };\n input.click();\n }}\n >\n {\n value ? <CloseOutlined /> : (changeIcon || <CameraAltOutlined />)\n }\n </IconButton>\n </Tag>}\n >\n <Avatar\n {...slotProps?.avatar}\n skeleton={loading}\n size={avatarSize}\n src={preview || defaultPreview}\n border={target ? '1px solid' : 0}\n borderColor={target ? \"danger.main\" : \"transparent\"}\n bgcolor={target ? \"danger.ghost\" : bgcolor}\n />\n <Menu\n {...slotProps?.menu}\n target={target}\n placement={\"bottom\"}\n onClickOutside={() => setTarget(undefined)}\n slotProps={{\n content: {\n mt: 2\n }\n }}\n >\n <Text\n bgcolor=\"danger.main\"\n color=\"danger.contrast\"\n fontSize={\"small\"}\n p={1}\n px={2}\n radius={1}\n >\n {`File size exceeds the maximum limit of ${maxSize} KB`}\n </Text>\n </Menu>\n </Badge>\n </Tag>\n )\n})\n\nexport default AvatarPicker;"],"names":[],"mappings":";;;;;;;;;;;;;;;AA+BA;;;;;AAIG;AAAoB;AACpB;AAAgB;AAChB;;AAEA;AACA;;;AAKA;;;;;AAIK;;;;;;;AAOL;AAEA;AAMS;AACA;AACF;;AAcc;AACA;;;;;;;AAOH;AACA;AACA;;;AAGM;;;;;;AAMH;AACA;AACH;;;AAyBH;AACG;AACF;AACH;AAgBhB;;"}
@@ -0,0 +1,27 @@
1
+ import { AvatarProps } from '../Avatar/index.js';
2
+ import { BadgeProps } from '../Badge/index.js';
3
+ import { MenuProps } from '../Menu/index.js';
4
+ import React__default from 'react';
5
+ import { TagComponentType, TagProps, useBreakpointPropsType } from '@xanui/core';
6
+
7
+ type AvataPickerValue = File | string | null;
8
+ type AvatarPickerProps<T extends TagComponentType = "div"> = TagProps<T> & {
9
+ value?: AvataPickerValue;
10
+ defaultPreview?: string;
11
+ maxSize?: number;
12
+ changeIcon?: React__default.ReactNode;
13
+ loading?: boolean;
14
+ avatarSize?: useBreakpointPropsType<number>;
15
+ onChange?: (file: AvataPickerValue) => void;
16
+ onDelete?: (file: File | string) => void;
17
+ onSelect?: (file: File | string) => void;
18
+ slotProps?: {
19
+ Avatar?: Omit<AvatarProps, "src">;
20
+ badge?: Omit<BadgeProps, "placement" | "content">;
21
+ menu?: Omit<MenuProps, "target" | "onClickOutside">;
22
+ };
23
+ };
24
+ declare const AvatarPicker: React__default.ForwardRefExoticComponent<Omit<AvatarPickerProps<"div">, "ref"> & React__default.RefAttributes<"symbol" | "object" | "cite" | "data" | "form" | "label" | "pattern" | "span" | "summary" | "slot" | "style" | "title" | "div" | "filter" | "small" | "h1" | "h2" | "h3" | "h4" | "h5" | "h6" | "big" | "text" | "button" | "p" | "a" | "abbr" | "address" | "area" | "article" | "aside" | "audio" | "b" | "base" | "bdi" | "bdo" | "blockquote" | "body" | "br" | "canvas" | "caption" | "center" | "code" | "col" | "colgroup" | "datalist" | "dd" | "del" | "details" | "dfn" | "dialog" | "dl" | "dt" | "em" | "embed" | "fieldset" | "figcaption" | "figure" | "footer" | "head" | "header" | "hgroup" | "hr" | "html" | "i" | "iframe" | "img" | "input" | "ins" | "kbd" | "keygen" | "legend" | "li" | "link" | "main" | "map" | "mark" | "menu" | "menuitem" | "meta" | "meter" | "nav" | "noindex" | "noscript" | "ol" | "optgroup" | "option" | "output" | "param" | "picture" | "pre" | "progress" | "q" | "rp" | "rt" | "ruby" | "s" | "samp" | "search" | "script" | "section" | "select" | "source" | "strong" | "sub" | "sup" | "table" | "template" | "tbody" | "td" | "textarea" | "tfoot" | "th" | "thead" | "time" | "tr" | "track" | "u" | "ul" | "var" | "video" | "wbr" | "webview" | "svg" | "animate" | "animateMotion" | "animateTransform" | "circle" | "clipPath" | "defs" | "desc" | "ellipse" | "feBlend" | "feColorMatrix" | "feComponentTransfer" | "feComposite" | "feConvolveMatrix" | "feDiffuseLighting" | "feDisplacementMap" | "feDistantLight" | "feDropShadow" | "feFlood" | "feFuncA" | "feFuncB" | "feFuncG" | "feFuncR" | "feGaussianBlur" | "feImage" | "feMerge" | "feMergeNode" | "feMorphology" | "feOffset" | "fePointLight" | "feSpecularLighting" | "feSpotLight" | "feTile" | "feTurbulence" | "foreignObject" | "g" | "image" | "line" | "linearGradient" | "marker" | "mask" | "metadata" | "mpath" | "path" | "polygon" | "polyline" | "radialGradient" | "rect" | "set" | "stop" | "switch" | "textPath" | "tspan" | "use" | "view" | React__default.ComponentClass<any, any> | React__default.FunctionComponent<any>>>;
25
+
26
+ export { AvatarPicker as default };
27
+ export type { AvataPickerValue, AvatarPickerProps };
@@ -0,0 +1,78 @@
1
+ "use client";
2
+ import { __rest } from 'tslib';
3
+ import { jsx, jsxs } from 'react/jsx-runtime';
4
+ import CloseOutlined from '@xanui/icons/CloseOutlined';
5
+ import CameraAltOutlined from '@xanui/icons/CameraAltOutlined';
6
+ import Avatar from '../Avatar/index.js';
7
+ import Badge from '../Badge/index.js';
8
+ import IconButton from '../IconButton/index.js';
9
+ import Menu from '../Menu/index.js';
10
+ import Text from '../Text/index.js';
11
+ import React from 'react';
12
+ import { useInterface, useBreakpointProps, Tag } from '@xanui/core';
13
+
14
+ const AvatarPicker = React.forwardRef((_a, ref) => {
15
+ var _b;
16
+ var { value, maxSize, changeIcon, onChange, onDelete, onSelect, loading, bgcolor } = _a, rest = __rest(_a, ["value", "maxSize", "changeIcon", "onChange", "onDelete", "onSelect", "loading", "bgcolor"]);
17
+ let [_c] = useInterface("AvaterPicker", rest, {}), { defaultPreview, avatarSize, slotProps } = _c, props = __rest(_c, ["defaultPreview", "avatarSize", "slotProps"]);
18
+ const _p = {};
19
+ if (defaultPreview)
20
+ _p.defaultPreview = defaultPreview;
21
+ if (avatarSize)
22
+ _p.avatarSize = avatarSize;
23
+ const bp = useBreakpointProps(_p);
24
+ maxSize = maxSize || (1024 * 2); // default 2MB
25
+ defaultPreview = bp.defaultPreview;
26
+ avatarSize = (_b = bp.avatarSize) !== null && _b !== void 0 ? _b : 100;
27
+ const [preview, setPreview] = React.useState();
28
+ const [target, setTarget] = React.useState();
29
+ React.useEffect(() => {
30
+ if (!value) {
31
+ setPreview(undefined);
32
+ return;
33
+ }
34
+ if (typeof value === 'string') {
35
+ setPreview(value);
36
+ return;
37
+ }
38
+ const objectUrl = URL.createObjectURL(value);
39
+ setPreview(objectUrl);
40
+ return () => URL.revokeObjectURL(objectUrl);
41
+ }, [value, onChange]);
42
+ return (jsx(Tag, Object.assign({}, props, { baseClass: "avatar-picker", ref: ref, sxr: {
43
+ display: 'inline-block',
44
+ position: 'relative',
45
+ }, children: jsxs(Badge, Object.assign({ disableSpace: true, disableTransition: true }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.badge, { placement: value ? "right-top" : "right-bottom", content: jsx(Tag, { children: jsx(IconButton, { color: value ? "danger" : 'surface', cursor: "pointer", size: value ? 20 : "small", onClick: (be) => {
46
+ if (value) {
47
+ onDelete && onDelete(value);
48
+ onChange && onChange(null);
49
+ return;
50
+ }
51
+ if (target) {
52
+ setTarget(undefined);
53
+ }
54
+ const input = document.createElement('input');
55
+ input.type = 'file';
56
+ input.accept = 'image/*';
57
+ input.onchange = (e) => {
58
+ const selectedFile = e.target.files[0];
59
+ if (maxSize && selectedFile.size > maxSize * 1024) {
60
+ setTarget(be.target);
61
+ setTimeout(() => {
62
+ setTarget(undefined);
63
+ }, 3000);
64
+ return;
65
+ }
66
+ onSelect && onSelect(selectedFile);
67
+ onChange && onChange(selectedFile);
68
+ };
69
+ input.click();
70
+ }, children: value ? jsx(CloseOutlined, {}) : (changeIcon || jsx(CameraAltOutlined, {})) }) }), children: [jsx(Avatar, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.avatar, { skeleton: loading, size: avatarSize, src: preview || defaultPreview, border: target ? '1px solid' : 0, borderColor: target ? "danger.main" : "transparent", bgcolor: target ? "danger.ghost" : bgcolor })), jsx(Menu, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.menu, { target: target, placement: "bottom", onClickOutside: () => setTarget(undefined), slotProps: {
71
+ content: {
72
+ mt: 2
73
+ }
74
+ }, children: jsx(Text, { bgcolor: "danger.main", color: "danger.contrast", fontSize: "small", p: 1, px: 2, radius: 1, children: `File size exceeds the maximum limit of ${maxSize} KB` }) }))] })) })));
75
+ });
76
+
77
+ export { AvatarPicker as default };
78
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/AvatarPicker/index.tsx"],"sourcesContent":["\"use client\"\nimport CloseOutlined from \"@xanui/icons/CloseOutlined\";\nimport CameraAltOutlined from \"@xanui/icons/CameraAltOutlined\";\nimport Avatar, { AvatarProps } from \"../Avatar\"\nimport Badge, { BadgeProps } from \"../Badge\"\nimport IconButton from \"../IconButton\"\nimport Menu, { MenuProps } from \"../Menu\"\nimport Text from \"../Text\"\nimport React from \"react\";\nimport { Tag, TagComponentType, TagProps, useBreakpointProps, useBreakpointPropsType, useInterface } from \"@xanui/core\";\n\n\nexport type AvataPickerValue = File | string | null;\n\nexport type AvatarPickerProps<T extends TagComponentType = \"div\"> = TagProps<T> & {\n value?: AvataPickerValue\n defaultPreview?: string;\n maxSize?: number; // in kb\n changeIcon?: React.ReactNode;\n loading?: boolean;\n avatarSize?: useBreakpointPropsType<number>;\n onChange?: (file: AvataPickerValue) => void;\n onDelete?: (file: File | string) => void\n onSelect?: (file: File | string) => void\n slotProps?: {\n Avatar?: Omit<AvatarProps, \"src\">;\n badge?: Omit<BadgeProps, \"placement\" | \"content\">;\n menu?: Omit<MenuProps, \"target\" | \"onClickOutside\">\n }\n};\n\nconst AvatarPicker = React.forwardRef(<T extends TagComponentType = \"div\">({ value, maxSize, changeIcon, onChange, onDelete, onSelect, loading, bgcolor, ...rest }: AvatarPickerProps, ref: React.Ref<T>) => {\n let [{ defaultPreview, avatarSize, slotProps, ...props }]: any = useInterface(\"AvaterPicker\", rest, {})\n\n const _p: any = {}\n if (defaultPreview) _p.defaultPreview = defaultPreview\n if (avatarSize) _p.avatarSize = avatarSize\n const bp = useBreakpointProps(_p)\n maxSize = maxSize || (1024 * 2); // default 2MB\n defaultPreview = bp.defaultPreview\n avatarSize = bp.avatarSize ?? 100\n\n const [preview, setPreview] = React.useState<string | undefined>();\n const [target, setTarget] = React.useState<HTMLElement | undefined>();\n\n React.useEffect(() => {\n if (!value) {\n setPreview(undefined);\n return;\n } if (typeof value === 'string') {\n setPreview(value);\n return;\n }\n const objectUrl = URL.createObjectURL(value);\n setPreview(objectUrl);\n return () => URL.revokeObjectURL(objectUrl);\n }, [value, onChange]);\n\n return (\n <Tag\n {...props}\n baseClass=\"avatar-picker\"\n ref={ref}\n sxr={{\n display: 'inline-block',\n position: 'relative',\n }}\n >\n <Badge\n disableSpace\n disableTransition\n {...slotProps?.badge}\n placement={value ? \"right-top\" : \"right-bottom\"}\n content={<Tag>\n <IconButton\n color={value ? \"danger\" : 'surface'}\n cursor={\"pointer\"}\n size={value ? 20 : \"small\"}\n onClick={(be: any) => {\n if (value) {\n onDelete && onDelete(value)\n onChange && onChange(null);\n return\n }\n if (target) {\n setTarget(undefined);\n }\n const input = document.createElement('input');\n input.type = 'file';\n input.accept = 'image/*';\n input.onchange = (e: any) => {\n const selectedFile = e.target.files[0];\n if (maxSize && selectedFile.size > maxSize * 1024) {\n setTarget(be.target);\n setTimeout(() => {\n setTarget(undefined);\n }, 3000);\n return;\n }\n onSelect && onSelect(selectedFile)\n onChange && onChange(selectedFile);\n };\n input.click();\n }}\n >\n {\n value ? <CloseOutlined /> : (changeIcon || <CameraAltOutlined />)\n }\n </IconButton>\n </Tag>}\n >\n <Avatar\n {...slotProps?.avatar}\n skeleton={loading}\n size={avatarSize}\n src={preview || defaultPreview}\n border={target ? '1px solid' : 0}\n borderColor={target ? \"danger.main\" : \"transparent\"}\n bgcolor={target ? \"danger.ghost\" : bgcolor}\n />\n <Menu\n {...slotProps?.menu}\n target={target}\n placement={\"bottom\"}\n onClickOutside={() => setTarget(undefined)}\n slotProps={{\n content: {\n mt: 2\n }\n }}\n >\n <Text\n bgcolor=\"danger.main\"\n color=\"danger.contrast\"\n fontSize={\"small\"}\n p={1}\n px={2}\n radius={1}\n >\n {`File size exceeds the maximum limit of ${maxSize} KB`}\n </Text>\n </Menu>\n </Badge>\n </Tag>\n )\n})\n\nexport default AvatarPicker;"],"names":[],"mappings":";;;;;;;;;;;;;AA+BA;;;;;AAIG;AAAoB;AACpB;AAAgB;AAChB;;AAEA;AACA;;;AAKA;;;;;AAIK;;;;;;;AAOL;AAEA;AAMS;AACA;AACF;;AAcc;AACA;;;;;;;AAOH;AACA;AACA;;;AAGM;;;;;;AAMH;AACA;AACH;;;AAyBH;AACG;AACF;AACH;AAgBhB;;"}
package/Badge/index.cjs CHANGED
@@ -91,7 +91,7 @@ const Badge = React.forwardRef((_a, ref) => {
91
91
  else {
92
92
  template = {};
93
93
  }
94
- 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
+ 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.main), _css), children: content }));
95
95
  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: () => {
96
96
  return {
97
97
  from: {
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../../src/Badge/index.tsx"],"sourcesContent":["\"use client\"\nimport React, { ReactElement } from 'react';\nimport { Tag, TagProps, TagComponentType, Transition, useInterface, UseColorTemplateColor, useColorTemplate, useBreakpointPropsType, useBreakpointProps, TransitionProps } from '@xanui/core';\n\nexport type BadgeProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, \"baseClass\" | \"content\"> & {\n content?: useBreakpointPropsType<number | string | ReactElement>;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n placement?: useBreakpointPropsType<\"left-top\" | \"left-bottom\" | \"right-top\" | \"right-bottom\">;\n visible?: useBreakpointPropsType<boolean>;\n disableTransition?: boolean;\n disableSpace?: boolean;\n slotProps?: {\n transition?: Omit<TransitionProps, \"open\">;\n content?: Omit<TagProps<\"span\">, \"children\">;\n },\n refs?: {\n content?: React.Ref<any>;\n transition?: React.Ref<any>;\n };\n}\n\nconst Badge = React.forwardRef(<T extends TagComponentType = \"div\">({ children, content, refs, ...rest }: BadgeProps<T>, ref: React.Ref<any>) => {\n let [{ color, placement, visible, slotProps, disableTransition, disableSpace, ...props }] = useInterface<any>(\"Badge\", rest, {})\n color ??= \"danger\"\n visible ??= true\n placement ??= \"right-top\"\n disableTransition ??= false\n disableSpace ??= false\n\n const _p: any = {}\n\n _p.content = content\n _p.color = color\n _p.placement = placement\n _p.visible = visible\n _p.disableTransition = disableTransition ?? false\n\n const p: any = useBreakpointProps(_p)\n\n content = p.content\n color = p.color\n placement = p.placement\n visible = p.visible\n disableTransition = p.disableTransition\n\n const isReactElement = React.isValidElement(content);\n\n let template: any = useColorTemplate(color, \"fill\")\n let _css: any = {\n position: \"absolute\",\n }\n\n let translate = ''\n\n switch (placement) {\n case \"right-top\":\n _css.top = 0;\n _css.right = 0;\n if (!disableSpace) {\n translate = \"translate(50%, -50%)\";\n }\n break;\n case \"right-bottom\":\n _css.bottom = 0;\n _css.right = 0;\n if (!disableSpace) {\n translate = \"translate(50%, 50%)\";\n }\n break;\n case \"left-top\":\n _css.top = 0;\n _css.left = 0;\n if (!disableSpace) {\n translate = \"translate(-50%, -50%)\";\n }\n break;\n case \"left-bottom\":\n _css.bottom = 0;\n _css.left = 0;\n if (!disableSpace) {\n translate = \"translate(-50%, 50%)\";\n }\n break;\n }\n\n if (disableTransition) {\n _css.transform = translate\n }\n\n if (!isReactElement) {\n _css.userSelect = \"none\"\n _css.pointerEvents = \"none\"\n _css.fontSize = \"small\"\n _css.lineHeight = 1\n _css.fontWeight = 500\n _css.radius = 2\n\n if (typeof content === 'number') {\n if (content > 99) {\n content = \"99+\"\n }\n }\n\n if (content !== undefined) {\n _css.minWidth = 16\n _css.height = 16\n _css.p = .8\n _css.px = .4\n } else {\n _css.width = 8\n _css.height = 8\n }\n } else {\n template = {}\n }\n\n const _badge = <Tag\n {...slotProps?.content}\n ref={refs?.content}\n component='span'\n baseClass='badge-content'\n sxr={{\n position: \"absolute\",\n zIndex: 1,\n display: 'flex',\n justifyContent: \"center\",\n alignItems: 'center',\n ...template.primary,\n ..._css,\n }}\n >\n {content}\n </Tag>\n\n return (\n <Tag\n {...props}\n position=\"relative\"\n display=\"inline-block\"\n baseClass='badge'\n ref={ref}\n >\n {\n !disableTransition ? (<Transition\n open={content !== undefined && visible}\n {...slotProps?.transition}\n variant={() => {\n return {\n from: {\n opacity: 0,\n transform: `scale(0) ${translate}`.trim(),\n },\n to: {\n opacity: 1,\n transform: `scale(1) ${translate}`.trim(),\n },\n }\n }}\n ref={refs?.transition}\n >\n {_badge}\n </Transition>) : <>{_badge}</>\n }\n\n {children}\n </Tag>\n )\n})\n\nexport default Badge\n\n"],"names":[],"mappings":";;;;;;;;AAqBA;;AACI;;;;;;;AASA;AACA;AACA;AACA;;AAGA;AAEA;AACA;AACA;AACA;AACA;;;AAKA;AACI;;;;AAMA;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;;;AAQJ;;;AAIA;AACA;AACA;AACA;AACA;AACA;AAEA;AACI;;;;AAKJ;AACI;AACA;AACA;AACA;;;AAEA;AACA;;;;;;AAMR;;;AAgCwB;AACI;AACA;AACH;AACD;AACI;AACA;AACH;;;AAY7B;;"}
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Badge/index.tsx"],"sourcesContent":["\"use client\"\nimport React, { ReactElement } from 'react';\nimport { Tag, TagProps, TagComponentType, Transition, useInterface, UseColorTemplateColor, useColorTemplate, useBreakpointPropsType, useBreakpointProps, TransitionProps } from '@xanui/core';\n\nexport type BadgeProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, \"baseClass\" | \"content\"> & {\n content?: useBreakpointPropsType<number | string | ReactElement>;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n placement?: useBreakpointPropsType<\"left-top\" | \"left-bottom\" | \"right-top\" | \"right-bottom\">;\n visible?: useBreakpointPropsType<boolean>;\n disableTransition?: boolean;\n disableSpace?: boolean;\n slotProps?: {\n transition?: Omit<TransitionProps, \"open\">;\n content?: Omit<TagProps<\"span\">, \"children\">;\n },\n refs?: {\n content?: React.Ref<any>;\n transition?: React.Ref<any>;\n };\n}\n\nconst Badge = React.forwardRef(<T extends TagComponentType = \"div\">({ children, content, refs, ...rest }: BadgeProps<T>, ref: React.Ref<any>) => {\n let [{ color, placement, visible, slotProps, disableTransition, disableSpace, ...props }] = useInterface<any>(\"Badge\", rest, {})\n color ??= \"danger\"\n visible ??= true\n placement ??= \"right-top\"\n disableTransition ??= false\n disableSpace ??= false\n\n const _p: any = {}\n\n _p.content = content\n _p.color = color\n _p.placement = placement\n _p.visible = visible\n _p.disableTransition = disableTransition ?? false\n\n const p: any = useBreakpointProps(_p)\n\n content = p.content\n color = p.color\n placement = p.placement\n visible = p.visible\n disableTransition = p.disableTransition\n\n const isReactElement = React.isValidElement(content);\n\n let template: any = useColorTemplate(color, \"fill\")\n let _css: any = {\n position: \"absolute\",\n }\n\n let translate = ''\n\n switch (placement) {\n case \"right-top\":\n _css.top = 0;\n _css.right = 0;\n if (!disableSpace) {\n translate = \"translate(50%, -50%)\";\n }\n break;\n case \"right-bottom\":\n _css.bottom = 0;\n _css.right = 0;\n if (!disableSpace) {\n translate = \"translate(50%, 50%)\";\n }\n break;\n case \"left-top\":\n _css.top = 0;\n _css.left = 0;\n if (!disableSpace) {\n translate = \"translate(-50%, -50%)\";\n }\n break;\n case \"left-bottom\":\n _css.bottom = 0;\n _css.left = 0;\n if (!disableSpace) {\n translate = \"translate(-50%, 50%)\";\n }\n break;\n }\n\n if (disableTransition) {\n _css.transform = translate\n }\n\n if (!isReactElement) {\n _css.userSelect = \"none\"\n _css.pointerEvents = \"none\"\n _css.fontSize = \"small\"\n _css.lineHeight = 1\n _css.fontWeight = 500\n _css.radius = 2\n\n if (typeof content === 'number') {\n if (content > 99) {\n content = \"99+\"\n }\n }\n\n if (content !== undefined) {\n _css.minWidth = 16\n _css.height = 16\n _css.p = .8\n _css.px = .4\n } else {\n _css.width = 8\n _css.height = 8\n }\n } else {\n template = {}\n }\n\n const _badge = <Tag\n {...slotProps?.content}\n ref={refs?.content}\n component='span'\n baseClass='badge-content'\n sxr={{\n position: \"absolute\",\n zIndex: 1,\n display: 'flex',\n justifyContent: \"center\",\n alignItems: 'center',\n ...template.main,\n ..._css,\n }}\n >\n {content}\n </Tag>\n\n return (\n <Tag\n {...props}\n position=\"relative\"\n display=\"inline-block\"\n baseClass='badge'\n ref={ref}\n >\n {\n !disableTransition ? (<Transition\n open={content !== undefined && visible}\n {...slotProps?.transition}\n variant={() => {\n return {\n from: {\n opacity: 0,\n transform: `scale(0) ${translate}`.trim(),\n },\n to: {\n opacity: 1,\n transform: `scale(1) ${translate}`.trim(),\n },\n }\n }}\n ref={refs?.transition}\n >\n {_badge}\n </Transition>) : <>{_badge}</>\n }\n\n {children}\n </Tag>\n )\n})\n\nexport default Badge\n\n"],"names":[],"mappings":";;;;;;;;AAqBA;;AACI;;;;;;;AASA;AACA;AACA;AACA;;AAGA;AAEA;AACA;AACA;AACA;AACA;;;AAKA;AACI;;;;AAMA;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;;;AAQJ;;;AAIA;AACA;AACA;AACA;AACA;AACA;AAEA;AACI;;;;AAKJ;AACI;AACA;AACA;AACA;;;AAEA;AACA;;;;;;AAMR;;;AAgCwB;AACI;AACA;AACH;AACD;AACI;AACA;AACH;;;AAY7B;;"}
package/Badge/index.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import React, { ReactElement } from 'react';
1
+ import React__default, { ReactElement } from 'react';
2
2
  import { TagComponentType, TagProps, useBreakpointPropsType, UseColorTemplateColor, TransitionProps } from '@xanui/core';
3
3
 
4
4
  type BadgeProps<T extends TagComponentType = "div"> = Omit<TagProps<T>, "baseClass" | "content"> & {
@@ -13,11 +13,11 @@ type BadgeProps<T extends TagComponentType = "div"> = Omit<TagProps<T>, "baseCla
13
13
  content?: Omit<TagProps<"span">, "children">;
14
14
  };
15
15
  refs?: {
16
- content?: React.Ref<any>;
17
- transition?: React.Ref<any>;
16
+ content?: React__default.Ref<any>;
17
+ transition?: React__default.Ref<any>;
18
18
  };
19
19
  };
20
- declare const Badge: React.ForwardRefExoticComponent<Omit<BadgeProps<TagComponentType>, "ref"> & React.RefAttributes<any>>;
20
+ declare const Badge: React__default.ForwardRefExoticComponent<Omit<BadgeProps<TagComponentType>, "ref"> & React__default.RefAttributes<any>>;
21
21
 
22
22
  export { Badge as default };
23
23
  export type { BadgeProps };
package/Badge/index.js CHANGED
@@ -89,7 +89,7 @@ const Badge = React.forwardRef((_a, ref) => {
89
89
  else {
90
90
  template = {};
91
91
  }
92
- const _badge = jsx(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 }));
92
+ const _badge = jsx(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.main), _css), children: content }));
93
93
  return (jsxs(Tag, Object.assign({}, props, { position: "relative", display: "inline-block", baseClass: 'badge', ref: ref, children: [!disableTransition ? (jsx(Transition, Object.assign({ open: content !== undefined && visible }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.transition, { variant: () => {
94
94
  return {
95
95
  from: {
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/Badge/index.tsx"],"sourcesContent":["\"use client\"\nimport React, { ReactElement } from 'react';\nimport { Tag, TagProps, TagComponentType, Transition, useInterface, UseColorTemplateColor, useColorTemplate, useBreakpointPropsType, useBreakpointProps, TransitionProps } from '@xanui/core';\n\nexport type BadgeProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, \"baseClass\" | \"content\"> & {\n content?: useBreakpointPropsType<number | string | ReactElement>;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n placement?: useBreakpointPropsType<\"left-top\" | \"left-bottom\" | \"right-top\" | \"right-bottom\">;\n visible?: useBreakpointPropsType<boolean>;\n disableTransition?: boolean;\n disableSpace?: boolean;\n slotProps?: {\n transition?: Omit<TransitionProps, \"open\">;\n content?: Omit<TagProps<\"span\">, \"children\">;\n },\n refs?: {\n content?: React.Ref<any>;\n transition?: React.Ref<any>;\n };\n}\n\nconst Badge = React.forwardRef(<T extends TagComponentType = \"div\">({ children, content, refs, ...rest }: BadgeProps<T>, ref: React.Ref<any>) => {\n let [{ color, placement, visible, slotProps, disableTransition, disableSpace, ...props }] = useInterface<any>(\"Badge\", rest, {})\n color ??= \"danger\"\n visible ??= true\n placement ??= \"right-top\"\n disableTransition ??= false\n disableSpace ??= false\n\n const _p: any = {}\n\n _p.content = content\n _p.color = color\n _p.placement = placement\n _p.visible = visible\n _p.disableTransition = disableTransition ?? false\n\n const p: any = useBreakpointProps(_p)\n\n content = p.content\n color = p.color\n placement = p.placement\n visible = p.visible\n disableTransition = p.disableTransition\n\n const isReactElement = React.isValidElement(content);\n\n let template: any = useColorTemplate(color, \"fill\")\n let _css: any = {\n position: \"absolute\",\n }\n\n let translate = ''\n\n switch (placement) {\n case \"right-top\":\n _css.top = 0;\n _css.right = 0;\n if (!disableSpace) {\n translate = \"translate(50%, -50%)\";\n }\n break;\n case \"right-bottom\":\n _css.bottom = 0;\n _css.right = 0;\n if (!disableSpace) {\n translate = \"translate(50%, 50%)\";\n }\n break;\n case \"left-top\":\n _css.top = 0;\n _css.left = 0;\n if (!disableSpace) {\n translate = \"translate(-50%, -50%)\";\n }\n break;\n case \"left-bottom\":\n _css.bottom = 0;\n _css.left = 0;\n if (!disableSpace) {\n translate = \"translate(-50%, 50%)\";\n }\n break;\n }\n\n if (disableTransition) {\n _css.transform = translate\n }\n\n if (!isReactElement) {\n _css.userSelect = \"none\"\n _css.pointerEvents = \"none\"\n _css.fontSize = \"small\"\n _css.lineHeight = 1\n _css.fontWeight = 500\n _css.radius = 2\n\n if (typeof content === 'number') {\n if (content > 99) {\n content = \"99+\"\n }\n }\n\n if (content !== undefined) {\n _css.minWidth = 16\n _css.height = 16\n _css.p = .8\n _css.px = .4\n } else {\n _css.width = 8\n _css.height = 8\n }\n } else {\n template = {}\n }\n\n const _badge = <Tag\n {...slotProps?.content}\n ref={refs?.content}\n component='span'\n baseClass='badge-content'\n sxr={{\n position: \"absolute\",\n zIndex: 1,\n display: 'flex',\n justifyContent: \"center\",\n alignItems: 'center',\n ...template.primary,\n ..._css,\n }}\n >\n {content}\n </Tag>\n\n return (\n <Tag\n {...props}\n position=\"relative\"\n display=\"inline-block\"\n baseClass='badge'\n ref={ref}\n >\n {\n !disableTransition ? (<Transition\n open={content !== undefined && visible}\n {...slotProps?.transition}\n variant={() => {\n return {\n from: {\n opacity: 0,\n transform: `scale(0) ${translate}`.trim(),\n },\n to: {\n opacity: 1,\n transform: `scale(1) ${translate}`.trim(),\n },\n }\n }}\n ref={refs?.transition}\n >\n {_badge}\n </Transition>) : <>{_badge}</>\n }\n\n {children}\n </Tag>\n )\n})\n\nexport default Badge\n\n"],"names":[],"mappings":";;;;;;AAqBA;;AACI;;;;;;;AASA;AACA;AACA;AACA;;AAGA;AAEA;AACA;AACA;AACA;AACA;;;AAKA;AACI;;;;AAMA;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;;;AAQJ;;;AAIA;AACA;AACA;AACA;AACA;AACA;AAEA;AACI;;;;AAKJ;AACI;AACA;AACA;AACA;;;AAEA;AACA;;;;;;AAMR;;;AAgCwB;AACI;AACA;AACH;AACD;AACI;AACA;AACH;;;AAY7B;;"}
1
+ {"version":3,"file":"index.js","sources":["../../src/Badge/index.tsx"],"sourcesContent":["\"use client\"\nimport React, { ReactElement } from 'react';\nimport { Tag, TagProps, TagComponentType, Transition, useInterface, UseColorTemplateColor, useColorTemplate, useBreakpointPropsType, useBreakpointProps, TransitionProps } from '@xanui/core';\n\nexport type BadgeProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, \"baseClass\" | \"content\"> & {\n content?: useBreakpointPropsType<number | string | ReactElement>;\n color?: useBreakpointPropsType<UseColorTemplateColor>;\n placement?: useBreakpointPropsType<\"left-top\" | \"left-bottom\" | \"right-top\" | \"right-bottom\">;\n visible?: useBreakpointPropsType<boolean>;\n disableTransition?: boolean;\n disableSpace?: boolean;\n slotProps?: {\n transition?: Omit<TransitionProps, \"open\">;\n content?: Omit<TagProps<\"span\">, \"children\">;\n },\n refs?: {\n content?: React.Ref<any>;\n transition?: React.Ref<any>;\n };\n}\n\nconst Badge = React.forwardRef(<T extends TagComponentType = \"div\">({ children, content, refs, ...rest }: BadgeProps<T>, ref: React.Ref<any>) => {\n let [{ color, placement, visible, slotProps, disableTransition, disableSpace, ...props }] = useInterface<any>(\"Badge\", rest, {})\n color ??= \"danger\"\n visible ??= true\n placement ??= \"right-top\"\n disableTransition ??= false\n disableSpace ??= false\n\n const _p: any = {}\n\n _p.content = content\n _p.color = color\n _p.placement = placement\n _p.visible = visible\n _p.disableTransition = disableTransition ?? false\n\n const p: any = useBreakpointProps(_p)\n\n content = p.content\n color = p.color\n placement = p.placement\n visible = p.visible\n disableTransition = p.disableTransition\n\n const isReactElement = React.isValidElement(content);\n\n let template: any = useColorTemplate(color, \"fill\")\n let _css: any = {\n position: \"absolute\",\n }\n\n let translate = ''\n\n switch (placement) {\n case \"right-top\":\n _css.top = 0;\n _css.right = 0;\n if (!disableSpace) {\n translate = \"translate(50%, -50%)\";\n }\n break;\n case \"right-bottom\":\n _css.bottom = 0;\n _css.right = 0;\n if (!disableSpace) {\n translate = \"translate(50%, 50%)\";\n }\n break;\n case \"left-top\":\n _css.top = 0;\n _css.left = 0;\n if (!disableSpace) {\n translate = \"translate(-50%, -50%)\";\n }\n break;\n case \"left-bottom\":\n _css.bottom = 0;\n _css.left = 0;\n if (!disableSpace) {\n translate = \"translate(-50%, 50%)\";\n }\n break;\n }\n\n if (disableTransition) {\n _css.transform = translate\n }\n\n if (!isReactElement) {\n _css.userSelect = \"none\"\n _css.pointerEvents = \"none\"\n _css.fontSize = \"small\"\n _css.lineHeight = 1\n _css.fontWeight = 500\n _css.radius = 2\n\n if (typeof content === 'number') {\n if (content > 99) {\n content = \"99+\"\n }\n }\n\n if (content !== undefined) {\n _css.minWidth = 16\n _css.height = 16\n _css.p = .8\n _css.px = .4\n } else {\n _css.width = 8\n _css.height = 8\n }\n } else {\n template = {}\n }\n\n const _badge = <Tag\n {...slotProps?.content}\n ref={refs?.content}\n component='span'\n baseClass='badge-content'\n sxr={{\n position: \"absolute\",\n zIndex: 1,\n display: 'flex',\n justifyContent: \"center\",\n alignItems: 'center',\n ...template.main,\n ..._css,\n }}\n >\n {content}\n </Tag>\n\n return (\n <Tag\n {...props}\n position=\"relative\"\n display=\"inline-block\"\n baseClass='badge'\n ref={ref}\n >\n {\n !disableTransition ? (<Transition\n open={content !== undefined && visible}\n {...slotProps?.transition}\n variant={() => {\n return {\n from: {\n opacity: 0,\n transform: `scale(0) ${translate}`.trim(),\n },\n to: {\n opacity: 1,\n transform: `scale(1) ${translate}`.trim(),\n },\n }\n }}\n ref={refs?.transition}\n >\n {_badge}\n </Transition>) : <>{_badge}</>\n }\n\n {children}\n </Tag>\n )\n})\n\nexport default Badge\n\n"],"names":[],"mappings":";;;;;;AAqBA;;AACI;;;;;;;AASA;AACA;AACA;AACA;;AAGA;AAEA;AACA;AACA;AACA;AACA;;;AAKA;AACI;;;;AAMA;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;AAKJ;AACI;AACA;;;;;;;AAQJ;;;AAIA;AACA;AACA;AACA;AACA;AACA;AAEA;AACI;;;;AAKJ;AACI;AACA;AACA;AACA;;;AAEA;AACA;;;;;;AAMR;;;AAgCwB;AACI;AACA;AACH;AACD;AACI;AACA;AACH;;;AAY7B;;"}