@salutejs/plasma-new-hope 0.145.0-canary.1418.10848257808.0 → 0.145.0-canary.1433.10846476158.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (80) hide show
  1. package/cjs/components/TextField/TextField.js +5 -3
  2. package/cjs/components/TextField/TextField.js.map +1 -1
  3. package/emotion/cjs/components/TextField/TextField.js +6 -4
  4. package/emotion/es/components/TextField/TextField.js +6 -4
  5. package/es/components/TextField/TextField.js +5 -3
  6. package/es/components/TextField/TextField.js.map +1 -1
  7. package/package.json +2 -2
  8. package/styled-components/cjs/components/TextField/TextField.js +5 -3
  9. package/styled-components/es/components/TextField/TextField.js +5 -3
  10. package/types/components/TextField/TextField.d.ts.map +1 -1
  11. package/emotion/cjs/components/Mask/Mask.js +0 -213
  12. package/emotion/cjs/components/Mask/Mask.types.js +0 -5
  13. package/emotion/cjs/components/Mask/index.js +0 -12
  14. package/emotion/cjs/components/Mask/utils/constants.js +0 -29
  15. package/emotion/cjs/components/Mask/utils/createMask.js +0 -50
  16. package/emotion/cjs/components/Mask/utils/mask.js +0 -241
  17. package/emotion/cjs/components/Mask/utils/parseMask.js +0 -36
  18. package/emotion/cjs/components/Mask/utils/processInput.js +0 -52
  19. package/emotion/cjs/components/Mask/utils/processMask.js +0 -99
  20. package/emotion/cjs/components/Mask/utils/selection.js +0 -48
  21. package/emotion/cjs/examples/plasma_b2c/components/Mask/Mask.js +0 -9
  22. package/emotion/cjs/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -125
  23. package/emotion/es/components/Mask/Mask.js +0 -205
  24. package/emotion/es/components/Mask/Mask.types.js +0 -1
  25. package/emotion/es/components/Mask/index.js +0 -1
  26. package/emotion/es/components/Mask/utils/constants.js +0 -23
  27. package/emotion/es/components/Mask/utils/createMask.js +0 -44
  28. package/emotion/es/components/Mask/utils/mask.js +0 -235
  29. package/emotion/es/components/Mask/utils/parseMask.js +0 -30
  30. package/emotion/es/components/Mask/utils/processInput.js +0 -46
  31. package/emotion/es/components/Mask/utils/processMask.js +0 -93
  32. package/emotion/es/components/Mask/utils/selection.js +0 -42
  33. package/emotion/es/examples/plasma_b2c/components/Mask/Mask.js +0 -3
  34. package/emotion/es/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -125
  35. package/styled-components/cjs/components/Mask/Mask.js +0 -213
  36. package/styled-components/cjs/components/Mask/Mask.types.js +0 -5
  37. package/styled-components/cjs/components/Mask/index.js +0 -12
  38. package/styled-components/cjs/components/Mask/utils/constants.js +0 -29
  39. package/styled-components/cjs/components/Mask/utils/createMask.js +0 -50
  40. package/styled-components/cjs/components/Mask/utils/mask.js +0 -241
  41. package/styled-components/cjs/components/Mask/utils/parseMask.js +0 -36
  42. package/styled-components/cjs/components/Mask/utils/processInput.js +0 -52
  43. package/styled-components/cjs/components/Mask/utils/processMask.js +0 -99
  44. package/styled-components/cjs/components/Mask/utils/selection.js +0 -48
  45. package/styled-components/cjs/examples/plasma_b2c/components/Mask/Mask.js +0 -9
  46. package/styled-components/cjs/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -125
  47. package/styled-components/es/components/Mask/Mask.js +0 -205
  48. package/styled-components/es/components/Mask/Mask.types.js +0 -1
  49. package/styled-components/es/components/Mask/index.js +0 -1
  50. package/styled-components/es/components/Mask/utils/constants.js +0 -23
  51. package/styled-components/es/components/Mask/utils/createMask.js +0 -44
  52. package/styled-components/es/components/Mask/utils/mask.js +0 -235
  53. package/styled-components/es/components/Mask/utils/parseMask.js +0 -30
  54. package/styled-components/es/components/Mask/utils/processInput.js +0 -46
  55. package/styled-components/es/components/Mask/utils/processMask.js +0 -93
  56. package/styled-components/es/components/Mask/utils/selection.js +0 -42
  57. package/styled-components/es/examples/plasma_b2c/components/Mask/Mask.js +0 -3
  58. package/styled-components/es/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -125
  59. package/types/components/Mask/Mask.d.ts +0 -5
  60. package/types/components/Mask/Mask.d.ts.map +0 -1
  61. package/types/components/Mask/Mask.types.d.ts +0 -84
  62. package/types/components/Mask/Mask.types.d.ts.map +0 -1
  63. package/types/components/Mask/index.d.ts +0 -2
  64. package/types/components/Mask/index.d.ts.map +0 -1
  65. package/types/components/Mask/utils/constants.d.ts +0 -15
  66. package/types/components/Mask/utils/constants.d.ts.map +0 -1
  67. package/types/components/Mask/utils/createMask.d.ts +0 -19
  68. package/types/components/Mask/utils/createMask.d.ts.map +0 -1
  69. package/types/components/Mask/utils/mask.d.ts +0 -42
  70. package/types/components/Mask/utils/mask.d.ts.map +0 -1
  71. package/types/components/Mask/utils/parseMask.d.ts +0 -3
  72. package/types/components/Mask/utils/parseMask.d.ts.map +0 -1
  73. package/types/components/Mask/utils/processInput.d.ts +0 -13
  74. package/types/components/Mask/utils/processInput.d.ts.map +0 -1
  75. package/types/components/Mask/utils/processMask.d.ts +0 -7
  76. package/types/components/Mask/utils/processMask.d.ts.map +0 -1
  77. package/types/components/Mask/utils/selection.d.ts +0 -10
  78. package/types/components/Mask/utils/selection.d.ts.map +0 -1
  79. package/types/examples/plasma_b2c/components/Mask/Mask.d.ts +0 -191
  80. package/types/examples/plasma_b2c/components/Mask/Mask.d.ts.map +0 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@salutejs/plasma-new-hope",
