@ozen-ui/kit 0.8.0 → 0.9.1
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/FieldControl/package.json +5 -0
- package/FieldInput/package.json +5 -0
- package/Fieldset/package.json +5 -0
- package/__inner__/cjs/components/Backdrop/Backdrop.d.ts +2 -2
- package/__inner__/cjs/components/Breadcrumbs/types.d.ts +2 -2
- package/__inner__/cjs/components/DataList/DataList.d.ts +1 -1
- package/__inner__/cjs/components/DataList/DataListProvider.d.ts +5 -5
- package/__inner__/cjs/components/FieldControl/FieldControl.css +135 -0
- package/__inner__/cjs/components/FieldControl/FieldControl.d.ts +13 -0
- package/__inner__/cjs/components/FieldControl/FieldControl.js +82 -0
- package/__inner__/cjs/components/FieldControl/FieldControlContext.d.ts +15 -0
- package/__inner__/cjs/components/FieldControl/FieldControlContext.js +6 -0
- package/__inner__/cjs/components/FieldControl/index.d.ts +2 -0
- package/__inner__/cjs/components/FieldControl/index.js +5 -0
- package/__inner__/cjs/components/FieldHint/FieldHint.d.ts +6 -9
- package/__inner__/cjs/components/FieldHint/FieldHint.js +24 -4
- package/__inner__/cjs/components/FieldIcon/FieldIcon.css +1 -21
- package/__inner__/cjs/components/FieldIcon/FieldIcon.d.ts +8 -12
- package/__inner__/cjs/components/FieldIcon/FieldIcon.js +15 -4
- package/__inner__/cjs/components/FieldInput/FieldInput.d.ts +11 -0
- package/__inner__/cjs/components/FieldInput/FieldInput.js +55 -0
- package/__inner__/cjs/components/FieldInput/index.d.ts +1 -0
- package/__inner__/cjs/components/FieldInput/index.js +4 -0
- package/__inner__/cjs/components/FieldLabel/FieldLabel.d.ts +7 -5
- package/__inner__/cjs/components/FieldLabel/FieldLabel.js +40 -10
- package/__inner__/cjs/components/Fieldset/Fieldset.css +13 -0
- package/__inner__/cjs/components/Fieldset/Fieldset.d.ts +10 -0
- package/__inner__/cjs/components/Fieldset/Fieldset.js +15 -0
- package/__inner__/cjs/components/Fieldset/index.d.ts +1 -0
- package/__inner__/cjs/components/Fieldset/index.js +4 -0
- package/__inner__/cjs/components/FilePicker/FilePicker.css +48 -59
- package/__inner__/cjs/components/FilePicker/FilePicker.js +2 -1
- package/__inner__/cjs/components/Input/Input.css +9 -121
- package/__inner__/cjs/components/Input/Input.d.ts +1 -62
- package/__inner__/cjs/components/Input/Input.js +32 -53
- package/__inner__/cjs/components/Input/constants.d.ts +1 -0
- package/__inner__/cjs/components/Input/constants.js +4 -0
- package/__inner__/cjs/components/Input/index.d.ts +1 -0
- package/__inner__/cjs/components/Input/index.js +1 -0
- package/__inner__/cjs/components/Input/types.d.ts +71 -0
- package/__inner__/cjs/components/Input/types.js +13 -0
- package/__inner__/cjs/components/InputNumber/InputNumber.css +61 -74
- package/__inner__/cjs/components/InputNumber/InputNumber.js +2 -1
- package/__inner__/cjs/components/InputNumber/utils.d.ts +2 -2
- package/__inner__/cjs/components/Link/Link.d.ts +1 -1
- package/__inner__/cjs/components/List/components/ListItem/ListItem.d.ts +1 -2
- package/__inner__/cjs/components/List/components/ListItemButton/ListItemButton.d.ts +1 -2
- package/__inner__/cjs/components/List/types.d.ts +3 -3
- package/__inner__/cjs/components/Menu/components/MenuItem/MenuItem.d.ts +1 -1
- package/__inner__/cjs/components/Menu/components/MenuList/MenuList.d.ts +1 -1
- package/__inner__/cjs/components/Modal/Modal.d.ts +1 -1
- package/__inner__/cjs/components/Modal/Modal.js +1 -1
- package/__inner__/cjs/components/Modal/components/ModalConsumer.d.ts +2 -2
- package/__inner__/cjs/components/Pagination/helpers/createPaginationRange/createPaginationRange.d.ts +1 -1
- package/__inner__/cjs/components/Pagination/types.d.ts +5 -5
- package/__inner__/cjs/components/Popover/types.d.ts +4 -5
- package/__inner__/cjs/components/ProgressBar/ProgressBar.d.ts +2 -2
- package/__inner__/cjs/components/Select/Select.css +5 -16
- package/__inner__/cjs/components/Select/components/SelectInput/SelectInput.js +2 -1
- package/__inner__/cjs/components/Select/types.d.ts +3 -4
- package/__inner__/cjs/components/Slider/types.d.ts +1 -1
- package/__inner__/cjs/components/Snackbar/types.d.ts +1 -1
- package/__inner__/cjs/components/Tag/components/RemoveButton/RemoveButton.d.ts +1 -1
- package/__inner__/cjs/components/Textarea/Textarea.css +3 -107
- package/__inner__/cjs/components/Textarea/Textarea.d.ts +1 -59
- package/__inner__/cjs/components/Textarea/Textarea.js +8 -62
- package/__inner__/cjs/components/Textarea/components/TextareaConsumer.d.ts +3 -0
- package/__inner__/cjs/components/Textarea/components/TextareaConsumer.js +36 -0
- package/__inner__/cjs/components/Textarea/components/TextareaCounter.d.ts +7 -0
- package/__inner__/cjs/components/Textarea/components/TextareaCounter.js +25 -0
- package/__inner__/cjs/components/Textarea/components/index.d.ts +2 -0
- package/__inner__/cjs/components/Textarea/components/index.js +5 -0
- package/__inner__/cjs/components/Textarea/constants.d.ts +1 -0
- package/__inner__/cjs/components/Textarea/constants.js +4 -0
- package/__inner__/cjs/components/Textarea/index.d.ts +1 -0
- package/__inner__/cjs/components/Textarea/index.js +1 -0
- package/__inner__/cjs/components/Textarea/types.d.ts +69 -0
- package/__inner__/cjs/components/Textarea/types.js +4 -0
- package/__inner__/cjs/components/ThemeProvider/ThemeProvider.d.ts +2 -1
- package/__inner__/cjs/components/ThemeProvider/types.d.ts +2 -0
- package/__inner__/cjs/components/Tooltip/types.d.ts +1 -1
- package/__inner__/cjs/hooks/useMultiRef/useMultiRef.d.ts +2 -3
- package/__inner__/cjs/types/ResponsiveValue.d.ts +1 -1
- package/__inner__/cjs/utils/isKey.d.ts +2 -2
- package/__inner__/cjs/utils/polymorphicComponentWithRef.d.ts +0 -1
- package/__inner__/esm/components/Backdrop/Backdrop.d.ts +2 -2
- package/__inner__/esm/components/Backdrop/Backdrop.js +1 -1
- package/__inner__/esm/components/Breadcrumbs/types.d.ts +2 -2
- package/__inner__/esm/components/DataList/DataList.d.ts +1 -1
- package/__inner__/esm/components/DataList/DataListProvider.d.ts +5 -5
- package/__inner__/esm/components/FieldControl/FieldControl.css +135 -0
- package/__inner__/esm/components/FieldControl/FieldControl.d.ts +13 -0
- package/__inner__/esm/components/FieldControl/FieldControl.js +79 -0
- package/__inner__/esm/components/FieldControl/FieldControlContext.d.ts +15 -0
- package/__inner__/esm/components/FieldControl/FieldControlContext.js +2 -0
- package/__inner__/esm/components/FieldControl/index.d.ts +2 -0
- package/__inner__/esm/components/FieldControl/index.js +2 -0
- package/__inner__/esm/components/FieldHint/FieldHint.d.ts +6 -9
- package/__inner__/esm/components/FieldHint/FieldHint.js +25 -5
- package/__inner__/esm/components/FieldIcon/FieldIcon.css +1 -21
- package/__inner__/esm/components/FieldIcon/FieldIcon.d.ts +8 -12
- package/__inner__/esm/components/FieldIcon/FieldIcon.js +16 -5
- package/__inner__/esm/components/FieldInput/FieldInput.d.ts +11 -0
- package/__inner__/esm/components/FieldInput/FieldInput.js +52 -0
- package/__inner__/esm/components/FieldInput/index.d.ts +1 -0
- package/__inner__/esm/components/FieldInput/index.js +1 -0
- package/__inner__/esm/components/FieldLabel/FieldLabel.d.ts +7 -5
- package/__inner__/esm/components/FieldLabel/FieldLabel.js +39 -8
- package/__inner__/esm/components/Fieldset/Fieldset.css +13 -0
- package/__inner__/esm/components/Fieldset/Fieldset.d.ts +10 -0
- package/__inner__/esm/components/Fieldset/Fieldset.js +12 -0
- package/__inner__/esm/components/Fieldset/index.d.ts +1 -0
- package/__inner__/esm/components/Fieldset/index.js +1 -0
- package/__inner__/esm/components/FilePicker/FilePicker.css +48 -59
- package/__inner__/esm/components/FilePicker/FilePicker.js +2 -1
- package/__inner__/esm/components/Input/Input.css +9 -121
- package/__inner__/esm/components/Input/Input.d.ts +1 -62
- package/__inner__/esm/components/Input/Input.js +33 -54
- package/__inner__/esm/components/Input/constants.d.ts +1 -0
- package/__inner__/esm/components/Input/constants.js +1 -0
- package/__inner__/esm/components/Input/index.d.ts +1 -0
- package/__inner__/esm/components/Input/index.js +1 -0
- package/__inner__/esm/components/Input/types.d.ts +71 -0
- package/__inner__/esm/components/Input/types.js +10 -0
- package/__inner__/esm/components/InputNumber/InputNumber.css +61 -74
- package/__inner__/esm/components/InputNumber/InputNumber.js +2 -1
- package/__inner__/esm/components/InputNumber/utils.d.ts +2 -2
- package/__inner__/esm/components/Link/Link.d.ts +1 -1
- package/__inner__/esm/components/List/components/ListItem/ListItem.d.ts +1 -2
- package/__inner__/esm/components/List/components/ListItemButton/ListItemButton.d.ts +1 -2
- package/__inner__/esm/components/List/types.d.ts +3 -3
- package/__inner__/esm/components/Menu/components/MenuItem/MenuItem.d.ts +1 -1
- package/__inner__/esm/components/Menu/components/MenuList/MenuList.d.ts +1 -1
- package/__inner__/esm/components/Modal/Modal.d.ts +1 -1
- package/__inner__/esm/components/Modal/Modal.js +1 -1
- package/__inner__/esm/components/Modal/components/ModalConsumer.d.ts +2 -2
- package/__inner__/esm/components/Pagination/helpers/createPaginationRange/createPaginationRange.d.ts +1 -1
- package/__inner__/esm/components/Pagination/types.d.ts +5 -5
- package/__inner__/esm/components/Popover/types.d.ts +4 -5
- package/__inner__/esm/components/ProgressBar/ProgressBar.d.ts +2 -2
- package/__inner__/esm/components/ProgressBar/ProgressBar.js +1 -1
- package/__inner__/esm/components/Select/Select.css +5 -16
- package/__inner__/esm/components/Select/components/SelectInput/SelectInput.js +2 -1
- package/__inner__/esm/components/Select/types.d.ts +3 -4
- package/__inner__/esm/components/Slider/types.d.ts +1 -1
- package/__inner__/esm/components/Snackbar/types.d.ts +1 -1
- package/__inner__/esm/components/Tag/components/RemoveButton/RemoveButton.d.ts +1 -1
- package/__inner__/esm/components/Textarea/Textarea.css +3 -107
- package/__inner__/esm/components/Textarea/Textarea.d.ts +1 -59
- package/__inner__/esm/components/Textarea/Textarea.js +9 -63
- package/__inner__/esm/components/Textarea/components/TextareaConsumer.d.ts +3 -0
- package/__inner__/esm/components/Textarea/components/TextareaConsumer.js +32 -0
- package/__inner__/esm/components/Textarea/components/TextareaCounter.d.ts +7 -0
- package/__inner__/esm/components/Textarea/components/TextareaCounter.js +21 -0
- package/__inner__/esm/components/Textarea/components/index.d.ts +2 -0
- package/__inner__/esm/components/Textarea/components/index.js +2 -0
- package/__inner__/esm/components/Textarea/constants.d.ts +1 -0
- package/__inner__/esm/components/Textarea/constants.js +1 -0
- package/__inner__/esm/components/Textarea/index.d.ts +1 -0
- package/__inner__/esm/components/Textarea/index.js +1 -0
- package/__inner__/esm/components/Textarea/types.d.ts +69 -0
- package/__inner__/esm/components/Textarea/types.js +1 -0
- package/__inner__/esm/components/ThemeProvider/ThemeProvider.d.ts +2 -1
- package/__inner__/esm/components/ThemeProvider/types.d.ts +2 -0
- package/__inner__/esm/components/Tooltip/Tooltip.js +1 -1
- package/__inner__/esm/components/Tooltip/types.d.ts +1 -1
- package/__inner__/esm/hooks/useMultiRef/useMultiRef.d.ts +2 -3
- package/__inner__/esm/types/ResponsiveValue.d.ts +1 -1
- package/__inner__/esm/utils/isKey.d.ts +2 -2
- package/__inner__/esm/utils/polymorphicComponentWithRef.d.ts +0 -1
- package/package.json +1 -1
|
@@ -1,20 +1,50 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
exports.__esModule = true;
|
|
3
|
-
exports.FieldLabel = exports.cnFieldLabel = exports.
|
|
3
|
+
exports.FieldLabel = exports.cnFieldLabel = exports.FIELD_LABEL_DEFAULT_TAG = void 0;
|
|
4
4
|
var tslib_1 = require("tslib");
|
|
5
|
-
var react_1 = require("react");
|
|
6
|
-
var React = tslib_1.__importStar(require("react"));
|
|
7
|
-
var classname_1 = require("../../utils/classname");
|
|
8
5
|
require("./FieldLabel.css");
|
|
9
|
-
|
|
6
|
+
var react_1 = tslib_1.__importStar(require("react"));
|
|
7
|
+
var useIsomorphicEffect_1 = require("../../hooks/useIsomorphicEffect");
|
|
8
|
+
var classname_1 = require("../../utils/classname");
|
|
9
|
+
var FieldControl_1 = require("../FieldControl");
|
|
10
|
+
exports.FIELD_LABEL_DEFAULT_TAG = 'span';
|
|
10
11
|
exports.cnFieldLabel = (0, classname_1.cn)('FieldLabel');
|
|
11
12
|
exports.FieldLabel = (0, react_1.forwardRef)(function (_a, ref) {
|
|
12
|
-
var
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
13
|
+
var focusedProp = _a.focused, children = _a.children, filledProp = _a.filled, shrink = _a.shrink, requiredProp = _a.required, disabledProp = _a.disabled, className = _a.className, sizeProp = _a.size;
|
|
14
|
+
var context = (0, react_1.useContext)(FieldControl_1.FieldControlContext);
|
|
15
|
+
var _b = tslib_1.__read(context, 2), fieldControl = _b[0], setFieldControl = _b[1];
|
|
16
|
+
var Tag = exports.FIELD_LABEL_DEFAULT_TAG;
|
|
17
|
+
var size = sizeProp;
|
|
18
|
+
var required = requiredProp;
|
|
19
|
+
var disabled = disabledProp;
|
|
20
|
+
var focused = focusedProp;
|
|
21
|
+
var filled = filledProp;
|
|
22
|
+
(0, useIsomorphicEffect_1.useIsomorphicEffect)(function () {
|
|
23
|
+
setFieldControl(function (prevState) { return (tslib_1.__assign(tslib_1.__assign({}, prevState), { label: children })); });
|
|
24
|
+
}, [children]);
|
|
25
|
+
if (!children) {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
if (fieldControl) {
|
|
29
|
+
if (size === undefined && fieldControl.size) {
|
|
30
|
+
size = fieldControl.size;
|
|
31
|
+
}
|
|
32
|
+
if (required === undefined && fieldControl.required) {
|
|
33
|
+
required = fieldControl.required;
|
|
34
|
+
}
|
|
35
|
+
if (disabled === undefined && fieldControl.disabled) {
|
|
36
|
+
disabled = fieldControl.disabled;
|
|
37
|
+
}
|
|
38
|
+
if (focused === undefined && fieldControl.focused) {
|
|
39
|
+
focused = fieldControl.focused;
|
|
40
|
+
}
|
|
41
|
+
if (filled === undefined && fieldControl.filled) {
|
|
42
|
+
filled = fieldControl.filled;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return (react_1["default"].createElement(Tag, { className: (0, exports.cnFieldLabel)({ filled: filled, shrink: shrink, focused: focused, disabled: disabled, size: size, required: required }, [className]), ref: ref },
|
|
16
46
|
children,
|
|
17
47
|
" ",
|
|
18
|
-
required &&
|
|
48
|
+
required && react_1["default"].createElement("sup", null, "*")));
|
|
19
49
|
});
|
|
20
50
|
exports.FieldLabel.displayName = 'FieldLabel';
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
.Fieldset {
|
|
2
|
+
position: absolute;
|
|
3
|
+
inset-block-end: 0;
|
|
4
|
+
inset-inline-end: 0;
|
|
5
|
+
inset-block-start: 0;
|
|
6
|
+
inset-inline-start: 0;
|
|
7
|
+
margin: 0;
|
|
8
|
+
padding: 0;
|
|
9
|
+
pointer-events: none;
|
|
10
|
+
border-radius: var(--border-radius-xs);
|
|
11
|
+
border: var(--textfield-border-width) solid var(--textfield-border-color);
|
|
12
|
+
transition: border var(--transition-default);
|
|
13
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import './Fieldset.css';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import type { ComponentPropsWithRef, ComponentRef } from 'react';
|
|
4
|
+
export declare const FIELDSET_DEFAULT_TAG = "fieldset";
|
|
5
|
+
export type FieldsetRef = ComponentRef<typeof FIELDSET_DEFAULT_TAG>;
|
|
6
|
+
export type FieldsetProps = ComponentPropsWithRef<typeof FIELDSET_DEFAULT_TAG>;
|
|
7
|
+
export declare const cnFieldset: import("@bem-react/classname").ClassNameFormatter;
|
|
8
|
+
export declare const Fieldset: React.ForwardRefExoticComponent<Omit<Omit<React.DetailedHTMLProps<React.FieldsetHTMLAttributes<HTMLFieldSetElement>, HTMLFieldSetElement>, "ref"> & {
|
|
9
|
+
ref?: ((instance: HTMLFieldSetElement | null) => void) | React.RefObject<HTMLFieldSetElement> | null | undefined;
|
|
10
|
+
}, "ref"> & React.RefAttributes<HTMLFieldSetElement>>;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
exports.__esModule = true;
|
|
3
|
+
exports.Fieldset = exports.cnFieldset = exports.FIELDSET_DEFAULT_TAG = void 0;
|
|
4
|
+
var tslib_1 = require("tslib");
|
|
5
|
+
require("./Fieldset.css");
|
|
6
|
+
var react_1 = tslib_1.__importStar(require("react"));
|
|
7
|
+
var classname_1 = require("../../utils/classname");
|
|
8
|
+
exports.FIELDSET_DEFAULT_TAG = 'fieldset';
|
|
9
|
+
exports.cnFieldset = (0, classname_1.cn)('Fieldset');
|
|
10
|
+
exports.Fieldset = (0, react_1.forwardRef)(function (_a, ref) {
|
|
11
|
+
var className = _a.className, other = tslib_1.__rest(_a, ["className"]);
|
|
12
|
+
var Tag = exports.FIELDSET_DEFAULT_TAG;
|
|
13
|
+
return react_1["default"].createElement(Tag, tslib_1.__assign({ className: (0, exports.cnFieldset)({}, [className]) }, other, { ref: ref }));
|
|
14
|
+
});
|
|
15
|
+
exports.Fieldset.displayName = 'Fieldset';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './Fieldset';
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
/* stylelint-disable */
|
|
2
2
|
.FilePicker {
|
|
3
|
-
--
|
|
4
|
-
--
|
|
5
|
-
--
|
|
6
|
-
--
|
|
3
|
+
--textfield-color: var(--color-content-tertiary);
|
|
4
|
+
--textfield-background-color: var(--color-background-primary);
|
|
5
|
+
--textfield-border-width: var(--border-width-s);
|
|
6
|
+
--textfield-border-color: var(--color-border-main);
|
|
7
|
+
font: var(--textfield-input-font);
|
|
7
8
|
display: inline-flex;
|
|
8
9
|
vertical-align: top;
|
|
9
10
|
flex-direction: column;
|
|
@@ -11,14 +12,14 @@
|
|
|
11
12
|
.FilePicker-Body {
|
|
12
13
|
position: relative;
|
|
13
14
|
display: flex;
|
|
14
|
-
-moz-column-gap: var(--
|
|
15
|
-
column-gap: var(--
|
|
15
|
+
-moz-column-gap: var(--textfield-input-gap);
|
|
16
|
+
column-gap: var(--textfield-input-gap);
|
|
16
17
|
align-items: center;
|
|
17
18
|
box-sizing: border-box;
|
|
18
|
-
padding: 0 var(--
|
|
19
|
-
background-color: var(--
|
|
19
|
+
padding: 0 var(--textfield-gutter-x);
|
|
20
|
+
background-color: var(--textfield-background-color);
|
|
20
21
|
transition: background-color var(--transition-slow);
|
|
21
|
-
color: var(--
|
|
22
|
+
color: var(--textfield-color);
|
|
22
23
|
border-radius: var(--border-radius-xs);
|
|
23
24
|
cursor: pointer;
|
|
24
25
|
}
|
|
@@ -42,9 +43,8 @@
|
|
|
42
43
|
padding: 0;
|
|
43
44
|
background: none;
|
|
44
45
|
box-sizing: border-box;
|
|
45
|
-
color: var(--
|
|
46
|
-
block-size: var(--
|
|
47
|
-
font: var(--file-picker-input-font);
|
|
46
|
+
color: var(--textfield-color);
|
|
47
|
+
block-size: var(--textfield-input-height);
|
|
48
48
|
}
|
|
49
49
|
.FilePicker-Input {
|
|
50
50
|
inset-block-end: 0;
|
|
@@ -57,85 +57,74 @@
|
|
|
57
57
|
.FilePicker-Input:focus + .FilePicker-Placeholder {
|
|
58
58
|
opacity: 1;
|
|
59
59
|
}
|
|
60
|
-
.FilePicker-Fieldset {
|
|
61
|
-
position: absolute;
|
|
62
|
-
inset: 0;
|
|
63
|
-
margin: 0;
|
|
64
|
-
padding: 0;
|
|
65
|
-
pointer-events: none;
|
|
66
|
-
border-radius: var(--border-radius-xs);
|
|
67
|
-
border: var(--file-picker-border-width) solid
|
|
68
|
-
var(--file-picker-border-color);
|
|
69
|
-
transition: border var(--transition-default);
|
|
70
|
-
}
|
|
71
60
|
.FilePicker_size_2xs {
|
|
72
|
-
--
|
|
73
|
-
--
|
|
74
|
-
--
|
|
75
|
-
--
|
|
76
|
-
--
|
|
61
|
+
--textfield-gutter-x: 12px;
|
|
62
|
+
--textfield-input-height: 32px;
|
|
63
|
+
--textfield-input-font: var(--typography-text-2xs-font);
|
|
64
|
+
--textfield-input-padding: 8px 0 8px;
|
|
65
|
+
--textfield-input-gap: var(--space-s);
|
|
77
66
|
}
|
|
78
67
|
.FilePicker_size_xs {
|
|
79
|
-
--
|
|
80
|
-
--
|
|
81
|
-
--
|
|
82
|
-
--
|
|
83
|
-
--
|
|
68
|
+
--textfield-gutter-x: 12px;
|
|
69
|
+
--textfield-input-height: 40px;
|
|
70
|
+
--textfield-input-font: var(--typography-text-xs-font);
|
|
71
|
+
--textfield-input-padding: 19px 0 4px;
|
|
72
|
+
--textfield-input-gap: var(--space-s);
|
|
84
73
|
}
|
|
85
74
|
.FilePicker_size_s {
|
|
86
|
-
--
|
|
87
|
-
--
|
|
88
|
-
--
|
|
89
|
-
--
|
|
90
|
-
--
|
|
75
|
+
--textfield-gutter-x: 16px;
|
|
76
|
+
--textfield-input-height: 48px;
|
|
77
|
+
--textfield-input-font: var(--typography-text-s-font);
|
|
78
|
+
--textfield-input-padding: 21px 0 6px;
|
|
79
|
+
--textfield-input-gap: var(--space-m);
|
|
91
80
|
}
|
|
92
81
|
.FilePicker_size_m {
|
|
93
|
-
--
|
|
94
|
-
--
|
|
95
|
-
--
|
|
96
|
-
--
|
|
97
|
-
--
|
|
82
|
+
--textfield-gutter-x: 20px;
|
|
83
|
+
--textfield-input-height: 56px;
|
|
84
|
+
--textfield-input-font: var(--typography-text-m-font);
|
|
85
|
+
--textfield-input-padding: 24px 0 6px;
|
|
86
|
+
--textfield-input-gap: var(--space-m);
|
|
98
87
|
}
|
|
99
88
|
.FilePicker_size_l {
|
|
100
|
-
--
|
|
101
|
-
--
|
|
102
|
-
--
|
|
103
|
-
--
|
|
104
|
-
--
|
|
89
|
+
--textfield-gutter-x: 24px;
|
|
90
|
+
--textfield-input-height: 64px;
|
|
91
|
+
--textfield-input-font: var(--typography-text-l-font);
|
|
92
|
+
--textfield-input-padding: 26px 0 6px;
|
|
93
|
+
--textfield-input-gap: var(--space-l);
|
|
105
94
|
}
|
|
106
95
|
.FilePicker_fullWidth {
|
|
107
96
|
inline-size: 100%;
|
|
108
97
|
}
|
|
109
98
|
.FilePicker_hasValue {
|
|
110
|
-
--
|
|
99
|
+
--textfield-color: var(--color-content-primary);
|
|
111
100
|
}
|
|
112
101
|
.FilePicker_hasLabel .FilePicker-Placeholder {
|
|
113
102
|
opacity: 0;
|
|
114
103
|
}
|
|
115
104
|
.FilePicker_hasLabel .FilePicker-FileName,
|
|
116
105
|
.FilePicker_hasLabel .FilePicker-Placeholder {
|
|
117
|
-
padding: var(--
|
|
118
|
-
font: var(--
|
|
106
|
+
padding: var(--textfield-input-padding);
|
|
107
|
+
font: var(--textfield-input-font);
|
|
119
108
|
}
|
|
120
109
|
.FilePicker:hover {
|
|
121
|
-
--
|
|
110
|
+
--textfield-border-color: var(--color-border-main-hover);
|
|
122
111
|
}
|
|
123
112
|
.FilePicker_focused,
|
|
124
113
|
.FilePicker_focused:hover {
|
|
125
|
-
--
|
|
126
|
-
--
|
|
127
|
-
--
|
|
114
|
+
--textfield-border-width: var(--border-width-m);
|
|
115
|
+
--textfield-background-color: var(--color-background-main);
|
|
116
|
+
--textfield-border-color: var(--color-border-action);
|
|
128
117
|
}
|
|
129
118
|
.FilePicker_error,
|
|
130
119
|
.FilePicker_error.FilePicker:hover,
|
|
131
120
|
.FilePicker_error.FilePicker_focused,
|
|
132
121
|
.FilePicker_error.FilePicker_focused:hover {
|
|
133
|
-
--
|
|
122
|
+
--textfield-border-color: var(--color-border-error);
|
|
134
123
|
}
|
|
135
124
|
.FilePicker_disabled {
|
|
136
|
-
--
|
|
137
|
-
--
|
|
138
|
-
--
|
|
125
|
+
--textfield-border-color: var(--color-border-disabled);
|
|
126
|
+
--textfield-background-color: var(--color-background-disabled);
|
|
127
|
+
--textfield-color: var(--color-content-secondary);
|
|
139
128
|
pointer-events: none;
|
|
140
129
|
cursor: default;
|
|
141
130
|
}
|
|
@@ -12,6 +12,7 @@ var isKey_1 = require("../../utils/isKey");
|
|
|
12
12
|
var FieldHint_1 = require("../FieldHint");
|
|
13
13
|
var FieldIcon_1 = require("../FieldIcon");
|
|
14
14
|
var FieldLabel_1 = require("../FieldLabel");
|
|
15
|
+
var Fieldset_1 = require("../Fieldset");
|
|
15
16
|
var IconButton_1 = require("../IconButton");
|
|
16
17
|
var constants_1 = require("./constants");
|
|
17
18
|
exports.cnFilePicker = (0, classname_1.cn)('FilePicker');
|
|
@@ -72,7 +73,7 @@ exports.FilePicker = (0, react_1.forwardRef)(function (inProps, ref) {
|
|
|
72
73
|
(fileList === null || fileList === void 0 ? void 0 : fileList.length) ? (react_1["default"].createElement("span", { className: (0, exports.cnFilePicker)('FileName') }, renderValue(fileList, disableTruncate))) : (react_1["default"].createElement("span", { "aria-placeholder": placeholder, className: (0, exports.cnFilePicker)('Placeholder') }, placeholder))),
|
|
73
74
|
!!(fileList === null || fileList === void 0 ? void 0 : fileList.length) && onClearProp && (react_1["default"].createElement(IconButton_1.IconButton, { tabIndex: -1, variant: "function", "aria-label": clearText, ref: clearRef, onClick: onClear, size: size, icon: icons_1.CloseIcon })),
|
|
74
75
|
react_1["default"].createElement(FieldIcon_1.FieldIcon, { className: (0, exports.cnFilePicker)('RenderRight'), icon: renderRight, size: size }),
|
|
75
|
-
react_1["default"].createElement(
|
|
76
|
+
react_1["default"].createElement(Fieldset_1.Fieldset, { className: (0, exports.cnFilePicker)('Fieldset') })),
|
|
76
77
|
react_1["default"].createElement(FieldHint_1.FieldHint, { size: size, error: error, disabled: disabled }, hint)));
|
|
77
78
|
});
|
|
78
79
|
exports.FilePicker.displayName = 'FilePicker';
|
|
@@ -1,30 +1,3 @@
|
|
|
1
|
-
/* stylelint-disable */
|
|
2
|
-
.Input {
|
|
3
|
-
--textfield-color: var(--color-content-primary);
|
|
4
|
-
--textfield-background-color: var(--color-background-primary);
|
|
5
|
-
--textfield-border-width: var(--border-width-s);
|
|
6
|
-
--textfield-border-color: var(--color-border-main);
|
|
7
|
-
cursor: text;
|
|
8
|
-
display: inline-flex;
|
|
9
|
-
vertical-align: top;
|
|
10
|
-
flex-direction: column;
|
|
11
|
-
}
|
|
12
|
-
.Input > * {
|
|
13
|
-
cursor: text;
|
|
14
|
-
}
|
|
15
|
-
.Input-Fieldset {
|
|
16
|
-
position: absolute;
|
|
17
|
-
inset-block-end: 0;
|
|
18
|
-
inset-inline-end: 0;
|
|
19
|
-
inset-block-start: 0;
|
|
20
|
-
inset-inline-start: 0;
|
|
21
|
-
margin: 0;
|
|
22
|
-
padding: 0;
|
|
23
|
-
pointer-events: none;
|
|
24
|
-
border-radius: var(--border-radius-xs);
|
|
25
|
-
border: var(--textfield-border-width) solid var(--textfield-border-color);
|
|
26
|
-
transition: border var(--transition-default);
|
|
27
|
-
}
|
|
28
1
|
.Input-Body {
|
|
29
2
|
position: relative;
|
|
30
3
|
display: flex;
|
|
@@ -38,133 +11,48 @@
|
|
|
38
11
|
color: var(--textfield-color);
|
|
39
12
|
border-radius: var(--border-radius-xs);
|
|
40
13
|
}
|
|
41
|
-
.Input-FieldContainer {
|
|
14
|
+
.Input-FieldContainer {
|
|
42
15
|
inline-size: 100%;
|
|
43
16
|
position: relative;
|
|
44
17
|
}
|
|
45
|
-
.Input-Field {
|
|
18
|
+
.Input-Field {
|
|
46
19
|
border: none;
|
|
47
20
|
outline: none;
|
|
48
21
|
display: flex;
|
|
49
22
|
inline-size: 100%;
|
|
50
|
-
padding:
|
|
23
|
+
padding: var(--textfield-input-padding);
|
|
51
24
|
background: none;
|
|
52
25
|
color: var(--textfield-color);
|
|
53
26
|
box-sizing: border-box;
|
|
54
27
|
block-size: var(--textfield-input-height);
|
|
55
|
-
font:
|
|
28
|
+
font: inherit;
|
|
56
29
|
}
|
|
57
|
-
.Input-Field::placeholder {
|
|
30
|
+
.Input-Field::placeholder {
|
|
58
31
|
opacity: 1;
|
|
59
32
|
color: var(--color-content-tertiary);
|
|
60
33
|
}
|
|
61
|
-
.Input-Field:-webkit-autofill,
|
|
34
|
+
.Input-Field:-webkit-autofill,
|
|
62
35
|
.Input-Field:-webkit-autofill:hover,
|
|
63
36
|
.Input-Field:-webkit-autofill:focus {
|
|
64
37
|
box-shadow: 0 0 0 1000px var(--textfield-background-color) inset !important;
|
|
65
38
|
background-color: transparent !important;
|
|
66
39
|
-webkit-text-fill-color: var(--color-content-info-dark);
|
|
67
40
|
}
|
|
68
|
-
.Input-Field::-webkit-outer-spin-button,
|
|
41
|
+
.Input-Field::-webkit-outer-spin-button,
|
|
69
42
|
.Input-Field::-webkit-inner-spin-button {
|
|
70
43
|
-webkit-appearance: none;
|
|
71
44
|
appearance: none;
|
|
72
45
|
margin: 0;
|
|
73
46
|
}
|
|
74
|
-
.Input-Field::-webkit-calendar-picker-indicator {
|
|
47
|
+
.Input-Field::-webkit-calendar-picker-indicator {
|
|
75
48
|
opacity: 0;
|
|
76
49
|
position: absolute;
|
|
77
50
|
inset-block-start: 50%;
|
|
78
51
|
transform: translateY(-50%);
|
|
79
52
|
cursor: pointer;
|
|
80
53
|
}
|
|
81
|
-
.Input-Field[type='number'] {
|
|
54
|
+
.Input-Field[type='number'] {
|
|
82
55
|
-webkit-appearance: textfield;
|
|
83
56
|
-moz-appearance: textfield;
|
|
84
57
|
appearance: textfield;
|
|
85
58
|
}
|
|
86
|
-
.Input_size_2xs {
|
|
87
|
-
--textfield-gutter-x: 12px;
|
|
88
|
-
--textfield-input-height: 32px;
|
|
89
|
-
--textfield-input-font: var(--typography-text-2xs-font);
|
|
90
|
-
--textfield-input-padding: 8px 0 8px;
|
|
91
|
-
--textfield-input-gap: var(--space-s);
|
|
92
|
-
}
|
|
93
|
-
.Input_size_2xs .Input-Field::-webkit-calendar-picker-indicator {
|
|
94
|
-
inset-inline-end: -25px;
|
|
95
|
-
}
|
|
96
|
-
.Input_size_xs {
|
|
97
|
-
--textfield-gutter-x: 12px;
|
|
98
|
-
--textfield-input-height: 40px;
|
|
99
|
-
--textfield-input-font: var(--typography-text-xs-font);
|
|
100
|
-
--textfield-input-padding: 19px 0 4px;
|
|
101
|
-
--textfield-input-gap: var(--space-s);
|
|
102
|
-
}
|
|
103
|
-
.Input_size_xs .Input-Field::-webkit-calendar-picker-indicator {
|
|
104
|
-
inset-inline-end: -25px;
|
|
105
|
-
}
|
|
106
|
-
.Input_size_s {
|
|
107
|
-
--textfield-gutter-x: 16px;
|
|
108
|
-
--textfield-input-height: 48px;
|
|
109
|
-
--textfield-input-font: var(--typography-text-s-font);
|
|
110
|
-
--textfield-input-padding: 21px 0 6px;
|
|
111
|
-
--textfield-input-gap: var(--space-m);
|
|
112
|
-
}
|
|
113
|
-
.Input_size_s .Input-Field::-webkit-calendar-picker-indicator {
|
|
114
|
-
inset-inline-end: -30px;
|
|
115
|
-
}
|
|
116
|
-
.Input_size_m {
|
|
117
|
-
--textfield-gutter-x: 20px;
|
|
118
|
-
--textfield-input-height: 56px;
|
|
119
|
-
--textfield-input-font: var(--typography-text-m-font);
|
|
120
|
-
--textfield-input-padding: 24px 0 6px;
|
|
121
|
-
--textfield-input-gap: var(--space-m);
|
|
122
|
-
}
|
|
123
|
-
.Input_size_m .Input-Field::-webkit-calendar-picker-indicator {
|
|
124
|
-
inset-inline-end: -34px;
|
|
125
|
-
}
|
|
126
|
-
.Input_size_l {
|
|
127
|
-
--textfield-gutter-x: 24px;
|
|
128
|
-
--textfield-input-height: 64px;
|
|
129
|
-
--textfield-input-font: var(--typography-text-l-font);
|
|
130
|
-
--textfield-input-padding: 26px 0 6px;
|
|
131
|
-
--textfield-input-gap: var(--space-l);
|
|
132
|
-
}
|
|
133
|
-
.Input_size_l .Input-Field::-webkit-calendar-picker-indicator {
|
|
134
|
-
inset-inline-end: -39px;
|
|
135
|
-
}
|
|
136
|
-
.Input_fullWidth {
|
|
137
|
-
inline-size: 100%;
|
|
138
|
-
}
|
|
139
|
-
.Input_hasLabel .Input-Field {
|
|
140
|
-
padding: var(--textfield-input-padding);
|
|
141
|
-
font: var(--textfield-input-font);
|
|
142
|
-
}
|
|
143
|
-
.Input_hasLabel .Input-Field::placeholder {
|
|
144
|
-
opacity: 0;
|
|
145
|
-
}
|
|
146
|
-
.Input_hasLabel .Input-Field:focus::placeholder {
|
|
147
|
-
opacity: 1;
|
|
148
|
-
}
|
|
149
|
-
.Input:hover {
|
|
150
|
-
--textfield-border-color: var(--color-border-main-hover);
|
|
151
|
-
}
|
|
152
|
-
.Input_focused,
|
|
153
|
-
.Input_focused:hover {
|
|
154
|
-
--textfield-border-width: var(--border-width-m);
|
|
155
|
-
--textfield-background-color: var(--color-background-main);
|
|
156
|
-
--textfield-border-color: var(--color-border-action);
|
|
157
|
-
}
|
|
158
|
-
.Input_error,
|
|
159
|
-
.Input_error.Input:hover,
|
|
160
|
-
.Input_error.Input_focused,
|
|
161
|
-
.Input_error.Input_focused:hover {
|
|
162
|
-
--textfield-border-color: var(--color-border-error);
|
|
163
|
-
}
|
|
164
|
-
.Input_disabled {
|
|
165
|
-
--textfield-border-color: var(--color-border-disabled);
|
|
166
|
-
--textfield-background-color: var(--color-background-disabled);
|
|
167
|
-
--textfield-color: var(--color-content-secondary);
|
|
168
|
-
pointer-events: none;
|
|
169
|
-
cursor: default;
|
|
170
|
-
}
|
|
@@ -1,66 +1,5 @@
|
|
|
1
1
|
import './Input.css';
|
|
2
2
|
import React from 'react';
|
|
3
|
-
import type {
|
|
4
|
-
import type { FormElementSizeVariant } from '../../types/FormElementSizeVariant';
|
|
5
|
-
import { type FieldIconProps } from '../FieldIcon';
|
|
6
|
-
import { type FieldLabelProps } from '../FieldLabel';
|
|
7
|
-
export declare const inputTypeVariant: readonly ["number", "date", "datetime-local", "time", "text", "tel", "password", "email"];
|
|
8
|
-
export type InputTypeVariant = (typeof inputTypeVariant)[number];
|
|
9
|
-
export type InputSizeVariant = FormElementSizeVariant;
|
|
10
|
-
type InputElement = InputHTMLAttributes<HTMLInputElement>;
|
|
11
|
-
export type InputProps = {
|
|
12
|
-
/** Атрибут id для элемента input */
|
|
13
|
-
id?: string;
|
|
14
|
-
/** Атрибут name для элемента input */
|
|
15
|
-
name?: string;
|
|
16
|
-
/** Лейбл */
|
|
17
|
-
label?: string;
|
|
18
|
-
/** Размер компонента */
|
|
19
|
-
size?: InputSizeVariant;
|
|
20
|
-
/** Подсказка. Отображается, когда вариант не выбран */
|
|
21
|
-
placeholder?: string;
|
|
22
|
-
/** Если {true} устанавливает автофокус */
|
|
23
|
-
autoFocus?: boolean;
|
|
24
|
-
/** Если {true} переводит поле в состояние ошибки */
|
|
25
|
-
error?: boolean;
|
|
26
|
-
/** Если {true} растягивает поле на всю ширину */
|
|
27
|
-
fullWidth?: boolean;
|
|
28
|
-
/** Дополнительное описание к полю */
|
|
29
|
-
hint?: string | null | undefined;
|
|
30
|
-
/** Атрибут type для элемента input */
|
|
31
|
-
type?: InputTypeVariant;
|
|
32
|
-
/** Если {true} делает элемент неактивным */
|
|
33
|
-
disabled?: boolean;
|
|
34
|
-
/** Если {true} делает элемент обязательным к заполнению */
|
|
35
|
-
required?: boolean;
|
|
36
|
-
/** Минимальное количество символов разрешенных для ввода */
|
|
37
|
-
minLength?: InputElement['minLength'];
|
|
38
|
-
/** Максимальное количество символов разрешенных для ввода */
|
|
39
|
-
maxLength?: InputElement['maxLength'];
|
|
40
|
-
/** Текст или иконка слева */
|
|
41
|
-
renderLeft?: FieldIconProps['icon'];
|
|
42
|
-
/** Текст или иконка справа */
|
|
43
|
-
renderRight?: FieldIconProps['icon'];
|
|
44
|
-
/** Выбранное значение */
|
|
45
|
-
value?: InputElement['value'];
|
|
46
|
-
/** Значение по умолчанию (неконтролируемый компонент) */
|
|
47
|
-
defaultValue?: InputElement['defaultValue'];
|
|
48
|
-
/** Обработчик события на изменение значения поля */
|
|
49
|
-
onChange?: InputElement['onChange'];
|
|
50
|
-
/** Ссылка на элемент input */
|
|
51
|
-
inputRef?: Ref<HTMLInputElement>;
|
|
52
|
-
/** Свойства элемента input */
|
|
53
|
-
inputProps?: InputElement & {
|
|
54
|
-
'data-testid'?: string;
|
|
55
|
-
};
|
|
56
|
-
/** Ссылка на FieldLabel */
|
|
57
|
-
labelRef?: FieldLabelProps['ref'];
|
|
58
|
-
/** Свойства FieldLabel */
|
|
59
|
-
labelProps?: FieldLabelProps;
|
|
60
|
-
/** Ссылка на корневой DOM-элемент компонента */
|
|
61
|
-
ref?: Ref<HTMLDivElement>;
|
|
62
|
-
'data-testid'?: string;
|
|
63
|
-
} & Omit<HTMLAttributes<HTMLDivElement>, 'value' | 'defaultValue' | 'onChange'>;
|
|
3
|
+
import type { InputProps } from './index';
|
|
64
4
|
export declare const cnInput: import("@bem-react/classname").ClassNameFormatter;
|
|
65
5
|
export declare const Input: React.ForwardRefExoticComponent<Omit<InputProps, "ref"> & React.RefAttributes<HTMLDivElement>>;
|
|
66
|
-
export {};
|