@xanui/ui 1.1.36 → 1.1.38

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 (155) hide show
  1. package/Accordion/index.js +19 -21
  2. package/Accordion/index.js.map +1 -1
  3. package/Alert/index.js +33 -35
  4. package/Alert/index.js.map +1 -1
  5. package/Autocomplete/index.js +23 -25
  6. package/Autocomplete/index.js.map +1 -1
  7. package/Avatar/index.js +15 -17
  8. package/Avatar/index.js.map +1 -1
  9. package/Badge/index.js +12 -14
  10. package/Badge/index.js.map +1 -1
  11. package/Box/index.js +7 -9
  12. package/Box/index.js.map +1 -1
  13. package/Button/index.js +17 -19
  14. package/Button/index.js.map +1 -1
  15. package/ButtonGroup/index.js +12 -14
  16. package/ButtonGroup/index.js.map +1 -1
  17. package/Calendar/index.js +39 -41
  18. package/Calendar/index.js.map +1 -1
  19. package/CalendarInput/index.js +19 -21
  20. package/CalendarInput/index.js.map +1 -1
  21. package/Checkbox/index.js +14 -16
  22. package/Checkbox/index.js.map +1 -1
  23. package/Chip/index.js +12 -14
  24. package/Chip/index.js.map +1 -1
  25. package/CircleProgress/index.js +13 -15
  26. package/CircleProgress/index.js.map +1 -1
  27. package/ClickOutside/index.js +9 -11
  28. package/ClickOutside/index.js.map +1 -1
  29. package/Collaps/index.js +9 -11
  30. package/Collaps/index.js.map +1 -1
  31. package/Container/index.js +9 -11
  32. package/Container/index.js.map +1 -1
  33. package/DataFilter/index.js +30 -41
  34. package/DataFilter/index.js.map +1 -1
  35. package/DataFilter/options/DateFilter.js +16 -18
  36. package/DataFilter/options/DateFilter.js.map +1 -1
  37. package/DataFilter/options/DateRangeFilter.js +12 -14
  38. package/DataFilter/options/DateRangeFilter.js.map +1 -1
  39. package/DataFilter/options/MultiSelectFilter.js +20 -22
  40. package/DataFilter/options/MultiSelectFilter.js.map +1 -1
  41. package/DataFilter/options/NumberFilter.js +11 -13
  42. package/DataFilter/options/NumberFilter.js.map +1 -1
  43. package/DataFilter/options/NumberRangeFilter.js +12 -14
  44. package/DataFilter/options/NumberRangeFilter.js.map +1 -1
  45. package/DataFilter/options/SelectFilter.js +18 -20
  46. package/DataFilter/options/SelectFilter.js.map +1 -1
  47. package/DataFilter/options/TextFilter.js +11 -13
  48. package/DataFilter/options/TextFilter.js.map +1 -1
  49. package/Datatable/FilterBox.js +21 -23
  50. package/Datatable/FilterBox.js.map +1 -1
  51. package/Datatable/Row.js +19 -21
  52. package/Datatable/Row.js.map +1 -1
  53. package/Datatable/SelectedBox.js +10 -12
  54. package/Datatable/SelectedBox.js.map +1 -1
  55. package/Datatable/Table.js +8 -10
  56. package/Datatable/Table.js.map +1 -1
  57. package/Datatable/TableHead.js +18 -20
  58. package/Datatable/TableHead.js.map +1 -1
  59. package/Datatable/index.js +21 -23
  60. package/Datatable/index.js.map +1 -1
  61. package/Divider/index.js +8 -10
  62. package/Divider/index.js.map +1 -1
  63. package/Drawer/index.js +12 -14
  64. package/Drawer/index.js.map +1 -1
  65. package/Form/index.js +8 -10
  66. package/Form/index.js.map +1 -1
  67. package/GridContainer/index.js +7 -9
  68. package/GridContainer/index.js.map +1 -1
  69. package/GridItem/index.js +7 -9
  70. package/GridItem/index.js.map +1 -1
  71. package/IconButton/index.js +12 -14
  72. package/IconButton/index.js.map +1 -1
  73. package/Image/index.js +9 -11
  74. package/Image/index.js.map +1 -1
  75. package/Input/index.js +18 -20
  76. package/Input/index.js.map +1 -1
  77. package/InputNumber/index.js +6 -8
  78. package/InputNumber/index.js.map +1 -1
  79. package/Label/index.js +7 -9
  80. package/Label/index.js.map +1 -1
  81. package/Layer/index.js +19 -21
  82. package/Layer/index.js.map +1 -1
  83. package/LineProgress/index.js +11 -13
  84. package/LineProgress/index.js.map +1 -1
  85. package/List/ListContext.js +2 -5
  86. package/List/ListContext.js.map +1 -1
  87. package/List/index.js +12 -14
  88. package/List/index.js.map +1 -1
  89. package/ListItem/index.js +12 -14
  90. package/ListItem/index.js.map +1 -1
  91. package/LoadingBox/index.js +11 -13
  92. package/LoadingBox/index.js.map +1 -1
  93. package/Menu/index.js +18 -20
  94. package/Menu/index.js.map +1 -1
  95. package/Modal/index.js +15 -17
  96. package/Modal/index.js.map +1 -1
  97. package/NoSSR/index.js +4 -6
  98. package/NoSSR/index.js.map +1 -1
  99. package/Option/index.js +7 -9
  100. package/Option/index.js.map +1 -1
  101. package/Paper/index.js +8 -10
  102. package/Paper/index.js.map +1 -1
  103. package/Portal/index.js +9 -11
  104. package/Portal/index.js.map +1 -1
  105. package/Radio/index.js +9 -11
  106. package/Radio/index.js.map +1 -1
  107. package/Scrollbar/index.js +10 -12
  108. package/Scrollbar/index.js.map +1 -1
  109. package/Select/index.js +22 -24
  110. package/Select/index.js.map +1 -1
  111. package/Skeleton/index.js +7 -9
  112. package/Skeleton/index.js.map +1 -1
  113. package/Stack/index.js +7 -9
  114. package/Stack/index.js.map +1 -1
  115. package/Switch/index.js +12 -14
  116. package/Switch/index.js.map +1 -1
  117. package/Tab/index.js +9 -11
  118. package/Tab/index.js.map +1 -1
  119. package/Table/index.js +13 -15
  120. package/Table/index.js.map +1 -1
  121. package/TableBody/index.js +7 -9
  122. package/TableBody/index.js.map +1 -1
  123. package/TableCell/index.js +7 -9
  124. package/TableCell/index.js.map +1 -1
  125. package/TableFooter/index.js +7 -9
  126. package/TableFooter/index.js.map +1 -1
  127. package/TableHead/index.js +7 -9
  128. package/TableHead/index.js.map +1 -1
  129. package/TablePagination/index.js +21 -23
  130. package/TablePagination/index.js.map +1 -1
  131. package/TableRow/index.js +7 -9
  132. package/TableRow/index.js.map +1 -1
  133. package/Tabs/index.js +19 -21
  134. package/Tabs/index.js.map +1 -1
  135. package/Text/index.js +8 -10
  136. package/Text/index.js.map +1 -1
  137. package/Toast/index.js +18 -20
  138. package/Toast/index.js.map +1 -1
  139. package/Tooltip/index.js +11 -13
  140. package/Tooltip/index.js.map +1 -1
  141. package/ViewBox/index.js +11 -13
  142. package/ViewBox/index.js.map +1 -1
  143. package/index.js +64 -133
  144. package/index.js.map +1 -1
  145. package/package.json +2 -2
  146. package/useAlert/index.js +12 -14
  147. package/useAlert/index.js.map +1 -1
  148. package/useBlurCss/index.js +5 -7
  149. package/useBlurCss/index.js.map +1 -1
  150. package/useCorner/index.js +1 -3
  151. package/useCorner/index.js.map +1 -1
  152. package/useLayer/index.js +7 -9
  153. package/useLayer/index.js.map +1 -1
  154. package/useModal/index.js +8 -10
  155. package/useModal/index.js.map +1 -1
