@public-ui/components 4.1.2-rc.1 → 4.1.2-rc.3

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 (764) hide show
  1. package/assets/kolicons/kolicons.eot +0 -0
  2. package/assets/kolicons/kolicons.ttf +0 -0
  3. package/assets/kolicons/kolicons.woff +0 -0
  4. package/assets/kolicons/kolicons.woff2 +0 -0
  5. package/assets/kolicons/style.css +6 -6
  6. package/custom-elements.json +155 -622
  7. package/dist/cjs/{Alert-Cw9sZoxW.js → Alert-go6x5H58.js} +1 -1
  8. package/dist/cjs/{Alert-Cw9sZoxW.js.map → Alert-go6x5H58.js.map} +1 -1
  9. package/dist/cjs/{Collapsible-W9myHFxA.js → Collapsible-KPU2LnRh.js} +1 -1
  10. package/dist/cjs/{Collapsible-W9myHFxA.js.map → Collapsible-KPU2LnRh.js.map} +1 -1
  11. package/dist/cjs/{CustomSuggestionsOptionsGroup-BTWrYAk-.js → CustomSuggestionsOptionsGroup-B4vOsNIs.js} +1 -1
  12. package/dist/cjs/{CustomSuggestionsOptionsGroup-BTWrYAk-.js.map → CustomSuggestionsOptionsGroup-B4vOsNIs.js.map} +1 -1
  13. package/dist/cjs/{FieldControlStateWrapper-C_inrfM7.js → FieldControlStateWrapper-n5xf19R3.js} +1 -1
  14. package/dist/cjs/{FieldControlStateWrapper-C_inrfM7.js.map → FieldControlStateWrapper-n5xf19R3.js.map} +1 -1
  15. package/dist/cjs/{FormFieldStateWrapper-4lfwXY_q.js → FormFieldStateWrapper-BO4uGD3W.js} +1 -1
  16. package/dist/cjs/{FormFieldStateWrapper-4lfwXY_q.js.map → FormFieldStateWrapper-BO4uGD3W.js.map} +1 -1
  17. package/dist/cjs/{Heading-C12RqDRf.js → Heading-DdVVf7u7.js} +1 -1
  18. package/dist/cjs/{Heading-C12RqDRf.js.map → Heading-DdVVf7u7.js.map} +1 -1
  19. package/dist/cjs/{Input-EcHO3kdR.js → Input-v3eYbRHb.js} +1 -1
  20. package/dist/cjs/{Input-EcHO3kdR.js.map → Input-v3eYbRHb.js.map} +1 -1
  21. package/dist/cjs/{InputStateWrapper-Bo6IoxAD.js → InputStateWrapper-BwRKTUeb.js} +1 -1
  22. package/dist/cjs/{InputStateWrapper-Bo6IoxAD.js.map → InputStateWrapper-BwRKTUeb.js.map} +1 -1
  23. package/dist/cjs/{app-globals-BhcKC4Ox.js → app-globals-E-almuqA.js} +1 -1
  24. package/dist/cjs/{app-globals-BhcKC4Ox.js.map → app-globals-E-almuqA.js.map} +1 -1
  25. package/dist/cjs/{associated.controller-CWsCf1nv.js → associated.controller-DmDwjGKd.js} +1 -1
  26. package/dist/cjs/{associated.controller-CWsCf1nv.js.map → associated.controller-DmDwjGKd.js.map} +1 -1
  27. package/dist/cjs/{bootstrap-CT2-lyBv.js → bootstrap-DDTG6qkT.js} +1 -1
  28. package/dist/cjs/{bootstrap-CT2-lyBv.js.map → bootstrap-DDTG6qkT.js.map} +1 -1
  29. package/dist/cjs/{component-D-qiYnI6.js → component-BD-Su794.js} +1 -1
  30. package/dist/cjs/{component-D-qiYnI6.js.map → component-BD-Su794.js.map} +1 -1
  31. package/dist/cjs/{component-DceU4ORK.js → component-CN71YSgI.js} +1 -1
  32. package/dist/cjs/{component-DceU4ORK.js.map → component-CN71YSgI.js.map} +1 -1
  33. package/dist/cjs/component-names-5aGrrIj9.js +4 -0
  34. package/dist/cjs/component-names-5aGrrIj9.js.map +1 -0
  35. package/dist/cjs/{controller-CnGbboNY.js → controller-BnpFb2DM.js} +1 -1
  36. package/dist/cjs/{controller-CnGbboNY.js.map → controller-BnpFb2DM.js.map} +1 -1
  37. package/dist/cjs/{controller-Clk7RX5l.js → controller-CUu2m-P4.js} +1 -1
  38. package/dist/cjs/{controller-Clk7RX5l.js.map → controller-CUu2m-P4.js.map} +1 -1
  39. package/dist/cjs/controller-CiyCFtUC.js +4 -0
  40. package/dist/cjs/{controller-CJLYpbTW.js.map → controller-CiyCFtUC.js.map} +1 -1
  41. package/dist/cjs/{controller-DFIu7HVA.js → controller-CsN2zb60.js} +1 -1
  42. package/dist/cjs/{controller-DFIu7HVA.js.map → controller-CsN2zb60.js.map} +1 -1
  43. package/dist/cjs/{controller-16gxT6uy.js → controller-D1-Z2gOH.js} +1 -1
  44. package/dist/cjs/{controller-16gxT6uy.js.map → controller-D1-Z2gOH.js.map} +1 -1
  45. package/dist/cjs/{controller-icon-BzDGBbsy.js → controller-icon-9MagAFeg.js} +1 -1
  46. package/dist/cjs/{controller-icon-BzDGBbsy.js.map → controller-icon-9MagAFeg.js.map} +1 -1
  47. package/dist/cjs/{dev.utils-Cd8lnY8W.js → dev.utils-2a8s8lTP.js} +1 -1
  48. package/dist/cjs/{dev.utils-Cd8lnY8W.js.map → dev.utils-2a8s8lTP.js.map} +1 -1
  49. package/dist/cjs/{devtools-CcQTicOw.js → devtools-Cry9oxrq.js} +1 -1
  50. package/dist/cjs/{devtools-CcQTicOw.js.map → devtools-Cry9oxrq.js.map} +1 -1
  51. package/dist/{esm/index-Cgf1FZ14.js → cjs/index-DyLDXxp-.js} +1 -1
  52. package/dist/cjs/{index-BDC4d4pa.js.map → index-DyLDXxp-.js.map} +1 -1
  53. package/dist/cjs/index.cjs.js +1 -1
  54. package/dist/cjs/kol-abbr.cjs.entry.js +1 -1
  55. package/dist/cjs/kol-abbr.entry.cjs.js.map +1 -1
  56. package/dist/cjs/kol-accordion.cjs.entry.js +1 -1
  57. package/dist/cjs/kol-accordion.entry.cjs.js.map +1 -1
  58. package/dist/cjs/kol-alert-wc.cjs.entry.js +1 -1
  59. package/dist/cjs/kol-alert-wc.entry.cjs.js.map +1 -1
  60. package/dist/cjs/kol-alert.cjs.entry.js +1 -1
  61. package/dist/cjs/kol-alert.entry.cjs.js.map +1 -1
  62. package/dist/cjs/kol-avatar.cjs.entry.js +1 -1
  63. package/dist/cjs/kol-avatar.entry.cjs.js.map +1 -1
  64. package/dist/cjs/kol-badge.cjs.entry.js +1 -1
  65. package/dist/cjs/kol-badge.entry.cjs.js.map +1 -1
  66. package/dist/cjs/kol-breadcrumb.cjs.entry.js +1 -1
  67. package/dist/cjs/kol-breadcrumb.entry.cjs.js.map +1 -1
  68. package/dist/cjs/kol-button-link.cjs.entry.js +1 -1
  69. package/dist/cjs/kol-button-link.entry.cjs.js.map +1 -1
  70. package/dist/cjs/kol-button-wc.cjs.entry.js +1 -1
  71. package/dist/cjs/kol-button-wc.entry.cjs.js.map +1 -1
  72. package/dist/cjs/kol-button.cjs.entry.js +1 -1
  73. package/dist/cjs/kol-button.entry.cjs.js.map +1 -1
  74. package/dist/cjs/kol-card-wc.cjs.entry.js +1 -1
  75. package/dist/cjs/kol-card-wc.entry.cjs.js.map +1 -1
  76. package/dist/cjs/kol-card.cjs.entry.js +1 -1
  77. package/dist/cjs/kol-card.entry.cjs.js.map +1 -1
  78. package/dist/cjs/kol-click-button.cjs.entry.js +1 -1
  79. package/dist/cjs/kol-click-button.entry.cjs.js.map +1 -1
  80. package/dist/cjs/kol-combobox.cjs.entry.js +1 -1
  81. package/dist/cjs/kol-combobox.entry.cjs.js.map +1 -1
  82. package/dist/cjs/kol-details.cjs.entry.js +1 -1
  83. package/dist/cjs/kol-details.entry.cjs.js.map +1 -1
  84. package/dist/cjs/kol-dialog-wc.cjs.entry.js +1 -1
  85. package/dist/cjs/kol-dialog.cjs.entry.js +1 -1
  86. package/dist/cjs/kol-dialog.entry.cjs.js.map +1 -1
  87. package/dist/cjs/kol-drawer.cjs.entry.js +1 -1
  88. package/dist/cjs/kol-drawer.entry.cjs.js.map +1 -1
  89. package/dist/cjs/kol-form.cjs.entry.js +1 -1
  90. package/dist/cjs/kol-form.entry.cjs.js.map +1 -1
  91. package/dist/cjs/kol-heading.cjs.entry.js +1 -1
  92. package/dist/cjs/kol-heading.entry.cjs.js.map +1 -1
  93. package/dist/cjs/kol-icon.cjs.entry.js +1 -1
  94. package/dist/cjs/kol-icon.entry.cjs.js.map +1 -1
  95. package/dist/cjs/kol-image.cjs.entry.js +1 -1
  96. package/dist/cjs/kol-image.entry.cjs.js.map +1 -1
  97. package/dist/cjs/kol-input-checkbox.cjs.entry.js +1 -1
  98. package/dist/cjs/kol-input-checkbox.entry.cjs.js.map +1 -1
  99. package/dist/cjs/kol-input-color.cjs.entry.js +1 -1
  100. package/dist/cjs/kol-input-color.entry.cjs.js.map +1 -1
  101. package/dist/cjs/kol-input-date.cjs.entry.js +1 -1
  102. package/dist/cjs/kol-input-date.entry.cjs.js.map +1 -1
  103. package/dist/cjs/kol-input-email.cjs.entry.js +1 -1
  104. package/dist/cjs/kol-input-email.entry.cjs.js.map +1 -1
  105. package/dist/cjs/kol-input-file.cjs.entry.js +1 -1
  106. package/dist/cjs/kol-input-file.entry.cjs.js.map +1 -1
  107. package/dist/cjs/kol-input-number.cjs.entry.js +1 -1
  108. package/dist/cjs/kol-input-number.entry.cjs.js.map +1 -1
  109. package/dist/cjs/kol-input-password.cjs.entry.js +1 -1
  110. package/dist/cjs/kol-input-password.entry.cjs.js.map +1 -1
  111. package/dist/cjs/kol-input-radio.cjs.entry.js +1 -1
  112. package/dist/cjs/kol-input-radio.entry.cjs.js.map +1 -1
  113. package/dist/cjs/kol-input-range.cjs.entry.js +1 -1
  114. package/dist/cjs/kol-input-range.entry.cjs.js.map +1 -1
  115. package/dist/cjs/kol-input-text.cjs.entry.js +1 -1
  116. package/dist/cjs/kol-input-text.entry.cjs.js.map +1 -1
  117. package/dist/cjs/kol-kolibri.cjs.entry.js +1 -1
  118. package/dist/cjs/kol-kolibri.entry.cjs.js.map +1 -1
  119. package/dist/cjs/kol-link-button.cjs.entry.js +1 -1
  120. package/dist/cjs/kol-link-button.entry.cjs.js.map +1 -1
  121. package/dist/cjs/kol-link-wc.cjs.entry.js +1 -1
  122. package/dist/cjs/kol-link.cjs.entry.js +1 -1
  123. package/dist/cjs/kol-link.entry.cjs.js.map +1 -1
  124. package/dist/cjs/kol-modal.cjs.entry.js +1 -1
  125. package/dist/cjs/kol-modal.entry.cjs.js.map +1 -1
  126. package/dist/cjs/kol-nav.cjs.entry.js +1 -1
  127. package/dist/cjs/kol-nav.entry.cjs.js.map +1 -1
  128. package/dist/cjs/kol-pagination-wc.cjs.entry.js +1 -1
  129. package/dist/cjs/kol-pagination-wc.entry.cjs.js.map +1 -1
  130. package/dist/cjs/kol-pagination.cjs.entry.js +1 -1
  131. package/dist/cjs/kol-pagination.entry.cjs.js.map +1 -1
  132. package/dist/cjs/kol-popover-button-wc.cjs.entry.js +1 -1
  133. package/dist/cjs/kol-popover-button-wc.entry.cjs.js.map +1 -1
  134. package/dist/cjs/kol-popover-button.cjs.entry.js +1 -1
  135. package/dist/cjs/kol-popover-button.entry.cjs.js.map +1 -1
  136. package/dist/cjs/kol-progress.cjs.entry.js +1 -1
  137. package/dist/cjs/kol-progress.entry.cjs.js.map +1 -1
  138. package/dist/cjs/kol-quote.cjs.entry.js +1 -1
  139. package/dist/cjs/kol-quote.entry.cjs.js.map +1 -1
  140. package/dist/cjs/kol-select-wc.cjs.entry.js +1 -1
  141. package/dist/cjs/kol-select-wc.entry.cjs.js.map +1 -1
  142. package/dist/cjs/kol-select.cjs.entry.js +1 -1
  143. package/dist/cjs/kol-select.entry.cjs.js.map +1 -1
  144. package/dist/cjs/kol-single-select.cjs.entry.js +1 -1
  145. package/dist/cjs/kol-single-select.entry.cjs.js.map +1 -1
  146. package/dist/cjs/kol-skeleton.cjs.entry.js +1 -1
  147. package/dist/cjs/kol-skip-nav.cjs.entry.js +1 -1
  148. package/dist/cjs/kol-skip-nav.entry.cjs.js.map +1 -1
  149. package/dist/cjs/kol-spin.cjs.entry.js +1 -1
  150. package/dist/cjs/kol-spin.entry.cjs.js.map +1 -1
  151. package/dist/cjs/kol-split-button.cjs.entry.js +1 -1
  152. package/dist/cjs/kol-split-button.entry.cjs.js.map +1 -1
  153. package/dist/cjs/kol-table-settings-wc.cjs.entry.js +1 -1
  154. package/dist/cjs/kol-table-stateful.cjs.entry.js +1 -1
  155. package/dist/cjs/kol-table-stateful.entry.cjs.js.map +1 -1
  156. package/dist/cjs/kol-table-stateless-wc.cjs.entry.js +1 -1
  157. package/dist/cjs/kol-table-stateless.cjs.entry.js +1 -1
  158. package/dist/cjs/kol-table-stateless.entry.cjs.js.map +1 -1
  159. package/dist/cjs/kol-tabs.cjs.entry.js +1 -1
  160. package/dist/cjs/kol-tabs.entry.cjs.js.map +1 -1
  161. package/dist/cjs/kol-textarea.cjs.entry.js +1 -1
  162. package/dist/cjs/kol-textarea.entry.cjs.js.map +1 -1
  163. package/dist/cjs/kol-toast-container.cjs.entry.js +1 -1
  164. package/dist/cjs/kol-toast-container.entry.cjs.js.map +1 -1
  165. package/dist/cjs/kol-toolbar.cjs.entry.js +1 -1
  166. package/dist/cjs/kol-toolbar.entry.cjs.js.map +1 -1
  167. package/dist/cjs/kol-tooltip-wc.cjs.entry.js +1 -1
  168. package/dist/cjs/kol-tree-item-wc.cjs.entry.js +1 -1
  169. package/dist/cjs/kol-tree-item-wc.entry.cjs.js.map +1 -1
  170. package/dist/cjs/kol-tree-item.cjs.entry.js +1 -1
  171. package/dist/cjs/kol-tree-item.entry.cjs.js.map +1 -1
  172. package/dist/cjs/kol-tree-wc.cjs.entry.js +1 -1
  173. package/dist/cjs/kol-tree.cjs.entry.js +1 -1
  174. package/dist/cjs/kol-tree.entry.cjs.js.map +1 -1
  175. package/dist/cjs/kol-version.cjs.entry.js +1 -1
  176. package/dist/cjs/kol-version.entry.cjs.js.map +1 -1
  177. package/dist/cjs/kolibri.cjs.js +1 -1
  178. package/dist/cjs/loader.cjs.js +1 -1
  179. package/dist/cjs/test-component.cjs.entry.js +1 -1
  180. package/dist/components/component-names.js +1 -1
  181. package/dist/components/component-names.js.map +1 -1
  182. package/dist/components/kol-abbr.js +1 -1
  183. package/dist/components/kol-abbr.js.map +1 -1
  184. package/dist/components/kol-accordion.js +1 -1
  185. package/dist/components/kol-accordion.js.map +1 -1
  186. package/dist/components/kol-alert-wc.js +1 -1
  187. package/dist/components/kol-alert-wc.js.map +1 -1
  188. package/dist/components/kol-alert.js +1 -1
  189. package/dist/components/kol-alert.js.map +1 -1
  190. package/dist/components/kol-avatar.js +1 -1
  191. package/dist/components/kol-avatar.js.map +1 -1
  192. package/dist/components/kol-badge.js +1 -1
  193. package/dist/components/kol-badge.js.map +1 -1
  194. package/dist/components/kol-breadcrumb.js +1 -1
  195. package/dist/components/kol-breadcrumb.js.map +1 -1
  196. package/dist/components/kol-button-link.js +1 -1
  197. package/dist/components/kol-button-link.js.map +1 -1
  198. package/dist/components/kol-button-wc.js +1 -1
  199. package/dist/components/kol-button-wc.js.map +1 -1
  200. package/dist/components/kol-button.js +1 -1
  201. package/dist/components/kol-button.js.map +1 -1
  202. package/dist/components/kol-card-wc.js +1 -1
  203. package/dist/components/kol-card-wc.js.map +1 -1
  204. package/dist/components/kol-card.js +1 -1
  205. package/dist/components/kol-card.js.map +1 -1
  206. package/dist/components/kol-click-button.js +1 -1
  207. package/dist/components/kol-click-button.js.map +1 -1
  208. package/dist/components/kol-combobox.js +1 -1
  209. package/dist/components/kol-combobox.js.map +1 -1
  210. package/dist/components/kol-details.js +1 -1
  211. package/dist/components/kol-details.js.map +1 -1
  212. package/dist/components/kol-dialog.js +1 -1
  213. package/dist/components/kol-dialog.js.map +1 -1
  214. package/dist/components/kol-drawer.js +1 -1
  215. package/dist/components/kol-drawer.js.map +1 -1
  216. package/dist/components/kol-form.js +1 -1
  217. package/dist/components/kol-form.js.map +1 -1
  218. package/dist/components/kol-heading.js +1 -1
  219. package/dist/components/kol-heading.js.map +1 -1
  220. package/dist/components/kol-icon.js +1 -1
  221. package/dist/components/kol-icon.js.map +1 -1
  222. package/dist/components/kol-image.js +1 -1
  223. package/dist/components/kol-image.js.map +1 -1
  224. package/dist/components/kol-input-checkbox.js +1 -1
  225. package/dist/components/kol-input-checkbox.js.map +1 -1
  226. package/dist/components/kol-input-color.js +1 -1
  227. package/dist/components/kol-input-color.js.map +1 -1
  228. package/dist/components/kol-input-date.js +1 -1
  229. package/dist/components/kol-input-date.js.map +1 -1
  230. package/dist/components/kol-input-email.js +1 -1
  231. package/dist/components/kol-input-email.js.map +1 -1
  232. package/dist/components/kol-input-file.js +1 -1
  233. package/dist/components/kol-input-file.js.map +1 -1
  234. package/dist/components/kol-input-number.js +1 -1
  235. package/dist/components/kol-input-number.js.map +1 -1
  236. package/dist/components/kol-input-password.js +1 -1
  237. package/dist/components/kol-input-password.js.map +1 -1
  238. package/dist/components/kol-input-radio.js +1 -1
  239. package/dist/components/kol-input-radio.js.map +1 -1
  240. package/dist/components/kol-input-range.js +1 -1
  241. package/dist/components/kol-input-range.js.map +1 -1
  242. package/dist/components/kol-input-text.js +1 -1
  243. package/dist/components/kol-input-text.js.map +1 -1
  244. package/dist/components/kol-kolibri.js.map +1 -1
  245. package/dist/components/kol-link-button.js +1 -1
  246. package/dist/components/kol-link-button.js.map +1 -1
  247. package/dist/components/kol-link.js +1 -1
  248. package/dist/components/kol-link.js.map +1 -1
  249. package/dist/components/kol-modal.js +1 -1
  250. package/dist/components/kol-modal.js.map +1 -1
  251. package/dist/components/kol-nav.js +1 -1
  252. package/dist/components/kol-nav.js.map +1 -1
  253. package/dist/components/kol-pagination-wc.js.map +1 -1
  254. package/dist/components/kol-pagination.js +1 -1
  255. package/dist/components/kol-pagination.js.map +1 -1
  256. package/dist/components/kol-popover-button-wc.js +1 -1
  257. package/dist/components/kol-popover-button-wc.js.map +1 -1
  258. package/dist/components/kol-popover-button.js +1 -1
  259. package/dist/components/kol-popover-button.js.map +1 -1
  260. package/dist/components/kol-progress.js +1 -1
  261. package/dist/components/kol-progress.js.map +1 -1
  262. package/dist/components/kol-quote.js +1 -1
  263. package/dist/components/kol-quote.js.map +1 -1
  264. package/dist/components/kol-select-wc.js +1 -1
  265. package/dist/components/kol-select-wc.js.map +1 -1
  266. package/dist/components/kol-select.js +1 -1
  267. package/dist/components/kol-select.js.map +1 -1
  268. package/dist/components/kol-single-select.js +1 -1
  269. package/dist/components/kol-single-select.js.map +1 -1
  270. package/dist/components/kol-skeleton.js +1 -1
  271. package/dist/components/kol-skip-nav.js +1 -1
  272. package/dist/components/kol-skip-nav.js.map +1 -1
  273. package/dist/components/kol-spin.js +1 -1
  274. package/dist/components/kol-spin.js.map +1 -1
  275. package/dist/components/kol-split-button.js +1 -1
  276. package/dist/components/kol-split-button.js.map +1 -1
  277. package/dist/components/kol-table-settings-wc.js +1 -1
  278. package/dist/components/kol-table-stateful.js +1 -1
  279. package/dist/components/kol-table-stateful.js.map +1 -1
  280. package/dist/components/kol-table-stateless-wc.js +1 -1
  281. package/dist/components/kol-table-stateless.js +1 -1
  282. package/dist/components/kol-table-stateless.js.map +1 -1
  283. package/dist/components/kol-tabs.js +1 -1
  284. package/dist/components/kol-tabs.js.map +1 -1
  285. package/dist/components/kol-textarea.js +1 -1
  286. package/dist/components/kol-textarea.js.map +1 -1
  287. package/dist/components/kol-toast-container.js +1 -1
  288. package/dist/components/kol-toast-container.js.map +1 -1
  289. package/dist/components/kol-toolbar.js +1 -1
  290. package/dist/components/kol-toolbar.js.map +1 -1
  291. package/dist/components/kol-tooltip-wc.js +1 -1
  292. package/dist/components/kol-tree-item-wc.js +1 -1
  293. package/dist/components/kol-tree-item-wc.js.map +1 -1
  294. package/dist/components/kol-tree-item.js +1 -1
  295. package/dist/components/kol-tree-item.js.map +1 -1
  296. package/dist/components/kol-tree-wc.js +1 -1
  297. package/dist/components/kol-tree.js +1 -1
  298. package/dist/components/kol-tree.js.map +1 -1
  299. package/dist/components/kol-version.js +1 -1
  300. package/dist/components/kol-version.js.map +1 -1
  301. package/dist/esm/{Alert-Cw_LoKSN.js → Alert-Bf3zI0Oz.js} +1 -1
  302. package/dist/{kolibri/Alert-Cw_LoKSN.js.map → esm/Alert-Bf3zI0Oz.js.map} +1 -1
  303. package/dist/esm/{Collapsible-DZA8yQbA.js → Collapsible-CCtIsh_g.js} +1 -1
  304. package/dist/esm/{Collapsible-DZA8yQbA.js.map → Collapsible-CCtIsh_g.js.map} +1 -1
  305. package/dist/esm/{CustomSuggestionsOptionsGroup-B7qeS4jH.js → CustomSuggestionsOptionsGroup-C5-whUT_.js} +1 -1
  306. package/dist/{kolibri/CustomSuggestionsOptionsGroup-B7qeS4jH.js.map → esm/CustomSuggestionsOptionsGroup-C5-whUT_.js.map} +1 -1
  307. package/dist/esm/{FieldControlStateWrapper-B3IEsGo5.js → FieldControlStateWrapper-D4SDQ2L5.js} +1 -1
  308. package/dist/{kolibri/FieldControlStateWrapper-B3IEsGo5.js.map → esm/FieldControlStateWrapper-D4SDQ2L5.js.map} +1 -1
  309. package/dist/esm/{FormFieldStateWrapper-D1JTt3ul.js → FormFieldStateWrapper-IvHw4Awz.js} +1 -1
  310. package/dist/{kolibri/FormFieldStateWrapper-D1JTt3ul.js.map → esm/FormFieldStateWrapper-IvHw4Awz.js.map} +1 -1
  311. package/dist/esm/{Heading-CMmrUlbQ.js → Heading-De11apd1.js} +1 -1
  312. package/dist/{kolibri/Heading-CMmrUlbQ.js.map → esm/Heading-De11apd1.js.map} +1 -1
  313. package/dist/esm/{Input-BtjxL296.js → Input-DcRyLUtC.js} +1 -1
  314. package/dist/esm/{Input-BtjxL296.js.map → Input-DcRyLUtC.js.map} +1 -1
  315. package/dist/esm/{InputStateWrapper-CEMRSPYO.js → InputStateWrapper-KZEMrzyL.js} +1 -1
  316. package/dist/{kolibri/InputStateWrapper-CEMRSPYO.js.map → esm/InputStateWrapper-KZEMrzyL.js.map} +1 -1
  317. package/dist/esm/{app-globals-MFFawMzD.js → app-globals-Gv0NC3KD.js} +1 -1
  318. package/dist/esm/{app-globals-MFFawMzD.js.map → app-globals-Gv0NC3KD.js.map} +1 -1
  319. package/dist/esm/{associated.controller-DCpxG_66.js → associated.controller-DKliwG01.js} +1 -1
  320. package/dist/esm/{associated.controller-DCpxG_66.js.map → associated.controller-DKliwG01.js.map} +1 -1
  321. package/dist/esm/{bootstrap-CyhVeeHa.js → bootstrap-7FNy-lUW.js} +1 -1
  322. package/dist/esm/{bootstrap-CyhVeeHa.js.map → bootstrap-7FNy-lUW.js.map} +1 -1
  323. package/dist/esm/{component-Dy6q6xwI.js → component-BEFjEo85.js} +1 -1
  324. package/dist/esm/{component-Dy6q6xwI.js.map → component-BEFjEo85.js.map} +1 -1
  325. package/dist/esm/{component-BssZbWQw.js → component-DARFRgRf.js} +1 -1
  326. package/dist/esm/{component-BssZbWQw.js.map → component-DARFRgRf.js.map} +1 -1
  327. package/dist/esm/component-names-C64MXeC1.js +4 -0
  328. package/dist/esm/component-names-C64MXeC1.js.map +1 -0
  329. package/dist/esm/{controller-bc3Jqv9j.js → controller-BFJ5Nfs0.js} +1 -1
  330. package/dist/{kolibri/controller-bc3Jqv9j.js.map → esm/controller-BFJ5Nfs0.js.map} +1 -1
  331. package/dist/esm/{controller-D2K5zD5B.js → controller-BShVWk74.js} +1 -1
  332. package/dist/esm/{controller-D2K5zD5B.js.map → controller-BShVWk74.js.map} +1 -1
  333. package/dist/esm/{controller-Bdpk05ma.js → controller-CEBHTDBr.js} +1 -1
  334. package/dist/{kolibri/controller-Bdpk05ma.js.map → esm/controller-CEBHTDBr.js.map} +1 -1
  335. package/dist/esm/{controller-Dcr8l6pm.js → controller-DQOFCySX.js} +1 -1
  336. package/dist/esm/{controller-Dcr8l6pm.js.map → controller-DQOFCySX.js.map} +1 -1
  337. package/dist/esm/{controller-D9pydrRe.js → controller-DRs4TxjK.js} +1 -1
  338. package/dist/{kolibri/controller-D9pydrRe.js.map → esm/controller-DRs4TxjK.js.map} +1 -1
  339. package/dist/esm/{controller-icon-BGyWFin_.js → controller-icon-zJSrVBl2.js} +1 -1
  340. package/dist/esm/{controller-icon-BGyWFin_.js.map → controller-icon-zJSrVBl2.js.map} +1 -1
  341. package/dist/esm/{dev.utils-9aA-dFCs.js → dev.utils-CDB3zpcq.js} +1 -1
  342. package/dist/esm/{dev.utils-9aA-dFCs.js.map → dev.utils-CDB3zpcq.js.map} +1 -1
  343. package/dist/esm/{devtools-Cak1VbpQ.js → devtools-BP4ULoUn.js} +1 -1
  344. package/dist/esm/{devtools-Cak1VbpQ.js.map → devtools-BP4ULoUn.js.map} +1 -1
  345. package/dist/esm/index-B8-Psqw5.js +4 -0
  346. package/dist/{kolibri/index-Cgf1FZ14.js.map → esm/index-B8-Psqw5.js.map} +1 -1
  347. package/dist/esm/index.js +1 -1
  348. package/dist/esm/kol-abbr.entry.js +1 -1
  349. package/dist/esm/kol-abbr.entry.js.map +1 -1
  350. package/dist/esm/kol-accordion.entry.js +1 -1
  351. package/dist/esm/kol-accordion.entry.js.map +1 -1
  352. package/dist/esm/kol-alert-wc.entry.js +1 -1
  353. package/dist/esm/kol-alert-wc.entry.js.map +1 -1
  354. package/dist/esm/kol-alert.entry.js +1 -1
  355. package/dist/esm/kol-alert.entry.js.map +1 -1
  356. package/dist/esm/kol-avatar.entry.js +1 -1
  357. package/dist/esm/kol-avatar.entry.js.map +1 -1
  358. package/dist/esm/kol-badge.entry.js +1 -1
  359. package/dist/esm/kol-badge.entry.js.map +1 -1
  360. package/dist/esm/kol-breadcrumb.entry.js +1 -1
  361. package/dist/esm/kol-breadcrumb.entry.js.map +1 -1
  362. package/dist/esm/kol-button-link.entry.js +1 -1
  363. package/dist/esm/kol-button-link.entry.js.map +1 -1
  364. package/dist/esm/kol-button-wc.entry.js +1 -1
  365. package/dist/esm/kol-button-wc.entry.js.map +1 -1
  366. package/dist/esm/kol-button.entry.js +1 -1
  367. package/dist/esm/kol-button.entry.js.map +1 -1
  368. package/dist/esm/kol-card-wc.entry.js +1 -1
  369. package/dist/esm/kol-card-wc.entry.js.map +1 -1
  370. package/dist/esm/kol-card.entry.js +1 -1
  371. package/dist/esm/kol-card.entry.js.map +1 -1
  372. package/dist/esm/kol-click-button.entry.js +1 -1
  373. package/dist/esm/kol-click-button.entry.js.map +1 -1
  374. package/dist/esm/kol-combobox.entry.js +1 -1
  375. package/dist/esm/kol-combobox.entry.js.map +1 -1
  376. package/dist/esm/kol-details.entry.js +1 -1
  377. package/dist/esm/kol-details.entry.js.map +1 -1
  378. package/dist/esm/kol-dialog-wc.entry.js +1 -1
  379. package/dist/esm/kol-dialog.entry.js +1 -1
  380. package/dist/esm/kol-dialog.entry.js.map +1 -1
  381. package/dist/esm/kol-drawer.entry.js +1 -1
  382. package/dist/esm/kol-drawer.entry.js.map +1 -1
  383. package/dist/esm/kol-form.entry.js +1 -1
  384. package/dist/esm/kol-form.entry.js.map +1 -1
  385. package/dist/esm/kol-heading.entry.js +1 -1
  386. package/dist/esm/kol-heading.entry.js.map +1 -1
  387. package/dist/esm/kol-icon.entry.js +1 -1
  388. package/dist/esm/kol-icon.entry.js.map +1 -1
  389. package/dist/esm/kol-image.entry.js +1 -1
  390. package/dist/esm/kol-image.entry.js.map +1 -1
  391. package/dist/esm/kol-input-checkbox.entry.js +1 -1
  392. package/dist/esm/kol-input-checkbox.entry.js.map +1 -1
  393. package/dist/esm/kol-input-color.entry.js +1 -1
  394. package/dist/esm/kol-input-color.entry.js.map +1 -1
  395. package/dist/esm/kol-input-date.entry.js +1 -1
  396. package/dist/esm/kol-input-date.entry.js.map +1 -1
  397. package/dist/esm/kol-input-email.entry.js +1 -1
  398. package/dist/esm/kol-input-email.entry.js.map +1 -1
  399. package/dist/esm/kol-input-file.entry.js +1 -1
  400. package/dist/esm/kol-input-file.entry.js.map +1 -1
  401. package/dist/esm/kol-input-number.entry.js +1 -1
  402. package/dist/esm/kol-input-number.entry.js.map +1 -1
  403. package/dist/esm/kol-input-password.entry.js +1 -1
  404. package/dist/esm/kol-input-password.entry.js.map +1 -1
  405. package/dist/esm/kol-input-radio.entry.js +1 -1
  406. package/dist/esm/kol-input-radio.entry.js.map +1 -1
  407. package/dist/esm/kol-input-range.entry.js +1 -1
  408. package/dist/esm/kol-input-range.entry.js.map +1 -1
  409. package/dist/esm/kol-input-text.entry.js +1 -1
  410. package/dist/esm/kol-input-text.entry.js.map +1 -1
  411. package/dist/esm/kol-kolibri.entry.js +1 -1
  412. package/dist/esm/kol-kolibri.entry.js.map +1 -1
  413. package/dist/esm/kol-link-button.entry.js +1 -1
  414. package/dist/esm/kol-link-button.entry.js.map +1 -1
  415. package/dist/esm/kol-link-wc.entry.js +1 -1
  416. package/dist/esm/kol-link.entry.js +1 -1
  417. package/dist/esm/kol-link.entry.js.map +1 -1
  418. package/dist/esm/kol-modal.entry.js +1 -1
  419. package/dist/esm/kol-modal.entry.js.map +1 -1
  420. package/dist/esm/kol-nav.entry.js +1 -1
  421. package/dist/esm/kol-nav.entry.js.map +1 -1
  422. package/dist/esm/kol-pagination-wc.entry.js +1 -1
  423. package/dist/esm/kol-pagination-wc.entry.js.map +1 -1
  424. package/dist/esm/kol-pagination.entry.js +1 -1
  425. package/dist/esm/kol-pagination.entry.js.map +1 -1
  426. package/dist/esm/kol-popover-button-wc.entry.js +1 -1
  427. package/dist/esm/kol-popover-button-wc.entry.js.map +1 -1
  428. package/dist/esm/kol-popover-button.entry.js +1 -1
  429. package/dist/esm/kol-popover-button.entry.js.map +1 -1
  430. package/dist/esm/kol-progress.entry.js +1 -1
  431. package/dist/esm/kol-progress.entry.js.map +1 -1
  432. package/dist/esm/kol-quote.entry.js +1 -1
  433. package/dist/esm/kol-quote.entry.js.map +1 -1
  434. package/dist/esm/kol-select-wc.entry.js +1 -1
  435. package/dist/esm/kol-select-wc.entry.js.map +1 -1
  436. package/dist/esm/kol-select.entry.js +1 -1
  437. package/dist/esm/kol-select.entry.js.map +1 -1
  438. package/dist/esm/kol-single-select.entry.js +1 -1
  439. package/dist/esm/kol-single-select.entry.js.map +1 -1
  440. package/dist/esm/kol-skeleton.entry.js +1 -1
  441. package/dist/esm/kol-skip-nav.entry.js +1 -1
  442. package/dist/esm/kol-skip-nav.entry.js.map +1 -1
  443. package/dist/esm/kol-spin.entry.js +1 -1
  444. package/dist/esm/kol-spin.entry.js.map +1 -1
  445. package/dist/esm/kol-split-button.entry.js +1 -1
  446. package/dist/esm/kol-split-button.entry.js.map +1 -1
  447. package/dist/esm/kol-table-settings-wc.entry.js +1 -1
  448. package/dist/esm/kol-table-stateful.entry.js +1 -1
  449. package/dist/esm/kol-table-stateful.entry.js.map +1 -1
  450. package/dist/esm/kol-table-stateless-wc.entry.js +1 -1
  451. package/dist/esm/kol-table-stateless.entry.js +1 -1
  452. package/dist/esm/kol-table-stateless.entry.js.map +1 -1
  453. package/dist/esm/kol-tabs.entry.js +1 -1
  454. package/dist/esm/kol-tabs.entry.js.map +1 -1
  455. package/dist/esm/kol-textarea.entry.js +1 -1
  456. package/dist/esm/kol-textarea.entry.js.map +1 -1
  457. package/dist/esm/kol-toast-container.entry.js +1 -1
  458. package/dist/esm/kol-toast-container.entry.js.map +1 -1
  459. package/dist/esm/kol-toolbar.entry.js +1 -1
  460. package/dist/esm/kol-toolbar.entry.js.map +1 -1
  461. package/dist/esm/kol-tooltip-wc.entry.js +1 -1
  462. package/dist/esm/kol-tree-item-wc.entry.js +1 -1
  463. package/dist/esm/kol-tree-item-wc.entry.js.map +1 -1
  464. package/dist/esm/kol-tree-item.entry.js +1 -1
  465. package/dist/esm/kol-tree-item.entry.js.map +1 -1
  466. package/dist/esm/kol-tree-wc.entry.js +1 -1
  467. package/dist/esm/kol-tree.entry.js +1 -1
  468. package/dist/esm/kol-tree.entry.js.map +1 -1
  469. package/dist/esm/kol-version.entry.js +1 -1
  470. package/dist/esm/kol-version.entry.js.map +1 -1
  471. package/dist/esm/kolibri.js +1 -1
  472. package/dist/esm/loader.js +1 -1
  473. package/dist/esm/test-component.entry.js +1 -1
  474. package/dist/kolibri/Alert-Bf3zI0Oz.js +4 -0
  475. package/dist/{esm/Alert-Cw_LoKSN.js.map → kolibri/Alert-Bf3zI0Oz.js.map} +1 -1
  476. package/dist/kolibri/{Collapsible-DZA8yQbA.js → Collapsible-CCtIsh_g.js} +1 -1
  477. package/dist/kolibri/{Collapsible-DZA8yQbA.js.map → Collapsible-CCtIsh_g.js.map} +1 -1
  478. package/dist/kolibri/{CustomSuggestionsOptionsGroup-B7qeS4jH.js → CustomSuggestionsOptionsGroup-C5-whUT_.js} +1 -1
  479. package/dist/{esm/CustomSuggestionsOptionsGroup-B7qeS4jH.js.map → kolibri/CustomSuggestionsOptionsGroup-C5-whUT_.js.map} +1 -1
  480. package/dist/kolibri/FieldControlStateWrapper-D4SDQ2L5.js +4 -0
  481. package/dist/{esm/FieldControlStateWrapper-B3IEsGo5.js.map → kolibri/FieldControlStateWrapper-D4SDQ2L5.js.map} +1 -1
  482. package/dist/kolibri/{FormFieldStateWrapper-D1JTt3ul.js → FormFieldStateWrapper-IvHw4Awz.js} +1 -1
  483. package/dist/{esm/FormFieldStateWrapper-D1JTt3ul.js.map → kolibri/FormFieldStateWrapper-IvHw4Awz.js.map} +1 -1
  484. package/dist/kolibri/{Heading-CMmrUlbQ.js → Heading-De11apd1.js} +1 -1
  485. package/dist/{esm/Heading-CMmrUlbQ.js.map → kolibri/Heading-De11apd1.js.map} +1 -1
  486. package/dist/kolibri/Input-DcRyLUtC.js +4 -0
  487. package/dist/kolibri/{Input-BtjxL296.js.map → Input-DcRyLUtC.js.map} +1 -1
  488. package/dist/kolibri/InputStateWrapper-KZEMrzyL.js +4 -0
  489. package/dist/{esm/InputStateWrapper-CEMRSPYO.js.map → kolibri/InputStateWrapper-KZEMrzyL.js.map} +1 -1
  490. package/dist/kolibri/app-globals-Gv0NC3KD.js +4 -0
  491. package/dist/kolibri/{app-globals-MFFawMzD.js.map → app-globals-Gv0NC3KD.js.map} +1 -1
  492. package/dist/kolibri/{associated.controller-DCpxG_66.js → associated.controller-DKliwG01.js} +1 -1
  493. package/dist/kolibri/{associated.controller-DCpxG_66.js.map → associated.controller-DKliwG01.js.map} +1 -1
  494. package/dist/kolibri/{bootstrap-CyhVeeHa.js → bootstrap-7FNy-lUW.js} +1 -1
  495. package/dist/kolibri/{bootstrap-CyhVeeHa.js.map → bootstrap-7FNy-lUW.js.map} +1 -1
  496. package/dist/kolibri/{component-Dy6q6xwI.js → component-BEFjEo85.js} +1 -1
  497. package/dist/kolibri/{component-Dy6q6xwI.js.map → component-BEFjEo85.js.map} +1 -1
  498. package/dist/kolibri/{component-BssZbWQw.js → component-DARFRgRf.js} +1 -1
  499. package/dist/kolibri/{component-BssZbWQw.js.map → component-DARFRgRf.js.map} +1 -1
  500. package/dist/kolibri/component-names-C64MXeC1.js +4 -0
  501. package/dist/kolibri/component-names-C64MXeC1.js.map +1 -0
  502. package/dist/kolibri/{controller-bc3Jqv9j.js → controller-BFJ5Nfs0.js} +1 -1
  503. package/dist/{esm/controller-bc3Jqv9j.js.map → kolibri/controller-BFJ5Nfs0.js.map} +1 -1
  504. package/dist/kolibri/{controller-D2K5zD5B.js → controller-BShVWk74.js} +1 -1
  505. package/dist/kolibri/{controller-D2K5zD5B.js.map → controller-BShVWk74.js.map} +1 -1
  506. package/dist/kolibri/{controller-Bdpk05ma.js → controller-CEBHTDBr.js} +1 -1
  507. package/dist/{esm/controller-Bdpk05ma.js.map → kolibri/controller-CEBHTDBr.js.map} +1 -1
  508. package/dist/kolibri/{controller-Dcr8l6pm.js → controller-DQOFCySX.js} +1 -1
  509. package/dist/kolibri/{controller-Dcr8l6pm.js.map → controller-DQOFCySX.js.map} +1 -1
  510. package/dist/kolibri/{controller-D9pydrRe.js → controller-DRs4TxjK.js} +1 -1
  511. package/dist/{esm/controller-D9pydrRe.js.map → kolibri/controller-DRs4TxjK.js.map} +1 -1
  512. package/dist/kolibri/{controller-icon-BGyWFin_.js → controller-icon-zJSrVBl2.js} +1 -1
  513. package/dist/kolibri/{controller-icon-BGyWFin_.js.map → controller-icon-zJSrVBl2.js.map} +1 -1
  514. package/dist/kolibri/{dev.utils-9aA-dFCs.js → dev.utils-CDB3zpcq.js} +1 -1
  515. package/dist/kolibri/{dev.utils-9aA-dFCs.js.map → dev.utils-CDB3zpcq.js.map} +1 -1
  516. package/dist/kolibri/{devtools-Cak1VbpQ.js → devtools-BP4ULoUn.js} +1 -1
  517. package/dist/kolibri/{devtools-Cak1VbpQ.js.map → devtools-BP4ULoUn.js.map} +1 -1
  518. package/dist/kolibri/{index-Cgf1FZ14.js → index-B8-Psqw5.js} +1 -1
  519. package/dist/{esm/index-Cgf1FZ14.js.map → kolibri/index-B8-Psqw5.js.map} +1 -1
  520. package/dist/kolibri/index.esm.js +1 -1
  521. package/dist/kolibri/kol-abbr.entry.esm.js.map +1 -1
  522. package/dist/kolibri/kol-abbr.entry.js +1 -1
  523. package/dist/kolibri/kol-accordion.entry.esm.js.map +1 -1
  524. package/dist/kolibri/kol-accordion.entry.js +1 -1
  525. package/dist/kolibri/kol-accordion.entry.js.map +1 -1
  526. package/dist/kolibri/kol-alert-wc.entry.esm.js.map +1 -1
  527. package/dist/kolibri/kol-alert-wc.entry.js +1 -1
  528. package/dist/kolibri/kol-alert.entry.esm.js.map +1 -1
  529. package/dist/kolibri/kol-alert.entry.js +1 -1
  530. package/dist/kolibri/kol-avatar.entry.esm.js.map +1 -1
  531. package/dist/kolibri/kol-avatar.entry.js +1 -1
  532. package/dist/kolibri/kol-badge.entry.esm.js.map +1 -1
  533. package/dist/kolibri/kol-badge.entry.js +1 -1
  534. package/dist/kolibri/kol-breadcrumb.entry.esm.js.map +1 -1
  535. package/dist/kolibri/kol-breadcrumb.entry.js +1 -1
  536. package/dist/kolibri/kol-button-link.entry.esm.js.map +1 -1
  537. package/dist/kolibri/kol-button-link.entry.js +1 -1
  538. package/dist/kolibri/kol-button-wc.entry.esm.js.map +1 -1
  539. package/dist/kolibri/kol-button-wc.entry.js +1 -1
  540. package/dist/kolibri/kol-button-wc.entry.js.map +1 -1
  541. package/dist/kolibri/kol-button.entry.esm.js.map +1 -1
  542. package/dist/kolibri/kol-button.entry.js +1 -1
  543. package/dist/kolibri/kol-card-wc.entry.esm.js.map +1 -1
  544. package/dist/kolibri/kol-card-wc.entry.js +1 -1
  545. package/dist/kolibri/kol-card.entry.esm.js.map +1 -1
  546. package/dist/kolibri/kol-card.entry.js +1 -1
  547. package/dist/kolibri/kol-click-button.entry.esm.js.map +1 -1
  548. package/dist/kolibri/kol-click-button.entry.js +1 -1
  549. package/dist/kolibri/kol-combobox.entry.esm.js.map +1 -1
  550. package/dist/kolibri/kol-combobox.entry.js +1 -1
  551. package/dist/kolibri/kol-combobox.entry.js.map +1 -1
  552. package/dist/kolibri/kol-details.entry.esm.js.map +1 -1
  553. package/dist/kolibri/kol-details.entry.js +1 -1
  554. package/dist/kolibri/kol-details.entry.js.map +1 -1
  555. package/dist/kolibri/kol-dialog-wc.entry.js +1 -1
  556. package/dist/kolibri/kol-dialog.entry.esm.js.map +1 -1
  557. package/dist/kolibri/kol-dialog.entry.js +1 -1
  558. package/dist/kolibri/kol-drawer.entry.esm.js.map +1 -1
  559. package/dist/kolibri/kol-drawer.entry.js +1 -1
  560. package/dist/kolibri/kol-form.entry.esm.js.map +1 -1
  561. package/dist/kolibri/kol-form.entry.js +1 -1
  562. package/dist/kolibri/kol-heading.entry.esm.js.map +1 -1
  563. package/dist/kolibri/kol-heading.entry.js +1 -1
  564. package/dist/kolibri/kol-icon.entry.esm.js.map +1 -1
  565. package/dist/kolibri/kol-icon.entry.js +1 -1
  566. package/dist/kolibri/kol-image.entry.esm.js.map +1 -1
  567. package/dist/kolibri/kol-image.entry.js +1 -1
  568. package/dist/kolibri/kol-input-checkbox.entry.esm.js.map +1 -1
  569. package/dist/kolibri/kol-input-checkbox.entry.js +1 -1
  570. package/dist/kolibri/kol-input-checkbox.entry.js.map +1 -1
  571. package/dist/kolibri/kol-input-color.entry.esm.js.map +1 -1
  572. package/dist/kolibri/kol-input-color.entry.js +1 -1
  573. package/dist/kolibri/kol-input-color.entry.js.map +1 -1
  574. package/dist/kolibri/kol-input-date.entry.esm.js.map +1 -1
  575. package/dist/kolibri/kol-input-date.entry.js +1 -1
  576. package/dist/kolibri/kol-input-date.entry.js.map +1 -1
  577. package/dist/kolibri/kol-input-email.entry.esm.js.map +1 -1
  578. package/dist/kolibri/kol-input-email.entry.js +1 -1
  579. package/dist/kolibri/kol-input-email.entry.js.map +1 -1
  580. package/dist/kolibri/kol-input-file.entry.esm.js.map +1 -1
  581. package/dist/kolibri/kol-input-file.entry.js +1 -1
  582. package/dist/kolibri/kol-input-file.entry.js.map +1 -1
  583. package/dist/kolibri/kol-input-number.entry.esm.js.map +1 -1
  584. package/dist/kolibri/kol-input-number.entry.js +1 -1
  585. package/dist/kolibri/kol-input-number.entry.js.map +1 -1
  586. package/dist/kolibri/kol-input-password.entry.esm.js.map +1 -1
  587. package/dist/kolibri/kol-input-password.entry.js +1 -1
  588. package/dist/kolibri/kol-input-password.entry.js.map +1 -1
  589. package/dist/kolibri/kol-input-radio.entry.esm.js.map +1 -1
  590. package/dist/kolibri/kol-input-radio.entry.js +1 -1
  591. package/dist/kolibri/kol-input-radio.entry.js.map +1 -1
  592. package/dist/kolibri/kol-input-range.entry.esm.js.map +1 -1
  593. package/dist/kolibri/kol-input-range.entry.js +1 -1
  594. package/dist/kolibri/kol-input-range.entry.js.map +1 -1
  595. package/dist/kolibri/kol-input-text.entry.esm.js.map +1 -1
  596. package/dist/kolibri/kol-input-text.entry.js +1 -1
  597. package/dist/kolibri/kol-input-text.entry.js.map +1 -1
  598. package/dist/kolibri/kol-kolibri.entry.esm.js.map +1 -1
  599. package/dist/kolibri/kol-kolibri.entry.js +1 -1
  600. package/dist/kolibri/kol-link-button.entry.esm.js.map +1 -1
  601. package/dist/kolibri/kol-link-button.entry.js +1 -1
  602. package/dist/kolibri/kol-link-wc.entry.js +1 -1
  603. package/dist/kolibri/kol-link.entry.esm.js.map +1 -1
  604. package/dist/kolibri/kol-link.entry.js +1 -1
  605. package/dist/kolibri/kol-modal.entry.esm.js.map +1 -1
  606. package/dist/kolibri/kol-modal.entry.js +1 -1
  607. package/dist/kolibri/kol-nav.entry.esm.js.map +1 -1
  608. package/dist/kolibri/kol-nav.entry.js +1 -1
  609. package/dist/kolibri/kol-pagination-wc.entry.esm.js.map +1 -1
  610. package/dist/kolibri/kol-pagination-wc.entry.js +1 -1
  611. package/dist/kolibri/kol-pagination.entry.esm.js.map +1 -1
  612. package/dist/kolibri/kol-pagination.entry.js +1 -1
  613. package/dist/kolibri/kol-pagination.entry.js.map +1 -1
  614. package/dist/kolibri/kol-popover-button-wc.entry.esm.js.map +1 -1
  615. package/dist/kolibri/kol-popover-button-wc.entry.js +1 -1
  616. package/dist/kolibri/kol-popover-button-wc.entry.js.map +1 -1
  617. package/dist/kolibri/kol-popover-button.entry.esm.js.map +1 -1
  618. package/dist/kolibri/kol-popover-button.entry.js +1 -1
  619. package/dist/kolibri/kol-popover-button.entry.js.map +1 -1
  620. package/dist/kolibri/kol-progress.entry.esm.js.map +1 -1
  621. package/dist/kolibri/kol-progress.entry.js +1 -1
  622. package/dist/kolibri/kol-quote.entry.esm.js.map +1 -1
  623. package/dist/kolibri/kol-quote.entry.js +1 -1
  624. package/dist/kolibri/kol-select-wc.entry.esm.js.map +1 -1
  625. package/dist/kolibri/kol-select-wc.entry.js +1 -1
  626. package/dist/kolibri/kol-select.entry.esm.js.map +1 -1
  627. package/dist/kolibri/kol-select.entry.js +1 -1
  628. package/dist/kolibri/kol-select.entry.js.map +1 -1
  629. package/dist/kolibri/kol-single-select.entry.esm.js.map +1 -1
  630. package/dist/kolibri/kol-single-select.entry.js +1 -1
  631. package/dist/kolibri/kol-single-select.entry.js.map +1 -1
  632. package/dist/kolibri/kol-skeleton.entry.js +1 -1
  633. package/dist/kolibri/kol-skip-nav.entry.esm.js.map +1 -1
  634. package/dist/kolibri/kol-skip-nav.entry.js +1 -1
  635. package/dist/kolibri/kol-spin.entry.esm.js.map +1 -1
  636. package/dist/kolibri/kol-spin.entry.js +1 -1
  637. package/dist/kolibri/kol-spin.entry.js.map +1 -1
  638. package/dist/kolibri/kol-split-button.entry.esm.js.map +1 -1
  639. package/dist/kolibri/kol-split-button.entry.js +1 -1
  640. package/dist/kolibri/kol-split-button.entry.js.map +1 -1
  641. package/dist/kolibri/kol-table-settings-wc.entry.js +1 -1
  642. package/dist/kolibri/kol-table-stateful.entry.esm.js.map +1 -1
  643. package/dist/kolibri/kol-table-stateful.entry.js +1 -1
  644. package/dist/kolibri/kol-table-stateful.entry.js.map +1 -1
  645. package/dist/kolibri/kol-table-stateless-wc.entry.js +1 -1
  646. package/dist/kolibri/kol-table-stateless.entry.esm.js.map +1 -1
  647. package/dist/kolibri/kol-table-stateless.entry.js +1 -1
  648. package/dist/kolibri/kol-table-stateless.entry.js.map +1 -1
  649. package/dist/kolibri/kol-tabs.entry.esm.js.map +1 -1
  650. package/dist/kolibri/kol-tabs.entry.js +1 -1
  651. package/dist/kolibri/kol-textarea.entry.esm.js.map +1 -1
  652. package/dist/kolibri/kol-textarea.entry.js +1 -1
  653. package/dist/kolibri/kol-textarea.entry.js.map +1 -1
  654. package/dist/kolibri/kol-toast-container.entry.esm.js.map +1 -1
  655. package/dist/kolibri/kol-toast-container.entry.js +1 -1
  656. package/dist/kolibri/kol-toolbar.entry.esm.js.map +1 -1
  657. package/dist/kolibri/kol-toolbar.entry.js +1 -1
  658. package/dist/kolibri/kol-tooltip-wc.entry.js +1 -1
  659. package/dist/kolibri/kol-tree-item-wc.entry.esm.js.map +1 -1
  660. package/dist/kolibri/kol-tree-item-wc.entry.js +1 -1
  661. package/dist/kolibri/kol-tree-item.entry.esm.js.map +1 -1
  662. package/dist/kolibri/kol-tree-item.entry.js +1 -1
  663. package/dist/kolibri/kol-tree-item.entry.js.map +1 -1
  664. package/dist/kolibri/kol-tree-wc.entry.js +1 -1
  665. package/dist/kolibri/kol-tree.entry.esm.js.map +1 -1
  666. package/dist/kolibri/kol-tree.entry.js +1 -1
  667. package/dist/kolibri/kol-version.entry.esm.js.map +1 -1
  668. package/dist/kolibri/kol-version.entry.js +1 -1
  669. package/dist/kolibri/kolibri.esm.js +1 -1
  670. package/dist/kolibri/test-component.entry.js +1 -1
  671. package/dist/types/components/component-list.d.ts +1 -2
  672. package/dist/types/components/popover-button/component.d.ts +7 -8
  673. package/dist/types/components/split-button/shadow.d.ts +3 -3
  674. package/dist/types/components.d.ts +510 -49
  675. package/dist/types/core/component-names.d.ts +0 -1
  676. package/dist/types/index.d.ts +1 -1
  677. package/dist/types/internal/functional-components/popover/api.d.ts +5 -0
  678. package/dist/types/internal/functional-components/popover/component.d.ts +9 -0
  679. package/dist/types/internal/functional-components/popover/controller.d.ts +16 -0
  680. package/dist/types/internal/functional-components/popover/snapshot.test.d.ts +1 -0
  681. package/dist/types/internal/props/align.d.ts +4 -0
  682. package/dist/types/internal/props/index.d.ts +1 -1
  683. package/dist/types/schema/components/index.d.ts +1 -1
  684. package/dist/types/schema/props/index.d.ts +1 -1
  685. package/doc/_skeleton.md +54 -84
  686. package/doc/abbr.md +5 -0
  687. package/doc/accordion.md +9 -3
  688. package/doc/alert.md +7 -3
  689. package/doc/avatar.md +4 -0
  690. package/doc/badge.md +5 -0
  691. package/doc/breadcrumb.md +4 -0
  692. package/doc/button-link.md +19 -0
  693. package/doc/button.md +11 -0
  694. package/doc/card.md +12 -4
  695. package/doc/combobox.md +3 -3
  696. package/doc/details.md +13 -3
  697. package/doc/form.md +7 -3
  698. package/doc/heading.md +7 -3
  699. package/doc/icon.md +4 -0
  700. package/doc/image.md +4 -0
  701. package/doc/input-checkbox.md +4 -0
  702. package/doc/input-color.md +7 -3
  703. package/doc/input-date.md +7 -3
  704. package/doc/input-email.md +7 -3
  705. package/doc/input-file.md +7 -3
  706. package/doc/input-number.md +7 -3
  707. package/doc/input-password.md +7 -3
  708. package/doc/input-radio.md +7 -3
  709. package/doc/input-range.md +7 -3
  710. package/doc/input-text.md +7 -3
  711. package/doc/link-button.md +11 -0
  712. package/doc/modal.md +4 -0
  713. package/doc/nav.md +5 -0
  714. package/doc/pagination.md +1 -1
  715. package/doc/popover-button.md +14 -8
  716. package/doc/progress.md +4 -0
  717. package/doc/quote.md +4 -0
  718. package/doc/select.md +11 -11
  719. package/doc/single-select.md +7 -3
  720. package/doc/skip-nav.md +4 -0
  721. package/doc/spin.md +11 -0
  722. package/doc/split-button.md +8 -3
  723. package/doc/table-stateful.md +4 -0
  724. package/doc/tabs.md +4 -0
  725. package/doc/textarea.md +7 -3
  726. package/doc/tree-item.md +7 -7
  727. package/package.json +9 -8
  728. package/vscode-custom-data.json +37 -408
  729. package/dist/cjs/component-names--SvI3zRN.js +0 -4
  730. package/dist/cjs/component-names--SvI3zRN.js.map +0 -1
  731. package/dist/cjs/controller-CJLYpbTW.js +0 -4
  732. package/dist/cjs/index-BDC4d4pa.js +0 -4
  733. package/dist/cjs/kol-popover-wc.cjs.entry.js +0 -4
  734. package/dist/cjs/kol-popover-wc.entry.cjs.js.map +0 -1
  735. package/dist/cjs/show-CCRUsfNF.js +0 -4
  736. package/dist/cjs/show-CCRUsfNF.js.map +0 -1
  737. package/dist/components/kol-popover-wc.d.ts +0 -11
  738. package/dist/components/kol-popover-wc.js +0 -4
  739. package/dist/components/kol-popover-wc.js.map +0 -1
  740. package/dist/components/show.js +0 -4
  741. package/dist/components/show.js.map +0 -1
  742. package/dist/esm/component-names-BQrMLr68.js +0 -4
  743. package/dist/esm/component-names-BQrMLr68.js.map +0 -1
  744. package/dist/esm/kol-popover-wc.entry.js +0 -4
  745. package/dist/esm/kol-popover-wc.entry.js.map +0 -1
  746. package/dist/esm/show-DWCKSt29.js +0 -4
  747. package/dist/esm/show-DWCKSt29.js.map +0 -1
  748. package/dist/kolibri/Alert-Cw_LoKSN.js +0 -4
  749. package/dist/kolibri/FieldControlStateWrapper-B3IEsGo5.js +0 -4
  750. package/dist/kolibri/Input-BtjxL296.js +0 -4
  751. package/dist/kolibri/InputStateWrapper-CEMRSPYO.js +0 -4
  752. package/dist/kolibri/app-globals-MFFawMzD.js +0 -4
  753. package/dist/kolibri/component-names-BQrMLr68.js +0 -4
  754. package/dist/kolibri/component-names-BQrMLr68.js.map +0 -1
  755. package/dist/kolibri/kol-popover-wc.entry.esm.js.map +0 -1
  756. package/dist/kolibri/kol-popover-wc.entry.js +0 -4
  757. package/dist/kolibri/kol-popover-wc.entry.js.map +0 -1
  758. package/dist/kolibri/show-DWCKSt29.js +0 -4
  759. package/dist/kolibri/show-DWCKSt29.js.map +0 -1
  760. package/dist/types/components/popover/component.d.ts +0 -33
  761. package/dist/types/schema/components/popover.d.ts +0 -12
  762. package/dist/types/schema/props/popover-callbacks.d.ts +0 -11
  763. package/doc/click-button.md +0 -28
  764. package/doc/toaster.md +0 -45
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{proxyCustomElement,HTMLElement,h}from"@stencil/core/internal/client";import{c as KolButtonWcTag}from"./component-names.js";import{g as getRenderStates,F as FormFieldStateWrapper}from"./controller3.js";import{I as InputIconController,a as InputContainerStateWrapperFc}from"./controller-icon.js";import{I as InputStateWrapper}from"./InputStateWrapper.js";import{C as CustomSuggestionsOptionsGroupFc,a as CustomSuggestionsOptionFc}from"./CustomSuggestionsOptionsGroup.js";import{t as translate}from"./i18n.js";import{I as IconFC}from"./component2.js";import{c as clsx}from"./clsx.js";import{n as nonce}from"./dev.utils.js";import{b as watchValidator,d as watchBoolean,O as watchNumber}from"./common.js";import{f as fillKeyOptionMap,b as validateOptions}from"./controller4.js";import{v as validatePlaceholder}from"./placeholder.js";import{v as validateRequired}from"./required.js";class SingleSelectController extends InputIconController{constructor(e,t,n){super(e,t,n),this.keyOptionMap=new Map,this.afterPatchOptions=(e,t,n,o)=>{"_value"===o&&this.setFormAssociatedValue(e)},this.beforePatchOptions=(e,t)=>{const n=t.has("_options")?t.get("_options"):this.component.state._options;Array.isArray(n)&&n.length>0&&(this.keyOptionMap.clear(),fillKeyOptionMap(this.keyOptionMap,n))},this.component=e}validateOptions(e){validateOptions(this.component,e,{hooks:{afterPatch:this.afterPatchOptions,beforePatch:this.beforePatchOptions}})}validateRequired(e){validateRequired(this.component,e)}validateValue(e){watchValidator(this.component,"_value",e=>void 0!==e,new Set(["KoliBriUnknown"]),e)}validatePlaceholder(e){validatePlaceholder(this.component,e)}validateHasClearButton(e){watchBoolean(this.component,"_hasClearButton",e)}validateRows(e){watchNumber(this.component,"_rows",e)}componentWillLoad(){super.componentWillLoad(),this.validateOptions(this.component._options),this.validateRequired(this.component._required),this.validateValue(this.component._value),this.validatePlaceholder(this.component._placeholder),this.validateHasClearButton(this.component._hasClearButton),this.validateRows(this.component._rows)}}const defaultStyleCss='@charset "UTF-8";\n/*\n* This file defines the layer order for all CSS layers used in KoliBri.\n* The order is important as it determines the cascade priority.\n*\n* Layer order (lowest to highest priority):\n* 1. kol-a11y - Accessibility defaults and requirements\n* 2. kol-global - Global component styles and resets\n* 3. kol-component - Component-specific styles\n* 4. kol-theme-global - Theme-specific global styles\n* 5. kol-theme-component - Theme-specific component styles\n*/\n@layer kol-a11y, kol-global, kol-component, kol-theme-global, kol-theme-component;\n/* forward the rem function */\n/*\n * This file contains all rules for accessibility.\n */\n@layer kol-a11y {\n :host {\n /*\n * Minimum size of interactive elements.\n */\n --a11y-min-size: calc(44 * 1rem / var(--kolibri-root-font-size, 16));\n /*\n * No element should be used without verifying the contrast ratio of its background and font colors.\n * By initially setting the background color to white and the font color to black,\n * the contrast ratio is ensured and explicit adjustment is forced.\n */\n color: black;\n background-color: white;\n /*\n * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n /*\n * Text should be aligned left by default to provide a predictable starting point.\n */\n text-align: left;\n }\n * {\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n hyphens: auto;\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n word-break: break-word;\n }\n /*\n * All interactive elements should have a minimum size of to-rem(44).\n */\n /* input:not([type=\'checkbox\'], [type=\'radio\'], [type=\'range\']), */\n /* option, */\n /* select, */\n /* textarea, */\n button,\n .kol-input .input {\n min-width: var(--a11y-min-size);\n min-height: var(--a11y-min-size);\n }\n /*\n * Some interactive elements should not inherit the font-family and font-size.\n */\n a,\n button,\n h1,\n h2,\n h3,\n h4,\n h5,\n h6,\n input,\n option,\n select,\n textarea {\n /*\n * All elements should inherit the text color from his parent element.\n */\n color: inherit;\n /*\n * All elements should inherit the font family from his parent element.\n */\n font-family: inherit;\n /*\n * All elements should inherit the font size from his parent element.\n */\n font-size: inherit;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n }\n /**\n * Sometimes we need the semantic element for accessibility reasons,\n * but we don\'t want to show it.\n *\n * - https://www.a11yproject.com/posts/how-to-hide-content/\n */\n .visually-hidden {\n position: fixed;\n top: 0;\n left: 0;\n width: 1px;\n height: 1px;\n overflow: hidden;\n white-space: nowrap;\n clip-path: inset(50%);\n }\n}\n@layer kol-global {\n /*\n * Dieses CSS stellt sicher, dass der Standard-Style\n * von A und Button resettet werden.\n */\n :is(a, button) {\n background-color: transparent;\n width: 100%;\n margin: 0;\n padding: 0;\n border: none;\n /* 100% needed for custom width from outside */\n }\n /*\n * Ensure elements with hidden attribute to be actually not visible\n * @see https://meowni.ca/hidden.is.a.lie.html\n */\n [hidden] {\n display: none !important;\n }\n .badge-text-hint {\n color: black;\n background-color: lightgray;\n }\n}\n@layer kol-global {\n :host {\n /*\n * The max-width is needed to prevent the table from overflowing the\n * parent node, if the table is wider than the parent node.\n */\n max-width: 100%;\n font-size: calc(16 * 1rem / var(--kolibri-root-font-size, 16));\n }\n * {\n /*\n * We prefer to box-sizing: border-box for all elements.\n */\n box-sizing: border-box;\n }\n .kol-span {\n /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n display: flex;\n flex-flow: column;\n align-items: center;\n justify-content: center;\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n }\n .kol-span__container {\n display: flex;\n align-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .kol-span .kol-span__label--hide-label .kol-span__label {\n display: none;\n }\n /* Reset browser agent style. */\n button:disabled {\n color: unset;\n }\n .disabled label,\n .disabled:focus-within label,\n [aria-disabled=true],\n [aria-disabled=true]:focus,\n [disabled],\n [disabled]:focus {\n opacity: 0.5;\n outline: none;\n cursor: not-allowed;\n }\n [aria-disabled=true]:focus .kol-span,\n [disabled]:focus .kol-span {\n outline: none !important;\n }\n .hastooltip {\n z-index: 900 !important;\n }\n}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n@font-face {\n font-family: "kolicons";\n src: url("kolicons.eot?t=1773232431126"); /* IE9*/\n src: url("kolicons.eot?t=1773232431126#iefix") format("embedded-opentype"), url("kolicons.woff2?t=1773232431126") format("woff2"), url("kolicons.woff?t=1773232431126") format("woff"), url("kolicons.ttf?t=1773232431126") format("truetype"), url("kolicons.svg?t=1773232431126#kolicons") format("svg"); /* iOS 4.1- */\n}\n[class^=kolicon-], [class*=" kolicon-"] {\n font-family: "kolicons";\n font-style: normal;\n font-weight: 400;\n line-height: 1em;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\n.kolicon-alert-error::before {\n content: "\\ea01";\n}\n\n.kolicon-alert-info::before {\n content: "\\ea02";\n}\n\n.kolicon-alert-success::before {\n content: "\\ea03";\n}\n\n.kolicon-alert-warning::before {\n content: "\\ea04";\n}\n\n.kolicon-check::before {\n content: "\\ea05";\n}\n\n.kolicon-chevron-double-left::before {\n content: "\\ea06";\n}\n\n.kolicon-chevron-double-right::before {\n content: "\\ea07";\n}\n\n.kolicon-chevron-down::before {\n content: "\\ea08";\n}\n\n.kolicon-chevron-left::before {\n content: "\\ea09";\n}\n\n.kolicon-chevron-right::before {\n content: "\\ea0a";\n}\n\n.kolicon-chevron-up::before {\n content: "\\ea0b";\n}\n\n.kolicon-cogwheel::before {\n content: "\\ea0c";\n}\n\n.kolicon-cross::before {\n content: "\\ea0d";\n}\n\n.kolicon-eye-closed::before {\n content: "\\ea0e";\n}\n\n.kolicon-eye::before {\n content: "\\ea0f";\n}\n\n.kolicon-house::before {\n content: "\\ea10";\n}\n\n.kolicon-kolibri::before {\n content: "\\ea11";\n}\n\n.kolicon-link-external::before {\n content: "\\ea12";\n}\n\n.kolicon-link::before {\n content: "\\ea13";\n}\n\n.kolicon-minus::before {\n content: "\\ea14";\n}\n\n.kolicon-plus::before {\n content: "\\ea15";\n}\n\n.kolicon-settings::before {\n content: "\\ea16";\n}\n\n.kolicon-sort-asc::before {\n content: "\\ea17";\n}\n\n.kolicon-sort-desc::before {\n content: "\\ea18";\n}\n\n.kolicon-sort-neutral::before {\n content: "\\ea19";\n}\n\n.kolicon-up::before {\n content: "\\ea1a";\n}\n\n.kolicon-version::before {\n content: "\\ea1b";\n}\n\n@layer kol-component {\n .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n .kol-tooltip {\n display: contents;\n }\n .kol-tooltip__floating {\n opacity: 0;\n display: none;\n position: fixed;\n /* Avoid layout interference - see https://floating-ui.com/docs/computePosition */\n top: 0;\n left: 0;\n /* Can be used to specify the tooltip-width from the outside. Unset by default. */\n width: var(--kol-tooltip-width, max-content);\n min-width: calc(8 * 1rem / var(--kolibri-root-font-size, 16));\n max-width: 90vw;\n max-height: 90vh;\n animation-direction: normal;\n /* Can be used to specify the animation duration from the outside. 250ms by default. */\n animation-duration: var(--kolibri-tooltip-animation-duration, 250ms);\n animation-fill-mode: forwards;\n animation-iteration-count: 1;\n animation-timing-function: ease-in;\n }\n .kol-tooltip__floating.hide {\n animation-name: hideTooltip;\n }\n .kol-tooltip__floating.show {\n animation-name: showTooltip;\n }\n .kol-tooltip__arrow {\n transform: rotate(45deg);\n color: #000;\n background-color: #fff;\n position: absolute;\n z-index: 999;\n width: calc(10 * 1rem / var(--kolibri-root-font-size, 16));\n height: calc(10 * 1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-tooltip__content {\n color: #000;\n background-color: #fff;\n position: relative;\n z-index: 1000;\n }\n @keyframes hideTooltip {\n 0% {\n opacity: 1;\n }\n 100% {\n opacity: 0;\n display: none;\n }\n }\n @keyframes showTooltip {\n 0% {\n opacity: 0;\n }\n 100% {\n opacity: 1;\n }\n }\n}\n@layer kol-component {\n .kol-alert .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n .kol-alert :host {\n display: inline-block;\n }\n .kol-alert .kol-button {\n display: flex;\n min-height: var(--a11y-min-size);\n font-style: calc(16 * 1rem / var(--kolibri-root-font-size, 16));\n text-decoration-line: none;\n }\n .kol-alert .kol-button::before {\n /* Render zero-width character as first element to set the baseline correctly. */\n content: "​";\n }\n .kol-alert .kol-button__text {\n flex: 1 0 100%;\n }\n .kol-alert {\n display: grid;\n }\n .kol-alert__container {\n display: flex;\n place-items: center;\n }\n .kol-alert__container-content {\n flex-grow: 1;\n }\n .kol-alert__closer {\n /* Visible with forced colors */\n outline: transparent solid calc(1 * 1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-custom-suggestions-option {\n line-height: 1.5;\n white-space: normal;\n cursor: pointer;\n overflow-wrap: break-word;\n }\n .kol-custom-suggestions-options-group--cursor-hidden .kol-custom-suggestions-option {\n cursor: none !important;\n }\n .kol-custom-suggestions-option--disabled:focus, .kol-custom-suggestions-option--disabled:focus * {\n cursor: not-allowed;\n }\n .kol-custom-suggestions-options-group {\n background-color: white;\n display: block;\n position: absolute;\n z-index: 2;\n max-height: calc(250 * 1rem / var(--kolibri-root-font-size, 16));\n margin: 0;\n padding: 0;\n overflow-x: hidden;\n overflow-y: auto;\n list-style-type: none;\n }\n .kol-input-container:has(.kol-custom-suggestions-options-group--open) {\n z-index: 10;\n }\n .kol-custom-suggestions-toggle {\n display: flex;\n min-width: var(--a11y-min-size);\n min-height: var(--a11y-min-size);\n align-items: center;\n justify-content: center;\n cursor: default;\n }\n .kol-custom-suggestions-toggle.kol-custom-suggestions-toggle--disabled {\n cursor: not-allowed;\n }\n .kol-form-field {\n display: grid;\n }\n .kol-form-field:not(.kol-form-field--disabled) .kol-form-field__label {\n cursor: pointer;\n }\n .kol-form-field__label-text {\n display: ruby;\n }\n .kol-form-field--disabled .kol-form-field__label {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__label-text:not(:has(> [name]))::after,\n .kol-form-field--required .kol-form-field__tooltip .span-label::after {\n content: "*"/"";\n }\n .kol-form-field--disabled .kol-form-field__hint {\n opacity: 0.5;\n }\n .kol-input-container {\n background-color: transparent;\n display: grid;\n width: 100%;\n min-width: var(--a11y-min-size);\n min-height: var(--a11y-min-size);\n align-items: center;\n grid-template-columns: 1fr;\n }\n .kol-input-container:has(> .kol-input-container__adornment--start) {\n grid-template-columns: auto 1fr auto;\n }\n .kol-input-container__container {\n position: relative;\n }\n .kol-input-container__adornment {\n display: flex;\n align-items: center;\n }\n .kol-input-container__adornment .kol-icon {\n display: grid;\n min-height: var(--a11y-min-size);\n place-items: center;\n }\n .kol-input {\n background-color: transparent;\n width: 100%;\n min-width: var(--a11y-min-size);\n }\n .kol-input:focus {\n outline: none;\n }\n .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n .kol-single-select__delete .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n .kol-single-select__delete :host {\n display: inline-block;\n }\n .kol-single-select__delete .kol-button {\n display: flex;\n min-height: var(--a11y-min-size);\n font-style: calc(16 * 1rem / var(--kolibri-root-font-size, 16));\n text-decoration-line: none;\n }\n .kol-single-select__delete .kol-button::before {\n /* Render zero-width character as first element to set the baseline correctly. */\n content: "​";\n }\n .kol-single-select__delete .kol-button__text {\n flex: 1 0 100%;\n }\n .kol-single-select__delete .kol-button {\n margin-top: -2px;\n margin-bottom: -2px;\n }\n .kol-single-select__no-results-message {\n display: flex;\n min-height: calc(50 * 1rem / var(--kolibri-root-font-size, 16));\n align-items: center;\n justify-content: center;\n cursor: default;\n }\n .kol-single-select .kol-custom-suggestions-options-group {\n max-height: calc(40 * 1rem / var(--kolibri-root-font-size, 16) * var(--visible-options, 5) + 2 * 1rem / var(--kolibri-root-font-size, 16)) !important;\n }\n .kol-custom-suggestions-toggle:not(.kol-custom-suggestions-toggle--disabled) {\n cursor: pointer;\n }\n .kol-custom-suggestions-toggle--disabled {\n opacity: 0.5;\n }\n}',KolSingleSelect$1=proxyCustomElement(class extends HTMLElement{async getValue(){return this._value}async focus(){return new Promise(e=>{requestAnimationFrame(()=>{var t;null===(t=this.refInput)||void 0===t||t.focus(),e()})})}onBlur(e){var t,n,o;const i=null===(t=this.state._options)||void 0===t?void 0:t.find(e=>{var t,n;return(null===(t=e.label)||void 0===t?void 0:t.toLowerCase())===(null===(n=this._inputValue)||void 0===n?void 0:n.toLowerCase())});i?this.selectOption(i):!this._isOpen&&this._value&&(this._inputValue=null===(o=null===(n=this.state._options)||void 0===n?void 0:n.find(e=>e.value===this._value))||void 0===o?void 0:o.label,this._filteredOptions=[...this.state._options]),e instanceof FocusEvent&&e.view===window&&!this.isClearing&&(this._isOpen=!1)}createEventWithTarget(e,t){const n=new CustomEvent(e,{bubbles:!0,detail:t});return this.refInput&&(Object.defineProperty(n,"target",{value:this.refInput}),Object.defineProperty(n,"currentTarget",{value:this.refInput})),n}clearSelection(){if(this.isClearing=!0,this.state._disabled)return;const e=null;this._focusedOptionIndex=-1,this._value=e,this._inputValue="",this._filteredOptions=[...this.state._options];const t=this.createEventWithTarget("input",{name:this.state._name,value:e}),n=this.createEventWithTarget("change",{name:this.state._name,value:e});this.controller.onFacade.onInput(t,!0,{value:e}),this.controller.onFacade.onChange(n,{value:e}),this.isClearing=!1}selectOption(e){var t,n;if(e.value===this._value)return this._inputValue=e.label,void(this._filteredOptions=[...this.state._options]);this._value=e.value,this._inputValue=e.label;const o=this.createEventWithTarget("input",{name:null!==(t=this.state._name)&&void 0!==t?t:"",value:e.value}),i=this.createEventWithTarget("change",{name:null!==(n=this.state._name)&&void 0!==n?n:"",value:e.value});this.controller.onFacade.onInput(o,!1,e.value),this.controller.onFacade.onChange(i,e.value),this._filteredOptions=[...this.state._options],this.controller.setFormAssociatedValue(this._value)}onInput(e){const t=e.target;this._inputValue=t.value,this._isOpen=!0,this.setFilteredOptionsByQuery(t.value),this._focusedOptionIndex=-1}handleKeyDownDropdown(e){1===e.key.length&&/[a-z0-9]/i.test(e.key)&&(e.preventDefault(),this._isOpen=!0,this.focusSuggestionStartingWith(e.key))}setFilteredOptionsByQuery(e){""===(null==e?void 0:e.trim())?this._filteredOptions=[...this.state._options]:Array.isArray(this.state._options)&&this.state._options.length>0&&e.length>0&&(this._filteredOptions=this.state._options.filter(t=>{var n,o;return null===(o=null===(n=t.label)||void 0===n?void 0:n.toLowerCase())||void 0===o?void 0:o.includes(null==e?void 0:e.toLowerCase())}))}moveFocus(e){if(!this._filteredOptions)return;let t=this._focusedOptionIndex+e,n=0,o=!1;const i=this._filteredOptions.length;for(;n<i;){t>=this._filteredOptions.length&&(t=0),t<0&&(t=this._filteredOptions.length-1);if(!this._filteredOptions[t].disabled){o=!0;break}t+=e,n++}o&&(this._focusedOptionIndex=t,this.focusOption(this._focusedOptionIndex))}focusOption(e){if(this.refOptions){const t=this.refOptions[e];null==t||t.focus()}}selectFocusedOption(){return!!(Array.isArray(this._filteredOptions)&&this._filteredOptions.length>0&&this._focusedOptionIndex>=0)&&(this.selectOption(this._filteredOptions[this._focusedOptionIndex]),!0)}focusSuggestionStartingWith(e){const t=e.toLowerCase(),n=Array.isArray(this._filteredOptions)&&this._filteredOptions.findIndex(e=>e.label.toLowerCase().startsWith(t)&&!e.disabled);"number"==typeof n&&n>=0&&(this._focusedOptionIndex=n,this.focusOption(n))}getFormFieldProps(){return{state:this.state,class:"kol-single-select",tooltipAlign:this._tooltipAlign,alert:this.showAsAlert()}}getInputProps(){const{ariaDescribedBy:e}=getRenderStates(this.state),t=!0===this.state._disabled;return Object.assign(Object.assign({"aria-activedescendant":this._isOpen&&this._focusedOptionIndex>=0?`option-${this._focusedOptionIndex}`:void 0,"aria-autocomplete":"both","aria-controls":"listbox","aria-describedby":e.length>0?e.join(" "):void 0,"aria-label":this.state._hideLabel&&"string"==typeof this.state._label?this.state._label:void 0,"aria-keyshortcuts":this.state._shortKey,accessKey:this.state._accessKey,autocapitalize:"off",autocorrect:"off",class:"kol-single-select__input",disabled:t,name:this.state._name,placeholder:this.state._placeholder,ref:this.catchRef,required:this.state._required,role:"combobox",state:this.state,type:"text",value:this._inputValue},this.controller.onFacade),{onChange:this.onChange.bind(this),onClick:this.onClick.bind(this),onInput:this.onInput.bind(this),onFocus:e=>{this.controller.onFacade.onFocus(e),this.inputHasFocus=!0},onBlur:e=>{this.controller.onFacade.onBlur(e),this.inputHasFocus=!1}})}render(){var e;const t=!0===this.state._disabled;return h(FormFieldStateWrapper,Object.assign({key:"01462ae2cfe7a4b013aeda8ee7f3dcb2a577a3d9"},this.getFormFieldProps()),h(InputContainerStateWrapperFc,{key:"dcd0cd2858e279495348a3e31646b88d653dc784",state:this.state},h("div",{key:"6234f9883dd1da2bc501ae2f2ac90491eb23ac9b",class:"kol-single-select__group"},h(InputStateWrapper,Object.assign({key:"09c0159be006bbf78473b707655421d9aa7f26bc"},this.getInputProps())),this._inputValue&&this.state._hasClearButton&&h(KolButtonWcTag,{key:"070fccb64dd13f5498c46e93fb7bda715bcb7349",_icons:"kolicon-cross",_label:this.translateDeleteSelection,_hideLabel:!0,_variant:"ghost",_disabled:t,"data-testid":"single-select-delete",class:"kol-single-select__delete",hidden:t,_on:{onClick:()=>{var e;this.clearSelection(),null===(e=this.refInput)||void 0===e||e.focus()}}}),h(IconFC,{key:"18b56debf53dc98556c566af8d692cff6318ca0a",icons:"kolicon-chevron-down",label:"",class:clsx("kol-custom-suggestions-toggle",{"kol-custom-suggestions-toggle--disabled":t}),onClick:this.toggleListbox.bind(this)})),h(CustomSuggestionsOptionsGroupFc,{key:"eb3bb614b05d58c7944ef6a09ea0dfbd10e28b9a",blockSuggestionMouseOver:this.blockSuggestionMouseOver,onKeyDown:this.handleKeyDownDropdown.bind(this),style:{"--visible-options":`${null!==(e=this._rows)&&void 0!==e?e:5}`},hidden:!this._isOpen||t},Array.isArray(this._filteredOptions)&&this._filteredOptions.length>0?this._filteredOptions.map((e,t)=>h(CustomSuggestionsOptionFc,{index:t,option:e.label,searchTerm:this._inputValue,ref:e=>{e&&(this.refOptions[t]=e)},selected:this._value===e.value,disabled:!!e.disabled,onClick:t=>{var n;e.disabled||(this.selectOption(e),null===(n=this.refInput)||void 0===n||n.focus(),this.toggleListbox(t),this._isOpen=!1)},onMouseOver:()=>{this.blockSuggestionMouseOver||(this._focusedOptionIndex=t,this.focusOption(t))},onFocus:()=>{e.disabled||(this._focusedOptionIndex=t,this.focusOption(t))},onKeyDown:t=>{var n;e.disabled||"Enter"!==t.key&&"NumpadEnter"!==t.key||(this.selectOption(e),null===(n=this.refInput)||void 0===n||n.focus(),this.toggleListbox(t),t.preventDefault())}})):h("li",{class:"kol-single-select__no-results-message",role:"alert"},this.translateNoResultsMessage," "))))}handleFocusOut(e){setTimeout(()=>{var t;(null===(t=this.host)||void 0===t?void 0:t.contains(document.activeElement))||this.onBlur(e)})}handleWindowBlur(e){this.onBlur(e)}handleKeyDown(e){var t,n;const o=(t,n)=>{var o;e.preventDefault(),void 0!==t&&(this._isOpen=t,t||null===(o=this.refInput)||void 0===o||o.focus()),null==n||n()};switch(e.key){case"Down":case"ArrowDown":this.blockSuggestionMouseOver=!0,o(!0,()=>this.moveFocus(1));break;case"Up":case"ArrowUp":this.blockSuggestionMouseOver=!0,o(!0,()=>this.moveFocus(-1));break;case"Tab":this._isOpen&&(this._isOpen=!this._isOpen,null===(t=this.refInput)||void 0===t||t.focus());break;case"Esc":case"Escape":this._isOpen=!1,o(!1);break;case" ":case"Enter":case"NumpadEnter":this._isOpen?this.selectFocusedOption()&&(null===(n=this.refInput)||void 0===n||n.focus(),o(!1)):this.toggleListbox(e);break;case"Home":this.blockSuggestionMouseOver=!0,o(void 0,()=>{this._isOpen&&(this._focusedOptionIndex=0,this.focusOption(this._focusedOptionIndex))});break;case"End":this.blockSuggestionMouseOver=!0,o(void 0,()=>{this._isOpen&&(this._focusedOptionIndex=this._filteredOptions?this._filteredOptions.length-1:0,this.focusOption(this._focusedOptionIndex))});break;case"PageUp":this.blockSuggestionMouseOver=!0,o(void 0,()=>this._isOpen&&this.moveFocus(-10));break;case"PageDown":this.blockSuggestionMouseOver=!0,o(void 0,()=>this._isOpen&&this.moveFocus(10))}}constructor(e){super(),!1!==e&&this.__registerHost(),this.__attachShadow(),this.refOptions=[],this.translateDeleteSelection=translate("kol-delete-selection"),this.translateNoResultsMessage=translate("kol-no-results-message"),this.isClearing=!1,this.catchRef=e=>{this.refInput=e},this.toggleListbox=e=>{var t;null==e||e.preventDefault();if(!(!0===this.state._disabled))if(null===(t=this.refInput)||void 0===t||t.focus(),this._isOpen)this._isOpen=!1;else{this._isOpen=!0;const e=Array.isArray(this._filteredOptions)?this._filteredOptions.findIndex(e=>e.label===this._inputValue):-1;this._focusedOptionIndex=e>=0?e:-1,this.focusOption(this._focusedOptionIndex)}},this._focusedOptionIndex=-1,this._isOpen=!1,this._filteredOptions=[],this._inputValue="",this.blockSuggestionMouseOver=!1,this._disabled=!1,this._hideMsg=!1,this._hideLabel=!1,this._hint="",this._required=!1,this._tooltipAlign="top",this._touched=!1,this._value=null,this._hasClearButton=!0,this.state={_hideMsg:!1,_id:`id-${nonce()}`,_label:"",_options:[],_hasClearButton:!0},this.inputHasFocus=!1,this.controller=new SingleSelectController(this,"single-select",this.host)}showAsAlert(){return Boolean(this.state._touched)&&!this.inputHasFocus}validatePlaceholder(e){this.controller.validatePlaceholder(e)}validateAccessKey(e){this.controller.validateAccessKey(e)}validateDisabled(e){this.controller.validateDisabled(e)}validateHideMsg(e){this.controller.validateHideMsg(e)}validateHideLabel(e){this.controller.validateHideLabel(e)}validateHint(e){this.controller.validateHint(e)}validateIcons(e){this.controller.validateIcons(e)}validateLabel(e){this.controller.validateLabel(e)}validateMsg(e){this.controller.validateMsg(e)}validateName(e){this.controller.validateName(e)}validateOn(e){this.controller.validateOn(e)}validateOptions(e){this.controller.validateOptions(e),this._filteredOptions=e,this.updateInputValue(this._value)}validateRequired(e){this.controller.validateRequired(e)}validateShortKey(e){this.controller.validateShortKey(e)}validateSyncValueBySelector(e){this.controller.validateSyncValueBySelector(e)}validateTouched(e){this.controller.validateTouched(e)}validateValue(e){this.controller.validateValue(e),this.oldValue=e,this.updateInputValue(e)}validateHasClearButton(e){this.controller.validateHasClearButton(e)}validateRows(e){this.controller.validateRows(e)}handleMouseEvent(){this.blockSuggestionMouseOver=!1}updateInputValue(e){if(Array.isArray(this._options)){const t=this._options.find(t=>t.value===e);this._inputValue=t?String(t.label):""}}componentWillLoad(){this.refOptions=[],this._touched=!0===this._touched,this.controller.componentWillLoad(),this.oldValue=this._value,this._filteredOptions=this.state._options,this.updateInputValue(this._value)}onChange(e){var t,n;this.oldValue!==(null===(t=this.refInput)||void 0===t?void 0:t.value)&&(this.oldValue=null===(n=this.refInput)||void 0===n?void 0:n.value),this._isOpen||this.controller.onFacade.onChange(e,this._value)}onClick(e){var t;this.toggleListbox(e),null===(t=this.refInput)||void 0===t||t.focus(),this.controller.onFacade.onClick(e)}get host(){return this}static get watchers(){return{_placeholder:["validatePlaceholder"],_accessKey:["validateAccessKey"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_label:["validateLabel"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_options:["validateOptions"],_required:["validateRequired"],_shortKey:["validateShortKey"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"],_hasClearButton:["validateHasClearButton"],_rows:["validateRows"]}}static get style(){return{default:defaultStyleCss}}},[289,"kol-single-select",{_accessKey:[1,"_access-key"],_placeholder:[1],_disabled:[4],_hideMsg:[4,"_hide-msg"],_hideLabel:[4,"_hide-label"],_hint:[1],_icons:[1],_label:[1],_msg:[1],_name:[1],_on:[16],_options:[1],_required:[4],_shortKey:[1,"_short-key"],_syncValueBySelector:[1,"_sync-value-by-selector"],_tooltipAlign:[1,"_tooltip-align"],_touched:[1540],_value:[1544],_hasClearButton:[4,"_has-clear-button"],_rows:[2],_isOpen:[32],_filteredOptions:[32],_inputValue:[32],blockSuggestionMouseOver:[32],state:[32],inputHasFocus:[32],getValue:[64],focus:[64]},[[0,"focusout","handleFocusOut"],[0,"blur","handleWindowBlur"],[0,"keydown","handleKeyDown"],[1,"mousemove","handleMouseEvent"]],{_placeholder:["validatePlaceholder"],_accessKey:["validateAccessKey"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_label:["validateLabel"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_options:["validateOptions"],_required:["validateRequired"],_shortKey:["validateShortKey"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"],_hasClearButton:["validateHasClearButton"],_rows:["validateRows"]}]);function defineCustomElement$1(){if("undefined"==typeof customElements)return;["kol-single-select"].forEach(e=>{if("kol-single-select"===e)customElements.get(e)||customElements.define(e,KolSingleSelect$1)})}const KolSingleSelect=KolSingleSelect$1,defineCustomElement=defineCustomElement$1;export{KolSingleSelect,defineCustomElement};
4
+ import{proxyCustomElement,HTMLElement,h}from"@stencil/core/internal/client";import{c as KolButtonWcTag}from"./component-names.js";import{g as getRenderStates,F as FormFieldStateWrapper}from"./controller3.js";import{I as InputIconController,a as InputContainerStateWrapperFc}from"./controller-icon.js";import{I as InputStateWrapper}from"./InputStateWrapper.js";import{C as CustomSuggestionsOptionsGroupFc,a as CustomSuggestionsOptionFc}from"./CustomSuggestionsOptionsGroup.js";import{t as translate}from"./i18n.js";import{I as IconFC}from"./component2.js";import{c as clsx}from"./clsx.js";import{n as nonce}from"./dev.utils.js";import{b as watchValidator,d as watchBoolean,O as watchNumber}from"./common.js";import{f as fillKeyOptionMap,b as validateOptions}from"./controller4.js";import{v as validatePlaceholder}from"./placeholder.js";import{v as validateRequired}from"./required.js";class SingleSelectController extends InputIconController{constructor(e,t,n){super(e,t,n),this.keyOptionMap=new Map,this.afterPatchOptions=(e,t,n,o)=>{"_value"===o&&this.setFormAssociatedValue(e)},this.beforePatchOptions=(e,t)=>{const n=t.has("_options")?t.get("_options"):this.component.state._options;Array.isArray(n)&&n.length>0&&(this.keyOptionMap.clear(),fillKeyOptionMap(this.keyOptionMap,n))},this.component=e}validateOptions(e){validateOptions(this.component,e,{hooks:{afterPatch:this.afterPatchOptions,beforePatch:this.beforePatchOptions}})}validateRequired(e){validateRequired(this.component,e)}validateValue(e){watchValidator(this.component,"_value",e=>void 0!==e,new Set(["KoliBriUnknown"]),e)}validatePlaceholder(e){validatePlaceholder(this.component,e)}validateHasClearButton(e){watchBoolean(this.component,"_hasClearButton",e)}validateRows(e){watchNumber(this.component,"_rows",e)}componentWillLoad(){super.componentWillLoad(),this.validateOptions(this.component._options),this.validateRequired(this.component._required),this.validateValue(this.component._value),this.validatePlaceholder(this.component._placeholder),this.validateHasClearButton(this.component._hasClearButton),this.validateRows(this.component._rows)}}const defaultStyleCss='@charset "UTF-8";\n/*\n* This file defines the layer order for all CSS layers used in KoliBri.\n* The order is important as it determines the cascade priority.\n*\n* Layer order (lowest to highest priority):\n* 1. kol-a11y - Accessibility defaults and requirements\n* 2. kol-global - Global component styles and resets\n* 3. kol-component - Component-specific styles\n* 4. kol-theme-global - Theme-specific global styles\n* 5. kol-theme-component - Theme-specific component styles\n*/\n@layer kol-a11y, kol-global, kol-component, kol-theme-global, kol-theme-component;\n/* forward the rem function */\n/*\n * This file contains all rules for accessibility.\n */\n@layer kol-a11y {\n :host {\n /*\n * Minimum size of interactive elements.\n */\n --a11y-min-size: calc(44 * 1rem / var(--kolibri-root-font-size, 16));\n /*\n * No element should be used without verifying the contrast ratio of its background and font colors.\n * By initially setting the background color to white and the font color to black,\n * the contrast ratio is ensured and explicit adjustment is forced.\n */\n color: black;\n background-color: white;\n /*\n * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n /*\n * Text should be aligned left by default to provide a predictable starting point.\n */\n text-align: left;\n }\n * {\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n hyphens: auto;\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n word-break: break-word;\n }\n /*\n * All interactive elements should have a minimum size of to-rem(44).\n */\n /* input:not([type=\'checkbox\'], [type=\'radio\'], [type=\'range\']), */\n /* option, */\n /* select, */\n /* textarea, */\n button,\n .kol-input .input {\n min-width: var(--a11y-min-size);\n min-height: var(--a11y-min-size);\n }\n /*\n * Some interactive elements should not inherit the font-family and font-size.\n */\n a,\n button,\n h1,\n h2,\n h3,\n h4,\n h5,\n h6,\n input,\n option,\n select,\n textarea {\n /*\n * All elements should inherit the text color from his parent element.\n */\n color: inherit;\n /*\n * All elements should inherit the font family from his parent element.\n */\n font-family: inherit;\n /*\n * All elements should inherit the font size from his parent element.\n */\n font-size: inherit;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n }\n /**\n * Sometimes we need the semantic element for accessibility reasons,\n * but we don\'t want to show it.\n *\n * - https://www.a11yproject.com/posts/how-to-hide-content/\n */\n .visually-hidden {\n position: fixed;\n top: 0;\n left: 0;\n width: 1px;\n height: 1px;\n overflow: hidden;\n white-space: nowrap;\n clip-path: inset(50%);\n }\n}\n@layer kol-global {\n /*\n * Dieses CSS stellt sicher, dass der Standard-Style\n * von A und Button resettet werden.\n */\n :is(a, button) {\n background-color: transparent;\n width: 100%;\n margin: 0;\n padding: 0;\n border: none;\n /* 100% needed for custom width from outside */\n }\n /*\n * Ensure elements with hidden attribute to be actually not visible\n * @see https://meowni.ca/hidden.is.a.lie.html\n */\n [hidden] {\n display: none !important;\n }\n .badge-text-hint {\n color: black;\n background-color: lightgray;\n }\n}\n@layer kol-global {\n :host {\n /*\n * The max-width is needed to prevent the table from overflowing the\n * parent node, if the table is wider than the parent node.\n */\n max-width: 100%;\n font-size: calc(16 * 1rem / var(--kolibri-root-font-size, 16));\n }\n * {\n /*\n * We prefer to box-sizing: border-box for all elements.\n */\n box-sizing: border-box;\n }\n .kol-span {\n /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n display: flex;\n flex-flow: column;\n align-items: center;\n justify-content: center;\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n }\n .kol-span__container {\n display: flex;\n align-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .kol-span .kol-span__label--hide-label .kol-span__label {\n display: none;\n }\n /* Reset browser agent style. */\n button:disabled {\n color: unset;\n }\n .disabled label,\n .disabled:focus-within label,\n [aria-disabled=true],\n [aria-disabled=true]:focus,\n [disabled],\n [disabled]:focus {\n opacity: 0.5;\n outline: none;\n cursor: not-allowed;\n }\n [aria-disabled=true]:focus .kol-span,\n [disabled]:focus .kol-span {\n outline: none !important;\n }\n .hastooltip {\n z-index: 900 !important;\n }\n}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n@font-face {\n font-family: "kolicons";\n src: url("kolicons.eot?t=1774433546045"); /* IE9*/\n src: url("kolicons.eot?t=1774433546045#iefix") format("embedded-opentype"), url("kolicons.woff2?t=1774433546045") format("woff2"), url("kolicons.woff?t=1774433546045") format("woff"), url("kolicons.ttf?t=1774433546045") format("truetype"), url("kolicons.svg?t=1774433546045#kolicons") format("svg"); /* iOS 4.1- */\n}\n[class^=kolicon-], [class*=" kolicon-"] {\n font-family: "kolicons";\n font-style: normal;\n font-weight: 400;\n line-height: 1em;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\n.kolicon-alert-error::before {\n content: "\\ea01";\n}\n\n.kolicon-alert-info::before {\n content: "\\ea02";\n}\n\n.kolicon-alert-success::before {\n content: "\\ea03";\n}\n\n.kolicon-alert-warning::before {\n content: "\\ea04";\n}\n\n.kolicon-check::before {\n content: "\\ea05";\n}\n\n.kolicon-chevron-double-left::before {\n content: "\\ea06";\n}\n\n.kolicon-chevron-double-right::before {\n content: "\\ea07";\n}\n\n.kolicon-chevron-down::before {\n content: "\\ea08";\n}\n\n.kolicon-chevron-left::before {\n content: "\\ea09";\n}\n\n.kolicon-chevron-right::before {\n content: "\\ea0a";\n}\n\n.kolicon-chevron-up::before {\n content: "\\ea0b";\n}\n\n.kolicon-cogwheel::before {\n content: "\\ea0c";\n}\n\n.kolicon-cross::before {\n content: "\\ea0d";\n}\n\n.kolicon-eye-closed::before {\n content: "\\ea0e";\n}\n\n.kolicon-eye::before {\n content: "\\ea0f";\n}\n\n.kolicon-house::before {\n content: "\\ea10";\n}\n\n.kolicon-kolibri::before {\n content: "\\ea11";\n}\n\n.kolicon-link-external::before {\n content: "\\ea12";\n}\n\n.kolicon-link::before {\n content: "\\ea13";\n}\n\n.kolicon-minus::before {\n content: "\\ea14";\n}\n\n.kolicon-plus::before {\n content: "\\ea15";\n}\n\n.kolicon-settings::before {\n content: "\\ea16";\n}\n\n.kolicon-sort-asc::before {\n content: "\\ea17";\n}\n\n.kolicon-sort-desc::before {\n content: "\\ea18";\n}\n\n.kolicon-sort-neutral::before {\n content: "\\ea19";\n}\n\n.kolicon-up::before {\n content: "\\ea1a";\n}\n\n.kolicon-version::before {\n content: "\\ea1b";\n}\n\n@layer kol-component {\n .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n .kol-tooltip {\n display: contents;\n }\n .kol-tooltip__floating {\n opacity: 0;\n display: none;\n position: fixed;\n /* Avoid layout interference - see https://floating-ui.com/docs/computePosition */\n top: 0;\n left: 0;\n /* Can be used to specify the tooltip-width from the outside. Unset by default. */\n width: var(--kol-tooltip-width, max-content);\n min-width: calc(8 * 1rem / var(--kolibri-root-font-size, 16));\n max-width: 90vw;\n max-height: 90vh;\n animation-direction: normal;\n /* Can be used to specify the animation duration from the outside. 250ms by default. */\n animation-duration: var(--kolibri-tooltip-animation-duration, 250ms);\n animation-fill-mode: forwards;\n animation-iteration-count: 1;\n animation-timing-function: ease-in;\n }\n .kol-tooltip__floating.hide {\n animation-name: hideTooltip;\n }\n .kol-tooltip__floating.show {\n animation-name: showTooltip;\n }\n .kol-tooltip__arrow {\n transform: rotate(45deg);\n color: #000;\n background-color: #fff;\n position: absolute;\n z-index: 999;\n width: calc(10 * 1rem / var(--kolibri-root-font-size, 16));\n height: calc(10 * 1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-tooltip__content {\n color: #000;\n background-color: #fff;\n position: relative;\n z-index: 1000;\n }\n @keyframes hideTooltip {\n 0% {\n opacity: 1;\n }\n 100% {\n opacity: 0;\n display: none;\n }\n }\n @keyframes showTooltip {\n 0% {\n opacity: 0;\n }\n 100% {\n opacity: 1;\n }\n }\n}\n@layer kol-component {\n .kol-alert .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n .kol-alert :host {\n display: inline-block;\n }\n .kol-alert .kol-button {\n display: flex;\n min-height: var(--a11y-min-size);\n font-style: calc(16 * 1rem / var(--kolibri-root-font-size, 16));\n text-decoration-line: none;\n }\n .kol-alert .kol-button::before {\n /* Render zero-width character as first element to set the baseline correctly. */\n content: "​";\n }\n .kol-alert .kol-button__text {\n flex: 1 0 100%;\n }\n .kol-alert {\n display: grid;\n }\n .kol-alert__container {\n display: flex;\n place-items: center;\n }\n .kol-alert__container-content {\n flex-grow: 1;\n }\n .kol-alert__closer {\n /* Visible with forced colors */\n outline: transparent solid calc(1 * 1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-custom-suggestions-option {\n line-height: 1.5;\n white-space: normal;\n cursor: pointer;\n overflow-wrap: break-word;\n }\n .kol-custom-suggestions-options-group--cursor-hidden .kol-custom-suggestions-option {\n cursor: none !important;\n }\n .kol-custom-suggestions-option--disabled:focus, .kol-custom-suggestions-option--disabled:focus * {\n cursor: not-allowed;\n }\n .kol-custom-suggestions-options-group {\n background-color: white;\n display: block;\n position: absolute;\n z-index: 2;\n max-height: calc(250 * 1rem / var(--kolibri-root-font-size, 16));\n margin: 0;\n padding: 0;\n overflow-x: hidden;\n overflow-y: auto;\n list-style-type: none;\n }\n .kol-input-container:has(.kol-custom-suggestions-options-group--open) {\n z-index: 10;\n }\n .kol-custom-suggestions-toggle {\n display: flex;\n min-width: var(--a11y-min-size);\n min-height: var(--a11y-min-size);\n align-items: center;\n justify-content: center;\n cursor: default;\n }\n .kol-custom-suggestions-toggle.kol-custom-suggestions-toggle--disabled {\n cursor: not-allowed;\n }\n .kol-form-field {\n display: grid;\n }\n .kol-form-field:not(.kol-form-field--disabled) .kol-form-field__label {\n cursor: pointer;\n }\n .kol-form-field__label-text {\n flex-flow: row;\n align-items: flex-start;\n justify-content: flex-start;\n }\n .kol-form-field--disabled .kol-form-field__label {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__label-text:not(:has(> [name]))::after,\n .kol-form-field--required .kol-form-field__tooltip .span-label::after {\n content: "*"/"";\n }\n .kol-form-field--disabled .kol-form-field__hint {\n opacity: 0.5;\n }\n .kol-input-container {\n background-color: transparent;\n display: grid;\n width: 100%;\n min-width: var(--a11y-min-size);\n min-height: var(--a11y-min-size);\n align-items: center;\n grid-template-columns: 1fr;\n }\n .kol-input-container:has(> .kol-input-container__adornment--start) {\n grid-template-columns: auto 1fr auto;\n }\n .kol-input-container__container {\n position: relative;\n }\n .kol-input-container__adornment {\n display: flex;\n align-items: center;\n }\n .kol-input-container__adornment .kol-icon {\n display: grid;\n min-height: var(--a11y-min-size);\n place-items: center;\n }\n .kol-input {\n background-color: transparent;\n width: 100%;\n min-width: var(--a11y-min-size);\n }\n .kol-input:focus {\n outline: none;\n }\n .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n .kol-single-select__delete .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n .kol-single-select__delete :host {\n display: inline-block;\n }\n .kol-single-select__delete .kol-button {\n display: flex;\n min-height: var(--a11y-min-size);\n font-style: calc(16 * 1rem / var(--kolibri-root-font-size, 16));\n text-decoration-line: none;\n }\n .kol-single-select__delete .kol-button::before {\n /* Render zero-width character as first element to set the baseline correctly. */\n content: "​";\n }\n .kol-single-select__delete .kol-button__text {\n flex: 1 0 100%;\n }\n .kol-single-select__delete .kol-button {\n margin-top: -2px;\n margin-bottom: -2px;\n }\n .kol-single-select__no-results-message {\n display: flex;\n min-height: calc(50 * 1rem / var(--kolibri-root-font-size, 16));\n align-items: center;\n justify-content: center;\n cursor: default;\n }\n .kol-single-select .kol-custom-suggestions-options-group {\n max-height: calc(40 * 1rem / var(--kolibri-root-font-size, 16) * var(--visible-options, 5) + 2 * 1rem / var(--kolibri-root-font-size, 16)) !important;\n }\n .kol-custom-suggestions-toggle:not(.kol-custom-suggestions-toggle--disabled) {\n cursor: pointer;\n }\n .kol-custom-suggestions-toggle--disabled {\n opacity: 0.5;\n }\n}',KolSingleSelect$1=proxyCustomElement(class extends HTMLElement{async getValue(){return this._value}async focus(){return new Promise(e=>{requestAnimationFrame(()=>{var t;null===(t=this.refInput)||void 0===t||t.focus(),e()})})}onBlur(e){var t,n,o;const i=null===(t=this.state._options)||void 0===t?void 0:t.find(e=>{var t,n;return(null===(t=e.label)||void 0===t?void 0:t.toLowerCase())===(null===(n=this._inputValue)||void 0===n?void 0:n.toLowerCase())});i?this.selectOption(i):!this._isOpen&&this._value&&(this._inputValue=null===(o=null===(n=this.state._options)||void 0===n?void 0:n.find(e=>e.value===this._value))||void 0===o?void 0:o.label,this._filteredOptions=[...this.state._options]),e instanceof FocusEvent&&e.view===window&&!this.isClearing&&(this._isOpen=!1)}createEventWithTarget(e,t){const n=new CustomEvent(e,{bubbles:!0,detail:t});return this.refInput&&(Object.defineProperty(n,"target",{value:this.refInput}),Object.defineProperty(n,"currentTarget",{value:this.refInput})),n}clearSelection(){if(this.isClearing=!0,this.state._disabled)return;const e=null;this._focusedOptionIndex=-1,this._value=e,this._inputValue="",this._filteredOptions=[...this.state._options];const t=this.createEventWithTarget("input",{name:this.state._name,value:e}),n=this.createEventWithTarget("change",{name:this.state._name,value:e});this.controller.onFacade.onInput(t,!0,{value:e}),this.controller.onFacade.onChange(n,{value:e}),this.isClearing=!1}selectOption(e){var t,n;if(e.value===this._value)return this._inputValue=e.label,void(this._filteredOptions=[...this.state._options]);this._value=e.value,this._inputValue=e.label;const o=this.createEventWithTarget("input",{name:null!==(t=this.state._name)&&void 0!==t?t:"",value:e.value}),i=this.createEventWithTarget("change",{name:null!==(n=this.state._name)&&void 0!==n?n:"",value:e.value});this.controller.onFacade.onInput(o,!1,e.value),this.controller.onFacade.onChange(i,e.value),this._filteredOptions=[...this.state._options],this.controller.setFormAssociatedValue(this._value)}onInput(e){const t=e.target;this._inputValue=t.value,this._isOpen=!0,this.setFilteredOptionsByQuery(t.value),this._focusedOptionIndex=-1}handleKeyDownDropdown(e){1===e.key.length&&/[a-z0-9]/i.test(e.key)&&(e.preventDefault(),this._isOpen=!0,this.focusSuggestionStartingWith(e.key))}setFilteredOptionsByQuery(e){""===(null==e?void 0:e.trim())?this._filteredOptions=[...this.state._options]:Array.isArray(this.state._options)&&this.state._options.length>0&&e.length>0&&(this._filteredOptions=this.state._options.filter(t=>{var n,o;return null===(o=null===(n=t.label)||void 0===n?void 0:n.toLowerCase())||void 0===o?void 0:o.includes(null==e?void 0:e.toLowerCase())}))}moveFocus(e){if(!this._filteredOptions)return;let t=this._focusedOptionIndex+e,n=0,o=!1;const i=this._filteredOptions.length;for(;n<i;){t>=this._filteredOptions.length&&(t=0),t<0&&(t=this._filteredOptions.length-1);if(!this._filteredOptions[t].disabled){o=!0;break}t+=e,n++}o&&(this._focusedOptionIndex=t,this.focusOption(this._focusedOptionIndex))}focusOption(e){if(this.refOptions){const t=this.refOptions[e];null==t||t.focus()}}selectFocusedOption(){return!!(Array.isArray(this._filteredOptions)&&this._filteredOptions.length>0&&this._focusedOptionIndex>=0)&&(this.selectOption(this._filteredOptions[this._focusedOptionIndex]),!0)}focusSuggestionStartingWith(e){const t=e.toLowerCase(),n=Array.isArray(this._filteredOptions)&&this._filteredOptions.findIndex(e=>e.label.toLowerCase().startsWith(t)&&!e.disabled);"number"==typeof n&&n>=0&&(this._focusedOptionIndex=n,this.focusOption(n))}getFormFieldProps(){return{state:this.state,class:"kol-single-select",tooltipAlign:this._tooltipAlign,alert:this.showAsAlert()}}getInputProps(){const{ariaDescribedBy:e}=getRenderStates(this.state),t=!0===this.state._disabled;return Object.assign(Object.assign({"aria-activedescendant":this._isOpen&&this._focusedOptionIndex>=0?`option-${this._focusedOptionIndex}`:void 0,"aria-autocomplete":"both","aria-controls":"listbox","aria-describedby":e.length>0?e.join(" "):void 0,"aria-label":this.state._hideLabel&&"string"==typeof this.state._label?this.state._label:void 0,"aria-keyshortcuts":this.state._shortKey,accessKey:this.state._accessKey,autocapitalize:"off",autocorrect:"off",class:"kol-single-select__input",disabled:t,name:this.state._name,placeholder:this.state._placeholder,ref:this.catchRef,required:this.state._required,role:"combobox",state:this.state,type:"text",value:this._inputValue},this.controller.onFacade),{onChange:this.onChange.bind(this),onClick:this.onClick.bind(this),onInput:this.onInput.bind(this),onFocus:e=>{this.controller.onFacade.onFocus(e),this.inputHasFocus=!0},onBlur:e=>{this.controller.onFacade.onBlur(e),this.inputHasFocus=!1}})}render(){var e;const t=!0===this.state._disabled;return h(FormFieldStateWrapper,Object.assign({key:"936aea64c96e1b41c51491d9b12e2007e86ab538"},this.getFormFieldProps()),h(InputContainerStateWrapperFc,{key:"ee1dbbac05316279a73a31ec3fe01ffd353d8439",state:this.state},h("div",{key:"ba8dfa3a0453f83ae87b3ab9897ef37c18f0c23a",class:"kol-single-select__group"},h(InputStateWrapper,Object.assign({key:"3fc17ed11af99cdec2a955722f17399721773f3b"},this.getInputProps())),this._inputValue&&this.state._hasClearButton&&h(KolButtonWcTag,{key:"78a7745d98330067ee4d2a6eef8245ebdce5709f",_icons:"kolicon-cross",_label:this.translateDeleteSelection,_hideLabel:!0,_variant:"ghost",_disabled:t,"data-testid":"single-select-delete",class:"kol-single-select__delete",hidden:t,_on:{onClick:()=>{var e;this.clearSelection(),null===(e=this.refInput)||void 0===e||e.focus()}}}),h(IconFC,{key:"b43ff56f9232d62b081035ccd11d7a88f1b8c195",icons:"kolicon-chevron-down",label:"",class:clsx("kol-custom-suggestions-toggle",{"kol-custom-suggestions-toggle--disabled":t}),onClick:this.toggleListbox.bind(this)})),h(CustomSuggestionsOptionsGroupFc,{key:"c7c67612809bad524cd1a9c636d4dcec2af58b06",blockSuggestionMouseOver:this.blockSuggestionMouseOver,onKeyDown:this.handleKeyDownDropdown.bind(this),style:{"--visible-options":`${null!==(e=this._rows)&&void 0!==e?e:5}`},hidden:!this._isOpen||t},Array.isArray(this._filteredOptions)&&this._filteredOptions.length>0?this._filteredOptions.map((e,t)=>h(CustomSuggestionsOptionFc,{index:t,option:e.label,searchTerm:this._inputValue,ref:e=>{e&&(this.refOptions[t]=e)},selected:this._value===e.value,disabled:!!e.disabled,onClick:t=>{var n;e.disabled||(this.selectOption(e),null===(n=this.refInput)||void 0===n||n.focus(),this.toggleListbox(t),this._isOpen=!1)},onMouseOver:()=>{this.blockSuggestionMouseOver||(this._focusedOptionIndex=t,this.focusOption(t))},onFocus:()=>{e.disabled||(this._focusedOptionIndex=t,this.focusOption(t))},onKeyDown:t=>{var n;e.disabled||"Enter"!==t.key&&"NumpadEnter"!==t.key||(this.selectOption(e),null===(n=this.refInput)||void 0===n||n.focus(),this.toggleListbox(t),t.preventDefault())}})):h("li",{class:"kol-single-select__no-results-message",role:"alert"},this.translateNoResultsMessage," "))))}handleFocusOut(e){setTimeout(()=>{var t;(null===(t=this.host)||void 0===t?void 0:t.contains(document.activeElement))||this.onBlur(e)})}handleWindowBlur(e){this.onBlur(e)}handleKeyDown(e){var t,n;const o=(t,n)=>{var o;e.preventDefault(),void 0!==t&&(this._isOpen=t,t||null===(o=this.refInput)||void 0===o||o.focus()),null==n||n()};switch(e.key){case"Down":case"ArrowDown":this.blockSuggestionMouseOver=!0,o(!0,()=>this.moveFocus(1));break;case"Up":case"ArrowUp":this.blockSuggestionMouseOver=!0,o(!0,()=>this.moveFocus(-1));break;case"Tab":this._isOpen&&(this._isOpen=!this._isOpen,null===(t=this.refInput)||void 0===t||t.focus());break;case"Esc":case"Escape":this._isOpen=!1,o(!1);break;case" ":case"Enter":case"NumpadEnter":this._isOpen?this.selectFocusedOption()&&(null===(n=this.refInput)||void 0===n||n.focus(),o(!1)):this.toggleListbox(e);break;case"Home":this.blockSuggestionMouseOver=!0,o(void 0,()=>{this._isOpen&&(this._focusedOptionIndex=0,this.focusOption(this._focusedOptionIndex))});break;case"End":this.blockSuggestionMouseOver=!0,o(void 0,()=>{this._isOpen&&(this._focusedOptionIndex=this._filteredOptions?this._filteredOptions.length-1:0,this.focusOption(this._focusedOptionIndex))});break;case"PageUp":this.blockSuggestionMouseOver=!0,o(void 0,()=>this._isOpen&&this.moveFocus(-10));break;case"PageDown":this.blockSuggestionMouseOver=!0,o(void 0,()=>this._isOpen&&this.moveFocus(10))}}constructor(e){super(),!1!==e&&this.__registerHost(),this.__attachShadow(),this.refOptions=[],this.translateDeleteSelection=translate("kol-delete-selection"),this.translateNoResultsMessage=translate("kol-no-results-message"),this.isClearing=!1,this.catchRef=e=>{this.refInput=e},this.toggleListbox=e=>{var t;null==e||e.preventDefault();if(!(!0===this.state._disabled))if(null===(t=this.refInput)||void 0===t||t.focus(),this._isOpen)this._isOpen=!1;else{this._isOpen=!0;const e=Array.isArray(this._filteredOptions)?this._filteredOptions.findIndex(e=>e.label===this._inputValue):-1;this._focusedOptionIndex=e>=0?e:-1,this.focusOption(this._focusedOptionIndex)}},this._focusedOptionIndex=-1,this._isOpen=!1,this._filteredOptions=[],this._inputValue="",this.blockSuggestionMouseOver=!1,this._disabled=!1,this._hideMsg=!1,this._hideLabel=!1,this._hint="",this._required=!1,this._tooltipAlign="top",this._touched=!1,this._value=null,this._hasClearButton=!0,this.state={_hideMsg:!1,_id:`id-${nonce()}`,_label:"",_options:[],_hasClearButton:!0},this.inputHasFocus=!1,this.controller=new SingleSelectController(this,"single-select",this.host)}showAsAlert(){return Boolean(this.state._touched)&&!this.inputHasFocus}validatePlaceholder(e){this.controller.validatePlaceholder(e)}validateAccessKey(e){this.controller.validateAccessKey(e)}validateDisabled(e){this.controller.validateDisabled(e)}validateHideMsg(e){this.controller.validateHideMsg(e)}validateHideLabel(e){this.controller.validateHideLabel(e)}validateHint(e){this.controller.validateHint(e)}validateIcons(e){this.controller.validateIcons(e)}validateLabel(e){this.controller.validateLabel(e)}validateMsg(e){this.controller.validateMsg(e)}validateName(e){this.controller.validateName(e)}validateOn(e){this.controller.validateOn(e)}validateOptions(e){this.controller.validateOptions(e),this._filteredOptions=e,this.updateInputValue(this._value)}validateRequired(e){this.controller.validateRequired(e)}validateShortKey(e){this.controller.validateShortKey(e)}validateSyncValueBySelector(e){this.controller.validateSyncValueBySelector(e)}validateTouched(e){this.controller.validateTouched(e)}validateValue(e){this.controller.validateValue(e),this.oldValue=e,this.updateInputValue(e)}validateHasClearButton(e){this.controller.validateHasClearButton(e)}validateRows(e){this.controller.validateRows(e)}handleMouseEvent(){this.blockSuggestionMouseOver=!1}updateInputValue(e){if(Array.isArray(this._options)){const t=this._options.find(t=>t.value===e);this._inputValue=t?String(t.label):""}}componentWillLoad(){this.refOptions=[],this._touched=!0===this._touched,this.controller.componentWillLoad(),this.oldValue=this._value,this._filteredOptions=this.state._options,this.updateInputValue(this._value)}onChange(e){var t,n;this.oldValue!==(null===(t=this.refInput)||void 0===t?void 0:t.value)&&(this.oldValue=null===(n=this.refInput)||void 0===n?void 0:n.value),this._isOpen||this.controller.onFacade.onChange(e,this._value)}onClick(e){var t;this.toggleListbox(e),null===(t=this.refInput)||void 0===t||t.focus(),this.controller.onFacade.onClick(e)}get host(){return this}static get watchers(){return{_placeholder:["validatePlaceholder"],_accessKey:["validateAccessKey"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_label:["validateLabel"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_options:["validateOptions"],_required:["validateRequired"],_shortKey:["validateShortKey"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"],_hasClearButton:["validateHasClearButton"],_rows:["validateRows"]}}static get style(){return{default:defaultStyleCss}}},[289,"kol-single-select",{_accessKey:[1,"_access-key"],_placeholder:[1],_disabled:[4],_hideMsg:[4,"_hide-msg"],_hideLabel:[4,"_hide-label"],_hint:[1],_icons:[1],_label:[1],_msg:[1],_name:[1],_on:[16],_options:[1],_required:[4],_shortKey:[1,"_short-key"],_syncValueBySelector:[1,"_sync-value-by-selector"],_tooltipAlign:[1,"_tooltip-align"],_touched:[1540],_value:[1544],_hasClearButton:[4,"_has-clear-button"],_rows:[2],_isOpen:[32],_filteredOptions:[32],_inputValue:[32],blockSuggestionMouseOver:[32],state:[32],inputHasFocus:[32],getValue:[64],focus:[64]},[[0,"focusout","handleFocusOut"],[0,"blur","handleWindowBlur"],[0,"keydown","handleKeyDown"],[1,"mousemove","handleMouseEvent"]],{_placeholder:["validatePlaceholder"],_accessKey:["validateAccessKey"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_label:["validateLabel"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_options:["validateOptions"],_required:["validateRequired"],_shortKey:["validateShortKey"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"],_hasClearButton:["validateHasClearButton"],_rows:["validateRows"]}]);function defineCustomElement$1(){if("undefined"==typeof customElements)return;["kol-single-select"].forEach(e=>{if("kol-single-select"===e)customElements.get(e)||customElements.define(e,KolSingleSelect$1)})}const KolSingleSelect=KolSingleSelect$1,defineCustomElement=defineCustomElement$1;export{KolSingleSelect,defineCustomElement};
@@ -1 +1 @@
1
- {"file":"kol-single-select.js","mappings":"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","names":["KolSingleSelect","__stencil_proxyCustomElement","KolFormFieldStateWrapperFc","KolInputContainerFc","KolInputStateWrapperFc"],"sources":["src/components/single-select/controller.ts","src/components/single-select/style.scss?tag=kol-single-select&mode=default&encapsulation=shadow","src/components/single-select/shadow.tsx"],"sourcesContent":["import type {\n\tOption,\n\tOptionsPropType,\n\tPlaceholderPropType,\n\tRequiredPropType,\n\tSelectOption,\n\tSingleSelectProps,\n\tSingleSelectWatches,\n\tStencilUnknown,\n\tW3CInputValue,\n} from '../../schema';\nimport { validateOptions, validatePlaceholder, validateRequired, watchBoolean, watchNumber, watchValidator } from '../../schema';\n\nimport { InputIconController } from '../@deprecated/input/controller-icon';\nimport { fillKeyOptionMap } from '../input-radio/controller';\n\nimport type { Generic } from 'adopted-style-sheets';\n\nexport class SingleSelectController extends InputIconController implements SingleSelectWatches {\n\tprotected readonly component: Generic.Element.Component & SingleSelectProps;\n\tprivate readonly keyOptionMap = new Map<string, Option<string>>();\n\n\tpublic constructor(component: Generic.Element.Component & SingleSelectProps, name: string, host?: HTMLElement) {\n\t\tsuper(component, name, host);\n\t\tthis.component = component;\n\t}\n\n\tprotected readonly afterPatchOptions = (value: unknown, _state: Record<string, unknown>, _component: Generic.Element.Component, key: string): void => {\n\t\tif (key === '_value') {\n\t\t\tthis.setFormAssociatedValue(value as string);\n\t\t}\n\t};\n\n\tprotected readonly beforePatchOptions = (_value: unknown, nextState: Map<string, unknown>): void => {\n\t\tconst options = nextState.has('_options') ? nextState.get('_options') : this.component.state._options;\n\t\tif (Array.isArray(options) && options.length > 0) {\n\t\t\tthis.keyOptionMap.clear();\n\t\t\tfillKeyOptionMap(this.keyOptionMap, options as SelectOption<W3CInputValue>[]);\n\t\t}\n\t};\n\n\tpublic validateOptions(value?: OptionsPropType): void {\n\t\tvalidateOptions(this.component, value, {\n\t\t\thooks: {\n\t\t\t\tafterPatch: this.afterPatchOptions,\n\t\t\t\tbeforePatch: this.beforePatchOptions,\n\t\t\t},\n\t\t});\n\t}\n\n\tpublic validateRequired(value?: RequiredPropType): void {\n\t\tvalidateRequired(this.component, value);\n\t}\n\n\tpublic validateValue(value: StencilUnknown): void {\n\t\twatchValidator(this.component, '_value', (v) => v !== undefined, new Set([`StencilUnknown`]), value);\n\t}\n\n\tpublic validatePlaceholder(value?: PlaceholderPropType): void {\n\t\tvalidatePlaceholder(this.component, value);\n\t}\n\n\tpublic validateHasClearButton(value?: boolean): void {\n\t\twatchBoolean(this.component, '_hasClearButton', value);\n\t}\n\n\tpublic validateRows(value?: number): void {\n\t\twatchNumber(this.component, '_rows', value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tsuper.componentWillLoad();\n\t\tthis.validateOptions(this.component._options);\n\t\tthis.validateRequired(this.component._required);\n\t\tthis.validateValue(this.component._value);\n\t\tthis.validatePlaceholder(this.component._placeholder);\n\t\tthis.validateHasClearButton(this.component._hasClearButton);\n\t\tthis.validateRows(this.component._rows);\n\t}\n}\n","@use '../../styles/global' as *;\n@use '../../styles/kol-alert-mixin' as *;\n@use '../../styles/kol-custom-suggestions-option' as *;\n@use '../../styles/kol-custom-suggestions-options-group' as *;\n@use '../../styles/kol-custom-suggestions-toggle' as *;\n@use '../../styles/kol-form-field-mixin' as *;\n@use '../../styles/kol-input-container-mixin' as *;\n@use '../../styles/kol-input-mixin' as *;\n@use '../@shared/mixins' as *;\n@use '../@shared/kol-button-mixin' as *;\n@use '../@shared/kol-icon-mixin' as *;\n\n@layer kol-component {\n\t@include kol-alert;\n\t@include kol-custom-suggestions-option;\n\t@include kol-custom-suggestions-options-group;\n\t@include kol-custom-suggestions-toggle;\n\t@include kol-form-field;\n\t@include kol-input-container;\n\t@include kol-input;\n\t@include kol-icon-styles();\n\n\t$option-height: to-rem(40);\n\t$visible-options: var(--visible-options, 5);\n\n\t.kol-single-select {\n\t\t&__delete {\n\t\t\t@include kol-button-styles('kol-button');\n\t\t\t.kol-button {\n\t\t\t\tmargin-top: -2px;\n\t\t\t\tmargin-bottom: -2px;\n\t\t\t}\n\t\t}\n\n\t\t&__no-results-message {\n\t\t\tdisplay: flex;\n\t\t\tmin-height: to-rem(50);\n\t\t\talign-items: center;\n\t\t\tjustify-content: center;\n\t\t\tcursor: default;\n\t\t}\n\n\t\t.kol-custom-suggestions-options-group {\n\t\t\tmax-height: calc($option-height * $visible-options + to-rem(2)) !important;\n\t\t}\n\t}\n\n\t.kol-custom-suggestions-toggle {\n\t\t&:not(&--disabled) {\n\t\t\tcursor: pointer;\n\t\t}\n\n\t\t&--disabled {\n\t\t\topacity: 0.5;\n\t\t}\n\t}\n}\n","import type { JSX } from '@stencil/core';\nimport { Component, Element, h, Listen, Method, Prop, State, Watch } from '@stencil/core';\nimport type {\n\tDisabledPropType,\n\tHideLabelPropType,\n\tHideMsgPropType,\n\tHintPropType,\n\tIconsHorizontalPropType,\n\tInputTypeOnDefault,\n\tLabelWithExpertSlotPropType,\n\tMsgPropType,\n\tNamePropType,\n\tOption,\n\tOptionsPropType,\n\tPlaceholderPropType,\n\tRequiredPropType,\n\tRowsPropType,\n\tShortKeyPropType,\n\tSingleSelectAPI,\n\tSingleSelectStates,\n\tStencilUnknown,\n\tStringified,\n\tSyncValueBySelectorPropType,\n\tTooltipAlignPropType,\n} from '../../schema';\n\nimport { KolButtonWcTag } from '../../core/component-names';\nimport { getRenderStates } from '../../functional-component-wrappers/_helpers/getRenderStates';\nimport KolFormFieldStateWrapperFc, { type FormFieldStateWrapperProps } from '../../functional-component-wrappers/FormFieldStateWrapper/FormFieldStateWrapper';\nimport KolInputContainerFc from '../../functional-component-wrappers/InputContainerStateWrapper/InputContainerStateWrapper';\nimport type { InputStateWrapperProps } from '../../functional-component-wrappers/InputStateWrapper/InputStateWrapper';\nimport KolInputStateWrapperFc from '../../functional-component-wrappers/InputStateWrapper/InputStateWrapper';\nimport CustomSuggestionsOptionFc from '../../functional-components/CustomSuggestionsOption/CustomSuggestionsOption';\nimport CustomSuggestionsOptionsGroupFc from '../../functional-components/CustomSuggestionsOptionsGroup';\nimport { translate } from '../../i18n';\nimport { IconFC } from '../../internal/functional-components/icon/component';\nimport type { EventDetail } from '../../schema/interfaces/EventDetail';\nimport clsx from '../../utils/clsx';\nimport { nonce } from '../../utils/dev.utils';\nimport { SingleSelectController } from './controller';\n\n/**\n * @slot - The input field label.\n */\n@Component({\n\ttag: 'kol-single-select',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolSingleSelect implements SingleSelectAPI {\n\t@Element() private readonly host?: HTMLElement;\n\tprivate refInput?: HTMLInputElement;\n\tprivate refOptions: HTMLLIElement[] = [];\n\tprivate readonly translateDeleteSelection = translate('kol-delete-selection');\n\tprivate readonly translateNoResultsMessage = translate('kol-no-results-message');\n\tprivate oldValue?: StencilUnknown;\n\t// so onBlur doesn't close the panel if clear button is pressed\n\tprivate isClearing = false;\n\n\t/**\n\t * Returns the current value.\n\t */\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tpublic async getValue(): Promise<StencilUnknown> {\n\t\treturn this._value;\n\t}\n\n\t/**\n\t * Sets focus on the internal element.\n\t */\n\t@Method()\n\tpublic async focus() {\n\t\treturn new Promise<void>((resolve) => {\n\t\t\trequestAnimationFrame(() => {\n\t\t\t\tthis.refInput?.focus();\n\t\t\t\tresolve();\n\t\t\t});\n\t\t});\n\t}\n\n\tprivate readonly catchRef = (ref?: HTMLInputElement) => {\n\t\tthis.refInput = ref;\n\t};\n\n\tprivate toggleListbox = (event: Event) => {\n\t\tevent?.preventDefault();\n\t\tconst isDisabled = this.state._disabled === true;\n\t\tif (isDisabled) {\n\t\t\treturn;\n\t\t} else {\n\t\t\tthis.refInput?.focus();\n\t\t\tif (this._isOpen) {\n\t\t\t\t// Liste schließen\n\t\t\t\tthis._isOpen = false;\n\t\t\t} else {\n\t\t\t\t// Liste öffnen\n\t\t\t\tthis._isOpen = true;\n\t\t\t\tconst selectedIndex = Array.isArray(this._filteredOptions) ? this._filteredOptions.findIndex((option) => option.label === this._inputValue) : -1;\n\t\t\t\tthis._focusedOptionIndex = selectedIndex >= 0 ? selectedIndex : -1;\n\t\t\t\tthis.focusOption(this._focusedOptionIndex);\n\t\t\t}\n\t\t}\n\t};\n\n\tprivate onBlur(event: FocusEvent) {\n\t\tconst matchingOption = this.state._options?.find((option) => (option.label as string)?.toLowerCase() === this._inputValue?.toLowerCase());\n\t\tif (matchingOption) {\n\t\t\tthis.selectOption(matchingOption as Option<string>);\n\t\t} else if (!this._isOpen && this._value) {\n\t\t\tthis._inputValue = this.state._options?.find((option) => (option as Option<string>).value === this._value)?.label as string;\n\t\t\tthis._filteredOptions = [...this.state._options];\n\t\t}\n\t\tif (event instanceof FocusEvent && event.view === window && !this.isClearing) {\n\t\t\tthis._isOpen = false;\n\t\t}\n\t}\n\n\tprivate createEventWithTarget(type: string, detail: EventDetail): CustomEvent<EventDetail> {\n\t\tconst event = new CustomEvent<EventDetail>(type, {\n\t\t\tbubbles: true,\n\t\t\tdetail,\n\t\t});\n\n\t\tif (this.refInput) {\n\t\t\tObject.defineProperty(event, 'target', {\n\t\t\t\tvalue: this.refInput,\n\t\t\t});\n\n\t\t\tObject.defineProperty(event, 'currentTarget', {\n\t\t\t\tvalue: this.refInput,\n\t\t\t});\n\t\t}\n\t\treturn event;\n\t}\n\n\tprivate clearSelection() {\n\t\tthis.isClearing = true;\n\n\t\tif (this.state._disabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst emptyValue = null;\n\t\tthis._focusedOptionIndex = -1;\n\t\tthis._value = emptyValue;\n\t\tthis._inputValue = '';\n\t\tthis._filteredOptions = [...this.state._options];\n\n\t\tconst inputEvent = this.createEventWithTarget('input', {\n\t\t\tname: this.state._name as string,\n\t\t\tvalue: emptyValue,\n\t\t});\n\t\tconst changeEvent = this.createEventWithTarget('change', {\n\t\t\tname: this.state._name as string,\n\t\t\tvalue: emptyValue,\n\t\t});\n\n\t\tthis.controller.onFacade.onInput(inputEvent, true, { value: emptyValue });\n\t\tthis.controller.onFacade.onChange(changeEvent, { value: emptyValue });\n\n\t\tthis.isClearing = false;\n\t}\n\n\tprivate selectOption(option: Option<string>) {\n\t\tif (option.value === this._value) {\n\t\t\tthis._inputValue = option.label as string;\n\t\t\tthis._filteredOptions = [...this.state._options];\n\t\t\treturn;\n\t\t}\n\n\t\tthis._value = option.value;\n\t\tthis._inputValue = option.label as string;\n\n\t\tconst inputEvent = this.createEventWithTarget('input', {\n\t\t\tname: this.state._name ?? '',\n\t\t\tvalue: option.value,\n\t\t});\n\t\tconst changeEvent = this.createEventWithTarget('change', {\n\t\t\tname: this.state._name ?? '',\n\t\t\tvalue: option.value,\n\t\t});\n\n\t\tthis.controller.onFacade.onInput(inputEvent, false, option.value);\n\t\tthis.controller.onFacade.onChange(changeEvent, option.value);\n\n\t\tthis._filteredOptions = [...this.state._options];\n\n\t\tthis.controller.setFormAssociatedValue(this._value);\n\t}\n\n\tprivate onInput(event: Event) {\n\t\tconst target = event.target as HTMLInputElement;\n\t\tthis._inputValue = target.value;\n\t\tthis._isOpen = true;\n\t\tthis.setFilteredOptionsByQuery(target.value);\n\t\tthis._focusedOptionIndex = -1;\n\t}\n\n\tprivate handleKeyDownDropdown(event: KeyboardEvent) {\n\t\tif (event.key.length === 1 && /[a-z0-9]/i.test(event.key)) {\n\t\t\tevent.preventDefault();\n\t\t\tthis._isOpen = true;\n\t\t\tthis.focusSuggestionStartingWith(event.key);\n\t\t}\n\t}\n\n\tprivate setFilteredOptionsByQuery(query: string) {\n\t\tif (query?.trim() === '') {\n\t\t\tthis._filteredOptions = [...this.state._options];\n\t\t} else if (Array.isArray(this.state._options) && this.state._options.length > 0 && query.length > 0) {\n\t\t\tthis._filteredOptions = this.state._options.filter((option) => {\n\t\t\t\treturn (option.label as string)?.toLowerCase()?.includes(query?.toLowerCase());\n\t\t\t});\n\t\t}\n\t}\n\n\tprivate _focusedOptionIndex: number = -1;\n\n\tprivate moveFocus(delta: number) {\n\t\tif (!this._filteredOptions) {\n\t\t\treturn;\n\t\t}\n\t\tlet newIndex = this._focusedOptionIndex + delta;\n\n\t\tlet iterations = 0;\n\t\tlet foundEnabledOption = false;\n\n\t\tconst maxIterations = this._filteredOptions.length;\n\n\t\twhile (iterations < maxIterations) {\n\t\t\tif (newIndex >= this._filteredOptions.length) {\n\t\t\t\tnewIndex = 0;\n\t\t\t}\n\t\t\tif (newIndex < 0) {\n\t\t\t\tnewIndex = this._filteredOptions.length - 1;\n\t\t\t}\n\n\t\t\tconst option = this._filteredOptions[newIndex] as Option<StencilUnknown>;\n\t\t\tif (!option.disabled) {\n\t\t\t\tfoundEnabledOption = true;\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tnewIndex += delta;\n\t\t\titerations++;\n\t\t}\n\n\t\tif (foundEnabledOption) {\n\t\t\tthis._focusedOptionIndex = newIndex;\n\t\t\tthis.focusOption(this._focusedOptionIndex);\n\t\t}\n\t}\n\n\tprivate focusOption(index: number) {\n\t\tif (this.refOptions) {\n\t\t\tconst optionElement = this.refOptions[index];\n\t\t\toptionElement?.focus();\n\t\t}\n\t}\n\n\tprivate selectFocusedOption(): boolean {\n\t\tif (Array.isArray(this._filteredOptions) && this._filteredOptions.length > 0 && this._focusedOptionIndex >= 0) {\n\t\t\tthis.selectOption(this._filteredOptions[this._focusedOptionIndex] as Option<string>);\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tprivate focusSuggestionStartingWith(char: string) {\n\t\tconst charLowerCase = char.toLowerCase();\n\n\t\tconst index =\n\t\t\tArray.isArray(this._filteredOptions) &&\n\t\t\tthis._filteredOptions.findIndex((option) => (option.label as string).toLowerCase().startsWith(charLowerCase) && !option.disabled);\n\n\t\tif (typeof index === 'number' && index >= 0) {\n\t\t\tthis._focusedOptionIndex = index;\n\t\t\tthis.focusOption(index);\n\t\t}\n\t}\n\n\tprivate getFormFieldProps(): FormFieldStateWrapperProps {\n\t\treturn {\n\t\t\tstate: this.state,\n\t\t\tclass: 'kol-single-select',\n\t\t\ttooltipAlign: this._tooltipAlign,\n\t\t\talert: this.showAsAlert(),\n\t\t};\n\t}\n\n\tprivate getInputProps(): InputStateWrapperProps {\n\t\tconst { ariaDescribedBy } = getRenderStates(this.state);\n\t\tconst isDisabled = this.state._disabled === true;\n\n\t\treturn {\n\t\t\t'aria-activedescendant': this._isOpen && this._focusedOptionIndex >= 0 ? `option-${this._focusedOptionIndex}` : undefined,\n\t\t\t'aria-autocomplete': 'both',\n\t\t\t'aria-controls': 'listbox',\n\t\t\t'aria-describedby': ariaDescribedBy.length > 0 ? ariaDescribedBy.join(' ') : undefined,\n\t\t\t'aria-label': this.state._hideLabel && typeof this.state._label === 'string' ? this.state._label : undefined,\n\t\t\t'aria-keyshortcuts': this.state._shortKey,\n\t\t\taccessKey: this.state._accessKey,\n\t\t\tautocapitalize: 'off',\n\t\t\tautocorrect: 'off',\n\t\t\tclass: 'kol-single-select__input',\n\t\t\tdisabled: isDisabled,\n\t\t\tname: this.state._name,\n\t\t\tplaceholder: this.state._placeholder,\n\t\t\tref: this.catchRef,\n\t\t\trequired: this.state._required,\n\t\t\trole: 'combobox',\n\t\t\tstate: this.state,\n\t\t\ttype: 'text',\n\t\t\tvalue: this._inputValue,\n\t\t\t...this.controller.onFacade,\n\t\t\tonChange: this.onChange.bind(this),\n\t\t\tonClick: this.onClick.bind(this),\n\t\t\tonInput: this.onInput.bind(this),\n\t\t\tonFocus: (event) => {\n\t\t\t\tthis.controller.onFacade.onFocus(event);\n\t\t\t\tthis.inputHasFocus = true;\n\t\t\t},\n\t\t\tonBlur: (event) => {\n\t\t\t\tthis.controller.onFacade.onBlur(event);\n\t\t\t\tthis.inputHasFocus = false;\n\t\t\t},\n\t\t};\n\t}\n\n\tpublic render(): JSX.Element {\n\t\tconst isDisabled = this.state._disabled === true;\n\t\treturn (\n\t\t\t<KolFormFieldStateWrapperFc {...this.getFormFieldProps()}>\n\t\t\t\t<KolInputContainerFc state={this.state}>\n\t\t\t\t\t<div class=\"kol-single-select__group\">\n\t\t\t\t\t\t<KolInputStateWrapperFc {...this.getInputProps()} />\n\n\t\t\t\t\t\t{this._inputValue && this.state._hasClearButton && (\n\t\t\t\t\t\t\t<KolButtonWcTag\n\t\t\t\t\t\t\t\t_icons=\"kolicon-cross\"\n\t\t\t\t\t\t\t\t_label={this.translateDeleteSelection}\n\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t_variant=\"ghost\"\n\t\t\t\t\t\t\t\t_disabled={isDisabled}\n\t\t\t\t\t\t\t\tdata-testid=\"single-select-delete\"\n\t\t\t\t\t\t\t\tclass=\"kol-single-select__delete\"\n\t\t\t\t\t\t\t\thidden={isDisabled}\n\t\t\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\t\t\tonClick: () => {\n\t\t\t\t\t\t\t\t\t\tthis.clearSelection();\n\t\t\t\t\t\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t)}\n\n\t\t\t\t\t\t<IconFC\n\t\t\t\t\t\t\ticons=\"kolicon-chevron-down\"\n\t\t\t\t\t\t\tlabel=\"\"\n\t\t\t\t\t\t\tclass={clsx('kol-custom-suggestions-toggle', {\n\t\t\t\t\t\t\t\t'kol-custom-suggestions-toggle--disabled': isDisabled,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\tonClick={this.toggleListbox.bind(this)}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</div>\n\t\t\t\t\t{\n\t\t\t\t\t\t<CustomSuggestionsOptionsGroupFc\n\t\t\t\t\t\t\tblockSuggestionMouseOver={this.blockSuggestionMouseOver}\n\t\t\t\t\t\t\tonKeyDown={this.handleKeyDownDropdown.bind(this)}\n\t\t\t\t\t\t\tstyle={{ '--visible-options': `${this._rows ?? 5}` }}\n\t\t\t\t\t\t\thidden={!this._isOpen || isDisabled}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{Array.isArray(this._filteredOptions) && this._filteredOptions.length > 0 ? (\n\t\t\t\t\t\t\t\tthis._filteredOptions.map((option, index) => (\n\t\t\t\t\t\t\t\t\t<CustomSuggestionsOptionFc\n\t\t\t\t\t\t\t\t\t\tindex={index}\n\t\t\t\t\t\t\t\t\t\toption={option.label}\n\t\t\t\t\t\t\t\t\t\tsearchTerm={this._inputValue}\n\t\t\t\t\t\t\t\t\t\tref={(el) => {\n\t\t\t\t\t\t\t\t\t\t\tif (el) this.refOptions[index] = el;\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tselected={this._value === (option as Option<string>).value}\n\t\t\t\t\t\t\t\t\t\tdisabled={option.disabled ? true : false}\n\t\t\t\t\t\t\t\t\t\tonClick={(event: Event) => {\n\t\t\t\t\t\t\t\t\t\t\tif (option.disabled) {\n\t\t\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as Option<string>);\n\t\t\t\t\t\t\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox(event);\n\t\t\t\t\t\t\t\t\t\t\tthis._isOpen = false;\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonMouseOver={() => {\n\t\t\t\t\t\t\t\t\t\t\tif (!this.blockSuggestionMouseOver) {\n\t\t\t\t\t\t\t\t\t\t\t\tthis._focusedOptionIndex = index;\n\t\t\t\t\t\t\t\t\t\t\t\tthis.focusOption(index);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonFocus={() => {\n\t\t\t\t\t\t\t\t\t\t\tif (!option.disabled) {\n\t\t\t\t\t\t\t\t\t\t\t\tthis._focusedOptionIndex = index;\n\t\t\t\t\t\t\t\t\t\t\t\tthis.focusOption(index);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonKeyDown={(e) => {\n\t\t\t\t\t\t\t\t\t\t\tif (option.disabled) {\n\t\t\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\tif (e.key === 'Enter' || e.key === 'NumpadEnter') {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as Option<string>);\n\t\t\t\t\t\t\t\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox(e);\n\t\t\t\t\t\t\t\t\t\t\t\te.preventDefault();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t))\n\t\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t\t// role=alert is the only role/state thats read from screenreader\n\t\t\t\t\t\t\t\t<li class=\"kol-single-select__no-results-message\" role=\"alert\">\n\t\t\t\t\t\t\t\t\t{this.translateNoResultsMessage}{' '}\n\t\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t</CustomSuggestionsOptionsGroupFc>\n\t\t\t\t\t}\n\t\t\t\t</KolInputContainerFc>\n\t\t\t</KolFormFieldStateWrapperFc>\n\t\t);\n\t}\n\n\t@Listen('focusout')\n\tpublic handleFocusOut(event: FocusEvent) {\n\t\tsetTimeout(() => {\n\t\t\tif (!this.host?.contains(document.activeElement)) {\n\t\t\t\tthis.onBlur(event);\n\t\t\t}\n\t\t});\n\t}\n\t@Listen('blur')\n\tpublic handleWindowBlur(event: FocusEvent) {\n\t\tthis.onBlur(event);\n\t}\n\n\t@Listen('keydown')\n\tpublic handleKeyDown(event: KeyboardEvent) {\n\t\tconst handleEvent = (isOpen?: boolean, callback?: () => void): void => {\n\t\t\tevent.preventDefault();\n\n\t\t\tif (isOpen !== undefined) {\n\t\t\t\tthis._isOpen = isOpen;\n\t\t\t\tif (!isOpen) {\n\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t}\n\t\t\t}\n\t\t\tcallback?.();\n\t\t};\n\n\t\tswitch (event.key) {\n\t\t\tcase 'Down':\n\t\t\tcase 'ArrowDown': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(true, () => this.moveFocus(1));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Up':\n\t\t\tcase 'ArrowUp': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(true, () => this.moveFocus(-1));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Tab':\n\t\t\t\tif (this._isOpen) {\n\t\t\t\t\tthis._isOpen = !this._isOpen;\n\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase 'Esc':\n\t\t\tcase 'Escape': {\n\t\t\t\tthis._isOpen = false;\n\t\t\t\thandleEvent(false);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase ' ':\n\t\t\tcase 'Enter':\n\t\t\tcase 'NumpadEnter': {\n\t\t\t\tif (this._isOpen) {\n\t\t\t\t\tif (this.selectFocusedOption()) {\n\t\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t\t\thandleEvent(false);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tthis.toggleListbox(event);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Home': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => {\n\t\t\t\t\tif (this._isOpen) {\n\t\t\t\t\t\tthis._focusedOptionIndex = 0;\n\t\t\t\t\t\tthis.focusOption(this._focusedOptionIndex);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'End': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => {\n\t\t\t\t\tif (this._isOpen) {\n\t\t\t\t\t\tthis._focusedOptionIndex = this._filteredOptions ? this._filteredOptions.length - 1 : 0;\n\t\t\t\t\t\tthis.focusOption(this._focusedOptionIndex);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'PageUp': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => this._isOpen && this.moveFocus(-10));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'PageDown': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => this._isOpen && this.moveFocus(10));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate readonly controller: SingleSelectController;\n\t@State()\n\tprivate _isOpen = false;\n\t@State()\n\tprivate _filteredOptions?: OptionsPropType = [];\n\t@State()\n\tprivate _inputValue: string = '';\n\t@State()\n\tprivate blockSuggestionMouseOver: boolean = false;\n\n\t/**\n\t * Defines the key combination that can be used to trigger or focus the component's interactive element.\n\t */\n\t@Prop() public _accessKey?: string;\n\n\t/**\n\t * Defines the placeholder for input field. To be shown when there's no value.\n\t */\n\t@Prop() public _placeholder?: string;\n\n\t/**\n\t * Makes the element not focusable and ignore all events.\n\t */\n\t@Prop() public _disabled?: boolean = false;\n\n\t/**\n\t * Hides the error message but leaves it in the DOM for the input's aria-describedby.\n\t * @TODO: Change type back to `HideMsgPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hideMsg?: boolean = false;\n\n\t/**\n\t * Hides the caption by default and displays the caption text with a tooltip when the\n\t * interactive element is focused or the mouse is over it.\n\t * @TODO: Change type back to `HideLabelPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hideLabel?: boolean = false;\n\n\t/**\n\t * Defines the hint text.\n\t */\n\t@Prop() public _hint?: string = '';\n\n\t/**\n\t * Defines the icon classnames (e.g. `icons=\"fa-solid fa-user\"`).\n\t */\n\t@Prop() public _icons?: IconsHorizontalPropType;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.). Set to `false` to enable the expert slot.\n\t */\n\t@Prop() public _label!: LabelWithExpertSlotPropType;\n\n\t/**\n\t * Defines the properties for a message rendered as Alert component.\n\t */\n\t@Prop() public _msg?: Stringified<MsgPropType>;\n\n\t/**\n\t * Defines the technical name of an input field.\n\t */\n\t@Prop() public _name?: NamePropType;\n\n\t/**\n\t * Gibt die EventCallback-Funktionen für das Input-Event an.\n\t */\n\t@Prop() public _on?: InputTypeOnDefault;\n\n\t/**\n\t * Options the user can choose from.\n\t */\n\t@Prop() public _options!: OptionsPropType;\n\n\t/**\n\t * Makes the input element required.\n\t * @TODO: Change type back to `RequiredPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _required?: boolean = false;\n\n\t/**\n\t * Adds a visual shortcut hint after the label and instructs the screen reader to read the shortcut aloud.\n\t */\n\t@Prop() public _shortKey?: ShortKeyPropType;\n\n\t/**\n\t * Selector for synchronizing the value with another input element.\n\t * @internal\n\t */\n\t@Prop() public _syncValueBySelector?: SyncValueBySelectorPropType;\n\n\t/**\n\t * Defines where to show the Tooltip preferably: top, right, bottom or left.\n\t */\n\t@Prop() public _tooltipAlign?: TooltipAlignPropType = 'top';\n\n\t/**\n\t * Shows if the input was touched by a user.\n\t * @TODO: Change type back to `TouchedPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _touched?: boolean = false;\n\n\t/**\n\t * Defines the value of the element.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _value: StencilUnknown = null;\n\n\t/**\n\t * Shows the clear button if enabled.\n\t */\n\t@Prop() public _hasClearButton?: boolean = true;\n\n\t/**\n\t * Maximum number of visible rows of the element.\n\t */\n\t@Prop() public _rows?: RowsPropType;\n\n\t@State() public state: SingleSelectStates = {\n\t\t_hideMsg: false,\n\t\t_id: `id-${nonce()}`,\n\t\t_label: '', // ⚠ required\n\t\t_options: [],\n\t\t_hasClearButton: true,\n\t};\n\n\t@State() private inputHasFocus = false;\n\n\tpublic constructor() {\n\t\tthis.controller = new SingleSelectController(this, 'single-select', this.host);\n\t}\n\n\tprivate showAsAlert(): boolean {\n\t\treturn Boolean(this.state._touched) && !this.inputHasFocus;\n\t}\n\n\t@Watch('_placeholder')\n\tpublic validatePlaceholder(value?: PlaceholderPropType): void {\n\t\tthis.controller.validatePlaceholder(value);\n\t}\n\n\t@Watch('_accessKey')\n\tpublic validateAccessKey(value?: string): void {\n\t\tthis.controller.validateAccessKey(value);\n\t}\n\n\t@Watch('_disabled')\n\tpublic validateDisabled(value?: DisabledPropType): void {\n\t\tthis.controller.validateDisabled(value);\n\t}\n\n\t@Watch('_hideMsg')\n\tpublic validateHideMsg(value?: HideMsgPropType): void {\n\t\tthis.controller.validateHideMsg(value);\n\t}\n\n\t@Watch('_hideLabel')\n\tpublic validateHideLabel(value?: HideLabelPropType): void {\n\t\tthis.controller.validateHideLabel(value);\n\t}\n\n\t@Watch('_hint')\n\tpublic validateHint(value?: HintPropType): void {\n\t\tthis.controller.validateHint(value);\n\t}\n\n\t@Watch('_icons')\n\tpublic validateIcons(value?: IconsHorizontalPropType): void {\n\t\tthis.controller.validateIcons(value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelWithExpertSlotPropType): void {\n\t\tthis.controller.validateLabel(value);\n\t}\n\n\t@Watch('_msg')\n\tpublic validateMsg(value?: Stringified<MsgPropType>): void {\n\t\tthis.controller.validateMsg(value);\n\t}\n\n\t@Watch('_name')\n\tpublic validateName(value?: string): void {\n\t\tthis.controller.validateName(value);\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: InputTypeOnDefault): void {\n\t\tthis.controller.validateOn(value);\n\t}\n\n\t@Watch('_options')\n\tpublic validateOptions(value?: OptionsPropType): void {\n\t\tthis.controller.validateOptions(value);\n\t\tthis._filteredOptions = value;\n\t\tthis.updateInputValue(this._value);\n\t}\n\n\t@Watch('_required')\n\tpublic validateRequired(value?: RequiredPropType): void {\n\t\tthis.controller.validateRequired(value);\n\t}\n\n\t@Watch('_shortKey')\n\tpublic validateShortKey(value?: ShortKeyPropType): void {\n\t\tthis.controller.validateShortKey(value);\n\t}\n\n\t@Watch('_syncValueBySelector')\n\tpublic validateSyncValueBySelector(value?: SyncValueBySelectorPropType): void {\n\t\tthis.controller.validateSyncValueBySelector(value);\n\t}\n\n\t@Watch('_touched')\n\tpublic validateTouched(value?: boolean): void {\n\t\tthis.controller.validateTouched(value);\n\t}\n\n\t@Watch('_value')\n\tpublic validateValue(value: StencilUnknown): void {\n\t\tthis.controller.validateValue(value);\n\t\tthis.oldValue = value;\n\t\tthis.updateInputValue(value);\n\t}\n\n\t@Watch('_hasClearButton')\n\tpublic validateHasClearButton(value?: boolean): void {\n\t\tthis.controller.validateHasClearButton(value);\n\t}\n\n\t@Watch('_rows')\n\tpublic validateRows(value?: number): void {\n\t\tthis.controller.validateRows(value);\n\t}\n\n\t@Listen('mousemove')\n\tpublic handleMouseEvent() {\n\t\tthis.blockSuggestionMouseOver = false;\n\t}\n\n\tprivate updateInputValue(value?: StencilUnknown) {\n\t\tif (Array.isArray(this._options)) {\n\t\t\tconst matchedOption = this._options.find((option) => option.value === value);\n\t\t\tthis._inputValue = matchedOption ? String(matchedOption.label) : '';\n\t\t}\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.refOptions = [];\n\t\tthis._touched = this._touched === true;\n\t\tthis.controller.componentWillLoad();\n\t\tthis.oldValue = this._value;\n\t\tthis._filteredOptions = this.state._options;\n\t\tthis.updateInputValue(this._value);\n\t}\n\n\tprivate onChange(event: Event): void {\n\t\tif (this.oldValue !== this.refInput?.value) {\n\t\t\tthis.oldValue = this.refInput?.value;\n\t\t}\n\n\t\tif (!this._isOpen) {\n\t\t\tthis.controller.onFacade.onChange(event, this._value);\n\t\t}\n\t}\n\n\tprivate onClick(event: MouseEvent): void {\n\t\tthis.toggleListbox(event);\n\t\tthis.refInput?.focus();\n\t\tthis.controller.onFacade.onClick(event);\n\t}\n}\n"],"version":3}
1
+ {"file":"kol-single-select.js","mappings":"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","names":["KolSingleSelect","__stencil_proxyCustomElement","KolFormFieldStateWrapperFc","KolInputContainerFc","KolInputStateWrapperFc"],"sources":["src/components/single-select/controller.ts","src/components/single-select/style.scss?tag=kol-single-select&mode=default&encapsulation=shadow","src/components/single-select/shadow.tsx"],"sourcesContent":["import type {\n\tOption,\n\tOptionsPropType,\n\tPlaceholderPropType,\n\tRequiredPropType,\n\tSelectOption,\n\tSingleSelectProps,\n\tSingleSelectWatches,\n\tStencilUnknown,\n\tW3CInputValue,\n} from '../../schema';\nimport { validateOptions, validatePlaceholder, validateRequired, watchBoolean, watchNumber, watchValidator } from '../../schema';\n\nimport { InputIconController } from '../@deprecated/input/controller-icon';\nimport { fillKeyOptionMap } from '../input-radio/controller';\n\nimport type { Generic } from 'adopted-style-sheets';\n\nexport class SingleSelectController extends InputIconController implements SingleSelectWatches {\n\tprotected readonly component: Generic.Element.Component & SingleSelectProps;\n\tprivate readonly keyOptionMap = new Map<string, Option<string>>();\n\n\tpublic constructor(component: Generic.Element.Component & SingleSelectProps, name: string, host?: HTMLElement) {\n\t\tsuper(component, name, host);\n\t\tthis.component = component;\n\t}\n\n\tprotected readonly afterPatchOptions = (value: unknown, _state: Record<string, unknown>, _component: Generic.Element.Component, key: string): void => {\n\t\tif (key === '_value') {\n\t\t\tthis.setFormAssociatedValue(value as string);\n\t\t}\n\t};\n\n\tprotected readonly beforePatchOptions = (_value: unknown, nextState: Map<string, unknown>): void => {\n\t\tconst options = nextState.has('_options') ? nextState.get('_options') : this.component.state._options;\n\t\tif (Array.isArray(options) && options.length > 0) {\n\t\t\tthis.keyOptionMap.clear();\n\t\t\tfillKeyOptionMap(this.keyOptionMap, options as SelectOption<W3CInputValue>[]);\n\t\t}\n\t};\n\n\tpublic validateOptions(value?: OptionsPropType): void {\n\t\tvalidateOptions(this.component, value, {\n\t\t\thooks: {\n\t\t\t\tafterPatch: this.afterPatchOptions,\n\t\t\t\tbeforePatch: this.beforePatchOptions,\n\t\t\t},\n\t\t});\n\t}\n\n\tpublic validateRequired(value?: RequiredPropType): void {\n\t\tvalidateRequired(this.component, value);\n\t}\n\n\tpublic validateValue(value: StencilUnknown): void {\n\t\twatchValidator(this.component, '_value', (v) => v !== undefined, new Set([`StencilUnknown`]), value);\n\t}\n\n\tpublic validatePlaceholder(value?: PlaceholderPropType): void {\n\t\tvalidatePlaceholder(this.component, value);\n\t}\n\n\tpublic validateHasClearButton(value?: boolean): void {\n\t\twatchBoolean(this.component, '_hasClearButton', value);\n\t}\n\n\tpublic validateRows(value?: number): void {\n\t\twatchNumber(this.component, '_rows', value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tsuper.componentWillLoad();\n\t\tthis.validateOptions(this.component._options);\n\t\tthis.validateRequired(this.component._required);\n\t\tthis.validateValue(this.component._value);\n\t\tthis.validatePlaceholder(this.component._placeholder);\n\t\tthis.validateHasClearButton(this.component._hasClearButton);\n\t\tthis.validateRows(this.component._rows);\n\t}\n}\n","@use '../@shared/global' as *;\n@use '../@shared/alert.mixin' as *;\n@use '../@shared/custom-suggestions-option' as *;\n@use '../@shared/custom-suggestions-options-group' as *;\n@use '../@shared/custom-suggestions-toggle' as *;\n@use '../@shared/form-field.mixin' as *;\n@use '../@shared/input-container.mixin' as *;\n@use '../@shared/input.mixin' as *;\n@use '../@shared/mixins' as *;\n@use '../@shared/button.mixin' as *;\n@use '../@shared/icon.mixin' as *;\n\n@layer kol-component {\n\t@include kol-alert;\n\t@include kol-custom-suggestions-option;\n\t@include kol-custom-suggestions-options-group;\n\t@include kol-custom-suggestions-toggle;\n\t@include kol-form-field;\n\t@include kol-input-container;\n\t@include kol-input;\n\t@include kol-icon-styles();\n\n\t$option-height: to-rem(40);\n\t$visible-options: var(--visible-options, 5);\n\n\t.kol-single-select {\n\t\t&__delete {\n\t\t\t@include kol-button-styles('kol-button');\n\t\t\t.kol-button {\n\t\t\t\tmargin-top: -2px;\n\t\t\t\tmargin-bottom: -2px;\n\t\t\t}\n\t\t}\n\n\t\t&__no-results-message {\n\t\t\tdisplay: flex;\n\t\t\tmin-height: to-rem(50);\n\t\t\talign-items: center;\n\t\t\tjustify-content: center;\n\t\t\tcursor: default;\n\t\t}\n\n\t\t.kol-custom-suggestions-options-group {\n\t\t\tmax-height: calc($option-height * $visible-options + to-rem(2)) !important;\n\t\t}\n\t}\n\n\t.kol-custom-suggestions-toggle {\n\t\t&:not(&--disabled) {\n\t\t\tcursor: pointer;\n\t\t}\n\n\t\t&--disabled {\n\t\t\topacity: 0.5;\n\t\t}\n\t}\n}\n","import type { JSX } from '@stencil/core';\nimport { Component, Element, h, Listen, Method, Prop, State, Watch } from '@stencil/core';\nimport type {\n\tDisabledPropType,\n\tHideLabelPropType,\n\tHideMsgPropType,\n\tHintPropType,\n\tIconsHorizontalPropType,\n\tInputTypeOnDefault,\n\tLabelWithExpertSlotPropType,\n\tMsgPropType,\n\tNamePropType,\n\tOption,\n\tOptionsPropType,\n\tPlaceholderPropType,\n\tRequiredPropType,\n\tRowsPropType,\n\tShortKeyPropType,\n\tSingleSelectAPI,\n\tSingleSelectStates,\n\tStencilUnknown,\n\tStringified,\n\tSyncValueBySelectorPropType,\n\tTooltipAlignPropType,\n} from '../../schema';\n\nimport { KolButtonWcTag } from '../../core/component-names';\nimport { getRenderStates } from '../../functional-component-wrappers/_helpers/getRenderStates';\nimport KolFormFieldStateWrapperFc, { type FormFieldStateWrapperProps } from '../../functional-component-wrappers/FormFieldStateWrapper/FormFieldStateWrapper';\nimport KolInputContainerFc from '../../functional-component-wrappers/InputContainerStateWrapper/InputContainerStateWrapper';\nimport type { InputStateWrapperProps } from '../../functional-component-wrappers/InputStateWrapper/InputStateWrapper';\nimport KolInputStateWrapperFc from '../../functional-component-wrappers/InputStateWrapper/InputStateWrapper';\nimport CustomSuggestionsOptionFc from '../../functional-components/CustomSuggestionsOption/CustomSuggestionsOption';\nimport CustomSuggestionsOptionsGroupFc from '../../functional-components/CustomSuggestionsOptionsGroup';\nimport { translate } from '../../i18n';\nimport { IconFC } from '../../internal/functional-components/icon/component';\nimport type { EventDetail } from '../../schema/interfaces/EventDetail';\nimport clsx from '../../utils/clsx';\nimport { nonce } from '../../utils/dev.utils';\nimport { SingleSelectController } from './controller';\n\n/**\n * The **SingleSelect** component creates a dropdown list from which exactly one predefined option can be selected.\n *\n * @slot - The label of the input field.\n */\n@Component({\n\ttag: 'kol-single-select',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolSingleSelect implements SingleSelectAPI {\n\t@Element() private readonly host?: HTMLElement;\n\tprivate refInput?: HTMLInputElement;\n\tprivate refOptions: HTMLLIElement[] = [];\n\tprivate readonly translateDeleteSelection = translate('kol-delete-selection');\n\tprivate readonly translateNoResultsMessage = translate('kol-no-results-message');\n\tprivate oldValue?: StencilUnknown;\n\t// so onBlur doesn't close the panel if clear button is pressed\n\tprivate isClearing = false;\n\n\t/**\n\t * Returns the current value.\n\t */\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tpublic async getValue(): Promise<StencilUnknown> {\n\t\treturn this._value;\n\t}\n\n\t/**\n\t * Sets focus on the internal element.\n\t */\n\t@Method()\n\tpublic async focus() {\n\t\treturn new Promise<void>((resolve) => {\n\t\t\trequestAnimationFrame(() => {\n\t\t\t\tthis.refInput?.focus();\n\t\t\t\tresolve();\n\t\t\t});\n\t\t});\n\t}\n\n\tprivate readonly catchRef = (ref?: HTMLInputElement) => {\n\t\tthis.refInput = ref;\n\t};\n\n\tprivate toggleListbox = (event: Event) => {\n\t\tevent?.preventDefault();\n\t\tconst isDisabled = this.state._disabled === true;\n\t\tif (isDisabled) {\n\t\t\treturn;\n\t\t} else {\n\t\t\tthis.refInput?.focus();\n\t\t\tif (this._isOpen) {\n\t\t\t\t// Liste schließen\n\t\t\t\tthis._isOpen = false;\n\t\t\t} else {\n\t\t\t\t// Liste öffnen\n\t\t\t\tthis._isOpen = true;\n\t\t\t\tconst selectedIndex = Array.isArray(this._filteredOptions) ? this._filteredOptions.findIndex((option) => option.label === this._inputValue) : -1;\n\t\t\t\tthis._focusedOptionIndex = selectedIndex >= 0 ? selectedIndex : -1;\n\t\t\t\tthis.focusOption(this._focusedOptionIndex);\n\t\t\t}\n\t\t}\n\t};\n\n\tprivate onBlur(event: FocusEvent) {\n\t\tconst matchingOption = this.state._options?.find((option) => (option.label as string)?.toLowerCase() === this._inputValue?.toLowerCase());\n\t\tif (matchingOption) {\n\t\t\tthis.selectOption(matchingOption as Option<string>);\n\t\t} else if (!this._isOpen && this._value) {\n\t\t\tthis._inputValue = this.state._options?.find((option) => (option as Option<string>).value === this._value)?.label as string;\n\t\t\tthis._filteredOptions = [...this.state._options];\n\t\t}\n\t\tif (event instanceof FocusEvent && event.view === window && !this.isClearing) {\n\t\t\tthis._isOpen = false;\n\t\t}\n\t}\n\n\tprivate createEventWithTarget(type: string, detail: EventDetail): CustomEvent<EventDetail> {\n\t\tconst event = new CustomEvent<EventDetail>(type, {\n\t\t\tbubbles: true,\n\t\t\tdetail,\n\t\t});\n\n\t\tif (this.refInput) {\n\t\t\tObject.defineProperty(event, 'target', {\n\t\t\t\tvalue: this.refInput,\n\t\t\t});\n\n\t\t\tObject.defineProperty(event, 'currentTarget', {\n\t\t\t\tvalue: this.refInput,\n\t\t\t});\n\t\t}\n\t\treturn event;\n\t}\n\n\tprivate clearSelection() {\n\t\tthis.isClearing = true;\n\n\t\tif (this.state._disabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst emptyValue = null;\n\t\tthis._focusedOptionIndex = -1;\n\t\tthis._value = emptyValue;\n\t\tthis._inputValue = '';\n\t\tthis._filteredOptions = [...this.state._options];\n\n\t\tconst inputEvent = this.createEventWithTarget('input', {\n\t\t\tname: this.state._name as string,\n\t\t\tvalue: emptyValue,\n\t\t});\n\t\tconst changeEvent = this.createEventWithTarget('change', {\n\t\t\tname: this.state._name as string,\n\t\t\tvalue: emptyValue,\n\t\t});\n\n\t\tthis.controller.onFacade.onInput(inputEvent, true, { value: emptyValue });\n\t\tthis.controller.onFacade.onChange(changeEvent, { value: emptyValue });\n\n\t\tthis.isClearing = false;\n\t}\n\n\tprivate selectOption(option: Option<string>) {\n\t\tif (option.value === this._value) {\n\t\t\tthis._inputValue = option.label as string;\n\t\t\tthis._filteredOptions = [...this.state._options];\n\t\t\treturn;\n\t\t}\n\n\t\tthis._value = option.value;\n\t\tthis._inputValue = option.label as string;\n\n\t\tconst inputEvent = this.createEventWithTarget('input', {\n\t\t\tname: this.state._name ?? '',\n\t\t\tvalue: option.value,\n\t\t});\n\t\tconst changeEvent = this.createEventWithTarget('change', {\n\t\t\tname: this.state._name ?? '',\n\t\t\tvalue: option.value,\n\t\t});\n\n\t\tthis.controller.onFacade.onInput(inputEvent, false, option.value);\n\t\tthis.controller.onFacade.onChange(changeEvent, option.value);\n\n\t\tthis._filteredOptions = [...this.state._options];\n\n\t\tthis.controller.setFormAssociatedValue(this._value);\n\t}\n\n\tprivate onInput(event: Event) {\n\t\tconst target = event.target as HTMLInputElement;\n\t\tthis._inputValue = target.value;\n\t\tthis._isOpen = true;\n\t\tthis.setFilteredOptionsByQuery(target.value);\n\t\tthis._focusedOptionIndex = -1;\n\t}\n\n\tprivate handleKeyDownDropdown(event: KeyboardEvent) {\n\t\tif (event.key.length === 1 && /[a-z0-9]/i.test(event.key)) {\n\t\t\tevent.preventDefault();\n\t\t\tthis._isOpen = true;\n\t\t\tthis.focusSuggestionStartingWith(event.key);\n\t\t}\n\t}\n\n\tprivate setFilteredOptionsByQuery(query: string) {\n\t\tif (query?.trim() === '') {\n\t\t\tthis._filteredOptions = [...this.state._options];\n\t\t} else if (Array.isArray(this.state._options) && this.state._options.length > 0 && query.length > 0) {\n\t\t\tthis._filteredOptions = this.state._options.filter((option) => {\n\t\t\t\treturn (option.label as string)?.toLowerCase()?.includes(query?.toLowerCase());\n\t\t\t});\n\t\t}\n\t}\n\n\tprivate _focusedOptionIndex: number = -1;\n\n\tprivate moveFocus(delta: number) {\n\t\tif (!this._filteredOptions) {\n\t\t\treturn;\n\t\t}\n\t\tlet newIndex = this._focusedOptionIndex + delta;\n\n\t\tlet iterations = 0;\n\t\tlet foundEnabledOption = false;\n\n\t\tconst maxIterations = this._filteredOptions.length;\n\n\t\twhile (iterations < maxIterations) {\n\t\t\tif (newIndex >= this._filteredOptions.length) {\n\t\t\t\tnewIndex = 0;\n\t\t\t}\n\t\t\tif (newIndex < 0) {\n\t\t\t\tnewIndex = this._filteredOptions.length - 1;\n\t\t\t}\n\n\t\t\tconst option = this._filteredOptions[newIndex] as Option<StencilUnknown>;\n\t\t\tif (!option.disabled) {\n\t\t\t\tfoundEnabledOption = true;\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tnewIndex += delta;\n\t\t\titerations++;\n\t\t}\n\n\t\tif (foundEnabledOption) {\n\t\t\tthis._focusedOptionIndex = newIndex;\n\t\t\tthis.focusOption(this._focusedOptionIndex);\n\t\t}\n\t}\n\n\tprivate focusOption(index: number) {\n\t\tif (this.refOptions) {\n\t\t\tconst optionElement = this.refOptions[index];\n\t\t\toptionElement?.focus();\n\t\t}\n\t}\n\n\tprivate selectFocusedOption(): boolean {\n\t\tif (Array.isArray(this._filteredOptions) && this._filteredOptions.length > 0 && this._focusedOptionIndex >= 0) {\n\t\t\tthis.selectOption(this._filteredOptions[this._focusedOptionIndex] as Option<string>);\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tprivate focusSuggestionStartingWith(char: string) {\n\t\tconst charLowerCase = char.toLowerCase();\n\n\t\tconst index =\n\t\t\tArray.isArray(this._filteredOptions) &&\n\t\t\tthis._filteredOptions.findIndex((option) => (option.label as string).toLowerCase().startsWith(charLowerCase) && !option.disabled);\n\n\t\tif (typeof index === 'number' && index >= 0) {\n\t\t\tthis._focusedOptionIndex = index;\n\t\t\tthis.focusOption(index);\n\t\t}\n\t}\n\n\tprivate getFormFieldProps(): FormFieldStateWrapperProps {\n\t\treturn {\n\t\t\tstate: this.state,\n\t\t\tclass: 'kol-single-select',\n\t\t\ttooltipAlign: this._tooltipAlign,\n\t\t\talert: this.showAsAlert(),\n\t\t};\n\t}\n\n\tprivate getInputProps(): InputStateWrapperProps {\n\t\tconst { ariaDescribedBy } = getRenderStates(this.state);\n\t\tconst isDisabled = this.state._disabled === true;\n\n\t\treturn {\n\t\t\t'aria-activedescendant': this._isOpen && this._focusedOptionIndex >= 0 ? `option-${this._focusedOptionIndex}` : undefined,\n\t\t\t'aria-autocomplete': 'both',\n\t\t\t'aria-controls': 'listbox',\n\t\t\t'aria-describedby': ariaDescribedBy.length > 0 ? ariaDescribedBy.join(' ') : undefined,\n\t\t\t'aria-label': this.state._hideLabel && typeof this.state._label === 'string' ? this.state._label : undefined,\n\t\t\t'aria-keyshortcuts': this.state._shortKey,\n\t\t\taccessKey: this.state._accessKey,\n\t\t\tautocapitalize: 'off',\n\t\t\tautocorrect: 'off',\n\t\t\tclass: 'kol-single-select__input',\n\t\t\tdisabled: isDisabled,\n\t\t\tname: this.state._name,\n\t\t\tplaceholder: this.state._placeholder,\n\t\t\tref: this.catchRef,\n\t\t\trequired: this.state._required,\n\t\t\trole: 'combobox',\n\t\t\tstate: this.state,\n\t\t\ttype: 'text',\n\t\t\tvalue: this._inputValue,\n\t\t\t...this.controller.onFacade,\n\t\t\tonChange: this.onChange.bind(this),\n\t\t\tonClick: this.onClick.bind(this),\n\t\t\tonInput: this.onInput.bind(this),\n\t\t\tonFocus: (event) => {\n\t\t\t\tthis.controller.onFacade.onFocus(event);\n\t\t\t\tthis.inputHasFocus = true;\n\t\t\t},\n\t\t\tonBlur: (event) => {\n\t\t\t\tthis.controller.onFacade.onBlur(event);\n\t\t\t\tthis.inputHasFocus = false;\n\t\t\t},\n\t\t};\n\t}\n\n\tpublic render(): JSX.Element {\n\t\tconst isDisabled = this.state._disabled === true;\n\t\treturn (\n\t\t\t<KolFormFieldStateWrapperFc {...this.getFormFieldProps()}>\n\t\t\t\t<KolInputContainerFc state={this.state}>\n\t\t\t\t\t<div class=\"kol-single-select__group\">\n\t\t\t\t\t\t<KolInputStateWrapperFc {...this.getInputProps()} />\n\n\t\t\t\t\t\t{this._inputValue && this.state._hasClearButton && (\n\t\t\t\t\t\t\t<KolButtonWcTag\n\t\t\t\t\t\t\t\t_icons=\"kolicon-cross\"\n\t\t\t\t\t\t\t\t_label={this.translateDeleteSelection}\n\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t_variant=\"ghost\"\n\t\t\t\t\t\t\t\t_disabled={isDisabled}\n\t\t\t\t\t\t\t\tdata-testid=\"single-select-delete\"\n\t\t\t\t\t\t\t\tclass=\"kol-single-select__delete\"\n\t\t\t\t\t\t\t\thidden={isDisabled}\n\t\t\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\t\t\tonClick: () => {\n\t\t\t\t\t\t\t\t\t\tthis.clearSelection();\n\t\t\t\t\t\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t)}\n\n\t\t\t\t\t\t<IconFC\n\t\t\t\t\t\t\ticons=\"kolicon-chevron-down\"\n\t\t\t\t\t\t\tlabel=\"\"\n\t\t\t\t\t\t\tclass={clsx('kol-custom-suggestions-toggle', {\n\t\t\t\t\t\t\t\t'kol-custom-suggestions-toggle--disabled': isDisabled,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\tonClick={this.toggleListbox.bind(this)}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</div>\n\t\t\t\t\t{\n\t\t\t\t\t\t<CustomSuggestionsOptionsGroupFc\n\t\t\t\t\t\t\tblockSuggestionMouseOver={this.blockSuggestionMouseOver}\n\t\t\t\t\t\t\tonKeyDown={this.handleKeyDownDropdown.bind(this)}\n\t\t\t\t\t\t\tstyle={{ '--visible-options': `${this._rows ?? 5}` }}\n\t\t\t\t\t\t\thidden={!this._isOpen || isDisabled}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{Array.isArray(this._filteredOptions) && this._filteredOptions.length > 0 ? (\n\t\t\t\t\t\t\t\tthis._filteredOptions.map((option, index) => (\n\t\t\t\t\t\t\t\t\t<CustomSuggestionsOptionFc\n\t\t\t\t\t\t\t\t\t\tindex={index}\n\t\t\t\t\t\t\t\t\t\toption={option.label}\n\t\t\t\t\t\t\t\t\t\tsearchTerm={this._inputValue}\n\t\t\t\t\t\t\t\t\t\tref={(el) => {\n\t\t\t\t\t\t\t\t\t\t\tif (el) this.refOptions[index] = el;\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tselected={this._value === (option as Option<string>).value}\n\t\t\t\t\t\t\t\t\t\tdisabled={option.disabled ? true : false}\n\t\t\t\t\t\t\t\t\t\tonClick={(event: Event) => {\n\t\t\t\t\t\t\t\t\t\t\tif (option.disabled) {\n\t\t\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as Option<string>);\n\t\t\t\t\t\t\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox(event);\n\t\t\t\t\t\t\t\t\t\t\tthis._isOpen = false;\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonMouseOver={() => {\n\t\t\t\t\t\t\t\t\t\t\tif (!this.blockSuggestionMouseOver) {\n\t\t\t\t\t\t\t\t\t\t\t\tthis._focusedOptionIndex = index;\n\t\t\t\t\t\t\t\t\t\t\t\tthis.focusOption(index);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonFocus={() => {\n\t\t\t\t\t\t\t\t\t\t\tif (!option.disabled) {\n\t\t\t\t\t\t\t\t\t\t\t\tthis._focusedOptionIndex = index;\n\t\t\t\t\t\t\t\t\t\t\t\tthis.focusOption(index);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonKeyDown={(e) => {\n\t\t\t\t\t\t\t\t\t\t\tif (option.disabled) {\n\t\t\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\tif (e.key === 'Enter' || e.key === 'NumpadEnter') {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as Option<string>);\n\t\t\t\t\t\t\t\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox(e);\n\t\t\t\t\t\t\t\t\t\t\t\te.preventDefault();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t))\n\t\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t\t// role=alert is the only role/state thats read from screenreader\n\t\t\t\t\t\t\t\t<li class=\"kol-single-select__no-results-message\" role=\"alert\">\n\t\t\t\t\t\t\t\t\t{this.translateNoResultsMessage}{' '}\n\t\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t</CustomSuggestionsOptionsGroupFc>\n\t\t\t\t\t}\n\t\t\t\t</KolInputContainerFc>\n\t\t\t</KolFormFieldStateWrapperFc>\n\t\t);\n\t}\n\n\t@Listen('focusout')\n\tpublic handleFocusOut(event: FocusEvent) {\n\t\tsetTimeout(() => {\n\t\t\tif (!this.host?.contains(document.activeElement)) {\n\t\t\t\tthis.onBlur(event);\n\t\t\t}\n\t\t});\n\t}\n\t@Listen('blur')\n\tpublic handleWindowBlur(event: FocusEvent) {\n\t\tthis.onBlur(event);\n\t}\n\n\t@Listen('keydown')\n\tpublic handleKeyDown(event: KeyboardEvent) {\n\t\tconst handleEvent = (isOpen?: boolean, callback?: () => void): void => {\n\t\t\tevent.preventDefault();\n\n\t\t\tif (isOpen !== undefined) {\n\t\t\t\tthis._isOpen = isOpen;\n\t\t\t\tif (!isOpen) {\n\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t}\n\t\t\t}\n\t\t\tcallback?.();\n\t\t};\n\n\t\tswitch (event.key) {\n\t\t\tcase 'Down':\n\t\t\tcase 'ArrowDown': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(true, () => this.moveFocus(1));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Up':\n\t\t\tcase 'ArrowUp': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(true, () => this.moveFocus(-1));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Tab':\n\t\t\t\tif (this._isOpen) {\n\t\t\t\t\tthis._isOpen = !this._isOpen;\n\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase 'Esc':\n\t\t\tcase 'Escape': {\n\t\t\t\tthis._isOpen = false;\n\t\t\t\thandleEvent(false);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase ' ':\n\t\t\tcase 'Enter':\n\t\t\tcase 'NumpadEnter': {\n\t\t\t\tif (this._isOpen) {\n\t\t\t\t\tif (this.selectFocusedOption()) {\n\t\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t\t\thandleEvent(false);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tthis.toggleListbox(event);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Home': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => {\n\t\t\t\t\tif (this._isOpen) {\n\t\t\t\t\t\tthis._focusedOptionIndex = 0;\n\t\t\t\t\t\tthis.focusOption(this._focusedOptionIndex);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'End': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => {\n\t\t\t\t\tif (this._isOpen) {\n\t\t\t\t\t\tthis._focusedOptionIndex = this._filteredOptions ? this._filteredOptions.length - 1 : 0;\n\t\t\t\t\t\tthis.focusOption(this._focusedOptionIndex);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'PageUp': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => this._isOpen && this.moveFocus(-10));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'PageDown': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => this._isOpen && this.moveFocus(10));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate readonly controller: SingleSelectController;\n\t@State()\n\tprivate _isOpen = false;\n\t@State()\n\tprivate _filteredOptions?: OptionsPropType = [];\n\t@State()\n\tprivate _inputValue: string = '';\n\t@State()\n\tprivate blockSuggestionMouseOver: boolean = false;\n\n\t/**\n\t * Defines the key combination that can be used to trigger or focus the component's interactive element.\n\t */\n\t@Prop() public _accessKey?: string;\n\n\t/**\n\t * Defines the placeholder for input field. To be shown when there's no value.\n\t */\n\t@Prop() public _placeholder?: string;\n\n\t/**\n\t * Makes the element not focusable and ignore all events.\n\t */\n\t@Prop() public _disabled?: boolean = false;\n\n\t/**\n\t * Hides the error message but leaves it in the DOM for the input's aria-describedby.\n\t * @TODO: Change type back to `HideMsgPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hideMsg?: boolean = false;\n\n\t/**\n\t * Hides the caption by default and displays the caption text with a tooltip when the\n\t * interactive element is focused or the mouse is over it.\n\t * @TODO: Change type back to `HideLabelPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hideLabel?: boolean = false;\n\n\t/**\n\t * Defines the hint text.\n\t */\n\t@Prop() public _hint?: string = '';\n\n\t/**\n\t * Defines the icon classnames (e.g. `icons=\"fa-solid fa-user\"`).\n\t */\n\t@Prop() public _icons?: IconsHorizontalPropType;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.). Set to `false` to enable the expert slot.\n\t */\n\t@Prop() public _label!: LabelWithExpertSlotPropType;\n\n\t/**\n\t * Defines the properties for a message rendered as Alert component.\n\t */\n\t@Prop() public _msg?: Stringified<MsgPropType>;\n\n\t/**\n\t * Defines the technical name of an input field.\n\t */\n\t@Prop() public _name?: NamePropType;\n\n\t/**\n\t * Gibt die EventCallback-Funktionen für das Input-Event an.\n\t */\n\t@Prop() public _on?: InputTypeOnDefault;\n\n\t/**\n\t * Options the user can choose from.\n\t */\n\t@Prop() public _options!: OptionsPropType;\n\n\t/**\n\t * Makes the input element required.\n\t * @TODO: Change type back to `RequiredPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _required?: boolean = false;\n\n\t/**\n\t * Adds a visual shortcut hint after the label and instructs the screen reader to read the shortcut aloud.\n\t */\n\t@Prop() public _shortKey?: ShortKeyPropType;\n\n\t/**\n\t * Selector for synchronizing the value with another input element.\n\t * @internal\n\t */\n\t@Prop() public _syncValueBySelector?: SyncValueBySelectorPropType;\n\n\t/**\n\t * Defines where to show the Tooltip preferably: top, right, bottom or left.\n\t */\n\t@Prop() public _tooltipAlign?: TooltipAlignPropType = 'top';\n\n\t/**\n\t * Shows if the input was touched by a user.\n\t * @TODO: Change type back to `TouchedPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _touched?: boolean = false;\n\n\t/**\n\t * Defines the value of the element.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _value: StencilUnknown = null;\n\n\t/**\n\t * Shows the clear button if enabled.\n\t */\n\t@Prop() public _hasClearButton?: boolean = true;\n\n\t/**\n\t * Maximum number of visible rows of the element.\n\t */\n\t@Prop() public _rows?: RowsPropType;\n\n\t@State() public state: SingleSelectStates = {\n\t\t_hideMsg: false,\n\t\t_id: `id-${nonce()}`,\n\t\t_label: '', // ⚠ required\n\t\t_options: [],\n\t\t_hasClearButton: true,\n\t};\n\n\t@State() private inputHasFocus = false;\n\n\tpublic constructor() {\n\t\tthis.controller = new SingleSelectController(this, 'single-select', this.host);\n\t}\n\n\tprivate showAsAlert(): boolean {\n\t\treturn Boolean(this.state._touched) && !this.inputHasFocus;\n\t}\n\n\t@Watch('_placeholder')\n\tpublic validatePlaceholder(value?: PlaceholderPropType): void {\n\t\tthis.controller.validatePlaceholder(value);\n\t}\n\n\t@Watch('_accessKey')\n\tpublic validateAccessKey(value?: string): void {\n\t\tthis.controller.validateAccessKey(value);\n\t}\n\n\t@Watch('_disabled')\n\tpublic validateDisabled(value?: DisabledPropType): void {\n\t\tthis.controller.validateDisabled(value);\n\t}\n\n\t@Watch('_hideMsg')\n\tpublic validateHideMsg(value?: HideMsgPropType): void {\n\t\tthis.controller.validateHideMsg(value);\n\t}\n\n\t@Watch('_hideLabel')\n\tpublic validateHideLabel(value?: HideLabelPropType): void {\n\t\tthis.controller.validateHideLabel(value);\n\t}\n\n\t@Watch('_hint')\n\tpublic validateHint(value?: HintPropType): void {\n\t\tthis.controller.validateHint(value);\n\t}\n\n\t@Watch('_icons')\n\tpublic validateIcons(value?: IconsHorizontalPropType): void {\n\t\tthis.controller.validateIcons(value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelWithExpertSlotPropType): void {\n\t\tthis.controller.validateLabel(value);\n\t}\n\n\t@Watch('_msg')\n\tpublic validateMsg(value?: Stringified<MsgPropType>): void {\n\t\tthis.controller.validateMsg(value);\n\t}\n\n\t@Watch('_name')\n\tpublic validateName(value?: string): void {\n\t\tthis.controller.validateName(value);\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: InputTypeOnDefault): void {\n\t\tthis.controller.validateOn(value);\n\t}\n\n\t@Watch('_options')\n\tpublic validateOptions(value?: OptionsPropType): void {\n\t\tthis.controller.validateOptions(value);\n\t\tthis._filteredOptions = value;\n\t\tthis.updateInputValue(this._value);\n\t}\n\n\t@Watch('_required')\n\tpublic validateRequired(value?: RequiredPropType): void {\n\t\tthis.controller.validateRequired(value);\n\t}\n\n\t@Watch('_shortKey')\n\tpublic validateShortKey(value?: ShortKeyPropType): void {\n\t\tthis.controller.validateShortKey(value);\n\t}\n\n\t@Watch('_syncValueBySelector')\n\tpublic validateSyncValueBySelector(value?: SyncValueBySelectorPropType): void {\n\t\tthis.controller.validateSyncValueBySelector(value);\n\t}\n\n\t@Watch('_touched')\n\tpublic validateTouched(value?: boolean): void {\n\t\tthis.controller.validateTouched(value);\n\t}\n\n\t@Watch('_value')\n\tpublic validateValue(value: StencilUnknown): void {\n\t\tthis.controller.validateValue(value);\n\t\tthis.oldValue = value;\n\t\tthis.updateInputValue(value);\n\t}\n\n\t@Watch('_hasClearButton')\n\tpublic validateHasClearButton(value?: boolean): void {\n\t\tthis.controller.validateHasClearButton(value);\n\t}\n\n\t@Watch('_rows')\n\tpublic validateRows(value?: number): void {\n\t\tthis.controller.validateRows(value);\n\t}\n\n\t@Listen('mousemove')\n\tpublic handleMouseEvent() {\n\t\tthis.blockSuggestionMouseOver = false;\n\t}\n\n\tprivate updateInputValue(value?: StencilUnknown) {\n\t\tif (Array.isArray(this._options)) {\n\t\t\tconst matchedOption = this._options.find((option) => option.value === value);\n\t\t\tthis._inputValue = matchedOption ? String(matchedOption.label) : '';\n\t\t}\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.refOptions = [];\n\t\tthis._touched = this._touched === true;\n\t\tthis.controller.componentWillLoad();\n\t\tthis.oldValue = this._value;\n\t\tthis._filteredOptions = this.state._options;\n\t\tthis.updateInputValue(this._value);\n\t}\n\n\tprivate onChange(event: Event): void {\n\t\tif (this.oldValue !== this.refInput?.value) {\n\t\t\tthis.oldValue = this.refInput?.value;\n\t\t}\n\n\t\tif (!this._isOpen) {\n\t\t\tthis.controller.onFacade.onChange(event, this._value);\n\t\t}\n\t}\n\n\tprivate onClick(event: MouseEvent): void {\n\t\tthis.toggleListbox(event);\n\t\tthis.refInput?.focus();\n\t\tthis.controller.onFacade.onClick(event);\n\t}\n}\n"],"version":3}
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{h,proxyCustomElement,createEvent,Host}from"@stencil/core/internal/client";import{c as createPropDefinition,n as normalizeString,B as BaseController,a as BaseWebComponent}from"./base-web-component.js";import{b as bem}from"./bem-registry.js";import{a as ClickButtonFC,C as ClickButtonController}from"./controller2.js";import{L as Log}from"./common.js";const nameProp=createPropDefinition("name","",normalizeString),skeletonBem=bem.forBlock("kol-skeleton"),BEM_CLASS_SKELETON__ACTIONS=skeletonBem("actions"),BEM_CLASS_SKELETON__CONTAINER=skeletonBem("container"),BEM_CLASS_SKELETON__COUNTER=skeletonBem("counter"),BEM_CLASS_SKELETON__NAME=skeletonBem("name"),SkeletonFC=e=>{const{count:t,label:o,name:n,show:l,handleClick:s,refButton:a}=e,i=!(!l||!(null==n?void 0:n.trim())),r=skeletonBem({"has-name":i,"is-hidden":!l});return h("div",{class:r},h("div",{class:BEM_CLASS_SKELETON__CONTAINER},i&&h("span",{class:BEM_CLASS_SKELETON__NAME},n),h("div",{class:BEM_CLASS_SKELETON__COUNTER},"Count: ",t)),h("div",{class:BEM_CLASS_SKELETON__ACTIONS},h(ClickButtonFC,{label:o,handleClick:s,refButton:a})))},skeletonPropsConfig={required:[nameProp]};class SkeletonController extends BaseController{constructor(e,t){super(skeletonPropsConfig,e,t),this.onKeydown=e=>{"Escape"===e.key&&(console.log("Show should be toggled"),this.toggle())},this.handleClick=()=>{var e,t;Log.debug("Button clicked, count should be increased"),this.setState("count",(null!==(t=null===(e=this.getState)||void 0===e?void 0:e.call(this,"count"))&&void 0!==t?t:0)+1)},this.setButtonRef=e=>{this.clickButtonCtrl.setButtonRef(e)},this.clickButtonCtrl=new ClickButtonController(e,t),this.startLoadedEventInterval()}componentWillLoad(e){const{name:t}=e;this.watchName(t),this.clickButtonCtrl.componentWillLoad({label:"Click me"})}watchName(e){nameProp.apply(e,e=>{this.setRenderProp("name",e)})}toggle(){var e,t;this.setState("show",!(null!==(t=null===(e=this.getState)||void 0===e?void 0:e.call(this,"show"))&&void 0!==t&&t))}focus(){return this.clickButtonCtrl.focus()}startLoadedEventInterval(){this.intervalId=setInterval(()=>{var e,t;this.emitLoaded(null!==(t=null===(e=this.getState)||void 0===e?void 0:e.call(this,"count"))&&void 0!==t?t:0)},2e3)}emitLoaded(e){this.onLoadedCallback&&this.onLoadedCallback(e)}setOnLoadedCallback(e){this.onLoadedCallback=e}destroy(){this.intervalId&&(clearInterval(this.intervalId),this.intervalId=void 0)}}const KolSkeleton$1=proxyCustomElement(class extends BaseWebComponent{constructor(e){super(!1),!1!==e&&this.__registerHost(),this.__attachShadow(),this.loaded=createEvent(this,"loaded",7),this.rendered=createEvent(this,"rendered",7),this.ctrl=new SkeletonController(this.setState,this.getState),this.count=0,this.label="Label",this.show=!0}async focus(){return Promise.resolve(this.ctrl.focus())}async toggle(){return Promise.resolve(this.ctrl.toggle())}watchName(e){this.ctrl.watchName(e)}handleKeyDown(e){"Enter"!==e.key&&" "!==e.key||(Log.debug("button pressed"),this.ctrl.handleClick())}onKeydown(e){this.ctrl.onKeydown(e)}componentWillLoad(){this.ctrl.componentWillLoad({name:this._name}),this.ctrl.setOnLoadedCallback(e=>{this.loaded.emit(e)})}componentDidLoad(){requestAnimationFrame(()=>{this.rendered.emit()})}disconnectedCallback(){this.ctrl.destroy()}render(){return h(Host,{key:"1d40f06baad4cb4052965dffe6b7de2cdcd9c29d"},h(SkeletonFC,{key:"d0f9cb22e085c3b90b88cfdaef92af67e9ca0add",count:this.count,label:this.label,name:this.ctrl.getRenderProp("name"),handleClick:()=>this.ctrl.handleClick(),onLoaded:this.loaded,onRendered:this.rendered,show:this.show,refButton:e=>this.ctrl.setButtonRef(e)}))}static get watchers(){return{_name:["watchName"]}}},[769,"kol-skeleton",{_name:[1],count:[32],label:[32],show:[32],focus:[64],toggle:[64]},[[0,"keydown","handleKeyDown"],[8,"keydown","onKeydown"]],{_name:["watchName"]}]);function defineCustomElement$1(){if("undefined"==typeof customElements)return;["kol-skeleton"].forEach(e=>{if("kol-skeleton"===e)customElements.get(e)||customElements.define(e,KolSkeleton$1)})}const KolSkeleton=KolSkeleton$1,defineCustomElement=defineCustomElement$1;export{KolSkeleton,defineCustomElement};
4
+ import{h,proxyCustomElement,createEvent,Host}from"@stencil/core/internal/client";import{c as createPropDefinition,n as normalizeString,B as BaseController,a as BaseWebComponent}from"./base-web-component.js";import{b as bem}from"./bem-registry.js";import{a as ClickButtonFC,C as ClickButtonController}from"./controller2.js";import{L as Log}from"./common.js";const nameProp=createPropDefinition("name","",normalizeString),skeletonBem=bem.forBlock("kol-skeleton"),BEM_CLASS_SKELETON__ACTIONS=skeletonBem("actions"),BEM_CLASS_SKELETON__CONTAINER=skeletonBem("container"),BEM_CLASS_SKELETON__COUNTER=skeletonBem("counter"),BEM_CLASS_SKELETON__NAME=skeletonBem("name"),SkeletonFC=e=>{const{count:t,label:o,name:n,show:l,handleClick:s,refButton:a}=e,i=!(!l||!(null==n?void 0:n.trim())),r=skeletonBem({"has-name":i,"is-hidden":!l});return h("div",{class:r},h("div",{class:BEM_CLASS_SKELETON__CONTAINER},i&&h("span",{class:BEM_CLASS_SKELETON__NAME},n),h("div",{class:BEM_CLASS_SKELETON__COUNTER},"Count: ",t)),h("div",{class:BEM_CLASS_SKELETON__ACTIONS},h(ClickButtonFC,{label:o,handleClick:s,refButton:a})))},skeletonPropsConfig={required:[nameProp]};class SkeletonController extends BaseController{constructor(e,t){super(skeletonPropsConfig,e,t),this.onKeydown=e=>{"Escape"===e.key&&(console.log("Show should be toggled"),this.toggle())},this.handleClick=()=>{var e,t;Log.debug("Button clicked, count should be increased"),this.setState("count",(null!==(t=null===(e=this.getState)||void 0===e?void 0:e.call(this,"count"))&&void 0!==t?t:0)+1)},this.setButtonRef=e=>{this.clickButtonCtrl.setButtonRef(e)},this.clickButtonCtrl=new ClickButtonController(e,t),this.startLoadedEventInterval()}componentWillLoad(e){const{name:t}=e;this.watchName(t),this.clickButtonCtrl.componentWillLoad({label:"Click me"})}watchName(e){nameProp.apply(e,e=>{this.setRenderProp("name",e)})}toggle(){var e,t;this.setState("show",!(null!==(t=null===(e=this.getState)||void 0===e?void 0:e.call(this,"show"))&&void 0!==t&&t))}focus(){return this.clickButtonCtrl.focus()}startLoadedEventInterval(){this.intervalId=setInterval(()=>{var e,t;this.emitLoaded(null!==(t=null===(e=this.getState)||void 0===e?void 0:e.call(this,"count"))&&void 0!==t?t:0)},2e3)}emitLoaded(e){this.onLoadedCallback&&this.onLoadedCallback(e)}setOnLoadedCallback(e){this.onLoadedCallback=e}destroy(){this.intervalId&&(clearInterval(this.intervalId),this.intervalId=void 0)}}const KolSkeleton$1=proxyCustomElement(class extends BaseWebComponent{constructor(e){super(!1),!1!==e&&this.__registerHost(),this.__attachShadow(),this.loaded=createEvent(this,"loaded",7),this.rendered=createEvent(this,"rendered",7),this.ctrl=new SkeletonController(this.setState,this.getState),this.count=0,this.label="Label",this.show=!0}async focus(){return Promise.resolve(this.ctrl.focus())}async toggle(){return Promise.resolve(this.ctrl.toggle())}watchName(e){this.ctrl.watchName(e)}handleKeyDown(e){"Enter"!==e.key&&" "!==e.key||(Log.debug("button pressed"),this.ctrl.handleClick())}onKeydown(e){this.ctrl.onKeydown(e)}componentWillLoad(){this.ctrl.componentWillLoad({name:this._name}),this.ctrl.setOnLoadedCallback(e=>{this.loaded.emit(e)})}componentDidLoad(){requestAnimationFrame(()=>{this.rendered.emit()})}disconnectedCallback(){this.ctrl.destroy()}render(){return h(Host,{key:"8b04c40db5658a744af6aaff13262f5d1e08af3e"},h(SkeletonFC,{key:"a7ba98cc2620d5aa4d6fb28fc02df5b18a0aa273",count:this.count,label:this.label,name:this.ctrl.getRenderProp("name"),handleClick:()=>this.ctrl.handleClick(),onLoaded:this.loaded,onRendered:this.rendered,show:this.show,refButton:e=>this.ctrl.setButtonRef(e)}))}static get watchers(){return{_name:["watchName"]}}},[769,"kol-skeleton",{_name:[1],count:[32],label:[32],show:[32],focus:[64],toggle:[64]},[[0,"keydown","handleKeyDown"],[8,"keydown","onKeydown"]],{_name:["watchName"]}]);function defineCustomElement$1(){if("undefined"==typeof customElements)return;["kol-skeleton"].forEach(e=>{if("kol-skeleton"===e)customElements.get(e)||customElements.define(e,KolSkeleton$1)})}const KolSkeleton=KolSkeleton$1,defineCustomElement=defineCustomElement$1;export{KolSkeleton,defineCustomElement};
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{proxyCustomElement,HTMLElement,h}from"@stencil/core/internal/client";import"./common.js";import{v as validateLabel}from"./label.js";import{r as removeNavLabel,a as addNavLabel}from"./unique-nav-labels.js";import{w as watchNavLinks}from"./validation2.js";import{d as KolLinkWcTag}from"./component-names.js";const defaultStyleCss='/* forward the rem function */\n/*\n* This file defines the layer order for all CSS layers used in KoliBri.\n* The order is important as it determines the cascade priority.\n*\n* Layer order (lowest to highest priority):\n* 1. kol-a11y - Accessibility defaults and requirements\n* 2. kol-global - Global component styles and resets\n* 3. kol-component - Component-specific styles\n* 4. kol-theme-global - Theme-specific global styles\n* 5. kol-theme-component - Theme-specific component styles\n*/\n@layer kol-a11y, kol-global, kol-component, kol-theme-global, kol-theme-component;\n/*\n * This file contains all rules for accessibility.\n */\n@layer kol-a11y {\n :host {\n /*\n * Minimum size of interactive elements.\n */\n --a11y-min-size: calc(44 * 1rem / var(--kolibri-root-font-size, 16));\n /*\n * No element should be used without verifying the contrast ratio of its background and font colors.\n * By initially setting the background color to white and the font color to black,\n * the contrast ratio is ensured and explicit adjustment is forced.\n */\n color: black;\n background-color: white;\n /*\n * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n /*\n * Text should be aligned left by default to provide a predictable starting point.\n */\n text-align: left;\n }\n * {\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n hyphens: auto;\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n word-break: break-word;\n }\n /*\n * All interactive elements should have a minimum size of to-rem(44).\n */\n /* input:not([type=\'checkbox\'], [type=\'radio\'], [type=\'range\']), */\n /* option, */\n /* select, */\n /* textarea, */\n button,\n .kol-input .input {\n min-width: var(--a11y-min-size);\n min-height: var(--a11y-min-size);\n }\n /*\n * Some interactive elements should not inherit the font-family and font-size.\n */\n a,\n button,\n h1,\n h2,\n h3,\n h4,\n h5,\n h6,\n input,\n option,\n select,\n textarea {\n /*\n * All elements should inherit the text color from his parent element.\n */\n color: inherit;\n /*\n * All elements should inherit the font family from his parent element.\n */\n font-family: inherit;\n /*\n * All elements should inherit the font size from his parent element.\n */\n font-size: inherit;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n }\n /**\n * Sometimes we need the semantic element for accessibility reasons,\n * but we don\'t want to show it.\n *\n * - https://www.a11yproject.com/posts/how-to-hide-content/\n */\n .visually-hidden {\n position: fixed;\n top: 0;\n left: 0;\n width: 1px;\n height: 1px;\n overflow: hidden;\n white-space: nowrap;\n clip-path: inset(50%);\n }\n}\n@layer kol-global {\n /*\n * Dieses CSS stellt sicher, dass der Standard-Style\n * von A und Button resettet werden.\n */\n :is(a, button) {\n background-color: transparent;\n width: 100%;\n margin: 0;\n padding: 0;\n border: none;\n /* 100% needed for custom width from outside */\n }\n /*\n * Ensure elements with hidden attribute to be actually not visible\n * @see https://meowni.ca/hidden.is.a.lie.html\n */\n [hidden] {\n display: none !important;\n }\n .badge-text-hint {\n color: black;\n background-color: lightgray;\n }\n}\n@layer kol-global {\n :host {\n /*\n * The max-width is needed to prevent the table from overflowing the\n * parent node, if the table is wider than the parent node.\n */\n max-width: 100%;\n font-size: calc(16 * 1rem / var(--kolibri-root-font-size, 16));\n }\n * {\n /*\n * We prefer to box-sizing: border-box for all elements.\n */\n box-sizing: border-box;\n }\n .kol-span {\n /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n display: flex;\n flex-flow: column;\n align-items: center;\n justify-content: center;\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n }\n .kol-span__container {\n display: flex;\n align-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .kol-span .kol-span__label--hide-label .kol-span__label {\n display: none;\n }\n /* Reset browser agent style. */\n button:disabled {\n color: unset;\n }\n .disabled label,\n .disabled:focus-within label,\n [aria-disabled=true],\n [aria-disabled=true]:focus,\n [disabled],\n [disabled]:focus {\n opacity: 0.5;\n outline: none;\n cursor: not-allowed;\n }\n [aria-disabled=true]:focus .kol-span,\n [disabled]:focus .kol-span {\n outline: none !important;\n }\n .hastooltip {\n z-index: 900 !important;\n }\n}\n@font-face {\n font-family: "kolicons";\n src: url("kolicons.eot?t=1773232431126"); /* IE9*/\n src: url("kolicons.eot?t=1773232431126#iefix") format("embedded-opentype"), url("kolicons.woff2?t=1773232431126") format("woff2"), url("kolicons.woff?t=1773232431126") format("woff"), url("kolicons.ttf?t=1773232431126") format("truetype"), url("kolicons.svg?t=1773232431126#kolicons") format("svg"); /* iOS 4.1- */\n}\n[class^=kolicon-], [class*=" kolicon-"] {\n font-family: "kolicons";\n font-style: normal;\n font-weight: 400;\n line-height: 1em;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\n.kolicon-alert-error::before {\n content: "\\ea01";\n}\n\n.kolicon-alert-info::before {\n content: "\\ea02";\n}\n\n.kolicon-alert-success::before {\n content: "\\ea03";\n}\n\n.kolicon-alert-warning::before {\n content: "\\ea04";\n}\n\n.kolicon-check::before {\n content: "\\ea05";\n}\n\n.kolicon-chevron-double-left::before {\n content: "\\ea06";\n}\n\n.kolicon-chevron-double-right::before {\n content: "\\ea07";\n}\n\n.kolicon-chevron-down::before {\n content: "\\ea08";\n}\n\n.kolicon-chevron-left::before {\n content: "\\ea09";\n}\n\n.kolicon-chevron-right::before {\n content: "\\ea0a";\n}\n\n.kolicon-chevron-up::before {\n content: "\\ea0b";\n}\n\n.kolicon-cogwheel::before {\n content: "\\ea0c";\n}\n\n.kolicon-cross::before {\n content: "\\ea0d";\n}\n\n.kolicon-eye-closed::before {\n content: "\\ea0e";\n}\n\n.kolicon-eye::before {\n content: "\\ea0f";\n}\n\n.kolicon-house::before {\n content: "\\ea10";\n}\n\n.kolicon-kolibri::before {\n content: "\\ea11";\n}\n\n.kolicon-link-external::before {\n content: "\\ea12";\n}\n\n.kolicon-link::before {\n content: "\\ea13";\n}\n\n.kolicon-minus::before {\n content: "\\ea14";\n}\n\n.kolicon-plus::before {\n content: "\\ea15";\n}\n\n.kolicon-settings::before {\n content: "\\ea16";\n}\n\n.kolicon-sort-asc::before {\n content: "\\ea17";\n}\n\n.kolicon-sort-desc::before {\n content: "\\ea18";\n}\n\n.kolicon-sort-neutral::before {\n content: "\\ea19";\n}\n\n.kolicon-up::before {\n content: "\\ea1a";\n}\n\n.kolicon-version::before {\n content: "\\ea1b";\n}\n\n@layer kol-component {\n .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n .kol-tooltip {\n display: contents;\n }\n .kol-tooltip__floating {\n opacity: 0;\n display: none;\n position: fixed;\n /* Avoid layout interference - see https://floating-ui.com/docs/computePosition */\n top: 0;\n left: 0;\n /* Can be used to specify the tooltip-width from the outside. Unset by default. */\n width: var(--kol-tooltip-width, max-content);\n min-width: calc(8 * 1rem / var(--kolibri-root-font-size, 16));\n max-width: 90vw;\n max-height: 90vh;\n animation-direction: normal;\n /* Can be used to specify the animation duration from the outside. 250ms by default. */\n animation-duration: var(--kolibri-tooltip-animation-duration, 250ms);\n animation-fill-mode: forwards;\n animation-iteration-count: 1;\n animation-timing-function: ease-in;\n }\n .kol-tooltip__floating.hide {\n animation-name: hideTooltip;\n }\n .kol-tooltip__floating.show {\n animation-name: showTooltip;\n }\n .kol-tooltip__arrow {\n transform: rotate(45deg);\n color: #000;\n background-color: #fff;\n position: absolute;\n z-index: 999;\n width: calc(10 * 1rem / var(--kolibri-root-font-size, 16));\n height: calc(10 * 1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-tooltip__content {\n color: #000;\n background-color: #fff;\n position: relative;\n z-index: 1000;\n }\n @keyframes hideTooltip {\n 0% {\n opacity: 1;\n }\n 100% {\n opacity: 0;\n display: none;\n }\n }\n @keyframes showTooltip {\n 0% {\n opacity: 0;\n }\n 100% {\n opacity: 1;\n }\n }\n}\n@layer kol-component {\n .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n :host {\n display: inline-block;\n }\n .kol-link {\n display: inline-flex;\n max-width: fit-content;\n align-items: baseline;\n place-items: center;\n text-align: left;\n text-decoration-line: none;\n }\n .kol-link--standalone {\n min-width: var(--a11y-min-size);\n min-height: var(--a11y-min-size);\n align-items: stretch;\n }\n .kol-link--standalone .kol-link__text {\n display: inline-flex;\n flex: 1 1 100%;\n place-items: center;\n }\n .kol-link .kol-span__label {\n text-decoration-line: underline;\n }\n .kol-link:focus:not([aria-disabled], [disabled]) .kol-span__label, .kol-link:hover:not([aria-disabled], [disabled]) .kol-span__label {\n text-decoration-thickness: 0.2em;\n }\n .kol-link__icon {\n display: inline-flex;\n margin-left: calc(8 * 1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-skip-nav__list {\n display: grid;\n place-items: center;\n list-style: none;\n }\n .kol-skip-nav__list-item {\n height: 0;\n }\n .kol-skip-nav .kol-link {\n position: absolute;\n left: calc(-99999 * 1rem / var(--kolibri-root-font-size, 16));\n z-index: 9999999;\n line-height: 1;\n }\n .kol-skip-nav .kol-link:focus {\n background-color: #fff;\n position: unset;\n left: unset;\n }\n}',KolSkipNav$1=proxyCustomElement(class extends HTMLElement{constructor(n){super(),!1!==n&&this.__registerHost(),this.__attachShadow(),this.state={_label:"",_links:[]}}render(){return h("nav",{key:"a6ded7b2bae70f051fc586555aef04f635ded319",class:"kol-skip-nav","aria-label":this.state._label},h("ul",{key:"f56a7c1fc39183f822a1bf782829b01b4252b44d",class:"kol-skip-nav__list"},this.state._links.map((n,e)=>h("li",{class:"kol-skip-nav__list-item",key:e},h(KolLinkWcTag,Object.assign({},n,{ref:0===e?n=>this.firstLinkRef=n:void 0}))))))}async focus(){var n;return Promise.resolve(null===(n=this.firstLinkRef)||void 0===n?void 0:n.focus())}validateLabel(n,e,o=!1){o||removeNavLabel(this.state._label),validateLabel(this,n,{required:!0}),addNavLabel(this.state._label)}validateLinks(n){watchNavLinks("KolSkipNav",this,n)}componentWillLoad(){this.validateLabel(this._label,void 0,!0),this.validateLinks(this._links)}disconnectedCallback(){removeNavLabel(this.state._label)}static get watchers(){return{_label:["validateLabel"],_links:["validateLinks"]}}static get style(){return{default:defaultStyleCss}}},[289,"kol-skip-nav",{_label:[1],_links:[1],state:[32],focus:[64]},void 0,{_label:["validateLabel"],_links:["validateLinks"]}]);function defineCustomElement$1(){if("undefined"==typeof customElements)return;["kol-skip-nav"].forEach(n=>{if("kol-skip-nav"===n)customElements.get(n)||customElements.define(n,KolSkipNav$1)})}const KolSkipNav=KolSkipNav$1,defineCustomElement=defineCustomElement$1;export{KolSkipNav,defineCustomElement};
4
+ import{proxyCustomElement,HTMLElement,h}from"@stencil/core/internal/client";import"./common.js";import{v as validateLabel}from"./label.js";import{r as removeNavLabel,a as addNavLabel}from"./unique-nav-labels.js";import{w as watchNavLinks}from"./validation2.js";import{d as KolLinkWcTag}from"./component-names.js";const defaultStyleCss='/* forward the rem function */\n/*\n* This file defines the layer order for all CSS layers used in KoliBri.\n* The order is important as it determines the cascade priority.\n*\n* Layer order (lowest to highest priority):\n* 1. kol-a11y - Accessibility defaults and requirements\n* 2. kol-global - Global component styles and resets\n* 3. kol-component - Component-specific styles\n* 4. kol-theme-global - Theme-specific global styles\n* 5. kol-theme-component - Theme-specific component styles\n*/\n@layer kol-a11y, kol-global, kol-component, kol-theme-global, kol-theme-component;\n/*\n * This file contains all rules for accessibility.\n */\n@layer kol-a11y {\n :host {\n /*\n * Minimum size of interactive elements.\n */\n --a11y-min-size: calc(44 * 1rem / var(--kolibri-root-font-size, 16));\n /*\n * No element should be used without verifying the contrast ratio of its background and font colors.\n * By initially setting the background color to white and the font color to black,\n * the contrast ratio is ensured and explicit adjustment is forced.\n */\n color: black;\n background-color: white;\n /*\n * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n /*\n * Text should be aligned left by default to provide a predictable starting point.\n */\n text-align: left;\n }\n * {\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n hyphens: auto;\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n word-break: break-word;\n }\n /*\n * All interactive elements should have a minimum size of to-rem(44).\n */\n /* input:not([type=\'checkbox\'], [type=\'radio\'], [type=\'range\']), */\n /* option, */\n /* select, */\n /* textarea, */\n button,\n .kol-input .input {\n min-width: var(--a11y-min-size);\n min-height: var(--a11y-min-size);\n }\n /*\n * Some interactive elements should not inherit the font-family and font-size.\n */\n a,\n button,\n h1,\n h2,\n h3,\n h4,\n h5,\n h6,\n input,\n option,\n select,\n textarea {\n /*\n * All elements should inherit the text color from his parent element.\n */\n color: inherit;\n /*\n * All elements should inherit the font family from his parent element.\n */\n font-family: inherit;\n /*\n * All elements should inherit the font size from his parent element.\n */\n font-size: inherit;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n }\n /**\n * Sometimes we need the semantic element for accessibility reasons,\n * but we don\'t want to show it.\n *\n * - https://www.a11yproject.com/posts/how-to-hide-content/\n */\n .visually-hidden {\n position: fixed;\n top: 0;\n left: 0;\n width: 1px;\n height: 1px;\n overflow: hidden;\n white-space: nowrap;\n clip-path: inset(50%);\n }\n}\n@layer kol-global {\n /*\n * Dieses CSS stellt sicher, dass der Standard-Style\n * von A und Button resettet werden.\n */\n :is(a, button) {\n background-color: transparent;\n width: 100%;\n margin: 0;\n padding: 0;\n border: none;\n /* 100% needed for custom width from outside */\n }\n /*\n * Ensure elements with hidden attribute to be actually not visible\n * @see https://meowni.ca/hidden.is.a.lie.html\n */\n [hidden] {\n display: none !important;\n }\n .badge-text-hint {\n color: black;\n background-color: lightgray;\n }\n}\n@layer kol-global {\n :host {\n /*\n * The max-width is needed to prevent the table from overflowing the\n * parent node, if the table is wider than the parent node.\n */\n max-width: 100%;\n font-size: calc(16 * 1rem / var(--kolibri-root-font-size, 16));\n }\n * {\n /*\n * We prefer to box-sizing: border-box for all elements.\n */\n box-sizing: border-box;\n }\n .kol-span {\n /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n display: flex;\n flex-flow: column;\n align-items: center;\n justify-content: center;\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n }\n .kol-span__container {\n display: flex;\n align-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .kol-span .kol-span__label--hide-label .kol-span__label {\n display: none;\n }\n /* Reset browser agent style. */\n button:disabled {\n color: unset;\n }\n .disabled label,\n .disabled:focus-within label,\n [aria-disabled=true],\n [aria-disabled=true]:focus,\n [disabled],\n [disabled]:focus {\n opacity: 0.5;\n outline: none;\n cursor: not-allowed;\n }\n [aria-disabled=true]:focus .kol-span,\n [disabled]:focus .kol-span {\n outline: none !important;\n }\n .hastooltip {\n z-index: 900 !important;\n }\n}\n@font-face {\n font-family: "kolicons";\n src: url("kolicons.eot?t=1774433546045"); /* IE9*/\n src: url("kolicons.eot?t=1774433546045#iefix") format("embedded-opentype"), url("kolicons.woff2?t=1774433546045") format("woff2"), url("kolicons.woff?t=1774433546045") format("woff"), url("kolicons.ttf?t=1774433546045") format("truetype"), url("kolicons.svg?t=1774433546045#kolicons") format("svg"); /* iOS 4.1- */\n}\n[class^=kolicon-], [class*=" kolicon-"] {\n font-family: "kolicons";\n font-style: normal;\n font-weight: 400;\n line-height: 1em;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\n.kolicon-alert-error::before {\n content: "\\ea01";\n}\n\n.kolicon-alert-info::before {\n content: "\\ea02";\n}\n\n.kolicon-alert-success::before {\n content: "\\ea03";\n}\n\n.kolicon-alert-warning::before {\n content: "\\ea04";\n}\n\n.kolicon-check::before {\n content: "\\ea05";\n}\n\n.kolicon-chevron-double-left::before {\n content: "\\ea06";\n}\n\n.kolicon-chevron-double-right::before {\n content: "\\ea07";\n}\n\n.kolicon-chevron-down::before {\n content: "\\ea08";\n}\n\n.kolicon-chevron-left::before {\n content: "\\ea09";\n}\n\n.kolicon-chevron-right::before {\n content: "\\ea0a";\n}\n\n.kolicon-chevron-up::before {\n content: "\\ea0b";\n}\n\n.kolicon-cogwheel::before {\n content: "\\ea0c";\n}\n\n.kolicon-cross::before {\n content: "\\ea0d";\n}\n\n.kolicon-eye-closed::before {\n content: "\\ea0e";\n}\n\n.kolicon-eye::before {\n content: "\\ea0f";\n}\n\n.kolicon-house::before {\n content: "\\ea10";\n}\n\n.kolicon-kolibri::before {\n content: "\\ea11";\n}\n\n.kolicon-link-external::before {\n content: "\\ea12";\n}\n\n.kolicon-link::before {\n content: "\\ea13";\n}\n\n.kolicon-minus::before {\n content: "\\ea14";\n}\n\n.kolicon-plus::before {\n content: "\\ea15";\n}\n\n.kolicon-settings::before {\n content: "\\ea16";\n}\n\n.kolicon-sort-asc::before {\n content: "\\ea17";\n}\n\n.kolicon-sort-desc::before {\n content: "\\ea18";\n}\n\n.kolicon-sort-neutral::before {\n content: "\\ea19";\n}\n\n.kolicon-up::before {\n content: "\\ea1a";\n}\n\n.kolicon-version::before {\n content: "\\ea1b";\n}\n\n@layer kol-component {\n .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n .kol-tooltip {\n display: contents;\n }\n .kol-tooltip__floating {\n opacity: 0;\n display: none;\n position: fixed;\n /* Avoid layout interference - see https://floating-ui.com/docs/computePosition */\n top: 0;\n left: 0;\n /* Can be used to specify the tooltip-width from the outside. Unset by default. */\n width: var(--kol-tooltip-width, max-content);\n min-width: calc(8 * 1rem / var(--kolibri-root-font-size, 16));\n max-width: 90vw;\n max-height: 90vh;\n animation-direction: normal;\n /* Can be used to specify the animation duration from the outside. 250ms by default. */\n animation-duration: var(--kolibri-tooltip-animation-duration, 250ms);\n animation-fill-mode: forwards;\n animation-iteration-count: 1;\n animation-timing-function: ease-in;\n }\n .kol-tooltip__floating.hide {\n animation-name: hideTooltip;\n }\n .kol-tooltip__floating.show {\n animation-name: showTooltip;\n }\n .kol-tooltip__arrow {\n transform: rotate(45deg);\n color: #000;\n background-color: #fff;\n position: absolute;\n z-index: 999;\n width: calc(10 * 1rem / var(--kolibri-root-font-size, 16));\n height: calc(10 * 1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-tooltip__content {\n color: #000;\n background-color: #fff;\n position: relative;\n z-index: 1000;\n }\n @keyframes hideTooltip {\n 0% {\n opacity: 1;\n }\n 100% {\n opacity: 0;\n display: none;\n }\n }\n @keyframes showTooltip {\n 0% {\n opacity: 0;\n }\n 100% {\n opacity: 1;\n }\n }\n}\n@layer kol-component {\n .kol-icon {\n color: inherit;\n display: inline-block;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n }\n :host {\n display: inline-block;\n }\n .kol-link {\n display: inline-flex;\n max-width: fit-content;\n align-items: baseline;\n place-items: center;\n text-align: left;\n text-decoration-line: none;\n }\n .kol-link--standalone {\n min-width: var(--a11y-min-size);\n min-height: var(--a11y-min-size);\n align-items: stretch;\n }\n .kol-link--standalone .kol-link__text {\n display: inline-flex;\n flex: 1 1 100%;\n place-items: center;\n }\n .kol-link .kol-span__label {\n text-decoration-line: underline;\n }\n .kol-link:focus:not([aria-disabled], [disabled]) .kol-span__label, .kol-link:hover:not([aria-disabled], [disabled]) .kol-span__label {\n text-decoration-thickness: 0.2em;\n }\n .kol-link__icon {\n display: inline-flex;\n margin-left: calc(8 * 1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-skip-nav__list {\n display: grid;\n place-items: center;\n list-style: none;\n }\n .kol-skip-nav__list-item {\n height: 0;\n }\n .kol-skip-nav .kol-link {\n position: absolute;\n left: calc(-99999 * 1rem / var(--kolibri-root-font-size, 16));\n z-index: 9999999;\n line-height: 1;\n }\n .kol-skip-nav .kol-link:focus {\n background-color: #fff;\n position: unset;\n left: unset;\n }\n}',KolSkipNav$1=proxyCustomElement(class extends HTMLElement{constructor(n){super(),!1!==n&&this.__registerHost(),this.__attachShadow(),this.state={_label:"",_links:[]}}render(){return h("nav",{key:"fe57cc1ba10ecafa0c82c8796ae3cd0d540b8491",class:"kol-skip-nav","aria-label":this.state._label},h("ul",{key:"f236d8b1c3e486d8199b12134484411f16554971",class:"kol-skip-nav__list"},this.state._links.map((n,e)=>h("li",{class:"kol-skip-nav__list-item",key:e},h(KolLinkWcTag,Object.assign({},n,{ref:0===e?n=>this.firstLinkRef=n:void 0}))))))}async focus(){var n;return Promise.resolve(null===(n=this.firstLinkRef)||void 0===n?void 0:n.focus())}validateLabel(n,e,o=!1){o||removeNavLabel(this.state._label),validateLabel(this,n,{required:!0}),addNavLabel(this.state._label)}validateLinks(n){watchNavLinks("KolSkipNav",this,n)}componentWillLoad(){this.validateLabel(this._label,void 0,!0),this.validateLinks(this._links)}disconnectedCallback(){removeNavLabel(this.state._label)}static get watchers(){return{_label:["validateLabel"],_links:["validateLinks"]}}static get style(){return{default:defaultStyleCss}}},[289,"kol-skip-nav",{_label:[1],_links:[1],state:[32],focus:[64]},void 0,{_label:["validateLabel"],_links:["validateLinks"]}]);function defineCustomElement$1(){if("undefined"==typeof customElements)return;["kol-skip-nav"].forEach(n=>{if("kol-skip-nav"===n)customElements.get(n)||customElements.define(n,KolSkipNav$1)})}const KolSkipNav=KolSkipNav$1,defineCustomElement=defineCustomElement$1;export{KolSkipNav,defineCustomElement};
@@ -1 +1 @@
1
- {"file":"kol-skip-nav.js","mappings":";;;;;;;;;;AAAA,MAAM,eAAe,GAAG,6oVAA6oV;;MCgBxpVA,YAAU,GAAAC,kBAAA,CAAA,MAAA,UAAA,SAAA,WAAA,CAAA;AAPvB,IAAA,WAAA,CAAA,YAAA,EAAA;;;;;;QA4CiB,IAAA,CAAA,KAAK,GAAkB;AACtC,YAAA,MAAM,EAAE,EAAE;AACV,YAAA,MAAM,EAAE,EAAE;SACV;AA0BD;IA/DO,MAAM,GAAA;QACZ,QACC,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,cAAc,gBAAa,IAAI,CAAC,KAAK,CAAC,MAAM,EAAA,EACtD,CAAA,CAAA,IAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAI,KAAK,EAAC,oBAAoB,EAC5B,EAAA,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAe,EAAE,KAAa,KAAI;YACzD,QACC,UAAI,KAAK,EAAC,yBAAyB,EAAC,GAAG,EAAE,KAAK,EAAA,EAC7C,CAAA,CAAC,YAAY,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAK,IAAI,EAAA,EAAE,GAAG,EAAE,KAAK,KAAK,CAAC,GAAG,CAAC,EAAE,MAAM,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC,GAAG,SAAS,EAAiB,CAAA,CAAA,CACpG;AAEP,SAAC,CAAC,CACE,CACA;;AAQD,IAAA,MAAM,KAAK,GAAA;;AACjB,QAAA,OAAO,OAAO,CAAC,OAAO,CAAC,CAAA,EAAA,GAAA,IAAI,CAAC,YAAY,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,EAAE,CAAC;;AAmB5C,IAAA,aAAa,CAAC,KAAqB,EAAE,SAAyB,EAAE,OAAO,GAAG,KAAK,EAAA;QACrF,IAAI,CAAC,OAAO,EAAE;AACb,YAAA,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;;AAElC,QAAA,aAAa,CAAC,IAAI,EAAE,KAAK,EAAE;AAC1B,YAAA,QAAQ,EAAE,IAAI;AACd,SAAA,CAAC;AACF,QAAA,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;;AAIxB,IAAA,aAAa,CAAC,KAAgC,EAAA;AACpD,QAAA,aAAa,CAAC,YAAY,EAAE,IAAI,EAAE,KAAK,CAAC;;IAGlC,iBAAiB,GAAA;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,IAAI,CAAC;AAChD,QAAA,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC;;IAGzB,oBAAoB,GAAA;AAC1B,QAAA,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["KolSkipNav","__stencil_proxyCustomElement"],"sources":["src/components/skip-nav/style.scss?tag=kol-skip-nav&mode=default&encapsulation=shadow","src/components/skip-nav/shadow.tsx"],"sourcesContent":["@use '../@shared/mixins' as *;\n@use '../../styles/global' as *;\n@use '../@shared/kol-link-mixin' as *;\n\n@layer kol-component {\n\t@include kol-link-styles('kol-link');\n\t.kol-skip-nav {\n\t\t&__list {\n\t\t\tdisplay: grid;\n\t\t\tplace-items: center;\n\t\t\tlist-style: none;\n\t\t}\n\n\t\t&__list-item {\n\t\t\theight: 0;\n\t\t}\n\n\t\t.kol-link {\n\t\t\tposition: absolute;\n\t\t\tleft: to-rem(-99999);\n\t\t\tz-index: 9999999;\n\n\t\t\tline-height: 1;\n\n\t\t\t&:focus {\n\t\t\t\tbackground-color: #fff;\n\t\t\t\tposition: unset;\n\t\t\t\tleft: unset;\n\t\t\t}\n\t\t}\n\t}\n}\n","import { Component, h, Method, Prop, State, Watch } from '@stencil/core';\nimport type { LabelPropType, LinkProps, SkipNavAPI, SkipNavStates, Stringified } from '../../schema';\nimport { validateLabel } from '../../schema';\n\nimport { addNavLabel, removeNavLabel } from '../../utils/unique-nav-labels';\nimport { watchNavLinks } from '../nav/validation';\n\nimport type { JSX } from '@stencil/core';\nimport { KolLinkWcTag } from '../../core/component-names';\n@Component({\n\ttag: 'kol-skip-nav',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolSkipNav implements SkipNavAPI {\n\tprivate firstLinkRef?: HTMLKolLinkWcElement;\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<nav class=\"kol-skip-nav\" aria-label={this.state._label}>\n\t\t\t\t<ul class=\"kol-skip-nav__list\">\n\t\t\t\t\t{this.state._links.map((link: LinkProps, index: number) => {\n\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t<li class=\"kol-skip-nav__list-item\" key={index}>\n\t\t\t\t\t\t\t\t<KolLinkWcTag {...link} ref={index === 0 ? (el) => (this.firstLinkRef = el) : undefined}></KolLinkWcTag>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t);\n\t\t\t\t\t})}\n\t\t\t\t</ul>\n\t\t\t</nav>\n\t\t);\n\t}\n\n\t/**\n\t * Sets focus on the internal element.\n\t */\n\t@Method()\n\tpublic async focus() {\n\t\treturn Promise.resolve(this.firstLinkRef?.focus());\n\t}\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: LabelPropType;\n\n\t/**\n\t * Defines the list of links combined with their labels to render.\n\t */\n\t@Prop() public _links!: Stringified<LinkProps[]>;\n\n\t@State() public state: SkipNavStates = {\n\t\t_label: '', // ⚠ required\n\t\t_links: [],\n\t};\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType, _oldValue?: LabelPropType, initial = false): void {\n\t\tif (!initial) {\n\t\t\tremoveNavLabel(this.state._label); // remove the current\n\t\t}\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t\taddNavLabel(this.state._label); // add the state instead of prop, because the prop could be invalid and not set as new label\n\t}\n\n\t@Watch('_links')\n\tpublic validateLinks(value?: Stringified<LinkProps[]>): void {\n\t\twatchNavLinks('KolSkipNav', this, value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateLabel(this._label, undefined, true);\n\t\tthis.validateLinks(this._links);\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tremoveNavLabel(this.state._label);\n\t}\n}\n"],"version":3}
1
+ {"file":"kol-skip-nav.js","mappings":";;;;;;;;;;AAAA,MAAM,eAAe,GAAG,6oVAA6oV;;MCoBxpVA,YAAU,GAAAC,kBAAA,CAAA,MAAA,UAAA,SAAA,WAAA,CAAA;AAPvB,IAAA,WAAA,CAAA,YAAA,EAAA;;;;;;QA4CiB,IAAA,CAAA,KAAK,GAAkB;AACtC,YAAA,MAAM,EAAE,EAAE;AACV,YAAA,MAAM,EAAE,EAAE;SACV;AA0BD;IA/DO,MAAM,GAAA;QACZ,QACC,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,cAAc,gBAAa,IAAI,CAAC,KAAK,CAAC,MAAM,EAAA,EACtD,CAAA,CAAA,IAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAI,KAAK,EAAC,oBAAoB,EAC5B,EAAA,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAe,EAAE,KAAa,KAAI;YACzD,QACC,UAAI,KAAK,EAAC,yBAAyB,EAAC,GAAG,EAAE,KAAK,EAAA,EAC7C,CAAA,CAAC,YAAY,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAK,IAAI,EAAA,EAAE,GAAG,EAAE,KAAK,KAAK,CAAC,GAAG,CAAC,EAAE,MAAM,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC,GAAG,SAAS,EAAiB,CAAA,CAAA,CACpG;AAEP,SAAC,CAAC,CACE,CACA;;AAQD,IAAA,MAAM,KAAK,GAAA;;AACjB,QAAA,OAAO,OAAO,CAAC,OAAO,CAAC,CAAA,EAAA,GAAA,IAAI,CAAC,YAAY,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,EAAE,CAAC;;AAmB5C,IAAA,aAAa,CAAC,KAAqB,EAAE,SAAyB,EAAE,OAAO,GAAG,KAAK,EAAA;QACrF,IAAI,CAAC,OAAO,EAAE;AACb,YAAA,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;;AAElC,QAAA,aAAa,CAAC,IAAI,EAAE,KAAK,EAAE;AAC1B,YAAA,QAAQ,EAAE,IAAI;AACd,SAAA,CAAC;AACF,QAAA,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;;AAIxB,IAAA,aAAa,CAAC,KAAgC,EAAA;AACpD,QAAA,aAAa,CAAC,YAAY,EAAE,IAAI,EAAE,KAAK,CAAC;;IAGlC,iBAAiB,GAAA;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,IAAI,CAAC;AAChD,QAAA,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC;;IAGzB,oBAAoB,GAAA;AAC1B,QAAA,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["KolSkipNav","__stencil_proxyCustomElement"],"sources":["src/components/skip-nav/style.scss?tag=kol-skip-nav&mode=default&encapsulation=shadow","src/components/skip-nav/shadow.tsx"],"sourcesContent":["@use '../@shared/mixins' as *;\n@use '../@shared/global' as *;\n@use '../@shared/link.mixin' as *;\n\n@layer kol-component {\n\t@include kol-link-styles('kol-link');\n\t.kol-skip-nav {\n\t\t&__list {\n\t\t\tdisplay: grid;\n\t\t\tplace-items: center;\n\t\t\tlist-style: none;\n\t\t}\n\n\t\t&__list-item {\n\t\t\theight: 0;\n\t\t}\n\n\t\t.kol-link {\n\t\t\tposition: absolute;\n\t\t\tleft: to-rem(-99999);\n\t\t\tz-index: 9999999;\n\n\t\t\tline-height: 1;\n\n\t\t\t&:focus {\n\t\t\t\tbackground-color: #fff;\n\t\t\t\tposition: unset;\n\t\t\t\tleft: unset;\n\t\t\t}\n\t\t}\n\t}\n}\n","import { Component, h, Method, Prop, State, Watch } from '@stencil/core';\nimport type { LabelPropType, LinkProps, SkipNavAPI, SkipNavStates, Stringified } from '../../schema';\nimport { validateLabel } from '../../schema';\n\nimport { addNavLabel, removeNavLabel } from '../../utils/unique-nav-labels';\nimport { watchNavLinks } from '../nav/validation';\n\nimport type { JSX } from '@stencil/core';\nimport { KolLinkWcTag } from '../../core/component-names';\n\n/**\n * The **SkipNav** component renders a hidden navigation that allows keyboard and assistive technology users to skip repetitive navigation sections and jump directly to the main content. It only becomes visible when reached via the Tab key.\n */\n@Component({\n\ttag: 'kol-skip-nav',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolSkipNav implements SkipNavAPI {\n\tprivate firstLinkRef?: HTMLKolLinkWcElement;\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<nav class=\"kol-skip-nav\" aria-label={this.state._label}>\n\t\t\t\t<ul class=\"kol-skip-nav__list\">\n\t\t\t\t\t{this.state._links.map((link: LinkProps, index: number) => {\n\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t<li class=\"kol-skip-nav__list-item\" key={index}>\n\t\t\t\t\t\t\t\t<KolLinkWcTag {...link} ref={index === 0 ? (el) => (this.firstLinkRef = el) : undefined}></KolLinkWcTag>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t);\n\t\t\t\t\t})}\n\t\t\t\t</ul>\n\t\t\t</nav>\n\t\t);\n\t}\n\n\t/**\n\t * Sets focus on the internal element.\n\t */\n\t@Method()\n\tpublic async focus() {\n\t\treturn Promise.resolve(this.firstLinkRef?.focus());\n\t}\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: LabelPropType;\n\n\t/**\n\t * Defines the list of links combined with their labels to render.\n\t */\n\t@Prop() public _links!: Stringified<LinkProps[]>;\n\n\t@State() public state: SkipNavStates = {\n\t\t_label: '', // ⚠ required\n\t\t_links: [],\n\t};\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType, _oldValue?: LabelPropType, initial = false): void {\n\t\tif (!initial) {\n\t\t\tremoveNavLabel(this.state._label); // remove the current\n\t\t}\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t\taddNavLabel(this.state._label); // add the state instead of prop, because the prop could be invalid and not set as new label\n\t}\n\n\t@Watch('_links')\n\tpublic validateLinks(value?: Stringified<LinkProps[]>): void {\n\t\twatchNavLinks('KolSkipNav', this, value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateLabel(this._label, undefined, true);\n\t\tthis.validateLinks(this._links);\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tremoveNavLabel(this.state._label);\n\t}\n}\n"],"version":3}