@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.
Files changed (158) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +271 -0
  3. package/dist/components/Alert/Alert.d.ts +11 -0
  4. package/dist/components/Alert/Alert.js +15 -0
  5. package/dist/components/Alert/Alert.js.map +1 -0
  6. package/dist/components/Alert/Alert.module.css +73 -0
  7. package/dist/components/Badge/Badge.d.ts +8 -0
  8. package/dist/components/Badge/Badge.js +15 -0
  9. package/dist/components/Badge/Badge.js.map +1 -0
  10. package/dist/components/Badge/Badge.module.css +47 -0
  11. package/dist/components/Breadcrumbs/Breadcrumbs.d.ts +24 -0
  12. package/dist/components/Breadcrumbs/Breadcrumbs.js +15 -0
  13. package/dist/components/Breadcrumbs/Breadcrumbs.js.map +1 -0
  14. package/dist/components/Breadcrumbs/Breadcrumbs.module.css +55 -0
  15. package/dist/components/Button/Button.d.ts +10 -0
  16. package/dist/components/Button/Button.js +37 -0
  17. package/dist/components/Button/Button.js.map +1 -0
  18. package/dist/components/Button/Button.module.css +130 -0
  19. package/dist/components/Card/Card.d.ts +15 -0
  20. package/dist/components/Card/Card.js +26 -0
  21. package/dist/components/Card/Card.js.map +1 -0
  22. package/dist/components/Card/Card.module.css +55 -0
  23. package/dist/components/CollapseButton/CollapseButton.d.ts +9 -0
  24. package/dist/components/CollapseButton/CollapseButton.js +11 -0
  25. package/dist/components/CollapseButton/CollapseButton.js.map +1 -0
  26. package/dist/components/CollapseButton/CollapseButton.module.css +57 -0
  27. package/dist/components/Drawer/Drawer.d.ts +19 -0
  28. package/dist/components/Drawer/Drawer.js +42 -0
  29. package/dist/components/Drawer/Drawer.js.map +1 -0
  30. package/dist/components/Drawer/Drawer.module.css +104 -0
  31. package/dist/components/Flex/Flex.module.css +11 -0
  32. package/dist/components/Flex/Row.d.ts +9 -0
  33. package/dist/components/Flex/Row.js +14 -0
  34. package/dist/components/Flex/Row.js.map +1 -0
  35. package/dist/components/Flex/Stack.d.ts +8 -0
  36. package/dist/components/Flex/Stack.js +13 -0
  37. package/dist/components/Flex/Stack.js.map +1 -0
  38. package/dist/components/Grid/Grid.d.ts +11 -0
  39. package/dist/components/Grid/Grid.js +16 -0
  40. package/dist/components/Grid/Grid.js.map +1 -0
  41. package/dist/components/Grid/Grid.module.css +32 -0
  42. package/dist/components/Input/DatePicker.d.ts +6 -0
  43. package/dist/components/Input/DatePicker.js +6 -0
  44. package/dist/components/Input/DatePicker.js.map +1 -0
  45. package/dist/components/Input/DateRangePicker.d.ts +16 -0
  46. package/dist/components/Input/DateRangePicker.js +16 -0
  47. package/dist/components/Input/DateRangePicker.js.map +1 -0
  48. package/dist/components/Input/Field.d.ts +5 -0
  49. package/dist/components/Input/Field.js +25 -0
  50. package/dist/components/Input/Field.js.map +1 -0
  51. package/dist/components/Input/FloatLabel/FloatLabel.d.ts +9 -0
  52. package/dist/components/Input/FloatLabel/FloatLabel.js +22 -0
  53. package/dist/components/Input/FloatLabel/FloatLabel.js.map +1 -0
  54. package/dist/components/Input/FloatLabel/FloatLabel.module.css +41 -0
  55. package/dist/components/Input/FormField/FormField.d.ts +29 -0
  56. package/dist/components/Input/FormField/FormField.js +60 -0
  57. package/dist/components/Input/FormField/FormField.js.map +1 -0
  58. package/dist/components/Input/FormField/FormField.module.css +30 -0
  59. package/dist/components/Input/Input.d.ts +59 -0
  60. package/dist/components/Input/Input.js +34 -0
  61. package/dist/components/Input/Input.js.map +1 -0
  62. package/dist/components/Input/Input.module.css +31 -0
  63. package/dist/components/Input/InputGroup.d.ts +11 -0
  64. package/dist/components/Input/InputGroup.js +25 -0
  65. package/dist/components/Input/InputGroup.js.map +1 -0
  66. package/dist/components/Input/InputGroup.module.css +38 -0
  67. package/dist/components/Input/MaskedInput.d.ts +9 -0
  68. package/dist/components/Input/MaskedInput.js +82 -0
  69. package/dist/components/Input/MaskedInput.js.map +1 -0
  70. package/dist/components/Input/NumberInput.d.ts +10 -0
  71. package/dist/components/Input/NumberInput.js +44 -0
  72. package/dist/components/Input/NumberInput.js.map +1 -0
  73. package/dist/components/Input/Radio/Radio.d.ts +7 -0
  74. package/dist/components/Input/Radio/Radio.js +9 -0
  75. package/dist/components/Input/Radio/Radio.js.map +1 -0
  76. package/dist/components/Input/Radio/Radio.module.css +83 -0
  77. package/dist/components/Input/Select/Select.d.ts +38 -0
  78. package/dist/components/Input/Select/Select.js +200 -0
  79. package/dist/components/Input/Select/Select.js.map +1 -0
  80. package/dist/components/Input/Select/Select.module.css +194 -0
  81. package/dist/components/Input/Switch/Switch.d.ts +6 -0
  82. package/dist/components/Input/Switch/Switch.js +9 -0
  83. package/dist/components/Input/Switch/Switch.js.map +1 -0
  84. package/dist/components/Input/Switch/Switch.module.css +62 -0
  85. package/dist/components/Input/Textarea/Textarea.d.ts +6 -0
  86. package/dist/components/Input/Textarea/Textarea.js +21 -0
  87. package/dist/components/Input/Textarea/Textarea.js.map +1 -0
  88. package/dist/components/Input/Textarea/Textarea.module.css +39 -0
  89. package/dist/components/Input/TimePicker.d.ts +4 -0
  90. package/dist/components/Input/TimePicker.js +6 -0
  91. package/dist/components/Input/TimePicker.js.map +1 -0
  92. package/dist/components/Menu/Dropdown.d.ts +13 -0
  93. package/dist/components/Menu/Dropdown.js +58 -0
  94. package/dist/components/Menu/Dropdown.js.map +1 -0
  95. package/dist/components/Menu/Menu.d.ts +31 -0
  96. package/dist/components/Menu/Menu.js +161 -0
  97. package/dist/components/Menu/Menu.js.map +1 -0
  98. package/dist/components/Menu/Menu.module.css +240 -0
  99. package/dist/components/Modal/Modal.d.ts +12 -0
  100. package/dist/components/Modal/Modal.js +31 -0
  101. package/dist/components/Modal/Modal.js.map +1 -0
  102. package/dist/components/Modal/Modal.module.css +90 -0
  103. package/dist/components/Notifier/Notifier.d.ts +17 -0
  104. package/dist/components/Notifier/Notifier.js +210 -0
  105. package/dist/components/Notifier/Notifier.js.map +1 -0
  106. package/dist/components/Notifier/Notifier.module.css +182 -0
  107. package/dist/components/Pagination/Pagination.d.ts +28 -0
  108. package/dist/components/Pagination/Pagination.js +70 -0
  109. package/dist/components/Pagination/Pagination.js.map +1 -0
  110. package/dist/components/Pagination/Pagination.module.css +93 -0
  111. package/dist/components/Progress/Progress.d.ts +16 -0
  112. package/dist/components/Progress/Progress.js +32 -0
  113. package/dist/components/Progress/Progress.js.map +1 -0
  114. package/dist/components/Progress/Progress.module.css +110 -0
  115. package/dist/components/Tabs/Tabs.d.ts +20 -0
  116. package/dist/components/Tabs/Tabs.js +115 -0
  117. package/dist/components/Tabs/Tabs.js.map +1 -0
  118. package/dist/components/Tabs/Tabs.module.css +101 -0
  119. package/dist/components/Typography/Heading.d.ts +13 -0
  120. package/dist/components/Typography/Heading.js +38 -0
  121. package/dist/components/Typography/Heading.js.map +1 -0
  122. package/dist/components/Typography/Text.d.ts +20 -0
  123. package/dist/components/Typography/Text.js +43 -0
  124. package/dist/components/Typography/Text.js.map +1 -0
  125. package/dist/components/Typography/Typography.module.css +132 -0
  126. package/dist/foundations/index.css +3 -0
  127. package/dist/foundations/layout.css +78 -0
  128. package/dist/foundations/tokens.css +236 -0
  129. package/dist/foundations/typography.css +49 -0
  130. package/dist/hooks/useDropdownPosition.d.ts +14 -0
  131. package/dist/hooks/useDropdownPosition.js +61 -0
  132. package/dist/hooks/useDropdownPosition.js.map +1 -0
  133. package/dist/hooks/useMediaQuery.d.ts +1 -0
  134. package/dist/hooks/useMediaQuery.js +33 -0
  135. package/dist/hooks/useMediaQuery.js.map +1 -0
  136. package/dist/index.d.ts +30 -0
  137. package/dist/index.js +29 -0
  138. package/dist/index.js.map +1 -0
  139. package/dist/theme.d.ts +12 -0
  140. package/dist/theme.js +133 -0
  141. package/dist/theme.js.map +1 -0
  142. package/dist/types.d.ts +1 -0
  143. package/dist/types.js +2 -0
  144. package/dist/types.js.map +1 -0
  145. package/docs/README.md +40 -0
  146. package/docs/breadcrumbs.md +47 -0
  147. package/docs/card.md +18 -0
  148. package/docs/feedback.md +38 -0
  149. package/docs/forms.md +166 -0
  150. package/docs/layout.md +39 -0
  151. package/docs/navigation.md +80 -0
  152. package/docs/overlays.md +31 -0
  153. package/docs/pagination.md +50 -0
  154. package/docs/progress.md +18 -0
  155. package/docs/tabs.md +34 -0
  156. package/docs/theme.md +49 -0
  157. package/docs/typography.md +26 -0
  158. 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,6 @@
1
+ import React from 'react';
2
+ type Props = Omit<React.InputHTMLAttributes<HTMLInputElement>, 'type'> & {
3
+ label?: React.ReactNode;
4
+ };
5
+ export default function Switch({ id, label, className, ...props }: Props): import("react/jsx-runtime").JSX.Element;
6
+ 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 './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"}