@taiga-ui/kit 3.29.2 → 3.30.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taiga-ui-kit-components-input-phone.umd.js +140 -94
- package/bundles/taiga-ui-kit-components-input-phone.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-tag.umd.js +25 -49
- package/bundles/taiga-ui-kit-components-input-tag.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-pdf-viewer.umd.js +8 -11
- package/bundles/taiga-ui-kit-components-pdf-viewer.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-progress.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-progress.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-push.umd.js +10 -15
- package/bundles/taiga-ui-kit-components-push.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-radio.umd.js +2 -3
- package/bundles/taiga-ui-kit-components-radio.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-tabs.umd.js +2 -2
- package/bundles/taiga-ui-kit-components-tabs.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-internal-primitive-calendar-range.umd.js +1 -1
- package/bundles/taiga-ui-kit-internal-primitive-calendar-range.umd.js.map +1 -1
- package/components/input-phone/input-phone.component.d.ts +8 -9
- package/components/input-phone/input-phone.module.d.ts +3 -2
- package/components/input-phone/utils/complete-phone-insertion-preprocessor.d.ts +9 -0
- package/components/input-phone/utils/create-phone-mask-expression.d.ts +7 -0
- package/components/input-phone/utils/index.d.ts +2 -0
- package/components/input-tag/input-tag.component.d.ts +5 -10
- package/components/pdf-viewer/pdf-viewer.component.d.ts +2 -9
- package/components/push/push-alert.component.d.ts +2 -9
- package/components/radio/radio.component.d.ts +2 -9
- package/esm2015/components/input-phone/input-phone.component.js +65 -88
- package/esm2015/components/input-phone/input-phone.directive.js +2 -2
- package/esm2015/components/input-phone/input-phone.module.js +6 -5
- package/esm2015/components/input-phone/utils/complete-phone-insertion-preprocessor.js +43 -0
- package/esm2015/components/input-phone/utils/create-phone-mask-expression.js +17 -0
- package/esm2015/components/input-phone/utils/index.js +3 -0
- package/esm2015/components/input-tag/input-tag.component.js +20 -39
- package/esm2015/components/pdf-viewer/pdf-viewer.component.js +10 -13
- package/esm2015/components/progress/progress-circle/progress-circle.component.js +1 -1
- package/esm2015/components/push/push-alert.component.js +12 -17
- package/esm2015/components/radio/radio.component.js +3 -4
- package/esm2015/components/tabs/tab/tab.component.js +1 -1
- package/esm2015/components/tabs/tabs-with-more/tabs-with-more.component.js +1 -1
- package/esm2015/internal/primitive-calendar-range/primitive-calendar-range.component.js +2 -2
- package/fesm2015/taiga-ui-kit-components-input-phone.js +129 -92
- package/fesm2015/taiga-ui-kit-components-input-phone.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-tag.js +20 -39
- package/fesm2015/taiga-ui-kit-components-input-tag.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-pdf-viewer.js +9 -12
- package/fesm2015/taiga-ui-kit-components-pdf-viewer.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-progress.js +1 -1
- package/fesm2015/taiga-ui-kit-components-progress.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-push.js +11 -16
- package/fesm2015/taiga-ui-kit-components-push.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-radio.js +2 -3
- package/fesm2015/taiga-ui-kit-components-radio.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-tabs.js +2 -2
- package/fesm2015/taiga-ui-kit-components-tabs.js.map +1 -1
- package/fesm2015/taiga-ui-kit-internal-primitive-calendar-range.js +1 -1
- package/fesm2015/taiga-ui-kit-internal-primitive-calendar-range.js.map +1 -1
- package/package.json +4 -4
|
@@ -1,17 +1,21 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, Inject, Input, Optional, Output, Self, TemplateRef, ViewChild, } from '@angular/core';
|
|
3
3
|
import { NgControl } from '@angular/forms';
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
4
|
+
import { MASKITO_DEFAULT_OPTIONS, maskitoTransform } from '@maskito/core';
|
|
5
|
+
import { maskitoPrefixPostprocessorGenerator } from '@maskito/kit';
|
|
6
|
+
import { AbstractTuiControl, tuiAsControl, tuiAsFocusableItemAccessor, tuiDefaultProp, TuiDestroyService, tuiIsNativeFocused, tuiPure, tuiRequiredSetter, } from '@taiga-ui/cdk';
|
|
7
|
+
import { TUI_MASK_SYMBOLS_REGEXP, TUI_SELECTION_STREAM, TUI_TEXTFIELD_CLEANER, tuiAsDataListHost, TuiDataListDirective, TuiHostedDropdownComponent, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core';
|
|
6
8
|
import { FIXED_DROPDOWN_CONTROLLER_PROVIDER } from '@taiga-ui/kit/providers';
|
|
7
9
|
import { takeUntil } from 'rxjs/operators';
|
|
8
10
|
import { TUI_INPUT_PHONE_OPTIONS } from './input-phone.options';
|
|
11
|
+
import { tuiCreateCompletePhoneInsertionPreprocessor, tuiCreatePhoneMaskExpression, } from './utils';
|
|
9
12
|
import * as i0 from "@angular/core";
|
|
10
13
|
import * as i1 from "@taiga-ui/core";
|
|
11
14
|
import * as i2 from "@taiga-ui/cdk";
|
|
12
15
|
import * as i3 from "@taiga-ui/kit/directives";
|
|
13
|
-
import * as i4 from "@angular
|
|
14
|
-
import * as i5 from "
|
|
16
|
+
import * as i4 from "@maskito/angular";
|
|
17
|
+
import * as i5 from "@angular/forms";
|
|
18
|
+
import * as i6 from "rxjs";
|
|
15
19
|
export class TuiInputPhoneComponent extends AbstractTuiControl {
|
|
16
20
|
constructor(control, destroy$, cdr, selection$, textfieldCleaner, options) {
|
|
17
21
|
super(control, cdr);
|
|
@@ -21,36 +25,16 @@ export class TuiInputPhoneComponent extends AbstractTuiControl {
|
|
|
21
25
|
this.allowText = this.options.allowText;
|
|
22
26
|
this.search = '';
|
|
23
27
|
this.searchChange = new EventEmitter();
|
|
24
|
-
this.textMaskOptions = {
|
|
25
|
-
mask: value => this.allowText && !this.value && isText(value) && value !== '+'
|
|
26
|
-
? false
|
|
27
|
-
: [
|
|
28
|
-
...this.countryCode.split(''),
|
|
29
|
-
' ',
|
|
30
|
-
...this.phoneMaskAfterCountryCode
|
|
31
|
-
.replace(/[^#\- ()]+/g, '')
|
|
32
|
-
.split('')
|
|
33
|
-
.map(item => (item === '#' ? /\d/ : item)),
|
|
34
|
-
],
|
|
35
|
-
pipe: value => {
|
|
36
|
-
if (this.allowText) {
|
|
37
|
-
return value;
|
|
38
|
-
}
|
|
39
|
-
return value === '' && this.focused && !this.readOnly
|
|
40
|
-
? `${this.countryCode} `
|
|
41
|
-
: value.replace(/-$/, '');
|
|
42
|
-
},
|
|
43
|
-
guide: false,
|
|
44
|
-
};
|
|
45
28
|
this.countryCode = this.options.countryCode;
|
|
46
29
|
this.open = false;
|
|
47
30
|
selection$.pipe(takeUntil(destroy$)).subscribe(() => {
|
|
48
31
|
this.setCaretPosition();
|
|
49
32
|
});
|
|
50
33
|
}
|
|
51
|
-
set countryCodeSetter(
|
|
52
|
-
this.
|
|
53
|
-
this.countryCode =
|
|
34
|
+
set countryCodeSetter(newCountryCode) {
|
|
35
|
+
const prevCountryCode = this.countryCode;
|
|
36
|
+
this.countryCode = newCountryCode;
|
|
37
|
+
this.updateValueWithNewCountryCode(prevCountryCode, newCountryCode);
|
|
54
38
|
}
|
|
55
39
|
get nativeFocusableElement() {
|
|
56
40
|
return !this.textfield || this.computedDisabled
|
|
@@ -61,10 +45,15 @@ export class TuiInputPhoneComponent extends AbstractTuiControl {
|
|
|
61
45
|
return (tuiIsNativeFocused(this.nativeFocusableElement) ||
|
|
62
46
|
(!!this.dropdown && this.dropdown.focused));
|
|
63
47
|
}
|
|
64
|
-
get
|
|
65
|
-
return this.
|
|
66
|
-
?
|
|
67
|
-
: this.
|
|
48
|
+
get nativeValue() {
|
|
49
|
+
return this.nativeFocusableElement
|
|
50
|
+
? this.nativeFocusableElement.value
|
|
51
|
+
: maskitoTransform(this.value, this.maskOptions);
|
|
52
|
+
}
|
|
53
|
+
set nativeValue(value) {
|
|
54
|
+
if (this.nativeFocusableElement) {
|
|
55
|
+
this.nativeFocusableElement.value = value;
|
|
56
|
+
}
|
|
68
57
|
}
|
|
69
58
|
get inputMode() {
|
|
70
59
|
return this.allowText ? 'text' : 'numeric';
|
|
@@ -73,39 +62,27 @@ export class TuiInputPhoneComponent extends AbstractTuiControl {
|
|
|
73
62
|
return this.interactive && !!this.datalist;
|
|
74
63
|
}
|
|
75
64
|
get canClean() {
|
|
76
|
-
return this.
|
|
65
|
+
return (this.nativeValue !== this.nonRemovablePrefix && this.textfieldCleaner.cleaner);
|
|
77
66
|
}
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
this.setValueWithoutPrefix(event.dataTransfer.getData('text'));
|
|
83
|
-
event.preventDefault();
|
|
84
|
-
}
|
|
85
|
-
onPaste(event) {
|
|
86
|
-
this.setValueWithoutPrefix(tuiGetClipboardDataText(event));
|
|
67
|
+
get maskOptions() {
|
|
68
|
+
return this.calculateMask(this.countryCode, this.phoneMaskAfterCountryCode, this.nonRemovablePrefix, this.allowText);
|
|
87
69
|
}
|
|
88
70
|
onActiveZone(active) {
|
|
89
71
|
this.updateFocused(active);
|
|
90
|
-
if (active && !this.
|
|
91
|
-
this.updateSearch(this.
|
|
72
|
+
if (active && !this.nativeValue && !this.readOnly && !this.allowText) {
|
|
73
|
+
this.updateSearch(this.nonRemovablePrefix);
|
|
74
|
+
this.nativeValue = this.nonRemovablePrefix;
|
|
92
75
|
return;
|
|
93
76
|
}
|
|
94
|
-
if (this.
|
|
95
|
-
(this.search !== null &&
|
|
96
|
-
Number.isNaN(parseInt(this.search.replace(TUI_MASK_SYMBOLS_REGEXP, ''), 10)))) {
|
|
77
|
+
if (this.nativeValue === this.nonRemovablePrefix || this.isTextValue) {
|
|
97
78
|
this.updateSearch('');
|
|
79
|
+
this.nativeValue = '';
|
|
98
80
|
}
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
const target = event.target;
|
|
102
|
-
if ((target.selectionStart || 0) <= this.nonRemovableLength &&
|
|
103
|
-
target.selectionStart === target.selectionEnd) {
|
|
104
|
-
event.preventDefault();
|
|
81
|
+
if (!active && !this.allowText && this.nativeFocusableElement) {
|
|
82
|
+
this.nativeValue = this.nativeValue.replace(/\D$/, '');
|
|
105
83
|
}
|
|
106
84
|
}
|
|
107
85
|
onValueChange(value) {
|
|
108
|
-
value = value === '' ? this.countryCode : value;
|
|
109
86
|
const parsed = isText(value)
|
|
110
87
|
? value
|
|
111
88
|
: value.replace(TUI_MASK_SYMBOLS_REGEXP, '').slice(0, this.maxPhoneLength);
|
|
@@ -116,6 +93,7 @@ export class TuiInputPhoneComponent extends AbstractTuiControl {
|
|
|
116
93
|
handleOption(item) {
|
|
117
94
|
this.focusInput();
|
|
118
95
|
this.value = item;
|
|
96
|
+
this.nativeValue = maskitoTransform(this.value, this.maskOptions);
|
|
119
97
|
this.updateSearch('');
|
|
120
98
|
this.open = false;
|
|
121
99
|
}
|
|
@@ -125,6 +103,7 @@ export class TuiInputPhoneComponent extends AbstractTuiControl {
|
|
|
125
103
|
}
|
|
126
104
|
writeValue(value) {
|
|
127
105
|
super.writeValue(value);
|
|
106
|
+
this.nativeValue = maskitoTransform(value || '', this.maskOptions);
|
|
128
107
|
this.updateSearch('');
|
|
129
108
|
}
|
|
130
109
|
getFallbackValue() {
|
|
@@ -141,8 +120,11 @@ export class TuiInputPhoneComponent extends AbstractTuiControl {
|
|
|
141
120
|
selectionStart < this.nonRemovableLength &&
|
|
142
121
|
selectionStart === selectionEnd);
|
|
143
122
|
}
|
|
123
|
+
get nonRemovablePrefix() {
|
|
124
|
+
return `${this.countryCode} `;
|
|
125
|
+
}
|
|
144
126
|
get nonRemovableLength() {
|
|
145
|
-
return this.isTextValue ? 0 : this.
|
|
127
|
+
return this.isTextValue ? 0 : this.nonRemovablePrefix.length;
|
|
146
128
|
}
|
|
147
129
|
get maxPhoneLength() {
|
|
148
130
|
return (this.countryCode.length +
|
|
@@ -151,36 +133,27 @@ export class TuiInputPhoneComponent extends AbstractTuiControl {
|
|
|
151
133
|
get isTextValue() {
|
|
152
134
|
return !!this.search && isText(this.search);
|
|
153
135
|
}
|
|
136
|
+
calculateMask(countryCode, phoneMaskAfterCountryCode, nonRemovablePrefix, allowText) {
|
|
137
|
+
const mask = tuiCreatePhoneMaskExpression(countryCode, phoneMaskAfterCountryCode);
|
|
138
|
+
const preprocessor = tuiCreateCompletePhoneInsertionPreprocessor(countryCode, phoneMaskAfterCountryCode);
|
|
139
|
+
return allowText
|
|
140
|
+
? {
|
|
141
|
+
mask: ({ value }) => isText(value) && value !== '+'
|
|
142
|
+
? MASKITO_DEFAULT_OPTIONS.mask
|
|
143
|
+
: mask,
|
|
144
|
+
preprocessor,
|
|
145
|
+
}
|
|
146
|
+
: {
|
|
147
|
+
mask,
|
|
148
|
+
preprocessor,
|
|
149
|
+
postprocessor: maskitoPrefixPostprocessorGenerator(nonRemovablePrefix),
|
|
150
|
+
};
|
|
151
|
+
}
|
|
154
152
|
setCaretPosition() {
|
|
155
153
|
if (this.caretIsInForbiddenArea && !!this.nativeFocusableElement) {
|
|
156
154
|
this.nativeFocusableElement.setSelectionRange(this.nonRemovableLength, this.nonRemovableLength);
|
|
157
155
|
}
|
|
158
156
|
}
|
|
159
|
-
setValueWithoutPrefix(value) {
|
|
160
|
-
if (this.readOnly) {
|
|
161
|
-
return;
|
|
162
|
-
}
|
|
163
|
-
this.open = true;
|
|
164
|
-
this.value = this.cleanValue(value);
|
|
165
|
-
this.updateSearch(this.allowText && isText(value)
|
|
166
|
-
? value
|
|
167
|
-
: value.replace(TUI_MASK_SYMBOLS_REGEXP, ''));
|
|
168
|
-
}
|
|
169
|
-
cleanValue(value) {
|
|
170
|
-
const reg = this.countryCode === '+7' ? /^7|^8/ : new RegExp(this.countryCode.slice(1));
|
|
171
|
-
const oldValueExist = this.value.length > this.countryCode.length &&
|
|
172
|
-
this.value.length < this.maxPhoneLength;
|
|
173
|
-
const newValueLength = value.replace(TUI_MASK_SYMBOLS_REGEXP, '').length;
|
|
174
|
-
const cleanNewValue = value.replace(/[^0-9]+/g, '');
|
|
175
|
-
const selectionLength = String(getSelection()).length;
|
|
176
|
-
if (oldValueExist && selectionLength === 0) {
|
|
177
|
-
return `${this.value}${cleanNewValue}`.slice(0, this.maxPhoneLength);
|
|
178
|
-
}
|
|
179
|
-
if (newValueLength < this.maxPhoneLength - 1) {
|
|
180
|
-
return `${this.countryCode}${cleanNewValue}`.slice(0, this.maxPhoneLength);
|
|
181
|
-
}
|
|
182
|
-
return `${this.countryCode}${cleanNewValue.replace(reg, '')}`.slice(0, this.maxPhoneLength);
|
|
183
|
-
}
|
|
184
157
|
focusInput() {
|
|
185
158
|
if (this.nativeFocusableElement) {
|
|
186
159
|
this.nativeFocusableElement.focus({ preventScroll: true });
|
|
@@ -193,9 +166,10 @@ export class TuiInputPhoneComponent extends AbstractTuiControl {
|
|
|
193
166
|
this.search = search;
|
|
194
167
|
this.searchChange.emit(search);
|
|
195
168
|
}
|
|
196
|
-
updateValueWithNewCountryCode(newCountryCode) {
|
|
169
|
+
updateValueWithNewCountryCode(prevCountryCode, newCountryCode) {
|
|
197
170
|
if (!this.isTextValue) {
|
|
198
|
-
this.value = this.value.replace(
|
|
171
|
+
this.value = this.value.replace(prevCountryCode, newCountryCode);
|
|
172
|
+
this.nativeValue = maskitoTransform(this.value, this.maskOptions);
|
|
199
173
|
}
|
|
200
174
|
}
|
|
201
175
|
}
|
|
@@ -205,7 +179,7 @@ TuiInputPhoneComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0",
|
|
|
205
179
|
tuiAsFocusableItemAccessor(TuiInputPhoneComponent),
|
|
206
180
|
tuiAsControl(TuiInputPhoneComponent),
|
|
207
181
|
tuiAsDataListHost(TuiInputPhoneComponent),
|
|
208
|
-
], queries: [{ propertyName: "datalist", first: true, predicate: TuiDataListDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "dropdown", first: true, predicate: TuiHostedDropdownComponent, descendants: true }, { propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-hosted-dropdown\n class=\"t-hosted\"\n [canOpen]=\"canOpen\"\n [content]=\"datalist || ''\"\n [(open)]=\"open\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n <tui-primitive-textfield\n tuiValueAccessor\n class=\"t-textfield\"\n [pseudoHover]=\"pseudoHover\"\n [pseudoFocus]=\"computedFocused\"\n [invalid]=\"computedInvalid\"\n [nativeId]=\"nativeId\"\n [readOnly]=\"readOnly\"\n [disabled]=\"computedDisabled\"\n [focusable]=\"focusable\"\n [
|
|
182
|
+
], queries: [{ propertyName: "datalist", first: true, predicate: TuiDataListDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "dropdown", first: true, predicate: TuiHostedDropdownComponent, descendants: true }, { propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-hosted-dropdown\n class=\"t-hosted\"\n [canOpen]=\"canOpen\"\n [content]=\"datalist || ''\"\n [(open)]=\"open\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n <tui-primitive-textfield\n tuiValueAccessor\n class=\"t-textfield\"\n [pseudoHover]=\"pseudoHover\"\n [pseudoFocus]=\"computedFocused\"\n [invalid]=\"computedInvalid\"\n [nativeId]=\"nativeId\"\n [readOnly]=\"readOnly\"\n [disabled]=\"computedDisabled\"\n [focusable]=\"focusable\"\n [maskito]=\"maskOptions\"\n [tuiTextfieldCleaner]=\"canClean\"\n [(value)]=\"nativeValue\"\n (valueChange)=\"onValueChange($event)\"\n >\n <ng-content></ng-content>\n <ng-content\n select=\"input\"\n ngProjectAs=\"input\"\n ></ng-content>\n </tui-primitive-textfield>\n</tui-hosted-dropdown>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}:host._disabled{pointer-events:none}.t-hosted{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}\n"], components: [{ type: i1.TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: ["content", "sided", "canOpen", "open"], outputs: ["openChange", "focusedChange"] }, { type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }], directives: [{ type: i2.TuiActiveZoneDirective, selector: "[tuiActiveZone]:not(ng-container), [tuiActiveZoneChange]:not(ng-container), [tuiActiveZoneParent]:not(ng-container)", inputs: ["tuiActiveZoneParent"], outputs: ["tuiActiveZoneChange"], exportAs: ["tuiActiveZone"] }, { type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i3.TuiValueAccessorDirective, selector: "[tuiValueAccessor]" }, { type: i4.MaskitoDirective, selector: "[maskito]", inputs: ["maskito", "maskitoElement"] }, { type: i1.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }], viewProviders: [FIXED_DROPDOWN_CONTROLLER_PROVIDER], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
209
183
|
__decorate([
|
|
210
184
|
tuiRequiredSetter()
|
|
211
185
|
], TuiInputPhoneComponent.prototype, "countryCodeSetter", null);
|
|
@@ -218,6 +192,9 @@ __decorate([
|
|
|
218
192
|
__decorate([
|
|
219
193
|
tuiDefaultProp()
|
|
220
194
|
], TuiInputPhoneComponent.prototype, "search", void 0);
|
|
195
|
+
__decorate([
|
|
196
|
+
tuiPure
|
|
197
|
+
], TuiInputPhoneComponent.prototype, "calculateMask", null);
|
|
221
198
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputPhoneComponent, decorators: [{
|
|
222
199
|
type: Component,
|
|
223
200
|
args: [{
|
|
@@ -233,14 +210,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
233
210
|
],
|
|
234
211
|
viewProviders: [FIXED_DROPDOWN_CONTROLLER_PROVIDER],
|
|
235
212
|
}]
|
|
236
|
-
}], ctorParameters: function () { return [{ type:
|
|
213
|
+
}], ctorParameters: function () { return [{ type: i5.NgControl, decorators: [{
|
|
237
214
|
type: Optional
|
|
238
215
|
}, {
|
|
239
216
|
type: Self
|
|
240
217
|
}, {
|
|
241
218
|
type: Inject,
|
|
242
219
|
args: [NgControl]
|
|
243
|
-
}] }, { type:
|
|
220
|
+
}] }, { type: i6.Observable, decorators: [{
|
|
244
221
|
type: Self
|
|
245
222
|
}, {
|
|
246
223
|
type: Inject,
|
|
@@ -248,7 +225,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
248
225
|
}] }, { type: i0.ChangeDetectorRef, decorators: [{
|
|
249
226
|
type: Inject,
|
|
250
227
|
args: [ChangeDetectorRef]
|
|
251
|
-
}] }, { type:
|
|
228
|
+
}] }, { type: i6.Observable, decorators: [{
|
|
252
229
|
type: Inject,
|
|
253
230
|
args: [TUI_SELECTION_STREAM]
|
|
254
231
|
}] }, { type: i1.TuiTextfieldCleanerDirective, decorators: [{
|
|
@@ -277,8 +254,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
277
254
|
}], datalist: [{
|
|
278
255
|
type: ContentChild,
|
|
279
256
|
args: [TuiDataListDirective, { read: TemplateRef }]
|
|
280
|
-
}] } });
|
|
257
|
+
}], calculateMask: [] } });
|
|
281
258
|
function isText(value) {
|
|
282
259
|
return Number.isNaN(parseInt(value.replace(TUI_MASK_SYMBOLS_REGEXP, ''), 10));
|
|
283
260
|
}
|
|
284
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-phone.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-phone/input-phone.component.ts","../../../../../projects/kit/components/input-phone/input-phone.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    EventEmitter,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiControl,\n    TuiActiveZoneDirective,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiDestroyService,\n    TuiFocusableElementAccessor,\n    tuiGetClipboardDataText,\n    TuiInputMode,\n    tuiIsNativeFocused,\n    tuiRequiredSetter,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_MASK_SYMBOLS_REGEXP,\n    TUI_SELECTION_STREAM,\n    TUI_TEXTFIELD_CLEANER,\n    tuiAsDataListHost,\n    TuiDataListDirective,\n    TuiDataListHost,\n    tuiFormatPhone,\n    TuiHostedDropdownComponent,\n    TuiPrimitiveTextfieldComponent,\n    TuiTextfieldCleanerDirective,\n    TuiTextMaskOptions,\n} from '@taiga-ui/core';\nimport {FIXED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {Observable} from 'rxjs';\nimport {takeUntil} from 'rxjs/operators';\n\nimport {TUI_INPUT_PHONE_OPTIONS, TuiInputPhoneOptions} from './input-phone.options';\n\n@Component({\n    selector: 'tui-input-phone',\n    templateUrl: './input-phone.template.html',\n    styleUrls: ['./input-phone.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        TuiDestroyService,\n        tuiAsFocusableItemAccessor(TuiInputPhoneComponent),\n        tuiAsControl(TuiInputPhoneComponent),\n        tuiAsDataListHost(TuiInputPhoneComponent),\n    ],\n    viewProviders: [FIXED_DROPDOWN_CONTROLLER_PROVIDER],\n})\nexport class TuiInputPhoneComponent\n    extends AbstractTuiControl<string>\n    implements TuiFocusableElementAccessor, TuiDataListHost<string>\n{\n    @ViewChild(TuiHostedDropdownComponent)\n    private readonly dropdown?: TuiHostedDropdownComponent;\n\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    @Input('countryCode')\n    @tuiRequiredSetter()\n    set countryCodeSetter(countryCode: string) {\n        this.updateValueWithNewCountryCode(countryCode);\n        this.countryCode = countryCode;\n    }\n\n    @Input()\n    @tuiDefaultProp()\n    phoneMaskAfterCountryCode = this.options.phoneMaskAfterCountryCode;\n\n    @Input()\n    @tuiDefaultProp()\n    allowText = this.options.allowText;\n\n    @Input()\n    @tuiDefaultProp()\n    search = '';\n\n    @Output()\n    readonly searchChange = new EventEmitter<string>();\n\n    @ContentChild(TuiDataListDirective, {read: TemplateRef})\n    readonly datalist?: TemplateRef<TuiContextWithImplicit<TuiActiveZoneDirective>>;\n\n    readonly textMaskOptions: TuiTextMaskOptions = {\n        mask: value =>\n            this.allowText && !this.value && isText(value) && value !== '+'\n                ? false\n                : [\n                      ...this.countryCode.split(''),\n                      ' ',\n                      ...this.phoneMaskAfterCountryCode\n                          .replace(/[^#\\- ()]+/g, '')\n                          .split('')\n                          .map(item => (item === '#' ? /\\d/ : item)),\n                  ],\n        pipe: value => {\n            if (this.allowText) {\n                return value;\n            }\n\n            return value === '' && this.focused && !this.readOnly\n                ? `${this.countryCode} `\n                : value.replace(/-$/, '');\n        },\n        guide: false,\n    };\n\n    countryCode = this.options.countryCode;\n\n    open = false;\n\n    constructor(\n        @Optional() @Self() @Inject(NgControl) control: NgControl | null,\n        @Self() @Inject(TuiDestroyService) destroy$: Observable<unknown>,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(TUI_SELECTION_STREAM) selection$: Observable<unknown>,\n        @Inject(TUI_TEXTFIELD_CLEANER)\n        private readonly textfieldCleaner: TuiTextfieldCleanerDirective,\n        @Inject(TUI_INPUT_PHONE_OPTIONS) private readonly options: TuiInputPhoneOptions,\n    ) {\n        super(control, cdr);\n\n        selection$.pipe(takeUntil(destroy$)).subscribe(() => {\n            this.setCaretPosition();\n        });\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return !this.textfield || this.computedDisabled\n            ? null\n            : this.textfield.nativeFocusableElement;\n    }\n\n    get focused(): boolean {\n        return (\n            tuiIsNativeFocused(this.nativeFocusableElement) ||\n            (!!this.dropdown && this.dropdown.focused)\n        );\n    }\n\n    get computedValue(): string {\n        return this.value\n            ? tuiFormatPhone(this.value, this.countryCode, this.phoneMaskAfterCountryCode)\n            : this.search || '';\n    }\n\n    get inputMode(): TuiInputMode {\n        return this.allowText ? 'text' : 'numeric';\n    }\n\n    get canOpen(): boolean {\n        return this.interactive && !!this.datalist;\n    }\n\n    get canClean(): boolean {\n        return this.computedValue !== this.countryCode && this.textfieldCleaner.cleaner;\n    }\n\n    onDrop(event: DragEvent): void {\n        if (!event.dataTransfer) {\n            return;\n        }\n\n        this.setValueWithoutPrefix(event.dataTransfer.getData('text'));\n        event.preventDefault();\n    }\n\n    onPaste(event: Event): void {\n        this.setValueWithoutPrefix(tuiGetClipboardDataText(event as ClipboardEvent));\n    }\n\n    onActiveZone(active: boolean): void {\n        this.updateFocused(active);\n\n        if (active && !this.computedValue && !this.readOnly && !this.allowText) {\n            this.updateSearch(this.countryCode);\n\n            return;\n        }\n\n        if (\n            this.computedValue === this.countryCode ||\n            (this.search !== null &&\n                Number.isNaN(\n                    parseInt(this.search.replace(TUI_MASK_SYMBOLS_REGEXP, ''), 10),\n                ))\n        ) {\n            this.updateSearch('');\n        }\n    }\n\n    onBackspace(event: Event): void {\n        const target = event.target as HTMLInputElement;\n\n        if (\n            (target.selectionStart || 0) <= this.nonRemovableLength &&\n            target.selectionStart === target.selectionEnd\n        ) {\n            event.preventDefault();\n        }\n    }\n\n    onValueChange(value: string): void {\n        value = value === '' ? this.countryCode : value;\n\n        const parsed = isText(value)\n            ? value\n            : value.replace(TUI_MASK_SYMBOLS_REGEXP, '').slice(0, this.maxPhoneLength);\n\n        this.updateSearch(parsed);\n        this.value = parsed === this.countryCode || isText(parsed) ? '' : parsed;\n        this.open = true;\n    }\n\n    handleOption(item: string): void {\n        this.focusInput();\n        this.value = item;\n        this.updateSearch('');\n        this.open = false;\n    }\n\n    override setDisabledState(): void {\n        super.setDisabledState();\n        this.open = false;\n    }\n\n    override writeValue(value: string | null): void {\n        super.writeValue(value);\n        this.updateSearch('');\n    }\n\n    protected getFallbackValue(): string {\n        return '';\n    }\n\n    private get caretIsInForbiddenArea(): boolean {\n        const {nativeFocusableElement} = this;\n\n        if (!nativeFocusableElement) {\n            return false;\n        }\n\n        const {selectionStart, selectionEnd} = nativeFocusableElement;\n\n        return (\n            tuiIsNativeFocused(nativeFocusableElement) &&\n            selectionStart !== null &&\n            selectionStart < this.nonRemovableLength &&\n            selectionStart === selectionEnd\n        );\n    }\n\n    private get nonRemovableLength(): number {\n        return this.isTextValue ? 0 : this.countryCode.length + 1;\n    }\n\n    private get maxPhoneLength(): number {\n        return (\n            this.countryCode.length +\n            this.phoneMaskAfterCountryCode.replace(/[^#]+/g, '').length\n        );\n    }\n\n    private get isTextValue(): boolean {\n        return !!this.search && isText(this.search);\n    }\n\n    private setCaretPosition(): void {\n        if (this.caretIsInForbiddenArea && !!this.nativeFocusableElement) {\n            this.nativeFocusableElement.setSelectionRange(\n                this.nonRemovableLength,\n                this.nonRemovableLength,\n            );\n        }\n    }\n\n    private setValueWithoutPrefix(value: string): void {\n        if (this.readOnly) {\n            return;\n        }\n\n        this.open = true;\n        this.value = this.cleanValue(value);\n        this.updateSearch(\n            this.allowText && isText(value)\n                ? value\n                : value.replace(TUI_MASK_SYMBOLS_REGEXP, ''),\n        );\n    }\n\n    private cleanValue(value: string): string {\n        const reg: RegExp =\n            this.countryCode === '+7' ? /^7|^8/ : new RegExp(this.countryCode.slice(1));\n        const oldValueExist =\n            this.value.length > this.countryCode.length &&\n            this.value.length < this.maxPhoneLength;\n        const newValueLength = value.replace(TUI_MASK_SYMBOLS_REGEXP, '').length;\n        const cleanNewValue = value.replace(/[^0-9]+/g, '');\n        const selectionLength = String(getSelection()).length;\n\n        if (oldValueExist && selectionLength === 0) {\n            return `${this.value}${cleanNewValue}`.slice(0, this.maxPhoneLength);\n        }\n\n        if (newValueLength < this.maxPhoneLength - 1) {\n            return `${this.countryCode}${cleanNewValue}`.slice(0, this.maxPhoneLength);\n        }\n\n        return `${this.countryCode}${cleanNewValue.replace(reg, '')}`.slice(\n            0,\n            this.maxPhoneLength,\n        );\n    }\n\n    private focusInput(): void {\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.focus({preventScroll: true});\n        }\n    }\n\n    private updateSearch(search: string): void {\n        if (this.search === search) {\n            return;\n        }\n\n        this.search = search;\n        this.searchChange.emit(search);\n    }\n\n    private updateValueWithNewCountryCode(newCountryCode: string): void {\n        if (!this.isTextValue) {\n            this.value = this.value.replace(this.countryCode, newCountryCode);\n        }\n    }\n}\n\nfunction isText(value: string): boolean {\n    return Number.isNaN(parseInt(value.replace(TUI_MASK_SYMBOLS_REGEXP, ''), 10));\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"canOpen\"\n    [content]=\"datalist || ''\"\n    [(open)]=\"open\"\n    (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n    <tui-primitive-textfield\n        tuiValueAccessor\n        class=\"t-textfield\"\n        [pseudoHover]=\"pseudoHover\"\n        [pseudoFocus]=\"computedFocused\"\n        [invalid]=\"computedInvalid\"\n        [nativeId]=\"nativeId\"\n        [readOnly]=\"readOnly\"\n        [disabled]=\"computedDisabled\"\n        [focusable]=\"focusable\"\n        [textMask]=\"textMaskOptions\"\n        [value]=\"computedValue\"\n        [tuiTextfieldCleaner]=\"canClean\"\n        (valueChange)=\"onValueChange($event)\"\n        (drop)=\"onDrop($event)\"\n        (keydown.backspace)=\"onBackspace($event)\"\n        (paste.prevent)=\"onPaste($event)\"\n    >\n        <ng-content></ng-content>\n        <ng-content\n            select=\"input\"\n            ngProjectAs=\"input\"\n        ></ng-content>\n    </tui-primitive-textfield>\n</tui-hosted-dropdown>\n"]}
|
|
261
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-phone.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-phone/input-phone.component.ts","../../../../../projects/kit/components/input-phone/input-phone.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    EventEmitter,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {MASKITO_DEFAULT_OPTIONS, MaskitoOptions, maskitoTransform} from '@maskito/core';\nimport {maskitoPrefixPostprocessorGenerator} from '@maskito/kit';\nimport {\n    AbstractTuiControl,\n    TuiActiveZoneDirective,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiDestroyService,\n    TuiFocusableElementAccessor,\n    TuiInputMode,\n    tuiIsNativeFocused,\n    tuiPure,\n    tuiRequiredSetter,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_MASK_SYMBOLS_REGEXP,\n    TUI_SELECTION_STREAM,\n    TUI_TEXTFIELD_CLEANER,\n    tuiAsDataListHost,\n    TuiDataListDirective,\n    TuiDataListHost,\n    TuiHostedDropdownComponent,\n    TuiPrimitiveTextfieldComponent,\n    TuiTextfieldCleanerDirective,\n} from '@taiga-ui/core';\nimport {FIXED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {Observable} from 'rxjs';\nimport {takeUntil} from 'rxjs/operators';\n\nimport {TUI_INPUT_PHONE_OPTIONS, TuiInputPhoneOptions} from './input-phone.options';\nimport {\n    tuiCreateCompletePhoneInsertionPreprocessor,\n    tuiCreatePhoneMaskExpression,\n} from './utils';\n\n@Component({\n    selector: 'tui-input-phone',\n    templateUrl: './input-phone.template.html',\n    styleUrls: ['./input-phone.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        TuiDestroyService,\n        tuiAsFocusableItemAccessor(TuiInputPhoneComponent),\n        tuiAsControl(TuiInputPhoneComponent),\n        tuiAsDataListHost(TuiInputPhoneComponent),\n    ],\n    viewProviders: [FIXED_DROPDOWN_CONTROLLER_PROVIDER],\n})\nexport class TuiInputPhoneComponent\n    extends AbstractTuiControl<string>\n    implements TuiFocusableElementAccessor, TuiDataListHost<string>\n{\n    @ViewChild(TuiHostedDropdownComponent)\n    private readonly dropdown?: TuiHostedDropdownComponent;\n\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    @Input('countryCode')\n    @tuiRequiredSetter()\n    set countryCodeSetter(newCountryCode: string) {\n        const prevCountryCode = this.countryCode;\n\n        this.countryCode = newCountryCode;\n        this.updateValueWithNewCountryCode(prevCountryCode, newCountryCode);\n    }\n\n    @Input()\n    @tuiDefaultProp()\n    phoneMaskAfterCountryCode = this.options.phoneMaskAfterCountryCode;\n\n    @Input()\n    @tuiDefaultProp()\n    allowText = this.options.allowText;\n\n    @Input()\n    @tuiDefaultProp()\n    search = '';\n\n    @Output()\n    readonly searchChange = new EventEmitter<string>();\n\n    @ContentChild(TuiDataListDirective, {read: TemplateRef})\n    readonly datalist?: TemplateRef<TuiContextWithImplicit<TuiActiveZoneDirective>>;\n\n    countryCode = this.options.countryCode;\n\n    open = false;\n\n    constructor(\n        @Optional() @Self() @Inject(NgControl) control: NgControl | null,\n        @Self() @Inject(TuiDestroyService) destroy$: Observable<unknown>,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(TUI_SELECTION_STREAM) selection$: Observable<unknown>,\n        @Inject(TUI_TEXTFIELD_CLEANER)\n        private readonly textfieldCleaner: TuiTextfieldCleanerDirective,\n        @Inject(TUI_INPUT_PHONE_OPTIONS) private readonly options: TuiInputPhoneOptions,\n    ) {\n        super(control, cdr);\n\n        selection$.pipe(takeUntil(destroy$)).subscribe(() => {\n            this.setCaretPosition();\n        });\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return !this.textfield || this.computedDisabled\n            ? null\n            : this.textfield.nativeFocusableElement;\n    }\n\n    get focused(): boolean {\n        return (\n            tuiIsNativeFocused(this.nativeFocusableElement) ||\n            (!!this.dropdown && this.dropdown.focused)\n        );\n    }\n\n    get nativeValue(): string {\n        return this.nativeFocusableElement\n            ? this.nativeFocusableElement.value\n            : maskitoTransform(this.value, this.maskOptions);\n    }\n\n    set nativeValue(value: string) {\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.value = value;\n        }\n    }\n\n    get inputMode(): TuiInputMode {\n        return this.allowText ? 'text' : 'numeric';\n    }\n\n    get canOpen(): boolean {\n        return this.interactive && !!this.datalist;\n    }\n\n    get canClean(): boolean {\n        return (\n            this.nativeValue !== this.nonRemovablePrefix && this.textfieldCleaner.cleaner\n        );\n    }\n\n    get maskOptions(): MaskitoOptions {\n        return this.calculateMask(\n            this.countryCode,\n            this.phoneMaskAfterCountryCode,\n            this.nonRemovablePrefix,\n            this.allowText,\n        );\n    }\n\n    onActiveZone(active: boolean): void {\n        this.updateFocused(active);\n\n        if (active && !this.nativeValue && !this.readOnly && !this.allowText) {\n            this.updateSearch(this.nonRemovablePrefix);\n            this.nativeValue = this.nonRemovablePrefix;\n\n            return;\n        }\n\n        if (this.nativeValue === this.nonRemovablePrefix || this.isTextValue) {\n            this.updateSearch('');\n            this.nativeValue = '';\n        }\n\n        if (!active && !this.allowText && this.nativeFocusableElement) {\n            this.nativeValue = this.nativeValue.replace(/\\D$/, '');\n        }\n    }\n\n    onValueChange(value: string): void {\n        const parsed = isText(value)\n            ? value\n            : value.replace(TUI_MASK_SYMBOLS_REGEXP, '').slice(0, this.maxPhoneLength);\n\n        this.updateSearch(parsed);\n        this.value = parsed === this.countryCode || isText(parsed) ? '' : parsed;\n        this.open = true;\n    }\n\n    handleOption(item: string): void {\n        this.focusInput();\n        this.value = item;\n        this.nativeValue = maskitoTransform(this.value, this.maskOptions);\n        this.updateSearch('');\n        this.open = false;\n    }\n\n    override setDisabledState(): void {\n        super.setDisabledState();\n        this.open = false;\n    }\n\n    override writeValue(value: string | null): void {\n        super.writeValue(value);\n        this.nativeValue = maskitoTransform(value || '', this.maskOptions);\n        this.updateSearch('');\n    }\n\n    protected getFallbackValue(): string {\n        return '';\n    }\n\n    private get caretIsInForbiddenArea(): boolean {\n        const {nativeFocusableElement} = this;\n\n        if (!nativeFocusableElement) {\n            return false;\n        }\n\n        const {selectionStart, selectionEnd} = nativeFocusableElement;\n\n        return (\n            tuiIsNativeFocused(nativeFocusableElement) &&\n            selectionStart !== null &&\n            selectionStart < this.nonRemovableLength &&\n            selectionStart === selectionEnd\n        );\n    }\n\n    private get nonRemovablePrefix(): string {\n        return `${this.countryCode} `;\n    }\n\n    private get nonRemovableLength(): number {\n        return this.isTextValue ? 0 : this.nonRemovablePrefix.length;\n    }\n\n    private get maxPhoneLength(): number {\n        return (\n            this.countryCode.length +\n            this.phoneMaskAfterCountryCode.replace(/[^#]+/g, '').length\n        );\n    }\n\n    private get isTextValue(): boolean {\n        return !!this.search && isText(this.search);\n    }\n\n    @tuiPure\n    private calculateMask(\n        countryCode: string,\n        phoneMaskAfterCountryCode: string,\n        nonRemovablePrefix: string,\n        allowText: boolean,\n    ): MaskitoOptions {\n        const mask = tuiCreatePhoneMaskExpression(countryCode, phoneMaskAfterCountryCode);\n        const preprocessor = tuiCreateCompletePhoneInsertionPreprocessor(\n            countryCode,\n            phoneMaskAfterCountryCode,\n        );\n\n        return allowText\n            ? {\n                  mask: ({value}) =>\n                      isText(value) && value !== '+'\n                          ? (MASKITO_DEFAULT_OPTIONS.mask as RegExp)\n                          : mask,\n                  preprocessor,\n              }\n            : {\n                  mask,\n                  preprocessor,\n                  postprocessor: maskitoPrefixPostprocessorGenerator(nonRemovablePrefix),\n              };\n    }\n\n    private setCaretPosition(): void {\n        if (this.caretIsInForbiddenArea && !!this.nativeFocusableElement) {\n            this.nativeFocusableElement.setSelectionRange(\n                this.nonRemovableLength,\n                this.nonRemovableLength,\n            );\n        }\n    }\n\n    private focusInput(): void {\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.focus({preventScroll: true});\n        }\n    }\n\n    private updateSearch(search: string): void {\n        if (this.search === search) {\n            return;\n        }\n\n        this.search = search;\n        this.searchChange.emit(search);\n    }\n\n    private updateValueWithNewCountryCode(\n        prevCountryCode: string,\n        newCountryCode: string,\n    ): void {\n        if (!this.isTextValue) {\n            this.value = this.value.replace(prevCountryCode, newCountryCode);\n            this.nativeValue = maskitoTransform(this.value, this.maskOptions);\n        }\n    }\n}\n\nfunction isText(value: string): boolean {\n    return Number.isNaN(parseInt(value.replace(TUI_MASK_SYMBOLS_REGEXP, ''), 10));\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"canOpen\"\n    [content]=\"datalist || ''\"\n    [(open)]=\"open\"\n    (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n    <tui-primitive-textfield\n        tuiValueAccessor\n        class=\"t-textfield\"\n        [pseudoHover]=\"pseudoHover\"\n        [pseudoFocus]=\"computedFocused\"\n        [invalid]=\"computedInvalid\"\n        [nativeId]=\"nativeId\"\n        [readOnly]=\"readOnly\"\n        [disabled]=\"computedDisabled\"\n        [focusable]=\"focusable\"\n        [maskito]=\"maskOptions\"\n        [tuiTextfieldCleaner]=\"canClean\"\n        [(value)]=\"nativeValue\"\n        (valueChange)=\"onValueChange($event)\"\n    >\n        <ng-content></ng-content>\n        <ng-content\n            select=\"input\"\n            ngProjectAs=\"input\"\n        ></ng-content>\n    </tui-primitive-textfield>\n</tui-hosted-dropdown>\n"]}
|
|
@@ -3,7 +3,7 @@ import { AbstractTuiTextfieldHost, tuiAsTextfieldHost } from '@taiga-ui/core';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class TuiInputPhoneDirective extends AbstractTuiTextfieldHost {
|
|
5
5
|
get value() {
|
|
6
|
-
return this.host.
|
|
6
|
+
return this.host.nativeValue;
|
|
7
7
|
}
|
|
8
8
|
onValueChange(value) {
|
|
9
9
|
this.host.onValueChange(value);
|
|
@@ -28,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
28
28
|
providers: [tuiAsTextfieldHost(TuiInputPhoneDirective)],
|
|
29
29
|
}]
|
|
30
30
|
}] });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtcGhvbmUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvaW5wdXQtcGhvbmUvaW5wdXQtcGhvbmUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFDLHdCQUF3QixFQUFFLGtCQUFrQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7O0FBUTVFLE1BQU0sT0FBTyxzQkFDVCxTQUFRLHdCQUFnRDtJQUt4RCxJQUFhLEtBQUs7UUFDZCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQ2pDLENBQUM7SUFFRCxhQUFhLENBQUMsS0FBYTtRQUN2QixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRVEsT0FBTyxDQUFDLEtBQXVCO1FBQ3BDLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxTQUFTO1FBQ0wsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDYixPQUFPO1NBQ1Y7UUFFRCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxLQUFLLENBQUM7UUFDeEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDL0MsQ0FBQzs7b0hBekJRLHNCQUFzQjt3R0FBdEIsc0JBQXNCLDBDQUZwQixDQUFDLGtCQUFrQixDQUFDLHNCQUFzQixDQUFDLENBQUM7NEZBRTlDLHNCQUFzQjtrQkFKbEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsaUJBQWlCO29CQUMzQixTQUFTLEVBQUUsQ0FBQyxrQkFBa0Isd0JBQXdCLENBQUM7aUJBQzFEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIERvQ2hlY2t9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtBYnN0cmFjdFR1aVRleHRmaWVsZEhvc3QsIHR1aUFzVGV4dGZpZWxkSG9zdH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuXG5pbXBvcnQge1R1aUlucHV0UGhvbmVDb21wb25lbnR9IGZyb20gJy4vaW5wdXQtcGhvbmUuY29tcG9uZW50JztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICd0dWktaW5wdXQtcGhvbmUnLFxuICAgIHByb3ZpZGVyczogW3R1aUFzVGV4dGZpZWxkSG9zdChUdWlJbnB1dFBob25lRGlyZWN0aXZlKV0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aUlucHV0UGhvbmVEaXJlY3RpdmVcbiAgICBleHRlbmRzIEFic3RyYWN0VHVpVGV4dGZpZWxkSG9zdDxUdWlJbnB1dFBob25lQ29tcG9uZW50PlxuICAgIGltcGxlbWVudHMgRG9DaGVja1xue1xuICAgIGlucHV0PzogSFRNTElucHV0RWxlbWVudDtcblxuICAgIG92ZXJyaWRlIGdldCB2YWx1ZSgpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gdGhpcy5ob3N0Lm5hdGl2ZVZhbHVlO1xuICAgIH1cblxuICAgIG9uVmFsdWVDaGFuZ2UodmFsdWU6IHN0cmluZyk6IHZvaWQge1xuICAgICAgICB0aGlzLmhvc3Qub25WYWx1ZUNoYW5nZSh2YWx1ZSk7XG4gICAgfVxuXG4gICAgb3ZlcnJpZGUgcHJvY2VzcyhpbnB1dDogSFRNTElucHV0RWxlbWVudCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlucHV0ID0gaW5wdXQ7XG4gICAgfVxuXG4gICAgbmdEb0NoZWNrKCk6IHZvaWQge1xuICAgICAgICBpZiAoIXRoaXMuaW5wdXQpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuaW5wdXQudHlwZSA9ICd0ZWwnO1xuICAgICAgICB0aGlzLmlucHV0LmlucHV0TW9kZSA9IHRoaXMuaG9zdC5pbnB1dE1vZGU7XG4gICAgfVxufVxuIl19
|
|
@@ -1,21 +1,22 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
|
+
import { MaskitoModule } from '@maskito/angular';
|
|
2
3
|
import { TuiActiveZoneModule } from '@taiga-ui/cdk';
|
|
3
4
|
import { TuiHostedDropdownModule, TuiPrimitiveTextfieldModule, TuiTextfieldComponent, TuiTextfieldControllerModule, } from '@taiga-ui/core';
|
|
4
|
-
import {
|
|
5
|
+
import { TuiValueAccessorModule } from '@taiga-ui/kit/directives';
|
|
5
6
|
import { TuiInputPhoneComponent } from './input-phone.component';
|
|
6
7
|
import { TuiInputPhoneDirective } from './input-phone.directive';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
export class TuiInputPhoneModule {
|
|
9
10
|
}
|
|
10
11
|
TuiInputPhoneModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputPhoneModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
-
TuiInputPhoneModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputPhoneModule, declarations: [TuiInputPhoneComponent, TuiInputPhoneDirective], imports: [
|
|
12
|
+
TuiInputPhoneModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputPhoneModule, declarations: [TuiInputPhoneComponent, TuiInputPhoneDirective], imports: [MaskitoModule,
|
|
12
13
|
TuiPrimitiveTextfieldModule,
|
|
13
14
|
TuiHostedDropdownModule,
|
|
14
15
|
TuiTextfieldControllerModule,
|
|
15
16
|
TuiActiveZoneModule,
|
|
16
17
|
TuiValueAccessorModule], exports: [TuiInputPhoneComponent, TuiInputPhoneDirective, TuiTextfieldComponent] });
|
|
17
18
|
TuiInputPhoneModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputPhoneModule, imports: [[
|
|
18
|
-
|
|
19
|
+
MaskitoModule,
|
|
19
20
|
TuiPrimitiveTextfieldModule,
|
|
20
21
|
TuiHostedDropdownModule,
|
|
21
22
|
TuiTextfieldControllerModule,
|
|
@@ -26,7 +27,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
26
27
|
type: NgModule,
|
|
27
28
|
args: [{
|
|
28
29
|
imports: [
|
|
29
|
-
|
|
30
|
+
MaskitoModule,
|
|
30
31
|
TuiPrimitiveTextfieldModule,
|
|
31
32
|
TuiHostedDropdownModule,
|
|
32
33
|
TuiTextfieldControllerModule,
|
|
@@ -37,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
37
38
|
exports: [TuiInputPhoneComponent, TuiInputPhoneDirective, TuiTextfieldComponent],
|
|
38
39
|
}]
|
|
39
40
|
}] });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtcGhvbmUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvaW5wdXQtcGhvbmUvaW5wdXQtcGhvbmUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLGtCQUFrQixDQUFDO0FBQy9DLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLDJCQUEyQixFQUMzQixxQkFBcUIsRUFDckIsNEJBQTRCLEdBQy9CLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEIsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFFaEUsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDL0QsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0seUJBQXlCLENBQUM7O0FBYy9ELE1BQU0sT0FBTyxtQkFBbUI7O2lIQUFuQixtQkFBbUI7a0hBQW5CLG1CQUFtQixpQkFIYixzQkFBc0IsRUFBRSxzQkFBc0IsYUFQekQsYUFBYTtRQUNiLDJCQUEyQjtRQUMzQix1QkFBdUI7UUFDdkIsNEJBQTRCO1FBQzVCLG1CQUFtQjtRQUNuQixzQkFBc0IsYUFHaEIsc0JBQXNCLEVBQUUsc0JBQXNCLEVBQUUscUJBQXFCO2tIQUV0RSxtQkFBbUIsWUFYbkI7WUFDTCxhQUFhO1lBQ2IsMkJBQTJCO1lBQzNCLHVCQUF1QjtZQUN2Qiw0QkFBNEI7WUFDNUIsbUJBQW1CO1lBQ25CLHNCQUFzQjtTQUN6Qjs0RkFJUSxtQkFBbUI7a0JBWi9CLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLGFBQWE7d0JBQ2IsMkJBQTJCO3dCQUMzQix1QkFBdUI7d0JBQ3ZCLDRCQUE0Qjt3QkFDNUIsbUJBQW1CO3dCQUNuQixzQkFBc0I7cUJBQ3pCO29CQUNELFlBQVksRUFBRSxDQUFDLHNCQUFzQixFQUFFLHNCQUFzQixDQUFDO29CQUM5RCxPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsRUFBRSxzQkFBc0IsRUFBRSxxQkFBcUIsQ0FBQztpQkFDbkYiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TWFza2l0b01vZHVsZX0gZnJvbSAnQG1hc2tpdG8vYW5ndWxhcic7XG5pbXBvcnQge1R1aUFjdGl2ZVpvbmVNb2R1bGV9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtcbiAgICBUdWlIb3N0ZWREcm9wZG93bk1vZHVsZSxcbiAgICBUdWlQcmltaXRpdmVUZXh0ZmllbGRNb2R1bGUsXG4gICAgVHVpVGV4dGZpZWxkQ29tcG9uZW50LFxuICAgIFR1aVRleHRmaWVsZENvbnRyb2xsZXJNb2R1bGUsXG59IGZyb20gJ0B0YWlnYS11aS9jb3JlJztcbmltcG9ydCB7VHVpVmFsdWVBY2Nlc3Nvck1vZHVsZX0gZnJvbSAnQHRhaWdhLXVpL2tpdC9kaXJlY3RpdmVzJztcblxuaW1wb3J0IHtUdWlJbnB1dFBob25lQ29tcG9uZW50fSBmcm9tICcuL2lucHV0LXBob25lLmNvbXBvbmVudCc7XG5pbXBvcnQge1R1aUlucHV0UGhvbmVEaXJlY3RpdmV9IGZyb20gJy4vaW5wdXQtcGhvbmUuZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIE1hc2tpdG9Nb2R1bGUsXG4gICAgICAgIFR1aVByaW1pdGl2ZVRleHRmaWVsZE1vZHVsZSxcbiAgICAgICAgVHVpSG9zdGVkRHJvcGRvd25Nb2R1bGUsXG4gICAgICAgIFR1aVRleHRmaWVsZENvbnRyb2xsZXJNb2R1bGUsXG4gICAgICAgIFR1aUFjdGl2ZVpvbmVNb2R1bGUsXG4gICAgICAgIFR1aVZhbHVlQWNjZXNzb3JNb2R1bGUsXG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtUdWlJbnB1dFBob25lQ29tcG9uZW50LCBUdWlJbnB1dFBob25lRGlyZWN0aXZlXSxcbiAgICBleHBvcnRzOiBbVHVpSW5wdXRQaG9uZUNvbXBvbmVudCwgVHVpSW5wdXRQaG9uZURpcmVjdGl2ZSwgVHVpVGV4dGZpZWxkQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpSW5wdXRQaG9uZU1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
const countDigits = (value) => value.replace(/\D/g, ``).length;
|
|
2
|
+
/**
|
|
3
|
+
* `InputPhone` component sets country code as non-removable prefix.
|
|
4
|
+
* This prefix appears on focus and cannot be erased.
|
|
5
|
+
* But users sometimes can copy complete phone number (from any different source)
|
|
6
|
+
* and try to insert the whole string inside our `InputPhone` textfield.
|
|
7
|
+
* This preprocessor helps to avoid country prefix duplication on paste/drop/autofill events.
|
|
8
|
+
*/
|
|
9
|
+
export function tuiCreateCompletePhoneInsertionPreprocessor(countryCode, phoneMaskAfterCountryCode) {
|
|
10
|
+
const completePhoneLength = (countryCode + phoneMaskAfterCountryCode).replace(/[^#\d]+/g, ``).length;
|
|
11
|
+
const trimCountryPrefix = (value) => {
|
|
12
|
+
return countryCode === `+7`
|
|
13
|
+
? value.replace(/^(\+?7?\s?8?)\s?/, ``)
|
|
14
|
+
: value.replace(new RegExp(`^(\\+?${countryCode.replace(`+`, ``)}?)\\s?`), ``);
|
|
15
|
+
};
|
|
16
|
+
return ({ elementState, data }) => {
|
|
17
|
+
const { value, selection } = elementState;
|
|
18
|
+
return {
|
|
19
|
+
elementState: {
|
|
20
|
+
selection,
|
|
21
|
+
value:
|
|
22
|
+
/**
|
|
23
|
+
* The only possible case when `value` includes digits more
|
|
24
|
+
* than mask expression allows – browser autofill.
|
|
25
|
+
* It means that we are inside `input`-event
|
|
26
|
+
* and mask are ready to reject "extra" characters.
|
|
27
|
+
* We should cut leading country prefix to save trailing characters!
|
|
28
|
+
*/
|
|
29
|
+
countDigits(value) > completePhoneLength
|
|
30
|
+
? trimCountryPrefix(value)
|
|
31
|
+
: value,
|
|
32
|
+
},
|
|
33
|
+
data: countDigits(data) >= completePhoneLength
|
|
34
|
+
? /**
|
|
35
|
+
* User tries to insert/drop the complete phone number (with country prefix).
|
|
36
|
+
* We should drop already existing non-removable prefix.
|
|
37
|
+
*/
|
|
38
|
+
trimCountryPrefix(data)
|
|
39
|
+
: data,
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcGxldGUtcGhvbmUtaW5zZXJ0aW9uLXByZXByb2Nlc3Nvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL2lucHV0LXBob25lL3V0aWxzL2NvbXBsZXRlLXBob25lLWluc2VydGlvbi1wcmVwcm9jZXNzb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxXQUFXLEdBQUcsQ0FBQyxLQUFhLEVBQVUsRUFBRSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQztBQUUvRTs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsMkNBQTJDLENBQ3ZELFdBQW1CLEVBQ25CLHlCQUFpQztJQUVqQyxNQUFNLG1CQUFtQixHQUFHLENBQUMsV0FBVyxHQUFHLHlCQUF5QixDQUFDLENBQUMsT0FBTyxDQUN6RSxVQUFVLEVBQ1YsRUFBRSxDQUNMLENBQUMsTUFBTSxDQUFDO0lBRVQsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLEtBQWEsRUFBVSxFQUFFO1FBQ2hELE9BQU8sV0FBVyxLQUFLLElBQUk7WUFDdkIsQ0FBQyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsa0JBQWtCLEVBQUUsRUFBRSxDQUFDO1lBQ3ZDLENBQUMsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUNULElBQUksTUFBTSxDQUFDLFNBQVMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxFQUN6RCxFQUFFLENBQ0wsQ0FBQztJQUNaLENBQUMsQ0FBQztJQUVGLE9BQU8sQ0FBQyxFQUFDLFlBQVksRUFBRSxJQUFJLEVBQUMsRUFBRSxFQUFFO1FBQzVCLE1BQU0sRUFBQyxLQUFLLEVBQUUsU0FBUyxFQUFDLEdBQUcsWUFBWSxDQUFDO1FBRXhDLE9BQU87WUFDSCxZQUFZLEVBQUU7Z0JBQ1YsU0FBUztnQkFDVCxLQUFLO2dCQUNEOzs7Ozs7bUJBTUc7Z0JBQ0gsV0FBVyxDQUFDLEtBQUssQ0FBQyxHQUFHLG1CQUFtQjtvQkFDcEMsQ0FBQyxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQztvQkFDMUIsQ0FBQyxDQUFDLEtBQUs7YUFDbEI7WUFDRCxJQUFJLEVBQ0EsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLG1CQUFtQjtnQkFDcEMsQ0FBQyxDQUFDOzs7cUJBR0c7b0JBQ0gsaUJBQWlCLENBQUMsSUFBSSxDQUFDO2dCQUN6QixDQUFDLENBQUMsSUFBSTtTQUNqQixDQUFDO0lBQ04sQ0FBQyxDQUFDO0FBQ04sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TWFza2l0b1ByZXByb2Nlc3Nvcn0gZnJvbSAnQG1hc2tpdG8vY29yZSc7XG5cbmNvbnN0IGNvdW50RGlnaXRzID0gKHZhbHVlOiBzdHJpbmcpOiBudW1iZXIgPT4gdmFsdWUucmVwbGFjZSgvXFxEL2csIGBgKS5sZW5ndGg7XG5cbi8qKlxuICogYElucHV0UGhvbmVgIGNvbXBvbmVudCBzZXRzIGNvdW50cnkgY29kZSBhcyBub24tcmVtb3ZhYmxlIHByZWZpeC5cbiAqIFRoaXMgcHJlZml4IGFwcGVhcnMgb24gZm9jdXMgYW5kIGNhbm5vdCBiZSBlcmFzZWQuXG4gKiBCdXQgdXNlcnMgc29tZXRpbWVzIGNhbiBjb3B5IGNvbXBsZXRlIHBob25lIG51bWJlciAoZnJvbSBhbnkgZGlmZmVyZW50IHNvdXJjZSlcbiAqIGFuZCB0cnkgdG8gaW5zZXJ0IHRoZSB3aG9sZSBzdHJpbmcgaW5zaWRlIG91ciBgSW5wdXRQaG9uZWAgdGV4dGZpZWxkLlxuICogVGhpcyBwcmVwcm9jZXNzb3IgaGVscHMgdG8gYXZvaWQgY291bnRyeSBwcmVmaXggZHVwbGljYXRpb24gb24gcGFzdGUvZHJvcC9hdXRvZmlsbCBldmVudHMuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB0dWlDcmVhdGVDb21wbGV0ZVBob25lSW5zZXJ0aW9uUHJlcHJvY2Vzc29yKFxuICAgIGNvdW50cnlDb2RlOiBzdHJpbmcsXG4gICAgcGhvbmVNYXNrQWZ0ZXJDb3VudHJ5Q29kZTogc3RyaW5nLFxuKTogTWFza2l0b1ByZXByb2Nlc3NvciB7XG4gICAgY29uc3QgY29tcGxldGVQaG9uZUxlbmd0aCA9IChjb3VudHJ5Q29kZSArIHBob25lTWFza0FmdGVyQ291bnRyeUNvZGUpLnJlcGxhY2UoXG4gICAgICAgIC9bXiNcXGRdKy9nLFxuICAgICAgICBgYCxcbiAgICApLmxlbmd0aDtcblxuICAgIGNvbnN0IHRyaW1Db3VudHJ5UHJlZml4ID0gKHZhbHVlOiBzdHJpbmcpOiBzdHJpbmcgPT4ge1xuICAgICAgICByZXR1cm4gY291bnRyeUNvZGUgPT09IGArN2BcbiAgICAgICAgICAgID8gdmFsdWUucmVwbGFjZSgvXihcXCs/Nz9cXHM/OD8pXFxzPy8sIGBgKVxuICAgICAgICAgICAgOiB2YWx1ZS5yZXBsYWNlKFxuICAgICAgICAgICAgICAgICAgbmV3IFJlZ0V4cChgXihcXFxcKz8ke2NvdW50cnlDb2RlLnJlcGxhY2UoYCtgLCBgYCl9PylcXFxccz9gKSxcbiAgICAgICAgICAgICAgICAgIGBgLFxuICAgICAgICAgICAgICApO1xuICAgIH07XG5cbiAgICByZXR1cm4gKHtlbGVtZW50U3RhdGUsIGRhdGF9KSA9PiB7XG4gICAgICAgIGNvbnN0IHt2YWx1ZSwgc2VsZWN0aW9ufSA9IGVsZW1lbnRTdGF0ZTtcblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgZWxlbWVudFN0YXRlOiB7XG4gICAgICAgICAgICAgICAgc2VsZWN0aW9uLFxuICAgICAgICAgICAgICAgIHZhbHVlOlxuICAgICAgICAgICAgICAgICAgICAvKipcbiAgICAgICAgICAgICAgICAgICAgICogVGhlIG9ubHkgcG9zc2libGUgY2FzZSB3aGVuIGB2YWx1ZWAgaW5jbHVkZXMgZGlnaXRzIG1vcmVcbiAgICAgICAgICAgICAgICAgICAgICogdGhhbiBtYXNrIGV4cHJlc3Npb24gYWxsb3dzIOKAkyBicm93c2VyIGF1dG9maWxsLlxuICAgICAgICAgICAgICAgICAgICAgKiBJdCBtZWFucyB0aGF0IHdlIGFyZSBpbnNpZGUgYGlucHV0YC1ldmVudFxuICAgICAgICAgICAgICAgICAgICAgKiBhbmQgbWFzayBhcmUgcmVhZHkgdG8gcmVqZWN0IFwiZXh0cmFcIiBjaGFyYWN0ZXJzLlxuICAgICAgICAgICAgICAgICAgICAgKiBXZSBzaG91bGQgY3V0IGxlYWRpbmcgY291bnRyeSBwcmVmaXggdG8gc2F2ZSB0cmFpbGluZyBjaGFyYWN0ZXJzIVxuICAgICAgICAgICAgICAgICAgICAgKi9cbiAgICAgICAgICAgICAgICAgICAgY291bnREaWdpdHModmFsdWUpID4gY29tcGxldGVQaG9uZUxlbmd0aFxuICAgICAgICAgICAgICAgICAgICAgICAgPyB0cmltQ291bnRyeVByZWZpeCh2YWx1ZSlcbiAgICAgICAgICAgICAgICAgICAgICAgIDogdmFsdWUsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgZGF0YTpcbiAgICAgICAgICAgICAgICBjb3VudERpZ2l0cyhkYXRhKSA+PSBjb21wbGV0ZVBob25lTGVuZ3RoXG4gICAgICAgICAgICAgICAgICAgID8gLyoqXG4gICAgICAgICAgICAgICAgICAgICAgICogVXNlciB0cmllcyB0byBpbnNlcnQvZHJvcCB0aGUgY29tcGxldGUgcGhvbmUgbnVtYmVyICh3aXRoIGNvdW50cnkgcHJlZml4KS5cbiAgICAgICAgICAgICAgICAgICAgICAgKiBXZSBzaG91bGQgZHJvcCBhbHJlYWR5IGV4aXN0aW5nIG5vbi1yZW1vdmFibGUgcHJlZml4LlxuICAgICAgICAgICAgICAgICAgICAgICAqL1xuICAgICAgICAgICAgICAgICAgICAgIHRyaW1Db3VudHJ5UHJlZml4KGRhdGEpXG4gICAgICAgICAgICAgICAgICAgIDogZGF0YSxcbiAgICAgICAgfTtcbiAgICB9O1xufVxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Create {@link https://tinkoff.github.io/maskito/core-concepts/mask-expression pattern mask expression} for phone number
|
|
3
|
+
*
|
|
4
|
+
* @example
|
|
5
|
+
* tuiCreatePhoneMaskExpression('+1', '(###) ###-####');
|
|
6
|
+
*/
|
|
7
|
+
export function tuiCreatePhoneMaskExpression(countryCode, phoneMaskAfterCountryCode) {
|
|
8
|
+
return [
|
|
9
|
+
...countryCode.split(``),
|
|
10
|
+
` `,
|
|
11
|
+
...phoneMaskAfterCountryCode
|
|
12
|
+
.replace(/[^#\- ()]+/g, ``)
|
|
13
|
+
.split(``)
|
|
14
|
+
.map(item => (item === `#` ? /\d/ : item)),
|
|
15
|
+
];
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLXBob25lLW1hc2stZXhwcmVzc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL2lucHV0LXBob25lL3V0aWxzL2NyZWF0ZS1waG9uZS1tYXNrLWV4cHJlc3Npb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7QUFDSCxNQUFNLFVBQVUsNEJBQTRCLENBQ3hDLFdBQW1CLEVBQ25CLHlCQUFpQztJQUVqQyxPQUFPO1FBQ0gsR0FBRyxXQUFXLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUN4QixHQUFHO1FBQ0gsR0FBRyx5QkFBeUI7YUFDdkIsT0FBTyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUM7YUFDMUIsS0FBSyxDQUFDLEVBQUUsQ0FBQzthQUNULEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztLQUNqRCxDQUFDO0FBQ04sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ3JlYXRlIHtAbGluayBodHRwczovL3RpbmtvZmYuZ2l0aHViLmlvL21hc2tpdG8vY29yZS1jb25jZXB0cy9tYXNrLWV4cHJlc3Npb24gcGF0dGVybiBtYXNrIGV4cHJlc3Npb259IGZvciBwaG9uZSBudW1iZXJcbiAqXG4gKiBAZXhhbXBsZVxuICogdHVpQ3JlYXRlUGhvbmVNYXNrRXhwcmVzc2lvbignKzEnLCAnKCMjIykgIyMjLSMjIyMnKTtcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHR1aUNyZWF0ZVBob25lTWFza0V4cHJlc3Npb24oXG4gICAgY291bnRyeUNvZGU6IHN0cmluZyxcbiAgICBwaG9uZU1hc2tBZnRlckNvdW50cnlDb2RlOiBzdHJpbmcsXG4pOiBBcnJheTxSZWdFeHAgfCBzdHJpbmc+IHtcbiAgICByZXR1cm4gW1xuICAgICAgICAuLi5jb3VudHJ5Q29kZS5zcGxpdChgYCksXG4gICAgICAgIGAgYCxcbiAgICAgICAgLi4ucGhvbmVNYXNrQWZ0ZXJDb3VudHJ5Q29kZVxuICAgICAgICAgICAgLnJlcGxhY2UoL1teI1xcLSAoKV0rL2csIGBgKVxuICAgICAgICAgICAgLnNwbGl0KGBgKVxuICAgICAgICAgICAgLm1hcChpdGVtID0+IChpdGVtID09PSBgI2AgPyAvXFxkLyA6IGl0ZW0pKSxcbiAgICBdO1xufVxuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './complete-phone-insertion-preprocessor';
|
|
2
|
+
export * from './create-phone-mask-expression';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1waG9uZS91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsZ0NBQWdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbXBsZXRlLXBob25lLWluc2VydGlvbi1wcmVwcm9jZXNzb3InO1xuZXhwb3J0ICogZnJvbSAnLi9jcmVhdGUtcGhvbmUtbWFzay1leHByZXNzaW9uJztcbiJdfQ==
|