@megafon/ui-core 7.6.1 → 7.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/es/components/ErrorLoad/ErrorLoad.css +1 -0
- package/dist/es/components/ErrorLoad/ErrorLoad.d.ts +23 -0
- package/dist/es/components/ErrorLoad/ErrorLoad.js +59 -0
- package/dist/es/components/Search/Search.d.ts +6 -0
- package/dist/es/components/Search/Search.js +7 -2
- package/dist/es/components/Select/Select.d.ts +3 -1
- package/dist/es/components/Select/Select.js +9 -1
- package/dist/es/components/Sliders/Slider/Slider.css +1 -1
- package/dist/es/components/Sliders/Slider/Slider.d.ts +2 -4
- package/dist/es/components/Sliders/Slider/Slider.js +6 -5
- package/dist/es/components/Sliders/SliderRange/SliderRange.css +1 -1
- package/dist/es/components/Sliders/SliderRange/SliderRange.d.ts +2 -4
- package/dist/es/components/Sliders/SliderRange/SliderRange.js +13 -15
- package/dist/es/components/Sliders/SliderRatio/SliderRatio.css +1 -1
- package/dist/es/components/Sliders/SliderRatio/SliderRatio.d.ts +1 -2
- package/dist/es/components/Sliders/SliderRatio/SliderRatio.js +14 -16
- package/dist/es/index.d.ts +1 -1
- package/dist/es/index.js +1 -1
- package/dist/lib/components/ErrorLoad/ErrorLoad.css +1 -0
- package/dist/lib/components/ErrorLoad/ErrorLoad.d.ts +23 -0
- package/dist/lib/components/ErrorLoad/ErrorLoad.js +68 -0
- package/dist/lib/components/Search/Search.d.ts +6 -0
- package/dist/lib/components/Search/Search.js +7 -2
- package/dist/lib/components/Select/Select.d.ts +3 -1
- package/dist/lib/components/Select/Select.js +9 -1
- package/dist/lib/components/Sliders/Slider/Slider.css +1 -1
- package/dist/lib/components/Sliders/Slider/Slider.d.ts +2 -4
- package/dist/lib/components/Sliders/Slider/Slider.js +6 -5
- package/dist/lib/components/Sliders/SliderRange/SliderRange.css +1 -1
- package/dist/lib/components/Sliders/SliderRange/SliderRange.d.ts +2 -4
- package/dist/lib/components/Sliders/SliderRange/SliderRange.js +13 -15
- package/dist/lib/components/Sliders/SliderRatio/SliderRatio.css +1 -1
- package/dist/lib/components/Sliders/SliderRatio/SliderRatio.d.ts +1 -2
- package/dist/lib/components/Sliders/SliderRatio/SliderRatio.js +14 -16
- package/dist/lib/index.d.ts +1 -1
- package/dist/lib/index.js +7 -7
- package/package.json +3 -3
- package/dist/es/components/Sliders/components/SliderDisplayValue/SliderDisplayValue.css +0 -1
- package/dist/es/components/Sliders/components/SliderDisplayValue/SliderDisplayValue.d.ts +0 -23
- package/dist/es/components/Sliders/components/SliderDisplayValue/SliderDisplayValue.js +0 -78
- package/dist/lib/components/Sliders/components/SliderDisplayValue/SliderDisplayValue.css +0 -1
- package/dist/lib/components/Sliders/components/SliderDisplayValue/SliderDisplayValue.d.ts +0 -23
- package/dist/lib/components/Sliders/components/SliderDisplayValue/SliderDisplayValue.js +0 -86
|
@@ -68,6 +68,8 @@ export interface ISearchProps {
|
|
|
68
68
|
verification?: VerificationType;
|
|
69
69
|
/** Дополнительный текст под полем. Свойство verification влияет на цвет текста. */
|
|
70
70
|
noticeText?: string | JSX.Element;
|
|
71
|
+
/** Максимальное вводимое количество текста */
|
|
72
|
+
maxLength?: number;
|
|
71
73
|
/** Отключение поля ввода */
|
|
72
74
|
disabled?: boolean;
|
|
73
75
|
/** Делает поле обязательным */
|
|
@@ -79,6 +81,8 @@ export interface ISearchProps {
|
|
|
79
81
|
label?: string;
|
|
80
82
|
input?: string;
|
|
81
83
|
listItemTitle?: string;
|
|
84
|
+
list?: string;
|
|
85
|
+
listInner?: string;
|
|
82
86
|
control?: string;
|
|
83
87
|
icon?: string;
|
|
84
88
|
submitButton?: string;
|
|
@@ -103,6 +107,8 @@ export interface ISearchProps {
|
|
|
103
107
|
minTextareaHeight?: MinTextareaHeightType;
|
|
104
108
|
/** Показать хендлер для ресайза текстового поля */
|
|
105
109
|
showResizer?: boolean;
|
|
110
|
+
/** Ref обработчик */
|
|
111
|
+
inputRef?: (node: HTMLInputElement | HTMLTextAreaElement) => void;
|
|
106
112
|
/** Обработчик изменения поля */
|
|
107
113
|
onChange?: (value: string) => void;
|
|
108
114
|
/** Обработчик нажатия на enter */
|
|
@@ -94,6 +94,7 @@ var Search = function Search(_ref) {
|
|
|
94
94
|
disabled = _ref.disabled,
|
|
95
95
|
required = _ref.required,
|
|
96
96
|
noticeText = _ref.noticeText,
|
|
97
|
+
maxLength = _ref.maxLength,
|
|
97
98
|
className = _ref.className,
|
|
98
99
|
classes = _ref.classes,
|
|
99
100
|
_ref$type = _ref.type,
|
|
@@ -109,6 +110,7 @@ var Search = function Search(_ref) {
|
|
|
109
110
|
_ref$minTextareaHeigh = _ref.minTextareaHeight,
|
|
110
111
|
minTextareaHeight = _ref$minTextareaHeigh === void 0 ? MinTextareaHeight.ONE_ROW : _ref$minTextareaHeigh,
|
|
111
112
|
showResizer = _ref.showResizer,
|
|
113
|
+
inputRef = _ref.inputRef,
|
|
112
114
|
onChange = _ref.onChange,
|
|
113
115
|
onSubmit = _ref.onSubmit,
|
|
114
116
|
onBlur = _ref.onBlur,
|
|
@@ -164,6 +166,7 @@ var Search = function Search(_ref) {
|
|
|
164
166
|
return;
|
|
165
167
|
}
|
|
166
168
|
fieldRef.current = node;
|
|
169
|
+
inputRef === null || inputRef === void 0 ? void 0 : inputRef(node);
|
|
167
170
|
};
|
|
168
171
|
var textareaResize = React.useCallback(function () {
|
|
169
172
|
if (!isTextarea || !fieldRef.current || !containerRef.current || isTextareaResized) {
|
|
@@ -424,10 +427,10 @@ var Search = function Search(_ref) {
|
|
|
424
427
|
};
|
|
425
428
|
var renderList = function renderList() {
|
|
426
429
|
return /*#__PURE__*/React.createElement("div", {
|
|
427
|
-
className: cn('list'),
|
|
430
|
+
className: cn('list', [classes === null || classes === void 0 ? void 0 : classes.list]),
|
|
428
431
|
ref: listRef
|
|
429
432
|
}, /*#__PURE__*/React.createElement("div", {
|
|
430
|
-
className: cn('list-inner')
|
|
433
|
+
className: cn('list-inner', [classes === null || classes === void 0 ? void 0 : classes.listInner])
|
|
431
434
|
}, items.map(function (_ref2, i) {
|
|
432
435
|
var itemValue = _ref2.value,
|
|
433
436
|
searchView = _ref2.searchView,
|
|
@@ -507,6 +510,7 @@ var Search = function Search(_ref) {
|
|
|
507
510
|
}, [classes === null || classes === void 0 ? void 0 : classes.input]),
|
|
508
511
|
placeholder: placeholder,
|
|
509
512
|
value: searchQuery,
|
|
513
|
+
maxLength: maxLength,
|
|
510
514
|
onChange: handleChange,
|
|
511
515
|
onFocus: handleFocus,
|
|
512
516
|
onBlur: handleBlur,
|
|
@@ -533,6 +537,7 @@ var Search = function Search(_ref) {
|
|
|
533
537
|
},
|
|
534
538
|
placeholder: placeholder,
|
|
535
539
|
value: searchQuery,
|
|
540
|
+
maxLength: maxLength,
|
|
536
541
|
onChange: handleChange,
|
|
537
542
|
onFocus: handleFocus,
|
|
538
543
|
onBlur: handleBlur,
|
|
@@ -84,6 +84,8 @@ export interface ISelectProps<T extends SelectItemValueType> {
|
|
|
84
84
|
listItemTitle?: Record<string, string>;
|
|
85
85
|
notFound?: Record<string, string>;
|
|
86
86
|
};
|
|
87
|
+
/** Ref обработчик */
|
|
88
|
+
inputRef?: (node: HTMLDivElement) => void;
|
|
87
89
|
/** Обработчик выбора элемента селекта */
|
|
88
90
|
onSelect?: (e: React.MouseEvent<HTMLDivElement> | React.KeyboardEvent<HTMLDivElement> | null, dataItem?: ISelectItem<T>) => void;
|
|
89
91
|
/** Обработчик при открытом селекте */
|
|
@@ -91,5 +93,5 @@ export interface ISelectProps<T extends SelectItemValueType> {
|
|
|
91
93
|
/** Обработчик при закрытом селекте */
|
|
92
94
|
onClosed?: () => void;
|
|
93
95
|
}
|
|
94
|
-
declare const Select: <T extends SelectItemValueType>({ type, disabled, verification, noticeText, label, labelId, required, className, classes, dataAttrs, notFoundText, items, placeholder, currentValue, shortList, onClosed, onOpened, onSelect, }: ISelectProps<T>) => JSX.Element;
|
|
96
|
+
declare const Select: <T extends SelectItemValueType>({ type, disabled, verification, noticeText, label, labelId, required, className, classes, dataAttrs, notFoundText, items, placeholder, currentValue, shortList, inputRef, onClosed, onOpened, onSelect, }: ISelectProps<T>) => JSX.Element;
|
|
95
97
|
export default Select;
|
|
@@ -84,6 +84,7 @@ var Select = function Select(_ref) {
|
|
|
84
84
|
currentValue = _ref.currentValue,
|
|
85
85
|
_ref$shortList = _ref.shortList,
|
|
86
86
|
shortList = _ref$shortList === void 0 ? false : _ref$shortList,
|
|
87
|
+
inputRef = _ref.inputRef,
|
|
87
88
|
onClosed = _ref.onClosed,
|
|
88
89
|
onOpened = _ref.onOpened,
|
|
89
90
|
onSelect = _ref.onSelect;
|
|
@@ -103,6 +104,13 @@ var Select = function Select(_ref) {
|
|
|
103
104
|
var currentIndex = itemsList.findIndex(function (elem) {
|
|
104
105
|
return elem.value === currentValue;
|
|
105
106
|
});
|
|
107
|
+
var getFieldNode = function getFieldNode(node) {
|
|
108
|
+
if (!node) {
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
selectNode.current = node;
|
|
112
|
+
inputRef === null || inputRef === void 0 ? void 0 : inputRef(node);
|
|
113
|
+
};
|
|
106
114
|
var handleClickOutside = (0, _react.useCallback)(function (e) {
|
|
107
115
|
var _a;
|
|
108
116
|
if (e.target instanceof Node && ((_a = selectNode.current) === null || _a === void 0 ? void 0 : _a.contains(e.target)) || !isOpened) {
|
|
@@ -393,7 +401,7 @@ var Select = function Select(_ref) {
|
|
|
393
401
|
valid: verification === Verification.VALID,
|
|
394
402
|
error: verification === Verification.ERROR
|
|
395
403
|
}, [className, classes.root]),
|
|
396
|
-
ref:
|
|
404
|
+
ref: getFieldNode
|
|
397
405
|
}), /*#__PURE__*/React.createElement("div", {
|
|
398
406
|
className: cn('inner')
|
|
399
407
|
}, /*#__PURE__*/React.createElement("div", (0, _extends2["default"])({}, (0, _uiHelpers.filterDataAttrs)(dataAttrs === null || dataAttrs === void 0 ? void 0 : dataAttrs.control), {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
h1,h2,h3,h4,h5{margin:0}.mfui-slider{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.mfui-slider__head{display:grid;font-size:15px;font-weight:500;grid-template-columns:auto 55%;line-height:24px;margin-bottom:8px}.mfui-
|
|
1
|
+
h1,h2,h3,h4,h5{margin:0}.mfui-slider{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.mfui-slider__head{display:grid;font-size:15px;font-weight:500;grid-template-columns:auto 55%;line-height:24px;margin-bottom:8px}.mfui-slider__range-input{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--spbSky0);background-image:-webkit-gradient(linear,left top,left bottom,from(var(--brandGreen)),to(var(--brandGreen)));background-image:linear-gradient(var(--brandGreen),var(--brandGreen));background-repeat:no-repeat;border-radius:100px;cursor:pointer;height:12px;margin:6px 0;outline:none}.mfui-slider__range-input:focus{outline:none}.mfui-slider__range-input::-webkit-slider-thumb{-webkit-appearance:none;background-color:var(--stcWhite);border:none;border-radius:50%;-webkit-box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:0 2px 6px rgba(0,0,0,.16);height:24px;width:24px}.mfui-slider__range-input::-moz-range-thumb{-webkit-appearance:none;background-color:var(--stcWhite);border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);height:24px;width:24px}.mfui-slider__range-input::-ms-thumb{-webkit-appearance:none;background-color:var(--stcWhite);border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);height:24px;width:24px}.mfui-slider__range-input::-webkit-slider-runnable-track{-webkit-appearance:none;background:transparent;border:none;-webkit-box-shadow:none;box-shadow:none}.mfui-slider__range-input::-moz-range-track{-webkit-appearance:none;background:transparent;border:none;box-shadow:none}.mfui-slider__range-input::-ms-track{-webkit-appearance:none;background:transparent;border:none;box-shadow:none}.mfui-slider_disabled .mfui-slider__head{color:var(--spbSky3)}.mfui-slider_disabled .mfui-slider__range-input{background-image:-webkit-gradient(linear,left top,left bottom,from(var(--spbSky1)),to(var(--spbSky1)));background-image:linear-gradient(var(--spbSky1),var(--spbSky1));cursor:default}.mfui-slider_disabled .mfui-slider__range-input::-webkit-slider-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-color:var(--spbSky2);border:none;border-radius:50%;-webkit-box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:0 2px 6px rgba(0,0,0,.16);-webkit-box-shadow:none;box-shadow:none;height:24px;width:24px}.mfui-slider_disabled .mfui-slider__range-input::-moz-range-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-color:var(--spbSky2);border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:none;height:24px;width:24px}.mfui-slider_disabled .mfui-slider__range-input::-ms-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-color:var(--spbSky2);border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:none;height:24px;width:24px}
|
|
@@ -1,6 +1,4 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
|
-
import { DisplayValueType } from '../components/SliderDisplayValue/SliderDisplayValue';
|
|
3
|
-
import { ScaleType } from '../components/SliderScale/SliderScale';
|
|
4
2
|
import './Slider.scss';
|
|
5
3
|
export interface ISlider {
|
|
6
4
|
/** Дополнительный класс корневого элемента */
|
|
@@ -14,7 +12,7 @@ export interface ISlider {
|
|
|
14
12
|
/** Лейбл */
|
|
15
13
|
label?: string;
|
|
16
14
|
/** Тип выводимого значения */
|
|
17
|
-
displayValueType?:
|
|
15
|
+
displayValueType?: 'input' | 'line';
|
|
18
16
|
/** Единица измерения выводимого значения */
|
|
19
17
|
displayValueUnit?: string;
|
|
20
18
|
/** Переводит компонент в контролируемое состояние */
|
|
@@ -22,7 +20,7 @@ export interface ISlider {
|
|
|
22
20
|
/** Шаг */
|
|
23
21
|
step?: number;
|
|
24
22
|
/** Тип встроенной шкалы */
|
|
25
|
-
scale?:
|
|
23
|
+
scale?: 'interval' | 'base';
|
|
26
24
|
/** Кастомная шкала */
|
|
27
25
|
customScale?: string[];
|
|
28
26
|
/** Переводит компонент в выключенное состояние */
|
|
@@ -9,7 +9,7 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
|
|
|
9
9
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
10
10
|
var React = _interopRequireWildcard(require("react"));
|
|
11
11
|
var _uiHelpers = require("@megafon/ui-helpers");
|
|
12
|
-
var
|
|
12
|
+
var _ValueField = _interopRequireDefault(require("../../ValueField/ValueField"));
|
|
13
13
|
var _SliderScale = _interopRequireDefault(require("../components/SliderScale/SliderScale"));
|
|
14
14
|
var _helpers = require("../helpers");
|
|
15
15
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
@@ -67,11 +67,12 @@ var Slider = function Slider(_ref) {
|
|
|
67
67
|
className: cn('head')
|
|
68
68
|
}, !!label && /*#__PURE__*/React.createElement("div", {
|
|
69
69
|
className: cn('label')
|
|
70
|
-
}, label), !!displayValueType && /*#__PURE__*/React.createElement(
|
|
71
|
-
|
|
70
|
+
}, label), !!displayValueType && /*#__PURE__*/React.createElement(_ValueField["default"], {
|
|
71
|
+
isControlled: true,
|
|
72
|
+
position: "right",
|
|
72
73
|
value: rawInputValue !== null && rawInputValue !== void 0 ? rawInputValue : rangeValue,
|
|
73
|
-
|
|
74
|
-
|
|
74
|
+
fieldType: displayValueType,
|
|
75
|
+
valueUnit: displayValueUnit,
|
|
75
76
|
disabled: disabled,
|
|
76
77
|
onChange: handleInputChange(false),
|
|
77
78
|
onBlur: handleInputBlur,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
h1,h2,h3,h4,h5{margin:0}.mfui-slider-range{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.mfui-slider-range__head{font-size:15px;font-weight:500;line-height:24px;margin-bottom:8px}.mfui-slider-range__display-values{display:grid;grid-template-columns:45% 45%;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;margin-top:8px;width:100%}.mfui-slider-
|
|
1
|
+
h1,h2,h3,h4,h5{margin:0}.mfui-slider-range{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.mfui-slider-range__head{font-size:15px;font-weight:500;line-height:24px;margin-bottom:8px}.mfui-slider-range__display-values{display:grid;grid-template-columns:45% 45%;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;margin-top:8px;width:100%}.mfui-slider-range__range-container{cursor:pointer;height:12px;margin:6px 0;position:relative}.mfui-slider-range__range-input{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;cursor:pointer;height:0;margin:0;outline:none;pointer-events:none;position:absolute;top:50%;width:100%}.mfui-slider-range__range-input_left{z-index:1}.mfui-slider-range__range-input_left.mfui-slider-range__range-input_over{z-index:3}.mfui-slider-range__range-input_right{z-index:2}.mfui-slider-range__range-input:focus{outline:none}.mfui-slider-range__range-input::-webkit-slider-thumb{-webkit-appearance:none;background-color:var(--stcWhite);border:none;border-radius:50%;-webkit-box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:0 2px 6px rgba(0,0,0,.16);height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-range__range-input::-moz-range-thumb{-webkit-appearance:none;background-color:var(--stcWhite);border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-range__range-input::-ms-thumb{-webkit-appearance:none;background-color:var(--stcWhite);border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-range__range-track{background-color:var(--spbSky0);border-radius:100px;cursor:pointer;height:100%;left:0;padding:0 12px;position:absolute;right:0;z-index:0}.mfui-slider-range__range-track-inner{height:100%;position:relative;width:100%}.mfui-slider-range__range-track-segment{background-color:var(--brandGreen);border-radius:100px;height:100%;position:absolute}.mfui-slider-range_disabled .mfui-slider-range__head{color:var(--spbSky3)}.mfui-slider-range_disabled .mfui-slider-range__range-track{cursor:default}.mfui-slider-range_disabled .mfui-slider-range__range-input{background-image:-webkit-gradient(linear,left top,left bottom,from(var(--spbSky1)),to(var(--spbSky1)));background-image:linear-gradient(var(--spbSky1),var(--spbSky1));cursor:default}.mfui-slider-range_disabled .mfui-slider-range__range-track-segment{background-color:var(--spbSky1)}.mfui-slider-range_disabled .mfui-slider-range__range-input::-webkit-slider-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-color:var(--spbSky2);border:none;border-radius:50%;-webkit-box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:0 2px 6px rgba(0,0,0,.16);-webkit-box-shadow:none;box-shadow:none;height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-range_disabled .mfui-slider-range__range-input::-moz-range-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-color:var(--spbSky2);border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:none;height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-range_disabled .mfui-slider-range__range-input::-ms-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-color:var(--spbSky2);border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:none;height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}
|
|
@@ -1,6 +1,4 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
|
-
import { DisplayValueType } from '../components/SliderDisplayValue/SliderDisplayValue';
|
|
3
|
-
import { ScaleType } from '../components/SliderScale/SliderScale';
|
|
4
2
|
import './SliderRange.scss';
|
|
5
3
|
export interface ISliderRange {
|
|
6
4
|
/** Дополнительный класс корневого элемента */
|
|
@@ -16,7 +14,7 @@ export interface ISliderRange {
|
|
|
16
14
|
/** Лейбл */
|
|
17
15
|
label?: string;
|
|
18
16
|
/** Тип выводимого значения */
|
|
19
|
-
displayValueType?:
|
|
17
|
+
displayValueType?: 'input' | 'line';
|
|
20
18
|
/** Префикс для выводимого значения слева */
|
|
21
19
|
displayLeftValuePrefix?: string;
|
|
22
20
|
/** Префикс для выводимого значения справа */
|
|
@@ -28,7 +26,7 @@ export interface ISliderRange {
|
|
|
28
26
|
/** Шаг */
|
|
29
27
|
step?: number;
|
|
30
28
|
/** Тип встроенной шкалы */
|
|
31
|
-
scale?:
|
|
29
|
+
scale?: 'interval' | 'base';
|
|
32
30
|
/** Кастомная шкала */
|
|
33
31
|
customScale?: string[];
|
|
34
32
|
/** Переводит компонент в выключенное состояние */
|
|
@@ -9,7 +9,7 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
|
|
|
9
9
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
10
10
|
var React = _interopRequireWildcard(require("react"));
|
|
11
11
|
var _uiHelpers = require("@megafon/ui-helpers");
|
|
12
|
-
var
|
|
12
|
+
var _ValueField = _interopRequireDefault(require("../../ValueField/ValueField"));
|
|
13
13
|
var _SliderScale = _interopRequireDefault(require("../components/SliderScale/SliderScale"));
|
|
14
14
|
var _helpers = require("../helpers");
|
|
15
15
|
var _helpers2 = require("./helpers");
|
|
@@ -135,28 +135,26 @@ var SliderRange = function SliderRange(_ref) {
|
|
|
135
135
|
className: cn('label')
|
|
136
136
|
}, label), !!displayValueType && /*#__PURE__*/React.createElement("div", {
|
|
137
137
|
className: cn('display-values')
|
|
138
|
-
}, /*#__PURE__*/React.createElement(
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
}),
|
|
138
|
+
}, /*#__PURE__*/React.createElement(_ValueField["default"], {
|
|
139
|
+
isControlled: true,
|
|
140
|
+
position: "left",
|
|
142
141
|
value: rawLeftInputValue !== null && rawLeftInputValue !== void 0 ? rawLeftInputValue : leftRangeValue,
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
142
|
+
fieldType: displayValueType,
|
|
143
|
+
valuePrefix: displayLeftValuePrefix,
|
|
144
|
+
valueUnit: displayValueUnit,
|
|
146
145
|
disabled: disabled,
|
|
147
146
|
onChange: handleLeftInputChange(false),
|
|
148
147
|
onBlur: handleInputBlur(true),
|
|
149
148
|
dataAttrs: {
|
|
150
149
|
input: dataAttrs === null || dataAttrs === void 0 ? void 0 : dataAttrs.leftInput
|
|
151
150
|
}
|
|
152
|
-
}), /*#__PURE__*/React.createElement(
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
}),
|
|
151
|
+
}), /*#__PURE__*/React.createElement(_ValueField["default"], {
|
|
152
|
+
isControlled: true,
|
|
153
|
+
position: "right",
|
|
156
154
|
value: rawRightInputValue !== null && rawRightInputValue !== void 0 ? rawRightInputValue : rightRangeValue,
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
155
|
+
fieldType: displayValueType,
|
|
156
|
+
valuePrefix: displayRightValuePrefix,
|
|
157
|
+
valueUnit: displayValueUnit,
|
|
160
158
|
disabled: disabled,
|
|
161
159
|
onChange: handleRightInputChange(false),
|
|
162
160
|
onBlur: handleInputBlur(false),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
h1,h2,h3,h4,h5{margin:0}.mfui-slider-ratio{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.mfui-slider-ratio__head{font-size:15px;font-weight:500;line-height:24px;margin-bottom:8px}.mfui-slider-ratio__display-values{display:grid;grid-template-columns:45% 45%;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;margin-top:8px;width:100%}.mfui-slider-
|
|
1
|
+
h1,h2,h3,h4,h5{margin:0}.mfui-slider-ratio{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.mfui-slider-ratio__head{font-size:15px;font-weight:500;line-height:24px;margin-bottom:8px}.mfui-slider-ratio__display-values{display:grid;grid-template-columns:45% 45%;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;margin-top:8px;width:100%}.mfui-slider-ratio__range-container{position:relative;width:100%}.mfui-slider-ratio__range-input{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--brandPurple);background-image:-webkit-gradient(linear,left top,left bottom,from(var(--brandGreen)),to(var(--brandGreen)));background-image:linear-gradient(var(--brandGreen),var(--brandGreen));background-repeat:no-repeat;border-radius:100px;cursor:pointer;display:block;height:12px;margin:6px 0;outline:none;pointer-events:none;position:relative;width:100%;z-index:1}.mfui-slider-ratio__range-input:focus{outline:none}.mfui-slider-ratio__range-input::-webkit-slider-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-image:url(i/thumb.png);background-repeat:no-repeat;background-size:100% 100%;border:none;border-radius:50%;-webkit-box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:0 2px 6px rgba(0,0,0,.16);height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-ratio__range-input::-moz-range-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-image:url(i/thumb.png);background-repeat:no-repeat;background-size:100% 100%;border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-ratio__range-input::-ms-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-image:url(i/thumb.png);background-repeat:no-repeat;background-size:100% 100%;border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-ratio__range-input::-webkit-slider-runnable-track{-webkit-appearance:none;background:transparent;border:none;-webkit-box-shadow:none;box-shadow:none}.mfui-slider-ratio__range-input::-moz-range-track{-webkit-appearance:none;background:transparent;border:none;box-shadow:none}.mfui-slider-ratio__range-input::-ms-track{-webkit-appearance:none;background:transparent;border:none;box-shadow:none}.mfui-slider-ratio__range-track{cursor:pointer;height:100%;position:absolute;top:0;width:100%;z-index:0}.mfui-slider-ratio__scale{bottom:0;display:-webkit-box;display:-ms-flexbox;display:flex;left:calc(var(--thumbSize)/2);position:absolute;right:calc(var(--thumbSize)/2);top:0;z-index:2;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;pointer-events:none}.mfui-slider-ratio__scale-item{background-color:var(--stcWhite);border-radius:50%;height:4px;width:4px}.mfui-slider-ratio__scale-item:first-child{margin-left:-2px}.mfui-slider-ratio__scale-item:last-child{margin-right:-2px}.mfui-slider-ratio_disabled .mfui-slider-ratio__head{color:var(--spbSky3)}.mfui-slider-ratio_disabled .mfui-slider-ratio__range-input{background-color:var(--spbSky1);background-image:-webkit-gradient(linear,left top,left bottom,from(var(--spbSky0)),to(var(--spbSky0)));background-image:linear-gradient(var(--spbSky0),var(--spbSky0));cursor:default}.mfui-slider-ratio_disabled .mfui-slider-ratio__range-input::-webkit-slider-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-color:var(--spbSky2);background-image:url(i/thumb.png);background-image:none;background-repeat:no-repeat;background-size:100% 100%;border:none;border-radius:50%;-webkit-box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:0 2px 6px rgba(0,0,0,.16);-webkit-box-shadow:none;box-shadow:none;height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-ratio_disabled .mfui-slider-ratio__range-input::-moz-range-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-color:var(--spbSky2);background-image:url(i/thumb.png);background-image:none;background-repeat:no-repeat;background-size:100% 100%;border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:none;height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-ratio_disabled .mfui-slider-ratio__range-input::-ms-thumb{-webkit-appearance:none;background-color:var(--stcWhite);background-color:var(--spbSky2);background-image:url(i/thumb.png);background-image:none;background-repeat:no-repeat;background-size:100% 100%;border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.16);box-shadow:none;height:var(--thumbSize);pointer-events:auto;width:var(--thumbSize)}.mfui-slider-ratio_disabled .mfui-slider-ratio__range-track{cursor:default}.mfui-slider-ratio_disabled .mfui-slider-ratio__scale{display:none}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
|
-
import { DisplayValueType } from '../components/SliderDisplayValue/SliderDisplayValue';
|
|
3
2
|
import { ValueType } from './types';
|
|
4
3
|
import './SliderRatio.scss';
|
|
5
4
|
export interface ISliderRatio {
|
|
@@ -12,7 +11,7 @@ export interface ISliderRatio {
|
|
|
12
11
|
/** Лейбл */
|
|
13
12
|
label?: string;
|
|
14
13
|
/** Тип выводимого значения */
|
|
15
|
-
displayValueType?:
|
|
14
|
+
displayValueType?: 'input' | 'line';
|
|
16
15
|
/** Префикс для выводимого значения слева */
|
|
17
16
|
displayLeftValuePrefix?: string;
|
|
18
17
|
/** Префикс для выводимого значения справа */
|
|
@@ -15,7 +15,7 @@ require("core-js/modules/es.object.to-string.js");
|
|
|
15
15
|
require("core-js/modules/web.dom-collections.iterator.js");
|
|
16
16
|
var React = _interopRequireWildcard(require("react"));
|
|
17
17
|
var _uiHelpers = require("@megafon/ui-helpers");
|
|
18
|
-
var
|
|
18
|
+
var _ValueField = _interopRequireDefault(require("../../ValueField/ValueField"));
|
|
19
19
|
var _helpers = require("../helpers");
|
|
20
20
|
var _helpers2 = require("./helpers");
|
|
21
21
|
var _types = require("./types");
|
|
@@ -30,7 +30,7 @@ var SliderRatio = function SliderRatio(_ref) {
|
|
|
30
30
|
var className = _ref.className,
|
|
31
31
|
label = _ref.label,
|
|
32
32
|
_ref$displayValueType = _ref.displayValueType,
|
|
33
|
-
displayValueType = _ref$displayValueType === void 0 ?
|
|
33
|
+
displayValueType = _ref$displayValueType === void 0 ? 'line' : _ref$displayValueType,
|
|
34
34
|
displayLeftValuePrefix = _ref.displayLeftValuePrefix,
|
|
35
35
|
displayRightValuePrefix = _ref.displayRightValuePrefix,
|
|
36
36
|
displayLeftValueUnit = _ref.displayLeftValueUnit,
|
|
@@ -150,28 +150,26 @@ var SliderRatio = function SliderRatio(_ref) {
|
|
|
150
150
|
className: cn('label')
|
|
151
151
|
}, label), /*#__PURE__*/React.createElement("div", {
|
|
152
152
|
className: cn('display-values')
|
|
153
|
-
}, /*#__PURE__*/React.createElement(
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
}),
|
|
153
|
+
}, /*#__PURE__*/React.createElement(_ValueField["default"], {
|
|
154
|
+
isControlled: true,
|
|
155
|
+
position: "left",
|
|
157
156
|
value: leftInputValue,
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
157
|
+
fieldType: displayValueType,
|
|
158
|
+
valuePrefix: displayLeftValuePrefix,
|
|
159
|
+
valueUnit: displayLeftValueUnit,
|
|
161
160
|
disabled: disabled,
|
|
162
161
|
onChange: handleInputChange(_types.KeyValueEnum.LEFT),
|
|
163
162
|
onBlur: handleInputBlur(_types.KeyValueEnum.LEFT),
|
|
164
163
|
dataAttrs: {
|
|
165
164
|
input: dataAttrs === null || dataAttrs === void 0 ? void 0 : dataAttrs.leftInput
|
|
166
165
|
}
|
|
167
|
-
}), /*#__PURE__*/React.createElement(
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
}),
|
|
166
|
+
}), /*#__PURE__*/React.createElement(_ValueField["default"], {
|
|
167
|
+
isControlled: true,
|
|
168
|
+
position: "right",
|
|
171
169
|
value: rightInputValue,
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
170
|
+
fieldType: displayValueType,
|
|
171
|
+
valuePrefix: displayRightValuePrefix,
|
|
172
|
+
valueUnit: displayRightValueUnit,
|
|
175
173
|
disabled: disabled,
|
|
176
174
|
onChange: handleInputChange(_types.KeyValueEnum.RIGHT),
|
|
177
175
|
onBlur: handleInputBlur(_types.KeyValueEnum.RIGHT),
|
package/dist/lib/index.d.ts
CHANGED
|
@@ -18,6 +18,7 @@ export { default as Counter } from './components/Counter/Counter';
|
|
|
18
18
|
export { default as CounterBadge } from './components/Badges/CounterBadge/CounterBadge';
|
|
19
19
|
export { default as countGraphemes } from './components/TextField/utils/countGraphemes';
|
|
20
20
|
export { default as Day } from './components/Calendar/components/_Day/Day';
|
|
21
|
+
export { default as ErrorLoad } from './components/ErrorLoad/ErrorLoad';
|
|
21
22
|
export { default as Grid } from './components/Grid/Grid';
|
|
22
23
|
export { default as GridColumn } from './components/Grid/GridColumn';
|
|
23
24
|
export { default as Header } from './components/Header/Header';
|
|
@@ -53,7 +54,6 @@ export { default as Select } from './components/Select/Select';
|
|
|
53
54
|
export { default as Selector } from './components/Selector/Selector';
|
|
54
55
|
export { default as selectReducer } from './components/Select/reducer/selectReducer';
|
|
55
56
|
export { default as Slider } from './components/Sliders/Slider/Slider';
|
|
56
|
-
export { default as SliderDisplayValue } from './components/Sliders/components/SliderDisplayValue/SliderDisplayValue';
|
|
57
57
|
export { default as SliderRange } from './components/Sliders/SliderRange/SliderRange';
|
|
58
58
|
export { default as SliderRatio } from './components/Sliders/SliderRatio/SliderRatio';
|
|
59
59
|
export { default as SliderScale } from './components/Sliders/components/SliderScale/SliderScale';
|
package/dist/lib/index.js
CHANGED
|
@@ -111,6 +111,12 @@ Object.defineProperty(exports, "Day", {
|
|
|
111
111
|
return _Day["default"];
|
|
112
112
|
}
|
|
113
113
|
});
|
|
114
|
+
Object.defineProperty(exports, "ErrorLoad", {
|
|
115
|
+
enumerable: true,
|
|
116
|
+
get: function get() {
|
|
117
|
+
return _ErrorLoad["default"];
|
|
118
|
+
}
|
|
119
|
+
});
|
|
114
120
|
Object.defineProperty(exports, "Grid", {
|
|
115
121
|
enumerable: true,
|
|
116
122
|
get: function get() {
|
|
@@ -315,12 +321,6 @@ Object.defineProperty(exports, "Slider", {
|
|
|
315
321
|
return _Slider["default"];
|
|
316
322
|
}
|
|
317
323
|
});
|
|
318
|
-
Object.defineProperty(exports, "SliderDisplayValue", {
|
|
319
|
-
enumerable: true,
|
|
320
|
-
get: function get() {
|
|
321
|
-
return _SliderDisplayValue["default"];
|
|
322
|
-
}
|
|
323
|
-
});
|
|
324
324
|
Object.defineProperty(exports, "SliderRange", {
|
|
325
325
|
enumerable: true,
|
|
326
326
|
get: function get() {
|
|
@@ -503,6 +503,7 @@ var _Counter = _interopRequireDefault(require("./components/Counter/Counter"));
|
|
|
503
503
|
var _CounterBadge = _interopRequireDefault(require("./components/Badges/CounterBadge/CounterBadge"));
|
|
504
504
|
var _countGraphemes = _interopRequireDefault(require("./components/TextField/utils/countGraphemes"));
|
|
505
505
|
var _Day = _interopRequireDefault(require("./components/Calendar/components/_Day/Day"));
|
|
506
|
+
var _ErrorLoad = _interopRequireDefault(require("./components/ErrorLoad/ErrorLoad"));
|
|
506
507
|
var _Grid = _interopRequireDefault(require("./components/Grid/Grid"));
|
|
507
508
|
var _GridColumn = _interopRequireDefault(require("./components/Grid/GridColumn"));
|
|
508
509
|
var _Header = _interopRequireDefault(require("./components/Header/Header"));
|
|
@@ -538,7 +539,6 @@ var _Select = _interopRequireDefault(require("./components/Select/Select"));
|
|
|
538
539
|
var _Selector = _interopRequireDefault(require("./components/Selector/Selector"));
|
|
539
540
|
var _selectReducer = _interopRequireDefault(require("./components/Select/reducer/selectReducer"));
|
|
540
541
|
var _Slider = _interopRequireDefault(require("./components/Sliders/Slider/Slider"));
|
|
541
|
-
var _SliderDisplayValue = _interopRequireDefault(require("./components/Sliders/components/SliderDisplayValue/SliderDisplayValue"));
|
|
542
542
|
var _SliderRange = _interopRequireDefault(require("./components/Sliders/SliderRange/SliderRange"));
|
|
543
543
|
var _SliderRatio = _interopRequireDefault(require("./components/Sliders/SliderRatio/SliderRatio"));
|
|
544
544
|
var _SliderScale = _interopRequireDefault(require("./components/Sliders/components/SliderScale/SliderScale"));
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@megafon/ui-core",
|
|
3
|
-
"version": "7.
|
|
3
|
+
"version": "7.8.0",
|
|
4
4
|
"files": [
|
|
5
5
|
"dist",
|
|
6
6
|
"styles"
|
|
@@ -50,7 +50,7 @@
|
|
|
50
50
|
"@babel/preset-env": "^7.8.6",
|
|
51
51
|
"@babel/preset-react": "^7.8.3",
|
|
52
52
|
"@babel/preset-typescript": "^7.8.3",
|
|
53
|
-
"@megafon/ui-icons": "^3.
|
|
53
|
+
"@megafon/ui-icons": "^3.5.0",
|
|
54
54
|
"@svgr/core": "^2.4.1",
|
|
55
55
|
"@testing-library/jest-dom": "^6.5.0",
|
|
56
56
|
"@testing-library/react": "^16.0.1",
|
|
@@ -104,5 +104,5 @@
|
|
|
104
104
|
"simplebar-react": "^3.2.5",
|
|
105
105
|
"swiper": "^11.1.1"
|
|
106
106
|
},
|
|
107
|
-
"gitHead": "
|
|
107
|
+
"gitHead": "adbb57b018314be1e716b9f09fe226e66107d198"
|
|
108
108
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
h1,h2,h3,h4,h5{margin:0}.mfui-slider-display-value{color:var(--content);display:-webkit-box;display:-ms-flexbox;display:flex;font-weight:400;max-width:100%}.mfui-slider-display-value_interactive{-webkit-box-align:center;-ms-flex-align:center;align-items:center;background-color:var(--base);border:1px solid var(--spbSky2);border-radius:12px;cursor:text;min-width:90px;overflow:hidden;padding:7px 16px}.mfui-slider-display-value_interactive.mfui-slider-display-value:hover,.mfui-slider-display-value_interactive.mfui-slider-display-value_focus{border-color:var(--content)}.mfui-slider-display-value_disabled{background-color:var(--spbSky0);border-color:var(--spbSky0);color:var(--spbSky3);cursor:default}.mfui-slider-display-value_disabled.mfui-slider-display-value_interactive:hover{border-color:var(--spbSky0)}.mfui-slider-display-value__box{overflow:hidden}.mfui-slider-display-value__line{font-weight:500}.mfui-slider-display-value__unit{margin-left:4px}.mfui-slider-display-value_interactive .mfui-slider-display-value__line{height:0;opacity:0;visibility:hidden}.mfui-slider-display-value__prefix{color:var(--spbSky3);margin-right:4px}.mfui-slider-display-value__input{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:transparent;border:none;border-radius:0;-webkit-box-shadow:none;box-shadow:none;caret-color:var(--brandGreen);color:inherit;cursor:text;display:block;font-family:inherit;font-size:15px;font-weight:400;line-height:24px;margin:0;min-width:100%;opacity:1;outline:none;padding:0;width:10px}.mfui-slider-display-value__input::-webkit-inner-spin-button,.mfui-slider-display-value__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.mfui-slider-display-value__input[type=number]{-moz-appearance:textfield}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import './SliderDisplayValue.scss';
|
|
3
|
-
export declare const DisplayValue: {
|
|
4
|
-
readonly LINE: "line";
|
|
5
|
-
readonly INPUT: "input";
|
|
6
|
-
};
|
|
7
|
-
export type DisplayValueType = (typeof DisplayValue)[keyof typeof DisplayValue];
|
|
8
|
-
export interface ISliderDisplayValue {
|
|
9
|
-
className?: string;
|
|
10
|
-
value: string | number;
|
|
11
|
-
displayValueType?: DisplayValueType;
|
|
12
|
-
displayValuePrefix?: string;
|
|
13
|
-
displayValueUnit?: string;
|
|
14
|
-
disabled?: boolean;
|
|
15
|
-
dataAttrs?: {
|
|
16
|
-
root?: Record<string, string>;
|
|
17
|
-
input?: Record<string, string>;
|
|
18
|
-
};
|
|
19
|
-
onChange: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
20
|
-
onBlur: () => void;
|
|
21
|
-
}
|
|
22
|
-
declare const SliderDisplayValue: React.FC<ISliderDisplayValue>;
|
|
23
|
-
export default SliderDisplayValue;
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
import _extends from "@babel/runtime/helpers/extends";
|
|
2
|
-
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
3
|
-
import "core-js/modules/es.array.includes.js";
|
|
4
|
-
import * as React from 'react';
|
|
5
|
-
import { cnCreate, filterDataAttrs } from '@megafon/ui-helpers';
|
|
6
|
-
import "./SliderDisplayValue.css";
|
|
7
|
-
export var DisplayValue = {
|
|
8
|
-
LINE: 'line',
|
|
9
|
-
INPUT: 'input'
|
|
10
|
-
};
|
|
11
|
-
var charsAllowedByNumberInput = ['e', 'E', '+', '-'];
|
|
12
|
-
var cn = cnCreate('mfui-slider-display-value');
|
|
13
|
-
var SliderDisplayValue = function SliderDisplayValue(_ref) {
|
|
14
|
-
var className = _ref.className,
|
|
15
|
-
value = _ref.value,
|
|
16
|
-
displayValueType = _ref.displayValueType,
|
|
17
|
-
displayValuePrefix = _ref.displayValuePrefix,
|
|
18
|
-
displayValueUnit = _ref.displayValueUnit,
|
|
19
|
-
disabled = _ref.disabled,
|
|
20
|
-
dataAttrs = _ref.dataAttrs,
|
|
21
|
-
onChange = _ref.onChange,
|
|
22
|
-
onBlur = _ref.onBlur;
|
|
23
|
-
var inputRef = React.useRef(null);
|
|
24
|
-
var _React$useState = React.useState(false),
|
|
25
|
-
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
26
|
-
isFocused = _React$useState2[0],
|
|
27
|
-
setIsFocused = _React$useState2[1];
|
|
28
|
-
var isDisplayValueInput = displayValueType === DisplayValue.INPUT;
|
|
29
|
-
var handleInputBlur = function handleInputBlur() {
|
|
30
|
-
setIsFocused(false);
|
|
31
|
-
onBlur();
|
|
32
|
-
};
|
|
33
|
-
var handleInputFocus = function handleInputFocus() {
|
|
34
|
-
setIsFocused(true);
|
|
35
|
-
};
|
|
36
|
-
var handleKeyDown = function handleKeyDown(e) {
|
|
37
|
-
var _a;
|
|
38
|
-
if (e.key === 'Enter') {
|
|
39
|
-
(_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.blur();
|
|
40
|
-
onBlur();
|
|
41
|
-
return;
|
|
42
|
-
}
|
|
43
|
-
if (charsAllowedByNumberInput.includes(e.key)) {
|
|
44
|
-
e.preventDefault();
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
return (
|
|
48
|
-
/*#__PURE__*/
|
|
49
|
-
// eslint-disable-next-line jsx-a11y/label-has-associated-control
|
|
50
|
-
React.createElement("label", _extends({
|
|
51
|
-
className: cn({
|
|
52
|
-
interactive: isDisplayValueInput,
|
|
53
|
-
focus: isFocused,
|
|
54
|
-
disabled: disabled
|
|
55
|
-
}, [className])
|
|
56
|
-
}, filterDataAttrs(dataAttrs === null || dataAttrs === void 0 ? void 0 : dataAttrs.root)), !!displayValuePrefix && /*#__PURE__*/React.createElement("div", {
|
|
57
|
-
className: cn('prefix')
|
|
58
|
-
}, displayValuePrefix), /*#__PURE__*/React.createElement("div", {
|
|
59
|
-
className: cn('box')
|
|
60
|
-
}, isDisplayValueInput && /*#__PURE__*/React.createElement("input", _extends({
|
|
61
|
-
className: cn('input'),
|
|
62
|
-
type: "number",
|
|
63
|
-
value: value,
|
|
64
|
-
onChange: onChange,
|
|
65
|
-
onBlur: handleInputBlur,
|
|
66
|
-
onFocus: handleInputFocus,
|
|
67
|
-
onKeyDown: handleKeyDown,
|
|
68
|
-
disabled: disabled
|
|
69
|
-
}, filterDataAttrs(dataAttrs === null || dataAttrs === void 0 ? void 0 : dataAttrs.input), {
|
|
70
|
-
ref: inputRef
|
|
71
|
-
})), /*#__PURE__*/React.createElement("div", {
|
|
72
|
-
className: cn('line')
|
|
73
|
-
}, value)), !!displayValueUnit && /*#__PURE__*/React.createElement("div", {
|
|
74
|
-
className: cn('unit')
|
|
75
|
-
}, displayValueUnit))
|
|
76
|
-
);
|
|
77
|
-
};
|
|
78
|
-
export default SliderDisplayValue;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
h1,h2,h3,h4,h5{margin:0}.mfui-slider-display-value{color:var(--content);display:-webkit-box;display:-ms-flexbox;display:flex;font-weight:400;max-width:100%}.mfui-slider-display-value_interactive{-webkit-box-align:center;-ms-flex-align:center;align-items:center;background-color:var(--base);border:1px solid var(--spbSky2);border-radius:12px;cursor:text;min-width:90px;overflow:hidden;padding:7px 16px}.mfui-slider-display-value_interactive.mfui-slider-display-value:hover,.mfui-slider-display-value_interactive.mfui-slider-display-value_focus{border-color:var(--content)}.mfui-slider-display-value_disabled{background-color:var(--spbSky0);border-color:var(--spbSky0);color:var(--spbSky3);cursor:default}.mfui-slider-display-value_disabled.mfui-slider-display-value_interactive:hover{border-color:var(--spbSky0)}.mfui-slider-display-value__box{overflow:hidden}.mfui-slider-display-value__line{font-weight:500}.mfui-slider-display-value__unit{margin-left:4px}.mfui-slider-display-value_interactive .mfui-slider-display-value__line{height:0;opacity:0;visibility:hidden}.mfui-slider-display-value__prefix{color:var(--spbSky3);margin-right:4px}.mfui-slider-display-value__input{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:transparent;border:none;border-radius:0;-webkit-box-shadow:none;box-shadow:none;caret-color:var(--brandGreen);color:inherit;cursor:text;display:block;font-family:inherit;font-size:15px;font-weight:400;line-height:24px;margin:0;min-width:100%;opacity:1;outline:none;padding:0;width:10px}.mfui-slider-display-value__input::-webkit-inner-spin-button,.mfui-slider-display-value__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.mfui-slider-display-value__input[type=number]{-moz-appearance:textfield}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import './SliderDisplayValue.scss';
|
|
3
|
-
export declare const DisplayValue: {
|
|
4
|
-
readonly LINE: "line";
|
|
5
|
-
readonly INPUT: "input";
|
|
6
|
-
};
|
|
7
|
-
export type DisplayValueType = (typeof DisplayValue)[keyof typeof DisplayValue];
|
|
8
|
-
export interface ISliderDisplayValue {
|
|
9
|
-
className?: string;
|
|
10
|
-
value: string | number;
|
|
11
|
-
displayValueType?: DisplayValueType;
|
|
12
|
-
displayValuePrefix?: string;
|
|
13
|
-
displayValueUnit?: string;
|
|
14
|
-
disabled?: boolean;
|
|
15
|
-
dataAttrs?: {
|
|
16
|
-
root?: Record<string, string>;
|
|
17
|
-
input?: Record<string, string>;
|
|
18
|
-
};
|
|
19
|
-
onChange: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
20
|
-
onBlur: () => void;
|
|
21
|
-
}
|
|
22
|
-
declare const SliderDisplayValue: React.FC<ISliderDisplayValue>;
|
|
23
|
-
export default SliderDisplayValue;
|