@theseam/ui-common 0.4.13 → 0.4.15

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 (139) hide show
  1. package/buttons/public-api.d.ts +1 -0
  2. package/buttons/testing/anchor-badge-button.harness.d.ts +16 -0
  3. package/buttons/testing/anchor-button.harness.d.ts +16 -0
  4. package/buttons/testing/badge-button.harness.d.ts +15 -0
  5. package/buttons/testing/base-badge-button.harness.d.ts +15 -0
  6. package/buttons/testing/base-button.harness.d.ts +19 -0
  7. package/buttons/testing/button.harness.d.ts +15 -0
  8. package/buttons/testing/index.d.ts +5 -0
  9. package/buttons/testing/toggle-button.harness.d.ts +21 -0
  10. package/checkbox/checkbox.component.d.ts +1 -1
  11. package/checkbox/checkbox.module.d.ts +2 -3
  12. package/datatable/datatable.module.d.ts +1 -1
  13. package/esm2020/buttons/button/button.component.mjs +2 -1
  14. package/esm2020/buttons/public-api.mjs +2 -1
  15. package/esm2020/buttons/testing/anchor-badge-button.harness.mjs +18 -0
  16. package/esm2020/buttons/testing/anchor-button.harness.mjs +18 -0
  17. package/esm2020/buttons/testing/badge-button.harness.mjs +14 -0
  18. package/esm2020/buttons/testing/base-badge-button.harness.mjs +29 -0
  19. package/esm2020/buttons/testing/base-button.harness.mjs +41 -0
  20. package/esm2020/buttons/testing/button.harness.mjs +16 -0
  21. package/esm2020/buttons/testing/index.mjs +6 -0
  22. package/esm2020/buttons/testing/toggle-button.harness.mjs +25 -0
  23. package/esm2020/checkbox/checkbox.component.mjs +8 -3
  24. package/esm2020/checkbox/checkbox.module.mjs +5 -12
  25. package/esm2020/datatable/datatable.module.mjs +5 -5
  26. package/esm2020/form-field/form-field.component.mjs +4 -4
  27. package/esm2020/framework/schema-form/index.mjs +2 -1
  28. package/esm2020/framework/schema-form/schema-form-framework.component.mjs +6 -3
  29. package/esm2020/framework/schema-form/schema-form-framework.mjs +62 -7
  30. package/esm2020/framework/schema-form/schema-form-widget.mjs +2 -0
  31. package/esm2020/framework/schema-form/schema-form.module.mjs +1 -8
  32. package/esm2020/framework/schema-form-controls/schema-form-checkbox/schema-form-checkbox.component.mjs +21 -11
  33. package/esm2020/framework/schema-form-controls/schema-form-divider/schema-form-divider.component.mjs +20 -0
  34. package/esm2020/framework/schema-form-controls/schema-form-input/schema-form-input.component.mjs +17 -8
  35. package/esm2020/framework/schema-form-controls/schema-form-number/schema-form-number.component.mjs +14 -5
  36. package/esm2020/framework/schema-form-controls/schema-form-select/schema-form-select.component.mjs +19 -9
  37. package/esm2020/framework/schema-form-controls/schema-form-submit/schema-form-submit.component.mjs +21 -13
  38. package/esm2020/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.mjs +30 -18
  39. package/esm2020/framework/schema-form-controls/schema-form-tel/schema-form-tel.component.mjs +48 -0
  40. package/esm2020/framework/schema-form-controls/schema-form-tiled-select/schema-form-tiled-select.component.mjs +57 -0
  41. package/esm2020/google-maps/google-maps/google-maps.component.mjs +9 -2
  42. package/esm2020/google-maps/google-maps-api-loader/lazy-google-maps-api-loader.mjs +2 -1
  43. package/esm2020/menu/public-api.mjs +5 -1
  44. package/esm2020/menu/testing/menu-footer.harness.mjs +28 -0
  45. package/esm2020/menu/testing/menu-header.harness.mjs +23 -0
  46. package/esm2020/menu/testing/menu-item.harness.mjs +59 -0
  47. package/esm2020/menu/testing/menu.harness.mjs +163 -0
  48. package/esm2020/menu/testing/utils.mjs +13 -0
  49. package/esm2020/story-helpers/args-to-tpl.mjs +83 -0
  50. package/esm2020/story-helpers/public-api.mjs +2 -2
  51. package/esm2020/tel-input/public-api.mjs +2 -1
  52. package/esm2020/tel-input/tel-input/tel-input.component.mjs +22 -10
  53. package/esm2020/tel-input/tel-input.directive.mjs +12 -13
  54. package/esm2020/tel-input/tel-input.module.mjs +10 -9
  55. package/esm2020/tel-input/testing/tel-input.harness.mjs +49 -0
  56. package/esm2020/testing/harnesses/ng-select-dropdown.harness.mjs +39 -0
  57. package/esm2020/testing/harnesses/ng-select-option.harness.mjs +26 -0
  58. package/esm2020/testing/harnesses/ng-select.harness.mjs +104 -0
  59. package/esm2020/testing/public-api.mjs +4 -1
  60. package/esm2020/tiled-select/components/tiled-select/tiled-select.component.mjs +1 -1
  61. package/fesm2015/theseam-ui-common-buttons.mjs +181 -3
  62. package/fesm2015/theseam-ui-common-buttons.mjs.map +1 -1
  63. package/fesm2015/theseam-ui-common-checkbox.mjs +12 -14
  64. package/fesm2015/theseam-ui-common-checkbox.mjs.map +1 -1
  65. package/fesm2015/theseam-ui-common-datatable.mjs +4 -4
  66. package/fesm2015/theseam-ui-common-datatable.mjs.map +1 -1
  67. package/fesm2015/theseam-ui-common-form-field.mjs +3 -3
  68. package/fesm2015/theseam-ui-common-form-field.mjs.map +1 -1
  69. package/fesm2015/theseam-ui-common-framework.mjs +248 -164
  70. package/fesm2015/theseam-ui-common-framework.mjs.map +1 -1
  71. package/fesm2015/theseam-ui-common-google-maps.mjs +10 -1
  72. package/fesm2015/theseam-ui-common-google-maps.mjs.map +1 -1
  73. package/fesm2015/theseam-ui-common-menu.mjs +329 -3
  74. package/fesm2015/theseam-ui-common-menu.mjs.map +1 -1
  75. package/fesm2015/theseam-ui-common-story-helpers.mjs +86 -1
  76. package/fesm2015/theseam-ui-common-story-helpers.mjs.map +1 -1
  77. package/fesm2015/theseam-ui-common-tel-input.mjs +105 -29
  78. package/fesm2015/theseam-ui-common-tel-input.mjs.map +1 -1
  79. package/fesm2015/theseam-ui-common-testing.mjs +197 -1
  80. package/fesm2015/theseam-ui-common-testing.mjs.map +1 -1
  81. package/fesm2015/theseam-ui-common-tiled-select.mjs.map +1 -1
  82. package/fesm2020/theseam-ui-common-buttons.mjs +154 -2
  83. package/fesm2020/theseam-ui-common-buttons.mjs.map +1 -1
  84. package/fesm2020/theseam-ui-common-checkbox.mjs +12 -14
  85. package/fesm2020/theseam-ui-common-checkbox.mjs.map +1 -1
  86. package/fesm2020/theseam-ui-common-datatable.mjs +4 -4
  87. package/fesm2020/theseam-ui-common-datatable.mjs.map +1 -1
  88. package/fesm2020/theseam-ui-common-form-field.mjs +3 -3
  89. package/fesm2020/theseam-ui-common-form-field.mjs.map +1 -1
  90. package/fesm2020/theseam-ui-common-framework.mjs +236 -162
  91. package/fesm2020/theseam-ui-common-framework.mjs.map +1 -1
  92. package/fesm2020/theseam-ui-common-google-maps.mjs +9 -1
  93. package/fesm2020/theseam-ui-common-google-maps.mjs.map +1 -1
  94. package/fesm2020/theseam-ui-common-menu.mjs +275 -2
  95. package/fesm2020/theseam-ui-common-menu.mjs.map +1 -1
  96. package/fesm2020/theseam-ui-common-story-helpers.mjs +84 -1
  97. package/fesm2020/theseam-ui-common-story-helpers.mjs.map +1 -1
  98. package/fesm2020/theseam-ui-common-tel-input.mjs +89 -29
  99. package/fesm2020/theseam-ui-common-tel-input.mjs.map +1 -1
  100. package/fesm2020/theseam-ui-common-testing.mjs +165 -1
  101. package/fesm2020/theseam-ui-common-testing.mjs.map +1 -1
  102. package/fesm2020/theseam-ui-common-tiled-select.mjs.map +1 -1
  103. package/framework/schema-form/index.d.ts +1 -0
  104. package/framework/schema-form/schema-form-framework.d.ts +12 -1
  105. package/framework/schema-form/schema-form-widget.d.ts +61 -0
  106. package/framework/schema-form/schema-form.module.d.ts +1 -2
  107. package/framework/schema-form-controls/schema-form-checkbox/schema-form-checkbox.component.d.ts +12 -11
  108. package/framework/schema-form-controls/schema-form-divider/schema-form-divider.component.d.ts +12 -0
  109. package/framework/schema-form-controls/schema-form-input/schema-form-input.component.d.ts +10 -9
  110. package/framework/schema-form-controls/schema-form-number/schema-form-number.component.d.ts +8 -7
  111. package/framework/schema-form-controls/schema-form-select/schema-form-select.component.d.ts +10 -9
  112. package/framework/schema-form-controls/schema-form-submit/schema-form-submit.component.d.ts +10 -9
  113. package/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.d.ts +10 -9
  114. package/framework/schema-form-controls/schema-form-tel/schema-form-tel.component.d.ts +23 -0
  115. package/framework/schema-form-controls/schema-form-tiled-select/schema-form-tiled-select.component.d.ts +32 -0
  116. package/google-maps/google-maps/google-maps.component.d.ts +2 -1
  117. package/google-maps/google-maps-api-loader/lazy-google-maps-api-loader.d.ts +1 -0
  118. package/menu/menu-footer-action/menu-footer-action.component.d.ts +1 -1
  119. package/menu/public-api.d.ts +4 -0
  120. package/menu/testing/menu-footer.harness.d.ts +22 -0
  121. package/menu/testing/menu-header.harness.d.ts +18 -0
  122. package/menu/testing/menu-item.harness.d.ts +37 -0
  123. package/menu/testing/menu.harness.d.ts +74 -0
  124. package/menu/testing/utils.d.ts +5 -0
  125. package/package.json +1 -1
  126. package/story-helpers/args-to-tpl.d.ts +25 -0
  127. package/story-helpers/public-api.d.ts +1 -0
  128. package/tel-input/public-api.d.ts +1 -0
  129. package/tel-input/tel-input/tel-input.component.d.ts +2 -2
  130. package/tel-input/tel-input.directive.d.ts +1 -1
  131. package/tel-input/tel-input.module.d.ts +7 -7
  132. package/tel-input/testing/tel-input.harness.d.ts +19 -0
  133. package/testing/harnesses/ng-select-dropdown.harness.d.ts +23 -0
  134. package/testing/harnesses/ng-select-option.harness.d.ts +18 -0
  135. package/testing/harnesses/ng-select.harness.d.ts +50 -0
  136. package/testing/public-api.d.ts +3 -0
  137. package/tiled-select/components/tiled-select/tiled-select.component.d.ts +10 -10
  138. package/esm2020/framework/schema-form-controls/schema-form-controls.module.mjs +0 -79
  139. package/framework/schema-form-controls/schema-form-controls.module.d.ts +0 -20
