@wlcm/angular 18.2.22 → 18.2.24

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 (179) hide show
  1. package/button/esm2022/index.mjs +3 -0
  2. package/button/esm2022/lib/button.module.mjs +16 -0
  3. package/button/esm2022/lib/components/button/button.component.mjs +37 -0
  4. package/button/esm2022/lib/models/button.models.mjs +2 -0
  5. package/button/esm2022/wlcm-angular-button.mjs +5 -0
  6. package/button/fesm2022/wlcm-angular-button.mjs +7 -7
  7. package/button/fesm2022/wlcm-angular-button.mjs.map +1 -1
  8. package/core/esm2022/index.mjs +17 -0
  9. package/core/esm2022/lib/components/default-loader/default-loader.component.mjs +12 -0
  10. package/core/esm2022/lib/components/icons/calendar-icon/calendar-icon.component.mjs +12 -0
  11. package/core/esm2022/lib/components/icons/chevron-down-icon/chevron-down-icon.component.mjs +12 -0
  12. package/core/esm2022/lib/components/icons/close-icon/close-icon.component.mjs +12 -0
  13. package/core/esm2022/lib/components/icons/search-icon/search-icon.component.mjs +12 -0
  14. package/core/esm2022/lib/components/loader/loader.component.mjs +32 -0
  15. package/core/esm2022/lib/constants/_index.mjs +3 -0
  16. package/core/esm2022/lib/constants/http.constants.mjs +6 -0
  17. package/core/esm2022/lib/constants/icon.contants.mjs +15 -0
  18. package/core/esm2022/lib/constants/loader.constants.mjs +7 -0
  19. package/core/esm2022/lib/directives/_index.mjs +2 -0
  20. package/core/esm2022/lib/directives/icon.directive.mjs +49 -0
  21. package/core/esm2022/lib/models/_index.mjs +3 -0
  22. package/core/esm2022/lib/models/icon.models.mjs +7 -0
  23. package/core/esm2022/lib/models/option.models.mjs +17 -0
  24. package/core/esm2022/lib/services/scroll-detection.api.mjs +27 -0
  25. package/core/esm2022/lib/utils/paginated-data-emulator.utils.mjs +20 -0
  26. package/core/esm2022/lib/utils/stream.utils.mjs +16 -0
  27. package/core/esm2022/wlcm-angular-core.mjs +5 -0
  28. package/core/fesm2022/wlcm-angular-core.mjs +24 -24
  29. package/core/fesm2022/wlcm-angular-core.mjs.map +1 -1
  30. package/datepicker/esm2022/index.mjs +14 -0
  31. package/datepicker/esm2022/lib/components/calendar-header/calendar-header.component.mjs +63 -0
  32. package/datepicker/esm2022/lib/components/range/date-range-calendar-header/date-range-calendar-header.component.mjs +87 -0
  33. package/datepicker/esm2022/lib/components/range/date-range-picker-bottom-panel/date-range-picker-bottom-panel.component.mjs +19 -0
  34. package/datepicker/esm2022/lib/components/range/date-range-picker-input/date-range-picker-input.component.mjs +126 -0
  35. package/datepicker/esm2022/lib/components/range/double-calendar-range-picker/double-calendar-range-picker.component.mjs +168 -0
  36. package/datepicker/esm2022/lib/components/range/single-calendar-range-picker/single-calendar-range-picker.component.mjs +95 -0
  37. package/datepicker/esm2022/lib/components/single/datepicker-input-container/datepicker-input-container.component.mjs +92 -0
  38. package/datepicker/esm2022/lib/components/single/datepicker-panel/datepicker-panel.component.mjs +33 -0
  39. package/datepicker/esm2022/lib/constants/datepicker.constants.mjs +23 -0
  40. package/datepicker/esm2022/lib/constants/range/date-range-picker.constants.mjs +5 -0
  41. package/datepicker/esm2022/lib/constants/range/date-range-selection-model.constants.mjs +10 -0
  42. package/datepicker/esm2022/lib/constants/range/date-range-trigger-selection-model.constants.mjs +10 -0
  43. package/datepicker/esm2022/lib/datepicker.module.mjs +33 -0
  44. package/datepicker/esm2022/lib/directives/calendar.directive.mjs +15 -0
  45. package/datepicker/esm2022/lib/directives/datepicker-input.base.mjs +103 -0
  46. package/datepicker/esm2022/lib/directives/datepicker-trigger.base.mjs +105 -0
  47. package/datepicker/esm2022/lib/directives/ragne/date-range-picker-input-end.directive.mjs +81 -0
  48. package/datepicker/esm2022/lib/directives/ragne/date-range-picker-input-start.directive.mjs +81 -0
  49. package/datepicker/esm2022/lib/directives/ragne/date-range-picker-input.base.mjs +58 -0
  50. package/datepicker/esm2022/lib/directives/ragne/left-calendar.directive.mjs +51 -0
  51. package/datepicker/esm2022/lib/directives/ragne/right-calendar.directive.mjs +64 -0
  52. package/datepicker/esm2022/lib/directives/single/datepicker-input.directive.mjs +67 -0
  53. package/datepicker/esm2022/lib/models/date-picker.models.mjs +29 -0
  54. package/datepicker/esm2022/lib/models/range/data-range-calendar.models.mjs +61 -0
  55. package/datepicker/esm2022/lib/models/range/date-range-picker.models.mjs +27 -0
  56. package/datepicker/esm2022/lib/models/range/date-range-validation.models.mjs +5 -0
  57. package/datepicker/esm2022/lib/utils/range/date-range-input.validators.mjs +16 -0
  58. package/datepicker/esm2022/lib/utils/range/date-range-picker-errors.mjs +9 -0
  59. package/datepicker/esm2022/wlcm-angular-datepicker.mjs +5 -0
  60. package/datepicker/fesm2022/wlcm-angular-datepicker.mjs +63 -63
  61. package/datepicker/fesm2022/wlcm-angular-datepicker.mjs.map +1 -1
  62. package/datepicker/lib/directives/datepicker-input.base.d.ts +1 -1
  63. package/datepicker/lib/directives/datepicker-trigger.base.d.ts +1 -1
  64. package/datepicker/lib/directives/ragne/date-range-picker-input.base.d.ts +1 -1
  65. package/datepicker/lib/models/range/data-range-calendar.models.d.ts +1 -1
  66. package/filters/esm2022/index.mjs +6 -0
  67. package/filters/esm2022/lib/components/filters-group/filters-group.component.mjs +13 -0
  68. package/filters/esm2022/lib/constants/filter.constants.mjs +3 -0
  69. package/filters/esm2022/lib/constants/index.mjs +2 -0
  70. package/filters/esm2022/lib/directives/filter.directive.mjs +11 -0
  71. package/filters/esm2022/lib/directives/index.mjs +2 -0
  72. package/filters/esm2022/lib/filters.module.mjs +20 -0
  73. package/filters/esm2022/lib/models/array-filter.models.mjs +73 -0
  74. package/filters/esm2022/lib/models/filter.models.mjs +39 -0
  75. package/filters/esm2022/lib/models/filters-group.models.mjs +60 -0
  76. package/filters/esm2022/lib/models/index.mjs +4 -0
  77. package/filters/esm2022/wlcm-angular-filters.mjs +5 -0
  78. package/filters/fesm2022/wlcm-angular-filters.mjs +13 -13
  79. package/filters/fesm2022/wlcm-angular-filters.mjs.map +1 -1
  80. package/filters/lib/models/filters-group.models.d.ts +1 -1
  81. package/forms/esm2022/index.mjs +13 -0
  82. package/forms/esm2022/lib/forms/components/autocomplete/autocomplete.component.mjs +243 -0
  83. package/forms/esm2022/lib/forms/components/checkbox/checkbox.component.mjs +85 -0
  84. package/forms/esm2022/lib/forms/components/checkbox-group/checkbox-group.component.mjs +87 -0
  85. package/forms/esm2022/lib/forms/components/error/error.component.mjs +12 -0
  86. package/forms/esm2022/lib/forms/components/form-field/form-field.component.mjs +137 -0
  87. package/forms/esm2022/lib/forms/components/index.mjs +9 -0
  88. package/forms/esm2022/lib/forms/components/label/label.component.mjs +23 -0
  89. package/forms/esm2022/lib/forms/components/partials/autocomplete-suffix/autocomplete-suffix.component.mjs +19 -0
  90. package/forms/esm2022/lib/forms/components/partials/index.mjs +2 -0
  91. package/forms/esm2022/lib/forms/components/select/select.component.mjs +330 -0
  92. package/forms/esm2022/lib/forms/constants/form-elements.constants.mjs +5 -0
  93. package/forms/esm2022/lib/forms/constants/form-errors.constants.mjs +7 -0
  94. package/forms/esm2022/lib/forms/constants/form-field.constants.mjs +2 -0
  95. package/forms/esm2022/lib/forms/constants/form-state-handlers.constants.mjs +13 -0
  96. package/forms/esm2022/lib/forms/constants/index.mjs +6 -0
  97. package/forms/esm2022/lib/forms/constants/select.constants.mjs +3 -0
  98. package/forms/esm2022/lib/forms/directives/autocomplete.directive.mjs +64 -0
  99. package/forms/esm2022/lib/forms/directives/form-field-custom-container.directive.mjs +17 -0
  100. package/forms/esm2022/lib/forms/directives/form-field-hint.directive.mjs +15 -0
  101. package/forms/esm2022/lib/forms/directives/form-field-prefix.directive.mjs +22 -0
  102. package/forms/esm2022/lib/forms/directives/form-field-suffix.directive.mjs +14 -0
  103. package/forms/esm2022/lib/forms/directives/input.directive.mjs +47 -0
  104. package/forms/esm2022/lib/forms/directives/select-input-binder.directive.mjs +33 -0
  105. package/forms/esm2022/lib/forms/forms.module.mjs +64 -0
  106. package/forms/esm2022/lib/forms/models/_index.mjs +6 -0
  107. package/forms/esm2022/lib/forms/models/autocomplete.models.mjs +10 -0
  108. package/forms/esm2022/lib/forms/models/form-errors.models.mjs +2 -0
  109. package/forms/esm2022/lib/forms/models/form.models.mjs +2 -0
  110. package/forms/esm2022/lib/forms/models/input.models.mjs +2 -0
  111. package/forms/esm2022/lib/forms/models/select.models.mjs +2 -0
  112. package/forms/esm2022/lib/forms/pipes/errors-mapper.pipe.mjs +53 -0
  113. package/forms/esm2022/lib/forms/services/form-state-handler.service.mjs +19 -0
  114. package/forms/esm2022/lib/forms/services/index.mjs +3 -0
  115. package/forms/esm2022/lib/forms/services/places.api.mjs +62 -0
  116. package/forms/esm2022/wlcm-angular-forms.mjs +5 -0
  117. package/forms/fesm2022/wlcm-angular-forms.mjs +76 -67
  118. package/forms/fesm2022/wlcm-angular-forms.mjs.map +1 -1
  119. package/forms/lib/forms/components/select/select.component.d.ts +1 -0
  120. package/forms/lib/forms/models/autocomplete.models.d.ts +1 -1
  121. package/package.json +1 -1
  122. package/phone-input/esm2022/index.mjs +5 -0
  123. package/phone-input/esm2022/lib/components/country-code-select/country-code-select.component.mjs +32 -0
  124. package/phone-input/esm2022/lib/components/phone-input-container/phone-input-container.component.mjs +107 -0
  125. package/phone-input/esm2022/lib/constants/country-code-options.constants.mjs +20 -0
  126. package/phone-input/esm2022/lib/constants/phone-adapter.constants.mjs +3 -0
  127. package/phone-input/esm2022/lib/directives/phone-input.directive.mjs +155 -0
  128. package/phone-input/esm2022/lib/models/country-code.models.mjs +10 -0
  129. package/phone-input/esm2022/lib/models/phone-adapter.models.mjs +3 -0
  130. package/phone-input/esm2022/lib/models/phone.models.mjs +5 -0
  131. package/phone-input/esm2022/lib/phone-input.module.mjs +20 -0
  132. package/phone-input/esm2022/lib/pipes/phone-code.pipe.mjs +18 -0
  133. package/phone-input/esm2022/wlcm-angular-phone-input.mjs +5 -0
  134. package/phone-input/fesm2022/wlcm-angular-phone-input.mjs +16 -16
  135. package/phone-input/fesm2022/wlcm-angular-phone-input.mjs.map +1 -1
  136. package/search-field/esm2022/index.mjs +3 -0
  137. package/search-field/esm2022/lib/components/search-field/search-field.component.mjs +39 -0
  138. package/search-field/esm2022/lib/search-field.module.mjs +18 -0
  139. package/search-field/esm2022/wlcm-angular-search-field.mjs +5 -0
  140. package/search-field/fesm2022/wlcm-angular-search-field.mjs +7 -7
  141. package/search-field/fesm2022/wlcm-angular-search-field.mjs.map +1 -1
  142. package/stepper/esm2022/index.mjs +11 -0
  143. package/stepper/esm2022/lib/components/step/step.component.mjs +53 -0
  144. package/stepper/esm2022/lib/components/step-header/step-header.component.mjs +81 -0
  145. package/stepper/esm2022/lib/components/stepper/stepper.component.mjs +15 -0
  146. package/stepper/esm2022/lib/components/stepper-header/stepper-header.component.mjs +16 -0
  147. package/stepper/esm2022/lib/constants/step.constants.mjs +9 -0
  148. package/stepper/esm2022/lib/constants/stepper.stepper.mjs +3 -0
  149. package/stepper/esm2022/lib/directives/load-on-active-step.directive.mjs +51 -0
  150. package/stepper/esm2022/lib/models/step.models.mjs +60 -0
  151. package/stepper/esm2022/lib/models/stepper.models.mjs +114 -0
  152. package/stepper/esm2022/lib/stepper.module.mjs +34 -0
  153. package/stepper/esm2022/wlcm-angular-stepper.mjs +5 -0
  154. package/stepper/fesm2022/wlcm-angular-stepper.mjs +25 -25
  155. package/stepper/fesm2022/wlcm-angular-stepper.mjs.map +1 -1
  156. package/stepper/lib/models/step.models.d.ts +1 -1
  157. package/stepper/lib/models/stepper.models.d.ts +1 -1
  158. package/table/esm2022/index.mjs +9 -0
  159. package/table/esm2022/lib/components/table/table.component.mjs +79 -0
  160. package/table/esm2022/lib/components/table-head/table-head.component.mjs +18 -0
  161. package/table/esm2022/lib/components/table-head-actions/table-head-actions.component.mjs +41 -0
  162. package/table/esm2022/lib/components/table-head-data/table-head-data.component.mjs +12 -0
  163. package/table/esm2022/lib/components/table-row/table-row.component.mjs +87 -0
  164. package/table/esm2022/lib/components/table-row-actions/table-row-actions.component.mjs +12 -0
  165. package/table/esm2022/lib/components/table-row-data/table-row-data.component.mjs +12 -0
  166. package/table/esm2022/lib/components/table-row-spacer/table-row-spacer.component.mjs +12 -0
  167. package/table/esm2022/lib/constants/table-row.constants.mjs +3 -0
  168. package/table/esm2022/lib/constants/table.constants.mjs +5 -0
  169. package/table/esm2022/lib/directives/scrollable-table-container.directive.mjs +46 -0
  170. package/table/esm2022/lib/models/table-config-manager.models.mjs +18 -0
  171. package/table/esm2022/lib/models/table-row.models.mjs +2 -0
  172. package/table/esm2022/lib/models/table-selection-model.mjs +48 -0
  173. package/table/esm2022/lib/models/table.models.mjs +2 -0
  174. package/table/esm2022/lib/pipes/table-row-injector.pipe.mjs +24 -0
  175. package/table/esm2022/lib/table.module.mjs +38 -0
  176. package/table/esm2022/lib/utils/table-errors.utils.mjs +6 -0
  177. package/table/esm2022/wlcm-angular-table.mjs +5 -0
  178. package/table/fesm2022/wlcm-angular-table.mjs +34 -34
  179. package/table/fesm2022/wlcm-angular-table.mjs.map +1 -1
