@xanui/ui 1.1.38 → 1.1.41

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 (157) hide show
  1. package/Accordion/index.cjs +96 -0
  2. package/Accordion/index.cjs.map +1 -0
  3. package/Accordion/index.js.map +1 -1
  4. package/Alert/index.cjs +121 -0
  5. package/Alert/index.cjs.map +1 -0
  6. package/Autocomplete/index.cjs +136 -0
  7. package/Autocomplete/index.cjs.map +1 -0
  8. package/Avatar/index.cjs +50 -0
  9. package/Avatar/index.cjs.map +1 -0
  10. package/Badge/index.cjs +109 -0
  11. package/Badge/index.cjs.map +1 -0
  12. package/Box/index.cjs +14 -0
  13. package/Box/index.cjs.map +1 -0
  14. package/Button/index.cjs +94 -0
  15. package/Button/index.cjs.map +1 -0
  16. package/ButtonGroup/index.cjs +58 -0
  17. package/ButtonGroup/index.cjs.map +1 -0
  18. package/Calendar/index.cjs +174 -0
  19. package/Calendar/index.cjs.map +1 -0
  20. package/CalendarInput/index.cjs +34 -0
  21. package/CalendarInput/index.cjs.map +1 -0
  22. package/Checkbox/index.cjs +58 -0
  23. package/Checkbox/index.cjs.map +1 -0
  24. package/Chip/index.cjs +76 -0
  25. package/Chip/index.cjs.map +1 -0
  26. package/CircleProgress/index.cjs +129 -0
  27. package/CircleProgress/index.cjs.map +1 -0
  28. package/ClickOutside/index.cjs +37 -0
  29. package/ClickOutside/index.cjs.map +1 -0
  30. package/Collaps/index.cjs +26 -0
  31. package/Collaps/index.cjs.map +1 -0
  32. package/Container/index.cjs +29 -0
  33. package/Container/index.cjs.map +1 -0
  34. package/DataFilter/index.cjs +78 -0
  35. package/DataFilter/index.cjs.map +1 -0
  36. package/DataFilter/options/DateFilter.cjs +32 -0
  37. package/DataFilter/options/DateFilter.cjs.map +1 -0
  38. package/DataFilter/options/DateRangeFilter.cjs +27 -0
  39. package/DataFilter/options/DateRangeFilter.cjs.map +1 -0
  40. package/DataFilter/options/MultiSelectFilter.cjs +38 -0
  41. package/DataFilter/options/MultiSelectFilter.cjs.map +1 -0
  42. package/DataFilter/options/NumberFilter.cjs +24 -0
  43. package/DataFilter/options/NumberFilter.cjs.map +1 -0
  44. package/DataFilter/options/NumberRangeFilter.cjs +29 -0
  45. package/DataFilter/options/NumberRangeFilter.cjs.map +1 -0
  46. package/DataFilter/options/SelectFilter.cjs +34 -0
  47. package/DataFilter/options/SelectFilter.cjs.map +1 -0
  48. package/DataFilter/options/TextFilter.cjs +24 -0
  49. package/DataFilter/options/TextFilter.cjs.map +1 -0
  50. package/Datatable/FilterBox.cjs +39 -0
  51. package/Datatable/FilterBox.cjs.map +1 -0
  52. package/Datatable/Row.cjs +59 -0
  53. package/Datatable/Row.cjs.map +1 -0
  54. package/Datatable/SelectedBox.cjs +21 -0
  55. package/Datatable/SelectedBox.cjs.map +1 -0
  56. package/Datatable/Table.cjs +23 -0
  57. package/Datatable/Table.cjs.map +1 -0
  58. package/Datatable/TableHead.cjs +61 -0
  59. package/Datatable/TableHead.cjs.map +1 -0
  60. package/Datatable/index.cjs +93 -0
  61. package/Datatable/index.cjs.map +1 -0
  62. package/Divider/index.cjs +31 -0
  63. package/Divider/index.cjs.map +1 -0
  64. package/Drawer/index.cjs +78 -0
  65. package/Drawer/index.cjs.map +1 -0
  66. package/Form/index.cjs +45 -0
  67. package/Form/index.cjs.map +1 -0
  68. package/GridContainer/index.cjs +19 -0
  69. package/GridContainer/index.cjs.map +1 -0
  70. package/GridItem/index.cjs +20 -0
  71. package/GridItem/index.cjs.map +1 -0
  72. package/IconButton/index.cjs +64 -0
  73. package/IconButton/index.cjs.map +1 -0
  74. package/Image/index.cjs +27 -0
  75. package/Image/index.cjs.map +1 -0
  76. package/Input/index.cjs +144 -0
  77. package/Input/index.cjs.map +1 -0
  78. package/InputNumber/index.cjs +32 -0
  79. package/InputNumber/index.cjs.map +1 -0
  80. package/Label/index.cjs +24 -0
  81. package/Label/index.cjs.map +1 -0
  82. package/Layer/index.cjs +62 -0
  83. package/Layer/index.cjs.map +1 -0
  84. package/LineProgress/index.cjs +59 -0
  85. package/LineProgress/index.cjs.map +1 -0
  86. package/List/ListContext.cjs +11 -0
  87. package/List/ListContext.cjs.map +1 -0
  88. package/List/index.cjs +63 -0
  89. package/List/index.cjs.map +1 -0
  90. package/ListItem/index.cjs +54 -0
  91. package/ListItem/index.cjs.map +1 -0
  92. package/LoadingBox/index.cjs +32 -0
  93. package/LoadingBox/index.cjs.map +1 -0
  94. package/Menu/index.cjs +150 -0
  95. package/Menu/index.cjs.map +1 -0
  96. package/Modal/index.cjs +59 -0
  97. package/Modal/index.cjs.map +1 -0
  98. package/NoSSR/index.cjs +15 -0
  99. package/NoSSR/index.cjs.map +1 -0
  100. package/Option/index.cjs +14 -0
  101. package/Option/index.cjs.map +1 -0
  102. package/Paper/index.cjs +15 -0
  103. package/Paper/index.cjs.map +1 -0
  104. package/Portal/index.cjs +27 -0
  105. package/Portal/index.cjs.map +1 -0
  106. package/Radio/index.cjs +16 -0
  107. package/Radio/index.cjs.map +1 -0
  108. package/Scrollbar/index.cjs +59 -0
  109. package/Scrollbar/index.cjs.map +1 -0
  110. package/Select/index.cjs +59 -0
  111. package/Select/index.cjs.map +1 -0
  112. package/Skeleton/index.cjs +60 -0
  113. package/Skeleton/index.cjs.map +1 -0
  114. package/Stack/index.cjs +17 -0
  115. package/Stack/index.cjs.map +1 -0
  116. package/Switch/index.cjs +79 -0
  117. package/Switch/index.cjs.map +1 -0
  118. package/Tab/index.cjs +17 -0
  119. package/Tab/index.cjs.map +1 -0
  120. package/Table/index.cjs +88 -0
  121. package/Table/index.cjs.map +1 -0
  122. package/TableBody/index.cjs +14 -0
  123. package/TableBody/index.cjs.map +1 -0
  124. package/TableCell/index.cjs +14 -0
  125. package/TableCell/index.cjs.map +1 -0
  126. package/TableFooter/index.cjs +14 -0
  127. package/TableFooter/index.cjs.map +1 -0
  128. package/TableHead/index.cjs +14 -0
  129. package/TableHead/index.cjs.map +1 -0
  130. package/TablePagination/index.cjs +59 -0
  131. package/TablePagination/index.cjs.map +1 -0
  132. package/TableRow/index.cjs +14 -0
  133. package/TableRow/index.cjs.map +1 -0
  134. package/Tabs/index.cjs +201 -0
  135. package/Tabs/index.cjs.map +1 -0
  136. package/Text/index.cjs +25 -0
  137. package/Text/index.cjs.map +1 -0
  138. package/Toast/index.cjs +120 -0
  139. package/Toast/index.cjs.map +1 -0
  140. package/Tooltip/index.cjs +40 -0
  141. package/Tooltip/index.cjs.map +1 -0
  142. package/ViewBox/index.cjs +32 -0
  143. package/ViewBox/index.cjs.map +1 -0
  144. package/index.cjs +134 -0
  145. package/index.cjs.map +1 -0
  146. package/package.json +3 -3
  147. package/readme.md +4 -4
  148. package/useAlert/index.cjs +94 -0
  149. package/useAlert/index.cjs.map +1 -0
  150. package/useBlurCss/index.cjs +19 -0
  151. package/useBlurCss/index.cjs.map +1 -0
  152. package/useCorner/index.cjs +22 -0
  153. package/useCorner/index.cjs.map +1 -0
  154. package/useLayer/index.cjs +38 -0
  155. package/useLayer/index.cjs.map +1 -0
  156. package/useModal/index.cjs +37 -0
  157. package/useModal/index.cjs.map +1 -0