3
- "version": "0.145.0-canary.1418.10848257808.0",
3
+ "version": "0.145.0-canary.1433.10846476158.0",
4
4
  "description": "Salute Design System blueprint",
5
5
  "main": "cjs/index.js",
6
6
  "module": "es/index.js",
@@ -121,5 +121,5 @@
121
121
  "react-popper": "2.3.0",
122
122
  "storeon": "3.1.5"
123
123
  },
124
- "gitHead": "b6a3fc153f007df25da60067982532cffcfb5713"
124
+ "gitHead": "5aa7854e24d5a32c6a3fd4d1f9eb3107d1b76e5c"
125
125
  }
@@ -34,6 +34,7 @@ var optionalText = 'optional';
34
34
  var base = exports.base = /*#__PURE__*/(0, _styledComponents.css)(["display:block;"]);
35
35
  var textFieldRoot = exports.textFieldRoot = function textFieldRoot(Root) {
36
36
  return /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
37
+ var _inputRef$current, _inputRef$current3;
37
38
  var id = _ref.id,
38
39
  className = _ref.className,
39
40
  style = _ref.style,
@@ -74,7 +75,7 @@ var textFieldRoot = exports.textFieldRoot = function textFieldRoot(Root) {
74
75
  inputRef: inputRef,
75
76
  chipsRefs: chipsRefs
76
77
  };
77
- var _useState = (0, _react.useState)(Boolean(outerValue) || Boolean(rest === null || rest === void 0 ? void 0 : rest.defaultValue)),
78
+ var _useState = (0, _react.useState)(Boolean(outerValue) || Boolean(inputRef === null || inputRef === void 0 || (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.value) || Boolean(rest === null || rest === void 0 ? void 0 : rest.defaultValue)),
78
79
  _useState2 = _slicedToArray(_useState, 2),
79
80
  hasValue = _useState2[0],
80
81
  setHasValue = _useState2[1];
@@ -172,8 +173,9 @@ var textFieldRoot = exports.textFieldRoot = function textFieldRoot(Root) {
172
173
  setChips(newChips);
173
174
  }, [isChipEnumeration, values]);
174
175
  (0, _react.useEffect)(function () {
175
- setHasValue(Boolean(outerValue) || Boolean(rest === null || rest === void 0 ? void 0 : rest.defaultValue));
176
- }, [outerValue, rest.defaultValue]);
176
+ var _inputRef$current2;
177
+ setHasValue(Boolean(outerValue) || Boolean(inputRef === null || inputRef === void 0 || (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 ? void 0 : _inputRef$current2.value) || Boolean(rest === null || rest === void 0 ? void 0 : rest.defaultValue));
178
+ }, [outerValue, rest.defaultValue, inputRef === null || inputRef === void 0 || (_inputRef$current3 = inputRef.current) === null || _inputRef$current3 === void 0 ? void 0 : _inputRef$current3.value]);
177
179
  var innerOptional = Boolean(required ? false : optional);