@@ -0,0 +1,32 @@
1
+ import { Component, Inject, ViewChild, input, output } from '@angular/core';
2
+ import { WlcmFormsModule, WlcmSelectComponent } from '@wlcm/angular/forms';
3
+ import { CommonModule } from '@angular/common';
4
+ import { WLCM_COUNTRY_CODE_OPTIONS } from '../../constants/country-code-options.constants';
5
+ import { FormControl, ReactiveFormsModule } from '@angular/forms';
6
+ import { PhoneCodePipe } from '../../pipes/phone-code.pipe';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@wlcm/angular/forms";
9
+ import * as i2 from "@angular/forms";
10
+ export class WlcmCountryCodeSelectComponent {
11
+ constructor(options) {
12
+ this.options = options;
13
+ this.changed = output();
14
+ this.control = input(new FormControl('US'));
15
+ }
16
+ get selectComponent() {
17
+ return this.wlcmSelect.matSelect;
18
+ }
19
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmCountryCodeSelectComponent, deps: [{ token: WLCM_COUNTRY_CODE_OPTIONS }], target: i0.ɵɵFactoryTarget.Component }); }
20
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.6", type: WlcmCountryCodeSelectComponent, isStandalone: true, selector: "wlcm-country-code-select", inputs: { control: { classPropertyName: "control", publicName: "control", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { changed: "changed" }, host: { classAttribute: "wlcm-country-code-select" }, viewQueries: [{ propertyName: "wlcmSelect", first: true, predicate: WlcmSelectComponent, descendants: true }], ngImport: i0, template: "<wlcm-select\n [options]=\"options\"\n [formControl]=\"control()\"\n [optionTemplate]=\"optionTemplate\"\n [triggerTemplate]=\"triggerTemplate\"\n (selectionChange)=\"changed.emit($event)\"\n></wlcm-select>\n\n<ng-template #optionTemplate let-option>\n <span class=\"emoji-flag\">{{ option.emojiFlag }}</span>\n\n {{ option.viewValue }}\n</ng-template>\n\n<ng-template #triggerTemplate let-selected>\n <div class=\"wlcm-country-code-select-trigger\">\n +{{ selected?.value | phoneCode }}\n </div>\n</ng-template>\n", styles: [".emoji-flag{font-size:20px;vertical-align:bottom;margin-right:8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: WlcmFormsModule }, { kind: "component", type: i1.WlcmSelectComponent, selector: "wlcm-select", inputs: ["multiple", "placeholder", "fetchPaginatedOptions", "canSelect", "queryParams", "paginated", "options", "selectOptionFormat", "optionTemplate", "triggerTemplate", "isOptionDisabled"], outputs: ["selectionChange", "opened", "closed"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: PhoneCodePipe, name: "phoneCode" }] }); }
21
+ }
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmCountryCodeSelectComponent, decorators: [{
23
+ type: Component,
24
+ args: [{ selector: 'wlcm-country-code-select', host: { class: 'wlcm-country-code-select' }, standalone: true, imports: [CommonModule, WlcmFormsModule, ReactiveFormsModule, PhoneCodePipe], template: "<wlcm-select\n [options]=\"options\"\n [formControl]=\"control()\"\n [optionTemplate]=\"optionTemplate\"\n [triggerTemplate]=\"triggerTemplate\"\n (selectionChange)=\"changed.emit($event)\"\n></wlcm-select>\n\n<ng-template #optionTemplate let-option>\n <span class=\"emoji-flag\">{{ option.emojiFlag }}</span>\n\n {{ option.viewValue }}\n</ng-template>\n\n<ng-template #triggerTemplate let-selected>\n <div class=\"wlcm-country-code-select-trigger\">\n +{{ selected?.value | phoneCode }}\n </div>\n</ng-template>\n", styles: [".emoji-flag{font-size:20px;vertical-align:bottom;margin-right:8px}\n"] }]
25
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
26
+ type: Inject,
27
+ args: [WLCM_COUNTRY_CODE_OPTIONS]
28
+ }] }], propDecorators: { wlcmSelect: [{
29
+ type: ViewChild,
30
+ args: [WlcmSelectComponent]
31
+ }] } });
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291bnRyeS1jb2RlLXNlbGVjdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9tb2R1bGVzL3Bob25lLWlucHV0L3NyYy9saWIvY29tcG9uZW50cy9jb3VudHJ5LWNvZGUtc2VsZWN0L2NvdW50cnktY29kZS1zZWxlY3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9waG9uZS1pbnB1dC9zcmMvbGliL2NvbXBvbmVudHMvY291bnRyeS1jb2RlLXNlbGVjdC9jb3VudHJ5LWNvZGUtc2VsZWN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFpQyxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzRyxPQUFPLEVBQUUsZUFBZSxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDM0UsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBRTNGLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7Ozs7QUFXNUQsTUFBTSxPQUFPLDhCQUE4QjtJQU96QyxZQUF5RCxPQUFnQztRQUFoQyxZQUFPLEdBQVAsT0FBTyxDQUF5QjtRQU56RixZQUFPLEdBQTBCLE1BQU0sRUFBRSxDQUFDO1FBRTFDLFlBQU8sR0FBNkIsS0FBSyxDQUFDLElBQUksV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFJMkIsQ0FBQztJQUU3RixJQUFJLGVBQWU7UUFDakIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQztJQUNuQyxDQUFDOzhHQVhVLDhCQUE4QixrQkFPckIseUJBQXlCO2tHQVBsQyw4QkFBOEIsaVdBSzlCLG1CQUFtQixnREN2QmhDLGdoQkFtQkEsNkhETFksWUFBWSw4QkFBRSxlQUFlLCtWQUFFLG1CQUFtQixxVEFBRSxhQUFhOzsyRkFJaEUsOEJBQThCO2tCQVIxQyxTQUFTOytCQUNFLDBCQUEwQixRQUM5QixFQUFFLEtBQUssRUFBRSwwQkFBMEIsRUFBRSxjQUMvQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLG1CQUFtQixFQUFFLGFBQWEsQ0FBQzs7MEJBVy9ELE1BQU07MkJBQUMseUJBQXlCO3lDQUZMLFVBQVU7c0JBQWpELFNBQVM7dUJBQUMsbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QsIElucHV0U2lnbmFsLCBPdXRwdXRFbWl0dGVyUmVmLCBWaWV3Q2hpbGQsIGlucHV0LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFdsY21Gb3Jtc01vZHVsZSwgV2xjbVNlbGVjdENvbXBvbmVudCB9IGZyb20gJ0B3bGNtL2FuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgV0xDTV9DT1VOVFJZX0NPREVfT1BUSU9OUyB9IGZyb20gJy4uLy4uL2NvbnN0YW50cy9jb3VudHJ5LWNvZGUtb3B0aW9ucy5jb25zdGFudHMnO1xuaW1wb3J0IHsgV2xjbUNvdW50cnlDb2RlT3B0aW9uIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2NvdW50cnktY29kZS5tb2RlbHMnO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQaG9uZUNvZGVQaXBlIH0gZnJvbSAnLi4vLi4vcGlwZXMvcGhvbmUtY29kZS5waXBlJztcbmltcG9ydCB7IE1hdFNlbGVjdCB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NlbGVjdCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3dsY20tY291bnRyeS1jb2RlLXNlbGVjdCcsXG4gIGhvc3Q6IHsgY2xhc3M6ICd3bGNtLWNvdW50cnktY29kZS1zZWxlY3QnIH0sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFdsY21Gb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSwgUGhvbmVDb2RlUGlwZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi9jb3VudHJ5LWNvZGUtc2VsZWN0LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL2NvdW50cnktY29kZS1zZWxlY3QuY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBXbGNtQ291bnRyeUNvZGVTZWxlY3RDb21wb25lbnQge1xuICBjaGFuZ2VkOiBPdXRwdXRFbWl0dGVyUmVmPGFueT4gPSBvdXRwdXQoKTtcblxuICBjb250cm9sOiBJbnB1dFNpZ25hbDxGb3JtQ29udHJvbD4gPSBpbnB1dChuZXcgRm9ybUNvbnRyb2woJ1VTJykpO1xuXG4gIEBWaWV3Q2hpbGQoV2xjbVNlbGVjdENvbXBvbmVudCkgcHJpdmF0ZSB3bGNtU2VsZWN0ITogV2xjbVNlbGVjdENvbXBvbmVudDtcblxuICBjb25zdHJ1Y3RvcihASW5qZWN0KFdMQ01fQ09VTlRSWV9DT0RFX09QVElPTlMpIHByb3RlY3RlZCBvcHRpb25zOiBXbGNtQ291bnRyeUNvZGVPcHRpb25bXSkge31cblxuICBnZXQgc2VsZWN0Q29tcG9uZW50KCk6IE1hdFNlbGVjdCB7XG4gICAgcmV0dXJuIHRoaXMud2xjbVNlbGVjdC5tYXRTZWxlY3Q7XG4gIH1cbn1cbiIsIjx3bGNtLXNlbGVjdFxuICBbb3B0aW9uc109XCJvcHRpb25zXCJcbiAgW2Zvcm1Db250cm9sXT1cImNvbnRyb2woKVwiXG4gIFtvcHRpb25UZW1wbGF0ZV09XCJvcHRpb25UZW1wbGF0ZVwiXG4gIFt0cmlnZ2VyVGVtcGxhdGVdPVwidHJpZ2dlclRlbXBsYXRlXCJcbiAgKHNlbGVjdGlvbkNoYW5nZSk9XCJjaGFuZ2VkLmVtaXQoJGV2ZW50KVwiXG4+PC93bGNtLXNlbGVjdD5cblxuPG5nLXRlbXBsYXRlICNvcHRpb25UZW1wbGF0ZSBsZXQtb3B0aW9uPlxuICA8c3BhbiBjbGFzcz1cImVtb2ppLWZsYWdcIj57eyBvcHRpb24uZW1vamlGbGFnIH19PC9zcGFuPlxuXG4gIHt7IG9wdGlvbi52aWV3VmFsdWUgfX1cbjwvbmctdGVtcGxhdGU+XG5cbjxuZy10ZW1wbGF0ZSAjdHJpZ2dlclRlbXBsYXRlIGxldC1zZWxlY3RlZD5cbiAgPGRpdiBjbGFzcz1cIndsY20tY291bnRyeS1jb2RlLXNlbGVjdC10cmlnZ2VyXCI+XG4gICAgK3t7IHNlbGVjdGVkPy52YWx1ZSB8IHBob25lQ29kZSB9fVxuICA8L2Rpdj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
@@ -0,0 +1,107 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { CommonModule } from '@angular/common';
3
+ import { Component, ContentChild, NgZone, ViewChild, forwardRef, inject } from '@angular/core';
4
+ import { WlcmPhoneInputDirective } from '../../directives/phone-input.directive';
5
+ import { WLCM_INPUT_BINDER } from '@wlcm/angular/forms';
6
+ import { WLCM_PHONE_ADAPTER } from '../../constants/phone-adapter.constants';
7
+ import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
8
+ import { Subject, fromEvent, merge, tap } from 'rxjs';
9
+ import { AsYouType, getPhoneCode, isValidNumber, parsePhoneNumber } from 'libphonenumber-js';
10
+ import { WlcmCountryCodeSelectComponent } from '../country-code-select/country-code-select.component';
11
+ import { FormControl } from '@angular/forms';
12
+ import * as i0 from "@angular/core";
13
+ let WlcmPhoneInputContainerComponent = class WlcmPhoneInputContainerComponent {
14
+ constructor(_zone) {
15
+ this._zone = _zone;
16
+ this._focusStream$ = new Subject();
17
+ this._blurStream$ = new Subject();
18
+ this.focus$ = this._focusStream$.asObservable();
19
+ this.blur$ = this._blurStream$.asObservable();
20
+ this.control = new FormControl('US');
21
+ this._asYouType = new AsYouType('US');
22
+ this.parseValue = (value) => {
23
+ if (!value || value.length === 0)
24
+ return '';
25
+ if (isValidNumber(value)) {
26
+ const result = parsePhoneNumber(value, 'US');
27
+ if (result.country)
28
+ this.control.setValue(result.country);
29
+ return result.nationalNumber;
30
+ }
31
+ return value;
32
+ };
33
+ this.formatValue = (value) => {
34
+ this._asYouType.reset();
35
+ this._asYouType.input(`+${this.currentCallingCode}${value}`);
36
+ const countryCode = this._asYouType.getCountry();
37
+ if (countryCode)
38
+ this.control.setValue(countryCode);
39
+ return this._asYouType.getNumber()?.number ?? '';
40
+ };
41
+ }
42
+ ngAfterContentInit() {
43
+ if (!this.phoneInput) {
44
+ throw new Error('The [wlcmPhoneInput] directive must be provided.');
45
+ }
46
+ this.handleInputEvents();
47
+ }
48
+ isFocused() {
49
+ return this.phoneInput.element === document.activeElement || this.codeSelect?.selectComponent.panelOpen;
50
+ }
51
+ focus() {
52
+ this.phoneInput.element.focus();
53
+ }
54
+ getCurrentCountryCode() {
55
+ return this.control.value;
56
+ }
57
+ handleCountryChange() {
58
+ this.phoneInput._updateControl();
59
+ this.phoneInput._updateMaskByCountryCode();
60
+ }
61
+ get currentCallingCode() {
62
+ return getPhoneCode(this.control.value);
63
+ }
64
+ handleInputEvents() {
65
+ this._zone.runOutsideAngular(() => {
66
+ merge(fromEvent(this.phoneInput.element, 'focus').pipe(tap(() => this._focusStream$.next())), fromEvent(this.phoneInput.element, 'blur').pipe(tap(() => this._blurStream$.next())))
67
+ .pipe(untilDestroyed(this))
68
+ .subscribe();
69
+ });
70
+ }
71
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputContainerComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
72
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: WlcmPhoneInputContainerComponent, isStandalone: true, selector: "wlcm-phone-input-container", host: { classAttribute: "wlcm-phone-input-container" }, providers: [
73
+ {
74
+ provide: WLCM_INPUT_BINDER,
75
+ useFactory: () => {
76
+ const container = inject(WlcmPhoneInputContainerComponent, { self: true });
77
+ return { bind: () => container };
78
+ },
79
+ },
80
+ { provide: WLCM_PHONE_ADAPTER, useExisting: forwardRef(() => WlcmPhoneInputContainerComponent) },
81
+ ], queries: [{ propertyName: "phoneInput", first: true, predicate: WlcmPhoneInputDirective, descendants: true }], viewQueries: [{ propertyName: "codeSelect", first: true, predicate: WlcmCountryCodeSelectComponent, descendants: true }], ngImport: i0, template: "<wlcm-country-code-select\n [control]=\"control\"\n (changed)=\"handleCountryChange()\"\n (click)=\"$event.stopPropagation()\"\n></wlcm-country-code-select>\n\n<div class=\"wlcm-phone-input-container-divider\"></div>\n\n<ng-content select=\"[wlcmPhoneInput]\"></ng-content>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: WlcmCountryCodeSelectComponent, selector: "wlcm-country-code-select", inputs: ["control"], outputs: ["changed"] }] }); }
82
+ };
83
+ WlcmPhoneInputContainerComponent = __decorate([
84
+ UntilDestroy(),
85
+ __metadata("design:paramtypes", [NgZone])
86
+ ], WlcmPhoneInputContainerComponent);
87
+ export { WlcmPhoneInputContainerComponent };
88
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputContainerComponent, decorators: [{
89
+ type: Component,
90
+ args: [{ selector: 'wlcm-phone-input-container', host: { class: 'wlcm-phone-input-container' }, standalone: true, imports: [CommonModule, WlcmCountryCodeSelectComponent], providers: [
91
+ {
92
+ provide: WLCM_INPUT_BINDER,
93
+ useFactory: () => {
94
+ const container = inject(WlcmPhoneInputContainerComponent, { self: true });
95
+ return { bind: () => container };
96
+ },
97
+ },
98
+ { provide: WLCM_PHONE_ADAPTER, useExisting: forwardRef(() => WlcmPhoneInputContainerComponent) },
99
+ ], template: "<wlcm-country-code-select\n [control]=\"control\"\n (changed)=\"handleCountryChange()\"\n (click)=\"$event.stopPropagation()\"\n></wlcm-country-code-select>\n\n<div class=\"wlcm-phone-input-container-divider\"></div>\n\n<ng-content select=\"[wlcmPhoneInput]\"></ng-content>\n" }]
100
+ }], ctorParameters: () => [{ type: i0.NgZone }], propDecorators: { codeSelect: [{
101
+ type: ViewChild,
102
+ args: [WlcmCountryCodeSelectComponent]
103
+ }], phoneInput: [{
104
+ type: ContentChild,
105
+ args: [WlcmPhoneInputDirective]
106
+ }] } });
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-input-container.component.js","sourceRoot":"","sources":["../../../../../../../modules/phone-input/src/lib/components/phone-input-container/phone-input-container.component.ts","../../../../../../../modules/phone-input/src/lib/components/phone-input-container/phone-input-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { AfterContentInit, Component, ContentChild, NgZone, ViewChild, forwardRef, inject } from '@angular/core';\nimport { WlcmPhoneInputDirective } from '../../directives/phone-input.directive';\nimport { WLCM_INPUT_BINDER, WlcmFormFieldInput } from '@wlcm/angular/forms';\nimport { WLCM_PHONE_ADAPTER } from '../../constants/phone-adapter.constants';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { Observable, Subject, fromEvent, merge, tap } from 'rxjs';\nimport { WlcmPhoneAdapter } from '../../models/phone-adapter.models';\nimport { AsYouType, CountryCode, PhoneNumber, getPhoneCode, isValidNumber, parsePhoneNumber } from 'libphonenumber-js';\nimport { WlcmCountryCodeSelectComponent } from '../country-code-select/country-code-select.component';\nimport { FormControl } from '@angular/forms';\n\n@UntilDestroy()\n@Component({\n  selector: 'wlcm-phone-input-container',\n  host: { class: 'wlcm-phone-input-container' },\n  standalone: true,\n  imports: [CommonModule, WlcmCountryCodeSelectComponent],\n  templateUrl: './phone-input-container.component.html',\n  styleUrl: './phone-input-container.component.scss',\n  providers: [\n    {\n      provide: WLCM_INPUT_BINDER,\n      useFactory: () => {\n        const container: WlcmPhoneInputContainerComponent = inject(WlcmPhoneInputContainerComponent, { self: true });\n\n        return { bind: () => container };\n      },\n    },\n    { provide: WLCM_PHONE_ADAPTER, useExisting: forwardRef(() => WlcmPhoneInputContainerComponent) },\n  ],\n})\nexport class WlcmPhoneInputContainerComponent implements AfterContentInit, WlcmFormFieldInput, WlcmPhoneAdapter {\n  private readonly _focusStream$: Subject<void> = new Subject();\n\n  private readonly _blurStream$: Subject<void> = new Subject();\n\n  focus$: Observable<void> = this._focusStream$.asObservable();\n\n  blur$: Observable<void> = this._blurStream$.asObservable();\n\n  @ViewChild(WlcmCountryCodeSelectComponent) private codeSelect!: WlcmCountryCodeSelectComponent;\n\n  @ContentChild(WlcmPhoneInputDirective) private phoneInput!: WlcmPhoneInputDirective;\n\n  readonly control: FormControl = new FormControl('US');\n\n  private _asYouType = new AsYouType('US');\n\n  constructor(private _zone: NgZone) {}\n\n  ngAfterContentInit(): void {\n    if (!this.phoneInput) {\n      throw new Error('The [wlcmPhoneInput] directive must be provided.');\n    }\n\n    this.handleInputEvents();\n  }\n\n  isFocused(): boolean {\n    return this.phoneInput.element === document.activeElement || this.codeSelect?.selectComponent.panelOpen;\n  }\n\n  focus(): void {\n    this.phoneInput.element.focus();\n  }\n\n  getCurrentCountryCode(): CountryCode {\n    return this.control.value;\n  }\n\n  parseValue = (value: string): string => {\n    if (!value || value.length === 0) return '';\n\n    if (isValidNumber(value)) {\n      const result: PhoneNumber = parsePhoneNumber(value, 'US');\n\n      if (result.country) this.control.setValue(result.country);\n\n      return result.nationalNumber;\n    }\n\n    return value;\n  };\n\n  formatValue = (value: string): string => {\n    this._asYouType.reset();\n\n    this._asYouType.input(`+${this.currentCallingCode}${value}`);\n\n    const countryCode: CountryCode | undefined = this._asYouType.getCountry();\n\n    if (countryCode) this.control.setValue(countryCode);\n\n    return this._asYouType.getNumber()?.number ?? '';\n  };\n\n  handleCountryChange(): void {\n    this.phoneInput._updateControl();\n\n    this.phoneInput._updateMaskByCountryCode();\n  }\n\n  private get currentCallingCode(): string {\n    return getPhoneCode(this.control.value);\n  }\n\n  private handleInputEvents(): void {\n    this._zone.runOutsideAngular(() => {\n      merge(\n        fromEvent(this.phoneInput.element, 'focus').pipe(tap(() => this._focusStream$.next())),\n        fromEvent(this.phoneInput.element, 'blur').pipe(tap(() => this._blurStream$.next())),\n      )\n        .pipe(untilDestroyed(this))\n        .subscribe();\n    });\n  }\n}\n","<wlcm-country-code-select\n  [control]=\"control\"\n  (changed)=\"handleCountryChange()\"\n  (click)=\"$event.stopPropagation()\"\n></wlcm-country-code-select>\n\n<div class=\"wlcm-phone-input-container-divider\"></div>\n\n<ng-content select=\"[wlcmPhoneInput]\"></ng-content>\n"]}
@@ -0,0 +1,20 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ import { WlcmCountryCodeOption } from '../models/country-code.models';
3
+ import { countries, getCountryCode, getEmojiFlag } from 'countries-list';
4
+ import { getCountries, getPhoneCode } from 'libphonenumber-js';
5
+ const COUNTRIES_LIST = getCountries()
6
+ .filter((code) => countries.hasOwnProperty(code))
7
+ .map((code) => ({ ...countries[code], code }))
8
+ .sort((a, b) => a.name.localeCompare(b.name));
9
+ export const WLCM_COUNTRY_CODE_OPTIONS = new InjectionToken('WLCM_COUNTRY_CODE_OPTIONS', {
10
+ providedIn: 'root',
11
+ factory: () => {
12
+ return COUNTRIES_LIST.map((country) => {
13
+ const phone = getPhoneCode(country.code);
14
+ const viewValue = `${country.name} +${phone}`;
15
+ const emojiFlag = getEmojiFlag(getCountryCode(country.name));
16
+ return new WlcmCountryCodeOption(getCountryCode(country.name), viewValue, emojiFlag);
17
+ });
18
+ },
19
+ });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291bnRyeS1jb2RlLW9wdGlvbnMuY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9waG9uZS1pbnB1dC9zcmMvbGliL2NvbnN0YW50cy9jb3VudHJ5LWNvZGUtb3B0aW9ucy5jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvQyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUN0RSxPQUFPLEVBQTBCLFNBQVMsRUFBRSxjQUFjLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDakcsT0FBTyxFQUFlLFlBQVksRUFBRSxZQUFZLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQU01RSxNQUFNLGNBQWMsR0FBa0IsWUFBWSxFQUFFO0tBQ2pELE1BQU0sQ0FBQyxDQUFDLElBQWlCLEVBQUUsRUFBRSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUM7S0FDN0QsR0FBRyxDQUFDLENBQUMsSUFBaUIsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsU0FBUyxDQUFDLElBQW9CLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0tBQzFFLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0FBRWhELE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUE0QyxJQUFJLGNBQWMsQ0FDbEcsMkJBQTJCLEVBQzNCO0lBQ0UsVUFBVSxFQUFFLE1BQU07SUFDbEIsT0FBTyxFQUFFLEdBQTRCLEVBQUU7UUFDckMsT0FBTyxjQUFjLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBb0IsRUFBRSxFQUFFO1lBQ2pELE1BQU0sS0FBSyxHQUFXLFlBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7WUFFakQsTUFBTSxTQUFTLEdBQVcsR0FBRyxPQUFPLENBQUMsSUFBSSxLQUFLLEtBQUssRUFBRSxDQUFDO1lBRXRELE1BQU0sU0FBUyxHQUFXLFlBQVksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBaUIsQ0FBQyxDQUFDO1lBRXJGLE9BQU8sSUFBSSxxQkFBcUIsQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBaUIsRUFBRSxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDdkcsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YsQ0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFdsY21Db3VudHJ5Q29kZU9wdGlvbiB9IGZyb20gJy4uL21vZGVscy9jb3VudHJ5LWNvZGUubW9kZWxzJztcbmltcG9ydCB7IElDb3VudHJ5LCBUQ291bnRyeUNvZGUsIGNvdW50cmllcywgZ2V0Q291bnRyeUNvZGUsIGdldEVtb2ppRmxhZyB9IGZyb20gJ2NvdW50cmllcy1saXN0JztcbmltcG9ydCB7IENvdW50cnlDb2RlLCBnZXRDb3VudHJpZXMsIGdldFBob25lQ29kZSB9IGZyb20gJ2xpYnBob25lbnVtYmVyLWpzJztcblxuaW50ZXJmYWNlIFdsY21Db3VudHJ5IGV4dGVuZHMgSUNvdW50cnkge1xuICBjb2RlOiBDb3VudHJ5Q29kZTtcbn1cblxuY29uc3QgQ09VTlRSSUVTX0xJU1Q6IFdsY21Db3VudHJ5W10gPSBnZXRDb3VudHJpZXMoKVxuICAuZmlsdGVyKChjb2RlOiBDb3VudHJ5Q29kZSkgPT4gY291bnRyaWVzLmhhc093blByb3BlcnR5KGNvZGUpKVxuICAubWFwKChjb2RlOiBDb3VudHJ5Q29kZSkgPT4gKHsgLi4uY291bnRyaWVzW2NvZGUgYXMgVENvdW50cnlDb2RlXSwgY29kZSB9KSlcbiAgLnNvcnQoKGEsIGIpID0+IGEubmFtZS5sb2NhbGVDb21wYXJlKGIubmFtZSkpO1xuXG5leHBvcnQgY29uc3QgV0xDTV9DT1VOVFJZX0NPREVfT1BUSU9OUzogSW5qZWN0aW9uVG9rZW48V2xjbUNvdW50cnlDb2RlT3B0aW9uW10+ID0gbmV3IEluamVjdGlvblRva2VuKFxuICAnV0xDTV9DT1VOVFJZX0NPREVfT1BUSU9OUycsXG4gIHtcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXG4gICAgZmFjdG9yeTogKCk6IFdsY21Db3VudHJ5Q29kZU9wdGlvbltdID0+IHtcbiAgICAgIHJldHVybiBDT1VOVFJJRVNfTElTVC5tYXAoKGNvdW50cnk6IFdsY21Db3VudHJ5KSA9PiB7XG4gICAgICAgIGNvbnN0IHBob25lOiBzdHJpbmcgPSBnZXRQaG9uZUNvZGUoY291bnRyeS5jb2RlKTtcblxuICAgICAgICBjb25zdCB2aWV3VmFsdWU6IHN0cmluZyA9IGAke2NvdW50cnkubmFtZX0gKyR7cGhvbmV9YDtcblxuICAgICAgICBjb25zdCBlbW9qaUZsYWc6IHN0cmluZyA9IGdldEVtb2ppRmxhZyhnZXRDb3VudHJ5Q29kZShjb3VudHJ5Lm5hbWUpIGFzIFRDb3VudHJ5Q29kZSk7XG5cbiAgICAgICAgcmV0dXJuIG5ldyBXbGNtQ291bnRyeUNvZGVPcHRpb24oZ2V0Q291bnRyeUNvZGUoY291bnRyeS5uYW1lKSBhcyBUQ291bnRyeUNvZGUsIHZpZXdWYWx1ZSwgZW1vamlGbGFnKTtcbiAgICAgIH0pO1xuICAgIH0sXG4gIH1cbik7XG4iXX0=
@@ -0,0 +1,3 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const WLCM_PHONE_ADAPTER = new InjectionToken('WLCM_PHONE_ADAPTER');
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGhvbmUtYWRhcHRlci5jb25zdGFudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9tb2R1bGVzL3Bob25lLWlucHV0L3NyYy9saWIvY29uc3RhbnRzL3Bob25lLWFkYXB0ZXIuY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHL0MsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQXFDLElBQUksY0FBYyxDQUFDLG9CQUFvQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgV2xjbVBob25lQWRhcHRlciB9IGZyb20gJy4uL21vZGVscy9waG9uZS1hZGFwdGVyLm1vZGVscyc7XG5cbmV4cG9ydCBjb25zdCBXTENNX1BIT05FX0FEQVBURVI6IEluamVjdGlvblRva2VuPFdsY21QaG9uZUFkYXB0ZXI+ID0gbmV3IEluamVjdGlvblRva2VuKCdXTENNX1BIT05FX0FEQVBURVInKTtcbiJdfQ==
@@ -0,0 +1,155 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { Directive, ElementRef, HostListener, Inject, effect, forwardRef, input, } from '@angular/core';
3
+ import { FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
4
+ import IMask from 'imask';
5
+ import { WLCM_PHONE_ADAPTER } from '../constants/phone-adapter.constants';
6
+ import { WlcmPhoneAdapter } from '../models/phone-adapter.models';
7
+ import { WlcmPhoneValidationErrorType } from '../models/phone.models';
8
+ import { isValidNumber, getExampleNumber } from 'libphonenumber-js';
9
+ import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
10
+ import examples from 'libphonenumber-js/mobile/examples';
11
+ import { Subject, fromEvent, takeUntil } from 'rxjs';
12
+ import * as i0 from "@angular/core";
13
+ import * as i1 from "../models/phone-adapter.models";
14
+ let WlcmPhoneInputDirective = class WlcmPhoneInputDirective {
15
+ handleBlur() {
16
+ this._touched?.();
17
+ }
18
+ constructor(_elementRef, phoneAdapter) {
19
+ this._elementRef = _elementRef;
20
+ this.phoneAdapter = phoneAdapter;
21
+ this.control = new FormControl();
22
+ this.destroyInputObserver$ = new Subject();
23
+ this.applyMask = input(true);
24
+ effect(() => {
25
+ if (this.applyMask()) {
26
+ if (!this._imaskRef)
27
+ this.initializeMask();
28
+ this._imaskRef.mask = this.getMask();
29
+ this._imaskRef.updateControl();
30
+ this._imaskRef.on('accept', () => this.handleInput());
31
+ this.destroyInputObserver$.next();
32
+ }
33
+ else {
34
+ this.subscribeToInputEvent();
35
+ }
36
+ });
37
+ this._updateMaskByCountryCode();
38
+ this.subscribeToPasteEvent();
39
+ }
40
+ ngOnDestroy() {
41
+ this.destroyInputObserver$.next();
42
+ this.destroyInputObserver$.complete();
43
+ }
44
+ writeValue(value) {
45
+ const parsedValue = this.phoneAdapter.parseValue(value);
46
+ this.updateValue(parsedValue);
47
+ }
48
+ registerOnChange(callback) {
49
+ this._changed = callback;
50
+ }
51
+ registerOnTouched(callback) {
52
+ this._touched = callback;
53
+ }
54
+ registerOnValidatorChange(callback) {
55
+ this._validatorChanged = callback;
56
+ }
57
+ validate(control) {
58
+ const isValid = isValidNumber(control.value ?? '');
59
+ if (!isValid) {
60
+ return { [WlcmPhoneValidationErrorType.InvalidPhoneNumber]: true };
61
+ }
62
+ return null;
63
+ }
64
+ setDisabledState(isDisabled) {
65
+ if (isDisabled) {
66
+ return this.control.disable();
67
+ }
68
+ this.control.enable();
69
+ }
70
+ _updateControl() {
71
+ this.handleInput();
72
+ }
73
+ _updateMaskByCountryCode() {
74
+ const code = this.phoneAdapter.getCurrentCountryCode();
75
+ const nationalFormat = getExampleNumber(code, examples)?.formatNational();
76
+ const mask = this.getMask(nationalFormat);
77
+ if (this._imaskRef) {
78
+ this._imaskRef.mask = mask;
79
+ this._imaskRef.updateControl();
80
+ }
81
+ this.element.placeholder = mask;
82
+ }
83
+ get element() {
84
+ return this._elementRef.nativeElement;
85
+ }
86
+ getMask(nationalFormat) {
87
+ if (!nationalFormat)
88
+ return '(000) 000-0000';
89
+ return nationalFormat.replace(/\d/g, '0');
90
+ }
91
+ updateValue(parsedValue) {
92
+ if (this._imaskRef) {
93
+ this._imaskRef.value = parsedValue;
94
+ this._imaskRef.updateControl();
95
+ }
96
+ else {
97
+ this.element.value = parsedValue;
98
+ }
99
+ }
100
+ handleInput() {
101
+ const value = this.element.value;
102
+ this._changed?.(this.phoneAdapter.formatValue(value));
103
+ }
104
+ handlePaste(event) {
105
+ event.preventDefault();
106
+ const value = event.clipboardData?.getData('text') ?? '';
107
+ const parsedValue = this.phoneAdapter.parseValue(value);
108
+ this._updateMaskByCountryCode();
109
+ this.updateValue(parsedValue);
110
+ this.handleInput();
111
+ }
112
+ initializeMask() {
113
+ this._imaskRef = IMask(this.element, { mask: Number });
114
+ }
115
+ subscribeToInputEvent() {
116
+ fromEvent(this.element, 'input')
117
+ .pipe(takeUntil(this.destroyInputObserver$))
118
+ .subscribe(() => this.handleInput());
119
+ }
120
+ subscribeToPasteEvent() {
121
+ fromEvent(this.element, 'paste')
122
+ .pipe(untilDestroyed(this))
123
+ .subscribe((event) => this.handlePaste(event));
124
+ }
125
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputDirective, deps: [{ token: i0.ElementRef }, { token: WLCM_PHONE_ADAPTER }], target: i0.ɵɵFactoryTarget.Directive }); }
126
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.6", type: WlcmPhoneInputDirective, isStandalone: true, selector: "[wlcmPhoneInput]", inputs: { applyMask: { classPropertyName: "applyMask", publicName: "applyMask", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "blur": "handleBlur($event)" }, classAttribute: "wlcm-form-field-input" }, providers: [
127
+ { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmPhoneInputDirective), multi: true },
128
+ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmPhoneInputDirective), multi: true },
129
+ ], ngImport: i0 }); }
130
+ };
131
+ WlcmPhoneInputDirective = __decorate([
132
+ UntilDestroy(),
133
+ __metadata("design:paramtypes", [ElementRef,
134
+ WlcmPhoneAdapter])
135
+ ], WlcmPhoneInputDirective);
136
+ export { WlcmPhoneInputDirective };
137
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputDirective, decorators: [{
138
+ type: Directive,
139
+ args: [{
140
+ selector: '[wlcmPhoneInput]',
141
+ host: { class: 'wlcm-form-field-input' },
142
+ standalone: true,
143
+ providers: [
144
+ { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmPhoneInputDirective), multi: true },
145
+ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmPhoneInputDirective), multi: true },
146
+ ],
147
+ }]
148
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.WlcmPhoneAdapter, decorators: [{
149
+ type: Inject,
150
+ args: [WLCM_PHONE_ADAPTER]
151
+ }] }], propDecorators: { handleBlur: [{
152
+ type: HostListener,
153
+ args: ['blur', ['$event']]
154
+ }] } });
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-input.directive.js","sourceRoot":"","sources":["../../../../../../modules/phone-input/src/lib/directives/phone-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  HostListener,\n  Inject,\n  InputSignal,\n  OnDestroy,\n  effect,\n  forwardRef,\n  input,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport IMask, { InputMask } from 'imask';\nimport { WLCM_PHONE_ADAPTER } from '../constants/phone-adapter.constants';\nimport { WlcmPhoneAdapter } from '../models/phone-adapter.models';\nimport { WlcmPhoneValidationErrorType } from '../models/phone.models';\nimport { isValidNumber, getExampleNumber, CountryCode } from 'libphonenumber-js';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport examples from 'libphonenumber-js/mobile/examples';\nimport { Subject, fromEvent, takeUntil } from 'rxjs';\n\n@UntilDestroy()\n@Directive({\n  selector: '[wlcmPhoneInput]',\n  host: { class: 'wlcm-form-field-input' },\n  standalone: true,\n  providers: [\n    { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmPhoneInputDirective), multi: true },\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmPhoneInputDirective), multi: true },\n  ],\n})\nexport class WlcmPhoneInputDirective implements OnDestroy, ControlValueAccessor, Validator {\n  readonly control: FormControl = new FormControl();\n\n  private _changed?: (value: string) => void;\n\n  private _touched?: () => void;\n\n  private _validatorChanged?: () => void;\n\n  private destroyInputObserver$: Subject<void> = new Subject();\n\n  private _imaskRef?: InputMask;\n\n  applyMask: InputSignal<boolean> = input(true);\n\n  @HostListener('blur', ['$event']) handleBlur(): void {\n    this._touched?.();\n  }\n\n  constructor(\n    private _elementRef: ElementRef<HTMLInputElement>,\n    @Inject(WLCM_PHONE_ADAPTER) private phoneAdapter: WlcmPhoneAdapter,\n  ) {\n    effect(() => {\n      if (this.applyMask()) {\n        if (!this._imaskRef) this.initializeMask();\n\n        this._imaskRef!.mask = this.getMask();\n\n        this._imaskRef!.updateControl();\n\n        this._imaskRef!.on('accept', () => this.handleInput());\n\n        this.destroyInputObserver$.next();\n      } else {\n        this.subscribeToInputEvent();\n      }\n    });\n\n    this._updateMaskByCountryCode();\n\n    this.subscribeToPasteEvent();\n  }\n\n  ngOnDestroy(): void {\n    this.destroyInputObserver$.next();\n    this.destroyInputObserver$.complete();\n  }\n\n  writeValue(value: string): void {\n    const parsedValue: string = this.phoneAdapter.parseValue(value);\n\n    this.updateValue(parsedValue);\n  }\n\n  registerOnChange(callback: (value: string) => void): void {\n    this._changed = callback;\n  }\n\n  registerOnTouched(callback: () => void): void {\n    this._touched = callback;\n  }\n\n  registerOnValidatorChange(callback: () => void): void {\n    this._validatorChanged = callback;\n  }\n\n  validate(control: AbstractControl): ValidationErrors | null {\n    const isValid: boolean = isValidNumber(control.value ?? '');\n\n    if (!isValid) {\n      return { [WlcmPhoneValidationErrorType.InvalidPhoneNumber]: true };\n    }\n\n    return null;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      return this.control.disable();\n    }\n\n    this.control.enable();\n  }\n\n  _updateControl(): void {\n    this.handleInput();\n  }\n\n  _updateMaskByCountryCode(): void {\n    const code: CountryCode = this.phoneAdapter.getCurrentCountryCode();\n\n    const nationalFormat = getExampleNumber(code, examples)?.formatNational();\n\n    const mask: string = this.getMask(nationalFormat);\n\n    if (this._imaskRef) {\n      this._imaskRef.mask = mask;\n\n      this._imaskRef.updateControl();\n    }\n\n    this.element.placeholder = mask;\n  }\n\n  get element(): HTMLInputElement {\n    return this._elementRef.nativeElement;\n  }\n\n  private getMask(nationalFormat?: string): string {\n    if (!nationalFormat) return '(000) 000-0000';\n\n    return nationalFormat.replace(/\\d/g, '0');\n  }\n\n  private updateValue(parsedValue: string): void {\n    if (this._imaskRef) {\n      this._imaskRef.value = parsedValue;\n\n      this._imaskRef.updateControl();\n    } else {\n      this.element.value = parsedValue;\n    }\n  }\n\n  private handleInput(): void {\n    const value: string = this.element.value;\n\n    this._changed?.(this.phoneAdapter.formatValue(value));\n  }\n\n  private handlePaste(event: ClipboardEvent): void {\n    event.preventDefault();\n\n    const value: string = event.clipboardData?.getData('text') ?? '';\n\n    const parsedValue: string = this.phoneAdapter.parseValue(value);\n\n    this._updateMaskByCountryCode();\n\n    this.updateValue(parsedValue);\n\n    this.handleInput();\n  }\n\n  private initializeMask(): void {\n    this._imaskRef = IMask(this.element, { mask: Number });\n  }\n\n  private subscribeToInputEvent(): void {\n    fromEvent(this.element, 'input')\n      .pipe(takeUntil(this.destroyInputObserver$))\n      .subscribe(() => this.handleInput());\n  }\n\n  private subscribeToPasteEvent(): void {\n    fromEvent<ClipboardEvent>(this.element, 'paste')\n      .pipe(untilDestroyed(this))\n      .subscribe((event: ClipboardEvent) => this.handlePaste(event));\n  }\n}\n"]}
@@ -0,0 +1,10 @@
1
+ import { WlcmOption } from '@wlcm/angular/core';
2
+ export class WlcmCountryCodeOption extends WlcmOption {
3
+ constructor(value, viewValue, emojiFlag) {
4
+ super(value, viewValue);
5
+ this.value = value;
6
+ this.viewValue = viewValue;
7
+ this.emojiFlag = emojiFlag;
8
+ }
9
+ }
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291bnRyeS1jb2RlLm1vZGVscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL21vZHVsZXMvcGhvbmUtaW5wdXQvc3JjL2xpYi9tb2RlbHMvY291bnRyeS1jb2RlLm1vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFaEQsTUFBTSxPQUFPLHFCQUFzQixTQUFRLFVBQVU7SUFDbkQsWUFBNEIsS0FBYSxFQUFrQixTQUFpQixFQUFTLFNBQWlCO1FBQ3BHLEtBQUssQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFERSxVQUFLLEdBQUwsS0FBSyxDQUFRO1FBQWtCLGNBQVMsR0FBVCxTQUFTLENBQVE7UUFBUyxjQUFTLEdBQVQsU0FBUyxDQUFRO0lBRXRHLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFdsY21PcHRpb24gfSBmcm9tICdAd2xjbS9hbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY2xhc3MgV2xjbUNvdW50cnlDb2RlT3B0aW9uIGV4dGVuZHMgV2xjbU9wdGlvbiB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBvdmVycmlkZSB2YWx1ZTogc3RyaW5nLCBwdWJsaWMgb3ZlcnJpZGUgdmlld1ZhbHVlOiBzdHJpbmcsIHB1YmxpYyBlbW9qaUZsYWc6IHN0cmluZykge1xuICAgIHN1cGVyKHZhbHVlLCB2aWV3VmFsdWUpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export class WlcmPhoneAdapter {
2
+ }
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGhvbmUtYWRhcHRlci5tb2RlbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9tb2R1bGVzL3Bob25lLWlucHV0L3NyYy9saWIvbW9kZWxzL3Bob25lLWFkYXB0ZXIubW9kZWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFBLE1BQU0sT0FBZ0IsZ0JBQWdCO0NBTXJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ291bnRyeUNvZGUgfSBmcm9tICdsaWJwaG9uZW51bWJlci1qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2xjbVBhcnNlZFBob25lIHtcbiAgY291bnRyeUNvZGU6IHN0cmluZztcblxuICBwaG9uZU51bWJlcjogc3RyaW5nO1xufVxuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgV2xjbVBob25lQWRhcHRlciB7XG4gIGFic3RyYWN0IGdldEN1cnJlbnRDb3VudHJ5Q29kZSgpOiBDb3VudHJ5Q29kZTtcblxuICBhYnN0cmFjdCBwYXJzZVZhbHVlKHZhbHVlOiBzdHJpbmcpOiBzdHJpbmc7XG5cbiAgYWJzdHJhY3QgZm9ybWF0VmFsdWUodmFsdWU6IHN0cmluZyk6IHN0cmluZztcbn1cbiJdfQ==
@@ -0,0 +1,5 @@
1
+ export var WlcmPhoneValidationErrorType;
2
+ (function (WlcmPhoneValidationErrorType) {
3
+ WlcmPhoneValidationErrorType["InvalidPhoneNumber"] = "InvalidPhoneNumber";
4
+ })(WlcmPhoneValidationErrorType || (WlcmPhoneValidationErrorType = {}));
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGhvbmUubW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9waG9uZS1pbnB1dC9zcmMvbGliL21vZGVscy9waG9uZS5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksNEJBRVg7QUFGRCxXQUFZLDRCQUE0QjtJQUN0Qyx5RUFBeUMsQ0FBQTtBQUMzQyxDQUFDLEVBRlcsNEJBQTRCLEtBQTVCLDRCQUE0QixRQUV2QyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFdsY21QaG9uZVZhbGlkYXRpb25FcnJvclR5cGUge1xuICBJbnZhbGlkUGhvbmVOdW1iZXIgPSAnSW52YWxpZFBob25lTnVtYmVyJyxcbn1cbiJdfQ==
@@ -0,0 +1,20 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { WlcmPhoneInputContainerComponent } from './components/phone-input-container/phone-input-container.component';
4
+ import { WlcmPhoneInputDirective } from './directives/phone-input.directive';
5
+ import * as i0 from "@angular/core";
6
+ const publicComponents = [WlcmPhoneInputContainerComponent];
7
+ const publicDirectives = [WlcmPhoneInputDirective];
8
+ export class WlcmPhoneInputModule {
9
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
10
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputModule, imports: [CommonModule, WlcmPhoneInputContainerComponent, WlcmPhoneInputDirective], exports: [WlcmPhoneInputContainerComponent, WlcmPhoneInputDirective] }); }
11
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputModule, imports: [CommonModule, publicComponents] }); }
12
+ }
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputModule, decorators: [{
14
+ type: NgModule,
15
+ args: [{
16
+ imports: [CommonModule, ...publicComponents, ...publicDirectives],
17
+ exports: [...publicComponents, ...publicDirectives],
18
+ }]
19
+ }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGhvbmUtaW5wdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9waG9uZS1pbnB1dC9zcmMvbGliL3Bob25lLWlucHV0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFRLE1BQU0sZUFBZSxDQUFDO0FBQy9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSxvRUFBb0UsQ0FBQztBQUN0SCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7QUFFN0UsTUFBTSxnQkFBZ0IsR0FBb0IsQ0FBQyxnQ0FBZ0MsQ0FBQyxDQUFDO0FBRTdFLE1BQU0sZ0JBQWdCLEdBQW9CLENBQUMsdUJBQXVCLENBQUMsQ0FBQztBQU1wRSxNQUFNLE9BQU8sb0JBQW9COzhHQUFwQixvQkFBb0I7K0dBQXBCLG9CQUFvQixZQUhyQixZQUFZLEVBTG1CLGdDQUFnQyxFQUVoQyx1QkFBdUIsYUFGdkIsZ0NBQWdDLEVBRWhDLHVCQUF1QjsrR0FNckQsb0JBQW9CLFlBSHJCLFlBQVksRUFBSyxnQkFBZ0I7OzJGQUdoQyxvQkFBb0I7a0JBSmhDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLEdBQUcsZ0JBQWdCLEVBQUUsR0FBRyxnQkFBZ0IsQ0FBQztvQkFDakUsT0FBTyxFQUFFLENBQUMsR0FBRyxnQkFBZ0IsRUFBRSxHQUFHLGdCQUFnQixDQUFDO2lCQUNwRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlLCBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgV2xjbVBob25lSW5wdXRDb250YWluZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvcGhvbmUtaW5wdXQtY29udGFpbmVyL3Bob25lLWlucHV0LWNvbnRhaW5lci5jb21wb25lbnQnO1xuaW1wb3J0IHsgV2xjbVBob25lSW5wdXREaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZXMvcGhvbmUtaW5wdXQuZGlyZWN0aXZlJztcblxuY29uc3QgcHVibGljQ29tcG9uZW50czogVHlwZTx1bmtub3duPltdID0gW1dsY21QaG9uZUlucHV0Q29udGFpbmVyQ29tcG9uZW50XTtcblxuY29uc3QgcHVibGljRGlyZWN0aXZlczogVHlwZTx1bmtub3duPltdID0gW1dsY21QaG9uZUlucHV0RGlyZWN0aXZlXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgLi4ucHVibGljQ29tcG9uZW50cywgLi4ucHVibGljRGlyZWN0aXZlc10sXG4gIGV4cG9ydHM6IFsuLi5wdWJsaWNDb21wb25lbnRzLCAuLi5wdWJsaWNEaXJlY3RpdmVzXSxcbn0pXG5leHBvcnQgY2xhc3MgV2xjbVBob25lSW5wdXRNb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,18 @@
1
+ import { Pipe } from '@angular/core';
2
+ import { getPhoneCode } from 'libphonenumber-js';
3
+ import * as i0 from "@angular/core";
4
+ export class PhoneCodePipe {
5
+ transform(value) {
6
+ return value ? getPhoneCode(value) : '1';
7
+ }
8
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: PhoneCodePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
9
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.6", ngImport: i0, type: PhoneCodePipe, isStandalone: true, name: "phoneCode" }); }
10
+ }
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: PhoneCodePipe, decorators: [{
12
+ type: Pipe,
13
+ args: [{
14
+ name: 'phoneCode',
15
+ standalone: true,
16
+ }]
17
+ }] });
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGhvbmUtY29kZS5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9waG9uZS1pbnB1dC9zcmMvbGliL3BpcGVzL3Bob25lLWNvZGUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQWUsWUFBWSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBTTlELE1BQU0sT0FBTyxhQUFhO0lBQ3hCLFNBQVMsQ0FBQyxLQUF5QjtRQUNqQyxPQUFPLEtBQUssQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUM7SUFDM0MsQ0FBQzs4R0FIVSxhQUFhOzRHQUFiLGFBQWE7OzJGQUFiLGFBQWE7a0JBSnpCLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLFdBQVc7b0JBQ2pCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvdW50cnlDb2RlLCBnZXRQaG9uZUNvZGUgfSBmcm9tICdsaWJwaG9uZW51bWJlci1qcyc7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ3Bob25lQ29kZScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIFBob25lQ29kZVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgdHJhbnNmb3JtKHZhbHVlOiBDb3VudHJ5Q29kZSB8IG51bGwpOiBzdHJpbmcge1xuICAgIHJldHVybiB2YWx1ZSA/IGdldFBob25lQ29kZSh2YWx1ZSkgOiAnMSc7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2xjbS1hbmd1bGFyLXBob25lLWlucHV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbW9kdWxlcy9waG9uZS1pbnB1dC9zcmMvd2xjbS1hbmd1bGFyLXBob25lLWlucHV0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
@@ -135,8 +135,8 @@ let WlcmPhoneInputDirective = class WlcmPhoneInputDirective {
135
135
  .pipe(untilDestroyed(this))
136
136
  .subscribe((event) => this.handlePaste(event));
137
137
  }