@@ -0,0 +1,96 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var tslib = require('tslib');
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var core = require('@xanui/core');
8
+ var ExpandIcon = require('@xanui/icons/ExpandMore');
9
+ var index$2 = require('../Collaps/index.cjs');
10
+ var index = require('../List/index.cjs');
11
+ var index$1 = require('../ListItem/index.cjs');
12
+
13
+ const Accordion = React.forwardRef((_a, ref) => {
14
+ var { children, title, subtitle } = _a, rest = tslib.__rest(_a, ["children", "title", "subtitle"]);
15
+ const [_expand, setExpand] = React.useState(false);
16
+ let [_b] = core.useInterface("Accordion", rest, {
17
+ onClick: () => setExpand(!_expand),
18
+ color: "brand",
19
+ variant: "soft"
20
+ }), { expand, onClick, color, variant, hoverColor, hoverVariant, expandIcon, expandIconPlacement, startIcon, endIcon, expandAction, classNames, slotProps } = _b, rootProps = tslib.__rest(_b, ["expand", "onClick", "color", "variant", "hoverColor", "hoverVariant", "expandIcon", "expandIconPlacement", "startIcon", "endIcon", "expandAction", "classNames", "slotProps"]);
21
+ const _p = {};
22
+ if (title)
23
+ _p.title = title;
24
+ if (subtitle)
25
+ _p.subtitle = subtitle;
26
+ if (startIcon)
27
+ _p.startIcon = startIcon;
28
+ if (endIcon)
29
+ _p.endIcon = endIcon;
30
+ if (expandIcon)
31
+ _p.expandIcon = expandIcon;
32
+ if (expandIconPlacement)
33
+ _p.expandIconPlacement = expandIconPlacement;
34
+ if (expandAction)
35
+ _p.expandAction = expandAction;
36
+ if (color)
37
+ _p.color = color;
38
+ if (variant)
39
+ _p.variant = variant;
40
+ if (hoverColor)
41
+ _p.hoverColor = hoverColor;
42
+ if (hoverVariant)
43
+ _p.hoverVariant = hoverVariant;
44
+ const p = core.useBreakpointProps(_p);
45
+ title = p.title;
46
+ subtitle = p.subtitle;
47
+ startIcon = p.startIcon;
48
+ endIcon = p.endIcon;
49
+ expandIcon = p.expandIcon;
50
+ expandIconPlacement = p.expandIconPlacement;
51
+ expandAction = p.expandAction;
52
+ color = p.color;
53
+ variant = p.variant;
54
+ hoverColor = p.hoverColor;
55
+ hoverVariant = p.hoverVariant;
56
+ expand = expand === undefined ? _expand : expand;
57
+ expandIcon = expandIcon ? jsxRuntime.jsx(core.Tag, Object.assign({ cursor: "pointer" }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.expandIconContainer, { onClick: expandAction === 'icon' && onClick ? () => onClick() : () => { }, className: 'expand-icon-container', children: expandIcon })) : jsxRuntime.jsx(core.Tag, Object.assign({ transform: `rotate(${expand ? 0 : -180}deg)`, transition: "transform .4s", cursor: "pointer" }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.expandIconContainer, { onClick: expandAction === 'icon' && onClick ? () => onClick() : () => { }, className: 'expand-icon-container', children: jsxRuntime.jsx(ExpandIcon, {}) }));
58
+ let itemsx = {};
59
+ if (expandIconPlacement === 'start') {
60
+ itemsx = {
61
+ startIcon: jsxRuntime.jsxs(core.Tag, { className: 'start-icon-container', sxr: {
62
+ display: "flex",
63
+ flexDirection: "row",
64
+ alignItems: "center",
65
+ gap: 1
66
+ }, children: [expandIcon, startIcon] }),
67
+ endIcon
68
+ };
69
+ }
70
+ else {
71
+ itemsx = {
72
+ endIcon: jsxRuntime.jsxs(core.Tag, { className: 'end-icon-container', sxr: {
73
+ display: "flex",
74
+ flexDirection: "row",
75
+ alignItems: "center",
76
+ gap: 1
77
+ }, children: [endIcon, expandIcon] }),
78
+ startIcon
79
+ };
80
+ }
81
+ if (expandAction === 'icon') {
82
+ itemsx.onClick = () => { };
83
+ itemsx.cursor = "initial!important";
84
+ }
85
+ return (jsxRuntime.jsx(core.Tag, Object.assign({}, rootProps, { sxr: {
86
+ bgcolor: "background.primary"
87
+ }, baseClass: 'accordion', classNames: [{ "accordion-expanded": expand }, ...(classNames || [])], ref: ref, children: jsxRuntime.jsxs(index, Object.assign({ component: 'div' }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.header, { color: color, variant: variant, hoverColor: hoverColor, hoverVariant: hoverVariant, className: 'accoutdion-header', children: [jsxRuntime.jsx(index$1, Object.assign({ minHeight: 55, radius: 0, component: 'div' }, slotProps === null || slotProps === void 0 ? void 0 : slotProps.headerContent, itemsx, { subtitle: subtitle, selected: expand, onClick: () => onClick && onClick(), className: "accordion-header-content", children: title })), jsxRuntime.jsx(index$2, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.collaps, { open: expand, className: "accordion-collaps", children: jsxRuntime.jsx(core.Tag, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.content, { sxr: {
88
+ color: "text.primary",
89
+ p: 2,
90
+ py: 1,
91
+ bgcolor: "background.primary"
92
+ }, baseClass: 'accordion-content', children: children })) }))] })) })));
93
+ });
94
+
95
+ module.exports = Accordion;
96
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Accordion/index.tsx"],"sourcesContent":["\"use client\";\r\nimport React, { ReactElement, useState } from 'react';\r\nimport { Tag, TagProps, useInterface, UseColorTemplateColor, UseColorTemplateType, TagComponentType, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\r\nimport ExpandIcon from \"@xanui/icons/ExpandMore\";\r\nimport Collaps from '../Collaps';\r\nimport List from '../List';\r\nimport ListItem from '../ListItem';\r\nimport type { CollapsProps } from '../Collaps';\r\nimport type { ListProps } from '../List';\r\nimport type { ListItemProps } from '../ListItem';\r\n\r\nexport type AccordionProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, \"color\"> & {\r\n expand?: boolean;\r\n onClick?: () => void;\r\n title: useBreakpointPropsType<ReactElement | string>;\r\n subtitle?: useBreakpointPropsType<ReactElement | string>;\r\n startIcon?: useBreakpointPropsType<ReactElement>;\r\n endIcon?: useBreakpointPropsType<ReactElement>;\r\n expandIcon?: useBreakpointPropsType<ReactElement>;\r\n expandIconPlacement?: useBreakpointPropsType<\"start\" | \"end\">;\r\n expandAction?: useBreakpointPropsType<\"header\" | \"icon\">;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n hoverColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n hoverVariant?: useBreakpointPropsType<UseColorTemplateType>;\r\n\r\n slotProps?: {\r\n header?: Omit<ListProps, \"children\" | \"color\" | \"variant\" | \"hoverColor\" | \"hoverVariant\" | \"className\">;\r\n headerContent?: Omit<ListItemProps, \"children\" | \"subtitle\" | \"selected\" | \"startIcon\" | \"endIcon\" | \"onClick\" | \"className\">\r\n collaps?: Omit<CollapsProps, \"children\" | \"in\">;\r\n content?: Omit<TagProps, \"children\">;\r\n expandIconContainer?: Omit<TagProps<\"div\">, 'children' | 'className'>;\r\n }\r\n}\r\n\r\nconst Accordion = React.forwardRef(<T extends TagComponentType = \"div\">({ children, title, subtitle, ...rest }: AccordionProps<T>, ref: React.Ref<any>) => {\r\n const [_expand, setExpand] = useState(false)\r\n let [{\r\n expand,\r\n onClick,\r\n color,\r\n variant,\r\n hoverColor,\r\n hoverVariant,\r\n expandIcon,\r\n expandIconPlacement,\r\n startIcon,\r\n endIcon,\r\n expandAction,\r\n classNames,\r\n slotProps,\r\n ...rootProps\r\n }] = useInterface<any>(\"Accordion\", rest, {\r\n onClick: () => setExpand(!_expand) as any,\r\n color: \"brand\",\r\n variant: \"soft\"\r\n })\r\n\r\n const _p: any = {}\r\n if (title) _p.title = title\r\n if (subtitle) _p.subtitle = subtitle\r\n if (startIcon) _p.startIcon = startIcon\r\n if (endIcon) _p.endIcon = endIcon\r\n if (expandIcon) _p.expandIcon = expandIcon\r\n if (expandIconPlacement) _p.expandIconPlacement = expandIconPlacement\r\n if (expandAction) _p.expandAction = expandAction\r\n if (color) _p.color = color\r\n if (variant) _p.variant = variant\r\n if (hoverColor) _p.hoverColor = hoverColor\r\n if (hoverVariant) _p.hoverVariant = hoverVariant\r\n\r\n const p: any = useBreakpointProps(_p)\r\n\r\n title = p.title\r\n subtitle = p.subtitle\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n expandIcon = p.expandIcon\r\n expandIconPlacement = p.expandIconPlacement\r\n expandAction = p.expandAction\r\n color = p.color\r\n variant = p.variant\r\n hoverColor = p.hoverColor\r\n hoverVariant = p.hoverVariant\r\n\r\n expand = expand === undefined ? _expand : expand\r\n expandIcon = expandIcon ? <Tag\r\n cursor=\"pointer\"\r\n {...slotProps?.expandIconContainer}\r\n onClick={expandAction === 'icon' && onClick ? () => onClick() : () => { }}\r\n className='expand-icon-container'\r\n >\r\n {expandIcon}\r\n </Tag> : <Tag\r\n transform={`rotate(${expand ? 0 : -180}deg)`}\r\n transition=\"transform .4s\"\r\n cursor=\"pointer\"\r\n {...slotProps?.expandIconContainer}\r\n onClick={expandAction === 'icon' && onClick ? () => onClick() : () => { }}\r\n className='expand-icon-container'\r\n >\r\n <ExpandIcon />\r\n </Tag>\r\n\r\n let itemsx: any = {}\r\n\r\n if (expandIconPlacement === 'start') {\r\n itemsx = {\r\n startIcon: <Tag\r\n className='start-icon-container'\r\n sxr={{\r\n display: \"flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n gap: 1\r\n }}\r\n >\r\n {expandIcon}\r\n {startIcon}\r\n </Tag>,\r\n endIcon\r\n }\r\n\r\n } else {\r\n itemsx = {\r\n endIcon: <Tag\r\n className='end-icon-container'\r\n sxr={{\r\n display: \"flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n gap: 1\r\n }}\r\n >\r\n {endIcon}\r\n {expandIcon}\r\n </Tag>,\r\n startIcon\r\n }\r\n }\r\n\r\n if (expandAction === 'icon') {\r\n itemsx.onClick = () => { }\r\n itemsx.cursor = \"initial!important\"\r\n }\r\n\r\n return (\r\n <Tag\r\n {...rootProps}\r\n sxr={{\r\n bgcolor: \"background.primary\"\r\n }}\r\n baseClass='accordion'\r\n classNames={[{ \"accordion-expanded\": expand }, ...(classNames || [])]}\r\n ref={ref}\r\n >\r\n <List\r\n component='div'\r\n {...slotProps?.header}\r\n color={color}\r\n variant={variant}\r\n hoverColor={hoverColor}\r\n hoverVariant={hoverVariant}\r\n className='accoutdion-header'\r\n >\r\n <ListItem\r\n minHeight={55}\r\n radius={0}\r\n component='div'\r\n {...slotProps?.headerContent}\r\n {...itemsx}\r\n subtitle={subtitle}\r\n selected={expand}\r\n onClick={() => onClick && onClick()}\r\n className=\"accordion-header-content\"\r\n >{title}</ListItem>\r\n <Collaps\r\n {...slotProps?.collaps}\r\n open={expand}\r\n className=\"accordion-collaps\"\r\n >\r\n <Tag\r\n {...slotProps?.content}\r\n sxr={{\r\n color: \"text.primary\",\r\n p: 2,\r\n py: 1,\r\n bgcolor: \"background.primary\"\r\n }}\r\n baseClass='accordion-content'\r\n >\r\n {children}\r\n </Tag>\r\n </Collaps>\r\n </List>\r\n </Tag>\r\n )\r\n})\r\nexport default Accordion\r\n\r\n\r\n"],"names":[],"mappings":";;;;;;;;;;;;AAmCA;;;AAEI;;AAiBI;AACA;AACH;;AAGD;AAAW;AACX;AAAc;AACd;AAAe;AACf;AAAa;AACb;AAAgB;AAChB;AAAyB;AACzB;AAAkB;AAClB;AAAW;AACX;AAAa;AACb;AAAgB;AAChB;AAAkB;AAElB;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAqBA;AACI;;AAIY;AACA;AACA;AACA;;;;;;AAUZ;;AAIY;AACA;AACA;AACA;;;;;AAUhB;AACI;AACA;;AAGJ;AAIY;AACH;AAiCe;AACA;AACA;AACA;;AAU5B;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/Accordion/index.tsx"],"sourcesContent":["\"use client\";\r\nimport React, { ReactElement, useState } from 'react';\r\nimport { Tag, TagProps, useInterface, UseColorTemplateColor, UseColorTemplateType, TagComponentType, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\r\nimport ExpandIcon from \"@xanui/icons/ExpandMore\";\r\nimport Collaps, { CollapsProps } from '../Collaps';\r\nimport List, { ListProps } from '../List';\r\nimport ListItem, { ListItemProps } from '../ListItem';\r\n\r\nexport type AccordionProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, \"color\"> & {\r\n expand?: boolean;\r\n onClick?: () => void;\r\n title: useBreakpointPropsType<ReactElement | string>;\r\n subtitle?: useBreakpointPropsType<ReactElement | string>;\r\n startIcon?: useBreakpointPropsType<ReactElement>;\r\n endIcon?: useBreakpointPropsType<ReactElement>;\r\n expandIcon?: useBreakpointPropsType<ReactElement>;\r\n expandIconPlacement?: useBreakpointPropsType<\"start\" | \"end\">;\r\n expandAction?: useBreakpointPropsType<\"header\" | \"icon\">;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n hoverColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n hoverVariant?: useBreakpointPropsType<UseColorTemplateType>;\r\n\r\n slotProps?: {\r\n header?: Omit<ListProps, \"children\" | \"color\" | \"variant\" | \"hoverColor\" | \"hoverVariant\" | \"className\">;\r\n headerContent?: Omit<ListItemProps, \"children\" | \"subtitle\" | \"selected\" | \"startIcon\" | \"endIcon\" | \"onClick\" | \"className\">\r\n collaps?: Omit<CollapsProps, \"children\" | \"in\">;\r\n content?: Omit<TagProps, \"children\">;\r\n expandIconContainer?: Omit<TagProps<\"div\">, 'children' | 'className'>;\r\n }\r\n}\r\n\r\nconst Accordion = React.forwardRef(<T extends TagComponentType = \"div\">({ children, title, subtitle, ...rest }: AccordionProps<T>, ref: React.Ref<any>) => {\r\n const [_expand, setExpand] = useState(false)\r\n let [{\r\n expand,\r\n onClick,\r\n color,\r\n variant,\r\n hoverColor,\r\n hoverVariant,\r\n expandIcon,\r\n expandIconPlacement,\r\n startIcon,\r\n endIcon,\r\n expandAction,\r\n classNames,\r\n slotProps,\r\n ...rootProps\r\n }] = useInterface<any>(\"Accordion\", rest, {\r\n onClick: () => setExpand(!_expand) as any,\r\n color: \"brand\",\r\n variant: \"soft\"\r\n })\r\n\r\n const _p: any = {}\r\n if (title) _p.title = title\r\n if (subtitle) _p.subtitle = subtitle\r\n if (startIcon) _p.startIcon = startIcon\r\n if (endIcon) _p.endIcon = endIcon\r\n if (expandIcon) _p.expandIcon = expandIcon\r\n if (expandIconPlacement) _p.expandIconPlacement = expandIconPlacement\r\n if (expandAction) _p.expandAction = expandAction\r\n if (color) _p.color = color\r\n if (variant) _p.variant = variant\r\n if (hoverColor) _p.hoverColor = hoverColor\r\n if (hoverVariant) _p.hoverVariant = hoverVariant\r\n\r\n const p: any = useBreakpointProps(_p)\r\n\r\n title = p.title\r\n subtitle = p.subtitle\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n expandIcon = p.expandIcon\r\n expandIconPlacement = p.expandIconPlacement\r\n expandAction = p.expandAction\r\n color = p.color\r\n variant = p.variant\r\n hoverColor = p.hoverColor\r\n hoverVariant = p.hoverVariant\r\n\r\n expand = expand === undefined ? _expand : expand\r\n expandIcon = expandIcon ? <Tag\r\n cursor=\"pointer\"\r\n {...slotProps?.expandIconContainer}\r\n onClick={expandAction === 'icon' && onClick ? () => onClick() : () => { }}\r\n className='expand-icon-container'\r\n >\r\n {expandIcon}\r\n </Tag> : <Tag\r\n transform={`rotate(${expand ? 0 : -180}deg)`}\r\n transition=\"transform .4s\"\r\n cursor=\"pointer\"\r\n {...slotProps?.expandIconContainer}\r\n onClick={expandAction === 'icon' && onClick ? () => onClick() : () => { }}\r\n className='expand-icon-container'\r\n >\r\n <ExpandIcon />\r\n </Tag>\r\n\r\n let itemsx: any = {}\r\n\r\n if (expandIconPlacement === 'start') {\r\n itemsx = {\r\n startIcon: <Tag\r\n className='start-icon-container'\r\n sxr={{\r\n display: \"flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n gap: 1\r\n }}\r\n >\r\n {expandIcon}\r\n {startIcon}\r\n </Tag>,\r\n endIcon\r\n }\r\n\r\n } else {\r\n itemsx = {\r\n endIcon: <Tag\r\n className='end-icon-container'\r\n sxr={{\r\n display: \"flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n gap: 1\r\n }}\r\n >\r\n {endIcon}\r\n {expandIcon}\r\n </Tag>,\r\n startIcon\r\n }\r\n }\r\n\r\n if (expandAction === 'icon') {\r\n itemsx.onClick = () => { }\r\n itemsx.cursor = \"initial!important\"\r\n }\r\n\r\n return (\r\n <Tag\r\n {...rootProps}\r\n sxr={{\r\n bgcolor: \"background.primary\"\r\n }}\r\n baseClass='accordion'\r\n classNames={[{ \"accordion-expanded\": expand }, ...(classNames || [])]}\r\n ref={ref}\r\n >\r\n <List\r\n component='div'\r\n {...slotProps?.header}\r\n color={color}\r\n variant={variant}\r\n hoverColor={hoverColor}\r\n hoverVariant={hoverVariant}\r\n className='accoutdion-header'\r\n >\r\n <ListItem\r\n minHeight={55}\r\n radius={0}\r\n component='div'\r\n {...slotProps?.headerContent}\r\n {...itemsx}\r\n subtitle={subtitle}\r\n selected={expand}\r\n onClick={() => onClick && onClick()}\r\n className=\"accordion-header-content\"\r\n >{title}</ListItem>\r\n <Collaps\r\n {...slotProps?.collaps}\r\n open={expand}\r\n className=\"accordion-collaps\"\r\n >\r\n <Tag\r\n {...slotProps?.content}\r\n sxr={{\r\n color: \"text.primary\",\r\n p: 2,\r\n py: 1,\r\n bgcolor: \"background.primary\"\r\n }}\r\n baseClass='accordion-content'\r\n >\r\n {children}\r\n </Tag>\r\n </Collaps>\r\n </List>\r\n </Tag>\r\n )\r\n})\r\nexport default Accordion\r\n\r\n\r\n"],"names":[],"mappings":";;;;;;;;;;AAgCA;;;AAEI;;AAiBI;AACA;AACH;;AAGD;AAAW;AACX;AAAc;AACd;AAAe;AACf;AAAa;AACb;AAAgB;AAChB;AAAyB;AACzB;AAAkB;AAClB;AAAW;AACX;AAAa;AACb;AAAgB;AAChB;AAAkB;AAElB;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAqBA;AACI;;AAIY;AACA;AACA;AACA;;;;;;AAUZ;;AAIY;AACA;AACA;AACA;;;;;AAUhB;AACI;AACA;;AAGJ;AAIY;AACH;AAiCe;AACA;AACA;AACA;;AAU5B;;"}
1
+ {"version":3,"file":"index.js","sources":["../../src/Accordion/index.tsx"],"sourcesContent":["\"use client\";\r\nimport React, { ReactElement, useState } from 'react';\r\nimport { Tag, TagProps, useInterface, UseColorTemplateColor, UseColorTemplateType, TagComponentType, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\r\nimport ExpandIcon from \"@xanui/icons/ExpandMore\";\r\nimport Collaps from '../Collaps';\r\nimport List from '../List';\r\nimport ListItem from '../ListItem';\r\nimport type { CollapsProps } from '../Collaps';\r\nimport type { ListProps } from '../List';\r\nimport type { ListItemProps } from '../ListItem';\r\n\r\nexport type AccordionProps<T extends TagComponentType = \"div\"> = Omit<TagProps<T>, \"color\"> & {\r\n expand?: boolean;\r\n onClick?: () => void;\r\n title: useBreakpointPropsType<ReactElement | string>;\r\n subtitle?: useBreakpointPropsType<ReactElement | string>;\r\n startIcon?: useBreakpointPropsType<ReactElement>;\r\n endIcon?: useBreakpointPropsType<ReactElement>;\r\n expandIcon?: useBreakpointPropsType<ReactElement>;\r\n expandIconPlacement?: useBreakpointPropsType<\"start\" | \"end\">;\r\n expandAction?: useBreakpointPropsType<\"header\" | \"icon\">;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n hoverColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n hoverVariant?: useBreakpointPropsType<UseColorTemplateType>;\r\n\r\n slotProps?: {\r\n header?: Omit<ListProps, \"children\" | \"color\" | \"variant\" | \"hoverColor\" | \"hoverVariant\" | \"className\">;\r\n headerContent?: Omit<ListItemProps, \"children\" | \"subtitle\" | \"selected\" | \"startIcon\" | \"endIcon\" | \"onClick\" | \"className\">\r\n collaps?: Omit<CollapsProps, \"children\" | \"in\">;\r\n content?: Omit<TagProps, \"children\">;\r\n expandIconContainer?: Omit<TagProps<\"div\">, 'children' | 'className'>;\r\n }\r\n}\r\n\r\nconst Accordion = React.forwardRef(<T extends TagComponentType = \"div\">({ children, title, subtitle, ...rest }: AccordionProps<T>, ref: React.Ref<any>) => {\r\n const [_expand, setExpand] = useState(false)\r\n let [{\r\n expand,\r\n onClick,\r\n color,\r\n variant,\r\n hoverColor,\r\n hoverVariant,\r\n expandIcon,\r\n expandIconPlacement,\r\n startIcon,\r\n endIcon,\r\n expandAction,\r\n classNames,\r\n slotProps,\r\n ...rootProps\r\n }] = useInterface<any>(\"Accordion\", rest, {\r\n onClick: () => setExpand(!_expand) as any,\r\n color: \"brand\",\r\n variant: \"soft\"\r\n })\r\n\r\n const _p: any = {}\r\n if (title) _p.title = title\r\n if (subtitle) _p.subtitle = subtitle\r\n if (startIcon) _p.startIcon = startIcon\r\n if (endIcon) _p.endIcon = endIcon\r\n if (expandIcon) _p.expandIcon = expandIcon\r\n if (expandIconPlacement) _p.expandIconPlacement = expandIconPlacement\r\n if (expandAction) _p.expandAction = expandAction\r\n if (color) _p.color = color\r\n if (variant) _p.variant = variant\r\n if (hoverColor) _p.hoverColor = hoverColor\r\n if (hoverVariant) _p.hoverVariant = hoverVariant\r\n\r\n const p: any = useBreakpointProps(_p)\r\n\r\n title = p.title\r\n subtitle = p.subtitle\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n expandIcon = p.expandIcon\r\n expandIconPlacement = p.expandIconPlacement\r\n expandAction = p.expandAction\r\n color = p.color\r\n variant = p.variant\r\n hoverColor = p.hoverColor\r\n hoverVariant = p.hoverVariant\r\n\r\n expand = expand === undefined ? _expand : expand\r\n expandIcon = expandIcon ? <Tag\r\n cursor=\"pointer\"\r\n {...slotProps?.expandIconContainer}\r\n onClick={expandAction === 'icon' && onClick ? () => onClick() : () => { }}\r\n className='expand-icon-container'\r\n >\r\n {expandIcon}\r\n </Tag> : <Tag\r\n transform={`rotate(${expand ? 0 : -180}deg)`}\r\n transition=\"transform .4s\"\r\n cursor=\"pointer\"\r\n {...slotProps?.expandIconContainer}\r\n onClick={expandAction === 'icon' && onClick ? () => onClick() : () => { }}\r\n className='expand-icon-container'\r\n >\r\n <ExpandIcon />\r\n </Tag>\r\n\r\n let itemsx: any = {}\r\n\r\n if (expandIconPlacement === 'start') {\r\n itemsx = {\r\n startIcon: <Tag\r\n className='start-icon-container'\r\n sxr={{\r\n display: \"flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n gap: 1\r\n }}\r\n >\r\n {expandIcon}\r\n {startIcon}\r\n </Tag>,\r\n endIcon\r\n }\r\n\r\n } else {\r\n itemsx = {\r\n endIcon: <Tag\r\n className='end-icon-container'\r\n sxr={{\r\n display: \"flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n gap: 1\r\n }}\r\n >\r\n {endIcon}\r\n {expandIcon}\r\n </Tag>,\r\n startIcon\r\n }\r\n }\r\n\r\n if (expandAction === 'icon') {\r\n itemsx.onClick = () => { }\r\n itemsx.cursor = \"initial!important\"\r\n }\r\n\r\n return (\r\n <Tag\r\n {...rootProps}\r\n sxr={{\r\n bgcolor: \"background.primary\"\r\n }}\r\n baseClass='accordion'\r\n classNames={[{ \"accordion-expanded\": expand }, ...(classNames || [])]}\r\n ref={ref}\r\n >\r\n <List\r\n component='div'\r\n {...slotProps?.header}\r\n color={color}\r\n variant={variant}\r\n hoverColor={hoverColor}\r\n hoverVariant={hoverVariant}\r\n className='accoutdion-header'\r\n >\r\n <ListItem\r\n minHeight={55}\r\n radius={0}\r\n component='div'\r\n {...slotProps?.headerContent}\r\n {...itemsx}\r\n subtitle={subtitle}\r\n selected={expand}\r\n onClick={() => onClick && onClick()}\r\n className=\"accordion-header-content\"\r\n >{title}</ListItem>\r\n <Collaps\r\n {...slotProps?.collaps}\r\n open={expand}\r\n className=\"accordion-collaps\"\r\n >\r\n <Tag\r\n {...slotProps?.content}\r\n sxr={{\r\n color: \"text.primary\",\r\n p: 2,\r\n py: 1,\r\n bgcolor: \"background.primary\"\r\n }}\r\n baseClass='accordion-content'\r\n >\r\n {children}\r\n </Tag>\r\n </Collaps>\r\n </List>\r\n </Tag>\r\n )\r\n})\r\nexport default Accordion\r\n\r\n\r\n"],"names":[],"mappings":";;;;;;;;;;AAmCA;;;AAEI;;AAiBI;AACA;AACH;;AAGD;AAAW;AACX;AAAc;AACd;AAAe;AACf;AAAa;AACb;AAAgB;AAChB;AAAyB;AACzB;AAAkB;AAClB;AAAW;AACX;AAAa;AACb;AAAgB;AAChB;AAAkB;AAElB;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAqBA;AACI;;AAIY;AACA;AACA;AACA;;;;;;AAUZ;;AAIY;AACA;AACA;AACA;;;;;AAUhB;AACI;AACA;;AAGJ;AAIY;AACH;AAiCe;AACA;AACA;AACA;;AAU5B;;"}
@@ -0,0 +1,121 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var tslib = require('tslib');
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var core = require('@xanui/core');
7
+ var React = require('react');
8
+ var index$1 = require('../Text/index.cjs');
9
+ var InfoIcon = require('@xanui/icons/Info');
10
+ var WarningIcon = require('@xanui/icons/Warning');
11
+ var SuccessIcon = require('@xanui/icons/CheckCircle');
12
+ var ErrorIcon = require('@xanui/icons/Cancel');
13
+ var Close = require('@xanui/icons/Close');
14
+ var index = require('../IconButton/index.cjs');
15
+ var index$2 = require('../useAlert/index.cjs');
16
+
17
+ const Alert = (_a) => {
18
+ var { children } = _a, rest = tslib.__rest(_a, ["children"]);
19
+ let [_b] = core.useInterface("Alert", rest, {
20
+ variant: "fill"
21
+ }), { title, variant, icon, color, direction, slotProps, onClose } = _b, _props = tslib.__rest(_b, ["title", "variant", "icon", "color", "direction", "slotProps", "onClose"]);
22
+ color !== null && color !== void 0 ? color : (color = "default");
23
+ direction !== null && direction !== void 0 ? direction : (direction = "row");
24
+ const _p = {};
25
+ if (title)
26
+ _p.title = title;
27
+ if (variant)
28
+ _p.variant = variant;
29
+ if (icon)
30
+ _p.icon = icon;
31
+ if (color)
32
+ _p.color = color;
33
+ if (direction)
34
+ _p.direction = direction;
35
+ const p = core.useBreakpointProps(_p);
36
+ title = p.title;
37
+ variant = p.variant;
38
+ icon = p.icon;
39
+ color = p.color;
40
+ direction = p.direction;
41
+ let isRow = direction === 'row';
42
+ const template = core.useColorTemplate(color, variant);
43
+ let iconsx = {
44
+ fontSize: isRow ? 22 : 40,
45
+ color: color === 'default' ? "text.primary" : template.primary.color
46
+ };
47
+ const icons = {
48
+ "info": jsxRuntime.jsx(InfoIcon, { sx: iconsx }),
49
+ "warning": jsxRuntime.jsx(WarningIcon, { sx: iconsx }),
50
+ "success": jsxRuntime.jsx(SuccessIcon, { sx: iconsx }),
51
+ "danger": jsxRuntime.jsx(ErrorIcon, { sx: iconsx })
52
+ };
53
+ let _icon = icons[icon] || icons[color];
54
+ return (jsxRuntime.jsxs(core.Tag, Object.assign({}, _props, { baseClass: "alert", sxr: Object.assign({ justifyContent: "flex-start", position: "relative", radius: 1, px: isRow ? (_icon ? .5 : 2) : 3, py: isRow ? .5 : 3, flexDirection: "column", display: 'flex' }, _props === null || _props === void 0 ? void 0 : _props.sx) }, template.primary, { children: [onClose && jsxRuntime.jsx(index, { color: color, variant: variant === 'fill' ? "fill" : "text", size: 25, sx: {
55
+ position: "absolute",
56
+ top: 5,
57
+ right: 5
58
+ }, onClick: onClose, className: "alert-close-button", children: jsxRuntime.jsx(Close, { fontSize: 18 }) }), jsxRuntime.jsxs(core.Tag, { sx: {
59
+ display: "flex",
60
+ gap: 1,
61
+ flexDirection: direction,
62
+ alignItems: isRow ? "flex-start" : "center"
63
+ }, baseClass: "alert-container", children: [_icon && jsxRuntime.jsx(core.Tag, { baseClass: "alert-icon", sxr: {
64
+ display: "flex",
65
+ alignItems: "center",
66
+ justifyContent: "center",
67
+ p: isRow ? 1 : 0,
68
+ "& svg": {
69
+ color: template.primary.color
70
+ }
71
+ }, children: _icon }), jsxRuntime.jsxs(core.Tag, { baseClass: "alert-content", sxr: {
72
+ display: "flex",
73
+ flexDirection: "column",
74
+ flex: 1,
75
+ color: template.primary.color,
76
+ py: 1,
77
+ textAlign: isRow ? "left" : "center",
78
+ gap: isRow ? 0 : 1
79
+ }, children: [title && jsxRuntime.jsx(jsxRuntime.Fragment, { children: React.isValidElement(title) ? jsxRuntime.jsx(core.Tag, { className: "alert-title", children: title }) : jsxRuntime.jsx(index$1, { className: "alert-title", variant: "text", sx: {
80
+ font: "text",
81
+ fontWeight: "bold!important",
82
+ color: template.primary.color
83
+ }, children: title }) }), jsxRuntime.jsx(core.Tag, { sxr: {
84
+ font: "button",
85
+ }, children: children })] })] })] })));
86
+ };
87
+ const ActionAlert = (props) => {
88
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
89
+ const ref = React.useRef(null);
90
+ const alert = index$2(Object.assign(Object.assign({}, props), { slotProps: Object.assign(Object.assign({}, props.slotProps), { modal: Object.assign(Object.assign({}, (_a = props.slotProps) === null || _a === void 0 ? void 0 : _a.modal), { slotProps: Object.assign(Object.assign({}, (_c = (_b = props.slotProps) === null || _b === void 0 ? void 0 : _b.modal) === null || _c === void 0 ? void 0 : _c.slotProps), { layer: Object.assign(Object.assign({}, (_f = (_e = (_d = props.slotProps) === null || _d === void 0 ? void 0 : _d.modal) === null || _e === void 0 ? void 0 : _e.slotProps) === null || _f === void 0 ? void 0 : _f.layer), { portal: Object.assign(Object.assign({}, (_k = (_j = (_h = (_g = props.slotProps) === null || _g === void 0 ? void 0 : _g.modal) === null || _h === void 0 ? void 0 : _h.slotProps) === null || _j === void 0 ? void 0 : _j.layer) === null || _k === void 0 ? void 0 : _k.portal), { container: ref.current || undefined }) }) }) }) }) }));
91
+ React.useEffect(() => {
92
+ if (props.open) {
93
+ alert.open();
94
+ }
95
+ else {
96
+ alert.close();
97
+ }
98
+ }, [props.open]);
99
+ return jsxRuntime.jsx(core.Tag, { ref: ref });
100
+ };
101
+ Alert.confirm = (props) => {
102
+ var _a;
103
+ const a = core.Renderar.render(ActionAlert, Object.assign(Object.assign({ open: true }, props), { slotProps: Object.assign(Object.assign({}, props.slotProps), { modal: Object.assign(Object.assign({}, (_a = props.slotProps) === null || _a === void 0 ? void 0 : _a.modal), { onClosed: () => {
104
+ var _a, _b, _c, _d;
105
+ a.unrender();
106
+ if ((_b = (_a = props === null || props === void 0 ? void 0 : props.slotProps) === null || _a === void 0 ? void 0 : _a.modal) === null || _b === void 0 ? void 0 : _b.onClosed) {
107
+ (_d = (_c = props.slotProps) === null || _c === void 0 ? void 0 : _c.modal) === null || _d === void 0 ? void 0 : _d.onClosed();
108
+ }
109
+ } }) }) }));
110
+ return {
111
+ open: () => {
112
+ a.updateProps({ open: true });
113
+ },
114
+ close: () => {
115
+ a.updateProps({ open: false });
116
+ },
117
+ };
118
+ };
119
+
120
+ module.exports = Alert;
121
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Alert/index.tsx"],"sourcesContent":["\"use client\";\r\nimport { Tag, TagProps, useBreakpointProps, useColorTemplate, useInterface, useBreakpointPropsType, Renderar, UseColorTemplateType, UseColorTemplateColor } from \"@xanui/core\"\r\nimport React, { isValidElement, ReactElement, useEffect, useRef } from \"react\"\r\nimport Text from \"../Text\"\r\nimport InfoIcon from '@xanui/icons/Info';\r\nimport WarningIcon from '@xanui/icons/Warning';\r\nimport SuccessIcon from '@xanui/icons/CheckCircle';\r\nimport ErrorIcon from '@xanui/icons/Cancel';\r\nimport IconClose from '@xanui/icons/Close';\r\nimport IconButton from \"../IconButton\";\r\nimport useAlert, { UseAlerProps } from \"../useAlert\";\r\n\r\n\r\nexport type AlertProps = Omit<TagProps<\"div\">, \"content\" | \"title\" | \"direction\"> & {\r\n title?: useBreakpointPropsType<string | ReactElement>;\r\n direction?: useBreakpointPropsType<\"row\" | \"column\">;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n icon?: useBreakpointPropsType<\"info\" | \"warning\" | \"success\" | \"error\" | false | ReactElement>;\r\n onClose?: React.DOMAttributes<\"button\">['onClick'];\r\n}\r\n\r\nexport type AlertMesssageType = string | ReactElement | AlertProps\r\n\r\nconst Alert = ({ children, ...rest }: AlertProps) => {\r\n let [{\r\n title,\r\n variant,\r\n icon,\r\n color,\r\n direction,\r\n slotProps,\r\n onClose,\r\n ..._props\r\n }] = useInterface<any>(\"Alert\", rest, {\r\n variant: \"fill\"\r\n })\r\n color ??= \"default\"\r\n direction ??= \"row\"\r\n\r\n const _p: any = {}\r\n if (title) _p.title = title\r\n if (variant) _p.variant = variant\r\n if (icon) _p.icon = icon\r\n if (color) _p.color = color\r\n if (direction) _p.direction = direction\r\n\r\n const p: any = useBreakpointProps(_p)\r\n\r\n title = p.title\r\n variant = p.variant\r\n icon = p.icon\r\n color = p.color\r\n direction = p.direction\r\n\r\n let isRow = direction === 'row'\r\n\r\n\r\n const template = useColorTemplate(color, variant)\r\n\r\n let iconsx = {\r\n fontSize: isRow ? 22 : 40,\r\n color: color === 'default' ? \"text.primary\" : template.primary.color\r\n }\r\n\r\n const icons: any = {\r\n \"info\": <InfoIcon sx={iconsx} />,\r\n \"warning\": <WarningIcon sx={iconsx} />,\r\n \"success\": <SuccessIcon sx={iconsx} />,\r\n \"danger\": <ErrorIcon sx={iconsx} />\r\n }\r\n\r\n let _icon = icons[icon] || icons[color]\r\n\r\n return (\r\n <Tag\r\n {..._props}\r\n baseClass=\"alert\"\r\n sxr={{\r\n justifyContent: \"flex-start\",\r\n position: \"relative\",\r\n radius: 1,\r\n px: isRow ? (_icon ? .5 : 2) : 3,\r\n py: isRow ? .5 : 3,\r\n flexDirection: \"column\",\r\n display: 'flex',\r\n ..._props?.sx\r\n }}\r\n {...template.primary}\r\n >\r\n {\r\n onClose && <IconButton\r\n color={color}\r\n variant={variant === 'fill' ? \"fill\" : \"text\"}\r\n size={25}\r\n sx={{\r\n position: \"absolute\",\r\n top: 5,\r\n right: 5\r\n }}\r\n onClick={onClose}\r\n className=\"alert-close-button\"\r\n >\r\n <IconClose fontSize={18} />\r\n </IconButton>\r\n }\r\n <Tag\r\n sx={{\r\n display: \"flex\",\r\n gap: 1,\r\n flexDirection: direction,\r\n alignItems: isRow ? \"flex-start\" : \"center\"\r\n }}\r\n baseClass=\"alert-container\"\r\n >\r\n {\r\n _icon && <Tag\r\n baseClass=\"alert-icon\"\r\n sxr={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n p: isRow ? 1 : 0,\r\n \"& svg\": {\r\n color: template.primary.color\r\n }\r\n }}\r\n >\r\n {_icon}\r\n </Tag>\r\n }\r\n <Tag\r\n baseClass=\"alert-content\"\r\n sxr={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n flex: 1,\r\n color: template.primary.color,\r\n py: 1,\r\n textAlign: isRow ? \"left\" : \"center\",\r\n gap: isRow ? 0 : 1\r\n }}\r\n >\r\n {title && <>\r\n {\r\n isValidElement(title) ? <Tag className=\"alert-title\">{title}</Tag> : <Text\r\n className=\"alert-title\"\r\n variant=\"text\"\r\n sx={{\r\n font: \"text\",\r\n fontWeight: \"bold!important\",\r\n color: template.primary.color\r\n }}\r\n >{title}</Text>\r\n }\r\n </>}\r\n <Tag\r\n sxr={{\r\n font: \"button\",\r\n }}\r\n >\r\n {children}\r\n </Tag>\r\n </Tag>\r\n </Tag>\r\n </Tag>\r\n )\r\n}\r\n\r\nconst ActionAlert = (props: UseAlerProps) => {\r\n const ref = useRef<HTMLDivElement>(null);\r\n const alert = useAlert({\r\n ...props,\r\n slotProps: {\r\n ...props.slotProps,\r\n modal: {\r\n ...props.slotProps?.modal,\r\n slotProps: {\r\n ...props.slotProps?.modal?.slotProps,\r\n layer: {\r\n ...props.slotProps?.modal?.slotProps?.layer,\r\n portal: {\r\n ...props.slotProps?.modal?.slotProps?.layer?.portal,\r\n container: ref.current || undefined\r\n }\r\n }\r\n }\r\n }\r\n }\r\n })\r\n\r\n useEffect(() => {\r\n if (props.open) {\r\n alert.open()\r\n } else {\r\n alert.close()\r\n }\r\n }, [props.open])\r\n return <Tag ref={ref}></Tag>\r\n}\r\n\r\nAlert.confirm = (props: UseAlerProps) => {\r\n const a = Renderar.render(ActionAlert as any, {\r\n open: true,\r\n ...props,\r\n slotProps: {\r\n ...props.slotProps,\r\n modal: {\r\n ...props.slotProps?.modal,\r\n onClosed: () => {\r\n a.unrender()\r\n if (props?.slotProps?.modal?.onClosed) {\r\n props.slotProps?.modal?.onClosed()\r\n }\r\n },\r\n }\r\n },\r\n })\r\n\r\n return {\r\n open: () => {\r\n a.updateProps({ open: true })\r\n },\r\n close: () => {\r\n a.updateProps({ open: false })\r\n },\r\n }\r\n}\r\n\r\nexport default Alert"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAwBA;AAAe;AACX;AAUI;;;;;AAMJ;AAAW;AACX;AAAa;AACb;AAAU;AACV;AAAW;AACX;AAAe;AAEf;AAEA;AACA;AACA;AACA;AACA;AAEA;;AAKA;;AAEI;;AAGJ;AACI;AACA;AACA;AACA;;;;AA2BgB;AACA;AACA;;AAUJ;AACA;AACA;;AAEH;AAOW;AACA;AACA;;AAEA;AACI;AACH;;AASL;AACA;AACA;AACA;AACA;;;AAGH;AAQe;AACA;AACA;;AAOR;AACH;AAQzB;AAEA;;AACI;AACA;;AAqBI;;;;;;AAKJ;AACA;AACJ;AAEA;;AACI;;;AASgB;;;AAGJ;;;;;;;;;AAahB;;"}
@@ -0,0 +1,136 @@
1
+ 'use strict';
2
+
3
+ var tslib = require('tslib');
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var React = require('react');
6
+ var index$3 = require('../Input/index.cjs');
7
+ var index$4 = require('../Menu/index.cjs');
8
+ var index$5 = require('../List/index.cjs');
9
+ var index$6 = require('../ListItem/index.cjs');
10
+ var index = require('../Chip/index.cjs');
11
+ var index$1 = require('../IconButton/index.cjs');
12
+ var Close = require('@xanui/icons/Close');
13
+ var index$2 = require('../CircleProgress/index.cjs');
14
+
15
+ const Autocomplete = (_a) => {
16
+ var { value, onChange, renderOption, options, getLabel, multiple } = _a, inputProps = tslib.__rest(_a, ["value", "onChange", "renderOption", "options", "getLabel", "multiple"]);
17
+ const [_options, setOptions] = React.useState();
18
+ const [inputValue, setInputValue] = React.useState("");
19
+ const [timer, setTimer] = React.useState(null);
20
+ const [loading, setLoading] = React.useState(false);
21
+ const [open, setOpen] = React.useState(false);
22
+ const menuRef = React.useRef(null);
23
+ getLabel !== null && getLabel !== void 0 ? getLabel : (getLabel = (option) => option.toString());
24
+ multiple !== null && multiple !== void 0 ? multiple : (multiple = false);
25
+ let startIcons = [
26
+ inputProps.startIcon
27
+ ];
28
+ if (!!value && multiple && Array.isArray(value)) {
29
+ value.map((v, index$2) => {
30
+ startIcons.push(jsxRuntime.jsx(index, { size: "small", label: getLabel(v), variant: "fill", color: "default", endIcon: jsxRuntime.jsx(index$1, { size: 20, variant: "text", color: "default", onClick: (e) => {
31
+ e.stopPropagation();
32
+ let newValue = Array.isArray(value) ? [...value] : [];
33
+ newValue = newValue.filter((val) => getLabel(val) !== getLabel(v));
34
+ onChange && onChange(newValue);
35
+ }, children: jsxRuntime.jsx(Close, {}) }) }, index$2));
36
+ });
37
+ }
38
+ let endIcons = [
39
+ inputProps.endIcon
40
+ ];
41
+ if (loading) {
42
+ endIcons.push(jsxRuntime.jsx(index$2, { size: "small" }, "auto-complete-loading-icon"));
43
+ }
44
+ else if (!!value && !multiple) {
45
+ endIcons.push(jsxRuntime.jsx(index$1, { variant: "text", color: "default", onClick: (e) => {
46
+ e.stopPropagation();
47
+ onChange && onChange(undefined);
48
+ setInputValue("");
49
+ }, children: jsxRuntime.jsx(Close, {}) }, "auto-complete-clear-button"));
50
+ }
51
+ return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(index$3, Object.assign({}, inputProps, { ref: menuRef, slotProps: {
52
+ rootContainer: Object.assign({ flexWrap: 'wrap' }, (multiple ? { height: "auto", gap: .5 } : {})),
53
+ input: {
54
+ width: multiple ? 'auto' : '100%',
55
+ flex: 1,
56
+ minWidth: 20,
57
+ }
58
+ }, startIcon: startIcons, endIcon: endIcons, value: inputValue, onKeyDown: (e) => {
59
+ if (inputProps === null || inputProps === void 0 ? void 0 : inputProps.onKeyDown) {
60
+ inputProps.onKeyDown(e);
61
+ }
62
+ if (multiple && e.key === 'Backspace' && inputValue === "" && Array.isArray(value) && value.length > 0) {
63
+ let newValue = [...value];
64
+ newValue.pop();
65
+ onChange && onChange(newValue);
66
+ }
67
+ }, onChange: (e) => {
68
+ const value = e.target.value;
69
+ setInputValue(value);
70
+ if (!value) {
71
+ setOptions([]);
72
+ setOpen(false);
73
+ return;
74
+ }
75
+ setOpen(true);
76
+ clearTimeout(timer);
77
+ setTimer(setTimeout(async () => {
78
+ if (typeof options === 'function') {
79
+ setLoading(true);
80
+ const result = await options(value);
81
+ setOptions(result);
82
+ setLoading(false);
83
+ }
84
+ else {
85
+ const filtered = options.filter(option => getLabel(option).toLowerCase().includes(value.toLowerCase()));
86
+ setOptions(filtered);
87
+ }
88
+ }, 300));
89
+ } })), jsxRuntime.jsx(index$4, { target: open ? menuRef.current : null, onClickOutside: () => {
90
+ setOptions([]);
91
+ setInputValue("");
92
+ }, slotProps: {
93
+ content: { minWidth: menuRef.current ? menuRef.current.offsetWidth : 'auto' }
94
+ }, children: jsxRuntime.jsx(index$5, { maxHeight: 400, overflow: "auto", children: _options === null || _options === void 0 ? void 0 : _options.map((option, index) => (renderOption ? jsxRuntime.jsx("div", { children: renderOption(option, {
95
+ onClick: () => {
96
+ if (multiple) {
97
+ let newValue = Array.isArray(value) ? [...value] : [];
98
+ const has = newValue.find((v) => getLabel(v) === getLabel(option));
99
+ if (!has) {
100
+ newValue.push(option);
101
+ }
102
+ else {
103
+ newValue = newValue.filter((v) => getLabel(v) !== getLabel(option));
104
+ }
105
+ onChange && onChange(newValue);
106
+ }
107
+ else {
108
+ onChange && onChange(option);
109
+ setOpen(false);
110
+ setInputValue(getLabel(option));
111
+ setOptions([]);
112
+ }
113
+ }
114
+ }) }, "auto-complete" + index + getLabel(option)) : jsxRuntime.jsx(index$6, { onClick: () => {
115
+ if (multiple) {
116
+ let newValue = Array.isArray(value) ? [...value] : [];
117
+ const has = newValue.find((v) => getLabel(v) === getLabel(option));
118
+ if (!has) {
119
+ newValue.push(option);
120
+ }
121
+ else {
122
+ newValue = newValue.filter((v) => getLabel(v) !== getLabel(option));
123
+ }
124
+ onChange && onChange(newValue);
125
+ }
126
+ else {
127
+ onChange && onChange(option);
128
+ setOpen(false);
129
+ setInputValue(getLabel(option));
130
+ setOptions([]);
131
+ }
132
+ }, children: getLabel(option) }, index))) }) })] }));
133
+ };
134
+
135
+ module.exports = Autocomplete;
136
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Autocomplete/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react'\r\nimport Input from '../Input'\r\nimport Menu from '../Menu'\r\nimport List from '../List';\r\nimport ListItem, { ListItemProps } from '../ListItem';\r\nimport Chip from '../Chip';\r\nimport IconButton from '../IconButton';\r\nimport Close from '@xanui/icons/Close';\r\nimport CircleProgress from '../CircleProgress';\r\nimport { useBreakpointPropsType, UseColorTemplateColor } from '@xanui/core';\r\n\r\nexport type AutocompleteProps = {\r\n\r\n options: any[] | ((text: string) => Promise<any[]>)\r\n getLabel: (option: any) => string;\r\n onChange?: (value: any) => void;\r\n value?: any;\r\n multiple?: boolean;\r\n renderOption?: (option: any, props: any) => ReactElement<ListItemProps>\r\n\r\n // input props customization\r\n name?: string;\r\n placeholder?: string;\r\n readOnly?: boolean;\r\n autoFocus?: boolean;\r\n autoComplete?: string;\r\n label?: useBreakpointPropsType<string>;\r\n\r\n onFocus?: (e: React.FocusEvent<any>) => void;\r\n onBlur?: (e: React.FocusEvent<any>) => void;\r\n onInput?: (e: React.FormEvent<any>) => void;\r\n onKeyDown?: (e: React.KeyboardEvent<any>) => void;\r\n onKeyUp?: (e: React.KeyboardEvent<any>) => void;\r\n\r\n rows?: useBreakpointPropsType<number>;\r\n minRows?: useBreakpointPropsType<number>;\r\n maxRows?: useBreakpointPropsType<number>;\r\n fullWidth?: boolean;\r\n\r\n startIcon?: useBreakpointPropsType<ReactElement>;\r\n endIcon?: useBreakpointPropsType<ReactElement>;\r\n iconPlacement?: useBreakpointPropsType<\"start\" | \"center\" | \"end\">;\r\n focused?: boolean;\r\n color?: useBreakpointPropsType<Omit<UseColorTemplateColor, \"default\">>;\r\n variant?: useBreakpointPropsType<\"fill\" | \"outline\" | \"text\">;\r\n error?: boolean;\r\n helperText?: useBreakpointPropsType<string>;\r\n\r\n}\r\n\r\nconst Autocomplete = ({ value, onChange, renderOption, options, getLabel, multiple, ...inputProps }: AutocompleteProps) => {\r\n const [_options, setOptions] = React.useState<any[]>()\r\n const [inputValue, setInputValue] = React.useState(\"\")\r\n const [timer, setTimer] = React.useState<any>(null)\r\n const [loading, setLoading] = React.useState(false)\r\n const [open, setOpen] = React.useState(false)\r\n const menuRef = React.useRef<any>(null)\r\n\r\n getLabel ??= (option: any) => option.toString();\r\n multiple ??= false;\r\n\r\n let startIcons = [\r\n inputProps.startIcon\r\n ]\r\n\r\n if (!!value && multiple && Array.isArray(value)) {\r\n value.map((v: any, index: number) => {\r\n startIcons.push(<Chip\r\n key={index}\r\n size=\"small\"\r\n label={getLabel!(v)}\r\n variant={\"fill\"}\r\n color=\"default\"\r\n endIcon={<IconButton\r\n size={20}\r\n variant={\"text\"}\r\n color=\"default\"\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n let newValue = Array.isArray(value) ? [...value] : []\r\n newValue = newValue.filter((val: any) => getLabel!(val) !== getLabel!(v))\r\n onChange && onChange(newValue)\r\n }}\r\n >\r\n <Close />\r\n </IconButton>}\r\n />)\r\n })\r\n }\r\n\r\n let endIcons = [\r\n inputProps.endIcon\r\n ]\r\n\r\n if (loading) {\r\n endIcons.push(<CircleProgress\r\n key=\"auto-complete-loading-icon\"\r\n size=\"small\"\r\n />)\r\n } else if (!!value && !multiple) {\r\n endIcons.push(<IconButton\r\n key=\"auto-complete-clear-button\"\r\n variant={\"text\"}\r\n color=\"default\"\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n onChange && onChange(undefined)\r\n setInputValue(\"\")\r\n }}\r\n >\r\n <Close />\r\n </IconButton>)\r\n }\r\n\r\n\r\n return (\r\n <>\r\n <Input\r\n {...inputProps as any}\r\n ref={menuRef}\r\n slotProps={{\r\n rootContainer: {\r\n flexWrap: 'wrap',\r\n ...(multiple ? { height: \"auto\", gap: .5 } : {})\r\n },\r\n input: {\r\n width: multiple ? 'auto' : '100%',\r\n flex: 1,\r\n minWidth: 20,\r\n }\r\n }}\r\n startIcon={startIcons}\r\n endIcon={endIcons}\r\n value={inputValue}\r\n onKeyDown={(e) => {\r\n if (inputProps?.onKeyDown) {\r\n inputProps.onKeyDown(e)\r\n }\r\n if (multiple && e.key === 'Backspace' && inputValue === \"\" && Array.isArray(value) && value.length > 0) {\r\n let newValue = [...value]\r\n newValue.pop()\r\n onChange && onChange(newValue)\r\n }\r\n }}\r\n onChange={(e) => {\r\n const value = e.target.value;\r\n setInputValue(value)\r\n if (!value) {\r\n setOptions([])\r\n setOpen(false)\r\n return;\r\n }\r\n setOpen(true)\r\n\r\n clearTimeout(timer)\r\n setTimer(setTimeout(async () => {\r\n if (typeof options === 'function') {\r\n setLoading(true)\r\n const result = await options(value)\r\n setOptions(result)\r\n setLoading(false)\r\n } else {\r\n const filtered = options.filter(option => getLabel!(option).toLowerCase().includes(value.toLowerCase()))\r\n setOptions(filtered)\r\n }\r\n }, 300))\r\n }}\r\n />\r\n <Menu\r\n target={open ? menuRef.current : null}\r\n onClickOutside={() => {\r\n setOptions([])\r\n setInputValue(\"\")\r\n }}\r\n slotProps={{\r\n content: { minWidth: menuRef.current ? menuRef.current.offsetWidth : 'auto' }\r\n }}\r\n >\r\n <List\r\n maxHeight={400}\r\n overflow={\"auto\"}\r\n >\r\n {_options?.map((option, index) => (\r\n renderOption ? <div key={\"auto-complete\" + index + getLabel!(option)}>{renderOption(option, {\r\n onClick: () => {\r\n if (multiple) {\r\n let newValue = Array.isArray(value) ? [...value] : []\r\n const has = newValue.find((v: any) => getLabel!(v) === getLabel!(option))\r\n if (!has) {\r\n newValue.push(option)\r\n } else {\r\n newValue = newValue.filter((v: any) => getLabel!(v) !== getLabel!(option))\r\n }\r\n onChange && onChange(newValue)\r\n } else {\r\n onChange && onChange(option)\r\n setOpen(false)\r\n setInputValue(getLabel!(option))\r\n setOptions([])\r\n }\r\n }\r\n })}</div> : <ListItem\r\n key={index}\r\n onClick={() => {\r\n if (multiple) {\r\n let newValue = Array.isArray(value) ? [...value] : []\r\n const has = newValue.find((v: any) => getLabel!(v) === getLabel!(option))\r\n if (!has) {\r\n newValue.push(option)\r\n } else {\r\n newValue = newValue.filter((v: any) => getLabel!(v) !== getLabel!(option))\r\n }\r\n onChange && onChange(newValue)\r\n } else {\r\n onChange && onChange(option)\r\n setOpen(false)\r\n setInputValue(getLabel!(option))\r\n setOptions([])\r\n }\r\n }}\r\n >\r\n {getLabel!(option)}\r\n </ListItem>\r\n ))}\r\n </List>\r\n </Menu>\r\n </>\r\n )\r\n}\r\n\r\nexport default Autocomplete\r\n"],"names":["__rest","index","_jsx","Chip","IconButton","CircleProgress","_jsxs","_Fragment","Input","Menu","List","ListItem"],"mappings":"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"}
@@ -0,0 +1,50 @@
1
+ 'use strict';
2
+
3
+ var tslib = require('tslib');
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var React = require('react');
6
+ var core = require('@xanui/core');
7
+ var PersonIcon = require('@xanui/icons/Person');
8
+ var index = require('../Skeleton/index.cjs');
9
+
10
+ const Avatar = React.forwardRef((_a, ref) => {
11
+ var _b;
12
+ var { children, src, alt, skeleton } = _a, rest = tslib.__rest(_a, ["children", "src", "alt", "skeleton"]);
13
+ const [faild, setFaild] = React.useState();
14
+ let [_c] = core.useInterface("Avatar", rest, {}), { size, slotProps } = _c, props = tslib.__rest(_c, ["size", "slotProps"]);
15
+ size !== null && size !== void 0 ? size : (size = 36);
16
+ const _p = {};
17
+ if (size)
18
+ _p.size = size;
19
+ const p = core.useBreakpointProps(_p);
20
+ size = p.size;
21
+ if (skeleton) {
22
+ return jsxRuntime.jsx(index, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.skeleton, { height: size, width: size, animation: "wave", sx: Object.assign(Object.assign({}, (_b = slotProps === null || slotProps === void 0 ? void 0 : slotProps.skeleton) === null || _b === void 0 ? void 0 : _b.sx), { borderRadius: size }) }));
23
+ }
24
+ if (faild === false || !src) {
25
+ let t = (alt === null || alt === void 0 ? void 0 : alt.charAt(0).toUpperCase()) || (children || jsxRuntime.jsx(PersonIcon, {}));
26
+ return (jsxRuntime.jsx(core.Tag, Object.assign({ component: "div", src: src }, props, { baseClass: 'avatar', sxr: {
27
+ display: "inline-flex",
28
+ justifyContent: "center",
29
+ alignItems: "center",
30
+ bgcolor: "background.secondary",
31
+ radius: size,
32
+ fontSize: (size / 3) * 2,
33
+ width: size,
34
+ height: size,
35
+ userSelect: "none",
36
+ color: "text.primary",
37
+ '& svg': {
38
+ fontSize: (size / 3) * 2,
39
+ opacity: .6
40
+ }
41
+ }, ref: ref, children: t })));
42
+ }
43
+ return (jsxRuntime.jsx(core.Tag, Object.assign({ component: "img", radius: size, width: size, height: size, objectFit: "cover" }, props, { alt: alt, src: src, baseClass: 'avatar', onError: (e) => {
44
+ setFaild(false);
45
+ props.onError && props.onError(e);
46
+ }, ref: ref })));
47
+ });
48
+
49
+ module.exports = Avatar;
50
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/Avatar/index.tsx"],"sourcesContent":["import React, { useState } from 'react';\r\nimport { Tag, TagProps, TagComponentType, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\r\nimport PersonIcon from '@xanui/icons/Person'\r\nimport Skeleton, { SkeletonProps } from '../Skeleton';\r\n\r\nexport type AvatarProps<T extends TagComponentType = \"img\"> = TagProps<T> & {\r\n size?: useBreakpointPropsType<number>;\r\n skeleton?: boolean;\r\n slotProps?: {\r\n skeleton?: Omit<SkeletonProps, \"height\" | \"width\" | \"loading\" | \"children\">\r\n }\r\n}\r\n\r\nconst Avatar = React.forwardRef(<T extends TagComponentType = \"img\">({ children, src, alt, skeleton, ...rest }: AvatarProps<T>, ref: any) => {\r\n const [faild, setFaild] = useState<boolean>()\r\n let [{ size, slotProps, ...props }] = useInterface<any>(\"Avatar\", rest, {})\r\n size ??= 36\r\n const _p: any = {}\r\n if (size) _p.size = size\r\n const p: any = useBreakpointProps(_p)\r\n size = p.size\r\n\r\n if (skeleton) {\r\n return <Skeleton\r\n {...slotProps?.skeleton}\r\n height={size}\r\n width={size}\r\n animation={\"wave\"}\r\n sx={{\r\n ...slotProps?.skeleton?.sx,\r\n borderRadius: size,\r\n }}\r\n />\r\n }\r\n\r\n if (faild === false || !src) {\r\n let t = alt?.charAt(0).toUpperCase() || (children || <PersonIcon />)\r\n return (\r\n <Tag\r\n component=\"div\"\r\n src={src}\r\n {...props}\r\n baseClass='avatar'\r\n sxr={{\r\n display: \"inline-flex\",\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n bgcolor: \"background.secondary\",\r\n radius: size,\r\n fontSize: (size / 3) * 2,\r\n width: size,\r\n height: size,\r\n userSelect: \"none\",\r\n color: \"text.primary\",\r\n '& svg': {\r\n fontSize: (size / 3) * 2,\r\n opacity: .6\r\n }\r\n }}\r\n ref={ref}\r\n >{t}</Tag>\r\n )\r\n }\r\n return (\r\n <Tag\r\n component=\"img\"\r\n radius={size}\r\n width={size}\r\n height={size}\r\n objectFit=\"cover\"\r\n {...props}\r\n alt={alt}\r\n src={src}\r\n baseClass='avatar'\r\n onError={(e) => {\r\n setFaild(false)\r\n props.onError && props.onError(e as any)\r\n }}\r\n ref={ref}\r\n />\r\n )\r\n})\r\n\r\nexport default Avatar\r\n\r\n\r\n"],"names":["__rest","useState","useInterface","useBreakpointProps","_jsx","Skeleton","Tag"],"mappings":"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"}