@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.
Files changed (241) hide show
  1. package/index.js +0 -0
  2. package/lib/display/Alerts/Alert.d.ts +2 -0
  3. package/lib/display/Alerts/Alert.js +121 -0
  4. package/lib/display/Alerts/AlertSection.d.ts +18 -0
  5. package/lib/display/Alerts/AlertSection.js +64 -0
  6. package/lib/display/Alerts/AlertWrapper.d.ts +6 -0
  7. package/lib/display/Alerts/AlertWrapper.js +39 -0
  8. package/lib/display/Alerts/DefaultAlert.d.ts +6 -0
  9. package/lib/display/Alerts/DefaultAlert.js +125 -0
  10. package/lib/display/Alerts/LoaderAlert.d.ts +5 -0
  11. package/lib/display/Alerts/LoaderAlert.js +36 -0
  12. package/lib/display/Alerts/types.d.ts +49 -0
  13. package/lib/display/Alerts/types.js +24 -0
  14. package/lib/display/Alerts/utils.d.ts +15 -0
  15. package/lib/display/Alerts/utils.js +102 -0
  16. package/lib/display/Badge/Badge.d.ts +16 -0
  17. package/lib/display/Badge/Badge.js +77 -0
  18. package/lib/display/Badge/enums.d.ts +9 -0
  19. package/lib/display/Badge/enums.js +23 -0
  20. package/lib/display/Badge/utils.d.ts +9 -0
  21. package/lib/display/Badge/utils.js +49 -0
  22. package/lib/display/Block.d.ts +369 -0
  23. package/lib/display/Block.js +38 -0
  24. package/lib/display/CodeViewer/CodeViewer.d.ts +13 -0
  25. package/lib/display/CodeViewer/CodeViewer.js +96 -0
  26. package/lib/display/Drawer/Drawer.d.ts +25 -0
  27. package/lib/display/Drawer/Drawer.js +99 -0
  28. package/lib/display/DropdownCustomItem.d.ts +7 -0
  29. package/lib/display/DropdownCustomItem.js +23 -0
  30. package/lib/display/Filter/Buttons.d.ts +11 -0
  31. package/lib/display/Filter/Buttons.js +42 -0
  32. package/lib/display/Filter/Filter.d.ts +8 -0
  33. package/lib/display/Filter/Filter.js +38 -0
  34. package/lib/display/HelpPopover.d.ts +16 -0
  35. package/lib/display/HelpPopover.js +104 -0
  36. package/lib/display/Html.d.ts +8 -0
  37. package/lib/display/Html.js +29 -0
  38. package/lib/display/Icon/Icon.d.ts +11 -0
  39. package/lib/display/Icon/Icon.js +42 -0
  40. package/lib/display/Image/Image.d.ts +30 -0
  41. package/lib/display/Image/Image.js +93 -0
  42. package/lib/display/Image/ImageInfo.d.ts +7 -0
  43. package/lib/display/Image/ImageInfo.js +23 -0
  44. package/lib/display/InputIcon.d.ts +13 -0
  45. package/lib/display/InputIcon.js +33 -0
  46. package/lib/display/NavItemImage/NavItemImage.d.ts +9 -0
  47. package/lib/display/NavItemImage/NavItemImage.js +35 -0
  48. package/lib/display/OutputList.d.ts +12 -0
  49. package/lib/display/OutputList.js +46 -0
  50. package/lib/display/OutputListItem.d.ts +10 -0
  51. package/lib/display/OutputListItem.js +58 -0
  52. package/lib/display/OutputText.d.ts +15 -0
  53. package/lib/display/OutputText.js +170 -0
  54. package/lib/display/Pagination/Pagination.d.ts +2 -0
  55. package/lib/display/Pagination/Pagination.js +273 -0
  56. package/lib/display/Pagination/PaginationButton.d.ts +13 -0
  57. package/lib/display/Pagination/PaginationButton.js +53 -0
  58. package/lib/display/Pagination/types.d.ts +62 -0
  59. package/lib/display/Pagination/types.js +36 -0
  60. package/lib/display/PopoverConfirm/PopoverConfirm.d.ts +30 -0
  61. package/lib/display/PopoverConfirm/PopoverConfirm.js +87 -0
  62. package/lib/display/ProgressControl/ProgressControl.d.ts +17 -0
  63. package/lib/display/ProgressControl/ProgressControl.js +68 -0
  64. package/lib/display/Slider.d.ts +23 -0
  65. package/lib/display/Slider.js +107 -0
  66. package/lib/display/Status.d.ts +9 -0
  67. package/lib/display/Status.js +40 -0
  68. package/lib/display/StatusText/StatusText.d.ts +10 -0
  69. package/lib/display/StatusText/StatusText.js +35 -0
  70. package/lib/display/StatusText/types.d.ts +18 -0
  71. package/lib/display/StatusText/types.js +19 -0
  72. package/lib/display/StatusText/utils.d.ts +3 -0
  73. package/lib/display/StatusText/utils.js +29 -0
  74. package/lib/display/Text.d.ts +12 -0
  75. package/lib/display/Text.js +38 -0
  76. package/lib/display/Typography/Base.d.ts +32 -0
  77. package/lib/display/Typography/Base.js +259 -0
  78. package/lib/display/Typography/ContentEditable.d.ts +15 -0
  79. package/lib/display/Typography/ContentEditable.js +86 -0
  80. package/lib/display/Typography/Paragraph.d.ts +4 -0
  81. package/lib/display/Typography/Paragraph.js +23 -0
  82. package/lib/display/Typography/Text.d.ts +9 -0
  83. package/lib/display/Typography/Text.js +37 -0
  84. package/lib/display/Typography/Title.d.ts +7 -0
  85. package/lib/display/Typography/Title.js +28 -0
  86. package/lib/display/Typography/utils.d.ts +13 -0
  87. package/lib/display/Typography/utils.js +75 -0
  88. package/lib/helpers/HelpPopover.d.ts +9 -0
  89. package/lib/helpers/HelpPopover.js +46 -0
  90. package/lib/helpers/withRightPlaceholder.d.ts +9 -0
  91. package/lib/helpers/withRightPlaceholder.js +35 -0
  92. package/lib/inputs/Checkbox/Checkbox.d.ts +29 -0
  93. package/lib/inputs/Checkbox/Checkbox.js +117 -0
  94. package/lib/inputs/Checkbox/CheckboxControl.d.ts +7 -0
  95. package/lib/inputs/Checkbox/CheckboxControl.js +33 -0
  96. package/lib/inputs/CheckboxGroup/CheckboxGroup.d.ts +11 -0
  97. package/lib/inputs/CheckboxGroup/CheckboxGroup.js +84 -0
  98. package/lib/inputs/CodeEditor/CodeEditor.d.ts +21 -0
  99. package/lib/inputs/CodeEditor/CodeEditor.js +85 -0
  100. package/lib/inputs/DatePicker/Calendar.d.ts +65 -0
  101. package/lib/inputs/DatePicker/Calendar.js +556 -0
  102. package/lib/inputs/DatePicker/CalendarHeader.d.ts +26 -0
  103. package/lib/inputs/DatePicker/CalendarHeader.js +213 -0
  104. package/lib/inputs/DatePicker/Clock.d.ts +10 -0
  105. package/lib/inputs/DatePicker/Clock.js +45 -0
  106. package/lib/inputs/DatePicker/DateInput.d.ts +44 -0
  107. package/lib/inputs/DatePicker/DateInput.js +262 -0
  108. package/lib/inputs/DatePicker/DateInputGroup.d.ts +20 -0
  109. package/lib/inputs/DatePicker/DateInputGroup.js +77 -0
  110. package/lib/inputs/DatePicker/DateInterval.d.ts +24 -0
  111. package/lib/inputs/DatePicker/DateInterval.js +92 -0
  112. package/lib/inputs/DatePicker/DatePicker.d.ts +22 -0
  113. package/lib/inputs/DatePicker/DatePicker.js +36 -0
  114. package/lib/inputs/DatePicker/DateTimeControl.d.ts +98 -0
  115. package/lib/inputs/DatePicker/DateTimeControl.js +452 -0
  116. package/lib/inputs/DatePicker/Day.d.ts +14 -0
  117. package/lib/inputs/DatePicker/Day.js +50 -0
  118. package/lib/inputs/DatePicker/PopUp.d.ts +19 -0
  119. package/lib/inputs/DatePicker/PopUp.js +71 -0
  120. package/lib/inputs/DatePicker/types.d.ts +31 -0
  121. package/lib/inputs/DatePicker/types.js +25 -0
  122. package/lib/inputs/DatePicker/utils.d.ts +39 -0
  123. package/lib/inputs/DatePicker/utils.js +304 -0
  124. package/lib/inputs/Input.d.ts +51 -0
  125. package/lib/inputs/Input.js +200 -0
  126. package/lib/inputs/InputMask/InputMask.d.ts +23 -0
  127. package/lib/inputs/InputMask/InputMask.js +310 -0
  128. package/lib/inputs/InputMoney/InputMoney.d.ts +101 -0
  129. package/lib/inputs/InputMoney/InputMoney.js +258 -0
  130. package/lib/inputs/InputNumber/InputNumber.d.ts +29 -0
  131. package/lib/inputs/InputNumber/InputNumber.js +316 -0
  132. package/lib/inputs/InputNumber/index.d.ts +1 -0
  133. package/lib/inputs/InputNumber/index.js +14 -0
  134. package/lib/inputs/InputNumber/types.d.ts +18 -0
  135. package/lib/inputs/InputNumber/types.js +14 -0
  136. package/lib/inputs/InputNumber/utils.d.ts +6 -0
  137. package/lib/inputs/InputNumber/utils.js +86 -0
  138. package/lib/inputs/InputPassword/InputPassword.d.ts +10 -0
  139. package/lib/inputs/InputPassword/InputPassword.js +81 -0
  140. package/lib/inputs/InputSelect/InputAddon.d.ts +17 -0
  141. package/lib/inputs/InputSelect/InputAddon.js +31 -0
  142. package/lib/inputs/InputSelect/InputContent.d.ts +63 -0
  143. package/lib/inputs/InputSelect/InputContent.js +188 -0
  144. package/lib/inputs/InputSelect/InputSelect.d.ts +296 -0
  145. package/lib/inputs/InputSelect/InputSelect.js +795 -0
  146. package/lib/inputs/InputSelect/InputSelectGroup.d.ts +43 -0
  147. package/lib/inputs/InputSelect/InputSelectGroup.js +113 -0
  148. package/lib/inputs/InputSelect/PopupItems.d.ts +55 -0
  149. package/lib/inputs/InputSelect/PopupItems.js +357 -0
  150. package/lib/inputs/InputSelect/PopupList.d.ts +82 -0
  151. package/lib/inputs/InputSelect/PopupList.js +138 -0
  152. package/lib/inputs/InputSelect/SelectedItems.d.ts +17 -0
  153. package/lib/inputs/InputSelect/SelectedItems.js +125 -0
  154. package/lib/inputs/InputSelect/constants.d.ts +4 -0
  155. package/lib/inputs/InputSelect/constants.js +15 -0
  156. package/lib/inputs/InputSelect/types.d.ts +16 -0
  157. package/lib/inputs/InputSelect/types.js +16 -0
  158. package/lib/inputs/InputSelect/utils.d.ts +9 -0
  159. package/lib/inputs/InputSelect/utils.js +142 -0
  160. package/lib/inputs/InputSelectTree/InputSelectTree.d.ts +114 -0
  161. package/lib/inputs/InputSelectTree/InputSelectTree.js +466 -0
  162. package/lib/inputs/InputSelectTree/TreeSelectNode.d.ts +36 -0
  163. package/lib/inputs/InputSelectTree/TreeSelectNode.js +63 -0
  164. package/lib/inputs/InputSelectTree/allProps.d.ts +123 -0
  165. package/lib/inputs/InputSelectTree/allProps.js +48 -0
  166. package/lib/inputs/InputSelectTree/until.d.ts +4 -0
  167. package/lib/inputs/InputSelectTree/until.js +83 -0
  168. package/lib/inputs/InputText.d.ts +41 -0
  169. package/lib/inputs/InputText.js +170 -0
  170. package/lib/inputs/NumberPicker/NumberPicker.d.ts +15 -0
  171. package/lib/inputs/NumberPicker/NumberPicker.js +129 -0
  172. package/lib/inputs/NumberPicker/NumberPickerButton.d.ts +8 -0
  173. package/lib/inputs/NumberPicker/NumberPickerButton.js +64 -0
  174. package/lib/inputs/NumberPicker/index.d.ts +1 -0
  175. package/lib/inputs/NumberPicker/index.js +14 -0
  176. package/lib/inputs/NumberPicker/utils.d.ts +2 -0
  177. package/lib/inputs/NumberPicker/utils.js +31 -0
  178. package/lib/inputs/RadioGroup/default/Group.d.ts +15 -0
  179. package/lib/inputs/RadioGroup/default/Group.js +63 -0
  180. package/lib/inputs/RadioGroup/default/Input.d.ts +17 -0
  181. package/lib/inputs/RadioGroup/default/Input.js +77 -0
  182. package/lib/inputs/RadioGroup/tabs/Group.d.ts +3 -0
  183. package/lib/inputs/RadioGroup/tabs/Group.js +24 -0
  184. package/lib/inputs/RadioGroup/tabs/Input.d.ts +3 -0
  185. package/lib/inputs/RadioGroup/tabs/Input.js +21 -0
  186. package/lib/inputs/Rating/Rating.d.ts +30 -0
  187. package/lib/inputs/Rating/Rating.js +212 -0
  188. package/lib/inputs/Select/Popup.d.ts +31 -0
  189. package/lib/inputs/Select/Popup.js +131 -0
  190. package/lib/inputs/Select/Select.d.ts +225 -0
  191. package/lib/inputs/Select/Select.js +705 -0
  192. package/lib/inputs/Select/SelectInput.d.ts +19 -0
  193. package/lib/inputs/Select/SelectInput.js +85 -0
  194. package/lib/inputs/Select/utils.d.ts +1 -0
  195. package/lib/inputs/Select/utils.js +28 -0
  196. package/lib/inputs/Switch/Switch.d.ts +11 -0
  197. package/lib/inputs/Switch/Switch.js +41 -0
  198. package/lib/inputs/TextArea.d.ts +12 -0
  199. package/lib/inputs/TextArea.js +54 -0
  200. package/lib/inputs/TextEditor/TextEditor.d.ts +11 -0
  201. package/lib/inputs/TextEditor/TextEditor.js +89 -0
  202. package/lib/inputs/TimePicker/TimePicker.d.ts +50 -0
  203. package/lib/inputs/TimePicker/TimePicker.js +398 -0
  204. package/lib/inputs/utils.d.ts +5 -0
  205. package/lib/inputs/utils.js +39 -0
  206. package/lib/layouts/ScrollContainer.d.ts +218 -0
  207. package/lib/layouts/ScrollContainer.js +128 -0
  208. package/lib/layouts/Spinner/CoverSpinner.d.ts +29 -0
  209. package/lib/layouts/Spinner/CoverSpinner.js +153 -0
  210. package/lib/layouts/Spinner/InlineSpinner.d.ts +5 -0
  211. package/lib/layouts/Spinner/InlineSpinner.js +27 -0
  212. package/lib/layouts/Spinner/Spinner.d.ts +31 -0
  213. package/lib/layouts/Spinner/Spinner.js +178 -0
  214. package/lib/styles/components/Calendar.scss +125 -0
  215. package/lib/styles/components/CalendarHeader.scss +75 -0
  216. package/lib/styles/components/DateInputGroup.scss +39 -0
  217. package/lib/styles/components/DatePicker.scss +18 -0
  218. package/lib/styles/components/Day.scss +29 -0
  219. package/lib/styles/components/OutputList.scss +14 -0
  220. package/lib/styles/components/OutputText.scss +50 -0
  221. package/lib/styles/controls/CodeEditor.scss +4 -0
  222. package/lib/styles/controls/InputNumber.scss +36 -0
  223. package/lib/styles/controls/InputPassword.scss +17 -0
  224. package/lib/styles/controls/InputText.scss +59 -0
  225. package/lib/styles/controls/NumberPicker.scss +36 -0
  226. package/lib/styles/controls/ProgressControl.scss +3 -0
  227. package/lib/styles/controls/Slider.scss +32 -0
  228. package/lib/styles/controls/Switch.scss +105 -0
  229. package/lib/styles/controls/TextEditor.scss +23 -0
  230. package/lib/styles/controls/TimePicker.scss +32 -0
  231. package/lib/styles/n2o/variables.scss +328 -0
  232. package/lib/styles/theme/variables.scss +81 -0
  233. package/lib/styles/variables.scss +10 -0
  234. package/lib/types.d.ts +25 -0
  235. package/lib/types.js +6 -0
  236. package/lib/utils/id.d.ts +3 -0
  237. package/lib/utils/id.js +46 -0
  238. package/lib/utils/isEmptyModel.d.ts +1 -0
  239. package/lib/utils/isEmptyModel.js +21 -0
  240. package/lib/utils/parseFormatter.js +153 -0
  241. 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"]}