@@ -0,0 +1,83 @@
1
+ import { useStoryContext } from '@storybook/preview-api';
2
+ /**
3
+ * This is an attempt at simplifying the use of auto-generated args in stories
4
+ * defined with `template`, since Angular doesn't have a way to simply use a
5
+ * spread operator syntax.
6
+ *
7
+ * @experimental
8
+ */
9
+ // export function argsToTplParts(args: any, argTypes: ArgTypes): ArgsTplParts {
10
+ // // console.log({ args, argTypes })
11
+ // const parts: ArgsTplParts = {
12
+ // actions: {},
13
+ // tplfragment: ''
14
+ // }
15
+ // Object.keys(argTypes).forEach(k => {
16
+ // // Inputs
17
+ // if (
18
+ // // Is in the inputs category
19
+ // argTypes[k].table.category === 'inputs' &&
20
+ // // Needs a control to be able to change from auto-generated args.
21
+ // argTypes[k]?.hasOwnProperty('control') &&
22
+ // // Assuming the arg might not be in props if there isn't an arg value.
23
+ // args.hasOwnProperty(k)
24
+ // ) {
25
+ // parts.tplfragment += `[${k}]="${k}" `
26
+ // }
27
+ // // Outputs
28
+ // if (
29
+ // // Is in the outputs category
30
+ // argTypes[k]?.table?.category === 'outputs'
31
+ // ) {
32
+ // // Without access to props, I don't know if I can get an action into the
33
+ // // template context like this.
34
+ // parts.tplfragment += `(${k})="${k}($event)" `
35
+ // parts.actions[k] = action(k)
36
+ // }
37
+ // })
38
+ // return parts
39
+ // }
40
+ function removeDuplicates(arr) {
41
+ const seen = {};
42
+ return arr.filter(item => {
43
+ if (!seen[item]) {
44
+ seen[item] = true;
45
+ return true;
46
+ }
47
+ return false;
48
+ });
49
+ }
50
+ /**
51
+ * This is an attempt at simplifying the use of auto-generated args in stories
52
+ * defined with `template`, since Angular doesn't have a way to simply use a
53
+ * spread operator syntax.
54
+ *
55
+ * @experimental
56
+ */
57
+ export function argsToTpl(options) {
58
+ const context = useStoryContext();
59
+ const exclude = [
60
+ ...(context?.parameters?.argsToTplOptions?.exclude || []),
61
+ ...(options?.exclude || []),
62
+ ];
63
+ const alwaysBind = context?.parameters?.argsToTplOptions?.alwaysBind || [];
64
+ const props = removeDuplicates([
65
+ ...alwaysBind,
66
+ ...Object.keys(context.args),
67
+ ]);
68
+ const parts = props
69
+ .filter(k => exclude.indexOf(k) === -1)
70
+ .map(k => {
71
+ // Outputs
72
+ if (context.argTypes[k]?.hasOwnProperty('action') &&
73
+ (context.args.hasOwnProperty(k) || alwaysBind.indexOf(k) !== -1)) {
74
+ return `(${k})="${k}($event)"`;
75
+ }
76
+ // Inputs
77
+ if ((context.args.hasOwnProperty(k) || alwaysBind.indexOf(k) !== -1)) {
78
+ return `[${k}]="${k}"`;
79
+ }
80
+ });
81
+ return parts.length > 0 ? parts.join(' ') : '';
82
+ }
83
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJncy10by10cGwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vc3RvcnktaGVscGVycy9hcmdzLXRvLXRwbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFPeEQ7Ozs7OztHQU1HO0FBQ0gsZ0ZBQWdGO0FBQ2hGLHVDQUF1QztBQUN2QyxrQ0FBa0M7QUFDbEMsbUJBQW1CO0FBQ25CLHNCQUFzQjtBQUN0QixNQUFNO0FBRU4seUNBQXlDO0FBQ3pDLGdCQUFnQjtBQUNoQixXQUFXO0FBQ1gscUNBQXFDO0FBQ3JDLG1EQUFtRDtBQUNuRCwwRUFBMEU7QUFDMUUsa0RBQWtEO0FBQ2xELCtFQUErRTtBQUMvRSwrQkFBK0I7QUFDL0IsVUFBVTtBQUNWLDhDQUE4QztBQUM5QyxRQUFRO0FBRVIsaUJBQWlCO0FBQ2pCLFdBQVc7QUFDWCxzQ0FBc0M7QUFDdEMsbURBQW1EO0FBQ25ELFVBQVU7QUFDVixpRkFBaUY7QUFDakYsdUNBQXVDO0FBQ3ZDLHNEQUFzRDtBQUN0RCxxQ0FBcUM7QUFDckMsUUFBUTtBQUNSLE9BQU87QUFFUCxpQkFBaUI7QUFDakIsSUFBSTtBQUVKLFNBQVMsZ0JBQWdCLENBQUMsR0FBYTtJQUNyQyxNQUFNLElBQUksR0FBNkIsRUFBRSxDQUFBO0lBQ3pDLE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUN2QixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ2YsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQTtZQUNqQixPQUFPLElBQUksQ0FBQTtTQUNaO1FBQ0QsT0FBTyxLQUFLLENBQUE7SUFDZCxDQUFDLENBQUMsQ0FBQTtBQUNKLENBQUM7QUFhRDs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsU0FBUyxDQUFDLE9BQXdCO0lBQ2hELE1BQU0sT0FBTyxHQUFHLGVBQWUsRUFBbUIsQ0FBQTtJQUVsRCxNQUFNLE9BQU8sR0FBRztRQUNkLEdBQUcsQ0FBQyxPQUFPLEVBQUUsVUFBVSxFQUFFLGdCQUFnQixFQUFFLE9BQU8sSUFBSSxFQUFFLENBQUM7UUFDekQsR0FBRyxDQUFDLE9BQU8sRUFBRSxPQUFPLElBQUksRUFBRSxDQUFDO0tBQzVCLENBQUE7SUFFRCxNQUFNLFVBQVUsR0FBRyxPQUFPLEVBQUUsVUFBVSxFQUFFLGdCQUFnQixFQUFFLFVBQVUsSUFBSSxFQUFFLENBQUE7SUFFMUUsTUFBTSxLQUFLLEdBQUcsZ0JBQWdCLENBQUM7UUFDN0IsR0FBRyxVQUFVO1FBQ2IsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7S0FDN0IsQ0FBQyxDQUFBO0lBRUYsTUFBTSxLQUFLLEdBQUcsS0FBSztTQUNoQixNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1NBQ3RDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRTtRQUNQLFVBQVU7UUFDVixJQUNFLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsY0FBYyxDQUFDLFFBQVEsQ0FBQztZQUM3QyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxJQUFJLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFDaEU7WUFDQSxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFBO1NBQy9CO1FBRUQsU0FBUztRQUNULElBQ0UsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsSUFBSSxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQ2hFO1lBQ0EsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQTtTQUN2QjtJQUNILENBQUMsQ0FBQyxDQUFBO0lBRUosT0FBTyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFBO0FBQ2hELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1wcm90b3R5cGUtYnVpbHRpbnMgKi9cbmltcG9ydCB7IGFjdGlvbiwgSGFuZGxlckZ1bmN0aW9uIH0gZnJvbSAnQHN0b3J5Ym9vay9hZGRvbi1hY3Rpb25zJ1xuaW1wb3J0IHsgQW5ndWxhclJlbmRlcmVyLCBBcmdUeXBlcyB9IGZyb20gJ0BzdG9yeWJvb2svYW5ndWxhcidcbmltcG9ydCB7IHVzZVN0b3J5Q29udGV4dCB9IGZyb20gJ0BzdG9yeWJvb2svcHJldmlldy1hcGknXG5cbmV4cG9ydCBpbnRlcmZhY2UgQXJnc1RwbFBhcnRzIHtcbiAgYWN0aW9uczogeyBbcHJvcDogc3RyaW5nXTogSGFuZGxlckZ1bmN0aW9uIH1cbiAgdHBsZnJhZ21lbnQ6IHN0cmluZ1xufVxuXG4vKipcbiAqIFRoaXMgaXMgYW4gYXR0ZW1wdCBhdCBzaW1wbGlmeWluZyB0aGUgdXNlIG9mIGF1dG8tZ2VuZXJhdGVkIGFyZ3MgaW4gc3Rvcmllc1xuICogZGVmaW5lZCB3aXRoIGB0ZW1wbGF0ZWAsIHNpbmNlIEFuZ3VsYXIgZG9lc24ndCBoYXZlIGEgd2F5IHRvIHNpbXBseSB1c2UgYVxuICogc3ByZWFkIG9wZXJhdG9yIHN5bnRheC5cbiAqXG4gKiBAZXhwZXJpbWVudGFsXG4gKi9cbi8vIGV4cG9ydCBmdW5jdGlvbiBhcmdzVG9UcGxQYXJ0cyhhcmdzOiBhbnksIGFyZ1R5cGVzOiBBcmdUeXBlcyk6IEFyZ3NUcGxQYXJ0cyB7XG4vLyAgIC8vIGNvbnNvbGUubG9nKHsgYXJncywgYXJnVHlwZXMgfSlcbi8vICAgY29uc3QgcGFydHM6IEFyZ3NUcGxQYXJ0cyA9IHtcbi8vICAgICBhY3Rpb25zOiB7fSxcbi8vICAgICB0cGxmcmFnbWVudDogJydcbi8vICAgfVxuXG4vLyAgIE9iamVjdC5rZXlzKGFyZ1R5cGVzKS5mb3JFYWNoKGsgPT4ge1xuLy8gICAgIC8vIElucHV0c1xuLy8gICAgIGlmIChcbi8vICAgICAgIC8vIElzIGluIHRoZSBpbnB1dHMgY2F0ZWdvcnlcbi8vICAgICAgIGFyZ1R5cGVzW2tdLnRhYmxlLmNhdGVnb3J5ID09PSAnaW5wdXRzJyAmJlxuLy8gICAgICAgLy8gTmVlZHMgYSBjb250cm9sIHRvIGJlIGFibGUgdG8gY2hhbmdlIGZyb20gYXV0by1nZW5lcmF0ZWQgYXJncy5cbi8vICAgICAgIGFyZ1R5cGVzW2tdPy5oYXNPd25Qcm9wZXJ0eSgnY29udHJvbCcpICYmXG4vLyAgICAgICAvLyBBc3N1bWluZyB0aGUgYXJnIG1pZ2h0IG5vdCBiZSBpbiBwcm9wcyBpZiB0aGVyZSBpc24ndCBhbiBhcmcgdmFsdWUuXG4vLyAgICAgICBhcmdzLmhhc093blByb3BlcnR5KGspXG4vLyAgICAgKSB7XG4vLyAgICAgICBwYXJ0cy50cGxmcmFnbWVudCArPSBgWyR7a31dPVwiJHtrfVwiIGBcbi8vICAgICB9XG5cbi8vICAgICAvLyBPdXRwdXRzXG4vLyAgICAgaWYgKFxuLy8gICAgICAgLy8gSXMgaW4gdGhlIG91dHB1dHMgY2F0ZWdvcnlcbi8vICAgICAgIGFyZ1R5cGVzW2tdPy50YWJsZT8uY2F0ZWdvcnkgPT09ICdvdXRwdXRzJ1xuLy8gICAgICkge1xuLy8gICAgICAgLy8gV2l0aG91dCBhY2Nlc3MgdG8gcHJvcHMsIEkgZG9uJ3Qga25vdyBpZiBJIGNhbiBnZXQgYW4gYWN0aW9uIGludG8gdGhlXG4vLyAgICAgICAvLyB0ZW1wbGF0ZSBjb250ZXh0IGxpa2UgdGhpcy5cbi8vICAgICAgIHBhcnRzLnRwbGZyYWdtZW50ICs9IGAoJHtrfSk9XCIke2t9KCRldmVudClcIiBgXG4vLyAgICAgICBwYXJ0cy5hY3Rpb25zW2tdID0gYWN0aW9uKGspXG4vLyAgICAgfVxuLy8gICB9KVxuXG4vLyAgIHJldHVybiBwYXJ0c1xuLy8gfVxuXG5mdW5jdGlvbiByZW1vdmVEdXBsaWNhdGVzKGFycjogc3RyaW5nW10pIHtcbiAgY29uc3Qgc2VlbjogeyBbazogc3RyaW5nXTogYm9vbGVhbiB9ID0ge31cbiAgcmV0dXJuIGFyci5maWx0ZXIoaXRlbSA9PiB7XG4gICAgaWYgKCFzZWVuW2l0ZW1dKSB7XG4gICAgICBzZWVuW2l0ZW1dID0gdHJ1ZVxuICAgICAgcmV0dXJuIHRydWVcbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlXG4gIH0pXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXJnc1RwbE9wdGlvbnMge1xuICAvKipcbiAgICogUHJvcGVydGllcyB0byBhbHdheXMgYmluZCB0byB0aGUgdGVtcGxhdGUuXG4gICAqL1xuICBhbHdheXNCaW5kPzogc3RyaW5nW11cbiAgLyoqXG4gICAqIFByb3BlcnRpZXMgdG8gZXhjbHVkZSBmcm9tIGJpZG5pbmcgdG8gdGhlIHRlbXBsYXRlLlxuICAgKi9cbiAgZXhjbHVkZT86IHN0cmluZ1tdXG59XG5cbi8qKlxuICogVGhpcyBpcyBhbiBhdHRlbXB0IGF0IHNpbXBsaWZ5aW5nIHRoZSB1c2Ugb2YgYXV0by1nZW5lcmF0ZWQgYXJncyBpbiBzdG9yaWVzXG4gKiBkZWZpbmVkIHdpdGggYHRlbXBsYXRlYCwgc2luY2UgQW5ndWxhciBkb2Vzbid0IGhhdmUgYSB3YXkgdG8gc2ltcGx5IHVzZSBhXG4gKiBzcHJlYWQgb3BlcmF0b3Igc3ludGF4LlxuICpcbiAqIEBleHBlcmltZW50YWxcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGFyZ3NUb1RwbChvcHRpb25zPzogQXJnc1RwbE9wdGlvbnMpIHtcbiAgY29uc3QgY29udGV4dCA9IHVzZVN0b3J5Q29udGV4dDxBbmd1bGFyUmVuZGVyZXI+KClcblxuICBjb25zdCBleGNsdWRlID0gW1xuICAgIC4uLihjb250ZXh0Py5wYXJhbWV0ZXJzPy5hcmdzVG9UcGxPcHRpb25zPy5leGNsdWRlIHx8IFtdKSxcbiAgICAuLi4ob3B0aW9ucz8uZXhjbHVkZSB8fCBbXSksXG4gIF1cblxuICBjb25zdCBhbHdheXNCaW5kID0gY29udGV4dD8ucGFyYW1ldGVycz8uYXJnc1RvVHBsT3B0aW9ucz8uYWx3YXlzQmluZCB8fCBbXVxuXG4gIGNvbnN0IHByb3BzID0gcmVtb3ZlRHVwbGljYXRlcyhbXG4gICAgLi4uYWx3YXlzQmluZCxcbiAgICAuLi5PYmplY3Qua2V5cyhjb250ZXh0LmFyZ3MpLFxuICBdKVxuXG4gIGNvbnN0IHBhcnRzID0gcHJvcHNcbiAgICAuZmlsdGVyKGsgPT4gZXhjbHVkZS5pbmRleE9mKGspID09PSAtMSlcbiAgICAubWFwKGsgPT4ge1xuICAgICAgLy8gT3V0cHV0c1xuICAgICAgaWYgKFxuICAgICAgICBjb250ZXh0LmFyZ1R5cGVzW2tdPy5oYXNPd25Qcm9wZXJ0eSgnYWN0aW9uJykgJiZcbiAgICAgICAgKGNvbnRleHQuYXJncy5oYXNPd25Qcm9wZXJ0eShrKSB8fCBhbHdheXNCaW5kLmluZGV4T2YoaykgIT09IC0xKVxuICAgICAgKSB7XG4gICAgICAgIHJldHVybiBgKCR7a30pPVwiJHtrfSgkZXZlbnQpXCJgXG4gICAgICB9XG5cbiAgICAgIC8vIElucHV0c1xuICAgICAgaWYgKFxuICAgICAgICAoY29udGV4dC5hcmdzLmhhc093blByb3BlcnR5KGspIHx8IGFsd2F5c0JpbmQuaW5kZXhPZihrKSAhPT0gLTEpXG4gICAgICApIHtcbiAgICAgICAgcmV0dXJuIGBbJHtrfV09XCIke2t9XCJgXG4gICAgICB9XG4gICAgfSlcblxuICByZXR1cm4gcGFydHMubGVuZ3RoID4gMCA/IHBhcnRzLmpvaW4oJyAnKSA6ICcnXG59XG4iXX0=
@@ -1,5 +1,5 @@
1
1
  export * from './arg-type-helpers';
