@alfalab/core-components-phone-input 7.5.8 → 8.0.0-snapshot-6a9d3fc

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 (62) hide show
  1. package/Component.d.ts +3 -5
  2. package/Component.js +11 -10
  3. package/Component.js.map +1 -0
  4. package/cssm/Component.d.ts +3 -5
  5. package/cssm/Component.js +13 -12
  6. package/cssm/Component.js.map +1 -0
  7. package/cssm/index.d.ts +1 -1
  8. package/cssm/index.js +1 -0
  9. package/cssm/index.js.map +1 -0
  10. package/cssm/utils/check-insert-before.d.ts +1 -2
  11. package/cssm/utils/check-insert-before.js +1 -0
  12. package/cssm/utils/check-insert-before.js.map +1 -0
  13. package/cssm/utils/index.d.ts +5 -6
  14. package/cssm/utils/index.js +1 -0
  15. package/cssm/utils/index.js.map +1 -0
  16. package/esm/Component.d.ts +3 -5
  17. package/esm/Component.js +1 -0
  18. package/esm/Component.js.map +1 -0
  19. package/esm/index.d.ts +1 -1
  20. package/esm/index.js +1 -0
  21. package/esm/index.js.map +1 -0
  22. package/esm/utils/check-insert-before.d.ts +1 -2
  23. package/esm/utils/check-insert-before.js +1 -0
  24. package/esm/utils/check-insert-before.js.map +1 -0
  25. package/esm/utils/index.d.ts +5 -6
  26. package/esm/utils/index.js +1 -0
  27. package/esm/utils/index.js.map +1 -0
  28. package/index.d.ts +1 -1
  29. package/index.js +1 -0
  30. package/index.js.map +1 -0
  31. package/modern/Component.d.ts +3 -5
  32. package/modern/Component.js +1 -0
  33. package/modern/Component.js.map +1 -0
  34. package/modern/index.d.ts +1 -1
  35. package/modern/index.js +1 -0
  36. package/modern/index.js.map +1 -0
  37. package/modern/utils/check-insert-before.d.ts +1 -2
  38. package/modern/utils/check-insert-before.js +1 -0
  39. package/modern/utils/check-insert-before.js.map +1 -0
  40. package/modern/utils/index.d.ts +5 -6
  41. package/modern/utils/index.js +1 -0
  42. package/modern/utils/index.js.map +1 -0
  43. package/moderncssm/Component.d.ts +3 -5
  44. package/moderncssm/Component.js +1 -0
  45. package/moderncssm/Component.js.map +1 -0
  46. package/moderncssm/index.d.ts +1 -1
  47. package/moderncssm/index.js +1 -0
  48. package/moderncssm/index.js.map +1 -0
  49. package/moderncssm/utils/check-insert-before.d.ts +1 -2
  50. package/moderncssm/utils/check-insert-before.js +1 -0
  51. package/moderncssm/utils/check-insert-before.js.map +1 -0
  52. package/moderncssm/utils/index.d.ts +5 -6
  53. package/moderncssm/utils/index.js +1 -0
  54. package/moderncssm/utils/index.js.map +1 -0
  55. package/package.json +6 -5
  56. package/src/text-mask-core.d.ts +44 -0
  57. package/utils/check-insert-before.d.ts +1 -2
  58. package/utils/check-insert-before.js +1 -0
  59. package/utils/check-insert-before.js.map +1 -0
  60. package/utils/index.d.ts +5 -6
  61. package/utils/index.js +1 -0
  62. package/utils/index.js.map +1 -0
package/Component.d.ts CHANGED
@@ -1,10 +1,8 @@
1
- /// <reference types="react" />
2
1
  import React from 'react';
