@xanui/ui 1.1.35 → 1.1.36

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 (156) hide show
  1. package/DataFilter/index.js +3 -3
  2. package/package.json +3 -3
  3. package/Accordion/index.mjs +0 -94
  4. package/Accordion/index.mjs.map +0 -1
  5. package/Alert/index.mjs +0 -119
  6. package/Alert/index.mjs.map +0 -1
  7. package/Autocomplete/index.mjs +0 -134
  8. package/Autocomplete/index.mjs.map +0 -1
  9. package/Avatar/index.mjs +0 -48
  10. package/Avatar/index.mjs.map +0 -1
  11. package/Badge/index.mjs +0 -107
  12. package/Badge/index.mjs.map +0 -1
  13. package/Box/index.mjs +0 -12
  14. package/Box/index.mjs.map +0 -1
  15. package/Button/index.mjs +0 -92
  16. package/Button/index.mjs.map +0 -1
  17. package/ButtonGroup/index.mjs +0 -56
  18. package/ButtonGroup/index.mjs.map +0 -1
  19. package/Calendar/index.mjs +0 -172
  20. package/Calendar/index.mjs.map +0 -1
  21. package/CalendarInput/index.mjs +0 -32
  22. package/CalendarInput/index.mjs.map +0 -1
  23. package/Checkbox/index.mjs +0 -56
  24. package/Checkbox/index.mjs.map +0 -1
  25. package/Chip/index.mjs +0 -74
  26. package/Chip/index.mjs.map +0 -1
  27. package/CircleProgress/index.mjs +0 -127
  28. package/CircleProgress/index.mjs.map +0 -1
  29. package/ClickOutside/index.mjs +0 -35
  30. package/ClickOutside/index.mjs.map +0 -1
  31. package/Collaps/index.mjs +0 -24
  32. package/Collaps/index.mjs.map +0 -1
  33. package/Container/index.mjs +0 -27
  34. package/Container/index.mjs.map +0 -1
  35. package/DataFilter/index.mjs +0 -67
  36. package/DataFilter/index.mjs.map +0 -1
  37. package/DataFilter/options/DateFilter.mjs +0 -30
  38. package/DataFilter/options/DateFilter.mjs.map +0 -1
  39. package/DataFilter/options/DateRangeFilter.mjs +0 -25
  40. package/DataFilter/options/DateRangeFilter.mjs.map +0 -1
  41. package/DataFilter/options/MultiSelectFilter.mjs +0 -36
  42. package/DataFilter/options/MultiSelectFilter.mjs.map +0 -1
  43. package/DataFilter/options/NumberFilter.mjs +0 -22
  44. package/DataFilter/options/NumberFilter.mjs.map +0 -1
  45. package/DataFilter/options/NumberRangeFilter.mjs +0 -27
  46. package/DataFilter/options/NumberRangeFilter.mjs.map +0 -1
  47. package/DataFilter/options/SelectFilter.mjs +0 -32
  48. package/DataFilter/options/SelectFilter.mjs.map +0 -1
  49. package/DataFilter/options/TextFilter.mjs +0 -22
  50. package/DataFilter/options/TextFilter.mjs.map +0 -1
  51. package/Datatable/FilterBox.mjs +0 -37
  52. package/Datatable/FilterBox.mjs.map +0 -1
  53. package/Datatable/Row.mjs +0 -57
  54. package/Datatable/Row.mjs.map +0 -1
  55. package/Datatable/SelectedBox.mjs +0 -19
  56. package/Datatable/SelectedBox.mjs.map +0 -1
  57. package/Datatable/Table.mjs +0 -21
  58. package/Datatable/Table.mjs.map +0 -1
  59. package/Datatable/TableHead.mjs +0 -59
  60. package/Datatable/TableHead.mjs.map +0 -1
  61. package/Datatable/index.mjs +0 -91
  62. package/Datatable/index.mjs.map +0 -1
  63. package/Divider/index.mjs +0 -29
  64. package/Divider/index.mjs.map +0 -1
  65. package/Drawer/index.mjs +0 -76
  66. package/Drawer/index.mjs.map +0 -1
  67. package/Form/index.mjs +0 -43
  68. package/Form/index.mjs.map +0 -1
  69. package/GridContainer/index.mjs +0 -17
  70. package/GridContainer/index.mjs.map +0 -1
  71. package/GridItem/index.mjs +0 -18
  72. package/GridItem/index.mjs.map +0 -1
  73. package/IconButton/index.mjs +0 -62
  74. package/IconButton/index.mjs.map +0 -1
  75. package/Image/index.mjs +0 -25
  76. package/Image/index.mjs.map +0 -1
  77. package/Input/index.mjs +0 -142
  78. package/Input/index.mjs.map +0 -1
  79. package/InputNumber/index.mjs +0 -30
  80. package/InputNumber/index.mjs.map +0 -1
  81. package/Label/index.mjs +0 -22
  82. package/Label/index.mjs.map +0 -1
  83. package/Layer/index.mjs +0 -60
  84. package/Layer/index.mjs.map +0 -1
  85. package/LineProgress/index.mjs +0 -57
  86. package/LineProgress/index.mjs.map +0 -1
  87. package/List/ListContext.mjs +0 -8
  88. package/List/ListContext.mjs.map +0 -1
  89. package/List/index.mjs +0 -61
  90. package/List/index.mjs.map +0 -1
  91. package/ListItem/index.mjs +0 -52
  92. package/ListItem/index.mjs.map +0 -1
  93. package/LoadingBox/index.mjs +0 -30
  94. package/LoadingBox/index.mjs.map +0 -1
  95. package/Menu/index.mjs +0 -148
  96. package/Menu/index.mjs.map +0 -1
  97. package/Modal/index.mjs +0 -57
  98. package/Modal/index.mjs.map +0 -1
  99. package/NoSSR/index.mjs +0 -13
  100. package/NoSSR/index.mjs.map +0 -1
  101. package/Option/index.mjs +0 -12
  102. package/Option/index.mjs.map +0 -1
  103. package/Paper/index.mjs +0 -13
  104. package/Paper/index.mjs.map +0 -1
  105. package/Portal/index.mjs +0 -25
  106. package/Portal/index.mjs.map +0 -1
  107. package/Radio/index.mjs +0 -14
  108. package/Radio/index.mjs.map +0 -1
  109. package/Scrollbar/index.mjs +0 -57
  110. package/Scrollbar/index.mjs.map +0 -1
  111. package/Select/index.mjs +0 -57
  112. package/Select/index.mjs.map +0 -1
  113. package/Skeleton/index.mjs +0 -58
  114. package/Skeleton/index.mjs.map +0 -1
  115. package/Stack/index.mjs +0 -15
  116. package/Stack/index.mjs.map +0 -1
  117. package/Switch/index.mjs +0 -77
  118. package/Switch/index.mjs.map +0 -1
  119. package/Tab/index.mjs +0 -15
  120. package/Tab/index.mjs.map +0 -1
  121. package/Table/index.mjs +0 -86
  122. package/Table/index.mjs.map +0 -1
  123. package/TableBody/index.mjs +0 -12
  124. package/TableBody/index.mjs.map +0 -1
  125. package/TableCell/index.mjs +0 -12
  126. package/TableCell/index.mjs.map +0 -1
  127. package/TableFooter/index.mjs +0 -12
  128. package/TableFooter/index.mjs.map +0 -1
  129. package/TableHead/index.mjs +0 -12
  130. package/TableHead/index.mjs.map +0 -1
  131. package/TablePagination/index.mjs +0 -57
  132. package/TablePagination/index.mjs.map +0 -1
  133. package/TableRow/index.mjs +0 -12
  134. package/TableRow/index.mjs.map +0 -1
  135. package/Tabs/index.mjs +0 -199
  136. package/Tabs/index.mjs.map +0 -1
  137. package/Text/index.mjs +0 -23
  138. package/Text/index.mjs.map +0 -1
  139. package/Toast/index.mjs +0 -118
  140. package/Toast/index.mjs.map +0 -1
  141. package/Tooltip/index.mjs +0 -38
  142. package/Tooltip/index.mjs.map +0 -1
  143. package/ViewBox/index.mjs +0 -30
  144. package/ViewBox/index.mjs.map +0 -1
  145. package/index.mjs +0 -65
  146. package/index.mjs.map +0 -1
  147. package/useAlert/index.mjs +0 -92
  148. package/useAlert/index.mjs.map +0 -1
  149. package/useBlurCss/index.mjs +0 -17
  150. package/useBlurCss/index.mjs.map +0 -1
  151. package/useCorner/index.mjs +0 -20
  152. package/useCorner/index.mjs.map +0 -1
  153. package/useLayer/index.mjs +0 -36
  154. package/useLayer/index.mjs.map +0 -1
  155. package/useModal/index.mjs +0 -35
  156. package/useModal/index.mjs.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/useAlert/index.tsx"],"sourcesContent":["\"use client\";\r\n\r\nimport { Tag, UseTransitionVariantTypes } from \"@xanui/core\"\r\nimport Button, { ButtonProps } from \"../Button\";\r\nimport useModal, { UseModalProps } from \"../useModal\";\r\nimport Alert, { AlertProps } from \"../Alert\";\r\nimport React from \"react\";\r\nexport type UseAlertContentProps = {\r\n open: () => void;\r\n close: () => void;\r\n loading: (is: boolean) => void;\r\n isLoading: () => boolean;\r\n}\r\n\r\nexport type UseAlertContent = React.ReactElement | ((props: UseAlertContentProps) => React.ReactElement)\r\n\r\nexport type UseAlerProps = Omit<AlertProps, 'children' | 'onClose' | 'variant' | \"size\"> & {\r\n content: string | UseAlertContent,\r\n size?: \"small\" | \"medium\" | \"large\" | number;\r\n closeButton?: boolean;\r\n clickOutsideToClose?: boolean;\r\n okButtonText?: string;\r\n cancelButtonText?: string;\r\n hideOkButton?: boolean;\r\n hideCancelButton?: boolean;\r\n buttonPlacement?: \"start\" | \"end\" | \"between\" | \"full\";\r\n variant?: \"text\" | \"fill\"\r\n onConfirm?: () => Promise<void> | void;\r\n onCancel?: () => Promise<void> | void;\r\n transition?: UseTransitionVariantTypes;\r\n blurMode?: UseModalProps['blurMode'];\r\n slotProps?: {\r\n modal?: UseModalProps;\r\n okButton?: Omit<ButtonProps, \"children\">;\r\n closeButton?: Omit<ButtonProps, \"children\">;\r\n }\r\n}\r\n\r\n\r\nconst useAlert = (props: UseAlerProps) => {\r\n const [loading, setLoading] = React.useState(false)\r\n let {\r\n content,\r\n size,\r\n color,\r\n direction,\r\n variant,\r\n closeButton,\r\n clickOutsideToClose,\r\n okButtonText,\r\n cancelButtonText,\r\n hideOkButton,\r\n hideCancelButton,\r\n buttonPlacement,\r\n onConfirm,\r\n onCancel,\r\n transition,\r\n blurMode,\r\n slotProps,\r\n ...rest\r\n } = props\r\n\r\n hideOkButton ??= false\r\n hideCancelButton ??= false\r\n\r\n size ??= \"small\"\r\n color ??= 'default'\r\n variant ??= \"text\"\r\n direction ??= \"column\"\r\n buttonPlacement ??= \"end\"\r\n let sx: any = {};\r\n\r\n switch (buttonPlacement) {\r\n case \"start\":\r\n sx.justifyContent = 'flex-start'\r\n break;\r\n case \"end\":\r\n sx.justifyContent = 'flex-end'\r\n break;\r\n case \"between\":\r\n sx.justifyContent = 'space-between'\r\n break;\r\n case \"full\":\r\n sx = {\r\n \"& button\": {\r\n flex: 1\r\n }\r\n }\r\n break;\r\n }\r\n\r\n let sizes: any = {\r\n small: 320,\r\n medium: 400,\r\n large: 600\r\n }\r\n\r\n let okcolor = color\r\n let closecolor = color\r\n if (color === 'default') {\r\n okcolor = 'brand'\r\n closecolor = 'default'\r\n variant = 'text'\r\n } else {\r\n if (variant === 'fill') {\r\n okcolor = 'default'\r\n closecolor = 'default'\r\n } else {\r\n okcolor = color\r\n closecolor = 'default'\r\n }\r\n }\r\n\r\n const modal = useModal(<Alert\r\n direction={direction}\r\n sx={{\r\n px: 2,\r\n py: 1,\r\n pt: direction === 'row' ? 1 : 2\r\n }}\r\n color={color}\r\n variant={variant}\r\n onClose={closeButton ? close : undefined}\r\n {...rest}\r\n >\r\n {typeof content === \"function\" ? content({\r\n open: () => modal.open(),\r\n close: () => modal.close(),\r\n loading: (is: boolean) => setLoading(is),\r\n isLoading: () => loading\r\n }) : content}\r\n <Tag\r\n sxr={{\r\n display: \"flex\",\r\n gap: 1,\r\n pt: 4,\r\n flexDirection: \"row\",\r\n ...sx,\r\n }}\r\n >\r\n {!hideCancelButton && <Button\r\n disabled={loading}\r\n color={closecolor}\r\n variant=\"fill\"\r\n {...slotProps?.closeButton}\r\n onClick={async () => {\r\n setLoading(true)\r\n onCancel && await onCancel()\r\n setLoading(false)\r\n modal.close()\r\n }}\r\n >{cancelButtonText || \"Close\"}</Button>}\r\n <Button\r\n loading={loading}\r\n color={okcolor}\r\n variant=\"fill\"\r\n {...slotProps?.okButton}\r\n\r\n onClick={async () => {\r\n setLoading(true)\r\n onConfirm && await onConfirm()\r\n setLoading(false)\r\n modal.close()\r\n }}\r\n >{okButtonText || \"OK\"}</Button>\r\n </Tag>\r\n </Alert>, {\r\n ...slotProps?.modal,\r\n size: sizes[size] || size,\r\n blur: 40,\r\n blurMode: blurMode || \"transparent\",\r\n transition: transition || \"zoom\",\r\n onClickOutside: async () => {\r\n if (clickOutsideToClose && !loading) {\r\n setLoading(true)\r\n onCancel && await onCancel()\r\n setLoading(false)\r\n modal.close()\r\n }\r\n }\r\n })\r\n\r\n return {\r\n ...modal,\r\n loading: (is: boolean) => setLoading(is),\r\n isLoading: () => loading\r\n }\r\n}\r\n\r\nexport default useAlert"],"names":[],"mappings":";;;;;;;;;AAuCA;AACI;AACA;;;;;;;;;;AAgCI;AACI;;AAEJ;AACI;;AAEJ;AACI;;AAEJ;AACI;AACI;AACI;AACH;;;;AAKb;AACI;AACA;AACA;;;;AAKJ;;;;;;AAKI;;;;;;;;;AASJ;AAGQ;AACA;;AAEH;AAOG;AACA;;AAEA;;;AAkBQ;;;AAGJ;;AAUI;;;;AAaR;;AAEI;;;;AAIR;;AAQR;;"}
