@alfalab/core-components-number-input 1.3.0 → 2.0.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/Component.desktop.d.ts +1 -1
- package/Component.desktop.js +9 -1
- package/Component.mobile.d.ts +1 -1
- package/Component.mobile.js +9 -1
- package/Component.responsive.d.ts +1 -1
- package/Component.responsive.js +14 -1
- package/components/number-input/Component.d.ts +21 -46
- package/components/number-input/Component.js +97 -84
- package/components/number-input/default.css +24 -0
- package/components/number-input/index.css +23 -0
- package/components/number-input/index.js +8 -0
- package/components/number-input/inverted.css +24 -0
- package/components/steppers/Component.d.ts +15 -0
- package/components/steppers/Component.js +43 -0
- package/components/steppers/default.css +20 -0
- package/components/steppers/index.css +30 -0
- package/components/steppers/index.d.ts +1 -0
- package/components/steppers/index.js +15 -0
- package/components/steppers/inverted.css +20 -0
- package/cssm/Component.desktop.d.ts +1 -1
- package/cssm/Component.desktop.js +15 -1
- package/cssm/Component.mobile.d.ts +1 -1
- package/cssm/Component.mobile.js +15 -1
- package/cssm/Component.responsive.d.ts +1 -1
- package/cssm/Component.responsive.js +20 -1
- package/cssm/components/number-input/Component.d.ts +21 -46
- package/cssm/components/number-input/Component.js +97 -84
- package/cssm/components/number-input/default.module.css +23 -0
- package/cssm/components/number-input/index.js +14 -0
- package/cssm/components/number-input/index.module.css +22 -0
- package/cssm/components/number-input/inverted.module.css +23 -0
- package/cssm/components/steppers/Component.d.ts +15 -0
- package/cssm/components/steppers/Component.js +40 -0
- package/cssm/components/steppers/default.module.css +19 -0
- package/cssm/components/steppers/index.d.ts +1 -0
- package/cssm/components/steppers/index.js +18 -0
- package/cssm/components/steppers/index.module.css +29 -0
- package/cssm/components/steppers/inverted.module.css +19 -0
- package/cssm/desktop/index.js +14 -0
- package/cssm/index.js +15 -0
- package/cssm/mobile/index.js +14 -0
- package/cssm/utils.d.ts +19 -9
- package/cssm/utils.js +244 -21
- package/desktop/index.js +8 -0
- package/esm/Component.desktop.d.ts +1 -1
- package/esm/Component.desktop.js +9 -1
- package/esm/Component.mobile.d.ts +1 -1
- package/esm/Component.mobile.js +9 -1
- package/esm/Component.responsive.d.ts +1 -1
- package/esm/Component.responsive.js +15 -2
- package/esm/components/number-input/Component.d.ts +21 -46
- package/esm/components/number-input/Component.js +98 -86
- package/esm/components/number-input/default.css +24 -0
- package/esm/components/number-input/index.css +23 -0
- package/esm/components/number-input/index.js +8 -0
- package/esm/components/number-input/inverted.css +24 -0
- package/esm/components/steppers/Component.d.ts +15 -0
- package/esm/components/steppers/Component.js +34 -0
- package/esm/components/steppers/default.css +20 -0
- package/esm/components/steppers/index.css +30 -0
- package/esm/components/steppers/index.d.ts +1 -0
- package/esm/components/steppers/index.js +7 -0
- package/esm/components/steppers/inverted.css +20 -0
- package/esm/desktop/index.js +8 -0
- package/esm/index.js +9 -0
- package/esm/mobile/index.js +8 -0
- package/esm/utils.d.ts +19 -9
- package/esm/utils.js +236 -19
- package/index.js +9 -0
- package/mobile/index.js +8 -0
- package/modern/Component.desktop.d.ts +1 -1
- package/modern/Component.desktop.js +9 -1
- package/modern/Component.mobile.d.ts +1 -1
- package/modern/Component.mobile.js +9 -1
- package/modern/Component.responsive.d.ts +1 -1
- package/modern/Component.responsive.js +13 -1
- package/modern/components/number-input/Component.d.ts +21 -46
- package/modern/components/number-input/Component.js +94 -86
- package/modern/components/number-input/default.css +24 -0
- package/modern/components/number-input/index.css +23 -0
- package/modern/components/number-input/index.js +8 -0
- package/modern/components/number-input/inverted.css +24 -0
- package/modern/components/steppers/Component.d.ts +15 -0
- package/modern/components/steppers/Component.js +33 -0
- package/modern/components/steppers/default.css +20 -0
- package/modern/components/steppers/index.css +30 -0
- package/modern/components/steppers/index.d.ts +1 -0
- package/modern/components/steppers/index.js +7 -0
- package/modern/components/steppers/inverted.css +20 -0
- package/modern/desktop/index.js +8 -0
- package/modern/index.js +9 -0
- package/modern/mobile/index.js +8 -0
- package/modern/utils.d.ts +19 -9
- package/modern/utils.js +223 -18
- package/package.json +9 -2
- package/src/Component.desktop.tsx +2 -2
- package/src/Component.mobile.tsx +2 -2
- package/src/Component.responsive.tsx +16 -2
- package/src/components/number-input/Component.tsx +204 -128
- package/src/components/number-input/default.module.css +10 -0
- package/src/components/number-input/index.module.css +9 -0
- package/src/components/number-input/inverted.module.css +10 -0
- package/src/components/steppers/Component.tsx +75 -0
- package/src/components/steppers/default.module.css +5 -0
- package/src/components/steppers/index.module.css +20 -0
- package/src/components/steppers/index.ts +1 -0
- package/src/components/steppers/inverted.module.css +5 -0
- package/src/utils.ts +302 -24
- package/utils.d.ts +19 -9
- package/utils.js +244 -21
package/Component.desktop.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { NumberInputProps } from "./components/number-input/index";
|
|
4
|
-
type NumberInputDesktopProps = Omit<NumberInputProps, 'Input' | 'breakpoint'>;
|
|
4
|
+
type NumberInputDesktopProps = Omit<NumberInputProps, 'Input' | 'breakpoint' | 'view'>;
|
|
5
5
|
declare const NumberInputDesktop: React.ForwardRefExoticComponent<NumberInputDesktopProps & React.RefAttributes<HTMLInputElement>>;
|
|
6
6
|
export { NumberInputDesktopProps, NumberInputDesktop };
|
package/Component.desktop.js
CHANGED
|
@@ -7,12 +7,20 @@ var React = require('react');
|
|
|
7
7
|
var desktop = require('@alfalab/core-components-input/desktop');
|
|
8
8
|
var components_numberInput_Component = require('./components/number-input/Component.js');
|
|
9
9
|
require('react-merge-refs');
|
|
10
|
+
require('@maskito/core');
|
|
11
|
+
require('@maskito/react');
|
|
12
|
+
require('classnames');
|
|
13
|
+
require('@alfalab/core-components-shared');
|
|
10
14
|
require('./utils.js');
|
|
15
|
+
require('./components/steppers/Component.js');
|
|
16
|
+
require('@alfalab/core-components-icon-button');
|
|
17
|
+
require('@alfalab/icons-glyph/MinusMIcon');
|
|
18
|
+
require('@alfalab/icons-glyph/PlusMediumMIcon');
|
|
11
19
|
|
|
12
20
|
function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
|
|
13
21
|
|
|
14
22
|
var React__default = /*#__PURE__*/_interopDefaultCompat(React);
|
|
15
23
|
|
|
16
|
-
var NumberInputDesktop = React.forwardRef(function (props, ref) { return React__default.default.createElement(components_numberInput_Component.NumberInput, tslib.__assign({}, props, { Input: desktop.InputDesktop, ref: ref })); });
|
|
24
|
+
var NumberInputDesktop = React.forwardRef(function (props, ref) { return React__default.default.createElement(components_numberInput_Component.NumberInput, tslib.__assign({}, props, { Input: desktop.InputDesktop, ref: ref, view: 'desktop' })); });
|
|
17
25
|
|
|
18
26
|
exports.NumberInputDesktop = NumberInputDesktop;
|
package/Component.mobile.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { NumberInputProps } from "./components/number-input/index";
|
|
4
|
-
type NumberInputMobileProps = Omit<NumberInputProps, 'Input' | 'breakpoint'>;
|
|
4
|
+
type NumberInputMobileProps = Omit<NumberInputProps, 'Input' | 'breakpoint' | 'view'>;
|
|
5
5
|
declare const NumberInputMobile: React.ForwardRefExoticComponent<NumberInputMobileProps & React.RefAttributes<HTMLInputElement>>;
|
|
6
6
|
export { NumberInputMobileProps, NumberInputMobile };
|
package/Component.mobile.js
CHANGED
|
@@ -7,12 +7,20 @@ var React = require('react');
|
|
|
7
7
|
var mobile = require('@alfalab/core-components-input/mobile');
|
|
8
8
|
var components_numberInput_Component = require('./components/number-input/Component.js');
|
|
9
9
|
require('react-merge-refs');
|
|
10
|
+
require('@maskito/core');
|
|
11
|
+
require('@maskito/react');
|
|
12
|
+
require('classnames');
|
|
13
|
+
require('@alfalab/core-components-shared');
|
|
10
14
|
require('./utils.js');
|
|
15
|
+
require('./components/steppers/Component.js');
|
|
16
|
+
require('@alfalab/core-components-icon-button');
|
|
17
|
+
require('@alfalab/icons-glyph/MinusMIcon');
|
|
18
|
+
require('@alfalab/icons-glyph/PlusMediumMIcon');
|
|
11
19
|
|
|
12
20
|
function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
|
|
13
21
|
|
|
14
22
|
var React__default = /*#__PURE__*/_interopDefaultCompat(React);
|
|
15
23
|
|
|
16
|
-
var NumberInputMobile = React.forwardRef(function (props, ref) { return React__default.default.createElement(components_numberInput_Component.NumberInput, tslib.__assign({}, props, { Input: mobile.InputMobile, ref: ref })); });
|
|
24
|
+
var NumberInputMobile = React.forwardRef(function (props, ref) { return React__default.default.createElement(components_numberInput_Component.NumberInput, tslib.__assign({}, props, { Input: mobile.InputMobile, ref: ref, view: 'mobile' })); });
|
|
17
25
|
|
|
18
26
|
exports.NumberInputMobile = NumberInputMobile;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { NumberInputProps } from "./components/number-input/index";
|
|
4
|
-
type NumberInputResponsiveProps = Omit<NumberInputProps, 'Input'>;
|
|
4
|
+
type NumberInputResponsiveProps = Omit<NumberInputProps, 'Input' | 'view'>;
|
|
5
5
|
declare const NumberInputResponsive: React.ForwardRefExoticComponent<NumberInputResponsiveProps & React.RefAttributes<HTMLInputElement>>;
|
|
6
6
|
export { NumberInputResponsiveProps, NumberInputResponsive };
|
package/Component.responsive.js
CHANGED
|
@@ -5,14 +5,27 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
5
5
|
var tslib = require('tslib');
|
|
6
6
|
var React = require('react');
|
|
7
7
|
var coreComponentsInput = require('@alfalab/core-components-input');
|
|
8
|
+
var coreComponentsMq = require('@alfalab/core-components-mq');
|
|
8
9
|
var components_numberInput_Component = require('./components/number-input/Component.js');
|
|
9
10
|
require('react-merge-refs');
|
|
11
|
+
require('@maskito/core');
|
|
12
|
+
require('@maskito/react');
|
|
13
|
+
require('classnames');
|
|
14
|
+
require('@alfalab/core-components-shared');
|
|
10
15
|
require('./utils.js');
|
|
16
|
+
require('./components/steppers/Component.js');
|
|
17
|
+
require('@alfalab/core-components-icon-button');
|
|
18
|
+
require('@alfalab/icons-glyph/MinusMIcon');
|
|
19
|
+
require('@alfalab/icons-glyph/PlusMediumMIcon');
|
|
11
20
|
|
|
12
21
|
function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
|
|
13
22
|
|
|
14
23
|
var React__default = /*#__PURE__*/_interopDefaultCompat(React);
|
|
15
24
|
|
|
16
|
-
var NumberInputResponsive = React.forwardRef(function (
|
|
25
|
+
var NumberInputResponsive = React.forwardRef(function (_a, ref) {
|
|
26
|
+
var _b = _a.breakpoint, breakpoint = _b === void 0 ? 1024 : _b, defaultMatchMediaValue = _a.defaultMatchMediaValue, restProps = tslib.__rest(_a, ["breakpoint", "defaultMatchMediaValue"]);
|
|
27
|
+
var isDesktop = coreComponentsMq.useMatchMedia("(min-width: ".concat(breakpoint, "px)"), defaultMatchMediaValue)[0];
|
|
28
|
+
return (React__default.default.createElement(components_numberInput_Component.NumberInput, tslib.__assign({}, restProps, { Input: coreComponentsInput.Input, ref: ref, view: isDesktop ? 'desktop' : 'mobile', breakpoint: breakpoint, defaultMatchMediaValue: defaultMatchMediaValue })));
|
|
29
|
+
});
|
|
17
30
|
|
|
18
31
|
exports.NumberInputResponsive = NumberInputResponsive;
|
|
@@ -1,80 +1,55 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import React from 'react';
|
|
3
|
+
import { ChangeEvent, FC, Ref } from "react";
|
|
3
4
|
import { InputProps } from "@alfalab/core-components-input";
|
|
4
|
-
|
|
5
|
+
interface NumberInputProps extends Omit<InputProps, 'value' | 'onChange' | 'type' | 'defaultValue'> {
|
|
5
6
|
/**
|
|
6
7
|
* Значение поля ввода
|
|
7
8
|
*/
|
|
8
9
|
value?: string | number | null;
|
|
9
10
|
/**
|
|
10
|
-
*
|
|
11
|
+
* Значение по-умолчанию
|
|
11
12
|
*/
|
|
12
|
-
|
|
13
|
+
defaultValue?: string | number | null;
|
|
13
14
|
/**
|
|
14
15
|
* Разделитель ',' или '.'
|
|
15
16
|
*/
|
|
16
17
|
separator?: '.' | ',';
|
|
17
18
|
/**
|
|
18
19
|
* Количество символов после разделителя
|
|
20
|
+
* Если указан проп step, то всегда 0
|
|
19
21
|
*/
|
|
20
22
|
fractionLength?: number;
|
|
21
23
|
/**
|
|
22
|
-
*
|
|
24
|
+
* Шаг инкремента/декремента. Используйте только целочисленные значения
|
|
23
25
|
*/
|
|
24
|
-
|
|
25
|
-
ref?: React.Ref<HTMLInputElement>;
|
|
26
|
-
}>;
|
|
26
|
+
step?: number;
|
|
27
27
|
/**
|
|
28
|
-
*
|
|
28
|
+
* Минимальное значение
|
|
29
|
+
* @default Number.MIN_SAFE_INTEGER
|
|
29
30
|
*/
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Числовое значение инпута
|
|
33
|
-
*/
|
|
34
|
-
value: number | null;
|
|
35
|
-
/**
|
|
36
|
-
* Строковое значение инпута
|
|
37
|
-
* Используйте для изменения значения инпута
|
|
38
|
-
*/
|
|
39
|
-
valueString: string;
|
|
40
|
-
}) => void;
|
|
41
|
-
};
|
|
42
|
-
declare const NumberInput: React.ForwardRefExoticComponent<Omit<InputProps, "value" | "onChange" | "type"> & {
|
|
31
|
+
min?: number;
|
|
43
32
|
/**
|
|
44
|
-
*
|
|
33
|
+
* Максимальное значение
|
|
34
|
+
* @default Number.MAX_SAFE_INTEGER
|
|
45
35
|
*/
|
|
46
|
-
|
|
36
|
+
max?: number;
|
|
47
37
|
/**
|
|
48
|
-
*
|
|
38
|
+
* Отображение компонента в мобильном или десктопном виде
|
|
49
39
|
*/
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* Разделитель ',' или '.'
|
|
53
|
-
*/
|
|
54
|
-
separator?: "," | "." | undefined;
|
|
55
|
-
/**
|
|
56
|
-
* Количество символов после разделителя
|
|
57
|
-
*/
|
|
58
|
-
fractionLength?: number | undefined;
|
|
40
|
+
view?: 'desktop' | 'mobile';
|
|
59
41
|
/**
|
|
60
42
|
* Компонент инпута
|
|
61
43
|
*/
|
|
62
|
-
Input:
|
|
63
|
-
ref?:
|
|
44
|
+
Input: FC<InputProps & {
|
|
45
|
+
ref?: Ref<HTMLInputElement>;
|
|
64
46
|
}>;
|
|
65
47
|
/**
|
|
66
48
|
* Обработчик события изменения значения
|
|
67
49
|
*/
|
|
68
|
-
onChange?: (
|
|
69
|
-
/**
|
|
70
|
-
* Числовое значение инпута
|
|
71
|
-
*/
|
|
50
|
+
onChange?: (e: ChangeEvent<HTMLInputElement> | null, payload: {
|
|
72
51
|
value: number | null;
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
*/
|
|
77
|
-
valueString: string;
|
|
78
|
-
}) => void) | undefined;
|
|
79
|
-
} & React.RefAttributes<HTMLInputElement>>;
|
|
52
|
+
}) => void;
|
|
53
|
+
}
|
|
54
|
+
declare const NumberInput: React.ForwardRefExoticComponent<NumberInputProps & React.RefAttributes<HTMLInputElement>>;
|
|
80
55
|
export { NumberInputProps, NumberInput };
|
|
@@ -5,106 +5,119 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
5
5
|
var tslib = require('tslib');
|
|
6
6
|
var React = require('react');
|
|
7
7
|
var mergeRefs = require('react-merge-refs');
|
|
8
|
+
var core = require('@maskito/core');
|
|
9
|
+
var react = require('@maskito/react');
|
|
10
|
+
var cn = require('classnames');
|
|
11
|
+
var coreComponentsShared = require('@alfalab/core-components-shared');
|
|
8
12
|
var utils = require('../../utils.js');
|
|
13
|
+
var components_steppers_Component = require('../steppers/Component.js');
|
|
14
|
+
require('@alfalab/core-components-icon-button');
|
|
15
|
+
require('@alfalab/icons-glyph/MinusMIcon');
|
|
16
|
+
require('@alfalab/icons-glyph/PlusMediumMIcon');
|
|
9
17
|
|
|
10
18
|
function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
|
|
11
19
|
|
|
12
20
|
var React__default = /*#__PURE__*/_interopDefaultCompat(React);
|
|
13
21
|
var mergeRefs__default = /*#__PURE__*/_interopDefaultCompat(mergeRefs);
|
|
22
|
+
var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
|
|
14
23
|
|
|
15
|
-
var
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
if (!isEndPosition && shouldRestore) {
|
|
37
|
-
input.selectionStart = positionCursor;
|
|
38
|
-
input.selectionEnd = positionCursor;
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
};
|
|
42
|
-
var handleChange = function (event) {
|
|
43
|
-
var input = event.target;
|
|
44
|
-
var newValue = input.value.replace(utils.createSeparatorsRegExp(), separator);
|
|
45
|
-
var allowedValue = utils.getAllowedValue({
|
|
46
|
-
value: newValue,
|
|
47
|
-
fractionLength: fractionLength,
|
|
48
|
-
allowSigns: allowSigns,
|
|
24
|
+
var defaultColors = {"steppers":"number-input__steppers_vqdas","steppersFocused":"number-input__steppersFocused_vqdas","steppersDisabled":"number-input__steppersDisabled_vqdas"};
|
|
25
|
+
require('./default.css')
|
|
26
|
+
|
|
27
|
+
var styles = {"s":"number-input__s_77v6k","m":"number-input__m_77v6k"};
|
|
28
|
+
require('./index.css')
|
|
29
|
+
|
|
30
|
+
var invertedColors = {"steppers":"number-input__steppers_163tu","steppersFocused":"number-input__steppersFocused_163tu","steppersDisabled":"number-input__steppersDisabled_163tu"};
|
|
31
|
+
require('./inverted.css')
|
|
32
|
+
|
|
33
|
+
var colorStyles = {
|
|
34
|
+
default: defaultColors,
|
|
35
|
+
inverted: invertedColors,
|
|
36
|
+
};
|
|
37
|
+
var NumberInput = React.forwardRef(function (_a, ref) {
|
|
38
|
+
var _b;
|
|
39
|
+
var propValue = _a.value, onChange = _a.onChange, _c = _a.separator, separator = _c === void 0 ? ',' : _c, _d = _a.fractionLength, fractionLength = _d === void 0 ? utils.MAX_DIGITS : _d, defaultValue = _a.defaultValue, Input = _a.Input, minProp = _a.min, maxProp = _a.max, rightAddons = _a.rightAddons, dataTestId = _a.dataTestId, disabled = _a.disabled, onBlur = _a.onBlur, onFocus = _a.onFocus; _a.view; var stepProp = _a.step, _e = _a.size, size = _e === void 0 ? 's' : _e, disableUserInput = _a.disableUserInput, clearProp = _a.clear, _f = _a.colors, colors = _f === void 0 ? 'default' : _f, restProps = tslib.__rest(_a, ["value", "onChange", "separator", "fractionLength", "defaultValue", "Input", "min", "max", "rightAddons", "dataTestId", "disabled", "onBlur", "onFocus", "view", "step", "size", "disableUserInput", "clear", "colors"]);
|
|
40
|
+
var min = Math.max(utils.MIN_SAFE_INTEGER, minProp !== null && minProp !== void 0 ? minProp : utils.MIN_SAFE_INTEGER);
|
|
41
|
+
var max = Math.min(utils.MAX_SAFE_INTEGER, maxProp !== null && maxProp !== void 0 ? maxProp : utils.MAX_SAFE_INTEGER);
|
|
42
|
+
var withStepper = stepProp !== undefined;
|
|
43
|
+
var maskOptions = React.useMemo(function () {
|
|
44
|
+
return utils.createMaskOptions({
|
|
49
45
|
separator: separator,
|
|
46
|
+
fractionLength: withStepper ? 0 : fractionLength,
|
|
47
|
+
min: min,
|
|
48
|
+
max: max,
|
|
50
49
|
});
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
50
|
+
}, [separator, fractionLength, min, max, withStepper]);
|
|
51
|
+
var _g = React.useState(false), focused = _g[0], setFocused = _g[1];
|
|
52
|
+
var _h = React.useState(function () {
|
|
53
|
+
if (defaultValue == null) {
|
|
54
|
+
return withStepper ? coreComponentsShared.fnUtils.clamp(0, min, max).toString() : '';
|
|
56
55
|
}
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
var hasSeparator = (val.match(utils.createSeparatorsRegExp()) || []).length > 0;
|
|
72
|
-
// Запрещаем вводить второй сепаратор
|
|
73
|
-
if (hasSeparator && utils.SEPARATORS.some(function (s) { return s === event.key; })) {
|
|
74
|
-
return event.preventDefault();
|
|
75
|
-
}
|
|
76
|
-
// Запрещаем вводить лишний знак
|
|
77
|
-
if ((!allowSigns || utils.SIGNS.some(function (s) { return s === val[0]; })) &&
|
|
78
|
-
utils.SIGNS.some(function (s) { return s === event.key; })) {
|
|
79
|
-
return event.preventDefault();
|
|
80
|
-
}
|
|
81
|
-
var selectionStart = target.selectionStart || 0;
|
|
82
|
-
// Запрещаем вводить цифры в дробную часть, если кол-во цифр больше fractionLength
|
|
83
|
-
if (hasSeparator &&
|
|
84
|
-
fractionLength &&
|
|
85
|
-
event.key.length === 1 &&
|
|
86
|
-
selectionStart > val.indexOf(separator) &&
|
|
87
|
-
val.split(separator)[1].length >= fractionLength) {
|
|
88
|
-
return event.preventDefault();
|
|
56
|
+
return coreComponentsShared.fnUtils
|
|
57
|
+
.clamp(utils.parseNumber(core.maskitoTransform(defaultValue.toString(), maskOptions)), min, max)
|
|
58
|
+
.toString();
|
|
59
|
+
}), value = _h[0], setValue = _h[1];
|
|
60
|
+
var maskRef = react.useMaskito({ options: maskOptions });
|
|
61
|
+
React.useEffect(function () {
|
|
62
|
+
if (propValue !== undefined) {
|
|
63
|
+
setValue(function (prev) {
|
|
64
|
+
var parsedNumber = utils.parseNumber(propValue);
|
|
65
|
+
if (parsedNumber !== utils.parseNumber(prev)) {
|
|
66
|
+
return core.maskitoTransform(utils.stringifyNumberWithoutExp(parsedNumber), maskOptions);
|
|
67
|
+
}
|
|
68
|
+
return prev;
|
|
69
|
+
});
|
|
89
70
|
}
|
|
90
|
-
|
|
71
|
+
}, [maskOptions, propValue, separator]);
|
|
72
|
+
var getMaxLength = function (valueString) {
|
|
73
|
+
var hasSeparator = valueString === null || valueString === void 0 ? void 0 : valueString.includes(separator);
|
|
74
|
+
var hasSigns = valueString === null || valueString === void 0 ? void 0 : valueString.startsWith(utils.MINUS_SIGN);
|
|
75
|
+
return utils.MAX_DIGITS + (hasSeparator ? 1 : 0) + (hasSigns ? 1 : 0);
|
|
91
76
|
};
|
|
92
|
-
var
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
77
|
+
var getStep = function () { return Math.round(stepProp !== null && stepProp !== void 0 ? stepProp : 1); };
|
|
78
|
+
var changeValue = function (event, newValue) {
|
|
79
|
+
var _a, _b;
|
|
80
|
+
var isNaNValue = Number.isNaN(newValue);
|
|
81
|
+
var valueString = (_b = (_a = event === null || event === void 0 ? void 0 : event.target.value) !== null && _a !== void 0 ? _a : newValue === null || newValue === void 0 ? void 0 : newValue.toString()) !== null && _b !== void 0 ? _b : '';
|
|
82
|
+
setValue(valueString);
|
|
83
|
+
if (valueString === '' || !isNaNValue) {
|
|
84
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(event, {
|
|
85
|
+
value: isNaNValue ? null : newValue,
|
|
98
86
|
});
|
|
99
87
|
}
|
|
100
|
-
|
|
101
|
-
|
|
88
|
+
};
|
|
89
|
+
var handleChange = function (event) {
|
|
90
|
+
var valueString = event.target.value;
|
|
91
|
+
changeValue(event, utils.parseNumber(valueString));
|
|
92
|
+
};
|
|
93
|
+
var handleIncrement = function () {
|
|
94
|
+
var parsed = utils.parseNumber(value);
|
|
95
|
+
var nextValue = core.maskitoTransform((Number.isNaN(parsed) ? min : parsed + getStep()).toString(), maskOptions);
|
|
96
|
+
changeValue(null, utils.parseNumber(nextValue));
|
|
97
|
+
};
|
|
98
|
+
var handleDecrement = function () {
|
|
99
|
+
var parsed = utils.parseNumber(value);
|
|
100
|
+
var nextValue = core.maskitoTransform((Number.isNaN(parsed) ? max : parsed - getStep()).toString(), maskOptions);
|
|
101
|
+
changeValue(null, utils.parseNumber(nextValue));
|
|
102
|
+
};
|
|
103
|
+
var handleFocus = function (e) {
|
|
104
|
+
onFocus === null || onFocus === void 0 ? void 0 : onFocus(e);
|
|
105
|
+
if (!disableUserInput) {
|
|
106
|
+
setFocused(true);
|
|
102
107
|
}
|
|
103
|
-
if (onBlur)
|
|
104
|
-
onBlur(event);
|
|
105
108
|
};
|
|
106
|
-
var
|
|
107
|
-
|
|
109
|
+
var handleBlur = function (e) {
|
|
110
|
+
onBlur === null || onBlur === void 0 ? void 0 : onBlur(e);
|
|
111
|
+
setFocused(false);
|
|
112
|
+
};
|
|
113
|
+
return (React__default.default.createElement(Input, tslib.__assign({ maxLength: getMaxLength(value) }, restProps, {
|
|
114
|
+
// В iOS в цифровой клавиатуре невозможно ввести минус.
|
|
115
|
+
inputMode: min < 0 && coreComponentsShared.os.isIOS() ? 'text' : 'decimal', ref: mergeRefs__default.default([ref, maskRef]), value: value, onInput: handleChange, dataTestId: dataTestId, colors: colors, disabled: disabled, onFocus: handleFocus, onBlur: handleBlur, size: size, disableUserInput: disableUserInput, clear: clearProp && /\d/.test(value), rightAddons: withStepper ? (React__default.default.createElement(React__default.default.Fragment, null,
|
|
116
|
+
rightAddons,
|
|
117
|
+
React__default.default.createElement(components_steppers_Component.Steppers, { colors: colors, dataTestId: dataTestId, disabled: disabled, value: utils.parseNumber(value), min: min, max: max, className: cn__default.default(colorStyles[colors].steppers, styles[size], (_b = {},
|
|
118
|
+
_b[colorStyles[colors].steppersFocused] = focused,
|
|
119
|
+
_b[colorStyles[colors].steppersDisabled] = disabled,
|
|
120
|
+
_b)), onIncrement: handleIncrement, onDecrement: handleDecrement }))) : (rightAddons) })));
|
|
108
121
|
});
|
|
109
122
|
|
|
110
123
|
exports.NumberInput = NumberInput;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/* hash: o5lab */
|
|
2
|
+
:root {
|
|
3
|
+
} /* deprecated */ :root {
|
|
4
|
+
--color-light-neutral-1500-inverted: #fff;
|
|
5
|
+
--color-light-neutral-translucent-200: rgba(30, 43, 68, 0.08); /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
6
|
+
} :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
7
|
+
} :root {
|
|
8
|
+
} :root {
|
|
9
|
+
|
|
10
|
+
/* Hard */
|
|
11
|
+
|
|
12
|
+
/* Up */
|
|
13
|
+
|
|
14
|
+
/* Hard up */
|
|
15
|
+
} :root {
|
|
16
|
+
} :root {
|
|
17
|
+
} :root {
|
|
18
|
+
} :root {
|
|
19
|
+
} .number-input__steppers_vqdas {
|
|
20
|
+
background-color: var(--color-light-neutral-1500-inverted);
|
|
21
|
+
} .number-input__steppersFocused_vqdas,
|
|
22
|
+
.number-input__steppersDisabled_vqdas {
|
|
23
|
+
background-color: var(--color-light-neutral-translucent-200);
|
|
24
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/* hash: bzled */
|
|
2
|
+
:root {
|
|
3
|
+
} /* deprecated */ :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
4
|
+
} :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
5
|
+
} :root {
|
|
6
|
+
} :root {
|
|
7
|
+
|
|
8
|
+
/* Hard */
|
|
9
|
+
|
|
10
|
+
/* Up */
|
|
11
|
+
|
|
12
|
+
/* Hard up */
|
|
13
|
+
} :root {
|
|
14
|
+
} :root {
|
|
15
|
+
--gap-2xs-neg: -4px;
|
|
16
|
+
--gap-xs-neg: -8px;
|
|
17
|
+
} :root {
|
|
18
|
+
} :root {
|
|
19
|
+
} .number-input__s_77v6k {
|
|
20
|
+
margin-right: var(--gap-xs-neg);
|
|
21
|
+
} .number-input__m_77v6k {
|
|
22
|
+
margin-right: var(--gap-2xs-neg);
|
|
23
|
+
}
|
|
@@ -6,7 +6,15 @@ var components_numberInput_Component = require('./Component.js');
|
|
|
6
6
|
require('tslib');
|
|
7
7
|
require('react');
|
|
8
8
|
require('react-merge-refs');
|
|
9
|
+
require('@maskito/core');
|
|
10
|
+
require('@maskito/react');
|
|
11
|
+
require('classnames');
|
|
12
|
+
require('@alfalab/core-components-shared');
|
|
9
13
|
require('../../utils.js');
|
|
14
|
+
require('../steppers/Component.js');
|
|
15
|
+
require('@alfalab/core-components-icon-button');
|
|
16
|
+
require('@alfalab/icons-glyph/MinusMIcon');
|
|
17
|
+
require('@alfalab/icons-glyph/PlusMediumMIcon');
|
|
10
18
|
|
|
11
19
|
|
|
12
20
|
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/* hash: omvxl */
|
|
2
|
+
:root {
|
|
3
|
+
} /* deprecated */ :root {
|
|
4
|
+
--color-light-neutral-1500: #0e0e0e;
|
|
5
|
+
--color-light-neutral-translucent-300-inverted: rgba(222, 222, 238, 0.13); /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
6
|
+
} :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
7
|
+
} :root {
|
|
8
|
+
} :root {
|
|
9
|
+
|
|
10
|
+
/* Hard */
|
|
11
|
+
|
|
12
|
+
/* Up */
|
|
13
|
+
|
|
14
|
+
/* Hard up */
|
|
15
|
+
} :root {
|
|
16
|
+
} :root {
|
|
17
|
+
} :root {
|
|
18
|
+
} :root {
|
|
19
|
+
} .number-input__steppers_163tu {
|
|
20
|
+
background-color: var(--color-light-neutral-1500);
|
|
21
|
+
} .number-input__steppersFocused_163tu,
|
|
22
|
+
.number-input__steppersDisabled_163tu {
|
|
23
|
+
background-color: var(--color-light-neutral-translucent-300-inverted);
|
|
24
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import React from 'react';
|
|
3
|
+
type SteppersProps = {
|
|
4
|
+
value: number;
|
|
5
|
+
min: number;
|
|
6
|
+
max: number;
|
|
7
|
+
className?: string;
|
|
8
|
+
disabled?: boolean;
|
|
9
|
+
onIncrement: () => void;
|
|
10
|
+
onDecrement: () => void;
|
|
11
|
+
dataTestId?: string;
|
|
12
|
+
colors: 'default' | 'inverted';
|
|
13
|
+
};
|
|
14
|
+
declare const Steppers: React.FC<SteppersProps>;
|
|
15
|
+
export { SteppersProps, Steppers };
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var cn = require('classnames');
|
|
7
|
+
var coreComponentsIconButton = require('@alfalab/core-components-icon-button');
|
|
8
|
+
var coreComponentsShared = require('@alfalab/core-components-shared');
|
|
9
|
+
var MinusMIcon = require('@alfalab/icons-glyph/MinusMIcon');
|
|
10
|
+
var PlusMediumMIcon = require('@alfalab/icons-glyph/PlusMediumMIcon');
|
|
11
|
+
|
|
12
|
+
function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
|
|
13
|
+
|
|
14
|
+
var React__default = /*#__PURE__*/_interopDefaultCompat(React);
|
|
15
|
+
var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
|
|
16
|
+
|
|
17
|
+
var defaultColors = {"separator":"number-input__separator_1xrwr"};
|
|
18
|
+
require('./default.css')
|
|
19
|
+
|
|
20
|
+
var styles = {"component":"number-input__component_1ab92","separator":"number-input__separator_1ab92","button":"number-input__button_1ab92"};
|
|
21
|
+
require('./index.css')
|
|
22
|
+
|
|
23
|
+
var invertedColors = {"separator":"number-input__separator_1uwaa"};
|
|
24
|
+
require('./inverted.css')
|
|
25
|
+
|
|
26
|
+
var colorStyles = {
|
|
27
|
+
default: defaultColors,
|
|
28
|
+
inverted: invertedColors,
|
|
29
|
+
};
|
|
30
|
+
function preventDefault(e) {
|
|
31
|
+
e.preventDefault();
|
|
32
|
+
}
|
|
33
|
+
var Steppers = function (_a) {
|
|
34
|
+
var className = _a.className, onIncrement = _a.onIncrement, onDecrement = _a.onDecrement, value = _a.value, min = _a.min, max = _a.max, disabled = _a.disabled, dataTestId = _a.dataTestId, colors = _a.colors;
|
|
35
|
+
var decButtonDisabled = disabled || value <= min;
|
|
36
|
+
var incButtonDisabled = disabled || value >= max;
|
|
37
|
+
return (React__default.default.createElement("div", { className: cn__default.default(styles.component, className) },
|
|
38
|
+
React__default.default.createElement(coreComponentsIconButton.IconButton, { colors: colors, disabled: decButtonDisabled, className: styles.button, icon: React__default.default.createElement(MinusMIcon.MinusMIcon, null), "aria-label": '\u0443\u043C\u0435\u043D\u044C\u0448\u0438\u0442\u044C', onMouseDown: preventDefault, onClick: onDecrement, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'decrement-button'), view: 'secondary' }),
|
|
39
|
+
React__default.default.createElement("div", { className: cn__default.default(styles.separator, colorStyles[colors].separator) }),
|
|
40
|
+
React__default.default.createElement(coreComponentsIconButton.IconButton, { colors: colors, disabled: incButtonDisabled, className: styles.button, icon: React__default.default.createElement(PlusMediumMIcon.PlusMediumMIcon, null), "aria-label": '\u0443\u0432\u0435\u043B\u0438\u0447\u0438\u0442\u044C', onMouseDown: preventDefault, onClick: onIncrement, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'increment-button'), view: 'secondary' })));
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
exports.Steppers = Steppers;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/* hash: 306x5 */
|
|
2
|
+
:root {
|
|
3
|
+
} /* deprecated */ :root {
|
|
4
|
+
--color-light-neutral-translucent-300: rgba(15, 25, 55, 0.1); /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
5
|
+
} :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
6
|
+
} :root {
|
|
7
|
+
} :root {
|
|
8
|
+
|
|
9
|
+
/* Hard */
|
|
10
|
+
|
|
11
|
+
/* Up */
|
|
12
|
+
|
|
13
|
+
/* Hard up */
|
|
14
|
+
} :root {
|
|
15
|
+
} :root {
|
|
16
|
+
} :root {
|
|
17
|
+
} :root {
|
|
18
|
+
} .number-input__separator_1xrwr {
|
|
19
|
+
background-color: var(--color-light-neutral-translucent-300);
|
|
20
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/* hash: 6nhr0 */
|
|
2
|
+
:root {
|
|
3
|
+
} /* deprecated */ :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
4
|
+
} :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
5
|
+
} :root {
|
|
6
|
+
} :root {
|
|
7
|
+
|
|
8
|
+
/* Hard */
|
|
9
|
+
|
|
10
|
+
/* Up */
|
|
11
|
+
|
|
12
|
+
/* Hard up */
|
|
13
|
+
} :root {
|
|
14
|
+
} :root {
|
|
15
|
+
} :root {
|
|
16
|
+
} :root {
|
|
17
|
+
} .number-input__component_1ab92 {
|
|
18
|
+
display: flex;
|
|
19
|
+
flex-flow: row nowrap;
|
|
20
|
+
align-items: center;
|
|
21
|
+
border-radius: 5px;
|
|
22
|
+
transition: background-color 0.2s ease;
|
|
23
|
+
overflow: visible;
|
|
24
|
+
} .number-input__separator_1ab92 {
|
|
25
|
+
height: 18px;
|
|
26
|
+
width: 1px;
|
|
27
|
+
} .number-input__button_1ab92 {
|
|
28
|
+
width: 40px;
|
|
29
|
+
height: 40px;
|
|
30
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./Component";
|