@@ -1,23 +1,21 @@
1
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.js');
10
- var index = require('../List/index.js');
11
- var index$1 = require('../ListItem/index.js');
2
+ import { __rest } from 'tslib';
3
+ import { jsx, jsxs } from 'react/jsx-runtime';
4
+ import React, { useState } from 'react';
5
+ import { useInterface, useBreakpointProps, Tag } from '@xanui/core';
6
+ import ExpandIcon from '@xanui/icons/ExpandMore';
7
+ import Collaps from '../Collaps/index.js';
8
+ import List from '../List/index.js';
9
+ import ListItem from '../ListItem/index.js';
12
10
 
13
11
  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, {
12
+ var { children, title, subtitle } = _a, rest = __rest(_a, ["children", "title", "subtitle"]);
13
+ const [_expand, setExpand] = useState(false);
14
+ let [_b] = useInterface("Accordion", rest, {
17
15
  onClick: () => setExpand(!_expand),
18
16
  color: "brand",
19
17
  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"]);
18
+ }), { expand, onClick, color, variant, hoverColor, hoverVariant, expandIcon, expandIconPlacement, startIcon, endIcon, expandAction, classNames, slotProps } = _b, rootProps = __rest(_b, ["expand", "onClick", "color", "variant", "hoverColor", "hoverVariant", "expandIcon", "expandIconPlacement", "startIcon", "endIcon", "expandAction", "classNames", "slotProps"]);
21
19
  const _p = {};
22
20
  if (title)
23
21
  _p.title = title;
@@ -41,7 +39,7 @@ const Accordion = React.forwardRef((_a, ref) => {
41
39
  _p.hoverColor = hoverColor;
42
40
  if (hoverVariant)
43
41
  _p.hoverVariant = hoverVariant;
44
- const p = core.useBreakpointProps(_p);
42
+ const p = useBreakpointProps(_p);
45
43
  title = p.title;
46
44
  subtitle = p.subtitle;
47
45
  startIcon = p.startIcon;
@@ -54,11 +52,11 @@ const Accordion = React.forwardRef((_a, ref) => {
54
52
  hoverColor = p.hoverColor;
55
53
  hoverVariant = p.hoverVariant;
56
54
  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, {}) }));
55
+ expandIcon = expandIcon ? jsx(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 })) : jsx(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: jsx(ExpandIcon, {}) }));
58
56
  let itemsx = {};