138
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: WlcmPhoneInputDirective, deps: [{ token: i0.ElementRef }, { token: WLCM_PHONE_ADAPTER }], target: i0.ɵɵFactoryTarget.Directive }); }
139
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "19.1.4", type: WlcmPhoneInputDirective, isStandalone: true, selector: "[wlcmPhoneInput]", inputs: { applyMask: { classPropertyName: "applyMask", publicName: "applyMask", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "blur": "handleBlur($event)" }, classAttribute: "wlcm-form-field-input" }, providers: [
138
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputDirective, deps: [{ token: i0.ElementRef }, { token: WLCM_PHONE_ADAPTER }], target: i0.ɵɵFactoryTarget.Directive }); }
139
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.6", type: WlcmPhoneInputDirective, isStandalone: true, selector: "[wlcmPhoneInput]", inputs: { applyMask: { classPropertyName: "applyMask", publicName: "applyMask", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "blur": "handleBlur($event)" }, classAttribute: "wlcm-form-field-input" }, providers: [
140
140
  { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmPhoneInputDirective), multi: true },
141
141
  { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmPhoneInputDirective), multi: true },
142
142
  ], ngImport: i0 }); }
@@ -146,7 +146,7 @@ WlcmPhoneInputDirective = __decorate([
146
146
  __metadata("design:paramtypes", [ElementRef,
147
147
  WlcmPhoneAdapter])
148
148
  ], WlcmPhoneInputDirective);