3
- import { MaskedInputProps } from "@alfalab/core-components-masked-input";
4
- type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {
2
+ import { MaskedInputProps } from '@alfalab/core-components-masked-input';
3
+ export declare type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {
5
4
  clearableCountryCode?: boolean;
6
5
  };
7
- declare const PhoneInput: React.ForwardRefExoticComponent<Omit<MaskedInputProps, "mask" | "type" | "onBeforeDisplay"> & {
6
+ export declare const PhoneInput: React.ForwardRefExoticComponent<Omit<MaskedInputProps, "type" | "onBeforeDisplay" | "mask"> & {
8
7
  clearableCountryCode?: boolean | undefined;
9
8
  } & React.RefAttributes<HTMLInputElement>>;
10
- export { PhoneInputProps, PhoneInput };
package/Component.js CHANGED
@@ -7,8 +7,8 @@ var React = require('react');
7
7
  var mergeRefs = require('react-merge-refs');
8
8
  var textMaskCore = require('text-mask-core');
9
9
  var coreComponentsMaskedInput = require('@alfalab/core-components-masked-input');
10
- var utils_checkInsertBefore = require('./utils/check-insert-before.js');
11
- var utils_index = require('./utils/index.js');
10
+ var checkInsertBefore = require('./utils/check-insert-before.js');
11
+ var index = require('./utils/index.js');
12
12
 
13
13
  function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
14
14
 
@@ -40,7 +40,7 @@ var PhoneInput = React__default.default.forwardRef(function (_a, ref) {
40
40
  var handleBeforeDisplay = React.useCallback(function (conformedValue, config) {
41
41
  var rawValue = config.rawValue, previousConformedValue = config.previousConformedValue, currentCaretPosition = config.currentCaretPosition;
42
42
  var previousValueWithoutFormatting = previousConformedValue
43
- ? utils_index.deleteFormatting(previousConformedValue)
43
+ ? index.deleteFormatting(previousConformedValue)
44
44
  : '';
45
45
  // Вставка номера с 10 или 11 цифрами без кода страны
46
46
  var digits = rawValue.replace(/\D/g, '');
@@ -56,11 +56,11 @@ var PhoneInput = React__default.default.forwardRef(function (_a, ref) {
56
56
  /*
57
57
  * Удаляем лишний символ маски при вводе или вставке значений перед знаком + или после него.
58
58
  */
59
- if (utils_checkInsertBefore.checkInsertBefore(previousConformedValue, rawValue)) {
60
- var newRaw = utils_index.deleteMaskChar(previousValueWithoutFormatting, rawValue);
59
+ if (checkInsertBefore.checkInsertBefore(previousConformedValue, rawValue)) {
60
+ var newRaw = index.deleteMaskChar(previousValueWithoutFormatting, rawValue);
61
61
  conformedValue = textMaskCore.conformToMask(newRaw, mask, config).conformedValue;
62
62
  }
63
- var currentValueWithoutFormatting = utils_index.deleteFormatting(conformedValue) || '';
63
+ var currentValueWithoutFormatting = index.deleteFormatting(conformedValue) || '';
64
64
  /*
65
65
  * код ниже нужен для фикса следующих багов библиотеки text-mask:
66
66
  * 1) так как код страны указан в маске жестко как "+7",
@@ -75,17 +75,17 @@ var PhoneInput = React__default.default.forwardRef(function (_a, ref) {
75
75
  currentValueWithoutFormatting.length) === 1) ||
76
76
  ([7, 10, 13].includes(currentCaretPosition) &&
77
77
  previousConformedValue.length > currentCaretPosition))) {
78
- utils_index.setCaretPosition({ position: currentCaretPosition, inputRef: inputRef });
78
+ index.setCaretPosition({ position: currentCaretPosition, inputRef: inputRef });
79
79
  }
80
80
  // // В режиме clearableCountryCode удаляет лишний пробел, чтобы можно было стереть код города.
81
81
  if (rawValue === '+7' && conformedValue === '' && clearableCountryCode) {
82
- utils_index.setCaretPosition({ position: countryPrefix.length - 1, inputRef: inputRef });
82
+ index.setCaretPosition({ position: countryPrefix.length - 1, inputRef: inputRef });
83
83
  }
84
84
  // Удаление цифры перед кодом страны удаляет только саму цифру, код остается ("+7 1" -> "+7 ")
85
85
  if (rawValue === countryPrefix) {
86
86
  return rawValue;
87
87
  }
88
- var insertedNumber = utils_index.getInsertedNumber({
88
+ var insertedNumber = index.getInsertedNumber({
89
89
  rawValue: rawValue,
90
90
  clearableCountryCode: clearableCountryCode,
91
91
  countryPrefix: countryPrefix,
@@ -103,7 +103,7 @@ var PhoneInput = React__default.default.forwardRef(function (_a, ref) {
103
103
  }
104
104
  // Запрет на удаление кода страны
105
105
  if (!clearableCountryCode && !conformedValue) {
106
- utils_index.setCaretPosition({ position: countryPrefix.length, inputRef: inputRef });
106
+ index.setCaretPosition({ position: countryPrefix.length, inputRef: inputRef });
107
107
  return rawValue.length ? false : countryPrefix;
108
108
  }
109
109
  return conformedValue;
@@ -113,3 +113,4 @@ var PhoneInput = React__default.default.forwardRef(function (_a, ref) {
113
113
  PhoneInput.displayName = 'PhoneInputs';
114
114
 
115
115
  exports.PhoneInput = PhoneInput;
116
+ //# sourceMappingURL=Component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Component.js","sources":["src/Component.tsx"],"sourcesContent":["/* eslint-disable complexity, no-param-reassign */\nimport React, { useCallback, useRef } from 'react';\nimport mergeRefs from 'react-merge-refs';\nimport { conformToMask, TextMaskConfig } from 'text-mask-core';\n\nimport { MaskedInput, MaskedInputProps } from '@alfalab/core-components-masked-input';\n\nimport { checkInsertBefore } from './utils/check-insert-before';\nimport { deleteFormatting, deleteMaskChar, getInsertedNumber, setCaretPosition } from './utils';\n\nconst mask = [\n '+',\n '7',\n ' ',\n /([0-6]|[8-9])/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n];\n\nconst countryPrefix = '+7 ';\n\nexport type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {\n clearableCountryCode?: boolean;\n};\n\nexport const PhoneInput = React.forwardRef<HTMLInputElement, PhoneInputProps>(\n ({ clearableCountryCode = true, ...restProps }, ref) => {\n const inputRef = useRef<HTMLInputElement>(null);\n\n const handleBeforeDisplay = useCallback(\n (conformedValue: string, config: TextMaskConfig) => {\n const { rawValue, previousConformedValue, currentCaretPosition } = config;\n\n const previousValueWithoutFormatting = previousConformedValue\n ? deleteFormatting(previousConformedValue)\n : '';\n\n // Вставка номера с 10 или 11 цифрами без кода страны\n const digits = rawValue.replace(/\\D/g, '');\n\n if ((digits.length === 10 || digits.length === 11) && !rawValue.startsWith('+7')) {\n let processedDigits = digits;\n\n if (\n digits.length === 11 &&\n (digits.startsWith('7') || digits.startsWith('8'))\n ) {\n processedDigits = digits.slice(1);\n }\n const masked = conformToMask(`+7${processedDigits}`, mask, config);\n\n return masked.conformedValue;\n }\n\n /*\n * Удаляем лишний символ маски при вводе или вставке значений перед знаком + или после него.\n */\n if (checkInsertBefore(previousConformedValue, rawValue)) {\n const newRaw = deleteMaskChar(previousValueWithoutFormatting, rawValue);\n\n conformedValue = conformToMask(newRaw, mask, config).conformedValue;\n }\n\n const currentValueWithoutFormatting = deleteFormatting(conformedValue) || '';\n\n /*\n * код ниже нужен для фикса следующих багов библиотеки text-mask:\n * 1) так как код страны указан в маске жестко как \"+7\",\n * то при удалении цифры перед ним каретка устанавливается перед кодом страны\n * 2) в номере телефона есть пробелы и дефисы,\n * при редактировании цифр рядом с этими символами каретка перескакивает через них,\n * а не остается на том же месте, на котором была до редактирования\n */\n if (\n previousConformedValue &&\n (([3, 6].includes(currentCaretPosition) &&\n Math.abs(\n previousValueWithoutFormatting.length -\n currentValueWithoutFormatting.length,\n ) === 1) ||\n ([7, 10, 13].includes(currentCaretPosition) &&\n previousConformedValue.length > currentCaretPosition))\n ) {\n setCaretPosition({ position: currentCaretPosition, inputRef });\n }\n\n // // В режиме clearableCountryCode удаляет лишний пробел, чтобы можно было стереть код города.\n if (rawValue === '+7' && conformedValue === '' && clearableCountryCode) {\n setCaretPosition({ position: countryPrefix.length - 1, inputRef });\n }\n\n // Удаление цифры перед кодом страны удаляет только саму цифру, код остается (\"+7 1\" -> \"+7 \")\n if (rawValue === countryPrefix) {\n return rawValue;\n }\n\n const insertedNumber = getInsertedNumber({\n rawValue,\n clearableCountryCode,\n countryPrefix,\n previousConformedValue,\n });\n\n // Вставка номера, начинающегося с 8 или 7: 89990313131, 71112223344\n if (\n (insertedNumber.startsWith('7') || insertedNumber.startsWith('8')) &&\n insertedNumber.length >= 10\n ) {\n const masked = conformToMask(`+7${insertedNumber.slice(1)}`, mask, config);\n\n return masked.conformedValue;\n }\n\n // Если ввод начат с 7 или 8 - выводит \"+7 \" и дает продолжить ввод со след. цифры\n if (rawValue.length === 1 && ['7', '8'].includes(rawValue[0])) {\n return countryPrefix;\n }\n\n // Запрет на удаление кода страны\n if (!clearableCountryCode && !conformedValue) {\n setCaretPosition({ position: countryPrefix.length, inputRef });\n\n return rawValue.length ? false : countryPrefix;\n }\n\n return conformedValue;\n },\n [clearableCountryCode],\n );\n\n return (\n <MaskedInput\n {...restProps}\n defaultValue={clearableCountryCode ? restProps.defaultValue : countryPrefix}\n mask={mask}\n onBeforeDisplay={handleBeforeDisplay}\n type='tel'\n ref={mergeRefs([ref, inputRef])}\n />\n );\n },\n);\n\nPhoneInput.displayName = 'PhoneInputs';\n"],"names":["React","__rest","useRef","useCallback","deleteFormatting","conformToMask","checkInsertBefore","deleteMaskChar","setCaretPosition","getInsertedNumber","MaskedInput","__assign","mergeRefs"],"mappings":"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"}
@@ -1,10 +1,8 @@
1
- /// <reference types="react" />
2
1
  import React from 'react';
3
- import { MaskedInputProps } from "@alfalab/core-components-masked-input";
4
- type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {
2
+ import { MaskedInputProps } from '@alfalab/core-components-masked-input';
3
+ export declare type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {
5
4
  clearableCountryCode?: boolean;
6
5
  };
7
- declare const PhoneInput: React.ForwardRefExoticComponent<Omit<MaskedInputProps, "mask" | "type" | "onBeforeDisplay"> & {
6
+ export declare const PhoneInput: React.ForwardRefExoticComponent<Omit<MaskedInputProps, "type" | "onBeforeDisplay" | "mask"> & {
8
7
  clearableCountryCode?: boolean | undefined;
9
8
  } & React.RefAttributes<HTMLInputElement>>;
10
- export { PhoneInputProps, PhoneInput };
package/cssm/Component.js CHANGED
@@ -6,9 +6,9 @@ var tslib = require('tslib');
6
6
  var React = require('react');
7
7
  var mergeRefs = require('react-merge-refs');
8
8
  var textMaskCore = require('text-mask-core');
9
- var coreComponentsMaskedInput = require('@alfalab/core-components-masked-input/cssm');
10
- var utils_checkInsertBefore = require('./utils/check-insert-before.js');
11
- var utils_index = require('./utils/index.js');
9
+ var cssm = require('@alfalab/core-components-masked-input/cssm');
10
+ var checkInsertBefore = require('./utils/check-insert-before.js');
11
+ var index = require('./utils/index.js');
12
12
 
13
13
  function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
14
14
 
@@ -40,7 +40,7 @@ var PhoneInput = React__default.default.forwardRef(function (_a, ref) {
40
40
  var handleBeforeDisplay = React.useCallback(function (conformedValue, config) {
41
41
  var rawValue = config.rawValue, previousConformedValue = config.previousConformedValue, currentCaretPosition = config.currentCaretPosition;
42
42
  var previousValueWithoutFormatting = previousConformedValue
43
- ? utils_index.deleteFormatting(previousConformedValue)
43
+ ? index.deleteFormatting(previousConformedValue)
44
44
  : '';
45
45
  // Вставка номера с 10 или 11 цифрами без кода страны
46
46
  var digits = rawValue.replace(/\D/g, '');
@@ -56,11 +56,11 @@ var PhoneInput = React__default.default.forwardRef(function (_a, ref) {
56
56
  /*
57
57
  * Удаляем лишний символ маски при вводе или вставке значений перед знаком + или после него.
58
58
  */
59
- if (utils_checkInsertBefore.checkInsertBefore(previousConformedValue, rawValue)) {
60
- var newRaw = utils_index.deleteMaskChar(previousValueWithoutFormatting, rawValue);
59
+ if (checkInsertBefore.checkInsertBefore(previousConformedValue, rawValue)) {
60
+ var newRaw = index.deleteMaskChar(previousValueWithoutFormatting, rawValue);
61
61
  conformedValue = textMaskCore.conformToMask(newRaw, mask, config).conformedValue;
62
62
  }
63
- var currentValueWithoutFormatting = utils_index.deleteFormatting(conformedValue) || '';
63
+ var currentValueWithoutFormatting = index.deleteFormatting(conformedValue) || '';
64
64
  /*
65
65
  * код ниже нужен для фикса следующих багов библиотеки text-mask:
66
66
  * 1) так как код страны указан в маске жестко как "+7",
@@ -75,17 +75,17 @@ var PhoneInput = React__default.default.forwardRef(function (_a, ref) {
75
75
  currentValueWithoutFormatting.length) === 1) ||
76
76
  ([7, 10, 13].includes(currentCaretPosition) &&
77
77
  previousConformedValue.length > currentCaretPosition))) {
78
- utils_index.setCaretPosition({ position: currentCaretPosition, inputRef: inputRef });
78
+ index.setCaretPosition({ position: currentCaretPosition, inputRef: inputRef });
79
79
  }
80
80
  // // В режиме clearableCountryCode удаляет лишний пробел, чтобы можно было стереть код города.
81
81
  if (rawValue === '+7' && conformedValue === '' && clearableCountryCode) {
82
- utils_index.setCaretPosition({ position: countryPrefix.length - 1, inputRef: inputRef });
82
+ index.setCaretPosition({ position: countryPrefix.length - 1, inputRef: inputRef });
83
83
  }
84
84
  // Удаление цифры перед кодом страны удаляет только саму цифру, код остается ("+7 1" -> "+7 ")
85
85
  if (rawValue === countryPrefix) {
86
86
  return rawValue;
87
87
  }
88
- var insertedNumber = utils_index.getInsertedNumber({
88
+ var insertedNumber = index.getInsertedNumber({
89
89
  rawValue: rawValue,
90
90
  clearableCountryCode: clearableCountryCode,
91
91
  countryPrefix: countryPrefix,
@@ -103,13 +103,14 @@ var PhoneInput = React__default.default.forwardRef(function (_a, ref) {
103
103
  }
104
104
  // Запрет на удаление кода страны
105
105
  if (!clearableCountryCode && !conformedValue) {
106
- utils_index.setCaretPosition({ position: countryPrefix.length, inputRef: inputRef });
106
+ index.setCaretPosition({ position: countryPrefix.length, inputRef: inputRef });
107
107
  return rawValue.length ? false : countryPrefix;
108
108
  }
109
109
  return conformedValue;
110
110
  }, [clearableCountryCode]);
111
- return (React__default.default.createElement(coreComponentsMaskedInput.MaskedInput, tslib.__assign({}, restProps, { defaultValue: clearableCountryCode ? restProps.defaultValue : countryPrefix, mask: mask, onBeforeDisplay: handleBeforeDisplay, type: 'tel', ref: mergeRefs__default.default([ref, inputRef]) })));
111
+ return (React__default.default.createElement(cssm.MaskedInput, tslib.__assign({}, restProps, { defaultValue: clearableCountryCode ? restProps.defaultValue : countryPrefix, mask: mask, onBeforeDisplay: handleBeforeDisplay, type: 'tel', ref: mergeRefs__default.default([ref, inputRef]) })));
112
112
  });
113
113
  PhoneInput.displayName = 'PhoneInputs';
114
114
 
115
115
  exports.PhoneInput = PhoneInput;
116
+ //# sourceMappingURL=Component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Component.js","sources":["../src/Component.tsx"],"sourcesContent":["/* eslint-disable complexity, no-param-reassign */\nimport React, { useCallback, useRef } from 'react';\nimport mergeRefs from 'react-merge-refs';\nimport { conformToMask, TextMaskConfig } from 'text-mask-core';\n\nimport { MaskedInput, MaskedInputProps } from '@alfalab/core-components-masked-input';\n\nimport { checkInsertBefore } from './utils/check-insert-before';\nimport { deleteFormatting, deleteMaskChar, getInsertedNumber, setCaretPosition } from './utils';\n\nconst mask = [\n '+',\n '7',\n ' ',\n /([0-6]|[8-9])/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n];\n\nconst countryPrefix = '+7 ';\n\nexport type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {\n clearableCountryCode?: boolean;\n};\n\nexport const PhoneInput = React.forwardRef<HTMLInputElement, PhoneInputProps>(\n ({ clearableCountryCode = true, ...restProps }, ref) => {\n const inputRef = useRef<HTMLInputElement>(null);\n\n const handleBeforeDisplay = useCallback(\n (conformedValue: string, config: TextMaskConfig) => {\n const { rawValue, previousConformedValue, currentCaretPosition } = config;\n\n const previousValueWithoutFormatting = previousConformedValue\n ? deleteFormatting(previousConformedValue)\n : '';\n\n // Вставка номера с 10 или 11 цифрами без кода страны\n const digits = rawValue.replace(/\\D/g, '');\n\n if ((digits.length === 10 || digits.length === 11) && !rawValue.startsWith('+7')) {\n let processedDigits = digits;\n\n if (\n digits.length === 11 &&\n (digits.startsWith('7') || digits.startsWith('8'))\n ) {\n processedDigits = digits.slice(1);\n }\n const masked = conformToMask(`+7${processedDigits}`, mask, config);\n\n return masked.conformedValue;\n }\n\n /*\n * Удаляем лишний символ маски при вводе или вставке значений перед знаком + или после него.\n */\n if (checkInsertBefore(previousConformedValue, rawValue)) {\n const newRaw = deleteMaskChar(previousValueWithoutFormatting, rawValue);\n\n conformedValue = conformToMask(newRaw, mask, config).conformedValue;\n }\n\n const currentValueWithoutFormatting = deleteFormatting(conformedValue) || '';\n\n /*\n * код ниже нужен для фикса следующих багов библиотеки text-mask:\n * 1) так как код страны указан в маске жестко как \"+7\",\n * то при удалении цифры перед ним каретка устанавливается перед кодом страны\n * 2) в номере телефона есть пробелы и дефисы,\n * при редактировании цифр рядом с этими символами каретка перескакивает через них,\n * а не остается на том же месте, на котором была до редактирования\n */\n if (\n previousConformedValue &&\n (([3, 6].includes(currentCaretPosition) &&\n Math.abs(\n previousValueWithoutFormatting.length -\n currentValueWithoutFormatting.length,\n ) === 1) ||\n ([7, 10, 13].includes(currentCaretPosition) &&\n previousConformedValue.length > currentCaretPosition))\n ) {\n setCaretPosition({ position: currentCaretPosition, inputRef });\n }\n\n // // В режиме clearableCountryCode удаляет лишний пробел, чтобы можно было стереть код города.\n if (rawValue === '+7' && conformedValue === '' && clearableCountryCode) {\n setCaretPosition({ position: countryPrefix.length - 1, inputRef });\n }\n\n // Удаление цифры перед кодом страны удаляет только саму цифру, код остается (\"+7 1\" -> \"+7 \")\n if (rawValue === countryPrefix) {\n return rawValue;\n }\n\n const insertedNumber = getInsertedNumber({\n rawValue,\n clearableCountryCode,\n countryPrefix,\n previousConformedValue,\n });\n\n // Вставка номера, начинающегося с 8 или 7: 89990313131, 71112223344\n if (\n (insertedNumber.startsWith('7') || insertedNumber.startsWith('8')) &&\n insertedNumber.length >= 10\n ) {\n const masked = conformToMask(`+7${insertedNumber.slice(1)}`, mask, config);\n\n return masked.conformedValue;\n }\n\n // Если ввод начат с 7 или 8 - выводит \"+7 \" и дает продолжить ввод со след. цифры\n if (rawValue.length === 1 && ['7', '8'].includes(rawValue[0])) {\n return countryPrefix;\n }\n\n // Запрет на удаление кода страны\n if (!clearableCountryCode && !conformedValue) {\n setCaretPosition({ position: countryPrefix.length, inputRef });\n\n return rawValue.length ? false : countryPrefix;\n }\n\n return conformedValue;\n },\n [clearableCountryCode],\n );\n\n return (\n <MaskedInput\n {...restProps}\n defaultValue={clearableCountryCode ? restProps.defaultValue : countryPrefix}\n mask={mask}\n onBeforeDisplay={handleBeforeDisplay}\n type='tel'\n ref={mergeRefs([ref, inputRef])}\n />\n );\n },\n);\n\nPhoneInput.displayName = 'PhoneInputs';\n"],"names":["React","__rest","useRef","useCallback","deleteFormatting","conformToMask","checkInsertBefore","deleteMaskChar","setCaretPosition","getInsertedNumber","MaskedInput","__assign","mergeRefs"],"mappings":"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"}
package/cssm/index.d.ts CHANGED
@@ -1 +1 @@
1
- export * from "./Component";
1
+ export * from './Component';
package/cssm/index.js CHANGED
@@ -7,3 +7,4 @@ var Component = require('./Component.js');
7
7
 
8
8
 
9
9
  exports.PhoneInput = Component.PhoneInput;
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
@@ -3,5 +3,4 @@
3
3
  * @description +7 123 => paste 222 => +2227 123
4
4
  * @description +7 123 => paste 222 => 222+7 123
5
5
  */
6
- declare const checkInsertBefore: (baseNumber: string | undefined, modifiedNumber: string) => boolean;
7
- export { checkInsertBefore };
6
+ export declare const checkInsertBefore: (baseNumber: string | undefined, modifiedNumber: string) => boolean;
@@ -42,3 +42,4 @@ var checkInsertBefore = function (baseNumber, modifiedNumber) {
42
42
  };
43
43
 
44
44
  exports.checkInsertBefore = checkInsertBefore;
45
+ //# sourceMappingURL=check-insert-before.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"check-insert-before.js","sources":["../../src/utils/check-insert-before.ts"],"sourcesContent":["/**\n * Позволяет проверить что цифры были вставлены до или после знака плюс [+]\n * @description +7 123 => paste 222 => +2227 123\n * @description +7 123 => paste 222 => 222+7 123\n */\nexport const checkInsertBefore = (baseNumber: string | undefined, modifiedNumber: string) => {\n if (baseNumber) {\n try {\n /** Удаляем лишние символы */\n // +7 123 => 7123\n const base = baseNumber.replace(/\\s+/g, '').replace('+', '');\n // +7 123 => +7123\n const modified = modifiedNumber.replace(/\\s+/g, '');\n\n /**\n * Числа вставлены между [+] и номером\n * +7 123 => paste 222 => +2227 123\n */\n const afterPlusPattern = new RegExp(`^\\\\+\\\\d*${base}$`);\n\n if (afterPlusPattern.test(modified)) {\n return true;\n }\n\n /**\n * Числа вставлены перед [+]\n * +7 123 => paste 222 => 222+7 123\n */\n const beforePlusPattern = new RegExp(`^\\\\d*\\\\+${base}$`);\n\n if (beforePlusPattern.test(modified)) {\n return true;\n }\n\n return false;\n } catch (e) {\n // eslint-disable-next-line no-console\n console.error('checkInsertAtBeginning', e);\n }\n }\n\n return false;\n};\n"],"names":[],"mappings":";;;;AAAA;;;;AAIG;AACU,IAAA,iBAAiB,GAAG,UAAC,UAA8B,EAAE,cAAsB,EAAA;AACpF,IAAA,IAAI,UAAU,EAAE;QACZ,IAAI;;;AAGA,YAAA,IAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC;;YAE5D,IAAM,QAAQ,GAAG,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;AAEnD;;;AAGG;YACH,IAAM,gBAAgB,GAAG,IAAI,MAAM,CAAC,UAAW,CAAA,MAAA,CAAA,IAAI,EAAG,GAAA,CAAA,CAAC;AAEvD,YAAA,IAAI,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;AACjC,gBAAA,OAAO,IAAI;AACd;AAED;;;AAGG;YACH,IAAM,iBAAiB,GAAG,IAAI,MAAM,CAAC,UAAW,CAAA,MAAA,CAAA,IAAI,EAAG,GAAA,CAAA,CAAC;AAExD,YAAA,IAAI,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;AAClC,gBAAA,OAAO,IAAI;AACd;AAED,YAAA,OAAO,KAAK;AACf;AAAC,QAAA,OAAO,CAAC,EAAE;;AAER,YAAA,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,CAAC,CAAC;AAC7C;AACJ;AAED,IAAA,OAAO,KAAK;AAChB;;;;"}
@@ -1,18 +1,17 @@
1
- /// <reference types="react" />
2
1
  /**
3
2
  * Удаляет форматирование номера телефона
4
3
  * @param phone Номер телефона
5
4
  */
6
- declare const deleteFormatting: (phone: string) => string;
7
- declare function setCaretPosition({ position, inputRef, }: {
5
+ /// <reference types="react" />
6
+ export declare const deleteFormatting: (phone: string) => string;
7
+ export declare function setCaretPosition({ position, inputRef, }: {
8
8
  position: number;
9
9
  inputRef: React.RefObject<HTMLInputElement>;
10
10
  }): void;
11
- declare function getInsertedNumber({ rawValue, clearableCountryCode, countryPrefix, previousConformedValue, }: {
11
+ export declare function getInsertedNumber({ rawValue, clearableCountryCode, countryPrefix, previousConformedValue, }: {
12
12
  rawValue: string;
13
13
  clearableCountryCode: boolean;
14
14
  countryPrefix: string;
15
15
  previousConformedValue: string;
16
16
  }): string;
17
- declare function deleteMaskChar(previousValue: string, rawValue: string): string;
18
- export { deleteFormatting, setCaretPosition, getInsertedNumber, deleteMaskChar };
17
+ export declare function deleteMaskChar(previousValue: string, rawValue: string): string;
@@ -48,3 +48,4 @@ exports.deleteFormatting = deleteFormatting;
48
48
  exports.deleteMaskChar = deleteMaskChar;
49
49
  exports.getInsertedNumber = getInsertedNumber;
50
50
  exports.setCaretPosition = setCaretPosition;
51
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/utils/index.ts"],"sourcesContent":["/**\n * Удаляет форматирование номера телефона\n * @param phone Номер телефона\n */\n\nexport const deleteFormatting = (phone: string) =>\n phone.replace('+', '').replace(/^7/, '').replace(/\\s/g, '');\n\nexport function setCaretPosition({\n position,\n inputRef,\n}: {\n position: number;\n inputRef: React.RefObject<HTMLInputElement>;\n}) {\n window.requestAnimationFrame(() => {\n if (inputRef === null || !inputRef.current) return;\n\n inputRef.current.setSelectionRange(position, position);\n });\n}\n\nexport function getInsertedNumber({\n rawValue,\n clearableCountryCode,\n countryPrefix,\n previousConformedValue,\n}: {\n rawValue: string;\n clearableCountryCode: boolean;\n countryPrefix: string;\n previousConformedValue: string;\n}) {\n if (!clearableCountryCode && previousConformedValue === countryPrefix) {\n if (rawValue.startsWith('7') || rawValue.startsWith('8')) {\n return rawValue;\n }\n\n return rawValue.slice(countryPrefix.length);\n }\n\n return rawValue;\n}\n\nexport function deleteMaskChar(previousValue: string, rawValue: string) {\n const prevRawValueAsArr = deleteFormatting(rawValue).split('').reverse();\n let prevConformedCharIdx = previousValue.length - 1;\n let isMaskRemoved = false;\n const newRaw: string[] = [];\n\n prevRawValueAsArr.forEach((char) => {\n if (isMaskRemoved || char === previousValue[prevConformedCharIdx]) {\n newRaw.push(char);\n prevConformedCharIdx -= 1;\n } else if (char === '7') {\n isMaskRemoved = true;\n }\n });\n\n return newRaw.reverse().join('');\n}\n"],"names":[],"mappings":";;;;AAAA;;;AAGG;AAEI,IAAM,gBAAgB,GAAG,UAAC,KAAa,EAAA;IAC1C,OAAA,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;AAA3D;AAEE,SAAU,gBAAgB,CAAC,EAMhC,EAAA;QALG,QAAQ,GAAA,EAAA,CAAA,QAAA,EACR,QAAQ,GAAA,EAAA,CAAA,QAAA;IAKR,MAAM,CAAC,qBAAqB,CAAC,YAAA;AACzB,QAAA,IAAI,QAAQ,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO;YAAE;QAE5C,QAAQ,CAAC,OAAO,CAAC,iBAAiB,CAAC,QAAQ,EAAE,QAAQ,CAAC;AAC1D,KAAC,CAAC;AACN;AAEM,SAAU,iBAAiB,CAAC,EAUjC,EAAA;QATG,QAAQ,GAAA,EAAA,CAAA,QAAA,EACR,oBAAoB,GAAA,EAAA,CAAA,oBAAA,EACpB,aAAa,GAAA,EAAA,CAAA,aAAA,EACb,sBAAsB,GAAA,EAAA,CAAA,sBAAA;AAOtB,IAAA,IAAI,CAAC,oBAAoB,IAAI,sBAAsB,KAAK,aAAa,EAAE;AACnE,QAAA,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;AACtD,YAAA,OAAO,QAAQ;AAClB;QAED,OAAO,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC;AAC9C;AAED,IAAA,OAAO,QAAQ;AACnB;AAEgB,SAAA,cAAc,CAAC,aAAqB,EAAE,QAAgB,EAAA;AAClE,IAAA,IAAM,iBAAiB,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE;AACxE,IAAA,IAAI,oBAAoB,GAAG,aAAa,CAAC,MAAM,GAAG,CAAC;IACnD,IAAI,aAAa,GAAG,KAAK;IACzB,IAAM,MAAM,GAAa,EAAE;AAE3B,IAAA,iBAAiB,CAAC,OAAO,CAAC,UAAC,IAAI,EAAA;QAC3B,IAAI,aAAa,IAAI,IAAI,KAAK,aAAa,CAAC,oBAAoB,CAAC,EAAE;AAC/D,YAAA,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;YACjB,oBAAoB,IAAI,CAAC;AAC5B;aAAM,IAAI,IAAI,KAAK,GAAG,EAAE;YACrB,aAAa,GAAG,IAAI;AACvB;AACL,KAAC,CAAC;IAEF,OAAO,MAAM,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;AACpC;;;;;;;"}
@@ -1,10 +1,8 @@
1
- /// <reference types="react" />
2
1
  import React from 'react';
3
- import { MaskedInputProps } from "@alfalab/core-components-masked-input";
4
- type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {
2
+ import { MaskedInputProps } from '@alfalab/core-components-masked-input';
3
+ export declare type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {
5
4
  clearableCountryCode?: boolean;
6
5
  };
7
- declare const PhoneInput: React.ForwardRefExoticComponent<Omit<MaskedInputProps, "mask" | "type" | "onBeforeDisplay"> & {
6
+ export declare const PhoneInput: React.ForwardRefExoticComponent<Omit<MaskedInputProps, "type" | "onBeforeDisplay" | "mask"> & {
8
7
  clearableCountryCode?: boolean | undefined;
9
8
  } & React.RefAttributes<HTMLInputElement>>;
10
- export { PhoneInputProps, PhoneInput };
package/esm/Component.js CHANGED
@@ -104,3 +104,4 @@ var PhoneInput = React.forwardRef(function (_a, ref) {
104
104
  PhoneInput.displayName = 'PhoneInputs';
105
105
 
106
106
  export { PhoneInput };
107
+ //# sourceMappingURL=Component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Component.js","sources":["../src/Component.tsx"],"sourcesContent":["/* eslint-disable complexity, no-param-reassign */\nimport React, { useCallback, useRef } from 'react';\nimport mergeRefs from 'react-merge-refs';\nimport { conformToMask, TextMaskConfig } from 'text-mask-core';\n\nimport { MaskedInput, MaskedInputProps } from '@alfalab/core-components-masked-input';\n\nimport { checkInsertBefore } from './utils/check-insert-before';\nimport { deleteFormatting, deleteMaskChar, getInsertedNumber, setCaretPosition } from './utils';\n\nconst mask = [\n '+',\n '7',\n ' ',\n /([0-6]|[8-9])/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n];\n\nconst countryPrefix = '+7 ';\n\nexport type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {\n clearableCountryCode?: boolean;\n};\n\nexport const PhoneInput = React.forwardRef<HTMLInputElement, PhoneInputProps>(\n ({ clearableCountryCode = true, ...restProps }, ref) => {\n const inputRef = useRef<HTMLInputElement>(null);\n\n const handleBeforeDisplay = useCallback(\n (conformedValue: string, config: TextMaskConfig) => {\n const { rawValue, previousConformedValue, currentCaretPosition } = config;\n\n const previousValueWithoutFormatting = previousConformedValue\n ? deleteFormatting(previousConformedValue)\n : '';\n\n // Вставка номера с 10 или 11 цифрами без кода страны\n const digits = rawValue.replace(/\\D/g, '');\n\n if ((digits.length === 10 || digits.length === 11) && !rawValue.startsWith('+7')) {\n let processedDigits = digits;\n\n if (\n digits.length === 11 &&\n (digits.startsWith('7') || digits.startsWith('8'))\n ) {\n processedDigits = digits.slice(1);\n }\n const masked = conformToMask(`+7${processedDigits}`, mask, config);\n\n return masked.conformedValue;\n }\n\n /*\n * Удаляем лишний символ маски при вводе или вставке значений перед знаком + или после него.\n */\n if (checkInsertBefore(previousConformedValue, rawValue)) {\n const newRaw = deleteMaskChar(previousValueWithoutFormatting, rawValue);\n\n conformedValue = conformToMask(newRaw, mask, config).conformedValue;\n }\n\n const currentValueWithoutFormatting = deleteFormatting(conformedValue) || '';\n\n /*\n * код ниже нужен для фикса следующих багов библиотеки text-mask:\n * 1) так как код страны указан в маске жестко как \"+7\",\n * то при удалении цифры перед ним каретка устанавливается перед кодом страны\n * 2) в номере телефона есть пробелы и дефисы,\n * при редактировании цифр рядом с этими символами каретка перескакивает через них,\n * а не остается на том же месте, на котором была до редактирования\n */\n if (\n previousConformedValue &&\n (([3, 6].includes(currentCaretPosition) &&\n Math.abs(\n previousValueWithoutFormatting.length -\n currentValueWithoutFormatting.length,\n ) === 1) ||\n ([7, 10, 13].includes(currentCaretPosition) &&\n previousConformedValue.length > currentCaretPosition))\n ) {\n setCaretPosition({ position: currentCaretPosition, inputRef });\n }\n\n // // В режиме clearableCountryCode удаляет лишний пробел, чтобы можно было стереть код города.\n if (rawValue === '+7' && conformedValue === '' && clearableCountryCode) {\n setCaretPosition({ position: countryPrefix.length - 1, inputRef });\n }\n\n // Удаление цифры перед кодом страны удаляет только саму цифру, код остается (\"+7 1\" -> \"+7 \")\n if (rawValue === countryPrefix) {\n return rawValue;\n }\n\n const insertedNumber = getInsertedNumber({\n rawValue,\n clearableCountryCode,\n countryPrefix,\n previousConformedValue,\n });\n\n // Вставка номера, начинающегося с 8 или 7: 89990313131, 71112223344\n if (\n (insertedNumber.startsWith('7') || insertedNumber.startsWith('8')) &&\n insertedNumber.length >= 10\n ) {\n const masked = conformToMask(`+7${insertedNumber.slice(1)}`, mask, config);\n\n return masked.conformedValue;\n }\n\n // Если ввод начат с 7 или 8 - выводит \"+7 \" и дает продолжить ввод со след. цифры\n if (rawValue.length === 1 && ['7', '8'].includes(rawValue[0])) {\n return countryPrefix;\n }\n\n // Запрет на удаление кода страны\n if (!clearableCountryCode && !conformedValue) {\n setCaretPosition({ position: countryPrefix.length, inputRef });\n\n return rawValue.length ? false : countryPrefix;\n }\n\n return conformedValue;\n },\n [clearableCountryCode],\n );\n\n return (\n <MaskedInput\n {...restProps}\n defaultValue={clearableCountryCode ? restProps.defaultValue : countryPrefix}\n mask={mask}\n onBeforeDisplay={handleBeforeDisplay}\n type='tel'\n ref={mergeRefs([ref, inputRef])}\n />\n );\n },\n);\n\nPhoneInput.displayName = 'PhoneInputs';\n"],"names":[],"mappings":"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"}
package/esm/index.d.ts CHANGED
@@ -1 +1 @@
1
- export * from "./Component";
1
+ export * from './Component';
package/esm/index.js CHANGED
@@ -1 +1,2 @@
1
1
  export { PhoneInput } from './Component.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -3,5 +3,4 @@
3
3
  * @description +7 123 => paste 222 => +2227 123
4
4
  * @description +7 123 => paste 222 => 222+7 123
5
5
  */
6
- declare const checkInsertBefore: (baseNumber: string | undefined, modifiedNumber: string) => boolean;
7
- export { checkInsertBefore };
6
+ export declare const checkInsertBefore: (baseNumber: string | undefined, modifiedNumber: string) => boolean;
@@ -38,3 +38,4 @@ var checkInsertBefore = function (baseNumber, modifiedNumber) {
38
38
  };
39
39
 
40
40
  export { checkInsertBefore };
41
+ //# sourceMappingURL=check-insert-before.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"check-insert-before.js","sources":["../../src/utils/check-insert-before.ts"],"sourcesContent":["/**\n * Позволяет проверить что цифры были вставлены до или после знака плюс [+]\n * @description +7 123 => paste 222 => +2227 123\n * @description +7 123 => paste 222 => 222+7 123\n */\nexport const checkInsertBefore = (baseNumber: string | undefined, modifiedNumber: string) => {\n if (baseNumber) {\n try {\n /** Удаляем лишние символы */\n // +7 123 => 7123\n const base = baseNumber.replace(/\\s+/g, '').replace('+', '');\n // +7 123 => +7123\n const modified = modifiedNumber.replace(/\\s+/g, '');\n\n /**\n * Числа вставлены между [+] и номером\n * +7 123 => paste 222 => +2227 123\n */\n const afterPlusPattern = new RegExp(`^\\\\+\\\\d*${base}$`);\n\n if (afterPlusPattern.test(modified)) {\n return true;\n }\n\n /**\n * Числа вставлены перед [+]\n * +7 123 => paste 222 => 222+7 123\n */\n const beforePlusPattern = new RegExp(`^\\\\d*\\\\+${base}$`);\n\n if (beforePlusPattern.test(modified)) {\n return true;\n }\n\n return false;\n } catch (e) {\n // eslint-disable-next-line no-console\n console.error('checkInsertAtBeginning', e);\n }\n }\n\n return false;\n};\n"],"names":[],"mappings":"AAAA;;;;AAIG;AACU,IAAA,iBAAiB,GAAG,UAAC,UAA8B,EAAE,cAAsB,EAAA;AACpF,IAAA,IAAI,UAAU,EAAE;QACZ,IAAI;;;AAGA,YAAA,IAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC;;YAE5D,IAAM,QAAQ,GAAG,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;AAEnD;;;AAGG;YACH,IAAM,gBAAgB,GAAG,IAAI,MAAM,CAAC,UAAW,CAAA,MAAA,CAAA,IAAI,EAAG,GAAA,CAAA,CAAC;AAEvD,YAAA,IAAI,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;AACjC,gBAAA,OAAO,IAAI;AACd;AAED;;;AAGG;YACH,IAAM,iBAAiB,GAAG,IAAI,MAAM,CAAC,UAAW,CAAA,MAAA,CAAA,IAAI,EAAG,GAAA,CAAA,CAAC;AAExD,YAAA,IAAI,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;AAClC,gBAAA,OAAO,IAAI;AACd;AAED,YAAA,OAAO,KAAK;AACf;AAAC,QAAA,OAAO,CAAC,EAAE;;AAER,YAAA,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,CAAC,CAAC;AAC7C;AACJ;AAED,IAAA,OAAO,KAAK;AAChB;;;;"}
@@ -1,18 +1,17 @@
1
- /// <reference types="react" />
2
1
  /**
3
2
  * Удаляет форматирование номера телефона
4
3
  * @param phone Номер телефона
5
4
  */
6
- declare const deleteFormatting: (phone: string) => string;
7
- declare function setCaretPosition({ position, inputRef, }: {
5
+ /// <reference types="react" />
6
+ export declare const deleteFormatting: (phone: string) => string;
7
+ export declare function setCaretPosition({ position, inputRef, }: {
8
8
  position: number;
9
9
  inputRef: React.RefObject<HTMLInputElement>;
10
10
  }): void;
11
- declare function getInsertedNumber({ rawValue, clearableCountryCode, countryPrefix, previousConformedValue, }: {
11
+ export declare function getInsertedNumber({ rawValue, clearableCountryCode, countryPrefix, previousConformedValue, }: {
12
12
  rawValue: string;
13
13
  clearableCountryCode: boolean;
14
14
  countryPrefix: string;
15
15
  previousConformedValue: string;
16
16
  }): string;
17
- declare function deleteMaskChar(previousValue: string, rawValue: string): string;
18
- export { deleteFormatting, setCaretPosition, getInsertedNumber, deleteMaskChar };
17
+ export declare function deleteMaskChar(previousValue: string, rawValue: string): string;
@@ -41,3 +41,4 @@ function deleteMaskChar(previousValue, rawValue) {
41
41
  }
42
42
 
43
43
  export { deleteFormatting, deleteMaskChar, getInsertedNumber, setCaretPosition };
44
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/utils/index.ts"],"sourcesContent":["/**\n * Удаляет форматирование номера телефона\n * @param phone Номер телефона\n */\n\nexport const deleteFormatting = (phone: string) =>\n phone.replace('+', '').replace(/^7/, '').replace(/\\s/g, '');\n\nexport function setCaretPosition({\n position,\n inputRef,\n}: {\n position: number;\n inputRef: React.RefObject<HTMLInputElement>;\n}) {\n window.requestAnimationFrame(() => {\n if (inputRef === null || !inputRef.current) return;\n\n inputRef.current.setSelectionRange(position, position);\n });\n}\n\nexport function getInsertedNumber({\n rawValue,\n clearableCountryCode,\n countryPrefix,\n previousConformedValue,\n}: {\n rawValue: string;\n clearableCountryCode: boolean;\n countryPrefix: string;\n previousConformedValue: string;\n}) {\n if (!clearableCountryCode && previousConformedValue === countryPrefix) {\n if (rawValue.startsWith('7') || rawValue.startsWith('8')) {\n return rawValue;\n }\n\n return rawValue.slice(countryPrefix.length);\n }\n\n return rawValue;\n}\n\nexport function deleteMaskChar(previousValue: string, rawValue: string) {\n const prevRawValueAsArr = deleteFormatting(rawValue).split('').reverse();\n let prevConformedCharIdx = previousValue.length - 1;\n let isMaskRemoved = false;\n const newRaw: string[] = [];\n\n prevRawValueAsArr.forEach((char) => {\n if (isMaskRemoved || char === previousValue[prevConformedCharIdx]) {\n newRaw.push(char);\n prevConformedCharIdx -= 1;\n } else if (char === '7') {\n isMaskRemoved = true;\n }\n });\n\n return newRaw.reverse().join('');\n}\n"],"names":[],"mappings":"AAAA;;;AAGG;AAEI,IAAM,gBAAgB,GAAG,UAAC,KAAa,EAAA;IAC1C,OAAA,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;AAA3D;AAEE,SAAU,gBAAgB,CAAC,EAMhC,EAAA;QALG,QAAQ,GAAA,EAAA,CAAA,QAAA,EACR,QAAQ,GAAA,EAAA,CAAA,QAAA;IAKR,MAAM,CAAC,qBAAqB,CAAC,YAAA;AACzB,QAAA,IAAI,QAAQ,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO;YAAE;QAE5C,QAAQ,CAAC,OAAO,CAAC,iBAAiB,CAAC,QAAQ,EAAE,QAAQ,CAAC;AAC1D,KAAC,CAAC;AACN;AAEM,SAAU,iBAAiB,CAAC,EAUjC,EAAA;QATG,QAAQ,GAAA,EAAA,CAAA,QAAA,EACR,oBAAoB,GAAA,EAAA,CAAA,oBAAA,EACpB,aAAa,GAAA,EAAA,CAAA,aAAA,EACb,sBAAsB,GAAA,EAAA,CAAA,sBAAA;AAOtB,IAAA,IAAI,CAAC,oBAAoB,IAAI,sBAAsB,KAAK,aAAa,EAAE;AACnE,QAAA,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;AACtD,YAAA,OAAO,QAAQ;AAClB;QAED,OAAO,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC;AAC9C;AAED,IAAA,OAAO,QAAQ;AACnB;AAEgB,SAAA,cAAc,CAAC,aAAqB,EAAE,QAAgB,EAAA;AAClE,IAAA,IAAM,iBAAiB,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE;AACxE,IAAA,IAAI,oBAAoB,GAAG,aAAa,CAAC,MAAM,GAAG,CAAC;IACnD,IAAI,aAAa,GAAG,KAAK;IACzB,IAAM,MAAM,GAAa,EAAE;AAE3B,IAAA,iBAAiB,CAAC,OAAO,CAAC,UAAC,IAAI,EAAA;QAC3B,IAAI,aAAa,IAAI,IAAI,KAAK,aAAa,CAAC,oBAAoB,CAAC,EAAE;AAC/D,YAAA,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;YACjB,oBAAoB,IAAI,CAAC;AAC5B;aAAM,IAAI,IAAI,KAAK,GAAG,EAAE;YACrB,aAAa,GAAG,IAAI;AACvB;AACL,KAAC,CAAC;IAEF,OAAO,MAAM,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;AACpC;;;;"}
package/index.d.ts CHANGED
@@ -1 +1 @@
1
- export * from "./Component";
1
+ export * from './Component';
package/index.js CHANGED
@@ -7,3 +7,4 @@ var Component = require('./Component.js');
7
7
 
8
8
 
9
9
  exports.PhoneInput = Component.PhoneInput;
10
+ //# sourceMappingURL=index.js.map
package/index.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
@@ -1,10 +1,8 @@
1
- /// <reference types="react" />
2
1
  import React from 'react';
3
- import { MaskedInputProps } from "@alfalab/core-components-masked-input";
4
- type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {
2
+ import { MaskedInputProps } from '@alfalab/core-components-masked-input';
3
+ export declare type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {
5
4
  clearableCountryCode?: boolean;
6
5
  };
7
- declare const PhoneInput: React.ForwardRefExoticComponent<Omit<MaskedInputProps, "mask" | "type" | "onBeforeDisplay"> & {
6
+ export declare const PhoneInput: React.ForwardRefExoticComponent<Omit<MaskedInputProps, "type" | "onBeforeDisplay" | "mask"> & {
8
7
  clearableCountryCode?: boolean | undefined;
9
8
  } & React.RefAttributes<HTMLInputElement>>;
10
- export { PhoneInputProps, PhoneInput };
@@ -103,3 +103,4 @@ const PhoneInput = React.forwardRef(({ clearableCountryCode = true, ...restProps
103
103
  PhoneInput.displayName = 'PhoneInputs';
104
104
 
105
105
  export { PhoneInput };
106
+ //# sourceMappingURL=Component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Component.js","sources":["../src/Component.tsx"],"sourcesContent":["/* eslint-disable complexity, no-param-reassign */\nimport React, { useCallback, useRef } from 'react';\nimport mergeRefs from 'react-merge-refs';\nimport { conformToMask, TextMaskConfig } from 'text-mask-core';\n\nimport { MaskedInput, MaskedInputProps } from '@alfalab/core-components-masked-input';\n\nimport { checkInsertBefore } from './utils/check-insert-before';\nimport { deleteFormatting, deleteMaskChar, getInsertedNumber, setCaretPosition } from './utils';\n\nconst mask = [\n '+',\n '7',\n ' ',\n /([0-6]|[8-9])/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n];\n\nconst countryPrefix = '+7 ';\n\nexport type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {\n clearableCountryCode?: boolean;\n};\n\nexport const PhoneInput = React.forwardRef<HTMLInputElement, PhoneInputProps>(\n ({ clearableCountryCode = true, ...restProps }, ref) => {\n const inputRef = useRef<HTMLInputElement>(null);\n\n const handleBeforeDisplay = useCallback(\n (conformedValue: string, config: TextMaskConfig) => {\n const { rawValue, previousConformedValue, currentCaretPosition } = config;\n\n const previousValueWithoutFormatting = previousConformedValue\n ? deleteFormatting(previousConformedValue)\n : '';\n\n // Вставка номера с 10 или 11 цифрами без кода страны\n const digits = rawValue.replace(/\\D/g, '');\n\n if ((digits.length === 10 || digits.length === 11) && !rawValue.startsWith('+7')) {\n let processedDigits = digits;\n\n if (\n digits.length === 11 &&\n (digits.startsWith('7') || digits.startsWith('8'))\n ) {\n processedDigits = digits.slice(1);\n }\n const masked = conformToMask(`+7${processedDigits}`, mask, config);\n\n return masked.conformedValue;\n }\n\n /*\n * Удаляем лишний символ маски при вводе или вставке значений перед знаком + или после него.\n */\n if (checkInsertBefore(previousConformedValue, rawValue)) {\n const newRaw = deleteMaskChar(previousValueWithoutFormatting, rawValue);\n\n conformedValue = conformToMask(newRaw, mask, config).conformedValue;\n }\n\n const currentValueWithoutFormatting = deleteFormatting(conformedValue) || '';\n\n /*\n * код ниже нужен для фикса следующих багов библиотеки text-mask:\n * 1) так как код страны указан в маске жестко как \"+7\",\n * то при удалении цифры перед ним каретка устанавливается перед кодом страны\n * 2) в номере телефона есть пробелы и дефисы,\n * при редактировании цифр рядом с этими символами каретка перескакивает через них,\n * а не остается на том же месте, на котором была до редактирования\n */\n if (\n previousConformedValue &&\n (([3, 6].includes(currentCaretPosition) &&\n Math.abs(\n previousValueWithoutFormatting.length -\n currentValueWithoutFormatting.length,\n ) === 1) ||\n ([7, 10, 13].includes(currentCaretPosition) &&\n previousConformedValue.length > currentCaretPosition))\n ) {\n setCaretPosition({ position: currentCaretPosition, inputRef });\n }\n\n // // В режиме clearableCountryCode удаляет лишний пробел, чтобы можно было стереть код города.\n if (rawValue === '+7' && conformedValue === '' && clearableCountryCode) {\n setCaretPosition({ position: countryPrefix.length - 1, inputRef });\n }\n\n // Удаление цифры перед кодом страны удаляет только саму цифру, код остается (\"+7 1\" -> \"+7 \")\n if (rawValue === countryPrefix) {\n return rawValue;\n }\n\n const insertedNumber = getInsertedNumber({\n rawValue,\n clearableCountryCode,\n countryPrefix,\n previousConformedValue,\n });\n\n // Вставка номера, начинающегося с 8 или 7: 89990313131, 71112223344\n if (\n (insertedNumber.startsWith('7') || insertedNumber.startsWith('8')) &&\n insertedNumber.length >= 10\n ) {\n const masked = conformToMask(`+7${insertedNumber.slice(1)}`, mask, config);\n\n return masked.conformedValue;\n }\n\n // Если ввод начат с 7 или 8 - выводит \"+7 \" и дает продолжить ввод со след. цифры\n if (rawValue.length === 1 && ['7', '8'].includes(rawValue[0])) {\n return countryPrefix;\n }\n\n // Запрет на удаление кода страны\n if (!clearableCountryCode && !conformedValue) {\n setCaretPosition({ position: countryPrefix.length, inputRef });\n\n return rawValue.length ? false : countryPrefix;\n }\n\n return conformedValue;\n },\n [clearableCountryCode],\n );\n\n return (\n <MaskedInput\n {...restProps}\n defaultValue={clearableCountryCode ? restProps.defaultValue : countryPrefix}\n mask={mask}\n onBeforeDisplay={handleBeforeDisplay}\n type='tel'\n ref={mergeRefs([ref, inputRef])}\n />\n );\n },\n);\n\nPhoneInput.displayName = 'PhoneInputs';\n"],"names":[],"mappings":";;;;;;;AAAA;AAUA,MAAM,IAAI,GAAG;IACT,GAAG;IACH,GAAG;IACH,GAAG;IACH,eAAe;IACf,IAAI;IACJ,IAAI;IACJ,GAAG;IACH,IAAI;IACJ,IAAI;IACJ,IAAI;IACJ,GAAG;IACH,IAAI;IACJ,IAAI;IACJ,GAAG;IACH,IAAI;IACJ,IAAI;CACP;AAED,MAAM,aAAa,GAAG,KAAK;MAMd,UAAU,GAAG,KAAK,CAAC,UAAU,CACtC,CAAC,EAAE,oBAAoB,GAAG,IAAI,EAAE,GAAG,SAAS,EAAE,EAAE,GAAG,KAAI;AACnD,IAAA,MAAM,QAAQ,GAAG,MAAM,CAAmB,IAAI,CAAC;IAE/C,MAAM,mBAAmB,GAAG,WAAW,CACnC,CAAC,cAAsB,EAAE,MAAsB,KAAI;QAC/C,MAAM,EAAE,QAAQ,EAAE,sBAAsB,EAAE,oBAAoB,EAAE,GAAG,MAAM;QAEzE,MAAM,8BAA8B,GAAG;AACnC,cAAE,gBAAgB,CAAC,sBAAsB;cACvC,EAAE;;QAGR,MAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;QAE1C,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,EAAE,IAAI,MAAM,CAAC,MAAM,KAAK,EAAE,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YAC9E,IAAI,eAAe,GAAG,MAAM;AAE5B,YAAA,IACI,MAAM,CAAC,MAAM,KAAK,EAAE;AACpB,iBAAC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,EACpD;AACE,gBAAA,eAAe,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;AACpC;AACD,YAAA,MAAM,MAAM,GAAG,aAAa,CAAC,CAAK,EAAA,EAAA,eAAe,CAAE,CAAA,EAAE,IAAI,EAAE,MAAM,CAAC;YAElE,OAAO,MAAM,CAAC,cAAc;AAC/B;AAED;;AAEG;AACH,QAAA,IAAI,iBAAiB,CAAC,sBAAsB,EAAE,QAAQ,CAAC,EAAE;YACrD,MAAM,MAAM,GAAG,cAAc,CAAC,8BAA8B,EAAE,QAAQ,CAAC;YAEvE,cAAc,GAAG,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC,cAAc;AACtE;QAED,MAAM,6BAA6B,GAAG,gBAAgB,CAAC,cAAc,CAAC,IAAI,EAAE;AAE5E;;;;;;;AAOG;AACH,QAAA,IACI,sBAAsB;aACrB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,oBAAoB,CAAC;AACnC,gBAAA,IAAI,CAAC,GAAG,CACJ,8BAA8B,CAAC,MAAM;AACjC,oBAAA,6BAA6B,CAAC,MAAM,CAC3C,KAAK,CAAC;iBACN,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,oBAAoB,CAAC;AACvC,oBAAA,sBAAsB,CAAC,MAAM,GAAG,oBAAoB,CAAC,CAAC,EAChE;YACE,gBAAgB,CAAC,EAAE,QAAQ,EAAE,oBAAoB,EAAE,QAAQ,EAAE,CAAC;AACjE;;QAGD,IAAI,QAAQ,KAAK,IAAI,IAAI,cAAc,KAAK,EAAE,IAAI,oBAAoB,EAAE;AACpE,YAAA,gBAAgB,CAAC,EAAE,QAAQ,EAAE,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,QAAQ,EAAE,CAAC;AACrE;;QAGD,IAAI,QAAQ,KAAK,aAAa,EAAE;AAC5B,YAAA,OAAO,QAAQ;AAClB;QAED,MAAM,cAAc,GAAG,iBAAiB,CAAC;YACrC,QAAQ;YACR,oBAAoB;YACpB,aAAa;YACb,sBAAsB;AACzB,SAAA,CAAC;;AAGF,QAAA,IACI,CAAC,cAAc,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,cAAc,CAAC,UAAU,CAAC,GAAG,CAAC;AACjE,YAAA,cAAc,CAAC,MAAM,IAAI,EAAE,EAC7B;AACE,YAAA,MAAM,MAAM,GAAG,aAAa,CAAC,CAAA,EAAA,EAAK,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAE,CAAA,EAAE,IAAI,EAAE,MAAM,CAAC;YAE1E,OAAO,MAAM,CAAC,cAAc;AAC/B;;AAGD,QAAA,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE;AAC3D,YAAA,OAAO,aAAa;AACvB;;AAGD,QAAA,IAAI,CAAC,oBAAoB,IAAI,CAAC,cAAc,EAAE;YAC1C,gBAAgB,CAAC,EAAE,QAAQ,EAAE,aAAa,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC;YAE9D,OAAO,QAAQ,CAAC,MAAM,GAAG,KAAK,GAAG,aAAa;AACjD;AAED,QAAA,OAAO,cAAc;AACzB,KAAC,EACD,CAAC,oBAAoB,CAAC,CACzB;IAED,QACI,oBAAC,WAAW,EAAA,EAAA,GACJ,SAAS,EACb,YAAY,EAAE,oBAAoB,GAAG,SAAS,CAAC,YAAY,GAAG,aAAa,EAC3E,IAAI,EAAE,IAAI,EACV,eAAe,EAAE,mBAAmB,EACpC,IAAI,EAAC,KAAK,EACV,GAAG,EAAE,SAAS,CAAC,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC,EAAA,CACjC;AAEV,CAAC;AAGL,UAAU,CAAC,WAAW,GAAG,aAAa;;;;"}
package/modern/index.d.ts CHANGED
@@ -1 +1 @@
1
- export * from "./Component";
1
+ export * from './Component';
package/modern/index.js CHANGED
@@ -1 +1,2 @@
1
1
  export { PhoneInput } from './Component.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -3,5 +3,4 @@
3
3
  * @description +7 123 => paste 222 => +2227 123
4
4
  * @description +7 123 => paste 222 => 222+7 123
5
5
  */
6
- declare const checkInsertBefore: (baseNumber: string | undefined, modifiedNumber: string) => boolean;
7
- export { checkInsertBefore };
6
+ export declare const checkInsertBefore: (baseNumber: string | undefined, modifiedNumber: string) => boolean;
@@ -38,3 +38,4 @@ const checkInsertBefore = (baseNumber, modifiedNumber) => {
38
38
  };
39
39
 
40
40
  export { checkInsertBefore };
41
+ //# sourceMappingURL=check-insert-before.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"check-insert-before.js","sources":["../../src/utils/check-insert-before.ts"],"sourcesContent":["/**\n * Позволяет проверить что цифры были вставлены до или после знака плюс [+]\n * @description +7 123 => paste 222 => +2227 123\n * @description +7 123 => paste 222 => 222+7 123\n */\nexport const checkInsertBefore = (baseNumber: string | undefined, modifiedNumber: string) => {\n if (baseNumber) {\n try {\n /** Удаляем лишние символы */\n // +7 123 => 7123\n const base = baseNumber.replace(/\\s+/g, '').replace('+', '');\n // +7 123 => +7123\n const modified = modifiedNumber.replace(/\\s+/g, '');\n\n /**\n * Числа вставлены между [+] и номером\n * +7 123 => paste 222 => +2227 123\n */\n const afterPlusPattern = new RegExp(`^\\\\+\\\\d*${base}$`);\n\n if (afterPlusPattern.test(modified)) {\n return true;\n }\n\n /**\n * Числа вставлены перед [+]\n * +7 123 => paste 222 => 222+7 123\n */\n const beforePlusPattern = new RegExp(`^\\\\d*\\\\+${base}$`);\n\n if (beforePlusPattern.test(modified)) {\n return true;\n }\n\n return false;\n } catch (e) {\n // eslint-disable-next-line no-console\n console.error('checkInsertAtBeginning', e);\n }\n }\n\n return false;\n};\n"],"names":[],"mappings":"AAAA;;;;AAIG;MACU,iBAAiB,GAAG,CAAC,UAA8B,EAAE,cAAsB,KAAI;AACxF,IAAA,IAAI,UAAU,EAAE;QACZ,IAAI;;;AAGA,YAAA,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC;;YAE5D,MAAM,QAAQ,GAAG,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;AAEnD;;;AAGG;YACH,MAAM,gBAAgB,GAAG,IAAI,MAAM,CAAC,CAAW,QAAA,EAAA,IAAI,CAAG,CAAA,CAAA,CAAC;AAEvD,YAAA,IAAI,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;AACjC,gBAAA,OAAO,IAAI;AACd;AAED;;;AAGG;YACH,MAAM,iBAAiB,GAAG,IAAI,MAAM,CAAC,CAAW,QAAA,EAAA,IAAI,CAAG,CAAA,CAAA,CAAC;AAExD,YAAA,IAAI,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;AAClC,gBAAA,OAAO,IAAI;AACd;AAED,YAAA,OAAO,KAAK;AACf;AAAC,QAAA,OAAO,CAAC,EAAE;;AAER,YAAA,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,CAAC,CAAC;AAC7C;AACJ;AAED,IAAA,OAAO,KAAK;AAChB;;;;"}
@@ -1,18 +1,17 @@
1
- /// <reference types="react" />
2
1
  /**
3
2
  * Удаляет форматирование номера телефона
4
3
  * @param phone Номер телефона
5
4
  */
6
- declare const deleteFormatting: (phone: string) => string;
7
- declare function setCaretPosition({ position, inputRef, }: {
5
+ /// <reference types="react" />
6
+ export declare const deleteFormatting: (phone: string) => string;
7
+ export declare function setCaretPosition({ position, inputRef, }: {
8
8
  position: number;
9
9
  inputRef: React.RefObject<HTMLInputElement>;
10
10
  }): void;
11
- declare function getInsertedNumber({ rawValue, clearableCountryCode, countryPrefix, previousConformedValue, }: {
11
+ export declare function getInsertedNumber({ rawValue, clearableCountryCode, countryPrefix, previousConformedValue, }: {
12
12
  rawValue: string;
13
13
  clearableCountryCode: boolean;
14
14
  countryPrefix: string;
15
15
  previousConformedValue: string;
16
16
  }): string;
17
- declare function deleteMaskChar(previousValue: string, rawValue: string): string;
18
- export { deleteFormatting, setCaretPosition, getInsertedNumber, deleteMaskChar };
17
+ export declare function deleteMaskChar(previousValue: string, rawValue: string): string;
@@ -37,3 +37,4 @@ function deleteMaskChar(previousValue, rawValue) {
37
37
  }
38
38
 
39
39
  export { deleteFormatting, deleteMaskChar, getInsertedNumber, setCaretPosition };
40
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/utils/index.ts"],"sourcesContent":["/**\n * Удаляет форматирование номера телефона\n * @param phone Номер телефона\n */\n\nexport const deleteFormatting = (phone: string) =>\n phone.replace('+', '').replace(/^7/, '').replace(/\\s/g, '');\n\nexport function setCaretPosition({\n position,\n inputRef,\n}: {\n position: number;\n inputRef: React.RefObject<HTMLInputElement>;\n}) {\n window.requestAnimationFrame(() => {\n if (inputRef === null || !inputRef.current) return;\n\n inputRef.current.setSelectionRange(position, position);\n });\n}\n\nexport function getInsertedNumber({\n rawValue,\n clearableCountryCode,\n countryPrefix,\n previousConformedValue,\n}: {\n rawValue: string;\n clearableCountryCode: boolean;\n countryPrefix: string;\n previousConformedValue: string;\n}) {\n if (!clearableCountryCode && previousConformedValue === countryPrefix) {\n if (rawValue.startsWith('7') || rawValue.startsWith('8')) {\n return rawValue;\n }\n\n return rawValue.slice(countryPrefix.length);\n }\n\n return rawValue;\n}\n\nexport function deleteMaskChar(previousValue: string, rawValue: string) {\n const prevRawValueAsArr = deleteFormatting(rawValue).split('').reverse();\n let prevConformedCharIdx = previousValue.length - 1;\n let isMaskRemoved = false;\n const newRaw: string[] = [];\n\n prevRawValueAsArr.forEach((char) => {\n if (isMaskRemoved || char === previousValue[prevConformedCharIdx]) {\n newRaw.push(char);\n prevConformedCharIdx -= 1;\n } else if (char === '7') {\n isMaskRemoved = true;\n }\n });\n\n return newRaw.reverse().join('');\n}\n"],"names":[],"mappings":"AAAA;;;AAGG;AAEI,MAAM,gBAAgB,GAAG,CAAC,KAAa,KAC1C,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE;SAE9C,gBAAgB,CAAC,EAC7B,QAAQ,EACR,QAAQ,GAIX,EAAA;AACG,IAAA,MAAM,CAAC,qBAAqB,CAAC,MAAK;AAC9B,QAAA,IAAI,QAAQ,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO;YAAE;QAE5C,QAAQ,CAAC,OAAO,CAAC,iBAAiB,CAAC,QAAQ,EAAE,QAAQ,CAAC;AAC1D,KAAC,CAAC;AACN;AAEM,SAAU,iBAAiB,CAAC,EAC9B,QAAQ,EACR,oBAAoB,EACpB,aAAa,EACb,sBAAsB,GAMzB,EAAA;AACG,IAAA,IAAI,CAAC,oBAAoB,IAAI,sBAAsB,KAAK,aAAa,EAAE;AACnE,QAAA,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;AACtD,YAAA,OAAO,QAAQ;AAClB;QAED,OAAO,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC;AAC9C;AAED,IAAA,OAAO,QAAQ;AACnB;AAEgB,SAAA,cAAc,CAAC,aAAqB,EAAE,QAAgB,EAAA;AAClE,IAAA,MAAM,iBAAiB,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE;AACxE,IAAA,IAAI,oBAAoB,GAAG,aAAa,CAAC,MAAM,GAAG,CAAC;IACnD,IAAI,aAAa,GAAG,KAAK;IACzB,MAAM,MAAM,GAAa,EAAE;AAE3B,IAAA,iBAAiB,CAAC,OAAO,CAAC,CAAC,IAAI,KAAI;QAC/B,IAAI,aAAa,IAAI,IAAI,KAAK,aAAa,CAAC,oBAAoB,CAAC,EAAE;AAC/D,YAAA,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;YACjB,oBAAoB,IAAI,CAAC;AAC5B;aAAM,IAAI,IAAI,KAAK,GAAG,EAAE;YACrB,aAAa,GAAG,IAAI;AACvB;AACL,KAAC,CAAC;IAEF,OAAO,MAAM,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;AACpC;;;;"}
@@ -1,10 +1,8 @@
1
- /// <reference types="react" />
2
1
  import React from 'react';
3
- import { MaskedInputProps } from "@alfalab/core-components-masked-input";
4
- type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {
2
+ import { MaskedInputProps } from '@alfalab/core-components-masked-input';
3
+ export declare type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {
5
4
  clearableCountryCode?: boolean;
6
5
  };
7
- declare const PhoneInput: React.ForwardRefExoticComponent<Omit<MaskedInputProps, "mask" | "type" | "onBeforeDisplay"> & {
6
+ export declare const PhoneInput: React.ForwardRefExoticComponent<Omit<MaskedInputProps, "type" | "onBeforeDisplay" | "mask"> & {
8
7
  clearableCountryCode?: boolean | undefined;
9
8
  } & React.RefAttributes<HTMLInputElement>>;
10
- export { PhoneInputProps, PhoneInput };
@@ -103,3 +103,4 @@ const PhoneInput = React.forwardRef(({ clearableCountryCode = true, ...restProps
103
103
  PhoneInput.displayName = 'PhoneInputs';
104
104
 
105
105
  export { PhoneInput };
106
+ //# sourceMappingURL=Component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Component.js","sources":["../src/Component.tsx"],"sourcesContent":["/* eslint-disable complexity, no-param-reassign */\nimport React, { useCallback, useRef } from 'react';\nimport mergeRefs from 'react-merge-refs';\nimport { conformToMask, TextMaskConfig } from 'text-mask-core';\n\nimport { MaskedInput, MaskedInputProps } from '@alfalab/core-components-masked-input';\n\nimport { checkInsertBefore } from './utils/check-insert-before';\nimport { deleteFormatting, deleteMaskChar, getInsertedNumber, setCaretPosition } from './utils';\n\nconst mask = [\n '+',\n '7',\n ' ',\n /([0-6]|[8-9])/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n];\n\nconst countryPrefix = '+7 ';\n\nexport type PhoneInputProps = Omit<MaskedInputProps, 'onBeforeDisplay' | 'type' | 'mask'> & {\n clearableCountryCode?: boolean;\n};\n\nexport const PhoneInput = React.forwardRef<HTMLInputElement, PhoneInputProps>(\n ({ clearableCountryCode = true, ...restProps }, ref) => {\n const inputRef = useRef<HTMLInputElement>(null);\n\n const handleBeforeDisplay = useCallback(\n (conformedValue: string, config: TextMaskConfig) => {\n const { rawValue, previousConformedValue, currentCaretPosition } = config;\n\n const previousValueWithoutFormatting = previousConformedValue\n ? deleteFormatting(previousConformedValue)\n : '';\n\n // Вставка номера с 10 или 11 цифрами без кода страны\n const digits = rawValue.replace(/\\D/g, '');\n\n if ((digits.length === 10 || digits.length === 11) && !rawValue.startsWith('+7')) {\n let processedDigits = digits;\n\n if (\n digits.length === 11 &&\n (digits.startsWith('7') || digits.startsWith('8'))\n ) {\n processedDigits = digits.slice(1);\n }\n const masked = conformToMask(`+7${processedDigits}`, mask, config);\n\n return masked.conformedValue;\n }\n\n /*\n * Удаляем лишний символ маски при вводе или вставке значений перед знаком + или после него.\n */\n if (checkInsertBefore(previousConformedValue, rawValue)) {\n const newRaw = deleteMaskChar(previousValueWithoutFormatting, rawValue);\n\n conformedValue = conformToMask(newRaw, mask, config).conformedValue;\n }\n\n const currentValueWithoutFormatting = deleteFormatting(conformedValue) || '';\n\n /*\n * код ниже нужен для фикса следующих багов библиотеки text-mask:\n * 1) так как код страны указан в маске жестко как \"+7\",\n * то при удалении цифры перед ним каретка устанавливается перед кодом страны\n * 2) в номере телефона есть пробелы и дефисы,\n * при редактировании цифр рядом с этими символами каретка перескакивает через них,\n * а не остается на том же месте, на котором была до редактирования\n */\n if (\n previousConformedValue &&\n (([3, 6].includes(currentCaretPosition) &&\n Math.abs(\n previousValueWithoutFormatting.length -\n currentValueWithoutFormatting.length,\n ) === 1) ||\n ([7, 10, 13].includes(currentCaretPosition) &&\n previousConformedValue.length > currentCaretPosition))\n ) {\n setCaretPosition({ position: currentCaretPosition, inputRef });\n }\n\n // // В режиме clearableCountryCode удаляет лишний пробел, чтобы можно было стереть код города.\n if (rawValue === '+7' && conformedValue === '' && clearableCountryCode) {\n setCaretPosition({ position: countryPrefix.length - 1, inputRef });\n }\n\n // Удаление цифры перед кодом страны удаляет только саму цифру, код остается (\"+7 1\" -> \"+7 \")\n if (rawValue === countryPrefix) {\n return rawValue;\n }\n\n const insertedNumber = getInsertedNumber({\n rawValue,\n clearableCountryCode,\n countryPrefix,\n previousConformedValue,\n });\n\n // Вставка номера, начинающегося с 8 или 7: 89990313131, 71112223344\n if (\n (insertedNumber.startsWith('7') || insertedNumber.startsWith('8')) &&\n insertedNumber.length >= 10\n ) {\n const masked = conformToMask(`+7${insertedNumber.slice(1)}`, mask, config);\n\n return masked.conformedValue;\n }\n\n // Если ввод начат с 7 или 8 - выводит \"+7 \" и дает продолжить ввод со след. цифры\n if (rawValue.length === 1 && ['7', '8'].includes(rawValue[0])) {\n return countryPrefix;\n }\n\n // Запрет на удаление кода страны\n if (!clearableCountryCode && !conformedValue) {\n setCaretPosition({ position: countryPrefix.length, inputRef });\n\n return rawValue.length ? false : countryPrefix;\n }\n\n return conformedValue;\n },\n [clearableCountryCode],\n );\n\n return (\n <MaskedInput\n {...restProps}\n defaultValue={clearableCountryCode ? restProps.defaultValue : countryPrefix}\n mask={mask}\n onBeforeDisplay={handleBeforeDisplay}\n type='tel'\n ref={mergeRefs([ref, inputRef])}\n />\n );\n },\n);\n\nPhoneInput.displayName = 'PhoneInputs';\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- export * from "./Component";
1
+ export * from './Component';
@@ -1 +1,2 @@
1
1
  export { PhoneInput } from './Component.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -3,5 +3,4 @@
3
3
  * @description +7 123 => paste 222 => +2227 123
4
4
  * @description +7 123 => paste 222 => 222+7 123
5
5
  */
6
- declare const checkInsertBefore: (baseNumber: string | undefined, modifiedNumber: string) => boolean;
7
- export { checkInsertBefore };
6
+ export declare const checkInsertBefore: (baseNumber: string | undefined, modifiedNumber: string) => boolean;
@@ -38,3 +38,4 @@ const checkInsertBefore = (baseNumber, modifiedNumber) => {
38
38
  };
39
39
 
40
40
  export { checkInsertBefore };
41
+ //# sourceMappingURL=check-insert-before.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"check-insert-before.js","sources":["../../src/utils/check-insert-before.ts"],"sourcesContent":["/**\n * Позволяет проверить что цифры были вставлены до или после знака плюс [+]\n * @description +7 123 => paste 222 => +2227 123\n * @description +7 123 => paste 222 => 222+7 123\n */\nexport const checkInsertBefore = (baseNumber: string | undefined, modifiedNumber: string) => {\n if (baseNumber) {\n try {\n /** Удаляем лишние символы */\n // +7 123 => 7123\n const base = baseNumber.replace(/\\s+/g, '').replace('+', '');\n // +7 123 => +7123\n const modified = modifiedNumber.replace(/\\s+/g, '');\n\n /**\n * Числа вставлены между [+] и номером\n * +7 123 => paste 222 => +2227 123\n */\n const afterPlusPattern = new RegExp(`^\\\\+\\\\d*${base}$`);\n\n if (afterPlusPattern.test(modified)) {\n return true;\n }\n\n /**\n * Числа вставлены перед [+]\n * +7 123 => paste 222 => 222+7 123\n */\n const beforePlusPattern = new RegExp(`^\\\\d*\\\\+${base}$`);\n\n if (beforePlusPattern.test(modified)) {\n return true;\n }\n\n return false;\n } catch (e) {\n // eslint-disable-next-line no-console\n console.error('checkInsertAtBeginning', e);\n }\n }\n\n return false;\n};\n"],"names":[],"mappings":"AAAA;;;;AAIG;MACU,iBAAiB,GAAG,CAAC,UAA8B,EAAE,cAAsB,KAAI;AACxF,IAAA,IAAI,UAAU,EAAE;QACZ,IAAI;;;AAGA,YAAA,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC;;YAE5D,MAAM,QAAQ,GAAG,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;AAEnD;;;AAGG;YACH,MAAM,gBAAgB,GAAG,IAAI,MAAM,CAAC,CAAW,QAAA,EAAA,IAAI,CAAG,CAAA,CAAA,CAAC;AAEvD,YAAA,IAAI,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;AACjC,gBAAA,OAAO,IAAI;AACd;AAED;;;AAGG;YACH,MAAM,iBAAiB,GAAG,IAAI,MAAM,CAAC,CAAW,QAAA,EAAA,IAAI,CAAG,CAAA,CAAA,CAAC;AAExD,YAAA,IAAI,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;AAClC,gBAAA,OAAO,IAAI;AACd;AAED,YAAA,OAAO,KAAK;AACf;AAAC,QAAA,OAAO,CAAC,EAAE;;AAER,YAAA,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,CAAC,CAAC;AAC7C;AACJ;AAED,IAAA,OAAO,KAAK;AAChB;;;;"}
@@ -1,18 +1,17 @@
1
- /// <reference types="react" />
2
1
  /**
3
2
  * Удаляет форматирование номера телефона
4
3
  * @param phone Номер телефона
5
4
  */
6
- declare const deleteFormatting: (phone: string) => string;
7
- declare function setCaretPosition({ position, inputRef, }: {
5
+ /// <reference types="react" />
6
+ export declare const deleteFormatting: (phone: string) => string;
7
+ export declare function setCaretPosition({ position, inputRef, }: {
8
8
  position: number;
9
9
  inputRef: React.RefObject<HTMLInputElement>;
10
10
  }): void;
11
- declare function getInsertedNumber({ rawValue, clearableCountryCode, countryPrefix, previousConformedValue, }: {
11
+ export declare function getInsertedNumber({ rawValue, clearableCountryCode, countryPrefix, previousConformedValue, }: {
12
12
  rawValue: string;
13
13
  clearableCountryCode: boolean;
14
14
  countryPrefix: string;
15
15
  previousConformedValue: string;
16
16
  }): string;
17
- declare function deleteMaskChar(previousValue: string, rawValue: string): string;
18
- export { deleteFormatting, setCaretPosition, getInsertedNumber, deleteMaskChar };
17
+ export declare function deleteMaskChar(previousValue: string, rawValue: string): string;
@@ -37,3 +37,4 @@ function deleteMaskChar(previousValue, rawValue) {
37
37
  }
38
38
 
39
39
  export { deleteFormatting, deleteMaskChar, getInsertedNumber, setCaretPosition };
40
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/utils/index.ts"],"sourcesContent":["/**\n * Удаляет форматирование номера телефона\n * @param phone Номер телефона\n */\n\nexport const deleteFormatting = (phone: string) =>\n phone.replace('+', '').replace(/^7/, '').replace(/\\s/g, '');\n\nexport function setCaretPosition({\n position,\n inputRef,\n}: {\n position: number;\n inputRef: React.RefObject<HTMLInputElement>;\n}) {\n window.requestAnimationFrame(() => {\n if (inputRef === null || !inputRef.current) return;\n\n inputRef.current.setSelectionRange(position, position);\n });\n}\n\nexport function getInsertedNumber({\n rawValue,\n clearableCountryCode,\n countryPrefix,\n previousConformedValue,\n}: {\n rawValue: string;\n clearableCountryCode: boolean;\n countryPrefix: string;\n previousConformedValue: string;\n}) {\n if (!clearableCountryCode && previousConformedValue === countryPrefix) {\n if (rawValue.startsWith('7') || rawValue.startsWith('8')) {\n return rawValue;\n }\n\n return rawValue.slice(countryPrefix.length);\n }\n\n return rawValue;\n}\n\nexport function deleteMaskChar(previousValue: string, rawValue: string) {\n const prevRawValueAsArr = deleteFormatting(rawValue).split('').reverse();\n let prevConformedCharIdx = previousValue.length - 1;\n let isMaskRemoved = false;\n const newRaw: string[] = [];\n\n prevRawValueAsArr.forEach((char) => {\n if (isMaskRemoved || char === previousValue[prevConformedCharIdx]) {\n newRaw.push(char);\n prevConformedCharIdx -= 1;\n } else if (char === '7') {\n isMaskRemoved = true;\n }\n });\n\n return newRaw.reverse().join('');\n}\n"],"names":[],"mappings":"AAAA;;;AAGG;AAEI,MAAM,gBAAgB,GAAG,CAAC,KAAa,KAC1C,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE;SAE9C,gBAAgB,CAAC,EAC7B,QAAQ,EACR,QAAQ,GAIX,EAAA;AACG,IAAA,MAAM,CAAC,qBAAqB,CAAC,MAAK;AAC9B,QAAA,IAAI,QAAQ,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO;YAAE;QAE5C,QAAQ,CAAC,OAAO,CAAC,iBAAiB,CAAC,QAAQ,EAAE,QAAQ,CAAC;AAC1D,KAAC,CAAC;AACN;AAEM,SAAU,iBAAiB,CAAC,EAC9B,QAAQ,EACR,oBAAoB,EACpB,aAAa,EACb,sBAAsB,GAMzB,EAAA;AACG,IAAA,IAAI,CAAC,oBAAoB,IAAI,sBAAsB,KAAK,aAAa,EAAE;AACnE,QAAA,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;AACtD,YAAA,OAAO,QAAQ;AAClB;QAED,OAAO,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC;AAC9C;AAED,IAAA,OAAO,QAAQ;AACnB;AAEgB,SAAA,cAAc,CAAC,aAAqB,EAAE,QAAgB,EAAA;AAClE,IAAA,MAAM,iBAAiB,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE;AACxE,IAAA,IAAI,oBAAoB,GAAG,aAAa,CAAC,MAAM,GAAG,CAAC;IACnD,IAAI,aAAa,GAAG,KAAK;IACzB,MAAM,MAAM,GAAa,EAAE;AAE3B,IAAA,iBAAiB,CAAC,OAAO,CAAC,CAAC,IAAI,KAAI;QAC/B,IAAI,aAAa,IAAI,IAAI,KAAK,aAAa,CAAC,oBAAoB,CAAC,EAAE;AAC/D,YAAA,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;YACjB,oBAAoB,IAAI,CAAC;AAC5B;aAAM,IAAI,IAAI,KAAK,GAAG,EAAE;YACrB,aAAa,GAAG,IAAI;AACvB;AACL,KAAC,CAAC;IAEF,OAAO,MAAM,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;AACpC;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alfalab/core-components-phone-input",
3
- "version": "7.5.8",
3
+ "version": "8.0.0-snapshot-6a9d3fc",
4
4
  "description": "",
5
5
  "keywords": [],
6
6
  "license": "MIT",
@@ -12,14 +12,15 @@
12
12
  },
13
13
  "sideEffects": false,
14
14
  "peerDependencies": {
15
- "react": "^16.9.0 || ^17.0.1 || ^18.0.0"
15
+ "react": "^16.9.0 || ^17.0.1 || ^18.0.0",
16
+ "react-dom": "^16.9.0 || ^17.0.1 || ^18.0.0"
16
17
  },
17
18
  "dependencies": {
18
- "@alfalab/core-components-masked-input": "^6.3.39",
19
+ "@alfalab/core-components-masked-input": "7.0.0-snapshot-6a9d3fc",
19
20
  "react-merge-refs": "^1.1.0",
20
21
  "text-mask-core": "^5.1.2",
21
22
  "tslib": "^2.4.0"
22
23
  },
23
- "themesVersion": "13.7.4",
24
- "varsVersion": "9.20.1"
24
+ "themesVersion": "14.0.0-snapshot-6a9d3fc",
25
+ "varsVersion": "10.0.0-snapshot-6a9d3fc"
25
26
  }
@@ -0,0 +1,44 @@
1
+ declare module 'text-mask-core' {
2
+ export type Mask = Array<string | RegExp>;
3
+
4
+ export type TextMaskConfig = {
5
+ currentCaretPosition: number;
6
+ rawValue: string;
7
+ previousConformedValue: string;
8
+ mask?: Mask | ((rawValue: string) => Mask);
9
+ guide?: boolean;
10
+ showMask?: boolean;
11
+ placeholderChar?: string;
12
+ keepCharPositions?: boolean;
13
+ pipe?: (
14
+ conformedValue: string,
15
+ config: TextMaskConfig,
16
+ ) => false | string | { value: string; indexesOfPipedChars: number[] };
17
+ };
18
+
19
+ export type TextMaskInputElement = {
20
+ state: { previousConformedValue: string; previousPlaceholder: string };
21
+ update: (
22
+ rawValue?: string,
23
+ textMaskConfig?: TextMaskConfig & { inputElement: HTMLInputElement },
24
+ ) => void;
25
+ };
26
+
27
+ export function createTextMaskInputElement(
28
+ config: TextMaskConfig & { inputElement: HTMLInputElement },
29
+ ): TextMaskInputElement;
30
+
31
+ export function conformToMask(
32
+ text: string,
33
+ mask: Mask | ((rawValue: string) => Mask),
34
+ config?: TextMaskConfig,
35
+ ): conformToMaskResult;
36
+
37
+ // eslint-disable-next-line @typescript-eslint/naming-convention
38
+ export type conformToMaskResult = {
39
+ conformedValue: string;
40
+ meta: {
41
+ someCharsRejected: boolean;
42
+ };
43
+ };
44
+ }
@@ -3,5 +3,4 @@
3
3
  * @description +7 123 => paste 222 => +2227 123
4
4
  * @description +7 123 => paste 222 => 222+7 123
5
5
  */
6
- declare const checkInsertBefore: (baseNumber: string | undefined, modifiedNumber: string) => boolean;
7
- export { checkInsertBefore };
6
+ export declare const checkInsertBefore: (baseNumber: string | undefined, modifiedNumber: string) => boolean;
@@ -42,3 +42,4 @@ var checkInsertBefore = function (baseNumber, modifiedNumber) {
42
42
  };
43
43
 
44
44
  exports.checkInsertBefore = checkInsertBefore;
45
+ //# sourceMappingURL=check-insert-before.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"check-insert-before.js","sources":["../src/utils/check-insert-before.ts"],"sourcesContent":["/**\n * Позволяет проверить что цифры были вставлены до или после знака плюс [+]\n * @description +7 123 => paste 222 => +2227 123\n * @description +7 123 => paste 222 => 222+7 123\n */\nexport const checkInsertBefore = (baseNumber: string | undefined, modifiedNumber: string) => {\n if (baseNumber) {\n try {\n /** Удаляем лишние символы */\n // +7 123 => 7123\n const base = baseNumber.replace(/\\s+/g, '').replace('+', '');\n // +7 123 => +7123\n const modified = modifiedNumber.replace(/\\s+/g, '');\n\n /**\n * Числа вставлены между [+] и номером\n * +7 123 => paste 222 => +2227 123\n */\n const afterPlusPattern = new RegExp(`^\\\\+\\\\d*${base}$`);\n\n if (afterPlusPattern.test(modified)) {\n return true;\n }\n\n /**\n * Числа вставлены перед [+]\n * +7 123 => paste 222 => 222+7 123\n */\n const beforePlusPattern = new RegExp(`^\\\\d*\\\\+${base}$`);\n\n if (beforePlusPattern.test(modified)) {\n return true;\n }\n\n return false;\n } catch (e) {\n // eslint-disable-next-line no-console\n console.error('checkInsertAtBeginning', e);\n }\n }\n\n return false;\n};\n"],"names":[],"mappings":";;;;AAAA;;;;AAIG;AACU,IAAA,iBAAiB,GAAG,UAAC,UAA8B,EAAE,cAAsB,EAAA;AACpF,IAAA,IAAI,UAAU,EAAE;QACZ,IAAI;;;AAGA,YAAA,IAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC;;YAE5D,IAAM,QAAQ,GAAG,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;AAEnD;;;AAGG;YACH,IAAM,gBAAgB,GAAG,IAAI,MAAM,CAAC,UAAW,CAAA,MAAA,CAAA,IAAI,EAAG,GAAA,CAAA,CAAC;AAEvD,YAAA,IAAI,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;AACjC,gBAAA,OAAO,IAAI;AACd;AAED;;;AAGG;YACH,IAAM,iBAAiB,GAAG,IAAI,MAAM,CAAC,UAAW,CAAA,MAAA,CAAA,IAAI,EAAG,GAAA,CAAA,CAAC;AAExD,YAAA,IAAI,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;AAClC,gBAAA,OAAO,IAAI;AACd;AAED,YAAA,OAAO,KAAK;AACf;AAAC,QAAA,OAAO,CAAC,EAAE;;AAER,YAAA,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,CAAC,CAAC;AAC7C;AACJ;AAED,IAAA,OAAO,KAAK;AAChB;;;;"}
package/utils/index.d.ts CHANGED
@@ -1,18 +1,17 @@
1
- /// <reference types="react" />
2
1
  /**
3
2
  * Удаляет форматирование номера телефона
4
3
  * @param phone Номер телефона
5
4
  */
6
- declare const deleteFormatting: (phone: string) => string;
7
- declare function setCaretPosition({ position, inputRef, }: {
5
+ /// <reference types="react" />
6
+ export declare const deleteFormatting: (phone: string) => string;
7
+ export declare function setCaretPosition({ position, inputRef, }: {
8
8
  position: number;
9
9
  inputRef: React.RefObject<HTMLInputElement>;
10
10
  }): void;
11
- declare function getInsertedNumber({ rawValue, clearableCountryCode, countryPrefix, previousConformedValue, }: {
11
+ export declare function getInsertedNumber({ rawValue, clearableCountryCode, countryPrefix, previousConformedValue, }: {
12
12
  rawValue: string;
13
13
  clearableCountryCode: boolean;
14
14
  countryPrefix: string;
15
15
  previousConformedValue: string;
16
16
  }): string;
17
- declare function deleteMaskChar(previousValue: string, rawValue: string): string;
18
- export { deleteFormatting, setCaretPosition, getInsertedNumber, deleteMaskChar };
17
+ export declare function deleteMaskChar(previousValue: string, rawValue: string): string;
package/utils/index.js CHANGED
@@ -48,3 +48,4 @@ exports.deleteFormatting = deleteFormatting;
48
48
  exports.deleteMaskChar = deleteMaskChar;
49
49
  exports.getInsertedNumber = getInsertedNumber;
50
50
  exports.setCaretPosition = setCaretPosition;
51
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../src/utils/index.ts"],"sourcesContent":["/**\n * Удаляет форматирование номера телефона\n * @param phone Номер телефона\n */\n\nexport const deleteFormatting = (phone: string) =>\n phone.replace('+', '').replace(/^7/, '').replace(/\\s/g, '');\n\nexport function setCaretPosition({\n position,\n inputRef,\n}: {\n position: number;\n inputRef: React.RefObject<HTMLInputElement>;\n}) {\n window.requestAnimationFrame(() => {\n if (inputRef === null || !inputRef.current) return;\n\n inputRef.current.setSelectionRange(position, position);\n });\n}\n\nexport function getInsertedNumber({\n rawValue,\n clearableCountryCode,\n countryPrefix,\n previousConformedValue,\n}: {\n rawValue: string;\n clearableCountryCode: boolean;\n countryPrefix: string;\n previousConformedValue: string;\n}) {\n if (!clearableCountryCode && previousConformedValue === countryPrefix) {\n if (rawValue.startsWith('7') || rawValue.startsWith('8')) {\n return rawValue;\n }\n\n return rawValue.slice(countryPrefix.length);\n }\n\n return rawValue;\n}\n\nexport function deleteMaskChar(previousValue: string, rawValue: string) {\n const prevRawValueAsArr = deleteFormatting(rawValue).split('').reverse();\n let prevConformedCharIdx = previousValue.length - 1;\n let isMaskRemoved = false;\n const newRaw: string[] = [];\n\n prevRawValueAsArr.forEach((char) => {\n if (isMaskRemoved || char === previousValue[prevConformedCharIdx]) {\n newRaw.push(char);\n prevConformedCharIdx -= 1;\n } else if (char === '7') {\n isMaskRemoved = true;\n }\n });\n\n return newRaw.reverse().join('');\n}\n"],"names":[],"mappings":";;;;AAAA;;;AAGG;AAEI,IAAM,gBAAgB,GAAG,UAAC,KAAa,EAAA;IAC1C,OAAA,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;AAA3D;AAEE,SAAU,gBAAgB,CAAC,EAMhC,EAAA;QALG,QAAQ,GAAA,EAAA,CAAA,QAAA,EACR,QAAQ,GAAA,EAAA,CAAA,QAAA;IAKR,MAAM,CAAC,qBAAqB,CAAC,YAAA;AACzB,QAAA,IAAI,QAAQ,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO;YAAE;QAE5C,QAAQ,CAAC,OAAO,CAAC,iBAAiB,CAAC,QAAQ,EAAE,QAAQ,CAAC;AAC1D,KAAC,CAAC;AACN;AAEM,SAAU,iBAAiB,CAAC,EAUjC,EAAA;QATG,QAAQ,GAAA,EAAA,CAAA,QAAA,EACR,oBAAoB,GAAA,EAAA,CAAA,oBAAA,EACpB,aAAa,GAAA,EAAA,CAAA,aAAA,EACb,sBAAsB,GAAA,EAAA,CAAA,sBAAA;AAOtB,IAAA,IAAI,CAAC,oBAAoB,IAAI,sBAAsB,KAAK,aAAa,EAAE;AACnE,QAAA,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;AACtD,YAAA,OAAO,QAAQ;AAClB;QAED,OAAO,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC;AAC9C;AAED,IAAA,OAAO,QAAQ;AACnB;AAEgB,SAAA,cAAc,CAAC,aAAqB,EAAE,QAAgB,EAAA;AAClE,IAAA,IAAM,iBAAiB,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE;AACxE,IAAA,IAAI,oBAAoB,GAAG,aAAa,CAAC,MAAM,GAAG,CAAC;IACnD,IAAI,aAAa,GAAG,KAAK;IACzB,IAAM,MAAM,GAAa,EAAE;AAE3B,IAAA,iBAAiB,CAAC,OAAO,CAAC,UAAC,IAAI,EAAA;QAC3B,IAAI,aAAa,IAAI,IAAI,KAAK,aAAa,CAAC,oBAAoB,CAAC,EAAE;AAC/D,YAAA,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;YACjB,oBAAoB,IAAI,CAAC;AAC5B;aAAM,IAAI,IAAI,KAAK,GAAG,EAAE;YACrB,aAAa,GAAG,IAAI;AACvB;AACL,KAAC,CAAC;IAEF,OAAO,MAAM,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;AACpC;;;;;;;"}