@siemens/element-ng 47.3.0 → 47.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (313) hide show
  1. package/badge/si-badge.component.d.ts +1 -1
  2. package/breadcrumb/breadcrumb-item.model.d.ts +36 -0
  3. package/breadcrumb/index.d.ts +7 -0
  4. package/breadcrumb/package.json +3 -0
  5. package/breadcrumb/si-breadcrumb-item-template.directive.d.ts +10 -0
  6. package/breadcrumb/si-breadcrumb.component.d.ts +46 -0
  7. package/breadcrumb/si-breadcrumb.module.d.ts +7 -0
  8. package/card/index.d.ts +6 -0
  9. package/card/package.json +3 -0
  10. package/card/si-card.component.d.ts +79 -0
  11. package/card/si-card.module.d.ts +7 -0
  12. package/circle-status/index.d.ts +6 -0
  13. package/circle-status/package.json +3 -0
  14. package/circle-status/si-circle-status.component.d.ts +66 -0
  15. package/circle-status/si-circle-status.module.d.ts +7 -0
  16. package/column-selection-dialog/column-selection-editor/si-column-selection-editor.component.d.ts +23 -0
  17. package/column-selection-dialog/index.d.ts +6 -0
  18. package/column-selection-dialog/package.json +3 -0
  19. package/column-selection-dialog/si-column-selection-dialog.component.d.ts +114 -0
  20. package/column-selection-dialog/si-column-selection-dialog.service.d.ts +20 -0
  21. package/column-selection-dialog/si-column-selection-dialog.types.d.ts +68 -0
  22. package/common/models/status-type.model.d.ts +4 -2
  23. package/datatable/index.d.ts +42 -0
  24. package/datatable/package.json +3 -0
  25. package/datatable/si-datatable-interaction.directive.d.ts +34 -0
  26. package/datatable/si-datatable.module.d.ts +7 -0
  27. package/date-range-filter/index.d.ts +8 -0
  28. package/date-range-filter/package.json +3 -0
  29. package/date-range-filter/si-date-range-calculation.service.d.ts +33 -0
  30. package/date-range-filter/si-date-range-filter.component.d.ts +248 -0
  31. package/date-range-filter/si-date-range-filter.module.d.ts +7 -0
  32. package/date-range-filter/si-date-range-filter.types.d.ts +40 -0
  33. package/date-range-filter/si-relative-date.component.d.ts +31 -0
  34. package/datepicker/components/si-calendar-body.component.d.ts +137 -0
  35. package/datepicker/components/si-calendar-date-cell.directive.d.ts +16 -0
  36. package/datepicker/components/si-calendar-direction-button.component.d.ts +18 -0
  37. package/datepicker/components/si-compare-adapter.d.ts +37 -0
  38. package/datepicker/components/si-day-selection.component.d.ts +76 -0
  39. package/datepicker/components/si-initial-focus.component.d.ts +74 -0
  40. package/datepicker/components/si-month-selection.component.d.ts +62 -0
  41. package/datepicker/components/si-year-selection.component.d.ts +65 -0
  42. package/datepicker/date-time-helper.d.ts +302 -0
  43. package/datepicker/index.d.ts +15 -0
  44. package/datepicker/package.json +3 -0
  45. package/datepicker/si-calendar-button.component.d.ts +49 -0
  46. package/datepicker/si-date-input.directive.d.ts +114 -0
  47. package/datepicker/si-date-range.component.d.ts +150 -0
  48. package/datepicker/si-datepicker-overlay.component.d.ts +82 -0
  49. package/datepicker/si-datepicker-overlay.directive.d.ts +104 -0
  50. package/datepicker/si-datepicker.component.d.ts +228 -0
  51. package/datepicker/si-datepicker.directive.d.ts +62 -0
  52. package/datepicker/si-datepicker.model.d.ts +129 -0
  53. package/datepicker/si-datepicker.module.d.ts +12 -0
  54. package/datepicker/si-timepicker.component.d.ts +214 -0
  55. package/electron-titlebar/electron.helpers.d.ts +5 -0
  56. package/electron-titlebar/index.d.ts +7 -0
  57. package/electron-titlebar/package.json +3 -0
  58. package/electron-titlebar/si-electron-titlebar.component.d.ts +72 -0
  59. package/electron-titlebar/si-electron-titlebar.module.d.ts +7 -0
  60. package/fesm2022/siemens-element-ng-badge.mjs.map +1 -1
  61. package/fesm2022/siemens-element-ng-breadcrumb.mjs +302 -0
  62. package/fesm2022/siemens-element-ng-breadcrumb.mjs.map +1 -0
  63. package/fesm2022/siemens-element-ng-card.mjs +122 -0
  64. package/fesm2022/siemens-element-ng-card.mjs.map +1 -0
  65. package/fesm2022/siemens-element-ng-circle-status.mjs +146 -0
  66. package/fesm2022/siemens-element-ng-circle-status.mjs.map +1 -0
  67. package/fesm2022/siemens-element-ng-column-selection-dialog.mjs +369 -0
  68. package/fesm2022/siemens-element-ng-column-selection-dialog.mjs.map +1 -0
  69. package/fesm2022/siemens-element-ng-common.mjs.map +1 -1
  70. package/fesm2022/siemens-element-ng-datatable.mjs +173 -0
  71. package/fesm2022/siemens-element-ng-datatable.mjs.map +1 -0
  72. package/fesm2022/siemens-element-ng-date-range-filter.mjs +649 -0
  73. package/fesm2022/siemens-element-ng-date-range-filter.mjs.map +1 -0
  74. package/fesm2022/siemens-element-ng-datepicker.mjs +4231 -0
  75. package/fesm2022/siemens-element-ng-datepicker.mjs.map +1 -0
  76. package/fesm2022/siemens-element-ng-electron-titlebar.mjs +142 -0
  77. package/fesm2022/siemens-element-ng-electron-titlebar.mjs.map +1 -0
  78. package/fesm2022/siemens-element-ng-file-uploader.mjs +751 -0
  79. package/fesm2022/siemens-element-ng-file-uploader.mjs.map +1 -0
  80. package/fesm2022/siemens-element-ng-filter-bar.mjs +153 -0
  81. package/fesm2022/siemens-element-ng-filter-bar.mjs.map +1 -0
  82. package/fesm2022/siemens-element-ng-filtered-search.mjs +1139 -0
  83. package/fesm2022/siemens-element-ng-filtered-search.mjs.map +1 -0
  84. package/fesm2022/siemens-element-ng-formly.mjs +935 -0
  85. package/fesm2022/siemens-element-ng-formly.mjs.map +1 -0
  86. package/fesm2022/siemens-element-ng-icon.mjs +52 -14
  87. package/fesm2022/siemens-element-ng-icon.mjs.map +1 -1
  88. package/fesm2022/siemens-element-ng-info-page.mjs +63 -0
  89. package/fesm2022/siemens-element-ng-info-page.mjs.map +1 -0
  90. package/fesm2022/siemens-element-ng-inline-notification.mjs +4 -6
  91. package/fesm2022/siemens-element-ng-inline-notification.mjs.map +1 -1
  92. package/fesm2022/siemens-element-ng-ip-input.mjs +451 -0
  93. package/fesm2022/siemens-element-ng-ip-input.mjs.map +1 -0
  94. package/fesm2022/siemens-element-ng-list-details.mjs +390 -0
  95. package/fesm2022/siemens-element-ng-list-details.mjs.map +1 -0
  96. package/fesm2022/siemens-element-ng-loading-spinner.mjs +15 -12
  97. package/fesm2022/siemens-element-ng-loading-spinner.mjs.map +1 -1
  98. package/fesm2022/siemens-element-ng-localization.mjs +306 -0
  99. package/fesm2022/siemens-element-ng-localization.mjs.map +1 -0
  100. package/fesm2022/siemens-element-ng-modal.mjs +4 -1
  101. package/fesm2022/siemens-element-ng-modal.mjs.map +1 -1
  102. package/fesm2022/siemens-element-ng-password-strength.mjs +22 -16
  103. package/fesm2022/siemens-element-ng-password-strength.mjs.map +1 -1
  104. package/fesm2022/siemens-element-ng-phone-number.mjs +426 -0
  105. package/fesm2022/siemens-element-ng-phone-number.mjs.map +1 -0
  106. package/fesm2022/siemens-element-ng-photo-upload.mjs +480 -0
  107. package/fesm2022/siemens-element-ng-photo-upload.mjs.map +1 -0
  108. package/fesm2022/siemens-element-ng-result-details-list.mjs +74 -0
  109. package/fesm2022/siemens-element-ng-result-details-list.mjs.map +1 -0
  110. package/fesm2022/siemens-element-ng-search-bar.mjs +193 -0
  111. package/fesm2022/siemens-element-ng-search-bar.mjs.map +1 -0
  112. package/fesm2022/siemens-element-ng-shadow-root.mjs +70 -0
  113. package/fesm2022/siemens-element-ng-shadow-root.mjs.map +1 -0
  114. package/fesm2022/siemens-element-ng-side-panel.mjs +554 -0
  115. package/fesm2022/siemens-element-ng-side-panel.mjs.map +1 -0
  116. package/fesm2022/siemens-element-ng-slider.mjs +313 -0
  117. package/fesm2022/siemens-element-ng-slider.mjs.map +1 -0
  118. package/fesm2022/siemens-element-ng-sort-bar.mjs +89 -0
  119. package/fesm2022/siemens-element-ng-sort-bar.mjs.map +1 -0
  120. package/fesm2022/siemens-element-ng-split.mjs +575 -0
  121. package/fesm2022/siemens-element-ng-split.mjs.map +1 -0
  122. package/fesm2022/siemens-element-ng-status-bar.mjs +348 -0
  123. package/fesm2022/siemens-element-ng-status-bar.mjs.map +1 -0
  124. package/fesm2022/siemens-element-ng-status-toggle.mjs +196 -0
  125. package/fesm2022/siemens-element-ng-status-toggle.mjs.map +1 -0
  126. package/fesm2022/siemens-element-ng-system-banner.mjs +47 -0
  127. package/fesm2022/siemens-element-ng-system-banner.mjs.map +1 -0
  128. package/fesm2022/siemens-element-ng-tabs-next.mjs +491 -0
  129. package/fesm2022/siemens-element-ng-tabs-next.mjs.map +1 -0
  130. package/fesm2022/siemens-element-ng-tabs.mjs +395 -0
  131. package/fesm2022/siemens-element-ng-tabs.mjs.map +1 -0
  132. package/fesm2022/siemens-element-ng-translate.mjs.map +1 -1
  133. package/fesm2022/siemens-element-ng-tree-view.mjs +2936 -0
  134. package/fesm2022/siemens-element-ng-tree-view.mjs.map +1 -0
  135. package/fesm2022/siemens-element-ng-unauthorized-page.mjs +76 -0
  136. package/fesm2022/siemens-element-ng-unauthorized-page.mjs.map +1 -0
  137. package/fesm2022/siemens-element-ng-wizard.mjs +2 -2
  138. package/fesm2022/siemens-element-ng-wizard.mjs.map +1 -1
  139. package/file-uploader/index.d.ts +8 -0
  140. package/file-uploader/package.json +3 -0
  141. package/file-uploader/si-file-dropzone.component.d.ts +106 -0
  142. package/file-uploader/si-file-uploader.component.d.ts +296 -0
  143. package/file-uploader/si-file-uploader.model.d.ts +12 -0
  144. package/file-uploader/si-file-uploader.module.d.ts +8 -0
  145. package/filter-bar/filter.d.ts +26 -0
  146. package/filter-bar/index.d.ts +8 -0
  147. package/filter-bar/package.json +3 -0
  148. package/filter-bar/si-filter-bar.component.d.ts +65 -0
  149. package/filter-bar/si-filter-bar.module.d.ts +7 -0
  150. package/filter-bar/si-filter-pill.component.d.ts +20 -0
  151. package/filtered-search/index.d.ts +7 -0
  152. package/filtered-search/package.json +3 -0
  153. package/filtered-search/si-filtered-search-helper.d.ts +22 -0
  154. package/filtered-search/si-filtered-search-value.component.d.ts +53 -0
  155. package/filtered-search/si-filtered-search.component.d.ts +329 -0
  156. package/filtered-search/si-filtered-search.model.d.ts +139 -0
  157. package/filtered-search/si-filtered-search.module.d.ts +7 -0
  158. package/filtered-search/values/date-value/si-filtered-search-date-value.component.d.ts +57 -0
  159. package/filtered-search/values/si-filtered-search-value.base.d.ts +27 -0
  160. package/filtered-search/values/typeahead/si-filtered-search-typeahead.component.d.ts +45 -0
  161. package/formly/fields/button/si-formly-button.component.d.ts +7 -0
  162. package/formly/fields/date-range/si-formly-date-range.component.d.ts +6 -0
  163. package/formly/fields/datetime/si-formly-datetime.component.d.ts +13 -0
  164. package/formly/fields/email/si-formly-email.component.d.ts +6 -0
  165. package/formly/fields/ip-input/si-formly-ip-input.component.d.ts +6 -0
  166. package/formly/fields/number/si-formly-number.component.d.ts +6 -0
  167. package/formly/fields/password/si-formly-password.component.d.ts +6 -0
  168. package/formly/fields/select/si-formly-select.component.d.ts +6 -0
  169. package/formly/fields/text/si-formly-text-display.component.d.ts +7 -0
  170. package/formly/fields/textarea/si-formly-textarea.component.d.ts +18 -0
  171. package/formly/fields/time/si-formly-time.component.d.ts +13 -0
  172. package/formly/index.d.ts +6 -0
  173. package/formly/package.json +3 -0
  174. package/formly/si-formly-translate.extension.d.ts +11 -0
  175. package/formly/si-formly.component.d.ts +62 -0
  176. package/formly/si-formly.module.d.ts +35 -0
  177. package/formly/structural/si-formly-accordion/si-formly-accordion.component.d.ts +13 -0
  178. package/formly/structural/si-formly-array/si-formly-array.component.d.ts +6 -0
  179. package/formly/structural/si-formly-object/si-formly-object.component.d.ts +6 -0
  180. package/formly/structural/si-formly-object-grid/si-formly-object-grid.component.d.ts +22 -0
  181. package/formly/structural/si-formly-object-grid/si-formly-object-grid.model.d.ts +21 -0
  182. package/formly/structural/si-formly-object-plain/si-formly-object-plain.component.d.ts +6 -0
  183. package/formly/structural/si-formly-tabset/si-formly-object-tabset.component.d.ts +7 -0
  184. package/formly/utils.d.ts +6 -0
  185. package/formly/wrapper/si-formly-fieldset.component.d.ts +8 -0
  186. package/formly/wrapper/si-formly-form-field-provider.directive.d.ts +19 -0
  187. package/formly/wrapper/si-formly-horizontal-wrapper.component.d.ts +6 -0
  188. package/formly/wrapper/si-formly-icon-wrapper.component.d.ts +6 -0
  189. package/formly/wrapper/si-formly-wrapper.component.d.ts +8 -0
  190. package/icon/element-icons.d.ts +15 -0
  191. package/icon/si-status-icon.component.d.ts +6 -1
  192. package/info-page/index.d.ts +5 -0
  193. package/info-page/package.json +3 -0
  194. package/info-page/si-info-page.component.d.ts +38 -0
  195. package/inline-notification/si-inline-notification.component.d.ts +0 -2
  196. package/ip-input/address-utils.d.ts +28 -0
  197. package/ip-input/address-validators.d.ts +21 -0
  198. package/ip-input/index.d.ts +7 -0
  199. package/ip-input/package.json +3 -0
  200. package/ip-input/si-ip-input.directive.d.ts +53 -0
  201. package/ip-input/si-ip4-input.directive.d.ts +9 -0
  202. package/ip-input/si-ip6-input.directive.d.ts +10 -0
  203. package/list-details/index.d.ts +12 -0
  204. package/list-details/package.json +3 -0
  205. package/list-details/si-details-pane/si-details-pane.component.d.ts +8 -0
  206. package/list-details/si-details-pane-body/si-details-pane-body.component.d.ts +6 -0
  207. package/list-details/si-details-pane-footer/si-details-pane-footer.component.d.ts +6 -0
  208. package/list-details/si-details-pane-header/si-details-pane-header.component.d.ts +38 -0
  209. package/list-details/si-list-details.component.d.ts +100 -0
  210. package/list-details/si-list-pane/si-list-pane.component.d.ts +10 -0
  211. package/list-details/si-list-pane-body/si-list-pane-body.component.d.ts +6 -0
  212. package/list-details/si-list-pane-header/si-list-pane-header.component.d.ts +6 -0
  213. package/loading-spinner/si-loading-spinner.directive.d.ts +3 -2
  214. package/localization/index.d.ts +8 -0
  215. package/localization/package.json +3 -0
  216. package/localization/si-directionality.d.ts +41 -0
  217. package/localization/si-locale-id.d.ts +22 -0
  218. package/localization/si-locale-store.d.ts +16 -0
  219. package/localization/si-locale.service.d.ts +73 -0
  220. package/package.json +161 -9
  221. package/password-strength/si-password-strength.directive.d.ts +11 -0
  222. package/phone-number/index.d.ts +7 -0
  223. package/phone-number/package.json +3 -0
  224. package/phone-number/si-phone-number-input-select.directive.d.ts +10 -0
  225. package/phone-number/si-phone-number-input.component.d.ts +137 -0
  226. package/phone-number/si-phone-number-input.models.d.ts +48 -0
  227. package/phone-number/si-phone-number-input.module.d.ts +7 -0
  228. package/photo-upload/index.d.ts +6 -0
  229. package/photo-upload/package.json +3 -0
  230. package/photo-upload/si-image-cropper-style.component.d.ts +5 -0
  231. package/photo-upload/si-photo-upload.component.d.ts +298 -0
  232. package/result-details-list/index.d.ts +7 -0
  233. package/result-details-list/package.json +3 -0
  234. package/result-details-list/si-result-details-list.component.d.ts +14 -0
  235. package/result-details-list/si-result-details-list.datamodel.d.ts +48 -0
  236. package/result-details-list/si-result-details-list.module.d.ts +7 -0
  237. package/search-bar/index.d.ts +6 -0
  238. package/search-bar/package.json +3 -0
  239. package/search-bar/si-search-bar.component.d.ts +87 -0
  240. package/search-bar/si-search-bar.module.d.ts +7 -0
  241. package/shadow-root/index.d.ts +5 -0
  242. package/shadow-root/package.json +3 -0
  243. package/shadow-root/si-shadow-root.directive.d.ts +39 -0
  244. package/side-panel/index.d.ts +9 -0
  245. package/side-panel/package.json +3 -0
  246. package/side-panel/si-side-panel-content.component.d.ts +105 -0
  247. package/side-panel/si-side-panel.component.d.ts +108 -0
  248. package/side-panel/si-side-panel.module.d.ts +8 -0
  249. package/side-panel/si-side-panel.service.d.ts +45 -0
  250. package/side-panel/side-panel.model.d.ts +16 -0
  251. package/slider/index.d.ts +6 -0
  252. package/slider/package.json +3 -0
  253. package/slider/si-slider.component.d.ts +129 -0
  254. package/slider/si-slider.module.d.ts +7 -0
  255. package/sort-bar/index.d.ts +6 -0
  256. package/sort-bar/package.json +3 -0
  257. package/sort-bar/si-sort-bar.component.d.ts +42 -0
  258. package/sort-bar/si-sort-bar.module.d.ts +7 -0
  259. package/split/index.d.ts +8 -0
  260. package/split/package.json +3 -0
  261. package/split/si-split-part.component.d.ts +154 -0
  262. package/split/si-split.component.d.ts +48 -0
  263. package/split/si-split.interfaces.d.ts +17 -0
  264. package/split/si-split.module.d.ts +8 -0
  265. package/status-bar/index.d.ts +7 -0
  266. package/status-bar/package.json +3 -0
  267. package/status-bar/si-status-bar-item/index.d.ts +6 -0
  268. package/status-bar/si-status-bar-item/si-status-bar-item.component.d.ts +22 -0
  269. package/status-bar/si-status-bar-item/si-status-bar-item.model.d.ts +33 -0
  270. package/status-bar/si-status-bar.component.d.ts +116 -0
  271. package/status-bar/si-status-bar.module.d.ts +7 -0
  272. package/status-toggle/index.d.ts +6 -0
  273. package/status-toggle/package.json +3 -0
  274. package/status-toggle/si-status-toggle.component.d.ts +54 -0
  275. package/status-toggle/status-toggle.model.d.ts +26 -0
  276. package/system-banner/index.d.ts +5 -0
  277. package/system-banner/package.json +3 -0
  278. package/system-banner/system-banner.component.d.ts +23 -0
  279. package/tabs/index.d.ts +7 -0
  280. package/tabs/package.json +3 -0
  281. package/tabs/si-tab/index.d.ts +5 -0
  282. package/tabs/si-tab/si-tab.component.d.ts +58 -0
  283. package/tabs/si-tabs.module.d.ts +8 -0
  284. package/tabs/si-tabset/index.d.ts +5 -0
  285. package/tabs/si-tabset/si-tabset.component.d.ts +100 -0
  286. package/tabs-next/index.d.ts +7 -0
  287. package/tabs-next/package.json +3 -0
  288. package/tabs-next/si-tab-next-base.directive.d.ts +66 -0
  289. package/tabs-next/si-tab-next-link.component.d.ts +18 -0
  290. package/tabs-next/si-tab-next.component.d.ts +16 -0
  291. package/tabs-next/si-tabs-tokens.d.ts +7 -0
  292. package/tabs-next/si-tabset-next.component.d.ts +72 -0
  293. package/template-i18n.json +111 -0
  294. package/translate/si-translatable-keys.interface.d.ts +111 -0
  295. package/tree-view/drag-drop.util.d.ts +32 -0
  296. package/tree-view/index.d.ts +12 -0
  297. package/tree-view/package.json +3 -0
  298. package/tree-view/si-tree-view-converter.service.d.ts +41 -0
  299. package/tree-view/si-tree-view-item/si-tree-view-item.component.d.ts +105 -0
  300. package/tree-view/si-tree-view-item/si-tree-view-item.directive.d.ts +24 -0
  301. package/tree-view/si-tree-view-item-context.d.ts +11 -0
  302. package/tree-view/si-tree-view-item-height.service.d.ts +49 -0
  303. package/tree-view/si-tree-view-item-template.directive.d.ts +18 -0
  304. package/tree-view/si-tree-view-virtualization.service.d.ts +150 -0
  305. package/tree-view/si-tree-view.component.d.ts +466 -0
  306. package/tree-view/si-tree-view.model.d.ts +146 -0
  307. package/tree-view/si-tree-view.module.d.ts +10 -0
  308. package/tree-view/si-tree-view.service.d.ts +55 -0
  309. package/tree-view/si-tree-view.utils.d.ts +46 -0
  310. package/unauthorized-page/index.d.ts +6 -0
  311. package/unauthorized-page/package.json +3 -0
  312. package/unauthorized-page/si-unauthorized-page.component.d.ts +35 -0
  313. package/unauthorized-page/si-unauthorized-page.module.d.ts +7 -0