@@ -1,17 +0,0 @@
1
- import { useMemo } from 'react';
2
- import { alpha } from '@xanui/core';
3
-
4
- let _d;
5
- const useBlurCss = (blur, mode) => {
6
- return useMemo(() => {
7
- let transparent = { bgcolor: alpha("#000000", blur / 100) };
8
- if (typeof window === 'undefined' || mode === 'transparent') {
9
- return transparent;
10
- }
11
- const d = _d || (_d = window.document.createElement("div").style);
12
- return d['backdropFilter'] !== undefined ? { backdropFilter: `blur(${(blur / 100) * 10}px)` } : transparent;
13
- }, [blur]);
14
- };
15
-
16
- export { useBlurCss as default };
17
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/useBlurCss/index.tsx"],"sourcesContent":["import { useMemo } from \"react\"\r\nimport { alpha } from \"@xanui/core\";\r\n\r\nlet _d: CSSStyleDeclaration;\r\n\r\nconst useBlurCss = (blur: number, mode?: \"transparent\" | \"blur\") => {\r\n return useMemo(() => {\r\n let transparent = { bgcolor: alpha(\"#000000\", blur / 100) }\r\n if (typeof window === 'undefined' || mode === 'transparent') {\r\n return transparent\r\n }\r\n const d = _d || (_d = window.document.createElement(\"div\").style)\r\n return d['backdropFilter'] !== undefined ? { backdropFilter: `blur(${(blur / 100) * 10}px)` } : transparent\r\n }, [blur])\r\n}\r\n\r\n\r\nexport default useBlurCss"],"names":[],"mappings":";;;AAGA,IAAI,EAAuB;AAE3B,MAAM,UAAU,GAAG,CAAC,IAAY,EAAE,IAA6B,KAAI;IAChE,OAAO,OAAO,CAAC,MAAK;AACjB,QAAA,IAAI,WAAW,GAAG,EAAE,OAAO,EAAE,KAAK,CAAC,SAAS,EAAE,IAAI,GAAG,GAAG,CAAC,EAAE;QAC3D,IAAI,OAAO,MAAM,KAAK,WAAW,IAAI,IAAI,KAAK,aAAa,EAAE;AAC1D,YAAA,OAAO,WAAW;QACrB;AACA,QAAA,MAAM,CAAC,GAAG,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC;QACjE,OAAO,CAAC,CAAC,gBAAgB,CAAC,KAAK,SAAS,GAAG,EAAE,cAAc,EAAE,CAAA,KAAA,EAAQ,CAAC,IAAI,GAAG,GAAG,IAAI,EAAE,CAAA,GAAA,CAAK,EAAE,GAAG,WAAW;AAC9G,IAAA,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;AACb;;;;"}
@@ -1,20 +0,0 @@
1
- const useCorner = (type) => {
2
- switch (type) {
3
- case 'square':
4
- return {
5
- radius: 0
6
- };
7
- case 'rounded':
8
- return {
9
- radius: 1
10
- };
11
- case 'circle':
12
- return {
13
- radius: 100
14
- };
15
- }
16
- return {};
17
- };
18
-
19
- export { useCorner as default };
20
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/useCorner/index.ts"],"sourcesContent":["\r\nexport type UseCornerTypes = \"square\" | \"rounded\" | \"circle\"\r\nconst useCorner = (type?: UseCornerTypes): object => {\r\n switch (type) {\r\n case 'square':\r\n return {\r\n radius: 0\r\n }\r\n case 'rounded':\r\n return {\r\n radius: 1\r\n }\r\n case 'circle':\r\n return {\r\n radius: 100\r\n }\r\n }\r\n return {}\r\n}\r\n\r\nexport default useCorner"],"names":[],"mappings":"AAEA,MAAM,SAAS,GAAG,CAAC,IAAqB,KAAY;IAChD,QAAQ,IAAI;AACR,QAAA,KAAK,QAAQ;YACT,OAAO;AACH,gBAAA,MAAM,EAAE;aACX;AACL,QAAA,KAAK,SAAS;YACV,OAAO;AACH,gBAAA,MAAM,EAAE;aACX;AACL,QAAA,KAAK,QAAQ;YACT,OAAO;AACH,gBAAA,MAAM,EAAE;aACX;;AAET,IAAA,OAAO,EAAE;AACb;;;;"}
@@ -1,36 +0,0 @@
1
- "use client";
2
- import { jsx } from 'react/jsx-runtime';
3
- import { usePortal } from '@xanui/core';
4
- import { useState } from 'react';
5
- import Layer from '../Layer/index.mjs';
6
-
7
- const useLayer = (children, props) => {
8
- var _a;
9
- const [open, setOpen] = useState(false);
10
- const portalProps = ((_a = props === null || props === void 0 ? void 0 : props.slotProps) === null || _a === void 0 ? void 0 : _a.portal) || {};
11
- const portal = usePortal(jsx(Layer, Object.assign({ blur: 20 }, props, { open: open, onClosed: () => {
12
- portal.unmount();
13
- if (props === null || props === void 0 ? void 0 : props.onClosed) {
14
- props.onClosed();
15
- }
16
- }, onClickOutside: () => {
17
- if (props === null || props === void 0 ? void 0 : props.onClickOutside) {
18
- props.onClickOutside();
19
- }
20
- else {
21
- setOpen(false);
22
- }
23
- }, children: typeof children === "function" ? children({ open: () => setOpen(true), close: () => setOpen(false) }) : children })), portalProps);
24
- return {
25
- open: () => {
26
- portal.mount();
27
- setOpen(true);
28
- },
29
- close: () => {
30
- setOpen(false);
31
- },
32
- };
33
- };
34
-
35
- export { useLayer as default };
36
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/useLayer/index.tsx"],"sourcesContent":["\"use client\";\r\n\r\nimport { usePortal } from \"@xanui/core\"\r\nimport { useState } from \"react\"\r\nimport Layer, { LayerProps } from \"../Layer\"\r\nimport { UsePortalOptions } from \"@xanui/core/hooks/usePortal\"\r\n\r\nexport type UseLayerProps = Omit<LayerProps, \"open\" | \"children\" | \"slotProps\"> & {\r\n slotProps?: LayerProps[\"slotProps\"] & {\r\n portal?: UsePortalOptions\r\n }\r\n}\r\n\r\nexport type UseLayerReturn = {\r\n open: () => void;\r\n close: () => void;\r\n}\r\n\r\nexport type UseLayerChildren = React.ReactElement | ((props: UseLayerReturn) => React.ReactElement)\r\n\r\nconst useLayer = (children: UseLayerChildren, props?: UseLayerProps): UseLayerReturn => {\r\n const [open, setOpen] = useState(false)\r\n const portalProps = props?.slotProps?.portal || {}\r\n const portal = usePortal(<Layer\r\n blur={20}\r\n {...props}\r\n open={open}\r\n onClosed={() => {\r\n portal.unmount()\r\n if (props?.onClosed) {\r\n props.onClosed()\r\n }\r\n }}\r\n onClickOutside={() => {\r\n if (props?.onClickOutside) {\r\n props.onClickOutside()\r\n } else {\r\n setOpen(false)\r\n }\r\n }}\r\n >\r\n {typeof children === \"function\" ? children({ open: () => setOpen(true), close: () => setOpen(false) }) : children}\r\n </Layer>, portalProps)\r\n\r\n return {\r\n open: () => {\r\n portal.mount()\r\n setOpen(true)\r\n },\r\n close: () => {\r\n setOpen(false)\r\n },\r\n }\r\n}\r\n\r\nexport default useLayer"],"names":[],"mappings":";;;;;;AAoBA;;;AAEG;;;;;;AAUG;;;;;;;AAOA;;;;;;;;;;AAcN;;"}
@@ -1,35 +0,0 @@
1
- "use client";
2
- import { __rest } from 'tslib';
3
- import { jsx } from 'react/jsx-runtime';
4
- import useLayer from '../useLayer/index.mjs';
5
- import { Tag } from '@xanui/core';
6
-
7
- const useModal = (children, props) => {
8
- var _a, _b;
9
- let sizes = {
10
- xs: 420,
11
- sm: 760,
12
- md: 990,
13
- lg: 1120,
14
- xl: 1300,
15
- full: "100%"
16
- };
17
- let _c = props || {}, { size, slotProps } = _c, useLayerProps = __rest(_c, ["size", "slotProps"]);
18
- size = size !== null && size !== void 0 ? size : "xs";
19
- slotProps = slotProps || {};
20
- const root = (slotProps === null || slotProps === void 0 ? void 0 : slotProps.root) || {};
21
- const layer = useLayer(() => {
22
- return (jsx(Tag, Object.assign({}, root, { sxr: Object.assign({ maxWidth: sizes[size] || size, width: "100%", radius: 2, bgcolor: "background.primary", shadow: 15 }, root === null || root === void 0 ? void 0 : root.sx), baseClass: 'modal', children: typeof children === "function" ? children({ open: layer.open, close: layer.close }) : children })));
23
- }, Object.assign(Object.assign({}, useLayerProps), { onClickOutside: () => {
24
- if (props === null || props === void 0 ? void 0 : props.onClickOutside) {
25
- props.onClickOutside();
26
- }
27
- else {
28
- layer.close();
29
- }
30
- }, slotProps: Object.assign(Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.layer), { clickOutside: Object.assign({ maxWidth: sizes[size] || size, width: "100%" }, (_a = slotProps === null || slotProps === void 0 ? void 0 : slotProps.layer) === null || _a === void 0 ? void 0 : _a.clickOutside), root: Object.assign({ display: "flex", alignItems: 'center', justifyContent: "center" }, (_b = slotProps === null || slotProps === void 0 ? void 0 : slotProps.layer) === null || _b === void 0 ? void 0 : _b.root) }) }));
31
- return layer;
32
- };
33
-
34
- export { useModal as default };
35
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/useModal/index.tsx"],"sourcesContent":["\"use client\";\r\n\r\nimport useLayer, { UseLayerProps } from \"../useLayer\";\r\nimport { Tag, TagProps } from '@xanui/core'\r\n\r\nexport type UseModalProps = Omit<UseLayerProps, \"slotProps\"> & {\r\n size?: \"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\" | number;\r\n slotProps?: {\r\n layer?: UseLayerProps['slotProps'];\r\n root?: Omit<TagProps<'div'>, \"children\">\r\n }\r\n}\r\n\r\nexport type UseModalChildren = React.ReactElement | ((props: UseModalReturn) => React.ReactElement)\r\n\r\nexport type UseModalReturn = {\r\n open: () => void;\r\n close: () => void;\r\n}\r\n\r\nconst useModal = (children: UseModalChildren, props?: UseModalProps) => {\r\n\r\n let sizes: any = {\r\n xs: 420,\r\n sm: 760,\r\n md: 990,\r\n lg: 1120,\r\n xl: 1300,\r\n full: \"100%\"\r\n }\r\n let { size, slotProps, ...useLayerProps } = props || {}\r\n size = size ?? \"xs\"\r\n slotProps = slotProps || {} as any\r\n const root: any = slotProps?.root || {}\r\n\r\n const layer = useLayer(() => {\r\n return (\r\n <Tag\r\n {...root}\r\n sxr={{\r\n maxWidth: sizes[size as any] || size,\r\n width: \"100%\",\r\n radius: 2,\r\n bgcolor: \"background.primary\",\r\n shadow: 15,\r\n ...root?.sx\r\n }}\r\n baseClass='modal'\r\n >\r\n {typeof children === \"function\" ? children({ open: layer.open, close: layer.close }) : children}\r\n </Tag>\r\n )\r\n }, {\r\n ...useLayerProps,\r\n onClickOutside: () => {\r\n if (props?.onClickOutside) {\r\n props.onClickOutside()\r\n } else {\r\n layer.close()\r\n }\r\n },\r\n slotProps: {\r\n ...slotProps?.layer,\r\n clickOutside: {\r\n maxWidth: sizes[size as any] || size,\r\n width: \"100%\",\r\n ...slotProps?.layer?.clickOutside,\r\n },\r\n root: {\r\n display: \"flex\",\r\n alignItems: 'center',\r\n justifyContent: \"center\",\r\n ...slotProps?.layer?.root,\r\n }\r\n }\r\n })\r\n\r\n return layer\r\n}\r\n\r\nexport default useModal;"],"names":[],"mappings":";;;;;;AAoBA;;AAEG;AACG;AACA;AACA;AACA;AACA;AACA;;AAEH;;AAEA;AACA;AAEA;AACG;AAgBH;;;;;;;AAQG;AAiBH;AACH;;"}