@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.
Files changed (156) hide show
  1. package/bundles/taiga-ui-kit-components-input-phone-international.umd.js +25 -516
  2. package/bundles/taiga-ui-kit-components-input-phone-international.umd.js.map +1 -1
  3. package/bundles/taiga-ui-kit-components-input-phone-international.umd.min.js +1 -1
  4. package/bundles/taiga-ui-kit-components-input-phone-international.umd.min.js.map +1 -1
  5. package/bundles/taiga-ui-kit-constants.umd.js +275 -4
  6. package/bundles/taiga-ui-kit-constants.umd.js.map +1 -1
  7. package/bundles/taiga-ui-kit-constants.umd.min.js +1 -1
  8. package/bundles/taiga-ui-kit-constants.umd.min.js.map +1 -1
  9. package/bundles/taiga-ui-kit-pipes-iso-to-country-code.umd.js +339 -0
  10. package/bundles/taiga-ui-kit-pipes-iso-to-country-code.umd.js.map +1 -0
  11. package/bundles/taiga-ui-kit-pipes-iso-to-country-code.umd.min.js +2 -0
  12. package/bundles/taiga-ui-kit-pipes-iso-to-country-code.umd.min.js.map +1 -0
  13. package/bundles/taiga-ui-kit-pipes-to-country-code.umd.js +361 -0
  14. package/bundles/taiga-ui-kit-pipes-to-country-code.umd.js.map +1 -0
  15. package/bundles/taiga-ui-kit-pipes-to-country-code.umd.min.js +2 -0
  16. package/bundles/taiga-ui-kit-pipes-to-country-code.umd.min.js.map +1 -0
  17. package/bundles/taiga-ui-kit-pipes.umd.js +20 -4
  18. package/bundles/taiga-ui-kit-pipes.umd.js.map +1 -1
  19. package/bundles/taiga-ui-kit-pipes.umd.min.js +1 -1
  20. package/bundles/taiga-ui-kit-tokens.umd.js +9 -4
  21. package/bundles/taiga-ui-kit-tokens.umd.js.map +1 -1
  22. package/bundles/taiga-ui-kit-tokens.umd.min.js +1 -1
  23. package/bundles/taiga-ui-kit-tokens.umd.min.js.map +1 -1
  24. package/bundles/taiga-ui-kit-utils-phone.umd.js +27 -0
  25. package/bundles/taiga-ui-kit-utils-phone.umd.js.map +1 -0
  26. package/bundles/taiga-ui-kit-utils-phone.umd.min.js +2 -0
  27. package/bundles/taiga-ui-kit-utils-phone.umd.min.js.map +1 -0
  28. package/bundles/taiga-ui-kit-utils.umd.js +12 -4
  29. package/bundles/taiga-ui-kit-utils.umd.js.map +1 -1
  30. package/bundles/taiga-ui-kit-utils.umd.min.js +1 -1
  31. package/components/input-phone-international/index.d.ts +0 -4
  32. package/components/input-phone-international/input-phone-international.component.d.ts +7 -3
  33. package/components/input-phone-international/taiga-ui-kit-components-input-phone-international.metadata.json +1 -1
  34. package/{components/input-phone-international/const → constants}/countries.d.ts +1 -2
  35. package/constants/index.d.ts +2 -0
  36. package/constants/mask-after-code-regexp.d.ts +1 -0
  37. package/constants/taiga-ui-kit-constants.metadata.json +1 -1
  38. package/esm2015/components/input-phone-international/index.js +1 -4
  39. package/esm2015/components/input-phone-international/input-phone-international.component.js +24 -30
  40. package/esm2015/constants/countries.js +264 -0
  41. package/esm2015/constants/index.js +3 -1
  42. package/esm2015/constants/mask-after-code-regexp.js +2 -0
  43. package/esm2015/interfaces/country.js +1 -0
  44. package/esm2015/interfaces/index.js +1 -1
  45. package/esm2015/pipes/index.js +3 -1
  46. package/esm2015/pipes/iso-to-country-code/index.js +3 -0
  47. package/esm2015/pipes/iso-to-country-code/iso-to-country-code.module.js +13 -0
  48. package/esm2015/pipes/iso-to-country-code/iso-to-country-code.pipe.js +24 -0
  49. package/esm2015/pipes/iso-to-country-code/taiga-ui-kit-pipes-iso-to-country-code.js +5 -0
  50. package/esm2015/pipes/to-country-code/index.js +3 -0
  51. package/esm2015/pipes/to-country-code/taiga-ui-kit-pipes-to-country-code.js +5 -0
  52. package/esm2015/pipes/to-country-code/to-country-code.module.js +13 -0
  53. package/esm2015/pipes/to-country-code/to-country-code.pipe.js +47 -0
  54. package/esm2015/tokens/countries-masks.js +6 -0
  55. package/esm2015/tokens/index.js +2 -1
  56. package/esm2015/utils/index.js +2 -1
  57. package/esm2015/utils/phone/get-max-allowed-phone-length.js +4 -0
  58. package/esm2015/utils/phone/index.js +4 -0
  59. package/esm2015/utils/phone/iso-to-country-code.js +5 -0
  60. package/esm2015/utils/phone/not-kz-region.js +5 -0
  61. package/esm2015/utils/phone/taiga-ui-kit-utils-phone.js +5 -0
  62. package/esm5/components/input-phone-international/index.js +1 -4
  63. package/esm5/components/input-phone-international/input-phone-international.component.js +24 -31
  64. package/esm5/constants/countries.js +267 -0
  65. package/esm5/constants/index.js +3 -1
  66. package/esm5/constants/mask-after-code-regexp.js +2 -0
  67. package/esm5/interfaces/country.js +1 -0
  68. package/esm5/interfaces/index.js +1 -1
  69. package/esm5/pipes/index.js +3 -1
  70. package/esm5/pipes/iso-to-country-code/index.js +3 -0
  71. package/esm5/pipes/iso-to-country-code/iso-to-country-code.module.js +16 -0
  72. package/esm5/pipes/iso-to-country-code/iso-to-country-code.pipe.js +25 -0
  73. package/esm5/pipes/iso-to-country-code/taiga-ui-kit-pipes-iso-to-country-code.js +5 -0
  74. package/esm5/pipes/to-country-code/index.js +3 -0
  75. package/esm5/pipes/to-country-code/taiga-ui-kit-pipes-to-country-code.js +5 -0
  76. package/esm5/pipes/to-country-code/to-country-code.module.js +16 -0
  77. package/esm5/pipes/to-country-code/to-country-code.pipe.js +49 -0
  78. package/esm5/tokens/countries-masks.js +6 -0
  79. package/esm5/tokens/index.js +2 -1
  80. package/esm5/utils/index.js +2 -1
  81. package/esm5/utils/phone/get-max-allowed-phone-length.js +4 -0
  82. package/esm5/utils/phone/index.js +4 -0
  83. package/esm5/utils/phone/iso-to-country-code.js +5 -0
  84. package/esm5/utils/phone/not-kz-region.js +5 -0
  85. package/esm5/utils/phone/taiga-ui-kit-utils-phone.js +5 -0
  86. package/fesm2015/taiga-ui-kit-components-input-phone-international.js +26 -507
  87. package/fesm2015/taiga-ui-kit-components-input-phone-international.js.map +1 -1
  88. package/fesm2015/taiga-ui-kit-constants.js +267 -1
  89. package/fesm2015/taiga-ui-kit-constants.js.map +1 -1
  90. package/fesm2015/taiga-ui-kit-pipes-iso-to-country-code.js +39 -0
  91. package/fesm2015/taiga-ui-kit-pipes-iso-to-country-code.js.map +1 -0
  92. package/fesm2015/taiga-ui-kit-pipes-to-country-code.js +62 -0
  93. package/fesm2015/taiga-ui-kit-pipes-to-country-code.js.map +1 -0
  94. package/fesm2015/taiga-ui-kit-pipes.js +2 -0
  95. package/fesm2015/taiga-ui-kit-pipes.js.map +1 -1
  96. package/fesm2015/taiga-ui-kit-tokens.js +6 -1
  97. package/fesm2015/taiga-ui-kit-tokens.js.map +1 -1
  98. package/fesm2015/taiga-ui-kit-utils-phone.js +21 -0
  99. package/fesm2015/taiga-ui-kit-utils-phone.js.map +1 -0
  100. package/fesm2015/taiga-ui-kit-utils.js +1 -0
  101. package/fesm2015/taiga-ui-kit-utils.js.map +1 -1
  102. package/fesm5/taiga-ui-kit-components-input-phone-international.js +27 -511
  103. package/fesm5/taiga-ui-kit-components-input-phone-international.js.map +1 -1
  104. package/fesm5/taiga-ui-kit-constants.js +270 -2
  105. package/fesm5/taiga-ui-kit-constants.js.map +1 -1
  106. package/fesm5/taiga-ui-kit-pipes-iso-to-country-code.js +43 -0
  107. package/fesm5/taiga-ui-kit-pipes-iso-to-country-code.js.map +1 -0
  108. package/fesm5/taiga-ui-kit-pipes-to-country-code.js +67 -0
  109. package/fesm5/taiga-ui-kit-pipes-to-country-code.js.map +1 -0
  110. package/fesm5/taiga-ui-kit-pipes.js +2 -0
  111. package/fesm5/taiga-ui-kit-pipes.js.map +1 -1
  112. package/fesm5/taiga-ui-kit-tokens.js +6 -1
  113. package/fesm5/taiga-ui-kit-tokens.js.map +1 -1
  114. package/fesm5/taiga-ui-kit-utils-phone.js +21 -0
  115. package/fesm5/taiga-ui-kit-utils-phone.js.map +1 -0
  116. package/fesm5/taiga-ui-kit-utils.js +1 -0
  117. package/fesm5/taiga-ui-kit-utils.js.map +1 -1
  118. package/interfaces/index.d.ts +1 -0
  119. package/interfaces/taiga-ui-kit-interfaces.metadata.json +1 -1
  120. package/package.json +4 -4
  121. package/pipes/index.d.ts +2 -0
  122. package/pipes/iso-to-country-code/index.d.ts +2 -0
  123. package/pipes/iso-to-country-code/iso-to-country-code.module.d.ts +2 -0
  124. package/pipes/iso-to-country-code/iso-to-country-code.pipe.d.ts +7 -0
  125. package/pipes/iso-to-country-code/package.json +13 -0
  126. package/pipes/iso-to-country-code/taiga-ui-kit-pipes-iso-to-country-code.d.ts +4 -0
  127. package/pipes/iso-to-country-code/taiga-ui-kit-pipes-iso-to-country-code.metadata.json +1 -0
  128. package/pipes/taiga-ui-kit-pipes.metadata.json +1 -1
  129. package/pipes/to-country-code/index.d.ts +2 -0
  130. package/pipes/to-country-code/package.json +13 -0
  131. package/pipes/to-country-code/taiga-ui-kit-pipes-to-country-code.d.ts +4 -0
  132. package/pipes/to-country-code/taiga-ui-kit-pipes-to-country-code.metadata.json +1 -0
  133. package/pipes/to-country-code/to-country-code.module.d.ts +2 -0
  134. package/pipes/to-country-code/to-country-code.pipe.d.ts +7 -0
  135. package/tokens/index.d.ts +1 -0
  136. package/tokens/taiga-ui-kit-tokens.metadata.json +1 -1
  137. package/utils/index.d.ts +1 -0
  138. package/utils/phone/get-max-allowed-phone-length.d.ts +2 -0
  139. package/utils/phone/index.d.ts +3 -0
  140. package/utils/phone/iso-to-country-code.d.ts +2 -0
  141. package/utils/phone/not-kz-region.d.ts +1 -0
  142. package/utils/phone/package.json +13 -0
  143. package/utils/phone/taiga-ui-kit-utils-phone.d.ts +4 -0
  144. package/utils/phone/taiga-ui-kit-utils-phone.metadata.json +1 -0
  145. package/utils/taiga-ui-kit-utils.metadata.json +1 -1
  146. package/components/input-phone-international/country-iso-code.d.ts +0 -207
  147. package/esm2015/components/input-phone-international/const/countries.js +0 -265
  148. package/esm2015/components/input-phone-international/country-iso-code.js +0 -209
  149. package/esm2015/components/input-phone-international/interfaces/country.js +0 -1
  150. package/esm2015/components/input-phone-international/tokens/countries-masks.js +0 -6
  151. package/esm5/components/input-phone-international/const/countries.js +0 -268
  152. package/esm5/components/input-phone-international/country-iso-code.js +0 -209
  153. package/esm5/components/input-phone-international/interfaces/country.js +0 -1
  154. package/esm5/components/input-phone-international/tokens/countries-masks.js +0 -6
  155. /package/{components/input-phone-international/interfaces → interfaces}/country.d.ts +0 -0
  156. /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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtcGhvbmUtaW50ZXJuYXRpb25hbC8iLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyxxQ0FBcUMsQ0FBQztBQUVwRCxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsa0NBQWtDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbnN0L2NvdW50cmllcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvdW50cnktaXNvLWNvZGUnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1waG9uZS1pbnRlcm5hdGlvbmFsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LXBob25lLWludGVybmF0aW9uYWwubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtcGhvbmUtaW50ZXJuYXRpb25hbC5vcHRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlcy9jb3VudHJ5JztcbmV4cG9ydCAqIGZyb20gJy4vdG9rZW5zL2NvdW50cmllcy1tYXNrcyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL2V4dHJhY3QtdmFsdWUtZnJvbS1ldmVudCc7XG4iXX0=
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 { TUI_COUNTRIES_MASKS } from './tokens/countries-masks';
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.isoToCountryCode(item);
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.isoToCountryCode(this.countryIsoCode);
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.isoToCountryCode(this.countryIsoCode);
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 = extractValueFromEvent(event).replace(TUI_NON_DIGITS_REGEXP, '');
90
- var countryIsoCode = this.extractCountryCode(value);
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.getMaxAllowedLength(this.countryIsoCode)));
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.getMaxAllowedLength(isoCode);
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[isoCode].replace(MASK_AFTER_CODE_REGEXP, '');
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":";AAAA,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EACL,QAAQ,EACR,MAAM,EACN,IAAI,EACJ,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACzC,OAAO,EACH,kBAAkB,EAClB,SAAS,EACT,gBAAgB,EAChB,2BAA2B,EAE3B,cAAc,EAGd,OAAO,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,uBAAuB,EACvB,qBAAqB,EACrB,WAAW,EACX,8BAA8B,EAC9B,QAAQ,EACR,QAAQ,EACR,QAAQ,GACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAC,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAC,SAAS,EAAC,MAAM,gCAAgC,CAAC;AACzD,OAAO,EAAC,sBAAsB,EAAC,MAAM,sCAAsC,CAAC;AAC5E,OAAO,EAAC,kCAAkC,EAAC,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAEnD,OAAO,EAAC,UAAU,EAAC,MAAM,MAAM,CAAC;AAEhC,OAAO,EAAC,sBAAsB,EAAC,MAAM,mBAAmB,CAAC;AACzD,OAAO,EACH,qCAAqC,GAExC,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAC,mBAAmB,EAAC,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAC,qBAAqB,EAAC,MAAM,kCAAkC,CAAC;AAEvE,WAAW;AAgBX;IACY,uDAA0B;IA8BlC,6CAII,OAAyB,EACE,iBAAoC,EAEtD,eAA8D,EAE9D,cAAiD,EAEzC,OAA0C,EAE1C,QAAqB;QAb1C,YAeI,kBAAM,OAAO,EAAE,iBAAiB,CAAC,SACpC;QATY,qBAAe,GAAf,eAAe,CAA+C;QAE9D,oBAAc,GAAd,cAAc,CAAmC;QAEzC,aAAO,GAAP,OAAO,CAAmC;QAE1C,cAAQ,GAAR,QAAQ,CAAa;QA1B1C,eAAS,GAAG,KAAI,CAAC,OAAO,CAAC,SAAS,CAAC;QAG1B,0BAAoB,GAAG,IAAI,YAAY,EAAqB,CAAC;QAEtE,oBAAc,GAAG,KAAI,CAAC,OAAO,CAAC,cAAc,CAAC;QAE7C,UAAI,GAAG,KAAK,CAAC;QAEJ,WAAK,GAEV,SAAS,CAAC;QA8EL,4BAAsB,GAAyC,UAAA,IAAI;YACxE,OAAA,KAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC;QAA3B,CAA2B,CAAC;;IA7DhC,CAAC;4CA/CQ,mCAAmC;IAY5C,sBAAI,wDAAO;aAAX,UAAY,IAAuB;;YAC/B,MAAA,IAAI,CAAC,mBAAmB,0CAAE,UAAU,CAAC,IAAI,CAAC,KAAK,EAAE;YACjD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC/B,CAAC;;;OAAA;IAkCD,sBAAI,uEAAsB;aAA1B;YACI,OAAO,IAAI,CAAC,mBAAmB,IAAI,CAAC,IAAI,CAAC,gBAAgB;gBACrD,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,sBAAsB;gBACjD,CAAC,CAAC,IAAI,CAAC;QACf,CAAC;;;OAAA;IAED,sBAAI,wDAAO;aAAX;YACI,OAAO,CACH,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC;gBAC9D,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CACnE,CAAC;QACN,CAAC;;;OAAA;IAED,sBAAI,sEAAqB;aAAzB;YACI,OAAO,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACtD,CAAC;;;OAAA;IAED,sBAAI,0EAAyB;aAA7B;YACI,IAAM,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAE/D,OAAO,IAAI,CAAC,6BAA6B,CACrC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC,EACxC,WAAW,CACd,CAAC;QACN,CAAC;;;OAAA;IAMD,sBAAI,gEAAe;QAJnB;;;WAGG;aACH;YACI,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACjD,CAAC;;;OAAA;IAID,qDAAO,GAAP,UAAQ,KAAiC;QACrC,IAAI,KAAK,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,qBAAqB,EAAE,EAAE,CAAC,CAAC;QAC5E,IAAM,cAAc,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEtD,IAAI,CAAC,cAAc,EAAE;YACjB,IAAI,CAAC,WAAW,CACZ,CAAA,KAAG,IAAI,CAAC,qBAAqB,GAAG,KAAO,CAAA;iBAClC,OAAO,CAAC,uBAAuB,EAAE,EAAE,CAAC;iBACpC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAC/D,CAAC;YAEF,OAAO;SACV;QAED,IAAI,cAAc,KAAK,iBAAiB,CAAC,EAAE,EAAE;YACzC,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SACpC;QAED,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;QAC1C,IAAI,CAAC,WAAW,CAAC,KAAG,SAAS,GAAG,KAAO,CAAC,CAAC;IAC7C,CAAC;IAKD;;;OAGG;IACH,yDAAW,GAAX,UAAY,IAAuB;QAC/B,OAAO,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAED,yDAAW,GAAX,UAAY,OAA0B;QAClC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAClB,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;QACnC,kEAAkE;QAClE,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;QAEvC,IAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;QAEpD,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,EAAE;YAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC;SACpD;QAED,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC7B,gBAAgB,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;SACjD;IACL,CAAC;IAED,8DAAgB,GAAhB;QACI,iBAAM,gBAAgB,WAAE,CAAC;QACzB,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IAED,8DAAgB,GAAhB,UAAiB,OAA0B;QACvC,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,sBAAsB,EAAE,EAAE,CAAC,CAAC;IAC5E,CAAC;IAED,2DAAa,GAAb,UAAc,KAAa;QACvB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,0DAAY,GAAZ,UAAa,MAAe;QACxB,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;IAES,8DAAgB,GAA1B;QACI,OAAO,EAAE,CAAC;IACd,CAAC;IAGO,2EAA6B,GAArC,UAAsC,IAAY,EAAE,WAAmB;QACnE,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;IAChD,CAAC;IAEO,mDAAK,GAAb;QACI,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;IACtB,CAAC;IAEO,iEAAmB,GAA3B,UAA4B,OAA0B;QAClD,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC;IACvE,CAAC;IAEO,kEAAoB,GAA5B,UAA6B,IAAuB;QAChD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAEO,gEAAkB,GAA1B,UAA2B,KAAa;QAAxC,iBAgBC;QAfG,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAA,cAAc;YACrC,IAAM,UAAU,GACZ,cAAc,KAAK,iBAAiB,CAAC,EAAE;gBACvC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC;gBACtB,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC;gBAC5B,KAAK,CAAC,MAAM,GAAG,CAAC,KAAK,KAAI,CAAC,mBAAmB,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;YAExE,OAAO,CACH,UAAU;gBACV,CAAC,KAAK,CAAC,UAAU,CACb,KAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAC/D;oBACG,KAAK,CAAC,MAAM,GAAG,CAAC,KAAK,KAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC,CAAC,CACrE,CAAC;QACN,CAAC,CAAC,CAAC;IACP,CAAC;;;gBA3JY,SAAS,uBAHjB,QAAQ,YACR,IAAI,YACJ,MAAM,SAAC,SAAS;gBAE6B,iBAAiB,uBAA9D,MAAM,SAAC,iBAAiB;gBAEC,UAAU,uBADnC,MAAM,SAAC,aAAa;gDAEpB,MAAM,SAAC,mBAAmB;gDAE1B,MAAM,SAAC,qCAAqC;gBAGlB,WAAW,uBADrC,MAAM,SAAC,WAAW;;IAtCvB;QADC,SAAS,CAAC,sBAAsB,CAAC;oFAC4B;IAG9D;QADC,SAAS,CAAC,8BAA8B,CAAC;mFAC2B;IAIrE;QAFC,KAAK,CAAC,gBAAgB,CAAC;QACvB,cAAc,EAAE;sEAIhB;IAGD;QADC,KAAK,EAAE;0EAC2B;IAGnC;QADC,MAAM,EAAE;qFAC6D;IAgEtE;QAFC,YAAY,CAAC,4BAA4B,EAAE,CAAC,QAAQ,CAAC,CAAC;QACtD,YAAY,CAAC,2BAA2B,EAAE,CAAC,QAAQ,CAAC,CAAC;sEAqBrD;IAoDD;QADC,OAAO;4FAGP;IA/JQ,mCAAmC;QAf/C,SAAS,CAAC;YACP,QAAQ,EAAE,+BAA+B;YACzC,88EAAwD;YAExD,eAAe,EAAE,uBAAuB,CAAC,MAAM;YAC/C,SAAS,EAAE;gBACP;oBACI,OAAO,EAAE,2BAA2B;oBACpC,WAAW,EAAE,UAAU,CAAC,cAAM,OAAA,qCAAmC,EAAnC,CAAmC,CAAC;iBACrE;gBACD,kCAAkC;gBAClC,sDAAsD;gBACtD,WAAW;aACd;;SACJ,CAAC;QAiCO,WAAA,QAAQ,EAAE,CAAA;QACV,WAAA,IAAI,EAAE,CAAA;QACN,WAAA,MAAM,CAAC,SAAS,CAAC,CAAA;QAEjB,WAAA,MAAM,CAAC,iBAAiB,CAAC,CAAA;QACzB,WAAA,MAAM,CAAC,aAAa,CAAC,CAAA;QAErB,WAAA,MAAM,CAAC,mBAAmB,CAAC,CAAA;QAE3B,WAAA,MAAM,CAAC,qCAAqC,CAAC,CAAA;QAE7C,WAAA,MAAM,CAAC,WAAW,CAAC,CAAA;OA3Cf,mCAAmC,CA+L/C;IAAD,0CAAC;CAAA,AA/LD,CACY,kBAAkB,GA8L7B;SA/LY,mCAAmC","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"]}