@@ -51,30 +51,36 @@ class SiPasswordStrengthDirective {
51
51
  passwordStrengthChanged = output();
52
52
  /** @internal */
53
53
  validate(control) {
54
- if (this.getStrength(control.value) >= this.maxStrength()) {
54
+ const strength = this.getStrength(control.value);
55
+ // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing
56
+ const requiredStrength = this.siPasswordStrength().minRequiredPolicies || this.maxStrength();
57
+ if (strength.length && strength.strength >= requiredStrength) {
55
58
  return {};
56
59
  }
57
60
  return { siPasswordStrength: true };
58
61
  }
59
62
  getStrength(password) {
63
+ const policy = this.siPasswordStrength();
64
+ if (!password) {
65
+ this.noValidation = false;
66
+ this.passwordStrengthChanged.emit();
67
+ return { length: false, strength: 0 };
68
+ }
60
69
  let strength = 0;
61
- if (password && password !== '') {
62
- // Strength check
63
- strength += password.length >= this.siPasswordStrength().minLength ? 1 : 0;
64
- strength += this.siPasswordStrength().uppercase && password.match(RE_UPPER_CASE) ? 1 : 0;
65
- strength += this.siPasswordStrength().lowercase && password.match(RE_LOWER_CASE) ? 1 : 0;
66
- strength += this.siPasswordStrength().digits && password.match(RE_DIGITS) ? 1 : 0;
67
- strength += this.siPasswordStrength().special && password.match(RE_SPECIAL_CHARS) ? 1 : 0;
68
- // Hard limit check
70
+ // Strength check
71
+ const length = password.length >= policy.minLength;
72
+ strength += length ? 1 : 0;
73
+ strength += policy.uppercase && password.match(RE_UPPER_CASE) ? 1 : 0;
74
+ strength += policy.lowercase && password.match(RE_LOWER_CASE) ? 1 : 0;
75
+ strength += policy.digits && password.match(RE_DIGITS) ? 1 : 0;
76
+ strength += policy.special && password.match(RE_SPECIAL_CHARS) ? 1 : 0;
77
+ if (policy.allowWhitespace !== true) {
69
78
  strength = password.match(RE_WHITESPACES) ? 0 : strength;
70
- this.noValidation = true;
71
- // Notify listeners
72
- this.passwordStrengthChanged.emit(strength - this.maxStrength());
73
- return strength;
74
79
  }
75
- this.noValidation = false;
76
- this.passwordStrengthChanged.emit();
77
- return strength;
80
+ this.noValidation = true;
81
+ // Notify listeners
82
+ this.passwordStrengthChanged.emit(strength - this.maxStrength());
83
+ return { length, strength };
78
84
  }
79
85
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiPasswordStrengthDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
80
86
  static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "19.0.6", type: SiPasswordStrengthDirective, isStandalone: true, selector: "[siPasswordStrength]", inputs: { siPasswordStrength: { classPropertyName: "siPasswordStrength", publicName: "siPasswordStrength", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { passwordStrengthChanged: "passwordStrengthChanged" }, host: { properties: { "class.no-validation": "noValidation" } }, providers: [{ provide: NG_VALIDATORS, useExisting: SiPasswordStrengthDirective, multi: true }], ngImport: i0 });
@@ -1 +1 @@
1
- {"version":3,"file":"siemens-element-ng-password-strength.mjs","sources":["../../../../projects/element-ng/password-strength/si-password-strength.directive.ts","../../../../projects/element-ng/password-strength/si-password-strength.component.ts","../../../../projects/element-ng/password-strength/si-password-strength.module.ts","../../../../projects/element-ng/password-strength/index.ts","../../../../projects/element-ng/password-strength/siemens-element-ng-password-strength.ts"],"sourcesContent":["/**\n * Copyright Siemens 2016 - 2025.\n * SPDX-License-Identifier: MIT\n */\nimport { computed, Directive, input, output } from '@angular/core';\nimport { AbstractControl, NG_VALIDATORS, ValidationErrors, Validator } from '@angular/forms';\n\nconst RE_UPPER_CASE = /[A-Z]/;\nconst RE_LOWER_CASE = /[a-z]/;\nconst RE_DIGITS = /[0-9]/;\nconst RE_SPECIAL_CHARS = /[\\x21-\\x2F|\\x3A-\\x40|\\x5B-\\x60]/;\nconst RE_WHITESPACES = /\\s/;\n\nexport interface PasswordPolicy {\n /**\n * Define minimal number of characters.\n */\n minLength: number;\n /**\n * Define if uppercase characters are required in password.\n */\n uppercase: boolean;\n /**\n * Define if lowercase characters are required in password.\n */\n lowercase: boolean;\n /**\n * Define if digits are required in password.\n */\n digits: boolean;\n /**\n * Define if special characters are required in password.\n */\n special: boolean;\n}\n\n@Directive({\n selector: '[siPasswordStrength]',\n providers: [{ provide: NG_VALIDATORS, useExisting: SiPasswordStrengthDirective, multi: true }],\n host: {\n '[class.no-validation]': 'noValidation'\n }\n})\nexport class SiPasswordStrengthDirective implements Validator {\n private readonly maxStrength = computed(() => {\n const strength = this.siPasswordStrength();\n return (\n 1 +\n (strength.uppercase ? 1 : 0) +\n (strength.lowercase ? 1 : 0) +\n (strength.digits ? 1 : 0) +\n (strength.special ? 1 : 0)\n );\n });\n\n protected noValidation = false;\n\n /**\n * Define Siemens password strength.\n *\n * @defaultValue\n * ```\n * {\n * minLength: 8,\n * uppercase: true,\n * lowercase: true,\n * digits: true,\n * special: true\n * }\n * ```\n */\n readonly siPasswordStrength = input<PasswordPolicy>({\n minLength: 8,\n uppercase: true,\n lowercase: true,\n digits: true,\n special: true\n });\n\n /**\n * Output callback event called when the password changes. The number\n * indicated the number of rules which still can be met. (`-2` --\\> 2 rules are\n * still unmet, `0` --\\> all met)\n */\n readonly passwordStrengthChanged = output<number | void>();\n\n /** @internal */\n validate(control: AbstractControl): ValidationErrors {\n if (this.getStrength(control.value) >= this.maxStrength()) {\n return {};\n }\n return { siPasswordStrength: true };\n }\n\n private getStrength(password: string): number {\n let strength = 0;\n if (password && password !== '') {\n // Strength check\n strength += password.length >= this.siPasswordStrength().minLength ? 1 : 0;\n strength += this.siPasswordStrength().uppercase && password.match(RE_UPPER_CASE) ? 1 : 0;\n strength += this.siPasswordStrength().lowercase && password.match(RE_LOWER_CASE) ? 1 : 0;\n strength += this.siPasswordStrength().digits && password.match(RE_DIGITS) ? 1 : 0;\n strength += this.siPasswordStrength().special && password.match(RE_SPECIAL_CHARS) ? 1 : 0;\n // Hard limit check\n strength = password.match(RE_WHITESPACES) ? 0 : strength;\n this.noValidation = true;\n // Notify listeners\n this.passwordStrengthChanged.emit(strength - this.maxStrength());\n return strength;\n }\n this.noValidation = false;\n this.passwordStrengthChanged.emit();\n return strength;\n }\n}\n","/**\n * Copyright Siemens 2016 - 2025.\n * SPDX-License-Identifier: MIT\n */\nimport {\n AfterViewInit,\n Component,\n contentChildren,\n ElementRef,\n inject,\n input,\n signal\n} from '@angular/core';\nimport { SiPasswordToggleComponent } from '@siemens/element-ng/password-toggle';\n\nimport { SiPasswordStrengthDirective } from './si-password-strength.directive';\n\n@Component({\n selector: 'si-password-strength',\n template: `\n <si-password-toggle [showVisibilityIcon]=\"showVisibilityIcon()\" (typeChange)=\"toggle($event)\">\n <ng-content />\n </si-password-toggle>\n `,\n styleUrl: './si-password-strength.component.scss',\n imports: [SiPasswordToggleComponent],\n host: {\n '[class.bad]': 'bad()',\n '[class.weak]': 'weak()',\n '[class.medium]': 'medium()',\n '[class.good]': 'good()',\n '[class.strong]': 'strong()'\n }\n})\nexport class SiPasswordStrengthComponent implements AfterViewInit {\n /**\n * Whether to show the visibility toggle icon.\n *\n * @defaultValue true\n */\n readonly showVisibilityIcon = input(true);\n\n private readonly passwordStrengthDirective = contentChildren(SiPasswordStrengthDirective);\n private elRef = inject(ElementRef);\n\n protected readonly bad = signal(false);\n protected readonly weak = signal(false);\n protected readonly medium = signal(false);\n protected readonly good = signal(false);\n protected readonly strong = signal(false);\n\n protected toggle(type: string): void {\n const inputEl = this.elRef.nativeElement.querySelector('input');\n if (inputEl) {\n inputEl.type = type;\n }\n }\n\n ngAfterViewInit(): void {\n this.passwordStrengthDirective().forEach(directive => {\n directive.passwordStrengthChanged.subscribe((strength: number | void) => {\n this.strong.set(strength === 0);\n this.good.set(strength === -1);\n this.medium.set(strength === -2);\n this.weak.set(strength === -3);\n this.bad.set(strength === -4);\n });\n });\n }\n}\n","/**\n * Copyright Siemens 2016 - 2025.\n * SPDX-License-Identifier: MIT\n */\nimport { NgModule } from '@angular/core';\n\nimport { SiPasswordStrengthComponent } from './si-password-strength.component';\nimport { SiPasswordStrengthDirective } from './si-password-strength.directive';\n\n@NgModule({\n imports: [SiPasswordStrengthComponent, SiPasswordStrengthDirective],\n exports: [SiPasswordStrengthComponent, SiPasswordStrengthDirective]\n})\nexport class SiPasswordStrengthModule {}\n","/**\n * Copyright Siemens 2016 - 2025.\n * SPDX-License-Identifier: MIT\n */\nexport * from './si-password-strength.component';\nexport * from './si-password-strength.directive';\nexport * from './si-password-strength.module';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;AAAA;;;AAGG;AAIH,MAAM,aAAa,GAAG,OAAO;AAC7B,MAAM,aAAa,GAAG,OAAO;AAC7B,MAAM,SAAS,GAAG,OAAO;AACzB,MAAM,gBAAgB,GAAG,iCAAiC;AAC1D,MAAM,cAAc,GAAG,IAAI;MAgCd,2BAA2B,CAAA;AACrB,IAAA,WAAW,GAAG,QAAQ,CAAC,MAAK;AAC3C,QAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,kBAAkB,EAAE;AAC1C,QAAA,QACE,CAAC;aACA,QAAQ,CAAC,SAAS,GAAG,CAAC,GAAG,CAAC,CAAC;aAC3B,QAAQ,CAAC,SAAS,GAAG,CAAC,GAAG,CAAC,CAAC;aAC3B,QAAQ,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC;AACzB,aAAC,QAAQ,CAAC,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC;AAE9B,KAAC,CAAC;IAEQ,YAAY,GAAG,KAAK;AAE9B;;;;;;;;;;;;;AAaG;IACM,kBAAkB,GAAG,KAAK,CAAiB;AAClD,QAAA,SAAS,EAAE,CAAC;AACZ,QAAA,SAAS,EAAE,IAAI;AACf,QAAA,SAAS,EAAE,IAAI;AACf,QAAA,MAAM,EAAE,IAAI;AACZ,QAAA,OAAO,EAAE;AACV,KAAA,CAAC;AAEF;;;;AAIG;IACM,uBAAuB,GAAG,MAAM,EAAiB;;AAG1D,IAAA,QAAQ,CAAC,OAAwB,EAAA;AAC/B,QAAA,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE;AACzD,YAAA,OAAO,EAAE;;AAEX,QAAA,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAE;;AAG7B,IAAA,WAAW,CAAC,QAAgB,EAAA;QAClC,IAAI,QAAQ,GAAG,CAAC;AAChB,QAAA,IAAI,QAAQ,IAAI,QAAQ,KAAK,EAAE,EAAE;;AAE/B,YAAA,QAAQ,IAAI,QAAQ,CAAC,MAAM,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC,SAAS,GAAG,CAAC,GAAG,CAAC;YAC1E,QAAQ,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC,SAAS,IAAI,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC;YACxF,QAAQ,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC,SAAS,IAAI,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC;YACxF,QAAQ,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC,MAAM,IAAI,QAAQ,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC;YACjF,QAAQ,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC,OAAO,IAAI,QAAQ,CAAC,KAAK,CAAC,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC;;AAEzF,YAAA,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,QAAQ;AACxD,YAAA,IAAI,CAAC,YAAY,GAAG,IAAI;;AAExB,YAAA,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;AAChE,YAAA,OAAO,QAAQ;;AAEjB,QAAA,IAAI,CAAC,YAAY,GAAG,KAAK;AACzB,QAAA,IAAI,CAAC,uBAAuB,CAAC,IAAI,EAAE;AACnC,QAAA,OAAO,QAAQ;;uGArEN,2BAA2B,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;AAA3B,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,2BAA2B,EAL3B,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,sBAAA,EAAA,MAAA,EAAA,EAAA,kBAAA,EAAA,EAAA,iBAAA,EAAA,oBAAA,EAAA,UAAA,EAAA,oBAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,EAAA,OAAA,EAAA,EAAA,uBAAA,EAAA,yBAAA,EAAA,EAAA,IAAA,EAAA,EAAA,UAAA,EAAA,EAAA,qBAAA,EAAA,cAAA,EAAA,EAAA,EAAA,SAAA,EAAA,CAAC,EAAE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,2BAA2B,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA;;2FAKnF,2BAA2B,EAAA,UAAA,EAAA,CAAA;kBAPvC,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACT,oBAAA,QAAQ,EAAE,sBAAsB;AAChC,oBAAA,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAA,2BAA6B,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;AAC9F,oBAAA,IAAI,EAAE;AACJ,wBAAA,uBAAuB,EAAE;AAC1B;AACF,iBAAA;;;AC1CD;;;AAGG;MA+BU,2BAA2B,CAAA;AACtC;;;;AAIG;AACM,IAAA,kBAAkB,GAAG,KAAK,CAAC,IAAI,CAAC;AAExB,IAAA,yBAAyB,GAAG,eAAe,CAAC,2BAA2B,CAAC;AACjF,IAAA,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC;AAEf,IAAA,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC;AACnB,IAAA,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC;AACpB,IAAA,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC;AACtB,IAAA,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC;AACpB,IAAA,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC;AAE/B,IAAA,MAAM,CAAC,IAAY,EAAA;AAC3B,QAAA,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,CAAC;QAC/D,IAAI,OAAO,EAAE;AACX,YAAA,OAAO,CAAC,IAAI,GAAG,IAAI;;;IAIvB,eAAe,GAAA;QACb,IAAI,CAAC,yBAAyB,EAAE,CAAC,OAAO,CAAC,SAAS,IAAG;YACnD,SAAS,CAAC,uBAAuB,CAAC,SAAS,CAAC,CAAC,QAAuB,KAAI;gBACtE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,KAAK,CAAC,CAAC;gBAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC;gBAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC;gBAChC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC;gBAC9B,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC;AAC/B,aAAC,CAAC;AACJ,SAAC,CAAC;;uGAjCO,2BAA2B,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;2FAA3B,2BAA2B,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,sBAAA,EAAA,MAAA,EAAA,EAAA,kBAAA,EAAA,EAAA,iBAAA,EAAA,oBAAA,EAAA,UAAA,EAAA,oBAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,EAAA,IAAA,EAAA,EAAA,UAAA,EAAA,EAAA,WAAA,EAAA,OAAA,EAAA,YAAA,EAAA,QAAA,EAAA,cAAA,EAAA,UAAA,EAAA,YAAA,EAAA,QAAA,EAAA,cAAA,EAAA,UAAA,EAAA,EAAA,EAAA,OAAA,EAAA,CAAA,EAAA,YAAA,EAAA,2BAAA,EAAA,SAAA,EAQuB,2BAA2B,EAvB9E,QAAA,EAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EAAA;;;;AAIT,EAAA,CAAA,EAAA,QAAA,EAAA,IAAA,EAAA,MAAA,EAAA,CAAA,u8BAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAES,yBAAyB,EAAA,QAAA,EAAA,oBAAA,EAAA,MAAA,EAAA,CAAA,oBAAA,EAAA,WAAA,EAAA,WAAA,CAAA,EAAA,OAAA,EAAA,CAAA,YAAA,CAAA,EAAA,CAAA,EAAA,CAAA;;2FASxB,2BAA2B,EAAA,UAAA,EAAA,CAAA;kBAjBvC,SAAS;AACE,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,sBAAsB,EACtB,QAAA,EAAA;;;;GAIT,EAEQ,OAAA,EAAA,CAAC,yBAAyB,CAAC,EAC9B,IAAA,EAAA;AACJ,wBAAA,aAAa,EAAE,OAAO;AACtB,wBAAA,cAAc,EAAE,QAAQ;AACxB,wBAAA,gBAAgB,EAAE,UAAU;AAC5B,wBAAA,cAAc,EAAE,QAAQ;AACxB,wBAAA,gBAAgB,EAAE;AACnB,qBAAA,EAAA,MAAA,EAAA,CAAA,u8BAAA,CAAA,EAAA;;;AChCH;;;AAGG;MAUU,wBAAwB,CAAA;uGAAxB,wBAAwB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,QAAA,EAAA,CAAA;AAAxB,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,wBAAwB,YAHzB,2BAA2B,EAAE,2BAA2B,CACxD,EAAA,OAAA,EAAA,CAAA,2BAA2B,EAAE,2BAA2B,CAAA,EAAA,CAAA;AAEvD,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,wBAAwB,YAHzB,2BAA2B,CAAA,EAAA,CAAA;;2FAG1B,wBAAwB,EAAA,UAAA,EAAA,CAAA;kBAJpC,QAAQ;AAAC,YAAA,IAAA,EAAA,CAAA;AACR,oBAAA,OAAO,EAAE,CAAC,2BAA2B,EAAE,2BAA2B,CAAC;AACnE,oBAAA,OAAO,EAAE,CAAC,2BAA2B,EAAE,2BAA2B;AACnE,iBAAA;;;ACZD;;;AAGG;;ACHH;;AAEG;;;;"}
1
+ {"version":3,"file":"siemens-element-ng-password-strength.mjs","sources":["../../../../projects/element-ng/password-strength/si-password-strength.directive.ts","../../../../projects/element-ng/password-strength/si-password-strength.component.ts","../../../../projects/element-ng/password-strength/si-password-strength.module.ts","../../../../projects/element-ng/password-strength/index.ts","../../../../projects/element-ng/password-strength/siemens-element-ng-password-strength.ts"],"sourcesContent":["/**\n * Copyright Siemens 2016 - 2025.\n * SPDX-License-Identifier: MIT\n */\nimport { computed, Directive, input, output } from '@angular/core';\nimport { AbstractControl, NG_VALIDATORS, ValidationErrors, Validator } from '@angular/forms';\n\nconst RE_UPPER_CASE = /[A-Z]/;\nconst RE_LOWER_CASE = /[a-z]/;\nconst RE_DIGITS = /[0-9]/;\nconst RE_SPECIAL_CHARS = /[\\x21-\\x2F|\\x3A-\\x40|\\x5B-\\x60]/;\nconst RE_WHITESPACES = /\\s/;\n\nexport interface PasswordPolicy {\n /**\n * Define minimal number of characters.\n */\n minLength: number;\n /**\n * Define if uppercase characters are required in password.\n */\n uppercase: boolean;\n /**\n * Define if lowercase characters are required in password.\n */\n lowercase: boolean;\n /**\n * Define if digits are required in password.\n */\n digits: boolean;\n /**\n * Define if special characters are required in password.\n */\n special: boolean;\n /**\n * Whether to allow whitespaces. By default whitespaces are not allowed.\n */\n allowWhitespace?: boolean;\n /**\n * Minimum required policies for valid password. When set to a number greater than 0,\n * defines the number of policies that must be met for the password to be valid.\n * E.g. when set to 3 and the policies uppercase/lowercase/digits/special are all set\n * and the password contains 3 out of these four, the password will be valid.\n */\n minRequiredPolicies?: number;\n}\n\ninterface StrengthCheck {\n length: boolean;\n strength: number;\n}\n\n@Directive({\n selector: '[siPasswordStrength]',\n providers: [{ provide: NG_VALIDATORS, useExisting: SiPasswordStrengthDirective, multi: true }],\n host: {\n '[class.no-validation]': 'noValidation'\n }\n})\nexport class SiPasswordStrengthDirective implements Validator {\n private readonly maxStrength = computed(() => {\n const strength = this.siPasswordStrength();\n return (\n 1 +\n (strength.uppercase ? 1 : 0) +\n (strength.lowercase ? 1 : 0) +\n (strength.digits ? 1 : 0) +\n (strength.special ? 1 : 0)\n );\n });\n\n protected noValidation = false;\n\n /**\n * Define Siemens password strength.\n *\n * @defaultValue\n * ```\n * {\n * minLength: 8,\n * uppercase: true,\n * lowercase: true,\n * digits: true,\n * special: true\n * }\n * ```\n */\n readonly siPasswordStrength = input<PasswordPolicy>({\n minLength: 8,\n uppercase: true,\n lowercase: true,\n digits: true,\n special: true\n });\n\n /**\n * Output callback event called when the password changes. The number\n * indicated the number of rules which still can be met. (`-2` --\\> 2 rules are\n * still unmet, `0` --\\> all met)\n */\n readonly passwordStrengthChanged = output<number | void>();\n\n /** @internal */\n validate(control: AbstractControl): ValidationErrors {\n const strength = this.getStrength(control.value);\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n const requiredStrength = this.siPasswordStrength().minRequiredPolicies || this.maxStrength();\n if (strength.length && strength.strength >= requiredStrength) {\n return {};\n }\n return { siPasswordStrength: true };\n }\n\n private getStrength(password: string): StrengthCheck {\n const policy = this.siPasswordStrength();\n if (!password) {\n this.noValidation = false;\n this.passwordStrengthChanged.emit();\n return { length: false, strength: 0 };\n }\n\n let strength = 0;\n // Strength check\n const length = password.length >= policy.minLength;\n strength += length ? 1 : 0;\n strength += policy.uppercase && password.match(RE_UPPER_CASE) ? 1 : 0;\n strength += policy.lowercase && password.match(RE_LOWER_CASE) ? 1 : 0;\n strength += policy.digits && password.match(RE_DIGITS) ? 1 : 0;\n strength += policy.special && password.match(RE_SPECIAL_CHARS) ? 1 : 0;\n if (policy.allowWhitespace !== true) {\n strength = password.match(RE_WHITESPACES) ? 0 : strength;\n }\n this.noValidation = true;\n // Notify listeners\n this.passwordStrengthChanged.emit(strength - this.maxStrength());\n return { length, strength };\n }\n}\n","/**\n * Copyright Siemens 2016 - 2025.\n * SPDX-License-Identifier: MIT\n */\nimport {\n AfterViewInit,\n Component,\n contentChildren,\n ElementRef,\n inject,\n input,\n signal\n} from '@angular/core';\nimport { SiPasswordToggleComponent } from '@siemens/element-ng/password-toggle';\n\nimport { SiPasswordStrengthDirective } from './si-password-strength.directive';\n\n@Component({\n selector: 'si-password-strength',\n template: `\n <si-password-toggle [showVisibilityIcon]=\"showVisibilityIcon()\" (typeChange)=\"toggle($event)\">\n <ng-content />\n </si-password-toggle>\n `,\n styleUrl: './si-password-strength.component.scss',\n imports: [SiPasswordToggleComponent],\n host: {\n '[class.bad]': 'bad()',\n '[class.weak]': 'weak()',\n '[class.medium]': 'medium()',\n '[class.good]': 'good()',\n '[class.strong]': 'strong()'\n }\n})\nexport class SiPasswordStrengthComponent implements AfterViewInit {\n /**\n * Whether to show the visibility toggle icon.\n *\n * @defaultValue true\n */\n readonly showVisibilityIcon = input(true);\n\n private readonly passwordStrengthDirective = contentChildren(SiPasswordStrengthDirective);\n private elRef = inject(ElementRef);\n\n protected readonly bad = signal(false);\n protected readonly weak = signal(false);\n protected readonly medium = signal(false);\n protected readonly good = signal(false);\n protected readonly strong = signal(false);\n\n protected toggle(type: string): void {\n const inputEl = this.elRef.nativeElement.querySelector('input');\n if (inputEl) {\n inputEl.type = type;\n }\n }\n\n ngAfterViewInit(): void {\n this.passwordStrengthDirective().forEach(directive => {\n directive.passwordStrengthChanged.subscribe((strength: number | void) => {\n this.strong.set(strength === 0);\n this.good.set(strength === -1);\n this.medium.set(strength === -2);\n this.weak.set(strength === -3);\n this.bad.set(strength === -4);\n });\n });\n }\n}\n","/**\n * Copyright Siemens 2016 - 2025.\n * SPDX-License-Identifier: MIT\n */\nimport { NgModule } from '@angular/core';\n\nimport { SiPasswordStrengthComponent } from './si-password-strength.component';\nimport { SiPasswordStrengthDirective } from './si-password-strength.directive';\n\n@NgModule({\n imports: [SiPasswordStrengthComponent, SiPasswordStrengthDirective],\n exports: [SiPasswordStrengthComponent, SiPasswordStrengthDirective]\n})\nexport class SiPasswordStrengthModule {}\n","/**\n * Copyright Siemens 2016 - 2025.\n * SPDX-License-Identifier: MIT\n */\nexport * from './si-password-strength.component';\nexport * from './si-password-strength.directive';\nexport * from './si-password-strength.module';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,426 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Directive, inject, ChangeDetectorRef, ElementRef, input, model, booleanAttribute, output, viewChild, signal, computed, ChangeDetectionStrategy, Component, NgModule } from '@angular/core';
3
+ import { CdkOverlayOrigin, CdkConnectedOverlay } from '@angular/cdk/overlay';
4
+ import { NgClass } from '@angular/common';
5
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
6
+ import { SI_FORM_ITEM_CONTROL } from '@siemens/element-ng/form';
7
+ import { addIcons, elementDown2, SiIconNextComponent } from '@siemens/element-ng/icon';
8
+ import * as i1 from '@siemens/element-ng/select';
9
+ import { SiSelectComplexOptionsDirective, SiSelectSingleValueDirective, SiSelectListHasFilterComponent } from '@siemens/element-ng/select';
10
+ import * as i1$1 from '@siemens/element-translate-ng/translate';
11
+ import { SiTranslateService, SiTranslateModule } from '@siemens/element-translate-ng/translate';
12
+ import { PhoneNumberUtil, PhoneNumberFormat } from 'google-libphonenumber';
13
+
14
+ /**
15
+ * Copyright Siemens 2016 - 2025.
16
+ * SPDX-License-Identifier: MIT
17
+ */
18
+ /**
19
+ * This directive provides the si-select options and value strategy for the phone number input.
20
+ * As we don't use si-select directly, we need to provide these strategies manually.
21
+ */
22
+ class SiPhoneNumberInputSelectDirective {
23
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiPhoneNumberInputSelectDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
24
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.6", type: SiPhoneNumberInputSelectDirective, isStandalone: true, selector: "[siPhoneNumberInputSelect]", hostDirectives: [{ directive: i1.SiSelectComplexOptionsDirective, inputs: ["complexOptions", "complexOptions", "valueProvider", "valueProvider"] }, { directive: i1.SiSelectSingleValueDirective, inputs: ["value", "value"], outputs: ["valueChange", "valueChange"] }], ngImport: i0 });
25
+ }
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiPhoneNumberInputSelectDirective, decorators: [{
27
+ type: Directive,
28
+ args: [{
29
+ selector: '[siPhoneNumberInputSelect]',
30
+ hostDirectives: [
31
+ {
32
+ directive: SiSelectComplexOptionsDirective,
33
+ inputs: ['complexOptions', 'valueProvider']
34
+ },
35
+ { directive: SiSelectSingleValueDirective, inputs: ['value'], outputs: ['valueChange'] }
36
+ ]
37
+ }]
38
+ }] });
39
+
40
+ /**
41
+ * Copyright Siemens 2016 - 2025.
42
+ * SPDX-License-Identifier: MIT
43
+ */
44
+ class SiPhoneNumberInputComponent {
45
+ static idCounter = 0;
46
+ phoneUtil = PhoneNumberUtil.getInstance();
47
+ translate = inject(SiTranslateService);
48
+ changeDetectorRef = inject(ChangeDetectorRef);
49
+ elementRef = inject(ElementRef);
50
+ /**
51
+ * Unique identifier.
52
+ *
53
+ * @defaultValue
54
+ * ```
55
+ * `__si-phone-number-input-${SiPhoneNumberInputComponent.idCounter++}`
56
+ * ```
57
+ */
58
+ id = input(`__si-phone-number-input-${SiPhoneNumberInputComponent.idCounter++}`);
59
+ /**
60
+ * ISO_3166-2 Code of the selected country.
61
+ */
62
+ country = model();
63
+ /**
64
+ * ISO_3166-2 Code of the country which shall be used on form-control reset.
65
+ */
66
+ defaultCountry = input();
67
+ /**
68
+ * Placeholder text for country search input.
69
+ *
70
+ * @defaultValue
71
+ * ```
72
+ * $localize`:@@SI_PHONE_NUMBER_INPUT.SEARCH_PLACEHOLDER:Search`
73
+ * ```
74
+ */
75
+ placeholderForSearch = input($localize `:@@SI_PHONE_NUMBER_INPUT.SEARCH_PLACEHOLDER:Search`);
76
+ /**
77
+ * @defaultValue
78
+ * ```
79
+ * $localize`:@@SI_PHONE_NUMBER_INPUT.SEARCH_NO-RESULTS_FOUND:No results found`
80
+ * ```
81
+ */
82
+ searchNoResultsFoundLabel = input($localize `:@@SI_PHONE_NUMBER_INPUT.SEARCH_NO-RESULTS_FOUND:No results found`);
83
+ /**
84
+ * Text for the country dropdown aria-label attribute.
85
+ *
86
+ * @defaultValue
87
+ * ```
88
+ * $localize`:@@SI_PHONE_NUMBER_INPUT.SELECT_COUNTRY:Select country`
89
+ * ```
90
+ */
91
+ selectCountryAriaLabel = input($localize `:@@SI_PHONE_NUMBER_INPUT.SELECT_COUNTRY:Select country`);
92
+ /**
93
+ * Text for the phone number input aria-label attribute.
94
+ *
95
+ * @defaultValue
96
+ * ```
97
+ * $localize`:@@SI_PHONE_NUMBER_INPUT.PHONE_NUMBER_INPUT_LABEL:Enter phone number`
98
+ * ```
99
+ */
100
+ phoneNumberAriaLabel = input($localize `:@@SI_PHONE_NUMBER_INPUT.PHONE_NUMBER_INPUT_LABEL:Enter phone number`);
101
+ /**
102
+ * List of countries in ISO2 format, from which the user is allowed to select one.
103
+ * If no values are provided, the dropdown will show all known countries.
104
+ */
105
+ supportedCountries = input();
106
+ /**
107
+ * @defaultValue
108
+ * ```
109
+ * `${this.id()}-label`
110
+ * ```
111
+ */
112
+ labelledby = input(`${this.id()}-label`);
113
+ /** @defaultValue false */
114
+ // eslint-disable-next-line @angular-eslint/no-input-rename
115
+ disabledInput = input(false, { alias: 'disabled', transform: booleanAttribute });
116
+ /** @defaultValue false */
117
+ readonly = input(false, { transform: booleanAttribute });
118
+ valueChange = output();
119
+ /** @internal */
120
+ errormessageId = `${this.id()}-errormessage`;
121
+ phoneInput = viewChild.required('phoneInput');
122
+ selectedCountry;
123
+ placeholder = '';
124
+ countryFocused = signal(false);
125
+ open = false;
126
+ overlayWidth = 0;
127
+ disabled = computed(() => this.disabledInput() || this.disabledNgControl());
128
+ countryList = computed(() => {
129
+ const countries = this.allowedCountries() ?? this.phoneUtil.getSupportedRegions();
130
+ return countries
131
+ .map((country) => ({
132
+ name: this.getCountryName(country),
133
+ countryCode: this.phoneUtil.getCountryCodeForRegion(country),
134
+ isoCode: country
135
+ }))
136
+ .sort((a, b) => a.name.localeCompare(b.name));
137
+ });
138
+ icons = addIcons({ elementDown2 });
139
+ allowedCountries = computed(() => this.supportedCountries() ?? this.phoneUtil.getSupportedRegions());
140
+ disabledNgControl = signal(false);
141
+ isValidNumber = true;
142
+ phoneNumber;
143
+ onChange = () => { };
144
+ onTouched = () => { };
145
+ ngOnChanges(changes) {
146
+ if (changes.country) {
147
+ this.writeCountry();
148
+ }
149
+ }
150
+ /** @internal */
151
+ writeValue(value) {
152
+ this.phoneNumber = this.parseNumber(value);
153
+ if (this.phoneNumber) {
154
+ this.writeValueToInput();
155
+ this.country.set(this.getRegionCode());
156
+ }
157
+ else {
158
+ // Number could not be parsed, write raw value instead to handle cases like undefined
159
+ this.writeTextToInput(value);
160
+ this.country.set(this.defaultCountry() ?? this.country());
161
+ }
162
+ this.writeCountry();
163
+ this.changeDetectorRef.markForCheck();
164
+ }
165
+ /** @internal */
166
+ registerOnChange(fn) {
167
+ this.onChange = fn;
168
+ }
169
+ /** @internal */
170
+ registerOnTouched(fn) {
171
+ this.onTouched = fn;
172
+ }
173
+ /** @internal */
174
+ setDisabledState(isDisabled) {
175
+ this.disabledNgControl.set(isDisabled);
176
+ }
177
+ /** @internal */
178
+ validate(control) {
179
+ if (!this.phoneInput().nativeElement.value) {
180
+ return null;
181
+ }
182
+ this.isValidNumber = false;
183
+ if (!this.phoneNumber || !this.phoneUtil.isValidNumber(this.phoneNumber)) {
184
+ return {
185
+ invalidPhoneNumberFormat: true
186
+ };
187
+ }
188
+ if (!this.countryList().some(c => c.isoCode === this.selectedCountry.isoCode)) {
189
+ return {
190
+ notSupportedPhoneNumberCountry: true
191
+ };
192
+ }
193
+ this.isValidNumber = true;
194
+ return null;
195
+ }
196
+ input() {
197
+ const rawNumber = this.phoneInput().nativeElement.value;
198
+ this.phoneNumber = this.parseNumber(rawNumber);
199
+ if (this.phoneNumber) {
200
+ const regionCode = this.getRegionCode();
201
+ let countryInfo = this.countryList().find(country => regionCode === country.isoCode);
202
+ if (!countryInfo && regionCode) {
203
+ countryInfo = {
204
+ name: this.getCountryName(regionCode),
205
+ countryCode: this.phoneNumber.getCountryCode(),
206
+ isoCode: regionCode
207
+ };
208
+ }
209
+ if (countryInfo && this.selectedCountry?.isoCode !== countryInfo.isoCode) {
210
+ this.selectedCountry = countryInfo;
211
+ }
212
+ }
213
+ else if (rawNumber.trim().startsWith('+')) {
214
+ this.selectedCountry = undefined;
215
+ }
216
+ this.handleChange();
217
+ }
218
+ blur() {
219
+ this.countryFocused.set(false);
220
+ this.onTouched();
221
+ this.writeValueToInput();
222
+ this.valueChange.emit({
223
+ country: this.selectedCountry,
224
+ phoneNumber: this.formatPhoneNumber(PhoneNumberFormat.INTERNATIONAL),
225
+ isValid: this.isValidNumber
226
+ });
227
+ }
228
+ countryInput(num) {
229
+ this.selectedCountry = num;
230
+ this.updatePlaceholder();
231
+ this.refreshValueAfterCountryChange();
232
+ this.handleChange();
233
+ }
234
+ openOverlay() {
235
+ if (!this.readonly()) {
236
+ this.open = true;
237
+ this.overlayWidth = this.elementRef.nativeElement.getBoundingClientRect().width + 2; // 2px border
238
+ }
239
+ }
240
+ overlayDetach() {
241
+ this.open = false;
242
+ this.phoneInput().nativeElement.focus();
243
+ }
244
+ valueProvider(country) {
245
+ return `${country.name} +${country.countryCode}`;
246
+ }
247
+ writeCountry() {
248
+ const currentCountry = this.country();
249
+ this.selectedCountry = this.countryList().find(country => country.isoCode === currentCountry);
250
+ if (!this.selectedCountry) {
251
+ const countryCode = this.phoneUtil.getCountryCodeForRegion(currentCountry ?? this.defaultCountry() ?? 'XX');
252
+ if (countryCode) {
253
+ this.selectedCountry = {
254
+ isoCode: currentCountry,
255
+ countryCode,
256
+ name: this.getCountryName(currentCountry)
257
+ };
258
+ }
259
+ }
260
+ this.updatePlaceholder();
261
+ this.refreshValueAfterCountryChange();
262
+ }
263
+ getCountryName(countryCode) {
264
+ // This auto translates the given country name to the selected locale language
265
+ return (new Intl.DisplayNames([this.translate.currentLanguage], { type: 'region' }).of(countryCode.toUpperCase()) ?? '');
266
+ }
267
+ updatePlaceholder() {
268
+ if (this.selectedCountry) {
269
+ this.placeholder = this.phoneUtil
270
+ .format(this.phoneUtil.getExampleNumber(this.selectedCountry.isoCode), PhoneNumberFormat.NATIONAL)
271
+ .replace(/^0/, '');
272
+ }
273
+ }
274
+ parseNumber(rawNumber) {
275
+ try {
276
+ let regionCodeForParsing;
277
+ if (!rawNumber?.trim().startsWith('+')) {
278
+ regionCodeForParsing = this.selectedCountry?.isoCode;
279
+ }
280
+ return this.phoneUtil.parse(rawNumber, regionCodeForParsing);
281
+ }
282
+ catch (e) {
283
+ // The Number is too short, we cannot parse it yet. Error can be ignored. Hopefully, the user enters more digits.
284
+ return;
285
+ }
286
+ }
287
+ /**
288
+ * PhoneUtil does not resolve country code early enough when the national prefix is shared among other countries (+1 and +44).
289
+ * This Method fakes a complete number to force PhoneUtil returning a proper region code.
290
+ */
291
+ getRegionCode() {
292
+ if (this.phoneNumber) {
293
+ const regionCode = this.phoneUtil.getRegionCodeForNumber(this.phoneNumber);
294
+ if (regionCode) {
295
+ return regionCode;
296
+ }
297
+ const nationalNumber = this.phoneNumber.getNationalNumber() + '';
298
+ if (
299
+ // USA, CANADA, ...
300
+ (this.phoneNumber.getCountryCode() === 1 && nationalNumber.length >= 3) ||
301
+ // UK, ...
302
+ (this.phoneNumber.getCountryCode() === 44 && nationalNumber.length >= 4)) {
303
+ return this.phoneUtil.getRegionCodeForNumber(this.phoneUtil.parse('+' +
304
+ this.phoneNumber.getCountryCode() +
305
+ nationalNumber +
306
+ new Array(10 - nationalNumber.length).fill(5).join('')));
307
+ }
308
+ return this.phoneUtil.getRegionCodeForCountryCode(this.phoneNumber.getCountryCode());
309
+ }
310
+ return undefined;
311
+ }
312
+ formatPhoneNumber(format) {
313
+ if (this.phoneNumber) {
314
+ return this.phoneUtil.format(this.phoneNumber, format);
315
+ }
316
+ return undefined;
317
+ }
318
+ handleChange() {
319
+ if (this.selectedCountry && this.country() !== this.selectedCountry?.isoCode) {
320
+ this.country.set(this.selectedCountry?.isoCode);
321
+ }
322
+ if (this.phoneNumber) {
323
+ this.onChange(this.formatPhoneNumber(PhoneNumberFormat.INTERNATIONAL));
324
+ }
325
+ else {
326
+ this.onChange('');
327
+ }
328
+ }
329
+ writeTextToInput(value) {
330
+ this.phoneInput().nativeElement.value = value ?? '';
331
+ }
332
+ /**
333
+ * Format and update input text or clear input text if the input value is undefined.
334
+ */
335
+ writeValueToInput() {
336
+ if (this.phoneNumber) {
337
+ this.writeTextToInput(this.formatPhoneNumber(PhoneNumberFormat.NATIONAL).replace(/^0/, ''));
338
+ }
339
+ }
340
+ refreshValueAfterCountryChange() {
341
+ if (this.selectedCountry) {
342
+ this.phoneNumber?.setCountryCode(this.selectedCountry?.countryCode);
343
+ this.writeValueToInput();
344
+ }
345
+ }
346
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiPhoneNumberInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
347
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.6", type: SiPhoneNumberInputComponent, isStandalone: true, selector: "si-phone-number-input", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, country: { classPropertyName: "country", publicName: "country", isSignal: true, isRequired: false, transformFunction: null }, defaultCountry: { classPropertyName: "defaultCountry", publicName: "defaultCountry", isSignal: true, isRequired: false, transformFunction: null }, placeholderForSearch: { classPropertyName: "placeholderForSearch", publicName: "placeholderForSearch", isSignal: true, isRequired: false, transformFunction: null }, searchNoResultsFoundLabel: { classPropertyName: "searchNoResultsFoundLabel", publicName: "searchNoResultsFoundLabel", isSignal: true, isRequired: false, transformFunction: null }, selectCountryAriaLabel: { classPropertyName: "selectCountryAriaLabel", publicName: "selectCountryAriaLabel", isSignal: true, isRequired: false, transformFunction: null }, phoneNumberAriaLabel: { classPropertyName: "phoneNumberAriaLabel", publicName: "phoneNumberAriaLabel", isSignal: true, isRequired: false, transformFunction: null }, supportedCountries: { classPropertyName: "supportedCountries", publicName: "supportedCountries", isSignal: true, isRequired: false, transformFunction: null }, labelledby: { classPropertyName: "labelledby", publicName: "labelledby", isSignal: true, isRequired: false, transformFunction: null }, disabledInput: { classPropertyName: "disabledInput", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { country: "countryChange", valueChange: "valueChange" }, host: { attributes: { "role": "group" }, properties: { "attr.aria-labelledby": "labelledby()", "attr.id": "id()", "class.disabled": "disabled()", "class.readonly": "readonly()", "class.country-focus": "countryFocused()" } }, providers: [
348
+ {
349
+ provide: NG_VALIDATORS,
350
+ useExisting: SiPhoneNumberInputComponent,
351
+ multi: true
352
+ },
353
+ {
354
+ provide: NG_VALUE_ACCESSOR,
355
+ useExisting: SiPhoneNumberInputComponent,
356
+ multi: true
357
+ },
358
+ {
359
+ provide: SI_FORM_ITEM_CONTROL,
360
+ useExisting: SiPhoneNumberInputComponent
361
+ }
362
+ ], viewQueries: [{ propertyName: "phoneInput", first: true, predicate: ["phoneInput"], descendants: true, isSignal: true }], usesOnChanges: true, ngImport: i0, template: "<div\n class=\"btn-group w-100 d-flex shadow-none border-0\"\n [class.disabled]=\"disabled()\"\n [class.readonly]=\"readonly()\"\n [attr.aria-disabled]=\"disabled()\"\n>\n <button\n #trigger=\"cdkOverlayOrigin\"\n cdkOverlayOrigin\n siPhoneNumberInputSelect\n class=\"dropdown-toggle d-flex align-items-center ms-n4 my-n4 py-2 px-4 border-0\"\n type=\"button\"\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n [disabled]=\"disabled()\"\n [class.readonly]=\"readonly()\"\n [attr.aria-labelledby]=\"id() + '-aria-label ' + id() + '-value'\"\n [attr.aria-expanded]=\"open\"\n [complexOptions]=\"countryList()\"\n [value]=\"selectedCountry\"\n [valueProvider]=\"valueProvider\"\n [tabindex]=\"disabled() ? '-1' : '0'\"\n [attr.aria-controls]=\"id() + '-listbox'\"\n (valueChange)=\"countryInput($event)\"\n (click)=\"openOverlay()\"\n (focus)=\"countryFocused.set(true)\"\n (blur)=\"countryFocused.set(false)\"\n >\n <span class=\"visually-hidden\" [id]=\"id() + '-aria-label'\">{{\n selectCountryAriaLabel() | translate\n }}</span>\n <span\n class=\"fi\"\n aria-hidden=\"true\"\n [ngClass]=\"'fi-' + (selectedCountry?.isoCode?.toLowerCase() ?? 'xx')\"\n ></span>\n @if (selectedCountry) {\n <span class=\"si-body-2 ms-4\" [id]=\"id() + '-value'\">\n <span class=\"visually-hidden\">{{ selectedCountry.name }}</span>\n +{{ selectedCountry.countryCode }}\n </span>\n }\n <si-icon-next class=\"icon dropdown-caret\" [icon]=\"icons.elementDown2\" />\n\n <ng-template\n cdkConnectedOverlay\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n [cdkConnectedOverlayHasBackdrop]=\"true\"\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"open\"\n [cdkConnectedOverlayFlexibleDimensions]=\"true\"\n [cdkConnectedOverlayOffsetX]=\"-1\"\n [cdkConnectedOverlayWidth]=\"overlayWidth\"\n (backdropClick)=\"overlayDetach()\"\n (detach)=\"overlayDetach()\"\n >\n <si-select-list-has-filter\n [baseId]=\"id()\"\n [filterPlaceholder]=\"placeholderForSearch()\"\n [noResultsFoundLabel]=\"searchNoResultsFoundLabel()\"\n [optionTemplate]=\"optionTemplate\"\n (closeOverlay)=\"overlayDetach()\"\n />\n </ng-template>\n <ng-template #optionTemplate let-option>\n <span class=\"fi me-5\" [ngClass]=\"'fi-' + option.value.isoCode.toLowerCase()\"></span>\n {{ option.value.name }} +{{ option.value.countryCode }}\n </ng-template>\n </button>\n <input\n #phoneInput\n type=\"tel\"\n class=\"ms-4 border-0 p-0 focus-none shadow-none flex-grow-1 phone-number\"\n [attr.aria-label]=\"phoneNumberAriaLabel() | translate\"\n [attr.aria-describedby]=\"errormessageId\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled()\"\n [readonly]=\"readonly()\"\n (input)=\"input()\"\n (blur)=\"blur()\"\n />\n</div>\n", styles: [":host:focus-within:not(.country-focus){outline:var(--element-button-focus-width) solid var(--element-focus-default);outline-offset:var(--element-button-focus-overlay-width)}.search-country{display:inline-block;margin-block-start:8px;margin-block-end:8px;margin-inline:8px;inline-size:calc(100% - 16px)}.disabled{pointer-events:none}.disabled,.disabled:hover,.disabled:focus{--border-color: var(--element-ui-3);color:var(--element-text-disabled)}.dropdown-toggle{border-radius:var(--element-input-radius);min-inline-size:auto!important;background:transparent}.dropdown-toggle .fi.fi-xx{background-image:none;background-color:var(--element-text-disabled)}.dropdown-toggle:disabled{opacity:var(--element-action-disabled-opacity)}.dropdown-toggle.readonly{cursor:default}.phone-number{background-color:transparent;inline-size:inherit}.phone-number:disabled,.phone-number[readonly]{opacity:1}.phone-number:disabled{color:var(--element-text-disabled)}.phone-number:disabled::placeholder{color:transparent}.phone-number::placeholder{color:var(--element-text-secondary)}\n"], dependencies: [{ kind: "directive", type: CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "directive", type: CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush", "cdkConnectedOverlayDisposeOnNavigation"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: SiIconNextComponent, selector: "si-icon-next", inputs: ["icon"] }, { kind: "directive", type: SiPhoneNumberInputSelectDirective, selector: "[siPhoneNumberInputSelect]" }, { kind: "component", type: SiSelectListHasFilterComponent, selector: "si-select-list-has-filter", inputs: ["filterPlaceholder", "noResultsFoundLabel"] }, { kind: "ngmodule", type: SiTranslateModule }, { kind: "pipe", type: i1$1.SiTranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
363
+ }
364
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiPhoneNumberInputComponent, decorators: [{
365
+ type: Component,
366
+ args: [{ selector: 'si-phone-number-input', providers: [
367
+ {
368
+ provide: NG_VALIDATORS,
369
+ useExisting: SiPhoneNumberInputComponent,
370
+ multi: true
371
+ },
372
+ {
373
+ provide: NG_VALUE_ACCESSOR,
374
+ useExisting: SiPhoneNumberInputComponent,
375
+ multi: true
376
+ },
377
+ {
378
+ provide: SI_FORM_ITEM_CONTROL,
379
+ useExisting: SiPhoneNumberInputComponent
380
+ }
381
+ ], changeDetection: ChangeDetectionStrategy.OnPush, imports: [
382
+ CdkOverlayOrigin,
383
+ CdkConnectedOverlay,
384
+ NgClass,
385
+ SiIconNextComponent,
386
+ SiPhoneNumberInputSelectDirective,
387
+ SiSelectListHasFilterComponent,
388
+ SiTranslateModule
389
+ ], host: {
390
+ 'role': 'group',
391
+ '[attr.aria-labelledby]': 'labelledby()',
392
+ '[attr.id]': 'id()',
393
+ '[class.disabled]': 'disabled()',
394
+ '[class.readonly]': 'readonly()',
395
+ '[class.country-focus]': 'countryFocused()'
396
+ }, template: "<div\n class=\"btn-group w-100 d-flex shadow-none border-0\"\n [class.disabled]=\"disabled()\"\n [class.readonly]=\"readonly()\"\n [attr.aria-disabled]=\"disabled()\"\n>\n <button\n #trigger=\"cdkOverlayOrigin\"\n cdkOverlayOrigin\n siPhoneNumberInputSelect\n class=\"dropdown-toggle d-flex align-items-center ms-n4 my-n4 py-2 px-4 border-0\"\n type=\"button\"\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n [disabled]=\"disabled()\"\n [class.readonly]=\"readonly()\"\n [attr.aria-labelledby]=\"id() + '-aria-label ' + id() + '-value'\"\n [attr.aria-expanded]=\"open\"\n [complexOptions]=\"countryList()\"\n [value]=\"selectedCountry\"\n [valueProvider]=\"valueProvider\"\n [tabindex]=\"disabled() ? '-1' : '0'\"\n [attr.aria-controls]=\"id() + '-listbox'\"\n (valueChange)=\"countryInput($event)\"\n (click)=\"openOverlay()\"\n (focus)=\"countryFocused.set(true)\"\n (blur)=\"countryFocused.set(false)\"\n >\n <span class=\"visually-hidden\" [id]=\"id() + '-aria-label'\">{{\n selectCountryAriaLabel() | translate\n }}</span>\n <span\n class=\"fi\"\n aria-hidden=\"true\"\n [ngClass]=\"'fi-' + (selectedCountry?.isoCode?.toLowerCase() ?? 'xx')\"\n ></span>\n @if (selectedCountry) {\n <span class=\"si-body-2 ms-4\" [id]=\"id() + '-value'\">\n <span class=\"visually-hidden\">{{ selectedCountry.name }}</span>\n +{{ selectedCountry.countryCode }}\n </span>\n }\n <si-icon-next class=\"icon dropdown-caret\" [icon]=\"icons.elementDown2\" />\n\n <ng-template\n cdkConnectedOverlay\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n [cdkConnectedOverlayHasBackdrop]=\"true\"\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"open\"\n [cdkConnectedOverlayFlexibleDimensions]=\"true\"\n [cdkConnectedOverlayOffsetX]=\"-1\"\n [cdkConnectedOverlayWidth]=\"overlayWidth\"\n (backdropClick)=\"overlayDetach()\"\n (detach)=\"overlayDetach()\"\n >\n <si-select-list-has-filter\n [baseId]=\"id()\"\n [filterPlaceholder]=\"placeholderForSearch()\"\n [noResultsFoundLabel]=\"searchNoResultsFoundLabel()\"\n [optionTemplate]=\"optionTemplate\"\n (closeOverlay)=\"overlayDetach()\"\n />\n </ng-template>\n <ng-template #optionTemplate let-option>\n <span class=\"fi me-5\" [ngClass]=\"'fi-' + option.value.isoCode.toLowerCase()\"></span>\n {{ option.value.name }} +{{ option.value.countryCode }}\n </ng-template>\n </button>\n <input\n #phoneInput\n type=\"tel\"\n class=\"ms-4 border-0 p-0 focus-none shadow-none flex-grow-1 phone-number\"\n [attr.aria-label]=\"phoneNumberAriaLabel() | translate\"\n [attr.aria-describedby]=\"errormessageId\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled()\"\n [readonly]=\"readonly()\"\n (input)=\"input()\"\n (blur)=\"blur()\"\n />\n</div>\n", styles: [":host:focus-within:not(.country-focus){outline:var(--element-button-focus-width) solid var(--element-focus-default);outline-offset:var(--element-button-focus-overlay-width)}.search-country{display:inline-block;margin-block-start:8px;margin-block-end:8px;margin-inline:8px;inline-size:calc(100% - 16px)}.disabled{pointer-events:none}.disabled,.disabled:hover,.disabled:focus{--border-color: var(--element-ui-3);color:var(--element-text-disabled)}.dropdown-toggle{border-radius:var(--element-input-radius);min-inline-size:auto!important;background:transparent}.dropdown-toggle .fi.fi-xx{background-image:none;background-color:var(--element-text-disabled)}.dropdown-toggle:disabled{opacity:var(--element-action-disabled-opacity)}.dropdown-toggle.readonly{cursor:default}.phone-number{background-color:transparent;inline-size:inherit}.phone-number:disabled,.phone-number[readonly]{opacity:1}.phone-number:disabled{color:var(--element-text-disabled)}.phone-number:disabled::placeholder{color:transparent}.phone-number::placeholder{color:var(--element-text-secondary)}\n"] }]
397
+ }] });
398
+
399
+ /**
400
+ * Copyright Siemens 2016 - 2025.
401
+ * SPDX-License-Identifier: MIT
402
+ */
403
+ class SiPhoneNumberInputModule {
404
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiPhoneNumberInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
405
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "19.0.6", ngImport: i0, type: SiPhoneNumberInputModule, imports: [SiPhoneNumberInputComponent], exports: [SiPhoneNumberInputComponent] });
406
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiPhoneNumberInputModule, imports: [SiPhoneNumberInputComponent] });
407
+ }
408
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.6", ngImport: i0, type: SiPhoneNumberInputModule, decorators: [{
409
+ type: NgModule,
410
+ args: [{
411
+ imports: [SiPhoneNumberInputComponent],
412
+ exports: [SiPhoneNumberInputComponent]
413
+ }]
414
+ }] });
415
+
416
+ /**
417
+ * Copyright Siemens 2016 - 2025.
418
+ * SPDX-License-Identifier: MIT
419
+ */
420
+
421
+ /**
422
+ * Generated bundle index. Do not edit.
423
+ */
424
+
425
+ export { SiPhoneNumberInputComponent, SiPhoneNumberInputModule };
426
+ //# sourceMappingURL=siemens-element-ng-phone-number.mjs.map