@i-novus/n2o-components 1.0.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/index.js +0 -0
- package/lib/display/Alerts/Alert.d.ts +2 -0
- package/lib/display/Alerts/Alert.js +121 -0
- package/lib/display/Alerts/AlertSection.d.ts +18 -0
- package/lib/display/Alerts/AlertSection.js +64 -0
- package/lib/display/Alerts/AlertWrapper.d.ts +6 -0
- package/lib/display/Alerts/AlertWrapper.js +39 -0
- package/lib/display/Alerts/DefaultAlert.d.ts +6 -0
- package/lib/display/Alerts/DefaultAlert.js +125 -0
- package/lib/display/Alerts/LoaderAlert.d.ts +5 -0
- package/lib/display/Alerts/LoaderAlert.js +36 -0
- package/lib/display/Alerts/types.d.ts +49 -0
- package/lib/display/Alerts/types.js +24 -0
- package/lib/display/Alerts/utils.d.ts +15 -0
- package/lib/display/Alerts/utils.js +102 -0
- package/lib/display/Badge/Badge.d.ts +16 -0
- package/lib/display/Badge/Badge.js +77 -0
- package/lib/display/Badge/enums.d.ts +9 -0
- package/lib/display/Badge/enums.js +23 -0
- package/lib/display/Badge/utils.d.ts +9 -0
- package/lib/display/Badge/utils.js +49 -0
- package/lib/display/Block.d.ts +369 -0
- package/lib/display/Block.js +38 -0
- package/lib/display/CodeViewer/CodeViewer.d.ts +13 -0
- package/lib/display/CodeViewer/CodeViewer.js +96 -0
- package/lib/display/Drawer/Drawer.d.ts +25 -0
- package/lib/display/Drawer/Drawer.js +99 -0
- package/lib/display/DropdownCustomItem.d.ts +7 -0
- package/lib/display/DropdownCustomItem.js +23 -0
- package/lib/display/Filter/Buttons.d.ts +11 -0
- package/lib/display/Filter/Buttons.js +42 -0
- package/lib/display/Filter/Filter.d.ts +8 -0
- package/lib/display/Filter/Filter.js +38 -0
- package/lib/display/HelpPopover.d.ts +16 -0
- package/lib/display/HelpPopover.js +104 -0
- package/lib/display/Html.d.ts +8 -0
- package/lib/display/Html.js +29 -0
- package/lib/display/Icon/Icon.d.ts +11 -0
- package/lib/display/Icon/Icon.js +42 -0
- package/lib/display/Image/Image.d.ts +30 -0
- package/lib/display/Image/Image.js +93 -0
- package/lib/display/Image/ImageInfo.d.ts +7 -0
- package/lib/display/Image/ImageInfo.js +23 -0
- package/lib/display/InputIcon.d.ts +13 -0
- package/lib/display/InputIcon.js +33 -0
- package/lib/display/NavItemImage/NavItemImage.d.ts +9 -0
- package/lib/display/NavItemImage/NavItemImage.js +35 -0
- package/lib/display/OutputList.d.ts +12 -0
- package/lib/display/OutputList.js +46 -0
- package/lib/display/OutputListItem.d.ts +10 -0
- package/lib/display/OutputListItem.js +58 -0
- package/lib/display/OutputText.d.ts +15 -0
- package/lib/display/OutputText.js +170 -0
- package/lib/display/Pagination/Pagination.d.ts +2 -0
- package/lib/display/Pagination/Pagination.js +273 -0
- package/lib/display/Pagination/PaginationButton.d.ts +13 -0
- package/lib/display/Pagination/PaginationButton.js +53 -0
- package/lib/display/Pagination/types.d.ts +62 -0
- package/lib/display/Pagination/types.js +36 -0
- package/lib/display/PopoverConfirm/PopoverConfirm.d.ts +30 -0
- package/lib/display/PopoverConfirm/PopoverConfirm.js +87 -0
- package/lib/display/ProgressControl/ProgressControl.d.ts +17 -0
- package/lib/display/ProgressControl/ProgressControl.js +68 -0
- package/lib/display/Slider.d.ts +23 -0
- package/lib/display/Slider.js +107 -0
- package/lib/display/Status.d.ts +9 -0
- package/lib/display/Status.js +40 -0
- package/lib/display/StatusText/StatusText.d.ts +10 -0
- package/lib/display/StatusText/StatusText.js +35 -0
- package/lib/display/StatusText/types.d.ts +18 -0
- package/lib/display/StatusText/types.js +19 -0
- package/lib/display/StatusText/utils.d.ts +3 -0
- package/lib/display/StatusText/utils.js +29 -0
- package/lib/display/Text.d.ts +12 -0
- package/lib/display/Text.js +38 -0
- package/lib/display/Typography/Base.d.ts +32 -0
- package/lib/display/Typography/Base.js +259 -0
- package/lib/display/Typography/ContentEditable.d.ts +15 -0
- package/lib/display/Typography/ContentEditable.js +86 -0
- package/lib/display/Typography/Paragraph.d.ts +4 -0
- package/lib/display/Typography/Paragraph.js +23 -0
- package/lib/display/Typography/Text.d.ts +9 -0
- package/lib/display/Typography/Text.js +37 -0
- package/lib/display/Typography/Title.d.ts +7 -0
- package/lib/display/Typography/Title.js +28 -0
- package/lib/display/Typography/utils.d.ts +13 -0
- package/lib/display/Typography/utils.js +75 -0
- package/lib/helpers/HelpPopover.d.ts +9 -0
- package/lib/helpers/HelpPopover.js +46 -0
- package/lib/helpers/withRightPlaceholder.d.ts +9 -0
- package/lib/helpers/withRightPlaceholder.js +35 -0
- package/lib/inputs/Checkbox/Checkbox.d.ts +29 -0
- package/lib/inputs/Checkbox/Checkbox.js +117 -0
- package/lib/inputs/Checkbox/CheckboxControl.d.ts +7 -0
- package/lib/inputs/Checkbox/CheckboxControl.js +33 -0
- package/lib/inputs/CheckboxGroup/CheckboxGroup.d.ts +11 -0
- package/lib/inputs/CheckboxGroup/CheckboxGroup.js +84 -0
- package/lib/inputs/CodeEditor/CodeEditor.d.ts +21 -0
- package/lib/inputs/CodeEditor/CodeEditor.js +85 -0
- package/lib/inputs/DatePicker/Calendar.d.ts +65 -0
- package/lib/inputs/DatePicker/Calendar.js +556 -0
- package/lib/inputs/DatePicker/CalendarHeader.d.ts +26 -0
- package/lib/inputs/DatePicker/CalendarHeader.js +213 -0
- package/lib/inputs/DatePicker/Clock.d.ts +10 -0
- package/lib/inputs/DatePicker/Clock.js +45 -0
- package/lib/inputs/DatePicker/DateInput.d.ts +44 -0
- package/lib/inputs/DatePicker/DateInput.js +262 -0
- package/lib/inputs/DatePicker/DateInputGroup.d.ts +20 -0
- package/lib/inputs/DatePicker/DateInputGroup.js +77 -0
- package/lib/inputs/DatePicker/DateInterval.d.ts +24 -0
- package/lib/inputs/DatePicker/DateInterval.js +92 -0
- package/lib/inputs/DatePicker/DatePicker.d.ts +22 -0
- package/lib/inputs/DatePicker/DatePicker.js +36 -0
- package/lib/inputs/DatePicker/DateTimeControl.d.ts +98 -0
- package/lib/inputs/DatePicker/DateTimeControl.js +452 -0
- package/lib/inputs/DatePicker/Day.d.ts +14 -0
- package/lib/inputs/DatePicker/Day.js +50 -0
- package/lib/inputs/DatePicker/PopUp.d.ts +19 -0
- package/lib/inputs/DatePicker/PopUp.js +71 -0
- package/lib/inputs/DatePicker/types.d.ts +31 -0
- package/lib/inputs/DatePicker/types.js +25 -0
- package/lib/inputs/DatePicker/utils.d.ts +39 -0
- package/lib/inputs/DatePicker/utils.js +304 -0
- package/lib/inputs/Input.d.ts +51 -0
- package/lib/inputs/Input.js +200 -0
- package/lib/inputs/InputMask/InputMask.d.ts +23 -0
- package/lib/inputs/InputMask/InputMask.js +310 -0
- package/lib/inputs/InputMoney/InputMoney.d.ts +101 -0
- package/lib/inputs/InputMoney/InputMoney.js +258 -0
- package/lib/inputs/InputNumber/InputNumber.d.ts +29 -0
- package/lib/inputs/InputNumber/InputNumber.js +316 -0
- package/lib/inputs/InputNumber/index.d.ts +1 -0
- package/lib/inputs/InputNumber/index.js +14 -0
- package/lib/inputs/InputNumber/types.d.ts +18 -0
- package/lib/inputs/InputNumber/types.js +14 -0
- package/lib/inputs/InputNumber/utils.d.ts +6 -0
- package/lib/inputs/InputNumber/utils.js +86 -0
- package/lib/inputs/InputPassword/InputPassword.d.ts +10 -0
- package/lib/inputs/InputPassword/InputPassword.js +81 -0
- package/lib/inputs/InputSelect/InputAddon.d.ts +17 -0
- package/lib/inputs/InputSelect/InputAddon.js +31 -0
- package/lib/inputs/InputSelect/InputContent.d.ts +63 -0
- package/lib/inputs/InputSelect/InputContent.js +188 -0
- package/lib/inputs/InputSelect/InputSelect.d.ts +296 -0
- package/lib/inputs/InputSelect/InputSelect.js +795 -0
- package/lib/inputs/InputSelect/InputSelectGroup.d.ts +43 -0
- package/lib/inputs/InputSelect/InputSelectGroup.js +113 -0
- package/lib/inputs/InputSelect/PopupItems.d.ts +55 -0
- package/lib/inputs/InputSelect/PopupItems.js +357 -0
- package/lib/inputs/InputSelect/PopupList.d.ts +82 -0
- package/lib/inputs/InputSelect/PopupList.js +138 -0
- package/lib/inputs/InputSelect/SelectedItems.d.ts +17 -0
- package/lib/inputs/InputSelect/SelectedItems.js +125 -0
- package/lib/inputs/InputSelect/constants.d.ts +4 -0
- package/lib/inputs/InputSelect/constants.js +15 -0
- package/lib/inputs/InputSelect/types.d.ts +16 -0
- package/lib/inputs/InputSelect/types.js +16 -0
- package/lib/inputs/InputSelect/utils.d.ts +9 -0
- package/lib/inputs/InputSelect/utils.js +142 -0
- package/lib/inputs/InputSelectTree/InputSelectTree.d.ts +114 -0
- package/lib/inputs/InputSelectTree/InputSelectTree.js +466 -0
- package/lib/inputs/InputSelectTree/TreeSelectNode.d.ts +36 -0
- package/lib/inputs/InputSelectTree/TreeSelectNode.js +63 -0
- package/lib/inputs/InputSelectTree/allProps.d.ts +123 -0
- package/lib/inputs/InputSelectTree/allProps.js +48 -0
- package/lib/inputs/InputSelectTree/until.d.ts +4 -0
- package/lib/inputs/InputSelectTree/until.js +83 -0
- package/lib/inputs/InputText.d.ts +41 -0
- package/lib/inputs/InputText.js +170 -0
- package/lib/inputs/NumberPicker/NumberPicker.d.ts +15 -0
- package/lib/inputs/NumberPicker/NumberPicker.js +129 -0
- package/lib/inputs/NumberPicker/NumberPickerButton.d.ts +8 -0
- package/lib/inputs/NumberPicker/NumberPickerButton.js +64 -0
- package/lib/inputs/NumberPicker/index.d.ts +1 -0
- package/lib/inputs/NumberPicker/index.js +14 -0
- package/lib/inputs/NumberPicker/utils.d.ts +2 -0
- package/lib/inputs/NumberPicker/utils.js +31 -0
- package/lib/inputs/RadioGroup/default/Group.d.ts +15 -0
- package/lib/inputs/RadioGroup/default/Group.js +63 -0
- package/lib/inputs/RadioGroup/default/Input.d.ts +17 -0
- package/lib/inputs/RadioGroup/default/Input.js +77 -0
- package/lib/inputs/RadioGroup/tabs/Group.d.ts +3 -0
- package/lib/inputs/RadioGroup/tabs/Group.js +24 -0
- package/lib/inputs/RadioGroup/tabs/Input.d.ts +3 -0
- package/lib/inputs/RadioGroup/tabs/Input.js +21 -0
- package/lib/inputs/Rating/Rating.d.ts +30 -0
- package/lib/inputs/Rating/Rating.js +212 -0
- package/lib/inputs/Select/Popup.d.ts +31 -0
- package/lib/inputs/Select/Popup.js +131 -0
- package/lib/inputs/Select/Select.d.ts +225 -0
- package/lib/inputs/Select/Select.js +705 -0
- package/lib/inputs/Select/SelectInput.d.ts +19 -0
- package/lib/inputs/Select/SelectInput.js +85 -0
- package/lib/inputs/Select/utils.d.ts +1 -0
- package/lib/inputs/Select/utils.js +28 -0
- package/lib/inputs/Switch/Switch.d.ts +11 -0
- package/lib/inputs/Switch/Switch.js +41 -0
- package/lib/inputs/TextArea.d.ts +12 -0
- package/lib/inputs/TextArea.js +54 -0
- package/lib/inputs/TextEditor/TextEditor.d.ts +11 -0
- package/lib/inputs/TextEditor/TextEditor.js +89 -0
- package/lib/inputs/TimePicker/TimePicker.d.ts +50 -0
- package/lib/inputs/TimePicker/TimePicker.js +398 -0
- package/lib/inputs/utils.d.ts +5 -0
- package/lib/inputs/utils.js +39 -0
- package/lib/layouts/ScrollContainer.d.ts +218 -0
- package/lib/layouts/ScrollContainer.js +128 -0
- package/lib/layouts/Spinner/CoverSpinner.d.ts +29 -0
- package/lib/layouts/Spinner/CoverSpinner.js +153 -0
- package/lib/layouts/Spinner/InlineSpinner.d.ts +5 -0
- package/lib/layouts/Spinner/InlineSpinner.js +27 -0
- package/lib/layouts/Spinner/Spinner.d.ts +31 -0
- package/lib/layouts/Spinner/Spinner.js +178 -0
- package/lib/styles/components/Calendar.scss +125 -0
- package/lib/styles/components/CalendarHeader.scss +75 -0
- package/lib/styles/components/DateInputGroup.scss +39 -0
- package/lib/styles/components/DatePicker.scss +18 -0
- package/lib/styles/components/Day.scss +29 -0
- package/lib/styles/components/OutputList.scss +14 -0
- package/lib/styles/components/OutputText.scss +50 -0
- package/lib/styles/controls/CodeEditor.scss +4 -0
- package/lib/styles/controls/InputNumber.scss +36 -0
- package/lib/styles/controls/InputPassword.scss +17 -0
- package/lib/styles/controls/InputText.scss +59 -0
- package/lib/styles/controls/NumberPicker.scss +36 -0
- package/lib/styles/controls/ProgressControl.scss +3 -0
- package/lib/styles/controls/Slider.scss +32 -0
- package/lib/styles/controls/Switch.scss +105 -0
- package/lib/styles/controls/TextEditor.scss +23 -0
- package/lib/styles/controls/TimePicker.scss +32 -0
- package/lib/styles/n2o/variables.scss +328 -0
- package/lib/styles/theme/variables.scss +81 -0
- package/lib/styles/variables.scss +10 -0
- package/lib/types.d.ts +25 -0
- package/lib/types.js +6 -0
- package/lib/utils/id.d.ts +3 -0
- package/lib/utils/id.js +46 -0
- package/lib/utils/isEmptyModel.d.ts +1 -0
- package/lib/utils/isEmptyModel.js +21 -0
- package/lib/utils/parseFormatter.js +153 -0
- package/package.json +196 -0
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.Input = void 0;
|
|
9
|
+
|
|
10
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
11
|
+
|
|
12
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
13
|
+
|
|
14
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
15
|
+
|
|
16
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
17
|
+
|
|
18
|
+
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
19
|
+
|
|
20
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
21
|
+
|
|
22
|
+
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
23
|
+
|
|
24
|
+
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
25
|
+
|
|
26
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
27
|
+
|
|
28
|
+
var _react = _interopRequireDefault(require("react"));
|
|
29
|
+
|
|
30
|
+
var _classnames = _interopRequireDefault(require("classnames"));
|
|
31
|
+
|
|
32
|
+
var _isObject = _interopRequireDefault(require("lodash/isObject"));
|
|
33
|
+
|
|
34
|
+
var _isArray = _interopRequireDefault(require("lodash/isArray"));
|
|
35
|
+
|
|
36
|
+
var _omit = _interopRequireDefault(require("lodash/omit"));
|
|
37
|
+
|
|
38
|
+
var _isString = _interopRequireDefault(require("lodash/isString"));
|
|
39
|
+
|
|
40
|
+
var _excluded = ["autoFocus", "className", "disabled", "id", "inputRef", "label", "name", "onBlur", "onClick", "onFocus", "onPaste", "placeholder", "readonly", "style", "type", "value"];
|
|
41
|
+
|
|
42
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
43
|
+
|
|
44
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
45
|
+
|
|
46
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
|
|
47
|
+
|
|
48
|
+
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
49
|
+
|
|
50
|
+
var Input = /*#__PURE__*/function (_React$Component) {
|
|
51
|
+
(0, _inherits2["default"])(Input, _React$Component);
|
|
52
|
+
|
|
53
|
+
var _super = _createSuper(Input);
|
|
54
|
+
|
|
55
|
+
function Input(props) {
|
|
56
|
+
var _this;
|
|
57
|
+
|
|
58
|
+
(0, _classCallCheck2["default"])(this, Input);
|
|
59
|
+
_this = _super.call(this, props);
|
|
60
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleKeyDown", function (evt) {
|
|
61
|
+
var onKeyDown = _this.props.onKeyDown;
|
|
62
|
+
|
|
63
|
+
if (onKeyDown) {
|
|
64
|
+
onKeyDown(evt);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
if (evt.target.tagName === 'INPUT' && evt.target.type === 'checkbox' && evt.key === 'Enter') {
|
|
68
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
69
|
+
_this.handleChange(evt);
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
_this.input = null;
|
|
73
|
+
_this.handleChange = _this.handleChange.bind((0, _assertThisInitialized2["default"])(_this));
|
|
74
|
+
_this.setRef = _this.setRef.bind((0, _assertThisInitialized2["default"])(_this));
|
|
75
|
+
return _this;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
(0, _createClass2["default"])(Input, [{
|
|
79
|
+
key: "focus",
|
|
80
|
+
value: function focus() {
|
|
81
|
+
var _this$input;
|
|
82
|
+
|
|
83
|
+
(_this$input = this.input) === null || _this$input === void 0 ? void 0 : _this$input.focus();
|
|
84
|
+
}
|
|
85
|
+
}, {
|
|
86
|
+
key: "blur",
|
|
87
|
+
value: function blur() {
|
|
88
|
+
var _this$input2;
|
|
89
|
+
|
|
90
|
+
(_this$input2 = this.input) === null || _this$input2 === void 0 ? void 0 : _this$input2.blur();
|
|
91
|
+
}
|
|
92
|
+
}, {
|
|
93
|
+
key: "handleChange",
|
|
94
|
+
value: function handleChange(e) {
|
|
95
|
+
var props = this.props,
|
|
96
|
+
input = this.input;
|
|
97
|
+
|
|
98
|
+
if (props.disabled) {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
var value = (0, _isObject["default"])(props.value) || (0, _isArray["default"])(props.value) ? props.value : e.target.value;
|
|
103
|
+
|
|
104
|
+
if (props.onChange) {
|
|
105
|
+
props.onChange({
|
|
106
|
+
target: _objectSpread(_objectSpread({}, props), {}, {
|
|
107
|
+
value: value
|
|
108
|
+
}),
|
|
109
|
+
stopPropagation: function stopPropagation() {
|
|
110
|
+
e.stopPropagation();
|
|
111
|
+
},
|
|
112
|
+
preventDefault: function preventDefault() {
|
|
113
|
+
e.preventDefault();
|
|
114
|
+
},
|
|
115
|
+
getElement: function getElement() {
|
|
116
|
+
return input;
|
|
117
|
+
},
|
|
118
|
+
getNormalizeValue: function getNormalizeValue() {
|
|
119
|
+
return (0, _defineProperty2["default"])({}, props.name, props.value);
|
|
120
|
+
},
|
|
121
|
+
nativeEvent: e
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}, {
|
|
126
|
+
key: "setRef",
|
|
127
|
+
value: function setRef(node) {
|
|
128
|
+
this.input = node;
|
|
129
|
+
}
|
|
130
|
+
}, {
|
|
131
|
+
key: "render",
|
|
132
|
+
value: function render() {
|
|
133
|
+
var _this$props = this.props,
|
|
134
|
+
autoFocus = _this$props.autoFocus,
|
|
135
|
+
className = _this$props.className,
|
|
136
|
+
disabled = _this$props.disabled,
|
|
137
|
+
id = _this$props.id,
|
|
138
|
+
inputRef = _this$props.inputRef,
|
|
139
|
+
label = _this$props.label,
|
|
140
|
+
name = _this$props.name,
|
|
141
|
+
onBlur = _this$props.onBlur,
|
|
142
|
+
onClick = _this$props.onClick,
|
|
143
|
+
onFocus = _this$props.onFocus,
|
|
144
|
+
onPaste = _this$props.onPaste,
|
|
145
|
+
placeholder = _this$props.placeholder,
|
|
146
|
+
readonly = _this$props.readonly,
|
|
147
|
+
style = _this$props.style,
|
|
148
|
+
type = _this$props.type,
|
|
149
|
+
value = _this$props.value,
|
|
150
|
+
restProps = (0, _objectWithoutProperties2["default"])(_this$props, _excluded);
|
|
151
|
+
return /*#__PURE__*/_react["default"].createElement("input", (0, _extends2["default"])({
|
|
152
|
+
ref: inputRef,
|
|
153
|
+
className: (0, _classnames["default"])('n2o-input', className),
|
|
154
|
+
style: style,
|
|
155
|
+
id: id,
|
|
156
|
+
name: name,
|
|
157
|
+
type: type,
|
|
158
|
+
disabled: disabled
|
|
159
|
+
/* eslint-disable-next-line jsx-a11y/no-autofocus */
|
|
160
|
+
,
|
|
161
|
+
autoFocus: autoFocus,
|
|
162
|
+
value: value,
|
|
163
|
+
onPaste: onPaste // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
164
|
+
,
|
|
165
|
+
onFocus: onFocus // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
166
|
+
,
|
|
167
|
+
onBlur: onBlur,
|
|
168
|
+
onClick: onClick,
|
|
169
|
+
onKeyDown: this.handleKeyDown,
|
|
170
|
+
placeholder: placeholder,
|
|
171
|
+
readOnly: readonly
|
|
172
|
+
}, (0, _omit["default"])(restProps, ['length', 'onChange', 'onKeyDown']), {
|
|
173
|
+
onChange: this.handleChange,
|
|
174
|
+
title: (0, _isString["default"])(value) ? value : label
|
|
175
|
+
}));
|
|
176
|
+
}
|
|
177
|
+
}]);
|
|
178
|
+
return Input;
|
|
179
|
+
}(_react["default"].Component);
|
|
180
|
+
|
|
181
|
+
exports.Input = Input;
|
|
182
|
+
(0, _defineProperty2["default"])(Input, "defaultProps", {
|
|
183
|
+
id: '',
|
|
184
|
+
value: null,
|
|
185
|
+
name: '',
|
|
186
|
+
disabled: false,
|
|
187
|
+
autoFocus: false,
|
|
188
|
+
checked: false,
|
|
189
|
+
className: '',
|
|
190
|
+
tabIndex: 0,
|
|
191
|
+
style: {},
|
|
192
|
+
type: 'text',
|
|
193
|
+
onFocus: function onFocus() {},
|
|
194
|
+
onBlur: function onBlur() {},
|
|
195
|
+
onChange: function onChange() {},
|
|
196
|
+
onPaste: function onPaste() {},
|
|
197
|
+
onClick: function onClick() {},
|
|
198
|
+
onKeyDown: function onKeyDown() {}
|
|
199
|
+
});
|
|
200
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/inputs/Input.tsx"],"names":["Input","props","evt","onKeyDown","target","tagName","type","key","handleChange","input","bind","setRef","focus","blur","e","disabled","value","onChange","stopPropagation","preventDefault","getElement","getNormalizeValue","name","nativeEvent","node","autoFocus","className","id","inputRef","label","onBlur","onClick","onFocus","onPaste","placeholder","readonly","style","restProps","handleKeyDown","React","Component","checked","tabIndex"],"mappings":"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","sourcesContent":["import React, { ChangeEvent, KeyboardEvent, LegacyRef } from 'react'\nimport classNames from 'classnames'\nimport isObject from 'lodash/isObject'\nimport isArray from 'lodash/isArray'\nimport omit from 'lodash/omit'\nimport isString from 'lodash/isString'\n\nimport { TBaseInputProps, TBaseProps } from '../types'\n\n/**\n * Контрол Input\n * @reactProps {boolean} length - максимальная длина значения\n * @reactProps {string} value - значение поля\n * @reactProps {string} placeholder - плэйсхолдер\n * @reactProps {boolean} disabled - флаг неактивности поля\n * @reactProps {boolean} disabled - флаг только для чтения\n * @reactProps {boolean} autoFocus - автофокус\n * @reactProps {function} onFocus - callback на фокус\n * @reactProps {function} onClick - callback на клик\n * @reactProps {function} onPaste - callback при вставке в инпут\n * @reactProps {function} onBlur - callback при блюре инпута\n * @reactProps {function} onChange - callback при изменение инпута\n * @reactProps {function} onKeyDown - callback при нажатии на кнопку клавиатуры\n * @reactProps {boolean} autoFocus - флаг автофокуса\n * @reactProps {string} className - css-класс\n * @reactProps {object} style - объект стилей\n * @reactProps {boolean} disabled - флаг неактивности поля\n * @reactProps {string} type - тип поля\n */\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype Props = TBaseProps & TBaseInputProps<any> & {\n    autoFocus: boolean,\n    checked: boolean,\n    inputRef?: LegacyRef<HTMLInputElement>,\n    label?: string,\n    length?: string,\n    max?: number,\n    min?: number,\n    name: string,\n    onClick(): void,\n    onKeyDown(arg: KeyboardEvent): void,\n    onPaste(): void,\n    placeholder?: string,\n    step?: string | number,\n    tabIndex: number,\n    type: string\n}\n\nexport class Input extends React.Component<Props> {\n    input: HTMLInputElement | null\n\n    constructor(props: Props) {\n        super(props)\n        this.input = null\n        this.handleChange = this.handleChange.bind(this)\n        this.setRef = this.setRef.bind(this)\n    }\n\n    focus() {\n        this.input?.focus()\n    }\n\n    blur() {\n        this.input?.blur()\n    }\n\n    handleChange(e: ChangeEvent<HTMLInputElement>) {\n        const { props, input } = this\n\n        if (props.disabled) {\n            return\n        }\n        const value = isObject(props.value) || isArray(props.value)\n            ? props.value\n            : (e.target as HTMLInputElement).value\n\n        if (props.onChange) {\n            props.onChange({\n                target: {\n                    ...props,\n                    value,\n                },\n                stopPropagation() {\n                    e.stopPropagation()\n                },\n                preventDefault() {\n                    e.preventDefault()\n                },\n                getElement() {\n                    return input\n                },\n                getNormalizeValue() {\n                    return { [props.name]: props.value }\n                },\n                nativeEvent: e,\n            })\n        }\n    }\n\n    setRef(node: HTMLInputElement) {\n        this.input = node\n    }\n\n    handleKeyDown = (evt: KeyboardEvent<HTMLInputElement>) => {\n        const { onKeyDown } = this.props\n\n        if (onKeyDown) {\n            onKeyDown(evt)\n        }\n\n        if ((evt.target as HTMLInputElement).tagName === 'INPUT' && (evt.target as HTMLInputElement).type === 'checkbox' && evt.key === 'Enter') {\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            this.handleChange(evt as any)\n        }\n    }\n\n    render() {\n        const {\n            autoFocus,\n            className,\n            disabled,\n            id,\n            inputRef,\n            label,\n            name,\n            onBlur,\n            onClick,\n            onFocus,\n            onPaste,\n            placeholder,\n            readonly,\n            style,\n            type,\n            value,\n            ...restProps\n        } = this.props\n\n        return (\n            <input\n                ref={inputRef}\n                className={classNames('n2o-input', className)}\n                style={style}\n                id={id}\n                name={name}\n                type={type}\n                disabled={disabled}\n                /* eslint-disable-next-line jsx-a11y/no-autofocus */\n                autoFocus={autoFocus}\n                value={value}\n                onPaste={onPaste}\n                // eslint-disable-next-line @typescript-eslint/no-explicit-any\n                onFocus={onFocus as any}\n                // eslint-disable-next-line @typescript-eslint/no-explicit-any\n                onBlur={onBlur as any}\n                onClick={onClick}\n                onKeyDown={this.handleKeyDown}\n                placeholder={placeholder}\n                readOnly={readonly}\n                {...omit(restProps, ['length', 'onChange', 'onKeyDown'])}\n                onChange={this.handleChange}\n                title={isString(value) ? value : label}\n            />\n        )\n    }\n\n    static defaultProps = {\n        id: '',\n        value: null,\n        name: '',\n        disabled: false,\n        autoFocus: false,\n        checked: false,\n        className: '',\n        tabIndex: 0,\n        style: {},\n        type: 'text',\n        onFocus: () => {},\n        onBlur: () => {},\n        onChange: () => {},\n        onPaste: () => {},\n        onClick: () => {},\n        onKeyDown: () => {},\n    } as Props\n}\n"]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { TBaseInputProps, TBaseProps } from '../../types';
|
|
3
|
+
export declare type PresetType = 'phone' | 'post-code' | 'date' | 'money' | 'percentage' | 'card';
|
|
4
|
+
declare type MaskType = string | Array<string | RegExp> | ((val?: unknown) => Array<string | RegExp>);
|
|
5
|
+
export declare const InputMask: {
|
|
6
|
+
({ measure, ...props }: TBaseProps & Omit<TBaseInputProps<string>, "onBlur"> & {
|
|
7
|
+
clearOnBlur?: boolean | undefined;
|
|
8
|
+
dictionary?: Record<string, RegExp> | undefined;
|
|
9
|
+
guide?: boolean | undefined;
|
|
10
|
+
keepCharPositions?: boolean | undefined;
|
|
11
|
+
mask?: MaskType | undefined;
|
|
12
|
+
onBlur?(value: string): void;
|
|
13
|
+
onChange?(value: string): void;
|
|
14
|
+
placeholder?: string | undefined;
|
|
15
|
+
placeholderChar?: string | undefined;
|
|
16
|
+
preset?: PresetType | undefined;
|
|
17
|
+
presetConfig?: Record<string, unknown> | undefined;
|
|
18
|
+
} & {
|
|
19
|
+
measure?: string | undefined;
|
|
20
|
+
}): JSX.Element;
|
|
21
|
+
displayName: string;
|
|
22
|
+
};
|
|
23
|
+
export {};
|
|
@@ -0,0 +1,310 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.InputMask = void 0;
|
|
9
|
+
|
|
10
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
11
|
+
|
|
12
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
13
|
+
|
|
14
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
15
|
+
|
|
16
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
17
|
+
|
|
18
|
+
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
19
|
+
|
|
20
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
21
|
+
|
|
22
|
+
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
23
|
+
|
|
24
|
+
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
25
|
+
|
|
26
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
27
|
+
|
|
28
|
+
var _react = _interopRequireDefault(require("react"));
|
|
29
|
+
|
|
30
|
+
var _reactTextMask = _interopRequireDefault(require("react-text-mask"));
|
|
31
|
+
|
|
32
|
+
var _classnames = _interopRequireDefault(require("classnames"));
|
|
33
|
+
|
|
34
|
+
var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
|
|
35
|
+
|
|
36
|
+
var _createNumberMask = _interopRequireDefault(require("text-mask-addons/dist/createNumberMask"));
|
|
37
|
+
|
|
38
|
+
var _lodash = require("lodash");
|
|
39
|
+
|
|
40
|
+
var _withRightPlaceholder = require("../../helpers/withRightPlaceholder");
|
|
41
|
+
|
|
42
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
43
|
+
|
|
44
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
45
|
+
|
|
46
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
|
|
47
|
+
|
|
48
|
+
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
49
|
+
|
|
50
|
+
var InputMaskComponent = /*#__PURE__*/function (_React$Component) {
|
|
51
|
+
(0, _inherits2["default"])(InputMaskComponent, _React$Component);
|
|
52
|
+
|
|
53
|
+
var _super = _createSuper(InputMaskComponent);
|
|
54
|
+
|
|
55
|
+
function InputMaskComponent(props) {
|
|
56
|
+
var _this;
|
|
57
|
+
|
|
58
|
+
(0, _classCallCheck2["default"])(this, InputMaskComponent);
|
|
59
|
+
_this = _super.call(this, props);
|
|
60
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "mask", function () {
|
|
61
|
+
var mask = _this.props.mask;
|
|
62
|
+
|
|
63
|
+
if ((0, _lodash.isArray)(mask)) {
|
|
64
|
+
return mask;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
if ((0, _lodash.isFunction)(mask)) {
|
|
68
|
+
return mask();
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
return _this.mapToArray(mask);
|
|
72
|
+
});
|
|
73
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "preset", function (preset) {
|
|
74
|
+
var _this$props$presetCon = _this.props.presetConfig,
|
|
75
|
+
presetConfig = _this$props$presetCon === void 0 ? {} : _this$props$presetCon;
|
|
76
|
+
|
|
77
|
+
switch (preset) {
|
|
78
|
+
case 'phone':
|
|
79
|
+
return _this.mapToArray('+9 (999)-999-99-99');
|
|
80
|
+
|
|
81
|
+
case 'post-code':
|
|
82
|
+
return _this.mapToArray('999999');
|
|
83
|
+
|
|
84
|
+
case 'date':
|
|
85
|
+
return _this.mapToArray('99.99.9999');
|
|
86
|
+
|
|
87
|
+
case 'money':
|
|
88
|
+
return (0, _createNumberMask["default"])(presetConfig);
|
|
89
|
+
|
|
90
|
+
case 'percentage':
|
|
91
|
+
return (0, _createNumberMask["default"])({
|
|
92
|
+
prefix: '',
|
|
93
|
+
suffix: '%'
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
case 'card':
|
|
97
|
+
return _this.mapToArray('9999 9999 9999 9999');
|
|
98
|
+
|
|
99
|
+
default:
|
|
100
|
+
return undefined;
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "indexOfFirstPlaceHolder", function () {
|
|
104
|
+
var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
|
|
105
|
+
var placeholderChar = _this.props.placeholderChar;
|
|
106
|
+
|
|
107
|
+
if (!placeholderChar) {
|
|
108
|
+
return null;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
return value.toString().indexOf(placeholderChar);
|
|
112
|
+
});
|
|
113
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "indexOfLastPlaceholder", function (mask) {
|
|
114
|
+
if (typeof mask === 'function') {
|
|
115
|
+
return mask().map(function (item) {
|
|
116
|
+
return item instanceof RegExp;
|
|
117
|
+
}).lastIndexOf(true);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
if (typeof mask === 'string') {
|
|
121
|
+
return Math.max.apply(Math, (0, _toConsumableArray2["default"])(Object.keys(_this.dict).map(function (_char) {
|
|
122
|
+
return mask.lastIndexOf(_char);
|
|
123
|
+
})));
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
if ((0, _lodash.isArray)(mask)) {
|
|
127
|
+
return mask.map(function (item) {
|
|
128
|
+
return item instanceof RegExp;
|
|
129
|
+
}).lastIndexOf(true);
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
return -1;
|
|
133
|
+
});
|
|
134
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "isValid", function (value) {
|
|
135
|
+
var _this$props = _this.props,
|
|
136
|
+
preset = _this$props.preset,
|
|
137
|
+
mask = _this$props.mask,
|
|
138
|
+
_this$props$guide = _this$props.guide,
|
|
139
|
+
guide = _this$props$guide === void 0 ? true : _this$props$guide;
|
|
140
|
+
|
|
141
|
+
if (guide) {
|
|
142
|
+
return value && _this.indexOfFirstPlaceHolder(value) === -1;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
if (preset) {
|
|
146
|
+
return value.length > _this.indexOfLastPlaceholder(_this.preset(preset) || mask);
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
return false;
|
|
150
|
+
});
|
|
151
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "mapToArray", function () {
|
|
152
|
+
var mask = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
|
|
153
|
+
return mask.split('').map(function (_char2) {
|
|
154
|
+
return _this.dict[_char2] ? _this.dict[_char2] : _char2;
|
|
155
|
+
});
|
|
156
|
+
});
|
|
157
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onChange", function (e) {
|
|
158
|
+
var _ref = e.target,
|
|
159
|
+
value = _ref.value;
|
|
160
|
+
var _this$props2 = _this.props,
|
|
161
|
+
_this$props2$guide = _this$props2.guide,
|
|
162
|
+
guide = _this$props2$guide === void 0 ? true : _this$props2$guide,
|
|
163
|
+
_this$props2$onChange = _this$props2.onChange,
|
|
164
|
+
onChange = _this$props2$onChange === void 0 ? function () {} : _this$props2$onChange;
|
|
165
|
+
_this.valid = _this.isValid(value);
|
|
166
|
+
|
|
167
|
+
_this.setState({
|
|
168
|
+
value: value,
|
|
169
|
+
guide: guide
|
|
170
|
+
}, function () {
|
|
171
|
+
if (_this.valid || value === '') {
|
|
172
|
+
onChange(value);
|
|
173
|
+
}
|
|
174
|
+
});
|
|
175
|
+
});
|
|
176
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onBlur", function (e) {
|
|
177
|
+
var _ref2 = e.nativeEvent.target,
|
|
178
|
+
value = _ref2.value;
|
|
179
|
+
var _this$props3 = _this.props,
|
|
180
|
+
_this$props3$onBlur = _this$props3.onBlur,
|
|
181
|
+
onBlur = _this$props3$onBlur === void 0 ? function () {} : _this$props3$onBlur,
|
|
182
|
+
clearOnBlur = _this$props3.clearOnBlur,
|
|
183
|
+
_this$props3$onChange = _this$props3.onChange,
|
|
184
|
+
onChange = _this$props3$onChange === void 0 ? function () {} : _this$props3$onChange;
|
|
185
|
+
_this.valid = _this.isValid(value);
|
|
186
|
+
onBlur(value);
|
|
187
|
+
|
|
188
|
+
if (!_this.valid) {
|
|
189
|
+
var newValue = clearOnBlur ? '' : value;
|
|
190
|
+
|
|
191
|
+
_this.setState({
|
|
192
|
+
value: newValue,
|
|
193
|
+
guide: false
|
|
194
|
+
}, function () {
|
|
195
|
+
return newValue === '' && onChange(newValue);
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
});
|
|
199
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onFocus", function () {
|
|
200
|
+
var _this$props$guide2 = _this.props.guide,
|
|
201
|
+
guide = _this$props$guide2 === void 0 ? true : _this$props$guide2;
|
|
202
|
+
var value = _this.state.value;
|
|
203
|
+
_this.valid = _this.isValid(value);
|
|
204
|
+
|
|
205
|
+
if (!_this.valid) {
|
|
206
|
+
_this.setState({
|
|
207
|
+
guide: guide
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
});
|
|
211
|
+
_this.state = {
|
|
212
|
+
value: props.value || '',
|
|
213
|
+
guide: false
|
|
214
|
+
};
|
|
215
|
+
_this.valid = false;
|
|
216
|
+
_this.dict = _objectSpread({
|
|
217
|
+
9: /\d/,
|
|
218
|
+
S: /[A-Za-z]/,
|
|
219
|
+
Б: /[А-я]/
|
|
220
|
+
}, props.dictionary);
|
|
221
|
+
return _this;
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* преобразует маску-функцию, маску-строку в массив-маску (с regexp вместо символов) при помощи _mapToArray
|
|
225
|
+
*/
|
|
226
|
+
|
|
227
|
+
|
|
228
|
+
(0, _createClass2["default"])(InputMaskComponent, [{
|
|
229
|
+
key: "componentDidUpdate",
|
|
230
|
+
value: function componentDidUpdate(prevProps) {
|
|
231
|
+
var valueFromState = this.state.value;
|
|
232
|
+
var _this$props4 = this.props,
|
|
233
|
+
_this$props4$value = _this$props4.value,
|
|
234
|
+
valueFromProps = _this$props4$value === void 0 ? '' : _this$props4$value,
|
|
235
|
+
_this$props4$dictiona = _this$props4.dictionary,
|
|
236
|
+
dictionary = _this$props4$dictiona === void 0 ? {} : _this$props4$dictiona;
|
|
237
|
+
|
|
238
|
+
if (!(0, _isEqual["default"])(prevProps.value, valueFromProps) && !(0, _isEqual["default"])(valueFromProps, valueFromState)) {
|
|
239
|
+
this.setState({
|
|
240
|
+
value: this.isValid(valueFromProps) ? valueFromProps : ''
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
this.dict = _objectSpread(_objectSpread({}, this.dict), dictionary);
|
|
245
|
+
this.valid = this.isValid(valueFromState);
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* базовый рендер компонента
|
|
249
|
+
*/
|
|
250
|
+
|
|
251
|
+
}, {
|
|
252
|
+
key: "render",
|
|
253
|
+
value: function render() {
|
|
254
|
+
var _this$props5 = this.props,
|
|
255
|
+
preset = _this$props5.preset,
|
|
256
|
+
_this$props5$placehol = _this$props5.placeholderChar,
|
|
257
|
+
placeholderChar = _this$props5$placehol === void 0 ? '_' : _this$props5$placehol,
|
|
258
|
+
placeholder = _this$props5.placeholder,
|
|
259
|
+
className = _this$props5.className,
|
|
260
|
+
autoFocus = _this$props5.autoFocus,
|
|
261
|
+
disabled = _this$props5.disabled,
|
|
262
|
+
keepCharPositions = _this$props5.keepCharPositions;
|
|
263
|
+
var _this$state = this.state,
|
|
264
|
+
guide = _this$state.guide,
|
|
265
|
+
value = _this$state.value;
|
|
266
|
+
var mask = this.preset(preset);
|
|
267
|
+
return /*#__PURE__*/_react["default"].createElement(_reactTextMask["default"], {
|
|
268
|
+
disabled: disabled,
|
|
269
|
+
className: (0, _classnames["default"])(['form-control', 'n2o-input-mask', className]),
|
|
270
|
+
placeholderChar: placeholderChar,
|
|
271
|
+
placeholder: placeholder,
|
|
272
|
+
guide: guide,
|
|
273
|
+
mask: mask || this.mask,
|
|
274
|
+
value: value,
|
|
275
|
+
onBlur: this.onBlur,
|
|
276
|
+
onChange: this.onChange,
|
|
277
|
+
onFocus: this.onFocus,
|
|
278
|
+
keepCharPositions: keepCharPositions,
|
|
279
|
+
render: function render(_ref3, props) {
|
|
280
|
+
return /*#__PURE__*/_react["default"].createElement("input", (0, _extends2["default"])({
|
|
281
|
+
ref: function ref(input) {
|
|
282
|
+
return _ref3(input);
|
|
283
|
+
}
|
|
284
|
+
}, props, {
|
|
285
|
+
/* eslint-disable-next-line jsx-a11y/no-autofocus */
|
|
286
|
+
autoFocus: autoFocus
|
|
287
|
+
}));
|
|
288
|
+
}
|
|
289
|
+
});
|
|
290
|
+
}
|
|
291
|
+
}]);
|
|
292
|
+
return InputMaskComponent;
|
|
293
|
+
}(_react["default"].Component);
|
|
294
|
+
|
|
295
|
+
(0, _defineProperty2["default"])(InputMaskComponent, "defaultProps", {
|
|
296
|
+
onChange: function onChange() {},
|
|
297
|
+
placeholderChar: '_',
|
|
298
|
+
guide: true,
|
|
299
|
+
keepCharPositions: false,
|
|
300
|
+
clearOnBlur: false,
|
|
301
|
+
value: '',
|
|
302
|
+
dictionary: {},
|
|
303
|
+
mask: '',
|
|
304
|
+
presetConfig: {},
|
|
305
|
+
onBlur: function onBlur() {},
|
|
306
|
+
disabled: false
|
|
307
|
+
});
|
|
308
|
+
var InputMask = (0, _withRightPlaceholder.withRightPlaceholder)(InputMaskComponent);
|
|
309
|
+
exports.InputMask = InputMask;
|
|
310
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/inputs/InputMask/InputMask.tsx"],"names":["InputMaskComponent","props","mask","mapToArray","preset","presetConfig","prefix","suffix","undefined","value","placeholderChar","toString","indexOf","map","item","RegExp","lastIndexOf","Math","max","Object","keys","dict","char","guide","indexOfFirstPlaceHolder","length","indexOfLastPlaceholder","split","e","target","onChange","valid","isValid","setState","nativeEvent","onBlur","clearOnBlur","newValue","state","S","Б","dictionary","prevProps","valueFromState","valueFromProps","placeholder","className","autoFocus","disabled","keepCharPositions","onFocus","ref","input","React","Component","InputMask"],"mappings":"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","sourcesContent":["import React, { SyntheticEvent, ChangeEventHandler } from 'react'\nimport MaskedInput from 'react-text-mask'\nimport cn from 'classnames'\nimport isEqual from 'lodash/isEqual'\nimport createNumberMask from 'text-mask-addons/dist/createNumberMask'\nimport { isArray, isFunction } from 'lodash'\n\nimport { withRightPlaceholder } from '../../helpers/withRightPlaceholder'\nimport { TBaseInputProps, TBaseProps } from '../../types'\n\nexport type PresetType = 'phone' | 'post-code' | 'date' | 'money' | 'percentage' | 'card'\ntype MaskType = string | Array<string | RegExp> | ((val?: unknown) => Array<string | RegExp>)\ntype InputMaskProps = TBaseProps & Omit<TBaseInputProps<string>, 'onBlur'> & {\n    clearOnBlur?: boolean,\n    dictionary?: Record<string, RegExp>,\n    // https://github.com/text-mask/text-mask/blob/master/componentDocumentation.md#guide\n    guide?: boolean,\n    // https://github.com/text-mask/text-mask/blob/master/componentDocumentation.md#keepcharpositions\n    keepCharPositions?: boolean,\n    // Стандартная конфигурация: 9 - цифра, S - английская буква, Б - русская буква. Дополнительную конфигурацию можно осуществить, используя dictionary\n    mask?: MaskType\n    onBlur?(value: string): void,\n    onChange?(value: string): void,\n    placeholder?: string,\n    // символ, который будет на месте незаполненного символа маски\n    placeholderChar?: string,\n    preset?: PresetType,\n    // настройки пресета для InputMoney\n    presetConfig?: Record<string, unknown>,\n}\n\ntype InputMaskState = {\n    guide: boolean,\n    value: string\n}\n\nclass InputMaskComponent extends React.Component<InputMaskProps, InputMaskState> {\n    valid: string | boolean\n\n    dict: Record<string | number, RegExp>\n\n    constructor(props: InputMaskProps) {\n        super(props)\n        this.state = {\n            value: props.value || '',\n            guide: false,\n        }\n        this.valid = false\n        this.dict = {\n            9: /\\d/,\n            S: /[A-Za-z]/,\n            Б: /[А-я]/,\n            ...props.dictionary,\n        }\n    }\n\n    /**\n     * преобразует маску-функцию, маску-строку в массив-маску (с regexp вместо символов) при помощи _mapToArray\n     */\n    mask = () => {\n        const { mask } = this.props\n\n        if (isArray(mask)) {\n            return mask\n        }\n\n        if (isFunction(mask)) {\n            return mask()\n        }\n\n        return this.mapToArray(mask)\n    }\n\n    /**\n     * возвращает маску для пресета\n     * @returns (number) возвращает массив-маску для пресета-аргумента\n     */\n    // eslint-disable-next-line consistent-return\n    preset = (preset?: PresetType) => {\n        const { presetConfig = {} } = this.props\n\n        switch (preset) {\n            case 'phone':\n                return this.mapToArray('+9 (999)-999-99-99')\n            case 'post-code':\n                return this.mapToArray('999999')\n            case 'date':\n                return this.mapToArray('99.99.9999')\n            case 'money':\n                return createNumberMask(presetConfig)\n            case 'percentage':\n                return createNumberMask({ prefix: '', suffix: '%' })\n            case 'card':\n                return this.mapToArray('9999 9999 9999 9999')\n            default:\n                return undefined\n        }\n    }\n\n    /**\n     * возвращает индекс первого символа маски, который еще не заполнен\n     * @returns (number) индекс первого символа маски, который еще не заполнен\n     */\n    indexOfFirstPlaceHolder = (value = '') => {\n        const { placeholderChar } = this.props\n\n        if (!placeholderChar) {\n            return null\n        }\n\n        return value.toString().indexOf(placeholderChar)\n    }\n\n    /**\n     * возвращает индекс последнего символа маски, который еще не заполнен\n     * @returns (number) индекс последнего символа маски, который еще не заполнен\n     */\n    indexOfLastPlaceholder = (mask: MaskType) => {\n        if (typeof mask === 'function') {\n            return mask()\n                .map(item => item instanceof RegExp)\n                .lastIndexOf(true)\n        }\n\n        if (typeof mask === 'string') {\n            return Math.max(\n                ...Object.keys(this.dict).map(char => mask.lastIndexOf(char)),\n            )\n        }\n\n        if (isArray(mask)) {\n            return mask.map(item => item instanceof RegExp).lastIndexOf(true)\n        }\n\n        return -1\n    }\n\n    isValid = (value: string) => {\n        const { preset, mask, guide = true } = this.props\n\n        if (guide) {\n            return value && this.indexOfFirstPlaceHolder(value) === -1\n        }\n\n        if (preset) {\n            return (\n                value.length > this.indexOfLastPlaceholder(this.preset(preset) || mask)\n            )\n        }\n\n        return false\n    }\n\n    /**\n     * преобразование строки маски в массив (уже с регулярными выражениями)\n     */\n    mapToArray = (mask = '') => mask.split('').map(char => (this.dict[char] ? this.dict[char] : char))\n\n    onChange: ChangeEventHandler = (e) => {\n        const { value } = e.target as HTMLInputElement\n        const { guide = true, onChange = () => {} } = this.props\n\n        this.valid = this.isValid(value)\n\n        this.setState({ value, guide }, () => {\n            if (this.valid || value === '') {\n                onChange(value)\n            }\n        })\n    }\n\n    onBlur = (e: SyntheticEvent) => {\n        const { value } = e.nativeEvent.target as HTMLInputElement\n        const { onBlur = () => {}, clearOnBlur, onChange = () => {} } = this.props\n\n        this.valid = this.isValid(value)\n        onBlur(value)\n        if (!this.valid) {\n            const newValue = clearOnBlur ? '' : value\n\n            this.setState(\n                { value: newValue, guide: false },\n                () => newValue === '' && onChange(newValue),\n            )\n        }\n    }\n\n    onFocus = () => {\n        const { guide = true } = this.props\n        const { value } = this.state\n\n        this.valid = this.isValid(value)\n        if (!this.valid) {\n            this.setState({ guide })\n        }\n    }\n\n    componentDidUpdate(prevProps: InputMaskProps) {\n        const { value: valueFromState } = this.state\n        const { value: valueFromProps = '', dictionary = {} } = this.props\n\n        if (\n            !isEqual(prevProps.value, valueFromProps) &&\n            !isEqual(valueFromProps, valueFromState)\n        ) {\n            this.setState({\n                value: this.isValid(valueFromProps) ? valueFromProps : '',\n            })\n        }\n\n        this.dict = { ...this.dict, ...dictionary }\n        this.valid = this.isValid(valueFromState)\n    }\n\n    /**\n     * базовый рендер компонента\n     */\n    render() {\n        const {\n            preset,\n            placeholderChar = '_',\n            placeholder,\n            className,\n            autoFocus,\n            disabled,\n            keepCharPositions,\n        } = this.props\n        const { guide, value } = this.state\n        const mask = this.preset(preset)\n\n        return (\n            <MaskedInput\n                disabled={disabled}\n                className={cn([\n                    'form-control',\n                    'n2o-input-mask',\n                    className,\n                ])}\n                placeholderChar={placeholderChar}\n                placeholder={placeholder}\n                guide={guide}\n                mask={mask || this.mask}\n                value={value}\n                onBlur={this.onBlur}\n                onChange={this.onChange}\n                onFocus={this.onFocus}\n                keepCharPositions={keepCharPositions}\n                render={(ref, props) => (\n                    <input\n                        ref={(input: HTMLInputElement) => ref(input)}\n                        {...props}\n                        /* eslint-disable-next-line jsx-a11y/no-autofocus */\n                        autoFocus={autoFocus}\n                    />\n                )}\n            />\n        )\n    }\n\n    static defaultProps = {\n        onChange: () => {},\n        placeholderChar: '_',\n        guide: true,\n        keepCharPositions: false,\n        clearOnBlur: false,\n        value: '',\n        dictionary: {},\n        mask: '',\n        presetConfig: {},\n        onBlur: () => {},\n        disabled: false,\n    } as InputMaskProps\n}\n\nexport const InputMask = withRightPlaceholder<InputMaskProps>(InputMaskComponent)\n"]}
|