2
- // export * from './args-to-tpl'
2
+ export * from './args-to-tpl';
3
3
  export * from './story-empty.component';
4
4
  export * from './story-initial-route';
5
5
  export * from './route-button';
@@ -13,4 +13,4 @@ export * from './story-toastr.service';
13
13
  export * from './on-story-bootstrapped-exec';
14
14
  export * from './on-story-bootstrapped-trigger';
15
15
  export * from './story-preferences-accessor.service';
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9zdG9yeS1oZWxwZXJzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQTtBQUNsQyxnQ0FBZ0M7QUFDaEMsY0FBYyx5QkFBeUIsQ0FBQTtBQUN2QyxjQUFjLHVCQUF1QixDQUFBO0FBQ3JDLGNBQWMsZ0JBQWdCLENBQUE7QUFDOUIsY0FBYyxtQkFBbUIsQ0FBQTtBQUNqQyxjQUFjLGtDQUFrQyxDQUFBO0FBQ2hELGNBQWMseUJBQXlCLENBQUE7QUFDdkMsY0FBYyx5QkFBeUIsQ0FBQTtBQUN2QyxjQUFjLG9DQUFvQyxDQUFBO0FBQ2xELGNBQWMsbUNBQW1DLENBQUE7QUFDakQsY0FBYyx3QkFBd0IsQ0FBQTtBQUN0QyxjQUFjLDhCQUE4QixDQUFBO0FBQzVDLGNBQWMsaUNBQWlDLENBQUE7QUFDL0MsY0FBYyxzQ0FBc0MsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYXJnLXR5cGUtaGVscGVycydcbi8vIGV4cG9ydCAqIGZyb20gJy4vYXJncy10by10cGwnXG5leHBvcnQgKiBmcm9tICcuL3N0b3J5LWVtcHR5LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vc3RvcnktaW5pdGlhbC1yb3V0ZSdcbmV4cG9ydCAqIGZyb20gJy4vcm91dGUtYnV0dG9uJ1xuZXhwb3J0ICogZnJvbSAnLi9yb3V0ZXMtYXJnLXR5cGUnXG5leHBvcnQgKiBmcm9tICcuL3N0b3J5LWhlbHBlci1jb21wb25lbnRzLm1vZHVsZSdcbmV4cG9ydCAqIGZyb20gJy4vaW5pdGlhbC1yb3V0ZS5zZXJ2aWNlJ1xuZXhwb3J0ICogZnJvbSAnLi9pbml0aWFsLXJvdXRlLWZhY3RvcnknXG5leHBvcnQgKiBmcm9tICcuL3N0b3J5LWVtcHR5LXdpdGgtcm91dGUuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9zdG9yeS1tb2RhbC1jb250YWluZXIuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9zdG9yeS10b2FzdHIuc2VydmljZSdcbmV4cG9ydCAqIGZyb20gJy4vb24tc3RvcnktYm9vdHN0cmFwcGVkLWV4ZWMnXG5leHBvcnQgKiBmcm9tICcuL29uLXN0b3J5LWJvb3RzdHJhcHBlZC10cmlnZ2VyJ1xuZXhwb3J0ICogZnJvbSAnLi9zdG9yeS1wcmVmZXJlbmNlcy1hY2Nlc3Nvci5zZXJ2aWNlJ1xuIl19
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9zdG9yeS1oZWxwZXJzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQTtBQUNsQyxjQUFjLGVBQWUsQ0FBQTtBQUM3QixjQUFjLHlCQUF5QixDQUFBO0FBQ3ZDLGNBQWMsdUJBQXVCLENBQUE7QUFDckMsY0FBYyxnQkFBZ0IsQ0FBQTtBQUM5QixjQUFjLG1CQUFtQixDQUFBO0FBQ2pDLGNBQWMsa0NBQWtDLENBQUE7QUFDaEQsY0FBYyx5QkFBeUIsQ0FBQTtBQUN2QyxjQUFjLHlCQUF5QixDQUFBO0FBQ3ZDLGNBQWMsb0NBQW9DLENBQUE7QUFDbEQsY0FBYyxtQ0FBbUMsQ0FBQTtBQUNqRCxjQUFjLHdCQUF3QixDQUFBO0FBQ3RDLGNBQWMsOEJBQThCLENBQUE7QUFDNUMsY0FBYyxpQ0FBaUMsQ0FBQTtBQUMvQyxjQUFjLHNDQUFzQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hcmctdHlwZS1oZWxwZXJzJ1xuZXhwb3J0ICogZnJvbSAnLi9hcmdzLXRvLXRwbCdcbmV4cG9ydCAqIGZyb20gJy4vc3RvcnktZW1wdHkuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9zdG9yeS1pbml0aWFsLXJvdXRlJ1xuZXhwb3J0ICogZnJvbSAnLi9yb3V0ZS1idXR0b24nXG5leHBvcnQgKiBmcm9tICcuL3JvdXRlcy1hcmctdHlwZSdcbmV4cG9ydCAqIGZyb20gJy4vc3RvcnktaGVscGVyLWNvbXBvbmVudHMubW9kdWxlJ1xuZXhwb3J0ICogZnJvbSAnLi9pbml0aWFsLXJvdXRlLnNlcnZpY2UnXG5leHBvcnQgKiBmcm9tICcuL2luaXRpYWwtcm91dGUtZmFjdG9yeSdcbmV4cG9ydCAqIGZyb20gJy4vc3RvcnktZW1wdHktd2l0aC1yb3V0ZS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3N0b3J5LW1vZGFsLWNvbnRhaW5lci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3N0b3J5LXRvYXN0ci5zZXJ2aWNlJ1xuZXhwb3J0ICogZnJvbSAnLi9vbi1zdG9yeS1ib290c3RyYXBwZWQtZXhlYydcbmV4cG9ydCAqIGZyb20gJy4vb24tc3RvcnktYm9vdHN0cmFwcGVkLXRyaWdnZXInXG5leHBvcnQgKiBmcm9tICcuL3N0b3J5LXByZWZlcmVuY2VzLWFjY2Vzc29yLnNlcnZpY2UnXG4iXX0=
@@ -7,4 +7,5 @@ export * from './tel-input.directive';
7
7
  export * from './tel-input-validator';
8
8
  export * from './tel-input.module';
9
9
  export * from './phone-number.pipe';
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90ZWwtaW5wdXQvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFBO0FBQy9DLGNBQWMsVUFBVSxDQUFBO0FBQ3hCLGNBQWMsU0FBUyxDQUFBO0FBQ3ZCLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyx1QkFBdUIsQ0FBQTtBQUNyQyxjQUFjLHVCQUF1QixDQUFBO0FBQ3JDLGNBQWMsdUJBQXVCLENBQUE7QUFDckMsY0FBYyxvQkFBb0IsQ0FBQTtBQUNsQyxjQUFjLHFCQUFxQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90ZWwtaW5wdXQvdGVsLWlucHV0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWxzJ1xuZXhwb3J0ICogZnJvbSAnLi91dGlscydcbmV4cG9ydCAqIGZyb20gJy4vaW50bC10ZWwtaW5wdXQnXG5leHBvcnQgKiBmcm9tICcuL3RlbC1pbnB1dC1jb25zdGFudHMnXG5leHBvcnQgKiBmcm9tICcuL3RlbC1pbnB1dC5kaXJlY3RpdmUnXG5leHBvcnQgKiBmcm9tICcuL3RlbC1pbnB1dC12YWxpZGF0b3InXG5leHBvcnQgKiBmcm9tICcuL3RlbC1pbnB1dC5tb2R1bGUnXG5leHBvcnQgKiBmcm9tICcuL3Bob25lLW51bWJlci5waXBlJ1xuIl19
10
+ export * from './testing/tel-input.harness';
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90ZWwtaW5wdXQvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFBO0FBQy9DLGNBQWMsVUFBVSxDQUFBO0FBQ3hCLGNBQWMsU0FBUyxDQUFBO0FBQ3ZCLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyx1QkFBdUIsQ0FBQTtBQUNyQyxjQUFjLHVCQUF1QixDQUFBO0FBQ3JDLGNBQWMsdUJBQXVCLENBQUE7QUFDckMsY0FBYyxvQkFBb0IsQ0FBQTtBQUNsQyxjQUFjLHFCQUFxQixDQUFBO0FBRW5DLGNBQWMsNkJBQTZCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3RlbC1pbnB1dC90ZWwtaW5wdXQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbHMnXG5leHBvcnQgKiBmcm9tICcuL3V0aWxzJ1xuZXhwb3J0ICogZnJvbSAnLi9pbnRsLXRlbC1pbnB1dCdcbmV4cG9ydCAqIGZyb20gJy4vdGVsLWlucHV0LWNvbnN0YW50cydcbmV4cG9ydCAqIGZyb20gJy4vdGVsLWlucHV0LmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vdGVsLWlucHV0LXZhbGlkYXRvcidcbmV4cG9ydCAqIGZyb20gJy4vdGVsLWlucHV0Lm1vZHVsZSdcbmV4cG9ydCAqIGZyb20gJy4vcGhvbmUtbnVtYmVyLnBpcGUnXG5cbmV4cG9ydCAqIGZyb20gJy4vdGVzdGluZy90ZWwtaW5wdXQuaGFybmVzcydcbiJdfQ==
@@ -1,18 +1,18 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
3
3
  import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, HostBinding, HostListener, InjectFlags, Input, Output, ViewChild } from '@angular/core';