149
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: WlcmPhoneInputDirective, decorators: [{
149
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputDirective, decorators: [{
150
150
  type: Directive,
151
151
  args: [{
152
152
  selector: '[wlcmPhoneInput]',
@@ -194,10 +194,10 @@ class PhoneCodePipe {
194
194
  transform(value) {
195
195
  return value ? getPhoneCode(value) : '1';
196
196
  }
197
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: PhoneCodePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
198
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "19.1.4", ngImport: i0, type: PhoneCodePipe, isStandalone: true, name: "phoneCode" }); }
197
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: PhoneCodePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
198
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.6", ngImport: i0, type: PhoneCodePipe, isStandalone: true, name: "phoneCode" }); }
199
199
  }
200
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: PhoneCodePipe, decorators: [{
200
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: PhoneCodePipe, decorators: [{
201
201
  type: Pipe,
202
202
  args: [{
203
203
  name: 'phoneCode',
@@ -214,10 +214,10 @@ class WlcmCountryCodeSelectComponent {
214
214
  get selectComponent() {
215
215
  return this.wlcmSelect.matSelect;
216
216
  }
217
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: WlcmCountryCodeSelectComponent, deps: [{ token: WLCM_COUNTRY_CODE_OPTIONS }], target: i0.ɵɵFactoryTarget.Component }); }
218
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "19.1.4", type: WlcmCountryCodeSelectComponent, isStandalone: true, selector: "wlcm-country-code-select", inputs: { control: { classPropertyName: "control", publicName: "control", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { changed: "changed" }, host: { classAttribute: "wlcm-country-code-select" }, viewQueries: [{ propertyName: "wlcmSelect", first: true, predicate: WlcmSelectComponent, descendants: true }], ngImport: i0, template: "<wlcm-select\n [options]=\"options\"\n [formControl]=\"control()\"\n [optionTemplate]=\"optionTemplate\"\n [triggerTemplate]=\"triggerTemplate\"\n (selectionChange)=\"changed.emit($event)\"\n></wlcm-select>\n\n<ng-template #optionTemplate let-option>\n <span class=\"emoji-flag\">{{ option.emojiFlag }}</span>\n\n {{ option.viewValue }}\n</ng-template>\n\n<ng-template #triggerTemplate let-selected>\n <div class=\"wlcm-country-code-select-trigger\">\n +{{ selected?.value | phoneCode }}\n </div>\n</ng-template>\n", styles: [".emoji-flag{font-size:20px;vertical-align:bottom;margin-right:8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: WlcmFormsModule }, { kind: "component", type: i1.WlcmSelectComponent, selector: "wlcm-select", inputs: ["multiple", "placeholder", "fetchPaginatedOptions", "canSelect", "queryParams", "paginated", "options", "selectOptionFormat", "optionTemplate", "triggerTemplate", "isOptionDisabled"], outputs: ["selectionChange", "opened", "closed"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: PhoneCodePipe, name: "phoneCode" }] }); }
217
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmCountryCodeSelectComponent, deps: [{ token: WLCM_COUNTRY_CODE_OPTIONS }], target: i0.ɵɵFactoryTarget.Component }); }
218
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.6", type: WlcmCountryCodeSelectComponent, isStandalone: true, selector: "wlcm-country-code-select", inputs: { control: { classPropertyName: "control", publicName: "control", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { changed: "changed" }, host: { classAttribute: "wlcm-country-code-select" }, viewQueries: [{ propertyName: "wlcmSelect", first: true, predicate: WlcmSelectComponent, descendants: true }], ngImport: i0, template: "<wlcm-select\n [options]=\"options\"\n [formControl]=\"control()\"\n [optionTemplate]=\"optionTemplate\"\n [triggerTemplate]=\"triggerTemplate\"\n (selectionChange)=\"changed.emit($event)\"\n></wlcm-select>\n\n<ng-template #optionTemplate let-option>\n <span class=\"emoji-flag\">{{ option.emojiFlag }}</span>\n\n {{ option.viewValue }}\n</ng-template>\n\n<ng-template #triggerTemplate let-selected>\n <div class=\"wlcm-country-code-select-trigger\">\n +{{ selected?.value | phoneCode }}\n </div>\n</ng-template>\n", styles: [".emoji-flag{font-size:20px;vertical-align:bottom;margin-right:8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: WlcmFormsModule }, { kind: "component", type: i1.WlcmSelectComponent, selector: "wlcm-select", inputs: ["multiple", "placeholder", "fetchPaginatedOptions", "canSelect", "queryParams", "paginated", "options", "selectOptionFormat", "optionTemplate", "triggerTemplate", "isOptionDisabled"], outputs: ["selectionChange", "opened", "closed"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: PhoneCodePipe, name: "phoneCode" }] }); }
219
219
  }
220
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: WlcmCountryCodeSelectComponent, decorators: [{
220
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmCountryCodeSelectComponent, decorators: [{
221
221
  type: Component,
222
222
  args: [{ selector: 'wlcm-country-code-select', host: { class: 'wlcm-country-code-select' }, standalone: true, imports: [CommonModule, WlcmFormsModule, ReactiveFormsModule, PhoneCodePipe], template: "<wlcm-select\n [options]=\"options\"\n [formControl]=\"control()\"\n [optionTemplate]=\"optionTemplate\"\n [triggerTemplate]=\"triggerTemplate\"\n (selectionChange)=\"changed.emit($event)\"\n></wlcm-select>\n\n<ng-template #optionTemplate let-option>\n <span class=\"emoji-flag\">{{ option.emojiFlag }}</span>\n\n {{ option.viewValue }}\n</ng-template>\n\n<ng-template #triggerTemplate let-selected>\n <div class=\"wlcm-country-code-select-trigger\">\n +{{ selected?.value | phoneCode }}\n </div>\n</ng-template>\n", styles: [".emoji-flag{font-size:20px;vertical-align:bottom;margin-right:8px}\n"] }]
223
223
  }], ctorParameters: () => [{ type: undefined, decorators: [{
@@ -286,8 +286,8 @@ let WlcmPhoneInputContainerComponent = class WlcmPhoneInputContainerComponent {
286
286
  .subscribe();
287
287
  });
288
288
  }
289
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: WlcmPhoneInputContainerComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
290
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.4", type: WlcmPhoneInputContainerComponent, isStandalone: true, selector: "wlcm-phone-input-container", host: { classAttribute: "wlcm-phone-input-container" }, providers: [
289
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputContainerComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
290
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: WlcmPhoneInputContainerComponent, isStandalone: true, selector: "wlcm-phone-input-container", host: { classAttribute: "wlcm-phone-input-container" }, providers: [
291
291
  {
292
292
  provide: WLCM_INPUT_BINDER,
293
293
  useFactory: () => {
@@ -302,7 +302,7 @@ WlcmPhoneInputContainerComponent = __decorate([
302
302
  UntilDestroy(),
303
303
  __metadata("design:paramtypes", [NgZone])
304
304
  ], WlcmPhoneInputContainerComponent);
305
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: WlcmPhoneInputContainerComponent, decorators: [{
305
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputContainerComponent, decorators: [{
306
306
  type: Component,
307
307
  args: [{ selector: 'wlcm-phone-input-container', host: { class: 'wlcm-phone-input-container' }, standalone: true, imports: [CommonModule, WlcmCountryCodeSelectComponent], providers: [
308
308
  {
@@ -325,11 +325,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.4", ngImpor
325
325
  const publicComponents = [WlcmPhoneInputContainerComponent];
326
326
  const publicDirectives = [WlcmPhoneInputDirective];
327
327
  class WlcmPhoneInputModule {
328
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: WlcmPhoneInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
329
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "19.1.4", ngImport: i0, type: WlcmPhoneInputModule, imports: [CommonModule, WlcmPhoneInputContainerComponent, WlcmPhoneInputDirective], exports: [WlcmPhoneInputContainerComponent, WlcmPhoneInputDirective] }); }
330
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: WlcmPhoneInputModule, imports: [CommonModule, publicComponents] }); }
328
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
329
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputModule, imports: [CommonModule, WlcmPhoneInputContainerComponent, WlcmPhoneInputDirective], exports: [WlcmPhoneInputContainerComponent, WlcmPhoneInputDirective] }); }
330
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputModule, imports: [CommonModule, publicComponents] }); }
331
331
  }
332
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.4", ngImport: i0, type: WlcmPhoneInputModule, decorators: [{
332
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: WlcmPhoneInputModule, decorators: [{
333
333
  type: NgModule,
334
334
  args: [{
335
335
  imports: [CommonModule, ...publicComponents, ...publicDirectives],