@phpsoftbox/react-softbox 0.1.0
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/LICENSE +21 -0
- package/README.md +271 -0
- package/dist/components/Alert/Alert.d.ts +11 -0
- package/dist/components/Alert/Alert.js +15 -0
- package/dist/components/Alert/Alert.js.map +1 -0
- package/dist/components/Alert/Alert.module.css +73 -0
- package/dist/components/Badge/Badge.d.ts +8 -0
- package/dist/components/Badge/Badge.js +15 -0
- package/dist/components/Badge/Badge.js.map +1 -0
- package/dist/components/Badge/Badge.module.css +47 -0
- package/dist/components/Breadcrumbs/Breadcrumbs.d.ts +24 -0
- package/dist/components/Breadcrumbs/Breadcrumbs.js +15 -0
- package/dist/components/Breadcrumbs/Breadcrumbs.js.map +1 -0
- package/dist/components/Breadcrumbs/Breadcrumbs.module.css +55 -0
- package/dist/components/Button/Button.d.ts +10 -0
- package/dist/components/Button/Button.js +37 -0
- package/dist/components/Button/Button.js.map +1 -0
- package/dist/components/Button/Button.module.css +130 -0
- package/dist/components/Card/Card.d.ts +15 -0
- package/dist/components/Card/Card.js +26 -0
- package/dist/components/Card/Card.js.map +1 -0
- package/dist/components/Card/Card.module.css +55 -0
- package/dist/components/CollapseButton/CollapseButton.d.ts +9 -0
- package/dist/components/CollapseButton/CollapseButton.js +11 -0
- package/dist/components/CollapseButton/CollapseButton.js.map +1 -0
- package/dist/components/CollapseButton/CollapseButton.module.css +57 -0
- package/dist/components/Drawer/Drawer.d.ts +19 -0
- package/dist/components/Drawer/Drawer.js +42 -0
- package/dist/components/Drawer/Drawer.js.map +1 -0
- package/dist/components/Drawer/Drawer.module.css +104 -0
- package/dist/components/Flex/Flex.module.css +11 -0
- package/dist/components/Flex/Row.d.ts +9 -0
- package/dist/components/Flex/Row.js +14 -0
- package/dist/components/Flex/Row.js.map +1 -0
- package/dist/components/Flex/Stack.d.ts +8 -0
- package/dist/components/Flex/Stack.js +13 -0
- package/dist/components/Flex/Stack.js.map +1 -0
- package/dist/components/Grid/Grid.d.ts +11 -0
- package/dist/components/Grid/Grid.js +16 -0
- package/dist/components/Grid/Grid.js.map +1 -0
- package/dist/components/Grid/Grid.module.css +32 -0
- package/dist/components/Input/DatePicker.d.ts +6 -0
- package/dist/components/Input/DatePicker.js +6 -0
- package/dist/components/Input/DatePicker.js.map +1 -0
- package/dist/components/Input/DateRangePicker.d.ts +16 -0
- package/dist/components/Input/DateRangePicker.js +16 -0
- package/dist/components/Input/DateRangePicker.js.map +1 -0
- package/dist/components/Input/Field.d.ts +5 -0
- package/dist/components/Input/Field.js +25 -0
- package/dist/components/Input/Field.js.map +1 -0
- package/dist/components/Input/FloatLabel/FloatLabel.d.ts +9 -0
- package/dist/components/Input/FloatLabel/FloatLabel.js +22 -0
- package/dist/components/Input/FloatLabel/FloatLabel.js.map +1 -0
- package/dist/components/Input/FloatLabel/FloatLabel.module.css +41 -0
- package/dist/components/Input/FormField/FormField.d.ts +29 -0
- package/dist/components/Input/FormField/FormField.js +60 -0
- package/dist/components/Input/FormField/FormField.js.map +1 -0
- package/dist/components/Input/FormField/FormField.module.css +30 -0
- package/dist/components/Input/Input.d.ts +59 -0
- package/dist/components/Input/Input.js +34 -0
- package/dist/components/Input/Input.js.map +1 -0
- package/dist/components/Input/Input.module.css +31 -0
- package/dist/components/Input/InputGroup.d.ts +11 -0
- package/dist/components/Input/InputGroup.js +25 -0
- package/dist/components/Input/InputGroup.js.map +1 -0
- package/dist/components/Input/InputGroup.module.css +38 -0
- package/dist/components/Input/MaskedInput.d.ts +9 -0
- package/dist/components/Input/MaskedInput.js +82 -0
- package/dist/components/Input/MaskedInput.js.map +1 -0
- package/dist/components/Input/NumberInput.d.ts +10 -0
- package/dist/components/Input/NumberInput.js +44 -0
- package/dist/components/Input/NumberInput.js.map +1 -0
- package/dist/components/Input/Radio/Radio.d.ts +7 -0
- package/dist/components/Input/Radio/Radio.js +9 -0
- package/dist/components/Input/Radio/Radio.js.map +1 -0
- package/dist/components/Input/Radio/Radio.module.css +83 -0
- package/dist/components/Input/Select/Select.d.ts +38 -0
- package/dist/components/Input/Select/Select.js +200 -0
- package/dist/components/Input/Select/Select.js.map +1 -0
- package/dist/components/Input/Select/Select.module.css +194 -0
- package/dist/components/Input/Switch/Switch.d.ts +6 -0
- package/dist/components/Input/Switch/Switch.js +9 -0
- package/dist/components/Input/Switch/Switch.js.map +1 -0
- package/dist/components/Input/Switch/Switch.module.css +62 -0
- package/dist/components/Input/Textarea/Textarea.d.ts +6 -0
- package/dist/components/Input/Textarea/Textarea.js +21 -0
- package/dist/components/Input/Textarea/Textarea.js.map +1 -0
- package/dist/components/Input/Textarea/Textarea.module.css +39 -0
- package/dist/components/Input/TimePicker.d.ts +4 -0
- package/dist/components/Input/TimePicker.js +6 -0
- package/dist/components/Input/TimePicker.js.map +1 -0
- package/dist/components/Menu/Dropdown.d.ts +13 -0
- package/dist/components/Menu/Dropdown.js +58 -0
- package/dist/components/Menu/Dropdown.js.map +1 -0
- package/dist/components/Menu/Menu.d.ts +31 -0
- package/dist/components/Menu/Menu.js +161 -0
- package/dist/components/Menu/Menu.js.map +1 -0
- package/dist/components/Menu/Menu.module.css +240 -0
- package/dist/components/Modal/Modal.d.ts +12 -0
- package/dist/components/Modal/Modal.js +31 -0
- package/dist/components/Modal/Modal.js.map +1 -0
- package/dist/components/Modal/Modal.module.css +90 -0
- package/dist/components/Notifier/Notifier.d.ts +17 -0
- package/dist/components/Notifier/Notifier.js +210 -0
- package/dist/components/Notifier/Notifier.js.map +1 -0
- package/dist/components/Notifier/Notifier.module.css +182 -0
- package/dist/components/Pagination/Pagination.d.ts +28 -0
- package/dist/components/Pagination/Pagination.js +70 -0
- package/dist/components/Pagination/Pagination.js.map +1 -0
- package/dist/components/Pagination/Pagination.module.css +93 -0
- package/dist/components/Progress/Progress.d.ts +16 -0
- package/dist/components/Progress/Progress.js +32 -0
- package/dist/components/Progress/Progress.js.map +1 -0
- package/dist/components/Progress/Progress.module.css +110 -0
- package/dist/components/Tabs/Tabs.d.ts +20 -0
- package/dist/components/Tabs/Tabs.js +115 -0
- package/dist/components/Tabs/Tabs.js.map +1 -0
- package/dist/components/Tabs/Tabs.module.css +101 -0
- package/dist/components/Typography/Heading.d.ts +13 -0
- package/dist/components/Typography/Heading.js +38 -0
- package/dist/components/Typography/Heading.js.map +1 -0
- package/dist/components/Typography/Text.d.ts +20 -0
- package/dist/components/Typography/Text.js +43 -0
- package/dist/components/Typography/Text.js.map +1 -0
- package/dist/components/Typography/Typography.module.css +132 -0
- package/dist/foundations/index.css +3 -0
- package/dist/foundations/layout.css +78 -0
- package/dist/foundations/tokens.css +236 -0
- package/dist/foundations/typography.css +49 -0
- package/dist/hooks/useDropdownPosition.d.ts +14 -0
- package/dist/hooks/useDropdownPosition.js +61 -0
- package/dist/hooks/useDropdownPosition.js.map +1 -0
- package/dist/hooks/useMediaQuery.d.ts +1 -0
- package/dist/hooks/useMediaQuery.js +33 -0
- package/dist/hooks/useMediaQuery.js.map +1 -0
- package/dist/index.d.ts +30 -0
- package/dist/index.js +29 -0
- package/dist/index.js.map +1 -0
- package/dist/theme.d.ts +12 -0
- package/dist/theme.js +133 -0
- package/dist/theme.js.map +1 -0
- package/dist/types.d.ts +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/docs/README.md +40 -0
- package/docs/breadcrumbs.md +47 -0
- package/docs/card.md +18 -0
- package/docs/feedback.md +38 -0
- package/docs/forms.md +166 -0
- package/docs/layout.md +39 -0
- package/docs/navigation.md +80 -0
- package/docs/overlays.md +31 -0
- package/docs/pagination.md +50 -0
- package/docs/progress.md +18 -0
- package/docs/tabs.md +34 -0
- package/docs/theme.md +49 -0
- package/docs/typography.md +26 -0
- package/package.json +49 -0
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import InputField from './Field';
|
|
4
|
+
const normalize = (raw, allowNegative) => {
|
|
5
|
+
let next = raw.replace(/[^0-9,.-]/g, '');
|
|
6
|
+
if (!allowNegative) {
|
|
7
|
+
next = next.replace(/-/g, '');
|
|
8
|
+
}
|
|
9
|
+
else {
|
|
10
|
+
const hasMinus = next.startsWith('-');
|
|
11
|
+
next = next.replace(/-/g, '');
|
|
12
|
+
if (hasMinus) {
|
|
13
|
+
next = `-${next}`;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
const parts = next.split(/[.,]/);
|
|
17
|
+
const integer = parts[0] ?? '';
|
|
18
|
+
const decimal = parts.slice(1).join('');
|
|
19
|
+
return { integer, decimal, negative: integer.startsWith('-') };
|
|
20
|
+
};
|
|
21
|
+
export default function NumberInput({ value, onChange, allowNegative = false, decimalSeparator = '.', decimalScale = 2, ...props }) {
|
|
22
|
+
const isControlled = value !== undefined;
|
|
23
|
+
const [internal, setInternal] = React.useState('');
|
|
24
|
+
const displayValue = React.useMemo(() => {
|
|
25
|
+
const source = isControlled ? String(value ?? '') : internal;
|
|
26
|
+
const { integer, decimal } = normalize(source, allowNegative);
|
|
27
|
+
const cleanInteger = integer.replace(/(?!^)-/g, '');
|
|
28
|
+
const slicedDecimal = decimalScale >= 0 ? decimal.slice(0, decimalScale) : decimal;
|
|
29
|
+
const base = `${cleanInteger}${slicedDecimal ? `${decimalSeparator}${slicedDecimal}` : ''}`;
|
|
30
|
+
return base;
|
|
31
|
+
}, [value, internal, allowNegative, decimalSeparator, decimalScale, isControlled]);
|
|
32
|
+
const handleChange = (event) => {
|
|
33
|
+
const raw = event.target.value;
|
|
34
|
+
const { integer, decimal } = normalize(raw, allowNegative);
|
|
35
|
+
const nextDecimal = decimalScale >= 0 ? decimal.slice(0, decimalScale) : decimal;
|
|
36
|
+
const normalized = `${integer.replace(/(?!^)-/g, '')}${nextDecimal ? `.${nextDecimal}` : ''}`;
|
|
37
|
+
if (!isControlled) {
|
|
38
|
+
setInternal(normalized);
|
|
39
|
+
}
|
|
40
|
+
onChange?.(normalized);
|
|
41
|
+
};
|
|
42
|
+
return (_jsx(InputField, { ...props, type: "text", inputMode: "decimal", value: displayValue, onChange: handleChange }));
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=NumberInput.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NumberInput.js","sourceRoot":"","sources":["../../../src/components/Input/NumberInput.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
type Props = Omit<React.InputHTMLAttributes<HTMLInputElement>, 'type'> & {
|
|
3
|
+
label?: React.ReactNode;
|
|
4
|
+
description?: React.ReactNode;
|
|
5
|
+
};
|
|
6
|
+
export default function Radio({ id, label, description, className, ...props }: Props): import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
export {};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import styles from './Radio.module.css';
|
|
4
|
+
export default function Radio({ id, label, description, className, ...props }) {
|
|
5
|
+
const inputId = id ?? React.useId();
|
|
6
|
+
const classes = [styles.radio, className].filter(Boolean).join(' ');
|
|
7
|
+
return (_jsxs("label", { className: classes, htmlFor: inputId, children: [_jsx("input", { id: inputId, type: "radio", className: styles.input, ...props }), _jsx("span", { className: styles.control, "aria-hidden": "true" }), _jsxs("span", { className: styles.texts, children: [label ? _jsx("span", { className: styles.label, children: label }) : null, description ? _jsx("span", { className: styles.description, children: description }) : null] })] }));
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=Radio.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Radio.js","sourceRoot":"","sources":["../../../../src/components/Input/Radio/Radio.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AAOxC,MAAM,CAAC,OAAO,UAAU,KAAK,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,GAAG,KAAK,EAAS;IAClF,MAAM,OAAO,GAAG,EAAE,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;IACpC,MAAM,OAAO,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAEpE,OAAO,CACL,iBAAO,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,aACzC,gBAAO,EAAE,EAAE,OAAO,EAAE,IAAI,EAAC,OAAO,EAAC,SAAS,EAAE,MAAM,CAAC,KAAK,KAAM,KAAK,GAAI,EACvE,eAAM,SAAS,EAAE,MAAM,CAAC,OAAO,iBAAc,MAAM,GAAG,EACtD,gBAAM,SAAS,EAAE,MAAM,CAAC,KAAK,aAC1B,KAAK,CAAC,CAAC,CAAC,eAAM,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAQ,CAAC,CAAC,CAAC,IAAI,EAC5D,WAAW,CAAC,CAAC,CAAC,eAAM,SAAS,EAAE,MAAM,CAAC,WAAW,YAAG,WAAW,GAAQ,CAAC,CAAC,CAAC,IAAI,IAC1E,IACD,CACT,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
.radio {
|
|
2
|
+
display: inline-flex;
|
|
3
|
+
align-items: flex-start;
|
|
4
|
+
gap: 10px;
|
|
5
|
+
cursor: pointer;
|
|
6
|
+
color: var(--color-text);
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
.input {
|
|
10
|
+
position: absolute;
|
|
11
|
+
opacity: 0;
|
|
12
|
+
pointer-events: none;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
.control {
|
|
16
|
+
width: 18px;
|
|
17
|
+
height: 18px;
|
|
18
|
+
border-radius: 50%;
|
|
19
|
+
border: 1px solid rgba(30, 99, 233, 0.45);
|
|
20
|
+
background: var(--surface-input);
|
|
21
|
+
display: inline-flex;
|
|
22
|
+
align-items: center;
|
|
23
|
+
justify-content: center;
|
|
24
|
+
transition: border-color 0.2s ease, box-shadow 0.2s ease;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.control::after {
|
|
28
|
+
content: '';
|
|
29
|
+
width: 8px;
|
|
30
|
+
height: 8px;
|
|
31
|
+
border-radius: 50%;
|
|
32
|
+
background: var(--color-teal);
|
|
33
|
+
transform: scale(0);
|
|
34
|
+
transition: transform 0.2s ease;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.input:checked + .control {
|
|
38
|
+
border-color: rgba(20, 201, 214, 0.8);
|
|
39
|
+
box-shadow: 0 0 0 3px rgba(20, 201, 214, 0.2);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
.input:checked + .control::after {
|
|
43
|
+
transform: scale(1);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.input:focus-visible + .control {
|
|
47
|
+
outline: none;
|
|
48
|
+
box-shadow: 0 0 0 3px rgba(20, 201, 214, 0.2);
|
|
49
|
+
border-color: rgba(20, 201, 214, 0.8);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.input:disabled + .control {
|
|
53
|
+
opacity: 0.6;
|
|
54
|
+
cursor: not-allowed;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
.input:disabled ~ .texts {
|
|
58
|
+
opacity: 0.6;
|
|
59
|
+
cursor: not-allowed;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.texts {
|
|
63
|
+
display: flex;
|
|
64
|
+
flex-direction: column;
|
|
65
|
+
gap: 4px;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
.label {
|
|
69
|
+
font-size: 14px;
|
|
70
|
+
font-weight: 600;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
.description {
|
|
74
|
+
font-size: 12px;
|
|
75
|
+
color: var(--color-muted);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
@media (prefers-reduced-motion: reduce) {
|
|
79
|
+
.control,
|
|
80
|
+
.control::after {
|
|
81
|
+
transition: none;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
export type SelectOption = {
|
|
2
|
+
value: string;
|
|
3
|
+
label: string;
|
|
4
|
+
disabled?: boolean;
|
|
5
|
+
};
|
|
6
|
+
type RequestConfig = {
|
|
7
|
+
url: string;
|
|
8
|
+
method?: 'get' | 'post';
|
|
9
|
+
params?: Record<string, unknown>;
|
|
10
|
+
data?: Record<string, unknown>;
|
|
11
|
+
mapOptions?: (data: unknown) => SelectOption[];
|
|
12
|
+
};
|
|
13
|
+
type Props = {
|
|
14
|
+
label?: string;
|
|
15
|
+
id?: string;
|
|
16
|
+
name?: string;
|
|
17
|
+
options?: SelectOption[];
|
|
18
|
+
value?: string | string[];
|
|
19
|
+
defaultValue?: string | string[];
|
|
20
|
+
placeholder?: string;
|
|
21
|
+
multiple?: boolean;
|
|
22
|
+
searchable?: boolean;
|
|
23
|
+
loadingText?: string;
|
|
24
|
+
emptyText?: string;
|
|
25
|
+
loadOptions?: (query: string) => Promise<SelectOption[]>;
|
|
26
|
+
request?: RequestConfig;
|
|
27
|
+
onAfterRequest?: (options: SelectOption[], query: string) => void;
|
|
28
|
+
placement?: 'auto' | 'down' | 'up';
|
|
29
|
+
disabled?: boolean;
|
|
30
|
+
floatLabel?: boolean;
|
|
31
|
+
className?: string;
|
|
32
|
+
onChange?: (value: string | string[], options: SelectOption[]) => void;
|
|
33
|
+
};
|
|
34
|
+
declare function Select({ label, id, name, options, value, defaultValue, placeholder, multiple, searchable, loadingText, emptyText, loadOptions, request, onAfterRequest, placement, disabled, floatLabel, className, onChange, }: Props): import("react/jsx-runtime").JSX.Element;
|
|
35
|
+
declare namespace Select {
|
|
36
|
+
var supportsFloatLabel: boolean;
|
|
37
|
+
}
|
|
38
|
+
export default Select;
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import axios from 'axios';
|
|
4
|
+
import styles from './Select.module.css';
|
|
5
|
+
import useDropdownPosition from '../../../hooks/useDropdownPosition';
|
|
6
|
+
import { useFormFieldContext } from '../FormField/FormField';
|
|
7
|
+
const defaultMapOptions = (data) => {
|
|
8
|
+
if (Array.isArray(data)) {
|
|
9
|
+
return data;
|
|
10
|
+
}
|
|
11
|
+
return [];
|
|
12
|
+
};
|
|
13
|
+
export default function Select({ label, id, name, options = [], value, defaultValue, placeholder = 'Выберите...', multiple = false, searchable = true, loadingText = 'Загрузка...', emptyText = 'Нет данных', loadOptions, request, onAfterRequest, placement = 'auto', disabled = false, floatLabel = false, className, onChange, }) {
|
|
14
|
+
const context = useFormFieldContext();
|
|
15
|
+
const [open, setOpen] = React.useState(false);
|
|
16
|
+
const [query, setQuery] = React.useState('');
|
|
17
|
+
const [loading, setLoading] = React.useState(false);
|
|
18
|
+
const isRemote = Boolean(loadOptions || request);
|
|
19
|
+
const [items, setItems] = React.useState(options);
|
|
20
|
+
const controlRef = React.useRef(null);
|
|
21
|
+
const { ref: dropdownRef, style: dropdownStyle } = useDropdownPosition(open, {
|
|
22
|
+
gap: 6,
|
|
23
|
+
align: 'left',
|
|
24
|
+
placement,
|
|
25
|
+
anchorRef: controlRef,
|
|
26
|
+
});
|
|
27
|
+
const containerRef = React.useRef(null);
|
|
28
|
+
const inputRef = React.useRef(null);
|
|
29
|
+
const generatedId = React.useId();
|
|
30
|
+
const labelId = React.useId();
|
|
31
|
+
const listId = React.useId();
|
|
32
|
+
const controlId = id ?? context?.fieldId ?? generatedId;
|
|
33
|
+
const hasLabel = Boolean(label);
|
|
34
|
+
const isControlled = value !== undefined;
|
|
35
|
+
const [internalValue, setInternalValue] = React.useState(defaultValue ?? (multiple ? [] : ''));
|
|
36
|
+
const selectedValues = React.useMemo(() => {
|
|
37
|
+
const raw = isControlled ? value : internalValue;
|
|
38
|
+
if (multiple) {
|
|
39
|
+
return Array.isArray(raw) ? raw : raw ? [raw] : [];
|
|
40
|
+
}
|
|
41
|
+
return Array.isArray(raw) ? raw[0] ?? '' : raw ?? '';
|
|
42
|
+
}, [value, internalValue, isControlled, multiple]);
|
|
43
|
+
React.useEffect(() => {
|
|
44
|
+
if (!isRemote) {
|
|
45
|
+
setItems(options);
|
|
46
|
+
}
|
|
47
|
+
}, [options, isRemote]);
|
|
48
|
+
React.useEffect(() => {
|
|
49
|
+
if (!open || !isRemote) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
let active = true;
|
|
53
|
+
setLoading(true);
|
|
54
|
+
const timer = window.setTimeout(async () => {
|
|
55
|
+
try {
|
|
56
|
+
let next = [];
|
|
57
|
+
if (loadOptions) {
|
|
58
|
+
next = await loadOptions(query);
|
|
59
|
+
}
|
|
60
|
+
else if (request) {
|
|
61
|
+
const response = await axios({
|
|
62
|
+
url: request.url,
|
|
63
|
+
method: request.method ?? 'get',
|
|
64
|
+
params: { ...request.params, q: query },
|
|
65
|
+
data: request.data,
|
|
66
|
+
});
|
|
67
|
+
const mapper = request.mapOptions ?? defaultMapOptions;
|
|
68
|
+
next = mapper(response.data);
|
|
69
|
+
}
|
|
70
|
+
if (active) {
|
|
71
|
+
setItems(next);
|
|
72
|
+
onAfterRequest?.(next, query);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
catch {
|
|
76
|
+
if (active) {
|
|
77
|
+
setItems([]);
|
|
78
|
+
onAfterRequest?.([], query);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
finally {
|
|
82
|
+
if (active) {
|
|
83
|
+
setLoading(false);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}, 200);
|
|
87
|
+
return () => {
|
|
88
|
+
active = false;
|
|
89
|
+
window.clearTimeout(timer);
|
|
90
|
+
};
|
|
91
|
+
}, [open, query, isRemote, loadOptions, request]);
|
|
92
|
+
React.useEffect(() => {
|
|
93
|
+
const handleClick = (event) => {
|
|
94
|
+
if (!containerRef.current) {
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
if (!containerRef.current.contains(event.target)) {
|
|
98
|
+
setOpen(false);
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
document.addEventListener('click', handleClick);
|
|
102
|
+
return () => document.removeEventListener('click', handleClick);
|
|
103
|
+
}, []);
|
|
104
|
+
React.useEffect(() => {
|
|
105
|
+
context?.registerField(controlId, name);
|
|
106
|
+
}, [context, controlId, name]);
|
|
107
|
+
if (process.env.NODE_ENV !== 'production') {
|
|
108
|
+
if (!id && !name) {
|
|
109
|
+
// eslint-disable-next-line no-console
|
|
110
|
+
console.warn('Input.Select: рекомендуется передавать id или name для связки с label.');
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
React.useEffect(() => {
|
|
114
|
+
if (open && searchable) {
|
|
115
|
+
inputRef.current?.focus();
|
|
116
|
+
}
|
|
117
|
+
}, [open, searchable]);
|
|
118
|
+
const optionMap = React.useMemo(() => {
|
|
119
|
+
return new Map(items.map((item) => [item.value, item]));
|
|
120
|
+
}, [items]);
|
|
121
|
+
const selectedList = React.useMemo(() => {
|
|
122
|
+
const values = multiple ? selectedValues : selectedValues ? [selectedValues] : [];
|
|
123
|
+
return values.map((val) => optionMap.get(val) ?? { value: val, label: val });
|
|
124
|
+
}, [selectedValues, optionMap, multiple]);
|
|
125
|
+
const hasValue = multiple ? selectedValues.length > 0 : Boolean(selectedValues);
|
|
126
|
+
const floatActive = floatLabel && (open || hasValue);
|
|
127
|
+
const displayedOptions = React.useMemo(() => {
|
|
128
|
+
if (isRemote) {
|
|
129
|
+
return items;
|
|
130
|
+
}
|
|
131
|
+
if (!query) {
|
|
132
|
+
return items;
|
|
133
|
+
}
|
|
134
|
+
const lowered = query.toLowerCase();
|
|
135
|
+
return items.filter((item) => item.label.toLowerCase().includes(lowered));
|
|
136
|
+
}, [items, query, isRemote]);
|
|
137
|
+
const updateValue = (next, nextOptions) => {
|
|
138
|
+
if (!isControlled) {
|
|
139
|
+
setInternalValue(next);
|
|
140
|
+
}
|
|
141
|
+
onChange?.(next, nextOptions);
|
|
142
|
+
};
|
|
143
|
+
const handleSelect = (option) => {
|
|
144
|
+
if (option.disabled) {
|
|
145
|
+
return;
|
|
146
|
+
}
|
|
147
|
+
if (multiple) {
|
|
148
|
+
const list = selectedValues;
|
|
149
|
+
const exists = list.includes(option.value);
|
|
150
|
+
const nextValues = exists ? list.filter((val) => val !== option.value) : [...list, option.value];
|
|
151
|
+
const nextOptions = exists
|
|
152
|
+
? selectedList.filter((item) => item.value !== option.value)
|
|
153
|
+
: [...selectedList, option];
|
|
154
|
+
updateValue(nextValues, nextOptions);
|
|
155
|
+
}
|
|
156
|
+
else {
|
|
157
|
+
updateValue(option.value, [option]);
|
|
158
|
+
setOpen(false);
|
|
159
|
+
}
|
|
160
|
+
};
|
|
161
|
+
const handleRemove = (valueToRemove) => {
|
|
162
|
+
if (!multiple) {
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
const list = selectedValues;
|
|
166
|
+
const nextValues = list.filter((val) => val !== valueToRemove);
|
|
167
|
+
const nextOptions = selectedList.filter((item) => item.value !== valueToRemove);
|
|
168
|
+
updateValue(nextValues, nextOptions);
|
|
169
|
+
};
|
|
170
|
+
const handleKeyDown = (event) => {
|
|
171
|
+
if (event.key === 'Escape') {
|
|
172
|
+
setOpen(false);
|
|
173
|
+
}
|
|
174
|
+
};
|
|
175
|
+
return (_jsxs("div", { className: [styles.wrapper, className].filter(Boolean).join(' '), "data-open": open, "data-has-value": hasValue, "data-has-query": query.length > 0, "data-has-label": hasLabel, "data-float-label": floatLabel ? 'true' : undefined, "data-float-active": floatActive ? 'true' : undefined, ref: containerRef, onKeyDown: handleKeyDown, children: [label ? (_jsx("span", { id: labelId, className: styles.label, children: label })) : null, _jsxs("button", { type: "button", className: styles.control, "aria-haspopup": "listbox", "aria-expanded": open, "aria-controls": listId, "aria-labelledby": label ? labelId : undefined, id: controlId, onClick: () => !disabled && setOpen((prev) => !prev), disabled: disabled, ref: controlRef, children: [_jsx("div", { className: styles.value, children: hasValue ? (multiple ? (selectedList.map((item) => (_jsxs("span", { className: styles.tag, children: [item.label, _jsx("span", { role: "button", tabIndex: 0, className: styles.remove, onClick: (event) => {
|
|
176
|
+
event.stopPropagation();
|
|
177
|
+
handleRemove(item.value);
|
|
178
|
+
}, onKeyDown: (event) => {
|
|
179
|
+
if (event.key === 'Enter' || event.key === ' ') {
|
|
180
|
+
event.preventDefault();
|
|
181
|
+
event.stopPropagation();
|
|
182
|
+
handleRemove(item.value);
|
|
183
|
+
}
|
|
184
|
+
}, "aria-label": `Удалить ${item.label}`, children: "\u00D7" })] }, item.value)))) : (_jsx("span", { children: selectedList[0]?.label }))) : (_jsx("span", { className: styles.placeholder, children: placeholder })) }), _jsx("span", { className: styles.chevron, "aria-hidden": "true" })] }), open ? (_jsxs("div", { className: styles.dropdown, ref: dropdownRef, style: dropdownStyle, children: [searchable ? (_jsx("input", { ref: inputRef, className: styles.search, placeholder: "\u041F\u043E\u0438\u0441\u043A...", value: query, onChange: (event) => setQuery(event.target.value) })) : null, _jsxs("div", { className: styles.list, role: "listbox", id: listId, children: [loading ? _jsx("div", { className: styles.status, children: loadingText }) : null, !loading && displayedOptions.length === 0 ? (_jsx("div", { className: styles.status, children: emptyText })) : null, !loading
|
|
185
|
+
? displayedOptions.map((option) => {
|
|
186
|
+
const selected = multiple
|
|
187
|
+
? selectedValues.includes(option.value)
|
|
188
|
+
: selectedValues === option.value;
|
|
189
|
+
return (_jsxs("button", { type: "button", className: [
|
|
190
|
+
styles.option,
|
|
191
|
+
selected ? styles.optionSelected : null,
|
|
192
|
+
option.disabled ? styles.optionDisabled : null,
|
|
193
|
+
]
|
|
194
|
+
.filter(Boolean)
|
|
195
|
+
.join(' '), role: "option", "aria-selected": selected, onClick: () => handleSelect(option), disabled: option.disabled, children: [_jsx("span", { children: option.label }), selected ? _jsx("span", { className: styles.check, children: "\u2713" }) : null] }, option.value));
|
|
196
|
+
})
|
|
197
|
+
: null] })] })) : null] }));
|
|
198
|
+
}
|
|
199
|
+
Select.supportsFloatLabel = true;
|
|
200
|
+
//# sourceMappingURL=Select.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Select.js","sourceRoot":"","sources":["../../../../src/components/Input/Select/Select.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
.wrapper {
|
|
2
|
+
position: relative;
|
|
3
|
+
display: flex;
|
|
4
|
+
flex-direction: column;
|
|
5
|
+
gap: 6px;
|
|
6
|
+
width: 100%;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
.label {
|
|
10
|
+
position: absolute;
|
|
11
|
+
top: 16px;
|
|
12
|
+
left: 16px;
|
|
13
|
+
font-size: 14px;
|
|
14
|
+
color: var(--color-muted-2);
|
|
15
|
+
pointer-events: none;
|
|
16
|
+
transition: transform 0.2s ease, color 0.2s ease;
|
|
17
|
+
background: transparent;
|
|
18
|
+
padding: 0 4px;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/*.wrapper[data-open="true"] .label,*/
|
|
22
|
+
/*.wrapper[data-has-value="true"] .label,*/
|
|
23
|
+
/*.wrapper[data-has-query="true"] .label {*/
|
|
24
|
+
/* transform: translateY(-12px);*/
|
|
25
|
+
/* color: var(--color-teal);*/
|
|
26
|
+
/*}*/
|
|
27
|
+
|
|
28
|
+
.wrapper .label {
|
|
29
|
+
transform: translateY(-8px);
|
|
30
|
+
color: var(--color-teal);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.wrapper[data-has-label="false"] .label {
|
|
34
|
+
display: none;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.control {
|
|
38
|
+
min-height: 48px;
|
|
39
|
+
width: 100%;
|
|
40
|
+
border-radius: var(--radius-sm);
|
|
41
|
+
border: 1px solid var(--color-line);
|
|
42
|
+
background: var(--surface-input);
|
|
43
|
+
color: var(--color-text);
|
|
44
|
+
display: flex;
|
|
45
|
+
align-items: center;
|
|
46
|
+
justify-content: space-between;
|
|
47
|
+
gap: 12px;
|
|
48
|
+
padding: 24px 12px 12px 12px;
|
|
49
|
+
cursor: pointer;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.wrapper[data-has-label="false"] .control {
|
|
53
|
+
padding: 12px 12px;
|
|
54
|
+
min-height: 44px;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
.wrapper[data-float-label="true"] .control {
|
|
58
|
+
padding: 22px 12px 12px 12px;
|
|
59
|
+
min-height: 48px;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.wrapper:global(.rsb-group-item) .control {
|
|
63
|
+
border-radius: 0;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
.control:focus-visible {
|
|
67
|
+
outline: none;
|
|
68
|
+
border-color: rgba(20, 201, 214, 0.8);
|
|
69
|
+
box-shadow: 0 0 0 3px rgba(20, 201, 214, 0.2);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
.control:disabled {
|
|
73
|
+
opacity: 0.6;
|
|
74
|
+
cursor: not-allowed;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
.value {
|
|
78
|
+
display: flex;
|
|
79
|
+
align-items: center;
|
|
80
|
+
gap: 6px;
|
|
81
|
+
flex: 1;
|
|
82
|
+
min-width: 0;
|
|
83
|
+
flex-wrap: wrap;
|
|
84
|
+
padding: 4px 4px;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
.placeholder {
|
|
88
|
+
color: var(--color-muted-2);
|
|
89
|
+
font-size: 14px;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
.tag {
|
|
93
|
+
display: inline-flex;
|
|
94
|
+
align-items: center;
|
|
95
|
+
gap: 6px;
|
|
96
|
+
padding: 4px 10px;
|
|
97
|
+
border-radius: 10px;
|
|
98
|
+
background: var(--surface-pill);
|
|
99
|
+
border: 1px solid var(--color-line);
|
|
100
|
+
font-size: 12px;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
.remove {
|
|
104
|
+
border: none;
|
|
105
|
+
background: transparent;
|
|
106
|
+
color: var(--color-muted);
|
|
107
|
+
cursor: pointer;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
.chevron {
|
|
111
|
+
width: 8px;
|
|
112
|
+
height: 8px;
|
|
113
|
+
border-right: 2px solid currentColor;
|
|
114
|
+
border-bottom: 2px solid currentColor;
|
|
115
|
+
transform: rotate(45deg);
|
|
116
|
+
transition: transform 0.2s ease;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
.wrapper[data-open="true"] .chevron {
|
|
120
|
+
transform: rotate(225deg);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
.dropdown {
|
|
124
|
+
position: absolute;
|
|
125
|
+
top: calc(100% + 6px);
|
|
126
|
+
left: 0;
|
|
127
|
+
min-width: 100%;
|
|
128
|
+
max-width: calc(100vw - 24px);
|
|
129
|
+
border-radius: var(--radius-md);
|
|
130
|
+
border: 1px solid var(--color-line);
|
|
131
|
+
background: var(--surface-panel);
|
|
132
|
+
box-shadow: var(--shadow-soft);
|
|
133
|
+
padding: 8px;
|
|
134
|
+
z-index: 15;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
.search {
|
|
138
|
+
width: 100%;
|
|
139
|
+
border-radius: var(--radius-sm);
|
|
140
|
+
border: 1px solid var(--color-line);
|
|
141
|
+
background: var(--surface-input-muted);
|
|
142
|
+
color: var(--color-text);
|
|
143
|
+
padding: 16px 16px;
|
|
144
|
+
margin-bottom: 8px;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
.list {
|
|
148
|
+
display: flex;
|
|
149
|
+
flex-direction: column;
|
|
150
|
+
gap: 4px;
|
|
151
|
+
max-height: 220px;
|
|
152
|
+
overflow-y: auto;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
.option {
|
|
156
|
+
display: flex;
|
|
157
|
+
align-items: center;
|
|
158
|
+
justify-content: space-between;
|
|
159
|
+
gap: 8px;
|
|
160
|
+
padding: 8px 10px;
|
|
161
|
+
border-radius: 10px;
|
|
162
|
+
border: 1px solid transparent;
|
|
163
|
+
background: transparent;
|
|
164
|
+
color: var(--color-text);
|
|
165
|
+
cursor: pointer;
|
|
166
|
+
text-align: left;
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
.option:hover {
|
|
170
|
+
border-color: rgba(79, 230, 163, 0.35);
|
|
171
|
+
background: rgba(79, 230, 163, 0.08);
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
.optionSelected {
|
|
175
|
+
border-color: rgba(20, 201, 214, 0.6);
|
|
176
|
+
color: var(--color-teal);
|
|
177
|
+
background: rgba(20, 201, 214, 0.12);
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
.optionDisabled {
|
|
181
|
+
opacity: 0.5;
|
|
182
|
+
cursor: not-allowed;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
.status {
|
|
186
|
+
padding: 10px;
|
|
187
|
+
color: var(--color-muted);
|
|
188
|
+
font-size: 13px;
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
.check {
|
|
192
|
+
font-size: 12px;
|
|
193
|
+
color: var(--color-mint);
|
|
194
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import styles from './Switch.module.css';
|
|
4
|
+
export default function Switch({ id, label, className, ...props }) {
|
|
5
|
+
const inputId = id ?? React.useId();
|
|
6
|
+
const classes = [styles.switch, className].filter(Boolean).join(' ');
|
|
7
|
+
return (_jsxs("label", { className: classes, htmlFor: inputId, children: [_jsx("input", { id: inputId, type: "checkbox", role: "switch", className: styles.input, ...props }), _jsx("span", { className: styles.track, "aria-hidden": "true", children: _jsx("span", { className: styles.thumb }) }), label ? _jsx("span", { className: styles.label, children: label }) : null] }));
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=Switch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Switch.js","sourceRoot":"","sources":["../../../../src/components/Input/Switch/Switch.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,MAAM,MAAM,qBAAqB,CAAC;AAMzC,MAAM,CAAC,OAAO,UAAU,MAAM,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,KAAK,EAAS;IACtE,MAAM,OAAO,GAAG,EAAE,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;IACpC,MAAM,OAAO,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAErE,OAAO,CACL,iBAAO,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,aACzC,gBAAO,EAAE,EAAE,OAAO,EAAE,IAAI,EAAC,UAAU,EAAC,IAAI,EAAC,QAAQ,EAAC,SAAS,EAAE,MAAM,CAAC,KAAK,KAAM,KAAK,GAAI,EACxF,eAAM,SAAS,EAAE,MAAM,CAAC,KAAK,iBAAc,MAAM,YAC/C,eAAM,SAAS,EAAE,MAAM,CAAC,KAAK,GAAI,GAC5B,EACN,KAAK,CAAC,CAAC,CAAC,eAAM,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAQ,CAAC,CAAC,CAAC,IAAI,IACvD,CACT,CAAC;AACJ,CAAC"}
|