4
- import { UntypedFormControl, NgControl, NG_VALUE_ACCESSOR } from '@angular/forms';
4
+ import { UntypedFormControl, NgControl, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
5
5
  import { defer, fromEvent, merge, of, Subject } from 'rxjs';
6
6
  import { auditTime, map, switchMap, takeUntil } from 'rxjs/operators';
7
7
  import { InputBoolean } from '@theseam/ui-common/core';
8
- import { InputDirective } from '@theseam/ui-common/form-field';
8
+ import { InputDirective, TheSeamFormFieldModule } from '@theseam/ui-common/form-field';
9
9
  import { TheSeamTelInputDirective } from '../tel-input.directive';
10
+ import { CommonModule } from '@angular/common';
10
11
  import * as i0 from "@angular/core";
11
12
  import * as i1 from "@angular/cdk/a11y";
12
- import * as i2 from "@angular/forms";
13
- import * as i3 from "@theseam/ui-common/form-field";
14
- import * as i4 from "../tel-input.directive";
15
- import * as i5 from "@angular/common";
13
+ import * as i2 from "@angular/common";
14
+ import * as i3 from "@angular/forms";
15
+ import * as i4 from "@theseam/ui-common/form-field";
16
16
  // TODO: Fix focus
17
17
  // TODO: Fix disabled
18
18
  export class TheSeamTelInputComponent {
@@ -88,11 +88,14 @@ export class TheSeamTelInputComponent {
88
88
  this._focusMonitor.monitor(this._elementRef, true).pipe(takeUntil(this._ngUnsubscribe)).subscribe(origin => this._focusOrigin = origin);
89
89
  this._control.valueChanges.pipe(takeUntil(this._ngUnsubscribe)).subscribe(v => {
90
90
  const value = this._telInputDirective?.getFullNumber();
91
+ // console.log('valueChanges', v, value)
91
92
  this.value = value;
92
93
  if (this._controlValueAccessorChangeFn) {
93
94
  this._controlValueAccessorChangeFn(value);
95
+ this.change.emit(value);
94
96
  }
95
97
  });
98
+ this._control.setValue(this.value ?? '');
96
99
  }
97
100
  /** @ignore */
98
101
  ngOnDestroy() {
@@ -103,7 +106,11 @@ export class TheSeamTelInputComponent {
103
106
  // Implemented as part of ControlValueAccessor.
104
107
  /** @ignore */
105
108
  writeValue(value) {
109
+ // console.log('writeValue', value, this._telInputDirective?.getFullNumber(), this._control.value)
106
110
  this.value = value;
111
+ if (this._control.value !== value) {
112
+ this._control.setValue(value);
113
+ }
107
114
  if (this._telInputDirective) {
108
115
  this._telInputDirective.value = value;
109
116
  this._telInputDirective.updateValue();
@@ -137,11 +144,11 @@ export class TheSeamTelInputComponent {
137
144
  }
138
145
  }
139
146
  TheSeamTelInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamTelInputComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Injector }, { token: i0.ElementRef }, { token: i1.FocusMonitor }], target: i0.ɵɵFactoryTarget.Component });
140
- TheSeamTelInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: TheSeamTelInputComponent, selector: "seam-tel-input", inputs: { required: "required", disabled: "disabled", tabIndex: "tabIndex", name: "name", value: "value" }, outputs: { change: "change" }, host: { listeners: { "focus": "_onFocus($event)" }, properties: { "attr.disabled": "this._attrDisabled", "attr.tabindex": "this._attrTabIndex" } }, providers: [{
147
+ TheSeamTelInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: TheSeamTelInputComponent, isStandalone: true, selector: "seam-tel-input", inputs: { required: "required", disabled: "disabled", tabIndex: "tabIndex", name: "name", value: "value" }, outputs: { change: "change" }, host: { listeners: { "focus": "_onFocus($event)" }, properties: { "attr.disabled": "this._attrDisabled", "attr.tabindex": "this._attrTabIndex" } }, providers: [{
141
148
  provide: NG_VALUE_ACCESSOR,
142
149
  useExisting: forwardRef(() => TheSeamTelInputComponent),
143
150
  multi: true
144
- }], viewQueries: [{ propertyName: "_telInputDirective", first: true, predicate: TheSeamTelInputDirective, descendants: true, static: true }, { propertyName: "_inputDirective", first: true, predicate: InputDirective, descendants: true, static: true }, { propertyName: "_inputElementRef", first: true, predicate: ["input"], descendants: true, static: true }], ngImport: i0, template: "<input seamTelInput seamInput\n [formControl]=\"_control\"\n [class.is-invalid]=\"_hasInvalidCss$ | async\" />\n", styles: [":host{display:block}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover{cursor:default}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover .iti__selected-flag{background-color:transparent}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__arrow{display:none}\n"], dependencies: [{ kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { 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: "directive", type: i3.InputDirective, selector: "input[seamInput], textarea[seamInput], ng-select[seamInput], seam-checkbox[seamInput] [ngbRadioGroup], seam-tel-input[seamInput], quill-editor[seamInput], seam-google-maps[seamInput]", inputs: ["seamInputSize", "id", "type", "placeholder", "required", "disabled", "readonly"], exportAs: ["seamInput"] }, { kind: "directive", type: i4.TheSeamTelInputDirective, selector: "input[seamTelInput]", inputs: ["value"], exportAs: ["seamTelInput"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
151
+ }], viewQueries: [{ propertyName: "_telInputDirective", first: true, predicate: TheSeamTelInputDirective, descendants: true, static: true }, { propertyName: "_inputDirective", first: true, predicate: InputDirective, descendants: true, static: true }, { propertyName: "_inputElementRef", first: true, predicate: ["input"], descendants: true, static: true }], ngImport: i0, template: "<input seamTelInput seamInput\n [formControl]=\"_control\"\n [class.is-invalid]=\"_hasInvalidCss$ | async\"\n [required]=\"required\"/>\n", styles: [":host{display:block}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover{cursor:default}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover .iti__selected-flag{background-color:transparent}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__arrow{display:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: TheSeamFormFieldModule }, { kind: "directive", type: i4.InputDirective, selector: "input[seamInput], textarea[seamInput], ng-select[seamInput], seam-checkbox[seamInput] [ngbRadioGroup], seam-tel-input[seamInput], quill-editor[seamInput], seam-google-maps[seamInput]", inputs: ["seamInputSize", "id", "type", "placeholder", "required", "disabled", "readonly"], exportAs: ["seamInput"] }, { kind: "directive", type: TheSeamTelInputDirective, selector: "input[seamTelInput]", inputs: ["value"], exportAs: ["seamTelInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
145
152
  __decorate([
146
153
  InputBoolean()
147
154
  ], TheSeamTelInputComponent.prototype, "required", void 0);
@@ -151,7 +158,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
151
158
  provide: NG_VALUE_ACCESSOR,
152
159
  useExisting: forwardRef(() => TheSeamTelInputComponent),
153
160
  multi: true
154
- }], changeDetection: ChangeDetectionStrategy.OnPush, template: "<input seamTelInput seamInput\n [formControl]=\"_control\"\n [class.is-invalid]=\"_hasInvalidCss$ | async\" />\n", styles: [":host{display:block}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover{cursor:default}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover .iti__selected-flag{background-color:transparent}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__arrow{display:none}\n"] }]
161
+ }], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
162
+ CommonModule,
163
+ ReactiveFormsModule,
164
+ TheSeamFormFieldModule,
165
+ TheSeamTelInputDirective,
166
+ ], template: "<input seamTelInput seamInput\n [formControl]=\"_control\"\n [class.is-invalid]=\"_hasInvalidCss$ | async\"\n [required]=\"required\"/>\n", styles: [":host{display:block}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover{cursor:default}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover .iti__selected-flag{background-color:transparent}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__arrow{display:none}\n"] }]
155
167
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i0.ElementRef }, { type: i1.FocusMonitor }]; }, propDecorators: { required: [{
156
168
  type: Input
157
169
  }], disabled: [{
@@ -183,4 +195,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
183
195
  type: HostListener,
184
196
  args: ['focus', ['$event']]
185
197
  }] } });
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tel-input.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/tel-input/tel-input/tel-input.component.ts","../../../../../projects/ui-common/tel-input/tel-input/tel-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y'\nimport { BooleanInput, coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  InjectFlags,\n  Injector,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core'\nimport { ControlValueAccessor, UntypedFormControl, NgControl, NG_VALUE_ACCESSOR } from '@angular/forms'\nimport { defer, fromEvent, merge, Observable, of, Subject } from 'rxjs'\nimport { auditTime, map, switchMap, takeUntil } from 'rxjs/operators'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { InputDirective } from '@theseam/ui-common/form-field'\n\nimport { TheSeamTelInputDirective } from '../tel-input.directive'\n\n// TODO: Fix focus\n// TODO: Fix disabled\n\n@Component({\n  selector: 'seam-tel-input',\n  templateUrl: './tel-input.component.html',\n  styleUrls: ['./tel-input.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => TheSeamTelInputComponent),\n    multi: true\n  }],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TheSeamTelInputComponent implements OnInit, OnDestroy, ControlValueAccessor {\n  static ngAcceptInputType_required: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n\n  /** @ignore */\n  private readonly _ngUnsubscribe = new Subject<void>()\n\n  /** @ignore */\n  readonly _control = new UntypedFormControl()\n\n  private _focusOrigin: FocusOrigin = null\n\n  _hasInvalidCss$: Observable<boolean>\n\n  @Input() @InputBoolean() required = false\n\n  @Input()\n  get disabled(): boolean { return this._disabled }\n  set disabled(value: boolean) {\n    const newValue = coerceBooleanProperty(value)\n\n    if (this._control.disabled !== newValue) {\n      if (newValue) {\n        this._control.disable()\n      } else {\n        this._control.enable()\n      }\n    }\n\n    if (newValue !== this.disabled) {\n      this._disabled = newValue\n      this._changeDetectorRef.markForCheck()\n    }\n  }\n  /** @ignore */\n  private _disabled = false\n\n  /**\n   * Set the tab index to `-1` to allow the root element of the\n   * component to receive `focus` event from javascript, but not get focused by\n   * keyboard navigation.\n   */\n  @Input()\n  set tabIndex(value: number) { this._tabIndex = coerceNumberProperty(value) }\n  get tabIndex(): number { return this._tabIndex }\n  private _tabIndex = -1\n\n  @HostBinding('attr.disabled')\n  get _attrDisabled() { return this.disabled || null }\n\n  @HostBinding('attr.tabindex')\n  get _attrTabIndex() { return this.disabled ? -1 : (this.tabIndex || 0) }\n\n  /** Name value will be applied to the input element if present */\n  @Input() name: string | undefined | null = null\n\n  /** The value attribute of the native input element */\n  @Input() value: string | undefined | null\n\n  /** Event emitted when the \"tel\" input value changes. */\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() readonly change = new EventEmitter<string>()\n\n  /**\n   * The telInput directive\n   * @ignore\n   */\n  @ViewChild(TheSeamTelInputDirective, { static: true }) _telInputDirective?: TheSeamTelInputDirective\n\n  /**\n   * The telInput directive\n   * @ignore\n   */\n  @ViewChild(InputDirective, { static: true }) _inputDirective?: InputDirective\n\n  /**\n   * The native `<input type=\"tel\">` element\n   * @ignore\n   */\n  @ViewChild('input', { static: true }) _inputElementRef?: ElementRef<HTMLInputElement>\n\n  @HostListener('focus', [ '$event' ])\n  _onFocus() {\n    this._telInputDirective?.focus()\n  }\n\n  /**\n   * Called when the checkbox is blurred. Needed to properly implement ControlValueAccessor.\n   * @ignore\n   */\n  _onTouched: () => any = () => {}\n\n  /** @ignore */\n  private _controlValueAccessorChangeFn: (value: any) => void = () => {}\n\n  constructor(\n    private readonly _changeDetectorRef: ChangeDetectorRef,\n    private readonly _injector: Injector,\n    private readonly _elementRef: ElementRef,\n    private readonly _focusMonitor: FocusMonitor\n  ) {\n    const telInputBlurEvent$ = this._telInputDirective\n      ? fromEvent(this._telInputDirective.getHostElement(), 'blur')\n      : of<Event>()\n\n    this._hasInvalidCss$ = defer(() => of((this._injector.get(NgControl, null, InjectFlags.Self)?.control) || undefined)).pipe(\n      switchMap(control => {\n        if (control) {\n          return merge(\n            control.valueChanges,\n            control.statusChanges,\n            telInputBlurEvent$\n          ).pipe(\n            auditTime(0),\n            map(() => {\n              const inputControl = this._inputDirective?.ngControl\n              return control.invalid && (inputControl?.dirty as boolean || inputControl?.touched as boolean)\n            })\n          )\n        }\n        return of(false)\n      })\n    )\n  }\n\n  /** @ignore */\n  ngOnInit(): void {\n    this._focusMonitor.monitor(this._elementRef, true).pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(origin => this._focusOrigin = origin)\n\n    this._control.valueChanges.pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(v => {\n      const value = this._telInputDirective?.getFullNumber()\n      this.value = value\n      if (this._controlValueAccessorChangeFn) {\n        this._controlValueAccessorChangeFn(value)\n      }\n    })\n  }\n\n  /** @ignore */\n  ngOnDestroy(): void {\n    this._focusMonitor.stopMonitoring(this._elementRef)\n\n    this._ngUnsubscribe.next(undefined)\n    this._ngUnsubscribe.complete()\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  writeValue(value: any) {\n    this.value = value\n    if (this._telInputDirective) {\n      this._telInputDirective.value = value\n      this._telInputDirective.updateValue()\n    }\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  registerOnChange(fn: (value: any) => void) {\n    this._controlValueAccessorChangeFn = fn\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  registerOnTouched(fn: any) {\n    this._onTouched = fn\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled\n  }\n\n  /** Focuses the input. */\n  public focus(): void {\n    this._telInputDirective?.focus()\n  }\n\n  /** Unfocuses the input. */\n  public blur(): void {\n    this._telInputDirective?.blur()\n  }\n\n  public hasFocus(): boolean {\n    return this._focusOrigin !== null && this._focusOrigin !== undefined\n  }\n\n}\n","<input seamTelInput seamInput\n  [formControl]=\"_control\"\n  [class.is-invalid]=\"_hasInvalidCss$ | async\" />\n"]}
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tel-input.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/tel-input/tel-input/tel-input.component.ts","../../../../../projects/ui-common/tel-input/tel-input/tel-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y'\nimport { BooleanInput, coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  InjectFlags,\n  Injector,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core'\nimport { ControlValueAccessor, UntypedFormControl, NgControl, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms'\nimport { defer, fromEvent, merge, Observable, of, Subject } from 'rxjs'\nimport { auditTime, map, switchMap, takeUntil } from 'rxjs/operators'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { InputDirective, TheSeamFormFieldModule } from '@theseam/ui-common/form-field'\n\nimport { TheSeamTelInputDirective } from '../tel-input.directive'\nimport { CommonModule } from '@angular/common'\n\n// TODO: Fix focus\n// TODO: Fix disabled\n\n@Component({\n  selector: 'seam-tel-input',\n  templateUrl: './tel-input.component.html',\n  styleUrls: ['./tel-input.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => TheSeamTelInputComponent),\n    multi: true\n  }],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    TheSeamFormFieldModule,\n    TheSeamTelInputDirective,\n  ],\n})\nexport class TheSeamTelInputComponent implements OnInit, OnDestroy, ControlValueAccessor {\n  static ngAcceptInputType_required: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n\n  /** @ignore */\n  private readonly _ngUnsubscribe = new Subject<void>()\n\n  /** @ignore */\n  readonly _control = new UntypedFormControl()\n\n  private _focusOrigin: FocusOrigin = null\n\n  _hasInvalidCss$: Observable<boolean>\n\n  @Input() @InputBoolean() required = false\n\n  @Input()\n  get disabled(): boolean { return this._disabled }\n  set disabled(value: boolean) {\n    const newValue = coerceBooleanProperty(value)\n\n    if (this._control.disabled !== newValue) {\n      if (newValue) {\n        this._control.disable()\n      } else {\n        this._control.enable()\n      }\n    }\n\n    if (newValue !== this.disabled) {\n      this._disabled = newValue\n      this._changeDetectorRef.markForCheck()\n    }\n  }\n  /** @ignore */\n  private _disabled = false\n\n  /**\n   * Set the tab index to `-1` to allow the root element of the\n   * component to receive `focus` event from javascript, but not get focused by\n   * keyboard navigation.\n   */\n  @Input()\n  set tabIndex(value: number) { this._tabIndex = coerceNumberProperty(value) }\n  get tabIndex(): number { return this._tabIndex }\n  private _tabIndex = -1\n\n  @HostBinding('attr.disabled')\n  get _attrDisabled() { return this.disabled || null }\n\n  @HostBinding('attr.tabindex')\n  get _attrTabIndex() { return this.disabled ? -1 : (this.tabIndex || 0) }\n\n  /** Name value will be applied to the input element if present */\n  @Input() name: string | undefined | null = null\n\n  /** The value attribute of the native input element */\n  @Input() value: string | undefined | null\n\n  /** Event emitted when the \"tel\" input value changes. */\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() readonly change = new EventEmitter<string | undefined | null>()\n\n  /**\n   * The telInput directive\n   * @ignore\n   */\n  @ViewChild(TheSeamTelInputDirective, { static: true }) _telInputDirective?: TheSeamTelInputDirective\n\n  /**\n   * The telInput directive\n   * @ignore\n   */\n  @ViewChild(InputDirective, { static: true }) _inputDirective?: InputDirective\n\n  /**\n   * The native `<input type=\"tel\">` element\n   * @ignore\n   */\n  @ViewChild('input', { static: true }) _inputElementRef?: ElementRef<HTMLInputElement>\n\n  @HostListener('focus', [ '$event' ])\n  _onFocus() {\n    this._telInputDirective?.focus()\n  }\n\n  /**\n   * Called when the checkbox is blurred. Needed to properly implement ControlValueAccessor.\n   * @ignore\n   */\n  _onTouched: () => any = () => {}\n\n  /** @ignore */\n  private _controlValueAccessorChangeFn: (value: any) => void = () => {}\n\n  constructor(\n    private readonly _changeDetectorRef: ChangeDetectorRef,\n    private readonly _injector: Injector,\n    private readonly _elementRef: ElementRef,\n    private readonly _focusMonitor: FocusMonitor\n  ) {\n    const telInputBlurEvent$ = this._telInputDirective\n      ? fromEvent(this._telInputDirective.getHostElement(), 'blur')\n      : of<Event>()\n\n    this._hasInvalidCss$ = defer(() => of((this._injector.get(NgControl, null, InjectFlags.Self)?.control) || undefined)).pipe(\n      switchMap(control => {\n        if (control) {\n          return merge(\n            control.valueChanges,\n            control.statusChanges,\n            telInputBlurEvent$\n          ).pipe(\n            auditTime(0),\n            map(() => {\n              const inputControl = this._inputDirective?.ngControl\n              return control.invalid && (inputControl?.dirty as boolean || inputControl?.touched as boolean)\n            })\n          )\n        }\n        return of(false)\n      })\n    )\n  }\n\n  /** @ignore */\n  ngOnInit(): void {\n    this._focusMonitor.monitor(this._elementRef, true).pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(origin => this._focusOrigin = origin)\n\n    this._control.valueChanges.pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(v => {\n      const value = this._telInputDirective?.getFullNumber()\n      // console.log('valueChanges', v, value)\n      this.value = value\n      if (this._controlValueAccessorChangeFn) {\n        this._controlValueAccessorChangeFn(value)\n        this.change.emit(value)\n      }\n    })\n    this._control.setValue(this.value ?? '')\n  }\n\n  /** @ignore */\n  ngOnDestroy(): void {\n    this._focusMonitor.stopMonitoring(this._elementRef)\n\n    this._ngUnsubscribe.next(undefined)\n    this._ngUnsubscribe.complete()\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  writeValue(value: any) {\n    // console.log('writeValue', value, this._telInputDirective?.getFullNumber(), this._control.value)\n    this.value = value\n    if (this._control.value !== value) {\n      this._control.setValue(value)\n    }\n    if (this._telInputDirective) {\n      this._telInputDirective.value = value\n      this._telInputDirective.updateValue()\n    }\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  registerOnChange(fn: (value: any) => void) {\n    this._controlValueAccessorChangeFn = fn\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  registerOnTouched(fn: any) {\n    this._onTouched = fn\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled\n  }\n\n  /** Focuses the input. */\n  public focus(): void {\n    this._telInputDirective?.focus()\n  }\n\n  /** Unfocuses the input. */\n  public blur(): void {\n    this._telInputDirective?.blur()\n  }\n\n  public hasFocus(): boolean {\n    return this._focusOrigin !== null && this._focusOrigin !== undefined\n  }\n\n}\n","<input seamTelInput seamInput\n  [formControl]=\"_control\"\n  [class.is-invalid]=\"_hasInvalidCss$ | async\"\n  [required]=\"required\"/>\n"]}
@@ -11,7 +11,6 @@ import * as i1 from "@theseam/ui-common/services";
11
11
  import * as i2 from "@angular/forms";
12
12
  export class TheSeamTelInputDirective {
13
13
  set value(v) {
14
- // console.log('set value', v, this._instance)
15
14
  this._value = v;
16
15
  if (this._instance) {
17
16
  this._instance.setNumber(notNullOrUndefined(v) ? v : '');
@@ -46,11 +45,9 @@ export class TheSeamTelInputDirective {
46
45
  };
47
46
  }
48
47
  ngOnInit() {
49
- merge(this._assetLoader.loadStyleSheet(TEL_INPUT_STYLESHEET_PATH), this._assetLoader.loadStyle(TEL_INPUT_STYLES)).pipe(
50
- // tap(v => console.log('loaded', v)),
51
- tap(v => this._loadedAssetRefs.push(v)), last(),
52
- // tap(v => console.log('StyleLoadingDone', v)),
53
- switchMap(() => {
48
+ this._elementRef.nativeElement.value = this._ngControl ? this._ngControl.value : this.value ?? '';
49
+ this._elementRef.nativeElement.setAttribute('instance-loading', '');
50
+ merge(this._assetLoader.loadStyleSheet(TEL_INPUT_STYLESHEET_PATH), this._assetLoader.loadStyle(TEL_INPUT_STYLES)).pipe(tap(v => this._loadedAssetRefs.push(v)), last(), switchMap(() => {
54
51
  this._instance = IntlTelInputFn(this._elementRef.nativeElement, {
55
52
  utilsScript: TEL_INPUT_UTILS_PATH,
56
53
  preferredCountries: ['US'],
@@ -63,10 +60,11 @@ export class TheSeamTelInputDirective {
63
60
  // initialCountry: 'auto'
64
61
  });
65
62
  this._tryUpdateDropdownAttributes();
66
- return this._instance.promise;
67
- }),
68
- // tap(() => console.log('%c_instance ready', 'color:green', this._instance, this._elementRef.nativeElement.value)),
69
- tap(() => this._initDropdownListener()), tap(() => this.value = this._value), tap(this._formatIntlTelInput), switchMap(() => merge(fromEvent(this._elementRef.nativeElement, 'keyup'), fromEvent(this._elementRef.nativeElement, 'change'))), tap(this._formatIntlTelInput), takeUntil(this._ngUnsubscribe)).subscribe();
63
+ return this._instance.promise.then(v => {
64
+ this._elementRef.nativeElement.removeAttribute('instance-loading');
65
+ return v;
66
+ });
67
+ }), tap(() => this._initDropdownListener()), tap(() => this.value = this._value), tap(this._formatIntlTelInput), switchMap(() => merge(fromEvent(this._elementRef.nativeElement, 'keyup'), fromEvent(this._elementRef.nativeElement, 'change'))), tap(this._formatIntlTelInput), takeUntil(this._ngUnsubscribe)).subscribe();
70
68
  }
71
69
  ngOnDestroy() {
72
70
  this._instance?.destroy();
@@ -185,12 +183,13 @@ export class TheSeamTelInputDirective {
185
183
  }
186
184
  }
187
185
  TheSeamTelInputDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamTelInputDirective, deps: [{ token: i0.ElementRef }, { token: i1.AssetLoaderService }, { token: i0.NgZone }, { token: DOCUMENT, optional: true }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Directive });
188
- TheSeamTelInputDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.7", type: TheSeamTelInputDirective, selector: "input[seamTelInput]", inputs: { value: "value" }, host: { properties: { "attr.type": "this._attrType" } }, exportAs: ["seamTelInput"], ngImport: i0 });
186
+ TheSeamTelInputDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.7", type: TheSeamTelInputDirective, isStandalone: true, selector: "input[seamTelInput]", inputs: { value: "value" }, host: { properties: { "attr.type": "this._attrType" } }, exportAs: ["seamTelInput"], ngImport: i0 });
189
187
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamTelInputDirective, decorators: [{
190
188
  type: Directive,
191
189
  args: [{
192
190
  selector: 'input[seamTelInput]',
193
- exportAs: 'seamTelInput'
191
+ exportAs: 'seamTelInput',
192
+ standalone: true,
194
193
  }]
195
194
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.AssetLoaderService }, { type: i0.NgZone }, { type: undefined, decorators: [{
196
195
  type: Optional
@@ -207,4 +206,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
207
206
  }], value: [{
208
207
  type: Input
209
208
  }] } });
210
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tel-input.directive.js","sourceRoot":"","sources":["../../../../projects/ui-common/tel-input/tel-input.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAC1C,OAAO,EAAE,SAAS,EAA6B,WAAW,EAAE,MAAM,EAAE,KAAK,EAA6B,QAAQ,EAAE,IAAI,EAAE,MAAM,eAAe,CAAA;AAC3I,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAChD,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAG3E,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAA;AAG1G,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAEpE,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAA;AACzG,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAA;;;;AAMvD,MAAM,OAAO,wBAAwB;IAQnC,IACI,KAAK,CAAC,CAA4B;QACpC,8CAA8C;QAC9C,IAAI,CAAC,MAAM,GAAG,CAAC,CAAA;QACf,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;YACxD,IAAI,CAAC,WAAW,EAAE,CAAA;SACnB;IACH,CAAC;IACD,IAAI,KAAK;QACP,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,OAAO,IAAI,CAAC,SAAS,EAAE,SAAS,EAAE,CAAA;SACnC;QACD,OAAO,IAAI,CAAC,MAAM,CAAA;IACpB,CAAC;IAGD,YACmB,WAAyC,EACzC,YAAgC,EAChC,OAAe,EACe,SAAe,EACzB,UAAsB;QAJ1C,gBAAW,GAAX,WAAW,CAA8B;QACzC,iBAAY,GAAZ,YAAY,CAAoB;QAChC,YAAO,GAAP,OAAO,CAAQ;QACe,cAAS,GAAT,SAAS,CAAM;QACzB,eAAU,GAAV,UAAU,CAAY;QA7B5C,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAA;QAG7C,qBAAgB,GAAyD,EAAE,CAAA;QAEzD,cAAS,GAAG,KAAK,CAAA;QAqGnC,wBAAmB,GAAG,GAAG,EAAE;YACjC,kDAAkD;YAClD,gGAAgG;YAChG,sFAAsF;YACtF,sDAAsD;YACtD,2CAA2C;YAC3C,6CAA6C;YAC7C,MAAM;YACN,IAAI;YAEJ,IAAI,CAAC,WAAW,EAAE,CAAA;QACpB,CAAC,CAAA;IAvFG,CAAC;IAEL,QAAQ;QACN,KAAK,CACH,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,yBAAyB,CAAC,EAC3D,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAC9C,CAAC,IAAI;QACJ,sCAAsC;QACtC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EACvC,IAAI,EAAE;QACN,gDAAgD;QAChD,SAAS,CAAC,GAAG,EAAE;YACb,IAAI,CAAC,SAAS,GAAG,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE;gBAC9D,WAAW,EAAE,oBAAoB;gBACjC,kBAAkB,EAAE,CAAE,IAAI,CAAE;gBAC5B,YAAY,EAAE,KAAK;gBACnB,eAAe,EAAE,IAAI;gBACrB,eAAe,EAAE,KAAK;gBACtB,gBAAgB,EAAE,KAAK;gBACvB,gBAAgB,EAAE,KAAK;gBACvB,oCAAoC;gBACpC,yBAAyB;aAC1B,CAAC,CAAA;YAEF,IAAI,CAAC,4BAA4B,EAAE,CAAA;YAEnC,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAA;QAC/B,CAAC,CAAC;QACF,oHAAoH;QACpH,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,EACvC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,EACnC,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC,EAC7B,SAAS,CAAC,GAAG,EAAE,CAAC,KAAK,CACnB,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,OAAO,CAAC,EAClD,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,QAAQ,CAAC,CACpD,CAAC,EACF,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC,EAC7B,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAC/B,CAAC,SAAS,EAAE,CAAA;IACf,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,CAAA;QACzB,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvC,GAAG,CAAC,OAAO,EAAE,CAAA;SACd;QAED,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QACnC,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAA;IAChC,CAAC;IAED,SAAS;QACP,IAAI,CAAC,4BAA4B,EAAE,CAAA;IACrC,CAAC;IAEO,4BAA4B;QAClC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAA;QAC/B,IAAI,OAAO,EAAE;YACX,MAAM,cAAc,GAAoC,IAAI,CAAC,SAAiB,EAAE,YAAY,CAAA;YAC5F,IAAI,cAAc,EAAE;gBAClB,eAAe,CAAC,cAAc,EAAE,eAAe,EAAE,OAAO,CAAC,QAAQ,IAAI,KAAK,CAAC,CAAA;gBAE3E,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,KAAK,CAAA;gBAC1C,IAAI,CAAC,QAAQ,EAAE;oBACb,IAAI,YAAY,CAAC,cAAc,EAAE,UAAU,CAAC,KAAK,GAAG,EAAE;wBACpD,cAAc,CAAC,YAAY,CAAC,UAAU,EAAE,GAAG,CAAC,CAAA;qBAC7C;iBACF;qBAAM;oBACL,IAAI,YAAY,CAAC,cAAc,EAAE,UAAU,CAAC,EAAE;wBAC5C,cAAc,CAAC,eAAe,CAAC,UAAU,CAAC,CAAA;qBAC3C;iBACF;aACF;SACF;IACH,CAAC;IAeM,WAAW;QAChB,6FAA6F;QAC7F,IAAI,OAAO,uBAAuB,EAAE,KAAK,WAAW,EAAE;YACpD,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,EAAE,SAAS,CAAC,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;YAClF,oFAAoF;YACpF,sEAAsE;YACtE,sFAAsF;YACtF,wGAAwG;YACxG,8FAA8F;YAC9F,4FAA4F;YAC5F,0EAA0E;YAC1E,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE;gBACnC,IAAI,CAAC,SAAS,EAAE,SAAS,CAAC,WAAW,CAAC,CAAA;aACvC;SACF;QACD,iDAAiD;IACnD,CAAC;IAEM,aAAa;QAClB,IAAI,OAAO,uBAAuB,EAAE,KAAK,WAAW,IAAI,IAAI,CAAC,SAAS,EAAE;YACtE,kDAAkD;YAClD,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;SACrE;QACD,OAAO,IAAI,CAAC,KAAK,CAAA;IACnB,CAAC;IAEO,qBAAqB;QAC3B,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAA;QAC1B,IAAI,CAAC,GAAG,EAAE;YACN,OAAM;SACT;QAED,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAClC,MAAM,aAAa,GAAG,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,sBAAsB,CAAC,CAAA;YACvF,MAAM,cAAc,GAAG,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,uBAAuB,CAAC,CAAA;YACzF,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAgB,CAAA;YACtC,aAAa,CAAC,IAAI,CAChB,SAAS,CAAC,GAAG,EAAE;gBACb,MAAM,UAAU,GAAG,KAAK,CACtB,SAAS,CAAC,GAAG,EAAE,YAAY,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EAC/C,SAAS,CAAC,GAAG,EAAE,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAC/C,CAAC,IAAI,CACJ,SAAS,CAAC,CAAC,CAAC,EACZ,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;oBACjB,IAAI,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;wBAC/F,OAAM;qBACP;oBACD,QAAQ,CAAC,cAAc,EAAE,CAAA;gBAC3B,CAAC,CAAC,CACH,CAAA;gBAED,MAAM,aAAa,GAAG,SAAS,CAAa,QAAQ,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,IAAI,CAC9E,GAAG,CAAC,CAAC,KAAiB,EAAE,EAAE;oBACxB,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE;wBAC7B,OAAM;qBACP;oBAED,KAAK,CAAC,cAAc,EAAE,CAAA;oBACtB,QAAQ,CAAC,cAAc,EAAE,CAAA;gBAC3B,CAAC,CAAC,CACH,CAAA;gBAED,OAAO,KAAK,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,CAAA;YACzE,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAC/B,CAAC,SAAS,EAAE,CAAA;YAEb,MAAM,cAAc,GAAoC,IAAI,CAAC,SAAiB,EAAE,YAAY,CAAA;YAC5F,IAAI,cAAc,EAAE;gBAClB,SAAS,CAAC,cAAc,EAAE,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAC1D,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE;oBACb,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAA;oBAC/B,IAAI,OAAO,EAAE;wBACX,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,KAAK,CAAA;wBAC1C,IAAI,QAAQ,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE;4BAC1F,2DAA2D;4BAC3D,CAAC,CAAC,cAAc,EAAE,CAAA;4BAClB,qDAAqD;4BACrD,CAAC,CAAC,eAAe,EAAE,CAAA;yBACpB;qBACF;gBACH,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAC/B,CAAC,SAAS,EAAE,CAAA;aACd;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,OAAO,KAAK,CAAA;SACb;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAgB,CAAA;QACtC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAA;IAC9D,CAAC;IAED,yBAAyB;IAClB,KAAK;QACV,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,CAAA;IACxC,CAAC;IAED,2BAA2B;IACpB,IAAI;QACT,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,EAAE,CAAA;IACvC,CAAC;IAEM,cAAc;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAA;IACvC,CAAC;;qHArOU,wBAAwB,oGA6Bb,QAAQ;yGA7BnB,wBAAwB;2FAAxB,wBAAwB;kBAJpC,SAAS;mBAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,QAAQ,EAAE,cAAc;iBACzB;;0BA8BI,QAAQ;;0BAAI,MAAM;2BAAC,QAAQ;;0BAC3B,QAAQ;;0BAAI,IAAI;4CAxBO,SAAS;sBAAlC,WAAW;uBAAC,WAAW;gBAGpB,KAAK;sBADR,KAAK","sourcesContent":["import { DOCUMENT } from '@angular/common'\nimport { Directive, DoCheck, ElementRef, Host, HostBinding, Inject, Input, NgZone, OnDestroy, OnInit, Optional, Self } from '@angular/core'\nimport { fromEvent, merge, Subject } from 'rxjs'\nimport { auditTime, last, switchMap, takeUntil, tap } from 'rxjs/operators'\n\nimport { AssetLoaderService, LoadedAssetRef } from '@theseam/ui-common/services'\nimport { getAttribute, hasAttribute, notNullOrUndefined, toggleAttribute } from '@theseam/ui-common/utils'\n\nimport { NgControl } from '@angular/forms'\nimport { IntlTelInputFn, intlTelInputUtils } from './intl-tel-input'\nimport type { IntlTelInput } from './intl-tel-input'\nimport { TEL_INPUT_STYLES, TEL_INPUT_STYLESHEET_PATH, TEL_INPUT_UTILS_PATH } from './tel-input-constants'\nimport { globalIntlTelInputUtils } from './utils/index'\n\n@Directive({\n  selector: 'input[seamTelInput]',\n  exportAs: 'seamTelInput'\n})\nexport class TheSeamTelInputDirective implements OnInit, OnDestroy, DoCheck {\n  private readonly _ngUnsubscribe = new Subject<void>()\n\n  private _instance: IntlTelInput.Plugin | undefined\n  private _loadedAssetRefs: LoadedAssetRef<HTMLLinkElement | HTMLStyleElement>[] = []\n\n  @HostBinding('attr.type') _attrType = 'tel'\n\n  @Input()\n  set value(v: string | undefined | null) {\n    // console.log('set value', v, this._instance)\n    this._value = v\n    if (this._instance) {\n      this._instance.setNumber(notNullOrUndefined(v) ? v : '')\n      this.updateValue()\n    }\n  }\n  get value(): string | undefined | null {\n    if (this._instance) {\n      return this._instance?.getNumber()\n    }\n    return this._value\n  }\n  private _value: string | undefined | null\n\n  constructor(\n    private readonly _elementRef: ElementRef<HTMLInputElement>,\n    private readonly _assetLoader: AssetLoaderService,\n    private readonly _ngZone: NgZone,\n    @Optional() @Inject(DOCUMENT) private readonly _document?: any,\n    @Optional() @Self() private readonly _ngControl?: NgControl,\n  ) { }\n\n  ngOnInit(): void {\n    merge(\n      this._assetLoader.loadStyleSheet(TEL_INPUT_STYLESHEET_PATH),\n      this._assetLoader.loadStyle(TEL_INPUT_STYLES)\n    ).pipe(\n      // tap(v => console.log('loaded', v)),\n      tap(v => this._loadedAssetRefs.push(v)),\n      last(),\n      // tap(v => console.log('StyleLoadingDone', v)),\n      switchMap(() => {\n        this._instance = IntlTelInputFn(this._elementRef.nativeElement, {\n          utilsScript: TEL_INPUT_UTILS_PATH,\n          preferredCountries: [ 'US' ],\n          nationalMode: false,\n          formatOnDisplay: true,\n          autoPlaceholder: 'off',\n          separateDialCode: false,\n          autoHideDialCode: false,\n          // TODO: Add initialCountry support.\n          // initialCountry: 'auto'\n        })\n\n        this._tryUpdateDropdownAttributes()\n\n        return this._instance.promise\n      }),\n      // tap(() => console.log('%c_instance ready', 'color:green', this._instance, this._elementRef.nativeElement.value)),\n      tap(() => this._initDropdownListener()),\n      tap(() => this.value = this._value),\n      tap(this._formatIntlTelInput),\n      switchMap(() => merge(\n        fromEvent(this._elementRef.nativeElement, 'keyup'),\n        fromEvent(this._elementRef.nativeElement, 'change')\n      )),\n      tap(this._formatIntlTelInput),\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe()\n  }\n\n  ngOnDestroy(): void {\n    this._instance?.destroy()\n    for (const ref of this._loadedAssetRefs) {\n      ref.destroy()\n    }\n\n    this._ngUnsubscribe.next(undefined)\n    this._ngUnsubscribe.complete()\n  }\n\n  ngDoCheck() {\n    this._tryUpdateDropdownAttributes()\n  }\n\n  private _tryUpdateDropdownAttributes() {\n    const control = this._ngControl\n    if (control) {\n      const flagsContainer: HTMLElement | null | undefined = (this._instance as any)?.selectedFlag\n      if (flagsContainer) {\n        toggleAttribute(flagsContainer, 'aria-disabled', control.disabled ?? false)\n\n        const disabled = control.disabled ?? false\n        if (!disabled) {\n          if (getAttribute(flagsContainer, 'tabindex') !== '0') {\n            flagsContainer.setAttribute('tabindex', '0')\n          }\n        } else {\n          if (hasAttribute(flagsContainer, 'tabindex')) {\n            flagsContainer.removeAttribute('tabindex')\n          }\n        }\n      }\n    }\n  }\n\n  private _formatIntlTelInput = () => {\n    // if (typeof intlTelInputUtils !== 'undefined') {\n    //   const currentText = this._instance?.getNumber(intlTelInputUtils.numberFormat.INTERNATIONAL)\n    //   console.log('currentText', currentText, this._instance?.getSelectedCountryData())\n    //   console.log(this._instance?.getValidationError())\n    //   if (typeof currentText === 'string') {\n    //     this._instance?.setNumber(currentText)\n    //   }\n    // }\n\n    this.updateValue()\n  }\n\n  public updateValue(): void {\n    // console.log('%cupdateValue START', 'color:cyan', typeof intlTelInputUtils !== 'undefined')\n    if (typeof globalIntlTelInputUtils() !== 'undefined') {\n      const currentText = this._instance?.getNumber(intlTelInputUtils.numberFormat.E164)\n      // console.log('currentText', currentText, this._instance?.getSelectedCountryData())\n      // console.log('fullNumber', (this._instance as any)._getFullNumber())\n      // console.log('E164', this._instance?.getNumber(intlTelInputUtils.numberFormat.E164))\n      // console.log('INTERNATIONAL', this._instance?.getNumber(intlTelInputUtils.numberFormat.INTERNATIONAL))\n      // console.log('NATIONAL', this._instance?.getNumber(intlTelInputUtils.numberFormat.NATIONAL))\n      // console.log('RFC3966', this._instance?.getNumber(intlTelInputUtils.numberFormat.RFC3966))\n      // console.log('getValidationError', this._instance?.getValidationError())\n      if (typeof currentText === 'string') {\n        this._instance?.setNumber(currentText)\n      }\n    }\n    // console.log('%cupdateValue END', 'color:cyan')\n  }\n\n  public getFullNumber(): string | undefined | null {\n    if (typeof globalIntlTelInputUtils() !== 'undefined' && this._instance) {\n      // return (this._instance as any)._getFullNumber()\n      return this._instance.getNumber(intlTelInputUtils.numberFormat.E164)\n    }\n    return this.value\n  }\n\n  private _initDropdownListener() {\n    const doc = this._document\n    if (!doc) {\n        return\n    }\n\n    this._ngZone.runOutsideAngular(() => {\n      const openDropdown$ = fromEvent(this._elementRef.nativeElement, 'open:countrydropdown')\n      const closeDropdown$ = fromEvent(this._elementRef.nativeElement, 'close:countrydropdown')\n      const instance = this._instance as any\n      openDropdown$.pipe(\n        switchMap(() => {\n          const pressDown$ = merge(\n            fromEvent(doc, 'touchstart', { capture: true }),\n            fromEvent(doc, 'mousedown', { capture: true })\n          ).pipe(\n            auditTime(0),\n            tap((event: any) => {\n              if (instance.countryList.contains(event.target) || instance.selectedFlag.contains(event.target)) {\n                return\n              }\n              instance._closeDropdown()\n            })\n          )\n\n          const flagBtnClick$ = fromEvent<MouseEvent>(instance.selectedFlag, 'click').pipe(\n            tap((event: MouseEvent) => {\n              if (!this.isDropdownVisible()) {\n                return\n              }\n\n              event.preventDefault()\n              instance._closeDropdown()\n            })\n          )\n\n          return merge(pressDown$, flagBtnClick$).pipe(takeUntil(closeDropdown$))\n        }),\n        takeUntil(this._ngUnsubscribe)\n      ).subscribe()\n\n      const flagsContainer: HTMLElement | null | undefined = (this._instance as any)?.selectedFlag\n      if (flagsContainer) {\n        fromEvent(flagsContainer, 'keydown', { capture: true }).pipe(\n          tap((e: any) => {\n            const control = this._ngControl\n            if (control) {\n              const disabled = control.disabled ?? false\n              if (disabled && ['ArrowUp', 'Up', 'ArrowDown', 'Down', ' ', 'Enter'].indexOf(e.key) !== -1) {\n                // prevent form from being submitted if \"ENTER\" was pressed\n                e.preventDefault()\n                // prevent event from being handled again by document\n                e.stopPropagation()\n              }\n            }\n          }),\n          takeUntil(this._ngUnsubscribe)\n        ).subscribe()\n      }\n    })\n  }\n\n  public isDropdownVisible() {\n    if (!this._instance) {\n      return false\n    }\n\n    const instance = this._instance as any\n    return !instance.countryList.classList.contains('iti__hide')\n  }\n\n  /** Focuses the input. */\n  public focus(): void {\n    this._elementRef.nativeElement.focus()\n  }\n\n  /** Unfocuses the input. */\n  public blur(): void {\n    this._elementRef.nativeElement.blur()\n  }\n\n  public getHostElement(): HTMLInputElement {\n    return this._elementRef.nativeElement\n  }\n}\n"]}
209
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tel-input.directive.js","sourceRoot":"","sources":["../../../../projects/ui-common/tel-input/tel-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common'\nimport { Directive, DoCheck, ElementRef, HostBinding, Inject, Input, NgZone, OnDestroy, OnInit, Optional, Self } from '@angular/core'\nimport { fromEvent, merge, Subject } from 'rxjs'\nimport { auditTime, last, switchMap, takeUntil, tap } from 'rxjs/operators'\n\nimport { AssetLoaderService, LoadedAssetRef } from '@theseam/ui-common/services'\nimport { getAttribute, hasAttribute, notNullOrUndefined, toggleAttribute } from '@theseam/ui-common/utils'\n\nimport { NgControl } from '@angular/forms'\nimport { IntlTelInputFn, intlTelInputUtils } from './intl-tel-input'\nimport type { IntlTelInput } from './intl-tel-input'\nimport { TEL_INPUT_STYLES, TEL_INPUT_STYLESHEET_PATH, TEL_INPUT_UTILS_PATH } from './tel-input-constants'\nimport { globalIntlTelInputUtils } from './utils/index'\n\n@Directive({\n  selector: 'input[seamTelInput]',\n  exportAs: 'seamTelInput',\n  standalone: true,\n})\nexport class TheSeamTelInputDirective implements OnInit, OnDestroy, DoCheck {\n  private readonly _ngUnsubscribe = new Subject<void>()\n\n  private _instance: IntlTelInput.Plugin | undefined\n  private _loadedAssetRefs: LoadedAssetRef<HTMLLinkElement | HTMLStyleElement>[] = []\n\n  @HostBinding('attr.type') _attrType = 'tel'\n\n  @Input()\n  set value(v: string | undefined | null) {\n    this._value = v\n    if (this._instance) {\n      this._instance.setNumber(notNullOrUndefined(v) ? v : '')\n      this.updateValue()\n    }\n  }\n  get value(): string | undefined | null {\n    if (this._instance) {\n      return this._instance?.getNumber()\n    }\n    return this._value\n  }\n  private _value: string | undefined | null\n\n  constructor(\n    private readonly _elementRef: ElementRef<HTMLInputElement>,\n    private readonly _assetLoader: AssetLoaderService,\n    private readonly _ngZone: NgZone,\n    @Optional() @Inject(DOCUMENT) private readonly _document?: any,\n    @Optional() @Self() private readonly _ngControl?: NgControl,\n  ) { }\n\n  ngOnInit(): void {\n    this._elementRef.nativeElement.value = this._ngControl ? this._ngControl.value : this.value ?? ''\n    this._elementRef.nativeElement.setAttribute('instance-loading', '')\n    merge(\n      this._assetLoader.loadStyleSheet(TEL_INPUT_STYLESHEET_PATH),\n      this._assetLoader.loadStyle(TEL_INPUT_STYLES)\n    ).pipe(\n      tap(v => this._loadedAssetRefs.push(v)),\n      last(),\n      switchMap(() => {\n        this._instance = IntlTelInputFn(this._elementRef.nativeElement, {\n          utilsScript: TEL_INPUT_UTILS_PATH,\n          preferredCountries: [ 'US' ],\n          nationalMode: false,\n          formatOnDisplay: true,\n          autoPlaceholder: 'off',\n          separateDialCode: false,\n          autoHideDialCode: false,\n          // TODO: Add initialCountry support.\n          // initialCountry: 'auto'\n        })\n\n        this._tryUpdateDropdownAttributes()\n\n        return this._instance.promise.then(v => {\n          this._elementRef.nativeElement.removeAttribute('instance-loading')\n          return v\n        })\n      }),\n      tap(() => this._initDropdownListener()),\n      tap(() => this.value = this._value),\n      tap(this._formatIntlTelInput),\n      switchMap(() => merge(\n        fromEvent(this._elementRef.nativeElement, 'keyup'),\n        fromEvent(this._elementRef.nativeElement, 'change')\n      )),\n      tap(this._formatIntlTelInput),\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe()\n  }\n\n  ngOnDestroy(): void {\n    this._instance?.destroy()\n    for (const ref of this._loadedAssetRefs) {\n      ref.destroy()\n    }\n\n    this._ngUnsubscribe.next(undefined)\n    this._ngUnsubscribe.complete()\n  }\n\n  ngDoCheck() {\n    this._tryUpdateDropdownAttributes()\n  }\n\n  private _tryUpdateDropdownAttributes() {\n    const control = this._ngControl\n    if (control) {\n      const flagsContainer: HTMLElement | null | undefined = (this._instance as any)?.selectedFlag\n      if (flagsContainer) {\n        toggleAttribute(flagsContainer, 'aria-disabled', control.disabled ?? false)\n\n        const disabled = control.disabled ?? false\n        if (!disabled) {\n          if (getAttribute(flagsContainer, 'tabindex') !== '0') {\n            flagsContainer.setAttribute('tabindex', '0')\n          }\n        } else {\n          if (hasAttribute(flagsContainer, 'tabindex')) {\n            flagsContainer.removeAttribute('tabindex')\n          }\n        }\n      }\n    }\n  }\n\n  private _formatIntlTelInput = () => {\n    // if (typeof intlTelInputUtils !== 'undefined') {\n    //   const currentText = this._instance?.getNumber(intlTelInputUtils.numberFormat.INTERNATIONAL)\n    //   console.log('currentText', currentText, this._instance?.getSelectedCountryData())\n    //   console.log(this._instance?.getValidationError())\n    //   if (typeof currentText === 'string') {\n    //     this._instance?.setNumber(currentText)\n    //   }\n    // }\n\n    this.updateValue()\n  }\n\n  public updateValue(): void {\n    // console.log('%cupdateValue START', 'color:cyan', typeof intlTelInputUtils !== 'undefined')\n    if (typeof globalIntlTelInputUtils() !== 'undefined') {\n      const currentText = this._instance?.getNumber(intlTelInputUtils.numberFormat.E164)\n      // console.log('currentText', currentText, this._instance?.getSelectedCountryData())\n      // console.log('fullNumber', (this._instance as any)._getFullNumber())\n      // console.log('E164', this._instance?.getNumber(intlTelInputUtils.numberFormat.E164))\n      // console.log('INTERNATIONAL', this._instance?.getNumber(intlTelInputUtils.numberFormat.INTERNATIONAL))\n      // console.log('NATIONAL', this._instance?.getNumber(intlTelInputUtils.numberFormat.NATIONAL))\n      // console.log('RFC3966', this._instance?.getNumber(intlTelInputUtils.numberFormat.RFC3966))\n      // console.log('getValidationError', this._instance?.getValidationError())\n      if (typeof currentText === 'string') {\n        this._instance?.setNumber(currentText)\n      }\n    }\n    // console.log('%cupdateValue END', 'color:cyan')\n  }\n\n  public getFullNumber(): string | undefined | null {\n    if (typeof globalIntlTelInputUtils() !== 'undefined' && this._instance) {\n      // return (this._instance as any)._getFullNumber()\n      return this._instance.getNumber(intlTelInputUtils.numberFormat.E164)\n    }\n    return this.value\n  }\n\n  private _initDropdownListener() {\n    const doc = this._document\n    if (!doc) {\n        return\n    }\n\n    this._ngZone.runOutsideAngular(() => {\n      const openDropdown$ = fromEvent(this._elementRef.nativeElement, 'open:countrydropdown')\n      const closeDropdown$ = fromEvent(this._elementRef.nativeElement, 'close:countrydropdown')\n      const instance = this._instance as any\n      openDropdown$.pipe(\n        switchMap(() => {\n          const pressDown$ = merge(\n            fromEvent(doc, 'touchstart', { capture: true }),\n            fromEvent(doc, 'mousedown', { capture: true })\n          ).pipe(\n            auditTime(0),\n            tap((event: any) => {\n              if (instance.countryList.contains(event.target) || instance.selectedFlag.contains(event.target)) {\n                return\n              }\n              instance._closeDropdown()\n            })\n          )\n\n          const flagBtnClick$ = fromEvent<MouseEvent>(instance.selectedFlag, 'click').pipe(\n            tap((event: MouseEvent) => {\n              if (!this.isDropdownVisible()) {\n                return\n              }\n\n              event.preventDefault()\n              instance._closeDropdown()\n            })\n          )\n\n          return merge(pressDown$, flagBtnClick$).pipe(takeUntil(closeDropdown$))\n        }),\n        takeUntil(this._ngUnsubscribe)\n      ).subscribe()\n\n      const flagsContainer: HTMLElement | null | undefined = (this._instance as any)?.selectedFlag\n      if (flagsContainer) {\n        fromEvent(flagsContainer, 'keydown', { capture: true }).pipe(\n          tap((e: any) => {\n            const control = this._ngControl\n            if (control) {\n              const disabled = control.disabled ?? false\n              if (disabled && ['ArrowUp', 'Up', 'ArrowDown', 'Down', ' ', 'Enter'].indexOf(e.key) !== -1) {\n                // prevent form from being submitted if \"ENTER\" was pressed\n                e.preventDefault()\n                // prevent event from being handled again by document\n                e.stopPropagation()\n              }\n            }\n          }),\n          takeUntil(this._ngUnsubscribe)\n        ).subscribe()\n      }\n    })\n  }\n\n  public isDropdownVisible() {\n    if (!this._instance) {\n      return false\n    }\n\n    const instance = this._instance as any\n    return !instance.countryList.classList.contains('iti__hide')\n  }\n\n  /** Focuses the input. */\n  public focus(): void {\n    this._elementRef.nativeElement.focus()\n  }\n\n  /** Unfocuses the input. */\n  public blur(): void {\n    this._elementRef.nativeElement.blur()\n  }\n\n  public getHostElement(): HTMLInputElement {\n    return this._elementRef.nativeElement\n  }\n}\n"]}
@@ -9,28 +9,29 @@ import * as i0 from "@angular/core";
9
9
  export class TheSeamTelInputModule {
10
10
  }
11
11
  TheSeamTelInputModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamTelInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
- TheSeamTelInputModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: TheSeamTelInputModule, declarations: [TheSeamTelInputDirective,
13
- TheSeamTelInputComponent,
14
- TheSeamPhoneNumberPipe], imports: [CommonModule,
12
+ TheSeamTelInputModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: TheSeamTelInputModule, declarations: [TheSeamPhoneNumberPipe], imports: [CommonModule,
15
13
  ReactiveFormsModule,
16
- TheSeamFormFieldModule], exports: [TheSeamTelInputDirective,
14
+ TheSeamFormFieldModule,
15
+ TheSeamTelInputDirective,
16
+ TheSeamTelInputComponent], exports: [TheSeamTelInputDirective,
17
17
  TheSeamTelInputComponent,
18
18
  TheSeamPhoneNumberPipe] });
19
19
  TheSeamTelInputModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamTelInputModule, imports: [CommonModule,
20
20
  ReactiveFormsModule,
21
- TheSeamFormFieldModule] });
21
+ TheSeamFormFieldModule,
22
+ TheSeamTelInputComponent] });
22
23
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamTelInputModule, decorators: [{
23
24
  type: NgModule,
24
25
  args: [{
25
26
  declarations: [
26
- TheSeamTelInputDirective,
27
- TheSeamTelInputComponent,
28
27
  TheSeamPhoneNumberPipe
29
28
  ],
30
29
  imports: [
31
30
  CommonModule,
32
31
  ReactiveFormsModule,
33
- TheSeamFormFieldModule
32
+ TheSeamFormFieldModule,
33
+ TheSeamTelInputDirective,
34
+ TheSeamTelInputComponent,
34
35
  ],
35
36
  exports: [
36
37
  TheSeamTelInputDirective,
@@ -39,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
39
40
  ]
40
41
  }]
41
42
  }] });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVsLWlucHV0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90ZWwtaW5wdXQvdGVsLWlucHV0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUVwRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQTtBQUV0RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUM1RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQTtBQUNoRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQTs7QUFtQjFFLE1BQU0sT0FBTyxxQkFBcUI7O2tIQUFyQixxQkFBcUI7bUhBQXJCLHFCQUFxQixpQkFmOUIsd0JBQXdCO1FBQ3hCLHdCQUF3QjtRQUN4QixzQkFBc0IsYUFHdEIsWUFBWTtRQUNaLG1CQUFtQjtRQUNuQixzQkFBc0IsYUFHdEIsd0JBQXdCO1FBQ3hCLHdCQUF3QjtRQUN4QixzQkFBc0I7bUhBR2IscUJBQXFCLFlBVjlCLFlBQVk7UUFDWixtQkFBbUI7UUFDbkIsc0JBQXNCOzJGQVFiLHFCQUFxQjtrQkFqQmpDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHdCQUF3Qjt3QkFDeEIsd0JBQXdCO3dCQUN4QixzQkFBc0I7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLG1CQUFtQjt3QkFDbkIsc0JBQXNCO3FCQUN2QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1Asd0JBQXdCO3dCQUN4Qix3QkFBd0I7d0JBQ3hCLHNCQUFzQjtxQkFDdkI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnXG5cbmltcG9ydCB7IFRoZVNlYW1Gb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vZm9ybS1maWVsZCdcblxuaW1wb3J0IHsgVGhlU2VhbVBob25lTnVtYmVyUGlwZSB9IGZyb20gJy4vcGhvbmUtbnVtYmVyLnBpcGUnXG5pbXBvcnQgeyBUaGVTZWFtVGVsSW5wdXREaXJlY3RpdmUgfSBmcm9tICcuL3RlbC1pbnB1dC5kaXJlY3RpdmUnXG5pbXBvcnQgeyBUaGVTZWFtVGVsSW5wdXRDb21wb25lbnQgfSBmcm9tICcuL3RlbC1pbnB1dC90ZWwtaW5wdXQuY29tcG9uZW50J1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBUaGVTZWFtVGVsSW5wdXREaXJlY3RpdmUsXG4gICAgVGhlU2VhbVRlbElucHV0Q29tcG9uZW50LFxuICAgIFRoZVNlYW1QaG9uZU51bWJlclBpcGVcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIFRoZVNlYW1Gb3JtRmllbGRNb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFRoZVNlYW1UZWxJbnB1dERpcmVjdGl2ZSxcbiAgICBUaGVTZWFtVGVsSW5wdXRDb21wb25lbnQsXG4gICAgVGhlU2VhbVBob25lTnVtYmVyUGlwZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFRoZVNlYW1UZWxJbnB1dE1vZHVsZSB7IH1cbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVsLWlucHV0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90ZWwtaW5wdXQvdGVsLWlucHV0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUVwRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQTtBQUV0RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUM1RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQTtBQUNoRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQTs7QUFtQjFFLE1BQU0sT0FBTyxxQkFBcUI7O2tIQUFyQixxQkFBcUI7bUhBQXJCLHFCQUFxQixpQkFmOUIsc0JBQXNCLGFBR3RCLFlBQVk7UUFDWixtQkFBbUI7UUFDbkIsc0JBQXNCO1FBQ3RCLHdCQUF3QjtRQUN4Qix3QkFBd0IsYUFHeEIsd0JBQXdCO1FBQ3hCLHdCQUF3QjtRQUN4QixzQkFBc0I7bUhBR2IscUJBQXFCLFlBWjlCLFlBQVk7UUFDWixtQkFBbUI7UUFDbkIsc0JBQXNCO1FBRXRCLHdCQUF3QjsyRkFRZixxQkFBcUI7a0JBakJqQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixzQkFBc0I7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLG1CQUFtQjt3QkFDbkIsc0JBQXNCO3dCQUN0Qix3QkFBd0I7d0JBQ3hCLHdCQUF3QjtxQkFDekI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHdCQUF3Qjt3QkFDeEIsd0JBQXdCO3dCQUN4QixzQkFBc0I7cUJBQ3ZCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJ1xuXG5pbXBvcnQgeyBUaGVTZWFtRm9ybUZpZWxkTW9kdWxlIH0gZnJvbSAnQHRoZXNlYW0vdWktY29tbW9uL2Zvcm0tZmllbGQnXG5cbmltcG9ydCB7IFRoZVNlYW1QaG9uZU51bWJlclBpcGUgfSBmcm9tICcuL3Bob25lLW51bWJlci5waXBlJ1xuaW1wb3J0IHsgVGhlU2VhbVRlbElucHV0RGlyZWN0aXZlIH0gZnJvbSAnLi90ZWwtaW5wdXQuZGlyZWN0aXZlJ1xuaW1wb3J0IHsgVGhlU2VhbVRlbElucHV0Q29tcG9uZW50IH0gZnJvbSAnLi90ZWwtaW5wdXQvdGVsLWlucHV0LmNvbXBvbmVudCdcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgVGhlU2VhbVBob25lTnVtYmVyUGlwZVxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgVGhlU2VhbUZvcm1GaWVsZE1vZHVsZSxcbiAgICBUaGVTZWFtVGVsSW5wdXREaXJlY3RpdmUsXG4gICAgVGhlU2VhbVRlbElucHV0Q29tcG9uZW50LFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgVGhlU2VhbVRlbElucHV0RGlyZWN0aXZlLFxuICAgIFRoZVNlYW1UZWxJbnB1dENvbXBvbmVudCxcbiAgICBUaGVTZWFtUGhvbmVOdW1iZXJQaXBlXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgVGhlU2VhbVRlbElucHV0TW9kdWxlIHsgfVxuIl19
