@taiga-ui/kit 2.98.0 → 2.99.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-international.umd.js +25 -516
- package/bundles/taiga-ui-kit-components-input-phone-international.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-phone-international.umd.min.js +1 -1
- package/bundles/taiga-ui-kit-components-input-phone-international.umd.min.js.map +1 -1
- package/bundles/taiga-ui-kit-constants.umd.js +275 -4
- package/bundles/taiga-ui-kit-constants.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-constants.umd.min.js +1 -1
- package/bundles/taiga-ui-kit-constants.umd.min.js.map +1 -1
- package/bundles/taiga-ui-kit-pipes-iso-to-country-code.umd.js +339 -0
- package/bundles/taiga-ui-kit-pipes-iso-to-country-code.umd.js.map +1 -0
- package/bundles/taiga-ui-kit-pipes-iso-to-country-code.umd.min.js +2 -0
- package/bundles/taiga-ui-kit-pipes-iso-to-country-code.umd.min.js.map +1 -0
- package/bundles/taiga-ui-kit-pipes-to-country-code.umd.js +361 -0
- package/bundles/taiga-ui-kit-pipes-to-country-code.umd.js.map +1 -0
- package/bundles/taiga-ui-kit-pipes-to-country-code.umd.min.js +2 -0
- package/bundles/taiga-ui-kit-pipes-to-country-code.umd.min.js.map +1 -0
- package/bundles/taiga-ui-kit-pipes.umd.js +20 -4
- package/bundles/taiga-ui-kit-pipes.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-pipes.umd.min.js +1 -1
- package/bundles/taiga-ui-kit-tokens.umd.js +9 -4
- package/bundles/taiga-ui-kit-tokens.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-tokens.umd.min.js +1 -1
- package/bundles/taiga-ui-kit-tokens.umd.min.js.map +1 -1
- package/bundles/taiga-ui-kit-utils-phone.umd.js +27 -0
- package/bundles/taiga-ui-kit-utils-phone.umd.js.map +1 -0
- package/bundles/taiga-ui-kit-utils-phone.umd.min.js +2 -0
- package/bundles/taiga-ui-kit-utils-phone.umd.min.js.map +1 -0
- package/bundles/taiga-ui-kit-utils.umd.js +12 -4
- package/bundles/taiga-ui-kit-utils.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-utils.umd.min.js +1 -1
- package/components/input-phone-international/index.d.ts +0 -4
- package/components/input-phone-international/input-phone-international.component.d.ts +7 -3
- package/components/input-phone-international/taiga-ui-kit-components-input-phone-international.metadata.json +1 -1
- package/{components/input-phone-international/const → constants}/countries.d.ts +1 -2
- package/constants/index.d.ts +2 -0
- package/constants/mask-after-code-regexp.d.ts +1 -0
- package/constants/taiga-ui-kit-constants.metadata.json +1 -1
- package/esm2015/components/input-phone-international/index.js +1 -4
- package/esm2015/components/input-phone-international/input-phone-international.component.js +24 -30
- package/esm2015/constants/countries.js +264 -0
- package/esm2015/constants/index.js +3 -1
- package/esm2015/constants/mask-after-code-regexp.js +2 -0
- package/esm2015/interfaces/country.js +1 -0
- package/esm2015/interfaces/index.js +1 -1
- package/esm2015/pipes/index.js +3 -1
- package/esm2015/pipes/iso-to-country-code/index.js +3 -0
- package/esm2015/pipes/iso-to-country-code/iso-to-country-code.module.js +13 -0
- package/esm2015/pipes/iso-to-country-code/iso-to-country-code.pipe.js +24 -0
- package/esm2015/pipes/iso-to-country-code/taiga-ui-kit-pipes-iso-to-country-code.js +5 -0
- package/esm2015/pipes/to-country-code/index.js +3 -0
- package/esm2015/pipes/to-country-code/taiga-ui-kit-pipes-to-country-code.js +5 -0
- package/esm2015/pipes/to-country-code/to-country-code.module.js +13 -0
- package/esm2015/pipes/to-country-code/to-country-code.pipe.js +47 -0
- package/esm2015/tokens/countries-masks.js +6 -0
- package/esm2015/tokens/index.js +2 -1
- package/esm2015/utils/index.js +2 -1
- package/esm2015/utils/phone/get-max-allowed-phone-length.js +4 -0
- package/esm2015/utils/phone/index.js +4 -0
- package/esm2015/utils/phone/iso-to-country-code.js +5 -0
- package/esm2015/utils/phone/not-kz-region.js +5 -0
- package/esm2015/utils/phone/taiga-ui-kit-utils-phone.js +5 -0
- package/esm5/components/input-phone-international/index.js +1 -4
- package/esm5/components/input-phone-international/input-phone-international.component.js +24 -31
- package/esm5/constants/countries.js +267 -0
- package/esm5/constants/index.js +3 -1
- package/esm5/constants/mask-after-code-regexp.js +2 -0
- package/esm5/interfaces/country.js +1 -0
- package/esm5/interfaces/index.js +1 -1
- package/esm5/pipes/index.js +3 -1
- package/esm5/pipes/iso-to-country-code/index.js +3 -0
- package/esm5/pipes/iso-to-country-code/iso-to-country-code.module.js +16 -0
- package/esm5/pipes/iso-to-country-code/iso-to-country-code.pipe.js +25 -0
- package/esm5/pipes/iso-to-country-code/taiga-ui-kit-pipes-iso-to-country-code.js +5 -0
- package/esm5/pipes/to-country-code/index.js +3 -0
- package/esm5/pipes/to-country-code/taiga-ui-kit-pipes-to-country-code.js +5 -0
- package/esm5/pipes/to-country-code/to-country-code.module.js +16 -0
- package/esm5/pipes/to-country-code/to-country-code.pipe.js +49 -0
- package/esm5/tokens/countries-masks.js +6 -0
- package/esm5/tokens/index.js +2 -1
- package/esm5/utils/index.js +2 -1
- package/esm5/utils/phone/get-max-allowed-phone-length.js +4 -0
- package/esm5/utils/phone/index.js +4 -0
- package/esm5/utils/phone/iso-to-country-code.js +5 -0
- package/esm5/utils/phone/not-kz-region.js +5 -0
- package/esm5/utils/phone/taiga-ui-kit-utils-phone.js +5 -0
- package/fesm2015/taiga-ui-kit-components-input-phone-international.js +26 -507
- package/fesm2015/taiga-ui-kit-components-input-phone-international.js.map +1 -1
- package/fesm2015/taiga-ui-kit-constants.js +267 -1
- package/fesm2015/taiga-ui-kit-constants.js.map +1 -1
- package/fesm2015/taiga-ui-kit-pipes-iso-to-country-code.js +39 -0
- package/fesm2015/taiga-ui-kit-pipes-iso-to-country-code.js.map +1 -0
- package/fesm2015/taiga-ui-kit-pipes-to-country-code.js +62 -0
- package/fesm2015/taiga-ui-kit-pipes-to-country-code.js.map +1 -0
- package/fesm2015/taiga-ui-kit-pipes.js +2 -0
- package/fesm2015/taiga-ui-kit-pipes.js.map +1 -1
- package/fesm2015/taiga-ui-kit-tokens.js +6 -1
- package/fesm2015/taiga-ui-kit-tokens.js.map +1 -1
- package/fesm2015/taiga-ui-kit-utils-phone.js +21 -0
- package/fesm2015/taiga-ui-kit-utils-phone.js.map +1 -0
- package/fesm2015/taiga-ui-kit-utils.js +1 -0
- package/fesm2015/taiga-ui-kit-utils.js.map +1 -1
- package/fesm5/taiga-ui-kit-components-input-phone-international.js +27 -511
- package/fesm5/taiga-ui-kit-components-input-phone-international.js.map +1 -1
- package/fesm5/taiga-ui-kit-constants.js +270 -2
- package/fesm5/taiga-ui-kit-constants.js.map +1 -1
- package/fesm5/taiga-ui-kit-pipes-iso-to-country-code.js +43 -0
- package/fesm5/taiga-ui-kit-pipes-iso-to-country-code.js.map +1 -0
- package/fesm5/taiga-ui-kit-pipes-to-country-code.js +67 -0
- package/fesm5/taiga-ui-kit-pipes-to-country-code.js.map +1 -0
- package/fesm5/taiga-ui-kit-pipes.js +2 -0
- package/fesm5/taiga-ui-kit-pipes.js.map +1 -1
- package/fesm5/taiga-ui-kit-tokens.js +6 -1
- package/fesm5/taiga-ui-kit-tokens.js.map +1 -1
- package/fesm5/taiga-ui-kit-utils-phone.js +21 -0
- package/fesm5/taiga-ui-kit-utils-phone.js.map +1 -0
- package/fesm5/taiga-ui-kit-utils.js +1 -0
- package/fesm5/taiga-ui-kit-utils.js.map +1 -1
- package/interfaces/index.d.ts +1 -0
- package/interfaces/taiga-ui-kit-interfaces.metadata.json +1 -1
- package/package.json +4 -4
- package/pipes/index.d.ts +2 -0
- package/pipes/iso-to-country-code/index.d.ts +2 -0
- package/pipes/iso-to-country-code/iso-to-country-code.module.d.ts +2 -0
- package/pipes/iso-to-country-code/iso-to-country-code.pipe.d.ts +7 -0
- package/pipes/iso-to-country-code/package.json +13 -0
- package/pipes/iso-to-country-code/taiga-ui-kit-pipes-iso-to-country-code.d.ts +4 -0
- package/pipes/iso-to-country-code/taiga-ui-kit-pipes-iso-to-country-code.metadata.json +1 -0
- package/pipes/taiga-ui-kit-pipes.metadata.json +1 -1
- package/pipes/to-country-code/index.d.ts +2 -0
- package/pipes/to-country-code/package.json +13 -0
- package/pipes/to-country-code/taiga-ui-kit-pipes-to-country-code.d.ts +4 -0
- package/pipes/to-country-code/taiga-ui-kit-pipes-to-country-code.metadata.json +1 -0
- package/pipes/to-country-code/to-country-code.module.d.ts +2 -0
- package/pipes/to-country-code/to-country-code.pipe.d.ts +7 -0
- package/tokens/index.d.ts +1 -0
- package/tokens/taiga-ui-kit-tokens.metadata.json +1 -1
- package/utils/index.d.ts +1 -0
- package/utils/phone/get-max-allowed-phone-length.d.ts +2 -0
- package/utils/phone/index.d.ts +3 -0
- package/utils/phone/iso-to-country-code.d.ts +2 -0
- package/utils/phone/not-kz-region.d.ts +1 -0
- package/utils/phone/package.json +13 -0
- package/utils/phone/taiga-ui-kit-utils-phone.d.ts +4 -0
- package/utils/phone/taiga-ui-kit-utils-phone.metadata.json +1 -0
- package/utils/taiga-ui-kit-utils.metadata.json +1 -1
- package/components/input-phone-international/country-iso-code.d.ts +0 -207
- package/esm2015/components/input-phone-international/const/countries.js +0 -265
- package/esm2015/components/input-phone-international/country-iso-code.js +0 -209
- package/esm2015/components/input-phone-international/interfaces/country.js +0 -1
- package/esm2015/components/input-phone-international/tokens/countries-masks.js +0 -6
- package/esm5/components/input-phone-international/const/countries.js +0 -268
- package/esm5/components/input-phone-international/country-iso-code.js +0 -209
- package/esm5/components/input-phone-international/interfaces/country.js +0 -1
- package/esm5/components/input-phone-international/tokens/countries-masks.js +0 -6
- /package/{components/input-phone-international/interfaces → interfaces}/country.d.ts +0 -0
- /package/{components/input-phone-international/tokens → tokens}/countries-masks.d.ts +0 -0
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './get-max-allowed-phone-length';
|
|
2
|
+
export * from './iso-to-country-code';
|
|
3
|
+
export * from './not-kz-region';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AdGFpZ2EtdWkva2l0L3V0aWxzL3Bob25lLyIsInNvdXJjZXMiOlsiaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2dldC1tYXgtYWxsb3dlZC1waG9uZS1sZW5ndGgnO1xuZXhwb3J0ICogZnJvbSAnLi9pc28tdG8tY291bnRyeS1jb2RlJztcbmV4cG9ydCAqIGZyb20gJy4vbm90LWt6LXJlZ2lvbic7XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { MASK_AFTER_CODE_REGEXP } from '@taiga-ui/kit/constants';
|
|
2
|
+
export function tuiIsoToCountryCode(countriesMasks, isoCode) {
|
|
3
|
+
return countriesMasks[isoCode].replace(MASK_AFTER_CODE_REGEXP, ``);
|
|
4
|
+
}
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNvLXRvLWNvdW50cnktY29kZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0B0YWlnYS11aS9raXQvdXRpbHMvcGhvbmUvIiwic291cmNlcyI6WyJpc28tdG8tY291bnRyeS1jb2RlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBRS9ELE1BQU0sVUFBVSxtQkFBbUIsQ0FDL0IsY0FBaUQsRUFDakQsT0FBMEI7SUFFMUIsT0FBTyxjQUFjLENBQUMsT0FBTyxDQUFDLENBQUMsT0FBTyxDQUFDLHNCQUFzQixFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQ3ZFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1R1aUNvdW50cnlJc29Db2RlfSBmcm9tICdAdGFpZ2EtdWkvaTE4bic7XG5pbXBvcnQge01BU0tfQUZURVJfQ09ERV9SRUdFWFB9IGZyb20gJ0B0YWlnYS11aS9raXQvY29uc3RhbnRzJztcblxuZXhwb3J0IGZ1bmN0aW9uIHR1aUlzb1RvQ291bnRyeUNvZGUoXG4gICAgY291bnRyaWVzTWFza3M6IFJlY29yZDxUdWlDb3VudHJ5SXNvQ29kZSwgc3RyaW5nPixcbiAgICBpc29Db2RlOiBUdWlDb3VudHJ5SXNvQ29kZSxcbik6IHN0cmluZyB7XG4gICAgcmV0dXJuIGNvdW50cmllc01hc2tzW2lzb0NvZGVdLnJlcGxhY2UoTUFTS19BRlRFUl9DT0RFX1JFR0VYUCwgYGApO1xufVxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export function tuiNotKzRegion(value) {
|
|
2
|
+
const region = Number(value.slice(1, 4));
|
|
3
|
+
return region < 600 || region > 799;
|
|
4
|
+
}
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90LWt6LXJlZ2lvbi5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0B0YWlnYS11aS9raXQvdXRpbHMvcGhvbmUvIiwic291cmNlcyI6WyJub3Qta3otcmVnaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSxjQUFjLENBQUMsS0FBYTtJQUN4QyxNQUFNLE1BQU0sR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUV6QyxPQUFPLE1BQU0sR0FBRyxHQUFHLElBQUksTUFBTSxHQUFHLEdBQUcsQ0FBQztBQUN4QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIHR1aU5vdEt6UmVnaW9uKHZhbHVlOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICBjb25zdCByZWdpb24gPSBOdW1iZXIodmFsdWUuc2xpY2UoMSwgNCkpO1xuXG4gICAgcmV0dXJuIHJlZ2lvbiA8IDYwMCB8fCByZWdpb24gPiA3OTk7XG59XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWkta2l0LXV0aWxzLXBob25lLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHRhaWdhLXVpL2tpdC91dGlscy9waG9uZS8iLCJzb3VyY2VzIjpbInRhaWdhLXVpLWtpdC11dGlscy1waG9uZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
|
@@ -1,8 +1,5 @@
|
|
|
1
|
-
export * from './const/countries';
|
|
2
|
-
export * from './country-iso-code';
|
|
3
1
|
export * from './input-phone-international.component';
|
|
4
2
|
export * from './input-phone-international.module';
|
|
5
3
|
export * from './input-phone-international.options';
|
|
6
|
-
export * from './tokens/countries-masks';
|
|
7
4
|
export * from './utils/extract-value-from-event';
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtcGhvbmUtaW50ZXJuYXRpb25hbC8iLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0NBQWtDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2lucHV0LXBob25lLWludGVybmF0aW9uYWwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtcGhvbmUtaW50ZXJuYXRpb25hbC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1waG9uZS1pbnRlcm5hdGlvbmFsLm9wdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9leHRyYWN0LXZhbHVlLWZyb20tZXZlbnQnO1xuIl19
|
|
@@ -6,29 +6,30 @@ import { TUI_MASK_SYMBOLS_REGEXP, TUI_NON_DIGITS_REGEXP, TuiFlagPipe, TuiPrimiti
|
|
|
6
6
|
import { TuiCountryIsoCode } from '@taiga-ui/i18n';
|
|
7
7
|
import { TUI_ARROW } from '@taiga-ui/kit/components/arrow';
|
|
8
8
|
import { TuiInputPhoneComponent } from '@taiga-ui/kit/components/input-phone';
|
|
9
|
+
import { TuiToCountryCodePipe } from '@taiga-ui/kit/pipes';
|
|
9
10
|
import { FIXED_DROPDOWN_CONTROLLER_PROVIDER } from '@taiga-ui/kit/providers';
|
|
10
|
-
import { TUI_COUNTRIES } from '@taiga-ui/kit/tokens';
|
|
11
|
+
import { TUI_COUNTRIES, TUI_COUNTRIES_MASKS } from '@taiga-ui/kit/tokens';
|
|
12
|
+
import { tuiGetMaxAllowedPhoneLength, tuiIsoToCountryCode } from '@taiga-ui/kit/utils';
|
|
11
13
|
import { Observable } from 'rxjs';
|
|
12
|
-
import { MASK_AFTER_CODE_REGEXP } from './const/countries';
|
|
13
14
|
import { TUI_INPUT_PHONE_INTERNATIONAL_OPTIONS, } from './input-phone-international.options';
|
|
14
|
-
import {
|
|
15
|
-
import { extractValueFromEvent } from './utils/extract-value-from-event';
|
|
15
|
+
import { tuiExtractValueFromEvent } from './utils/extract-value-from-event';
|
|
16
16
|
// @dynamic
|
|
17
17
|
var TuiInputPhoneInternationalComponent = /** @class */ (function (_super) {
|
|
18
18
|
__extends(TuiInputPhoneInternationalComponent, _super);
|
|
19
|
-
function TuiInputPhoneInternationalComponent(control, changeDetectorRef, countriesNames$, countriesMasks, options, flagPipe) {
|
|
19
|
+
function TuiInputPhoneInternationalComponent(control, changeDetectorRef, countriesNames$, countriesMasks, options, flagPipe, extractCountryCodePipe) {
|
|
20
20
|
var _this = _super.call(this, control, changeDetectorRef) || this;
|
|
21
21
|
_this.countriesNames$ = countriesNames$;
|
|
22
22
|
_this.countriesMasks = countriesMasks;
|
|
23
23
|
_this.options = options;
|
|
24
24
|
_this.flagPipe = flagPipe;
|
|
25
|
+
_this.extractCountryCodePipe = extractCountryCodePipe;
|
|
25
26
|
_this.countries = _this.options.countries;
|
|
26
27
|
_this.countryIsoCodeChange = new EventEmitter();
|
|
27
28
|
_this.countryIsoCode = _this.options.countryIsoCode;
|
|
28
29
|
_this.open = false;
|
|
29
30
|
_this.arrow = TUI_ARROW;
|
|
30
31
|
_this.isoToCountryCodeMapper = function (item) {
|
|
31
|
-
return _this.
|
|
32
|
+
return tuiIsoToCountryCode(_this.countriesMasks, item);
|
|
32
33
|
};
|
|
33
34
|
return _this;
|
|
34
35
|
}
|
|
@@ -61,14 +62,14 @@ var TuiInputPhoneInternationalComponent = /** @class */ (function (_super) {
|
|
|
61
62
|
});
|
|
62
63
|
Object.defineProperty(TuiInputPhoneInternationalComponent.prototype, "inputPhoneCountryCode", {
|
|
63
64
|
get: function () {
|
|
64
|
-
return this.
|
|
65
|
+
return tuiIsoToCountryCode(this.countriesMasks, this.countryIsoCode);
|
|
65
66
|
},
|
|
66
67
|
enumerable: true,
|
|
67
68
|
configurable: true
|
|
68
69
|
});
|
|
69
70
|
Object.defineProperty(TuiInputPhoneInternationalComponent.prototype, "phoneMaskAfterCountryCode", {
|
|
70
71
|
get: function () {
|
|
71
|
-
var countryCode = this.
|
|
72
|
+
var countryCode = this.inputPhoneCountryCode;
|
|
72
73
|
return this.calculateMaskAfterCountryCode(this.countriesMasks[this.countryIsoCode], countryCode);
|
|
73
74
|
},
|
|
74
75
|
enumerable: true,
|
|
@@ -86,12 +87,12 @@ var TuiInputPhoneInternationalComponent = /** @class */ (function (_super) {
|
|
|
86
87
|
configurable: true
|
|
87
88
|
});
|
|
88
89
|
TuiInputPhoneInternationalComponent.prototype.onPaste = function (event) {
|
|
89
|
-
var value =
|
|
90
|
-
var countryIsoCode = this.
|
|
90
|
+
var value = tuiExtractValueFromEvent(event).replace(TUI_NON_DIGITS_REGEXP, '');
|
|
91
|
+
var countryIsoCode = this.extractCountryCodePipe.transform(value, this.countries);
|
|
91
92
|
if (!countryIsoCode) {
|
|
92
93
|
this.updateValue(("" + this.inputPhoneCountryCode + value)
|
|
93
94
|
.replace(TUI_MASK_SYMBOLS_REGEXP, '')
|
|
94
|
-
.slice(0, this.
|
|
95
|
+
.slice(0, tuiGetMaxAllowedPhoneLength(this.countriesMasks, this.countryIsoCode)));
|
|
95
96
|
return;
|
|
96
97
|
}
|
|
97
98
|
if (countryIsoCode === TuiCountryIsoCode.RU) {
|
|
@@ -112,7 +113,7 @@ var TuiInputPhoneInternationalComponent = /** @class */ (function (_super) {
|
|
|
112
113
|
this.updateCountryIsoCode(isoCode);
|
|
113
114
|
// recalculates mask inside inputPhone to prevent isoCode conflict
|
|
114
115
|
this.changeDetectorRef.detectChanges();
|
|
115
|
-
var maxLength = this.
|
|
116
|
+
var maxLength = tuiGetMaxAllowedPhoneLength(this.countriesMasks, isoCode);
|
|
116
117
|
if (this.value.length > maxLength) {
|
|
117
118
|
this.updateValue(this.value.slice(0, maxLength));
|
|
118
119
|
}
|
|
@@ -124,8 +125,12 @@ var TuiInputPhoneInternationalComponent = /** @class */ (function (_super) {
|
|
|
124
125
|
_super.prototype.setDisabledState.call(this);
|
|
125
126
|
this.close();
|
|
126
127
|
};
|
|
128
|
+
/**
|
|
129
|
+
* @deprecated use `{{ countryIsoCode | tuiIsoToCountryCode }}`
|
|
130
|
+
* TODO drop in v4.0
|
|
131
|
+
*/
|
|
127
132
|
TuiInputPhoneInternationalComponent.prototype.isoToCountryCode = function (isoCode) {
|
|
128
|
-
return this.countriesMasks
|
|
133
|
+
return tuiIsoToCountryCode(this.countriesMasks, isoCode);
|
|
129
134
|
};
|
|
130
135
|
TuiInputPhoneInternationalComponent.prototype.onModelChange = function (value) {
|
|
131
136
|
this.updateValue(value);
|
|
@@ -142,25 +147,10 @@ var TuiInputPhoneInternationalComponent = /** @class */ (function (_super) {
|
|
|
142
147
|
TuiInputPhoneInternationalComponent.prototype.close = function () {
|
|
143
148
|
this.open = false;
|
|
144
149
|
};
|
|
145
|
-
TuiInputPhoneInternationalComponent.prototype.getMaxAllowedLength = function (isoCode) {
|
|
146
|
-
return this.countriesMasks[isoCode].replace(/[()\- ]/g, '').length;
|
|
147
|
-
};
|
|
148
150
|
TuiInputPhoneInternationalComponent.prototype.updateCountryIsoCode = function (code) {
|
|
149
151
|
this.countryIsoCode = code;
|
|
150
152
|
this.countryIsoCodeChange.emit(code);
|
|
151
153
|
};
|
|
152
|
-
TuiInputPhoneInternationalComponent.prototype.extractCountryCode = function (value) {
|
|
153
|
-
var _this = this;
|
|
154
|
-
return this.countries.find(function (countryIsoCode) {
|
|
155
|
-
var ruCodeTest = countryIsoCode === TuiCountryIsoCode.RU &&
|
|
156
|
-
/^[7 | 8]/.test(value) &&
|
|
157
|
-
/^(?!880[1-9 ])/.test(value) &&
|
|
158
|
-
value.length + 1 === _this.getMaxAllowedLength(TuiCountryIsoCode.RU);
|
|
159
|
-
return (ruCodeTest ||
|
|
160
|
-
(value.startsWith(_this.isoToCountryCode(countryIsoCode).replace(CHAR_PLUS, '')) &&
|
|
161
|
-
value.length + 1 === _this.getMaxAllowedLength(countryIsoCode)));
|
|
162
|
-
});
|
|
163
|
-
};
|
|
164
154
|
var TuiInputPhoneInternationalComponent_1;
|
|
165
155
|
TuiInputPhoneInternationalComponent.ctorParameters = function () { return [
|
|
166
156
|
{ type: NgControl, decorators: [{ type: Optional }, { type: Self }, { type: Inject, args: [NgControl,] }] },
|
|
@@ -168,7 +158,8 @@ var TuiInputPhoneInternationalComponent = /** @class */ (function (_super) {
|
|
|
168
158
|
{ type: Observable, decorators: [{ type: Inject, args: [TUI_COUNTRIES,] }] },
|
|
169
159
|
{ type: undefined, decorators: [{ type: Inject, args: [TUI_COUNTRIES_MASKS,] }] },
|
|
170
160
|
{ type: undefined, decorators: [{ type: Inject, args: [TUI_INPUT_PHONE_INTERNATIONAL_OPTIONS,] }] },
|
|
171
|
-
{ type: TuiFlagPipe, decorators: [{ type: Inject, args: [TuiFlagPipe,] }] }
|
|
161
|
+
{ type: TuiFlagPipe, decorators: [{ type: Inject, args: [TuiFlagPipe,] }] },
|
|
162
|
+
{ type: TuiToCountryCodePipe, decorators: [{ type: Inject, args: [TuiToCountryCodePipe,] }] }
|
|
172
163
|
]; };
|
|
173
164
|
__decorate([
|
|
174
165
|
ViewChild(TuiInputPhoneComponent)
|
|
@@ -206,6 +197,7 @@ var TuiInputPhoneInternationalComponent = /** @class */ (function (_super) {
|
|
|
206
197
|
FIXED_DROPDOWN_CONTROLLER_PROVIDER,
|
|
207
198
|
// TODO: for backward compatibility only. Drop in v4.0
|
|
208
199
|
TuiFlagPipe,
|
|
200
|
+
TuiToCountryCodePipe,
|
|
209
201
|
],
|
|
210
202
|
styles: [":host{display:block}:host._disabled{pointer-events:none}.t-hosted-dropdown{display:block}.t-country-select{width:5.625rem}.t-country-select:not(._readonly) ::ng-deep input:not(:disabled){cursor:pointer}.t-country-select._readonly ::ng-deep input{cursor:default}.t-arrow-icon{transition-duration:var(--tui-duration,300ms);transition-timing-function:ease-in-out;display:flex;width:1.5rem;height:1.5rem;align-items:center;justify-content:center;color:var(--tui-text-03);position:relative;box-sizing:border-box;cursor:pointer;transition-property:color,transform}.t-arrow-icon:hover{color:var(--tui-text-02)}:host._disabled .t-arrow-icon,:host._readonly .t-arrow-icon{pointer-events:none}:host[data-mode=onDark] .t-arrow-icon{color:var(--tui-text-03-night)}:host[data-mode=onDark] .t-arrow-icon:hover{color:var(--tui-text-01-night)}.t-arrow-icon_open{transform:rotate(180deg)}.t-input-phone{flex:1}.t-flag{width:1.75rem;height:1.25rem;margin-left:-.5rem}.t-country-item-flag{width:1.75rem;height:1.25rem}.t-country-item-name{margin-left:.75rem;margin-right:auto}.t-country-item-code{color:var(--tui-text-02);margin-right:.25rem}"]
|
|
211
203
|
}),
|
|
@@ -216,9 +208,10 @@ var TuiInputPhoneInternationalComponent = /** @class */ (function (_super) {
|
|
|
216
208
|
__param(2, Inject(TUI_COUNTRIES)),
|
|
217
209
|
__param(3, Inject(TUI_COUNTRIES_MASKS)),
|
|
218
210
|
__param(4, Inject(TUI_INPUT_PHONE_INTERNATIONAL_OPTIONS)),
|
|
219
|
-
__param(5, Inject(TuiFlagPipe))
|
|
211
|
+
__param(5, Inject(TuiFlagPipe)),
|
|
212
|
+
__param(6, Inject(TuiToCountryCodePipe))
|
|
220
213
|
], TuiInputPhoneInternationalComponent);
|
|
221
214
|
return TuiInputPhoneInternationalComponent;
|
|
222
215
|
}(AbstractTuiControl));
|
|
223
216
|
export { TuiInputPhoneInternationalComponent };
|
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-phone-international.component.js","sourceRoot":"ng://@taiga-ui/kit/components/input-phone-international/","sources":["input-phone-international.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    forwardRef,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiControl,\n    CHAR_PLUS,\n    setNativeFocused,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiMapper,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_MASK_SYMBOLS_REGEXP,\n    TUI_NON_DIGITS_REGEXP,\n    TuiFlagPipe,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeM,\n    TuiSizeS,\n} from '@taiga-ui/core';\nimport {TuiCountryIsoCode} from '@taiga-ui/i18n';\nimport {TUI_ARROW} from '@taiga-ui/kit/components/arrow';\nimport {TuiInputPhoneComponent} from '@taiga-ui/kit/components/input-phone';\nimport {FIXED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {TUI_COUNTRIES} from '@taiga-ui/kit/tokens';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\n\nimport {MASK_AFTER_CODE_REGEXP} from './const/countries';\nimport {\n    TUI_INPUT_PHONE_INTERNATIONAL_OPTIONS,\n    TuiInputPhoneInternationalOptions,\n} from './input-phone-international.options';\nimport {TUI_COUNTRIES_MASKS} from './tokens/countries-masks';\nimport {extractValueFromEvent} from './utils/extract-value-from-event';\n\n// @dynamic\n@Component({\n    selector: 'tui-input-phone-international',\n    templateUrl: './input-phone-international.template.html',\n    styleUrls: ['./input-phone-international.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiInputPhoneInternationalComponent),\n        },\n        FIXED_DROPDOWN_CONTROLLER_PROVIDER,\n        // TODO: for backward compatibility only. Drop in v4.0\n        TuiFlagPipe,\n    ],\n})\nexport class TuiInputPhoneInternationalComponent\n    extends AbstractTuiControl<string>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild(TuiInputPhoneComponent)\n    private readonly inputPhoneComponent?: TuiInputPhoneComponent;\n\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly primitiveTextfield?: TuiPrimitiveTextfieldComponent;\n\n    @Input('countryIsoCode')\n    @tuiDefaultProp()\n    set isoCode(code: TuiCountryIsoCode) {\n        this.inputPhoneComponent?.writeValue(this.value);\n        this.countryIsoCode = code;\n    }\n\n    @Input()\n    countries = this.options.countries;\n\n    @Output()\n    readonly countryIsoCodeChange = new EventEmitter<TuiCountryIsoCode>();\n\n    countryIsoCode = this.options.countryIsoCode;\n\n    open = false;\n\n    readonly arrow: PolymorpheusContent<\n        TuiContextWithImplicit<TuiSizeL | TuiSizeM | TuiSizeS>\n    > = TUI_ARROW;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_COUNTRIES)\n        readonly countriesNames$: Observable<Record<TuiCountryIsoCode, string>>,\n        @Inject(TUI_COUNTRIES_MASKS)\n        readonly countriesMasks: Record<TuiCountryIsoCode, string>,\n        @Inject(TUI_INPUT_PHONE_INTERNATIONAL_OPTIONS)\n        private readonly options: TuiInputPhoneInternationalOptions,\n        @Inject(TuiFlagPipe)\n        private readonly flagPipe: TuiFlagPipe,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): HTMLElement | null {\n        return this.inputPhoneComponent && !this.computedDisabled\n            ? this.inputPhoneComponent.nativeFocusableElement\n            : null;\n    }\n\n    get focused(): boolean {\n        return (\n            (!!this.primitiveTextfield && this.primitiveTextfield.focused) ||\n            (!!this.inputPhoneComponent && this.inputPhoneComponent.focused)\n        );\n    }\n\n    get inputPhoneCountryCode(): string {\n        return this.isoToCountryCode(this.countryIsoCode);\n    }\n\n    get phoneMaskAfterCountryCode(): string {\n        const countryCode = this.isoToCountryCode(this.countryIsoCode);\n\n        return this.calculateMaskAfterCountryCode(\n            this.countriesMasks[this.countryIsoCode],\n            countryCode,\n        );\n    }\n\n    /**\n     * @deprecated use `<img [src]=\"countryIsoCode | tuiFlagPipe\" />`\n     * TODO drop in v4.0\n     */\n    get countryFlagPath(): string {\n        return this.getFlagPath(this.countryIsoCode);\n    }\n\n    @HostListener('paste.capture.prevent.stop', ['$event'])\n    @HostListener('drop.capture.prevent.stop', ['$event'])\n    onPaste(event: ClipboardEvent | DragEvent): void {\n        let value = extractValueFromEvent(event).replace(TUI_NON_DIGITS_REGEXP, '');\n        const countryIsoCode = this.extractCountryCode(value);\n\n        if (!countryIsoCode) {\n            this.updateValue(\n                `${this.inputPhoneCountryCode}${value}`\n                    .replace(TUI_MASK_SYMBOLS_REGEXP, '')\n                    .slice(0, this.getMaxAllowedLength(this.countryIsoCode)),\n            );\n\n            return;\n        }\n\n        if (countryIsoCode === TuiCountryIsoCode.RU) {\n            value = value.replace(/^8/, '7');\n        }\n\n        this.updateCountryIsoCode(countryIsoCode);\n        this.updateValue(`${CHAR_PLUS}${value}`);\n    }\n\n    readonly isoToCountryCodeMapper: TuiMapper<TuiCountryIsoCode, string> = item =>\n        this.isoToCountryCode(item);\n\n    /**\n     * @deprecated use `<img [src]=\"countryIsoCode | tuiFlagPipe\" />`\n     * TODO drop in v4.0\n     */\n    getFlagPath(code: TuiCountryIsoCode): string {\n        return this.flagPipe.transform(code);\n    }\n\n    onItemClick(isoCode: TuiCountryIsoCode): void {\n        this.open = false;\n        this.updateCountryIsoCode(isoCode);\n        // recalculates mask inside inputPhone to prevent isoCode conflict\n        this.changeDetectorRef.detectChanges();\n\n        const maxLength = this.getMaxAllowedLength(isoCode);\n\n        if (this.value.length > maxLength) {\n            this.updateValue(this.value.slice(0, maxLength));\n        }\n\n        if (this.nativeFocusableElement) {\n            setNativeFocused(this.nativeFocusableElement);\n        }\n    }\n\n    setDisabledState(): void {\n        super.setDisabledState();\n        this.close();\n    }\n\n    isoToCountryCode(isoCode: TuiCountryIsoCode): string {\n        return this.countriesMasks[isoCode].replace(MASK_AFTER_CODE_REGEXP, '');\n    }\n\n    onModelChange(value: string): void {\n        this.updateValue(value);\n    }\n\n    onActiveZone(active: boolean): void {\n        this.updateFocused(active);\n    }\n\n    protected getFallbackValue(): string {\n        return '';\n    }\n\n    @tuiPure\n    private calculateMaskAfterCountryCode(mask: string, countryCode: string): string {\n        return mask.replace(countryCode, '').trim();\n    }\n\n    private close(): void {\n        this.open = false;\n    }\n\n    private getMaxAllowedLength(isoCode: TuiCountryIsoCode): number {\n        return this.countriesMasks[isoCode].replace(/[()\\- ]/g, '').length;\n    }\n\n    private updateCountryIsoCode(code: TuiCountryIsoCode): void {\n        this.countryIsoCode = code;\n        this.countryIsoCodeChange.emit(code);\n    }\n\n    private extractCountryCode(value: string): TuiCountryIsoCode | undefined {\n        return this.countries.find(countryIsoCode => {\n            const ruCodeTest =\n                countryIsoCode === TuiCountryIsoCode.RU &&\n                /^[7 | 8]/.test(value) &&\n                /^(?!880[1-9 ])/.test(value) &&\n                value.length + 1 === this.getMaxAllowedLength(TuiCountryIsoCode.RU);\n\n            return (\n                ruCodeTest ||\n                (value.startsWith(\n                    this.isoToCountryCode(countryIsoCode).replace(CHAR_PLUS, ''),\n                ) &&\n                    value.length + 1 === this.getMaxAllowedLength(countryIsoCode))\n            );\n        });\n    }\n}\n"]}
|
|
217
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-phone-international.component.js","sourceRoot":"ng://@taiga-ui/kit/components/input-phone-international/","sources":["input-phone-international.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    forwardRef,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiControl,\n    CHAR_PLUS,\n    setNativeFocused,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiMapper,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_MASK_SYMBOLS_REGEXP,\n    TUI_NON_DIGITS_REGEXP,\n    TuiFlagPipe,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeM,\n    TuiSizeS,\n} from '@taiga-ui/core';\nimport {TuiCountryIsoCode} from '@taiga-ui/i18n';\nimport {TUI_ARROW} from '@taiga-ui/kit/components/arrow';\nimport {TuiInputPhoneComponent} from '@taiga-ui/kit/components/input-phone';\nimport {TuiToCountryCodePipe} from '@taiga-ui/kit/pipes';\nimport {FIXED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {TUI_COUNTRIES, TUI_COUNTRIES_MASKS} from '@taiga-ui/kit/tokens';\nimport {tuiGetMaxAllowedPhoneLength, tuiIsoToCountryCode} from '@taiga-ui/kit/utils';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\n\nimport {\n    TUI_INPUT_PHONE_INTERNATIONAL_OPTIONS,\n    TuiInputPhoneInternationalOptions,\n} from './input-phone-international.options';\nimport {tuiExtractValueFromEvent} from './utils/extract-value-from-event';\n\n// @dynamic\n@Component({\n    selector: 'tui-input-phone-international',\n    templateUrl: './input-phone-international.template.html',\n    styleUrls: ['./input-phone-international.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiInputPhoneInternationalComponent),\n        },\n        FIXED_DROPDOWN_CONTROLLER_PROVIDER,\n        // TODO: for backward compatibility only. Drop in v4.0\n        TuiFlagPipe,\n        TuiToCountryCodePipe,\n    ],\n})\nexport class TuiInputPhoneInternationalComponent\n    extends AbstractTuiControl<string>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild(TuiInputPhoneComponent)\n    private readonly inputPhoneComponent?: TuiInputPhoneComponent;\n\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly primitiveTextfield?: TuiPrimitiveTextfieldComponent;\n\n    @Input('countryIsoCode')\n    @tuiDefaultProp()\n    set isoCode(code: TuiCountryIsoCode) {\n        this.inputPhoneComponent?.writeValue(this.value);\n        this.countryIsoCode = code;\n    }\n\n    @Input()\n    countries = this.options.countries;\n\n    @Output()\n    readonly countryIsoCodeChange = new EventEmitter<TuiCountryIsoCode>();\n\n    countryIsoCode = this.options.countryIsoCode;\n\n    open = false;\n\n    readonly arrow: PolymorpheusContent<\n        TuiContextWithImplicit<TuiSizeL | TuiSizeM | TuiSizeS>\n    > = TUI_ARROW;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_COUNTRIES)\n        readonly countriesNames$: Observable<Record<TuiCountryIsoCode, string>>,\n        @Inject(TUI_COUNTRIES_MASKS)\n        readonly countriesMasks: Record<TuiCountryIsoCode, string>,\n        @Inject(TUI_INPUT_PHONE_INTERNATIONAL_OPTIONS)\n        private readonly options: TuiInputPhoneInternationalOptions,\n        @Inject(TuiFlagPipe)\n        private readonly flagPipe: TuiFlagPipe,\n        @Inject(TuiToCountryCodePipe)\n        private readonly extractCountryCodePipe: TuiToCountryCodePipe,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): HTMLElement | null {\n        return this.inputPhoneComponent && !this.computedDisabled\n            ? this.inputPhoneComponent.nativeFocusableElement\n            : null;\n    }\n\n    get focused(): boolean {\n        return (\n            (!!this.primitiveTextfield && this.primitiveTextfield.focused) ||\n            (!!this.inputPhoneComponent && this.inputPhoneComponent.focused)\n        );\n    }\n\n    get inputPhoneCountryCode(): string {\n        return tuiIsoToCountryCode(this.countriesMasks, this.countryIsoCode);\n    }\n\n    get phoneMaskAfterCountryCode(): string {\n        const countryCode = this.inputPhoneCountryCode;\n\n        return this.calculateMaskAfterCountryCode(\n            this.countriesMasks[this.countryIsoCode],\n            countryCode,\n        );\n    }\n\n    /**\n     * @deprecated use `<img [src]=\"countryIsoCode | tuiFlagPipe\" />`\n     * TODO drop in v4.0\n     */\n    get countryFlagPath(): string {\n        return this.getFlagPath(this.countryIsoCode);\n    }\n\n    @HostListener('paste.capture.prevent.stop', ['$event'])\n    @HostListener('drop.capture.prevent.stop', ['$event'])\n    onPaste(event: ClipboardEvent | DragEvent): void {\n        let value = tuiExtractValueFromEvent(event).replace(TUI_NON_DIGITS_REGEXP, '');\n        const countryIsoCode = this.extractCountryCodePipe.transform(\n            value,\n            this.countries,\n        );\n\n        if (!countryIsoCode) {\n            this.updateValue(\n                `${this.inputPhoneCountryCode}${value}`\n                    .replace(TUI_MASK_SYMBOLS_REGEXP, '')\n                    .slice(\n                        0,\n                        tuiGetMaxAllowedPhoneLength(\n                            this.countriesMasks,\n                            this.countryIsoCode,\n                        ),\n                    ),\n            );\n\n            return;\n        }\n\n        if (countryIsoCode === TuiCountryIsoCode.RU) {\n            value = value.replace(/^8/, '7');\n        }\n\n        this.updateCountryIsoCode(countryIsoCode);\n        this.updateValue(`${CHAR_PLUS}${value}`);\n    }\n\n    readonly isoToCountryCodeMapper: TuiMapper<TuiCountryIsoCode, string> = item =>\n        tuiIsoToCountryCode(this.countriesMasks, item);\n\n    /**\n     * @deprecated use `<img [src]=\"countryIsoCode | tuiFlagPipe\" />`\n     * TODO drop in v4.0\n     */\n    getFlagPath(code: TuiCountryIsoCode): string {\n        return this.flagPipe.transform(code);\n    }\n\n    onItemClick(isoCode: TuiCountryIsoCode): void {\n        this.open = false;\n        this.updateCountryIsoCode(isoCode);\n        // recalculates mask inside inputPhone to prevent isoCode conflict\n        this.changeDetectorRef.detectChanges();\n\n        const maxLength = tuiGetMaxAllowedPhoneLength(this.countriesMasks, isoCode);\n\n        if (this.value.length > maxLength) {\n            this.updateValue(this.value.slice(0, maxLength));\n        }\n\n        if (this.nativeFocusableElement) {\n            setNativeFocused(this.nativeFocusableElement);\n        }\n    }\n\n    setDisabledState(): void {\n        super.setDisabledState();\n        this.close();\n    }\n\n    /**\n     * @deprecated use `{{ countryIsoCode | tuiIsoToCountryCode }}`\n     * TODO drop in v4.0\n     */\n    isoToCountryCode(isoCode: TuiCountryIsoCode): string {\n        return tuiIsoToCountryCode(this.countriesMasks, isoCode);\n    }\n\n    onModelChange(value: string): void {\n        this.updateValue(value);\n    }\n\n    onActiveZone(active: boolean): void {\n        this.updateFocused(active);\n    }\n\n    protected getFallbackValue(): string {\n        return '';\n    }\n\n    @tuiPure\n    private calculateMaskAfterCountryCode(mask: string, countryCode: string): string {\n        return mask.replace(countryCode, '').trim();\n    }\n\n    private close(): void {\n        this.open = false;\n    }\n\n    private updateCountryIsoCode(code: TuiCountryIsoCode): void {\n        this.countryIsoCode = code;\n        this.countryIsoCodeChange.emit(code);\n    }\n}\n"]}
|