@siemens/ix 0.0.0-pr-2238-20251103105018 → 0.0.0-pr-2297-20251204163058

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 (1009) hide show
  1. package/components/index.js +4 -4
  2. package/components/index.js.map +1 -1
  3. package/components/ix-action-card.js +4 -4
  4. package/components/ix-application-header.js +263 -1
  5. package/components/ix-application-header.js.map +1 -1
  6. package/components/ix-application-sidebar.js +1 -1
  7. package/components/ix-application-switch-modal.js +8 -8
  8. package/components/ix-application.js +5 -7
  9. package/components/ix-application.js.map +1 -1
  10. package/components/ix-avatar.js +1 -1
  11. package/components/ix-blind.js +8 -8
  12. package/components/ix-breadcrumb-item.js +1 -1
  13. package/components/ix-breadcrumb.js +7 -7
  14. package/components/ix-button.js +1 -1
  15. package/components/ix-card-accordion.js +1 -1
  16. package/components/ix-card-content.js +1 -1
  17. package/components/ix-card-list.js +12 -12
  18. package/components/ix-card-title.js +1 -1
  19. package/components/ix-card.js +1 -1
  20. package/components/ix-category-filter.js +21 -15
  21. package/components/ix-category-filter.js.map +1 -1
  22. package/components/ix-checkbox-group.js +8 -8
  23. package/components/ix-checkbox.js +6 -6
  24. package/components/ix-chip.js +10 -10
  25. package/components/ix-col.js +1 -1
  26. package/components/ix-content-header.js +8 -8
  27. package/components/ix-content.js +4 -4
  28. package/components/ix-css-grid-item.js +2 -2
  29. package/components/ix-css-grid.js +2 -2
  30. package/components/ix-custom-field.js +7 -7
  31. package/components/ix-date-dropdown.js +16 -16
  32. package/components/ix-date-input.js +34 -20
  33. package/components/ix-date-input.js.map +1 -1
  34. package/components/ix-date-picker.js +1 -1
  35. package/components/ix-date-time-card.js +1 -1
  36. package/components/ix-datetime-picker.js +14 -14
  37. package/components/ix-datetime-picker.js.map +1 -1
  38. package/components/ix-divider.js +1 -1
  39. package/components/ix-drawer.js +9 -9
  40. package/components/ix-dropdown-button.js +9 -9
  41. package/components/ix-dropdown-header.js +3 -3
  42. package/components/ix-dropdown-item.js +1 -1
  43. package/components/ix-dropdown-quick-actions.js +2 -2
  44. package/components/ix-dropdown.js +1 -1
  45. package/components/ix-empty-state.js +5 -5
  46. package/components/ix-event-list-item.js +6 -6
  47. package/components/ix-event-list.js +3 -3
  48. package/components/ix-expanding-search.js +8 -8
  49. package/components/ix-field-label.js +1 -1
  50. package/components/ix-field-wrapper.js +1 -1
  51. package/components/ix-filter-chip.js +1 -1
  52. package/components/ix-flip-tile-content.js +2 -2
  53. package/components/ix-flip-tile.js +7 -7
  54. package/components/ix-group-context-menu.js +1 -1
  55. package/components/ix-group-item.js +1 -1
  56. package/components/ix-group.js +14 -14
  57. package/components/ix-helper-text.js +5 -5
  58. package/components/ix-icon-button.js +1 -1
  59. package/components/ix-icon-toggle-button.js +4 -4
  60. package/components/ix-input-group.js +2 -2
  61. package/components/ix-input.js +26 -15
  62. package/components/ix-input.js.map +1 -1
  63. package/components/ix-key-value-list.js +2 -2
  64. package/components/ix-key-value.js +2 -2
  65. package/components/ix-kpi.js +5 -5
  66. package/components/ix-layout-auto.js +2 -2
  67. package/components/ix-layout-grid.js +1 -1
  68. package/components/ix-link-button.js +6 -6
  69. package/components/ix-link-button.js.map +1 -1
  70. package/components/ix-menu-about-item.js +2 -2
  71. package/components/ix-menu-about-news.js +10 -10
  72. package/components/ix-menu-about.js +11 -9
  73. package/components/ix-menu-about.js.map +1 -1
  74. package/components/ix-menu-avatar-item.js +1 -1
  75. package/components/ix-menu-avatar.js +12 -12
  76. package/components/ix-menu-category.js +14 -14
  77. package/components/ix-menu-expand-icon.js +1 -1
  78. package/components/ix-menu-item.js +1 -1
  79. package/components/ix-menu-settings-item.js +2 -2
  80. package/components/ix-menu-settings.js +1 -1
  81. package/components/ix-menu.js +22 -32
  82. package/components/ix-menu.js.map +1 -1
  83. package/components/ix-message-bar.js +5 -5
  84. package/components/ix-modal-content.js +1 -1
  85. package/components/ix-modal-footer.js +2 -2
  86. package/components/ix-modal-header.js +1 -1
  87. package/components/ix-modal-loading.js +3 -3
  88. package/components/ix-modal.js +5 -5
  89. package/components/ix-number-input.js +172 -39
  90. package/components/ix-number-input.js.map +1 -1
  91. package/components/ix-pagination.js +45 -22
  92. package/components/ix-pagination.js.map +1 -1
  93. package/components/ix-pane-layout.js +2 -2
  94. package/components/ix-pane.js +11 -11
  95. package/components/ix-pill.js +7 -7
  96. package/components/ix-progress-indicator.js +7 -7
  97. package/components/ix-push-card.js +7 -7
  98. package/components/ix-radio-group.js +40 -9
  99. package/components/ix-radio-group.js.map +1 -1
  100. package/components/ix-radio.js +46 -20
  101. package/components/ix-radio.js.map +1 -1
  102. package/components/ix-row.js +1 -1
  103. package/components/ix-select-item.js +1 -1
  104. package/components/ix-select.js +1 -1
  105. package/components/ix-slider.js +10 -10
  106. package/components/ix-spinner.js +1 -1
  107. package/components/ix-split-button.js +32 -18
  108. package/components/ix-split-button.js.map +1 -1
  109. package/components/ix-tab-item.js +1 -1
  110. package/components/ix-tabs.js +1 -1
  111. package/components/ix-textarea.js +9 -9
  112. package/components/ix-tile.js +5 -5
  113. package/components/ix-time-input.js +35 -21
  114. package/components/ix-time-input.js.map +1 -1
  115. package/components/ix-time-picker.js +1 -1
  116. package/components/ix-toast-container.js +7 -7
  117. package/components/ix-toast.js +1 -1
  118. package/components/ix-toggle-button.js +3 -3
  119. package/components/ix-toggle.js +6 -6
  120. package/components/ix-toggle.js.map +1 -1
  121. package/components/ix-tooltip.js +1 -1
  122. package/components/ix-tree-item.js +1 -1
  123. package/components/ix-tree.js +3 -3
  124. package/components/ix-typography.js +1 -1
  125. package/components/ix-upload.js +7 -7
  126. package/components/ix-validation-tooltip.js +3 -3
  127. package/components/ix-workflow-step.js +5 -5
  128. package/components/ix-workflow-steps.js +2 -2
  129. package/components/{p-BccEFWg2.js → p-10zMtvCF.js} +6 -6
  130. package/components/{p-BccEFWg2.js.map → p-10zMtvCF.js.map} +1 -1
  131. package/components/{p-CkrLmEP7.js → p-1pd_0dhF.js} +4 -4
  132. package/components/{p-CkrLmEP7.js.map → p-1pd_0dhF.js.map} +1 -1
  133. package/components/{p-BUIOrNGz.js → p-7E7AMiQV.js} +7 -7
  134. package/components/p-7E7AMiQV.js.map +1 -0
  135. package/components/{p-BNwXjBuF.js → p-B006bhbX.js} +4 -4
  136. package/components/{p-BNwXjBuF.js.map → p-B006bhbX.js.map} +1 -1
  137. package/components/{p-DrH8EeUB.js → p-B1p0kpQJ.js} +6 -6
  138. package/components/{p-DrH8EeUB.js.map → p-B1p0kpQJ.js.map} +1 -1
  139. package/components/{p-DOEb0lKA.js → p-B45tl2du.js} +4 -4
  140. package/components/{p-DOEb0lKA.js.map → p-B45tl2du.js.map} +1 -1
  141. package/components/{p-DgfGA7Z3.js → p-BBwXlKhE.js} +4 -4
  142. package/components/{p-DgfGA7Z3.js.map → p-BBwXlKhE.js.map} +1 -1
  143. package/components/{p-ciUqTzkB.js → p-BEDohapR.js} +6 -6
  144. package/components/{p-ciUqTzkB.js.map → p-BEDohapR.js.map} +1 -1
  145. package/components/{p-DsftMeEA.js → p-BGdI6-nv.js} +4 -4
  146. package/components/{p-DsftMeEA.js.map → p-BGdI6-nv.js.map} +1 -1
  147. package/components/{p-XiZWDi7n.js → p-BGjnKa2h.js} +4 -4
  148. package/components/{p-XiZWDi7n.js.map → p-BGjnKa2h.js.map} +1 -1
  149. package/components/{p-D1In20Wh.js → p-BI7B-PUA.js} +5 -5
  150. package/components/{p-D1In20Wh.js.map → p-BI7B-PUA.js.map} +1 -1
  151. package/components/{p-VMk3rl5y.js → p-BIg1TSrD.js} +9 -9
  152. package/components/{p-VMk3rl5y.js.map → p-BIg1TSrD.js.map} +1 -1
  153. package/components/{p-CCQYIDJK.js → p-BLeWaHpy.js} +7 -7
  154. package/components/{p-CCQYIDJK.js.map → p-BLeWaHpy.js.map} +1 -1
  155. package/components/{p-DBsESzrF.js → p-BOQ00Fbs.js} +70 -29
  156. package/components/p-BOQ00Fbs.js.map +1 -0
  157. package/components/{p-CO2zhw6V.js → p-BQk7HpA-.js} +3 -3
  158. package/components/{p-CO2zhw6V.js.map → p-BQk7HpA-.js.map} +1 -1
  159. package/components/{p-CtusOOtv.js → p-BR5ayBuu.js} +6 -6
  160. package/components/{p-CtusOOtv.js.map → p-BR5ayBuu.js.map} +1 -1
  161. package/components/{p--2LOMK-5.js → p-BhgW5qDm.js} +2 -3
  162. package/components/p-BhgW5qDm.js.map +1 -0
  163. package/components/{p-BaWdG-ph.js → p-BiqdnsgA.js} +20 -13
  164. package/components/p-BiqdnsgA.js.map +1 -0
  165. package/components/{p-BxNzvWr2.js → p-Bk0vKwmt.js} +5 -5
  166. package/components/{p-BxNzvWr2.js.map → p-Bk0vKwmt.js.map} +1 -1
  167. package/components/{p-Bvf7gwPU.js → p-BmMUyJRQ.js} +89 -53
  168. package/components/p-BmMUyJRQ.js.map +1 -0
  169. package/components/{p-taILGXkr.js → p-BvsadYCu.js} +3 -3
  170. package/components/{p-taILGXkr.js.map → p-BvsadYCu.js.map} +1 -1
  171. package/components/{p-BEzKnceP.js → p-Bye33cYU.js} +9 -9
  172. package/components/{p-BEzKnceP.js.map → p-Bye33cYU.js.map} +1 -1
  173. package/components/{p-BvKUU6Ta.js → p-C4KxNeD2.js} +4 -4
  174. package/components/{p-BvKUU6Ta.js.map → p-C4KxNeD2.js.map} +1 -1
  175. package/components/{p-Qsbo2ls8.js → p-C6_1qmP4.js} +5 -5
  176. package/components/{p-Qsbo2ls8.js.map → p-C6_1qmP4.js.map} +1 -1
  177. package/components/{p-CQhe_rqk.js → p-COWPG_SD.js} +6 -6
  178. package/components/p-COWPG_SD.js.map +1 -0
  179. package/components/{p-CFAI8dx_.js → p-CV_EVAOW.js} +3 -3
  180. package/components/{p-CFAI8dx_.js.map → p-CV_EVAOW.js.map} +1 -1
  181. package/components/{p-D_rmJU0n.js → p-CjDPpSJX.js} +16 -16
  182. package/components/p-CjDPpSJX.js.map +1 -0
  183. package/components/{p-DeBhxnHo.js → p-ClQxnZ3d.js} +8 -8
  184. package/components/{p-DeBhxnHo.js.map → p-ClQxnZ3d.js.map} +1 -1
  185. package/components/{p-DcjRXRwg.js → p-ColBHyXN.js} +7 -7
  186. package/components/{p-DcjRXRwg.js.map → p-ColBHyXN.js.map} +1 -1
  187. package/components/{p-0MSWDTqB.js → p-CrqgL2m1.js} +10 -6
  188. package/components/p-CrqgL2m1.js.map +1 -0
  189. package/components/{p-By1IU8iL.js → p-CvD2yWeJ.js} +5 -5
  190. package/components/{p-By1IU8iL.js.map → p-CvD2yWeJ.js.map} +1 -1
  191. package/components/{p-fahyavc3.js → p-CvF96Z51.js} +8 -8
  192. package/components/{p-fahyavc3.js.map → p-CvF96Z51.js.map} +1 -1
  193. package/components/{p-CKuNFgoe.js → p-D-__gyet.js} +3 -3
  194. package/components/{p-CKuNFgoe.js.map → p-D-__gyet.js.map} +1 -1
  195. package/components/{p-cw5RHost.js → p-DC9anobw.js} +8 -8
  196. package/components/{p-cw5RHost.js.map → p-DC9anobw.js.map} +1 -1
  197. package/components/{p-CHAuj3bi.js → p-DSTHZygb.js} +10 -10
  198. package/components/{p-CHAuj3bi.js.map → p-DSTHZygb.js.map} +1 -1
  199. package/components/{p-DLPEB4G8.js → p-DUU5I7wZ.js} +70 -45
  200. package/components/p-DUU5I7wZ.js.map +1 -0
  201. package/components/{p-IgT3dgxG.js → p-DXFN8JXp.js} +21 -10
  202. package/components/p-DXFN8JXp.js.map +1 -0
  203. package/components/{p-JUUSQc_M.js → p-D_4Mf9jE.js} +3 -3
  204. package/components/{p-JUUSQc_M.js.map → p-D_4Mf9jE.js.map} +1 -1
  205. package/components/{p-BWTF-D2w.js → p-Db0RazS2.js} +4 -4
  206. package/components/{p-BWTF-D2w.js.map → p-Db0RazS2.js.map} +1 -1
  207. package/components/{p-W_8b1-4d.js → p-DdLose3V.js} +3 -3
  208. package/components/{p-W_8b1-4d.js.map → p-DdLose3V.js.map} +1 -1
  209. package/components/{p-DzscKBhb.js → p-DlVaL0Yi.js} +9 -9
  210. package/components/{p-DzscKBhb.js.map → p-DlVaL0Yi.js.map} +1 -1
  211. package/components/{p-CJphMgA7.js → p-Dp03DeD0.js} +7 -7
  212. package/components/{p-CJphMgA7.js.map → p-Dp03DeD0.js.map} +1 -1
  213. package/components/{p-2fxFa_VL.js → p-Dq_H2flK.js} +10 -4
  214. package/components/p-Dq_H2flK.js.map +1 -0
  215. package/components/{p-jbrSDf3o.js → p-Dy6xvLn4.js} +5 -5
  216. package/components/{p-jbrSDf3o.js.map → p-Dy6xvLn4.js.map} +1 -1
  217. package/components/{p-FnN74Elm.js → p-MuPiaYr1.js} +3 -3
  218. package/components/{p-FnN74Elm.js.map → p-MuPiaYr1.js.map} +1 -1
  219. package/components/{p-CINrBR9H.js → p-N4h8LKe5.js} +4 -4
  220. package/components/{p-CINrBR9H.js.map → p-N4h8LKe5.js.map} +1 -1
  221. package/components/{p-C6MbjoUl.js → p-PpLLlogo.js} +8 -8
  222. package/components/{p-C6MbjoUl.js.map → p-PpLLlogo.js.map} +1 -1
  223. package/components/{p-xZXH2vKm.js → p-hwPzPVf8.js} +5 -5
  224. package/components/{p-xZXH2vKm.js.map → p-hwPzPVf8.js.map} +1 -1
  225. package/dist/cjs/{context-B8bRIFA2.js → context-CmNuiaNz.js} +2 -3
  226. package/dist/{esm/context-CKM5pVsv.js.map → cjs/context-CmNuiaNz.js.map} +1 -1
  227. package/dist/cjs/{helper-text-util-BlElJLxk.js → helper-text-util-D2W-yNmK.js} +8 -4
  228. package/dist/cjs/helper-text-util-D2W-yNmK.js.map +1 -0
  229. package/dist/cjs/index-C8Xo8L1k.js +6 -18
  230. package/dist/cjs/index.cjs.js.map +1 -1
  231. package/dist/cjs/{input.util-4AhBphgX.js → input.fc-DrxRYq_G.js} +69 -43
  232. package/dist/cjs/input.fc-DrxRYq_G.js.map +1 -0
  233. package/dist/cjs/ix-application-header.cjs.entry.js +10 -15
  234. package/dist/cjs/ix-application-header.entry.cjs.js.map +1 -1
  235. package/dist/cjs/ix-application.cjs.entry.js +4 -6
  236. package/dist/cjs/ix-application.entry.cjs.js.map +1 -1
  237. package/dist/cjs/ix-avatar_2.cjs.entry.js +1 -1
  238. package/dist/cjs/ix-blind.cjs.entry.js +5 -5
  239. package/dist/cjs/ix-breadcrumb.cjs.entry.js +2 -2
  240. package/dist/cjs/ix-card-accordion_2.cjs.entry.js +5 -5
  241. package/dist/cjs/ix-card-list.cjs.entry.js +4 -4
  242. package/dist/cjs/ix-card_2.cjs.entry.js +3 -3
  243. package/dist/cjs/ix-category-filter.cjs.entry.js +14 -8
  244. package/dist/cjs/ix-category-filter.entry.cjs.js.map +1 -1
  245. package/dist/cjs/ix-checkbox-group.cjs.entry.js +3 -3
  246. package/dist/cjs/ix-checkbox.cjs.entry.js +4 -4
  247. package/dist/cjs/ix-chip.cjs.entry.js +4 -4
  248. package/dist/cjs/ix-col.ix-date-picker.ix-layout-grid.ix-row.entry.cjs.js.map +1 -1
  249. package/dist/cjs/ix-col_4.cjs.entry.js +10 -10
  250. package/dist/cjs/ix-content-header.cjs.entry.js +3 -3
  251. package/dist/cjs/ix-content.cjs.entry.js +3 -3
  252. package/dist/cjs/ix-css-grid-item.cjs.entry.js +1 -1
  253. package/dist/cjs/ix-css-grid.cjs.entry.js +1 -1
  254. package/dist/cjs/ix-custom-field.cjs.entry.js +2 -2
  255. package/dist/cjs/ix-date-dropdown.cjs.entry.js +4 -4
  256. package/dist/cjs/ix-date-input.cjs.entry.js +24 -12
  257. package/dist/cjs/ix-date-input.entry.cjs.js.map +1 -1
  258. package/dist/cjs/ix-date-time-card.cjs.entry.js +3 -3
  259. package/dist/cjs/ix-date-time-card.entry.cjs.js.map +1 -1
  260. package/dist/cjs/ix-datetime-picker.cjs.entry.js +2 -2
  261. package/dist/cjs/ix-datetime-picker.entry.cjs.js.map +1 -1
  262. package/dist/cjs/ix-divider.cjs.entry.js +1 -1
  263. package/dist/cjs/ix-drawer.cjs.entry.js +5 -5
  264. package/dist/cjs/ix-dropdown-button.cjs.entry.js +3 -3
  265. package/dist/cjs/ix-dropdown-header.cjs.entry.js +1 -1
  266. package/dist/cjs/ix-dropdown-item.cjs.entry.js +3 -3
  267. package/dist/cjs/ix-dropdown-quick-actions.cjs.entry.js +1 -1
  268. package/dist/cjs/ix-dropdown.cjs.entry.js +2 -2
  269. package/dist/cjs/ix-empty-state.cjs.entry.js +1 -1
  270. package/dist/cjs/ix-event-list-item.cjs.entry.js +4 -4
  271. package/dist/cjs/ix-event-list.cjs.entry.js +2 -2
  272. package/dist/cjs/ix-expanding-search.cjs.entry.js +4 -4
  273. package/dist/cjs/ix-field-label_2.cjs.entry.js +5 -5
  274. package/dist/cjs/ix-filter-chip_2.cjs.entry.js +2 -2
  275. package/dist/cjs/ix-flip-tile-content.cjs.entry.js +1 -1
  276. package/dist/cjs/ix-flip-tile.cjs.entry.js +3 -3
  277. package/dist/cjs/ix-group-context-menu_2.cjs.entry.js +1 -1
  278. package/dist/cjs/ix-group.cjs.entry.js +8 -8
  279. package/dist/cjs/ix-helper-text.cjs.entry.js +3 -3
  280. package/dist/cjs/ix-icon-button_2.cjs.entry.js +2 -2
  281. package/dist/cjs/ix-icon-toggle-button.cjs.entry.js +1 -1
  282. package/dist/cjs/ix-input-group.cjs.entry.js +1 -1
  283. package/dist/cjs/ix-input.cjs.entry.js +21 -12
  284. package/dist/cjs/ix-input.entry.cjs.js.map +1 -1
  285. package/dist/cjs/ix-key-value-list.cjs.entry.js +1 -1
  286. package/dist/cjs/ix-key-value.cjs.entry.js +1 -1
  287. package/dist/cjs/ix-kpi.cjs.entry.js +3 -3
  288. package/dist/cjs/ix-layout-auto.cjs.entry.js +1 -1
  289. package/dist/cjs/ix-link-button.cjs.entry.js +4 -4
  290. package/dist/cjs/ix-link-button.entry.cjs.js.map +1 -1
  291. package/dist/cjs/ix-menu-about-item.cjs.entry.js +1 -1
  292. package/dist/cjs/ix-menu-about-news.cjs.entry.js +4 -4
  293. package/dist/cjs/ix-menu-about.cjs.entry.js +6 -4
  294. package/dist/cjs/ix-menu-about.entry.cjs.js.map +1 -1
  295. package/dist/cjs/ix-menu-avatar.cjs.entry.js +2 -2
  296. package/dist/cjs/ix-menu-category.cjs.entry.js +6 -6
  297. package/dist/cjs/ix-menu-expand-icon.cjs.entry.js +1 -1
  298. package/dist/cjs/ix-menu-item.cjs.entry.js +4 -4
  299. package/dist/cjs/{ix-menu-settings-Cdqo0r8E.js → ix-menu-settings-CtWl0bME.js} +14 -7
  300. package/dist/cjs/ix-menu-settings-CtWl0bME.js.map +1 -0
  301. package/dist/cjs/ix-menu-settings-item.cjs.entry.js +1 -1
  302. package/dist/cjs/ix-menu-settings.cjs.entry.js +1 -1
  303. package/dist/cjs/ix-menu.cjs.entry.js +13 -23
  304. package/dist/cjs/ix-menu.entry.cjs.js.map +1 -1
  305. package/dist/cjs/ix-message-bar.cjs.entry.js +1 -1
  306. package/dist/cjs/ix-modal-content_2.cjs.entry.js +2 -2
  307. package/dist/cjs/ix-modal-footer.cjs.entry.js +1 -1
  308. package/dist/cjs/ix-modal-loading.cjs.entry.js +1 -1
  309. package/dist/cjs/ix-modal.cjs.entry.js +3 -3
  310. package/dist/cjs/ix-number-input.cjs.entry.js +162 -34
  311. package/dist/cjs/ix-number-input.entry.cjs.js.map +1 -1
  312. package/dist/cjs/ix-pagination.cjs.entry.js +29 -7
  313. package/dist/cjs/ix-pagination.entry.cjs.js.map +1 -1
  314. package/dist/cjs/ix-pane-layout.cjs.entry.js +1 -1
  315. package/dist/cjs/ix-pane.cjs.entry.js +6 -6
  316. package/dist/cjs/ix-pill.cjs.entry.js +4 -4
  317. package/dist/cjs/ix-progress-indicator.cjs.entry.js +3 -3
  318. package/dist/cjs/ix-push-card.cjs.entry.js +1 -1
  319. package/dist/cjs/ix-radio-group.cjs.entry.js +33 -3
  320. package/dist/cjs/ix-radio-group.entry.cjs.js.map +1 -1
  321. package/dist/cjs/ix-radio.cjs.entry.js +43 -18
  322. package/dist/cjs/ix-radio.entry.cjs.js.map +1 -1
  323. package/dist/cjs/ix-select.cjs.entry.js +53 -14
  324. package/dist/cjs/ix-select.entry.cjs.js.map +1 -1
  325. package/dist/cjs/ix-slider.cjs.entry.js +6 -6
  326. package/dist/cjs/ix-split-button.cjs.entry.js +24 -12
  327. package/dist/cjs/ix-split-button.entry.cjs.js.map +1 -1
  328. package/dist/cjs/ix-tab-item.ix-tabs.entry.cjs.js.map +1 -1
  329. package/dist/cjs/ix-tab-item_2.cjs.entry.js +6 -6
  330. package/dist/cjs/ix-textarea.cjs.entry.js +6 -6
  331. package/dist/cjs/ix-textarea.entry.cjs.js.map +1 -1
  332. package/dist/cjs/ix-tile.cjs.entry.js +4 -4
  333. package/dist/cjs/ix-time-input.cjs.entry.js +24 -12
  334. package/dist/cjs/ix-time-input.entry.cjs.js.map +1 -1
  335. package/dist/cjs/ix-time-picker.cjs.entry.js +81 -45
  336. package/dist/cjs/ix-time-picker.entry.cjs.js.map +1 -1
  337. package/dist/cjs/ix-toast-container.cjs.entry.js +2 -2
  338. package/dist/cjs/ix-toast.cjs.entry.js +2 -2
  339. package/dist/cjs/ix-toggle.cjs.entry.js +4 -4
  340. package/dist/cjs/ix-toggle.entry.cjs.js.map +1 -1
  341. package/dist/cjs/ix-tooltip.cjs.entry.js +17 -6
  342. package/dist/cjs/ix-tooltip.entry.cjs.js.map +1 -1
  343. package/dist/cjs/ix-tree-item.cjs.entry.js +4 -4
  344. package/dist/cjs/ix-tree.cjs.entry.js +1 -1
  345. package/dist/cjs/ix-typography.cjs.entry.js +1 -1
  346. package/dist/cjs/ix-upload.cjs.entry.js +3 -3
  347. package/dist/cjs/ix-validation-tooltip.cjs.entry.js +2 -2
  348. package/dist/cjs/ix-workflow-step.cjs.entry.js +3 -3
  349. package/dist/cjs/ix-workflow-steps.cjs.entry.js +1 -1
  350. package/dist/cjs/loader.cjs.js +1 -1
  351. package/dist/cjs/siemens-ix.cjs.js +1 -1
  352. package/dist/cjs/{validation-CfL71_0d.js → validation-DTmSqO2d.js} +9 -2
  353. package/dist/{esm/validation-D_dk-JqT.js.map → cjs/validation-DTmSqO2d.js.map} +1 -1
  354. package/dist/collection/collection-manifest.json +0 -3
  355. package/dist/collection/components/application/application.js +3 -5
  356. package/dist/collection/components/application/application.js.map +1 -1
  357. package/dist/collection/components/application-header/application-header.js +9 -14
  358. package/dist/collection/components/application-header/application-header.js.map +1 -1
  359. package/dist/collection/components/blind/blind.js +5 -5
  360. package/dist/collection/components/breadcrumb/breadcrumb.js +2 -2
  361. package/dist/collection/components/card/card.js +2 -2
  362. package/dist/collection/components/card-accordion/card-accordion.js +4 -4
  363. package/dist/collection/components/card-content/card-content.js +1 -1
  364. package/dist/collection/components/card-list/card-list.js +4 -4
  365. package/dist/collection/components/card-title/card-title.js +1 -1
  366. package/dist/collection/components/category-filter/category-filter.css +321 -50
  367. package/dist/collection/components/category-filter/category-filter.js +13 -7
  368. package/dist/collection/components/category-filter/category-filter.js.map +1 -1
  369. package/dist/collection/components/checkbox/checkbox.js +3 -3
  370. package/dist/collection/components/checkbox-group/checkbox-group.js +2 -2
  371. package/dist/collection/components/chip/chip.js +4 -4
  372. package/dist/collection/components/col/col.js +1 -1
  373. package/dist/collection/components/content/content.js +3 -3
  374. package/dist/collection/components/content-header/content-header.js +3 -3
  375. package/dist/collection/components/css-grid/css-grid-item.js +1 -1
  376. package/dist/collection/components/css-grid/css-grid.js +1 -1
  377. package/dist/collection/components/custom-field/custom-field.js +1 -1
  378. package/dist/collection/components/date-dropdown/date-dropdown.js +4 -4
  379. package/dist/collection/components/date-input/date-input.js +60 -8
  380. package/dist/collection/components/date-input/date-input.js.map +1 -1
  381. package/dist/collection/components/date-picker/date-picker.css +6 -8
  382. package/dist/collection/components/date-picker/date-picker.js +5 -5
  383. package/dist/collection/components/date-picker/date-picker.js.map +1 -1
  384. package/dist/collection/components/date-time-card/date-time-card.css +3 -2
  385. package/dist/collection/components/date-time-card/date-time-card.js +2 -2
  386. package/dist/collection/components/datetime-picker/datetime-picker.css +12 -1
  387. package/dist/collection/components/datetime-picker/datetime-picker.js +1 -1
  388. package/dist/collection/components/datetime-picker/datetime-picker.js.map +1 -1
  389. package/dist/collection/components/divider/divider.js +1 -1
  390. package/dist/collection/components/drawer/drawer.js +5 -5
  391. package/dist/collection/components/dropdown/dropdown.js +2 -2
  392. package/dist/collection/components/dropdown-button/dropdown-button.js +3 -3
  393. package/dist/collection/components/dropdown-header/dropdown-header.js +1 -1
  394. package/dist/collection/components/dropdown-item/dropdown-item.js +3 -3
  395. package/dist/collection/components/dropdown-quick-actions/dropdown-quick-actions.js +1 -1
  396. package/dist/collection/components/empty-state/empty-state.js +1 -1
  397. package/dist/collection/components/event-list/event-list.js +2 -2
  398. package/dist/collection/components/event-list-item/event-list-item.js +4 -4
  399. package/dist/collection/components/expanding-search/expanding-search.js +4 -4
  400. package/dist/collection/components/field-label/field-label.js +1 -1
  401. package/dist/collection/components/field-wrapper/field-wrapper.js +2 -2
  402. package/dist/collection/components/field-wrapper/helper-text-util.js +6 -2
  403. package/dist/collection/components/field-wrapper/helper-text-util.js.map +1 -1
  404. package/dist/collection/components/filter-chip/filter-chip.js +1 -1
  405. package/dist/collection/components/flip-tile/flip-tile.js +3 -3
  406. package/dist/collection/components/flip-tile-content/flip-tile-content.js +1 -1
  407. package/dist/collection/components/group/group-context-menu.js +1 -1
  408. package/dist/collection/components/group/group.js +8 -8
  409. package/dist/collection/components/helper-text/helper-text.js +1 -1
  410. package/dist/collection/components/icon-button/icon-button.js +1 -1
  411. package/dist/collection/components/icon-toggle-button/icon-toggle-button.js +1 -1
  412. package/dist/collection/components/input/input.fc.js +10 -1
  413. package/dist/collection/components/input/input.fc.js.map +1 -1
  414. package/dist/collection/components/input/input.js +54 -5
  415. package/dist/collection/components/input/input.js.map +1 -1
  416. package/dist/collection/components/input/input.util.js +20 -3
  417. package/dist/collection/components/input/input.util.js.map +1 -1
  418. package/dist/collection/components/input/number-input.js +228 -36
  419. package/dist/collection/components/input/number-input.js.map +1 -1
  420. package/dist/collection/components/input/textarea.js +2 -2
  421. package/dist/collection/components/input-group/input-group.js +1 -1
  422. package/dist/collection/components/key-value/key-value.js +1 -1
  423. package/dist/collection/components/key-value-list/key-value-list.js +1 -1
  424. package/dist/collection/components/kpi/kpi.js +3 -3
  425. package/dist/collection/components/layout-auto/layout-auto.js +1 -1
  426. package/dist/collection/components/layout-grid/layout-grid.js +2 -2
  427. package/dist/collection/components/link-button/link-button.css +2 -8
  428. package/dist/collection/components/link-button/link-button.js +3 -3
  429. package/dist/collection/components/menu/menu-expand-icon.js +1 -1
  430. package/dist/collection/components/menu/menu.js +12 -22
  431. package/dist/collection/components/menu/menu.js.map +1 -1
  432. package/dist/collection/components/menu-about/menu-about.js +6 -4
  433. package/dist/collection/components/menu-about/menu-about.js.map +1 -1
  434. package/dist/collection/components/menu-about-item/menu-about-item.js +1 -1
  435. package/dist/collection/components/menu-about-news/menu-about-news.js +4 -4
  436. package/dist/collection/components/menu-avatar/menu-avatar.js +2 -2
  437. package/dist/collection/components/menu-avatar-item/menu-avatar-item.js +1 -1
  438. package/dist/collection/components/menu-category/menu-category.js +5 -5
  439. package/dist/collection/components/menu-item/menu-item.js +4 -4
  440. package/dist/collection/components/menu-settings/menu-settings.js +6 -4
  441. package/dist/collection/components/menu-settings/menu-settings.js.map +1 -1
  442. package/dist/collection/components/menu-settings-item/menu-settings-item.js +1 -1
  443. package/dist/collection/components/message-bar/message-bar.js +1 -1
  444. package/dist/collection/components/modal/modal.js +3 -3
  445. package/dist/collection/components/modal-content/modal-content.js +1 -1
  446. package/dist/collection/components/modal-footer/modal-footer.js +1 -1
  447. package/dist/collection/components/modal-header/modal-header.js +1 -1
  448. package/dist/collection/components/modal-loading/modal-loading.js +1 -1
  449. package/dist/collection/components/pagination/pagination.js +52 -7
  450. package/dist/collection/components/pagination/pagination.js.map +1 -1
  451. package/dist/collection/components/pane/pane.js +6 -6
  452. package/dist/collection/components/pane-layout/pane-layout.js +1 -1
  453. package/dist/collection/components/pill/pill.js +4 -4
  454. package/dist/collection/components/progress-indicator/progress-indicator.js +3 -3
  455. package/dist/collection/components/push-card/push-card.js +1 -1
  456. package/dist/collection/components/radio/radio.css +70 -72
  457. package/dist/collection/components/radio/radio.js +69 -18
  458. package/dist/collection/components/radio/radio.js.map +1 -1
  459. package/dist/collection/components/radio-group/radio-group.js +64 -2
  460. package/dist/collection/components/radio-group/radio-group.js.map +1 -1
  461. package/dist/collection/components/row/row.js +1 -1
  462. package/dist/collection/components/select/select.js +94 -14
  463. package/dist/collection/components/select/select.js.map +1 -1
  464. package/dist/collection/components/select-item/select-item.js +1 -1
  465. package/dist/collection/components/slider/slider.js +6 -6
  466. package/dist/collection/components/spinner/spinner.js +1 -1
  467. package/dist/collection/components/split-button/split-button.js +70 -12
  468. package/dist/collection/components/split-button/split-button.js.map +1 -1
  469. package/dist/collection/components/tab-item/tab-item.css +1 -1
  470. package/dist/collection/components/tab-item/tab-item.js +3 -3
  471. package/dist/collection/components/tabs/tabs.js +2 -2
  472. package/dist/collection/components/tile/tile.js +4 -4
  473. package/dist/collection/components/time-input/time-input.js +61 -9
  474. package/dist/collection/components/time-input/time-input.js.map +1 -1
  475. package/dist/collection/components/time-picker/time-picker.css +20 -52
  476. package/dist/collection/components/time-picker/time-picker.js +83 -48
  477. package/dist/collection/components/time-picker/time-picker.js.map +1 -1
  478. package/dist/collection/components/time-picker/time-picker.types.js.map +1 -1
  479. package/dist/collection/components/toast/toast-container.js +2 -2
  480. package/dist/collection/components/toast/toast.js +2 -2
  481. package/dist/collection/components/toggle/toggle.js +3 -3
  482. package/dist/collection/components/toggle/toggle.js.map +1 -1
  483. package/dist/collection/components/tooltip/tooltip.css +2 -3
  484. package/dist/collection/components/tooltip/tooltip.js +17 -6
  485. package/dist/collection/components/tooltip/tooltip.js.map +1 -1
  486. package/dist/collection/components/tree/tree.js +1 -1
  487. package/dist/collection/components/tree-item/tree-item.js +4 -4
  488. package/dist/collection/components/typography/typography.js +1 -1
  489. package/dist/collection/components/upload/upload.js +3 -3
  490. package/dist/collection/components/utils/application-layout/context.js +0 -1
  491. package/dist/collection/components/utils/application-layout/context.js.map +1 -1
  492. package/dist/collection/components/utils/input/validation.js +6 -0
  493. package/dist/collection/components/utils/input/validation.js.map +1 -1
  494. package/dist/collection/components/utils/menu-tabs/menu-tabs-utils.js +6 -1
  495. package/dist/collection/components/utils/menu-tabs/menu-tabs-utils.js.map +1 -1
  496. package/dist/collection/components/utils/modal/index.js.map +1 -1
  497. package/dist/collection/components/utils/modal/loading.js.map +1 -1
  498. package/dist/collection/components/validation-tooltip/validation-tooltip.js +2 -2
  499. package/dist/collection/components/workflow-step/workflow-step.js +3 -3
  500. package/dist/collection/components/workflow-steps/workflow-steps.js +1 -1
  501. package/dist/esm/{context-CKM5pVsv.js → context-BniHpAE1.js} +2 -3
  502. package/dist/{cjs/context-B8bRIFA2.js.map → esm/context-BniHpAE1.js.map} +1 -1
  503. package/dist/esm/{helper-text-util-rnbkuaac.js → helper-text-util-gKdL-wH2.js} +9 -5
  504. package/dist/esm/helper-text-util-gKdL-wH2.js.map +1 -0
  505. package/dist/esm/{index-Cz75KU1f.js → index-8HpPmDK_.js} +3 -3
  506. package/dist/esm/{index-Cz75KU1f.js.map → index-8HpPmDK_.js.map} +1 -1
  507. package/dist/esm/index-CtoreFVF.js +6 -18
  508. package/dist/esm/{index--ZIr3Aqz.js → index-Kp5Wf9wr.js} +3 -3
  509. package/dist/esm/{index--ZIr3Aqz.js.map → index-Kp5Wf9wr.js.map} +1 -1
  510. package/dist/esm/index.js +3 -3
  511. package/dist/esm/index.js.map +1 -1
  512. package/dist/esm/{input.util-VHrSuCP7.js → input.fc-KJF8Z9iJ.js} +69 -44
  513. package/dist/esm/input.fc-KJF8Z9iJ.js.map +1 -0
  514. package/dist/esm/ix-application-header.entry.js +13 -18
  515. package/dist/esm/ix-application-header.entry.js.map +1 -1
  516. package/dist/esm/ix-application-switch-modal.entry.js +2 -2
  517. package/dist/esm/ix-application.entry.js +4 -6
  518. package/dist/esm/ix-application.entry.js.map +1 -1
  519. package/dist/esm/ix-avatar_2.entry.js +1 -1
  520. package/dist/esm/ix-blind.entry.js +6 -6
  521. package/dist/esm/ix-breadcrumb-item.entry.js +1 -1
  522. package/dist/esm/ix-breadcrumb.entry.js +2 -2
  523. package/dist/esm/ix-card-accordion_2.entry.js +6 -6
  524. package/dist/esm/ix-card-list.entry.js +5 -5
  525. package/dist/esm/ix-card_2.entry.js +3 -3
  526. package/dist/esm/ix-category-filter.entry.js +15 -9
  527. package/dist/esm/ix-category-filter.entry.js.map +1 -1
  528. package/dist/esm/ix-checkbox-group.entry.js +3 -3
  529. package/dist/esm/ix-checkbox.entry.js +4 -4
  530. package/dist/esm/ix-chip.entry.js +5 -5
  531. package/dist/esm/ix-col.ix-date-picker.ix-layout-grid.ix-row.entry.js.map +1 -1
  532. package/dist/esm/ix-col_4.entry.js +11 -11
  533. package/dist/esm/ix-content-header.entry.js +4 -4
  534. package/dist/esm/ix-content.entry.js +3 -3
  535. package/dist/esm/ix-css-grid-item.entry.js +1 -1
  536. package/dist/esm/ix-css-grid.entry.js +1 -1
  537. package/dist/esm/ix-custom-field.entry.js +2 -2
  538. package/dist/esm/ix-date-dropdown.entry.js +5 -5
  539. package/dist/esm/ix-date-input.entry.js +21 -9
  540. package/dist/esm/ix-date-input.entry.js.map +1 -1
  541. package/dist/esm/ix-date-time-card.entry.js +3 -3
  542. package/dist/esm/ix-date-time-card.entry.js.map +1 -1
  543. package/dist/esm/ix-datetime-picker.entry.js +2 -2
  544. package/dist/esm/ix-datetime-picker.entry.js.map +1 -1
  545. package/dist/esm/ix-divider.entry.js +1 -1
  546. package/dist/esm/ix-drawer.entry.js +6 -6
  547. package/dist/esm/ix-dropdown-button.entry.js +4 -4
  548. package/dist/esm/ix-dropdown-header.entry.js +1 -1
  549. package/dist/esm/ix-dropdown-item.entry.js +4 -4
  550. package/dist/esm/ix-dropdown-quick-actions.entry.js +1 -1
  551. package/dist/esm/ix-dropdown.entry.js +2 -2
  552. package/dist/esm/ix-empty-state.entry.js +1 -1
  553. package/dist/esm/ix-event-list-item.entry.js +5 -5
  554. package/dist/esm/ix-event-list.entry.js +2 -2
  555. package/dist/esm/ix-expanding-search.entry.js +5 -5
  556. package/dist/esm/ix-field-label_2.entry.js +6 -6
  557. package/dist/esm/ix-filter-chip_2.entry.js +3 -3
  558. package/dist/esm/ix-flip-tile-content.entry.js +1 -1
  559. package/dist/esm/ix-flip-tile.entry.js +4 -4
  560. package/dist/esm/ix-group-context-menu_2.entry.js +2 -2
  561. package/dist/esm/ix-group.entry.js +9 -9
  562. package/dist/esm/ix-helper-text.entry.js +4 -4
  563. package/dist/esm/ix-icon-button_2.entry.js +2 -2
  564. package/dist/esm/ix-icon-toggle-button.entry.js +1 -1
  565. package/dist/esm/ix-input-group.entry.js +1 -1
  566. package/dist/esm/ix-input.entry.js +17 -8
  567. package/dist/esm/ix-input.entry.js.map +1 -1
  568. package/dist/esm/ix-key-value-list.entry.js +1 -1
  569. package/dist/esm/ix-key-value.entry.js +1 -1
  570. package/dist/esm/ix-kpi.entry.js +4 -4
  571. package/dist/esm/ix-layout-auto.entry.js +1 -1
  572. package/dist/esm/ix-link-button.entry.js +5 -5
  573. package/dist/esm/ix-link-button.entry.js.map +1 -1
  574. package/dist/esm/ix-menu-about-item.entry.js +1 -1
  575. package/dist/esm/ix-menu-about-news.entry.js +5 -5
  576. package/dist/esm/ix-menu-about.entry.js +7 -5
  577. package/dist/esm/ix-menu-about.entry.js.map +1 -1
  578. package/dist/esm/ix-menu-avatar.entry.js +3 -3
  579. package/dist/esm/ix-menu-category.entry.js +7 -7
  580. package/dist/esm/ix-menu-expand-icon.entry.js +2 -2
  581. package/dist/esm/ix-menu-item.entry.js +5 -5
  582. package/dist/esm/{ix-menu-settings-DRSkDgox.js → ix-menu-settings-f9o5GGw5.js} +15 -8
  583. package/dist/esm/ix-menu-settings-f9o5GGw5.js.map +1 -0
  584. package/dist/esm/ix-menu-settings-item.entry.js +1 -1
  585. package/dist/esm/ix-menu-settings.entry.js +2 -2
  586. package/dist/esm/ix-menu.entry.js +16 -26
  587. package/dist/esm/ix-menu.entry.js.map +1 -1
  588. package/dist/esm/ix-message-bar.entry.js +2 -2
  589. package/dist/esm/ix-modal-content_2.entry.js +3 -3
  590. package/dist/esm/ix-modal-footer.entry.js +1 -1
  591. package/dist/esm/ix-modal-loading.entry.js +1 -1
  592. package/dist/esm/ix-modal.entry.js +3 -3
  593. package/dist/esm/ix-number-input.entry.js +160 -32
  594. package/dist/esm/ix-number-input.entry.js.map +1 -1
  595. package/dist/esm/ix-pagination.entry.js +30 -8
  596. package/dist/esm/ix-pagination.entry.js.map +1 -1
  597. package/dist/esm/ix-pane-layout.entry.js +1 -1
  598. package/dist/esm/ix-pane.entry.js +7 -7
  599. package/dist/esm/ix-pill.entry.js +4 -4
  600. package/dist/esm/ix-progress-indicator.entry.js +4 -4
  601. package/dist/esm/ix-push-card.entry.js +1 -1
  602. package/dist/esm/ix-radio-group.entry.js +33 -3
  603. package/dist/esm/ix-radio-group.entry.js.map +1 -1
  604. package/dist/esm/ix-radio.entry.js +43 -18
  605. package/dist/esm/ix-radio.entry.js.map +1 -1
  606. package/dist/esm/ix-select.entry.js +54 -15
  607. package/dist/esm/ix-select.entry.js.map +1 -1
  608. package/dist/esm/ix-slider.entry.js +6 -6
  609. package/dist/esm/ix-split-button.entry.js +25 -13
  610. package/dist/esm/ix-split-button.entry.js.map +1 -1
  611. package/dist/esm/ix-tab-item.ix-tabs.entry.js.map +1 -1
  612. package/dist/esm/ix-tab-item_2.entry.js +7 -7
  613. package/dist/esm/ix-textarea.entry.js +4 -4
  614. package/dist/esm/ix-tile.entry.js +4 -4
  615. package/dist/esm/ix-time-input.entry.js +22 -10
  616. package/dist/esm/ix-time-input.entry.js.map +1 -1
  617. package/dist/esm/ix-time-picker.entry.js +81 -45
  618. package/dist/esm/ix-time-picker.entry.js.map +1 -1
  619. package/dist/esm/ix-toast-container.entry.js +2 -2
  620. package/dist/esm/ix-toast.entry.js +3 -3
  621. package/dist/esm/ix-toggle.entry.js +4 -4
  622. package/dist/esm/ix-toggle.entry.js.map +1 -1
  623. package/dist/esm/ix-tooltip.entry.js +17 -6
  624. package/dist/esm/ix-tooltip.entry.js.map +1 -1
  625. package/dist/esm/ix-tree-item.entry.js +5 -5
  626. package/dist/esm/ix-tree.entry.js +1 -1
  627. package/dist/esm/ix-typography.entry.js +1 -1
  628. package/dist/esm/ix-upload.entry.js +4 -4
  629. package/dist/esm/ix-validation-tooltip.entry.js +2 -2
  630. package/dist/esm/ix-workflow-step.entry.js +4 -4
  631. package/dist/esm/ix-workflow-steps.entry.js +1 -1
  632. package/dist/esm/loader.js +1 -1
  633. package/dist/esm/{modal-D9BaTrTa.js → modal-BTxff2hq.js} +3 -3
  634. package/dist/esm/{modal-D9BaTrTa.js.map → modal-BTxff2hq.js.map} +1 -1
  635. package/dist/esm/siemens-ix.js +1 -1
  636. package/dist/esm/{validation-D_dk-JqT.js → validation-LJh16vt2.js} +9 -3
  637. package/dist/{cjs/validation-CfL71_0d.js.map → esm/validation-LJh16vt2.js.map} +1 -1
  638. package/dist/siemens-ix/index.esm.js +1 -1
  639. package/dist/siemens-ix/index.esm.js.map +1 -1
  640. package/dist/siemens-ix/ix-application-header.entry.esm.js.map +1 -1
  641. package/dist/siemens-ix/ix-application.entry.esm.js.map +1 -1
  642. package/dist/siemens-ix/ix-category-filter.entry.esm.js.map +1 -1
  643. package/dist/siemens-ix/ix-col.ix-date-picker.ix-layout-grid.ix-row.entry.esm.js.map +1 -1
  644. package/dist/siemens-ix/ix-date-input.entry.esm.js.map +1 -1
  645. package/dist/siemens-ix/ix-date-time-card.entry.esm.js.map +1 -1
  646. package/dist/siemens-ix/ix-datetime-picker.entry.esm.js.map +1 -1
  647. package/dist/siemens-ix/ix-input.entry.esm.js.map +1 -1
  648. package/dist/siemens-ix/ix-link-button.entry.esm.js.map +1 -1
  649. package/dist/siemens-ix/ix-menu-about.entry.esm.js.map +1 -1
  650. package/dist/siemens-ix/ix-menu.entry.esm.js.map +1 -1
  651. package/dist/siemens-ix/ix-number-input.entry.esm.js.map +1 -1
  652. package/dist/siemens-ix/ix-pagination.entry.esm.js.map +1 -1
  653. package/dist/siemens-ix/ix-radio-group.entry.esm.js.map +1 -1
  654. package/dist/siemens-ix/ix-radio.entry.esm.js.map +1 -1
  655. package/dist/siemens-ix/ix-select.entry.esm.js.map +1 -1
  656. package/dist/siemens-ix/ix-split-button.entry.esm.js.map +1 -1
  657. package/dist/siemens-ix/ix-tab-item.ix-tabs.entry.esm.js.map +1 -1
  658. package/dist/siemens-ix/ix-time-input.entry.esm.js.map +1 -1
  659. package/dist/siemens-ix/ix-time-picker.entry.esm.js.map +1 -1
  660. package/dist/siemens-ix/ix-toggle.entry.esm.js.map +1 -1
  661. package/dist/siemens-ix/ix-tooltip.entry.esm.js.map +1 -1
  662. package/dist/siemens-ix/p-0411df39.entry.js +2 -0
  663. package/dist/siemens-ix/p-051f428c.entry.js +2 -0
  664. package/dist/siemens-ix/{p-f753f1f5.entry.js.map → p-051f428c.entry.js.map} +1 -1
  665. package/dist/siemens-ix/{p-6f152ed2.entry.js → p-06a2c69b.entry.js} +2 -2
  666. package/dist/siemens-ix/p-07c079fd.entry.js +2 -0
  667. package/dist/siemens-ix/{p-f29f280b.entry.js.map → p-07c079fd.entry.js.map} +1 -1
  668. package/dist/siemens-ix/p-0c325f08.entry.js +2 -0
  669. package/dist/siemens-ix/p-0c325f08.entry.js.map +1 -0
  670. package/dist/siemens-ix/{p-7e6beda5.entry.js → p-0ce03ad3.entry.js} +2 -2
  671. package/dist/siemens-ix/{p-17a74a48.entry.js → p-0d621531.entry.js} +2 -2
  672. package/dist/siemens-ix/p-0eca5a77.entry.js +2 -0
  673. package/dist/siemens-ix/{p-75d8b192.entry.js.map → p-0eca5a77.entry.js.map} +1 -1
  674. package/dist/siemens-ix/{p-f9b4e5f1.entry.js → p-162a4cc0.entry.js} +2 -2
  675. package/dist/siemens-ix/{p-337a3457.entry.js → p-196cffb5.entry.js} +2 -2
  676. package/dist/siemens-ix/{p-3acbbe01.entry.js → p-1de1a2bf.entry.js} +2 -2
  677. package/dist/siemens-ix/{p-89449e22.entry.js → p-2597a988.entry.js} +2 -2
  678. package/dist/siemens-ix/{p-4b1745dc.entry.js → p-26c629c3.entry.js} +2 -2
  679. package/dist/siemens-ix/p-26c629c3.entry.js.map +1 -0
  680. package/dist/siemens-ix/{p-e825a921.entry.js → p-2ffde2d5.entry.js} +2 -2
  681. package/dist/siemens-ix/{p-759ba03d.entry.js → p-31a8eaf9.entry.js} +2 -2
  682. package/dist/siemens-ix/p-33b3ed5b.entry.js +2 -0
  683. package/dist/siemens-ix/p-33b3ed5b.entry.js.map +1 -0
  684. package/dist/siemens-ix/{p-7cf61ff6.entry.js → p-33fcea65.entry.js} +2 -2
  685. package/dist/siemens-ix/p-35d6b656.entry.js +2 -0
  686. package/dist/siemens-ix/p-35d6b656.entry.js.map +1 -0
  687. package/dist/siemens-ix/{p-34e530b9.entry.js → p-367df024.entry.js} +2 -2
  688. package/dist/siemens-ix/{p-67e4f814.entry.js → p-37bd983a.entry.js} +2 -2
  689. package/dist/siemens-ix/{p-a02e0685.entry.js → p-38e45020.entry.js} +2 -2
  690. package/dist/siemens-ix/{p-fabcc5f5.entry.js → p-396e1f3d.entry.js} +2 -2
  691. package/dist/siemens-ix/p-3ce5fd87.entry.js +2 -0
  692. package/dist/siemens-ix/p-3ce5fd87.entry.js.map +1 -0
  693. package/dist/siemens-ix/p-3f62166e.entry.js +2 -0
  694. package/dist/siemens-ix/{p-9d135d59.entry.js.map → p-3f62166e.entry.js.map} +1 -1
  695. package/dist/siemens-ix/p-425d6925.entry.js +2 -0
  696. package/dist/siemens-ix/{p-9c862819.entry.js → p-4431f891.entry.js} +2 -2
  697. package/dist/siemens-ix/{p-9c862819.entry.js.map → p-4431f891.entry.js.map} +1 -1
  698. package/dist/siemens-ix/{p-db9d5872.entry.js → p-484bddf4.entry.js} +2 -2
  699. package/dist/siemens-ix/{p-51786593.entry.js → p-496e98ac.entry.js} +2 -2
  700. package/dist/siemens-ix/{p-7388d2ee.entry.js → p-4c18f123.entry.js} +2 -2
  701. package/dist/siemens-ix/{p-548a2231.entry.js → p-4c1f90cb.entry.js} +2 -2
  702. package/dist/siemens-ix/{p-3b314194.entry.js → p-4e4d792d.entry.js} +2 -2
  703. package/dist/siemens-ix/p-4e77d861.entry.js +2 -0
  704. package/dist/siemens-ix/{p-d8fb5a86.entry.js → p-5779f16e.entry.js} +2 -2
  705. package/dist/siemens-ix/{p-48cbacaf.entry.js → p-5b57bde1.entry.js} +2 -2
  706. package/dist/siemens-ix/{p-aa6368b4.entry.js → p-667e3184.entry.js} +2 -2
  707. package/dist/siemens-ix/p-68aaf0fe.entry.js +2 -0
  708. package/dist/siemens-ix/p-68aaf0fe.entry.js.map +1 -0
  709. package/dist/siemens-ix/{p-538843d4.entry.js → p-6a4bc78a.entry.js} +2 -2
  710. package/dist/siemens-ix/{p-4b65234d.entry.js → p-6dc6eb63.entry.js} +2 -2
  711. package/dist/siemens-ix/p-70af7f44.entry.js +2 -0
  712. package/dist/siemens-ix/{p-788e1ef8.entry.js → p-74e7b03f.entry.js} +2 -2
  713. package/dist/siemens-ix/{p-e562ffb2.entry.js → p-77fd2138.entry.js} +2 -2
  714. package/dist/siemens-ix/{p-0d4f0223.entry.js → p-7827c263.entry.js} +2 -2
  715. package/dist/siemens-ix/p-79537728.entry.js +2 -0
  716. package/dist/siemens-ix/p-79537728.entry.js.map +1 -0
  717. package/dist/siemens-ix/{p-a4d6ee80.entry.js → p-7bad0544.entry.js} +2 -2
  718. package/dist/siemens-ix/{p-e25aa385.entry.js → p-7beba4ad.entry.js} +2 -2
  719. package/dist/siemens-ix/p-7beba4ad.entry.js.map +1 -0
  720. package/dist/siemens-ix/p-8418f756.entry.js +2 -0
  721. package/dist/siemens-ix/p-8418f756.entry.js.map +1 -0
  722. package/dist/siemens-ix/{p-Cz75KU1f.js → p-8HpPmDK_.js} +2 -2
  723. package/dist/siemens-ix/{p-Cz75KU1f.js.map → p-8HpPmDK_.js.map} +1 -1
  724. package/dist/siemens-ix/p-8b42ad35.entry.js +2 -0
  725. package/dist/siemens-ix/{p-5e86944d.entry.js.map → p-8b42ad35.entry.js.map} +1 -1
  726. package/dist/siemens-ix/{p-784c6dd6.entry.js → p-8ce61408.entry.js} +2 -2
  727. package/dist/siemens-ix/{p-c0064123.entry.js → p-8f17f6ec.entry.js} +2 -2
  728. package/dist/siemens-ix/{p-67766c28.entry.js → p-8f9368b8.entry.js} +2 -2
  729. package/dist/siemens-ix/p-8fa8d0e3.entry.js +2 -0
  730. package/dist/siemens-ix/{p-3472fc1a.entry.js → p-8fc2bea6.entry.js} +2 -2
  731. package/dist/siemens-ix/{p-9e7223f6.entry.js → p-905d4977.entry.js} +2 -2
  732. package/dist/siemens-ix/p-92ec7f27.entry.js +2 -0
  733. package/dist/siemens-ix/{p-CpVbQsUI.js → p-BC0Exw_O.js} +2 -2
  734. package/dist/siemens-ix/{p-CpVbQsUI.js.map → p-BC0Exw_O.js.map} +1 -1
  735. package/dist/siemens-ix/{p-sxLz5AVO.js → p-BcCDexod.js} +2 -2
  736. package/dist/siemens-ix/p-BcCDexod.js.map +1 -0
  737. package/dist/siemens-ix/{p--2LOMK-5.js → p-BhgW5qDm.js} +2 -2
  738. package/dist/siemens-ix/{p--2LOMK-5.js.map → p-BhgW5qDm.js.map} +1 -1
  739. package/dist/siemens-ix/{p-CAj3Tlcn.js → p-C7nQNUsO.js} +2 -2
  740. package/dist/siemens-ix/{p-CAj3Tlcn.js.map → p-C7nQNUsO.js.map} +1 -1
  741. package/dist/siemens-ix/{p-DRnSC9aV.js → p-CObJ-t0Z.js} +2 -2
  742. package/dist/siemens-ix/{p-DRnSC9aV.js.map → p-CObJ-t0Z.js.map} +1 -1
  743. package/dist/siemens-ix/p-Cn013Iz8.js +2 -0
  744. package/dist/siemens-ix/p-Cn013Iz8.js.map +1 -0
  745. package/dist/siemens-ix/p-DaswuiGO.js +2 -0
  746. package/dist/siemens-ix/p-DaswuiGO.js.map +1 -0
  747. package/dist/siemens-ix/p-a3baca2f.entry.js +2 -0
  748. package/dist/siemens-ix/{p-0e2b89f2.entry.js → p-a4225101.entry.js} +2 -2
  749. package/dist/siemens-ix/p-a61972c5.entry.js +2 -0
  750. package/dist/siemens-ix/{p-2180ddb8.entry.js.map → p-a61972c5.entry.js.map} +1 -1
  751. package/dist/siemens-ix/{p-20ad8d1e.entry.js → p-b27a9744.entry.js} +2 -2
  752. package/dist/siemens-ix/{p-fea12773.entry.js → p-b3453edf.entry.js} +2 -2
  753. package/dist/siemens-ix/{p-556417c6.entry.js → p-b41a7abb.entry.js} +2 -2
  754. package/dist/siemens-ix/{p-957d0d0b.entry.js → p-b76df1c7.entry.js} +2 -2
  755. package/dist/siemens-ix/{p-65842e35.entry.js → p-b7ef70d4.entry.js} +2 -2
  756. package/dist/siemens-ix/{p-b7c5ab43.entry.js → p-b8f4b001.entry.js} +2 -2
  757. package/dist/siemens-ix/p-b8f4b001.entry.js.map +1 -0
  758. package/dist/siemens-ix/{p-2f54ce99.entry.js → p-b9880608.entry.js} +2 -2
  759. package/dist/siemens-ix/p-ba9ed3d1.entry.js +2 -0
  760. package/dist/siemens-ix/p-ba9ed3d1.entry.js.map +1 -0
  761. package/dist/siemens-ix/p-c15e64a8.entry.js +2 -0
  762. package/dist/siemens-ix/p-c15e64a8.entry.js.map +1 -0
  763. package/dist/siemens-ix/{p-467c0fff.entry.js → p-c43b201b.entry.js} +2 -2
  764. package/dist/siemens-ix/{p-fc3071d0.entry.js → p-c5c863e1.entry.js} +2 -2
  765. package/dist/siemens-ix/{p-d1941577.entry.js → p-c94739d0.entry.js} +2 -2
  766. package/dist/siemens-ix/{p-04f1b89a.entry.js → p-ca3b24b1.entry.js} +2 -2
  767. package/dist/siemens-ix/p-ca43aa61.entry.js +2 -0
  768. package/dist/siemens-ix/{p-58219b7e.entry.js → p-cd1afcc9.entry.js} +2 -2
  769. package/dist/siemens-ix/{p-d4ba3f9f.entry.js → p-cf041cfd.entry.js} +2 -2
  770. package/dist/siemens-ix/{p-80f55403.entry.js → p-d10b9798.entry.js} +2 -2
  771. package/dist/siemens-ix/{p-ecff1e2f.entry.js → p-d193381f.entry.js} +2 -2
  772. package/dist/siemens-ix/{p-f3b485de.entry.js → p-d2c18c15.entry.js} +2 -2
  773. package/dist/siemens-ix/p-d2c18c15.entry.js.map +1 -0
  774. package/dist/siemens-ix/{p-dff78943.entry.js → p-d3a60c52.entry.js} +2 -2
  775. package/dist/siemens-ix/p-d688f76e.entry.js +2 -0
  776. package/dist/siemens-ix/{p-d49f7ae4.entry.js.map → p-d688f76e.entry.js.map} +1 -1
  777. package/dist/siemens-ix/{p-41b9392e.entry.js → p-da3a9845.entry.js} +2 -2
  778. package/dist/siemens-ix/p-dc8de6cb.entry.js +2 -0
  779. package/dist/siemens-ix/p-dc8de6cb.entry.js.map +1 -0
  780. package/dist/siemens-ix/p-de12078d.entry.js +2 -0
  781. package/dist/siemens-ix/{p-608b3631.entry.js.map → p-de12078d.entry.js.map} +1 -1
  782. package/dist/siemens-ix/{p-94fa5d00.entry.js → p-df6bb698.entry.js} +2 -2
  783. package/dist/siemens-ix/{p-85f3aa13.entry.js → p-e0b9cf68.entry.js} +2 -2
  784. package/dist/siemens-ix/{p-81120f11.entry.js → p-e42f62a1.entry.js} +2 -2
  785. package/dist/siemens-ix/{p-da6a27c1.entry.js → p-e48977ed.entry.js} +2 -2
  786. package/dist/siemens-ix/{p-2db36aa6.entry.js → p-e7bdc0a0.entry.js} +2 -2
  787. package/dist/siemens-ix/p-e7bdc0a0.entry.js.map +1 -0
  788. package/dist/siemens-ix/{p-1f5befb2.entry.js → p-ea15fc79.entry.js} +2 -2
  789. package/dist/siemens-ix/{p-4448252f.entry.js → p-ea37abf6.entry.js} +2 -2
  790. package/dist/siemens-ix/{p-b5e0ddb3.entry.js → p-ea410634.entry.js} +2 -2
  791. package/dist/siemens-ix/{p-39950a1c.entry.js → p-eba7f62c.entry.js} +2 -2
  792. package/dist/siemens-ix/{p-9d8fb7dd.entry.js → p-f119c105.entry.js} +2 -2
  793. package/dist/siemens-ix/p-fb8877bc.entry.js +2 -0
  794. package/dist/siemens-ix/p-fb8877bc.entry.js.map +1 -0
  795. package/dist/siemens-ix/{p-347fcf94.entry.js → p-fc73c8cc.entry.js} +2 -2
  796. package/dist/siemens-ix/{p-79798af1.entry.js → p-ff83eafd.entry.js} +2 -2
  797. package/dist/siemens-ix/siemens-ix-core.css +1 -1
  798. package/dist/siemens-ix/siemens-ix.css +2 -22
  799. package/dist/siemens-ix/siemens-ix.esm.js +1 -1
  800. package/dist/types/components/date-input/date-input.d.ts +10 -0
  801. package/dist/types/components/field-wrapper/helper-text-util.d.ts +5 -1
  802. package/dist/types/components/input/input.d.ts +9 -0
  803. package/dist/types/components/input/input.fc.d.ts +6 -0
  804. package/dist/types/components/input/input.util.d.ts +1 -0
  805. package/dist/types/components/input/number-input.d.ts +31 -5
  806. package/dist/types/components/menu-about/menu-about.d.ts +1 -1
  807. package/dist/types/components/menu-settings/menu-settings.d.ts +1 -1
  808. package/dist/types/components/pagination/pagination.d.ts +8 -0
  809. package/dist/types/components/radio/radio.d.ts +3 -2
  810. package/dist/types/components/radio-group/radio-group.d.ts +3 -0
  811. package/dist/types/components/select/select.d.ts +11 -0
  812. package/dist/types/components/split-button/split-button.d.ts +15 -4
  813. package/dist/types/components/time-input/time-input.d.ts +10 -0
  814. package/dist/types/components/time-picker/time-picker.d.ts +8 -2
  815. package/dist/types/components/tooltip/tooltip.d.ts +2 -1
  816. package/dist/types/components/utils/application-layout/context.d.ts +0 -1
  817. package/dist/types/components/utils/input/validation.d.ts +1 -0
  818. package/dist/types/components/utils/menu-tabs/menu-tabs-utils.d.ts +1 -0
  819. package/dist/types/components/utils/modal/index.d.ts +1 -1
  820. package/dist/types/components/utils/modal/loading.d.ts +4 -0
  821. package/dist/types/components.d.ts +162 -241
  822. package/hydrate/index.js +835 -791
  823. package/hydrate/index.mjs +835 -791
  824. package/package.json +1 -1
  825. package/scss/components/_links.scss +2 -5
  826. package/scss/mixins/_input.scss +2 -2
  827. package/scss/theme/classic/dark/_variables.scss +1 -1
  828. package/scss/theme/core/_components.scss +0 -2
  829. package/components/ix-basic-navigation.d.ts +0 -11
  830. package/components/ix-basic-navigation.js +0 -156
  831. package/components/ix-basic-navigation.js.map +0 -1
  832. package/components/ix-map-navigation-overlay.d.ts +0 -11
  833. package/components/ix-map-navigation-overlay.js +0 -9
  834. package/components/ix-map-navigation-overlay.js.map +0 -1
  835. package/components/ix-map-navigation.d.ts +0 -11
  836. package/components/ix-map-navigation.js +0 -240
  837. package/components/ix-map-navigation.js.map +0 -1
  838. package/components/p--2LOMK-5.js.map +0 -1
  839. package/components/p-0MSWDTqB.js.map +0 -1
  840. package/components/p-2fxFa_VL.js.map +0 -1
  841. package/components/p-BUIOrNGz.js.map +0 -1
  842. package/components/p-BaWdG-ph.js.map +0 -1
  843. package/components/p-Bvf7gwPU.js.map +0 -1
  844. package/components/p-CQhe_rqk.js.map +0 -1
  845. package/components/p-DBsESzrF.js.map +0 -1
  846. package/components/p-DLPEB4G8.js.map +0 -1
  847. package/components/p-D_rmJU0n.js.map +0 -1
  848. package/components/p-IgT3dgxG.js.map +0 -1
  849. package/components/p-UEMLzDk6.js +0 -92
  850. package/components/p-UEMLzDk6.js.map +0 -1
  851. package/components/p-yuZO1O90.js +0 -273
  852. package/components/p-yuZO1O90.js.map +0 -1
  853. package/dist/cjs/helper-text-util-BlElJLxk.js.map +0 -1
  854. package/dist/cjs/input.util-4AhBphgX.js.map +0 -1
  855. package/dist/cjs/ix-basic-navigation.cjs.entry.js +0 -93
  856. package/dist/cjs/ix-basic-navigation.entry.cjs.js.map +0 -1
  857. package/dist/cjs/ix-map-navigation-overlay.cjs.entry.js +0 -56
  858. package/dist/cjs/ix-map-navigation-overlay.entry.cjs.js.map +0 -1
  859. package/dist/cjs/ix-map-navigation.cjs.entry.js +0 -169
  860. package/dist/cjs/ix-map-navigation.entry.cjs.js.map +0 -1
  861. package/dist/cjs/ix-menu-settings-Cdqo0r8E.js.map +0 -1
  862. package/dist/collection/components/basic-navigation/basic-navigation.css +0 -113
  863. package/dist/collection/components/basic-navigation/basic-navigation.js +0 -209
  864. package/dist/collection/components/basic-navigation/basic-navigation.js.map +0 -1
  865. package/dist/collection/components/map-navigation/map-navigation.css +0 -212
  866. package/dist/collection/components/map-navigation/map-navigation.js +0 -401
  867. package/dist/collection/components/map-navigation/map-navigation.js.map +0 -1
  868. package/dist/collection/components/map-navigation-overlay/map-navigation-overlay.css +0 -156
  869. package/dist/collection/components/map-navigation-overlay/map-navigation-overlay.js +0 -209
  870. package/dist/collection/components/map-navigation-overlay/map-navigation-overlay.js.map +0 -1
  871. package/dist/esm/helper-text-util-rnbkuaac.js.map +0 -1
  872. package/dist/esm/input.util-VHrSuCP7.js.map +0 -1
  873. package/dist/esm/ix-basic-navigation.entry.js +0 -91
  874. package/dist/esm/ix-basic-navigation.entry.js.map +0 -1
  875. package/dist/esm/ix-map-navigation-overlay.entry.js +0 -54
  876. package/dist/esm/ix-map-navigation-overlay.entry.js.map +0 -1
  877. package/dist/esm/ix-map-navigation.entry.js +0 -167
  878. package/dist/esm/ix-map-navigation.entry.js.map +0 -1
  879. package/dist/esm/ix-menu-settings-DRSkDgox.js.map +0 -1
  880. package/dist/siemens-ix/ix-basic-navigation.entry.esm.js.map +0 -1
  881. package/dist/siemens-ix/ix-map-navigation-overlay.entry.esm.js.map +0 -1
  882. package/dist/siemens-ix/ix-map-navigation.entry.esm.js.map +0 -1
  883. package/dist/siemens-ix/p-01030dfb.entry.js +0 -2
  884. package/dist/siemens-ix/p-01030dfb.entry.js.map +0 -1
  885. package/dist/siemens-ix/p-08f4c3f0.entry.js +0 -2
  886. package/dist/siemens-ix/p-2055daf3.entry.js +0 -2
  887. package/dist/siemens-ix/p-2055daf3.entry.js.map +0 -1
  888. package/dist/siemens-ix/p-2180ddb8.entry.js +0 -2
  889. package/dist/siemens-ix/p-2db36aa6.entry.js.map +0 -1
  890. package/dist/siemens-ix/p-4b1745dc.entry.js.map +0 -1
  891. package/dist/siemens-ix/p-4f2fb1c5.entry.js +0 -2
  892. package/dist/siemens-ix/p-4f2fb1c5.entry.js.map +0 -1
  893. package/dist/siemens-ix/p-52d377d1.entry.js +0 -2
  894. package/dist/siemens-ix/p-52d377d1.entry.js.map +0 -1
  895. package/dist/siemens-ix/p-5e86944d.entry.js +0 -2
  896. package/dist/siemens-ix/p-608b3631.entry.js +0 -2
  897. package/dist/siemens-ix/p-710af987.entry.js +0 -2
  898. package/dist/siemens-ix/p-710af987.entry.js.map +0 -1
  899. package/dist/siemens-ix/p-730a6161.entry.js +0 -2
  900. package/dist/siemens-ix/p-730a6161.entry.js.map +0 -1
  901. package/dist/siemens-ix/p-75d8b192.entry.js +0 -2
  902. package/dist/siemens-ix/p-7e612a3b.entry.js +0 -2
  903. package/dist/siemens-ix/p-7e612a3b.entry.js.map +0 -1
  904. package/dist/siemens-ix/p-845054ca.entry.js +0 -2
  905. package/dist/siemens-ix/p-879a0cc5.entry.js +0 -2
  906. package/dist/siemens-ix/p-879a0cc5.entry.js.map +0 -1
  907. package/dist/siemens-ix/p-8aa0fda7.entry.js +0 -2
  908. package/dist/siemens-ix/p-8aa0fda7.entry.js.map +0 -1
  909. package/dist/siemens-ix/p-92a6324b.entry.js +0 -2
  910. package/dist/siemens-ix/p-9d135d59.entry.js +0 -2
  911. package/dist/siemens-ix/p-CX3n_rRh.js +0 -2
  912. package/dist/siemens-ix/p-CX3n_rRh.js.map +0 -1
  913. package/dist/siemens-ix/p-DS9crO46.js +0 -2
  914. package/dist/siemens-ix/p-DS9crO46.js.map +0 -1
  915. package/dist/siemens-ix/p-ad20efd0.entry.js +0 -2
  916. package/dist/siemens-ix/p-b6736ce7.entry.js +0 -2
  917. package/dist/siemens-ix/p-b6736ce7.entry.js.map +0 -1
  918. package/dist/siemens-ix/p-b7c5ab43.entry.js.map +0 -1
  919. package/dist/siemens-ix/p-c4b26603.entry.js +0 -2
  920. package/dist/siemens-ix/p-cc80918d.entry.js +0 -2
  921. package/dist/siemens-ix/p-d120adf6.entry.js +0 -2
  922. package/dist/siemens-ix/p-d120adf6.entry.js.map +0 -1
  923. package/dist/siemens-ix/p-d49f7ae4.entry.js +0 -2
  924. package/dist/siemens-ix/p-dd89a190.entry.js +0 -2
  925. package/dist/siemens-ix/p-e25aa385.entry.js.map +0 -1
  926. package/dist/siemens-ix/p-e3c57208.entry.js +0 -2
  927. package/dist/siemens-ix/p-eebe632b.entry.js +0 -2
  928. package/dist/siemens-ix/p-eebe632b.entry.js.map +0 -1
  929. package/dist/siemens-ix/p-eef311b1.entry.js +0 -2
  930. package/dist/siemens-ix/p-eef311b1.entry.js.map +0 -1
  931. package/dist/siemens-ix/p-f29f280b.entry.js +0 -2
  932. package/dist/siemens-ix/p-f3b485de.entry.js.map +0 -1
  933. package/dist/siemens-ix/p-f753f1f5.entry.js +0 -2
  934. package/dist/siemens-ix/p-f82e4e0f.entry.js +0 -2
  935. package/dist/siemens-ix/p-f82e4e0f.entry.js.map +0 -1
  936. package/dist/siemens-ix/p-sxLz5AVO.js.map +0 -1
  937. package/dist/types/components/basic-navigation/basic-navigation.d.ts +0 -33
  938. package/dist/types/components/map-navigation/map-navigation.d.ts +0 -68
  939. package/dist/types/components/map-navigation-overlay/map-navigation-overlay.d.ts +0 -43
  940. package/scss/theme/core/components/map-navigation.scss +0 -20
  941. /package/dist/siemens-ix/{p-08f4c3f0.entry.js.map → p-0411df39.entry.js.map} +0 -0
  942. /package/dist/siemens-ix/{p-6f152ed2.entry.js.map → p-06a2c69b.entry.js.map} +0 -0
  943. /package/dist/siemens-ix/{p-7e6beda5.entry.js.map → p-0ce03ad3.entry.js.map} +0 -0
  944. /package/dist/siemens-ix/{p-17a74a48.entry.js.map → p-0d621531.entry.js.map} +0 -0
  945. /package/dist/siemens-ix/{p-f9b4e5f1.entry.js.map → p-162a4cc0.entry.js.map} +0 -0
  946. /package/dist/siemens-ix/{p-337a3457.entry.js.map → p-196cffb5.entry.js.map} +0 -0
  947. /package/dist/siemens-ix/{p-3acbbe01.entry.js.map → p-1de1a2bf.entry.js.map} +0 -0
  948. /package/dist/siemens-ix/{p-89449e22.entry.js.map → p-2597a988.entry.js.map} +0 -0
  949. /package/dist/siemens-ix/{p-e825a921.entry.js.map → p-2ffde2d5.entry.js.map} +0 -0
  950. /package/dist/siemens-ix/{p-759ba03d.entry.js.map → p-31a8eaf9.entry.js.map} +0 -0
  951. /package/dist/siemens-ix/{p-7cf61ff6.entry.js.map → p-33fcea65.entry.js.map} +0 -0
  952. /package/dist/siemens-ix/{p-34e530b9.entry.js.map → p-367df024.entry.js.map} +0 -0
  953. /package/dist/siemens-ix/{p-67e4f814.entry.js.map → p-37bd983a.entry.js.map} +0 -0
  954. /package/dist/siemens-ix/{p-a02e0685.entry.js.map → p-38e45020.entry.js.map} +0 -0
  955. /package/dist/siemens-ix/{p-fabcc5f5.entry.js.map → p-396e1f3d.entry.js.map} +0 -0
  956. /package/dist/siemens-ix/{p-845054ca.entry.js.map → p-425d6925.entry.js.map} +0 -0
  957. /package/dist/siemens-ix/{p-db9d5872.entry.js.map → p-484bddf4.entry.js.map} +0 -0
  958. /package/dist/siemens-ix/{p-51786593.entry.js.map → p-496e98ac.entry.js.map} +0 -0
  959. /package/dist/siemens-ix/{p-7388d2ee.entry.js.map → p-4c18f123.entry.js.map} +0 -0
  960. /package/dist/siemens-ix/{p-548a2231.entry.js.map → p-4c1f90cb.entry.js.map} +0 -0
  961. /package/dist/siemens-ix/{p-3b314194.entry.js.map → p-4e4d792d.entry.js.map} +0 -0
  962. /package/dist/siemens-ix/{p-dd89a190.entry.js.map → p-4e77d861.entry.js.map} +0 -0
  963. /package/dist/siemens-ix/{p-d8fb5a86.entry.js.map → p-5779f16e.entry.js.map} +0 -0
  964. /package/dist/siemens-ix/{p-48cbacaf.entry.js.map → p-5b57bde1.entry.js.map} +0 -0
  965. /package/dist/siemens-ix/{p-aa6368b4.entry.js.map → p-667e3184.entry.js.map} +0 -0
  966. /package/dist/siemens-ix/{p-538843d4.entry.js.map → p-6a4bc78a.entry.js.map} +0 -0
  967. /package/dist/siemens-ix/{p-4b65234d.entry.js.map → p-6dc6eb63.entry.js.map} +0 -0
  968. /package/dist/siemens-ix/{p-e3c57208.entry.js.map → p-70af7f44.entry.js.map} +0 -0
  969. /package/dist/siemens-ix/{p-788e1ef8.entry.js.map → p-74e7b03f.entry.js.map} +0 -0
  970. /package/dist/siemens-ix/{p-e562ffb2.entry.js.map → p-77fd2138.entry.js.map} +0 -0
  971. /package/dist/siemens-ix/{p-0d4f0223.entry.js.map → p-7827c263.entry.js.map} +0 -0
  972. /package/dist/siemens-ix/{p-a4d6ee80.entry.js.map → p-7bad0544.entry.js.map} +0 -0
  973. /package/dist/siemens-ix/{p-784c6dd6.entry.js.map → p-8ce61408.entry.js.map} +0 -0
  974. /package/dist/siemens-ix/{p-c0064123.entry.js.map → p-8f17f6ec.entry.js.map} +0 -0
  975. /package/dist/siemens-ix/{p-67766c28.entry.js.map → p-8f9368b8.entry.js.map} +0 -0
  976. /package/dist/siemens-ix/{p-92a6324b.entry.js.map → p-8fa8d0e3.entry.js.map} +0 -0
  977. /package/dist/siemens-ix/{p-3472fc1a.entry.js.map → p-8fc2bea6.entry.js.map} +0 -0
  978. /package/dist/siemens-ix/{p-9e7223f6.entry.js.map → p-905d4977.entry.js.map} +0 -0
  979. /package/dist/siemens-ix/{p-c4b26603.entry.js.map → p-92ec7f27.entry.js.map} +0 -0
  980. /package/dist/siemens-ix/{p-ad20efd0.entry.js.map → p-a3baca2f.entry.js.map} +0 -0
  981. /package/dist/siemens-ix/{p-0e2b89f2.entry.js.map → p-a4225101.entry.js.map} +0 -0
  982. /package/dist/siemens-ix/{p-20ad8d1e.entry.js.map → p-b27a9744.entry.js.map} +0 -0
  983. /package/dist/siemens-ix/{p-fea12773.entry.js.map → p-b3453edf.entry.js.map} +0 -0
  984. /package/dist/siemens-ix/{p-556417c6.entry.js.map → p-b41a7abb.entry.js.map} +0 -0
  985. /package/dist/siemens-ix/{p-957d0d0b.entry.js.map → p-b76df1c7.entry.js.map} +0 -0
  986. /package/dist/siemens-ix/{p-65842e35.entry.js.map → p-b7ef70d4.entry.js.map} +0 -0
  987. /package/dist/siemens-ix/{p-2f54ce99.entry.js.map → p-b9880608.entry.js.map} +0 -0
  988. /package/dist/siemens-ix/{p-467c0fff.entry.js.map → p-c43b201b.entry.js.map} +0 -0
  989. /package/dist/siemens-ix/{p-fc3071d0.entry.js.map → p-c5c863e1.entry.js.map} +0 -0
  990. /package/dist/siemens-ix/{p-d1941577.entry.js.map → p-c94739d0.entry.js.map} +0 -0
  991. /package/dist/siemens-ix/{p-04f1b89a.entry.js.map → p-ca3b24b1.entry.js.map} +0 -0
  992. /package/dist/siemens-ix/{p-cc80918d.entry.js.map → p-ca43aa61.entry.js.map} +0 -0
  993. /package/dist/siemens-ix/{p-58219b7e.entry.js.map → p-cd1afcc9.entry.js.map} +0 -0
  994. /package/dist/siemens-ix/{p-d4ba3f9f.entry.js.map → p-cf041cfd.entry.js.map} +0 -0
  995. /package/dist/siemens-ix/{p-80f55403.entry.js.map → p-d10b9798.entry.js.map} +0 -0
  996. /package/dist/siemens-ix/{p-ecff1e2f.entry.js.map → p-d193381f.entry.js.map} +0 -0
  997. /package/dist/siemens-ix/{p-dff78943.entry.js.map → p-d3a60c52.entry.js.map} +0 -0
  998. /package/dist/siemens-ix/{p-41b9392e.entry.js.map → p-da3a9845.entry.js.map} +0 -0
  999. /package/dist/siemens-ix/{p-94fa5d00.entry.js.map → p-df6bb698.entry.js.map} +0 -0
  1000. /package/dist/siemens-ix/{p-85f3aa13.entry.js.map → p-e0b9cf68.entry.js.map} +0 -0
  1001. /package/dist/siemens-ix/{p-81120f11.entry.js.map → p-e42f62a1.entry.js.map} +0 -0
  1002. /package/dist/siemens-ix/{p-da6a27c1.entry.js.map → p-e48977ed.entry.js.map} +0 -0
  1003. /package/dist/siemens-ix/{p-1f5befb2.entry.js.map → p-ea15fc79.entry.js.map} +0 -0
  1004. /package/dist/siemens-ix/{p-4448252f.entry.js.map → p-ea37abf6.entry.js.map} +0 -0
  1005. /package/dist/siemens-ix/{p-b5e0ddb3.entry.js.map → p-ea410634.entry.js.map} +0 -0
  1006. /package/dist/siemens-ix/{p-39950a1c.entry.js.map → p-eba7f62c.entry.js.map} +0 -0
  1007. /package/dist/siemens-ix/{p-9d8fb7dd.entry.js.map → p-f119c105.entry.js.map} +0 -0
  1008. /package/dist/siemens-ix/{p-347fcf94.entry.js.map → p-fc73c8cc.entry.js.map} +0 -0
  1009. /package/dist/siemens-ix/{p-79798af1.entry.js.map → p-ff83eafd.entry.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"input.js","sourceRoot":"","sources":["../../../src/components/input/input.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { iconEye, iconEyeCancelled } from '@siemens/ix-icons/icons';\nimport {\n AttachInternals,\n Component,\n Element,\n Event,\n EventEmitter,\n Host,\n Method,\n Prop,\n State,\n Watch,\n h,\n} from '@stencil/core';\nimport { A11yAttributes } from '../utils/a11y';\nimport {\n HookValidationLifecycle,\n IxInputFieldComponent,\n ValidationResults,\n} from '../utils/input';\nimport { makeRef } from '../utils/make-ref';\nimport { InputElement, SlotEnd, SlotStart } from './input.fc';\nimport {\n addDisposableChangesAndVisibilityObservers,\n adjustPaddingForStartAndEnd,\n checkAllowedKeys,\n DisposableChangesAndVisibilityObservers,\n getAriaAttributesForInput,\n mapValidationResult,\n onInputBlur,\n} from './input.util';\n\nlet inputIds = 0;\n\n/**\n * @form-ready\n * @slot start - Element will be displayed at the start of the input\n * @slot end - Element will be displayed at the end of the input\n */\n@Component({\n tag: 'ix-input',\n styleUrl: 'input.scss',\n shadow: true,\n formAssociated: true,\n})\nexport class Input implements IxInputFieldComponent<string> {\n @Element() hostElement!: HTMLIxInputElement;\n @AttachInternals() formInternals!: ElementInternals;\n\n /**\n * The type of the text field. Possible values are 'text', 'email', or 'password'.\n */\n @Prop() type: 'text' | 'email' | 'password' | 'tel' | 'url' = 'text';\n\n /**\n * The name of the text field.\n */\n @Prop({ reflect: true }) name?: string;\n\n /**\n * The placeholder text for the text field.\n */\n @Prop({ reflect: true }) placeholder?: string;\n\n /**\n * The value of the text field.\n */\n @Prop({ reflect: true, mutable: true }) value: string = '';\n\n /**\n * Specifies whether the text field is required.\n */\n @Prop({ reflect: true }) required: boolean = false;\n\n /**\n * Specifies whether the text field is disabled.\n */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /**\n * Specifies whether the text field is readonly.\n */\n @Prop({ reflect: true }) readonly: boolean = false;\n\n /**\n * The helper text for the text field.\n */\n @Prop() helperText?: string;\n\n /**\n * The info text for the text field.\n */\n @Prop() infoText?: string;\n\n /**\n * Specifies whether to show the text as a tooltip.\n */\n @Prop() showTextAsTooltip?: boolean;\n\n /**\n * The valid text for the text field.\n */\n @Prop() validText?: string;\n\n /**\n * The warning text for the text field.\n */\n @Prop() warningText?: string;\n\n /**\n * The label for the text field.\n */\n @Prop({ reflect: true }) label?: string;\n\n /**\n * The error text for the text field.\n */\n @Prop() invalidText?: string;\n\n /**\n * The pattern for the text field.\n */\n @Prop() pattern?: string;\n\n /**\n * The maximum length of the text field.\n */\n @Prop() maxLength?: number;\n\n /**\n * The minimum length of the text field.\n */\n @Prop() minLength?: number;\n\n /**\n * The allowed characters pattern for the text field.\n */\n @Prop() allowedCharactersPattern?: string;\n\n /**\n * Event emitted when the value of the text field changes.\n */\n @Event() valueChange!: EventEmitter<string>;\n\n /**\n * Event emitted when the validity state of the text field changes.\n */\n @Event() validityStateChange!: EventEmitter<ValidityState>;\n\n /**\n * Event emitted when the text field loses focus.\n */\n @Event() ixBlur!: EventEmitter<void>;\n\n @State() isInvalid = false;\n @State() isValid = false;\n @State() isInfo = false;\n @State() isWarning = false;\n @State() isInvalidByRequired = false;\n\n @State() inputType = 'text';\n\n private readonly inputRef = makeRef<HTMLInputElement>();\n private readonly slotEndRef = makeRef<HTMLDivElement>();\n private readonly slotStartRef = makeRef<HTMLDivElement>();\n private readonly inputId = `input-${inputIds++}`;\n private touched = false;\n\n private disposableChangesAndVisibilityObservers?: DisposableChangesAndVisibilityObservers;\n\n @HookValidationLifecycle()\n updateClassMappings(result: ValidationResults) {\n mapValidationResult(this, result);\n }\n\n @Watch('type')\n updateInputType() {\n this.inputType = this.type;\n }\n\n componentWillLoad() {\n this.updateFormInternalValue(this.value);\n this.inputType = this.type;\n }\n\n connectedCallback(): void {\n this.disposableChangesAndVisibilityObservers =\n addDisposableChangesAndVisibilityObservers(\n this.hostElement,\n this.updatePaddings.bind(this)\n );\n }\n\n private updatePaddings() {\n adjustPaddingForStartAndEnd(\n this.slotStartRef.current,\n this.slotEndRef.current,\n this.inputRef.current\n );\n }\n\n disconnectedCallback(): void {\n this.disposableChangesAndVisibilityObservers?.();\n }\n\n updateFormInternalValue(value: string) {\n this.formInternals.setFormValue(value);\n this.value = value;\n }\n\n /** @internal */\n @Method()\n async getAssociatedFormElement(): Promise<HTMLFormElement | null> {\n return this.formInternals.form;\n }\n\n /** @internal */\n @Method()\n hasValidValue(): Promise<boolean> {\n return Promise.resolve(!!this.value);\n }\n\n /**\n * Returns the native input element used in the text field.\n */\n @Method()\n getNativeInputElement() {\n return this.inputRef.waitForCurrent();\n }\n\n /**\n * Returns the validity state of the input field.\n */\n @Method()\n async getValidityState(): Promise<ValidityState> {\n const input = await this.inputRef.waitForCurrent();\n return Promise.resolve(input.validity);\n }\n\n /**\n * Focuses the input field\n */\n @Method()\n async focusInput(): Promise<void> {\n return (await this.getNativeInputElement()).focus();\n }\n\n /**\n * Returns whether the text field has been touched.\n * @internal\n */\n @Method()\n isTouched(): Promise<boolean> {\n return Promise.resolve(this.touched);\n }\n\n render() {\n const inputAria: A11yAttributes = getAriaAttributesForInput(this);\n return (\n <Host\n class={{\n disabled: this.disabled,\n readonly: this.readonly,\n }}\n >\n <ix-field-wrapper\n htmlForLabel={this.inputId}\n required={this.required}\n label={this.label}\n helperText={this.helperText}\n invalidText={this.invalidText}\n infoText={this.infoText}\n warningText={this.warningText}\n validText={this.validText}\n showTextAsTooltip={this.showTextAsTooltip}\n isInvalid={this.isInvalid}\n isValid={this.isValid}\n isInfo={this.isInfo}\n isWarning={this.isWarning}\n controlRef={this.inputRef}\n >\n <div class=\"input-wrapper\">\n <SlotStart\n slotStartRef={this.slotStartRef}\n onSlotChange={() => this.updatePaddings()}\n ></SlotStart>\n <InputElement\n id={this.inputId}\n readonly={this.readonly}\n disabled={this.disabled}\n maxLength={this.maxLength}\n minLength={this.minLength}\n pattern={this.pattern}\n type={this.inputType}\n isInvalid={this.isInvalid}\n required={this.required}\n value={this.value}\n placeholder={this.placeholder}\n inputRef={this.inputRef}\n onKeyPress={(event) => checkAllowedKeys(this, event)}\n valueChange={(value) => this.valueChange.emit(value)}\n updateFormInternalValue={(value) =>\n this.updateFormInternalValue(value)\n }\n onBlur={() => {\n onInputBlur(this, this.inputRef.current);\n this.touched = true;\n }}\n ariaAttributes={inputAria}\n ></InputElement>\n <SlotEnd\n slotEndRef={this.slotEndRef}\n onSlotChange={() => this.updatePaddings()}\n >\n <ix-icon-button\n color=\"color-weak-text\"\n class={{\n 'password-eye': true,\n 'eye-hidden': this.type !== 'password' || this.disabled,\n }}\n variant=\"tertiary\"\n icon={\n this.inputType === 'password' ? iconEye : iconEyeCancelled\n }\n onClick={() => {\n if (this.inputType === 'password') {\n this.inputType = 'text';\n return;\n }\n\n this.inputType = 'password';\n }}\n ></ix-icon-button>\n </SlotEnd>\n </div>\n {!!this.maxLength && this.maxLength > 0 && (\n <ix-typography\n class=\"bottom-text\"\n slot=\"bottom-right\"\n textColor=\"soft\"\n >\n {(this.value ?? '').length}/{this.maxLength}\n </ix-typography>\n )}\n </ix-field-wrapper>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"input.js","sourceRoot":"","sources":["../../../src/components/input/input.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { iconEye, iconEyeCancelled } from '@siemens/ix-icons/icons';\nimport {\n AttachInternals,\n Component,\n Element,\n Event,\n EventEmitter,\n Host,\n Method,\n Prop,\n State,\n Watch,\n h,\n} from '@stencil/core';\nimport { A11yAttributes } from '../utils/a11y';\nimport {\n HookValidationLifecycle,\n IxInputFieldComponent,\n ValidationResults,\n} from '../utils/input';\nimport { makeRef } from '../utils/make-ref';\nimport { InputElement, SlotEnd, SlotStart } from './input.fc';\nimport {\n addDisposableChangesAndVisibilityObservers,\n adjustPaddingForStartAndEnd,\n checkAllowedKeys,\n DisposableChangesAndVisibilityObservers,\n getAriaAttributesForInput,\n mapValidationResult,\n onInputBlur,\n} from './input.util';\n\nlet inputIds = 0;\n\n/**\n * @form-ready\n * @slot start - Element will be displayed at the start of the input\n * @slot end - Element will be displayed at the end of the input\n */\n@Component({\n tag: 'ix-input',\n styleUrl: 'input.scss',\n shadow: true,\n formAssociated: true,\n})\nexport class Input implements IxInputFieldComponent<string> {\n @Element() hostElement!: HTMLIxInputElement;\n @AttachInternals() formInternals!: ElementInternals;\n\n /**\n * The type of the text field. Possible values are 'text', 'email', or 'password'.\n */\n @Prop() type: 'text' | 'email' | 'password' | 'tel' | 'url' = 'text';\n\n /**\n * The name of the text field.\n */\n @Prop({ reflect: true }) name?: string;\n\n /**\n * The placeholder text for the text field.\n */\n @Prop({ reflect: true }) placeholder?: string;\n\n /**\n * The value of the text field.\n */\n @Prop({ reflect: true, mutable: true }) value: string = '';\n\n /**\n * Specifies whether the text field is required.\n */\n @Prop({ reflect: true }) required: boolean = false;\n\n /**\n * Specifies whether the text field is disabled.\n */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /**\n * Specifies whether the text field is readonly.\n */\n @Prop({ reflect: true }) readonly: boolean = false;\n\n /**\n * The helper text for the text field.\n */\n @Prop() helperText?: string;\n\n /**\n * The info text for the text field.\n */\n @Prop() infoText?: string;\n\n /**\n * Specifies whether to show the text as a tooltip.\n */\n @Prop() showTextAsTooltip?: boolean;\n\n /**\n * The valid text for the text field.\n */\n @Prop() validText?: string;\n\n /**\n * The warning text for the text field.\n */\n @Prop() warningText?: string;\n\n /**\n * The label for the text field.\n */\n @Prop({ reflect: true }) label?: string;\n\n /**\n * The error text for the text field.\n */\n @Prop() invalidText?: string;\n\n /**\n * The pattern for the text field.\n */\n @Prop() pattern?: string;\n\n /**\n * The maximum length of the text field.\n */\n @Prop() maxLength?: number;\n\n /**\n * The minimum length of the text field.\n */\n @Prop() minLength?: number;\n\n /**\n * The allowed characters pattern for the text field.\n */\n @Prop() allowedCharactersPattern?: string;\n\n /**\n * If false, pressing Enter will submit the form (if inside a form).\n * Set to true to suppress submit on Enter.\n */\n @Prop({ reflect: true }) suppressSubmitOnEnter: boolean = false;\n\n /**\n * Text alignment within the input. 'start' aligns the text to the start of the input, 'end' aligns the text to the end of the input.\n */\n @Prop() textAlignment: 'start' | 'end' = 'start';\n\n /**\n * Event emitted when the value of the text field changes.\n */\n @Event() valueChange!: EventEmitter<string>;\n\n /**\n * Event emitted when the validity state of the text field changes.\n */\n @Event() validityStateChange!: EventEmitter<ValidityState>;\n\n /**\n * Event emitted when the text field loses focus.\n */\n @Event() ixBlur!: EventEmitter<void>;\n\n @State() isInvalid = false;\n @State() isValid = false;\n @State() isInfo = false;\n @State() isWarning = false;\n @State() isInvalidByRequired = false;\n\n @State() inputType = 'text';\n\n private readonly inputRef = makeRef<HTMLInputElement>();\n private readonly slotEndRef = makeRef<HTMLDivElement>();\n private readonly slotStartRef = makeRef<HTMLDivElement>();\n private readonly inputId = `input-${inputIds++}`;\n private touched = false;\n\n private disposableChangesAndVisibilityObservers?: DisposableChangesAndVisibilityObservers;\n\n @HookValidationLifecycle()\n updateClassMappings(result: ValidationResults) {\n mapValidationResult(this, result);\n }\n\n @Watch('type')\n updateInputType() {\n this.inputType = this.type;\n }\n\n componentWillLoad() {\n this.updateFormInternalValue(this.value);\n this.inputType = this.type;\n }\n\n connectedCallback(): void {\n this.disposableChangesAndVisibilityObservers =\n addDisposableChangesAndVisibilityObservers(\n this.hostElement,\n this.updatePaddings.bind(this)\n );\n }\n\n private updatePaddings() {\n adjustPaddingForStartAndEnd(\n this.slotStartRef.current,\n this.slotEndRef.current,\n this.inputRef.current\n );\n }\n\n disconnectedCallback(): void {\n this.disposableChangesAndVisibilityObservers?.();\n }\n\n updateFormInternalValue(value: string) {\n this.formInternals.setFormValue(value);\n this.value = value;\n }\n\n /** @internal */\n @Method()\n async getAssociatedFormElement(): Promise<HTMLFormElement | null> {\n return this.formInternals.form;\n }\n\n /** @internal */\n @Method()\n hasValidValue(): Promise<boolean> {\n return Promise.resolve(!!this.value);\n }\n\n /**\n * Returns the native input element used in the text field.\n */\n @Method()\n getNativeInputElement() {\n return this.inputRef.waitForCurrent();\n }\n\n /**\n * Returns the validity state of the input field.\n */\n @Method()\n async getValidityState(): Promise<ValidityState> {\n const input = await this.inputRef.waitForCurrent();\n return Promise.resolve(input.validity);\n }\n\n /**\n * Focuses the input field\n */\n @Method()\n async focusInput(): Promise<void> {\n return (await this.getNativeInputElement()).focus();\n }\n\n /**\n * Returns whether the text field has been touched.\n * @internal\n */\n @Method()\n isTouched(): Promise<boolean> {\n return Promise.resolve(this.touched);\n }\n\n render() {\n const inputAria: A11yAttributes = getAriaAttributesForInput(this);\n return (\n <Host\n class={{\n disabled: this.disabled,\n readonly: this.readonly,\n }}\n >\n <ix-field-wrapper\n htmlForLabel={this.inputId}\n required={this.required}\n label={this.label}\n helperText={this.helperText}\n invalidText={this.invalidText}\n infoText={this.infoText}\n warningText={this.warningText}\n validText={this.validText}\n showTextAsTooltip={this.showTextAsTooltip}\n isInvalid={this.isInvalid}\n isValid={this.isValid}\n isInfo={this.isInfo}\n isWarning={this.isWarning}\n controlRef={this.inputRef}\n >\n <div class=\"input-wrapper\">\n <SlotStart\n slotStartRef={this.slotStartRef}\n onSlotChange={() => this.updatePaddings()}\n ></SlotStart>\n <InputElement\n id={this.inputId}\n readonly={this.readonly}\n disabled={this.disabled}\n maxLength={this.maxLength}\n minLength={this.minLength}\n pattern={this.pattern}\n type={this.inputType}\n isInvalid={this.isInvalid}\n required={this.required}\n value={this.value}\n placeholder={this.placeholder}\n inputRef={this.inputRef}\n onKeyPress={(event) => checkAllowedKeys(this, event)}\n valueChange={(value) => this.valueChange.emit(value)}\n updateFormInternalValue={(value) =>\n this.updateFormInternalValue(value)\n }\n onBlur={() => {\n onInputBlur(this, this.inputRef.current);\n this.touched = true;\n }}\n ariaAttributes={inputAria}\n form={this.formInternals.form ?? undefined}\n suppressSubmitOnEnter={this.suppressSubmitOnEnter}\n textAlignment={this.textAlignment}\n ></InputElement>\n <SlotEnd\n slotEndRef={this.slotEndRef}\n onSlotChange={() => this.updatePaddings()}\n >\n <ix-icon-button\n color=\"color-weak-text\"\n class={{\n 'password-eye': true,\n 'eye-hidden': this.type !== 'password' || this.disabled,\n }}\n variant=\"tertiary\"\n icon={\n this.inputType === 'password' ? iconEye : iconEyeCancelled\n }\n onClick={() => {\n if (this.inputType === 'password') {\n this.inputType = 'text';\n return;\n }\n\n this.inputType = 'password';\n }}\n ></ix-icon-button>\n </SlotEnd>\n </div>\n {!!this.maxLength && this.maxLength > 0 && (\n <ix-typography\n class=\"bottom-text\"\n slot=\"bottom-right\"\n textColor=\"soft\"\n >\n {(this.value ?? '').length}/{this.maxLength}\n </ix-typography>\n )}\n </ix-field-wrapper>\n </Host>\n );\n }\n}\n"]}
@@ -34,9 +34,13 @@ export function checkAllowedKeys(comp, event) {
34
34
  }
35
35
  export async function checkInternalValidity(comp, input) {
36
36
  const validityState = input.validity;
37
- const eventResult = comp.validityStateChange.emit(validityState);
38
- if (eventResult.defaultPrevented) {
39
- return;
37
+ const currentValidityState = !comp.hostElement.classList.contains('ix-invalid--validity-invalid');
38
+ const newValidityState = validityState.valid;
39
+ if (currentValidityState !== newValidityState) {
40
+ const eventResult = comp.validityStateChange.emit(validityState);
41
+ if (eventResult.defaultPrevented) {
42
+ return;
43
+ }
40
44
  }
41
45
  if (comp.value === null || comp.value === undefined) {
42
46
  return;
@@ -125,4 +129,17 @@ function observeElementUntilVisible(hostElement, updateCallback) {
125
129
  intersectionObserver.observe(hostElement);
126
130
  return intersectionObserver;
127
131
  }
132
+ export function handleSubmitOnEnterKeydown(event, suppressSubmitOnEnter, form) {
133
+ if (suppressSubmitOnEnter || event.key !== 'Enter' || !form) {
134
+ return;
135
+ }
136
+ event.preventDefault();
137
+ const submitButton = form.querySelector('button[type="submit"], ix-button[type="submit"]');
138
+ if (submitButton) {
139
+ form.requestSubmit(submitButton);
140
+ }
141
+ if (form.length === 1) {
142
+ form.requestSubmit();
143
+ }
144
+ }
128
145
  //# sourceMappingURL=input.util.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"input.util.js","sourceRoot":"","sources":["../../../src/components/input/input.util.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { A11yAttributes, a11yBoolean } from '../utils/a11y';\nimport {\n IxFormComponent,\n IxInputFieldComponent,\n ValidationResults,\n shouldSuppressInternalValidation,\n} from '../utils/input';\nimport { createMutationObserver } from '../utils/mutation-observer';\nimport { convertToRemString } from '../utils/rwd.util';\nimport { generateUUID } from '../utils/uuid';\nimport { shakeInput } from './input.animation';\n\nexport function createIdIfNotExists(\n element: IxFormComponent,\n idPrefix: string = 'input'\n) {\n return element.hasAttribute('id')\n ? element.getAttribute('id')\n : `${idPrefix}-${generateUUID()}`;\n}\n\nexport function mapValidationResult<T>(\n ref: IxInputFieldComponent<T>,\n result: ValidationResults\n) {\n ref.isInvalid = result.isInvalid || result.isInvalidByRequired;\n ref.isValid = result.isValid;\n ref.isInfo = result.isInfo;\n ref.isWarning = result.isWarning;\n}\n\nexport function checkAllowedKeys<T>(\n comp: IxInputFieldComponent<T>,\n event: KeyboardEvent\n) {\n if (comp.allowedCharactersPattern) {\n const regex = new RegExp(comp.allowedCharactersPattern);\n if (!regex.test(event.key)) {\n event.preventDefault();\n shakeInput(comp.inputRef.current);\n }\n }\n}\n\nexport async function checkInternalValidity<T>(\n comp: IxFormComponent<T>,\n input: HTMLInputElement | HTMLTextAreaElement\n) {\n const validityState = input.validity;\n\n const eventResult = comp.validityStateChange.emit(validityState);\n\n if (eventResult.defaultPrevented) {\n return;\n }\n\n if (comp.value === null || comp.value === undefined) {\n return;\n }\n\n const skipValidation = await shouldSuppressInternalValidation(comp);\n if (skipValidation) {\n return;\n }\n\n const { valid } = validityState;\n comp.hostElement.classList.toggle('ix-invalid--validity-invalid', !valid);\n}\n\nexport function onInputBlur<T>(\n comp: IxFormComponent<T>,\n input?: HTMLInputElement | HTMLTextAreaElement | null\n) {\n comp.ixBlur.emit();\n\n if (!input) {\n throw new Error('Input element is not available');\n }\n\n input.setAttribute('data-ix-touched', 'true');\n checkInternalValidity(comp, input);\n}\n\nexport function applyPaddingEnd(\n inputElement: HTMLElement | null,\n width: number,\n options: {\n slotEnd: boolean;\n additionalPaddingRight?: string;\n }\n) {\n if (!inputElement) {\n return;\n }\n\n const remInPixels = 16;\n const padding = convertToRemString(width + remInPixels / 2);\n\n if (options.slotEnd) {\n inputElement.style.paddingRight = `calc(${padding} + ${\n options.additionalPaddingRight ?? '0rem'\n })`;\n } else {\n inputElement.style.paddingLeft = padding;\n }\n}\n\nexport function adjustPaddingForStartAndEnd(\n startElement: HTMLElement | null,\n endElement: HTMLElement | null,\n inputElement: HTMLElement | null\n) {\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n if (startElement) {\n const startBoundingRect = startElement.getBoundingClientRect();\n if (startBoundingRect) {\n applyPaddingEnd(inputElement, startBoundingRect.width, {\n slotEnd: false,\n });\n }\n }\n\n if (endElement) {\n const endBoundingRect = endElement.getBoundingClientRect();\n if (endBoundingRect) {\n applyPaddingEnd(inputElement, endBoundingRect.width, {\n slotEnd: true,\n });\n }\n }\n });\n });\n}\n\nexport function getAriaAttributesForInput(\n component: IxInputFieldComponent\n): A11yAttributes {\n const inputAria: A11yAttributes = {\n 'aria-invalid': `${a11yBoolean(component.isInvalid)}`,\n 'aria-required': `${a11yBoolean(component.required)}`,\n };\n\n if (component.isInvalid && component.invalidText) {\n inputAria['aria-errormessage'] = component.invalidText;\n }\n return inputAria;\n}\n\nexport type DisposableChangesAndVisibilityObservers = () => void;\n\nexport const addDisposableChangesAndVisibilityObservers = (\n element: HTMLElement,\n callback: () => void\n): DisposableChangesAndVisibilityObservers => {\n const intersectionObserver = observeElementUntilVisible(element, callback);\n const mutationObserver = createMutationObserver(callback);\n\n mutationObserver.observe(element, {\n subtree: true,\n attributes: true,\n });\n\n return () => {\n intersectionObserver.disconnect();\n mutationObserver.disconnect();\n };\n};\n\nfunction observeElementUntilVisible(\n hostElement: HTMLElement,\n updateCallback: () => void\n): IntersectionObserver {\n const intersectionObserver = new IntersectionObserver((entries) => {\n entries.forEach((entry) => {\n if (entry.isIntersecting) {\n updateCallback();\n }\n });\n });\n\n intersectionObserver.observe(hostElement);\n return intersectionObserver;\n}\n"]}
1
+ {"version":3,"file":"input.util.js","sourceRoot":"","sources":["../../../src/components/input/input.util.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { A11yAttributes, a11yBoolean } from '../utils/a11y';\nimport {\n IxFormComponent,\n IxInputFieldComponent,\n ValidationResults,\n shouldSuppressInternalValidation,\n} from '../utils/input';\nimport { createMutationObserver } from '../utils/mutation-observer';\nimport { convertToRemString } from '../utils/rwd.util';\nimport { generateUUID } from '../utils/uuid';\nimport { shakeInput } from './input.animation';\n\nexport function createIdIfNotExists(\n element: IxFormComponent,\n idPrefix: string = 'input'\n) {\n return element.hasAttribute('id')\n ? element.getAttribute('id')\n : `${idPrefix}-${generateUUID()}`;\n}\n\nexport function mapValidationResult<T>(\n ref: IxInputFieldComponent<T>,\n result: ValidationResults\n) {\n ref.isInvalid = result.isInvalid || result.isInvalidByRequired;\n ref.isValid = result.isValid;\n ref.isInfo = result.isInfo;\n ref.isWarning = result.isWarning;\n}\n\nexport function checkAllowedKeys<T>(\n comp: IxInputFieldComponent<T>,\n event: KeyboardEvent\n) {\n if (comp.allowedCharactersPattern) {\n const regex = new RegExp(comp.allowedCharactersPattern);\n if (!regex.test(event.key)) {\n event.preventDefault();\n shakeInput(comp.inputRef.current);\n }\n }\n}\n\nexport async function checkInternalValidity<T>(\n comp: IxFormComponent<T>,\n input: HTMLInputElement | HTMLTextAreaElement\n) {\n const validityState = input.validity;\n const currentValidityState = !comp.hostElement.classList.contains(\n 'ix-invalid--validity-invalid'\n );\n const newValidityState = validityState.valid;\n\n if (currentValidityState !== newValidityState) {\n const eventResult = comp.validityStateChange.emit(validityState);\n if (eventResult.defaultPrevented) {\n return;\n }\n }\n\n if (comp.value === null || comp.value === undefined) {\n return;\n }\n\n const skipValidation = await shouldSuppressInternalValidation(comp);\n if (skipValidation) {\n return;\n }\n\n const { valid } = validityState;\n comp.hostElement.classList.toggle('ix-invalid--validity-invalid', !valid);\n}\n\nexport function onInputBlur<T>(\n comp: IxFormComponent<T>,\n input?: HTMLInputElement | HTMLTextAreaElement | null\n) {\n comp.ixBlur.emit();\n\n if (!input) {\n throw new Error('Input element is not available');\n }\n\n input.setAttribute('data-ix-touched', 'true');\n checkInternalValidity(comp, input);\n}\n\nexport function applyPaddingEnd(\n inputElement: HTMLElement | null,\n width: number,\n options: {\n slotEnd: boolean;\n additionalPaddingRight?: string;\n }\n) {\n if (!inputElement) {\n return;\n }\n\n const remInPixels = 16;\n const padding = convertToRemString(width + remInPixels / 2);\n\n if (options.slotEnd) {\n inputElement.style.paddingRight = `calc(${padding} + ${\n options.additionalPaddingRight ?? '0rem'\n })`;\n } else {\n inputElement.style.paddingLeft = padding;\n }\n}\n\nexport function adjustPaddingForStartAndEnd(\n startElement: HTMLElement | null,\n endElement: HTMLElement | null,\n inputElement: HTMLElement | null\n) {\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n if (startElement) {\n const startBoundingRect = startElement.getBoundingClientRect();\n if (startBoundingRect) {\n applyPaddingEnd(inputElement, startBoundingRect.width, {\n slotEnd: false,\n });\n }\n }\n\n if (endElement) {\n const endBoundingRect = endElement.getBoundingClientRect();\n if (endBoundingRect) {\n applyPaddingEnd(inputElement, endBoundingRect.width, {\n slotEnd: true,\n });\n }\n }\n });\n });\n}\n\nexport function getAriaAttributesForInput(\n component: IxInputFieldComponent\n): A11yAttributes {\n const inputAria: A11yAttributes = {\n 'aria-invalid': `${a11yBoolean(component.isInvalid)}`,\n 'aria-required': `${a11yBoolean(component.required)}`,\n };\n\n if (component.isInvalid && component.invalidText) {\n inputAria['aria-errormessage'] = component.invalidText;\n }\n return inputAria;\n}\n\nexport type DisposableChangesAndVisibilityObservers = () => void;\n\nexport const addDisposableChangesAndVisibilityObservers = (\n element: HTMLElement,\n callback: () => void\n): DisposableChangesAndVisibilityObservers => {\n const intersectionObserver = observeElementUntilVisible(element, callback);\n const mutationObserver = createMutationObserver(callback);\n\n mutationObserver.observe(element, {\n subtree: true,\n attributes: true,\n });\n\n return () => {\n intersectionObserver.disconnect();\n mutationObserver.disconnect();\n };\n};\n\nfunction observeElementUntilVisible(\n hostElement: HTMLElement,\n updateCallback: () => void\n): IntersectionObserver {\n const intersectionObserver = new IntersectionObserver((entries) => {\n entries.forEach((entry) => {\n if (entry.isIntersecting) {\n updateCallback();\n }\n });\n });\n\n intersectionObserver.observe(hostElement);\n return intersectionObserver;\n}\n\nexport function handleSubmitOnEnterKeydown(\n event: KeyboardEvent,\n suppressSubmitOnEnter: boolean,\n form: HTMLFormElement | null | undefined\n) {\n if (suppressSubmitOnEnter || event.key !== 'Enter' || !form) {\n return;\n }\n\n event.preventDefault();\n const submitButton = form.querySelector<HTMLElement>(\n 'button[type=\"submit\"], ix-button[type=\"submit\"]'\n );\n\n if (submitButton) {\n form.requestSubmit(submitButton);\n }\n\n if (form.length === 1) {\n form.requestSubmit();\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  /*
2
- * SPDX-FileCopyrightText: 2024 Siemens AG
2
+ * SPDX-FileCopyrightText: 2025 Siemens AG
3
3
  *
4
4
  * SPDX-License-Identifier: MIT
5
5
  *
@@ -23,6 +23,7 @@ import { makeRef } from "../utils/make-ref";
23
23
  import { InputElement, SlotEnd, SlotStart } from "./input.fc";
24
24
  import { addDisposableChangesAndVisibilityObservers, adjustPaddingForStartAndEnd, checkAllowedKeys, checkInternalValidity, mapValidationResult, onInputBlur, } from "./input.util";
25
25
  let numberInputIds = 0;
26
+ const INVALID_NUMBER_INPUT_REGEX = /[^\dEe+\-.,]/;
26
27
  /**
27
28
  * @form-ready
28
29
  * @slot start - Element will be displayed at the start of the input
@@ -31,11 +32,11 @@ let numberInputIds = 0;
31
32
  export class NumberInput {
32
33
  constructor() {
33
34
  /**
34
- * The value of the input field
35
+ * The value of the input field. Supports numeric values, scientific notation (1E6, 1E-6), or undefined for empty.
35
36
  */
36
37
  this.value = 0;
37
38
  /**
38
- * Indicates if the field is required
39
+ * Indicates if the field is required. When required, empty values (undefined) are not accepted.
39
40
  */
40
41
  this.required = false;
41
42
  /**
@@ -46,6 +47,27 @@ export class NumberInput {
46
47
  * Indicates if the field is read-only
47
48
  */
48
49
  this.readonly = false;
50
+ /**
51
+ * Step value to increment or decrement the input value. Default step value is 1.
52
+ *
53
+ */
54
+ this.step = 1;
55
+ /**
56
+ * If false, pressing Enter will submit the form (if inside a form).
57
+ * Set to true to suppress submit on Enter.
58
+ */
59
+ this.suppressSubmitOnEnter = false;
60
+ /**
61
+ * Text alignment within the number input. 'start' aligns the text to the start of the input, 'end' aligns the text to the end of the input.
62
+ */
63
+ this.textAlignment = 'end';
64
+ /**
65
+ * If true, the valueChange event will return null instead of 0 for an empty input state.
66
+ * This property will be removed in 5.0.0 and this behaviour will be default.
67
+ *
68
+ * @since 4.1.0
69
+ */
70
+ this.allowEmptyValueChange = false;
49
71
  this.isInvalid = false;
50
72
  this.isValid = false;
51
73
  this.isInfo = false;
@@ -56,6 +78,70 @@ export class NumberInput {
56
78
  this.slotStartRef = makeRef();
57
79
  this.numberInputId = `number-input-${numberInputIds++}`;
58
80
  this.touched = false;
81
+ this.handleInputChange = (inputValue) => {
82
+ const parsedValue = this.convertNumberStringToFloat(inputValue);
83
+ const isScientificNotation = this.isScientificNotation(inputValue.trim());
84
+ if (isScientificNotation) {
85
+ this.formInternals.setFormValue(inputValue);
86
+ }
87
+ this.handleValueChangeEvent(parsedValue);
88
+ };
89
+ this.handleBlur = () => {
90
+ if (!this.inputRef.current)
91
+ return;
92
+ const inputValue = this.inputRef.current.value;
93
+ const parsedValue = this.convertNumberStringToFloat(inputValue);
94
+ if (parsedValue !== undefined) {
95
+ this.inputRef.current.value = this.formatValue(parsedValue);
96
+ }
97
+ this.updateFormInternalValue(parsedValue);
98
+ onInputBlur(this, this.inputRef.current);
99
+ this.touched = true;
100
+ };
101
+ this.handleKeyDown = (event) => {
102
+ if (this.disabled || this.readonly) {
103
+ return;
104
+ }
105
+ switch (event.key) {
106
+ case 'ArrowUp':
107
+ event.preventDefault();
108
+ this.handleStepOperation('up');
109
+ break;
110
+ case 'ArrowDown':
111
+ event.preventDefault();
112
+ this.handleStepOperation('down');
113
+ break;
114
+ }
115
+ };
116
+ this.handleBeforeInput = (e) => {
117
+ var _a, _b;
118
+ if (this.disabled || this.readonly)
119
+ return;
120
+ if (e.inputType === 'insertText') {
121
+ const character = e.data;
122
+ if (character && INVALID_NUMBER_INPUT_REGEX.test(character)) {
123
+ e.preventDefault();
124
+ }
125
+ }
126
+ if (e.inputType === 'insertFromPaste') {
127
+ const dt = e.dataTransfer || e.clipboardData;
128
+ const text = (_b = (_a = dt === null || dt === void 0 ? void 0 : dt.getData) === null || _a === void 0 ? void 0 : _a.call(dt, 'text')) !== null && _b !== void 0 ? _b : '';
129
+ if (INVALID_NUMBER_INPUT_REGEX.test(text)) {
130
+ e.preventDefault();
131
+ }
132
+ }
133
+ };
134
+ this.handlePaste = (e) => {
135
+ var _a, _b;
136
+ // Fallback for browsers that don’t fire beforeinput for paste
137
+ const text = (_b = (_a = e.clipboardData) === null || _a === void 0 ? void 0 : _a.getData('text')) !== null && _b !== void 0 ? _b : '';
138
+ if (INVALID_NUMBER_INPUT_REGEX.test(text)) {
139
+ e.preventDefault();
140
+ }
141
+ };
142
+ }
143
+ onValueChange(newValue) {
144
+ this.updateFormInternalValue(newValue);
59
145
  }
60
146
  updateClassMappings(result) {
61
147
  mapValidationResult(this, result);
@@ -74,10 +160,60 @@ export class NumberInput {
74
160
  updatePaddings() {
75
161
  adjustPaddingForStartAndEnd(this.slotStartRef.current, this.slotEndRef.current, this.inputRef.current);
76
162
  }
163
+ convertNumberStringToFloat(input) {
164
+ if (!input || input.trim() === '') {
165
+ return undefined;
166
+ }
167
+ const parsed = Number.parseFloat(input);
168
+ return Number.isNaN(parsed) ? undefined : parsed;
169
+ }
170
+ isScientificNotation(input) {
171
+ const parsed = Number.parseFloat(input);
172
+ return (!Number.isNaN(parsed) && Number.isFinite(parsed) && /[eE]/.test(input));
173
+ }
174
+ formatValue(value) {
175
+ if (value === undefined || value === null) {
176
+ return '';
177
+ }
178
+ return value.toString();
179
+ }
180
+ handleValueChangeEvent(value) {
181
+ this.valueChange.emit(this.allowEmptyValueChange ? value : (value !== null && value !== void 0 ? value : 0));
182
+ }
77
183
  updateFormInternalValue(value) {
78
- this.formInternals.setFormValue(value.toString());
184
+ const formValue = value !== undefined && value !== null ? value.toString() : '';
185
+ this.formInternals.setFormValue(formValue);
79
186
  this.value = value;
80
187
  }
188
+ handleStepOperation(operation) {
189
+ var _a, _b;
190
+ if (!this.inputRef.current) {
191
+ return;
192
+ }
193
+ const currentValue = (_a = this.value) !== null && _a !== void 0 ? _a : 0;
194
+ const stepValue = typeof this.step === 'string'
195
+ ? Number.parseFloat(this.step)
196
+ : ((_b = this.step) !== null && _b !== void 0 ? _b : 1);
197
+ let newValue;
198
+ if (operation === 'up') {
199
+ newValue = currentValue + stepValue;
200
+ }
201
+ else {
202
+ newValue = currentValue - stepValue;
203
+ }
204
+ if (this.min !== undefined) {
205
+ const minValue = typeof this.min === 'string' ? Number.parseFloat(this.min) : this.min;
206
+ newValue = Math.max(newValue, minValue);
207
+ }
208
+ if (this.max !== undefined) {
209
+ const maxValue = typeof this.max === 'string' ? Number.parseFloat(this.max) : this.max;
210
+ newValue = Math.min(newValue, maxValue);
211
+ }
212
+ this.inputRef.current.value = newValue.toString();
213
+ this.updateFormInternalValue(newValue);
214
+ checkInternalValidity(this, this.inputRef.current);
215
+ this.handleValueChangeEvent(newValue);
216
+ }
81
217
  /** @internal */
82
218
  async getAssociatedFormElement() {
83
219
  return this.formInternals.form;
@@ -86,9 +222,10 @@ export class NumberInput {
86
222
  async hasValidValue() {
87
223
  const nativeInput = await this.getNativeInputElement();
88
224
  if (nativeInput.value === '') {
89
- return Promise.resolve(false);
225
+ return !this.required;
90
226
  }
91
- return Promise.resolve(this.value !== null && this.value !== undefined && !isNaN(this.value));
227
+ const parsedValue = this.convertNumberStringToFloat(nativeInput.value);
228
+ return parsedValue !== undefined;
92
229
  }
93
230
  /**
94
231
  * Returns the native input element used under the hood
@@ -110,36 +247,24 @@ export class NumberInput {
110
247
  return Promise.resolve(this.touched);
111
248
  }
112
249
  render() {
250
+ var _a;
113
251
  const showStepperButtons = this.showStepperButtons && (this.disabled || this.readonly) === false;
114
- return (h(Host, { key: '8504c7c73fc9b962d3d1bb53f80515876579a799', class: {
252
+ return (h(Host, { key: '4b541dbe6fe2b32b5158eed8f398de300ea71bb4', class: {
115
253
  disabled: this.disabled,
116
254
  readonly: this.readonly,
117
- } }, h("ix-field-wrapper", { key: '5f833ae1f6e134b0056cceda27cce2491bfa5a04', id: this.numberInputId, required: this.required, label: this.label, helperText: this.helperText, invalidText: this.invalidText, infoText: this.infoText, warningText: this.warningText, validText: this.validText, showTextAsTooltip: this.showTextAsTooltip, isInvalid: this.isInvalid, isValid: this.isValid, isInfo: this.isInfo, isWarning: this.isWarning, controlRef: this.inputRef }, h("div", { key: '18d4fdfcb87f46340fd7f0c08587c8353122275f', class: {
255
+ } }, h("ix-field-wrapper", { key: '7ef2bb50ba7c9b3b24612752155a2072329e4b61', id: this.numberInputId, required: this.required, label: this.label, helperText: this.helperText, invalidText: this.invalidText, infoText: this.infoText, warningText: this.warningText, validText: this.validText, showTextAsTooltip: this.showTextAsTooltip, isInvalid: this.isInvalid, isValid: this.isValid, isInfo: this.isInfo, isWarning: this.isWarning, controlRef: this.inputRef }, h("div", { key: '7e71d63d2a9ecbb16550925e68f3dc8dd76c3968', class: {
118
256
  'input-wrapper': true,
119
257
  'show-stepper-buttons': !!this.showStepperButtons,
120
- } }, h(SlotStart, { key: '702b6335f92a587932de72d085487e21932897f9', slotStartRef: this.slotStartRef, onSlotChange: () => this.updatePaddings() }), h(InputElement, { key: '385e81700361f81a6ee4f4999a673acc452decf9', id: this.numberInputId, readonly: this.readonly, disabled: this.disabled, step: this.step, min: this.min, max: this.max, pattern: this.pattern, type: 'number', isInvalid: this.isInvalid, required: this.required, value: this.value, placeholder: this.placeholder, inputRef: this.inputRef, onKeyPress: (event) => checkAllowedKeys(this, event), valueChange: (value) => this.valueChange.emit(Number(value)), updateFormInternalValue: (value) => this.updateFormInternalValue(Number(value)), onBlur: () => {
121
- onInputBlur(this, this.inputRef.current);
122
- this.touched = true;
123
- } }), h(SlotEnd, { key: '346796a1af3fde17d66cc573457d63f3193f6420', slotEndRef: this.slotEndRef, onSlotChange: () => this.updatePaddings() }, h("div", { key: 'd4369359ea685b7ef974b3ff941652a496874207', class: {
258
+ } }, h(SlotStart, { key: '8d936c9126f94c42db87b2d95d34ab178eadd31d', slotStartRef: this.slotStartRef, onSlotChange: () => this.updatePaddings() }), h(InputElement, { key: 'c56f510ea8a519204d3d36136d4b0a5a17246370', id: this.numberInputId, readonly: this.readonly, disabled: this.disabled, step: this.step, min: this.min, max: this.max, pattern: this.pattern, type: 'number', isInvalid: this.isInvalid, required: this.required, value: this.formatValue(this.value), placeholder: this.placeholder, inputRef: this.inputRef, onKeyPress: (event) => checkAllowedKeys(this, event), onKeyDown: (event) => this.handleKeyDown(event), onBeforeInput: (event) => this.handleBeforeInput(event), onPaste: (event) => this.handlePaste(event), valueChange: this.handleInputChange, updateFormInternalValue: (value) => {
259
+ const isScientificNotation = this.isScientificNotation(value.trim());
260
+ if (!isScientificNotation) {
261
+ const parsedValue = this.convertNumberStringToFloat(value);
262
+ this.updateFormInternalValue(parsedValue);
263
+ }
264
+ }, onBlur: this.handleBlur, form: (_a = this.formInternals.form) !== null && _a !== void 0 ? _a : undefined, suppressSubmitOnEnter: this.suppressSubmitOnEnter, textAlignment: this.textAlignment }), h(SlotEnd, { key: '2d7e82c421d51985c9d24c69b6f641279e3e84aa', slotEndRef: this.slotEndRef, onSlotChange: () => this.updatePaddings() }, h("div", { key: '5b1e6f03bf456305386537428b23b3fc2706e411', class: {
124
265
  'number-stepper-container': true,
125
266
  'container-hidden': !showStepperButtons,
126
- } }, h("ix-icon-button", { key: '0e9729ec618851639232d0d50822a89dfe899e06', variant: "subtle-tertiary", icon: iconMinus, size: "16", class: "number-stepper-button step-minus", "aria-label": "decrement number", onClick: () => {
127
- if (!this.inputRef.current) {
128
- return;
129
- }
130
- this.inputRef.current.stepDown();
131
- checkInternalValidity(this, this.inputRef.current);
132
- this.updateFormInternalValue(Number(this.inputRef.current.value));
133
- this.valueChange.emit(this.value);
134
- } }), h("ix-icon-button", { key: '9799ab98f29a44549fcf233ea0b0ca3189704c76', variant: "subtle-tertiary", icon: iconPlus, size: "16", class: "number-stepper-button step-plus", "aria-label": "increment number", onClick: () => {
135
- if (!this.inputRef.current) {
136
- return;
137
- }
138
- this.inputRef.current.stepUp();
139
- checkInternalValidity(this, this.inputRef.current);
140
- this.updateFormInternalValue(Number(this.inputRef.current.value));
141
- this.valueChange.emit(this.value);
142
- } })))))));
267
+ } }, h("ix-icon-button", { key: '44a5f583fb174c556a063f384174883ec307f9f4', variant: "subtle-tertiary", icon: iconMinus, size: "16", class: "number-stepper-button step-minus", "aria-label": "decrement number", onClick: () => this.handleStepOperation('down') }), h("ix-icon-button", { key: 'c007fe5451c3f124e61214160c7ebc8cc1150b25', variant: "subtle-tertiary", icon: iconPlus, size: "16", class: "number-stepper-button step-plus", "aria-label": "increment number", onClick: () => this.handleStepOperation('up') })))))));
143
268
  }
144
269
  static get is() { return "ix-number-input"; }
145
270
  static get encapsulation() { return "shadow"; }
@@ -200,14 +325,14 @@ export class NumberInput {
200
325
  "mutable": true,
201
326
  "complexType": {
202
327
  "original": "number",
203
- "resolved": "number",
328
+ "resolved": "number | undefined",
204
329
  "references": {}
205
330
  },
206
331
  "required": false,
207
- "optional": false,
332
+ "optional": true,
208
333
  "docs": {
209
334
  "tags": [],
210
- "text": "The value of the input field"
335
+ "text": "The value of the input field. Supports numeric values, scientific notation (1E6, 1E-6), or undefined for empty."
211
336
  },
212
337
  "getter": false,
213
338
  "setter": false,
@@ -227,7 +352,7 @@ export class NumberInput {
227
352
  "optional": false,
228
353
  "docs": {
229
354
  "tags": [],
230
- "text": "Indicates if the field is required"
355
+ "text": "Indicates if the field is required. When required, empty values (undefined) are not accepted."
231
356
  },
232
357
  "getter": false,
233
358
  "setter": false,
@@ -513,16 +638,77 @@ export class NumberInput {
513
638
  },
514
639
  "required": false,
515
640
  "optional": true,
641
+ "docs": {
642
+ "tags": [],
643
+ "text": "Step value to increment or decrement the input value. Default step value is 1."
644
+ },
645
+ "getter": false,
646
+ "setter": false,
647
+ "reflect": false,
648
+ "defaultValue": "1"
649
+ },
650
+ "suppressSubmitOnEnter": {
651
+ "type": "boolean",
652
+ "attribute": "suppress-submit-on-enter",
653
+ "mutable": false,
654
+ "complexType": {
655
+ "original": "boolean",
656
+ "resolved": "boolean",
657
+ "references": {}
658
+ },
659
+ "required": false,
660
+ "optional": false,
661
+ "docs": {
662
+ "tags": [],
663
+ "text": "If false, pressing Enter will submit the form (if inside a form).\nSet to true to suppress submit on Enter."
664
+ },
665
+ "getter": false,
666
+ "setter": false,
667
+ "reflect": true,
668
+ "defaultValue": "false"
669
+ },
670
+ "textAlignment": {
671
+ "type": "string",
672
+ "attribute": "text-alignment",
673
+ "mutable": false,
674
+ "complexType": {
675
+ "original": "'start' | 'end'",
676
+ "resolved": "\"end\" | \"start\"",
677
+ "references": {}
678
+ },
679
+ "required": false,
680
+ "optional": false,
681
+ "docs": {
682
+ "tags": [],
683
+ "text": "Text alignment within the number input. 'start' aligns the text to the start of the input, 'end' aligns the text to the end of the input."
684
+ },
685
+ "getter": false,
686
+ "setter": false,
687
+ "reflect": false,
688
+ "defaultValue": "'end'"
689
+ },
690
+ "allowEmptyValueChange": {
691
+ "type": "boolean",
692
+ "attribute": "allow-empty-value-change",
693
+ "mutable": false,
694
+ "complexType": {
695
+ "original": "boolean",
696
+ "resolved": "boolean",
697
+ "references": {}
698
+ },
699
+ "required": false,
700
+ "optional": false,
516
701
  "docs": {
517
702
  "tags": [{
518
703
  "name": "since",
519
- "text": "3.0.0"
704
+ "text": "4.1.0"
520
705
  }],
521
- "text": "Step value to increment or decrement the input value"
706
+ "text": "If true, the valueChange event will return null instead of 0 for an empty input state.\nThis property will be removed in 5.0.0 and this behaviour will be default."
522
707
  },
523
708
  "getter": false,
524
709
  "setter": false,
525
- "reflect": false
710
+ "reflect": true,
711
+ "defaultValue": "false"
526
712
  }
527
713
  };
528
714
  }
@@ -695,6 +881,12 @@ export class NumberInput {
695
881
  };
696
882
  }
697
883
  static get elementRef() { return "hostElement"; }
884
+ static get watchers() {
885
+ return [{
886
+ "propName": "value",
887
+ "methodName": "onValueChange"
888
+ }];
889
+ }
698
890
  static get attachInternalsMemberName() { return "formInternals"; }
699
891
  }
700
892
  __decorate([
@@ -1 +1 @@
1
- {"version":3,"file":"number-input.js","sourceRoot":"","sources":["../../../src/components/input/number-input.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { iconMinus, iconPlus } from '@siemens/ix-icons/icons';\nimport {\n AttachInternals,\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Method,\n Prop,\n State,\n} from '@stencil/core';\nimport {\n HookValidationLifecycle,\n IxInputFieldComponent,\n ValidationResults,\n} from '../utils/input';\nimport { makeRef } from '../utils/make-ref';\nimport { InputElement, SlotEnd, SlotStart } from './input.fc';\nimport {\n addDisposableChangesAndVisibilityObservers,\n adjustPaddingForStartAndEnd,\n checkAllowedKeys,\n checkInternalValidity,\n DisposableChangesAndVisibilityObservers,\n mapValidationResult,\n onInputBlur,\n} from './input.util';\n\nlet numberInputIds = 0;\n\n/**\n * @form-ready\n * @slot start - Element will be displayed at the start of the input\n * @slot end - Element will be displayed at the end of the input\n */\n@Component({\n tag: 'ix-number-input',\n styleUrl: 'number-input.scss',\n shadow: true,\n formAssociated: true,\n})\nexport class NumberInput implements IxInputFieldComponent<number> {\n @Element() hostElement!: HTMLIxNumberInputElement;\n @AttachInternals() formInternals!: ElementInternals;\n\n /**\n * name of the input element\n */\n @Prop({ reflect: true }) name?: string;\n\n /**\n * placeholder of the input element\n */\n @Prop({ reflect: true }) placeholder?: string;\n\n /**\n * The value of the input field\n */\n @Prop({ reflect: true, mutable: true }) value: number = 0;\n\n /**\n * Indicates if the field is required\n */\n @Prop({ reflect: true }) required: boolean = false;\n\n /**\n * Disables the input field\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Indicates if the field is read-only\n */\n @Prop() readonly: boolean = false;\n\n /**\n * The helper text for the input field\n */\n @Prop() helperText?: string;\n\n /**\n * The info text for the input field\n */\n @Prop() infoText?: string;\n\n /**\n * Indicates if the text should be shown as a tooltip\n */\n @Prop() showTextAsTooltip?: boolean;\n\n /**\n * The valid text for the input field\n */\n @Prop() validText?: string;\n\n /**\n * The warning text for the input field\n */\n @Prop() warningText?: string;\n\n /**\n * The label for the input field\n */\n @Prop({ reflect: true }) label?: string;\n\n /**\n * The error text for the input field\n */\n @Prop() invalidText?: string;\n\n /**\n * The pattern for the input field\n */\n @Prop() pattern?: string;\n\n /**\n * The minimum value for the input field\n */\n @Prop() min?: string | number;\n\n /**\n * The maximum value for the input field\n */\n @Prop() max?: string | number;\n\n /**\n * The allowed characters pattern for the input field\n */\n @Prop() allowedCharactersPattern?: string;\n\n /**\n * Indicates if the stepper buttons should be shown\n */\n @Prop() showStepperButtons?: boolean;\n\n /**\n * Step value to increment or decrement the input value\n *\n * @since 3.0.0\n */\n @Prop() step?: string | number;\n\n /**\n * Event emitted when the value of the input field changes\n */\n @Event() valueChange!: EventEmitter<number>;\n\n /**\n * Event emitted when the validity state of the input field changes\n */\n @Event() validityStateChange!: EventEmitter<ValidityState>;\n\n /**\n * Event emitted when the input field loses focus\n */\n @Event() ixBlur!: EventEmitter<void>;\n\n @State() isInvalid = false;\n @State() isValid = false;\n @State() isInfo = false;\n @State() isWarning = false;\n @State() isInvalidByRequired = false;\n\n private readonly inputRef = makeRef<HTMLInputElement>();\n private readonly slotEndRef = makeRef<HTMLDivElement>();\n private readonly slotStartRef = makeRef<HTMLDivElement>();\n private readonly numberInputId = `number-input-${numberInputIds++}`;\n private touched = false;\n\n private disposableChangesAndVisibilityObservers?: DisposableChangesAndVisibilityObservers;\n\n @HookValidationLifecycle()\n updateClassMappings(result: ValidationResults) {\n mapValidationResult(this, result);\n }\n\n componentWillLoad() {\n this.updateFormInternalValue(this.value);\n }\n\n connectedCallback() {\n this.disposableChangesAndVisibilityObservers =\n addDisposableChangesAndVisibilityObservers(\n this.hostElement,\n this.updatePaddings.bind(this)\n );\n }\n\n disconnectedCallback() {\n this.disposableChangesAndVisibilityObservers?.();\n }\n\n private updatePaddings() {\n adjustPaddingForStartAndEnd(\n this.slotStartRef.current,\n this.slotEndRef.current,\n this.inputRef.current\n );\n }\n\n updateFormInternalValue(value: number) {\n this.formInternals.setFormValue(value.toString());\n this.value = value;\n }\n\n /** @internal */\n @Method()\n async getAssociatedFormElement(): Promise<HTMLFormElement | null> {\n return this.formInternals.form;\n }\n\n /** @internal */\n @Method()\n async hasValidValue(): Promise<boolean> {\n const nativeInput = await this.getNativeInputElement();\n if (nativeInput.value === '') {\n return Promise.resolve(false);\n }\n\n return Promise.resolve(\n this.value !== null && this.value !== undefined && !isNaN(this.value)\n );\n }\n\n /**\n * Returns the native input element used under the hood\n */\n @Method()\n getNativeInputElement(): Promise<HTMLInputElement> {\n return this.inputRef.waitForCurrent();\n }\n\n /**\n * Focuses the input field\n */\n @Method()\n async focusInput(): Promise<void> {\n return (await this.getNativeInputElement()).focus();\n }\n\n /**\n * Returns true if the input field has been touched\n * @internal\n */\n @Method()\n isTouched(): Promise<boolean> {\n return Promise.resolve(this.touched);\n }\n\n render() {\n const showStepperButtons =\n this.showStepperButtons && (this.disabled || this.readonly) === false;\n\n return (\n <Host\n class={{\n disabled: this.disabled,\n readonly: this.readonly,\n }}\n >\n <ix-field-wrapper\n id={this.numberInputId}\n required={this.required}\n label={this.label}\n helperText={this.helperText}\n invalidText={this.invalidText}\n infoText={this.infoText}\n warningText={this.warningText}\n validText={this.validText}\n showTextAsTooltip={this.showTextAsTooltip}\n isInvalid={this.isInvalid}\n isValid={this.isValid}\n isInfo={this.isInfo}\n isWarning={this.isWarning}\n controlRef={this.inputRef}\n >\n <div\n class={{\n 'input-wrapper': true,\n 'show-stepper-buttons': !!this.showStepperButtons,\n }}\n >\n <SlotStart\n slotStartRef={this.slotStartRef}\n onSlotChange={() => this.updatePaddings()}\n ></SlotStart>\n\n <InputElement\n id={this.numberInputId}\n readonly={this.readonly}\n disabled={this.disabled}\n step={this.step}\n min={this.min}\n max={this.max}\n pattern={this.pattern}\n type={'number'}\n isInvalid={this.isInvalid}\n required={this.required}\n value={this.value}\n placeholder={this.placeholder}\n inputRef={this.inputRef}\n onKeyPress={(event) => checkAllowedKeys(this, event)}\n valueChange={(value) => this.valueChange.emit(Number(value))}\n updateFormInternalValue={(value) =>\n this.updateFormInternalValue(Number(value))\n }\n onBlur={() => {\n onInputBlur(this, this.inputRef.current);\n this.touched = true;\n }}\n ></InputElement>\n <SlotEnd\n slotEndRef={this.slotEndRef}\n onSlotChange={() => this.updatePaddings()}\n >\n <div\n class={{\n 'number-stepper-container': true,\n 'container-hidden': !showStepperButtons,\n }}\n >\n <ix-icon-button\n variant=\"subtle-tertiary\"\n icon={iconMinus}\n size=\"16\"\n class=\"number-stepper-button step-minus\"\n aria-label=\"decrement number\"\n onClick={() => {\n if (!this.inputRef.current) {\n return;\n }\n this.inputRef.current.stepDown();\n checkInternalValidity(this, this.inputRef.current);\n this.updateFormInternalValue(\n Number(this.inputRef.current.value)\n );\n this.valueChange.emit(this.value);\n }}\n ></ix-icon-button>\n <ix-icon-button\n variant=\"subtle-tertiary\"\n icon={iconPlus}\n size=\"16\"\n class=\"number-stepper-button step-plus\"\n aria-label=\"increment number\"\n onClick={() => {\n if (!this.inputRef.current) {\n return;\n }\n this.inputRef.current.stepUp();\n checkInternalValidity(this, this.inputRef.current);\n this.updateFormInternalValue(\n Number(this.inputRef.current.value)\n );\n this.valueChange.emit(this.value);\n }}\n ></ix-icon-button>\n </div>\n </SlotEnd>\n </div>\n </ix-field-wrapper>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"number-input.js","sourceRoot":"","sources":["../../../src/components/input/number-input.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2025 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { iconMinus, iconPlus } from '@siemens/ix-icons/icons';\nimport {\n AttachInternals,\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Method,\n Prop,\n State,\n Watch,\n} from '@stencil/core';\nimport {\n HookValidationLifecycle,\n IxInputFieldComponent,\n ValidationResults,\n} from '../utils/input';\nimport { makeRef } from '../utils/make-ref';\nimport { InputElement, SlotEnd, SlotStart } from './input.fc';\nimport {\n addDisposableChangesAndVisibilityObservers,\n adjustPaddingForStartAndEnd,\n checkAllowedKeys,\n checkInternalValidity,\n DisposableChangesAndVisibilityObservers,\n mapValidationResult,\n onInputBlur,\n} from './input.util';\n\nlet numberInputIds = 0;\n\nconst INVALID_NUMBER_INPUT_REGEX = /[^\\dEe+\\-.,]/;\n\n/**\n * @form-ready\n * @slot start - Element will be displayed at the start of the input\n * @slot end - Element will be displayed at the end of the input\n */\n@Component({\n tag: 'ix-number-input',\n styleUrl: 'number-input.scss',\n shadow: true,\n formAssociated: true,\n})\nexport class NumberInput implements IxInputFieldComponent<number> {\n @Element() hostElement!: HTMLIxNumberInputElement;\n @AttachInternals() formInternals!: ElementInternals;\n\n /**\n * name of the input element\n */\n @Prop({ reflect: true }) name?: string;\n\n /**\n * placeholder of the input element\n */\n @Prop({ reflect: true }) placeholder?: string;\n\n /**\n * The value of the input field. Supports numeric values, scientific notation (1E6, 1E-6), or undefined for empty.\n */\n @Prop({ reflect: true, mutable: true }) value?: number = 0;\n\n /**\n * Indicates if the field is required. When required, empty values (undefined) are not accepted.\n */\n @Prop({ reflect: true }) required: boolean = false;\n\n /**\n * Disables the input field\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Indicates if the field is read-only\n */\n @Prop() readonly: boolean = false;\n\n /**\n * The helper text for the input field\n */\n @Prop() helperText?: string;\n\n /**\n * The info text for the input field\n */\n @Prop() infoText?: string;\n\n /**\n * Indicates if the text should be shown as a tooltip\n */\n @Prop() showTextAsTooltip?: boolean;\n\n /**\n * The valid text for the input field\n */\n @Prop() validText?: string;\n\n /**\n * The warning text for the input field\n */\n @Prop() warningText?: string;\n\n /**\n * The label for the input field\n */\n @Prop({ reflect: true }) label?: string;\n\n /**\n * The error text for the input field\n */\n @Prop() invalidText?: string;\n\n /**\n * The pattern for the input field\n */\n @Prop() pattern?: string;\n\n /**\n * The minimum value for the input field\n */\n @Prop() min?: string | number;\n\n /**\n * The maximum value for the input field\n */\n @Prop() max?: string | number;\n\n /**\n * The allowed characters pattern for the input field\n */\n @Prop() allowedCharactersPattern?: string;\n\n /**\n * Indicates if the stepper buttons should be shown\n */\n @Prop() showStepperButtons?: boolean;\n\n /**\n * Step value to increment or decrement the input value. Default step value is 1.\n *\n */\n @Prop() step?: string | number = 1;\n\n /**\n * If false, pressing Enter will submit the form (if inside a form).\n * Set to true to suppress submit on Enter.\n */\n @Prop({ reflect: true }) suppressSubmitOnEnter: boolean = false;\n\n /**\n * Text alignment within the number input. 'start' aligns the text to the start of the input, 'end' aligns the text to the end of the input.\n */\n @Prop() textAlignment: 'start' | 'end' = 'end';\n\n /**\n * If true, the valueChange event will return null instead of 0 for an empty input state.\n * This property will be removed in 5.0.0 and this behaviour will be default.\n *\n * @since 4.1.0\n */\n @Prop({ reflect: true }) allowEmptyValueChange: boolean = false;\n\n /**\n * Event emitted when the value of the input field changes\n */\n @Event() valueChange!: EventEmitter<number>;\n\n /**\n * Event emitted when the validity state of the input field changes\n */\n @Event() validityStateChange!: EventEmitter<ValidityState>;\n\n /**\n * Event emitted when the input field loses focus\n */\n @Event() ixBlur!: EventEmitter<void>;\n\n @State() isInvalid = false;\n @State() isValid = false;\n @State() isInfo = false;\n @State() isWarning = false;\n @State() isInvalidByRequired = false;\n\n private readonly inputRef = makeRef<HTMLInputElement>();\n private readonly slotEndRef = makeRef<HTMLDivElement>();\n private readonly slotStartRef = makeRef<HTMLDivElement>();\n private readonly numberInputId = `number-input-${numberInputIds++}`;\n private touched = false;\n\n private disposableChangesAndVisibilityObservers?: DisposableChangesAndVisibilityObservers;\n\n @Watch('value')\n onValueChange(newValue: number | undefined) {\n this.updateFormInternalValue(newValue!);\n }\n\n @HookValidationLifecycle()\n updateClassMappings(result: ValidationResults) {\n mapValidationResult(this, result);\n }\n\n componentWillLoad() {\n this.updateFormInternalValue(this.value!);\n }\n\n connectedCallback() {\n this.disposableChangesAndVisibilityObservers =\n addDisposableChangesAndVisibilityObservers(\n this.hostElement,\n this.updatePaddings.bind(this)\n );\n }\n\n disconnectedCallback() {\n this.disposableChangesAndVisibilityObservers?.();\n }\n\n private updatePaddings() {\n adjustPaddingForStartAndEnd(\n this.slotStartRef.current,\n this.slotEndRef.current,\n this.inputRef.current\n );\n }\n\n private convertNumberStringToFloat(input: string): number | undefined {\n if (!input || input.trim() === '') {\n return undefined;\n }\n\n const parsed = Number.parseFloat(input);\n return Number.isNaN(parsed) ? undefined : parsed;\n }\n\n private isScientificNotation(input: string): boolean {\n const parsed = Number.parseFloat(input);\n return (\n !Number.isNaN(parsed) && Number.isFinite(parsed) && /[eE]/.test(input)\n );\n }\n\n private formatValue(value: number | undefined): string {\n if (value === undefined || value === null) {\n return '';\n }\n return value.toString();\n }\n\n private handleValueChangeEvent(value: number | undefined) {\n this.valueChange.emit(this.allowEmptyValueChange ? value : (value ?? 0));\n }\n\n updateFormInternalValue(value: number) {\n const formValue =\n value !== undefined && value !== null ? value.toString() : '';\n this.formInternals.setFormValue(formValue);\n this.value = value;\n }\n\n private readonly handleInputChange = (inputValue: string) => {\n const parsedValue = this.convertNumberStringToFloat(inputValue);\n const isScientificNotation = this.isScientificNotation(inputValue.trim());\n\n if (isScientificNotation) {\n this.formInternals.setFormValue(inputValue);\n }\n\n this.handleValueChangeEvent(parsedValue);\n };\n\n private readonly handleBlur = () => {\n if (!this.inputRef.current) return;\n\n const inputValue = this.inputRef.current.value;\n\n const parsedValue = this.convertNumberStringToFloat(inputValue);\n\n if (parsedValue !== undefined) {\n this.inputRef.current.value = this.formatValue(parsedValue);\n }\n\n this.updateFormInternalValue(parsedValue!);\n\n onInputBlur(this, this.inputRef.current);\n this.touched = true;\n };\n\n private readonly handleKeyDown = (event: KeyboardEvent) => {\n if (this.disabled || this.readonly) {\n return;\n }\n\n switch (event.key) {\n case 'ArrowUp':\n event.preventDefault();\n this.handleStepOperation('up');\n break;\n case 'ArrowDown':\n event.preventDefault();\n this.handleStepOperation('down');\n break;\n }\n };\n\n private readonly handleBeforeInput = (e: InputEvent) => {\n if (this.disabled || this.readonly) return;\n\n if (e.inputType === 'insertText') {\n const character = e.data;\n\n if (character && INVALID_NUMBER_INPUT_REGEX.test(character)) {\n e.preventDefault();\n }\n }\n\n if (e.inputType === 'insertFromPaste') {\n const dt = e.dataTransfer || (e as any).clipboardData;\n const text = dt?.getData?.('text') ?? '';\n if (INVALID_NUMBER_INPUT_REGEX.test(text)) {\n e.preventDefault();\n }\n }\n };\n\n private readonly handlePaste = (e: ClipboardEvent) => {\n // Fallback for browsers that don’t fire beforeinput for paste\n const text = e.clipboardData?.getData('text') ?? '';\n if (INVALID_NUMBER_INPUT_REGEX.test(text)) {\n e.preventDefault();\n }\n };\n\n private handleStepOperation(operation: 'up' | 'down') {\n if (!this.inputRef.current) {\n return;\n }\n\n const currentValue = this.value ?? 0;\n const stepValue =\n typeof this.step === 'string'\n ? Number.parseFloat(this.step)\n : (this.step ?? 1);\n\n let newValue: number;\n\n if (operation === 'up') {\n newValue = currentValue + stepValue;\n } else {\n newValue = currentValue - stepValue;\n }\n\n if (this.min !== undefined) {\n const minValue =\n typeof this.min === 'string' ? Number.parseFloat(this.min) : this.min;\n newValue = Math.max(newValue, minValue);\n }\n\n if (this.max !== undefined) {\n const maxValue =\n typeof this.max === 'string' ? Number.parseFloat(this.max) : this.max;\n newValue = Math.min(newValue, maxValue);\n }\n\n this.inputRef.current.value = newValue.toString();\n this.updateFormInternalValue(newValue);\n checkInternalValidity(this, this.inputRef.current);\n this.handleValueChangeEvent(newValue);\n }\n\n /** @internal */\n @Method()\n async getAssociatedFormElement(): Promise<HTMLFormElement | null> {\n return this.formInternals.form;\n }\n\n /** @internal */\n @Method()\n async hasValidValue(): Promise<boolean> {\n const nativeInput = await this.getNativeInputElement();\n if (nativeInput.value === '') {\n return !this.required;\n }\n\n const parsedValue = this.convertNumberStringToFloat(nativeInput.value);\n return parsedValue !== undefined;\n }\n\n /**\n * Returns the native input element used under the hood\n */\n @Method()\n getNativeInputElement(): Promise<HTMLInputElement> {\n return this.inputRef.waitForCurrent();\n }\n\n /**\n * Focuses the input field\n */\n @Method()\n async focusInput(): Promise<void> {\n return (await this.getNativeInputElement()).focus();\n }\n\n /**\n * Returns true if the input field has been touched\n * @internal\n */\n @Method()\n isTouched(): Promise<boolean> {\n return Promise.resolve(this.touched);\n }\n\n render() {\n const showStepperButtons =\n this.showStepperButtons && (this.disabled || this.readonly) === false;\n\n return (\n <Host\n class={{\n disabled: this.disabled,\n readonly: this.readonly,\n }}\n >\n <ix-field-wrapper\n id={this.numberInputId}\n required={this.required}\n label={this.label}\n helperText={this.helperText}\n invalidText={this.invalidText}\n infoText={this.infoText}\n warningText={this.warningText}\n validText={this.validText}\n showTextAsTooltip={this.showTextAsTooltip}\n isInvalid={this.isInvalid}\n isValid={this.isValid}\n isInfo={this.isInfo}\n isWarning={this.isWarning}\n controlRef={this.inputRef}\n >\n <div\n class={{\n 'input-wrapper': true,\n 'show-stepper-buttons': !!this.showStepperButtons,\n }}\n >\n <SlotStart\n slotStartRef={this.slotStartRef}\n onSlotChange={() => this.updatePaddings()}\n ></SlotStart>\n\n <InputElement\n id={this.numberInputId}\n readonly={this.readonly}\n disabled={this.disabled}\n step={this.step}\n min={this.min}\n max={this.max}\n pattern={this.pattern}\n type={'number'}\n isInvalid={this.isInvalid}\n required={this.required}\n value={this.formatValue(this.value)}\n placeholder={this.placeholder}\n inputRef={this.inputRef}\n onKeyPress={(event) => checkAllowedKeys(this, event)}\n onKeyDown={(event) => this.handleKeyDown(event)}\n onBeforeInput={(event) => this.handleBeforeInput(event)}\n onPaste={(event) => this.handlePaste(event)}\n valueChange={this.handleInputChange}\n updateFormInternalValue={(value) => {\n const isScientificNotation = this.isScientificNotation(\n value.trim()\n );\n\n if (!isScientificNotation) {\n const parsedValue = this.convertNumberStringToFloat(value);\n this.updateFormInternalValue(parsedValue!);\n }\n }}\n onBlur={this.handleBlur}\n form={this.formInternals.form ?? undefined}\n suppressSubmitOnEnter={this.suppressSubmitOnEnter}\n textAlignment={this.textAlignment}\n ></InputElement>\n <SlotEnd\n slotEndRef={this.slotEndRef}\n onSlotChange={() => this.updatePaddings()}\n >\n <div\n class={{\n 'number-stepper-container': true,\n 'container-hidden': !showStepperButtons,\n }}\n >\n <ix-icon-button\n variant=\"subtle-tertiary\"\n icon={iconMinus}\n size=\"16\"\n class=\"number-stepper-button step-minus\"\n aria-label=\"decrement number\"\n onClick={() => this.handleStepOperation('down')}\n ></ix-icon-button>\n <ix-icon-button\n variant=\"subtle-tertiary\"\n icon={iconPlus}\n size=\"16\"\n class=\"number-stepper-button step-plus\"\n aria-label=\"increment number\"\n onClick={() => this.handleStepOperation('up')}\n ></ix-icon-button>\n </div>\n </SlotEnd>\n </div>\n </ix-field-wrapper>\n </Host>\n );\n }\n}\n"]}