@@ -0,0 +1,49 @@
1
+ import { ComponentHarness, HarnessPredicate } from '@angular/cdk/testing';
2
+ import { waitOnConditionAsync } from '@theseam/ui-common/utils';
3
+ export class TheSeamTelInputHarness extends ComponentHarness {
4
+ constructor() {
5
+ super(...arguments);
6
+ this._input = this.locatorFor('input');
7
+ }
8
+ /** Creates a `HarnessPredicate` used to locate a particular `TheSeamTelInputHarness`. */
9
+ static with(options) {
10
+ return new HarnessPredicate(TheSeamTelInputHarness, options)
11
+ .addOption('field name', options.name, (harness, name) => HarnessPredicate.stringMatches(harness.getName(), name));
12
+ }
13
+ async getName() {
14
+ return (await this._input()).getAttribute('name');
15
+ }
16
+ async getValue() {
17
+ return (await this._input()).getProperty('value');
18
+ }
19
+ async isDisabled() {
20
+ return (await this._input()).getProperty('disabled');
21
+ }
22
+ async isRequired() {
23
+ return (await this._input()).getProperty('required');
24
+ }
25
+ async click() {
26
+ return (await this._input()).click();
27
+ }
28
+ async setValue(value) {
29
+ await this._waitOnInstance();
30
+ // TODO: Find out why setInputValue() doesn't update the FormControl.
31
+ // return (await this._input()).setInputValue(value)
32
+ await (await this._input()).click();
33
+ await this._input().then(x => x.setInputValue(''));
34
+ return (await this._input()).sendKeys(value);
35
+ }
36
+ async _waitOnInstance() {
37
+ const input = document.querySelector('input');
38
+ const isInstanceReady = () => {
39
+ const instLoading = input?.getAttribute('instance-loading');
40
+ return instLoading === null;
41
+ };
42
+ if (isInstanceReady()) {
43
+ return true;
44
+ }
45
+ await waitOnConditionAsync(isInstanceReady, 10000);
46
+ }
47
+ }
48
+ TheSeamTelInputHarness.hostSelector = 'seam-tel-input';
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVsLWlucHV0Lmhhcm5lc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdGVsLWlucHV0L3Rlc3RpbmcvdGVsLWlucHV0Lmhhcm5lc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFzQixnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFBO0FBRTdGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBCQUEwQixDQUFBO0FBTy9ELE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxnQkFBZ0I7SUFBNUQ7O1FBR21CLFdBQU0sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFBO0lBbURwRCxDQUFDO0lBakRDLHlGQUF5RjtJQUN6RixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQXNDO1FBQ2hELE9BQU8sSUFBSSxnQkFBZ0IsQ0FBQyxzQkFBc0IsRUFBRSxPQUFPLENBQUM7YUFDdkQsU0FBUyxDQUFDLFlBQVksRUFBRSxPQUFPLENBQUMsSUFBSSxFQUNqQyxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLGdCQUFnQixDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQTtJQUNyRixDQUFDO0lBRU0sS0FBSyxDQUFDLE9BQU87UUFDbEIsT0FBTyxDQUFDLE1BQU0sSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQ25ELENBQUM7SUFFTSxLQUFLLENBQUMsUUFBUTtRQUNuQixPQUFPLENBQUMsTUFBTSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUE7SUFDbkQsQ0FBQztJQUVNLEtBQUssQ0FBQyxVQUFVO1FBQ3JCLE9BQU8sQ0FBQyxNQUFNLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsQ0FBQTtJQUN0RCxDQUFDO0lBRU0sS0FBSyxDQUFDLFVBQVU7UUFDckIsT0FBTyxDQUFDLE1BQU0sSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQyxDQUFBO0lBQ3RELENBQUM7SUFFTSxLQUFLLENBQUMsS0FBSztRQUNoQixPQUFPLENBQUMsTUFBTSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtJQUN0QyxDQUFDO0lBRU0sS0FBSyxDQUFDLFFBQVEsQ0FBQyxLQUFVO1FBQzlCLE1BQU0sSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFBO1FBQzVCLHFFQUFxRTtRQUNyRSxvREFBb0Q7UUFDcEQsTUFBTSxDQUFDLE1BQU0sSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUE7UUFDbkMsTUFBTSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFBO1FBQ2xELE9BQU8sQ0FBQyxNQUFNLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUM5QyxDQUFDO0lBRU8sS0FBSyxDQUFDLGVBQWU7UUFDM0IsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQTtRQUM3QyxNQUFNLGVBQWUsR0FBRyxHQUFHLEVBQUU7WUFDM0IsTUFBTSxXQUFXLEdBQUcsS0FBSyxFQUFFLFlBQVksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFBO1lBQzNELE9BQU8sV0FBVyxLQUFLLElBQUksQ0FBQTtRQUM3QixDQUFDLENBQUE7UUFDRCxJQUFJLGVBQWUsRUFBRSxFQUFFO1lBQ3JCLE9BQU8sSUFBSSxDQUFBO1NBQ1o7UUFDRCxNQUFNLG9CQUFvQixDQUN4QixlQUFlLEVBQUUsS0FBSyxDQUN2QixDQUFBO0lBQ0gsQ0FBQzs7QUFwRE0sbUNBQVksR0FBRyxnQkFBZ0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VIYXJuZXNzRmlsdGVycywgQ29tcG9uZW50SGFybmVzcywgSGFybmVzc1ByZWRpY2F0ZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay90ZXN0aW5nJ1xuXG5pbXBvcnQgeyB3YWl0T25Db25kaXRpb25Bc3luYyB9IGZyb20gJ0B0aGVzZWFtL3VpLWNvbW1vbi91dGlscydcblxuaW50ZXJmYWNlIFRoZVNlYW1UZWxJbnB1dEhhcm5lc3NGaWx0ZXJzIGV4dGVuZHMgQmFzZUhhcm5lc3NGaWx0ZXJzIHtcbiAgLyoqIEZpbHRlcnMgYmFzZWQgb24gdGhlIG5hbWUgb2YgdGhlIGZpZWxkLiAqL1xuICBuYW1lPzogc3RyaW5nIHwgUmVnRXhwXG59XG5cbmV4cG9ydCBjbGFzcyBUaGVTZWFtVGVsSW5wdXRIYXJuZXNzIGV4dGVuZHMgQ29tcG9uZW50SGFybmVzcyB7XG4gIHN0YXRpYyBob3N0U2VsZWN0b3IgPSAnc2VhbS10ZWwtaW5wdXQnXG5cbiAgcHJpdmF0ZSByZWFkb25seSBfaW5wdXQgPSB0aGlzLmxvY2F0b3JGb3IoJ2lucHV0JylcblxuICAvKiogQ3JlYXRlcyBhIGBIYXJuZXNzUHJlZGljYXRlYCB1c2VkIHRvIGxvY2F0ZSBhIHBhcnRpY3VsYXIgYFRoZVNlYW1UZWxJbnB1dEhhcm5lc3NgLiAqL1xuICBzdGF0aWMgd2l0aChvcHRpb25zOiBUaGVTZWFtVGVsSW5wdXRIYXJuZXNzRmlsdGVycyk6IEhhcm5lc3NQcmVkaWNhdGU8VGhlU2VhbVRlbElucHV0SGFybmVzcz4ge1xuICAgIHJldHVybiBuZXcgSGFybmVzc1ByZWRpY2F0ZShUaGVTZWFtVGVsSW5wdXRIYXJuZXNzLCBvcHRpb25zKVxuICAgICAgICAuYWRkT3B0aW9uKCdmaWVsZCBuYW1lJywgb3B0aW9ucy5uYW1lLFxuICAgICAgICAgICAgKGhhcm5lc3MsIG5hbWUpID0+IEhhcm5lc3NQcmVkaWNhdGUuc3RyaW5nTWF0Y2hlcyhoYXJuZXNzLmdldE5hbWUoKSwgbmFtZSkpXG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZ2V0TmFtZSgpOiBQcm9taXNlPHN0cmluZyB8IG51bGw+IHtcbiAgICByZXR1cm4gKGF3YWl0IHRoaXMuX2lucHV0KCkpLmdldEF0dHJpYnV0ZSgnbmFtZScpXG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZ2V0VmFsdWUoKTogUHJvbWlzZTxhbnk+IHtcbiAgICByZXR1cm4gKGF3YWl0IHRoaXMuX2lucHV0KCkpLmdldFByb3BlcnR5KCd2YWx1ZScpXG4gIH1cblxuICBwdWJsaWMgYXN5bmMgaXNEaXNhYmxlZCgpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gKGF3YWl0IHRoaXMuX2lucHV0KCkpLmdldFByb3BlcnR5KCdkaXNhYmxlZCcpXG4gIH1cblxuICBwdWJsaWMgYXN5bmMgaXNSZXF1aXJlZCgpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gKGF3YWl0IHRoaXMuX2lucHV0KCkpLmdldFByb3BlcnR5KCdyZXF1aXJlZCcpXG4gIH1cblxuICBwdWJsaWMgYXN5bmMgY2xpY2soKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIChhd2FpdCB0aGlzLl9pbnB1dCgpKS5jbGljaygpXG4gIH1cblxuICBwdWJsaWMgYXN5bmMgc2V0VmFsdWUodmFsdWU6IGFueSk6IFByb21pc2U8dm9pZD4ge1xuICAgIGF3YWl0IHRoaXMuX3dhaXRPbkluc3RhbmNlKClcbiAgICAvLyBUT0RPOiBGaW5kIG91dCB3aHkgc2V0SW5wdXRWYWx1ZSgpIGRvZXNuJ3QgdXBkYXRlIHRoZSBGb3JtQ29udHJvbC5cbiAgICAvLyByZXR1cm4gKGF3YWl0IHRoaXMuX2lucHV0KCkpLnNldElucHV0VmFsdWUodmFsdWUpXG4gICAgYXdhaXQgKGF3YWl0IHRoaXMuX2lucHV0KCkpLmNsaWNrKClcbiAgICBhd2FpdCB0aGlzLl9pbnB1dCgpLnRoZW4oeCA9PiB4LnNldElucHV0VmFsdWUoJycpKVxuICAgIHJldHVybiAoYXdhaXQgdGhpcy5faW5wdXQoKSkuc2VuZEtleXModmFsdWUpXG4gIH1cblxuICBwcml2YXRlIGFzeW5jIF93YWl0T25JbnN0YW5jZSgpIHtcbiAgICBjb25zdCBpbnB1dCA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoJ2lucHV0JylcbiAgICBjb25zdCBpc0luc3RhbmNlUmVhZHkgPSAoKSA9PiB7XG4gICAgICBjb25zdCBpbnN0TG9hZGluZyA9IGlucHV0Py5nZXRBdHRyaWJ1dGUoJ2luc3RhbmNlLWxvYWRpbmcnKVxuICAgICAgcmV0dXJuIGluc3RMb2FkaW5nID09PSBudWxsXG4gICAgfVxuICAgIGlmIChpc0luc3RhbmNlUmVhZHkoKSkge1xuICAgICAgcmV0dXJuIHRydWVcbiAgICB9XG4gICAgYXdhaXQgd2FpdE9uQ29uZGl0aW9uQXN5bmMoXG4gICAgICBpc0luc3RhbmNlUmVhZHksIDEwMDAwXG4gICAgKVxuICB9XG59XG4iXX0=