@xanui/ui 1.1.37 → 1.1.40
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.
- package/Accordion/index.cjs +96 -0
- package/Accordion/index.cjs.map +1 -0
- package/Accordion/index.js +19 -21
- package/Accordion/index.js.map +1 -1
- package/Alert/index.cjs +121 -0
- package/Alert/index.cjs.map +1 -0
- package/Alert/index.js +33 -35
- package/Alert/index.js.map +1 -1
- package/Autocomplete/index.cjs +136 -0
- package/Autocomplete/index.cjs.map +1 -0
- package/Autocomplete/index.js +23 -25
- package/Autocomplete/index.js.map +1 -1
- package/Avatar/index.cjs +50 -0
- package/Avatar/index.cjs.map +1 -0
- package/Avatar/index.js +15 -17
- package/Avatar/index.js.map +1 -1
- package/Badge/index.cjs +109 -0
- package/Badge/index.cjs.map +1 -0
- package/Badge/index.js +12 -14
- package/Badge/index.js.map +1 -1
- package/Box/index.cjs +14 -0
- package/Box/index.cjs.map +1 -0
- package/Box/index.js +7 -9
- package/Box/index.js.map +1 -1
- package/Button/index.cjs +94 -0
- package/Button/index.cjs.map +1 -0
- package/Button/index.js +17 -19
- package/Button/index.js.map +1 -1
- package/ButtonGroup/index.cjs +58 -0
- package/ButtonGroup/index.cjs.map +1 -0
- package/ButtonGroup/index.js +12 -14
- package/ButtonGroup/index.js.map +1 -1
- package/Calendar/index.cjs +174 -0
- package/Calendar/index.cjs.map +1 -0
- package/Calendar/index.js +39 -41
- package/Calendar/index.js.map +1 -1
- package/CalendarInput/index.cjs +34 -0
- package/CalendarInput/index.cjs.map +1 -0
- package/CalendarInput/index.js +19 -21
- package/CalendarInput/index.js.map +1 -1
- package/Checkbox/index.cjs +58 -0
- package/Checkbox/index.cjs.map +1 -0
- package/Checkbox/index.js +14 -16
- package/Checkbox/index.js.map +1 -1
- package/Chip/index.cjs +76 -0
- package/Chip/index.cjs.map +1 -0
- package/Chip/index.js +12 -14
- package/Chip/index.js.map +1 -1
- package/CircleProgress/index.cjs +129 -0
- package/CircleProgress/index.cjs.map +1 -0
- package/CircleProgress/index.js +13 -15
- package/CircleProgress/index.js.map +1 -1
- package/ClickOutside/index.cjs +37 -0
- package/ClickOutside/index.cjs.map +1 -0
- package/ClickOutside/index.js +9 -11
- package/ClickOutside/index.js.map +1 -1
- package/Collaps/index.cjs +26 -0
- package/Collaps/index.cjs.map +1 -0
- package/Collaps/index.js +9 -11
- package/Collaps/index.js.map +1 -1
- package/Container/index.cjs +29 -0
- package/Container/index.cjs.map +1 -0
- package/Container/index.js +9 -11
- package/Container/index.js.map +1 -1
- package/DataFilter/index.cjs +78 -0
- package/DataFilter/index.cjs.map +1 -0
- package/DataFilter/index.js +30 -41
- package/DataFilter/index.js.map +1 -1
- package/DataFilter/options/DateFilter.cjs +32 -0
- package/DataFilter/options/DateFilter.cjs.map +1 -0
- package/DataFilter/options/DateFilter.js +16 -18
- package/DataFilter/options/DateFilter.js.map +1 -1
- package/DataFilter/options/DateRangeFilter.cjs +27 -0
- package/DataFilter/options/DateRangeFilter.cjs.map +1 -0
- package/DataFilter/options/DateRangeFilter.js +12 -14
- package/DataFilter/options/DateRangeFilter.js.map +1 -1
- package/DataFilter/options/MultiSelectFilter.cjs +38 -0
- package/DataFilter/options/MultiSelectFilter.cjs.map +1 -0
- package/DataFilter/options/MultiSelectFilter.js +20 -22
- package/DataFilter/options/MultiSelectFilter.js.map +1 -1
- package/DataFilter/options/NumberFilter.cjs +24 -0
- package/DataFilter/options/NumberFilter.cjs.map +1 -0
- package/DataFilter/options/NumberFilter.js +11 -13
- package/DataFilter/options/NumberFilter.js.map +1 -1
- package/DataFilter/options/NumberRangeFilter.cjs +29 -0
- package/DataFilter/options/NumberRangeFilter.cjs.map +1 -0
- package/DataFilter/options/NumberRangeFilter.js +12 -14
- package/DataFilter/options/NumberRangeFilter.js.map +1 -1
- package/DataFilter/options/SelectFilter.cjs +34 -0
- package/DataFilter/options/SelectFilter.cjs.map +1 -0
- package/DataFilter/options/SelectFilter.js +18 -20
- package/DataFilter/options/SelectFilter.js.map +1 -1
- package/DataFilter/options/TextFilter.cjs +24 -0
- package/DataFilter/options/TextFilter.cjs.map +1 -0
- package/DataFilter/options/TextFilter.js +11 -13
- package/DataFilter/options/TextFilter.js.map +1 -1
- package/Datatable/FilterBox.cjs +39 -0
- package/Datatable/FilterBox.cjs.map +1 -0
- package/Datatable/FilterBox.js +21 -23
- package/Datatable/FilterBox.js.map +1 -1
- package/Datatable/Row.cjs +59 -0
- package/Datatable/Row.cjs.map +1 -0
- package/Datatable/Row.js +19 -21
- package/Datatable/Row.js.map +1 -1
- package/Datatable/SelectedBox.cjs +21 -0
- package/Datatable/SelectedBox.cjs.map +1 -0
- package/Datatable/SelectedBox.js +10 -12
- package/Datatable/SelectedBox.js.map +1 -1
- package/Datatable/Table.cjs +23 -0
- package/Datatable/Table.cjs.map +1 -0
- package/Datatable/Table.js +8 -10
- package/Datatable/Table.js.map +1 -1
- package/Datatable/TableHead.cjs +61 -0
- package/Datatable/TableHead.cjs.map +1 -0
- package/Datatable/TableHead.js +18 -20
- package/Datatable/TableHead.js.map +1 -1
- package/Datatable/index.cjs +93 -0
- package/Datatable/index.cjs.map +1 -0
- package/Datatable/index.js +21 -23
- package/Datatable/index.js.map +1 -1
- package/Divider/index.cjs +31 -0
- package/Divider/index.cjs.map +1 -0
- package/Divider/index.js +8 -10
- package/Divider/index.js.map +1 -1
- package/Drawer/index.cjs +78 -0
- package/Drawer/index.cjs.map +1 -0
- package/Drawer/index.js +12 -14
- package/Drawer/index.js.map +1 -1
- package/Form/index.cjs +45 -0
- package/Form/index.cjs.map +1 -0
- package/Form/index.js +8 -10
- package/Form/index.js.map +1 -1
- package/GridContainer/index.cjs +19 -0
- package/GridContainer/index.cjs.map +1 -0
- package/GridContainer/index.js +7 -9
- package/GridContainer/index.js.map +1 -1
- package/GridItem/index.cjs +20 -0
- package/GridItem/index.cjs.map +1 -0
- package/GridItem/index.js +7 -9
- package/GridItem/index.js.map +1 -1
- package/IconButton/index.cjs +64 -0
- package/IconButton/index.cjs.map +1 -0
- package/IconButton/index.js +12 -14
- package/IconButton/index.js.map +1 -1
- package/Image/index.cjs +27 -0
- package/Image/index.cjs.map +1 -0
- package/Image/index.js +9 -11
- package/Image/index.js.map +1 -1
- package/Input/index.cjs +144 -0
- package/Input/index.cjs.map +1 -0
- package/Input/index.js +18 -20
- package/Input/index.js.map +1 -1
- package/InputNumber/index.cjs +32 -0
- package/InputNumber/index.cjs.map +1 -0
- package/InputNumber/index.js +6 -8
- package/InputNumber/index.js.map +1 -1
- package/Label/index.cjs +24 -0
- package/Label/index.cjs.map +1 -0
- package/Label/index.js +7 -9
- package/Label/index.js.map +1 -1
- package/Layer/index.cjs +62 -0
- package/Layer/index.cjs.map +1 -0
- package/Layer/index.js +19 -21
- package/Layer/index.js.map +1 -1
- package/LineProgress/index.cjs +59 -0
- package/LineProgress/index.cjs.map +1 -0
- package/LineProgress/index.js +11 -13
- package/LineProgress/index.js.map +1 -1
- package/List/ListContext.cjs +11 -0
- package/List/ListContext.cjs.map +1 -0
- package/List/ListContext.js +2 -5
- package/List/ListContext.js.map +1 -1
- package/List/index.cjs +63 -0
- package/List/index.cjs.map +1 -0
- package/List/index.js +12 -14
- package/List/index.js.map +1 -1
- package/ListItem/index.cjs +54 -0
- package/ListItem/index.cjs.map +1 -0
- package/ListItem/index.js +12 -14
- package/ListItem/index.js.map +1 -1
- package/LoadingBox/index.cjs +32 -0
- package/LoadingBox/index.cjs.map +1 -0
- package/LoadingBox/index.js +11 -13
- package/LoadingBox/index.js.map +1 -1
- package/Menu/index.cjs +150 -0
- package/Menu/index.cjs.map +1 -0
- package/Menu/index.js +18 -20
- package/Menu/index.js.map +1 -1
- package/Modal/index.cjs +59 -0
- package/Modal/index.cjs.map +1 -0
- package/Modal/index.js +15 -17
- package/Modal/index.js.map +1 -1
- package/NoSSR/index.cjs +15 -0
- package/NoSSR/index.cjs.map +1 -0
- package/NoSSR/index.js +4 -6
- package/NoSSR/index.js.map +1 -1
- package/Option/index.cjs +14 -0
- package/Option/index.cjs.map +1 -0
- package/Option/index.js +7 -9
- package/Option/index.js.map +1 -1
- package/Paper/index.cjs +15 -0
- package/Paper/index.cjs.map +1 -0
- package/Paper/index.js +8 -10
- package/Paper/index.js.map +1 -1
- package/Portal/index.cjs +27 -0
- package/Portal/index.cjs.map +1 -0
- package/Portal/index.js +9 -11
- package/Portal/index.js.map +1 -1
- package/Radio/index.cjs +16 -0
- package/Radio/index.cjs.map +1 -0
- package/Radio/index.js +9 -11
- package/Radio/index.js.map +1 -1
- package/Scrollbar/index.cjs +59 -0
- package/Scrollbar/index.cjs.map +1 -0
- package/Scrollbar/index.js +10 -12
- package/Scrollbar/index.js.map +1 -1
- package/Select/index.cjs +59 -0
- package/Select/index.cjs.map +1 -0
- package/Select/index.js +22 -24
- package/Select/index.js.map +1 -1
- package/Skeleton/index.cjs +60 -0
- package/Skeleton/index.cjs.map +1 -0
- package/Skeleton/index.js +7 -9
- package/Skeleton/index.js.map +1 -1
- package/Stack/index.cjs +17 -0
- package/Stack/index.cjs.map +1 -0
- package/Stack/index.js +7 -9
- package/Stack/index.js.map +1 -1
- package/Switch/index.cjs +79 -0
- package/Switch/index.cjs.map +1 -0
- package/Switch/index.js +12 -14
- package/Switch/index.js.map +1 -1
- package/Tab/index.cjs +17 -0
- package/Tab/index.cjs.map +1 -0
- package/Tab/index.js +9 -11
- package/Tab/index.js.map +1 -1
- package/Table/index.cjs +88 -0
- package/Table/index.cjs.map +1 -0
- package/Table/index.js +13 -15
- package/Table/index.js.map +1 -1
- package/TableBody/index.cjs +14 -0
- package/TableBody/index.cjs.map +1 -0
- package/TableBody/index.js +7 -9
- package/TableBody/index.js.map +1 -1
- package/TableCell/index.cjs +14 -0
- package/TableCell/index.cjs.map +1 -0
- package/TableCell/index.js +7 -9
- package/TableCell/index.js.map +1 -1
- package/TableFooter/index.cjs +14 -0
- package/TableFooter/index.cjs.map +1 -0
- package/TableFooter/index.js +7 -9
- package/TableFooter/index.js.map +1 -1
- package/TableHead/index.cjs +14 -0
- package/TableHead/index.cjs.map +1 -0
- package/TableHead/index.js +7 -9
- package/TableHead/index.js.map +1 -1
- package/TablePagination/index.cjs +59 -0
- package/TablePagination/index.cjs.map +1 -0
- package/TablePagination/index.js +21 -23
- package/TablePagination/index.js.map +1 -1
- package/TableRow/index.cjs +14 -0
- package/TableRow/index.cjs.map +1 -0
- package/TableRow/index.js +7 -9
- package/TableRow/index.js.map +1 -1
- package/Tabs/index.cjs +201 -0
- package/Tabs/index.cjs.map +1 -0
- package/Tabs/index.js +19 -21
- package/Tabs/index.js.map +1 -1
- package/Text/index.cjs +25 -0
- package/Text/index.cjs.map +1 -0
- package/Text/index.js +8 -10
- package/Text/index.js.map +1 -1
- package/Toast/index.cjs +120 -0
- package/Toast/index.cjs.map +1 -0
- package/Toast/index.js +18 -20
- package/Toast/index.js.map +1 -1
- package/Tooltip/index.cjs +40 -0
- package/Tooltip/index.cjs.map +1 -0
- package/Tooltip/index.js +11 -13
- package/Tooltip/index.js.map +1 -1
- package/ViewBox/index.cjs +32 -0
- package/ViewBox/index.cjs.map +1 -0
- package/ViewBox/index.js +11 -13
- package/ViewBox/index.js.map +1 -1
- package/index.cjs +134 -0
- package/index.cjs.map +1 -0
- package/index.js +64 -133
- package/index.js.map +1 -1
- package/package.json +3 -3
- package/readme.md +4 -4
- package/useAlert/index.cjs +94 -0
- package/useAlert/index.cjs.map +1 -0
- package/useAlert/index.js +12 -14
- package/useAlert/index.js.map +1 -1
- package/useBlurCss/index.cjs +19 -0
- package/useBlurCss/index.cjs.map +1 -0
- package/useBlurCss/index.js +5 -7
- package/useBlurCss/index.js.map +1 -1
- package/useCorner/index.cjs +22 -0
- package/useCorner/index.cjs.map +1 -0
- package/useCorner/index.js +1 -3
- package/useCorner/index.js.map +1 -1
- package/useLayer/index.cjs +38 -0
- package/useLayer/index.cjs.map +1 -0
- package/useLayer/index.js +7 -9
- package/useLayer/index.js.map +1 -1
- package/useModal/index.cjs +37 -0
- package/useModal/index.cjs.map +1 -0
- package/useModal/index.js +8 -10
- package/useModal/index.js.map +1 -1
|
@@ -0,0 +1,58 @@
|
|
|
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 CheckIcon = require('@xanui/icons/CheckBox');
|
|
9
|
+
var UnCheckIcon = require('@xanui/icons/CheckBoxOutlineBlank');
|
|
10
|
+
var IndeterminateCheckBoxIcon = require('@xanui/icons/IndeterminateCheckBox');
|
|
11
|
+
|
|
12
|
+
const Checkbox = React.forwardRef((props, ref) => {
|
|
13
|
+
let [_a] = core.useInterface("Checkbox", props, {}), { color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange } = _a, rest = tslib.__rest(_a, ["color", "size", "checkIcon", "uncheckIcon", "checked", "indeterminate", "disabled", "onChange"]);
|
|
14
|
+
const _p = {};
|
|
15
|
+
if (checkIcon)
|
|
16
|
+
_p.checkIcon = checkIcon;
|
|
17
|
+
if (uncheckIcon)
|
|
18
|
+
_p.uncheckIcon = uncheckIcon;
|
|
19
|
+
if (indeterminate)
|
|
20
|
+
_p.indeterminate = indeterminate;
|
|
21
|
+
if (size)
|
|
22
|
+
_p.size = size;
|
|
23
|
+
if (color)
|
|
24
|
+
_p.color = color;
|
|
25
|
+
const p = core.useBreakpointProps(_p);
|
|
26
|
+
checkIcon = p.checkIcon;
|
|
27
|
+
uncheckIcon = p.uncheckIcon;
|
|
28
|
+
indeterminate = p.indeterminate;
|
|
29
|
+
size = p.size;
|
|
30
|
+
color = p.color;
|
|
31
|
+
const [c, set] = React.useState(false);
|
|
32
|
+
checked !== null && checked !== void 0 ? checked : (checked = c);
|
|
33
|
+
size !== null && size !== void 0 ? size : (size = "medium");
|
|
34
|
+
color !== null && color !== void 0 ? color : (color = "brand");
|
|
35
|
+
onChange = onChange || (() => set(!c));
|
|
36
|
+
if (indeterminate) {
|
|
37
|
+
checked = true;
|
|
38
|
+
checkIcon = jsxRuntime.jsx(IndeterminateCheckBoxIcon, {});
|
|
39
|
+
}
|
|
40
|
+
let sizes = {
|
|
41
|
+
small: 22,
|
|
42
|
+
medium: 24,
|
|
43
|
+
large: 32
|
|
44
|
+
};
|
|
45
|
+
if (typeof size === 'string' && sizes[size]) {
|
|
46
|
+
size = sizes[size];
|
|
47
|
+
}
|
|
48
|
+
return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(core.Tag, { baseClass: 'checkbox', onClick: () => {
|
|
49
|
+
onChange && onChange();
|
|
50
|
+
}, sxr: Object.assign({ height: size, width: size, display: "flex", alignItems: "center", justifyContent: "center", color: checked ? color : "text.secondary", cursor: "pointer", disabled: disabled, "& svg": {
|
|
51
|
+
fontSize: size
|
|
52
|
+
} }, rest === null || rest === void 0 ? void 0 : rest.sx), children: checked ? (checkIcon || jsxRuntime.jsx(CheckIcon, {})) : (uncheckIcon || jsxRuntime.jsx(UnCheckIcon, {})) }), jsxRuntime.jsx(core.Tag, Object.assign({}, rest, { component: 'input', ref: ref, readOnly: true, type: "checkbox", checked: checked, sxr: {
|
|
53
|
+
display: "none!important"
|
|
54
|
+
} }))] }));
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
module.exports = Checkbox;
|
|
58
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../../src/Checkbox/index.tsx"],"sourcesContent":["'use client'\r\nimport React, { useState, ReactElement } from 'react';\r\nimport { Tag, useInterface, UseColorTemplateColor, TagProps, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport CheckIcon from '@xanui/icons/CheckBox'\r\nimport UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank'\r\nimport IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';\r\n\r\n\r\nexport type CheckboxProps = Omit<TagProps<\"input\">, \"color\" | \"size\" | \"component\" | \"type\" | \"checked\"> & {\r\n checkIcon?: useBreakpointPropsType<ReactElement>;\r\n uncheckIcon?: useBreakpointPropsType<ReactElement>;\r\n indeterminate?: useBreakpointPropsType<boolean>;\r\n checked?: boolean;\r\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n}\r\n\r\nconst Checkbox = React.forwardRef((props: CheckboxProps, ref?: React.Ref<any>) => {\r\n let [{ color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange, ...rest }] = useInterface<any>(\"Checkbox\", props, {})\r\n const _p: any = {}\r\n if (checkIcon) _p.checkIcon = checkIcon\r\n if (uncheckIcon) _p.uncheckIcon = uncheckIcon\r\n if (indeterminate) _p.indeterminate = indeterminate\r\n if (size) _p.size = size\r\n if (color) _p.color = color\r\n const p: any = useBreakpointProps(_p)\r\n\r\n checkIcon = p.checkIcon\r\n uncheckIcon = p.uncheckIcon\r\n indeterminate = p.indeterminate\r\n size = p.size\r\n color = p.color\r\n\r\n const [c, set] = useState(false)\r\n checked ??= c\r\n size ??= \"medium\"\r\n color ??= \"brand\"\r\n\r\n onChange = onChange || (() => set(!c));\r\n if (indeterminate) {\r\n checked = true\r\n checkIcon = <IndeterminateCheckBoxIcon />\r\n }\r\n\r\n let sizes: any = {\r\n small: 22,\r\n medium: 24,\r\n large: 32\r\n }\r\n\r\n if (typeof size === 'string' && sizes[size]) {\r\n size = sizes[size]\r\n }\r\n\r\n return (\r\n <>\r\n <Tag\r\n baseClass='checkbox'\r\n onClick={() => {\r\n onChange && onChange()\r\n }}\r\n sxr={{\r\n height: size,\r\n width: size,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n color: checked ? color : \"text.secondary\",\r\n cursor: \"pointer\",\r\n disabled: disabled,\r\n \"& svg\": {\r\n fontSize: size\r\n },\r\n ...rest?.sx\r\n }}\r\n >\r\n {checked ? (checkIcon || <CheckIcon />) : (uncheckIcon || <UnCheckIcon />)}\r\n </Tag>\r\n <Tag\r\n {...rest}\r\n component='input'\r\n ref={ref}\r\n readOnly\r\n type=\"checkbox\"\r\n checked={checked}\r\n sxr={{\r\n display: \"none!important\"\r\n }}\r\n />\r\n </>\r\n )\r\n})\r\n\r\nexport default Checkbox\r\n"],"names":[],"mappings":";;;;;;;;;;;AAiBA;AACI;;AAEA;AAAe;AACf;AAAiB;AACjB;AAAmB;AACnB;AAAU;AACV;AAAW;AACX;AAEA;AACA;AACA;AACA;AACA;;;;;AAOA;;;AAGI;;AAGJ;AACI;AACA;AACA;;;AAIA;;AAGJ;;;AAiBoB;;AAeJ;;AAKpB;;"}
|
package/Checkbox/index.js
CHANGED
|
@@ -1,16 +1,14 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
var UnCheckIcon = require('@xanui/icons/CheckBoxOutlineBlank');
|
|
10
|
-
var IndeterminateCheckBoxIcon = require('@xanui/icons/IndeterminateCheckBox');
|
|
2
|
+
import { __rest } from 'tslib';
|
|
3
|
+
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
4
|
+
import React, { useState } from 'react';
|
|
5
|
+
import { useInterface, useBreakpointProps, Tag } from '@xanui/core';
|
|
6
|
+
import CheckIcon from '@xanui/icons/CheckBox';
|
|
7
|
+
import UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank';
|
|
8
|
+
import IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';
|
|
11
9
|
|
|
12
10
|
const Checkbox = React.forwardRef((props, ref) => {
|
|
13
|
-
let [_a] =
|
|
11
|
+
let [_a] = useInterface("Checkbox", props, {}), { color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange } = _a, rest = __rest(_a, ["color", "size", "checkIcon", "uncheckIcon", "checked", "indeterminate", "disabled", "onChange"]);
|
|
14
12
|
const _p = {};
|
|
15
13
|
if (checkIcon)
|
|
16
14
|
_p.checkIcon = checkIcon;
|
|
@@ -22,20 +20,20 @@ const Checkbox = React.forwardRef((props, ref) => {
|
|
|
22
20
|
_p.size = size;
|
|
23
21
|
if (color)
|
|
24
22
|
_p.color = color;
|
|
25
|
-
const p =
|
|
23
|
+
const p = useBreakpointProps(_p);
|
|
26
24
|
checkIcon = p.checkIcon;
|
|
27
25
|
uncheckIcon = p.uncheckIcon;
|
|
28
26
|
indeterminate = p.indeterminate;
|
|
29
27
|
size = p.size;
|
|
30
28
|
color = p.color;
|
|
31
|
-
const [c, set] =
|
|
29
|
+
const [c, set] = useState(false);
|
|
32
30
|
checked !== null && checked !== void 0 ? checked : (checked = c);
|
|
33
31
|
size !== null && size !== void 0 ? size : (size = "medium");
|
|
34
32
|
color !== null && color !== void 0 ? color : (color = "brand");
|
|
35
33
|
onChange = onChange || (() => set(!c));
|
|
36
34
|
if (indeterminate) {
|
|
37
35
|
checked = true;
|
|
38
|
-
checkIcon =
|
|
36
|
+
checkIcon = jsx(IndeterminateCheckBoxIcon, {});
|
|
39
37
|
}
|
|
40
38
|
let sizes = {
|
|
41
39
|
small: 22,
|
|
@@ -45,14 +43,14 @@ const Checkbox = React.forwardRef((props, ref) => {
|
|
|
45
43
|
if (typeof size === 'string' && sizes[size]) {
|
|
46
44
|
size = sizes[size];
|
|
47
45
|
}
|
|
48
|
-
return (
|
|
46
|
+
return (jsxs(Fragment, { children: [jsx(Tag, { baseClass: 'checkbox', onClick: () => {
|
|
49
47
|
onChange && onChange();
|
|
50
48
|
}, sxr: Object.assign({ height: size, width: size, display: "flex", alignItems: "center", justifyContent: "center", color: checked ? color : "text.secondary", cursor: "pointer", disabled: disabled, "& svg": {
|
|
51
49
|
fontSize: size
|
|
52
|
-
} }, rest === null || rest === void 0 ? void 0 : rest.sx), children: checked ? (checkIcon ||
|
|
50
|
+
} }, rest === null || rest === void 0 ? void 0 : rest.sx), children: checked ? (checkIcon || jsx(CheckIcon, {})) : (uncheckIcon || jsx(UnCheckIcon, {})) }), jsx(Tag, Object.assign({}, rest, { component: 'input', ref: ref, readOnly: true, type: "checkbox", checked: checked, sxr: {
|
|
53
51
|
display: "none!important"
|
|
54
52
|
} }))] }));
|
|
55
53
|
});
|
|
56
54
|
|
|
57
|
-
|
|
55
|
+
export { Checkbox as default };
|
|
58
56
|
//# sourceMappingURL=index.js.map
|
package/Checkbox/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/Checkbox/index.tsx"],"sourcesContent":["
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/Checkbox/index.tsx"],"sourcesContent":["'use client'\r\nimport React, { useState, ReactElement } from 'react';\r\nimport { Tag, useInterface, UseColorTemplateColor, TagProps, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport CheckIcon from '@xanui/icons/CheckBox'\r\nimport UnCheckIcon from '@xanui/icons/CheckBoxOutlineBlank'\r\nimport IndeterminateCheckBoxIcon from '@xanui/icons/IndeterminateCheckBox';\r\n\r\n\r\nexport type CheckboxProps = Omit<TagProps<\"input\">, \"color\" | \"size\" | \"component\" | \"type\" | \"checked\"> & {\r\n checkIcon?: useBreakpointPropsType<ReactElement>;\r\n uncheckIcon?: useBreakpointPropsType<ReactElement>;\r\n indeterminate?: useBreakpointPropsType<boolean>;\r\n checked?: boolean;\r\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n}\r\n\r\nconst Checkbox = React.forwardRef((props: CheckboxProps, ref?: React.Ref<any>) => {\r\n let [{ color, size, checkIcon, uncheckIcon, checked, indeterminate, disabled, onChange, ...rest }] = useInterface<any>(\"Checkbox\", props, {})\r\n const _p: any = {}\r\n if (checkIcon) _p.checkIcon = checkIcon\r\n if (uncheckIcon) _p.uncheckIcon = uncheckIcon\r\n if (indeterminate) _p.indeterminate = indeterminate\r\n if (size) _p.size = size\r\n if (color) _p.color = color\r\n const p: any = useBreakpointProps(_p)\r\n\r\n checkIcon = p.checkIcon\r\n uncheckIcon = p.uncheckIcon\r\n indeterminate = p.indeterminate\r\n size = p.size\r\n color = p.color\r\n\r\n const [c, set] = useState(false)\r\n checked ??= c\r\n size ??= \"medium\"\r\n color ??= \"brand\"\r\n\r\n onChange = onChange || (() => set(!c));\r\n if (indeterminate) {\r\n checked = true\r\n checkIcon = <IndeterminateCheckBoxIcon />\r\n }\r\n\r\n let sizes: any = {\r\n small: 22,\r\n medium: 24,\r\n large: 32\r\n }\r\n\r\n if (typeof size === 'string' && sizes[size]) {\r\n size = sizes[size]\r\n }\r\n\r\n return (\r\n <>\r\n <Tag\r\n baseClass='checkbox'\r\n onClick={() => {\r\n onChange && onChange()\r\n }}\r\n sxr={{\r\n height: size,\r\n width: size,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n color: checked ? color : \"text.secondary\",\r\n cursor: \"pointer\",\r\n disabled: disabled,\r\n \"& svg\": {\r\n fontSize: size\r\n },\r\n ...rest?.sx\r\n }}\r\n >\r\n {checked ? (checkIcon || <CheckIcon />) : (uncheckIcon || <UnCheckIcon />)}\r\n </Tag>\r\n <Tag\r\n {...rest}\r\n component='input'\r\n ref={ref}\r\n readOnly\r\n type=\"checkbox\"\r\n checked={checked}\r\n sxr={{\r\n display: \"none!important\"\r\n }}\r\n />\r\n </>\r\n )\r\n})\r\n\r\nexport default Checkbox\r\n"],"names":[],"mappings":";;;;;;;;;AAiBA;AACI;;AAEA;AAAe;AACf;AAAiB;AACjB;AAAmB;AACnB;AAAU;AACV;AAAW;AACX;AAEA;AACA;AACA;AACA;AACA;;;;;AAOA;;;AAGI;;AAGJ;AACI;AACA;AACA;;;AAIA;;AAGJ;;;AAiBoB;;AAeJ;;AAKpB;;"}
|
package/Chip/index.cjs
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
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 index = require('../useCorner/index.cjs');
|
|
8
|
+
|
|
9
|
+
const Chip = React.forwardRef((props, ref) => {
|
|
10
|
+
let [_a] = core.useInterface("Chip", props, {}), { label, variant, startIcon, endIcon, color, corner, size } = _a, rest = tslib.__rest(_a, ["label", "variant", "startIcon", "endIcon", "color", "corner", "size"]);
|
|
11
|
+
const _p = {};
|
|
12
|
+
if (label)
|
|
13
|
+
_p.label = label;
|
|
14
|
+
if (startIcon)
|
|
15
|
+
_p.startIcon = startIcon;
|
|
16
|
+
if (endIcon)
|
|
17
|
+
_p.endIcon = endIcon;
|
|
18
|
+
if (color)
|
|
19
|
+
_p.color = color;
|
|
20
|
+
if (variant)
|
|
21
|
+
_p.variant = variant;
|
|
22
|
+
if (corner)
|
|
23
|
+
_p.corner = corner;
|
|
24
|
+
if (size)
|
|
25
|
+
_p.size = size;
|
|
26
|
+
const p = core.useBreakpointProps(_p);
|
|
27
|
+
label = p.label;
|
|
28
|
+
startIcon = p.startIcon;
|
|
29
|
+
endIcon = p.endIcon;
|
|
30
|
+
color = p.color || "brand";
|
|
31
|
+
variant = p.variant || "fill";
|
|
32
|
+
corner = p.corner || "circle";
|
|
33
|
+
size = p.size || "medium";
|
|
34
|
+
rest.sx = rest.sx || {};
|
|
35
|
+
const cornerCss = index(corner);
|
|
36
|
+
const template = core.useColorTemplate(color, variant);
|
|
37
|
+
const sizes = {
|
|
38
|
+
small: {
|
|
39
|
+
height: 24,
|
|
40
|
+
gap: .5,
|
|
41
|
+
px: startIcon || endIcon ? .8 : 1,
|
|
42
|
+
fontSize: "small"
|
|
43
|
+
},
|
|
44
|
+
medium: {
|
|
45
|
+
height: 32,
|
|
46
|
+
gap: 1,
|
|
47
|
+
px: startIcon || endIcon ? .8 : 1.5,
|
|
48
|
+
fontSize: 'button',
|
|
49
|
+
},
|
|
50
|
+
large: {
|
|
51
|
+
height: 40,
|
|
52
|
+
fontSize: 'text',
|
|
53
|
+
gap: 1,
|
|
54
|
+
px: startIcon || endIcon ? .8 : 1.5,
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
return (jsxRuntime.jsxs(core.Tag, Object.assign({}, cornerCss, template.primary, (sizes[size] || {}), rest, { sxr: {
|
|
58
|
+
display: "inline-flex",
|
|
59
|
+
flexDirection: "row",
|
|
60
|
+
alignItems: "center",
|
|
61
|
+
transition: "background .3s",
|
|
62
|
+
overflow: "hidden",
|
|
63
|
+
"& > *": {
|
|
64
|
+
flex: "0 0 auto",
|
|
65
|
+
textOverflow: "ellipsis",
|
|
66
|
+
whiteSpace: "nowrap",
|
|
67
|
+
overflow: "hidden",
|
|
68
|
+
},
|
|
69
|
+
}, baseClass: 'chip', ref: ref, children: [startIcon, jsxRuntime.jsx(core.Tag, { sxr: {
|
|
70
|
+
alignItems: "center",
|
|
71
|
+
flexBox: true
|
|
72
|
+
}, children: label }), endIcon] })));
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
module.exports = Chip;
|
|
76
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../../src/Chip/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\r\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, UseColorTemplateColor, UseColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport useCorner, { UseCornerTypes } from '../useCorner'\r\n\r\n\r\n\r\nexport type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, \"color\" | \"children\" | \"size\"> & {\r\n label: useBreakpointPropsType<string | ReactElement>;\r\n startIcon?: useBreakpointPropsType<ReactElement>;\r\n endIcon?: useBreakpointPropsType<ReactElement>;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n corner?: useBreakpointPropsType<UseCornerTypes>;\r\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\r\n}\r\n\r\n\r\nconst Chip = React.forwardRef(<T extends TagComponentType = 'div'>(props: ChipProps<T>, ref: React.Ref<any>) => {\r\n let [{ label, variant, startIcon, endIcon, color, corner, size, ...rest }] = useInterface<any>(\"Chip\", props, {})\r\n const _p: any = {}\r\n if (label) _p.label = label\r\n if (startIcon) _p.startIcon = startIcon\r\n if (endIcon) _p.endIcon = endIcon\r\n if (color) _p.color = color\r\n if (variant) _p.variant = variant\r\n if (corner) _p.corner = corner\r\n if (size) _p.size = size\r\n const p: any = useBreakpointProps(_p)\r\n\r\n label = p.label\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n color = p.color || \"brand\"\r\n variant = p.variant || \"fill\"\r\n corner = p.corner || \"circle\"\r\n size = p.size || \"medium\"\r\n rest.sx = (rest as any).sx || {};\r\n\r\n const cornerCss = useCorner(corner)\r\n const template = useColorTemplate(color, variant)\r\n\r\n const sizes: any = {\r\n small: {\r\n height: 24,\r\n gap: .5,\r\n px: startIcon || endIcon ? .8 : 1,\r\n fontSize: \"small\"\r\n },\r\n medium: {\r\n height: 32,\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n fontSize: 'button',\r\n },\r\n large: {\r\n height: 40,\r\n fontSize: 'text',\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n }\r\n }\r\n\r\n return (\r\n <Tag\r\n {...cornerCss}\r\n {...template.primary}\r\n {...(sizes[size as any] || {})}\r\n {...rest}\r\n sxr={{\r\n display: \"inline-flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n transition: \"background .3s\",\r\n overflow: \"hidden\",\r\n\r\n \"& > *\": {\r\n flex: \"0 0 auto\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n overflow: \"hidden\",\r\n },\r\n }}\r\n baseClass='chip'\r\n ref={ref}\r\n >\r\n {startIcon}\r\n <Tag\r\n sxr={{\r\n alignItems: \"center\",\r\n flexBox: true\r\n }}\r\n >{label}</Tag>\r\n {endIcon}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default Chip\r\n"],"names":["useInterface","__rest","useBreakpointProps","useCorner","useColorTemplate","_jsxs","Tag","_jsx"],"mappings":"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"}
|
package/Chip/index.js
CHANGED
|
@@ -1,13 +1,11 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
var core = require('@xanui/core');
|
|
7
|
-
var index = require('../useCorner/index.js');
|
|
1
|
+
import { __rest } from 'tslib';
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { useInterface, useBreakpointProps, useColorTemplate, Tag } from '@xanui/core';
|
|
5
|
+
import useCorner from '../useCorner/index.js';
|
|
8
6
|
|
|
9
7
|
const Chip = React.forwardRef((props, ref) => {
|
|
10
|
-
let [_a] =
|
|
8
|
+
let [_a] = useInterface("Chip", props, {}), { label, variant, startIcon, endIcon, color, corner, size } = _a, rest = __rest(_a, ["label", "variant", "startIcon", "endIcon", "color", "corner", "size"]);
|
|
11
9
|
const _p = {};
|
|
12
10
|
if (label)
|
|
13
11
|
_p.label = label;
|
|
@@ -23,7 +21,7 @@ const Chip = React.forwardRef((props, ref) => {
|
|
|
23
21
|
_p.corner = corner;
|
|
24
22
|
if (size)
|
|
25
23
|
_p.size = size;
|
|
26
|
-
const p =
|
|
24
|
+
const p = useBreakpointProps(_p);
|
|
27
25
|
label = p.label;
|
|
28
26
|
startIcon = p.startIcon;
|
|
29
27
|
endIcon = p.endIcon;
|
|
@@ -32,8 +30,8 @@ const Chip = React.forwardRef((props, ref) => {
|
|
|
32
30
|
corner = p.corner || "circle";
|
|
33
31
|
size = p.size || "medium";
|
|
34
32
|
rest.sx = rest.sx || {};
|
|
35
|
-
const cornerCss =
|
|
36
|
-
const template =
|
|
33
|
+
const cornerCss = useCorner(corner);
|
|
34
|
+
const template = useColorTemplate(color, variant);
|
|
37
35
|
const sizes = {
|
|
38
36
|
small: {
|
|
39
37
|
height: 24,
|
|
@@ -54,7 +52,7 @@ const Chip = React.forwardRef((props, ref) => {
|
|
|
54
52
|
px: startIcon || endIcon ? .8 : 1.5,
|
|
55
53
|
}
|
|
56
54
|
};
|
|
57
|
-
return (
|
|
55
|
+
return (jsxs(Tag, Object.assign({}, cornerCss, template.primary, (sizes[size] || {}), rest, { sxr: {
|
|
58
56
|
display: "inline-flex",
|
|
59
57
|
flexDirection: "row",
|
|
60
58
|
alignItems: "center",
|
|
@@ -66,11 +64,11 @@ const Chip = React.forwardRef((props, ref) => {
|
|
|
66
64
|
whiteSpace: "nowrap",
|
|
67
65
|
overflow: "hidden",
|
|
68
66
|
},
|
|
69
|
-
}, baseClass: 'chip', ref: ref, children: [startIcon,
|
|
67
|
+
}, baseClass: 'chip', ref: ref, children: [startIcon, jsx(Tag, { sxr: {
|
|
70
68
|
alignItems: "center",
|
|
71
69
|
flexBox: true
|
|
72
70
|
}, children: label }), endIcon] })));
|
|
73
71
|
});
|
|
74
72
|
|
|
75
|
-
|
|
73
|
+
export { Chip as default };
|
|
76
74
|
//# sourceMappingURL=index.js.map
|
package/Chip/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/Chip/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\r\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, UseColorTemplateColor, UseColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport useCorner, { UseCornerTypes } from '../useCorner'\r\n\r\n\r\n\r\nexport type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, \"color\" | \"children\" | \"size\"> & {\r\n label: useBreakpointPropsType<string | ReactElement>;\r\n startIcon?: useBreakpointPropsType<ReactElement>;\r\n endIcon?: useBreakpointPropsType<ReactElement>;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n corner?: useBreakpointPropsType<UseCornerTypes>;\r\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\r\n}\r\n\r\n\r\nconst Chip = React.forwardRef(<T extends TagComponentType = 'div'>(props: ChipProps<T>, ref: React.Ref<any>) => {\r\n let [{ label, variant, startIcon, endIcon, color, corner, size, ...rest }] = useInterface<any>(\"Chip\", props, {})\r\n const _p: any = {}\r\n if (label) _p.label = label\r\n if (startIcon) _p.startIcon = startIcon\r\n if (endIcon) _p.endIcon = endIcon\r\n if (color) _p.color = color\r\n if (variant) _p.variant = variant\r\n if (corner) _p.corner = corner\r\n if (size) _p.size = size\r\n const p: any = useBreakpointProps(_p)\r\n\r\n label = p.label\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n color = p.color || \"brand\"\r\n variant = p.variant || \"fill\"\r\n corner = p.corner || \"circle\"\r\n size = p.size || \"medium\"\r\n rest.sx = (rest as any).sx || {};\r\n\r\n const cornerCss = useCorner(corner)\r\n const template = useColorTemplate(color, variant)\r\n\r\n const sizes: any = {\r\n small: {\r\n height: 24,\r\n gap: .5,\r\n px: startIcon || endIcon ? .8 : 1,\r\n fontSize: \"small\"\r\n },\r\n medium: {\r\n height: 32,\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n fontSize: 'button',\r\n },\r\n large: {\r\n height: 40,\r\n fontSize: 'text',\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n }\r\n }\r\n\r\n return (\r\n <Tag\r\n {...cornerCss}\r\n {...template.primary}\r\n {...(sizes[size as any] || {})}\r\n {...rest}\r\n sxr={{\r\n display: \"inline-flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n transition: \"background .3s\",\r\n overflow: \"hidden\",\r\n\r\n \"& > *\": {\r\n flex: \"0 0 auto\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n overflow: \"hidden\",\r\n },\r\n }}\r\n baseClass='chip'\r\n ref={ref}\r\n >\r\n {startIcon}\r\n <Tag\r\n sxr={{\r\n alignItems: \"center\",\r\n flexBox: true\r\n }}\r\n >{label}</Tag>\r\n {endIcon}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default Chip\r\n"],"names":["
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/Chip/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\r\nimport { Tag, TagProps, TagComponentType, useInterface, useColorTemplate, UseColorTemplateColor, UseColorTemplateType, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\nimport useCorner, { UseCornerTypes } from '../useCorner'\r\n\r\n\r\n\r\nexport type ChipProps<T extends TagComponentType = 'div'> = Omit<TagProps<T>, \"color\" | \"children\" | \"size\"> & {\r\n label: useBreakpointPropsType<string | ReactElement>;\r\n startIcon?: useBreakpointPropsType<ReactElement>;\r\n endIcon?: useBreakpointPropsType<ReactElement>;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n variant?: useBreakpointPropsType<UseColorTemplateType>;\r\n corner?: useBreakpointPropsType<UseCornerTypes>;\r\n size?: useBreakpointPropsType<\"small\" | \"medium\" | \"large\">;\r\n}\r\n\r\n\r\nconst Chip = React.forwardRef(<T extends TagComponentType = 'div'>(props: ChipProps<T>, ref: React.Ref<any>) => {\r\n let [{ label, variant, startIcon, endIcon, color, corner, size, ...rest }] = useInterface<any>(\"Chip\", props, {})\r\n const _p: any = {}\r\n if (label) _p.label = label\r\n if (startIcon) _p.startIcon = startIcon\r\n if (endIcon) _p.endIcon = endIcon\r\n if (color) _p.color = color\r\n if (variant) _p.variant = variant\r\n if (corner) _p.corner = corner\r\n if (size) _p.size = size\r\n const p: any = useBreakpointProps(_p)\r\n\r\n label = p.label\r\n startIcon = p.startIcon\r\n endIcon = p.endIcon\r\n color = p.color || \"brand\"\r\n variant = p.variant || \"fill\"\r\n corner = p.corner || \"circle\"\r\n size = p.size || \"medium\"\r\n rest.sx = (rest as any).sx || {};\r\n\r\n const cornerCss = useCorner(corner)\r\n const template = useColorTemplate(color, variant)\r\n\r\n const sizes: any = {\r\n small: {\r\n height: 24,\r\n gap: .5,\r\n px: startIcon || endIcon ? .8 : 1,\r\n fontSize: \"small\"\r\n },\r\n medium: {\r\n height: 32,\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n fontSize: 'button',\r\n },\r\n large: {\r\n height: 40,\r\n fontSize: 'text',\r\n gap: 1,\r\n px: startIcon || endIcon ? .8 : 1.5,\r\n }\r\n }\r\n\r\n return (\r\n <Tag\r\n {...cornerCss}\r\n {...template.primary}\r\n {...(sizes[size as any] || {})}\r\n {...rest}\r\n sxr={{\r\n display: \"inline-flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n transition: \"background .3s\",\r\n overflow: \"hidden\",\r\n\r\n \"& > *\": {\r\n flex: \"0 0 auto\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n overflow: \"hidden\",\r\n },\r\n }}\r\n baseClass='chip'\r\n ref={ref}\r\n >\r\n {startIcon}\r\n <Tag\r\n sxr={{\r\n alignItems: \"center\",\r\n flexBox: true\r\n }}\r\n >{label}</Tag>\r\n {endIcon}\r\n </Tag>\r\n )\r\n})\r\n\r\nexport default Chip\r\n"],"names":["_jsxs","_jsx"],"mappings":"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"}
|
|
@@ -0,0 +1,129 @@
|
|
|
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
|
+
|
|
9
|
+
const CircleProgress = React.forwardRef((_a, ref) => {
|
|
10
|
+
var _b, _c, _d, _e;
|
|
11
|
+
var { children } = _a, props = tslib.__rest(_a, ["children"]);
|
|
12
|
+
let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = core.useInterface("CircleProgress", props, {});
|
|
13
|
+
const _p = {};
|
|
14
|
+
if (color)
|
|
15
|
+
_p.color = color;
|
|
16
|
+
if (trackColor)
|
|
17
|
+
_p.trackColor = trackColor;
|
|
18
|
+
if (thumbColor)
|
|
19
|
+
_p.thumbColor = thumbColor;
|
|
20
|
+
if (size)
|
|
21
|
+
_p.size = size;
|
|
22
|
+
if (thumbSize)
|
|
23
|
+
_p.thumbSize = thumbSize;
|
|
24
|
+
if (trackSize)
|
|
25
|
+
_p.trackSize = trackSize;
|
|
26
|
+
if (value)
|
|
27
|
+
_p.value = value;
|
|
28
|
+
if (hideTrack)
|
|
29
|
+
_p.hideTrack = hideTrack;
|
|
30
|
+
if (showPercentage)
|
|
31
|
+
_p.showPercentage = showPercentage;
|
|
32
|
+
if (speed)
|
|
33
|
+
_p.speed = speed;
|
|
34
|
+
const p = core.useBreakpointProps(_p);
|
|
35
|
+
color = (_b = p.color) !== null && _b !== void 0 ? _b : "brand";
|
|
36
|
+
trackColor = p.trackColor;
|
|
37
|
+
thumbColor = p.thumbColor;
|
|
38
|
+
size = (_c = p.size) !== null && _c !== void 0 ? _c : "medium";
|
|
39
|
+
thumbSize = (_d = p.thumbSize) !== null && _d !== void 0 ? _d : 4;
|
|
40
|
+
trackSize = p.trackSize;
|
|
41
|
+
value = p.value;
|
|
42
|
+
hideTrack = p.hideTrack;
|
|
43
|
+
showPercentage = p.showPercentage;
|
|
44
|
+
speed = (_e = p.speed) !== null && _e !== void 0 ? _e : 1.3;
|
|
45
|
+
if (trackColor === 'default') {
|
|
46
|
+
trackColor = "divider";
|
|
47
|
+
}
|
|
48
|
+
if (thumbColor === 'default') {
|
|
49
|
+
thumbColor = "divider.secondary";
|
|
50
|
+
}
|
|
51
|
+
let sizes = {
|
|
52
|
+
small: 24,
|
|
53
|
+
medium: 32,
|
|
54
|
+
large: 44
|
|
55
|
+
};
|
|
56
|
+
if (typeof size === 'string' && sizes[size]) {
|
|
57
|
+
size = sizes[size];
|
|
58
|
+
}
|
|
59
|
+
let isVal = typeof value === 'number';
|
|
60
|
+
const animrotate = "anim" + React.useId().replace(":", "");
|
|
61
|
+
const animdash = "anim" + React.useId().replace(":", "");
|
|
62
|
+
if (isVal && value > 100)
|
|
63
|
+
value = 100;
|
|
64
|
+
const circumference = 125.66370614359172; //radius * 2 * Math.PI
|
|
65
|
+
const percent = circumference - ((value || 0) / 100) * circumference;
|
|
66
|
+
if (showPercentage && !children) {
|
|
67
|
+
children = jsxRuntime.jsxs(core.Tag, { sxr: {
|
|
68
|
+
color: color === 'default' ? "text.primary" : `${color}.primary`,
|
|
69
|
+
fontSize: size / 4
|
|
70
|
+
}, children: [value, "%"] });
|
|
71
|
+
}
|
|
72
|
+
return (jsxRuntime.jsxs(core.Tag, { baseClass: 'circle-progress', sxr: {
|
|
73
|
+
display: "inline-flex",
|
|
74
|
+
alignItems: "center",
|
|
75
|
+
justifyContent: "center",
|
|
76
|
+
"& svg[class='circle-progress-svg']": {
|
|
77
|
+
zIndex: 1,
|
|
78
|
+
position: "absolute",
|
|
79
|
+
top: 0,
|
|
80
|
+
left: 0,
|
|
81
|
+
width: "100%",
|
|
82
|
+
height: "100%",
|
|
83
|
+
transform: isVal ? "rotate(-90deg)" : "none",
|
|
84
|
+
transformOrigin: isVal ? "center" : "initial",
|
|
85
|
+
animation: isVal ? "none" : `${animrotate} ${speed}s linear infinite`,
|
|
86
|
+
[`@keyframes ${animrotate}`]: {
|
|
87
|
+
"100%": {
|
|
88
|
+
transform: "rotate(360deg)"
|
|
89
|
+
}
|
|
90
|
+
},
|
|
91
|
+
"& circle.circle-progress-thumb": {
|
|
92
|
+
strokeDasharray: circumference,
|
|
93
|
+
strokeDashoffset: percent,
|
|
94
|
+
stroke: thumbColor || (color === 'default' ? `divider` : `${color}.primary`),
|
|
95
|
+
fill: "none",
|
|
96
|
+
strokeWidth: thumbSize,
|
|
97
|
+
strokeLinecap: "round",
|
|
98
|
+
animation: isVal ? "none" : `${animdash} ${speed}s ease-in-out infinite`,
|
|
99
|
+
[`@keyframes ${animdash}`]: {
|
|
100
|
+
"0%": { strokeDasharray: "1, 150", strokeDashoffset: 0 },
|
|
101
|
+
"50%": { strokeDasharray: "90, 150", strokeDashoffset: -35 },
|
|
102
|
+
"100%": { strokeDasharray: "90, 150", strokeDashoffset: -124 }
|
|
103
|
+
}
|
|
104
|
+
},
|
|
105
|
+
"& circle.circle-progress-track": {
|
|
106
|
+
fill: "none",
|
|
107
|
+
stroke: trackColor || (color === 'default' ? `text.primary` : `${color}.soft.secondary`),
|
|
108
|
+
strokeWidth: trackSize !== null && trackSize !== void 0 ? trackSize : thumbSize,
|
|
109
|
+
}
|
|
110
|
+
},
|
|
111
|
+
width: size,
|
|
112
|
+
height: size,
|
|
113
|
+
position: "relative"
|
|
114
|
+
}, ref: ref, children: [jsxRuntime.jsxs("svg", { viewBox: "0 0 50 50", className: "circle-progress-svg", children: [!hideTrack && jsxRuntime.jsx("circle", { className: "circle-progress-track", cx: "25", cy: "25", r: 20 }), jsxRuntime.jsx("circle", { className: "circle-progress-thumb", cx: "25", cy: "25", r: 20 })] }), !!children && jsxRuntime.jsx(core.Tag, { baseClass: "circle-progress-content", sxr: {
|
|
115
|
+
zIndex: 2,
|
|
116
|
+
width: size - thumbSize,
|
|
117
|
+
height: size - thumbSize,
|
|
118
|
+
display: "flex",
|
|
119
|
+
alignItems: "center",
|
|
120
|
+
justifyContent: "center",
|
|
121
|
+
'& *': {
|
|
122
|
+
maxWidth: size - (thumbSize + 8),
|
|
123
|
+
maxHeight: size - (thumbSize + 8),
|
|
124
|
+
}
|
|
125
|
+
}, children: children })] }));
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
module.exports = CircleProgress;
|
|
129
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../../src/CircleProgress/index.tsx"],"sourcesContent":["'use client'\r\nimport React, { ReactElement, useId } from \"react\"\r\nimport { Tag, UseColorTemplateColor, useInterface, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\n\r\nexport type CircleProgressProps = {\r\n children?: ReactElement;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n trackColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n thumbColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\r\n thumbSize?: useBreakpointPropsType<number>;\r\n trackSize?: useBreakpointPropsType<number>;\r\n value?: useBreakpointPropsType<number>;\r\n hideTrack?: useBreakpointPropsType<boolean>;\r\n showPercentage?: useBreakpointPropsType<boolean>;\r\n speed?: useBreakpointPropsType<number>;\r\n}\r\n\r\nconst CircleProgress = React.forwardRef(({ children, ...props }: CircleProgressProps, ref: React.Ref<any>) => {\r\n let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface<any>(\"CircleProgress\", props, {})\r\n const _p: any = {}\r\n if (color) _p.color = color\r\n if (trackColor) _p.trackColor = trackColor\r\n if (thumbColor) _p.thumbColor = thumbColor\r\n if (size) _p.size = size\r\n if (thumbSize) _p.thumbSize = thumbSize\r\n if (trackSize) _p.trackSize = trackSize\r\n if (value) _p.value = value\r\n if (hideTrack) _p.hideTrack = hideTrack\r\n if (showPercentage) _p.showPercentage = showPercentage\r\n if (speed) _p.speed = speed\r\n const p: any = useBreakpointProps(_p)\r\n\r\n color = p.color ?? \"brand\"\r\n trackColor = p.trackColor\r\n thumbColor = p.thumbColor\r\n size = p.size ?? \"medium\"\r\n thumbSize = p.thumbSize ?? 4\r\n trackSize = p.trackSize\r\n value = p.value\r\n hideTrack = p.hideTrack\r\n showPercentage = p.showPercentage\r\n speed = p.speed ?? 1.3\r\n\r\n if (trackColor === 'default') {\r\n trackColor = \"divider\"\r\n }\r\n\r\n if (thumbColor === 'default') {\r\n thumbColor = \"divider.secondary\"\r\n }\r\n\r\n\r\n let sizes: any = {\r\n small: 24,\r\n medium: 32,\r\n large: 44\r\n }\r\n if (typeof size === 'string' && sizes[size]) {\r\n size = sizes[size]\r\n }\r\n\r\n let isVal = typeof value === 'number'\r\n const animrotate = \"anim\" + useId().replace(\":\", \"\")\r\n const animdash = \"anim\" + useId().replace(\":\", \"\")\r\n if (isVal && (value as number) > 100) value = 100\r\n const circumference = 125.66370614359172 //radius * 2 * Math.PI\r\n const percent = circumference - ((value || 0) / 100) * circumference\r\n\r\n if (showPercentage && !children) {\r\n children = <Tag\r\n sxr={{\r\n color: color === 'default' ? \"text.primary\" : `${color}.primary`,\r\n fontSize: size / 4\r\n }}\r\n >{value}%</Tag>\r\n }\r\n\r\n return (\r\n <Tag\r\n baseClass='circle-progress'\r\n sxr={{\r\n display: \"inline-flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n \"& svg[class='circle-progress-svg']\": {\r\n zIndex: 1,\r\n position: \"absolute\",\r\n top: 0,\r\n left: 0,\r\n width: \"100%\",\r\n height: \"100%\",\r\n transform: isVal ? \"rotate(-90deg)\" : \"none\",\r\n transformOrigin: isVal ? \"center\" : \"initial\",\r\n animation: isVal ? \"none\" : `${animrotate} ${speed}s linear infinite`,\r\n [`@keyframes ${animrotate}`]: {\r\n \"100%\": {\r\n transform: \"rotate(360deg)\"\r\n }\r\n },\r\n \"& circle.circle-progress-thumb\": {\r\n\r\n strokeDasharray: circumference,\r\n strokeDashoffset: percent,\r\n stroke: thumbColor || (color === 'default' ? `divider` : `${color}.primary`),\r\n fill: \"none\",\r\n strokeWidth: thumbSize,\r\n strokeLinecap: \"round\",\r\n animation: isVal ? \"none\" : `${animdash} ${speed}s ease-in-out infinite`,\r\n [`@keyframes ${animdash}`]: {\r\n \"0%\": { strokeDasharray: \"1, 150\", strokeDashoffset: 0 },\r\n \"50%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -35 },\r\n \"100%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -124 }\r\n }\r\n },\r\n \"& circle.circle-progress-track\": {\r\n fill: \"none\",\r\n stroke: trackColor || (color === 'default' ? `text.primary` : `${color}.soft.secondary`),\r\n strokeWidth: trackSize ?? thumbSize,\r\n }\r\n },\r\n width: size,\r\n height: size,\r\n position: \"relative\"\r\n }}\r\n ref={ref}\r\n >\r\n <svg viewBox=\"0 0 50 50\" className=\"circle-progress-svg\">\r\n {!hideTrack && <circle className=\"circle-progress-track\" cx=\"25\" cy=\"25\" r={20} />}\r\n <circle className=\"circle-progress-thumb\" cx=\"25\" cy=\"25\" r={20} />\r\n </svg>\r\n {!!children && <Tag\r\n baseClass=\"circle-progress-content\"\r\n sxr={{\r\n zIndex: 2,\r\n width: size - thumbSize,\r\n height: size - thumbSize,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n '& *': {\r\n maxWidth: size - (thumbSize + 8),\r\n maxHeight: size - (thumbSize + 8),\r\n }\r\n }}\r\n >\r\n {children}\r\n </Tag>}\r\n </Tag >\r\n )\r\n})\r\n\r\nexport default CircleProgress\r\n\r\n"],"names":[],"mappings":";;;;;;;;AAkBA;;AAAyC;AACrC;;AAEA;AAAW;AACX;AAAgB;AAChB;AAAgB;AAChB;AAAU;AACV;AAAe;AACf;AAAe;AACf;AAAW;AACX;AAAe;AACf;AAAoB;AACpB;AAAW;AACX;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAIA;;;AAKA;AACI;AACA;AACA;;;AAGA;;AAGJ;AACA;AACA;AACA;;AACA;AACA;AAEA;AACI;AAEQ;;;;;AAUA;AACA;AACA;AACA;AACI;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACI;AACI;AACH;AACJ;AACD;AAEI;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AAIC;AACJ;AACD;AACI;AACA;AACA;AACH;AACJ;AACD;AACA;AACA;AACH;AAUO;;;AAGA;AACA;AACA;AACA;AACI;AACA;AACH;AACJ;AAMjB;;"}
|
package/CircleProgress/index.js
CHANGED
|
@@ -1,15 +1,13 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
var React = require('react');
|
|
7
|
-
var core = require('@xanui/core');
|
|
2
|
+
import { __rest } from 'tslib';
|
|
3
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
4
|
+
import React, { useId } from 'react';
|
|
5
|
+
import { useInterface, useBreakpointProps, Tag } from '@xanui/core';
|
|
8
6
|
|
|
9
7
|
const CircleProgress = React.forwardRef((_a, ref) => {
|
|
10
8
|
var _b, _c, _d, _e;
|
|
11
|
-
var { children } = _a, props =
|
|
12
|
-
let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] =
|
|
9
|
+
var { children } = _a, props = __rest(_a, ["children"]);
|
|
10
|
+
let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface("CircleProgress", props, {});
|
|
13
11
|
const _p = {};
|
|
14
12
|
if (color)
|
|
15
13
|
_p.color = color;
|
|
@@ -31,7 +29,7 @@ const CircleProgress = React.forwardRef((_a, ref) => {
|
|
|
31
29
|
_p.showPercentage = showPercentage;
|
|
32
30
|
if (speed)
|
|
33
31
|
_p.speed = speed;
|
|
34
|
-
const p =
|
|
32
|
+
const p = useBreakpointProps(_p);
|
|
35
33
|
color = (_b = p.color) !== null && _b !== void 0 ? _b : "brand";
|
|
36
34
|
trackColor = p.trackColor;
|
|
37
35
|
thumbColor = p.thumbColor;
|
|
@@ -57,19 +55,19 @@ const CircleProgress = React.forwardRef((_a, ref) => {
|
|
|
57
55
|
size = sizes[size];
|
|
58
56
|
}
|
|
59
57
|
let isVal = typeof value === 'number';
|
|
60
|
-
const animrotate = "anim" +
|
|
61
|
-
const animdash = "anim" +
|
|
58
|
+
const animrotate = "anim" + useId().replace(":", "");
|
|
59
|
+
const animdash = "anim" + useId().replace(":", "");
|
|
62
60
|
if (isVal && value > 100)
|
|
63
61
|
value = 100;
|
|
64
62
|
const circumference = 125.66370614359172; //radius * 2 * Math.PI
|
|
65
63
|
const percent = circumference - ((value || 0) / 100) * circumference;
|
|
66
64
|
if (showPercentage && !children) {
|
|
67
|
-
children =
|
|
65
|
+
children = jsxs(Tag, { sxr: {
|
|
68
66
|
color: color === 'default' ? "text.primary" : `${color}.primary`,
|
|
69
67
|
fontSize: size / 4
|
|
70
68
|
}, children: [value, "%"] });
|
|
71
69
|
}
|
|
72
|
-
return (
|
|
70
|
+
return (jsxs(Tag, { baseClass: 'circle-progress', sxr: {
|
|
73
71
|
display: "inline-flex",
|
|
74
72
|
alignItems: "center",
|
|
75
73
|
justifyContent: "center",
|
|
@@ -111,7 +109,7 @@ const CircleProgress = React.forwardRef((_a, ref) => {
|
|
|
111
109
|
width: size,
|
|
112
110
|
height: size,
|
|
113
111
|
position: "relative"
|
|
114
|
-
}, ref: ref, children: [
|
|
112
|
+
}, ref: ref, children: [jsxs("svg", { viewBox: "0 0 50 50", className: "circle-progress-svg", children: [!hideTrack && jsx("circle", { className: "circle-progress-track", cx: "25", cy: "25", r: 20 }), jsx("circle", { className: "circle-progress-thumb", cx: "25", cy: "25", r: 20 })] }), !!children && jsx(Tag, { baseClass: "circle-progress-content", sxr: {
|
|
115
113
|
zIndex: 2,
|
|
116
114
|
width: size - thumbSize,
|
|
117
115
|
height: size - thumbSize,
|
|
@@ -125,5 +123,5 @@ const CircleProgress = React.forwardRef((_a, ref) => {
|
|
|
125
123
|
}, children: children })] }));
|
|
126
124
|
});
|
|
127
125
|
|
|
128
|
-
|
|
126
|
+
export { CircleProgress as default };
|
|
129
127
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/CircleProgress/index.tsx"],"sourcesContent":["
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/CircleProgress/index.tsx"],"sourcesContent":["'use client'\r\nimport React, { ReactElement, useId } from \"react\"\r\nimport { Tag, UseColorTemplateColor, useInterface, useBreakpointProps, useBreakpointPropsType } from '@xanui/core';\r\n\r\nexport type CircleProgressProps = {\r\n children?: ReactElement;\r\n color?: useBreakpointPropsType<UseColorTemplateColor>;\r\n trackColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n thumbColor?: useBreakpointPropsType<UseColorTemplateColor>;\r\n size?: useBreakpointPropsType<number | \"small\" | \"medium\" | \"large\">;\r\n thumbSize?: useBreakpointPropsType<number>;\r\n trackSize?: useBreakpointPropsType<number>;\r\n value?: useBreakpointPropsType<number>;\r\n hideTrack?: useBreakpointPropsType<boolean>;\r\n showPercentage?: useBreakpointPropsType<boolean>;\r\n speed?: useBreakpointPropsType<number>;\r\n}\r\n\r\nconst CircleProgress = React.forwardRef(({ children, ...props }: CircleProgressProps, ref: React.Ref<any>) => {\r\n let [{ color, trackColor, thumbColor, size, value, thumbSize, hideTrack, trackSize, showPercentage, speed }] = useInterface<any>(\"CircleProgress\", props, {})\r\n const _p: any = {}\r\n if (color) _p.color = color\r\n if (trackColor) _p.trackColor = trackColor\r\n if (thumbColor) _p.thumbColor = thumbColor\r\n if (size) _p.size = size\r\n if (thumbSize) _p.thumbSize = thumbSize\r\n if (trackSize) _p.trackSize = trackSize\r\n if (value) _p.value = value\r\n if (hideTrack) _p.hideTrack = hideTrack\r\n if (showPercentage) _p.showPercentage = showPercentage\r\n if (speed) _p.speed = speed\r\n const p: any = useBreakpointProps(_p)\r\n\r\n color = p.color ?? \"brand\"\r\n trackColor = p.trackColor\r\n thumbColor = p.thumbColor\r\n size = p.size ?? \"medium\"\r\n thumbSize = p.thumbSize ?? 4\r\n trackSize = p.trackSize\r\n value = p.value\r\n hideTrack = p.hideTrack\r\n showPercentage = p.showPercentage\r\n speed = p.speed ?? 1.3\r\n\r\n if (trackColor === 'default') {\r\n trackColor = \"divider\"\r\n }\r\n\r\n if (thumbColor === 'default') {\r\n thumbColor = \"divider.secondary\"\r\n }\r\n\r\n\r\n let sizes: any = {\r\n small: 24,\r\n medium: 32,\r\n large: 44\r\n }\r\n if (typeof size === 'string' && sizes[size]) {\r\n size = sizes[size]\r\n }\r\n\r\n let isVal = typeof value === 'number'\r\n const animrotate = \"anim\" + useId().replace(\":\", \"\")\r\n const animdash = \"anim\" + useId().replace(\":\", \"\")\r\n if (isVal && (value as number) > 100) value = 100\r\n const circumference = 125.66370614359172 //radius * 2 * Math.PI\r\n const percent = circumference - ((value || 0) / 100) * circumference\r\n\r\n if (showPercentage && !children) {\r\n children = <Tag\r\n sxr={{\r\n color: color === 'default' ? \"text.primary\" : `${color}.primary`,\r\n fontSize: size / 4\r\n }}\r\n >{value}%</Tag>\r\n }\r\n\r\n return (\r\n <Tag\r\n baseClass='circle-progress'\r\n sxr={{\r\n display: \"inline-flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n \"& svg[class='circle-progress-svg']\": {\r\n zIndex: 1,\r\n position: \"absolute\",\r\n top: 0,\r\n left: 0,\r\n width: \"100%\",\r\n height: \"100%\",\r\n transform: isVal ? \"rotate(-90deg)\" : \"none\",\r\n transformOrigin: isVal ? \"center\" : \"initial\",\r\n animation: isVal ? \"none\" : `${animrotate} ${speed}s linear infinite`,\r\n [`@keyframes ${animrotate}`]: {\r\n \"100%\": {\r\n transform: \"rotate(360deg)\"\r\n }\r\n },\r\n \"& circle.circle-progress-thumb\": {\r\n\r\n strokeDasharray: circumference,\r\n strokeDashoffset: percent,\r\n stroke: thumbColor || (color === 'default' ? `divider` : `${color}.primary`),\r\n fill: \"none\",\r\n strokeWidth: thumbSize,\r\n strokeLinecap: \"round\",\r\n animation: isVal ? \"none\" : `${animdash} ${speed}s ease-in-out infinite`,\r\n [`@keyframes ${animdash}`]: {\r\n \"0%\": { strokeDasharray: \"1, 150\", strokeDashoffset: 0 },\r\n \"50%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -35 },\r\n \"100%\": { strokeDasharray: \"90, 150\", strokeDashoffset: -124 }\r\n }\r\n },\r\n \"& circle.circle-progress-track\": {\r\n fill: \"none\",\r\n stroke: trackColor || (color === 'default' ? `text.primary` : `${color}.soft.secondary`),\r\n strokeWidth: trackSize ?? thumbSize,\r\n }\r\n },\r\n width: size,\r\n height: size,\r\n position: \"relative\"\r\n }}\r\n ref={ref}\r\n >\r\n <svg viewBox=\"0 0 50 50\" className=\"circle-progress-svg\">\r\n {!hideTrack && <circle className=\"circle-progress-track\" cx=\"25\" cy=\"25\" r={20} />}\r\n <circle className=\"circle-progress-thumb\" cx=\"25\" cy=\"25\" r={20} />\r\n </svg>\r\n {!!children && <Tag\r\n baseClass=\"circle-progress-content\"\r\n sxr={{\r\n zIndex: 2,\r\n width: size - thumbSize,\r\n height: size - thumbSize,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n '& *': {\r\n maxWidth: size - (thumbSize + 8),\r\n maxHeight: size - (thumbSize + 8),\r\n }\r\n }}\r\n >\r\n {children}\r\n </Tag>}\r\n </Tag >\r\n )\r\n})\r\n\r\nexport default CircleProgress\r\n\r\n"],"names":[],"mappings":";;;;;;AAkBA;;AAAyC;AACrC;;AAEA;AAAW;AACX;AAAgB;AAChB;AAAgB;AAChB;AAAU;AACV;AAAe;AACf;AAAe;AACf;AAAW;AACX;AAAe;AACf;AAAoB;AACpB;AAAW;AACX;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAIA;;;AAKA;AACI;AACA;AACA;;;AAGA;;AAGJ;AACA;AACA;AACA;;AACA;AACA;AAEA;AACI;AAEQ;;;;;AAUA;AACA;AACA;AACA;AACI;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACI;AACI;AACH;AACJ;AACD;AAEI;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AAIC;AACJ;AACD;AACI;AACA;AACA;AACH;AACJ;AACD;AACA;AACA;AACH;AAUO;;;AAGA;AACA;AACA;AACA;AACI;AACA;AACH;AACJ;AAMjB;;"}
|