@siemens/ix 2.5.0 → 2.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1456) hide show
  1. package/components/a11y.js +3 -2
  2. package/components/a11y.js.map +1 -1
  3. package/components/application-header.js +3 -3
  4. package/components/avatar.js +12 -4
  5. package/components/avatar.js.map +1 -1
  6. package/components/base-button.js +2 -2
  7. package/components/base-button.js.map +1 -1
  8. package/components/button.js +13 -4
  9. package/components/button.js.map +1 -1
  10. package/components/card-accordion.js +5 -5
  11. package/components/card-accordion.js.map +1 -1
  12. package/components/card-content.js +1 -1
  13. package/components/card-title.js +1 -1
  14. package/components/card.js +4 -4
  15. package/components/card.js.map +1 -1
  16. package/components/col.js +1 -1
  17. package/components/col.js.map +1 -1
  18. package/components/context.js +5 -2
  19. package/components/context.js.map +1 -1
  20. package/components/date-picker.js +65 -43
  21. package/components/date-picker.js.map +1 -1
  22. package/components/date-time-card.js +5 -6
  23. package/components/date-time-card.js.map +1 -1
  24. package/components/divider.js +1 -1
  25. package/components/dropdown-controller.js +28 -12
  26. package/components/dropdown-controller.js.map +1 -1
  27. package/components/dropdown-item.js +3 -3
  28. package/components/dropdown.js +103 -82
  29. package/components/dropdown.js.map +1 -1
  30. package/components/field-label.js +164 -0
  31. package/components/field-label.js.map +1 -0
  32. package/components/field-wrapper.js +97 -0
  33. package/components/field-wrapper.js.map +1 -0
  34. package/components/filter-chip.js +1 -1
  35. package/components/find-element.js +102 -0
  36. package/components/find-element.js.map +1 -0
  37. package/components/group-context-menu.js +1 -1
  38. package/components/group-item.js +2 -2
  39. package/components/helper-text-util.js +41 -0
  40. package/components/helper-text-util.js.map +1 -0
  41. package/components/icon-button.js +2 -2
  42. package/components/icon-button.js.map +1 -1
  43. package/components/index.js +43 -5
  44. package/components/index.js.map +1 -1
  45. package/components/index3.js +21 -0
  46. package/components/index3.js.map +1 -0
  47. package/components/input.util.js +181 -0
  48. package/components/input.util.js.map +1 -0
  49. package/components/ix-action-card.js +1 -1
  50. package/components/ix-action-card.js.map +1 -1
  51. package/components/ix-application-sidebar.js +1 -1
  52. package/components/ix-application-switch-modal.js +1 -1
  53. package/components/ix-application.js +3 -3
  54. package/components/ix-basic-navigation.js +2 -2
  55. package/components/ix-blind.js +5 -5
  56. package/components/ix-blind.js.map +1 -1
  57. package/components/ix-breadcrumb.js +9 -10
  58. package/components/ix-breadcrumb.js.map +1 -1
  59. package/components/ix-card-list.js +10 -7
  60. package/components/ix-card-list.js.map +1 -1
  61. package/components/ix-category-filter.js +152 -82
  62. package/components/ix-category-filter.js.map +1 -1
  63. package/components/{ix-playground-internal.d.ts → ix-checkbox-group.d.ts} +4 -4
  64. package/components/ix-checkbox-group.js +111 -0
  65. package/components/ix-checkbox-group.js.map +1 -0
  66. package/components/ix-checkbox.d.ts +11 -0
  67. package/components/ix-checkbox.js +144 -0
  68. package/components/ix-checkbox.js.map +1 -0
  69. package/components/ix-chip.js +4 -4
  70. package/components/ix-content-header.js +2 -2
  71. package/components/ix-content-header.js.map +1 -1
  72. package/components/ix-content.js +4 -4
  73. package/components/ix-content.js.map +1 -1
  74. package/components/ix-css-grid-item.js +1 -1
  75. package/components/ix-css-grid.js +8 -3
  76. package/components/ix-css-grid.js.map +1 -1
  77. package/components/ix-custom-field.d.ts +11 -0
  78. package/components/ix-custom-field.js +116 -0
  79. package/components/ix-custom-field.js.map +1 -0
  80. package/components/ix-date-dropdown.js +29 -16
  81. package/components/ix-date-dropdown.js.map +1 -1
  82. package/components/{ix-form-field.d.ts → ix-date-input.d.ts} +4 -4
  83. package/components/ix-date-input.js +364 -0
  84. package/components/ix-date-input.js.map +1 -0
  85. package/components/ix-datetime-picker.js +11 -11
  86. package/components/ix-datetime-picker.js.map +1 -1
  87. package/components/ix-drawer.js +28 -24
  88. package/components/ix-drawer.js.map +1 -1
  89. package/components/ix-dropdown-button.js +5 -7
  90. package/components/ix-dropdown-button.js.map +1 -1
  91. package/components/ix-dropdown-header.js +1 -1
  92. package/components/ix-dropdown-header.js.map +1 -1
  93. package/components/ix-dropdown-quick-actions.js +1 -1
  94. package/components/ix-empty-state.js +1 -1
  95. package/components/ix-empty-state.js.map +1 -1
  96. package/components/ix-event-list-item.js +7 -7
  97. package/components/ix-event-list-item.js.map +1 -1
  98. package/components/ix-event-list.js +4 -4
  99. package/components/ix-event-list.js.map +1 -1
  100. package/components/ix-expanding-search.js +4 -4
  101. package/components/ix-field-label.d.ts +11 -0
  102. package/components/ix-field-label.js +8 -0
  103. package/components/ix-field-label.js.map +1 -0
  104. package/components/{ix-modal-example.d.ts → ix-field-wrapper.d.ts} +4 -4
  105. package/components/ix-field-wrapper.js +8 -0
  106. package/components/ix-field-wrapper.js.map +1 -0
  107. package/components/ix-flip-tile-content.js +1 -1
  108. package/components/ix-flip-tile.js +4 -4
  109. package/components/ix-group.js +8 -8
  110. package/components/ix-helper-text.d.ts +11 -0
  111. package/components/ix-helper-text.js +97 -0
  112. package/components/ix-helper-text.js.map +1 -0
  113. package/components/ix-icon-toggle-button.js +2 -3
  114. package/components/ix-icon-toggle-button.js.map +1 -1
  115. package/components/ix-input-group.js +1 -1
  116. package/components/ix-input.d.ts +11 -0
  117. package/components/ix-input.js +221 -0
  118. package/components/ix-input.js.map +1 -0
  119. package/components/ix-key-value-list.js +1 -1
  120. package/components/ix-key-value.js +1 -1
  121. package/components/ix-kpi.js +3 -3
  122. package/components/ix-layout-auto.d.ts +11 -0
  123. package/components/ix-layout-auto.js +110 -0
  124. package/components/ix-layout-auto.js.map +1 -0
  125. package/components/ix-link-button.js +3 -3
  126. package/components/ix-map-navigation.js +2 -2
  127. package/components/ix-menu-about-item.js +1 -1
  128. package/components/ix-menu-about-news.js +4 -4
  129. package/components/ix-menu-about-news.js.map +1 -1
  130. package/components/ix-menu-about.js +1 -1
  131. package/components/ix-menu-avatar.js +2 -2
  132. package/components/ix-menu-category.js +5 -5
  133. package/components/ix-menu-category.js.map +1 -1
  134. package/components/ix-menu-settings-item.js +1 -1
  135. package/components/ix-menu.js +28 -29
  136. package/components/ix-menu.js.map +1 -1
  137. package/components/ix-message-bar.js +1 -1
  138. package/components/ix-modal-footer.js +2 -2
  139. package/components/ix-modal-footer.js.map +1 -1
  140. package/components/ix-modal-loading.js +1 -1
  141. package/components/ix-modal.js +11 -4
  142. package/components/ix-modal.js.map +1 -1
  143. package/components/ix-number-input.d.ts +11 -0
  144. package/components/ix-number-input.js +221 -0
  145. package/components/ix-number-input.js.map +1 -0
  146. package/components/ix-pagination.js +35 -17
  147. package/components/ix-pagination.js.map +1 -1
  148. package/components/ix-pane-layout.js +9 -9
  149. package/components/ix-pane-layout.js.map +1 -1
  150. package/components/ix-pane.js +43 -35
  151. package/components/ix-pane.js.map +1 -1
  152. package/components/ix-pill.js +4 -4
  153. package/components/ix-push-card.js +1 -1
  154. package/components/ix-radio-group.d.ts +11 -0
  155. package/components/ix-radio-group.js +174 -0
  156. package/components/ix-radio-group.js.map +1 -0
  157. package/components/ix-radio.d.ts +11 -0
  158. package/components/ix-radio.js +123 -0
  159. package/components/ix-radio.js.map +1 -0
  160. package/components/ix-slider.js +7 -7
  161. package/components/ix-slider.js.map +1 -1
  162. package/components/ix-split-button-item.js +1 -1
  163. package/components/ix-split-button.js +1 -1
  164. package/components/ix-textarea.d.ts +11 -0
  165. package/components/ix-textarea.js +179 -0
  166. package/components/ix-textarea.js.map +1 -0
  167. package/components/ix-tile.js +4 -4
  168. package/components/ix-toast-container.js +2 -2
  169. package/components/ix-toggle-button.js +2 -2
  170. package/components/ix-toggle.js +43 -5
  171. package/components/ix-toggle.js.map +1 -1
  172. package/components/ix-tree.js +1 -1
  173. package/components/ix-upload.js +61 -5
  174. package/components/ix-upload.js.map +1 -1
  175. package/components/ix-validation-tooltip.js +2 -2
  176. package/components/ix-workflow-step.js +3 -3
  177. package/components/ix-workflow-steps.js +1 -1
  178. package/components/layout-grid.js +2 -2
  179. package/components/layout-grid.js.map +1 -1
  180. package/components/listener.js +1 -1
  181. package/components/listener.js.map +1 -1
  182. package/components/make-ref.js +7 -12
  183. package/components/make-ref.js.map +1 -1
  184. package/components/map-navigation-overlay.js +2 -2
  185. package/components/menu-avatar-item.js +1 -1
  186. package/components/menu-expand-icon.js +1 -1
  187. package/components/menu-item.js +7 -6
  188. package/components/menu-item.js.map +1 -1
  189. package/components/menu-tabs-fc.js +17 -14
  190. package/components/menu-tabs-fc.js.map +1 -1
  191. package/components/modal-content.js +2 -2
  192. package/components/modal-content.js.map +1 -1
  193. package/components/modal-header.js +2 -2
  194. package/components/modal-header.js.map +1 -1
  195. package/components/modal.js +3 -1
  196. package/components/modal.js.map +1 -1
  197. package/components/row.js +1 -1
  198. package/components/select-item.js +27 -5
  199. package/components/select-item.js.map +1 -1
  200. package/components/select.js +196 -67
  201. package/components/select.js.map +1 -1
  202. package/components/spinner.js +4 -8
  203. package/components/spinner.js.map +1 -1
  204. package/components/tab-item.js +3 -3
  205. package/components/tabs.js +2 -2
  206. package/components/theme-switcher.js +1 -0
  207. package/components/theme-switcher.js.map +1 -1
  208. package/components/time-picker.js +39 -19
  209. package/components/time-picker.js.map +1 -1
  210. package/components/toast.js +2 -2
  211. package/components/tooltip.js +5 -4
  212. package/components/tooltip.js.map +1 -1
  213. package/components/tree-item.js +4 -4
  214. package/components/typography.js +3 -25
  215. package/components/typography.js.map +1 -1
  216. package/components/validation.js +112 -0
  217. package/components/validation.js.map +1 -0
  218. package/dist/cjs/{a11y-eba397e8.js → a11y-ae470f01.js} +4 -3
  219. package/dist/cjs/a11y-ae470f01.js.map +1 -0
  220. package/dist/cjs/app-globals-3c9c6a50.js +9 -0
  221. package/dist/cjs/app-globals-3c9c6a50.js.map +1 -0
  222. package/dist/cjs/{base-button-3735b8c2.js → base-button-119d9368.js} +4 -4
  223. package/dist/cjs/base-button-119d9368.js.map +1 -0
  224. package/dist/cjs/{base-icon-button-44c72bc8.js → base-icon-button-d09d934e.js} +3 -3
  225. package/dist/cjs/{base-icon-button-44c72bc8.js.map → base-icon-button-d09d934e.js.map} +1 -1
  226. package/dist/cjs/{context-938f7470.js → context-6644f454.js} +6 -3
  227. package/dist/cjs/context-6644f454.js.map +1 -0
  228. package/dist/cjs/disposable-event-listener-1ed769b9.js +20 -0
  229. package/dist/cjs/disposable-event-listener-1ed769b9.js.map +1 -0
  230. package/dist/cjs/{dropdown-controller-5ef3d018.js → dropdown-controller-aef51729.js} +28 -13
  231. package/dist/cjs/dropdown-controller-aef51729.js.map +1 -0
  232. package/dist/cjs/find-element-8e586600.js +105 -0
  233. package/dist/cjs/find-element-8e586600.js.map +1 -0
  234. package/dist/cjs/{focus-9c8ffbb0.js → focus-935fb067.js} +22 -18
  235. package/dist/cjs/focus-935fb067.js.map +1 -0
  236. package/dist/cjs/helper-text-util-3192e78f.js +44 -0
  237. package/dist/cjs/helper-text-util-3192e78f.js.map +1 -0
  238. package/dist/cjs/{index-c4629a8d.js → index-74904d8b.js} +2 -2
  239. package/dist/cjs/{index-c4629a8d.js.map → index-74904d8b.js.map} +1 -1
  240. package/dist/cjs/{index-529f21c1.js → index-757233c7.js} +86 -171
  241. package/dist/cjs/index-757233c7.js.map +1 -0
  242. package/dist/cjs/index-d2117dc0.js +38 -0
  243. package/dist/cjs/index-d2117dc0.js.map +1 -0
  244. package/dist/cjs/index.cjs.js +21 -2
  245. package/dist/cjs/index.cjs.js.map +1 -1
  246. package/dist/cjs/input.util-1c2fa43d.js +192 -0
  247. package/dist/cjs/input.util-1c2fa43d.js.map +1 -0
  248. package/dist/cjs/ix-action-card.cjs.entry.js +2 -2
  249. package/dist/cjs/ix-action-card.cjs.entry.js.map +1 -1
  250. package/dist/cjs/ix-application-header.cjs.entry.js +7 -7
  251. package/dist/cjs/ix-application-sidebar.cjs.entry.js +2 -2
  252. package/dist/cjs/ix-application-switch-modal.cjs.entry.js +3 -3
  253. package/dist/cjs/ix-application.cjs.entry.js +6 -6
  254. package/dist/cjs/ix-avatar_2.cjs.entry.js +16 -8
  255. package/dist/cjs/ix-avatar_2.cjs.entry.js.map +1 -1
  256. package/dist/cjs/ix-basic-navigation.cjs.entry.js +4 -4
  257. package/dist/cjs/ix-blind.cjs.entry.js +7 -7
  258. package/dist/cjs/ix-blind.cjs.entry.js.map +1 -1
  259. package/dist/cjs/ix-breadcrumb-item.cjs.entry.js +3 -3
  260. package/dist/cjs/ix-breadcrumb.cjs.entry.js +11 -10
  261. package/dist/cjs/ix-breadcrumb.cjs.entry.js.map +1 -1
  262. package/dist/cjs/ix-button.cjs.entry.js +14 -5
  263. package/dist/cjs/ix-button.cjs.entry.js.map +1 -1
  264. package/dist/cjs/ix-card-accordion_2.cjs.entry.js +7 -7
  265. package/dist/cjs/ix-card-accordion_2.cjs.entry.js.map +1 -1
  266. package/dist/cjs/ix-card-list.cjs.entry.js +11 -8
  267. package/dist/cjs/ix-card-list.cjs.entry.js.map +1 -1
  268. package/dist/cjs/ix-card_2.cjs.entry.js +6 -6
  269. package/dist/cjs/ix-card_2.cjs.entry.js.map +1 -1
  270. package/dist/cjs/ix-category-filter.cjs.entry.js +154 -82
  271. package/dist/cjs/ix-category-filter.cjs.entry.js.map +1 -1
  272. package/dist/cjs/ix-checkbox-group.cjs.entry.js +60 -0
  273. package/dist/cjs/ix-checkbox-group.cjs.entry.js.map +1 -0
  274. package/dist/cjs/ix-checkbox.cjs.entry.js +117 -0
  275. package/dist/cjs/ix-checkbox.cjs.entry.js.map +1 -0
  276. package/dist/cjs/ix-chip.cjs.entry.js +5 -5
  277. package/dist/cjs/ix-col_4.cjs.entry.js +75 -49
  278. package/dist/cjs/ix-col_4.cjs.entry.js.map +1 -1
  279. package/dist/cjs/ix-content-header.cjs.entry.js +3 -3
  280. package/dist/cjs/ix-content-header.cjs.entry.js.map +1 -1
  281. package/dist/cjs/ix-content.cjs.entry.js +5 -5
  282. package/dist/cjs/ix-content.cjs.entry.js.map +1 -1
  283. package/dist/cjs/ix-css-grid-item.cjs.entry.js +2 -2
  284. package/dist/cjs/ix-css-grid.cjs.entry.js +9 -4
  285. package/dist/cjs/ix-css-grid.cjs.entry.js.map +1 -1
  286. package/dist/cjs/ix-custom-field.cjs.entry.js +65 -0
  287. package/dist/cjs/ix-custom-field.cjs.entry.js.map +1 -0
  288. package/dist/cjs/ix-date-dropdown.cjs.entry.js +28 -16
  289. package/dist/cjs/ix-date-dropdown.cjs.entry.js.map +1 -1
  290. package/dist/cjs/ix-date-input.cjs.entry.js +266 -0
  291. package/dist/cjs/ix-date-input.cjs.entry.js.map +1 -0
  292. package/dist/cjs/ix-date-time-card.cjs.entry.js +5 -6
  293. package/dist/cjs/ix-date-time-card.cjs.entry.js.map +1 -1
  294. package/dist/cjs/ix-datetime-picker.cjs.entry.js +11 -11
  295. package/dist/cjs/ix-datetime-picker.cjs.entry.js.map +1 -1
  296. package/dist/cjs/ix-divider.cjs.entry.js +2 -2
  297. package/dist/cjs/ix-drawer.cjs.entry.js +29 -25
  298. package/dist/cjs/ix-drawer.cjs.entry.js.map +1 -1
  299. package/dist/cjs/ix-dropdown-button.cjs.entry.js +5 -6
  300. package/dist/cjs/ix-dropdown-button.cjs.entry.js.map +1 -1
  301. package/dist/cjs/ix-dropdown-header.cjs.entry.js +2 -2
  302. package/dist/cjs/ix-dropdown-header.cjs.entry.js.map +1 -1
  303. package/dist/cjs/ix-dropdown-item.cjs.entry.js +4 -4
  304. package/dist/cjs/ix-dropdown-quick-actions.cjs.entry.js +2 -2
  305. package/dist/cjs/ix-dropdown.cjs.entry.js +71 -67
  306. package/dist/cjs/ix-dropdown.cjs.entry.js.map +1 -1
  307. package/dist/cjs/ix-empty-state.cjs.entry.js +2 -2
  308. package/dist/cjs/ix-empty-state.cjs.entry.js.map +1 -1
  309. package/dist/cjs/ix-event-list-item.cjs.entry.js +9 -9
  310. package/dist/cjs/ix-event-list-item.cjs.entry.js.map +1 -1
  311. package/dist/cjs/ix-event-list.cjs.entry.js +5 -5
  312. package/dist/cjs/ix-event-list.cjs.entry.js.map +1 -1
  313. package/dist/cjs/ix-expanding-search.cjs.entry.js +5 -5
  314. package/dist/cjs/{ix-tooltip.cjs.entry.js → ix-field-label_3.cjs.entry.js} +184 -7
  315. package/dist/cjs/ix-field-label_3.cjs.entry.js.map +1 -0
  316. package/dist/cjs/ix-filter-chip_2.cjs.entry.js +28 -7
  317. package/dist/cjs/ix-filter-chip_2.cjs.entry.js.map +1 -1
  318. package/dist/cjs/ix-flip-tile-content.cjs.entry.js +2 -2
  319. package/dist/cjs/ix-flip-tile.cjs.entry.js +5 -5
  320. package/dist/cjs/ix-group-context-menu_2.cjs.entry.js +4 -4
  321. package/dist/cjs/ix-group.cjs.entry.js +9 -9
  322. package/dist/cjs/ix-helper-text.cjs.entry.js +70 -0
  323. package/dist/cjs/ix-helper-text.cjs.entry.js.map +1 -0
  324. package/dist/cjs/ix-icon-button_2.cjs.entry.js +10 -14
  325. package/dist/cjs/ix-icon-button_2.cjs.entry.js.map +1 -1
  326. package/dist/cjs/ix-icon-toggle-button.cjs.entry.js +6 -7
  327. package/dist/cjs/ix-icon-toggle-button.cjs.entry.js.map +1 -1
  328. package/dist/cjs/ix-input-group.cjs.entry.js +2 -2
  329. package/dist/cjs/ix-input.cjs.entry.js +149 -0
  330. package/dist/cjs/ix-input.cjs.entry.js.map +1 -0
  331. package/dist/cjs/ix-key-value-list.cjs.entry.js +2 -2
  332. package/dist/cjs/ix-key-value.cjs.entry.js +2 -2
  333. package/dist/cjs/ix-kpi.cjs.entry.js +4 -4
  334. package/dist/cjs/ix-layout-auto.cjs.entry.js +92 -0
  335. package/dist/cjs/ix-layout-auto.cjs.entry.js.map +1 -0
  336. package/dist/cjs/ix-link-button.cjs.entry.js +4 -4
  337. package/dist/cjs/ix-map-navigation-overlay.cjs.entry.js +3 -3
  338. package/dist/cjs/ix-map-navigation.cjs.entry.js +4 -4
  339. package/dist/cjs/ix-menu-about-item.cjs.entry.js +2 -2
  340. package/dist/cjs/ix-menu-about-news.cjs.entry.js +5 -5
  341. package/dist/cjs/ix-menu-about-news.cjs.entry.js.map +1 -1
  342. package/dist/cjs/ix-menu-about.cjs.entry.js +3 -3
  343. package/dist/cjs/ix-menu-avatar.cjs.entry.js +3 -3
  344. package/dist/cjs/ix-menu-category.cjs.entry.js +7 -7
  345. package/dist/cjs/ix-menu-category.cjs.entry.js.map +1 -1
  346. package/dist/cjs/ix-menu-expand-icon.cjs.entry.js +4 -4
  347. package/dist/cjs/ix-menu-item.cjs.entry.js +9 -8
  348. package/dist/cjs/ix-menu-item.cjs.entry.js.map +1 -1
  349. package/dist/cjs/ix-menu-settings-item.cjs.entry.js +2 -2
  350. package/dist/cjs/ix-menu-settings.cjs.entry.js +2 -2
  351. package/dist/cjs/ix-menu.cjs.entry.js +33 -33
  352. package/dist/cjs/ix-menu.cjs.entry.js.map +1 -1
  353. package/dist/cjs/ix-message-bar.cjs.entry.js +2 -2
  354. package/dist/cjs/ix-modal-content_2.cjs.entry.js +5 -5
  355. package/dist/cjs/ix-modal-content_2.cjs.entry.js.map +1 -1
  356. package/dist/cjs/ix-modal-footer.cjs.entry.js +3 -3
  357. package/dist/cjs/ix-modal-footer.cjs.entry.js.map +1 -1
  358. package/dist/cjs/ix-modal-loading.cjs.entry.js +2 -2
  359. package/dist/cjs/ix-modal.cjs.entry.js +14 -7
  360. package/dist/cjs/ix-modal.cjs.entry.js.map +1 -1
  361. package/dist/cjs/ix-number-input.cjs.entry.js +152 -0
  362. package/dist/cjs/ix-number-input.cjs.entry.js.map +1 -0
  363. package/dist/cjs/ix-pagination.cjs.entry.js +6 -6
  364. package/dist/cjs/ix-pagination.cjs.entry.js.map +1 -1
  365. package/dist/cjs/ix-pane-layout.cjs.entry.js +10 -10
  366. package/dist/cjs/ix-pane-layout.cjs.entry.js.map +1 -1
  367. package/dist/cjs/ix-pane.cjs.entry.js +43 -35
  368. package/dist/cjs/ix-pane.cjs.entry.js.map +1 -1
  369. package/dist/cjs/ix-pill.cjs.entry.js +5 -5
  370. package/dist/cjs/ix-push-card.cjs.entry.js +2 -2
  371. package/dist/cjs/ix-radio-group.cjs.entry.js +120 -0
  372. package/dist/cjs/ix-radio-group.cjs.entry.js.map +1 -0
  373. package/dist/cjs/ix-radio.cjs.entry.js +98 -0
  374. package/dist/cjs/ix-radio.cjs.entry.js.map +1 -0
  375. package/dist/cjs/ix-select.cjs.entry.js +150 -53
  376. package/dist/cjs/ix-select.cjs.entry.js.map +1 -1
  377. package/dist/cjs/ix-slider.cjs.entry.js +10 -10
  378. package/dist/cjs/ix-slider.cjs.entry.js.map +1 -1
  379. package/dist/cjs/ix-split-button-item.cjs.entry.js +3 -3
  380. package/dist/cjs/ix-split-button.cjs.entry.js +2 -2
  381. package/dist/cjs/ix-tab-item_2.cjs.entry.js +6 -6
  382. package/dist/cjs/ix-textarea.cjs.entry.js +120 -0
  383. package/dist/cjs/ix-textarea.cjs.entry.js.map +1 -0
  384. package/dist/cjs/ix-tile.cjs.entry.js +5 -5
  385. package/dist/cjs/ix-time-picker.cjs.entry.js +40 -20
  386. package/dist/cjs/ix-time-picker.cjs.entry.js.map +1 -1
  387. package/dist/cjs/ix-toast-container.cjs.entry.js +3 -3
  388. package/dist/cjs/ix-toast.cjs.entry.js +3 -3
  389. package/dist/cjs/ix-toggle-button.cjs.entry.js +5 -5
  390. package/dist/cjs/ix-toggle.cjs.entry.js +42 -5
  391. package/dist/cjs/ix-toggle.cjs.entry.js.map +1 -1
  392. package/dist/cjs/ix-tree-item.cjs.entry.js +5 -5
  393. package/dist/cjs/ix-tree.cjs.entry.js +3 -3
  394. package/dist/cjs/ix-typography.cjs.entry.js +4 -25
  395. package/dist/cjs/ix-typography.cjs.entry.js.map +1 -1
  396. package/dist/cjs/ix-upload.cjs.entry.js +60 -6
  397. package/dist/cjs/ix-upload.cjs.entry.js.map +1 -1
  398. package/dist/cjs/ix-validation-tooltip.cjs.entry.js +3 -3
  399. package/dist/cjs/ix-workflow-step.cjs.entry.js +4 -4
  400. package/dist/cjs/ix-workflow-steps.cjs.entry.js +2 -2
  401. package/dist/cjs/{listener-a124ed49.js → listener-9ec23f49.js} +3 -3
  402. package/dist/cjs/listener-9ec23f49.js.map +1 -0
  403. package/dist/cjs/loader.cjs.js +4 -3
  404. package/dist/cjs/loader.cjs.js.map +1 -1
  405. package/dist/cjs/{make-ref-c25629b7.js → make-ref-499e1e41.js} +8 -13
  406. package/dist/cjs/make-ref-499e1e41.js.map +1 -0
  407. package/dist/cjs/{menu-tabs-fc-df53f176.js → menu-tabs-fc-eb899b0d.js} +19 -16
  408. package/dist/cjs/menu-tabs-fc-eb899b0d.js.map +1 -0
  409. package/dist/cjs/{modal-828cb80a.js → modal-a49409aa.js} +4 -2
  410. package/dist/cjs/modal-a49409aa.js.map +1 -0
  411. package/dist/cjs/{app-globals-5cfdf2a0.js → setup-86b7d543.js} +20 -5
  412. package/dist/cjs/setup-86b7d543.js.map +1 -0
  413. package/dist/cjs/siemens-ix.cjs.js +4 -3
  414. package/dist/cjs/siemens-ix.cjs.js.map +1 -1
  415. package/dist/cjs/{theme-switcher-2d2bde85.js → theme-switcher-88b70d73.js} +2 -1
  416. package/dist/cjs/theme-switcher-88b70d73.js.map +1 -0
  417. package/dist/cjs/validation-1e3dd5ee.js +117 -0
  418. package/dist/cjs/validation-1e3dd5ee.js.map +1 -0
  419. package/dist/collection/collection-manifest.json +15 -5
  420. package/dist/collection/components/action-card/action-card.js +3 -3
  421. package/dist/collection/components/action-card/action-card.js.map +1 -1
  422. package/dist/collection/components/application/application.js +4 -4
  423. package/dist/collection/components/application-header/application-header.js +3 -3
  424. package/dist/collection/components/application-header/application-switch-modal/application-switch-modal.js +1 -1
  425. package/dist/collection/components/application-sidebar/application-sidebar.js +1 -1
  426. package/dist/collection/components/avatar/avatar.css +1 -1
  427. package/dist/collection/components/avatar/avatar.js +15 -7
  428. package/dist/collection/components/avatar/avatar.js.map +1 -1
  429. package/dist/collection/components/basic-navigation/basic-navigation.js +2 -2
  430. package/dist/collection/components/blind/blind.js +8 -8
  431. package/dist/collection/components/blind/blind.js.map +1 -1
  432. package/dist/collection/components/breadcrumb/breadcrumb.js +9 -10
  433. package/dist/collection/components/breadcrumb/breadcrumb.js.map +1 -1
  434. package/dist/collection/components/breadcrumb/test/breadcrumb.ct.js +2 -1
  435. package/dist/collection/components/breadcrumb/test/breadcrumb.ct.js.map +1 -1
  436. package/dist/collection/components/button/base-button.js +2 -2
  437. package/dist/collection/components/button/base-button.js.map +1 -1
  438. package/dist/collection/components/button/button.js +22 -4
  439. package/dist/collection/components/button/button.js.map +1 -1
  440. package/dist/collection/components/card/card.css +26 -10
  441. package/dist/collection/components/card/card.js +5 -4
  442. package/dist/collection/components/card/card.js.map +1 -1
  443. package/dist/collection/components/card-accordion/card-accordion.js +5 -5
  444. package/dist/collection/components/card-accordion/card-accordion.js.map +1 -1
  445. package/dist/collection/components/card-content/card-content.js +1 -1
  446. package/dist/collection/components/card-list/card-list.css +1 -1
  447. package/dist/collection/components/card-list/card-list.js +12 -9
  448. package/dist/collection/components/card-list/card-list.js.map +1 -1
  449. package/dist/collection/components/card-title/card-title.js +1 -1
  450. package/dist/collection/components/category-filter/category-filter.css +300 -36
  451. package/dist/collection/components/category-filter/category-filter.js +165 -80
  452. package/dist/collection/components/category-filter/category-filter.js.map +1 -1
  453. package/dist/collection/components/category-filter/test/category-filter.ct.js +15 -5
  454. package/dist/collection/components/category-filter/test/category-filter.ct.js.map +1 -1
  455. package/dist/collection/components/checkbox/checkbox.css +423 -0
  456. package/dist/collection/components/checkbox/checkbox.js +326 -0
  457. package/dist/collection/components/checkbox/checkbox.js.map +1 -0
  458. package/dist/collection/components/checkbox/tests/checkbox.ct.js +44 -0
  459. package/dist/collection/components/checkbox/tests/checkbox.ct.js.map +1 -0
  460. package/dist/collection/components/checkbox-group/checkbox-group.css +38 -0
  461. package/dist/collection/components/checkbox-group/checkbox-group.js +213 -0
  462. package/dist/collection/components/checkbox-group/checkbox-group.js.map +1 -0
  463. package/dist/collection/components/chip/chip.js +4 -4
  464. package/dist/collection/components/col/col.js +1 -1
  465. package/dist/collection/components/col/col.js.map +1 -1
  466. package/dist/collection/components/content/content.css +1 -0
  467. package/dist/collection/components/content/content.js +3 -3
  468. package/dist/collection/components/content/content.js.map +1 -1
  469. package/dist/collection/components/content-header/content-header.css +6 -3
  470. package/dist/collection/components/content-header/content-header.js +2 -2
  471. package/dist/collection/components/content-header/content-header.js.map +1 -1
  472. package/dist/collection/components/css-grid/css-grid-item.js +1 -1
  473. package/dist/collection/components/css-grid/css-grid.js +9 -4
  474. package/dist/collection/components/css-grid/css-grid.js.map +1 -1
  475. package/dist/collection/components/custom-field/custom-field.css +15 -0
  476. package/dist/collection/components/custom-field/custom-field.js +216 -0
  477. package/dist/collection/components/custom-field/custom-field.js.map +1 -0
  478. package/dist/collection/components/custom-field/tests/custom-field.ct.js +68 -0
  479. package/dist/collection/components/custom-field/tests/custom-field.ct.js.map +1 -0
  480. package/dist/collection/components/date-dropdown/date-dropdown.css +1 -1
  481. package/dist/collection/components/date-dropdown/date-dropdown.js +76 -20
  482. package/dist/collection/components/date-dropdown/date-dropdown.js.map +1 -1
  483. package/dist/collection/components/date-input/date-input.css +1126 -0
  484. package/dist/collection/components/date-input/date-input.js +743 -0
  485. package/dist/collection/components/date-input/date-input.js.map +1 -0
  486. package/dist/collection/components/date-input/tests/date-input.ct.js +114 -0
  487. package/dist/collection/components/date-input/tests/date-input.ct.js.map +1 -0
  488. package/dist/collection/components/date-picker/date-picker-component.js +2 -0
  489. package/dist/collection/components/date-picker/date-picker-component.js.map +1 -0
  490. package/dist/collection/components/date-picker/date-picker.css +26 -10
  491. package/dist/collection/components/date-picker/date-picker.js +74 -50
  492. package/dist/collection/components/date-picker/date-picker.js.map +1 -1
  493. package/dist/collection/components/date-picker/test/date-picker.ct.js +22 -0
  494. package/dist/collection/components/date-picker/test/date-picker.ct.js.map +1 -1
  495. package/dist/collection/components/date-time-card/date-time-card.css +1 -1
  496. package/dist/collection/components/date-time-card/date-time-card.js +8 -10
  497. package/dist/collection/components/date-time-card/date-time-card.js.map +1 -1
  498. package/dist/collection/components/datetime-picker/datetime-picker.css +23 -11
  499. package/dist/collection/components/datetime-picker/datetime-picker.js +24 -25
  500. package/dist/collection/components/datetime-picker/datetime-picker.js.map +1 -1
  501. package/dist/collection/components/divider/divider.js +1 -1
  502. package/dist/collection/components/drawer/drawer.css +0 -3
  503. package/dist/collection/components/drawer/drawer.js +27 -23
  504. package/dist/collection/components/drawer/drawer.js.map +1 -1
  505. package/dist/collection/components/drawer/test/drawer.spec.js +2 -2
  506. package/dist/collection/components/drawer/test/drawer.spec.js.map +1 -1
  507. package/dist/collection/components/dropdown/dropdown-controller.js +27 -15
  508. package/dist/collection/components/dropdown/dropdown-controller.js.map +1 -1
  509. package/dist/collection/components/dropdown/dropdown.js +105 -82
  510. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  511. package/dist/collection/components/dropdown/test/dropdown.ct.js +19 -8
  512. package/dist/collection/components/dropdown/test/dropdown.ct.js.map +1 -1
  513. package/dist/collection/components/dropdown-button/dropdown-button.js +7 -13
  514. package/dist/collection/components/dropdown-button/dropdown-button.js.map +1 -1
  515. package/dist/collection/components/dropdown-header/dropdown-header.js +1 -1
  516. package/dist/collection/components/dropdown-header/dropdown-header.js.map +1 -1
  517. package/dist/collection/components/dropdown-item/dropdown-item.js +3 -3
  518. package/dist/collection/components/dropdown-quick-actions/dropdown-quick-actions.js +1 -1
  519. package/dist/collection/components/empty-state/empty-state.js +1 -1
  520. package/dist/collection/components/empty-state/empty-state.js.map +1 -1
  521. package/dist/collection/components/event-list/event-list.css +0 -6
  522. package/dist/collection/components/event-list/event-list.js +5 -4
  523. package/dist/collection/components/event-list/event-list.js.map +1 -1
  524. package/dist/collection/components/event-list-item/event-list-item.js +15 -12
  525. package/dist/collection/components/event-list-item/event-list-item.js.map +1 -1
  526. package/dist/collection/components/expanding-search/expanding-search.js +4 -4
  527. package/dist/collection/components/field-label/field-label.css +14 -0
  528. package/dist/collection/components/field-label/field-label.js +230 -0
  529. package/dist/collection/components/field-label/field-label.js.map +1 -0
  530. package/dist/collection/components/field-label/tests/field-label.ct.js +113 -0
  531. package/dist/collection/components/field-label/tests/field-label.ct.js.map +1 -0
  532. package/dist/collection/components/field-wrapper/field-wrapper.css +62 -0
  533. package/dist/collection/components/field-wrapper/field-wrapper.js +317 -0
  534. package/dist/collection/components/field-wrapper/field-wrapper.js.map +1 -0
  535. package/dist/collection/components/field-wrapper/helper-text-util.js +29 -0
  536. package/dist/collection/components/field-wrapper/helper-text-util.js.map +1 -0
  537. package/dist/collection/components/field-wrapper/tests/field-wrapper.ct.js +63 -0
  538. package/dist/collection/components/field-wrapper/tests/field-wrapper.ct.js.map +1 -0
  539. package/dist/collection/components/filter-chip/filter-chip.js +1 -1
  540. package/dist/collection/components/flip-tile/flip-tile.js +4 -4
  541. package/dist/collection/components/flip-tile-content/flip-tile-content.js +1 -1
  542. package/dist/collection/components/group/group-context-menu.js +1 -1
  543. package/dist/collection/components/group/group.js +8 -8
  544. package/dist/collection/components/group-item/group-item.js +2 -2
  545. package/dist/collection/components/helper-text/helper-text.css +34 -0
  546. package/dist/collection/components/helper-text/helper-text.js +179 -0
  547. package/dist/collection/components/helper-text/helper-text.js.map +1 -0
  548. package/dist/collection/components/icon-button/icon-button.css +0 -15
  549. package/dist/collection/components/icon-button/icon-button.js +1 -1
  550. package/dist/collection/components/icon-toggle-button/icon-toggle-button.css +0 -15
  551. package/dist/collection/components/icon-toggle-button/icon-toggle-button.js +1 -2
  552. package/dist/collection/components/icon-toggle-button/icon-toggle-button.js.map +1 -1
  553. package/dist/collection/components/input/input.animation.js +36 -0
  554. package/dist/collection/components/input/input.animation.js.map +1 -0
  555. package/dist/collection/components/input/input.css +1087 -0
  556. package/dist/collection/components/input/input.fc.js +42 -0
  557. package/dist/collection/components/input/input.fc.js.map +1 -0
  558. package/dist/collection/components/input/input.js +608 -0
  559. package/dist/collection/components/input/input.js.map +1 -0
  560. package/dist/collection/components/input/input.util.js +103 -0
  561. package/dist/collection/components/input/input.util.js.map +1 -0
  562. package/dist/collection/components/{form-field/form-field.css → input/number-input.css} +348 -15
  563. package/dist/collection/components/input/number-input.js +606 -0
  564. package/dist/collection/components/input/number-input.js.map +1 -0
  565. package/dist/collection/components/input/tests/form-ready.ct.js +63 -0
  566. package/dist/collection/components/input/tests/form-ready.ct.js.map +1 -0
  567. package/dist/collection/components/input/textarea.css +649 -0
  568. package/dist/collection/components/input/textarea.js +615 -0
  569. package/dist/collection/components/input/textarea.js.map +1 -0
  570. package/dist/collection/components/input-group/input-group.js +1 -1
  571. package/dist/collection/components/key-value/key-value.js +1 -1
  572. package/dist/collection/components/key-value-list/key-value-list.js +1 -1
  573. package/dist/collection/components/kpi/kpi.js +3 -3
  574. package/dist/collection/components/layout-auto/layout-auto.css +16 -0
  575. package/dist/collection/components/layout-auto/layout-auto.js +122 -0
  576. package/dist/collection/components/layout-auto/layout-auto.js.map +1 -0
  577. package/dist/collection/components/{grid → layout-grid}/layout-grid.js +2 -2
  578. package/dist/collection/components/layout-grid/layout-grid.js.map +1 -0
  579. package/dist/collection/components/link-button/link-button.js +3 -3
  580. package/dist/collection/components/map-navigation/map-navigation.js +2 -2
  581. package/dist/collection/components/map-navigation-overlay/map-navigation-overlay.js +2 -2
  582. package/dist/collection/components/menu/menu-expand-icon.js +1 -1
  583. package/dist/collection/components/menu/menu.js +29 -30
  584. package/dist/collection/components/menu/menu.js.map +1 -1
  585. package/dist/collection/components/menu-about/menu-about.js +1 -1
  586. package/dist/collection/components/menu-about/test/menu-about.ct.js +44 -0
  587. package/dist/collection/components/menu-about/test/menu-about.ct.js.map +1 -0
  588. package/dist/collection/components/menu-about-item/menu-about-item.js +1 -1
  589. package/dist/collection/components/menu-about-news/menu-about-news.js +4 -4
  590. package/dist/collection/components/menu-about-news/menu-about-news.js.map +1 -1
  591. package/dist/collection/components/menu-avatar/menu-avatar.js +2 -2
  592. package/dist/collection/components/menu-avatar-item/menu-avatar-item.js +1 -1
  593. package/dist/collection/components/menu-category/menu-category.js +5 -5
  594. package/dist/collection/components/menu-category/menu-category.js.map +1 -1
  595. package/dist/collection/components/menu-item/menu-item.js +7 -6
  596. package/dist/collection/components/menu-item/menu-item.js.map +1 -1
  597. package/dist/collection/components/menu-settings/menu-settings.js +1 -1
  598. package/dist/collection/components/menu-settings-item/menu-settings-item.js +1 -1
  599. package/dist/collection/components/message-bar/message-bar.js +1 -1
  600. package/dist/collection/components/modal/modal.css +1 -1
  601. package/dist/collection/components/modal/modal.js +10 -3
  602. package/dist/collection/components/modal/modal.js.map +1 -1
  603. package/dist/collection/components/modal/test/modal.ct.js +46 -0
  604. package/dist/collection/components/modal/test/modal.ct.js.map +1 -1
  605. package/dist/collection/components/modal-content/modal-content.css +1 -1
  606. package/dist/collection/components/modal-content/modal-content.js +1 -1
  607. package/dist/collection/components/modal-footer/modal-footer.css +0 -1
  608. package/dist/collection/components/modal-footer/modal-footer.js +1 -1
  609. package/dist/collection/components/modal-header/modal-header.css +6 -7
  610. package/dist/collection/components/modal-header/modal-header.js +3 -3
  611. package/dist/collection/components/modal-header/modal-header.js.map +1 -1
  612. package/dist/collection/components/modal-loading/modal-loading.js +1 -1
  613. package/dist/collection/components/pagination/pagination.css +0 -15
  614. package/dist/collection/components/pagination/pagination.js +2 -2
  615. package/dist/collection/components/pagination/pagination.js.map +1 -1
  616. package/dist/collection/components/pane/pane.js +46 -38
  617. package/dist/collection/components/pane/pane.js.map +1 -1
  618. package/dist/collection/components/pane/test/panes.ct.js +24 -0
  619. package/dist/collection/components/pane/test/panes.ct.js.map +1 -1
  620. package/dist/collection/components/pane-layout/pane-layout.js +9 -9
  621. package/dist/collection/components/pane-layout/pane-layout.js.map +1 -1
  622. package/dist/collection/components/pill/pill.js +4 -4
  623. package/dist/collection/components/push-card/push-card.js +1 -1
  624. package/dist/collection/components/radio/radio.css +430 -0
  625. package/dist/collection/components/radio/radio.js +278 -0
  626. package/dist/collection/components/radio/radio.js.map +1 -0
  627. package/dist/collection/components/radio/test/radio.ct.js +36 -0
  628. package/dist/collection/components/radio/test/radio.ct.js.map +1 -0
  629. package/dist/collection/components/radio-group/radio-group.css +38 -0
  630. package/dist/collection/components/radio-group/radio-group.js +326 -0
  631. package/dist/collection/components/radio-group/radio-group.js.map +1 -0
  632. package/dist/collection/components/radio-group/test/radio-group.ct.js +100 -0
  633. package/dist/collection/components/radio-group/test/radio-group.ct.js.map +1 -0
  634. package/dist/collection/components/row/row.js +1 -1
  635. package/dist/collection/components/select/select.css +58 -0
  636. package/dist/collection/components/select/select.js +439 -56
  637. package/dist/collection/components/select/select.js.map +1 -1
  638. package/dist/collection/components/select/test/select.ct.js +59 -9
  639. package/dist/collection/components/select/test/select.ct.js.map +1 -1
  640. package/dist/collection/components/select-item/events.js +8 -0
  641. package/dist/collection/components/select-item/events.js.map +1 -1
  642. package/dist/collection/components/select-item/select-item.js +22 -7
  643. package/dist/collection/components/select-item/select-item.js.map +1 -1
  644. package/dist/collection/components/slider/slider.js +7 -7
  645. package/dist/collection/components/slider/slider.js.map +1 -1
  646. package/dist/collection/components/spinner/spinner.css +140 -125
  647. package/dist/collection/components/spinner/spinner.js +3 -7
  648. package/dist/collection/components/spinner/spinner.js.map +1 -1
  649. package/dist/collection/components/split-button/split-button.js +1 -1
  650. package/dist/collection/components/split-button-item/split-button-item.js +1 -1
  651. package/dist/collection/components/tab-item/tab-item.js +3 -3
  652. package/dist/collection/components/tabs/tabs.js +2 -2
  653. package/dist/collection/components/tile/tile.js +4 -4
  654. package/dist/collection/components/time-picker/time-picker.css +174 -16
  655. package/dist/collection/components/time-picker/time-picker.js +38 -18
  656. package/dist/collection/components/time-picker/time-picker.js.map +1 -1
  657. package/dist/collection/components/toast/toast-container.js +2 -2
  658. package/dist/collection/components/toast/toast.js +2 -2
  659. package/dist/collection/components/toggle/test/toggle.ct.js +24 -1
  660. package/dist/collection/components/toggle/test/toggle.ct.js.map +1 -1
  661. package/dist/collection/components/toggle/toggle.css +133 -4
  662. package/dist/collection/components/toggle/toggle.js +157 -2
  663. package/dist/collection/components/toggle/toggle.js.map +1 -1
  664. package/dist/collection/components/toggle-button/toggle-button.js +2 -2
  665. package/dist/collection/components/tooltip/test/tooltip.ct.js +37 -0
  666. package/dist/collection/components/tooltip/test/tooltip.ct.js.map +1 -1
  667. package/dist/collection/components/tooltip/tooltip.js +11 -13
  668. package/dist/collection/components/tooltip/tooltip.js.map +1 -1
  669. package/dist/collection/components/tree/tree.js +1 -1
  670. package/dist/collection/components/tree-item/tree-item.js +4 -4
  671. package/dist/collection/components/typography/test/ix-typography.spec.js +0 -14
  672. package/dist/collection/components/typography/test/ix-typography.spec.js.map +1 -1
  673. package/dist/collection/components/typography/type-mapping.js +3 -0
  674. package/dist/collection/components/typography/type-mapping.js.map +1 -1
  675. package/dist/collection/components/typography/typography.js +6 -42
  676. package/dist/collection/components/typography/typography.js.map +1 -1
  677. package/dist/collection/components/upload/test/upload.ct.js +17 -0
  678. package/dist/collection/components/upload/test/upload.ct.js.map +1 -0
  679. package/dist/collection/components/upload/upload.css +0 -2
  680. package/dist/collection/components/upload/upload.js +49 -5
  681. package/dist/collection/components/upload/upload.js.map +1 -1
  682. package/dist/collection/components/utils/a11y.js +3 -2
  683. package/dist/collection/components/utils/a11y.js.map +1 -1
  684. package/dist/collection/components/utils/application-layout/context.js.map +1 -1
  685. package/dist/collection/components/utils/attributes.js +25 -0
  686. package/dist/collection/components/utils/attributes.js.map +1 -0
  687. package/dist/collection/components/utils/context.js +5 -2
  688. package/dist/collection/components/utils/context.js.map +1 -1
  689. package/dist/collection/components/utils/disposable-event-listener.js +19 -0
  690. package/dist/collection/components/utils/disposable-event-listener.js.map +1 -0
  691. package/dist/collection/components/utils/element-reference.js +2 -0
  692. package/dist/collection/components/utils/element-reference.js.map +1 -0
  693. package/dist/collection/components/utils/find-element.js +99 -0
  694. package/dist/collection/components/utils/find-element.js.map +1 -0
  695. package/dist/collection/components/utils/focus.js +20 -17
  696. package/dist/collection/components/utils/focus.js.map +1 -1
  697. package/dist/collection/components/utils/input/index.js +9 -0
  698. package/dist/collection/components/utils/input/index.js.map +1 -0
  699. package/dist/collection/components/utils/input/validation.js +108 -0
  700. package/dist/collection/components/utils/input/validation.js.map +1 -0
  701. package/dist/collection/components/utils/listener.js +1 -1
  702. package/dist/collection/components/utils/listener.js.map +1 -1
  703. package/dist/collection/components/utils/make-ref.js +7 -12
  704. package/dist/collection/components/utils/make-ref.js.map +1 -1
  705. package/dist/collection/components/utils/menu-tabs/menu-tabs-fc.js +11 -8
  706. package/dist/collection/components/utils/menu-tabs/menu-tabs-fc.js.map +1 -1
  707. package/dist/collection/components/utils/modal/index.js.map +1 -1
  708. package/dist/collection/components/utils/modal/message.js +3 -1
  709. package/dist/collection/components/utils/modal/message.js.map +1 -1
  710. package/dist/collection/components/utils/theme-switcher.js +1 -0
  711. package/dist/collection/components/utils/theme-switcher.js.map +1 -1
  712. package/dist/collection/components/utils/type-helper.js +2 -0
  713. package/dist/collection/components/utils/type-helper.js.map +1 -0
  714. package/dist/collection/components/utils/uuid.js +16 -0
  715. package/dist/collection/components/utils/uuid.js.map +1 -0
  716. package/dist/collection/components/validation-tooltip/validation-tooltip.js +2 -2
  717. package/dist/collection/components/workflow-step/workflow-step.js +3 -3
  718. package/dist/collection/components/workflow-steps/workflow-steps.js +1 -1
  719. package/dist/collection/index.js +7 -0
  720. package/dist/collection/index.js.map +1 -1
  721. package/dist/collection/setup.js +16 -1
  722. package/dist/collection/setup.js.map +1 -1
  723. package/dist/collection/tests/application/application.e2e.js.map +1 -1
  724. package/dist/collection/tests/checkbox-group/checkbox-group.e2e.js +25 -0
  725. package/dist/collection/tests/checkbox-group/checkbox-group.e2e.js.map +1 -0
  726. package/dist/collection/tests/content/content.e2e.js +24 -0
  727. package/dist/collection/tests/content/content.e2e.js.map +1 -0
  728. package/dist/collection/tests/date-picker/date-picker.e2e.js +6 -6
  729. package/dist/collection/tests/date-picker/date-picker.e2e.js.map +1 -1
  730. package/dist/collection/tests/datetime-picker/datetime-picker.e2e.js +8 -1
  731. package/dist/collection/tests/datetime-picker/datetime-picker.e2e.js.map +1 -1
  732. package/dist/collection/tests/drawer/drawer.e2e.js +6 -0
  733. package/dist/collection/tests/drawer/drawer.e2e.js.map +1 -1
  734. package/dist/collection/tests/form-fields/form-fields.e2e.js +57 -0
  735. package/dist/collection/tests/form-fields/form-fields.e2e.js.map +1 -0
  736. package/dist/collection/tests/input/input.e2e.js +29 -5
  737. package/dist/collection/tests/input/input.e2e.js.map +1 -1
  738. package/dist/collection/tests/message/message.e2e.js +50 -0
  739. package/dist/collection/tests/message/message.e2e.js.map +1 -0
  740. package/dist/collection/tests/modal/modal.e2e.js +10 -1
  741. package/dist/collection/tests/modal/modal.e2e.js.map +1 -1
  742. package/dist/collection/tests/number-input/number-input.e2e.js +17 -0
  743. package/dist/collection/tests/number-input/number-input.e2e.js.map +1 -0
  744. package/dist/collection/tests/radio-group/radio-group.e2e.js +25 -0
  745. package/dist/collection/tests/radio-group/radio-group.e2e.js.map +1 -0
  746. package/dist/collection/tests/slider/slider.e2e.js +17 -0
  747. package/dist/collection/tests/slider/slider.e2e.js.map +1 -1
  748. package/dist/collection/tests/utils/test/index.js +12 -0
  749. package/dist/collection/tests/utils/test/index.js.map +1 -1
  750. package/dist/collection/tests/utils/test/page.js +3 -12
  751. package/dist/collection/tests/utils/test/page.js.map +1 -1
  752. package/dist/esm/{a11y-2e34777f.js → a11y-b10c12e0.js} +4 -3
  753. package/dist/esm/a11y-b10c12e0.js.map +1 -0
  754. package/dist/esm/app-globals-ae0ca705.js +7 -0
  755. package/dist/esm/app-globals-ae0ca705.js.map +1 -0
  756. package/dist/esm/{base-button-1b40b11d.js → base-button-845f2463.js} +4 -4
  757. package/dist/esm/base-button-845f2463.js.map +1 -0
  758. package/dist/esm/{base-icon-button-bc1dabe0.js → base-icon-button-38e2f6e6.js} +3 -3
  759. package/dist/esm/{base-icon-button-bc1dabe0.js.map → base-icon-button-38e2f6e6.js.map} +1 -1
  760. package/dist/esm/{context-82a1ccf8.js → context-42311cff.js} +6 -3
  761. package/dist/esm/context-42311cff.js.map +1 -0
  762. package/dist/esm/disposable-event-listener-ff2cb862.js +18 -0
  763. package/dist/esm/disposable-event-listener-ff2cb862.js.map +1 -0
  764. package/dist/esm/{dropdown-controller-95bd6750.js → dropdown-controller-cb6d3789.js} +29 -13
  765. package/dist/esm/dropdown-controller-cb6d3789.js.map +1 -0
  766. package/dist/esm/find-element-af8265f7.js +102 -0
  767. package/dist/esm/find-element-af8265f7.js.map +1 -0
  768. package/dist/esm/{focus-d4d3abaf.js → focus-664aef4f.js} +22 -18
  769. package/dist/esm/focus-664aef4f.js.map +1 -0
  770. package/dist/esm/helper-text-util-10896253.js +41 -0
  771. package/dist/esm/helper-text-util-10896253.js.map +1 -0
  772. package/dist/esm/{index-76b9c8de.js → index-60d17930.js} +2 -2
  773. package/dist/esm/{index-76b9c8de.js.map → index-60d17930.js.map} +1 -1
  774. package/dist/esm/{index-5429f20b.js → index-97874de0.js} +86 -172
  775. package/dist/esm/index-97874de0.js.map +1 -0
  776. package/dist/esm/index-ad2af369.js +21 -0
  777. package/dist/esm/index-ad2af369.js.map +1 -0
  778. package/dist/esm/index.js +21 -4
  779. package/dist/esm/index.js.map +1 -1
  780. package/dist/esm/input.util-715860e3.js +181 -0
  781. package/dist/esm/input.util-715860e3.js.map +1 -0
  782. package/dist/esm/ix-action-card.entry.js +2 -2
  783. package/dist/esm/ix-action-card.entry.js.map +1 -1
  784. package/dist/esm/ix-application-header.entry.js +7 -7
  785. package/dist/esm/ix-application-sidebar.entry.js +2 -2
  786. package/dist/esm/ix-application-switch-modal.entry.js +3 -3
  787. package/dist/esm/ix-application.entry.js +6 -6
  788. package/dist/esm/ix-avatar_2.entry.js +16 -8
  789. package/dist/esm/ix-avatar_2.entry.js.map +1 -1
  790. package/dist/esm/ix-basic-navigation.entry.js +4 -4
  791. package/dist/esm/ix-blind.entry.js +7 -7
  792. package/dist/esm/ix-blind.entry.js.map +1 -1
  793. package/dist/esm/ix-breadcrumb-item.entry.js +3 -3
  794. package/dist/esm/ix-breadcrumb.entry.js +11 -10
  795. package/dist/esm/ix-breadcrumb.entry.js.map +1 -1
  796. package/dist/esm/ix-button.entry.js +14 -5
  797. package/dist/esm/ix-button.entry.js.map +1 -1
  798. package/dist/esm/ix-card-accordion_2.entry.js +7 -7
  799. package/dist/esm/ix-card-accordion_2.entry.js.map +1 -1
  800. package/dist/esm/ix-card-list.entry.js +11 -8
  801. package/dist/esm/ix-card-list.entry.js.map +1 -1
  802. package/dist/esm/ix-card_2.entry.js +6 -6
  803. package/dist/esm/ix-card_2.entry.js.map +1 -1
  804. package/dist/esm/ix-category-filter.entry.js +154 -82
  805. package/dist/esm/ix-category-filter.entry.js.map +1 -1
  806. package/dist/esm/ix-checkbox-group.entry.js +56 -0
  807. package/dist/esm/ix-checkbox-group.entry.js.map +1 -0
  808. package/dist/esm/ix-checkbox.entry.js +113 -0
  809. package/dist/esm/ix-checkbox.entry.js.map +1 -0
  810. package/dist/esm/ix-chip.entry.js +5 -5
  811. package/dist/esm/ix-col_4.entry.js +71 -45
  812. package/dist/esm/ix-col_4.entry.js.map +1 -1
  813. package/dist/esm/ix-content-header.entry.js +3 -3
  814. package/dist/esm/ix-content-header.entry.js.map +1 -1
  815. package/dist/esm/ix-content.entry.js +5 -5
  816. package/dist/esm/ix-content.entry.js.map +1 -1
  817. package/dist/esm/ix-css-grid-item.entry.js +2 -2
  818. package/dist/esm/ix-css-grid.entry.js +9 -4
  819. package/dist/esm/ix-css-grid.entry.js.map +1 -1
  820. package/dist/esm/ix-custom-field.entry.js +61 -0
  821. package/dist/esm/ix-custom-field.entry.js.map +1 -0
  822. package/dist/esm/ix-date-dropdown.entry.js +28 -16
  823. package/dist/esm/ix-date-dropdown.entry.js.map +1 -1
  824. package/dist/esm/ix-date-input.entry.js +262 -0
  825. package/dist/esm/ix-date-input.entry.js.map +1 -0
  826. package/dist/esm/ix-date-time-card.entry.js +5 -6
  827. package/dist/esm/ix-date-time-card.entry.js.map +1 -1
  828. package/dist/esm/ix-datetime-picker.entry.js +11 -11
  829. package/dist/esm/ix-datetime-picker.entry.js.map +1 -1
  830. package/dist/esm/ix-divider.entry.js +2 -2
  831. package/dist/esm/ix-drawer.entry.js +29 -25
  832. package/dist/esm/ix-drawer.entry.js.map +1 -1
  833. package/dist/esm/ix-dropdown-button.entry.js +5 -6
  834. package/dist/esm/ix-dropdown-button.entry.js.map +1 -1
  835. package/dist/esm/ix-dropdown-header.entry.js +2 -2
  836. package/dist/esm/ix-dropdown-header.entry.js.map +1 -1
  837. package/dist/esm/ix-dropdown-item.entry.js +4 -4
  838. package/dist/esm/ix-dropdown-quick-actions.entry.js +2 -2
  839. package/dist/esm/ix-dropdown.entry.js +70 -66
  840. package/dist/esm/ix-dropdown.entry.js.map +1 -1
  841. package/dist/esm/ix-empty-state.entry.js +2 -2
  842. package/dist/esm/ix-empty-state.entry.js.map +1 -1
  843. package/dist/esm/ix-event-list-item.entry.js +9 -9
  844. package/dist/esm/ix-event-list-item.entry.js.map +1 -1
  845. package/dist/esm/ix-event-list.entry.js +5 -5
  846. package/dist/esm/ix-event-list.entry.js.map +1 -1
  847. package/dist/esm/ix-expanding-search.entry.js +5 -5
  848. package/dist/esm/{ix-tooltip.entry.js → ix-field-label_3.entry.js} +183 -8
  849. package/dist/esm/ix-field-label_3.entry.js.map +1 -0
  850. package/dist/esm/ix-filter-chip_2.entry.js +28 -7
  851. package/dist/esm/ix-filter-chip_2.entry.js.map +1 -1
  852. package/dist/esm/ix-flip-tile-content.entry.js +2 -2
  853. package/dist/esm/ix-flip-tile.entry.js +5 -5
  854. package/dist/esm/ix-group-context-menu_2.entry.js +4 -4
  855. package/dist/esm/ix-group.entry.js +9 -9
  856. package/dist/esm/ix-helper-text.entry.js +66 -0
  857. package/dist/esm/ix-helper-text.entry.js.map +1 -0
  858. package/dist/esm/ix-icon-button_2.entry.js +10 -14
  859. package/dist/esm/ix-icon-button_2.entry.js.map +1 -1
  860. package/dist/esm/ix-icon-toggle-button.entry.js +6 -7
  861. package/dist/esm/ix-icon-toggle-button.entry.js.map +1 -1
  862. package/dist/esm/ix-input-group.entry.js +2 -2
  863. package/dist/esm/ix-input.entry.js +145 -0
  864. package/dist/esm/ix-input.entry.js.map +1 -0
  865. package/dist/esm/ix-key-value-list.entry.js +2 -2
  866. package/dist/esm/ix-key-value.entry.js +2 -2
  867. package/dist/esm/ix-kpi.entry.js +4 -4
  868. package/dist/esm/ix-layout-auto.entry.js +88 -0
  869. package/dist/esm/ix-layout-auto.entry.js.map +1 -0
  870. package/dist/esm/ix-link-button.entry.js +4 -4
  871. package/dist/esm/ix-map-navigation-overlay.entry.js +3 -3
  872. package/dist/esm/ix-map-navigation.entry.js +4 -4
  873. package/dist/esm/ix-menu-about-item.entry.js +2 -2
  874. package/dist/esm/ix-menu-about-news.entry.js +5 -5
  875. package/dist/esm/ix-menu-about-news.entry.js.map +1 -1
  876. package/dist/esm/ix-menu-about.entry.js +3 -3
  877. package/dist/esm/ix-menu-avatar.entry.js +3 -3
  878. package/dist/esm/ix-menu-category.entry.js +7 -7
  879. package/dist/esm/ix-menu-category.entry.js.map +1 -1
  880. package/dist/esm/ix-menu-expand-icon.entry.js +4 -4
  881. package/dist/esm/ix-menu-item.entry.js +9 -8
  882. package/dist/esm/ix-menu-item.entry.js.map +1 -1
  883. package/dist/esm/ix-menu-settings-item.entry.js +2 -2
  884. package/dist/esm/ix-menu-settings.entry.js +2 -2
  885. package/dist/esm/ix-menu.entry.js +33 -33
  886. package/dist/esm/ix-menu.entry.js.map +1 -1
  887. package/dist/esm/ix-message-bar.entry.js +2 -2
  888. package/dist/esm/ix-modal-content_2.entry.js +5 -5
  889. package/dist/esm/ix-modal-content_2.entry.js.map +1 -1
  890. package/dist/esm/ix-modal-footer.entry.js +3 -3
  891. package/dist/esm/ix-modal-footer.entry.js.map +1 -1
  892. package/dist/esm/ix-modal-loading.entry.js +2 -2
  893. package/dist/esm/ix-modal.entry.js +14 -7
  894. package/dist/esm/ix-modal.entry.js.map +1 -1
  895. package/dist/esm/ix-number-input.entry.js +148 -0
  896. package/dist/esm/ix-number-input.entry.js.map +1 -0
  897. package/dist/esm/ix-pagination.entry.js +6 -6
  898. package/dist/esm/ix-pagination.entry.js.map +1 -1
  899. package/dist/esm/ix-pane-layout.entry.js +10 -10
  900. package/dist/esm/ix-pane-layout.entry.js.map +1 -1
  901. package/dist/esm/ix-pane.entry.js +43 -35
  902. package/dist/esm/ix-pane.entry.js.map +1 -1
  903. package/dist/esm/ix-pill.entry.js +5 -5
  904. package/dist/esm/ix-push-card.entry.js +2 -2
  905. package/dist/esm/ix-radio-group.entry.js +116 -0
  906. package/dist/esm/ix-radio-group.entry.js.map +1 -0
  907. package/dist/esm/ix-radio.entry.js +94 -0
  908. package/dist/esm/ix-radio.entry.js.map +1 -0
  909. package/dist/esm/ix-select.entry.js +150 -53
  910. package/dist/esm/ix-select.entry.js.map +1 -1
  911. package/dist/esm/ix-slider.entry.js +10 -10
  912. package/dist/esm/ix-slider.entry.js.map +1 -1
  913. package/dist/esm/ix-split-button-item.entry.js +3 -3
  914. package/dist/esm/ix-split-button.entry.js +2 -2
  915. package/dist/esm/ix-tab-item_2.entry.js +6 -6
  916. package/dist/esm/ix-textarea.entry.js +116 -0
  917. package/dist/esm/ix-textarea.entry.js.map +1 -0
  918. package/dist/esm/ix-tile.entry.js +5 -5
  919. package/dist/esm/ix-time-picker.entry.js +40 -20
  920. package/dist/esm/ix-time-picker.entry.js.map +1 -1
  921. package/dist/esm/ix-toast-container.entry.js +3 -3
  922. package/dist/esm/ix-toast.entry.js +3 -3
  923. package/dist/esm/ix-toggle-button.entry.js +5 -5
  924. package/dist/esm/ix-toggle.entry.js +42 -5
  925. package/dist/esm/ix-toggle.entry.js.map +1 -1
  926. package/dist/esm/ix-tree-item.entry.js +5 -5
  927. package/dist/esm/ix-tree.entry.js +3 -3
  928. package/dist/esm/ix-typography.entry.js +4 -25
  929. package/dist/esm/ix-typography.entry.js.map +1 -1
  930. package/dist/esm/ix-upload.entry.js +60 -6
  931. package/dist/esm/ix-upload.entry.js.map +1 -1
  932. package/dist/esm/ix-validation-tooltip.entry.js +3 -3
  933. package/dist/esm/ix-workflow-step.entry.js +4 -4
  934. package/dist/esm/ix-workflow-steps.entry.js +2 -2
  935. package/dist/esm/{listener-2c562054.js → listener-18b29507.js} +3 -3
  936. package/dist/esm/listener-18b29507.js.map +1 -0
  937. package/dist/esm/loader.js +5 -4
  938. package/dist/esm/loader.js.map +1 -1
  939. package/dist/esm/{make-ref-c80046bf.js → make-ref-4b76e9b5.js} +8 -13
  940. package/dist/esm/make-ref-4b76e9b5.js.map +1 -0
  941. package/dist/esm/{menu-tabs-fc-d9a7dd06.js → menu-tabs-fc-563a74d9.js} +19 -16
  942. package/dist/esm/menu-tabs-fc-563a74d9.js.map +1 -0
  943. package/dist/esm/{modal-54740f80.js → modal-101eef04.js} +4 -2
  944. package/dist/esm/modal-101eef04.js.map +1 -0
  945. package/dist/esm/{app-globals-0cd07cd9.js → setup-d88021f8.js} +19 -5
  946. package/dist/esm/setup-d88021f8.js.map +1 -0
  947. package/dist/esm/siemens-ix.js +5 -4
  948. package/dist/esm/siemens-ix.js.map +1 -1
  949. package/dist/esm/{theme-switcher-b10fb4da.js → theme-switcher-5fcf712d.js} +2 -1
  950. package/dist/esm/theme-switcher-5fcf712d.js.map +1 -0
  951. package/dist/esm/validation-45aa490c.js +112 -0
  952. package/dist/esm/validation-45aa490c.js.map +1 -0
  953. package/dist/siemens-ix/index.esm.js +1 -1
  954. package/dist/siemens-ix/index.esm.js.map +1 -1
  955. package/dist/siemens-ix/{p-928209e1.entry.js → p-044c2a7b.entry.js} +2 -2
  956. package/dist/siemens-ix/p-05839c77.entry.js +2 -0
  957. package/dist/siemens-ix/p-05839c77.entry.js.map +1 -0
  958. package/dist/siemens-ix/p-08463669.entry.js +2 -0
  959. package/dist/siemens-ix/p-08463669.entry.js.map +1 -0
  960. package/dist/siemens-ix/p-0be907d4.entry.js +2 -0
  961. package/dist/siemens-ix/p-0c89cbcc.entry.js +2 -0
  962. package/dist/siemens-ix/p-0c89cbcc.entry.js.map +1 -0
  963. package/dist/siemens-ix/p-0dbc970e.entry.js +2 -0
  964. package/dist/siemens-ix/p-0dbc970e.entry.js.map +1 -0
  965. package/dist/siemens-ix/{p-1da901d5.js → p-0e983f70.js} +2 -2
  966. package/dist/siemens-ix/p-0e983f70.js.map +1 -0
  967. package/dist/siemens-ix/{p-f001ecc1.entry.js → p-0f0e7e14.entry.js} +2 -2
  968. package/dist/siemens-ix/p-0f2bf43d.entry.js +2 -0
  969. package/dist/siemens-ix/p-0f2bf43d.entry.js.map +1 -0
  970. package/dist/siemens-ix/p-10a522ca.js +2 -0
  971. package/dist/siemens-ix/p-10a522ca.js.map +1 -0
  972. package/dist/siemens-ix/{p-cc65617d.entry.js → p-11ce9c6a.entry.js} +2 -2
  973. package/dist/siemens-ix/p-11ce9c6a.entry.js.map +1 -0
  974. package/dist/siemens-ix/p-175599e4.entry.js +2 -0
  975. package/dist/siemens-ix/p-175599e4.entry.js.map +1 -0
  976. package/dist/siemens-ix/p-178ce002.js +2 -0
  977. package/dist/siemens-ix/p-178ce002.js.map +1 -0
  978. package/dist/siemens-ix/p-18097528.entry.js +2 -0
  979. package/dist/siemens-ix/p-18097528.entry.js.map +1 -0
  980. package/dist/siemens-ix/{p-7c2f34f0.entry.js → p-1c5ebea3.entry.js} +2 -2
  981. package/dist/siemens-ix/p-1c5ebea3.entry.js.map +1 -0
  982. package/dist/siemens-ix/p-23a4b81f.js +2 -0
  983. package/dist/siemens-ix/p-23a4b81f.js.map +1 -0
  984. package/dist/siemens-ix/p-24a35b20.entry.js +2 -0
  985. package/dist/siemens-ix/p-24a35b20.entry.js.map +1 -0
  986. package/dist/siemens-ix/p-25465f91.entry.js +2 -0
  987. package/dist/siemens-ix/p-25465f91.entry.js.map +1 -0
  988. package/dist/siemens-ix/p-2643f32a.entry.js +2 -0
  989. package/dist/siemens-ix/p-286feb7e.entry.js +2 -0
  990. package/dist/siemens-ix/p-286feb7e.entry.js.map +1 -0
  991. package/dist/siemens-ix/{p-9079f6c8.entry.js → p-2a34a0c2.entry.js} +2 -2
  992. package/dist/siemens-ix/p-2b226409.entry.js +2 -0
  993. package/dist/siemens-ix/p-2b226409.entry.js.map +1 -0
  994. package/dist/siemens-ix/{p-1bd98772.entry.js → p-2b367b12.entry.js} +2 -2
  995. package/dist/siemens-ix/p-2b9c5f59.entry.js +2 -0
  996. package/dist/siemens-ix/{p-4e547dd3.entry.js → p-2d3a6d29.entry.js} +2 -2
  997. package/dist/siemens-ix/{p-82f9d976.entry.js → p-2d7ea063.entry.js} +2 -2
  998. package/dist/siemens-ix/{p-ae31be0d.entry.js → p-2db63240.entry.js} +2 -2
  999. package/dist/siemens-ix/{p-c81c4b9d.entry.js → p-3205726a.entry.js} +2 -2
  1000. package/dist/siemens-ix/{p-1d581190.js → p-35e14912.js} +2 -2
  1001. package/dist/siemens-ix/p-35e14912.js.map +1 -0
  1002. package/dist/siemens-ix/{p-33a7a26d.entry.js → p-37af7117.entry.js} +2 -2
  1003. package/dist/siemens-ix/{p-e0d03d67.entry.js → p-392b4297.entry.js} +2 -2
  1004. package/dist/siemens-ix/p-3c668c0e.js +2 -0
  1005. package/dist/siemens-ix/p-3c668c0e.js.map +1 -0
  1006. package/dist/siemens-ix/{p-ed7e76a3.entry.js → p-3f367d44.entry.js} +2 -2
  1007. package/dist/siemens-ix/p-3f367d44.entry.js.map +1 -0
  1008. package/dist/siemens-ix/p-40dc610f.entry.js +2 -0
  1009. package/dist/siemens-ix/p-40dc610f.entry.js.map +1 -0
  1010. package/dist/siemens-ix/p-424e8092.entry.js +2 -0
  1011. package/dist/siemens-ix/p-424e8092.entry.js.map +1 -0
  1012. package/dist/siemens-ix/p-429e3749.entry.js +2 -0
  1013. package/dist/siemens-ix/p-429e3749.entry.js.map +1 -0
  1014. package/dist/siemens-ix/{p-c7280736.entry.js → p-4624a772.entry.js} +2 -2
  1015. package/dist/siemens-ix/p-475ac85f.entry.js +2 -0
  1016. package/dist/siemens-ix/p-475ac85f.entry.js.map +1 -0
  1017. package/dist/siemens-ix/{p-1db6be55.js → p-484aa96b.js} +2 -2
  1018. package/dist/{cjs/menu-tabs-fc-df53f176.js.map → siemens-ix/p-484aa96b.js.map} +1 -1
  1019. package/dist/siemens-ix/{p-77273517.entry.js → p-48718dc1.entry.js} +2 -2
  1020. package/dist/siemens-ix/p-48718dc1.entry.js.map +1 -0
  1021. package/dist/siemens-ix/p-4a631d9c.entry.js +2 -0
  1022. package/dist/siemens-ix/p-4a9330a5.entry.js +2 -0
  1023. package/dist/siemens-ix/p-4a9330a5.entry.js.map +1 -0
  1024. package/dist/siemens-ix/{p-05dc6b2d.entry.js → p-4c9b7548.entry.js} +2 -2
  1025. package/dist/siemens-ix/p-4cc79e8f.entry.js +2 -0
  1026. package/dist/siemens-ix/{p-d300b332.entry.js → p-4e51d716.entry.js} +2 -2
  1027. package/dist/siemens-ix/{p-0ef97555.entry.js → p-4ec6ddfb.entry.js} +2 -2
  1028. package/dist/siemens-ix/p-50096707.js +2 -0
  1029. package/dist/siemens-ix/p-50096707.js.map +1 -0
  1030. package/dist/siemens-ix/p-52928e21.entry.js +2 -0
  1031. package/dist/siemens-ix/p-52928e21.entry.js.map +1 -0
  1032. package/dist/siemens-ix/p-54efe56b.entry.js +2 -0
  1033. package/dist/siemens-ix/p-54efe56b.entry.js.map +1 -0
  1034. package/dist/siemens-ix/p-5682e985.js +2 -0
  1035. package/dist/siemens-ix/{p-5af99eaa.entry.js → p-57e60a06.entry.js} +2 -2
  1036. package/dist/siemens-ix/p-5806df2b.js +3 -0
  1037. package/dist/siemens-ix/p-5806df2b.js.map +1 -0
  1038. package/dist/siemens-ix/{p-1483f65d.entry.js → p-5c1b136c.entry.js} +2 -2
  1039. package/dist/siemens-ix/p-5c1b136c.entry.js.map +1 -0
  1040. package/dist/siemens-ix/p-5db5a0b5.entry.js +2 -0
  1041. package/dist/siemens-ix/p-5db5a0b5.entry.js.map +1 -0
  1042. package/dist/siemens-ix/p-5fe87e71.js +2 -0
  1043. package/dist/siemens-ix/p-5fe87e71.js.map +1 -0
  1044. package/dist/siemens-ix/{p-0632731e.entry.js → p-63dd987f.entry.js} +2 -2
  1045. package/dist/siemens-ix/{p-f06b21f9.entry.js → p-654f91f2.entry.js} +2 -2
  1046. package/dist/siemens-ix/p-66178fe6.entry.js +2 -0
  1047. package/dist/siemens-ix/p-66178fe6.entry.js.map +1 -0
  1048. package/dist/siemens-ix/{p-67f44540.entry.js → p-6624076c.entry.js} +2 -2
  1049. package/dist/siemens-ix/p-6624076c.entry.js.map +1 -0
  1050. package/dist/siemens-ix/p-66559451.entry.js +2 -0
  1051. package/dist/siemens-ix/{p-86fd5922.entry.js → p-6722bcff.entry.js} +2 -2
  1052. package/dist/siemens-ix/{p-b4ce366d.entry.js → p-68bb2a09.entry.js} +2 -2
  1053. package/dist/siemens-ix/p-68bb2a09.entry.js.map +1 -0
  1054. package/dist/siemens-ix/{p-5351225b.entry.js → p-6a4a2064.entry.js} +2 -2
  1055. package/dist/siemens-ix/p-6a4a2064.entry.js.map +1 -0
  1056. package/dist/siemens-ix/{p-b804b8c5.entry.js → p-6bae4e9b.entry.js} +2 -2
  1057. package/dist/siemens-ix/p-6bf208b8.js +2 -0
  1058. package/dist/siemens-ix/{p-3dc1294b.entry.js → p-6e3f1de3.entry.js} +2 -2
  1059. package/dist/siemens-ix/p-6e3f1de3.entry.js.map +1 -0
  1060. package/dist/siemens-ix/{p-90440046.entry.js → p-76b57ff0.entry.js} +2 -2
  1061. package/dist/siemens-ix/p-76b57ff0.entry.js.map +1 -0
  1062. package/dist/siemens-ix/p-792e1c52.entry.js +2 -0
  1063. package/dist/siemens-ix/p-792e1c52.entry.js.map +1 -0
  1064. package/dist/siemens-ix/p-79bb0d39.js +2 -0
  1065. package/dist/siemens-ix/p-79bb0d39.js.map +1 -0
  1066. package/dist/siemens-ix/p-7aa07d9b.entry.js +2 -0
  1067. package/dist/siemens-ix/p-7aa07d9b.entry.js.map +1 -0
  1068. package/dist/siemens-ix/p-7aa26727.js +2 -0
  1069. package/dist/siemens-ix/p-7aa26727.js.map +1 -0
  1070. package/dist/siemens-ix/p-7af324e9.entry.js +2 -0
  1071. package/dist/siemens-ix/p-7af324e9.entry.js.map +1 -0
  1072. package/dist/siemens-ix/p-815699d1.entry.js +2 -0
  1073. package/dist/siemens-ix/p-815699d1.entry.js.map +1 -0
  1074. package/dist/siemens-ix/p-83da8f11.entry.js +2 -0
  1075. package/dist/siemens-ix/p-83da8f11.entry.js.map +1 -0
  1076. package/dist/siemens-ix/{p-958c5970.entry.js → p-8457d846.entry.js} +2 -2
  1077. package/dist/siemens-ix/p-8564bc5f.entry.js +2 -0
  1078. package/dist/siemens-ix/p-8564bc5f.entry.js.map +1 -0
  1079. package/dist/siemens-ix/p-857f99c8.entry.js +2 -0
  1080. package/dist/siemens-ix/p-857f99c8.entry.js.map +1 -0
  1081. package/dist/siemens-ix/{p-c7e58e9e.entry.js → p-8c2b62c3.entry.js} +2 -2
  1082. package/dist/siemens-ix/{p-c62966f8.entry.js → p-8da941cd.entry.js} +2 -2
  1083. package/dist/siemens-ix/{p-6618b2db.entry.js → p-8f616a5c.entry.js} +2 -2
  1084. package/dist/siemens-ix/p-91046d49.entry.js +2 -0
  1085. package/dist/siemens-ix/p-91046d49.entry.js.map +1 -0
  1086. package/dist/siemens-ix/{p-e14384df.entry.js → p-9948574f.entry.js} +2 -2
  1087. package/dist/siemens-ix/{p-085d5ec2.entry.js → p-9d323232.entry.js} +2 -2
  1088. package/dist/siemens-ix/p-9d5d4948.js +2 -0
  1089. package/dist/siemens-ix/p-9d5d4948.js.map +1 -0
  1090. package/dist/siemens-ix/p-9fe2759f.entry.js +2 -0
  1091. package/dist/siemens-ix/p-9fe2759f.entry.js.map +1 -0
  1092. package/dist/siemens-ix/{p-17a8aab2.entry.js → p-a3364116.entry.js} +2 -2
  1093. package/dist/siemens-ix/p-a36ad7c7.entry.js +2 -0
  1094. package/dist/siemens-ix/p-a36ad7c7.entry.js.map +1 -0
  1095. package/dist/siemens-ix/p-a427e6a2.js +2 -0
  1096. package/dist/siemens-ix/p-a427e6a2.js.map +1 -0
  1097. package/dist/siemens-ix/p-a61ed462.entry.js +2 -0
  1098. package/dist/siemens-ix/{p-8acc09aa.entry.js → p-b2a06e46.entry.js} +2 -2
  1099. package/dist/siemens-ix/p-b5c887e5.entry.js +2 -0
  1100. package/dist/siemens-ix/p-b5c887e5.entry.js.map +1 -0
  1101. package/dist/siemens-ix/p-b62f8f62.entry.js +2 -0
  1102. package/dist/siemens-ix/p-b62f8f62.entry.js.map +1 -0
  1103. package/dist/siemens-ix/{p-5aa0b93c.entry.js → p-b74a8cdc.entry.js} +2 -2
  1104. package/dist/siemens-ix/{p-ba24e694.entry.js → p-bd4c1a44.entry.js} +2 -2
  1105. package/dist/siemens-ix/p-bd4c1a44.entry.js.map +1 -0
  1106. package/dist/siemens-ix/{p-89e48bea.entry.js → p-bded112a.entry.js} +2 -2
  1107. package/dist/siemens-ix/{p-e95a5a97.entry.js → p-be860121.entry.js} +2 -2
  1108. package/dist/siemens-ix/p-c236cf18.entry.js +2 -0
  1109. package/dist/siemens-ix/p-c6796e64.entry.js +2 -0
  1110. package/dist/siemens-ix/p-caf49e00.entry.js +2 -0
  1111. package/dist/siemens-ix/p-caf49e00.entry.js.map +1 -0
  1112. package/dist/siemens-ix/p-cbfca958.entry.js +2 -0
  1113. package/dist/siemens-ix/p-ce563a48.js +2 -0
  1114. package/dist/siemens-ix/p-ce563a48.js.map +1 -0
  1115. package/dist/siemens-ix/p-d01f05cf.entry.js +2 -0
  1116. package/dist/siemens-ix/p-d01f05cf.entry.js.map +1 -0
  1117. package/dist/siemens-ix/{p-a8d291fa.entry.js → p-d0b38ae2.entry.js} +2 -2
  1118. package/dist/siemens-ix/p-d0b38ae2.entry.js.map +1 -0
  1119. package/dist/siemens-ix/p-d19b52bd.entry.js +2 -0
  1120. package/dist/siemens-ix/p-d19b52bd.entry.js.map +1 -0
  1121. package/dist/siemens-ix/p-d7aa00d6.js +2 -0
  1122. package/dist/siemens-ix/p-d7aa00d6.js.map +1 -0
  1123. package/dist/siemens-ix/{p-b663ca16.entry.js → p-d929f23d.entry.js} +2 -2
  1124. package/dist/siemens-ix/{p-e35805d0.entry.js → p-d95a6f49.entry.js} +2 -2
  1125. package/dist/siemens-ix/{p-e35805d0.entry.js.map → p-d95a6f49.entry.js.map} +1 -1
  1126. package/dist/siemens-ix/{p-37229f30.entry.js → p-dc2d5730.entry.js} +2 -2
  1127. package/dist/siemens-ix/p-dc2d5730.entry.js.map +1 -0
  1128. package/dist/siemens-ix/{p-7402f42a.entry.js → p-df7060ae.entry.js} +2 -2
  1129. package/dist/siemens-ix/p-df7060ae.entry.js.map +1 -0
  1130. package/dist/siemens-ix/{p-44a27b29.entry.js → p-dfb181c1.entry.js} +2 -2
  1131. package/dist/siemens-ix/p-dfb181c1.entry.js.map +1 -0
  1132. package/dist/siemens-ix/{p-0fafba48.entry.js → p-e7ac5657.entry.js} +2 -2
  1133. package/dist/siemens-ix/{p-ee96d1eb.entry.js → p-e9a37b3f.entry.js} +2 -2
  1134. package/dist/siemens-ix/{p-24a8737a.entry.js → p-edc1d44a.entry.js} +2 -2
  1135. package/dist/siemens-ix/{p-c072ddb5.entry.js → p-ede52531.entry.js} +2 -2
  1136. package/dist/siemens-ix/p-ede52531.entry.js.map +1 -0
  1137. package/dist/siemens-ix/p-f35386ec.js +2 -0
  1138. package/dist/siemens-ix/p-f35386ec.js.map +1 -0
  1139. package/dist/siemens-ix/p-f39048a2.entry.js +2 -0
  1140. package/dist/siemens-ix/p-f39048a2.entry.js.map +1 -0
  1141. package/dist/siemens-ix/p-f7618d1d.entry.js +2 -0
  1142. package/dist/siemens-ix/p-f7618d1d.entry.js.map +1 -0
  1143. package/dist/siemens-ix/p-f97a15c4.js +2 -0
  1144. package/dist/siemens-ix/p-f97a15c4.js.map +1 -0
  1145. package/dist/siemens-ix/p-fad9f568.js +2 -0
  1146. package/dist/siemens-ix/p-fad9f568.js.map +1 -0
  1147. package/dist/siemens-ix/p-ffca56d6.entry.js +2 -0
  1148. package/dist/siemens-ix/siemens-ix-core.css +1 -1
  1149. package/dist/siemens-ix/siemens-ix.css +172 -27
  1150. package/dist/siemens-ix/siemens-ix.esm.js +1 -1
  1151. package/dist/siemens-ix/siemens-ix.esm.js.map +1 -1
  1152. package/dist/siemens-ix/theme/classic-dark.css +1 -1
  1153. package/dist/siemens-ix/theme/classic-light.css +1 -1
  1154. package/dist/siemens-ix/theme/legacy-classic-dark.css +1 -1
  1155. package/dist/siemens-ix/theme/legacy-classic-light.css +1 -1
  1156. package/dist/types/components/action-card/action-card.d.ts +2 -2
  1157. package/dist/types/components/avatar/avatar.d.ts +6 -6
  1158. package/dist/types/components/blind/blind.d.ts +4 -4
  1159. package/dist/types/components/breadcrumb/breadcrumb.d.ts +3 -3
  1160. package/dist/types/components/button/base-button.d.ts +3 -2
  1161. package/dist/types/components/button/button.d.ts +3 -2
  1162. package/dist/types/components/card-list/card-list.d.ts +3 -3
  1163. package/dist/types/components/category-filter/category-filter.d.ts +22 -3
  1164. package/dist/types/components/checkbox/checkbox.d.ts +61 -0
  1165. package/dist/types/components/checkbox/tests/checkbox.ct.d.ts +1 -0
  1166. package/dist/types/components/checkbox-group/checkbox-group.d.ts +47 -0
  1167. package/dist/types/components/content-header/content-header.d.ts +1 -1
  1168. package/dist/types/components/css-grid/css-grid.d.ts +2 -2
  1169. package/dist/types/components/custom-field/custom-field.d.ts +46 -0
  1170. package/dist/types/components/custom-field/tests/custom-field.ct.d.ts +1 -0
  1171. package/dist/types/components/date-dropdown/date-dropdown.d.ts +18 -4
  1172. package/dist/types/components/date-input/date-input.d.ts +138 -0
  1173. package/dist/types/components/date-input/tests/date-input.ct.d.ts +1 -0
  1174. package/dist/types/components/date-picker/date-picker-component.d.ts +43 -0
  1175. package/dist/types/components/date-picker/date-picker.d.ts +9 -11
  1176. package/dist/types/components/date-time-card/date-time-card.d.ts +1 -1
  1177. package/dist/types/components/datetime-picker/datetime-picker.d.ts +13 -12
  1178. package/dist/types/components/dropdown/dropdown-controller.d.ts +3 -7
  1179. package/dist/types/components/dropdown/dropdown.d.ts +13 -12
  1180. package/dist/types/components/dropdown-button/dropdown-button.d.ts +4 -4
  1181. package/dist/types/components/event-list-item/event-list-item.d.ts +2 -2
  1182. package/dist/types/components/field-label/field-label.d.ts +33 -0
  1183. package/dist/types/components/field-label/tests/field-label.ct.d.ts +1 -0
  1184. package/dist/types/components/field-wrapper/field-wrapper.d.ts +64 -0
  1185. package/dist/types/components/field-wrapper/helper-text-util.d.ts +18 -0
  1186. package/dist/types/components/field-wrapper/tests/field-wrapper.ct.d.ts +1 -0
  1187. package/dist/types/components/helper-text/helper-text.d.ts +37 -0
  1188. package/dist/types/components/input/input.animation.d.ts +1 -0
  1189. package/dist/types/components/input/input.d.ts +123 -0
  1190. package/dist/types/components/input/input.fc.d.ts +52 -0
  1191. package/dist/types/components/input/input.util.d.ts +13 -0
  1192. package/dist/types/components/input/number-input.d.ts +121 -0
  1193. package/dist/types/components/input/tests/form-ready.ct.d.ts +1 -0
  1194. package/dist/types/components/input/textarea.d.ts +126 -0
  1195. package/dist/types/components/layout-auto/layout-auto.d.ts +24 -0
  1196. package/dist/types/components/menu/menu.d.ts +3 -7
  1197. package/dist/types/components/menu-about/test/menu-about.ct.d.ts +1 -0
  1198. package/dist/types/components/menu-item/menu-item.d.ts +3 -3
  1199. package/dist/types/components/modal/test/modal.ct.d.ts +3 -2
  1200. package/dist/types/components/modal-header/modal-header.d.ts +3 -3
  1201. package/dist/types/components/pane/pane.d.ts +9 -9
  1202. package/dist/types/components/pane-layout/pane-layout.d.ts +1 -1
  1203. package/dist/types/components/radio/radio.d.ts +53 -0
  1204. package/dist/types/components/radio/test/radio.ct.d.ts +1 -0
  1205. package/dist/types/components/radio-group/radio-group.d.ts +64 -0
  1206. package/dist/types/components/radio-group/test/radio-group.ct.d.ts +1 -0
  1207. package/dist/types/components/select/select.d.ts +97 -14
  1208. package/dist/types/components/select-item/events.d.ts +9 -0
  1209. package/dist/types/components/select-item/select-item.d.ts +3 -1
  1210. package/dist/types/components/time-picker/time-picker.d.ts +3 -3
  1211. package/dist/types/components/toggle/toggle.d.ts +29 -1
  1212. package/dist/types/components/tooltip/tooltip.d.ts +2 -1
  1213. package/dist/types/components/typography/type-mapping.d.ts +3 -0
  1214. package/dist/types/components/typography/typography.d.ts +3 -10
  1215. package/dist/types/components/upload/test/upload.ct.d.ts +1 -0
  1216. package/dist/types/components/upload/upload.d.ts +4 -2
  1217. package/dist/types/components/utils/a11y.d.ts +5 -5
  1218. package/dist/types/components/utils/application-layout/context.d.ts +2 -1
  1219. package/dist/types/components/utils/attributes.d.ts +2 -0
  1220. package/dist/types/components/utils/disposable-event-listener.d.ts +7 -0
  1221. package/dist/types/components/utils/element-reference.d.ts +1 -0
  1222. package/dist/types/components/utils/find-element.d.ts +22 -0
  1223. package/dist/types/components/utils/focus.d.ts +5 -4
  1224. package/dist/types/components/utils/input/index.d.ts +61 -0
  1225. package/dist/types/components/utils/input/validation.d.ts +15 -0
  1226. package/dist/types/components/utils/listener.d.ts +4 -2
  1227. package/dist/types/components/utils/make-ref.d.ts +2 -2
  1228. package/dist/types/components/utils/modal/index.d.ts +1 -1
  1229. package/dist/types/components/utils/modal/message.d.ts +10 -7
  1230. package/dist/types/components/utils/theme-switcher.d.ts +3 -2
  1231. package/dist/types/components/utils/type-helper.d.ts +1 -0
  1232. package/dist/types/components/utils/uuid.d.ts +1 -0
  1233. package/dist/types/components.d.ts +1965 -213
  1234. package/dist/types/index.d.ts +3 -0
  1235. package/dist/types/setup.d.ts +7 -1
  1236. package/dist/types/tests/utils/test/index.d.ts +3 -0
  1237. package/dist/types/tests/utils/test/page.d.ts +1 -3
  1238. package/hydrate/index.js +3563 -1101
  1239. package/package.json +13 -13
  1240. package/scss/components/_checkboxes.scss +4 -11
  1241. package/scss/components/form/_input.scss +84 -9
  1242. package/scss/mixins/_field.scss +18 -0
  1243. package/scss/mixins/validation/_form-component.scss +64 -0
  1244. package/components/ix-form-field.js +0 -44
  1245. package/components/ix-form-field.js.map +0 -1
  1246. package/components/ix-modal-example.js +0 -58
  1247. package/components/ix-modal-example.js.map +0 -1
  1248. package/components/ix-playground-internal.js +0 -35
  1249. package/components/ix-playground-internal.js.map +0 -1
  1250. package/dist/cjs/a11y-eba397e8.js.map +0 -1
  1251. package/dist/cjs/app-globals-5cfdf2a0.js.map +0 -1
  1252. package/dist/cjs/base-button-3735b8c2.js.map +0 -1
  1253. package/dist/cjs/context-938f7470.js.map +0 -1
  1254. package/dist/cjs/dropdown-controller-5ef3d018.js.map +0 -1
  1255. package/dist/cjs/focus-9c8ffbb0.js.map +0 -1
  1256. package/dist/cjs/index-529f21c1.js.map +0 -1
  1257. package/dist/cjs/ix-form-field.cjs.entry.js +0 -28
  1258. package/dist/cjs/ix-form-field.cjs.entry.js.map +0 -1
  1259. package/dist/cjs/ix-modal-example.cjs.entry.js +0 -28
  1260. package/dist/cjs/ix-modal-example.cjs.entry.js.map +0 -1
  1261. package/dist/cjs/ix-playground-internal.cjs.entry.js +0 -22
  1262. package/dist/cjs/ix-playground-internal.cjs.entry.js.map +0 -1
  1263. package/dist/cjs/ix-tooltip.cjs.entry.js.map +0 -1
  1264. package/dist/cjs/listener-a124ed49.js.map +0 -1
  1265. package/dist/cjs/make-ref-c25629b7.js.map +0 -1
  1266. package/dist/cjs/modal-828cb80a.js.map +0 -1
  1267. package/dist/cjs/theme-switcher-2d2bde85.js.map +0 -1
  1268. package/dist/collection/components/event-list/test/event-list.spec.js +0 -65
  1269. package/dist/collection/components/event-list/test/event-list.spec.js.map +0 -1
  1270. package/dist/collection/components/form-field/form-field.js +0 -56
  1271. package/dist/collection/components/form-field/form-field.js.map +0 -1
  1272. package/dist/collection/components/grid/layout-grid.js.map +0 -1
  1273. package/dist/collection/components/playground/example-modal.js +0 -24
  1274. package/dist/collection/components/playground/example-modal.js.map +0 -1
  1275. package/dist/collection/components/playground/playground.css +0 -27
  1276. package/dist/collection/components/playground/playground.js +0 -28
  1277. package/dist/collection/components/playground/playground.js.map +0 -1
  1278. package/dist/esm/a11y-2e34777f.js.map +0 -1
  1279. package/dist/esm/app-globals-0cd07cd9.js.map +0 -1
  1280. package/dist/esm/base-button-1b40b11d.js.map +0 -1
  1281. package/dist/esm/context-82a1ccf8.js.map +0 -1
  1282. package/dist/esm/dropdown-controller-95bd6750.js.map +0 -1
  1283. package/dist/esm/focus-d4d3abaf.js.map +0 -1
  1284. package/dist/esm/index-5429f20b.js.map +0 -1
  1285. package/dist/esm/ix-form-field.entry.js +0 -24
  1286. package/dist/esm/ix-form-field.entry.js.map +0 -1
  1287. package/dist/esm/ix-modal-example.entry.js +0 -24
  1288. package/dist/esm/ix-modal-example.entry.js.map +0 -1
  1289. package/dist/esm/ix-playground-internal.entry.js +0 -18
  1290. package/dist/esm/ix-playground-internal.entry.js.map +0 -1
  1291. package/dist/esm/ix-tooltip.entry.js.map +0 -1
  1292. package/dist/esm/listener-2c562054.js.map +0 -1
  1293. package/dist/esm/make-ref-c80046bf.js.map +0 -1
  1294. package/dist/esm/menu-tabs-fc-d9a7dd06.js.map +0 -1
  1295. package/dist/esm/modal-54740f80.js.map +0 -1
  1296. package/dist/esm/theme-switcher-b10fb4da.js.map +0 -1
  1297. package/dist/siemens-ix/p-04af3853.entry.js +0 -2
  1298. package/dist/siemens-ix/p-04ec538b.entry.js +0 -2
  1299. package/dist/siemens-ix/p-04ec538b.entry.js.map +0 -1
  1300. package/dist/siemens-ix/p-091b036d.entry.js +0 -2
  1301. package/dist/siemens-ix/p-0ca3528f.js +0 -2
  1302. package/dist/siemens-ix/p-1483f65d.entry.js.map +0 -1
  1303. package/dist/siemens-ix/p-157b1b28.js +0 -2
  1304. package/dist/siemens-ix/p-157b1b28.js.map +0 -1
  1305. package/dist/siemens-ix/p-15f44099.entry.js +0 -2
  1306. package/dist/siemens-ix/p-15f44099.entry.js.map +0 -1
  1307. package/dist/siemens-ix/p-1c3a0b1f.js +0 -2
  1308. package/dist/siemens-ix/p-1c3a0b1f.js.map +0 -1
  1309. package/dist/siemens-ix/p-1d581190.js.map +0 -1
  1310. package/dist/siemens-ix/p-1da901d5.js.map +0 -1
  1311. package/dist/siemens-ix/p-1db6be55.js.map +0 -1
  1312. package/dist/siemens-ix/p-235c14ca.js +0 -2
  1313. package/dist/siemens-ix/p-235c14ca.js.map +0 -1
  1314. package/dist/siemens-ix/p-25f1749c.entry.js +0 -2
  1315. package/dist/siemens-ix/p-25f1749c.entry.js.map +0 -1
  1316. package/dist/siemens-ix/p-2ebfd4fd.entry.js +0 -2
  1317. package/dist/siemens-ix/p-2ebfd4fd.entry.js.map +0 -1
  1318. package/dist/siemens-ix/p-306269ae.entry.js +0 -2
  1319. package/dist/siemens-ix/p-306269ae.entry.js.map +0 -1
  1320. package/dist/siemens-ix/p-32d4ed3b.entry.js +0 -2
  1321. package/dist/siemens-ix/p-35fff1e6.entry.js +0 -2
  1322. package/dist/siemens-ix/p-37229f30.entry.js.map +0 -1
  1323. package/dist/siemens-ix/p-3dc1294b.entry.js.map +0 -1
  1324. package/dist/siemens-ix/p-3f59a3c3.entry.js +0 -2
  1325. package/dist/siemens-ix/p-3f59a3c3.entry.js.map +0 -1
  1326. package/dist/siemens-ix/p-411f51c5.entry.js +0 -2
  1327. package/dist/siemens-ix/p-411f51c5.entry.js.map +0 -1
  1328. package/dist/siemens-ix/p-44a27b29.entry.js.map +0 -1
  1329. package/dist/siemens-ix/p-49d3fc15.entry.js +0 -2
  1330. package/dist/siemens-ix/p-49d3fc15.entry.js.map +0 -1
  1331. package/dist/siemens-ix/p-5099c070.entry.js +0 -2
  1332. package/dist/siemens-ix/p-5099c070.entry.js.map +0 -1
  1333. package/dist/siemens-ix/p-5351225b.entry.js.map +0 -1
  1334. package/dist/siemens-ix/p-5c673ae9.entry.js +0 -2
  1335. package/dist/siemens-ix/p-5c673ae9.entry.js.map +0 -1
  1336. package/dist/siemens-ix/p-62b089b6.entry.js +0 -2
  1337. package/dist/siemens-ix/p-62b089b6.entry.js.map +0 -1
  1338. package/dist/siemens-ix/p-63f0755e.entry.js +0 -2
  1339. package/dist/siemens-ix/p-64c3fa3d.js +0 -2
  1340. package/dist/siemens-ix/p-64c3fa3d.js.map +0 -1
  1341. package/dist/siemens-ix/p-67f44540.entry.js.map +0 -1
  1342. package/dist/siemens-ix/p-68532fa2.js +0 -2
  1343. package/dist/siemens-ix/p-6e4c9e3d.entry.js +0 -2
  1344. package/dist/siemens-ix/p-6e4c9e3d.entry.js.map +0 -1
  1345. package/dist/siemens-ix/p-6e6efb4c.js +0 -2
  1346. package/dist/siemens-ix/p-6e6efb4c.js.map +0 -1
  1347. package/dist/siemens-ix/p-713828ed.entry.js +0 -2
  1348. package/dist/siemens-ix/p-713828ed.entry.js.map +0 -1
  1349. package/dist/siemens-ix/p-7402f42a.entry.js.map +0 -1
  1350. package/dist/siemens-ix/p-77273517.entry.js.map +0 -1
  1351. package/dist/siemens-ix/p-78ac2ff1.entry.js +0 -2
  1352. package/dist/siemens-ix/p-7947ef3d.entry.js +0 -2
  1353. package/dist/siemens-ix/p-7c2f34f0.entry.js.map +0 -1
  1354. package/dist/siemens-ix/p-82d33168.entry.js +0 -2
  1355. package/dist/siemens-ix/p-86bbc005.entry.js +0 -2
  1356. package/dist/siemens-ix/p-86bbc005.entry.js.map +0 -1
  1357. package/dist/siemens-ix/p-90440046.entry.js.map +0 -1
  1358. package/dist/siemens-ix/p-9bdda7ff.entry.js +0 -2
  1359. package/dist/siemens-ix/p-a0138163.entry.js +0 -2
  1360. package/dist/siemens-ix/p-a0138163.entry.js.map +0 -1
  1361. package/dist/siemens-ix/p-a08efce0.entry.js +0 -2
  1362. package/dist/siemens-ix/p-a08efce0.entry.js.map +0 -1
  1363. package/dist/siemens-ix/p-a4755205.entry.js +0 -2
  1364. package/dist/siemens-ix/p-a8d291fa.entry.js.map +0 -1
  1365. package/dist/siemens-ix/p-aa814811.entry.js +0 -2
  1366. package/dist/siemens-ix/p-aa814811.entry.js.map +0 -1
  1367. package/dist/siemens-ix/p-accec846.js +0 -2
  1368. package/dist/siemens-ix/p-accec846.js.map +0 -1
  1369. package/dist/siemens-ix/p-adee6045.entry.js +0 -2
  1370. package/dist/siemens-ix/p-adee6045.entry.js.map +0 -1
  1371. package/dist/siemens-ix/p-b4ce366d.entry.js.map +0 -1
  1372. package/dist/siemens-ix/p-ba24e694.entry.js.map +0 -1
  1373. package/dist/siemens-ix/p-bf14c60b.entry.js +0 -2
  1374. package/dist/siemens-ix/p-bf14c60b.entry.js.map +0 -1
  1375. package/dist/siemens-ix/p-c022d6cc.entry.js +0 -2
  1376. package/dist/siemens-ix/p-c022d6cc.entry.js.map +0 -1
  1377. package/dist/siemens-ix/p-c05a98c8.entry.js +0 -2
  1378. package/dist/siemens-ix/p-c072ddb5.entry.js.map +0 -1
  1379. package/dist/siemens-ix/p-c09553f3.js +0 -2
  1380. package/dist/siemens-ix/p-c09553f3.js.map +0 -1
  1381. package/dist/siemens-ix/p-c1fe9f3d.entry.js +0 -2
  1382. package/dist/siemens-ix/p-c1fe9f3d.entry.js.map +0 -1
  1383. package/dist/siemens-ix/p-c33cee36.entry.js +0 -2
  1384. package/dist/siemens-ix/p-c33cee36.entry.js.map +0 -1
  1385. package/dist/siemens-ix/p-cc65617d.entry.js.map +0 -1
  1386. package/dist/siemens-ix/p-d14024d3.entry.js +0 -2
  1387. package/dist/siemens-ix/p-d14024d3.entry.js.map +0 -1
  1388. package/dist/siemens-ix/p-d1f49940.entry.js +0 -2
  1389. package/dist/siemens-ix/p-d1f49940.entry.js.map +0 -1
  1390. package/dist/siemens-ix/p-d6fc0727.entry.js +0 -2
  1391. package/dist/siemens-ix/p-d6fc0727.entry.js.map +0 -1
  1392. package/dist/siemens-ix/p-df370362.entry.js +0 -2
  1393. package/dist/siemens-ix/p-df370362.entry.js.map +0 -1
  1394. package/dist/siemens-ix/p-e948bcb0.js +0 -2
  1395. package/dist/siemens-ix/p-e948bcb0.js.map +0 -1
  1396. package/dist/siemens-ix/p-ed7e76a3.entry.js.map +0 -1
  1397. package/dist/siemens-ix/p-f87cd962.js +0 -3
  1398. package/dist/siemens-ix/p-f87cd962.js.map +0 -1
  1399. package/dist/siemens-ix/p-fd5bee44.entry.js +0 -2
  1400. package/dist/siemens-ix/p-fd5bee44.entry.js.map +0 -1
  1401. package/dist/siemens-ix/p-fefd5743.entry.js +0 -2
  1402. package/dist/siemens-ix/p-fefd5743.entry.js.map +0 -1
  1403. package/dist/siemens-ix/p-ffa856df.entry.js +0 -2
  1404. package/dist/siemens-ix/p-ffa856df.entry.js.map +0 -1
  1405. package/dist/types/components/form-field/form-field.d.ts +0 -10
  1406. package/dist/types/components/playground/example-modal.d.ts +0 -6
  1407. package/dist/types/components/playground/playground.d.ts +0 -4
  1408. /package/dist/collection/components/{grid → layout-grid}/layout-grid.css +0 -0
  1409. /package/dist/siemens-ix/{p-928209e1.entry.js.map → p-044c2a7b.entry.js.map} +0 -0
  1410. /package/dist/siemens-ix/{p-35fff1e6.entry.js.map → p-0be907d4.entry.js.map} +0 -0
  1411. /package/dist/siemens-ix/{p-f001ecc1.entry.js.map → p-0f0e7e14.entry.js.map} +0 -0
  1412. /package/dist/siemens-ix/{p-63f0755e.entry.js.map → p-2643f32a.entry.js.map} +0 -0
  1413. /package/dist/siemens-ix/{p-9079f6c8.entry.js.map → p-2a34a0c2.entry.js.map} +0 -0
  1414. /package/dist/siemens-ix/{p-1bd98772.entry.js.map → p-2b367b12.entry.js.map} +0 -0
  1415. /package/dist/siemens-ix/{p-c05a98c8.entry.js.map → p-2b9c5f59.entry.js.map} +0 -0
  1416. /package/dist/siemens-ix/{p-4e547dd3.entry.js.map → p-2d3a6d29.entry.js.map} +0 -0
  1417. /package/dist/siemens-ix/{p-82f9d976.entry.js.map → p-2d7ea063.entry.js.map} +0 -0
  1418. /package/dist/siemens-ix/{p-ae31be0d.entry.js.map → p-2db63240.entry.js.map} +0 -0
  1419. /package/dist/siemens-ix/{p-c81c4b9d.entry.js.map → p-3205726a.entry.js.map} +0 -0
  1420. /package/dist/siemens-ix/{p-33a7a26d.entry.js.map → p-37af7117.entry.js.map} +0 -0
  1421. /package/dist/siemens-ix/{p-e0d03d67.entry.js.map → p-392b4297.entry.js.map} +0 -0
  1422. /package/dist/siemens-ix/{p-c7280736.entry.js.map → p-4624a772.entry.js.map} +0 -0
  1423. /package/dist/siemens-ix/{p-a4755205.entry.js.map → p-4a631d9c.entry.js.map} +0 -0
  1424. /package/dist/siemens-ix/{p-05dc6b2d.entry.js.map → p-4c9b7548.entry.js.map} +0 -0
  1425. /package/dist/siemens-ix/{p-78ac2ff1.entry.js.map → p-4cc79e8f.entry.js.map} +0 -0
  1426. /package/dist/siemens-ix/{p-d300b332.entry.js.map → p-4e51d716.entry.js.map} +0 -0
  1427. /package/dist/siemens-ix/{p-0ef97555.entry.js.map → p-4ec6ddfb.entry.js.map} +0 -0
  1428. /package/dist/siemens-ix/{p-0ca3528f.js.map → p-5682e985.js.map} +0 -0
  1429. /package/dist/siemens-ix/{p-5af99eaa.entry.js.map → p-57e60a06.entry.js.map} +0 -0
  1430. /package/dist/siemens-ix/{p-0632731e.entry.js.map → p-63dd987f.entry.js.map} +0 -0
  1431. /package/dist/siemens-ix/{p-f06b21f9.entry.js.map → p-654f91f2.entry.js.map} +0 -0
  1432. /package/dist/siemens-ix/{p-82d33168.entry.js.map → p-66559451.entry.js.map} +0 -0
  1433. /package/dist/siemens-ix/{p-86fd5922.entry.js.map → p-6722bcff.entry.js.map} +0 -0
  1434. /package/dist/siemens-ix/{p-b804b8c5.entry.js.map → p-6bae4e9b.entry.js.map} +0 -0
  1435. /package/dist/siemens-ix/{p-68532fa2.js.map → p-6bf208b8.js.map} +0 -0
  1436. /package/dist/siemens-ix/{p-958c5970.entry.js.map → p-8457d846.entry.js.map} +0 -0
  1437. /package/dist/siemens-ix/{p-c7e58e9e.entry.js.map → p-8c2b62c3.entry.js.map} +0 -0
  1438. /package/dist/siemens-ix/{p-c62966f8.entry.js.map → p-8da941cd.entry.js.map} +0 -0
  1439. /package/dist/siemens-ix/{p-6618b2db.entry.js.map → p-8f616a5c.entry.js.map} +0 -0
  1440. /package/dist/siemens-ix/{p-e14384df.entry.js.map → p-9948574f.entry.js.map} +0 -0
  1441. /package/dist/siemens-ix/{p-085d5ec2.entry.js.map → p-9d323232.entry.js.map} +0 -0
  1442. /package/dist/siemens-ix/{p-17a8aab2.entry.js.map → p-a3364116.entry.js.map} +0 -0
  1443. /package/dist/siemens-ix/{p-32d4ed3b.entry.js.map → p-a61ed462.entry.js.map} +0 -0
  1444. /package/dist/siemens-ix/{p-8acc09aa.entry.js.map → p-b2a06e46.entry.js.map} +0 -0
  1445. /package/dist/siemens-ix/{p-5aa0b93c.entry.js.map → p-b74a8cdc.entry.js.map} +0 -0
  1446. /package/dist/siemens-ix/{p-89e48bea.entry.js.map → p-bded112a.entry.js.map} +0 -0
  1447. /package/dist/siemens-ix/{p-e95a5a97.entry.js.map → p-be860121.entry.js.map} +0 -0
  1448. /package/dist/siemens-ix/{p-7947ef3d.entry.js.map → p-c236cf18.entry.js.map} +0 -0
  1449. /package/dist/siemens-ix/{p-091b036d.entry.js.map → p-c6796e64.entry.js.map} +0 -0
  1450. /package/dist/siemens-ix/{p-04af3853.entry.js.map → p-cbfca958.entry.js.map} +0 -0
  1451. /package/dist/siemens-ix/{p-b663ca16.entry.js.map → p-d929f23d.entry.js.map} +0 -0
  1452. /package/dist/siemens-ix/{p-0fafba48.entry.js.map → p-e7ac5657.entry.js.map} +0 -0
  1453. /package/dist/siemens-ix/{p-ee96d1eb.entry.js.map → p-e9a37b3f.entry.js.map} +0 -0
  1454. /package/dist/siemens-ix/{p-24a8737a.entry.js.map → p-edc1d44a.entry.js.map} +0 -0
  1455. /package/dist/siemens-ix/{p-9bdda7ff.entry.js.map → p-ffca56d6.entry.js.map} +0 -0
  1456. /package/dist/types/components/{grid → layout-grid}/layout-grid.d.ts +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"datetime-picker.js","sourceRoot":"","sources":["../../../src/components/datetime-picker/datetime-picker.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 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 { Component, Event, EventEmitter, h, Host, Prop } from '@stencil/core';\nimport type { DateChangeEvent } from '../date-picker/date-picker';\n\nexport type DateTimeSelectEvent = {\n from: string;\n to: string;\n time: string;\n};\n\nexport type DateTimeDateChangeEvent =\n | string\n | Omit<DateTimeSelectEvent, 'time'>;\n\n@Component({\n tag: 'ix-datetime-picker',\n styleUrl: 'datetime-picker.scss',\n shadow: true,\n})\nexport class DatetimePicker {\n /**\n * If true a date-range can be selected (from/to).\n */\n @Prop() range = true;\n\n /**\n * Show hour input\n */\n @Prop() showHour = true;\n\n /**\n * Show minutes input\n */\n @Prop() showMinutes = true;\n\n /**\n * Show seconds input\n */\n @Prop() showSeconds = true;\n\n /**\n * The earliest date that can be selected by the date picker.\n * If not set there will be no restriction.\n *\n * @since 1.1.0\n */\n @Prop() minDate: string;\n\n /**\n * The latest date that can be selected by the date picker.\n * If not set there will be no restriction.\n *\n * @since 1.1.0\n */\n @Prop() maxDate: string;\n\n /**\n * Date format string.\n * See {@link \"https://moment.github.io/luxon/#/formatting?id=table-of-tokens\"} for all available tokens.\n *\n * @since 1.1.0\n */\n @Prop() dateFormat: string = 'yyyy/LL/dd';\n\n /**\n * Time format string.\n * See {@link \"https://moment.github.io/luxon/#/formatting?id=table-of-tokens\"} for all available tokens.\n *\n * @since 1.1.0\n */\n @Prop() timeFormat: string = 'HH:mm:ss';\n\n /**\n * The selected starting date. If the picker is not in range mode this is the selected date.\n * Format has to match the `format` property.\n *\n * @since 1.1.0\n */\n @Prop() from: string | undefined;\n\n /**\n * The selected end date. If the the picker is not in range mode this property has no impact.\n * Format has to match the `format` property.\n *\n * @since 1.1.0\n */\n @Prop() to: string | undefined;\n\n /**\n * Select time with format string\n *\n * @since 1.1.0\n */\n @Prop() time: string;\n\n /**\n * Show time reference input\n * Time reference is default aligned with @see {this.timeFormat}\n *\n * @since 1.1.0\n */\n @Prop() showTimeReference = undefined;\n\n /**\n * Set time reference\n */\n @Prop() timeReference: 'AM' | 'PM';\n\n /**\n * Text of date select button\n *\n * @since 1.1.0\n * @deprecated since 2.1.0. Use `i18nDone`\n */\n @Prop() textSelectDate: string;\n\n /**\n * Text of date select button\n *\n * @since 2.1.0\n */\n @Prop({ attribute: 'i18n-done' }) i18nDone: string = 'Done';\n\n /**\n * The index of which day to start the week on, based on the Locale#weekdays array.\n * E.g. if the locale is en-us, weekStartIndex = 1 results in starting the week on monday.\n *\n * @since 2.1.0\n */\n @Prop() weekStartIndex = 0;\n\n /**\n * Format of time string\n * See {@link \"https://moment.github.io/luxon/#/formatting?id=table-of-tokens\"} for all available tokens.\n *\n * @since 2.1.0\n */\n @Prop() locale: string = undefined;\n\n /**\n * Default behavior of the done event is to join the two events (date and time) into one combined string output.\n * This combination can be configured over the delimiter\n *\n * @since 1.1.0\n * @deprecated Not used anymore see `done` event\n */\n @Prop() eventDelimiter = ' - ';\n\n /**\n * Done event\n *\n * Set `doneEventDelimiter` to null or undefine to get the typed event\n * @deprecated Use `this.dateChange`\n */\n @Event() done: EventEmitter<string>;\n\n /**\n * Time change\n *\n * @since 1.1.0\n */\n @Event() timeChange: EventEmitter<string>;\n\n /**\n * Date change\n *\n * @since 1.1.0\n */\n @Event() dateChange: EventEmitter<DateTimeDateChangeEvent>;\n\n /**\n * Datetime selection event is fired after confirm button is pressed\n *\n * @since 1.1.0\n */\n @Event() dateSelect: EventEmitter<DateTimeSelectEvent>;\n\n private datePickerElement: HTMLIxDatePickerElement;\n private timePickerElement: HTMLIxTimePickerElement;\n\n private async onDone() {\n const date = await this.datePickerElement.getCurrentDate();\n const time = await this.timePickerElement.getCurrentTime();\n\n this.dateSelect.emit({\n from: date.from,\n to: date.to,\n time: time,\n });\n\n this.done.emit([date.from, date.to ?? '', time].join(this.eventDelimiter));\n }\n\n private async onDateChange(event: CustomEvent<string | DateChangeEvent>) {\n event.preventDefault();\n event.stopPropagation();\n\n const { detail: date } = event;\n this.dateChange.emit(date);\n }\n\n private async onTimeChange(event: CustomEvent<string>) {\n event.preventDefault();\n event.stopPropagation();\n\n const { detail: time } = event;\n this.timeChange.emit(time);\n }\n\n render() {\n return (\n <Host>\n <ix-layout-grid class=\"no-padding\">\n <ix-row>\n <ix-col class=\"no-padding\">\n <ix-date-picker\n ref={(ref) => (this.datePickerElement = ref)}\n corners=\"left\"\n range={this.range}\n onDateChange={(event) => this.onDateChange(event)}\n from={this.from}\n to={this.to}\n format={this.dateFormat}\n minDate={this.minDate}\n maxDate={this.maxDate}\n weekStartIndex={this.weekStartIndex}\n standaloneAppearance={false}\n locale={this.locale}\n ></ix-date-picker>\n </ix-col>\n\n <ix-col class=\"no-padding\">\n <ix-time-picker\n class=\"min-width\"\n ref={(ref) => (this.timePickerElement = ref)}\n corners=\"right\"\n standaloneAppearance={false}\n showHour={this.showHour}\n showMinutes={this.showMinutes}\n showSeconds={this.showSeconds}\n onTimeChange={(event) => this.onTimeChange(event)}\n format={this.timeFormat}\n time={this.time}\n ></ix-time-picker>\n </ix-col>\n </ix-row>\n <ix-row>\n <ix-col>\n <ix-button\n class=\"btn-select-date btn-md-width\"\n onClick={() => this.onDone()}\n >\n {this.textSelectDate || this.i18nDone}\n </ix-button>\n </ix-col>\n </ix-row>\n </ix-layout-grid>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"datetime-picker.js","sourceRoot":"","sources":["../../../src/components/datetime-picker/datetime-picker.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 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 { Component, Event, EventEmitter, h, Host, Prop } from '@stencil/core';\nimport type { DateChangeEvent } from '../date-picker/date-picker';\nimport { IxDatePickerComponent } from '../date-picker/date-picker-component';\n\nexport type DateTimeSelectEvent = {\n from: string;\n to: string;\n time: string;\n};\n\nexport type DateTimeDateChangeEvent =\n | string\n | Omit<DateTimeSelectEvent, 'time'>;\n\n@Component({\n tag: 'ix-datetime-picker',\n styleUrl: 'datetime-picker.scss',\n shadow: true,\n})\nexport class DatetimePicker\n implements Omit<IxDatePickerComponent, 'corners' | 'format'>\n{\n /**\n * If true a date-range can be selected (from/to).\n */\n @Prop() range = true;\n\n /**\n * Show hour input\n */\n @Prop() showHour = true;\n\n /**\n * Show minutes input\n */\n @Prop() showMinutes = true;\n\n /**\n * Show seconds input\n */\n @Prop() showSeconds = true;\n\n /**\n * The earliest date that can be selected by the date picker.\n * If not set there will be no restriction.\n *\n * @since 1.1.0\n */\n @Prop() minDate?: string;\n\n /**\n * The latest date that can be selected by the date picker.\n * If not set there will be no restriction.\n *\n * @since 1.1.0\n */\n @Prop() maxDate?: string;\n\n /**\n * Date format string.\n * See {@link \"https://moment.github.io/luxon/#/formatting?id=table-of-tokens\"} for all available tokens.\n *\n * @since 1.1.0\n */\n @Prop() dateFormat: string = 'yyyy/LL/dd';\n\n /**\n * Time format string.\n * See {@link \"https://moment.github.io/luxon/#/formatting?id=table-of-tokens\"} for all available tokens.\n *\n * @since 1.1.0\n */\n @Prop() timeFormat: string = 'HH:mm:ss';\n\n /**\n * The selected starting date. If the picker is not in range mode this is the selected date.\n * Format has to match the `format` property.\n *\n * @since 1.1.0\n */\n @Prop() from?: string;\n\n /**\n * The selected end date. If the the picker is not in range mode this property has no impact.\n * Format has to match the `format` property.\n *\n * @since 1.1.0\n */\n @Prop() to?: string;\n\n /**\n * Select time with format string\n *\n * @since 1.1.0\n */\n @Prop() time?: string;\n\n /**\n * Show time reference input\n * Time reference is default aligned with @see {this.timeFormat}\n *\n * @since 1.1.0\n */\n @Prop() showTimeReference: boolean = false;\n\n /**\n * Set time reference\n */\n @Prop() timeReference?: 'AM' | 'PM';\n\n /**\n * Text of date select button\n *\n * @since 1.1.0\n * @deprecated since 2.1.0. Use `i18nDone`\n */\n @Prop() textSelectDate?: string;\n\n /**\n * Text of date select button\n *\n * @since 2.1.0\n */\n @Prop({ attribute: 'i18n-done' }) i18nDone: string = 'Done';\n\n /**\n * The index of which day to start the week on, based on the Locale#weekdays array.\n * E.g. if the locale is en-us, weekStartIndex = 1 results in starting the week on monday.\n *\n * @since 2.1.0\n */\n @Prop() weekStartIndex = 0;\n\n /**\n * Format of time string\n * See {@link \"https://moment.github.io/luxon/#/formatting?id=table-of-tokens\"} for all available tokens.\n *\n * @since 2.1.0\n */\n @Prop() locale?: string;\n\n /**\n * Default behavior of the done event is to join the two events (date and time) into one combined string output.\n * This combination can be configured over the delimiter\n *\n * @since 1.1.0\n * @deprecated Not used anymore see `done` event\n */\n @Prop() eventDelimiter = ' - ';\n\n /**\n * Done event\n *\n * Set `doneEventDelimiter` to null or undefine to get the typed event\n * @deprecated Use `this.dateChange`\n */\n @Event() done!: EventEmitter<string>;\n\n /**\n * Time change\n *\n * @since 1.1.0\n */\n @Event() timeChange!: EventEmitter<string>;\n\n /**\n * Date change\n *\n * @since 1.1.0\n */\n @Event() dateChange!: EventEmitter<DateTimeDateChangeEvent>;\n\n /**\n * Datetime selection event is fired after confirm button is pressed\n *\n * @since 1.1.0\n */\n @Event() dateSelect!: EventEmitter<DateTimeSelectEvent>;\n\n private datePickerElement?: HTMLIxDatePickerElement;\n private timePickerElement?: HTMLIxTimePickerElement;\n\n private async onDone() {\n const date = await this.datePickerElement?.getCurrentDate();\n const time = await this.timePickerElement?.getCurrentTime();\n\n this.dateSelect.emit({\n from: date?.from ?? '',\n to: date?.to ?? '',\n time: time ?? '',\n });\n\n this.done.emit(\n [date?.from, date?.to ?? '', time].join(this.eventDelimiter)\n );\n }\n\n private async onDateChange(event: CustomEvent<string | DateChangeEvent>) {\n event.preventDefault();\n event.stopPropagation();\n\n const { detail: date } = event;\n this.dateChange.emit(date);\n }\n\n private async onTimeChange(event: CustomEvent<string>) {\n event.preventDefault();\n event.stopPropagation();\n\n const { detail: time } = event;\n this.timeChange.emit(time);\n }\n\n render() {\n return (\n <Host>\n <ix-layout-grid class=\"no-padding\">\n <ix-row>\n <ix-col>\n <ix-date-picker\n ref={(ref) => (this.datePickerElement = ref)}\n corners=\"left\"\n range={this.range}\n onDateChange={(event) => this.onDateChange(event)}\n from={this.from}\n to={this.to}\n format={this.dateFormat}\n minDate={this.minDate}\n maxDate={this.maxDate}\n weekStartIndex={this.weekStartIndex}\n standaloneAppearance={false}\n locale={this.locale}\n ></ix-date-picker>\n </ix-col>\n\n <ix-col class=\"d-flex flex-column\">\n <ix-time-picker\n class=\"min-width\"\n ref={(ref) => (this.timePickerElement = ref)}\n standaloneAppearance={false}\n showHour={this.showHour}\n showMinutes={this.showMinutes}\n showSeconds={this.showSeconds}\n onTimeChange={(event) => this.onTimeChange(event)}\n format={this.timeFormat}\n time={this.time}\n ></ix-time-picker>\n <div class=\"btn-select-date-container\">\n <ix-button\n class=\"btn-select-date\"\n onClick={() => this.onDone()}\n >\n {this.textSelectDate || this.i18nDone}\n </ix-button>\n </div>\n </ix-col>\n </ix-row>\n </ix-layout-grid>\n </Host>\n );\n }\n}\n"]}
@@ -12,7 +12,7 @@ import { h, Host } from "@stencil/core";
12
12
  */
13
13
  export class Divider {
14
14
  render() {
15
- return h(Host, { key: 'c86675e3fc86e702df2e59447d57bfcd6a5f80ba' });
15
+ return h(Host, { key: '1b2bc210e67cb0e1b5421a1f792feea56b7fec55' });
16
16
  }
17
17
  static get is() { return "ix-divider"; }
18
18
  static get encapsulation() { return "shadow"; }
@@ -101,9 +101,6 @@
101
101
  z-index: 100;
102
102
  visibility: visible;
103
103
  }
104
- :host .drawer-container.full-height {
105
- min-height: 100%;
106
- }
107
104
  :host .header {
108
105
  display: flex;
109
106
  position: relative;
@@ -59,43 +59,47 @@ export class Drawer {
59
59
  }
60
60
  }
61
61
  slideOutRight(el) {
62
- anime({
63
- targets: el,
64
- duration: Drawer.duration,
65
- translateX: [0, '16rem'],
66
- opacity: [1, 0],
67
- easing: 'easeInSine',
68
- complete: () => {
69
- el.classList.add('d-none');
70
- },
71
- });
62
+ if (el) {
63
+ anime({
64
+ targets: el,
65
+ duration: Drawer.duration,
66
+ translateX: [0, '16rem'],
67
+ opacity: [1, 0],
68
+ easing: 'easeInSine',
69
+ complete: () => {
70
+ el.classList.add('d-none');
71
+ },
72
+ });
73
+ }
72
74
  }
73
75
  slideInRight(el) {
74
- anime({
75
- targets: el,
76
- duration: Drawer.duration,
77
- translateX: ['16rem', 0],
78
- opacity: [0, 1],
79
- easing: 'easeOutSine',
80
- begin: () => {
81
- el.classList.remove('d-none');
82
- },
83
- });
76
+ if (el) {
77
+ anime({
78
+ targets: el,
79
+ duration: Drawer.duration,
80
+ translateX: ['16rem', 0],
81
+ opacity: [0, 1],
82
+ easing: 'easeOutSine',
83
+ begin: () => {
84
+ el.classList.remove('d-none');
85
+ },
86
+ });
87
+ }
84
88
  }
85
89
  componentDidLoad() {
86
90
  this.onShowChanged(this.show);
87
91
  }
88
92
  render() {
89
- return (h(Host, { key: '2a08d35b883881d7ce4fac52754f5ba6a6d87b67', class: {
93
+ return (h(Host, { key: 'fb5465b724d808ef07aac6c46aa7453ce794dc24', class: {
90
94
  'drawer-container': true,
91
95
  toggle: this.show,
92
- 'full-height': this.fullHeight,
93
96
  'd-none': true,
94
97
  }, style: {
95
98
  width: this.width === 'auto' ? this.width : `${this.width}rem`,
96
99
  'min-width': `${this.minWidth}rem`,
97
100
  'max-width': `${this.maxWidth}rem`,
98
- }, ref: (el) => (this.divElement = el), "data-testid": "container", id: "div-container" }, h("div", { key: '516fb16c8d2a99d29e158193b6e69f62e6805d7a', class: "header" }, h("div", { key: '24f3e13377044cc7b72fa3b0e01163afbf2b8bbd', class: "header-content" }, h("slot", { key: 'a0b4aeb829de7152941816142193ca23f15475f4', name: "header" })), h("ix-icon-button", { key: '3781d1a2bad00dd5c43b7514de103bfe9662e929', class: "close-button", icon: 'close', size: "24", ghost: true, onClick: () => this.onCloseClicked(), "data-testid": "close-button" })), h("div", { key: '9e19c76af291d53298aad23a7e113ec76b84f5a5', class: "content" }, h("slot", { key: '3b12eafb18a7fd75614a40c3f1e611e1556f4acd' }))));
101
+ height: this.fullHeight ? '100%' : 'auto',
102
+ }, ref: (el) => (this.divElement = el), "data-testid": "container", id: "div-container" }, h("div", { key: 'f43cd8663f7d04d06c30ad2f94f5099e3b863489', class: "header" }, h("div", { key: '0ebb196ddc6e9bb1eb00f5f7acfedf61ce5f39dd', class: "header-content" }, h("slot", { key: '16b8c5eb76f9275ff516b21c3469fa560eba866d', name: "header" })), h("ix-icon-button", { key: '7991db337a8fe5eb9808f4fef9d93a94e28b53c2', class: "close-button", icon: 'close', size: "24", ghost: true, onClick: () => this.onCloseClicked(), "data-testid": "close-button" })), h("div", { key: '60036ad51052c0ea0133f414857b3a329908fb98', class: "content" }, h("slot", { key: '965739949ca38d15004d1ff7538231c94feeab15' }))));
99
103
  }
100
104
  static get is() { return "ix-drawer"; }
101
105
  static get encapsulation() { return "shadow"; }
@@ -1 +1 @@
1
- {"version":3,"file":"drawer.js","sourceRoot":"","sources":["../../../src/components/drawer/drawer.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 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 {\n Component,\n Event,\n EventEmitter,\n h,\n Host,\n Method,\n Prop,\n Watch,\n} from '@stencil/core';\nimport anime from 'animejs';\n\n@Component({\n tag: 'ix-drawer',\n styleUrl: 'drawer.scss',\n shadow: true,\n})\nexport class Drawer {\n /**\n * Show or hide the drawer\n */\n @Prop({ mutable: true }) show = false;\n\n /**\n * Fired in case of an outside click during drawer showed state\n */\n @Prop() closeOnClickOutside = true;\n\n /**\n * Render the drawer with maximum height\n */\n @Prop() fullHeight = false;\n\n /**\n * Min width interpreted as REM\n */\n @Prop() minWidth = 16;\n\n /**\n * Max width interpreted as REM\n */\n @Prop() maxWidth = 28;\n\n /**\n * Width interpreted as REM if not set to 'auto'\n */\n @Prop() width: number | 'auto' = this.minWidth;\n\n /**\n * Fire event after drawer is open\n */\n @Event() open: EventEmitter;\n\n /**\n * Fire event after drawer is close\n */\n @Event() drawerClose: EventEmitter;\n\n private static duration = 300;\n private callback = this.clickedOutside.bind(this);\n private divElement?: HTMLElement;\n\n @Watch('show')\n onShowChanged(newValue: boolean) {\n this.show = newValue !== undefined ? newValue : !this.show;\n this.toggleDrawer(this.show);\n }\n\n /**\n * Toggle or define show state of drawer\n * @param show Overwrite toggle state with boolean\n */\n @Method()\n async toggleDrawer(show?: boolean): Promise<void> {\n this.show = show !== undefined ? show : !this.show;\n\n if (show) {\n this.open.emit();\n this.slideInRight(this.divElement);\n setTimeout(() => {\n window.addEventListener('mousedown', this.callback);\n }, 300);\n } else {\n this.drawerClose.emit();\n this.slideOutRight(this.divElement);\n window.removeEventListener('mousedown', this.callback);\n }\n\n return Promise.resolve();\n }\n\n private onCloseClicked() {\n this.show = false;\n }\n\n private clickedOutside(evt: any) {\n if (!this.closeOnClickOutside) {\n return;\n }\n\n const target = evt.target;\n const closestElement = target.closest('#div-container');\n const btn = target.closest('#drawer-btn');\n\n if (\n evt.target.type !== 'button' &&\n closestElement !== this.divElement &&\n target !== btn\n ) {\n this.show = false;\n }\n }\n\n private slideOutRight(el: HTMLElement) {\n anime({\n targets: el,\n duration: Drawer.duration,\n translateX: [0, '16rem'],\n opacity: [1, 0],\n easing: 'easeInSine',\n complete: () => {\n el.classList.add('d-none');\n },\n });\n }\n\n private slideInRight(el: HTMLElement) {\n anime({\n targets: el,\n duration: Drawer.duration,\n translateX: ['16rem', 0],\n opacity: [0, 1],\n easing: 'easeOutSine',\n begin: () => {\n el.classList.remove('d-none');\n },\n });\n }\n\n componentDidLoad() {\n this.onShowChanged(this.show);\n }\n\n render() {\n return (\n <Host\n class={{\n 'drawer-container': true,\n toggle: this.show,\n 'full-height': this.fullHeight,\n 'd-none': true,\n }}\n style={{\n width: this.width === 'auto' ? this.width : `${this.width}rem`,\n 'min-width': `${this.minWidth}rem`,\n 'max-width': `${this.maxWidth}rem`,\n }}\n ref={(el) => (this.divElement = el as HTMLElement)}\n data-testid=\"container\"\n id=\"div-container\"\n >\n <div class=\"header\">\n <div class=\"header-content\">\n <slot name=\"header\"></slot>\n </div>\n <ix-icon-button\n class=\"close-button\"\n icon={'close'}\n size=\"24\"\n ghost\n onClick={() => this.onCloseClicked()}\n data-testid=\"close-button\"\n ></ix-icon-button>\n </div>\n <div class=\"content\">\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"drawer.js","sourceRoot":"","sources":["../../../src/components/drawer/drawer.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 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 {\n Component,\n Event,\n EventEmitter,\n h,\n Host,\n Method,\n Prop,\n Watch,\n} from '@stencil/core';\nimport anime from 'animejs';\n\n@Component({\n tag: 'ix-drawer',\n styleUrl: 'drawer.scss',\n shadow: true,\n})\nexport class Drawer {\n /**\n * Show or hide the drawer\n */\n @Prop({ mutable: true }) show = false;\n\n /**\n * Fired in case of an outside click during drawer showed state\n */\n @Prop() closeOnClickOutside = true;\n\n /**\n * Render the drawer with maximum height\n */\n @Prop() fullHeight = false;\n\n /**\n * Min width interpreted as REM\n */\n @Prop() minWidth = 16;\n\n /**\n * Max width interpreted as REM\n */\n @Prop() maxWidth = 28;\n\n /**\n * Width interpreted as REM if not set to 'auto'\n */\n @Prop() width: number | 'auto' = this.minWidth;\n\n /**\n * Fire event after drawer is open\n */\n @Event() open!: EventEmitter;\n\n /**\n * Fire event after drawer is close\n */\n @Event() drawerClose!: EventEmitter;\n\n private static duration = 300;\n private callback = this.clickedOutside.bind(this);\n private divElement?: HTMLElement;\n\n @Watch('show')\n onShowChanged(newValue: boolean) {\n this.show = newValue !== undefined ? newValue : !this.show;\n this.toggleDrawer(this.show);\n }\n\n /**\n * Toggle or define show state of drawer\n * @param show Overwrite toggle state with boolean\n */\n @Method()\n async toggleDrawer(show?: boolean): Promise<void> {\n this.show = show !== undefined ? show : !this.show;\n\n if (show) {\n this.open.emit();\n this.slideInRight(this.divElement);\n setTimeout(() => {\n window.addEventListener('mousedown', this.callback);\n }, 300);\n } else {\n this.drawerClose.emit();\n this.slideOutRight(this.divElement);\n window.removeEventListener('mousedown', this.callback);\n }\n\n return Promise.resolve();\n }\n\n private onCloseClicked() {\n this.show = false;\n }\n\n private clickedOutside(evt: any) {\n if (!this.closeOnClickOutside) {\n return;\n }\n\n const target = evt.target;\n const closestElement = target.closest('#div-container');\n const btn = target.closest('#drawer-btn');\n\n if (\n evt.target.type !== 'button' &&\n closestElement !== this.divElement &&\n target !== btn\n ) {\n this.show = false;\n }\n }\n\n private slideOutRight(el?: HTMLElement) {\n if (el) {\n anime({\n targets: el,\n duration: Drawer.duration,\n translateX: [0, '16rem'],\n opacity: [1, 0],\n easing: 'easeInSine',\n complete: () => {\n el.classList.add('d-none');\n },\n });\n }\n }\n\n private slideInRight(el?: HTMLElement) {\n if (el) {\n anime({\n targets: el,\n duration: Drawer.duration,\n translateX: ['16rem', 0],\n opacity: [0, 1],\n easing: 'easeOutSine',\n begin: () => {\n el.classList.remove('d-none');\n },\n });\n }\n }\n\n componentDidLoad() {\n this.onShowChanged(this.show);\n }\n\n render() {\n return (\n <Host\n class={{\n 'drawer-container': true,\n toggle: this.show,\n 'd-none': true,\n }}\n style={{\n width: this.width === 'auto' ? this.width : `${this.width}rem`,\n 'min-width': `${this.minWidth}rem`,\n 'max-width': `${this.maxWidth}rem`,\n height: this.fullHeight ? '100%' : 'auto',\n }}\n ref={(el) => (this.divElement = el as HTMLElement)}\n data-testid=\"container\"\n id=\"div-container\"\n >\n <div class=\"header\">\n <div class=\"header-content\">\n <slot name=\"header\"></slot>\n </div>\n <ix-icon-button\n class=\"close-button\"\n icon={'close'}\n size=\"24\"\n ghost\n onClick={() => this.onCloseClicked()}\n data-testid=\"close-button\"\n ></ix-icon-button>\n </div>\n <div class=\"content\">\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -42,14 +42,14 @@ describe('ix-drawer', () => {
42
42
  await page.waitForChanges();
43
43
  drawer.fullHeight = true;
44
44
  await page.waitForChanges();
45
- expect(container.classList.contains('full-height')).toBeTruthy();
45
+ expect(container.style.height.includes('100%')).toBeTruthy();
46
46
  });
47
47
  it('drawer is NOT displayed at full height, if fullHeight is set to false', async () => {
48
48
  drawer.toggleDrawer();
49
49
  await page.waitForChanges();
50
50
  drawer.fullHeight = false;
51
51
  await page.waitForChanges();
52
- expect(container.classList.contains('full-height')).toBeFalsy();
52
+ expect(container.style.height.includes('auto')).toBeTruthy();
53
53
  });
54
54
  it('emits an event, when show changed', async () => {
55
55
  const mockCallback = jest.fn();
@@ -1 +1 @@
1
- {"version":3,"file":"drawer.spec.js","sourceRoot":"","sources":["../../../../src/components/drawer/test/drawer.spec.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 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 { newSpecPage } from '@stencil/core/testing';\nimport { fireEvent } from '@testing-library/dom';\nimport { Drawer } from '../drawer';\n\ndescribe('ix-drawer', () => {\n let page: any;\n let drawer: HTMLIxDrawerElement;\n let container: HTMLDivElement;\n\n beforeEach(async () => {\n page = await newSpecPage({\n components: [Drawer],\n html: '<ix-drawer>Example Content</ix-drawer>',\n });\n\n drawer = document.querySelector('ix-drawer');\n container = document.querySelector('[data-testid=\"container\"]');\n });\n\n it('opens the drawer', async () => {\n drawer.show = true;\n await page.waitForChanges();\n\n expect(drawer.show).toBeTruthy();\n\n await page.waitForChanges();\n expect(drawer.innerText).toContain('Example Content');\n });\n\n it('closes the drawer', async () => {\n drawer.show = true;\n await page.waitForChanges();\n\n const closeButton = drawer.shadowRoot.querySelector(\n '[data-testid=\"close-button\"]'\n );\n fireEvent.click(closeButton);\n await page.waitForChanges();\n expect(drawer.show).toBeFalsy();\n expect(drawer.innerHTML).not.toContain('toggle');\n });\n\n it('drawer is displayed at full height, if fullHeight is set to true', async () => {\n drawer.toggleDrawer();\n await page.waitForChanges();\n\n drawer.fullHeight = true;\n await page.waitForChanges();\n\n expect(container.classList.contains('full-height')).toBeTruthy();\n });\n\n it('drawer is NOT displayed at full height, if fullHeight is set to false', async () => {\n drawer.toggleDrawer();\n await page.waitForChanges();\n\n drawer.fullHeight = false;\n await page.waitForChanges();\n\n expect(container.classList.contains('full-height')).toBeFalsy();\n });\n\n it('emits an event, when show changed', async () => {\n const mockCallback = jest.fn();\n window.addEventListener('open', mockCallback);\n\n drawer.toggleDrawer();\n await page.waitForChanges();\n\n const closeButton = drawer.shadowRoot.querySelector(\n '[data-testid=\"close-button\"]'\n );\n fireEvent.click(closeButton);\n\n window.removeEventListener('open', mockCallback);\n expect(mockCallback).toHaveBeenCalled();\n });\n});\n"]}
1
+ {"version":3,"file":"drawer.spec.js","sourceRoot":"","sources":["../../../../src/components/drawer/test/drawer.spec.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 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 { newSpecPage } from '@stencil/core/testing';\nimport { fireEvent } from '@testing-library/dom';\nimport { Drawer } from '../drawer';\n\ndescribe('ix-drawer', () => {\n let page: any;\n let drawer: HTMLIxDrawerElement;\n let container: HTMLDivElement;\n\n beforeEach(async () => {\n page = await newSpecPage({\n components: [Drawer],\n html: '<ix-drawer>Example Content</ix-drawer>',\n });\n\n drawer = document.querySelector('ix-drawer')!;\n container = document.querySelector('[data-testid=\"container\"]')!;\n });\n\n it('opens the drawer', async () => {\n drawer.show = true;\n await page.waitForChanges();\n\n expect(drawer.show).toBeTruthy();\n\n await page.waitForChanges();\n expect(drawer.innerText).toContain('Example Content');\n });\n\n it('closes the drawer', async () => {\n drawer.show = true;\n await page.waitForChanges();\n\n const closeButton = drawer.shadowRoot!.querySelector(\n '[data-testid=\"close-button\"]'\n )!;\n fireEvent.click(closeButton);\n\n await page.waitForChanges();\n expect(drawer.show).toBeFalsy();\n expect(drawer.innerHTML).not.toContain('toggle');\n });\n\n it('drawer is displayed at full height, if fullHeight is set to true', async () => {\n drawer.toggleDrawer();\n await page.waitForChanges();\n\n drawer.fullHeight = true;\n await page.waitForChanges();\n\n expect(container.style.height.includes('100%')).toBeTruthy();\n });\n\n it('drawer is NOT displayed at full height, if fullHeight is set to false', async () => {\n drawer.toggleDrawer();\n await page.waitForChanges();\n\n drawer.fullHeight = false;\n await page.waitForChanges();\n\n expect(container.style.height.includes('auto')).toBeTruthy();\n });\n\n it('emits an event, when show changed', async () => {\n const mockCallback = jest.fn();\n window.addEventListener('open', mockCallback);\n\n drawer.toggleDrawer();\n await page.waitForChanges();\n\n const closeButton = drawer.shadowRoot!.querySelector(\n '[data-testid=\"close-button\"]'\n )!;\n fireEvent.click(closeButton);\n\n window.removeEventListener('open', mockCallback);\n expect(mockCallback).toHaveBeenCalled();\n });\n});\n"]}
@@ -7,7 +7,7 @@
7
7
  * LICENSE file in the root directory of this source tree.
8
8
  */
9
9
  export function hasDropdownItemWrapperImplemented(item) {
10
- return (item &&
10
+ return (item !== null &&
11
11
  item.getDropdownItemElement !== undefined &&
12
12
  typeof item.getDropdownItemElement === 'function');
13
13
  }
@@ -27,7 +27,24 @@ class DropdownController {
27
27
  }
28
28
  }
29
29
  disconnected(dropdown) {
30
- this.dropdowns.delete(dropdown.getId());
30
+ const id = dropdown.getId();
31
+ this.removeFromSubmenuIds(id);
32
+ this.dropdowns.delete(id);
33
+ }
34
+ removeFromSubmenuIds(id) {
35
+ this.dropdowns.forEach((dropdown) => {
36
+ const submenuIds = this.submenuIds[dropdown.getId()];
37
+ if (submenuIds) {
38
+ const index = submenuIds.indexOf(id);
39
+ if (index > -1) {
40
+ submenuIds.splice(index, 1);
41
+ }
42
+ }
43
+ });
44
+ delete this.submenuIds[id];
45
+ }
46
+ getDropdownById(id) {
47
+ return this.dropdowns.get(id);
31
48
  }
32
49
  discoverSubmenus() {
33
50
  this.dropdowns.forEach((dropdown) => {
@@ -35,7 +52,8 @@ class DropdownController {
35
52
  });
36
53
  }
37
54
  present(dropdown) {
38
- if (!dropdown.isPresent() && dropdown.willPresent()) {
55
+ var _a;
56
+ if (!dropdown.isPresent() && ((_a = dropdown.willPresent) === null || _a === void 0 ? void 0 : _a.call(dropdown))) {
39
57
  this.submenuIds[dropdown.getId()] = dropdown.getAssignedSubmenuIds();
40
58
  dropdown.present();
41
59
  }
@@ -43,11 +61,15 @@ class DropdownController {
43
61
  dismissChildren(uid) {
44
62
  const childIds = this.submenuIds[uid] || [];
45
63
  for (const id of childIds) {
46
- this.dismiss(this.dropdowns.get(id));
64
+ const dropdown = this.dropdowns.get(id);
65
+ if (dropdown) {
66
+ this.dismiss(dropdown);
67
+ }
47
68
  }
48
69
  }
49
70
  dismiss(dropdown) {
50
- if (dropdown.isPresent() && dropdown.willDismiss()) {
71
+ var _a;
72
+ if (dropdown.isPresent() && ((_a = dropdown.willDismiss) === null || _a === void 0 ? void 0 : _a.call(dropdown))) {
51
73
  this.dismissChildren(dropdown.getId());
52
74
  dropdown.dismiss();
53
75
  delete this.submenuIds[dropdown.getId()];
@@ -127,15 +149,5 @@ class DropdownController {
127
149
  });
128
150
  }
129
151
  }
130
- export const addDisposableEventListener = (element, eventType, callback) => {
131
- element.addEventListener(eventType, callback);
132
- return () => {
133
- element.removeEventListener(eventType, callback);
134
- };
135
- };
136
- export const addDisposableEventListenerAsArray = (listener) => {
137
- const disposables = listener.map(({ callback, element, eventType }) => addDisposableEventListener(element, eventType, callback));
138
- return () => disposables.forEach((dispose) => dispose());
139
- };
140
152
  export const dropdownController = new DropdownController();
141
153
  //# sourceMappingURL=dropdown-controller.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"dropdown-controller.js","sourceRoot":"","sources":["../../../src/components/dropdown/dropdown-controller.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 { IxComponent } from '../utils/internal';\nexport type CloseBehavior = 'inside' | 'outside' | 'both' | boolean;\n\nexport interface DropdownInterface extends IxComponent {\n closeBehavior: CloseBehavior;\n discoverAllSubmenus: boolean;\n\n getAssignedSubmenuIds(): string[];\n getId(): string;\n\n discoverSubmenu(): void;\n\n isPresent(): boolean;\n\n willPresent?(): boolean;\n willDismiss?(): boolean;\n\n present(): void;\n dismiss(): void;\n}\n\nexport function hasDropdownItemWrapperImplemented(\n item: unknown\n): item is DropdownItemWrapper {\n return (\n item &&\n (item as DropdownItemWrapper).getDropdownItemElement !== undefined &&\n typeof (item as DropdownItemWrapper).getDropdownItemElement === 'function'\n );\n}\n\nexport interface DropdownItemWrapper {\n getDropdownItemElement(): Promise<HTMLIxDropdownItemElement>;\n}\n\ntype SubmenuIds = Record<string, string[]>;\n\nclass DropdownController {\n private dropdowns: Map<string, DropdownInterface> = new Map<\n string,\n DropdownInterface\n >();\n private submenuIds: SubmenuIds = {};\n\n private isWindowListenerActive = false;\n\n connected(dropdown: DropdownInterface) {\n if (!this.isWindowListenerActive) {\n this.addOverlayListeners();\n }\n this.dropdowns.set(dropdown.getId(), dropdown);\n\n if (dropdown.discoverAllSubmenus) {\n this.discoverSubmenus();\n }\n }\n\n disconnected(dropdown: DropdownInterface) {\n this.dropdowns.delete(dropdown.getId());\n }\n\n discoverSubmenus() {\n this.dropdowns.forEach((dropdown) => {\n dropdown.discoverSubmenu();\n });\n }\n\n present(dropdown: DropdownInterface) {\n if (!dropdown.isPresent() && dropdown.willPresent()) {\n this.submenuIds[dropdown.getId()] = dropdown.getAssignedSubmenuIds();\n dropdown.present();\n }\n }\n\n dismissChildren(uid: string) {\n const childIds = this.submenuIds[uid] || [];\n for (const id of childIds) {\n this.dismiss(this.dropdowns.get(id));\n }\n }\n\n dismiss(dropdown: DropdownInterface) {\n if (dropdown.isPresent() && dropdown.willDismiss()) {\n this.dismissChildren(dropdown.getId());\n dropdown.dismiss();\n delete this.submenuIds[dropdown.getId()];\n }\n }\n\n dismissAll(\n ignoreBehaviorForIds: string[] = [],\n ignoreRelatedDropdowns = false\n ) {\n this.dropdowns.forEach((dropdown) => {\n const preventClosing =\n dropdown.closeBehavior === 'inside' || dropdown.closeBehavior === false;\n\n const shouldIgnore = ignoreBehaviorForIds.includes(dropdown.getId());\n const path = this.buildComposedPath(dropdown.getId(), new Set<string>());\n\n if (ignoreBehaviorForIds.length > 0 && ignoreRelatedDropdowns) {\n let skipRelatedDropdown = false;\n\n ignoreBehaviorForIds.forEach((id) => {\n if (path.has(id)) {\n skipRelatedDropdown = true;\n return;\n }\n });\n\n if (!skipRelatedDropdown) {\n return;\n }\n }\n\n if (!shouldIgnore && preventClosing) {\n return;\n }\n\n this.dismiss(dropdown);\n });\n }\n\n dismissOthers(uid: string) {\n let path = this.buildComposedPath(uid, new Set<string>());\n path.add(uid);\n\n this.dropdowns.forEach((dropdown) => {\n if (\n dropdown.closeBehavior !== 'inside' &&\n dropdown.closeBehavior !== false &&\n !path.has(dropdown.getId())\n ) {\n this.dismiss(dropdown);\n }\n });\n }\n\n pathIncludesTrigger(eventTargets: EventTarget[]) {\n for (let eventTarget of eventTargets) {\n if (eventTarget instanceof HTMLElement) {\n if (eventTarget.hasAttribute('data-ix-dropdown-trigger')) {\n return eventTarget;\n }\n }\n }\n\n return;\n }\n\n private pathIncludesDropdown(eventTargets: EventTarget[]) {\n return !!eventTargets.find(\n (element: HTMLElement) => element.tagName === 'IX-DROPDOWN'\n );\n }\n\n private buildComposedPath(id: string, path: Set<string>): Set<string> {\n if (this.submenuIds[id]) {\n path.add(id);\n }\n\n for (const ruleKey of Object.keys(this.submenuIds)) {\n if (this.submenuIds[ruleKey].includes(id)) {\n this.buildComposedPath(ruleKey, path).forEach((key) => path.add(key));\n }\n }\n\n return path;\n }\n\n private addOverlayListeners() {\n this.isWindowListenerActive = true;\n\n window.addEventListener('click', (event: PointerEvent) => {\n const hasTrigger = this.pathIncludesTrigger(event.composedPath());\n const hasDropdown = this.pathIncludesDropdown(event.composedPath());\n\n if (!hasTrigger && !hasDropdown) {\n this.dismissAll();\n }\n });\n\n window.addEventListener('keydown', (event: KeyboardEvent) => {\n if (event.key === 'Escape') {\n this.dismissAll([...this.dropdowns.keys()]);\n }\n });\n }\n}\n\nexport const addDisposableEventListener = (\n element: Element | Window | Document,\n eventType: string,\n callback: EventListenerOrEventListenerObject\n) => {\n element.addEventListener(eventType, callback);\n\n return () => {\n element.removeEventListener(eventType, callback);\n };\n};\n\nexport const addDisposableEventListenerAsArray = (\n listener: {\n element: Element | Window | Document;\n eventType: string;\n callback: EventListenerOrEventListenerObject;\n }[]\n) => {\n const disposables = listener.map(({ callback, element, eventType }) =>\n addDisposableEventListener(element, eventType, callback)\n );\n\n return () => disposables.forEach((dispose) => dispose());\n};\n\nexport const dropdownController = new DropdownController();\n"]}
1
+ {"version":3,"file":"dropdown-controller.js","sourceRoot":"","sources":["../../../src/components/dropdown/dropdown-controller.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 { IxComponent } from '../utils/internal';\nexport type CloseBehavior = 'inside' | 'outside' | 'both' | boolean;\n\nexport interface DropdownInterface extends IxComponent {\n closeBehavior: CloseBehavior;\n discoverAllSubmenus: boolean;\n\n getAssignedSubmenuIds(): string[];\n getId(): string;\n\n discoverSubmenu(): void;\n\n isPresent(): boolean;\n\n willPresent?(): boolean;\n willDismiss?(): boolean;\n\n present(): void;\n dismiss(): void;\n}\n\nexport function hasDropdownItemWrapperImplemented(\n item: unknown\n): item is DropdownItemWrapper {\n return (\n item !== null &&\n (item as DropdownItemWrapper).getDropdownItemElement !== undefined &&\n typeof (item as DropdownItemWrapper).getDropdownItemElement === 'function'\n );\n}\n\nexport interface DropdownItemWrapper {\n getDropdownItemElement(): Promise<HTMLIxDropdownItemElement>;\n}\n\ntype SubmenuIds = Record<string, string[]>;\n\nclass DropdownController {\n private readonly dropdowns: Map<string, DropdownInterface> = new Map<\n string,\n DropdownInterface\n >();\n private submenuIds: SubmenuIds = {};\n\n private isWindowListenerActive = false;\n\n connected(dropdown: DropdownInterface) {\n if (!this.isWindowListenerActive) {\n this.addOverlayListeners();\n }\n this.dropdowns.set(dropdown.getId(), dropdown);\n\n if (dropdown.discoverAllSubmenus) {\n this.discoverSubmenus();\n }\n }\n\n disconnected(dropdown: DropdownInterface) {\n const id = dropdown.getId();\n this.removeFromSubmenuIds(id);\n this.dropdowns.delete(id);\n }\n\n removeFromSubmenuIds(id: string) {\n this.dropdowns.forEach((dropdown) => {\n const submenuIds = this.submenuIds[dropdown.getId()];\n if (submenuIds) {\n const index = submenuIds.indexOf(id);\n if (index > -1) {\n submenuIds.splice(index, 1);\n }\n }\n });\n\n delete this.submenuIds[id];\n }\n\n getDropdownById(id: string) {\n return this.dropdowns.get(id);\n }\n\n discoverSubmenus() {\n this.dropdowns.forEach((dropdown) => {\n dropdown.discoverSubmenu();\n });\n }\n\n present(dropdown: DropdownInterface) {\n if (!dropdown.isPresent() && dropdown.willPresent?.()) {\n this.submenuIds[dropdown.getId()] = dropdown.getAssignedSubmenuIds();\n dropdown.present();\n }\n }\n\n dismissChildren(uid: string) {\n const childIds = this.submenuIds[uid] || [];\n for (const id of childIds) {\n const dropdown = this.dropdowns.get(id);\n if (dropdown) {\n this.dismiss(dropdown);\n }\n }\n }\n\n dismiss(dropdown: DropdownInterface) {\n if (dropdown.isPresent() && dropdown.willDismiss?.()) {\n this.dismissChildren(dropdown.getId());\n dropdown.dismiss();\n delete this.submenuIds[dropdown.getId()];\n }\n }\n\n dismissAll(\n ignoreBehaviorForIds: string[] = [],\n ignoreRelatedDropdowns = false\n ) {\n this.dropdowns.forEach((dropdown) => {\n const preventClosing =\n dropdown.closeBehavior === 'inside' || dropdown.closeBehavior === false;\n\n const shouldIgnore = ignoreBehaviorForIds.includes(dropdown.getId());\n const path = this.buildComposedPath(dropdown.getId(), new Set<string>());\n\n if (ignoreBehaviorForIds.length > 0 && ignoreRelatedDropdowns) {\n let skipRelatedDropdown = false;\n\n ignoreBehaviorForIds.forEach((id) => {\n if (path.has(id)) {\n skipRelatedDropdown = true;\n return;\n }\n });\n\n if (!skipRelatedDropdown) {\n return;\n }\n }\n\n if (!shouldIgnore && preventClosing) {\n return;\n }\n\n this.dismiss(dropdown);\n });\n }\n\n dismissOthers(uid: string) {\n let path = this.buildComposedPath(uid, new Set<string>());\n path.add(uid);\n\n this.dropdowns.forEach((dropdown) => {\n if (\n dropdown.closeBehavior !== 'inside' &&\n dropdown.closeBehavior !== false &&\n !path.has(dropdown.getId())\n ) {\n this.dismiss(dropdown);\n }\n });\n }\n\n pathIncludesTrigger(eventTargets: EventTarget[]) {\n for (let eventTarget of eventTargets) {\n if (eventTarget instanceof HTMLElement) {\n if (eventTarget.hasAttribute('data-ix-dropdown-trigger')) {\n return eventTarget;\n }\n }\n }\n\n return;\n }\n\n private pathIncludesDropdown(eventTargets: EventTarget[]) {\n return !!eventTargets.find(\n (element: EventTarget) =>\n (element as HTMLElement).tagName === 'IX-DROPDOWN'\n );\n }\n\n private buildComposedPath(id: string, path: Set<string>): Set<string> {\n if (this.submenuIds[id]) {\n path.add(id);\n }\n\n for (const ruleKey of Object.keys(this.submenuIds)) {\n if (this.submenuIds[ruleKey].includes(id)) {\n this.buildComposedPath(ruleKey, path).forEach((key) => path.add(key));\n }\n }\n\n return path;\n }\n\n private addOverlayListeners() {\n this.isWindowListenerActive = true;\n\n window.addEventListener('click', (event: MouseEvent) => {\n const hasTrigger = this.pathIncludesTrigger(event.composedPath());\n const hasDropdown = this.pathIncludesDropdown(event.composedPath());\n\n if (!hasTrigger && !hasDropdown) {\n this.dismissAll();\n }\n });\n\n window.addEventListener('keydown', (event: KeyboardEvent) => {\n if (event.key === 'Escape') {\n this.dismissAll([...this.dropdowns.keys()]);\n }\n });\n }\n}\n\nexport const dropdownController = new DropdownController();\n"]}