59
57
  if (expandIconPlacement === 'start') {
60
58
  itemsx = {
61
- startIcon: jsxRuntime.jsxs(core.Tag, { className: 'start-icon-container', sxr: {
59
+ startIcon: jsxs(Tag, { className: 'start-icon-container', sxr: {
62
60
  display: "flex",
63
61
  flexDirection: "row",
64
62
  alignItems: "center",
@@ -69,7 +67,7 @@ const Accordion = React.forwardRef((_a, ref) => {
69
67
  }
70
68
  else {
71
69
  itemsx = {
72
- endIcon: jsxRuntime.jsxs(core.Tag, { className: 'end-icon-container', sxr: {
70
+ endIcon: jsxs(Tag, { className: 'end-icon-container', sxr: {
73
71
  display: "flex",
74
72
  flexDirection: "row",
75
73
  alignItems: "center",
@@ -82,9 +80,9 @@ const Accordion = React.forwardRef((_a, ref) => {
82
80
  itemsx.onClick = () => { };
83
81
  itemsx.cursor = "initial!important";
84
82
  }
85
- return (jsxRuntime.jsx(core.Tag, Object.assign({}, rootProps, { sxr: {
83
+ return (jsx(Tag, Object.assign({}, rootProps, { sxr: {
86
84
  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: {
85
+ }, baseClass: 'accordion', classNames: [{ "accordion-expanded": expand }, ...(classNames || [])], ref: ref, children: jsxs(List, 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: [jsx(ListItem, 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 })), jsx(Collaps, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.collaps, { open: expand, className: "accordion-collaps", children: jsx(Tag, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.content, { sxr: {
88
86
  color: "text.primary",
89
87
  p: 2,
90
88
  py: 1,
@@ -92,5 +90,5 @@ const Accordion = React.forwardRef((_a, ref) => {
92
90
  }, baseClass: 'accordion-content', children: children })) }))] })) })));
93
91
  });
94
92
 
95
- module.exports = Accordion;
93
+ export { Accordion as default };
96
94
  //# sourceMappingURL=index.js.map
@@ -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, { 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;;"}
package/Alert/index.js CHANGED
@@ -1,24 +1,22 @@
1
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.js');
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.js');
15
- var index$2 = require('../useAlert/index.js');
2
+ import { __rest } from 'tslib';
3
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
4
+ import { useInterface, useBreakpointProps, useColorTemplate, Tag, Renderar } from '@xanui/core';
5
+ import { isValidElement, useRef, useEffect } from 'react';
6
+ import Text from '../Text/index.js';
7
+ import InfoIcon from '@xanui/icons/Info';
8
+ import WarningIcon from '@xanui/icons/Warning';
9
+ import SuccessIcon from '@xanui/icons/CheckCircle';
10
+ import ErrorIcon from '@xanui/icons/Cancel';
11
+ import Close from '@xanui/icons/Close';
12
+ import IconButton from '../IconButton/index.js';
13
+ import useAlert from '../useAlert/index.js';
16
14
 
17
15
  const Alert = (_a) => {
18
- var { children } = _a, rest = tslib.__rest(_a, ["children"]);
19
- let [_b] = core.useInterface("Alert", rest, {
16
+ var { children } = _a, rest = __rest(_a, ["children"]);
17
+ let [_b] = useInterface("Alert", rest, {
20
18
  variant: "fill"
21
- }), { title, variant, icon, color, direction, slotProps, onClose } = _b, _props = tslib.__rest(_b, ["title", "variant", "icon", "color", "direction", "slotProps", "onClose"]);
19
+ }), { title, variant, icon, color, direction, slotProps, onClose } = _b, _props = __rest(_b, ["title", "variant", "icon", "color", "direction", "slotProps", "onClose"]);
22
20
  color !== null && color !== void 0 ? color : (color = "default");
23
21
  direction !== null && direction !== void 0 ? direction : (direction = "row");
24
22
  const _p = {};
@@ -32,35 +30,35 @@ const Alert = (_a) => {
32
30
  _p.color = color;
33
31
  if (direction)
34
32
  _p.direction = direction;
35
- const p = core.useBreakpointProps(_p);
33
+ const p = useBreakpointProps(_p);
36
34
  title = p.title;
37
35
  variant = p.variant;
38
36
  icon = p.icon;
39
37
  color = p.color;
40
38
  direction = p.direction;
41
39
  let isRow = direction === 'row';
42
- const template = core.useColorTemplate(color, variant);
40
+ const template = useColorTemplate(color, variant);
43
41
  let iconsx = {
44
42
  fontSize: isRow ? 22 : 40,
45
43
  color: color === 'default' ? "text.primary" : template.primary.color
46
44
  };
47
45
  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 })
46
+ "info": jsx(InfoIcon, { sx: iconsx }),
47
+ "warning": jsx(WarningIcon, { sx: iconsx }),
48
+ "success": jsx(SuccessIcon, { sx: iconsx }),
49
+ "danger": jsx(ErrorIcon, { sx: iconsx })
52
50
  };
53
51
  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: {
52
+ return (jsxs(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 && jsx(IconButton, { color: color, variant: variant === 'fill' ? "fill" : "text", size: 25, sx: {
55
53
  position: "absolute",
56
54
  top: 5,
57
55
  right: 5
58
- }, onClick: onClose, className: "alert-close-button", children: jsxRuntime.jsx(Close, { fontSize: 18 }) }), jsxRuntime.jsxs(core.Tag, { sx: {
56
+ }, onClick: onClose, className: "alert-close-button", children: jsx(Close, { fontSize: 18 }) }), jsxs(Tag, { sx: {
59
57
  display: "flex",
60
58
  gap: 1,
61
59
  flexDirection: direction,
62
60
  alignItems: isRow ? "flex-start" : "center"
63
- }, baseClass: "alert-container", children: [_icon && jsxRuntime.jsx(core.Tag, { baseClass: "alert-icon", sxr: {
61
+ }, baseClass: "alert-container", children: [_icon && jsx(Tag, { baseClass: "alert-icon", sxr: {
64
62
  display: "flex",
65
63
  alignItems: "center",
66
64
  justifyContent: "center",
@@ -68,7 +66,7 @@ const Alert = (_a) => {
68
66
  "& svg": {
69
67
  color: template.primary.color
70
68
  }
71
- }, children: _icon }), jsxRuntime.jsxs(core.Tag, { baseClass: "alert-content", sxr: {
69
+ }, children: _icon }), jsxs(Tag, { baseClass: "alert-content", sxr: {
72
70
  display: "flex",
73
71
  flexDirection: "column",
74
72
  flex: 1,
@@ -76,19 +74,19 @@ const Alert = (_a) => {
76
74
  py: 1,
77
75
  textAlign: isRow ? "left" : "center",
78
76
  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: {
77
+ }, children: [title && jsx(Fragment, { children: isValidElement(title) ? jsx(Tag, { className: "alert-title", children: title }) : jsx(Text, { className: "alert-title", variant: "text", sx: {
80
78
  font: "text",
81
79
  fontWeight: "bold!important",
82
80
  color: template.primary.color
83
- }, children: title }) }), jsxRuntime.jsx(core.Tag, { sxr: {
81
+ }, children: title }) }), jsx(Tag, { sxr: {
84
82
  font: "button",
85
83
  }, children: children })] })] })] })));
86
84
  };
87
85
  const ActionAlert = (props) => {
88
86
  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(() => {
87
+ const ref = useRef(null);
88
+ const alert = useAlert(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 }) }) }) }) }) }));
89
+ useEffect(() => {
92
90
  if (props.open) {
93
91
  alert.open();
94
92
  }
@@ -96,11 +94,11 @@ const ActionAlert = (props) => {
96
94
  alert.close();
97
95
  }
98
96
  }, [props.open]);
99
- return jsxRuntime.jsx(core.Tag, { ref: ref });
97
+ return jsx(Tag, { ref: ref });
100
98
  };
101
99
  Alert.confirm = (props) => {
102
100
  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: () => {
101
+ const a = 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
102
  var _a, _b, _c, _d;
105
103
  a.unrender();
106
104
  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) {
@@ -117,5 +115,5 @@ Alert.confirm = (props) => {
117
115
  };
118
116
  };
119
117
 
120
- module.exports = Alert;
118
+ export { Alert as default };
121
119
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","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;;"}
1
+ {"version":3,"file":"index.js","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;;"}
@@ -1,19 +1,17 @@
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.js');
7
- var index$4 = require('../Menu/index.js');
8
- var index$5 = require('../List/index.js');
9
- var index$6 = require('../ListItem/index.js');
10
- var index = require('../Chip/index.js');
11
- var index$1 = require('../IconButton/index.js');
12
- var Close = require('@xanui/icons/Close');
13
- var index$2 = require('../CircleProgress/index.js');
1
+ import { __rest } from 'tslib';
2
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
3
+ import React from 'react';
4
+ import Input from '../Input/index.js';
5
+ import Menu from '../Menu/index.js';
6
+ import List from '../List/index.js';
7
+ import ListItem from '../ListItem/index.js';
8
+ import Chip from '../Chip/index.js';
9
+ import IconButton from '../IconButton/index.js';
10
+ import Close from '@xanui/icons/Close';
11
+ import CircleProgress from '../CircleProgress/index.js';
14
12
 
15
13
  const Autocomplete = (_a) => {
16
- var { value, onChange, renderOption, options, getLabel, multiple } = _a, inputProps = tslib.__rest(_a, ["value", "onChange", "renderOption", "options", "getLabel", "multiple"]);
14
+ var { value, onChange, renderOption, options, getLabel, multiple } = _a, inputProps = __rest(_a, ["value", "onChange", "renderOption", "options", "getLabel", "multiple"]);
17
15
  const [_options, setOptions] = React.useState();
18
16
  const [inputValue, setInputValue] = React.useState("");
19
17
  const [timer, setTimer] = React.useState(null);
@@ -26,29 +24,29 @@ const Autocomplete = (_a) => {
26
24
  inputProps.startIcon
27
25
  ];
28
26
  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) => {
27
+ value.map((v, index) => {
28
+ startIcons.push(jsx(Chip, { size: "small", label: getLabel(v), variant: "fill", color: "default", endIcon: jsx(IconButton, { size: 20, variant: "text", color: "default", onClick: (e) => {
31
29
  e.stopPropagation();
32
30
  let newValue = Array.isArray(value) ? [...value] : [];
33
31
  newValue = newValue.filter((val) => getLabel(val) !== getLabel(v));
34
32
  onChange && onChange(newValue);
35
- }, children: jsxRuntime.jsx(Close, {}) }) }, index$2));
33
+ }, children: jsx(Close, {}) }) }, index));
36
34
  });
37
35
  }
38
36
  let endIcons = [
39
37
  inputProps.endIcon
40
38
  ];
41
39
  if (loading) {
42
- endIcons.push(jsxRuntime.jsx(index$2, { size: "small" }, "auto-complete-loading-icon"));
40
+ endIcons.push(jsx(CircleProgress, { size: "small" }, "auto-complete-loading-icon"));
43
41
  }
44
42
  else if (!!value && !multiple) {
45
- endIcons.push(jsxRuntime.jsx(index$1, { variant: "text", color: "default", onClick: (e) => {
43
+ endIcons.push(jsx(IconButton, { variant: "text", color: "default", onClick: (e) => {
46
44
  e.stopPropagation();
47
45
  onChange && onChange(undefined);
48
46
  setInputValue("");
49
- }, children: jsxRuntime.jsx(Close, {}) }, "auto-complete-clear-button"));
47
+ }, children: jsx(Close, {}) }, "auto-complete-clear-button"));
50
48
  }
51
- return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(index$3, Object.assign({}, inputProps, { ref: menuRef, slotProps: {
49
+ return (jsxs(Fragment, { children: [jsx(Input, Object.assign({}, inputProps, { ref: menuRef, slotProps: {
52
50
  rootContainer: Object.assign({ flexWrap: 'wrap' }, (multiple ? { height: "auto", gap: .5 } : {})),
53
51
  input: {
54
52
  width: multiple ? 'auto' : '100%',
@@ -86,12 +84,12 @@ const Autocomplete = (_a) => {
86
84
  setOptions(filtered);
87
85
  }
88
86
  }, 300));
89
- } })), jsxRuntime.jsx(index$4, { target: open ? menuRef.current : null, onClickOutside: () => {
87
+ } })), jsx(Menu, { target: open ? menuRef.current : null, onClickOutside: () => {
90
88
  setOptions([]);
91
89
  setInputValue("");
92
90
  }, slotProps: {
93
91
  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, {
92
+ }, children: jsx(List, { maxHeight: 400, overflow: "auto", children: _options === null || _options === void 0 ? void 0 : _options.map((option, index) => (renderOption ? jsx("div", { children: renderOption(option, {
95
93
  onClick: () => {
96
94
  if (multiple) {
97
95
  let newValue = Array.isArray(value) ? [...value] : [];
@@ -111,7 +109,7 @@ const Autocomplete = (_a) => {
111
109
  setOptions([]);
112
110
  }
113
111
  }
114
- }) }, "auto-complete" + index + getLabel(option)) : jsxRuntime.jsx(index$6, { onClick: () => {
112
+ }) }, "auto-complete" + index + getLabel(option)) : jsx(ListItem, { onClick: () => {
115
113
  if (multiple) {
116
114
  let newValue = Array.isArray(value) ? [...value] : [];
117
115
  const has = newValue.find((v) => getLabel(v) === getLabel(option));
@@ -132,5 +130,5 @@ const Autocomplete = (_a) => {
132
130
  }, children: getLabel(option) }, index))) }) })] }));
133
131
  };
134
132
 
135
- module.exports = Autocomplete;
133
+ export { Autocomplete as default };
136
134
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","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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"}
1
+ {"version":3,"file":"index.js","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":["_jsx","_jsxs","_Fragment"],"mappings":"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"}
package/Avatar/index.js CHANGED
@@ -1,29 +1,27 @@
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.js');
1
+ import { __rest } from 'tslib';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import React, { useState } from 'react';
4
+ import { useInterface, useBreakpointProps, Tag } from '@xanui/core';
5
+ import PersonIcon from '@xanui/icons/Person';
6
+ import Skeleton from '../Skeleton/index.js';
9
7
 
10
8
  const Avatar = React.forwardRef((_a, ref) => {
11
9
  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"]);
10
+ var { children, src, alt, skeleton } = _a, rest = __rest(_a, ["children", "src", "alt", "skeleton"]);
11
+ const [faild, setFaild] = useState();
12
+ let [_c] = useInterface("Avatar", rest, {}), { size, slotProps } = _c, props = __rest(_c, ["size", "slotProps"]);
15
13
  size !== null && size !== void 0 ? size : (size = 36);
16
14
  const _p = {};
17
15
  if (size)
18
16
  _p.size = size;
19
- const p = core.useBreakpointProps(_p);
17
+ const p = useBreakpointProps(_p);
20
18
  size = p.size;
21
19
  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 }) }));
20
+ return jsx(Skeleton, 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
21
  }
24
22
  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: {
23
+ let t = (alt === null || alt === void 0 ? void 0 : alt.charAt(0).toUpperCase()) || (children || jsx(PersonIcon, {}));
24
+ return (jsx(Tag, Object.assign({ component: "div", src: src }, props, { baseClass: 'avatar', sxr: {
27
25
  display: "inline-flex",
28
26
  justifyContent: "center",
29
27
  alignItems: "center",
@@ -40,11 +38,11 @@ const Avatar = React.forwardRef((_a, ref) => {
40
38
  }
41
39
  }, ref: ref, children: t })));
42
40
  }
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) => {
41
+ return (jsx(Tag, Object.assign({ component: "img", radius: size, width: size, height: size, objectFit: "cover" }, props, { alt: alt, src: src, baseClass: 'avatar', onError: (e) => {
44
42
  setFaild(false);
45
43
  props.onError && props.onError(e);
46
44
  }, ref: ref })));
47
45
  });
48
46
 
49
- module.exports = Avatar;
47
+ export { Avatar as default };
50
48
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","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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"}
1
+ {"version":3,"file":"index.js","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":["_jsx"],"mappings":"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"}