178
180
  var hasPlaceholderOptional = innerOptional && !innerLabelValue && !hasOuterLabel;
179
181
  var optionalTextNode = innerOptional ? /*#__PURE__*/_react["default"].createElement(_TextField.StyledOptionalText, null, Boolean(hasPlaceholderOptional ? innerPlaceholderValue : innerLabelValue) && '\xa0', optionalText) : null;
@@ -25,6 +25,7 @@ var optionalText = 'optional';
25
25
  export var base = /*#__PURE__*/css(["display:block;"]);
26
26
  export var textFieldRoot = function textFieldRoot(Root) {
27
27
  return /*#__PURE__*/forwardRef(function (_ref, ref) {
28
+ var _inputRef$current, _inputRef$current3;
28
29
  var id = _ref.id,
29
30
  className = _ref.className,
30
31
  style = _ref.style,
@@ -65,7 +66,7 @@ export var textFieldRoot = function textFieldRoot(Root) {
65
66
  inputRef: inputRef,
66
67
  chipsRefs: chipsRefs
67
68
  };
68
- var _useState = useState(Boolean(outerValue) || Boolean(rest === null || rest === void 0 ? void 0 : rest.defaultValue)),
69
+ var _useState = useState(Boolean(outerValue) || Boolean(inputRef === null || inputRef === void 0 || (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.value) || Boolean(rest === null || rest === void 0 ? void 0 : rest.defaultValue)),
69
70
  _useState2 = _slicedToArray(_useState, 2),
70
71
  hasValue = _useState2[0],
71
72
  setHasValue = _useState2[1];
@@ -163,8 +164,9 @@ export var textFieldRoot = function textFieldRoot(Root) {
163
164
  setChips(newChips);
164
165
  }, [isChipEnumeration, values]);
165
166
  useEffect(function () {
166
- setHasValue(Boolean(outerValue) || Boolean(rest === null || rest === void 0 ? void 0 : rest.defaultValue));
167
- }, [outerValue, rest.defaultValue]);
167
+ var _inputRef$current2;
168
+ setHasValue(Boolean(outerValue) || Boolean(inputRef === null || inputRef === void 0 || (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 ? void 0 : _inputRef$current2.value) || Boolean(rest === null || rest === void 0 ? void 0 : rest.defaultValue));
169
+ }, [outerValue, rest.defaultValue, inputRef === null || inputRef === void 0 || (_inputRef$current3 = inputRef.current) === null || _inputRef$current3 === void 0 ? void 0 : _inputRef$current3.value]);
168
170
  var innerOptional = Boolean(required ? false : optional);
169
171
  var hasPlaceholderOptional = innerOptional && !innerLabelValue && !hasOuterLabel;
170
172
  var optionalTextNode = innerOptional ? /*#__PURE__*/React.createElement(StyledOptionalText, null, Boolean(hasPlaceholderOptional ? innerPlaceholderValue : innerLabelValue) && '\xa0', optionalText) : null;
@@ -1 +1 @@
1
- {"version":3,"file":"TextField.d.ts","sourceRoot":"","sources":["../../../src/components/TextField/TextField.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAkD,MAAM,OAAO,CAAC;AAKvE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAG/C,OAAO,KAAK,EAAuC,cAAc,EAAE,MAAM,mBAAmB,CAAC;AA4B7F,eAAO,MAAM,IAAI,0CAGhB,CAAC;AAEF,eAAO,MAAM,aAAa,SAAU,UAAU,cAAc,EAAE,cAAc,CAAC,4FAwQxE,CAAC;AAEN,eAAO,MAAM,eAAe;;;mBA1QQ,UAAU,cAAc,EAAE,cAAc,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;CAsS5E,CAAC"}
1
+ {"version":3,"file":"TextField.d.ts","sourceRoot":"","sources":["../../../src/components/TextField/TextField.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAkD,MAAM,OAAO,CAAC;AAKvE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAG/C,OAAO,KAAK,EAAuC,cAAc,EAAE,MAAM,mBAAmB,CAAC;AA4B7F,eAAO,MAAM,IAAI,0CAGhB,CAAC;AAEF,eAAO,MAAM,aAAa,SAAU,UAAU,cAAc,EAAE,cAAc,CAAC,4FA0QxE,CAAC;AAEN,eAAO,MAAM,eAAe;;;mBA5QQ,UAAU,cAAc,EAAE,cAAc,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;CAwS5E,CAAC"}
@@ -1,213 +0,0 @@
1
- "use strict";
2
-
3
- function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.composeMask = void 0;
8
- var _react = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("react"));
9
- var _plasmaCore = /*#__PURE__*/require("@salutejs/plasma-core");
10
- var _hooks = /*#__PURE__*/require("../../hooks");
11
- var _createMask = /*#__PURE__*/require("./utils/createMask");
12
- var _constants = /*#__PURE__*/require("./utils/constants");
13
- var _excluded = ["mask", "maskChar", "alwaysShowMask", "maskString", "showPrefix", "value", "defaultValue", "showMask", "onChange", "onBlur", "onFocus", "reformat"];
14
- function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
15
- function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
16
- function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
17
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
18
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
19
- function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
20
- function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
21
- function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
22
- function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
23
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
24
- function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
25
- function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
26
- function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
27
- function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
28
- var composeMask = exports.composeMask = function composeMask(InputComponent) {
29
- return /*#__PURE__*/(0, _react.forwardRef)(function (props, outerRef) {
30
- var maskValue = props.mask,
31
- maskChar = props.maskChar,
32
- alwaysShowMask = props.alwaysShowMask,
33
- maskString = props.maskString,
34
- showPrefix = props.showPrefix,
35
- value = props.value,
36
- defaultValue = props.defaultValue,
37
- showMaskedValue = props.showMask,
38
- onChange = props.onChange,
39
- onBlur = props.onBlur,
40
- onFocus = props.onFocus,
41
- reformat = props.reformat,
42
- rest = _objectWithoutProperties(props, _excluded);
43
- var _useState = (0, _react.useState)(alwaysShowMask || showMaskedValue),
44
- _useState2 = _slicedToArray(_useState, 2),
45
- showMask = _useState2[0],
46
- setShowMask = _useState2[1];
47
- var mask = (0, _react.useMemo)(function () {
48
- return (0, _createMask.createMask)({
49
- value: String(value) || String(defaultValue) || '',
50
- mask: maskValue,
51
- maskChar: maskChar || _createMask.defaults.maskChar,
52
- maskString: maskString,
53
- showPrefix: showPrefix || _createMask.defaults.showPrefix,
54
- reformat: reformat
55
- });
56
- }, []);
57
- var canSetSelection = (0, _react.useRef)(false);
58
- var inputRef = (0, _react.useRef)(null);
59
- var innerRef = (0, _plasmaCore.useForkRef)(inputRef, outerRef);
60
- var getSelection = function getSelection() {
61
- var _inputRef$current, _inputRef$current2;
62
- mask.setSelection = {
63
- start: (inputRef === null || inputRef === void 0 || (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.selectionStart) || 0,
64
- end: (inputRef === null || inputRef === void 0 || (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 ? void 0 : _inputRef$current2.selectionEnd) || 0
65
- };
66
- };
67
- var setSelection = function setSelection() {
68
- var _inputRef$current3;
69
- if (!canSetSelection.current) {
70
- return;
71
- }
72
- var selection = mask.getSelection;
73
- inputRef === null || inputRef === void 0 || (_inputRef$current3 = inputRef.current) === null || _inputRef$current3 === void 0 || _inputRef$current3.setSelectionRange(selection.start, selection.end);
74
- setTimeout(function () {
75
- var _inputRef$current4;
76
- return inputRef === null || inputRef === void 0 || (_inputRef$current4 = inputRef.current) === null || _inputRef$current4 === void 0 ? void 0 : _inputRef$current4.setSelectionRange(selection.start, selection.end);
77
- }, 0);
78
- };
79
- var showValue = function showValue() {
80
- if (!(inputRef !== null && inputRef !== void 0 && inputRef.current)) {
81
- return;
82
- }
83
- if (showMask && (canSetSelection.current || alwaysShowMask)) {
84
- inputRef.current.value = mask.getState.maskedValue;
85
- return;
86
- }
87
- inputRef.current.value = mask.getState.visibleValue;
88
- };
89
- var keyPressPropName = function keyPressPropName() {
90
- if (typeof navigator !== 'undefined' && navigator.userAgent.match(/Android/i)) {
91
- return 'onBeforeInput';
92
- }
93
- return 'onKeyPress';
94
- };
95
- var dispatchEvent = function dispatchEvent(e) {
96
- var _mask$getState = mask.getState,
97
- maskedValue = _mask$getState.maskedValue,
98
- visibleValue = _mask$getState.visibleValue;
99
- if (onChange) {
100
- onChange(e, {
101
- maskedValue: maskedValue,
102
- value: visibleValue
103
- });
104
- }
105
- };
106
- var onPaste = function onPaste(e) {
107
- e.preventDefault();
108
- getSelection();
109
- if (!(e !== null && e !== void 0 && e.clipboardData)) {
110
- return;
111
- }
112
- mask.paste(e.clipboardData.getData('Text'));
113
- setTimeout(setSelection, 0);
114
- dispatchEvent(e);
115
- };
116
- var handleChange = function handleChange(e) {
117
- var currentValue;
118
- if (showMask && (canSetSelection.current || alwaysShowMask)) {
119
- currentValue = mask.getState.maskedValue;
120
- } else {
121
- currentValue = mask.getState.visibleValue;
122
- }
123
- if (e.target.value !== currentValue) {
124
- getSelection();
125
- mask.updateValue(e.target.value);
126
- setTimeout(setSelection, 0);
127
- }
128
- dispatchEvent(e);
129
- };
130
- var onKeyPress = function onKeyPress(e) {
131
- if (e.metaKey || e.altKey || e.ctrlKey || e.key === 'Enter') {
132
- return;
133
- }
134
- e.preventDefault();
135
- getSelection();
136
- mask.input(e.key || String.fromCharCode(e.which));
137
- setSelection();
138
- dispatchEvent(e);
139
- };
140
- var onKeyDown = function onKeyDown(e) {
141
- if (e.code === _constants.keyboardCode.Backspace) {
142
- e.preventDefault();
143
- getSelection();
144
- mask.removePreviousOrSelected();
145
- setSelection();
146
- dispatchEvent(e);
147
- }
148
- if (e.code === _constants.keyboardCode.Delete) {
149
- e.preventDefault();
150
- getSelection();
151
- mask.removeNextOrSelected();
152
- setSelection();
153
- dispatchEvent(e);
154
- }
155
- };
156
- var handleFocus = function handleFocus(e) {
157
- canSetSelection.current = true;
158
- if (onFocus) {
159
- onFocus(e);
160
- }
161
- };
162
- var handleBlur = function handleBlur(e) {
163
- canSetSelection.current = false;
164
- if (onBlur) {
165
- onBlur(e);
166
- }
167
- };
168
- var keyPressEvent = _defineProperty({}, keyPressPropName(), onKeyPress);
169
- (0, _hooks.useDidMountEffect)(function () {
170
- setShowMask(alwaysShowMask || showMask);
171
- }, [alwaysShowMask, showMask]);
172
- (0, _hooks.useDidMountEffect)(function () {
173
- if (reformat) {
174
- mask.updateReformat(reformat);
175
- }
176
- }, [reformat]);
177
- (0, _hooks.useDidMountEffect)(function () {
178
- mask.updateMask(String(mask));
179
- }, [mask]);
180
- (0, _hooks.useDidMountEffect)(function () {
181
- mask.updateMaskString(String(maskString));
182
- }, [maskString]);
183
- (0, _hooks.useDidMountEffect)(function () {
184
- mask.updateMaskChar(String(maskChar));
185
- }, [maskChar]);
186
- (0, _hooks.useDidMountEffect)(function () {
187
- mask.updateValue(String(value));
188
- }, [value]);
189
- (0, _react.useEffect)(function () {
190
- showValue();
191
- }, [showValue, mask]);
192
- (0, _react.useEffect)(function () {
193
- var subscriber = function subscriber() {
194
- showValue();
195
- setSelection();
196
- };
197
- mask.subscribe(subscriber);
198
- return function () {
199
- mask.unsubscribe(subscriber);
200
- };
201
- }, [mask, showValue, setSelection]);
202
- return /*#__PURE__*/_react["default"].createElement(InputComponent, _extends({}, rest, {
203
- onChange: handleChange,
204
- onKeyDown: onKeyDown,
205
- onPaste: onPaste,
206
- onFocus: handleFocus,
207
- onBlur: handleBlur
208
- }, keyPressEvent, {
209
- ref: innerRef,
210
- autoComplete: "off"
211
- }));
212
- });
213
- };
@@ -1,5 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
@@ -1,12 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- Object.defineProperty(exports, "composeMask", {
7
- enumerable: true,
8
- get: function get() {
9
- return _Mask.composeMask;
10
- }
11
- });
12
- var _Mask = /*#__PURE__*/require("./Mask");
@@ -1,29 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.keyboardCode = exports.escapeChar = exports.defaultFormatChars = exports.charType = void 0;
7
- var charType = exports.charType = {
8
- User: 1,
9
- Char: 2,
10
- Mask: 3
11
- };
12
- var keyboardCode = exports.keyboardCode = {
13
- Backspace: 'Backspace',
14
- Delete: 'Delete'
15
- };
16
- var escapeChar = exports.escapeChar = '\\';
17
- var defaultFormatChars = exports.defaultFormatChars = [{
18
- str: '0',
19
- regexp: /[0-9]/
20
- }, {
21
- str: '*',
22
- regexp: /./
23
- }, {
24
- str: 'a',
25
- regexp: /[a-zA-Z]/
26
- }, {
27
- str: 'я',
28
- regexp: /[а-яА-ЯёЁ]/
29
- }];
@@ -1,50 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.defaults = exports.createMask = void 0;
7
- var _constants = /*#__PURE__*/require("./constants");
8
- var _mask = /*#__PURE__*/require("./mask");
9
- var _selection = /*#__PURE__*/require("./selection");
10
- var defaults = exports.defaults = {
11
- maskFormat: _constants.defaultFormatChars,
12
- maskChar: '',
13
- showMask: false,
14
- removeSelectedRange: _selection.removeSelectedRange,
15
- showPrefix: false
16
- };
17
- var createMask = exports.createMask = function createMask(params) {
18
- var _params$mask;
19
- var maskString = params.maskString,
20
- _params$showPrefix = params.showPrefix,
21
- showPrefix = _params$showPrefix === void 0 ? defaults.showPrefix : _params$showPrefix,
22
- _params$maskChar = params.maskChar,
23
- maskChar = _params$maskChar === void 0 ? defaults.maskChar : _params$maskChar,
24
- reformat = params.reformat;
25
- var resReformat = reformat;
26
- if (!reformat && !params.mask) {
27
- resReformat = function resReformat(args) {
28
- var str = args.value.map(function (item) {
29
- return item["char"];
30
- }).join('');
31
- return {
32
- value: args.value,
33
- visibleValue: str,
34
- maskedValue: str,
35
- selection: args.selection
36
- };
37
- };
38
- } else if (reformat && params.mask) {
39
- params.mask = undefined;
40
- }
41
- if (maskString && maskString.length !== (params === null || params === void 0 || (_params$mask = params.mask) === null || _params$mask === void 0 ? void 0 : _params$mask.length)) {
42
- throw new Error('maskString должна быть такой же длины, как и mask');
43
- }
44
- if (maskChar.length > 1) {
45
- throw new Error('maskChar должен содержать только 1 символ');
46
- }
47
- var mask = new _mask.Mask(showPrefix, maskChar, maskString, resReformat);
48
- mask.updateMask(params.mask);
49
- return mask;
50
- };
@@ -1,241 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.Mask = void 0;
7
- var _constants = /*#__PURE__*/require("./constants");
8
- var _parseMask = /*#__PURE__*/require("./parseMask");
9
- var _processInput = /*#__PURE__*/require("./processInput");
10
- var _selection = /*#__PURE__*/require("./selection");
11
- function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
12
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
13
- function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
14
- function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
15
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
16
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
17
- function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
18
- var Mask = exports.Mask = /*#__PURE__*/function () {
19
- function Mask(showPrefix, maskChar, maskString, reformat) {
20
- _classCallCheck(this, Mask);
21
- _defineProperty(this, "selection", void 0);
22
- _defineProperty(this, "value", void 0);
23
- _defineProperty(this, "maskedValue", void 0);
24
- _defineProperty(this, "visibleValue", void 0);
25
- _defineProperty(this, "mask", void 0);
26
- _defineProperty(this, "maskChar", void 0);
27
- _defineProperty(this, "maskFormatMap", void 0);
28
- _defineProperty(this, "showPrefix", void 0);
29
- _defineProperty(this, "callbacks", void 0);
30
- _defineProperty(this, "maskString", void 0);
31
- _defineProperty(this, "reformat", void 0);
32
- this.value = '';
33
- this.mask = [];
34
- this.maskedValue = '';
35
- this.visibleValue = '';
36
- this.selection = {
37
- start: 0,
38
- end: 0
39
- };
40
- this.callbacks = [];
41
- this.maskFormatMap = this.parseMaskFormat;
42
- this.showPrefix = showPrefix;
43
- this.maskChar = maskChar;
44
- this.maskString = maskString;
45
- this.reformat = reformat;
46
- }
47
- return _createClass(Mask, [{
48
- key: "parseMaskFormat",
49
- get: function get() {
50
- return _constants.defaultFormatChars.reduce(function (acc, current) {
51
- acc[String(current.str)] = current;
52
- return acc;
53
- }, {});
54
- }
55
- }, {
56
- key: "getSelection",
57
- get: function get() {
58
- var _this$selection = this.selection,
59
- start = _this$selection.start,
60
- end = _this$selection.end;
61
- return {
62
- start: start,
63
- end: end
64
- };
65
- }
66
- }, {
67
- key: "getState",
68
- get: function get() {
69
- return {
70
- value: this.value,
71
- maskedValue: this.maskedValue,
72
- visibleValue: this.visibleValue,
73
- selection: this.selection
74
- };
75
- }
76
- }, {
77
- key: "setSelection",
78
- set: function set(newSelection) {
79
- this.selection = newSelection;
80
- }
81
- }, {
82
- key: "setShowStartChars",
83
- set: function set(show) {
84
- this.showPrefix = show;
85
- }
86
- }, {
87
- key: "updateMask",
88
- value: function updateMask(newMask) {
89
- this.mask = (0, _parseMask.parseMask)(newMask, this.maskFormatMap);
90
- this.updateValue(this.value);
91
- }
92
- }, {
93
- key: "updateMaskChar",
94
- value: function updateMaskChar(newMaskChar) {
95
- if (this.maskChar.length > 1) {
96
- throw new Error('maskChar должен содержать только 1 символ');
97
- }
98
- this.maskChar = newMaskChar;
99
- this.updateValue(this.value);
100
- }
101
- }, {
102
- key: "updateMaskString",
103
- value: function updateMaskString(newMaskString) {
104
- if (newMaskString && newMaskString.length !== this.mask.length) {
105
- throw new Error('maskString должна иметь такую же длину, как и mask');
106
- }
107
- this.maskString = newMaskString;
108
- this.updateValue(this.value);
109
- }
110
- }, {
111
- key: "updateReformat",
112
- value: function updateReformat(newReformat) {
113
- this.reformat = newReformat;
114
- this.updateValue(this.value);
115
- }
116
- }, {
117
- key: "updateValue",
118
- value: function updateValue(data) {
119
- if (this.reformat) {
120
- var _result = this.reformat({
121
- value: data,
122
- selection: this.selection
123
- });
124
- return this.applyChanges(_result);
125
- }
126
- var dataList = Array.isArray(data) ? data : Array.from(data).reduce(function (acc, _char) {
127
- acc.push({
128
- "char": _char,
129
- type: _constants.charType.User
130
- });
131
- return acc;
132
- }, []);
133
- var result = (0, _processInput.processInput)({
134
- data: dataList,
135
- selection: this.selection,
136
- mask: this.mask,
137
- maskChar: this.maskChar,
138
- maskString: this.maskString,
139
- showPrefix: this.showPrefix
140
- });
141
- this.applyChanges(result);
142
- }
143
- }, {
144
- key: "removePreviousOrSelected",
145
- value: function removePreviousOrSelected() {
146
- var _this$selection2 = this.selection,
147
- start = _this$selection2.start,
148
- end = _this$selection2.end;
149
- if (start === end) {
150
- var newStart = end - 1 < 0 ? 0 : end - 1;
151
- this.setSelection = {
152
- start: newStart,
153
- end: end
154
- };
155
- }
156
- this.input('');
157
- }
158
- }, {
159
- key: "removeNextOrSelected",
160
- value: function removeNextOrSelected() {
161
- var _this$selection3 = this.selection,
162
- start = _this$selection3.start,
163
- end = _this$selection3.end;
164
- if (start === end) {
165
- this.setSelection = {
166
- start: start,
167
- end: end + 1
168
- };
169
- }
170
- this.input('');
171
- }
172
- }, {
173
- key: "paste",
174
- value: function paste(value) {
175
- this.input(value);
176
- }
177
- }, {
178
- key: "input",
179
- value: function input(_input) {
180
- if (this.reformat) {
181
- var _result2 = this.reformat({
182
- value: this.value,
183
- input: _input,
184
- selection: this.selection
185
- });
186
- return this.applyChanges(_result2);
187
- }
188
- var tmpValue = (0, _selection.removeSelectedRange)({
189
- value: this.value,
190
- selection: this.selection,
191
- maskChar: this.maskChar,
192
- maskString: String(this.maskString)
193
- });
194
- this.selection.end = this.selection.start;
195
- var result = (0, _processInput.processInput)({
196
- data: tmpValue,
197
- input: _input,
198
- selection: this.selection,
199
- mask: this.mask,
200
- maskChar: this.maskChar,
201
- maskString: this.maskString,
202
- showPrefix: this.showPrefix
203
- });
204
- this.applyChanges(result);
205
- }
206
- }, {
207
- key: "applyChanges",
208
- value: function applyChanges(result) {
209
- var oldMaskedValue = this.maskedValue;
210
- var oldVisibleValue = this.visibleValue;
211
- var oldSelection = this.selection;
212
- this.value = result.value;
213
- this.maskedValue = result.maskedValue;
214
- this.visibleValue = result.visibleValue;
215
- this.setSelection = result.selection;
216
- if (oldMaskedValue !== this.maskedValue || oldVisibleValue !== this.visibleValue || oldSelection.start !== this.selection.start || oldSelection.end !== this.selection.end) {
217
- this.notify();
218
- }
219
- }
220
- }, {
221
- key: "subscribe",
222
- value: function subscribe(callback) {
223
- this.callbacks.push(callback);
224
- }
225
- }, {
226
- key: "unsubscribe",
227
- value: function unsubscribe(callback) {
228
- this.callbacks = this.callbacks.filter(function (item) {
229
- return item !== callback;
230
- });
231
- }
232
- }, {
233
- key: "notify",
234
- value: function notify() {
235
- var state = this.getState;
236
- this.callbacks.forEach(function (callback) {
237
- callback(state);
238
- });
239
- }
240
- }]);
241
- }();
@@ -1,36 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.parseMask = void 0;
7
- var _constants = /*#__PURE__*/require("./constants");
8
- var parseMask = exports.parseMask = function parseMask(mask, format) {
9
- if (!mask) {
10
- return [];
11
- }
12
- var stack = [];
13
- var escape = false;
14
- mask.split('').forEach(function (maskChar) {
15
- var item = format === null || format === void 0 ? void 0 : format[maskChar];
16
- if (escape && item) {
17
- item = undefined;
18
- escape = false;
19
- }
20
- if (!item) {
21
- if (!escape && maskChar === _constants.escapeChar) {
22
- escape = true;
23
- return;
24
- }
25
- escape = false;
26
- stack.push({
27
- "char": maskChar
28
- });
29
- return;
30
- }
31
- if (item.regexp) {
32
- stack.push(item);
33
- }
34
- });
35
- return stack;
36
- };