@xanui/ui 1.1.26 → 1.1.28
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/Alert/index.js +2 -2
- package/Alert/index.mjs +2 -2
- package/Autocomplete/index.d.ts +40 -0
- package/Autocomplete/index.js +136 -0
- package/Autocomplete/index.js.map +1 -0
- package/Autocomplete/index.mjs +134 -0
- package/Autocomplete/index.mjs.map +1 -0
- package/Avatar/index.d.ts +5 -0
- package/Avatar/index.js +7 -2
- package/Avatar/index.js.map +1 -1
- package/Avatar/index.mjs +7 -2
- package/Avatar/index.mjs.map +1 -1
- package/Button/index.d.ts +3 -0
- package/Button/index.js +13 -9
- package/Button/index.js.map +1 -1
- package/Button/index.mjs +12 -8
- package/Button/index.mjs.map +1 -1
- package/Calendar/index.js +35 -20
- package/Calendar/index.js.map +1 -1
- package/Calendar/index.mjs +27 -12
- package/Calendar/index.mjs.map +1 -1
- package/CalendarInput/index.js +6 -2
- package/CalendarInput/index.js.map +1 -1
- package/CalendarInput/index.mjs +6 -2
- package/CalendarInput/index.mjs.map +1 -1
- package/DataFilter/index.d.ts +7 -0
- package/DataFilter/index.js +78 -0
- package/DataFilter/index.js.map +1 -0
- package/DataFilter/index.mjs +67 -0
- package/DataFilter/index.mjs.map +1 -0
- package/DataFilter/options/DateFilter.d.ts +11 -0
- package/DataFilter/options/DateFilter.js +32 -0
- package/DataFilter/options/DateFilter.js.map +1 -0
- package/DataFilter/options/DateFilter.mjs +30 -0
- package/DataFilter/options/DateFilter.mjs.map +1 -0
- package/DataFilter/options/DateRangeFilter.d.ts +11 -0
- package/DataFilter/options/DateRangeFilter.js +27 -0
- package/DataFilter/options/DateRangeFilter.js.map +1 -0
- package/DataFilter/options/DateRangeFilter.mjs +25 -0
- package/DataFilter/options/DateRangeFilter.mjs.map +1 -0
- package/DataFilter/options/MultiSelectFilter.d.ts +11 -0
- package/DataFilter/options/MultiSelectFilter.js +38 -0
- package/DataFilter/options/MultiSelectFilter.js.map +1 -0
- package/DataFilter/options/MultiSelectFilter.mjs +36 -0
- package/DataFilter/options/MultiSelectFilter.mjs.map +1 -0
- package/DataFilter/options/NumberFilter.d.ts +11 -0
- package/DataFilter/options/NumberFilter.js +24 -0
- package/DataFilter/options/NumberFilter.js.map +1 -0
- package/DataFilter/options/NumberFilter.mjs +22 -0
- package/DataFilter/options/NumberFilter.mjs.map +1 -0
- package/DataFilter/options/NumberRangeFilter.d.ts +11 -0
- package/DataFilter/options/NumberRangeFilter.js +29 -0
- package/DataFilter/options/NumberRangeFilter.js.map +1 -0
- package/DataFilter/options/NumberRangeFilter.mjs +27 -0
- package/DataFilter/options/NumberRangeFilter.mjs.map +1 -0
- package/DataFilter/options/SelectFilter.d.ts +11 -0
- package/DataFilter/options/SelectFilter.js +34 -0
- package/DataFilter/options/SelectFilter.js.map +1 -0
- package/DataFilter/options/SelectFilter.mjs +32 -0
- package/DataFilter/options/SelectFilter.mjs.map +1 -0
- package/DataFilter/options/TextFilter.d.ts +11 -0
- package/DataFilter/options/TextFilter.js +24 -0
- package/DataFilter/options/TextFilter.js.map +1 -0
- package/DataFilter/options/TextFilter.mjs +22 -0
- package/DataFilter/options/TextFilter.mjs.map +1 -0
- package/DataFilter/types.d.ts +58 -0
- package/Datatable/FilterBox.js +21 -13
- package/Datatable/FilterBox.js.map +1 -1
- package/Datatable/FilterBox.mjs +20 -12
- package/Datatable/FilterBox.mjs.map +1 -1
- package/Datatable/Row.js +15 -14
- package/Datatable/Row.js.map +1 -1
- package/Datatable/Row.mjs +16 -15
- package/Datatable/Row.mjs.map +1 -1
- package/Datatable/Table.js +3 -3
- package/Datatable/Table.js.map +1 -1
- package/Datatable/Table.mjs +3 -3
- package/Datatable/Table.mjs.map +1 -1
- package/Datatable/TableHead.js +5 -4
- package/Datatable/TableHead.js.map +1 -1
- package/Datatable/TableHead.mjs +5 -4
- package/Datatable/TableHead.mjs.map +1 -1
- package/Datatable/index.d.ts +1 -1
- package/Datatable/index.js +51 -11
- package/Datatable/index.js.map +1 -1
- package/Datatable/index.mjs +50 -10
- package/Datatable/index.mjs.map +1 -1
- package/Datatable/types.d.ts +13 -9
- package/Drawer/index.js +3 -3
- package/Drawer/index.js.map +1 -1
- package/Drawer/index.mjs +3 -3
- package/Drawer/index.mjs.map +1 -1
- package/IconButton/index.js +1 -7
- package/IconButton/index.js.map +1 -1
- package/IconButton/index.mjs +1 -7
- package/IconButton/index.mjs.map +1 -1
- package/Input/index.d.ts +7 -7
- package/Input/index.js +35 -66
- package/Input/index.js.map +1 -1
- package/Input/index.mjs +35 -66
- package/Input/index.mjs.map +1 -1
- package/InputNumber/index.js +32 -0
- package/InputNumber/index.js.map +1 -0
- package/InputNumber/index.mjs +30 -0
- package/InputNumber/index.mjs.map +1 -0
- package/List/ListContext.js +11 -0
- package/List/ListContext.js.map +1 -0
- package/List/ListContext.mjs +8 -0
- package/List/ListContext.mjs.map +1 -0
- package/List/index.d.ts +2 -1
- package/List/index.js +23 -19
- package/List/index.js.map +1 -1
- package/List/index.mjs +23 -19
- package/List/index.mjs.map +1 -1
- package/ListItem/index.d.ts +1 -0
- package/ListItem/index.js +30 -13
- package/ListItem/index.js.map +1 -1
- package/ListItem/index.mjs +30 -13
- package/ListItem/index.mjs.map +1 -1
- package/Menu/index.js +2 -0
- package/Menu/index.js.map +1 -1
- package/Menu/index.mjs +2 -0
- package/Menu/index.mjs.map +1 -1
- package/Paper/index.js +2 -2
- package/Paper/index.js.map +1 -1
- package/Paper/index.mjs +2 -2
- package/Paper/index.mjs.map +1 -1
- package/Select/index.d.ts +2 -10
- package/Select/index.js +3 -3
- package/Select/index.js.map +1 -1
- package/Select/index.mjs +3 -3
- package/Select/index.mjs.map +1 -1
- package/Skeleton/index.d.ts +8 -0
- package/Skeleton/index.js +60 -0
- package/Skeleton/index.js.map +1 -0
- package/Skeleton/index.mjs +58 -0
- package/Skeleton/index.mjs.map +1 -0
- package/Table/index.js +3 -3
- package/Table/index.js.map +1 -1
- package/Table/index.mjs +3 -3
- package/Table/index.mjs.map +1 -1
- package/TablePagination/index.d.ts +2 -2
- package/TablePagination/index.js +2 -7
- package/TablePagination/index.js.map +1 -1
- package/TablePagination/index.mjs +2 -7
- package/TablePagination/index.mjs.map +1 -1
- package/index.d.ts +65 -55
- package/index.js +126 -108
- package/index.js.map +1 -1
- package/index.mjs +9 -0
- package/index.mjs.map +1 -1
- package/package.json +2 -7
package/Alert/index.js
CHANGED
|
@@ -10,7 +10,7 @@ var InfoIcon = require('@xanui/icons/Info');
|
|
|
10
10
|
var WarningIcon = require('@xanui/icons/Warning');
|
|
11
11
|
var SuccessIcon = require('@xanui/icons/CheckCircle');
|
|
12
12
|
var ErrorIcon = require('@xanui/icons/Cancel');
|
|
13
|
-
var
|
|
13
|
+
var Close = require('@xanui/icons/Close');
|
|
14
14
|
var index = require('../IconButton/index.js');
|
|
15
15
|
var index$2 = require('../useAlert/index.js');
|
|
16
16
|
|
|
@@ -55,7 +55,7 @@ const Alert = (_a) => {
|
|
|
55
55
|
position: "absolute",
|
|
56
56
|
top: 5,
|
|
57
57
|
right: 5
|
|
58
|
-
}, onClick: onClose, className: "alert-close-button", children: jsxRuntime.jsx(
|
|
58
|
+
}, onClick: onClose, className: "alert-close-button", children: jsxRuntime.jsx(Close, { fontSize: 18 }) }), jsxRuntime.jsxs(core.Tag, { sx: {
|
|
59
59
|
display: "flex",
|
|
60
60
|
gap: 1,
|
|
61
61
|
flexDirection: direction,
|
package/Alert/index.mjs
CHANGED
|
@@ -8,7 +8,7 @@ import InfoIcon from '@xanui/icons/Info';
|
|
|
8
8
|
import WarningIcon from '@xanui/icons/Warning';
|
|
9
9
|
import SuccessIcon from '@xanui/icons/CheckCircle';
|
|
10
10
|
import ErrorIcon from '@xanui/icons/Cancel';
|
|
11
|
-
import
|
|
11
|
+
import Close from '@xanui/icons/Close';
|
|
12
12
|
import IconButton from '../IconButton/index.mjs';
|
|
13
13
|
import useAlert from '../useAlert/index.mjs';
|
|
14
14
|
|
|
@@ -53,7 +53,7 @@ const Alert = (_a) => {
|
|
|
53
53
|
position: "absolute",
|
|
54
54
|
top: 5,
|
|
55
55
|
right: 5
|
|
56
|
-
}, onClick: onClose, className: "alert-close-button", children: jsx(
|
|
56
|
+
}, onClick: onClose, className: "alert-close-button", children: jsx(Close, { fontSize: 18 }) }), jsxs(Tag, { sx: {
|
|
57
57
|
display: "flex",
|
|
58
58
|
gap: 1,
|
|
59
59
|
flexDirection: direction,
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
+
import React, { ReactElement } from 'react';
|
|
3
|
+
import { ListItemProps } from '../ListItem/index.js';
|
|
4
|
+
import { useBreakpointPropsType, UseColorTemplateColor } from '@xanui/core';
|
|
5
|
+
|
|
6
|
+
type AutocompleteProps = {
|
|
7
|
+
options: any[] | ((text: string) => Promise<any[]>);
|
|
8
|
+
getLabel: (option: any) => string;
|
|
9
|
+
onChange?: (value: any) => void;
|
|
10
|
+
value?: any;
|
|
11
|
+
multiple?: boolean;
|
|
12
|
+
renderOption?: (option: any, props: any) => ReactElement<ListItemProps>;
|
|
13
|
+
name?: string;
|
|
14
|
+
placeholder?: string;
|
|
15
|
+
readOnly?: boolean;
|
|
16
|
+
autoFocus?: boolean;
|
|
17
|
+
autoComplete?: string;
|
|
18
|
+
label?: useBreakpointPropsType<string>;
|
|
19
|
+
onFocus?: (e: React.FocusEvent<any>) => void;
|
|
20
|
+
onBlur?: (e: React.FocusEvent<any>) => void;
|
|
21
|
+
onInput?: (e: React.FormEvent<any>) => void;
|
|
22
|
+
onKeyDown?: (e: React.KeyboardEvent<any>) => void;
|
|
23
|
+
onKeyUp?: (e: React.KeyboardEvent<any>) => void;
|
|
24
|
+
rows?: useBreakpointPropsType<number>;
|
|
25
|
+
minRows?: useBreakpointPropsType<number>;
|
|
26
|
+
maxRows?: useBreakpointPropsType<number>;
|
|
27
|
+
fullWidth?: boolean;
|
|
28
|
+
startIcon?: useBreakpointPropsType<ReactElement>;
|
|
29
|
+
endIcon?: useBreakpointPropsType<ReactElement>;
|
|
30
|
+
iconPlacement?: useBreakpointPropsType<"start" | "center" | "end">;
|
|
31
|
+
focused?: boolean;
|
|
32
|
+
color?: useBreakpointPropsType<Omit<UseColorTemplateColor, "default">>;
|
|
33
|
+
variant?: useBreakpointPropsType<"fill" | "outline" | "text">;
|
|
34
|
+
error?: boolean;
|
|
35
|
+
helperText?: useBreakpointPropsType<string>;
|
|
36
|
+
};
|
|
37
|
+
declare const Autocomplete: ({ value, onChange, renderOption, options, getLabel, multiple, ...inputProps }: AutocompleteProps) => react_jsx_runtime.JSX.Element;
|
|
38
|
+
|
|
39
|
+
export { Autocomplete as default };
|
|
40
|
+
export type { AutocompleteProps };
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var tslib = require('tslib');
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var index$3 = require('../Input/index.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');
|
|
14
|
+
|
|
15
|
+
const Autocomplete = (_a) => {
|
|
16
|
+
var { value, onChange, renderOption, options, getLabel, multiple } = _a, inputProps = tslib.__rest(_a, ["value", "onChange", "renderOption", "options", "getLabel", "multiple"]);
|
|
17
|
+
const [_options, setOptions] = React.useState();
|
|
18
|
+
const [inputValue, setInputValue] = React.useState("");
|
|
19
|
+
const [timer, setTimer] = React.useState(null);
|
|
20
|
+
const [loading, setLoading] = React.useState(false);
|
|
21
|
+
const [open, setOpen] = React.useState(false);
|
|
22
|
+
const menuRef = React.useRef(null);
|
|
23
|
+
getLabel !== null && getLabel !== void 0 ? getLabel : (getLabel = (option) => option.toString());
|
|
24
|
+
multiple !== null && multiple !== void 0 ? multiple : (multiple = false);
|
|
25
|
+
let startIcons = [
|
|
26
|
+
inputProps.startIcon
|
|
27
|
+
];
|
|
28
|
+
if (!!value && multiple && Array.isArray(value)) {
|
|
29
|
+
value.map((v, index$2) => {
|
|
30
|
+
startIcons.push(jsxRuntime.jsx(index, { size: "small", label: getLabel(v), variant: "fill", color: "default", endIcon: jsxRuntime.jsx(index$1, { size: 20, variant: "text", color: "default", onClick: (e) => {
|
|
31
|
+
e.stopPropagation();
|
|
32
|
+
let newValue = Array.isArray(value) ? [...value] : [];
|
|
33
|
+
newValue = newValue.filter((val) => getLabel(val) !== getLabel(v));
|
|
34
|
+
onChange && onChange(newValue);
|
|
35
|
+
}, children: jsxRuntime.jsx(Close, {}) }) }, index$2));
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
let endIcons = [
|
|
39
|
+
inputProps.endIcon
|
|
40
|
+
];
|
|
41
|
+
if (loading) {
|
|
42
|
+
endIcons.push(jsxRuntime.jsx(index$2, { size: "small" }, "auto-complete-loading-icon"));
|
|
43
|
+
}
|
|
44
|
+
else if (!!value && !multiple) {
|
|
45
|
+
endIcons.push(jsxRuntime.jsx(index$1, { variant: "text", color: "default", onClick: (e) => {
|
|
46
|
+
e.stopPropagation();
|
|
47
|
+
onChange && onChange(undefined);
|
|
48
|
+
setInputValue("");
|
|
49
|
+
}, children: jsxRuntime.jsx(Close, {}) }, "auto-complete-clear-button"));
|
|
50
|
+
}
|
|
51
|
+
return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(index$3, Object.assign({}, inputProps, { ref: menuRef, slotProps: {
|
|
52
|
+
rootContainer: Object.assign({ flexWrap: 'wrap' }, (multiple ? { height: "auto", gap: .5 } : {})),
|
|
53
|
+
input: {
|
|
54
|
+
width: multiple ? 'auto' : '100%',
|
|
55
|
+
flex: 1,
|
|
56
|
+
minWidth: 20,
|
|
57
|
+
}
|
|
58
|
+
}, startIcon: startIcons, endIcon: endIcons, value: inputValue, onKeyDown: (e) => {
|
|
59
|
+
if (inputProps === null || inputProps === void 0 ? void 0 : inputProps.onKeyDown) {
|
|
60
|
+
inputProps.onKeyDown(e);
|
|
61
|
+
}
|
|
62
|
+
if (multiple && e.key === 'Backspace' && inputValue === "" && Array.isArray(value) && value.length > 0) {
|
|
63
|
+
let newValue = [...value];
|
|
64
|
+
newValue.pop();
|
|
65
|
+
onChange && onChange(newValue);
|
|
66
|
+
}
|
|
67
|
+
}, onChange: (e) => {
|
|
68
|
+
const value = e.target.value;
|
|
69
|
+
setInputValue(value);
|
|
70
|
+
if (!value) {
|
|
71
|
+
setOptions([]);
|
|
72
|
+
setOpen(false);
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
setOpen(true);
|
|
76
|
+
clearTimeout(timer);
|
|
77
|
+
setTimer(setTimeout(async () => {
|
|
78
|
+
if (typeof options === 'function') {
|
|
79
|
+
setLoading(true);
|
|
80
|
+
const result = await options(value);
|
|
81
|
+
setOptions(result);
|
|
82
|
+
setLoading(false);
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
const filtered = options.filter(option => getLabel(option).toLowerCase().includes(value.toLowerCase()));
|
|
86
|
+
setOptions(filtered);
|
|
87
|
+
}
|
|
88
|
+
}, 300));
|
|
89
|
+
} })), jsxRuntime.jsx(index$4, { target: open ? menuRef.current : null, onClickOutside: () => {
|
|
90
|
+
setOptions([]);
|
|
91
|
+
setInputValue("");
|
|
92
|
+
}, slotProps: {
|
|
93
|
+
content: { minWidth: menuRef.current ? menuRef.current.offsetWidth : 'auto' }
|
|
94
|
+
}, children: jsxRuntime.jsx(index$5, { maxHeight: 400, overflow: "auto", children: _options === null || _options === void 0 ? void 0 : _options.map((option, index) => (renderOption ? jsxRuntime.jsx("div", { children: renderOption(option, {
|
|
95
|
+
onClick: () => {
|
|
96
|
+
if (multiple) {
|
|
97
|
+
let newValue = Array.isArray(value) ? [...value] : [];
|
|
98
|
+
const has = newValue.find((v) => getLabel(v) === getLabel(option));
|
|
99
|
+
if (!has) {
|
|
100
|
+
newValue.push(option);
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
newValue = newValue.filter((v) => getLabel(v) !== getLabel(option));
|
|
104
|
+
}
|
|
105
|
+
onChange && onChange(newValue);
|
|
106
|
+
}
|
|
107
|
+
else {
|
|
108
|
+
onChange && onChange(option);
|
|
109
|
+
setOpen(false);
|
|
110
|
+
setInputValue(getLabel(option));
|
|
111
|
+
setOptions([]);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}) }, "auto-complete" + index + getLabel(option)) : jsxRuntime.jsx(index$6, { onClick: () => {
|
|
115
|
+
if (multiple) {
|
|
116
|
+
let newValue = Array.isArray(value) ? [...value] : [];
|
|
117
|
+
const has = newValue.find((v) => getLabel(v) === getLabel(option));
|
|
118
|
+
if (!has) {
|
|
119
|
+
newValue.push(option);
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
newValue = newValue.filter((v) => getLabel(v) !== getLabel(option));
|
|
123
|
+
}
|
|
124
|
+
onChange && onChange(newValue);
|
|
125
|
+
}
|
|
126
|
+
else {
|
|
127
|
+
onChange && onChange(option);
|
|
128
|
+
setOpen(false);
|
|
129
|
+
setInputValue(getLabel(option));
|
|
130
|
+
setOptions([]);
|
|
131
|
+
}
|
|
132
|
+
}, children: getLabel(option) }, index))) }) })] }));
|
|
133
|
+
};
|
|
134
|
+
|
|
135
|
+
module.exports = Autocomplete;
|
|
136
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/Autocomplete/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react'\nimport Input from '../Input'\nimport Menu from '../Menu'\nimport List from '../List';\nimport ListItem, { ListItemProps } from '../ListItem';\nimport Chip from '../Chip';\nimport IconButton from '../IconButton';\nimport Close from '@xanui/icons/Close';\nimport CircleProgress from '../CircleProgress';\nimport { useBreakpointPropsType, UseColorTemplateColor } from '@xanui/core';\n\nexport type AutocompleteProps = {\n\n options: any[] | ((text: string) => Promise<any[]>)\n getLabel: (option: any) => string;\n onChange?: (value: any) => void;\n value?: any;\n multiple?: boolean;\n renderOption?: (option: any, props: any) => ReactElement<ListItemProps>\n\n // input props customization\n name?: string;\n placeholder?: string;\n readOnly?: boolean;\n autoFocus?: boolean;\n autoComplete?: string;\n label?: useBreakpointPropsType<string>;\n\n onFocus?: (e: React.FocusEvent<any>) => void;\n onBlur?: (e: React.FocusEvent<any>) => void;\n onInput?: (e: React.FormEvent<any>) => void;\n onKeyDown?: (e: React.KeyboardEvent<any>) => void;\n onKeyUp?: (e: React.KeyboardEvent<any>) => void;\n\n rows?: useBreakpointPropsType<number>;\n minRows?: useBreakpointPropsType<number>;\n maxRows?: useBreakpointPropsType<number>;\n fullWidth?: boolean;\n\n startIcon?: useBreakpointPropsType<ReactElement>;\n endIcon?: useBreakpointPropsType<ReactElement>;\n iconPlacement?: useBreakpointPropsType<\"start\" | \"center\" | \"end\">;\n focused?: boolean;\n color?: useBreakpointPropsType<Omit<UseColorTemplateColor, \"default\">>;\n variant?: useBreakpointPropsType<\"fill\" | \"outline\" | \"text\">;\n error?: boolean;\n helperText?: useBreakpointPropsType<string>;\n\n}\n\nconst Autocomplete = ({ value, onChange, renderOption, options, getLabel, multiple, ...inputProps }: AutocompleteProps) => {\n const [_options, setOptions] = React.useState<any[]>()\n const [inputValue, setInputValue] = React.useState(\"\")\n const [timer, setTimer] = React.useState<any>(null)\n const [loading, setLoading] = React.useState(false)\n const [open, setOpen] = React.useState(false)\n const menuRef = React.useRef<any>(null)\n\n getLabel ??= (option: any) => option.toString();\n multiple ??= false;\n\n let startIcons = [\n inputProps.startIcon\n ]\n\n if (!!value && multiple && Array.isArray(value)) {\n value.map((v: any, index: number) => {\n startIcons.push(<Chip\n key={index}\n size=\"small\"\n label={getLabel!(v)}\n variant={\"fill\"}\n color=\"default\"\n endIcon={<IconButton\n size={20}\n variant={\"text\"}\n color=\"default\"\n onClick={(e) => {\n e.stopPropagation();\n let newValue = Array.isArray(value) ? [...value] : []\n newValue = newValue.filter((val: any) => getLabel!(val) !== getLabel!(v))\n onChange && onChange(newValue)\n }}\n >\n <Close />\n </IconButton>}\n />)\n })\n }\n\n let endIcons = [\n inputProps.endIcon\n ]\n\n if (loading) {\n endIcons.push(<CircleProgress\n key=\"auto-complete-loading-icon\"\n size=\"small\"\n />)\n } else if (!!value && !multiple) {\n endIcons.push(<IconButton\n key=\"auto-complete-clear-button\"\n variant={\"text\"}\n color=\"default\"\n onClick={(e) => {\n e.stopPropagation();\n onChange && onChange(undefined)\n setInputValue(\"\")\n }}\n >\n <Close />\n </IconButton>)\n }\n\n\n return (\n <>\n <Input\n {...inputProps as any}\n ref={menuRef}\n slotProps={{\n rootContainer: {\n flexWrap: 'wrap',\n ...(multiple ? { height: \"auto\", gap: .5 } : {})\n },\n input: {\n width: multiple ? 'auto' : '100%',\n flex: 1,\n minWidth: 20,\n }\n }}\n startIcon={startIcons}\n endIcon={endIcons}\n value={inputValue}\n onKeyDown={(e) => {\n if (inputProps?.onKeyDown) {\n inputProps.onKeyDown(e)\n }\n if (multiple && e.key === 'Backspace' && inputValue === \"\" && Array.isArray(value) && value.length > 0) {\n let newValue = [...value]\n newValue.pop()\n onChange && onChange(newValue)\n }\n }}\n onChange={(e) => {\n const value = e.target.value;\n setInputValue(value)\n if (!value) {\n setOptions([])\n setOpen(false)\n return;\n }\n setOpen(true)\n\n clearTimeout(timer)\n setTimer(setTimeout(async () => {\n if (typeof options === 'function') {\n setLoading(true)\n const result = await options(value)\n setOptions(result)\n setLoading(false)\n } else {\n const filtered = options.filter(option => getLabel!(option).toLowerCase().includes(value.toLowerCase()))\n setOptions(filtered)\n }\n }, 300))\n }}\n />\n <Menu\n target={open ? menuRef.current : null}\n onClickOutside={() => {\n setOptions([])\n setInputValue(\"\")\n }}\n slotProps={{\n content: { minWidth: menuRef.current ? menuRef.current.offsetWidth : 'auto' }\n }}\n >\n <List\n maxHeight={400}\n overflow={\"auto\"}\n >\n {_options?.map((option, index) => (\n renderOption ? <div key={\"auto-complete\" + index + getLabel!(option)}>{renderOption(option, {\n onClick: () => {\n if (multiple) {\n let newValue = Array.isArray(value) ? [...value] : []\n const has = newValue.find((v: any) => getLabel!(v) === getLabel!(option))\n if (!has) {\n newValue.push(option)\n } else {\n newValue = newValue.filter((v: any) => getLabel!(v) !== getLabel!(option))\n }\n onChange && onChange(newValue)\n } else {\n onChange && onChange(option)\n setOpen(false)\n setInputValue(getLabel!(option))\n setOptions([])\n }\n }\n })}</div> : <ListItem\n key={index}\n onClick={() => {\n if (multiple) {\n let newValue = Array.isArray(value) ? [...value] : []\n const has = newValue.find((v: any) => getLabel!(v) === getLabel!(option))\n if (!has) {\n newValue.push(option)\n } else {\n newValue = newValue.filter((v: any) => getLabel!(v) !== getLabel!(option))\n }\n onChange && onChange(newValue)\n } else {\n onChange && onChange(option)\n setOpen(false)\n setInputValue(getLabel!(option))\n setOptions([])\n }\n }}\n >\n {getLabel!(option)}\n </ListItem>\n ))}\n </List>\n </Menu>\n </>\n )\n}\n\nexport default Autocomplete\n"],"names":["__rest","index","_jsx","Chip","IconButton","CircleProgress","_jsxs","_Fragment","Input","Menu","List","ListItem"],"mappings":"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"}
|
|
@@ -0,0 +1,134 @@
|
|
|
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.mjs';
|
|
5
|
+
import Menu from '../Menu/index.mjs';
|
|
6
|
+
import List from '../List/index.mjs';
|
|
7
|
+
import ListItem from '../ListItem/index.mjs';
|
|
8
|
+
import Chip from '../Chip/index.mjs';
|
|
9
|
+
import IconButton from '../IconButton/index.mjs';
|
|
10
|
+
import Close from '@xanui/icons/Close';
|
|
11
|
+
import CircleProgress from '../CircleProgress/index.mjs';
|
|
12
|
+
|
|
13
|
+
const Autocomplete = (_a) => {
|
|
14
|
+
var { value, onChange, renderOption, options, getLabel, multiple } = _a, inputProps = __rest(_a, ["value", "onChange", "renderOption", "options", "getLabel", "multiple"]);
|
|
15
|
+
const [_options, setOptions] = React.useState();
|
|
16
|
+
const [inputValue, setInputValue] = React.useState("");
|
|
17
|
+
const [timer, setTimer] = React.useState(null);
|
|
18
|
+
const [loading, setLoading] = React.useState(false);
|
|
19
|
+
const [open, setOpen] = React.useState(false);
|
|
20
|
+
const menuRef = React.useRef(null);
|
|
21
|
+
getLabel !== null && getLabel !== void 0 ? getLabel : (getLabel = (option) => option.toString());
|
|
22
|
+
multiple !== null && multiple !== void 0 ? multiple : (multiple = false);
|
|
23
|
+
let startIcons = [
|
|
24
|
+
inputProps.startIcon
|
|
25
|
+
];
|
|
26
|
+
if (!!value && multiple && Array.isArray(value)) {
|
|
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) => {
|
|
29
|
+
e.stopPropagation();
|
|
30
|
+
let newValue = Array.isArray(value) ? [...value] : [];
|
|
31
|
+
newValue = newValue.filter((val) => getLabel(val) !== getLabel(v));
|
|
32
|
+
onChange && onChange(newValue);
|
|
33
|
+
}, children: jsx(Close, {}) }) }, index));
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
let endIcons = [
|
|
37
|
+
inputProps.endIcon
|
|
38
|
+
];
|
|
39
|
+
if (loading) {
|
|
40
|
+
endIcons.push(jsx(CircleProgress, { size: "small" }, "auto-complete-loading-icon"));
|
|
41
|
+
}
|
|
42
|
+
else if (!!value && !multiple) {
|
|
43
|
+
endIcons.push(jsx(IconButton, { variant: "text", color: "default", onClick: (e) => {
|
|
44
|
+
e.stopPropagation();
|
|
45
|
+
onChange && onChange(undefined);
|
|
46
|
+
setInputValue("");
|
|
47
|
+
}, children: jsx(Close, {}) }, "auto-complete-clear-button"));
|
|
48
|
+
}
|
|
49
|
+
return (jsxs(Fragment, { children: [jsx(Input, Object.assign({}, inputProps, { ref: menuRef, slotProps: {
|
|
50
|
+
rootContainer: Object.assign({ flexWrap: 'wrap' }, (multiple ? { height: "auto", gap: .5 } : {})),
|
|
51
|
+
input: {
|
|
52
|
+
width: multiple ? 'auto' : '100%',
|
|
53
|
+
flex: 1,
|
|
54
|
+
minWidth: 20,
|
|
55
|
+
}
|
|
56
|
+
}, startIcon: startIcons, endIcon: endIcons, value: inputValue, onKeyDown: (e) => {
|
|
57
|
+
if (inputProps === null || inputProps === void 0 ? void 0 : inputProps.onKeyDown) {
|
|
58
|
+
inputProps.onKeyDown(e);
|
|
59
|
+
}
|
|
60
|
+
if (multiple && e.key === 'Backspace' && inputValue === "" && Array.isArray(value) && value.length > 0) {
|
|
61
|
+
let newValue = [...value];
|
|
62
|
+
newValue.pop();
|
|
63
|
+
onChange && onChange(newValue);
|
|
64
|
+
}
|
|
65
|
+
}, onChange: (e) => {
|
|
66
|
+
const value = e.target.value;
|
|
67
|
+
setInputValue(value);
|
|
68
|
+
if (!value) {
|
|
69
|
+
setOptions([]);
|
|
70
|
+
setOpen(false);
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
setOpen(true);
|
|
74
|
+
clearTimeout(timer);
|
|
75
|
+
setTimer(setTimeout(async () => {
|
|
76
|
+
if (typeof options === 'function') {
|
|
77
|
+
setLoading(true);
|
|
78
|
+
const result = await options(value);
|
|
79
|
+
setOptions(result);
|
|
80
|
+
setLoading(false);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
const filtered = options.filter(option => getLabel(option).toLowerCase().includes(value.toLowerCase()));
|
|
84
|
+
setOptions(filtered);
|
|
85
|
+
}
|
|
86
|
+
}, 300));
|
|
87
|
+
} })), jsx(Menu, { target: open ? menuRef.current : null, onClickOutside: () => {
|
|
88
|
+
setOptions([]);
|
|
89
|
+
setInputValue("");
|
|
90
|
+
}, slotProps: {
|
|
91
|
+
content: { minWidth: menuRef.current ? menuRef.current.offsetWidth : 'auto' }
|
|
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, {
|
|
93
|
+
onClick: () => {
|
|
94
|
+
if (multiple) {
|
|
95
|
+
let newValue = Array.isArray(value) ? [...value] : [];
|
|
96
|
+
const has = newValue.find((v) => getLabel(v) === getLabel(option));
|
|
97
|
+
if (!has) {
|
|
98
|
+
newValue.push(option);
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
newValue = newValue.filter((v) => getLabel(v) !== getLabel(option));
|
|
102
|
+
}
|
|
103
|
+
onChange && onChange(newValue);
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
onChange && onChange(option);
|
|
107
|
+
setOpen(false);
|
|
108
|
+
setInputValue(getLabel(option));
|
|
109
|
+
setOptions([]);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}) }, "auto-complete" + index + getLabel(option)) : jsx(ListItem, { onClick: () => {
|
|
113
|
+
if (multiple) {
|
|
114
|
+
let newValue = Array.isArray(value) ? [...value] : [];
|
|
115
|
+
const has = newValue.find((v) => getLabel(v) === getLabel(option));
|
|
116
|
+
if (!has) {
|
|
117
|
+
newValue.push(option);
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
newValue = newValue.filter((v) => getLabel(v) !== getLabel(option));
|
|
121
|
+
}
|
|
122
|
+
onChange && onChange(newValue);
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
onChange && onChange(option);
|
|
126
|
+
setOpen(false);
|
|
127
|
+
setInputValue(getLabel(option));
|
|
128
|
+
setOptions([]);
|
|
129
|
+
}
|
|
130
|
+
}, children: getLabel(option) }, index))) }) })] }));
|
|
131
|
+
};
|
|
132
|
+
|
|
133
|
+
export { Autocomplete as default };
|
|
134
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../src/Autocomplete/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react'\nimport Input from '../Input'\nimport Menu from '../Menu'\nimport List from '../List';\nimport ListItem, { ListItemProps } from '../ListItem';\nimport Chip from '../Chip';\nimport IconButton from '../IconButton';\nimport Close from '@xanui/icons/Close';\nimport CircleProgress from '../CircleProgress';\nimport { useBreakpointPropsType, UseColorTemplateColor } from '@xanui/core';\n\nexport type AutocompleteProps = {\n\n options: any[] | ((text: string) => Promise<any[]>)\n getLabel: (option: any) => string;\n onChange?: (value: any) => void;\n value?: any;\n multiple?: boolean;\n renderOption?: (option: any, props: any) => ReactElement<ListItemProps>\n\n // input props customization\n name?: string;\n placeholder?: string;\n readOnly?: boolean;\n autoFocus?: boolean;\n autoComplete?: string;\n label?: useBreakpointPropsType<string>;\n\n onFocus?: (e: React.FocusEvent<any>) => void;\n onBlur?: (e: React.FocusEvent<any>) => void;\n onInput?: (e: React.FormEvent<any>) => void;\n onKeyDown?: (e: React.KeyboardEvent<any>) => void;\n onKeyUp?: (e: React.KeyboardEvent<any>) => void;\n\n rows?: useBreakpointPropsType<number>;\n minRows?: useBreakpointPropsType<number>;\n maxRows?: useBreakpointPropsType<number>;\n fullWidth?: boolean;\n\n startIcon?: useBreakpointPropsType<ReactElement>;\n endIcon?: useBreakpointPropsType<ReactElement>;\n iconPlacement?: useBreakpointPropsType<\"start\" | \"center\" | \"end\">;\n focused?: boolean;\n color?: useBreakpointPropsType<Omit<UseColorTemplateColor, \"default\">>;\n variant?: useBreakpointPropsType<\"fill\" | \"outline\" | \"text\">;\n error?: boolean;\n helperText?: useBreakpointPropsType<string>;\n\n}\n\nconst Autocomplete = ({ value, onChange, renderOption, options, getLabel, multiple, ...inputProps }: AutocompleteProps) => {\n const [_options, setOptions] = React.useState<any[]>()\n const [inputValue, setInputValue] = React.useState(\"\")\n const [timer, setTimer] = React.useState<any>(null)\n const [loading, setLoading] = React.useState(false)\n const [open, setOpen] = React.useState(false)\n const menuRef = React.useRef<any>(null)\n\n getLabel ??= (option: any) => option.toString();\n multiple ??= false;\n\n let startIcons = [\n inputProps.startIcon\n ]\n\n if (!!value && multiple && Array.isArray(value)) {\n value.map((v: any, index: number) => {\n startIcons.push(<Chip\n key={index}\n size=\"small\"\n label={getLabel!(v)}\n variant={\"fill\"}\n color=\"default\"\n endIcon={<IconButton\n size={20}\n variant={\"text\"}\n color=\"default\"\n onClick={(e) => {\n e.stopPropagation();\n let newValue = Array.isArray(value) ? [...value] : []\n newValue = newValue.filter((val: any) => getLabel!(val) !== getLabel!(v))\n onChange && onChange(newValue)\n }}\n >\n <Close />\n </IconButton>}\n />)\n })\n }\n\n let endIcons = [\n inputProps.endIcon\n ]\n\n if (loading) {\n endIcons.push(<CircleProgress\n key=\"auto-complete-loading-icon\"\n size=\"small\"\n />)\n } else if (!!value && !multiple) {\n endIcons.push(<IconButton\n key=\"auto-complete-clear-button\"\n variant={\"text\"}\n color=\"default\"\n onClick={(e) => {\n e.stopPropagation();\n onChange && onChange(undefined)\n setInputValue(\"\")\n }}\n >\n <Close />\n </IconButton>)\n }\n\n\n return (\n <>\n <Input\n {...inputProps as any}\n ref={menuRef}\n slotProps={{\n rootContainer: {\n flexWrap: 'wrap',\n ...(multiple ? { height: \"auto\", gap: .5 } : {})\n },\n input: {\n width: multiple ? 'auto' : '100%',\n flex: 1,\n minWidth: 20,\n }\n }}\n startIcon={startIcons}\n endIcon={endIcons}\n value={inputValue}\n onKeyDown={(e) => {\n if (inputProps?.onKeyDown) {\n inputProps.onKeyDown(e)\n }\n if (multiple && e.key === 'Backspace' && inputValue === \"\" && Array.isArray(value) && value.length > 0) {\n let newValue = [...value]\n newValue.pop()\n onChange && onChange(newValue)\n }\n }}\n onChange={(e) => {\n const value = e.target.value;\n setInputValue(value)\n if (!value) {\n setOptions([])\n setOpen(false)\n return;\n }\n setOpen(true)\n\n clearTimeout(timer)\n setTimer(setTimeout(async () => {\n if (typeof options === 'function') {\n setLoading(true)\n const result = await options(value)\n setOptions(result)\n setLoading(false)\n } else {\n const filtered = options.filter(option => getLabel!(option).toLowerCase().includes(value.toLowerCase()))\n setOptions(filtered)\n }\n }, 300))\n }}\n />\n <Menu\n target={open ? menuRef.current : null}\n onClickOutside={() => {\n setOptions([])\n setInputValue(\"\")\n }}\n slotProps={{\n content: { minWidth: menuRef.current ? menuRef.current.offsetWidth : 'auto' }\n }}\n >\n <List\n maxHeight={400}\n overflow={\"auto\"}\n >\n {_options?.map((option, index) => (\n renderOption ? <div key={\"auto-complete\" + index + getLabel!(option)}>{renderOption(option, {\n onClick: () => {\n if (multiple) {\n let newValue = Array.isArray(value) ? [...value] : []\n const has = newValue.find((v: any) => getLabel!(v) === getLabel!(option))\n if (!has) {\n newValue.push(option)\n } else {\n newValue = newValue.filter((v: any) => getLabel!(v) !== getLabel!(option))\n }\n onChange && onChange(newValue)\n } else {\n onChange && onChange(option)\n setOpen(false)\n setInputValue(getLabel!(option))\n setOptions([])\n }\n }\n })}</div> : <ListItem\n key={index}\n onClick={() => {\n if (multiple) {\n let newValue = Array.isArray(value) ? [...value] : []\n const has = newValue.find((v: any) => getLabel!(v) === getLabel!(option))\n if (!has) {\n newValue.push(option)\n } else {\n newValue = newValue.filter((v: any) => getLabel!(v) !== getLabel!(option))\n }\n onChange && onChange(newValue)\n } else {\n onChange && onChange(option)\n setOpen(false)\n setInputValue(getLabel!(option))\n setOptions([])\n }\n }}\n >\n {getLabel!(option)}\n </ListItem>\n ))}\n </List>\n </Menu>\n </>\n )\n}\n\nexport default Autocomplete\n"],"names":["_jsx","_jsxs","_Fragment"],"mappings":"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"}
|
package/Avatar/index.d.ts
CHANGED
|
@@ -1,8 +1,13 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { TagComponentType, TagProps, useBreakpointPropsType } from '@xanui/core';
|
|
3
|
+
import { SkeletonProps } from '../Skeleton/index.js';
|
|
3
4
|
|
|
4
5
|
type AvatarProps<T extends TagComponentType = "img"> = TagProps<T> & {
|
|
5
6
|
size?: useBreakpointPropsType<number>;
|
|
7
|
+
skeleton?: boolean;
|
|
8
|
+
slotProps?: {
|
|
9
|
+
skeleton?: Omit<SkeletonProps, "height" | "width" | "loading" | "children">;
|
|
10
|
+
};
|
|
6
11
|
};
|
|
7
12
|
declare const Avatar: React.ForwardRefExoticComponent<Omit<AvatarProps<TagComponentType>, "ref"> & React.RefAttributes<unknown>>;
|
|
8
13
|
|
package/Avatar/index.js
CHANGED
|
@@ -5,17 +5,22 @@ var jsxRuntime = require('react/jsx-runtime');
|
|
|
5
5
|
var React = require('react');
|
|
6
6
|
var core = require('@xanui/core');
|
|
7
7
|
var PersonIcon = require('@xanui/icons/Person');
|
|
8
|
+
var index = require('../Skeleton/index.js');
|
|
8
9
|
|
|
9
10
|
const Avatar = React.forwardRef((_a, ref) => {
|
|
10
|
-
var
|
|
11
|
+
var _b;
|
|
12
|
+
var { children, src, alt, skeleton } = _a, rest = tslib.__rest(_a, ["children", "src", "alt", "skeleton"]);
|
|
11
13
|
const [faild, setFaild] = React.useState();
|
|
12
|
-
let [
|
|
14
|
+
let [_c] = core.useInterface("Avatar", rest, {}), { size, slotProps } = _c, props = tslib.__rest(_c, ["size", "slotProps"]);
|
|
13
15
|
size !== null && size !== void 0 ? size : (size = 36);
|
|
14
16
|
const _p = {};
|
|
15
17
|
if (size)
|
|
16
18
|
_p.size = size;
|
|
17
19
|
const p = core.useBreakpointProps(_p);
|
|
18
20
|
size = p.size;
|
|
21
|
+
if (skeleton) {
|
|
22
|
+
return jsxRuntime.jsx(index, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.skeleton, { height: size, width: size, animation: "wave", sx: Object.assign(Object.assign({}, (_b = slotProps === null || slotProps === void 0 ? void 0 : slotProps.skeleton) === null || _b === void 0 ? void 0 : _b.sx), { borderRadius: size }) }));
|
|
23
|
+
}
|
|
19
24
|
if (faild === false || !src) {
|
|
20
25
|
let t = (alt === null || alt === void 0 ? void 0 : alt.charAt(0).toUpperCase()) || (children || jsxRuntime.jsx(PersonIcon, {}));
|
|
21
26
|
return (jsxRuntime.jsx(core.Tag, Object.assign({ component: "div", src: src }, props, { baseClass: 'avatar', sxr: {
|
package/Avatar/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/Avatar/index.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\nimport PersonIcon from '@xanui/icons/Person'\n\nexport type AvatarProps<T extends TagComponentType = \"img\"> = TagProps<T> & {\n size?: useBreakpointPropsType<number>;\n}\n\nconst Avatar = React.forwardRef(<T extends TagComponentType = \"img\">({ children, src, alt, ...rest }: AvatarProps<T>, ref: any) => {\n const [faild, setFaild] = useState<boolean>()\n let [{ size, ...props }] = useInterface<any>(\"Avatar\", rest, {})\n size ??= 36\n const _p: any = {}\n if (size) _p.size = size\n const p: any = useBreakpointProps(_p)\n size = p.size\n\n if (faild === false || !src) {\n let t = alt?.charAt(0).toUpperCase() || (children || <PersonIcon />)\n return (\n <Tag\n component=\"div\"\n src={src}\n {...props}\n baseClass='avatar'\n sxr={{\n display: \"inline-flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n bgcolor: \"background.secondary\",\n radius: size,\n fontSize: (size / 3) * 2,\n width: size,\n height: size,\n userSelect: \"none\",\n color: \"text.primary\",\n '& svg': {\n fontSize: (size / 3) * 2,\n opacity: .6\n }\n }}\n ref={ref}\n >{t}</Tag>\n )\n }\n return (\n <Tag\n component=\"img\"\n radius={size}\n width={size}\n height={size}\n objectFit=\"cover\"\n {...props}\n alt={alt}\n src={src}\n baseClass='avatar'\n onError={(e) => {\n setFaild(false)\n props.onError && props.onError(e as any)\n }}\n ref={ref}\n />\n )\n})\n\nexport default Avatar\n\n\n"],"names":["__rest","useState","useInterface","useBreakpointProps","_jsx","Tag"],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/Avatar/index.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\nimport PersonIcon from '@xanui/icons/Person'\nimport Skeleton, { SkeletonProps } from '../Skeleton';\n\nexport type AvatarProps<T extends TagComponentType = \"img\"> = TagProps<T> & {\n size?: useBreakpointPropsType<number>;\n skeleton?: boolean;\n slotProps?: {\n skeleton?: Omit<SkeletonProps, \"height\" | \"width\" | \"loading\" | \"children\">\n }\n}\n\nconst Avatar = React.forwardRef(<T extends TagComponentType = \"img\">({ children, src, alt, skeleton, ...rest }: AvatarProps<T>, ref: any) => {\n const [faild, setFaild] = useState<boolean>()\n let [{ size, slotProps, ...props }] = useInterface<any>(\"Avatar\", rest, {})\n size ??= 36\n const _p: any = {}\n if (size) _p.size = size\n const p: any = useBreakpointProps(_p)\n size = p.size\n\n if (skeleton) {\n return <Skeleton\n {...slotProps?.skeleton}\n height={size}\n width={size}\n animation={\"wave\"}\n sx={{\n ...slotProps?.skeleton?.sx,\n borderRadius: size,\n }}\n />\n }\n\n if (faild === false || !src) {\n let t = alt?.charAt(0).toUpperCase() || (children || <PersonIcon />)\n return (\n <Tag\n component=\"div\"\n src={src}\n {...props}\n baseClass='avatar'\n sxr={{\n display: \"inline-flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n bgcolor: \"background.secondary\",\n radius: size,\n fontSize: (size / 3) * 2,\n width: size,\n height: size,\n userSelect: \"none\",\n color: \"text.primary\",\n '& svg': {\n fontSize: (size / 3) * 2,\n opacity: .6\n }\n }}\n ref={ref}\n >{t}</Tag>\n )\n }\n return (\n <Tag\n component=\"img\"\n radius={size}\n width={size}\n height={size}\n objectFit=\"cover\"\n {...props}\n alt={alt}\n src={src}\n baseClass='avatar'\n onError={(e) => {\n setFaild(false)\n props.onError && props.onError(e as any)\n }}\n ref={ref}\n />\n )\n})\n\nexport default Avatar\n\n\n"],"names":["__rest","useState","useInterface","useBreakpointProps","_jsx","Skeleton","Tag"],"mappings":"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"}
|
package/Avatar/index.mjs
CHANGED
|
@@ -3,17 +3,22 @@ import { jsx } from 'react/jsx-runtime';
|
|
|
3
3
|
import React, { useState } from 'react';
|
|
4
4
|
import { useInterface, useBreakpointProps, Tag } from '@xanui/core';
|
|
5
5
|
import PersonIcon from '@xanui/icons/Person';
|
|
6
|
+
import Skeleton from '../Skeleton/index.mjs';
|
|
6
7
|
|
|
7
8
|
const Avatar = React.forwardRef((_a, ref) => {
|
|
8
|
-
var
|
|
9
|
+
var _b;
|
|
10
|
+
var { children, src, alt, skeleton } = _a, rest = __rest(_a, ["children", "src", "alt", "skeleton"]);
|
|
9
11
|
const [faild, setFaild] = useState();
|
|
10
|
-
let [
|
|
12
|
+
let [_c] = useInterface("Avatar", rest, {}), { size, slotProps } = _c, props = __rest(_c, ["size", "slotProps"]);
|
|
11
13
|
size !== null && size !== void 0 ? size : (size = 36);
|
|
12
14
|
const _p = {};
|
|
13
15
|
if (size)
|
|
14
16
|
_p.size = size;
|
|
15
17
|
const p = useBreakpointProps(_p);
|
|
16
18
|
size = p.size;
|
|
19
|
+
if (skeleton) {
|
|
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 }) }));
|
|
21
|
+
}
|
|
17
22
|
if (faild === false || !src) {
|
|
18
23
|
let t = (alt === null || alt === void 0 ? void 0 : alt.charAt(0).toUpperCase()) || (children || jsx(PersonIcon, {}));
|
|
19
24
|
return (jsx(Tag, Object.assign({ component: "div", src: src }, props, { baseClass: 'avatar', sxr: {
|
package/Avatar/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../src/Avatar/index.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\nimport PersonIcon from '@xanui/icons/Person'\n\nexport type AvatarProps<T extends TagComponentType = \"img\"> = TagProps<T> & {\n size?: useBreakpointPropsType<number>;\n}\n\nconst Avatar = React.forwardRef(<T extends TagComponentType = \"img\">({ children, src, alt, ...rest }: AvatarProps<T>, ref: any) => {\n const [faild, setFaild] = useState<boolean>()\n let [{ size, ...props }] = useInterface<any>(\"Avatar\", rest, {})\n size ??= 36\n const _p: any = {}\n if (size) _p.size = size\n const p: any = useBreakpointProps(_p)\n size = p.size\n\n if (faild === false || !src) {\n let t = alt?.charAt(0).toUpperCase() || (children || <PersonIcon />)\n return (\n <Tag\n component=\"div\"\n src={src}\n {...props}\n baseClass='avatar'\n sxr={{\n display: \"inline-flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n bgcolor: \"background.secondary\",\n radius: size,\n fontSize: (size / 3) * 2,\n width: size,\n height: size,\n userSelect: \"none\",\n color: \"text.primary\",\n '& svg': {\n fontSize: (size / 3) * 2,\n opacity: .6\n }\n }}\n ref={ref}\n >{t}</Tag>\n )\n }\n return (\n <Tag\n component=\"img\"\n radius={size}\n width={size}\n height={size}\n objectFit=\"cover\"\n {...props}\n alt={alt}\n src={src}\n baseClass='avatar'\n onError={(e) => {\n setFaild(false)\n props.onError && props.onError(e as any)\n }}\n ref={ref}\n />\n )\n})\n\nexport default Avatar\n\n\n"],"names":["_jsx"],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../src/Avatar/index.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport { Tag, TagProps, TagComponentType, useInterface, useBreakpointPropsType, useBreakpointProps } from '@xanui/core';\nimport PersonIcon from '@xanui/icons/Person'\nimport Skeleton, { SkeletonProps } from '../Skeleton';\n\nexport type AvatarProps<T extends TagComponentType = \"img\"> = TagProps<T> & {\n size?: useBreakpointPropsType<number>;\n skeleton?: boolean;\n slotProps?: {\n skeleton?: Omit<SkeletonProps, \"height\" | \"width\" | \"loading\" | \"children\">\n }\n}\n\nconst Avatar = React.forwardRef(<T extends TagComponentType = \"img\">({ children, src, alt, skeleton, ...rest }: AvatarProps<T>, ref: any) => {\n const [faild, setFaild] = useState<boolean>()\n let [{ size, slotProps, ...props }] = useInterface<any>(\"Avatar\", rest, {})\n size ??= 36\n const _p: any = {}\n if (size) _p.size = size\n const p: any = useBreakpointProps(_p)\n size = p.size\n\n if (skeleton) {\n return <Skeleton\n {...slotProps?.skeleton}\n height={size}\n width={size}\n animation={\"wave\"}\n sx={{\n ...slotProps?.skeleton?.sx,\n borderRadius: size,\n }}\n />\n }\n\n if (faild === false || !src) {\n let t = alt?.charAt(0).toUpperCase() || (children || <PersonIcon />)\n return (\n <Tag\n component=\"div\"\n src={src}\n {...props}\n baseClass='avatar'\n sxr={{\n display: \"inline-flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n bgcolor: \"background.secondary\",\n radius: size,\n fontSize: (size / 3) * 2,\n width: size,\n height: size,\n userSelect: \"none\",\n color: \"text.primary\",\n '& svg': {\n fontSize: (size / 3) * 2,\n opacity: .6\n }\n }}\n ref={ref}\n >{t}</Tag>\n )\n }\n return (\n <Tag\n component=\"img\"\n radius={size}\n width={size}\n height={size}\n objectFit=\"cover\"\n {...props}\n alt={alt}\n src={src}\n baseClass='avatar'\n onError={(e) => {\n setFaild(false)\n props.onError && props.onError(e as any)\n }}\n ref={ref}\n />\n )\n})\n\nexport default Avatar\n\n\n"],"names":["_jsx"],"mappings":"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"}
|
package/Button/index.d.ts
CHANGED
|
@@ -2,6 +2,7 @@ import React, { ReactElement } from 'react';
|
|
|
2
2
|
import { TagComponentType, TagProps, useBreakpointPropsType, UseColorTemplateColor, UseColorTemplateType } from '@xanui/core';
|
|
3
3
|
import { UseCornerTypes } from '../useCorner/index.js';
|
|
4
4
|
import { CircleProgressProps } from '../CircleProgress/index.js';
|
|
5
|
+
import { SkeletonProps } from '../Skeleton/index.js';
|
|
5
6
|
|
|
6
7
|
type ButtonProps<T extends TagComponentType = 'button'> = Omit<TagProps<T>, "color" | "size" | "direction"> & {
|
|
7
8
|
startIcon?: useBreakpointPropsType<ReactElement>;
|
|
@@ -12,8 +13,10 @@ type ButtonProps<T extends TagComponentType = 'button'> = Omit<TagProps<T>, "col
|
|
|
12
13
|
size?: useBreakpointPropsType<"small" | "medium" | "large">;
|
|
13
14
|
direction?: useBreakpointPropsType<"row" | "column">;
|
|
14
15
|
loading?: boolean;
|
|
16
|
+
skeleton?: boolean;
|
|
15
17
|
slotProps?: {
|
|
16
18
|
loading?: Omit<CircleProgressProps, "color" | "hideTrack" | "size">;
|
|
19
|
+
skeleton?: Omit<SkeletonProps, "height" | "width" | "loading" | "children">;
|
|
17
20
|
};
|
|
18
21
|
};
|
|
19
22
|
declare const Button: React.ForwardRefExoticComponent<Omit<ButtonProps<TagComponentType>, "ref"> & React.RefAttributes<any>>;
|
package/Button/index.js
CHANGED
|
@@ -6,17 +6,18 @@ var jsxRuntime = require('react/jsx-runtime');
|
|
|
6
6
|
var React = require('react');
|
|
7
7
|
var core = require('@xanui/core');
|
|
8
8
|
var index$1 = require('../useCorner/index.js');
|
|
9
|
-
var index = require('../CircleProgress/index.js');
|
|
9
|
+
var index$2 = require('../CircleProgress/index.js');
|
|
10
|
+
var index = require('../Skeleton/index.js');
|
|
10
11
|
|
|
11
12
|
const Button = React.forwardRef((_a, ref) => {
|
|
12
|
-
var _b;
|
|
13
|
-
var { children } = _a, rest = tslib.__rest(_a, ["children"]);
|
|
14
|
-
let [
|
|
13
|
+
var _b, _c;
|
|
14
|
+
var { children, skeleton } = _a, rest = tslib.__rest(_a, ["children", "skeleton"]);
|
|
15
|
+
let [_d] = core.useInterface('Button', rest, {
|
|
15
16
|
variant: "fill",
|
|
16
17
|
color: "brand",
|
|
17
18
|
corner: "rounded",
|
|
18
19
|
size: "medium"
|
|
19
|
-
}), { variant, startIcon, endIcon, color, corner, size, loading, direction, slotProps } =
|
|
20
|
+
}), { variant, startIcon, endIcon, color, corner, size, loading, direction, slotProps } = _d, _props = tslib.__rest(_d, ["variant", "startIcon", "endIcon", "color", "corner", "size", "loading", "direction", "slotProps"]);
|
|
20
21
|
const _p = {};
|
|
21
22
|
if (startIcon)
|
|
22
23
|
_p.startIcon = startIcon;
|
|
@@ -44,13 +45,13 @@ const Button = React.forwardRef((_a, ref) => {
|
|
|
44
45
|
const cornerCss = index$1(corner);
|
|
45
46
|
const sizes = {
|
|
46
47
|
small: {
|
|
47
|
-
height:
|
|
48
|
+
height: 38,
|
|
48
49
|
px: (startIcon || endIcon) ? 1 : 1.5,
|
|
49
50
|
gap: .5,
|
|
50
51
|
fontSize: 'button'
|
|
51
52
|
},
|
|
52
53
|
medium: {
|
|
53
|
-
height:
|
|
54
|
+
height: 44,
|
|
54
55
|
px: (startIcon || endIcon) ? 1.5 : 2,
|
|
55
56
|
gap: 1,
|
|
56
57
|
fontSize: 'button'
|
|
@@ -73,7 +74,10 @@ const Button = React.forwardRef((_a, ref) => {
|
|
|
73
74
|
_size.gap = .5;
|
|
74
75
|
_size.py = 1;
|
|
75
76
|
}
|
|
76
|
-
|
|
77
|
+
if (skeleton) {
|
|
78
|
+
return jsxRuntime.jsx(index, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.skeleton, { height: _size.height, animation: "wave", sx: Object.assign(Object.assign(Object.assign({}, (_b = slotProps === null || slotProps === void 0 ? void 0 : slotProps.skeleton) === null || _b === void 0 ? void 0 : _b.sx), _size), cornerCss) }));
|
|
79
|
+
}
|
|
80
|
+
return (jsxRuntime.jsxs(core.Tag, Object.assign({ component: 'button', baseClass: 'button' }, _props, { sxr: Object.assign(Object.assign(Object.assign({ flexShrink: "0", whiteSpace: "nowrap", cursor: "pointer", display: "flex", textTransform: "uppercase", flexDirection: direction, alignItems: "center", justifyContent: "center", position: "relative", overflow: "hidden", userSelect: "none", fontWeight: 500 }, _size), cornerCss), template.primary), hover: Object.assign(Object.assign({}, template.secondary), ((_props === null || _props === void 0 ? void 0 : _props.hover) || {})), disabled: (_c = loading !== null && loading !== void 0 ? loading : _props.disabled) !== null && _c !== void 0 ? _c : false, ref: ref, children: [loading && jsxRuntime.jsx(core.Tag, { baseClass: 'button-loading-container', sxr: {
|
|
77
81
|
position: "absolute",
|
|
78
82
|
top: 0,
|
|
79
83
|
left: 0,
|
|
@@ -83,7 +87,7 @@ const Button = React.forwardRef((_a, ref) => {
|
|
|
83
87
|
display: "flex",
|
|
84
88
|
justifyContent: "center",
|
|
85
89
|
alignItems: "center",
|
|
86
|
-
}, children: jsxRuntime.jsx(index, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.loading, { color: color === 'default' ? `brand` : "default", size: progressSizes[size], className: 'button-loading-progress' })) }), startIcon && jsxRuntime.jsx(core.Tag, { baseClass: 'button-start-icon', component: 'span', display: "inline-block", flexShrink: 0, children: startIcon }), children, endIcon && jsxRuntime.jsx(core.Tag, { baseClass: 'button-end-icon', component: 'span', display: "inline-block", flexShrink: 0, children: endIcon })] })));
|
|
90
|
+
}, children: jsxRuntime.jsx(index$2, Object.assign({}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.loading, { color: color === 'default' ? `brand` : "default", size: progressSizes[size], className: 'button-loading-progress' })) }), startIcon && jsxRuntime.jsx(core.Tag, { baseClass: 'button-start-icon', component: 'span', display: "inline-block", flexShrink: 0, children: startIcon }), children, endIcon && jsxRuntime.jsx(core.Tag, { baseClass: 'button-end-icon', component: 'span', display: "inline-block", flexShrink: 0, children: endIcon })] })));
|
|
87
91
|
});
|
|
88
92
|
|
|
89
93
|
module.exports = Button;
|