@public-ui/components 4.0.0-alpha.7 → 4.0.0-alpha.9

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 (784) hide show
  1. package/custom-elements.json +45 -31
  2. package/dist/cjs/{Alert-BqYNsCcH.js → Alert-DJji9pTY.js} +1 -1
  3. package/dist/cjs/{Alert-BqYNsCcH.js.map → Alert-DJji9pTY.js.map} +1 -1
  4. package/dist/cjs/{Collapsible-DTJWhv8p.js → Collapsible--nTMva3U.js} +1 -1
  5. package/dist/cjs/{Collapsible-DTJWhv8p.js.map → Collapsible--nTMva3U.js.map} +1 -1
  6. package/dist/cjs/CustomSuggestionsOptionsGroup-DchAIds4.js +4 -0
  7. package/dist/cjs/CustomSuggestionsOptionsGroup-DchAIds4.js.map +1 -0
  8. package/dist/cjs/{FieldControlStateWrapper-B_TP2y3b.js → FieldControlStateWrapper-CVGeHLm-.js} +1 -1
  9. package/dist/cjs/{FieldControlStateWrapper-B_TP2y3b.js.map → FieldControlStateWrapper-CVGeHLm-.js.map} +1 -1
  10. package/dist/cjs/FormFieldStateWrapper-CmhXozqy.js +4 -0
  11. package/dist/cjs/FormFieldStateWrapper-CmhXozqy.js.map +1 -0
  12. package/dist/cjs/{Heading-D_bFawIn.js → Heading-DaavIfCR.js} +1 -1
  13. package/dist/cjs/{Heading-D_bFawIn.js.map → Heading-DaavIfCR.js.map} +1 -1
  14. package/dist/cjs/{Icon-YOc5_4Ed.js → Icon-C1-8al8E.js} +1 -1
  15. package/dist/cjs/{Icon-YOc5_4Ed.js.map → Icon-C1-8al8E.js.map} +1 -1
  16. package/dist/cjs/Input-DLeBYNk9.js +4 -0
  17. package/dist/cjs/{Input-C0zMg2l7.js.map → Input-DLeBYNk9.js.map} +1 -1
  18. package/dist/cjs/{InputStateWrapper-D9zC05sO.js → InputStateWrapper-BFB4WYCN.js} +1 -1
  19. package/dist/cjs/{InputStateWrapper-D9zC05sO.js.map → InputStateWrapper-BFB4WYCN.js.map} +1 -1
  20. package/dist/cjs/{InternalUnderlinedBadgeText-C--2HF6e.js → InternalUnderlinedBadgeText-BEBfTuH2.js} +1 -1
  21. package/dist/cjs/{InternalUnderlinedBadgeText-C--2HF6e.js.map → InternalUnderlinedBadgeText-BEBfTuH2.js.map} +1 -1
  22. package/dist/cjs/{Span-CvfQvYhJ.js → Span-BKAcla8p.js} +1 -1
  23. package/dist/cjs/{Span-CvfQvYhJ.js.map → Span-BKAcla8p.js.map} +1 -1
  24. package/dist/cjs/{app-globals-DZtr2YDI.js → app-globals-1ypRH9fL.js} +1 -1
  25. package/dist/cjs/{app-globals-DZtr2YDI.js.map → app-globals-1ypRH9fL.js.map} +1 -1
  26. package/dist/cjs/{associated.controller-BOxMEHC7.js → associated.controller-CggkZ_kk.js} +1 -1
  27. package/dist/cjs/{associated.controller-BOxMEHC7.js.map → associated.controller-CggkZ_kk.js.map} +1 -1
  28. package/dist/cjs/{bootstrap-MHrRA1xR.js → bootstrap-Cj2LYo25.js} +1 -1
  29. package/dist/cjs/{bootstrap-MHrRA1xR.js.map → bootstrap-Cj2LYo25.js.map} +1 -1
  30. package/dist/cjs/{link-variant-gYtaoJ43.js → button-variant-Dc6H5OWB.js} +1 -1
  31. package/dist/cjs/button-variant-Dc6H5OWB.js.map +1 -0
  32. package/dist/cjs/{controller-Cry6hjMN.js → controller-CTBrikJs.js} +1 -1
  33. package/dist/cjs/{controller-Cry6hjMN.js.map → controller-CTBrikJs.js.map} +1 -1
  34. package/dist/cjs/{controller-BXRXJxEc.js → controller-CftAdu2B.js} +1 -1
  35. package/dist/cjs/{controller-BXRXJxEc.js.map → controller-CftAdu2B.js.map} +1 -1
  36. package/dist/cjs/controller-icon-CIKQAcIT.js +4 -0
  37. package/dist/cjs/controller-icon-CIKQAcIT.js.map +1 -0
  38. package/dist/cjs/{controller-BpIJrM_V.js → controller-p9a08L0H.js} +1 -1
  39. package/dist/cjs/{controller-BpIJrM_V.js.map → controller-p9a08L0H.js.map} +1 -1
  40. package/dist/cjs/{dev.utils-DST6uB5y.js → dev.utils-CM8ZYgoP.js} +1 -1
  41. package/dist/cjs/{dev.utils-DST6uB5y.js.map → dev.utils-CM8ZYgoP.js.map} +1 -1
  42. package/dist/cjs/{devtools-Z3ANpYCG.js → devtools-5M9LKr6a.js} +1 -1
  43. package/dist/cjs/{devtools-Z3ANpYCG.js.map → devtools-5M9LKr6a.js.map} +1 -1
  44. package/dist/cjs/i18n-Bu-c2BMf.js +4 -0
  45. package/dist/cjs/i18n-Bu-c2BMf.js.map +1 -0
  46. package/dist/cjs/i18n-CRy4IuYJ.js +4 -0
  47. package/dist/cjs/{i18n-Ch_xy25P.js.map → i18n-CRy4IuYJ.js.map} +1 -1
  48. package/dist/cjs/{index-D7f_k6zG.js → index-DI83iU9d.js} +1 -1
  49. package/dist/cjs/{index-D7f_k6zG.js.map → index-DI83iU9d.js.map} +1 -1
  50. package/dist/cjs/index.cjs.js +1 -1
  51. package/dist/cjs/inline-CGvu_CRs.js +4 -0
  52. package/dist/cjs/inline-CGvu_CRs.js.map +1 -0
  53. package/dist/cjs/kol-abbr.cjs.entry.js +1 -1
  54. package/dist/cjs/kol-accordion.cjs.entry.js +1 -1
  55. package/dist/cjs/kol-alert-wc.cjs.entry.js +1 -1
  56. package/dist/cjs/kol-alert.cjs.entry.js +1 -1
  57. package/dist/cjs/kol-avatar-wc.cjs.entry.js +1 -1
  58. package/dist/cjs/kol-avatar.cjs.entry.js +1 -1
  59. package/dist/cjs/kol-badge.cjs.entry.js +1 -1
  60. package/dist/cjs/kol-badge.entry.cjs.js.map +1 -1
  61. package/dist/cjs/kol-breadcrumb.cjs.entry.js +1 -1
  62. package/dist/cjs/kol-breadcrumb.entry.cjs.js.map +1 -1
  63. package/dist/cjs/kol-button-link.cjs.entry.js +1 -1
  64. package/dist/cjs/kol-button-link.entry.cjs.js.map +1 -1
  65. package/dist/cjs/kol-button-wc.cjs.entry.js +1 -1
  66. package/dist/cjs/kol-button-wc.entry.cjs.js.map +1 -1
  67. package/dist/cjs/kol-button.cjs.entry.js +1 -1
  68. package/dist/cjs/kol-button.entry.cjs.js.map +1 -1
  69. package/dist/cjs/kol-card-wc.cjs.entry.js +1 -1
  70. package/dist/cjs/kol-card.cjs.entry.js +1 -1
  71. package/dist/cjs/kol-combobox.cjs.entry.js +1 -1
  72. package/dist/cjs/kol-combobox.entry.cjs.js.map +1 -1
  73. package/dist/cjs/kol-details.cjs.entry.js +1 -1
  74. package/dist/cjs/kol-drawer.cjs.entry.js +1 -1
  75. package/dist/cjs/kol-form.cjs.entry.js +1 -1
  76. package/dist/cjs/kol-heading.cjs.entry.js +1 -1
  77. package/dist/cjs/kol-icon.cjs.entry.js +1 -1
  78. package/dist/cjs/kol-image.cjs.entry.js +1 -1
  79. package/dist/cjs/kol-input-checkbox.cjs.entry.js +1 -1
  80. package/dist/cjs/kol-input-checkbox.entry.cjs.js.map +1 -1
  81. package/dist/cjs/kol-input-color.cjs.entry.js +1 -1
  82. package/dist/cjs/kol-input-color.entry.cjs.js.map +1 -1
  83. package/dist/cjs/kol-input-date.cjs.entry.js +1 -1
  84. package/dist/cjs/kol-input-date.entry.cjs.js.map +1 -1
  85. package/dist/cjs/kol-input-email.cjs.entry.js +1 -1
  86. package/dist/cjs/kol-input-email.entry.cjs.js.map +1 -1
  87. package/dist/cjs/kol-input-file.cjs.entry.js +1 -1
  88. package/dist/cjs/kol-input-file.entry.cjs.js.map +1 -1
  89. package/dist/cjs/kol-input-number.cjs.entry.js +1 -1
  90. package/dist/cjs/kol-input-number.entry.cjs.js.map +1 -1
  91. package/dist/cjs/kol-input-password.cjs.entry.js +1 -1
  92. package/dist/cjs/kol-input-password.entry.cjs.js.map +1 -1
  93. package/dist/cjs/kol-input-radio.cjs.entry.js +1 -1
  94. package/dist/cjs/kol-input-radio.entry.cjs.js.map +1 -1
  95. package/dist/cjs/kol-input-range.cjs.entry.js +1 -1
  96. package/dist/cjs/kol-input-range.entry.cjs.js.map +1 -1
  97. package/dist/cjs/kol-input-text.cjs.entry.js +1 -1
  98. package/dist/cjs/kol-input-text.entry.cjs.js.map +1 -1
  99. package/dist/cjs/kol-kolibri.cjs.entry.js +1 -1
  100. package/dist/cjs/kol-link-button.cjs.entry.js +1 -1
  101. package/dist/cjs/kol-link-button.entry.cjs.js.map +1 -1
  102. package/dist/cjs/kol-link-wc.cjs.entry.js +1 -1
  103. package/dist/cjs/kol-link-wc.entry.cjs.js.map +1 -1
  104. package/dist/cjs/kol-link.cjs.entry.js +1 -1
  105. package/dist/cjs/kol-link.entry.cjs.js.map +1 -1
  106. package/dist/cjs/kol-modal.cjs.entry.js +1 -1
  107. package/dist/cjs/kol-nav.cjs.entry.js +1 -1
  108. package/dist/cjs/kol-nav.entry.cjs.js.map +1 -1
  109. package/dist/cjs/kol-pagination-wc.cjs.entry.js +1 -1
  110. package/dist/cjs/kol-pagination.cjs.entry.js +1 -1
  111. package/dist/cjs/kol-popover-button-wc.cjs.entry.js +1 -1
  112. package/dist/cjs/kol-popover-button-wc.entry.cjs.js.map +1 -1
  113. package/dist/cjs/kol-popover-button.cjs.entry.js +1 -1
  114. package/dist/cjs/kol-popover-button.entry.cjs.js.map +1 -1
  115. package/dist/cjs/kol-popover-wc.cjs.entry.js +1 -1
  116. package/dist/cjs/kol-progress.cjs.entry.js +1 -1
  117. package/dist/cjs/kol-quote.cjs.entry.js +1 -1
  118. package/dist/cjs/kol-select.cjs.entry.js +1 -1
  119. package/dist/cjs/kol-select.entry.cjs.js.map +1 -1
  120. package/dist/cjs/kol-single-select.cjs.entry.js +1 -1
  121. package/dist/cjs/kol-single-select.entry.cjs.js.map +1 -1
  122. package/dist/cjs/kol-skip-nav.cjs.entry.js +1 -1
  123. package/dist/cjs/kol-spin.cjs.entry.js +1 -1
  124. package/dist/cjs/kol-split-button.cjs.entry.js +1 -1
  125. package/dist/cjs/kol-table-settings-wc.cjs.entry.js +1 -1
  126. package/dist/cjs/kol-table-stateful.cjs.entry.js +1 -1
  127. package/dist/cjs/kol-table-stateful.entry.cjs.js.map +1 -1
  128. package/dist/cjs/kol-table-stateless-wc.cjs.entry.js +1 -1
  129. package/dist/cjs/kol-table-stateless-wc.entry.cjs.js.map +1 -1
  130. package/dist/cjs/kol-table-stateless.cjs.entry.js +1 -1
  131. package/dist/cjs/kol-table-stateless.entry.cjs.js.map +1 -1
  132. package/dist/cjs/kol-tabs.cjs.entry.js +1 -1
  133. package/dist/cjs/kol-textarea.cjs.entry.js +1 -1
  134. package/dist/cjs/kol-textarea.entry.cjs.js.map +1 -1
  135. package/dist/cjs/kol-toast-container.cjs.entry.js +1 -1
  136. package/dist/cjs/kol-toolbar.cjs.entry.js +1 -1
  137. package/dist/cjs/kol-toolbar.entry.cjs.js.map +1 -1
  138. package/dist/cjs/kol-tooltip-wc.cjs.entry.js +1 -1
  139. package/dist/cjs/kol-tree-item-wc.cjs.entry.js +1 -1
  140. package/dist/cjs/kol-tree-item.cjs.entry.js +1 -1
  141. package/dist/cjs/kol-tree-wc.cjs.entry.js +1 -1
  142. package/dist/cjs/kol-tree.cjs.entry.js +1 -1
  143. package/dist/cjs/kol-version.cjs.entry.js +1 -1
  144. package/dist/cjs/kolibri.cjs.js +1 -1
  145. package/dist/cjs/loader.cjs.js +1 -1
  146. package/dist/cjs/test-component.cjs.entry.js +1 -1
  147. package/dist/components/CustomSuggestionsOptionsGroup.js +1 -1
  148. package/dist/components/CustomSuggestionsOptionsGroup.js.map +1 -1
  149. package/dist/components/button-variant.js +4 -0
  150. package/dist/components/button-variant.js.map +1 -0
  151. package/dist/components/controller-icon.js +1 -1
  152. package/dist/components/controller-icon.js.map +1 -1
  153. package/dist/components/controller2.js +1 -1
  154. package/dist/components/controller2.js.map +1 -1
  155. package/dist/components/i18n2.js +1 -1
  156. package/dist/components/i18n2.js.map +1 -1
  157. package/dist/components/inline.js +4 -0
  158. package/dist/components/inline.js.map +1 -0
  159. package/dist/components/kol-badge.js +1 -1
  160. package/dist/components/kol-badge.js.map +1 -1
  161. package/dist/components/kol-breadcrumb.js +1 -1
  162. package/dist/components/kol-breadcrumb.js.map +1 -1
  163. package/dist/components/kol-button-link.js +1 -1
  164. package/dist/components/kol-button-link.js.map +1 -1
  165. package/dist/components/kol-button-wc.js +1 -1
  166. package/dist/components/kol-button-wc.js.map +1 -1
  167. package/dist/components/kol-button.js +1 -1
  168. package/dist/components/kol-button.js.map +1 -1
  169. package/dist/components/kol-combobox.js +1 -1
  170. package/dist/components/kol-combobox.js.map +1 -1
  171. package/dist/components/kol-input-checkbox.js +1 -1
  172. package/dist/components/kol-input-checkbox.js.map +1 -1
  173. package/dist/components/kol-input-color.js +1 -1
  174. package/dist/components/kol-input-color.js.map +1 -1
  175. package/dist/components/kol-input-date.js +1 -1
  176. package/dist/components/kol-input-date.js.map +1 -1
  177. package/dist/components/kol-input-email.js +1 -1
  178. package/dist/components/kol-input-email.js.map +1 -1
  179. package/dist/components/kol-input-file.js +1 -1
  180. package/dist/components/kol-input-file.js.map +1 -1
  181. package/dist/components/kol-input-number.js +1 -1
  182. package/dist/components/kol-input-number.js.map +1 -1
  183. package/dist/components/kol-input-password.js +1 -1
  184. package/dist/components/kol-input-password.js.map +1 -1
  185. package/dist/components/kol-input-radio.js +1 -1
  186. package/dist/components/kol-input-radio.js.map +1 -1
  187. package/dist/components/kol-input-range.js +1 -1
  188. package/dist/components/kol-input-range.js.map +1 -1
  189. package/dist/components/kol-input-text.js +1 -1
  190. package/dist/components/kol-input-text.js.map +1 -1
  191. package/dist/components/kol-link-button.js +1 -1
  192. package/dist/components/kol-link-button.js.map +1 -1
  193. package/dist/components/kol-link-wc.js +1 -1
  194. package/dist/components/kol-link-wc.js.map +1 -1
  195. package/dist/components/kol-link.js +1 -1
  196. package/dist/components/kol-link.js.map +1 -1
  197. package/dist/components/kol-nav.js +1 -1
  198. package/dist/components/kol-nav.js.map +1 -1
  199. package/dist/components/kol-popover-button-wc.js +1 -1
  200. package/dist/components/kol-popover-button-wc.js.map +1 -1
  201. package/dist/components/kol-popover-button.js +1 -1
  202. package/dist/components/kol-popover-button.js.map +1 -1
  203. package/dist/components/kol-select.js +1 -1
  204. package/dist/components/kol-select.js.map +1 -1
  205. package/dist/components/kol-single-select.js +1 -1
  206. package/dist/components/kol-single-select.js.map +1 -1
  207. package/dist/components/kol-table-stateful.js +1 -1
  208. package/dist/components/kol-table-stateful.js.map +1 -1
  209. package/dist/components/kol-table-stateless-wc.js +1 -1
  210. package/dist/components/kol-table-stateless-wc.js.map +1 -1
  211. package/dist/components/kol-table-stateless.js +1 -1
  212. package/dist/components/kol-table-stateless.js.map +1 -1
  213. package/dist/components/kol-textarea.js +1 -1
  214. package/dist/components/kol-textarea.js.map +1 -1
  215. package/dist/components/kol-toolbar.js +1 -1
  216. package/dist/components/kol-toolbar.js.map +1 -1
  217. package/dist/esm/{Alert-83Gb4NJi.js → Alert-BVXxAiPu.js} +1 -1
  218. package/dist/{kolibri/Alert-83Gb4NJi.js.map → esm/Alert-BVXxAiPu.js.map} +1 -1
  219. package/dist/esm/{Collapsible-BWBRUxlQ.js → Collapsible-DeF6ptXV.js} +1 -1
  220. package/dist/esm/{Collapsible-BWBRUxlQ.js.map → Collapsible-DeF6ptXV.js.map} +1 -1
  221. package/dist/esm/CustomSuggestionsOptionsGroup-CqxxUJGe.js +4 -0
  222. package/dist/esm/CustomSuggestionsOptionsGroup-CqxxUJGe.js.map +1 -0
  223. package/dist/esm/{FieldControlStateWrapper-DHi-9Vch.js → FieldControlStateWrapper-DQnEdxHI.js} +1 -1
  224. package/dist/{kolibri/FieldControlStateWrapper-DHi-9Vch.js.map → esm/FieldControlStateWrapper-DQnEdxHI.js.map} +1 -1
  225. package/dist/esm/FormFieldStateWrapper-Bd0o35ib.js +4 -0
  226. package/dist/esm/FormFieldStateWrapper-Bd0o35ib.js.map +1 -0
  227. package/dist/esm/{Heading-Dp1LmW2r.js → Heading-CYFoVwZo.js} +1 -1
  228. package/dist/{kolibri/Heading-Dp1LmW2r.js.map → esm/Heading-CYFoVwZo.js.map} +1 -1
  229. package/dist/esm/{Icon-BTCiUYU9.js → Icon-BhuXTCGL.js} +1 -1
  230. package/dist/esm/{Icon-BTCiUYU9.js.map → Icon-BhuXTCGL.js.map} +1 -1
  231. package/dist/esm/Input-Dr5ocqy1.js +4 -0
  232. package/dist/esm/{Input-DCya5HSR.js.map → Input-Dr5ocqy1.js.map} +1 -1
  233. package/dist/esm/{InputStateWrapper-B6CEb3g-.js → InputStateWrapper-DREwaQ1G.js} +1 -1
  234. package/dist/esm/{InputStateWrapper-B6CEb3g-.js.map → InputStateWrapper-DREwaQ1G.js.map} +1 -1
  235. package/dist/esm/InternalUnderlinedBadgeText-CJyOdgkx.js +4 -0
  236. package/dist/esm/{InternalUnderlinedBadgeText-Bs9VOx3f.js.map → InternalUnderlinedBadgeText-CJyOdgkx.js.map} +1 -1
  237. package/dist/esm/{Span-KZITft3P.js → Span-DFyIWuOc.js} +1 -1
  238. package/dist/esm/{Span-KZITft3P.js.map → Span-DFyIWuOc.js.map} +1 -1
  239. package/dist/esm/{access-and-short-key-B37XLwy2.js → access-and-short-key-Dy2a7Py3.js} +1 -1
  240. package/dist/esm/{access-and-short-key-B37XLwy2.js.map → access-and-short-key-Dy2a7Py3.js.map} +1 -1
  241. package/dist/esm/{align-D-ifSKu8.js → align-Bcqvz5vw.js} +1 -1
  242. package/dist/esm/{align-D-ifSKu8.js.map → align-Bcqvz5vw.js.map} +1 -1
  243. package/dist/esm/{align-floating-elements-BkpeqvtE.js → align-floating-elements-DUQRrio7.js} +1 -1
  244. package/dist/{kolibri/align-floating-elements-BkpeqvtE.js.map → esm/align-floating-elements-DUQRrio7.js.map} +1 -1
  245. package/dist/esm/{app-globals-BvgNyEID.js → app-globals-cbZ0c5AX.js} +1 -1
  246. package/dist/{kolibri/app-globals-BvgNyEID.js.map → esm/app-globals-cbZ0c5AX.js.map} +1 -1
  247. package/dist/esm/{associated.controller-CKSywYuL.js → associated.controller-CvM-u0FR.js} +1 -1
  248. package/dist/{kolibri/associated.controller-CKSywYuL.js.map → esm/associated.controller-CvM-u0FR.js.map} +1 -1
  249. package/dist/esm/{auto-complete-mCkUnxg2.js → auto-complete-h9OoHuC5.js} +1 -1
  250. package/dist/esm/{auto-complete-mCkUnxg2.js.map → auto-complete-h9OoHuC5.js.map} +1 -1
  251. package/dist/esm/{bem-BBRwGb1a.js → bem-B2ILLet6.js} +1 -1
  252. package/dist/esm/{bem-BBRwGb1a.js.map → bem-B2ILLet6.js.map} +1 -1
  253. package/dist/esm/{bem-C27SfH6w.js → bem-CIn1qsbp.js} +1 -1
  254. package/dist/esm/{bem-C27SfH6w.js.map → bem-CIn1qsbp.js.map} +1 -1
  255. package/dist/esm/{bootstrap-DiYNsmQ4.js → bootstrap-DKvDv4kw.js} +1 -1
  256. package/dist/esm/{bootstrap-DiYNsmQ4.js.map → bootstrap-DKvDv4kw.js.map} +1 -1
  257. package/dist/esm/{browser-DiRe0qUf.js → browser-CyCtPZc0.js} +1 -1
  258. package/dist/esm/{browser-DiRe0qUf.js.map → browser-CyCtPZc0.js.map} +1 -1
  259. package/dist/esm/button-variant-ueS50zGR.js +4 -0
  260. package/dist/esm/button-variant-ueS50zGR.js.map +1 -0
  261. package/dist/esm/{color-BOIEtqEM.js → color-DLhBoaj-.js} +1 -1
  262. package/dist/{kolibri/color-BOIEtqEM.js.map → esm/color-DLhBoaj-.js.map} +1 -1
  263. package/dist/esm/{common-Dd0zJQbD.js → common-L1K0yh1S.js} +1 -1
  264. package/dist/{kolibri/common-Dd0zJQbD.js.map → esm/common-L1K0yh1S.js.map} +1 -1
  265. package/dist/esm/{controller-BF_Czp7e.js → controller-CvQgz4Lj.js} +1 -1
  266. package/dist/{kolibri/controller-BF_Czp7e.js.map → esm/controller-CvQgz4Lj.js.map} +1 -1
  267. package/dist/esm/{controller-n_eFbbek.js → controller-Cyv3Nwdy.js} +1 -1
  268. package/dist/{kolibri/controller-n_eFbbek.js.map → esm/controller-Cyv3Nwdy.js.map} +1 -1
  269. package/dist/esm/{controller-C5Ill7ej.js → controller-DLgscExO.js} +1 -1
  270. package/dist/esm/{controller-C5Ill7ej.js.map → controller-DLgscExO.js.map} +1 -1
  271. package/dist/esm/{controller-CQtkSgzE.js → controller-_yDBKgWi.js} +1 -1
  272. package/dist/esm/{controller-CQtkSgzE.js.map → controller-_yDBKgWi.js.map} +1 -1
  273. package/dist/esm/controller-icon-C6oGFMFu.js +4 -0
  274. package/dist/esm/controller-icon-C6oGFMFu.js.map +1 -0
  275. package/dist/esm/{custom-class-nuoQ9Aml.js → custom-class-Dg0c6ST7.js} +1 -1
  276. package/dist/esm/{custom-class-nuoQ9Aml.js.map → custom-class-Dg0c6ST7.js.map} +1 -1
  277. package/dist/esm/{dev.utils-CLelInms.js → dev.utils-DczzdGZ6.js} +1 -1
  278. package/dist/esm/{dev.utils-CLelInms.js.map → dev.utils-DczzdGZ6.js.map} +1 -1
  279. package/dist/esm/{devtools-8P6cNSgN.js → devtools-DhNjMrnY.js} +1 -1
  280. package/dist/esm/{devtools-8P6cNSgN.js.map → devtools-DhNjMrnY.js.map} +1 -1
  281. package/dist/esm/disabled-u5a_azlj.js +4 -0
  282. package/dist/esm/{disabled-BhpAFgSp.js.map → disabled-u5a_azlj.js.map} +1 -1
  283. package/dist/esm/{has-closer-CQzjaTkv.js → has-closer-DENzUWH2.js} +1 -1
  284. package/dist/esm/{has-closer-CQzjaTkv.js.map → has-closer-DENzUWH2.js.map} +1 -1
  285. package/dist/esm/{hide-label-B9FhGrWP.js → hide-label-DjBQJOAP.js} +1 -1
  286. package/dist/esm/{hide-label-B9FhGrWP.js.map → hide-label-DjBQJOAP.js.map} +1 -1
  287. package/dist/esm/{href-rwDd36rS.js → href-LHUCJ_IZ.js} +1 -1
  288. package/dist/esm/{href-rwDd36rS.js.map → href-LHUCJ_IZ.js.map} +1 -1
  289. package/dist/esm/i18n-B-iJAw_i.js +4 -0
  290. package/dist/esm/i18n-B-iJAw_i.js.map +1 -0
  291. package/dist/esm/{i18n-BzQ08vD6.js → i18n-CQxlBXNV.js} +1 -1
  292. package/dist/esm/{i18n-BzQ08vD6.js.map → i18n-CQxlBXNV.js.map} +1 -1
  293. package/dist/esm/{icons-B5i9zwjJ.js → icons-CmMX8bbY.js} +1 -1
  294. package/dist/esm/{icons-B5i9zwjJ.js.map → icons-CmMX8bbY.js.map} +1 -1
  295. package/dist/esm/{image-source-BfBEJ0rX.js → image-source-DqpWx57w.js} +1 -1
  296. package/dist/esm/{image-source-BfBEJ0rX.js.map → image-source-DqpWx57w.js.map} +1 -1
  297. package/dist/esm/{index-BtD7uFmA.js → index-iB2O5Z2w.js} +1 -1
  298. package/dist/{kolibri/index-BtD7uFmA.js.map → esm/index-iB2O5Z2w.js.map} +1 -1
  299. package/dist/esm/index.js +1 -1
  300. package/dist/esm/inline-CeKQgcde.js +4 -0
  301. package/dist/esm/inline-CeKQgcde.js.map +1 -0
  302. package/dist/esm/kol-abbr.entry.js +1 -1
  303. package/dist/esm/kol-accordion.entry.js +1 -1
  304. package/dist/esm/kol-alert-wc.entry.js +1 -1
  305. package/dist/esm/kol-alert.entry.js +1 -1
  306. package/dist/esm/kol-avatar-wc.entry.js +1 -1
  307. package/dist/esm/kol-avatar.entry.js +1 -1
  308. package/dist/esm/kol-badge.entry.js +1 -1
  309. package/dist/esm/kol-badge.entry.js.map +1 -1
  310. package/dist/esm/kol-breadcrumb.entry.js +1 -1
  311. package/dist/esm/kol-breadcrumb.entry.js.map +1 -1
  312. package/dist/esm/kol-button-link.entry.js +1 -1
  313. package/dist/esm/kol-button-link.entry.js.map +1 -1
  314. package/dist/esm/kol-button-wc.entry.js +1 -1
  315. package/dist/esm/kol-button-wc.entry.js.map +1 -1
  316. package/dist/esm/kol-button.entry.js +1 -1
  317. package/dist/esm/kol-button.entry.js.map +1 -1
  318. package/dist/esm/kol-card-wc.entry.js +1 -1
  319. package/dist/esm/kol-card.entry.js +1 -1
  320. package/dist/esm/kol-combobox.entry.js +1 -1
  321. package/dist/esm/kol-combobox.entry.js.map +1 -1
  322. package/dist/esm/kol-details.entry.js +1 -1
  323. package/dist/esm/kol-drawer.entry.js +1 -1
  324. package/dist/esm/kol-form.entry.js +1 -1
  325. package/dist/esm/kol-heading.entry.js +1 -1
  326. package/dist/esm/kol-icon.entry.js +1 -1
  327. package/dist/esm/kol-image.entry.js +1 -1
  328. package/dist/esm/kol-input-checkbox.entry.js +1 -1
  329. package/dist/esm/kol-input-checkbox.entry.js.map +1 -1
  330. package/dist/esm/kol-input-color.entry.js +1 -1
  331. package/dist/esm/kol-input-color.entry.js.map +1 -1
  332. package/dist/esm/kol-input-date.entry.js +1 -1
  333. package/dist/esm/kol-input-date.entry.js.map +1 -1
  334. package/dist/esm/kol-input-email.entry.js +1 -1
  335. package/dist/esm/kol-input-email.entry.js.map +1 -1
  336. package/dist/esm/kol-input-file.entry.js +1 -1
  337. package/dist/esm/kol-input-file.entry.js.map +1 -1
  338. package/dist/esm/kol-input-number.entry.js +1 -1
  339. package/dist/esm/kol-input-number.entry.js.map +1 -1
  340. package/dist/esm/kol-input-password.entry.js +1 -1
  341. package/dist/esm/kol-input-password.entry.js.map +1 -1
  342. package/dist/esm/kol-input-radio.entry.js +1 -1
  343. package/dist/esm/kol-input-radio.entry.js.map +1 -1
  344. package/dist/esm/kol-input-range.entry.js +1 -1
  345. package/dist/esm/kol-input-range.entry.js.map +1 -1
  346. package/dist/esm/kol-input-text.entry.js +1 -1
  347. package/dist/esm/kol-input-text.entry.js.map +1 -1
  348. package/dist/esm/kol-kolibri.entry.js +1 -1
  349. package/dist/esm/kol-link-button.entry.js +1 -1
  350. package/dist/esm/kol-link-button.entry.js.map +1 -1
  351. package/dist/esm/kol-link-wc.entry.js +1 -1
  352. package/dist/esm/kol-link-wc.entry.js.map +1 -1
  353. package/dist/esm/kol-link.entry.js +1 -1
  354. package/dist/esm/kol-link.entry.js.map +1 -1
  355. package/dist/esm/kol-modal.entry.js +1 -1
  356. package/dist/esm/kol-nav.entry.js +1 -1
  357. package/dist/esm/kol-nav.entry.js.map +1 -1
  358. package/dist/esm/kol-pagination-wc.entry.js +1 -1
  359. package/dist/esm/kol-pagination.entry.js +1 -1
  360. package/dist/esm/kol-popover-button-wc.entry.js +1 -1
  361. package/dist/esm/kol-popover-button-wc.entry.js.map +1 -1
  362. package/dist/esm/kol-popover-button.entry.js +1 -1
  363. package/dist/esm/kol-popover-button.entry.js.map +1 -1
  364. package/dist/esm/kol-popover-wc.entry.js +1 -1
  365. package/dist/esm/kol-progress.entry.js +1 -1
  366. package/dist/esm/kol-quote.entry.js +1 -1
  367. package/dist/esm/kol-select.entry.js +1 -1
  368. package/dist/esm/kol-select.entry.js.map +1 -1
  369. package/dist/esm/kol-single-select.entry.js +1 -1
  370. package/dist/esm/kol-single-select.entry.js.map +1 -1
  371. package/dist/esm/kol-skip-nav.entry.js +1 -1
  372. package/dist/esm/kol-spin.entry.js +1 -1
  373. package/dist/esm/kol-split-button.entry.js +1 -1
  374. package/dist/esm/kol-table-settings-wc.entry.js +1 -1
  375. package/dist/esm/kol-table-stateful.entry.js +1 -1
  376. package/dist/esm/kol-table-stateful.entry.js.map +1 -1
  377. package/dist/esm/kol-table-stateless-wc.entry.js +1 -1
  378. package/dist/esm/kol-table-stateless-wc.entry.js.map +1 -1
  379. package/dist/esm/kol-table-stateless.entry.js +1 -1
  380. package/dist/esm/kol-table-stateless.entry.js.map +1 -1
  381. package/dist/esm/kol-tabs.entry.js +1 -1
  382. package/dist/esm/kol-textarea.entry.js +1 -1
  383. package/dist/esm/kol-textarea.entry.js.map +1 -1
  384. package/dist/esm/kol-toast-container.entry.js +1 -1
  385. package/dist/esm/kol-toolbar.entry.js +1 -1
  386. package/dist/esm/kol-toolbar.entry.js.map +1 -1
  387. package/dist/esm/kol-tooltip-wc.entry.js +1 -1
  388. package/dist/esm/kol-tree-item-wc.entry.js +1 -1
  389. package/dist/esm/kol-tree-item.entry.js +1 -1
  390. package/dist/esm/kol-tree-wc.entry.js +1 -1
  391. package/dist/esm/kol-tree.entry.js +1 -1
  392. package/dist/esm/kol-version.entry.js +1 -1
  393. package/dist/esm/kolibri.js +1 -1
  394. package/dist/esm/{label-Dnmzb2S_.js → label-ohY9ajP0.js} +1 -1
  395. package/dist/{kolibri/label-Dnmzb2S_.js.map → esm/label-ohY9ajP0.js.map} +1 -1
  396. package/dist/esm/loader.js +1 -1
  397. package/dist/esm/{markdown-BSkXjaSn.js → markdown-CVks1MC0.js} +1 -1
  398. package/dist/esm/{markdown-BSkXjaSn.js.map → markdown-CVks1MC0.js.map} +1 -1
  399. package/dist/esm/{max-length-behavior-nTw1Zuyf.js → max-length-behavior-N5Lbz6E-.js} +1 -1
  400. package/dist/esm/{max-length-behavior-nTw1Zuyf.js.map → max-length-behavior-N5Lbz6E-.js.map} +1 -1
  401. package/dist/esm/{multiple-Cj3JQafH.js → multiple-D1puaB9F.js} +1 -1
  402. package/dist/esm/{multiple-Cj3JQafH.js.map → multiple-D1puaB9F.js.map} +1 -1
  403. package/dist/esm/{open-CbvHO4XG.js → open-BFQWty8w.js} +1 -1
  404. package/dist/esm/{open-CbvHO4XG.js.map → open-BFQWty8w.js.map} +1 -1
  405. package/dist/esm/{orientation-eCMt8CD1.js → orientation-B0ErOlUK.js} +1 -1
  406. package/dist/esm/{orientation-eCMt8CD1.js.map → orientation-B0ErOlUK.js.map} +1 -1
  407. package/dist/esm/{placeholder-BVhy3BzI.js → placeholder-DrgXYoah.js} +1 -1
  408. package/dist/esm/{placeholder-BVhy3BzI.js.map → placeholder-DrgXYoah.js.map} +1 -1
  409. package/dist/esm/{read-only-BetTuumR.js → read-only-Bp291veM.js} +1 -1
  410. package/dist/esm/{read-only-BetTuumR.js.map → read-only-Bp291veM.js.map} +1 -1
  411. package/dist/esm/{required-CnTTpFCN.js → required-7L0ytoMT.js} +1 -1
  412. package/dist/esm/{required-CnTTpFCN.js.map → required-7L0ytoMT.js.map} +1 -1
  413. package/dist/esm/{rows-DtS-0sp9.js → rows-C8piLIWD.js} +1 -1
  414. package/dist/esm/{rows-DtS-0sp9.js.map → rows-C8piLIWD.js.map} +1 -1
  415. package/dist/esm/{show-DdPK3aM7.js → show-ChfALFZd.js} +1 -1
  416. package/dist/{kolibri/show-DdPK3aM7.js.map → esm/show-ChfALFZd.js.map} +1 -1
  417. package/dist/esm/{spell-check-B9ot-4t-.js → spell-check-DrU5XI1o.js} +1 -1
  418. package/dist/esm/{spell-check-B9ot-4t-.js.map → spell-check-DrU5XI1o.js.map} +1 -1
  419. package/dist/esm/{suggestions-B-jLvT4L.js → suggestions-Bufr76At.js} +1 -1
  420. package/dist/esm/{suggestions-B-jLvT4L.js.map → suggestions-Bufr76At.js.map} +1 -1
  421. package/dist/esm/{table-settings-DxLvhwRE.js → table-settings-BYcS3vAt.js} +1 -1
  422. package/dist/esm/{table-settings-DxLvhwRE.js.map → table-settings-BYcS3vAt.js.map} +1 -1
  423. package/dist/esm/test-component.entry.js +1 -1
  424. package/dist/esm/tooltip-align-DEw_M6Is.js +4 -0
  425. package/dist/esm/{tooltip-align-Cnin7S26.js.map → tooltip-align-DEw_M6Is.js.map} +1 -1
  426. package/dist/esm/{unique-nav-labels-CrfmPC99.js → unique-nav-labels-C-bt2E8D.js} +1 -1
  427. package/dist/esm/{unique-nav-labels-CrfmPC99.js.map → unique-nav-labels-C-bt2E8D.js.map} +1 -1
  428. package/dist/esm/{validation-aqgnZOL6.js → validation-BVeaxeev.js} +1 -1
  429. package/dist/esm/{validation-aqgnZOL6.js.map → validation-BVeaxeev.js.map} +1 -1
  430. package/dist/esm/{validation-BfjI5un_.js → validation-BmqW5reG.js} +1 -1
  431. package/dist/esm/{validation-BfjI5un_.js.map → validation-BmqW5reG.js.map} +1 -1
  432. package/dist/kolibri/Alert-BVXxAiPu.js +4 -0
  433. package/dist/{esm/Alert-83Gb4NJi.js.map → kolibri/Alert-BVXxAiPu.js.map} +1 -1
  434. package/dist/kolibri/Collapsible-DeF6ptXV.js +4 -0
  435. package/dist/kolibri/{Collapsible-BWBRUxlQ.js.map → Collapsible-DeF6ptXV.js.map} +1 -1
  436. package/dist/kolibri/CustomSuggestionsOptionsGroup-CqxxUJGe.js +4 -0
  437. package/dist/kolibri/CustomSuggestionsOptionsGroup-CqxxUJGe.js.map +1 -0
  438. package/dist/kolibri/FieldControlStateWrapper-DQnEdxHI.js +4 -0
  439. package/dist/{esm/FieldControlStateWrapper-DHi-9Vch.js.map → kolibri/FieldControlStateWrapper-DQnEdxHI.js.map} +1 -1
  440. package/dist/kolibri/FormFieldStateWrapper-Bd0o35ib.js +4 -0
  441. package/dist/kolibri/FormFieldStateWrapper-Bd0o35ib.js.map +1 -0
  442. package/dist/kolibri/{Heading-Dp1LmW2r.js → Heading-CYFoVwZo.js} +1 -1
  443. package/dist/{esm/Heading-Dp1LmW2r.js.map → kolibri/Heading-CYFoVwZo.js.map} +1 -1
  444. package/dist/kolibri/Icon-BhuXTCGL.js +4 -0
  445. package/dist/kolibri/{Icon-BTCiUYU9.js.map → Icon-BhuXTCGL.js.map} +1 -1
  446. package/dist/kolibri/Input-Dr5ocqy1.js +4 -0
  447. package/dist/kolibri/{Input-DCya5HSR.js.map → Input-Dr5ocqy1.js.map} +1 -1
  448. package/dist/kolibri/InputStateWrapper-DREwaQ1G.js +4 -0
  449. package/dist/kolibri/{InputStateWrapper-B6CEb3g-.js.map → InputStateWrapper-DREwaQ1G.js.map} +1 -1
  450. package/dist/kolibri/InternalUnderlinedBadgeText-CJyOdgkx.js +4 -0
  451. package/dist/kolibri/{InternalUnderlinedBadgeText-Bs9VOx3f.js.map → InternalUnderlinedBadgeText-CJyOdgkx.js.map} +1 -1
  452. package/dist/kolibri/Span-DFyIWuOc.js +4 -0
  453. package/dist/kolibri/{Span-KZITft3P.js.map → Span-DFyIWuOc.js.map} +1 -1
  454. package/dist/kolibri/{access-and-short-key-B37XLwy2.js → access-and-short-key-Dy2a7Py3.js} +1 -1
  455. package/dist/kolibri/{access-and-short-key-B37XLwy2.js.map → access-and-short-key-Dy2a7Py3.js.map} +1 -1
  456. package/dist/kolibri/{align-D-ifSKu8.js → align-Bcqvz5vw.js} +1 -1
  457. package/dist/kolibri/{align-D-ifSKu8.js.map → align-Bcqvz5vw.js.map} +1 -1
  458. package/dist/kolibri/{align-floating-elements-BkpeqvtE.js → align-floating-elements-DUQRrio7.js} +1 -1
  459. package/dist/{esm/align-floating-elements-BkpeqvtE.js.map → kolibri/align-floating-elements-DUQRrio7.js.map} +1 -1
  460. package/dist/kolibri/app-globals-cbZ0c5AX.js +4 -0
  461. package/dist/{esm/app-globals-BvgNyEID.js.map → kolibri/app-globals-cbZ0c5AX.js.map} +1 -1
  462. package/dist/kolibri/{associated.controller-CKSywYuL.js → associated.controller-CvM-u0FR.js} +1 -1
  463. package/dist/{esm/associated.controller-CKSywYuL.js.map → kolibri/associated.controller-CvM-u0FR.js.map} +1 -1
  464. package/dist/kolibri/{auto-complete-mCkUnxg2.js → auto-complete-h9OoHuC5.js} +1 -1
  465. package/dist/kolibri/{auto-complete-mCkUnxg2.js.map → auto-complete-h9OoHuC5.js.map} +1 -1
  466. package/dist/kolibri/bem-B2ILLet6.js +4 -0
  467. package/dist/kolibri/{bem-BBRwGb1a.js.map → bem-B2ILLet6.js.map} +1 -1
  468. package/dist/kolibri/{bem-C27SfH6w.js → bem-CIn1qsbp.js} +1 -1
  469. package/dist/kolibri/{bem-C27SfH6w.js.map → bem-CIn1qsbp.js.map} +1 -1
  470. package/dist/kolibri/{bootstrap-DiYNsmQ4.js → bootstrap-DKvDv4kw.js} +1 -1
  471. package/dist/kolibri/{bootstrap-DiYNsmQ4.js.map → bootstrap-DKvDv4kw.js.map} +1 -1
  472. package/dist/kolibri/{browser-DiRe0qUf.js → browser-CyCtPZc0.js} +1 -1
  473. package/dist/kolibri/{browser-DiRe0qUf.js.map → browser-CyCtPZc0.js.map} +1 -1
  474. package/dist/kolibri/button-variant-ueS50zGR.js +4 -0
  475. package/dist/kolibri/button-variant-ueS50zGR.js.map +1 -0
  476. package/dist/kolibri/{color-BOIEtqEM.js → color-DLhBoaj-.js} +1 -1
  477. package/dist/{esm/color-BOIEtqEM.js.map → kolibri/color-DLhBoaj-.js.map} +1 -1
  478. package/dist/kolibri/{common-Dd0zJQbD.js → common-L1K0yh1S.js} +1 -1
  479. package/dist/{esm/common-Dd0zJQbD.js.map → kolibri/common-L1K0yh1S.js.map} +1 -1
  480. package/dist/kolibri/{controller-BF_Czp7e.js → controller-CvQgz4Lj.js} +1 -1
  481. package/dist/{esm/controller-BF_Czp7e.js.map → kolibri/controller-CvQgz4Lj.js.map} +1 -1
  482. package/dist/kolibri/controller-Cyv3Nwdy.js +4 -0
  483. package/dist/{esm/controller-n_eFbbek.js.map → kolibri/controller-Cyv3Nwdy.js.map} +1 -1
  484. package/dist/kolibri/{controller-C5Ill7ej.js → controller-DLgscExO.js} +1 -1
  485. package/dist/kolibri/{controller-C5Ill7ej.js.map → controller-DLgscExO.js.map} +1 -1
  486. package/dist/kolibri/{controller-CQtkSgzE.js → controller-_yDBKgWi.js} +1 -1
  487. package/dist/kolibri/{controller-CQtkSgzE.js.map → controller-_yDBKgWi.js.map} +1 -1
  488. package/dist/kolibri/controller-icon-C6oGFMFu.js +4 -0
  489. package/dist/kolibri/controller-icon-C6oGFMFu.js.map +1 -0
  490. package/dist/kolibri/custom-class-Dg0c6ST7.js +4 -0
  491. package/dist/kolibri/{custom-class-nuoQ9Aml.js.map → custom-class-Dg0c6ST7.js.map} +1 -1
  492. package/dist/kolibri/{dev.utils-CLelInms.js → dev.utils-DczzdGZ6.js} +1 -1
  493. package/dist/kolibri/{dev.utils-CLelInms.js.map → dev.utils-DczzdGZ6.js.map} +1 -1
  494. package/dist/kolibri/{devtools-8P6cNSgN.js → devtools-DhNjMrnY.js} +1 -1
  495. package/dist/kolibri/{devtools-8P6cNSgN.js.map → devtools-DhNjMrnY.js.map} +1 -1
  496. package/dist/kolibri/disabled-u5a_azlj.js +4 -0
  497. package/dist/kolibri/{disabled-BhpAFgSp.js.map → disabled-u5a_azlj.js.map} +1 -1
  498. package/dist/kolibri/has-closer-DENzUWH2.js +4 -0
  499. package/dist/kolibri/{has-closer-CQzjaTkv.js.map → has-closer-DENzUWH2.js.map} +1 -1
  500. package/dist/kolibri/hide-label-DjBQJOAP.js +4 -0
  501. package/dist/kolibri/{hide-label-B9FhGrWP.js.map → hide-label-DjBQJOAP.js.map} +1 -1
  502. package/dist/kolibri/href-LHUCJ_IZ.js +4 -0
  503. package/dist/kolibri/{href-rwDd36rS.js.map → href-LHUCJ_IZ.js.map} +1 -1
  504. package/dist/kolibri/i18n-B-iJAw_i.js +4 -0
  505. package/dist/kolibri/i18n-B-iJAw_i.js.map +1 -0
  506. package/dist/kolibri/i18n-CQxlBXNV.js +4 -0
  507. package/dist/kolibri/{i18n-BzQ08vD6.js.map → i18n-CQxlBXNV.js.map} +1 -1
  508. package/dist/kolibri/{icons-B5i9zwjJ.js → icons-CmMX8bbY.js} +1 -1
  509. package/dist/kolibri/{icons-B5i9zwjJ.js.map → icons-CmMX8bbY.js.map} +1 -1
  510. package/dist/kolibri/image-source-DqpWx57w.js +4 -0
  511. package/dist/kolibri/{image-source-BfBEJ0rX.js.map → image-source-DqpWx57w.js.map} +1 -1
  512. package/dist/kolibri/{index-BtD7uFmA.js → index-iB2O5Z2w.js} +2 -2
  513. package/dist/{esm/index-BtD7uFmA.js.map → kolibri/index-iB2O5Z2w.js.map} +1 -1
  514. package/dist/kolibri/index.esm.js +1 -1
  515. package/dist/kolibri/inline-CeKQgcde.js +4 -0
  516. package/dist/kolibri/inline-CeKQgcde.js.map +1 -0
  517. package/dist/kolibri/kol-abbr.entry.js +1 -1
  518. package/dist/kolibri/kol-accordion.entry.js +1 -1
  519. package/dist/kolibri/kol-alert-wc.entry.js +1 -1
  520. package/dist/kolibri/kol-alert.entry.js +1 -1
  521. package/dist/kolibri/kol-avatar-wc.entry.js +1 -1
  522. package/dist/kolibri/kol-avatar.entry.js +1 -1
  523. package/dist/kolibri/kol-badge.entry.esm.js.map +1 -1
  524. package/dist/kolibri/kol-badge.entry.js +1 -1
  525. package/dist/kolibri/kol-badge.entry.js.map +1 -1
  526. package/dist/kolibri/kol-breadcrumb.entry.esm.js.map +1 -1
  527. package/dist/kolibri/kol-breadcrumb.entry.js +1 -1
  528. package/dist/kolibri/kol-breadcrumb.entry.js.map +1 -1
  529. package/dist/kolibri/kol-button-link.entry.esm.js.map +1 -1
  530. package/dist/kolibri/kol-button-link.entry.js +1 -1
  531. package/dist/kolibri/kol-button-link.entry.js.map +1 -1
  532. package/dist/kolibri/kol-button-wc.entry.esm.js.map +1 -1
  533. package/dist/kolibri/kol-button-wc.entry.js +1 -1
  534. package/dist/kolibri/kol-button-wc.entry.js.map +1 -1
  535. package/dist/kolibri/kol-button.entry.esm.js.map +1 -1
  536. package/dist/kolibri/kol-button.entry.js +1 -1
  537. package/dist/kolibri/kol-button.entry.js.map +1 -1
  538. package/dist/kolibri/kol-card-wc.entry.js +1 -1
  539. package/dist/kolibri/kol-card.entry.js +1 -1
  540. package/dist/kolibri/kol-combobox.entry.esm.js.map +1 -1
  541. package/dist/kolibri/kol-combobox.entry.js +1 -1
  542. package/dist/kolibri/kol-combobox.entry.js.map +1 -1
  543. package/dist/kolibri/kol-details.entry.js +1 -1
  544. package/dist/kolibri/kol-drawer.entry.js +1 -1
  545. package/dist/kolibri/kol-form.entry.js +1 -1
  546. package/dist/kolibri/kol-heading.entry.js +1 -1
  547. package/dist/kolibri/kol-icon.entry.js +1 -1
  548. package/dist/kolibri/kol-image.entry.js +1 -1
  549. package/dist/kolibri/kol-input-checkbox.entry.esm.js.map +1 -1
  550. package/dist/kolibri/kol-input-checkbox.entry.js +1 -1
  551. package/dist/kolibri/kol-input-checkbox.entry.js.map +1 -1
  552. package/dist/kolibri/kol-input-color.entry.esm.js.map +1 -1
  553. package/dist/kolibri/kol-input-color.entry.js +1 -1
  554. package/dist/kolibri/kol-input-color.entry.js.map +1 -1
  555. package/dist/kolibri/kol-input-date.entry.esm.js.map +1 -1
  556. package/dist/kolibri/kol-input-date.entry.js +1 -1
  557. package/dist/kolibri/kol-input-date.entry.js.map +1 -1
  558. package/dist/kolibri/kol-input-email.entry.esm.js.map +1 -1
  559. package/dist/kolibri/kol-input-email.entry.js +1 -1
  560. package/dist/kolibri/kol-input-email.entry.js.map +1 -1
  561. package/dist/kolibri/kol-input-file.entry.esm.js.map +1 -1
  562. package/dist/kolibri/kol-input-file.entry.js +1 -1
  563. package/dist/kolibri/kol-input-file.entry.js.map +1 -1
  564. package/dist/kolibri/kol-input-number.entry.esm.js.map +1 -1
  565. package/dist/kolibri/kol-input-number.entry.js +1 -1
  566. package/dist/kolibri/kol-input-number.entry.js.map +1 -1
  567. package/dist/kolibri/kol-input-password.entry.esm.js.map +1 -1
  568. package/dist/kolibri/kol-input-password.entry.js +1 -1
  569. package/dist/kolibri/kol-input-password.entry.js.map +1 -1
  570. package/dist/kolibri/kol-input-radio.entry.esm.js.map +1 -1
  571. package/dist/kolibri/kol-input-radio.entry.js +1 -1
  572. package/dist/kolibri/kol-input-radio.entry.js.map +1 -1
  573. package/dist/kolibri/kol-input-range.entry.esm.js.map +1 -1
  574. package/dist/kolibri/kol-input-range.entry.js +1 -1
  575. package/dist/kolibri/kol-input-range.entry.js.map +1 -1
  576. package/dist/kolibri/kol-input-text.entry.esm.js.map +1 -1
  577. package/dist/kolibri/kol-input-text.entry.js +1 -1
  578. package/dist/kolibri/kol-input-text.entry.js.map +1 -1
  579. package/dist/kolibri/kol-kolibri.entry.js +1 -1
  580. package/dist/kolibri/kol-link-button.entry.esm.js.map +1 -1
  581. package/dist/kolibri/kol-link-button.entry.js +1 -1
  582. package/dist/kolibri/kol-link-button.entry.js.map +1 -1
  583. package/dist/kolibri/kol-link-wc.entry.esm.js.map +1 -1
  584. package/dist/kolibri/kol-link-wc.entry.js +1 -1
  585. package/dist/kolibri/kol-link-wc.entry.js.map +1 -1
  586. package/dist/kolibri/kol-link.entry.esm.js.map +1 -1
  587. package/dist/kolibri/kol-link.entry.js +1 -1
  588. package/dist/kolibri/kol-link.entry.js.map +1 -1
  589. package/dist/kolibri/kol-modal.entry.js +1 -1
  590. package/dist/kolibri/kol-nav.entry.esm.js.map +1 -1
  591. package/dist/kolibri/kol-nav.entry.js +1 -1
  592. package/dist/kolibri/kol-nav.entry.js.map +1 -1
  593. package/dist/kolibri/kol-pagination-wc.entry.js +1 -1
  594. package/dist/kolibri/kol-pagination.entry.js +1 -1
  595. package/dist/kolibri/kol-popover-button-wc.entry.esm.js.map +1 -1
  596. package/dist/kolibri/kol-popover-button-wc.entry.js +1 -1
  597. package/dist/kolibri/kol-popover-button-wc.entry.js.map +1 -1
  598. package/dist/kolibri/kol-popover-button.entry.esm.js.map +1 -1
  599. package/dist/kolibri/kol-popover-button.entry.js +1 -1
  600. package/dist/kolibri/kol-popover-button.entry.js.map +1 -1
  601. package/dist/kolibri/kol-popover-wc.entry.js +1 -1
  602. package/dist/kolibri/kol-progress.entry.js +1 -1
  603. package/dist/kolibri/kol-quote.entry.js +1 -1
  604. package/dist/kolibri/kol-select.entry.esm.js.map +1 -1
  605. package/dist/kolibri/kol-select.entry.js +1 -1
  606. package/dist/kolibri/kol-select.entry.js.map +1 -1
  607. package/dist/kolibri/kol-single-select.entry.esm.js.map +1 -1
  608. package/dist/kolibri/kol-single-select.entry.js +1 -1
  609. package/dist/kolibri/kol-single-select.entry.js.map +1 -1
  610. package/dist/kolibri/kol-skip-nav.entry.js +1 -1
  611. package/dist/kolibri/kol-spin.entry.js +1 -1
  612. package/dist/kolibri/kol-split-button.entry.js +1 -1
  613. package/dist/kolibri/kol-table-settings-wc.entry.js +1 -1
  614. package/dist/kolibri/kol-table-stateful.entry.esm.js.map +1 -1
  615. package/dist/kolibri/kol-table-stateful.entry.js +1 -1
  616. package/dist/kolibri/kol-table-stateful.entry.js.map +1 -1
  617. package/dist/kolibri/kol-table-stateless-wc.entry.esm.js.map +1 -1
  618. package/dist/kolibri/kol-table-stateless-wc.entry.js +1 -1
  619. package/dist/kolibri/kol-table-stateless-wc.entry.js.map +1 -1
  620. package/dist/kolibri/kol-table-stateless.entry.esm.js.map +1 -1
  621. package/dist/kolibri/kol-table-stateless.entry.js +1 -1
  622. package/dist/kolibri/kol-table-stateless.entry.js.map +1 -1
  623. package/dist/kolibri/kol-tabs.entry.js +1 -1
  624. package/dist/kolibri/kol-textarea.entry.esm.js.map +1 -1
  625. package/dist/kolibri/kol-textarea.entry.js +1 -1
  626. package/dist/kolibri/kol-textarea.entry.js.map +1 -1
  627. package/dist/kolibri/kol-toast-container.entry.js +1 -1
  628. package/dist/kolibri/kol-toolbar.entry.esm.js.map +1 -1
  629. package/dist/kolibri/kol-toolbar.entry.js +1 -1
  630. package/dist/kolibri/kol-toolbar.entry.js.map +1 -1
  631. package/dist/kolibri/kol-tooltip-wc.entry.js +1 -1
  632. package/dist/kolibri/kol-tree-item-wc.entry.js +1 -1
  633. package/dist/kolibri/kol-tree-item.entry.js +1 -1
  634. package/dist/kolibri/kol-tree-wc.entry.js +1 -1
  635. package/dist/kolibri/kol-tree.entry.js +1 -1
  636. package/dist/kolibri/kol-version.entry.js +1 -1
  637. package/dist/kolibri/kolibri.esm.js +1 -1
  638. package/dist/kolibri/{label-Dnmzb2S_.js → label-ohY9ajP0.js} +1 -1
  639. package/dist/{esm/label-Dnmzb2S_.js.map → kolibri/label-ohY9ajP0.js.map} +1 -1
  640. package/dist/kolibri/{markdown-BSkXjaSn.js → markdown-CVks1MC0.js} +1 -1
  641. package/dist/kolibri/{markdown-BSkXjaSn.js.map → markdown-CVks1MC0.js.map} +1 -1
  642. package/dist/kolibri/{max-length-behavior-nTw1Zuyf.js → max-length-behavior-N5Lbz6E-.js} +1 -1
  643. package/dist/kolibri/{max-length-behavior-nTw1Zuyf.js.map → max-length-behavior-N5Lbz6E-.js.map} +1 -1
  644. package/dist/kolibri/multiple-D1puaB9F.js +4 -0
  645. package/dist/kolibri/{multiple-Cj3JQafH.js.map → multiple-D1puaB9F.js.map} +1 -1
  646. package/dist/kolibri/open-BFQWty8w.js +4 -0
  647. package/dist/kolibri/{open-CbvHO4XG.js.map → open-BFQWty8w.js.map} +1 -1
  648. package/dist/kolibri/{orientation-eCMt8CD1.js → orientation-B0ErOlUK.js} +1 -1
  649. package/dist/kolibri/{orientation-eCMt8CD1.js.map → orientation-B0ErOlUK.js.map} +1 -1
  650. package/dist/kolibri/placeholder-DrgXYoah.js +4 -0
  651. package/dist/kolibri/{placeholder-BVhy3BzI.js.map → placeholder-DrgXYoah.js.map} +1 -1
  652. package/dist/kolibri/read-only-Bp291veM.js +4 -0
  653. package/dist/kolibri/{read-only-BetTuumR.js.map → read-only-Bp291veM.js.map} +1 -1
  654. package/dist/kolibri/required-7L0ytoMT.js +4 -0
  655. package/dist/kolibri/{required-CnTTpFCN.js.map → required-7L0ytoMT.js.map} +1 -1
  656. package/dist/kolibri/rows-C8piLIWD.js +4 -0
  657. package/dist/kolibri/{rows-DtS-0sp9.js.map → rows-C8piLIWD.js.map} +1 -1
  658. package/dist/kolibri/show-ChfALFZd.js +4 -0
  659. package/dist/{esm/show-DdPK3aM7.js.map → kolibri/show-ChfALFZd.js.map} +1 -1
  660. package/dist/kolibri/spell-check-DrU5XI1o.js +4 -0
  661. package/dist/kolibri/{spell-check-B9ot-4t-.js.map → spell-check-DrU5XI1o.js.map} +1 -1
  662. package/dist/kolibri/{suggestions-B-jLvT4L.js → suggestions-Bufr76At.js} +1 -1
  663. package/dist/kolibri/{suggestions-B-jLvT4L.js.map → suggestions-Bufr76At.js.map} +1 -1
  664. package/dist/kolibri/{table-settings-DxLvhwRE.js → table-settings-BYcS3vAt.js} +1 -1
  665. package/dist/kolibri/{table-settings-DxLvhwRE.js.map → table-settings-BYcS3vAt.js.map} +1 -1
  666. package/dist/kolibri/test-component.entry.js +1 -1
  667. package/dist/kolibri/tooltip-align-DEw_M6Is.js +4 -0
  668. package/dist/kolibri/{tooltip-align-Cnin7S26.js.map → tooltip-align-DEw_M6Is.js.map} +1 -1
  669. package/dist/kolibri/{unique-nav-labels-CrfmPC99.js → unique-nav-labels-C-bt2E8D.js} +1 -1
  670. package/dist/kolibri/{unique-nav-labels-CrfmPC99.js.map → unique-nav-labels-C-bt2E8D.js.map} +1 -1
  671. package/dist/kolibri/validation-BVeaxeev.js +4 -0
  672. package/dist/kolibri/{validation-aqgnZOL6.js.map → validation-BVeaxeev.js.map} +1 -1
  673. package/dist/kolibri/{validation-BfjI5un_.js → validation-BmqW5reG.js} +1 -1
  674. package/dist/kolibri/{validation-BfjI5un_.js.map → validation-BmqW5reG.js.map} +1 -1
  675. package/dist/types/components/button/component.d.ts +3 -3
  676. package/dist/types/components/button/shadow.d.ts +2 -1
  677. package/dist/types/components/button-link/shadow.d.ts +2 -2
  678. package/dist/types/components/input-number/shadow.d.ts +2 -0
  679. package/dist/types/components/link/component.d.ts +3 -3
  680. package/dist/types/components/link/shadow.d.ts +2 -2
  681. package/dist/types/components/nav/shadow.d.ts +0 -3
  682. package/dist/types/components/popover-button/component.d.ts +3 -1
  683. package/dist/types/components/popover-button/shadow.d.ts +2 -1
  684. package/dist/types/components/table-stateful/shadow.d.ts +1 -0
  685. package/dist/types/components/table-stateless/component.d.ts +3 -0
  686. package/dist/types/components.d.ts +74 -44
  687. package/dist/types/functional-component-wrappers/_helpers/getRenderStates.d.ts +1 -0
  688. package/dist/types/functional-components/CustomSuggestionsOption/CustomSuggestionsOption.d.ts +1 -0
  689. package/dist/types/functional-components/FormField/FormField.d.ts +3 -4
  690. package/dist/types/functional-components/FormFieldCounter/FormFieldCounter.d.ts +2 -1
  691. package/dist/types/locales/de.d.ts +1 -0
  692. package/dist/types/locales/en.d.ts +1 -0
  693. package/dist/types/schema/components/button-link.d.ts +2 -2
  694. package/dist/types/schema/components/button.d.ts +3 -4
  695. package/dist/types/schema/components/link-button.d.ts +2 -2
  696. package/dist/types/schema/components/link.d.ts +2 -3
  697. package/dist/types/schema/components/nav.d.ts +2 -3
  698. package/dist/types/schema/components/popover-button.d.ts +3 -3
  699. package/dist/types/schema/props/index.d.ts +1 -1
  700. package/dist/types/schema/props/inline.d.ts +7 -0
  701. package/dist/types/schema/types/table.d.ts +1 -0
  702. package/doc/badge.md +6 -6
  703. package/doc/button-link.md +1 -1
  704. package/doc/button.md +1 -0
  705. package/doc/input-color.md +20 -20
  706. package/doc/input-date.md +26 -26
  707. package/doc/input-email.md +28 -28
  708. package/doc/input-file.md +20 -20
  709. package/doc/input-number.md +26 -26
  710. package/doc/input-password.md +27 -27
  711. package/doc/input-text.md +29 -29
  712. package/doc/link.md +1 -1
  713. package/doc/nav.md +8 -9
  714. package/doc/popover-button.md +1 -0
  715. package/loader/index.d.ts +1 -1
  716. package/loader/index.mjs +1 -1
  717. package/package.json +1 -1
  718. package/vscode-custom-data.json +21 -37
  719. package/dist/cjs/CustomSuggestionsOptionsGroup-U0UUhJm1.js +0 -4
  720. package/dist/cjs/CustomSuggestionsOptionsGroup-U0UUhJm1.js.map +0 -1
  721. package/dist/cjs/FormFieldStateWrapper-C1LUOq8e.js +0 -4
  722. package/dist/cjs/FormFieldStateWrapper-C1LUOq8e.js.map +0 -1
  723. package/dist/cjs/Input-C0zMg2l7.js +0 -4
  724. package/dist/cjs/controller-icon-lIch0k1l.js +0 -4
  725. package/dist/cjs/controller-icon-lIch0k1l.js.map +0 -1
  726. package/dist/cjs/i18n-Ch_xy25P.js +0 -4
  727. package/dist/cjs/i18n-DwU4rpIc.js +0 -4
  728. package/dist/cjs/i18n-DwU4rpIc.js.map +0 -1
  729. package/dist/cjs/link-variant-gYtaoJ43.js.map +0 -1
  730. package/dist/components/link-variant.js +0 -4
  731. package/dist/components/link-variant.js.map +0 -1
  732. package/dist/esm/CustomSuggestionsOptionsGroup-F-K5k1eH.js +0 -4
  733. package/dist/esm/CustomSuggestionsOptionsGroup-F-K5k1eH.js.map +0 -1
  734. package/dist/esm/FormFieldStateWrapper-DdxBfHk9.js +0 -4
  735. package/dist/esm/FormFieldStateWrapper-DdxBfHk9.js.map +0 -1
  736. package/dist/esm/Input-DCya5HSR.js +0 -4
  737. package/dist/esm/InternalUnderlinedBadgeText-Bs9VOx3f.js +0 -4
  738. package/dist/esm/controller-icon-C5Tj-Bw9.js +0 -4
  739. package/dist/esm/controller-icon-C5Tj-Bw9.js.map +0 -1
  740. package/dist/esm/disabled-BhpAFgSp.js +0 -4
  741. package/dist/esm/i18n-Bt8vh0qY.js +0 -4
  742. package/dist/esm/i18n-Bt8vh0qY.js.map +0 -1
  743. package/dist/esm/link-variant-DQEKOyAU.js +0 -4
  744. package/dist/esm/link-variant-DQEKOyAU.js.map +0 -1
  745. package/dist/esm/tooltip-align-Cnin7S26.js +0 -4
  746. package/dist/kolibri/Alert-83Gb4NJi.js +0 -4
  747. package/dist/kolibri/Collapsible-BWBRUxlQ.js +0 -4
  748. package/dist/kolibri/CustomSuggestionsOptionsGroup-F-K5k1eH.js +0 -4
  749. package/dist/kolibri/CustomSuggestionsOptionsGroup-F-K5k1eH.js.map +0 -1
  750. package/dist/kolibri/FieldControlStateWrapper-DHi-9Vch.js +0 -4
  751. package/dist/kolibri/FormFieldStateWrapper-DdxBfHk9.js +0 -4
  752. package/dist/kolibri/FormFieldStateWrapper-DdxBfHk9.js.map +0 -1
  753. package/dist/kolibri/Icon-BTCiUYU9.js +0 -4
  754. package/dist/kolibri/Input-DCya5HSR.js +0 -4
  755. package/dist/kolibri/InputStateWrapper-B6CEb3g-.js +0 -4
  756. package/dist/kolibri/InternalUnderlinedBadgeText-Bs9VOx3f.js +0 -4
  757. package/dist/kolibri/Span-KZITft3P.js +0 -4
  758. package/dist/kolibri/app-globals-BvgNyEID.js +0 -4
  759. package/dist/kolibri/bem-BBRwGb1a.js +0 -4
  760. package/dist/kolibri/controller-icon-C5Tj-Bw9.js +0 -4
  761. package/dist/kolibri/controller-icon-C5Tj-Bw9.js.map +0 -1
  762. package/dist/kolibri/controller-n_eFbbek.js +0 -4
  763. package/dist/kolibri/custom-class-nuoQ9Aml.js +0 -4
  764. package/dist/kolibri/disabled-BhpAFgSp.js +0 -4
  765. package/dist/kolibri/has-closer-CQzjaTkv.js +0 -4
  766. package/dist/kolibri/hide-label-B9FhGrWP.js +0 -4
  767. package/dist/kolibri/href-rwDd36rS.js +0 -4
  768. package/dist/kolibri/i18n-Bt8vh0qY.js +0 -4
  769. package/dist/kolibri/i18n-Bt8vh0qY.js.map +0 -1
  770. package/dist/kolibri/i18n-BzQ08vD6.js +0 -4
  771. package/dist/kolibri/image-source-BfBEJ0rX.js +0 -4
  772. package/dist/kolibri/link-variant-DQEKOyAU.js +0 -4
  773. package/dist/kolibri/link-variant-DQEKOyAU.js.map +0 -1
  774. package/dist/kolibri/multiple-Cj3JQafH.js +0 -4
  775. package/dist/kolibri/open-CbvHO4XG.js +0 -4
  776. package/dist/kolibri/placeholder-BVhy3BzI.js +0 -4
  777. package/dist/kolibri/read-only-BetTuumR.js +0 -4
  778. package/dist/kolibri/required-CnTTpFCN.js +0 -4
  779. package/dist/kolibri/rows-DtS-0sp9.js +0 -4
  780. package/dist/kolibri/show-DdPK3aM7.js +0 -4
  781. package/dist/kolibri/spell-check-B9ot-4t-.js +0 -4
  782. package/dist/kolibri/tooltip-align-Cnin7S26.js +0 -4
  783. package/dist/kolibri/validation-aqgnZOL6.js +0 -4
  784. package/dist/types/schema/props/link-variant.d.ts +0 -8
@@ -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 clsx}from"./clsx.js";import{d as KolButtonWcTag,e as KolIconTag}from"./component-names.js";import{g as getRenderStates,F as FormFieldStateWrapper}from"./controller2.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{n as nonce}from"./dev.utils.js";import{c as watchBoolean,h as watchString}from"./common.js";import{v as validatePlaceholder}from"./placeholder.js";import{v as validateRequired}from"./required.js";import{v as validateSuggestions}from"./suggestions.js";class ComboboxController extends InputIconController{constructor(e,t,n){super(e,t,n),this.component=e}validateHideClearButton(e){watchBoolean(this.component,"_hideClearButton",e)}validatePlaceholder(e){validatePlaceholder(this.component,e)}validateRequired(e){validateRequired(this.component,e)}validateSuggestions(e){validateSuggestions(this.component,e)}validateValue(e){watchString(this.component,"_value",e)}componentWillLoad(){super.componentWillLoad(),this.validateHideClearButton(this.component._hideClearButton),this.validatePlaceholder(this.component._placeholder),this.validateRequired(this.component._required),this.validateSuggestions(this.component._suggestions),this.validateValue(this.component._value)}}const defaultStyleCss='/*\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}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n@layer kol-component {\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 {\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-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-custom-suggestions-toggle {\n display: flex;\n width: var(--a11y-min-size);\n 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--disabled .kol-form-field__label {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__label-text::after {\n content: "*"/"";\n }\n .kol-form-field--disabled .kol-form-field__hint {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__tooltip .span-label::after {\n content: "*"/"";\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;\n }\n .kol-input-container:has(> .kol-input-container__adornment--end) {\n grid-template-columns: 1fr auto;\n }\n .kol-input-container:has(> .kol-input-container__adornment--start):has(> .kol-input-container__adornment--end) {\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 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-combobox__delete .kol-button {\n cursor: pointer;\n }\n .kol-combobox__delete--disabled .kol-button {\n cursor: not-allowed;\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}',KolCombobox$1=proxyCustomElement(class extends HTMLElement{async getValue(){return this.state._value}async kolFocus(){var e;null===(e=this.refInput)||void 0===e||e.focus()}selectOption(e){var t;this.controller.onFacade.onInput(new CustomEvent("input",{bubbles:!0,detail:{name:this.state._name,value:e}}),!0,e),this.controller.onFacade.onChange(new CustomEvent("change",{bubbles:!0,detail:{name:this.state._name,value:e}}),e),this.controller.setFormAssociatedValue(e),this.state._value=e,null===(t=this.refInput)||void 0===t||t.focus()}clearSelection(){var e;if(!0===this.state._disabled)return;const t="";this._focusedOptionIndex=-1,this._value=t,this.state._value=t,this._filteredSuggestions=[...this.state._suggestions],this._isOpen=!1;const n={name:this.state._name,value:t};this.controller.onFacade.onInput(new CustomEvent("input",{bubbles:!0,detail:n}),!0,t),this.controller.onFacade.onChange(new CustomEvent("change",{bubbles:!0,detail:n}),t),this.controller.setFormAssociatedValue(t),null===(e=this.refInput)||void 0===e||e.focus()}onInput(e){const t=e.target;this.state._value=t.value,this._value=t.value,this.controller.onFacade.onInput(e),this.setFilteredSuggestionsByQuery(t.value),this._focusedOptionIndex=-1}handleKeyDownDropdown(e){1===e.key.length&&/[a-z0-9]/i.test(e.key)&&(this._isOpen=!0,this.focusSuggestionStartingWith(e.key))}setFilteredSuggestionsByQuery(e){""===e.trim()?this._filteredSuggestions=[...this.state._suggestions]:(this._filteredSuggestions=Array.isArray(this.state._suggestions)?this.state._suggestions.filter(t=>t.toLowerCase().includes(e.toLowerCase())):this._filteredSuggestions,this._isOpen=!!(this._filteredSuggestions&&this._filteredSuggestions.length>0))}moveFocus(e){if(!this._filteredSuggestions)return;let t=this._focusedOptionIndex+e;t>=this._filteredSuggestions.length&&(t=0),t<0&&(t=this._filteredSuggestions.length-1),this.focusOption(t)}focusOption(e){if(this._focusedOptionIndex=e,this.refSuggestions){const t=this.refSuggestions[e];null==t||t.focus()}}focusSuggestionStartingWith(e){const t=e.toLowerCase(),n=Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0&&this._filteredSuggestions.findIndex(e=>e.toLowerCase().startsWith(t));"number"==typeof n&&this.focusOption(n)}getFormFieldProps(){return{state:this.state,class:clsx("kol-combobox",{"has-value":this.state._hasValue}),tooltipAlign:this._tooltipAlign,alert:this.showAsAlert()}}getInputProps(){const{ariaDescribedBy:e}=getRenderStates(this.state),t=!0===this.state._disabled;return Object.assign(Object.assign({ref:this.catchRef,state:this.state,class:"kol-combobox__input",type:"text",role:"combobox","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-expanded":this._isOpen?"true":"false","aria-label":this.state._hideLabel&&"string"==typeof this.state._label?this.state._label:void 0,"aria-labelledby":this.state._id,"aria-keyshortcuts":this.state._shortKey,value:this.state._value,accessKey:this.state._accessKey,autocapitalize:"off",autocorrect:"off",disabled:t,customSuggestions:!0,id:this.state._id,name:this.state._name,required:this.state._required},this.controller.onFacade),{onFocus:e=>{this.controller.onFacade.onFocus(e),this.inputHasFocus=!0},onBlur:e=>{this.controller.onFacade.onBlur(e),this.inputHasFocus=!1},onChange:this.onChange.bind(this),onInput:this.onInput.bind(this),placeholder:this.state._placeholder})}render(){const e=!0===this.state._disabled;return h(FormFieldStateWrapper,Object.assign({key:"0d9f276131000a7a398df8167b7ab687bf191bf8"},this.getFormFieldProps()),h(InputContainerStateWrapperFc,{key:"4bf740e369911ad5af8dc96498a7f895d09e7d86",state:this.state},h("div",{key:"839fb3245b49c1fc922e61898f0e966b3f8946d7",class:"kol-combobox__group"},h(InputStateWrapper,Object.assign({key:"c51fa942fe784d4b409e40c07b9f62ba623e8220"},this.getInputProps())),this.state._value&&!this.state._hideClearButton&&h(KolButtonWcTag,{key:"7121cc55857a492973ab7ea3b6cb68654dc30fcc",_icons:"codicon codicon-close",_label:this.translateDeleteSelection,_hideLabel:!0,_disabled:e,"data-testid":"combobox-delete",class:clsx("kol-combobox__delete",{"kol-combobox__delete--disabled":e}),_on:{onClick:()=>{this.clearSelection()}}}),h(KolIconTag,{key:"6b4af46bfe72c9da959729263c8f0adae6c92f81",_icons:"codicon codicon-triangle-down",_label:"",class:clsx("kol-custom-suggestions-toggle",{"kol-custom-suggestions-toggle--disabled":e}),onClick:this.toggleListbox.bind(this)})),this._isOpen&&!e&&h(CustomSuggestionsOptionsGroupFc,{key:"ffbaa34f6801783d5255b82d6df3df643b53913f",blockSuggestionMouseOver:this.blockSuggestionMouseOver,onKeyDown:this.handleKeyDownDropdown.bind(this)},Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0&&this._filteredSuggestions.map((e,t)=>h(CustomSuggestionsOptionFc,{index:t,option:e,searchTerm:this.state._value,ref:e=>{e&&(this.refSuggestions[t]=e)},selected:this.state._value===e,onClick:()=>{this.selectOption(e),this.toggleListbox(),this._isOpen=!1},onMouseOver:()=>{this.blockSuggestionMouseOver||this.focusOption(t)},onFocus:()=>{this.focusOption(t)},onKeyDown:t=>{"Enter"!==t.key&&"NumpadEnter"!==t.key||(this.selectOption(e),this.toggleListbox(),t.preventDefault())}})))))}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=!1,null===(t=this.refInput)||void 0===t||t.focus());break;case"Esc":case"Escape":this._isOpen=!1,e.preventDefault(),null===(n=this.refInput)||void 0===n||n.focus();break;case"NumpadEnter":case"Enter":this._isOpen&&this._focusedOptionIndex>=0?(this._filteredSuggestions&&this.selectOption(this._filteredSuggestions[this._focusedOptionIndex]),this._isOpen=!1):this.toggleListbox(),e.preventDefault();break;case"Home":this.blockSuggestionMouseOver=!0,o(void 0,()=>{this._isOpen&&this.focusOption(0)});break;case"End":this.blockSuggestionMouseOver=!0,o(void 0,()=>{this._isOpen&&this.focusOption(this._filteredSuggestions?this._filteredSuggestions.length-1:0)});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))}}handleWindowClick(e){void 0===this.host||this.host.contains(e.target)||(this._isOpen=!1)}constructor(e){super(),!1!==e&&this.__registerHost(),this.__attachShadow(),this.refSuggestions=[],this._focusedOptionIndex=-1,this.translateDeleteSelection=translate("kol-delete-selection"),this.toggleListbox=()=>{var e;if(!0===this.state._disabled)this._isOpen=!1;else if(null===(e=this.refInput)||void 0===e||e.focus(),this._isOpen)this._isOpen=!1;else if(Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0){this._isOpen=!0;const e=this._filteredSuggestions.findIndex(e=>e===this.state._value);this._focusedOptionIndex=e>=0?e:-1,this.focusOption(this._focusedOptionIndex)}},this.catchRef=e=>{this.refInput=e},this.blockSuggestionMouseOver=!1,this._isOpen=!1,this._disabled=!1,this._hideMsg=!1,this._hideLabel=!1,this._hint="",this._hideClearButton=!1,this._required=!1,this._tooltipAlign="top",this._touched=!1,this.state={_hasValue:!1,_hideClearButton:!1,_hideMsg:!1,_id:`id-${nonce()}`,_label:"",_suggestions:[],_value:""},this.inputHasFocus=!1,this.controller=new ComboboxController(this,"combobox",this.host),this.onInput=this.onInput.bind(this)}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)}validateId(e){this.controller.validateId(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)}validateShortKey(e){this.controller.validateShortKey(e)}validateSuggestions(e){this.controller.validateSuggestions(e),this._filteredSuggestions=e}validateHideClearButton(e){this.controller.validateHideClearButton(e)}validateRequired(e){this.controller.validateRequired(e)}validateSyncValueBySelector(e){this.controller.validateSyncValueBySelector(e)}validateTouched(e){this.controller.validateTouched(e)}validateValue(e){this.controller.validateValue(e),this.controller.setFormAssociatedValue(e)}componentWillLoad(){this.refSuggestions=[],this._touched=!0===this._touched,this.controller.componentWillLoad(),this.state._hasValue=!!this.state._value,this.controller.addValueChangeListener(e=>this.state._hasValue=!!e),this._filteredSuggestions=this.state._suggestions}handleMouseEvent(){this.blockSuggestionMouseOver=!1}handleFocusOut(){setTimeout(()=>{var e;(null===(e=this.host)||void 0===e?void 0:e.contains(document.activeElement))||this.onBlur()},0)}handleWindowBlur(){this.onBlur()}onBlur(){var e;this._isOpen&&(this._isOpen=!this._isOpen,null===(e=this.refInput)||void 0===e||e.focus())}onChange(e){this.controller.onFacade.onChange(e),this.controller.setFormAssociatedValue(this.state._value)}get host(){return this}static get watchers(){return{_placeholder:["validatePlaceholder"],_accessKey:["validateAccessKey"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_id:["validateId"],_label:["validateLabel"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_shortKey:["validateShortKey"],_suggestions:["validateSuggestions"],_hideClearButton:["validateHideClearButton"],_required:["validateRequired"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"]}}static get style(){return{default:defaultStyleCss}}},[289,"kol-combobox",{_accessKey:[1,"_access-key"],_placeholder:[1],_disabled:[4],_hideMsg:[4,"_hide-msg"],_hideLabel:[4,"_hide-label"],_hint:[1],_icons:[1],_id:[1],_label:[1],_msg:[1],_name:[1],_on:[16],_hideClearButton:[4,"_hide-clear-button"],_suggestions:[1],_required:[4],_shortKey:[1,"_short-key"],_syncValueBySelector:[1,"_sync-value-by-selector"],_tooltipAlign:[1,"_tooltip-align"],_touched:[1540],_value:[1537],blockSuggestionMouseOver:[32],_isOpen:[32],_filteredSuggestions:[32],state:[32],inputHasFocus:[32],getValue:[64],kolFocus:[64]},[[0,"keydown","handleKeyDown"],[8,"click","handleWindowClick"],[1,"mousemove","handleMouseEvent"],[8,"focusout","handleFocusOut"],[8,"blur","handleWindowBlur"]],{_placeholder:["validatePlaceholder"],_accessKey:["validateAccessKey"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_id:["validateId"],_label:["validateLabel"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_shortKey:["validateShortKey"],_suggestions:["validateSuggestions"],_hideClearButton:["validateHideClearButton"],_required:["validateRequired"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"]}]);function defineCustomElement$1(){if("undefined"==typeof customElements)return;["kol-combobox"].forEach(e=>{if("kol-combobox"===e)customElements.get(e)||customElements.define(e,KolCombobox$1)})}const KolCombobox=KolCombobox$1,defineCustomElement=defineCustomElement$1;export{KolCombobox,defineCustomElement};
4
+ import{proxyCustomElement,HTMLElement,h}from"@stencil/core/internal/client";import{c as clsx}from"./clsx.js";import{d as KolButtonWcTag,e as KolIconTag}from"./component-names.js";import{g as getRenderStates,F as FormFieldStateWrapper}from"./controller2.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{n as nonce}from"./dev.utils.js";import{c as watchBoolean,h as watchString}from"./common.js";import{v as validatePlaceholder}from"./placeholder.js";import{v as validateRequired}from"./required.js";import{v as validateSuggestions}from"./suggestions.js";class ComboboxController extends InputIconController{constructor(e,t,n){super(e,t,n),this.component=e}validateHideClearButton(e){watchBoolean(this.component,"_hideClearButton",e)}validatePlaceholder(e){validatePlaceholder(this.component,e)}validateRequired(e){validateRequired(this.component,e)}validateSuggestions(e){validateSuggestions(this.component,e)}validateValue(e){watchString(this.component,"_value",e)}componentWillLoad(){super.componentWillLoad(),this.validateHideClearButton(this.component._hideClearButton),this.validatePlaceholder(this.component._placeholder),this.validateRequired(this.component._required),this.validateSuggestions(this.component._suggestions),this.validateValue(this.component._value)}}const defaultStyleCss='/*\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}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n@layer kol-component {\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 {\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-custom-suggestions-toggle {\n display: flex;\n width: var(--a11y-min-size);\n 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--disabled .kol-form-field__label {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__label-text::after {\n content: "*"/"";\n }\n .kol-form-field--disabled .kol-form-field__hint {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__tooltip .span-label::after {\n content: "*"/"";\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:not(:empty)) {\n grid-template-columns: auto 1fr;\n }\n .kol-input-container:has(> .kol-input-container__adornment--end:not(:empty)) {\n grid-template-columns: 1fr auto;\n }\n .kol-input-container:has(> .kol-input-container__adornment--start:not(:empty)):has(> .kol-input-container__adornment--end:not(:empty)) {\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 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-combobox__delete .kol-button {\n cursor: pointer;\n }\n .kol-combobox__delete--disabled .kol-button {\n cursor: not-allowed;\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}',KolCombobox$1=proxyCustomElement(class extends HTMLElement{async getValue(){return this.state._value}async kolFocus(){var e;null===(e=this.refInput)||void 0===e||e.focus()}selectOption(e){var t;this.controller.onFacade.onInput(new CustomEvent("input",{bubbles:!0,detail:{name:this.state._name,value:e}}),!0,e),this.controller.onFacade.onChange(new CustomEvent("change",{bubbles:!0,detail:{name:this.state._name,value:e}}),e),this.controller.setFormAssociatedValue(e),this.state._value=e,null===(t=this.refInput)||void 0===t||t.focus()}clearSelection(){var e;if(!0===this.state._disabled)return;const t="";this._focusedOptionIndex=-1,this._value=t,this.state._value=t,this._filteredSuggestions=[...this.state._suggestions],this._isOpen=!1;const n={name:this.state._name,value:t};this.controller.onFacade.onInput(new CustomEvent("input",{bubbles:!0,detail:n}),!0,t),this.controller.onFacade.onChange(new CustomEvent("change",{bubbles:!0,detail:n}),t),this.controller.setFormAssociatedValue(t),null===(e=this.refInput)||void 0===e||e.focus()}onInput(e){const t=e.target;this.state._value=t.value,this._value=t.value,this.controller.onFacade.onInput(e),this.setFilteredSuggestionsByQuery(t.value),this._focusedOptionIndex=-1}handleKeyDownDropdown(e){1===e.key.length&&/[a-z0-9]/i.test(e.key)&&(this._isOpen=!0,this.focusSuggestionStartingWith(e.key))}setFilteredSuggestionsByQuery(e){""===e.trim()?this._filteredSuggestions=[...this.state._suggestions]:(this._filteredSuggestions=Array.isArray(this.state._suggestions)?this.state._suggestions.filter(t=>t.toLowerCase().includes(e.toLowerCase())):this._filteredSuggestions,this._isOpen=!!(this._filteredSuggestions&&this._filteredSuggestions.length>0))}moveFocus(e){if(!this._filteredSuggestions)return;let t=this._focusedOptionIndex+e;t>=this._filteredSuggestions.length&&(t=0),t<0&&(t=this._filteredSuggestions.length-1),this.focusOption(t)}focusOption(e){if(this._focusedOptionIndex=e,this.refSuggestions){const t=this.refSuggestions[e];null==t||t.focus()}}focusSuggestionStartingWith(e){const t=e.toLowerCase(),n=Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0&&this._filteredSuggestions.findIndex(e=>e.toLowerCase().startsWith(t));"number"==typeof n&&this.focusOption(n)}getFormFieldProps(){return{state:this.state,class:clsx("kol-combobox",{"has-value":this.state._hasValue}),tooltipAlign:this._tooltipAlign,alert:this.showAsAlert()}}getInputProps(){const{ariaDescribedBy:e}=getRenderStates(this.state),t=!0===this.state._disabled;return Object.assign(Object.assign({ref:this.catchRef,state:this.state,class:"kol-combobox__input",type:"text",role:"combobox","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-expanded":this._isOpen?"true":"false","aria-label":this.state._hideLabel&&"string"==typeof this.state._label?this.state._label:void 0,"aria-labelledby":this.state._id,"aria-keyshortcuts":this.state._shortKey,value:this.state._value,accessKey:this.state._accessKey,autocapitalize:"off",autocorrect:"off",disabled:t,customSuggestions:!0,id:this.state._id,name:this.state._name,required:this.state._required},this.controller.onFacade),{onFocus:e=>{this.controller.onFacade.onFocus(e),this.inputHasFocus=!0},onBlur:e=>{this.controller.onFacade.onBlur(e),this.inputHasFocus=!1},onChange:this.onChange.bind(this),onInput:this.onInput.bind(this),placeholder:this.state._placeholder})}render(){const e=!0===this.state._disabled;return h(FormFieldStateWrapper,Object.assign({key:"0d9f276131000a7a398df8167b7ab687bf191bf8"},this.getFormFieldProps()),h(InputContainerStateWrapperFc,{key:"4bf740e369911ad5af8dc96498a7f895d09e7d86",state:this.state},h("div",{key:"839fb3245b49c1fc922e61898f0e966b3f8946d7",class:"kol-combobox__group"},h(InputStateWrapper,Object.assign({key:"c51fa942fe784d4b409e40c07b9f62ba623e8220"},this.getInputProps())),this.state._value&&!this.state._hideClearButton&&h(KolButtonWcTag,{key:"7121cc55857a492973ab7ea3b6cb68654dc30fcc",_icons:"codicon codicon-close",_label:this.translateDeleteSelection,_hideLabel:!0,_disabled:e,"data-testid":"combobox-delete",class:clsx("kol-combobox__delete",{"kol-combobox__delete--disabled":e}),_on:{onClick:()=>{this.clearSelection()}}}),h(KolIconTag,{key:"6b4af46bfe72c9da959729263c8f0adae6c92f81",_icons:"codicon codicon-triangle-down",_label:"",class:clsx("kol-custom-suggestions-toggle",{"kol-custom-suggestions-toggle--disabled":e}),onClick:this.toggleListbox.bind(this)})),this._isOpen&&!e&&h(CustomSuggestionsOptionsGroupFc,{key:"ffbaa34f6801783d5255b82d6df3df643b53913f",blockSuggestionMouseOver:this.blockSuggestionMouseOver,onKeyDown:this.handleKeyDownDropdown.bind(this)},Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0&&this._filteredSuggestions.map((e,t)=>h(CustomSuggestionsOptionFc,{disabled:!1,index:t,option:e,searchTerm:this.state._value,ref:e=>{e&&(this.refSuggestions[t]=e)},selected:this.state._value===e,onClick:()=>{this.selectOption(e),this.toggleListbox(),this._isOpen=!1},onMouseOver:()=>{this.blockSuggestionMouseOver||this.focusOption(t)},onFocus:()=>{this.focusOption(t)},onKeyDown:t=>{"Enter"!==t.key&&"NumpadEnter"!==t.key||(this.selectOption(e),this.toggleListbox(),t.preventDefault())}})))))}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=!1,null===(t=this.refInput)||void 0===t||t.focus());break;case"Esc":case"Escape":this._isOpen=!1,e.preventDefault(),null===(n=this.refInput)||void 0===n||n.focus();break;case"NumpadEnter":case"Enter":this._isOpen&&this._focusedOptionIndex>=0?(this._filteredSuggestions&&this.selectOption(this._filteredSuggestions[this._focusedOptionIndex]),this._isOpen=!1):this.toggleListbox(),e.preventDefault();break;case"Home":this.blockSuggestionMouseOver=!0,o(void 0,()=>{this._isOpen&&this.focusOption(0)});break;case"End":this.blockSuggestionMouseOver=!0,o(void 0,()=>{this._isOpen&&this.focusOption(this._filteredSuggestions?this._filteredSuggestions.length-1:0)});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))}}handleWindowClick(e){void 0===this.host||this.host.contains(e.target)||(this._isOpen=!1)}constructor(e){super(),!1!==e&&this.__registerHost(),this.__attachShadow(),this.refSuggestions=[],this._focusedOptionIndex=-1,this.translateDeleteSelection=translate("kol-delete-selection"),this.toggleListbox=()=>{var e;if(!0===this.state._disabled)this._isOpen=!1;else if(null===(e=this.refInput)||void 0===e||e.focus(),this._isOpen)this._isOpen=!1;else if(Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0){this._isOpen=!0;const e=this._filteredSuggestions.findIndex(e=>e===this.state._value);this._focusedOptionIndex=e>=0?e:-1,this.focusOption(this._focusedOptionIndex)}},this.catchRef=e=>{this.refInput=e},this.blockSuggestionMouseOver=!1,this._isOpen=!1,this._disabled=!1,this._hideMsg=!1,this._hideLabel=!1,this._hint="",this._hideClearButton=!1,this._required=!1,this._tooltipAlign="top",this._touched=!1,this.state={_hasValue:!1,_hideClearButton:!1,_hideMsg:!1,_id:`id-${nonce()}`,_label:"",_suggestions:[],_value:""},this.inputHasFocus=!1,this.controller=new ComboboxController(this,"combobox",this.host),this.onInput=this.onInput.bind(this)}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)}validateId(e){this.controller.validateId(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)}validateShortKey(e){this.controller.validateShortKey(e)}validateSuggestions(e){this.controller.validateSuggestions(e),this._filteredSuggestions=e}validateHideClearButton(e){this.controller.validateHideClearButton(e)}validateRequired(e){this.controller.validateRequired(e)}validateSyncValueBySelector(e){this.controller.validateSyncValueBySelector(e)}validateTouched(e){this.controller.validateTouched(e)}validateValue(e){this.controller.validateValue(e),this.controller.setFormAssociatedValue(e)}componentWillLoad(){this.refSuggestions=[],this._touched=!0===this._touched,this.controller.componentWillLoad(),this.state._hasValue=!!this.state._value,this.controller.addValueChangeListener(e=>this.state._hasValue=!!e),this._filteredSuggestions=this.state._suggestions}handleMouseEvent(){this.blockSuggestionMouseOver=!1}handleFocusOut(){setTimeout(()=>{var e;(null===(e=this.host)||void 0===e?void 0:e.contains(document.activeElement))||this.onBlur()},0)}handleWindowBlur(){this.onBlur()}onBlur(){var e;this._isOpen&&(this._isOpen=!this._isOpen,null===(e=this.refInput)||void 0===e||e.focus())}onChange(e){this.controller.onFacade.onChange(e),this.controller.setFormAssociatedValue(this.state._value)}get host(){return this}static get watchers(){return{_placeholder:["validatePlaceholder"],_accessKey:["validateAccessKey"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_id:["validateId"],_label:["validateLabel"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_shortKey:["validateShortKey"],_suggestions:["validateSuggestions"],_hideClearButton:["validateHideClearButton"],_required:["validateRequired"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"]}}static get style(){return{default:defaultStyleCss}}},[289,"kol-combobox",{_accessKey:[1,"_access-key"],_placeholder:[1],_disabled:[4],_hideMsg:[4,"_hide-msg"],_hideLabel:[4,"_hide-label"],_hint:[1],_icons:[1],_id:[1],_label:[1],_msg:[1],_name:[1],_on:[16],_hideClearButton:[4,"_hide-clear-button"],_suggestions:[1],_required:[4],_shortKey:[1,"_short-key"],_syncValueBySelector:[1,"_sync-value-by-selector"],_tooltipAlign:[1,"_tooltip-align"],_touched:[1540],_value:[1537],blockSuggestionMouseOver:[32],_isOpen:[32],_filteredSuggestions:[32],state:[32],inputHasFocus:[32],getValue:[64],kolFocus:[64]},[[0,"keydown","handleKeyDown"],[8,"click","handleWindowClick"],[1,"mousemove","handleMouseEvent"],[8,"focusout","handleFocusOut"],[8,"blur","handleWindowBlur"]],{_placeholder:["validatePlaceholder"],_accessKey:["validateAccessKey"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_id:["validateId"],_label:["validateLabel"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_shortKey:["validateShortKey"],_suggestions:["validateSuggestions"],_hideClearButton:["validateHideClearButton"],_required:["validateRequired"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"]}]);function defineCustomElement$1(){if("undefined"==typeof customElements)return;["kol-combobox"].forEach(e=>{if("kol-combobox"===e)customElements.get(e)||customElements.define(e,KolCombobox$1)})}const KolCombobox=KolCombobox$1,defineCustomElement=defineCustomElement$1;export{KolCombobox,defineCustomElement};
@@ -1 +1 @@
1
- {"file":"kol-combobox.js","mappings":";;;;;;;;;;;;;;;;;AAOM,MAAO,kBAAmB,SAAQ,mBAAmB,CAAA;AAG1D,IAAA,WAAA,CAAmB,SAAoD,EAAE,IAAY,EAAE,IAAkB,EAAA;AACxG,QAAA,KAAK,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC;AAC5B,QAAA,IAAI,CAAC,SAAS,GAAG,SAAS;;AAGpB,IAAA,uBAAuB,CAAC,KAAe,EAAA;QAC7C,YAAY,CAAC,IAAI,CAAC,SAAS,EAAE,kBAAkB,EAAE,KAAK,CAAC;;AAGjD,IAAA,mBAAmB,CAAC,KAA2B,EAAA;AACrD,QAAA,mBAAmB,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC;;AAGpC,IAAA,gBAAgB,CAAC,KAAwB,EAAA;AAC/C,QAAA,gBAAgB,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC;;AAGjC,IAAA,mBAAmB,CAAC,KAA2B,EAAA;AACrD,QAAA,mBAAmB,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC;;AAGpC,IAAA,aAAa,CAAC,KAAc,EAAA;QAClC,WAAW,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,EAAE,KAAK,CAAC;;IAGtC,iBAAiB,GAAA;QACvB,KAAK,CAAC,iBAAiB,EAAE;QACzB,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC;QAC7D,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;QACrD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;QAC/C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;QACrD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;;AAE1C;;AC3CD,MAAM,eAAe,GAAG,i9TAAi9T;;MCgD59TA,aAAW,GAAAC,kBAAA,CAAA,MAAA,WAAA,SAAA,WAAA,CAAA;AAYhB,IAAA,MAAM,QAAQ,GAAA;AACpB,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM;;AAQlB,IAAA,MAAM,QAAQ,GAAA;;QACpB,CAAA,EAAA,GAAA,IAAI,CAAC,QAAQ,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,EAAE;;AAyBf,IAAA,YAAY,CAAC,MAAc,EAAA;;AAClC,QAAA,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO,CAC/B,IAAI,WAAW,CAAc,OAAO,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,KAAe,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,EACrH,IAAI,EACJ,MAAM,CACN;AACD,QAAA,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,QAAQ,CAChC,IAAI,WAAW,CAAc,QAAQ,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,KAAe,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,EACtH,MAAM,CACN;AACD,QAAA,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,MAAM,CAAC;AAC9C,QAAA,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM;QAC1B,CAAA,EAAA,GAAA,IAAI,CAAC,QAAQ,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,EAAE;;IAGf,cAAc,GAAA;;QACrB,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,KAAK,IAAI;QAChD,IAAI,UAAU,EAAE;YACf;;QAGD,MAAM,UAAU,GAAG,EAAE;AACrB,QAAA,IAAI,CAAC,mBAAmB,GAAG,EAAE;AAC7B,QAAA,IAAI,CAAC,MAAM,GAAG,UAAU;AACxB,QAAA,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,UAAU;QAC9B,IAAI,CAAC,oBAAoB,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC;AACxD,QAAA,IAAI,CAAC,OAAO,GAAG,KAAK;AAEpB,QAAA,MAAM,MAAM,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,KAAe,EAAE,KAAK,EAAE,UAAU,EAAE;QACtE,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,WAAW,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,CAAC;QACvG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,WAAW,CAAC,QAAQ,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,UAAU,CAAC;AACnG,QAAA,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,UAAU,CAAC;QAElD,CAAA,EAAA,GAAA,IAAI,CAAC,QAAQ,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,EAAE;;AAGf,IAAA,OAAO,CAAC,KAAY,EAAA;AAC3B,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,MAA0B;QAC/C,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,KAAK;AAChC,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,KAAK;QAC1B,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC;AACvC,QAAA,IAAI,CAAC,6BAA6B,CAAC,MAAM,CAAC,KAAK,CAAC;AAChD,QAAA,IAAI,CAAC,mBAAmB,GAAG,EAAE;;AAGtB,IAAA,qBAAqB,CAAC,KAAoB,EAAA;AACjD,QAAA,IAAI,KAAK,CAAC,GAAG,CAAC,MAAM,KAAK,CAAC,IAAI,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;AAC1D,YAAA,IAAI,CAAC,OAAO,GAAG,IAAI;AACnB,YAAA,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,GAAG,CAAC;;;AAIrC,IAAA,6BAA6B,CAAC,KAAa,EAAA;AAClD,QAAA,IAAI,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YACxB,IAAI,CAAC,oBAAoB,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC;;aAClD;AACN,YAAA,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY;AAChE,kBAAE,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,MAAqB,KAAI;AACzD,oBAAA,OAAQ,MAAiB,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;AACtE,iBAAC;AACF,kBAAE,IAAI,CAAC,oBAAoB;YAE5B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,oBAAoB,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,GAAG,KAAK;;;AAIzF,IAAA,SAAS,CAAC,KAAa,EAAA;AAC9B,QAAA,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE;YAC/B;;AAED,QAAA,IAAI,QAAQ,GAAG,IAAI,CAAC,mBAAmB,GAAG,KAAK;QAE/C,IAAI,QAAQ,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE;YACjD,QAAQ,GAAG,CAAC;;AAGb,QAAA,IAAI,QAAQ,GAAG,CAAC,EAAE;YACjB,QAAQ,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC;;AAEhD,QAAA,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC;;AAGnB,IAAA,WAAW,CAAC,KAAa,EAAA;AAChC,QAAA,IAAI,CAAC,mBAAmB,GAAG,KAAK;AAChC,QAAA,IAAI,IAAI,CAAC,cAAc,EAAE;YACxB,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;AAChD,YAAA,aAAa,aAAb,aAAa,KAAA,MAAA,GAAA,MAAA,GAAb,aAAa,CAAE,KAAK,EAAE;;;AAIhB,IAAA,2BAA2B,CAAC,IAAY,EAAA;AAC/C,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,WAAW,EAAE;QAExC,MAAM,KAAK,GACV,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC;AACxC,YAAA,IAAI,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC;YACpC,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,MAAqB,KAAM,MAAiB,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;AAE3H,QAAA,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;AAC9B,YAAA,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;;;IAIjB,iBAAiB,GAAA;QACxB,OAAO;YACN,KAAK,EAAE,IAAI,CAAC,KAAK;AACjB,YAAA,KAAK,EAAE,IAAI,CAAC,cAAc,EAAE;AAC3B,gBAAA,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS;aACjC,CAAC;YACF,YAAY,EAAE,IAAI,CAAC,aAAa;AAChC,YAAA,KAAK,EAAE,IAAI,CAAC,WAAW,EAAE;SACzB;;IAGM,aAAa,GAAA;QACpB,MAAM,EAAE,eAAe,EAAE,GAAG,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC;QACvD,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,KAAK,IAAI;QAEhD,OACC,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,GAAG,EAAE,IAAI,CAAC,QAAQ,EAClB,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,KAAK,EAAE,qBAAqB,EAC5B,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,UAAU,EAChB,uBAAuB,EAAE,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,mBAAmB,IAAI,CAAC,GAAG,CAAA,OAAA,EAAU,IAAI,CAAC,mBAAmB,CAAA,CAAE,GAAG,SAAS,EACzH,mBAAmB,EAAE,MAAM,EAC3B,eAAe,EAAE,SAAS,EAC1B,kBAAkB,EAAE,eAAe,CAAC,MAAM,GAAG,CAAC,GAAG,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,SAAS,EACtF,eAAe,EAAE,IAAI,CAAC,OAAO,GAAG,MAAM,GAAG,OAAO,EAChD,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,IAAI,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,EAC5G,iBAAiB,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,EACjC,mBAAmB,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,EACzC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,EACxB,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,EAChC,cAAc,EAAE,KAAK,EACrB,WAAW,EAAE,KAAK,EAClB,QAAQ,EAAE,UAAU,EACpB,iBAAiB,EAAE,IAAI,EACvB,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,EAClB,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,EACtB,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,EAAA,EAC3B,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAA,EAAA,EAC3B,OAAO,EAAE,CAAC,KAAK,KAAI;gBAClB,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC;AACvC,gBAAA,IAAI,CAAC,aAAa,GAAG,IAAI;AAC1B,aAAC,EACD,MAAM,EAAE,CAAC,KAAK,KAAI;gBACjB,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC;AACtC,gBAAA,IAAI,CAAC,aAAa,GAAG,KAAK;AAC3B,aAAC,EACD,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAClC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAChC,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY,EACnC,CAAA;;IAGI,MAAM,GAAA;QACZ,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,KAAK,IAAI;QAChD,QACC,CAAC,CAAAC,qBAA0B,qEAAK,IAAI,CAAC,iBAAiB,EAAE,CAAA,EACvD,CAAA,CAACC,4BAAmB,EAAC,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,IAAI,CAAC,KAAK,EAAA,EACrC,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,qBAAqB,EAAA,EAC/B,CAAA,CAACC,iBAAsB,EAAK,MAAA,CAAA,MAAA,CAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EAAA,IAAI,CAAC,aAAa,EAAE,CAAI,CAAA,EACnD,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,KACjD,EAAC,cAAc,EAAA,EAAA,GAAA,EAAA,0CAAA,EACd,MAAM,EAAC,uBAAuB,EAC9B,MAAM,EAAE,IAAI,CAAC,wBAAwB,EACrC,UAAU,QACV,SAAS,EAAE,UAAU,EAAA,aAAA,EACT,iBAAiB,EAC7B,KAAK,EAAE,IAAI,CAAC,sBAAsB,EAAE;AACnC,gBAAA,gCAAgC,EAAE,UAAU;aAC5C,CAAC,EACF,GAAG,EAAE;gBACJ,OAAO,EAAE,MAAK;oBACb,IAAI,CAAC,cAAc,EAAE;iBACrB;aACD,EAAA,CACA,CACF,EACD,CAAA,CAAC,UAAU,EAAA,EAAA,GAAA,EAAA,0CAAA,EACV,MAAM,EAAC,+BAA+B,EACtC,MAAM,EAAC,EAAE,EACT,KAAK,EAAE,IAAI,CAAC,+BAA+B,EAAE;AAC5C,gBAAA,yCAAyC,EAAE,UAAU;aACrD,CAAC,EACF,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAA,CACrC,CACG,EACL,IAAI,CAAC,OAAO,IAAI,CAAC,UAAU,KAC3B,CAAC,CAAA,+BAA+B,qDAAC,wBAAwB,EAAE,IAAI,CAAC,wBAAwB,EAAE,SAAS,EAAE,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,EACxI,EAAA,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC;AACxC,YAAA,IAAI,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC;AACpC,YAAA,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,MAC3C,CAAC,CAAA,yBAAyB,IACzB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,EAC7B,GAAG,EAAE,CAAC,EAAE,KAAI;AACX,oBAAA,IAAI,EAAE;AAAE,wBAAA,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG,EAAE;AACxC,iBAAC,EACD,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,MAAM,EACtC,OAAO,EAAE,MAAK;AACb,oBAAA,IAAI,CAAC,YAAY,CAAC,MAAgB,CAAC;oBACnC,IAAI,CAAC,aAAa,EAAE;AACpB,oBAAA,IAAI,CAAC,OAAO,GAAG,KAAK;AACrB,iBAAC,EACD,WAAW,EAAE,MAAK;AACjB,oBAAA,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE;AACnC,wBAAA,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;;AAEzB,iBAAC,EACD,OAAO,EAAE,MAAK;AACb,oBAAA,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;AACxB,iBAAC,EACD,SAAS,EAAE,CAAC,CAAC,KAAI;AAChB,oBAAA,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,aAAa,EAAE;AACjD,wBAAA,IAAI,CAAC,YAAY,CAAC,MAAgB,CAAC;wBACnC,IAAI,CAAC,aAAa,EAAE;wBACpB,CAAC,CAAC,cAAc,EAAE;;iBAEnB,EAAA,CACA,CACF,CAAC,CAC8B,CAClC,CACoB,CACM;;AAKxB,IAAA,aAAa,CAAC,KAAoB,EAAA;;AACxC,QAAA,MAAM,WAAW,GAAG,CAAC,MAAgB,EAAE,QAAqB,KAAU;;YACrE,KAAK,CAAC,cAAc,EAAE;AACtB,YAAA,IAAI,MAAM,KAAK,SAAS,EAAE;AACzB,gBAAA,IAAI,CAAC,OAAO,GAAG,MAAM;gBACrB,IAAI,CAAC,MAAM,EAAE;oBACZ,CAAA,EAAA,GAAA,IAAI,CAAC,QAAQ,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,EAAE;;;AAGxB,YAAA,QAAQ,KAAR,IAAA,IAAA,QAAQ,KAAR,MAAA,GAAA,MAAA,GAAA,QAAQ,EAAI;AACb,SAAC;AACD,QAAA,QAAQ,KAAK,CAAC,GAAG;AAChB,YAAA,KAAK,MAAM;YACX,KAAK,WAAW,EAAE;AACjB,gBAAA,IAAI,CAAC,wBAAwB,GAAG,IAAI;AACpC,gBAAA,WAAW,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBAC1C;;AAED,YAAA,KAAK,IAAI;YACT,KAAK,SAAS,EAAE;AACf,gBAAA,IAAI,CAAC,wBAAwB,GAAG,IAAI;AACpC,gBAAA,WAAW,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;gBAC3C;;AAED,YAAA,KAAK,KAAK;AACT,gBAAA,IAAI,IAAI,CAAC,OAAO,EAAE;AACjB,oBAAA,IAAI,CAAC,OAAO,GAAG,KAAK;oBACpB,CAAA,EAAA,GAAA,IAAI,CAAC,QAAQ,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,EAAE;;gBAEvB;AACD,YAAA,KAAK,KAAK;YACV,KAAK,QAAQ,EAAE;AACd,gBAAA,IAAI,CAAC,OAAO,GAAG,KAAK;gBACpB,KAAK,CAAC,cAAc,EAAE;gBACtB,CAAA,EAAA,GAAA,IAAI,CAAC,QAAQ,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,EAAE;gBACtB;;AAED,YAAA,KAAK,aAAa;YAClB,KAAK,OAAO,EAAE;gBACb,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,mBAAmB,IAAI,CAAC,EAAE;AAClD,oBAAA,IAAI,CAAC,oBAAoB,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,mBAAmB,CAAW,CAAC;AAC7G,oBAAA,IAAI,CAAC,OAAO,GAAG,KAAK;;qBACd;oBACN,IAAI,CAAC,aAAa,EAAE;;gBAErB,KAAK,CAAC,cAAc,EAAE;gBACtB;;YAED,KAAK,MAAM,EAAE;AACZ,gBAAA,IAAI,CAAC,wBAAwB,GAAG,IAAI;AACpC,gBAAA,WAAW,CAAC,SAAS,EAAE,MAAK;AAC3B,oBAAA,IAAI,IAAI,CAAC,OAAO,EAAE;AACjB,wBAAA,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;;AAErB,iBAAC,CAAC;gBACF;;YAED,KAAK,KAAK,EAAE;AACX,gBAAA,IAAI,CAAC,wBAAwB,GAAG,IAAI;AACpC,gBAAA,WAAW,CAAC,SAAS,EAAE,MAAK;AAC3B,oBAAA,IAAI,IAAI,CAAC,OAAO,EAAE;wBACjB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC;;AAExF,iBAAC,CAAC;gBACF;;YAED,KAAK,QAAQ,EAAE;AACd,gBAAA,IAAI,CAAC,wBAAwB,GAAG,IAAI;AACpC,gBAAA,WAAW,CAAC,SAAS,EAAE,MAAM,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;gBACjE;;YAED,KAAK,UAAU,EAAE;AAChB,gBAAA,IAAI,CAAC,wBAAwB,GAAG,IAAI;AACpC,gBAAA,WAAW,CAAC,SAAS,EAAE,MAAM,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;gBAChE;;;;AAcH,IAAA,iBAAiB,CAAC,KAAiB,EAAA;AAClC,QAAA,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAc,CAAC,EAAE;AACzE,YAAA,IAAI,CAAC,OAAO,GAAG,KAAK;;;AA2HtB,IAAA,WAAA,CAAA,YAAA,EAAA;;;;;;AAzeQ,QAAA,IAAc,CAAA,cAAA,GAAoB,EAAE;AACpC,QAAA,IAAmB,CAAA,mBAAA,GAAW,EAAE;AACvB,QAAA,IAAA,CAAA,wBAAwB,GAAG,SAAS,CAAC,sBAAsB,CAAC;AAoBrE,QAAA,IAAa,CAAA,aAAA,GAAG,MAAK;;YAC5B,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,KAAK,IAAI;YAChD,IAAI,UAAU,EAAE;AACf,gBAAA,IAAI,CAAC,OAAO,GAAG,KAAK;;iBACd;gBACN,CAAA,EAAA,GAAA,IAAI,CAAC,QAAQ,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,EAAE;AACtB,gBAAA,IAAI,IAAI,CAAC,OAAO,EAAE;AAEjB,oBAAA,IAAI,CAAC,OAAO,GAAG,KAAK;;AACd,qBAAA,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC,EAAE;AAE5F,oBAAA,IAAI,CAAC,OAAO,GAAG,IAAI;oBACnB,MAAM,aAAa,GAAG,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,MAAM,KAAK,MAAM,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;AACnG,oBAAA,IAAI,CAAC,mBAAmB,GAAG,aAAa,IAAI,CAAC,GAAG,aAAa,GAAG,EAAE;AAClE,oBAAA,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,mBAAmB,CAAC;;;AAG7C,SAAC;AACgB,QAAA,IAAA,CAAA,QAAQ,GAAG,CAAC,GAAsB,KAAI;AACtD,YAAA,IAAI,CAAC,QAAQ,GAAG,GAAG;AACpB,SAAC;AA2TO,QAAA,IAAwB,CAAA,wBAAA,GAAY,KAAK;AAEzC,QAAA,IAAO,CAAA,OAAA,GAAY,KAAK;AAwBjB,QAAA,IAAS,CAAA,SAAA,GAAa,KAAK;AAM3B,QAAA,IAAQ,CAAA,QAAA,GAAa,KAAK;AAO1B,QAAA,IAAU,CAAA,UAAA,GAAa,KAAK;AAK5B,QAAA,IAAK,CAAA,KAAA,GAAY,EAAE;AAoCnB,QAAA,IAAgB,CAAA,gBAAA,GAAa,KAAK;AAWlC,QAAA,IAAS,CAAA,SAAA,GAAa,KAAK;AAgB3B,QAAA,IAAa,CAAA,aAAA,GAA0B,KAAK;AAMZ,QAAA,IAAQ,CAAA,QAAA,GAAa,KAAK;QAOzD,IAAA,CAAA,KAAK,GAAmB;AACvC,YAAA,SAAS,EAAE,KAAK;AAChB,YAAA,gBAAgB,EAAE,KAAK;AACvB,YAAA,QAAQ,EAAE,KAAK;AACf,YAAA,GAAG,EAAE,CAAA,GAAA,EAAM,KAAK,EAAE,CAAE,CAAA;AACpB,YAAA,MAAM,EAAE,EAAE;AACV,YAAA,YAAY,EAAE,EAAE;AAChB,YAAA,MAAM,EAAE,EAAE;SACV;AAEgB,QAAA,IAAa,CAAA,aAAA,GAAG,KAAK;AAGrC,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,kBAAkB,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC;QACrE,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC;AACtC;IAEO,WAAW,GAAA;AAClB,QAAA,OAAO,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa;;AAIpD,IAAA,mBAAmB,CAAC,KAA2B,EAAA;AACrD,QAAA,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,KAAK,CAAC;;AAIpC,IAAA,iBAAiB,CAAC,KAAc,EAAA;AACtC,QAAA,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC;;AAIlC,IAAA,gBAAgB,CAAC,KAAwB,EAAA;AAC/C,QAAA,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,KAAK,CAAC;;AAIjC,IAAA,eAAe,CAAC,KAAuB,EAAA;AAC7C,QAAA,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,KAAK,CAAC;;AAIhC,IAAA,iBAAiB,CAAC,KAAyB,EAAA;AACjD,QAAA,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC;;AAIlC,IAAA,YAAY,CAAC,KAAoB,EAAA;AACvC,QAAA,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC;;AAI7B,IAAA,aAAa,CAAC,KAA+B,EAAA;AACnD,QAAA,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC;;AAI9B,IAAA,UAAU,CAAC,KAAc,EAAA;AAC/B,QAAA,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC;;AAI3B,IAAA,aAAa,CAAC,KAAmC,EAAA;AACvD,QAAA,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC;;AAI9B,IAAA,WAAW,CAAC,KAAgC,EAAA;AAClD,QAAA,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,KAAK,CAAC;;AAI5B,IAAA,YAAY,CAAC,KAAc,EAAA;AACjC,QAAA,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC;;AAI7B,IAAA,UAAU,CAAC,KAA0B,EAAA;AAC3C,QAAA,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC;;AAI3B,IAAA,gBAAgB,CAAC,KAAwB,EAAA;AAC/C,QAAA,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,KAAK,CAAC;;AAIjC,IAAA,mBAAmB,CAAC,KAA2B,EAAA;AACrD,QAAA,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,KAAK,CAAC;AAC1C,QAAA,IAAI,CAAC,oBAAoB,GAAG,KAAK;;AAI3B,IAAA,uBAAuB,CAAC,KAAe,EAAA;AAC7C,QAAA,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAAC,KAAK,CAAC;;AAIxC,IAAA,gBAAgB,CAAC,KAAwB,EAAA;AAC/C,QAAA,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,KAAK,CAAC;;AAIjC,IAAA,2BAA2B,CAAC,KAAmC,EAAA;AACrE,QAAA,IAAI,CAAC,UAAU,CAAC,2BAA2B,CAAC,KAAK,CAAC;;AAI5C,IAAA,eAAe,CAAC,KAAe,EAAA;AACrC,QAAA,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,KAAK,CAAC;;AAIhC,IAAA,aAAa,CAAC,KAAc,EAAA;AAClC,QAAA,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC;AACpC,QAAA,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,KAAK,CAAC;;IAGvC,iBAAiB,GAAA;AACvB,QAAA,IAAI,CAAC,cAAc,GAAG,EAAE;QACxB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,KAAK,IAAI;AACtC,QAAA,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE;AAEnC,QAAA,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM;QAC1C,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3E,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY;;IAI7C,gBAAgB,GAAA;AACtB,QAAA,IAAI,CAAC,wBAAwB,GAAG,KAAK;;IAI/B,cAAc,GAAA;QACpB,UAAU,CAAC,MAAK;;AACf,YAAA,IAAI,EAAC,CAAA,EAAA,GAAA,IAAI,CAAC,IAAI,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAA,EAAE;gBACjD,IAAI,CAAC,MAAM,EAAE;;SAEd,EAAE,CAAC,CAAC;;IAGC,gBAAgB,GAAA;QACtB,IAAI,CAAC,MAAM,EAAE;;IAGN,MAAM,GAAA;;AACb,QAAA,IAAI,IAAI,CAAC,OAAO,EAAE;AACjB,YAAA,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO;YAC5B,CAAA,EAAA,GAAA,IAAI,CAAC,QAAQ,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,EAAE;;;AAIhB,IAAA,QAAQ,CAAC,KAAY,EAAA;QAC5B,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC;QAGxC,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,IAAI,CAAC,KAAK,CAAC,MAA2B,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["KolCombobox","__stencil_proxyCustomElement","KolFormFieldStateWrapperFc","KolInputContainerFc","KolInputStateWrapperFc"],"sources":["src/components/combobox/controller.ts","src/components/combobox/style.scss?tag=kol-combobox&mode=default&encapsulation=shadow","src/components/combobox/shadow.tsx"],"sourcesContent":["import type { ComboboxProps, ComboboxWatches, PlaceholderPropType, RequiredPropType, SuggestionsPropType } from '../../schema';\nimport { validatePlaceholder, validateRequired, validateSuggestions, watchBoolean, watchString } from '../../schema';\n\nimport { InputIconController } from '../@deprecated/input/controller-icon';\n\nimport type { Generic } from 'adopted-style-sheets';\n\nexport class ComboboxController extends InputIconController implements ComboboxWatches {\n\tprotected readonly component: Generic.Element.Component & ComboboxProps;\n\n\tpublic constructor(component: Generic.Element.Component & ComboboxProps, name: string, host?: HTMLElement) {\n\t\tsuper(component, name, host);\n\t\tthis.component = component;\n\t}\n\n\tpublic validateHideClearButton(value?: boolean): void {\n\t\twatchBoolean(this.component, '_hideClearButton', value);\n\t}\n\n\tpublic validatePlaceholder(value?: PlaceholderPropType): void {\n\t\tvalidatePlaceholder(this.component, value);\n\t}\n\n\tpublic validateRequired(value?: RequiredPropType): void {\n\t\tvalidateRequired(this.component, value);\n\t}\n\n\tpublic validateSuggestions(value?: SuggestionsPropType): void {\n\t\tvalidateSuggestions(this.component, value);\n\t}\n\n\tpublic validateValue(value?: string): void {\n\t\twatchString(this.component, '_value', value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tsuper.componentWillLoad();\n\t\tthis.validateHideClearButton(this.component._hideClearButton);\n\t\tthis.validatePlaceholder(this.component._placeholder);\n\t\tthis.validateRequired(this.component._required);\n\t\tthis.validateSuggestions(this.component._suggestions);\n\t\tthis.validateValue(this.component._value);\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\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\n\t.kol-combobox {\n\t\t&__delete {\n\t\t\t.kol-button {\n\t\t\t\tcursor: pointer;\n\t\t\t}\n\n\t\t\t&--disabled {\n\t\t\t\t.kol-button {\n\t\t\t\t\tcursor: not-allowed;\n\t\t\t\t}\n\t\t\t}\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 clsx from 'clsx';\nimport { KolButtonWcTag, KolIconTag } 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 type {\n\tComboboxAPI,\n\tComboboxStates,\n\tDisabledPropType,\n\tHideLabelPropType,\n\tHideMsgPropType,\n\tHintPropType,\n\tIconsHorizontalPropType,\n\tIdPropType,\n\tInputTypeOnDefault,\n\tLabelWithExpertSlotPropType,\n\tMsgPropType,\n\tNamePropType,\n\tPlaceholderPropType,\n\tRequiredPropType,\n\tShortKeyPropType,\n\tStringified,\n\tSuggestionsPropType,\n\tSyncValueBySelectorPropType,\n\tTooltipAlignPropType,\n\tW3CInputValue,\n} from '../../schema';\nimport type { EventDetail } from '../../schema/interfaces/EventDetail';\nimport { nonce } from '../../utils/dev.utils';\nimport { ComboboxController } from './controller';\n\n/**\n * @slot - Die Beschriftung des Eingabefeldes.\n */\n@Component({\n\ttag: 'kol-combobox',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolCombobox implements ComboboxAPI {\n\t@Element() private readonly host?: HTMLKolComboboxElement;\n\tprivate refInput?: HTMLInputElement;\n\tprivate refSuggestions: HTMLLIElement[] = [];\n\tprivate _focusedOptionIndex: number = -1;\n\tprivate readonly translateDeleteSelection = translate('kol-delete-selection');\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<string> {\n\t\treturn this.state._value;\n\t}\n\n\t/**\n\t * Sets focus on the internal element.\n\t */\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tpublic async kolFocus() {\n\t\tthis.refInput?.focus();\n\t}\n\n\tprivate toggleListbox = () => {\n\t\tconst isDisabled = this.state._disabled === true;\n\t\tif (isDisabled) {\n\t\t\tthis._isOpen = false;\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 if (Array.isArray(this._filteredSuggestions) && this._filteredSuggestions.length > 0) {\n\t\t\t\t// Liste öffnen\n\t\t\t\tthis._isOpen = true;\n\t\t\t\tconst selectedIndex = this._filteredSuggestions.findIndex((option) => option === this.state._value);\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\tprivate readonly catchRef = (ref?: HTMLInputElement) => {\n\t\tthis.refInput = ref;\n\t};\n\n\tprivate selectOption(option: string) {\n\t\tthis.controller.onFacade.onInput(\n\t\t\tnew CustomEvent<EventDetail>('input', { bubbles: true, detail: { name: this.state._name as string, value: option } }),\n\t\t\ttrue,\n\t\t\toption,\n\t\t);\n\t\tthis.controller.onFacade.onChange(\n\t\t\tnew CustomEvent<EventDetail>('change', { bubbles: true, detail: { name: this.state._name as string, value: option } }),\n\t\t\toption,\n\t\t);\n\t\tthis.controller.setFormAssociatedValue(option);\n\t\tthis.state._value = option;\n\t\tthis.refInput?.focus();\n\t}\n\n\tprivate clearSelection() {\n\t\tconst isDisabled = this.state._disabled === true;\n\t\tif (isDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst emptyValue = '';\n\t\tthis._focusedOptionIndex = -1;\n\t\tthis._value = emptyValue;\n\t\tthis.state._value = emptyValue;\n\t\tthis._filteredSuggestions = [...this.state._suggestions];\n\t\tthis._isOpen = false;\n\n\t\tconst detail = { name: this.state._name as string, value: emptyValue };\n\t\tthis.controller.onFacade.onInput(new CustomEvent('input', { bubbles: true, detail }), true, emptyValue);\n\t\tthis.controller.onFacade.onChange(new CustomEvent('change', { bubbles: true, detail }), emptyValue);\n\t\tthis.controller.setFormAssociatedValue(emptyValue);\n\n\t\tthis.refInput?.focus();\n\t}\n\n\tprivate onInput(event: Event) {\n\t\tconst target = event.target as HTMLInputElement;\n\t\tthis.state._value = target.value;\n\t\tthis._value = target.value;\n\t\tthis.controller.onFacade.onInput(event);\n\t\tthis.setFilteredSuggestionsByQuery(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\tthis._isOpen = true;\n\t\t\tthis.focusSuggestionStartingWith(event.key);\n\t\t}\n\t}\n\n\tprivate setFilteredSuggestionsByQuery(query: string) {\n\t\tif (query.trim() === '') {\n\t\t\tthis._filteredSuggestions = [...this.state._suggestions];\n\t\t} else {\n\t\t\tthis._filteredSuggestions = Array.isArray(this.state._suggestions)\n\t\t\t\t? this.state._suggestions.filter((option: W3CInputValue) => {\n\t\t\t\t\t\treturn (option as string).toLowerCase().includes(query.toLowerCase());\n\t\t\t\t\t})\n\t\t\t\t: this._filteredSuggestions;\n\n\t\t\tthis._isOpen = this._filteredSuggestions && this._filteredSuggestions.length > 0 ? true : false;\n\t\t}\n\t}\n\n\tprivate moveFocus(delta: number) {\n\t\tif (!this._filteredSuggestions) {\n\t\t\treturn;\n\t\t}\n\t\tlet newIndex = this._focusedOptionIndex + delta;\n\n\t\tif (newIndex >= this._filteredSuggestions.length) {\n\t\t\tnewIndex = 0;\n\t\t}\n\n\t\tif (newIndex < 0) {\n\t\t\tnewIndex = this._filteredSuggestions.length - 1;\n\t\t}\n\t\tthis.focusOption(newIndex);\n\t}\n\n\tprivate focusOption(index: number) {\n\t\tthis._focusedOptionIndex = index;\n\t\tif (this.refSuggestions) {\n\t\t\tconst optionElement = this.refSuggestions[index];\n\t\t\toptionElement?.focus();\n\t\t}\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._filteredSuggestions) &&\n\t\t\tthis._filteredSuggestions.length > 0 &&\n\t\t\tthis._filteredSuggestions.findIndex((option: W3CInputValue) => (option as string).toLowerCase().startsWith(charLowerCase));\n\n\t\tif (typeof index === 'number') {\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: clsx('kol-combobox', {\n\t\t\t\t'has-value': this.state._hasValue,\n\t\t\t}),\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\tref: this.catchRef,\n\t\t\tstate: this.state,\n\t\t\tclass: 'kol-combobox__input',\n\t\t\ttype: 'text',\n\t\t\trole: 'combobox',\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-expanded': this._isOpen ? 'true' : 'false',\n\t\t\t'aria-label': this.state._hideLabel && typeof this.state._label === 'string' ? this.state._label : undefined,\n\t\t\t'aria-labelledby': this.state._id,\n\t\t\t'aria-keyshortcuts': this.state._shortKey,\n\t\t\tvalue: this.state._value,\n\t\t\taccessKey: this.state._accessKey,\n\t\t\tautocapitalize: 'off',\n\t\t\tautocorrect: 'off',\n\t\t\tdisabled: isDisabled,\n\t\t\tcustomSuggestions: true,\n\t\t\tid: this.state._id,\n\t\t\tname: this.state._name,\n\t\t\trequired: this.state._required,\n\t\t\t...this.controller.onFacade,\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\tonChange: this.onChange.bind(this),\n\t\t\tonInput: this.onInput.bind(this),\n\t\t\tplaceholder: this.state._placeholder,\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-combobox__group\">\n\t\t\t\t\t\t<KolInputStateWrapperFc {...this.getInputProps()} />\n\t\t\t\t\t\t{this.state._value && !this.state._hideClearButton && (\n\t\t\t\t\t\t\t<KolButtonWcTag\n\t\t\t\t\t\t\t\t_icons=\"codicon codicon-close\"\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_disabled={isDisabled}\n\t\t\t\t\t\t\t\tdata-testid=\"combobox-delete\"\n\t\t\t\t\t\t\t\tclass={clsx('kol-combobox__delete', {\n\t\t\t\t\t\t\t\t\t'kol-combobox__delete--disabled': isDisabled,\n\t\t\t\t\t\t\t\t})}\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},\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\t\t\t\t\t\t<KolIconTag\n\t\t\t\t\t\t\t_icons=\"codicon codicon-triangle-down\"\n\t\t\t\t\t\t\t_label=\"\"\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{this._isOpen && !isDisabled && (\n\t\t\t\t\t\t<CustomSuggestionsOptionsGroupFc blockSuggestionMouseOver={this.blockSuggestionMouseOver} onKeyDown={this.handleKeyDownDropdown.bind(this)}>\n\t\t\t\t\t\t\t{Array.isArray(this._filteredSuggestions) &&\n\t\t\t\t\t\t\t\tthis._filteredSuggestions.length > 0 &&\n\t\t\t\t\t\t\t\tthis._filteredSuggestions.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}\n\t\t\t\t\t\t\t\t\t\tsearchTerm={this.state._value}\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.refSuggestions[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.state._value === option}\n\t\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as string);\n\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox();\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.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\tthis.focusOption(index);\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 (e.key === 'Enter' || e.key === 'NumpadEnter') {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as string);\n\t\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox();\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</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('keydown')\n\tpublic handleKeyDown(event: KeyboardEvent) {\n\t\tconst handleEvent = (isOpen?: boolean, callback?: () => void): void => {\n\t\t\tevent.preventDefault();\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\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 = false;\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\tevent.preventDefault();\n\t\t\t\tthis.refInput?.focus();\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'NumpadEnter':\n\t\t\tcase 'Enter': {\n\t\t\t\tif (this._isOpen && this._focusedOptionIndex >= 0) {\n\t\t\t\t\tthis._filteredSuggestions && this.selectOption(this._filteredSuggestions[this._focusedOptionIndex] as string);\n\t\t\t\t\tthis._isOpen = false;\n\t\t\t\t} else {\n\t\t\t\t\tthis.toggleListbox();\n\t\t\t\t}\n\t\t\t\tevent.preventDefault();\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.focusOption(0);\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.focusOption(this._filteredSuggestions ? this._filteredSuggestions.length - 1 : 0);\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: ComboboxController;\n\t@State()\n\tprivate blockSuggestionMouseOver: boolean = false;\n\t@State()\n\tprivate _isOpen: boolean = false;\n\t@State()\n\tprivate _filteredSuggestions?: SuggestionsPropType;\n\n\t@Listen('click', { target: 'window' })\n\thandleWindowClick(event: MouseEvent) {\n\t\tif (this.host !== undefined && !this.host.contains(event.target as Node)) {\n\t\t\tthis._isOpen = false;\n\t\t}\n\t}\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 internal ID of the primary component element.\n\t * @deprecated Will be removed in the next major version.\n\t */\n\t@Prop() public _id?: IdPropType;\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 * Hides the clear button.\n\t */\n\t@Prop() public _hideClearButton?: boolean = false;\n\n\t/**\n\t * Suggestions to provide for the input.\n\t */\n\t@Prop() public _suggestions!: SuggestionsPropType;\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 input.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _value?: string;\n\n\t@State() public state: ComboboxStates = {\n\t\t_hasValue: false,\n\t\t_hideClearButton: false,\n\t\t_hideMsg: false,\n\t\t_id: `id-${nonce()}`,\n\t\t_label: '', // ⚠ required\n\t\t_suggestions: [],\n\t\t_value: '',\n\t};\n\n\t@State() private inputHasFocus = false;\n\n\tpublic constructor() {\n\t\tthis.controller = new ComboboxController(this, 'combobox', this.host);\n\t\tthis.onInput = this.onInput.bind(this);\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('_id')\n\tpublic validateId(value?: string): void {\n\t\tthis.controller.validateId(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('_shortKey')\n\tpublic validateShortKey(value?: ShortKeyPropType): void {\n\t\tthis.controller.validateShortKey(value);\n\t}\n\n\t@Watch('_suggestions')\n\tpublic validateSuggestions(value?: SuggestionsPropType): void {\n\t\tthis.controller.validateSuggestions(value);\n\t\tthis._filteredSuggestions = value;\n\t}\n\n\t@Watch('_hideClearButton')\n\tpublic validateHideClearButton(value?: boolean): void {\n\t\tthis.controller.validateHideClearButton(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('_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?: string): void {\n\t\tthis.controller.validateValue(value);\n\t\tthis.controller.setFormAssociatedValue(value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.refSuggestions = [];\n\t\tthis._touched = this._touched === true;\n\t\tthis.controller.componentWillLoad();\n\n\t\tthis.state._hasValue = !!this.state._value;\n\t\tthis.controller.addValueChangeListener((v) => (this.state._hasValue = !!v));\n\t\tthis._filteredSuggestions = this.state._suggestions;\n\t}\n\n\t@Listen('mousemove')\n\tpublic handleMouseEvent() {\n\t\tthis.blockSuggestionMouseOver = false;\n\t}\n\n\t@Listen('focusout', { target: 'window' })\n\tpublic handleFocusOut() {\n\t\tsetTimeout(() => {\n\t\t\tif (!this.host?.contains(document.activeElement)) {\n\t\t\t\tthis.onBlur();\n\t\t\t}\n\t\t}, 0);\n\t}\n\t@Listen('blur', { target: 'window' })\n\tpublic handleWindowBlur() {\n\t\tthis.onBlur();\n\t}\n\n\tprivate onBlur() {\n\t\tif (this._isOpen) {\n\t\t\tthis._isOpen = !this._isOpen;\n\t\t\tthis.refInput?.focus();\n\t\t}\n\t}\n\n\tprivate onChange(event: Event): void {\n\t\tthis.controller.onFacade.onChange(event);\n\n\t\t// Static form handling\n\t\tthis.controller.setFormAssociatedValue(this.state._value as unknown as string);\n\t}\n}\n"],"version":3}
1
+ {"file":"kol-combobox.js","mappings":"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","names":["KolCombobox","__stencil_proxyCustomElement","KolFormFieldStateWrapperFc","KolInputContainerFc","KolInputStateWrapperFc"],"sources":["src/components/combobox/controller.ts","src/components/combobox/style.scss?tag=kol-combobox&mode=default&encapsulation=shadow","src/components/combobox/shadow.tsx"],"sourcesContent":["import type { ComboboxProps, ComboboxWatches, PlaceholderPropType, RequiredPropType, SuggestionsPropType } from '../../schema';\nimport { validatePlaceholder, validateRequired, validateSuggestions, watchBoolean, watchString } from '../../schema';\n\nimport { InputIconController } from '../@deprecated/input/controller-icon';\n\nimport type { Generic } from 'adopted-style-sheets';\n\nexport class ComboboxController extends InputIconController implements ComboboxWatches {\n\tprotected readonly component: Generic.Element.Component & ComboboxProps;\n\n\tpublic constructor(component: Generic.Element.Component & ComboboxProps, name: string, host?: HTMLElement) {\n\t\tsuper(component, name, host);\n\t\tthis.component = component;\n\t}\n\n\tpublic validateHideClearButton(value?: boolean): void {\n\t\twatchBoolean(this.component, '_hideClearButton', value);\n\t}\n\n\tpublic validatePlaceholder(value?: PlaceholderPropType): void {\n\t\tvalidatePlaceholder(this.component, value);\n\t}\n\n\tpublic validateRequired(value?: RequiredPropType): void {\n\t\tvalidateRequired(this.component, value);\n\t}\n\n\tpublic validateSuggestions(value?: SuggestionsPropType): void {\n\t\tvalidateSuggestions(this.component, value);\n\t}\n\n\tpublic validateValue(value?: string): void {\n\t\twatchString(this.component, '_value', value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tsuper.componentWillLoad();\n\t\tthis.validateHideClearButton(this.component._hideClearButton);\n\t\tthis.validatePlaceholder(this.component._placeholder);\n\t\tthis.validateRequired(this.component._required);\n\t\tthis.validateSuggestions(this.component._suggestions);\n\t\tthis.validateValue(this.component._value);\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\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\n\t.kol-combobox {\n\t\t&__delete {\n\t\t\t.kol-button {\n\t\t\t\tcursor: pointer;\n\t\t\t}\n\n\t\t\t&--disabled {\n\t\t\t\t.kol-button {\n\t\t\t\t\tcursor: not-allowed;\n\t\t\t\t}\n\t\t\t}\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 clsx from 'clsx';\nimport { KolButtonWcTag, KolIconTag } 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 type {\n\tComboboxAPI,\n\tComboboxStates,\n\tDisabledPropType,\n\tHideLabelPropType,\n\tHideMsgPropType,\n\tHintPropType,\n\tIconsHorizontalPropType,\n\tIdPropType,\n\tInputTypeOnDefault,\n\tLabelWithExpertSlotPropType,\n\tMsgPropType,\n\tNamePropType,\n\tPlaceholderPropType,\n\tRequiredPropType,\n\tShortKeyPropType,\n\tStringified,\n\tSuggestionsPropType,\n\tSyncValueBySelectorPropType,\n\tTooltipAlignPropType,\n\tW3CInputValue,\n} from '../../schema';\nimport type { EventDetail } from '../../schema/interfaces/EventDetail';\nimport { nonce } from '../../utils/dev.utils';\nimport { ComboboxController } from './controller';\n\n/**\n * @slot - Die Beschriftung des Eingabefeldes.\n */\n@Component({\n\ttag: 'kol-combobox',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolCombobox implements ComboboxAPI {\n\t@Element() private readonly host?: HTMLKolComboboxElement;\n\tprivate refInput?: HTMLInputElement;\n\tprivate refSuggestions: HTMLLIElement[] = [];\n\tprivate _focusedOptionIndex: number = -1;\n\tprivate readonly translateDeleteSelection = translate('kol-delete-selection');\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<string> {\n\t\treturn this.state._value;\n\t}\n\n\t/**\n\t * Sets focus on the internal element.\n\t */\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tpublic async kolFocus() {\n\t\tthis.refInput?.focus();\n\t}\n\n\tprivate toggleListbox = () => {\n\t\tconst isDisabled = this.state._disabled === true;\n\t\tif (isDisabled) {\n\t\t\tthis._isOpen = false;\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 if (Array.isArray(this._filteredSuggestions) && this._filteredSuggestions.length > 0) {\n\t\t\t\t// Liste öffnen\n\t\t\t\tthis._isOpen = true;\n\t\t\t\tconst selectedIndex = this._filteredSuggestions.findIndex((option) => option === this.state._value);\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\tprivate readonly catchRef = (ref?: HTMLInputElement) => {\n\t\tthis.refInput = ref;\n\t};\n\n\tprivate selectOption(option: string) {\n\t\tthis.controller.onFacade.onInput(\n\t\t\tnew CustomEvent<EventDetail>('input', { bubbles: true, detail: { name: this.state._name as string, value: option } }),\n\t\t\ttrue,\n\t\t\toption,\n\t\t);\n\t\tthis.controller.onFacade.onChange(\n\t\t\tnew CustomEvent<EventDetail>('change', { bubbles: true, detail: { name: this.state._name as string, value: option } }),\n\t\t\toption,\n\t\t);\n\t\tthis.controller.setFormAssociatedValue(option);\n\t\tthis.state._value = option;\n\t\tthis.refInput?.focus();\n\t}\n\n\tprivate clearSelection() {\n\t\tconst isDisabled = this.state._disabled === true;\n\t\tif (isDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst emptyValue = '';\n\t\tthis._focusedOptionIndex = -1;\n\t\tthis._value = emptyValue;\n\t\tthis.state._value = emptyValue;\n\t\tthis._filteredSuggestions = [...this.state._suggestions];\n\t\tthis._isOpen = false;\n\n\t\tconst detail = { name: this.state._name as string, value: emptyValue };\n\t\tthis.controller.onFacade.onInput(new CustomEvent('input', { bubbles: true, detail }), true, emptyValue);\n\t\tthis.controller.onFacade.onChange(new CustomEvent('change', { bubbles: true, detail }), emptyValue);\n\t\tthis.controller.setFormAssociatedValue(emptyValue);\n\n\t\tthis.refInput?.focus();\n\t}\n\n\tprivate onInput(event: Event) {\n\t\tconst target = event.target as HTMLInputElement;\n\t\tthis.state._value = target.value;\n\t\tthis._value = target.value;\n\t\tthis.controller.onFacade.onInput(event);\n\t\tthis.setFilteredSuggestionsByQuery(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\tthis._isOpen = true;\n\t\t\tthis.focusSuggestionStartingWith(event.key);\n\t\t}\n\t}\n\n\tprivate setFilteredSuggestionsByQuery(query: string) {\n\t\tif (query.trim() === '') {\n\t\t\tthis._filteredSuggestions = [...this.state._suggestions];\n\t\t} else {\n\t\t\tthis._filteredSuggestions = Array.isArray(this.state._suggestions)\n\t\t\t\t? this.state._suggestions.filter((option: W3CInputValue) => {\n\t\t\t\t\t\treturn (option as string).toLowerCase().includes(query.toLowerCase());\n\t\t\t\t\t})\n\t\t\t\t: this._filteredSuggestions;\n\n\t\t\tthis._isOpen = this._filteredSuggestions && this._filteredSuggestions.length > 0 ? true : false;\n\t\t}\n\t}\n\n\tprivate moveFocus(delta: number) {\n\t\tif (!this._filteredSuggestions) {\n\t\t\treturn;\n\t\t}\n\t\tlet newIndex = this._focusedOptionIndex + delta;\n\n\t\tif (newIndex >= this._filteredSuggestions.length) {\n\t\t\tnewIndex = 0;\n\t\t}\n\n\t\tif (newIndex < 0) {\n\t\t\tnewIndex = this._filteredSuggestions.length - 1;\n\t\t}\n\t\tthis.focusOption(newIndex);\n\t}\n\n\tprivate focusOption(index: number) {\n\t\tthis._focusedOptionIndex = index;\n\t\tif (this.refSuggestions) {\n\t\t\tconst optionElement = this.refSuggestions[index];\n\t\t\toptionElement?.focus();\n\t\t}\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._filteredSuggestions) &&\n\t\t\tthis._filteredSuggestions.length > 0 &&\n\t\t\tthis._filteredSuggestions.findIndex((option: W3CInputValue) => (option as string).toLowerCase().startsWith(charLowerCase));\n\n\t\tif (typeof index === 'number') {\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: clsx('kol-combobox', {\n\t\t\t\t'has-value': this.state._hasValue,\n\t\t\t}),\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\tref: this.catchRef,\n\t\t\tstate: this.state,\n\t\t\tclass: 'kol-combobox__input',\n\t\t\ttype: 'text',\n\t\t\trole: 'combobox',\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-expanded': this._isOpen ? 'true' : 'false',\n\t\t\t'aria-label': this.state._hideLabel && typeof this.state._label === 'string' ? this.state._label : undefined,\n\t\t\t'aria-labelledby': this.state._id,\n\t\t\t'aria-keyshortcuts': this.state._shortKey,\n\t\t\tvalue: this.state._value,\n\t\t\taccessKey: this.state._accessKey,\n\t\t\tautocapitalize: 'off',\n\t\t\tautocorrect: 'off',\n\t\t\tdisabled: isDisabled,\n\t\t\tcustomSuggestions: true,\n\t\t\tid: this.state._id,\n\t\t\tname: this.state._name,\n\t\t\trequired: this.state._required,\n\t\t\t...this.controller.onFacade,\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\tonChange: this.onChange.bind(this),\n\t\t\tonInput: this.onInput.bind(this),\n\t\t\tplaceholder: this.state._placeholder,\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-combobox__group\">\n\t\t\t\t\t\t<KolInputStateWrapperFc {...this.getInputProps()} />\n\t\t\t\t\t\t{this.state._value && !this.state._hideClearButton && (\n\t\t\t\t\t\t\t<KolButtonWcTag\n\t\t\t\t\t\t\t\t_icons=\"codicon codicon-close\"\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_disabled={isDisabled}\n\t\t\t\t\t\t\t\tdata-testid=\"combobox-delete\"\n\t\t\t\t\t\t\t\tclass={clsx('kol-combobox__delete', {\n\t\t\t\t\t\t\t\t\t'kol-combobox__delete--disabled': isDisabled,\n\t\t\t\t\t\t\t\t})}\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},\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\t\t\t\t\t\t<KolIconTag\n\t\t\t\t\t\t\t_icons=\"codicon codicon-triangle-down\"\n\t\t\t\t\t\t\t_label=\"\"\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{this._isOpen && !isDisabled && (\n\t\t\t\t\t\t<CustomSuggestionsOptionsGroupFc blockSuggestionMouseOver={this.blockSuggestionMouseOver} onKeyDown={this.handleKeyDownDropdown.bind(this)}>\n\t\t\t\t\t\t\t{Array.isArray(this._filteredSuggestions) &&\n\t\t\t\t\t\t\t\tthis._filteredSuggestions.length > 0 &&\n\t\t\t\t\t\t\t\tthis._filteredSuggestions.map((option, index) => (\n\t\t\t\t\t\t\t\t\t<CustomSuggestionsOptionFc\n\t\t\t\t\t\t\t\t\t\tdisabled={false}\n\t\t\t\t\t\t\t\t\t\tindex={index}\n\t\t\t\t\t\t\t\t\t\toption={option}\n\t\t\t\t\t\t\t\t\t\tsearchTerm={this.state._value}\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.refSuggestions[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.state._value === option}\n\t\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as string);\n\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox();\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.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\tthis.focusOption(index);\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 (e.key === 'Enter' || e.key === 'NumpadEnter') {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as string);\n\t\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox();\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</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('keydown')\n\tpublic handleKeyDown(event: KeyboardEvent) {\n\t\tconst handleEvent = (isOpen?: boolean, callback?: () => void): void => {\n\t\t\tevent.preventDefault();\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\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 = false;\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\tevent.preventDefault();\n\t\t\t\tthis.refInput?.focus();\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'NumpadEnter':\n\t\t\tcase 'Enter': {\n\t\t\t\tif (this._isOpen && this._focusedOptionIndex >= 0) {\n\t\t\t\t\tthis._filteredSuggestions && this.selectOption(this._filteredSuggestions[this._focusedOptionIndex] as string);\n\t\t\t\t\tthis._isOpen = false;\n\t\t\t\t} else {\n\t\t\t\t\tthis.toggleListbox();\n\t\t\t\t}\n\t\t\t\tevent.preventDefault();\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.focusOption(0);\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.focusOption(this._filteredSuggestions ? this._filteredSuggestions.length - 1 : 0);\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: ComboboxController;\n\t@State()\n\tprivate blockSuggestionMouseOver: boolean = false;\n\t@State()\n\tprivate _isOpen: boolean = false;\n\t@State()\n\tprivate _filteredSuggestions?: SuggestionsPropType;\n\n\t@Listen('click', { target: 'window' })\n\thandleWindowClick(event: MouseEvent) {\n\t\tif (this.host !== undefined && !this.host.contains(event.target as Node)) {\n\t\t\tthis._isOpen = false;\n\t\t}\n\t}\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 internal ID of the primary component element.\n\t * @deprecated Will be removed in the next major version.\n\t */\n\t@Prop() public _id?: IdPropType;\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 * Hides the clear button.\n\t */\n\t@Prop() public _hideClearButton?: boolean = false;\n\n\t/**\n\t * Suggestions to provide for the input.\n\t */\n\t@Prop() public _suggestions!: SuggestionsPropType;\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 input.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _value?: string;\n\n\t@State() public state: ComboboxStates = {\n\t\t_hasValue: false,\n\t\t_hideClearButton: false,\n\t\t_hideMsg: false,\n\t\t_id: `id-${nonce()}`,\n\t\t_label: '', // ⚠ required\n\t\t_suggestions: [],\n\t\t_value: '',\n\t};\n\n\t@State() private inputHasFocus = false;\n\n\tpublic constructor() {\n\t\tthis.controller = new ComboboxController(this, 'combobox', this.host);\n\t\tthis.onInput = this.onInput.bind(this);\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('_id')\n\tpublic validateId(value?: string): void {\n\t\tthis.controller.validateId(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('_shortKey')\n\tpublic validateShortKey(value?: ShortKeyPropType): void {\n\t\tthis.controller.validateShortKey(value);\n\t}\n\n\t@Watch('_suggestions')\n\tpublic validateSuggestions(value?: SuggestionsPropType): void {\n\t\tthis.controller.validateSuggestions(value);\n\t\tthis._filteredSuggestions = value;\n\t}\n\n\t@Watch('_hideClearButton')\n\tpublic validateHideClearButton(value?: boolean): void {\n\t\tthis.controller.validateHideClearButton(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('_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?: string): void {\n\t\tthis.controller.validateValue(value);\n\t\tthis.controller.setFormAssociatedValue(value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.refSuggestions = [];\n\t\tthis._touched = this._touched === true;\n\t\tthis.controller.componentWillLoad();\n\n\t\tthis.state._hasValue = !!this.state._value;\n\t\tthis.controller.addValueChangeListener((v) => (this.state._hasValue = !!v));\n\t\tthis._filteredSuggestions = this.state._suggestions;\n\t}\n\n\t@Listen('mousemove')\n\tpublic handleMouseEvent() {\n\t\tthis.blockSuggestionMouseOver = false;\n\t}\n\n\t@Listen('focusout', { target: 'window' })\n\tpublic handleFocusOut() {\n\t\tsetTimeout(() => {\n\t\t\tif (!this.host?.contains(document.activeElement)) {\n\t\t\t\tthis.onBlur();\n\t\t\t}\n\t\t}, 0);\n\t}\n\t@Listen('blur', { target: 'window' })\n\tpublic handleWindowBlur() {\n\t\tthis.onBlur();\n\t}\n\n\tprivate onBlur() {\n\t\tif (this._isOpen) {\n\t\t\tthis._isOpen = !this._isOpen;\n\t\t\tthis.refInput?.focus();\n\t\t}\n\t}\n\n\tprivate onChange(event: Event): void {\n\t\tthis.controller.onFacade.onChange(event);\n\n\t\t// Static form handling\n\t\tthis.controller.setFormAssociatedValue(this.state._value as unknown as string);\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,HTMLElement}from"@stencil/core/internal/client";import{c as clsx}from"./clsx.js";import{n as nonce}from"./dev.utils.js";import{c as watchBoolean,w as watchValidator,j as isString,s as setState}from"./common.js";import{I as InputCheckboxRadioController}from"./controller3.js";import{_ as __rest}from"./tslib.es6.js";import{c as checkHasMsg,g as getRenderStates,F as FormFieldStateWrapper}from"./controller2.js";import{K as KolIconFc}from"./Icon.js";import{I as InputFc}from"./Input.js";import{F as FieldControlStateWrapper}from"./FieldControlStateWrapper.js";import{p as propagateSubmitEventToForm}from"./controller.js";const validateChecked=(e,t)=>{watchBoolean(e,"_checked",t)},validateIndeterminate=(e,t)=>{watchBoolean(e,"_indeterminate",t)},labelAlignPropTypeOptions=["left","right"],validateLabelAlign=(e,t)=>{watchValidator(e,"_labelAlign",e=>"string"==typeof e&&labelAlignPropTypeOptions.includes(e),new Set([`KoliBriLabelAlign {${labelAlignPropTypeOptions.join(", ")}`]),t)},inputCheckboxVariantOptions=["button","default","switch"],isInputCheckboxVariantPropType=e=>"string"==typeof e&&inputCheckboxVariantOptions.includes(e),validateVariantInputCheckbox=(e,t)=>{watchValidator(e,"_variant",isInputCheckboxVariantPropType,new Set(inputCheckboxVariantOptions),t)};class InputCheckboxController extends InputCheckboxRadioController{constructor(e,t,n){super(e,t,n),this.setFormAssociatedCheckboxValue=e=>{this.component._checked?this.setFormAssociatedValue(e):this.setFormAssociatedValue(null)},this.component=e}validateChecked(e){validateChecked(this.component,e),this.setFormAssociatedCheckboxValue(this.component.state._value)}validateIcons(e){watchValidator(this.component,"_icons",e=>{const t=e;return"object"==typeof t&&null!==t&&(isString(t.checked,1)||isString(t.indeterminate,1)||isString(t.unchecked,1))},new Set(["InputCheckboxIcons"]),e,{hooks:{beforePatch:(e,t,n)=>{t.set("_icons",Object.assign(Object.assign({},n.state._icons),e))}}})}validateIndeterminate(e){validateIndeterminate(this.component,e)}validateLabelAlign(e){validateLabelAlign(this.component,e)}validateValue(e){setState(this.component,"_value",e),this.setFormAssociatedCheckboxValue(this.component.state._value)}validateVariant(e){validateVariantInputCheckbox(this.component,e)}componentWillLoad(){super.componentWillLoad(),this.validateChecked(this.component._checked),this.validateIcons(this.component._icons),this.validateIndeterminate(this.component._indeterminate),this.validateValue(this.component._value),this.validateVariant(this.component._variant),this.validateLabelAlign(this.component._labelAlign)}}const IconWrapperFc=e=>{var{class:t}=e,n=__rest(e,["class"]);return h(KolIconFc,Object.assign({class:clsx("kol-checkbox__icon",t)},n))},InputWrapperFc=e=>{var{class:t}=e,n=__rest(e,["class"]);return h(InputFc,Object.assign({class:clsx("kol-checkbox__input",t)},n,{type:"checkbox"}))},CheckboxFc=e=>{var t,{class:n,variant:i="default",icon:o,inputProps:a}=e,l=__rest(e,["class","variant","icon","inputProps"]);const r=checkHasMsg(null==a?void 0:a.msg,null==a?void 0:a.touched),s="string"==typeof(null==a?void 0:a.msg)?"error":null===(t=null==a?void 0:a.msg)||void 0===t?void 0:t._type,c={[`kol-checkbox--variant-${i}`]:!0,"kol-checkbox--checked":null==a?void 0:a.checked,"kol-checkbox--indeterminate":null==a?void 0:a.indeterminate,"kol-checkbox--disabled":Boolean(null==a?void 0:a.disabled),"kol-checkbox--required":Boolean(null==a?void 0:a.required),"kol-checkbox--touched":Boolean(null==a?void 0:a.touched),[`kol-checkbox--${s||"error"}`]:Boolean(r)};return h("label",Object.assign({class:clsx("kol-checkbox",c,n)},l),h(IconWrapperFc,{label:"",icons:o}),h(InputWrapperFc,Object.assign({},a)))};function getCheckboxProps(e,t={}){const{ariaDescribedBy:n}=getRenderStates(e),i={id:e._id,hideLabel:e._hideLabel,label:e._label,value:e._value,accessKey:e._accessKey,disabled:e._disabled,name:e._name,ariaDescribedBy:n};return"_required"in e&&(i.required=e._required),"_checked"in e&&(i.checked=e._checked),"_indeterminate"in e&&(i.indeterminate=e._indeterminate),"_touched"in e&&(i.touched=e._touched),"_msg"in e&&(i.msg=e._msg),"_shortKey"in e&&(i["aria-keyshortcuts"]=e._shortKey),Object.assign(Object.assign({},i),t)}const CheckboxStateWrapper=e=>{var{state:t,inputProps:n}=e,i=__rest(e,["state","inputProps"]);const o=(null==t?void 0:t._variant)||"default";return h(CheckboxFc,Object.assign({variant:o,inputProps:getCheckboxProps(t,n)},i))},defaultStyleCss='/*\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}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n@layer kol-component {\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-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--disabled .kol-form-field__label {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__label-text::after {\n content: "*"/"";\n }\n .kol-form-field--disabled .kol-form-field__hint {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__tooltip .span-label::after {\n content: "*"/"";\n }\n .kol-field-control {\n display: grid;\n min-height: var(--a11y-min-size);\n align-items: center;\n justify-content: left;\n grid-template-areas: "input label";\n grid-template-columns: auto 1fr;\n grid-template-rows: auto;\n }\n .kol-field-control:has(.kol-field-control__hint) {\n grid-template-areas: "input label" "hint hint";\n grid-template-columns: auto 1fr;\n grid-template-rows: auto auto;\n }\n .kol-field-control--label-align-left:not(.kol-field-control--hide-label) {\n grid-template-areas: "label input";\n grid-template-columns: 1fr auto;\n grid-template-rows: auto;\n }\n .kol-field-control--label-align-left:not(.kol-field-control--hide-label):has(.kol-field-control__hint) {\n grid-template-areas: "label input" "hint hint";\n grid-template-columns: 1fr auto;\n grid-template-rows: auto auto;\n }\n .kol-field-control__input {\n display: flex;\n min-height: var(--a11y-min-size);\n align-items: center;\n grid-area: input;\n }\n .kol-field-control__label {\n display: flex;\n min-height: var(--a11y-min-size);\n flex-grow: 1;\n align-items: center;\n cursor: pointer;\n grid-area: label;\n }\n .kol-field-control__label--visually-hidden {\n height: 0;\n margin: 0;\n padding: 0;\n visibility: hidden;\n }\n .kol-field-control__label-text::after {\n content: "";\n }\n .kol-field-control__tooltip .span-label::after {\n content: "";\n }\n .kol-field-control__hint {\n grid-area: hint;\n }\n .kol-field-control--disabled .kol-field-control__label {\n opacity: 0.5;\n cursor: not-allowed;\n }\n .kol-field-control--required .kol-field-control__label-text::after {\n content: "*";\n }\n .kol-field-control--required .kol-field-control__tooltip .span-label::after {\n content: "*";\n }\n .kol-form-field {\n display: grid;\n }\n .kol-checkbox {\n display: flex;\n position: relative;\n align-items: center;\n cursor: pointer;\n }\n .kol-checkbox--disabled {\n cursor: not-allowed;\n }\n .kol-checkbox .kol-input {\n background-color: #fff;\n border-style: solid;\n margin: 0;\n border-width: 2px;\n appearance: none;\n cursor: inherit;\n }\n .kol-checkbox .kol-input:before {\n content: "";\n }\n /**\n * Variant: Checkbox\n */\n .kol-checkbox--variant-default {\n position: relative;\n width: var(--a11y-min-size);\n height: var(--a11y-min-size);\n justify-content: center;\n }\n .kol-checkbox--variant-default .kol-icon {\n display: flex;\n position: absolute;\n inset: auto;\n z-index: 1;\n pointer-events: none;\n }\n .kol-checkbox--variant-default .kol-icon::part(icon) {\n display: none;\n }\n .kol-checkbox--variant-default .kol-input {\n width: calc(22 * 1rem / var(--kolibri-root-font-size, 16));\n height: calc(22 * 1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-checkbox--variant-default.kol-checkbox--checked .kol-icon::part(icon), .kol-checkbox--variant-default.kol-checkbox--indeterminate .kol-icon::part(icon) {\n display: block;\n }\n /**\n * Variant: Switch\n */\n .kol-checkbox--variant-switch {\n position: relative;\n }\n .kol-checkbox--variant-switch .kol-input {\n display: inline-block;\n position: relative;\n width: 3.2em;\n min-width: 3.2em;\n height: 1.7em;\n }\n .kol-checkbox--variant-switch .kol-input::before {\n background-color: #000;\n position: absolute;\n top: calc(0.25em - 2 * 1rem / var(--kolibri-root-font-size, 16));\n left: calc(0.25em - 2 * 1rem / var(--kolibri-root-font-size, 16));\n width: 1.2em;\n height: 1.2em;\n transition: 0.5s;\n }\n .kol-checkbox--variant-switch .kol-input:checked::before {\n transform: translateX(1.5em);\n }\n .kol-checkbox--variant-switch .kol-input:indeterminate::before {\n transform: translateX(0.75em);\n }\n .kol-checkbox--variant-switch .kol-icon {\n transform: translate(0, -50%);\n color: #000;\n display: flex;\n position: absolute;\n top: 50%;\n left: calc(4 * 1rem / var(--kolibri-root-font-size, 16));\n z-index: 1;\n width: 1.2em;\n height: 1.2em;\n align-items: center;\n justify-content: center;\n transition: 0.5s;\n }\n .kol-checkbox--variant-switch.kol-checkbox--checked .kol-icon {\n transform: translate(1.5em, -50%);\n }\n .kol-checkbox--variant-switch.kol-checkbox--indeterminate .kol-icon {\n transform: translate(0.75em, -50%);\n }\n /**\n * Variant: Button\n */\n .kol-checkbox--variant-button {\n width: var(--a11y-min-size);\n }\n .kol-checkbox--variant-button .kol-icon {\n display: flex;\n width: var(--a11y-min-size);\n height: var(--a11y-min-size);\n align-items: center;\n justify-content: center;\n }\n}',KolInputCheckbox$1=proxyCustomElement(class extends HTMLElement{getModelValue(){return this._checked?this.state._value:null}async getValue(){return this.getModelValue()}async kolFocus(){var e;null===(e=this.inputRef)||void 0===e||e.focus()}getFormFieldProps(){return{state:this.state,class:clsx("kol-input-checkbox",{"kol-input-checkbox--checked":this.state._checked,"kol-input-checkbox--indeterminate":this.state._indeterminate,[`kol-input-checkbox--variant-${this.state._variant||"default"}`]:!0,[`kol-input-checkbox--label-align-${this.state._labelAlign||"right"}`]:!0}),tooltipAlign:this._tooltipAlign,"data-role":"button"===this.state._variant?"button":void 0,alert:this.showAsAlert(),renderNoTooltip:!0}}getFieldControlProps(){return{class:clsx("kol-input-checkbox__field-control",{"kol-input-checkbox__field-control--checked":this.state._checked,"kol-input-checkbox__field-control--indeterminate":this.state._indeterminate,[`kol-input-checkbox__field-control--variant-${this.state._variant||"default"}`]:!0}),state:this.state}}getInputProps(){return{state:this.state,icon:this.getIcon(),inputProps:Object.assign(Object.assign({class:clsx({"visually-hidden":"button"===this.state._variant}),ref:this.catchRef},this.controller.onFacade),{onInput:this.onInput,onChange:this.onChange,onKeyDown:this.onKeyDown.bind(this),onFocus:e=>{this.controller.onFacade.onFocus(e),this.inputHasFocus=!0},onBlur:e=>{this.controller.onFacade.onBlur(e),this.inputHasFocus=!1},onClick:void 0})}}getIcon(){return this.state._indeterminate?this.state._icons.indeterminate:this.state._checked?this.state._icons.checked:this.state._icons.unchecked}render(){return h(FormFieldStateWrapper,Object.assign({key:"447623044a8d0512702955f4711a4c1869f9e3c4"},this.getFormFieldProps(),{renderNoLabel:!0}),h(FieldControlStateWrapper,Object.assign({key:"a5301abd11f004163d8b870ecd99050d4b8b84bb"},this.getFieldControlProps(),{renderNoHint:!0}),h(CheckboxStateWrapper,Object.assign({key:"3df758d2985f455f7038b3423bd74f8a63642981"},this.getInputProps()))))}constructor(e){super(),!1!==e&&this.__registerHost(),this.__attachShadow(),this.catchRef=e=>{this.inputRef=e},this._checked=!1,this._hideMsg=!1,this._disabled=!1,this._hideLabel=!1,this._hint="",this._labelAlign="right",this._required=!1,this._tooltipAlign="top",this._touched=!1,this._value=!0,this._variant="default",this.state={_checked:!1,_hideMsg:!1,_icons:{checked:"codicon codicon-check",indeterminate:"codicon codicon-remove",unchecked:"codicon codicon-close"},_id:`id-${nonce()}`,_indeterminate:!1,_label:"",_value:!0,_variant:"default",_labelAlign:"right"},this.inputHasFocus=!1,this.onInput=e=>{this._checked=!this._checked,this._indeterminate=!1;const t=this.getModelValue();this.controller.onFacade.onInput(e,!1,t),this.controller.setFormAssociatedCheckboxValue(t)},this.onChange=e=>{this.controller.onFacade.onChange(e,this.getModelValue())},this.onKeyDown=e=>{this.controller.onFacade.onKeyDown(e),"Enter"!==e.code&&"NumpadEnter"!==e.code||propagateSubmitEventToForm({form:this.host})},this.controller=new InputCheckboxController(this,"checkbox",this.host)}showAsAlert(){return Boolean(this.state._touched)&&!this.inputHasFocus}validateAccessKey(e){this.controller.validateAccessKey(e)}validateChecked(e){this.controller.validateChecked(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)}validateId(e){this.controller.validateId(e)}validateIndeterminate(e){this.controller.validateIndeterminate(e)}validateLabel(e){this.controller.validateLabel(e)}validateLabelAlign(e){this.controller.validateLabelAlign(e)}validateMsg(e){this.controller.validateMsg(e)}validateName(e){this.controller.validateName(e)}validateOn(e){this.controller.validateOn(e)}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)}validateVariant(e){this.controller.validateVariant(e)}componentWillLoad(){this._touched=!0===this._touched,this.controller.componentWillLoad()}get host(){return this}static get watchers(){return{_accessKey:["validateAccessKey"],_checked:["validateChecked"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_id:["validateId"],_indeterminate:["validateIndeterminate"],_label:["validateLabel"],_labelAlign:["validateLabelAlign"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_required:["validateRequired"],_shortKey:["validateShortKey"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"],_variant:["validateVariant"]}}static get style(){return{default:defaultStyleCss}}},[289,"kol-input-checkbox",{_accessKey:[1,"_access-key"],_checked:[1540],_hideMsg:[4,"_hide-msg"],_disabled:[4],_hideLabel:[4,"_hide-label"],_hint:[1],_icons:[1],_id:[1],_indeterminate:[1540],_label:[1],_labelAlign:[1,"_label-align"],_msg:[1],_name:[1],_on:[16],_required:[4],_shortKey:[1,"_short-key"],_syncValueBySelector:[1,"_sync-value-by-selector"],_tooltipAlign:[1,"_tooltip-align"],_touched:[1540],_value:[8],_variant:[1],state:[32],inputHasFocus:[32],getValue:[64],kolFocus:[64]},void 0,{_accessKey:["validateAccessKey"],_checked:["validateChecked"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_id:["validateId"],_indeterminate:["validateIndeterminate"],_label:["validateLabel"],_labelAlign:["validateLabelAlign"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_required:["validateRequired"],_shortKey:["validateShortKey"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"],_variant:["validateVariant"]}]);function defineCustomElement$1(){if("undefined"==typeof customElements)return;["kol-input-checkbox"].forEach(e=>{if("kol-input-checkbox"===e)customElements.get(e)||customElements.define(e,KolInputCheckbox$1)})}const KolInputCheckbox=KolInputCheckbox$1,defineCustomElement=defineCustomElement$1;export{KolInputCheckbox,defineCustomElement};
4
+ import{h,proxyCustomElement,HTMLElement}from"@stencil/core/internal/client";import{c as clsx}from"./clsx.js";import{n as nonce}from"./dev.utils.js";import{c as watchBoolean,w as watchValidator,j as isString,s as setState}from"./common.js";import{I as InputCheckboxRadioController}from"./controller3.js";import{_ as __rest}from"./tslib.es6.js";import{c as checkHasMsg,g as getRenderStates,F as FormFieldStateWrapper}from"./controller2.js";import{K as KolIconFc}from"./Icon.js";import{I as InputFc}from"./Input.js";import{F as FieldControlStateWrapper}from"./FieldControlStateWrapper.js";import{p as propagateSubmitEventToForm}from"./controller.js";const validateChecked=(e,t)=>{watchBoolean(e,"_checked",t)},validateIndeterminate=(e,t)=>{watchBoolean(e,"_indeterminate",t)},labelAlignPropTypeOptions=["left","right"],validateLabelAlign=(e,t)=>{watchValidator(e,"_labelAlign",e=>"string"==typeof e&&labelAlignPropTypeOptions.includes(e),new Set([`KoliBriLabelAlign {${labelAlignPropTypeOptions.join(", ")}`]),t)},inputCheckboxVariantOptions=["button","default","switch"],isInputCheckboxVariantPropType=e=>"string"==typeof e&&inputCheckboxVariantOptions.includes(e),validateVariantInputCheckbox=(e,t)=>{watchValidator(e,"_variant",isInputCheckboxVariantPropType,new Set(inputCheckboxVariantOptions),t)};class InputCheckboxController extends InputCheckboxRadioController{constructor(e,t,n){super(e,t,n),this.setFormAssociatedCheckboxValue=e=>{this.component._checked?this.setFormAssociatedValue(e):this.setFormAssociatedValue(null)},this.component=e}validateChecked(e){validateChecked(this.component,e),this.setFormAssociatedCheckboxValue(this.component.state._value)}validateIcons(e){watchValidator(this.component,"_icons",e=>{const t=e;return"object"==typeof t&&null!==t&&(isString(t.checked,1)||isString(t.indeterminate,1)||isString(t.unchecked,1))},new Set(["InputCheckboxIcons"]),e,{hooks:{beforePatch:(e,t,n)=>{t.set("_icons",Object.assign(Object.assign({},n.state._icons),e))}}})}validateIndeterminate(e){validateIndeterminate(this.component,e)}validateLabelAlign(e){validateLabelAlign(this.component,e)}validateValue(e){setState(this.component,"_value",e),this.setFormAssociatedCheckboxValue(this.component.state._value)}validateVariant(e){validateVariantInputCheckbox(this.component,e)}componentWillLoad(){super.componentWillLoad(),this.validateChecked(this.component._checked),this.validateIcons(this.component._icons),this.validateIndeterminate(this.component._indeterminate),this.validateValue(this.component._value),this.validateVariant(this.component._variant),this.validateLabelAlign(this.component._labelAlign)}}const IconWrapperFc=e=>{var{class:t}=e,n=__rest(e,["class"]);return h(KolIconFc,Object.assign({class:clsx("kol-checkbox__icon",t)},n))},InputWrapperFc=e=>{var{class:t}=e,n=__rest(e,["class"]);return h(InputFc,Object.assign({class:clsx("kol-checkbox__input",t)},n,{type:"checkbox"}))},CheckboxFc=e=>{var t,{class:n,variant:i="default",icon:o,inputProps:a}=e,l=__rest(e,["class","variant","icon","inputProps"]);const r=checkHasMsg(null==a?void 0:a.msg,null==a?void 0:a.touched),s="string"==typeof(null==a?void 0:a.msg)?"error":null===(t=null==a?void 0:a.msg)||void 0===t?void 0:t._type,c={[`kol-checkbox--variant-${i}`]:!0,"kol-checkbox--checked":null==a?void 0:a.checked,"kol-checkbox--indeterminate":null==a?void 0:a.indeterminate,"kol-checkbox--disabled":Boolean(null==a?void 0:a.disabled),"kol-checkbox--required":Boolean(null==a?void 0:a.required),"kol-checkbox--touched":Boolean(null==a?void 0:a.touched),[`kol-checkbox--${s||"error"}`]:Boolean(r)};return h("label",Object.assign({class:clsx("kol-checkbox",c,n)},l),h(IconWrapperFc,{label:"",icons:o}),h(InputWrapperFc,Object.assign({},a)))};function getCheckboxProps(e,t={}){const{ariaDescribedBy:n}=getRenderStates(e),i={id:e._id,hideLabel:e._hideLabel,label:e._label,value:e._value,accessKey:e._accessKey,disabled:e._disabled,name:e._name,ariaDescribedBy:n};return"_required"in e&&(i.required=e._required),"_checked"in e&&(i.checked=e._checked),"_indeterminate"in e&&(i.indeterminate=e._indeterminate),"_touched"in e&&(i.touched=e._touched),"_msg"in e&&(i.msg=e._msg),"_shortKey"in e&&(i["aria-keyshortcuts"]=e._shortKey),Object.assign(Object.assign({},i),t)}const CheckboxStateWrapper=e=>{var{state:t,inputProps:n}=e,i=__rest(e,["state","inputProps"]);const o=(null==t?void 0:t._variant)||"default";return h(CheckboxFc,Object.assign({variant:o,inputProps:getCheckboxProps(t,n)},i))},defaultStyleCss='/*\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}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n@layer kol-component {\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-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--disabled .kol-form-field__label {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__label-text::after {\n content: "*"/"";\n }\n .kol-form-field--disabled .kol-form-field__hint {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__tooltip .span-label::after {\n content: "*"/"";\n }\n .kol-field-control {\n display: grid;\n min-height: var(--a11y-min-size);\n align-items: center;\n justify-content: left;\n grid-template-areas: "input label";\n grid-template-columns: auto 1fr;\n grid-template-rows: auto;\n }\n .kol-field-control:has(.kol-field-control__hint) {\n grid-template-areas: "input label" "hint hint";\n grid-template-columns: auto 1fr;\n grid-template-rows: auto auto;\n }\n .kol-field-control--label-align-left:not(.kol-field-control--hide-label) {\n grid-template-areas: "label input";\n grid-template-columns: 1fr auto;\n grid-template-rows: auto;\n }\n .kol-field-control--label-align-left:not(.kol-field-control--hide-label):has(.kol-field-control__hint) {\n grid-template-areas: "label input" "hint hint";\n grid-template-columns: 1fr auto;\n grid-template-rows: auto auto;\n }\n .kol-field-control__input {\n display: flex;\n min-height: var(--a11y-min-size);\n align-items: center;\n grid-area: input;\n }\n .kol-field-control__label {\n display: flex;\n min-height: var(--a11y-min-size);\n flex-grow: 1;\n align-items: center;\n cursor: pointer;\n grid-area: label;\n }\n .kol-field-control__label--visually-hidden {\n height: 0;\n margin: 0;\n padding: 0;\n visibility: hidden;\n }\n .kol-field-control__label-text::after {\n content: "";\n }\n .kol-field-control__tooltip .span-label::after {\n content: "";\n }\n .kol-field-control__hint {\n grid-area: hint;\n }\n .kol-field-control--disabled .kol-field-control__label {\n opacity: 0.5;\n cursor: not-allowed;\n }\n .kol-field-control--required .kol-field-control__label-text::after {\n content: "*";\n }\n .kol-field-control--required .kol-field-control__tooltip .span-label::after {\n content: "*";\n }\n .kol-form-field {\n display: grid;\n }\n .kol-checkbox {\n display: flex;\n position: relative;\n align-items: center;\n cursor: pointer;\n }\n .kol-checkbox--disabled {\n cursor: not-allowed;\n }\n .kol-checkbox .kol-input {\n background-color: #fff;\n border-style: solid;\n margin: 0;\n border-width: 2px;\n appearance: none;\n cursor: inherit;\n }\n .kol-checkbox .kol-input:before {\n content: "";\n }\n /**\n * Variant: Checkbox\n */\n .kol-checkbox--variant-default {\n position: relative;\n width: var(--a11y-min-size);\n height: var(--a11y-min-size);\n justify-content: center;\n }\n .kol-checkbox--variant-default .kol-icon {\n display: flex;\n position: absolute;\n inset: auto;\n z-index: 1;\n pointer-events: none;\n }\n .kol-checkbox--variant-default .kol-icon::part(icon) {\n display: none;\n }\n .kol-checkbox--variant-default .kol-input {\n width: calc(22 * 1rem / var(--kolibri-root-font-size, 16));\n height: calc(22 * 1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-checkbox--variant-default.kol-checkbox--checked .kol-icon::part(icon), .kol-checkbox--variant-default.kol-checkbox--indeterminate .kol-icon::part(icon) {\n display: block;\n }\n /**\n * Variant: Switch\n */\n .kol-checkbox--variant-switch {\n position: relative;\n }\n .kol-checkbox--variant-switch .kol-input {\n display: inline-block;\n position: relative;\n width: 3.2em;\n min-width: 3.2em;\n height: 1.7em;\n }\n .kol-checkbox--variant-switch .kol-input::before {\n background-color: #000;\n position: absolute;\n top: calc(0.25em - 2 * 1rem / var(--kolibri-root-font-size, 16));\n left: calc(0.25em - 2 * 1rem / var(--kolibri-root-font-size, 16));\n width: 1.2em;\n height: 1.2em;\n transition: 0.5s;\n }\n .kol-checkbox--variant-switch .kol-input:checked::before {\n transform: translateX(1.5em);\n }\n .kol-checkbox--variant-switch .kol-input:indeterminate::before {\n transform: translateX(0.75em);\n }\n .kol-checkbox--variant-switch .kol-icon {\n transform: translate(0, -50%);\n color: #000;\n display: flex;\n position: absolute;\n top: 50%;\n left: calc(4 * 1rem / var(--kolibri-root-font-size, 16));\n z-index: 1;\n width: 1.2em;\n height: 1.2em;\n align-items: center;\n justify-content: center;\n transition: 0.5s;\n }\n .kol-checkbox--variant-switch.kol-checkbox--checked .kol-icon {\n transform: translate(1.5em, -50%);\n }\n .kol-checkbox--variant-switch.kol-checkbox--indeterminate .kol-icon {\n transform: translate(0.75em, -50%);\n }\n /**\n * Variant: Button\n */\n .kol-checkbox--variant-button {\n width: var(--a11y-min-size);\n }\n .kol-checkbox--variant-button .kol-icon {\n display: flex;\n width: var(--a11y-min-size);\n height: var(--a11y-min-size);\n align-items: center;\n justify-content: center;\n }\n}',KolInputCheckbox$1=proxyCustomElement(class extends HTMLElement{getModelValue(){return this._checked?this.state._value:null}async getValue(){return this.getModelValue()}async kolFocus(){var e;null===(e=this.inputRef)||void 0===e||e.focus()}getFormFieldProps(){return{state:this.state,class:clsx("kol-input-checkbox",{"kol-input-checkbox--checked":this.state._checked,"kol-input-checkbox--indeterminate":this.state._indeterminate,[`kol-input-checkbox--variant-${this.state._variant||"default"}`]:!0,[`kol-input-checkbox--label-align-${this.state._labelAlign||"right"}`]:!0}),tooltipAlign:this._tooltipAlign,alert:this.showAsAlert(),renderNoTooltip:!0}}getFieldControlProps(){return{class:clsx("kol-input-checkbox__field-control",{"kol-input-checkbox__field-control--checked":this.state._checked,"kol-input-checkbox__field-control--indeterminate":this.state._indeterminate,[`kol-input-checkbox__field-control--variant-${this.state._variant||"default"}`]:!0}),state:this.state}}getInputProps(){return{state:this.state,icon:this.getIcon(),inputProps:Object.assign(Object.assign({class:clsx({"visually-hidden":"button"===this.state._variant}),ref:this.catchRef},this.controller.onFacade),{onInput:this.onInput,onChange:this.onChange,onKeyDown:this.onKeyDown.bind(this),onFocus:e=>{this.controller.onFacade.onFocus(e),this.inputHasFocus=!0},onBlur:e=>{this.controller.onFacade.onBlur(e),this.inputHasFocus=!1},onClick:void 0})}}getIcon(){return this.state._indeterminate?this.state._icons.indeterminate:this.state._checked?this.state._icons.checked:this.state._icons.unchecked}render(){return h(FormFieldStateWrapper,Object.assign({key:"ea78897d3814398c2b65d1a345d910d874a08098"},this.getFormFieldProps(),{renderNoLabel:!0}),h(FieldControlStateWrapper,Object.assign({key:"6b5bee7c4aa84f1a204f1ce6aafd5981e48d64b5"},this.getFieldControlProps(),{renderNoHint:!0}),h(CheckboxStateWrapper,Object.assign({key:"4f8275511a19f813c31ae714c448133588480339"},this.getInputProps()))))}constructor(e){super(),!1!==e&&this.__registerHost(),this.__attachShadow(),this.catchRef=e=>{this.inputRef=e},this._checked=!1,this._hideMsg=!1,this._disabled=!1,this._hideLabel=!1,this._hint="",this._labelAlign="right",this._required=!1,this._tooltipAlign="top",this._touched=!1,this._value=!0,this._variant="default",this.state={_checked:!1,_hideMsg:!1,_icons:{checked:"codicon codicon-check",indeterminate:"codicon codicon-remove",unchecked:"codicon codicon-close"},_id:`id-${nonce()}`,_indeterminate:!1,_label:"",_value:!0,_variant:"default",_labelAlign:"right"},this.inputHasFocus=!1,this.onInput=e=>{this._checked=!this._checked,this._indeterminate=!1;const t=this.getModelValue();this.controller.onFacade.onInput(e,!1,t),this.controller.setFormAssociatedCheckboxValue(t)},this.onChange=e=>{this.controller.onFacade.onChange(e,this.getModelValue())},this.onKeyDown=e=>{this.controller.onFacade.onKeyDown(e),"Enter"!==e.code&&"NumpadEnter"!==e.code||propagateSubmitEventToForm({form:this.host})},this.controller=new InputCheckboxController(this,"checkbox",this.host)}showAsAlert(){return Boolean(this.state._touched)&&!this.inputHasFocus}validateAccessKey(e){this.controller.validateAccessKey(e)}validateChecked(e){this.controller.validateChecked(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)}validateId(e){this.controller.validateId(e)}validateIndeterminate(e){this.controller.validateIndeterminate(e)}validateLabel(e){this.controller.validateLabel(e)}validateLabelAlign(e){this.controller.validateLabelAlign(e)}validateMsg(e){this.controller.validateMsg(e)}validateName(e){this.controller.validateName(e)}validateOn(e){this.controller.validateOn(e)}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)}validateVariant(e){this.controller.validateVariant(e)}componentWillLoad(){this._touched=!0===this._touched,this.controller.componentWillLoad()}get host(){return this}static get watchers(){return{_accessKey:["validateAccessKey"],_checked:["validateChecked"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_id:["validateId"],_indeterminate:["validateIndeterminate"],_label:["validateLabel"],_labelAlign:["validateLabelAlign"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_required:["validateRequired"],_shortKey:["validateShortKey"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"],_variant:["validateVariant"]}}static get style(){return{default:defaultStyleCss}}},[289,"kol-input-checkbox",{_accessKey:[1,"_access-key"],_checked:[1540],_hideMsg:[4,"_hide-msg"],_disabled:[4],_hideLabel:[4,"_hide-label"],_hint:[1],_icons:[1],_id:[1],_indeterminate:[1540],_label:[1],_labelAlign:[1,"_label-align"],_msg:[1],_name:[1],_on:[16],_required:[4],_shortKey:[1,"_short-key"],_syncValueBySelector:[1,"_sync-value-by-selector"],_tooltipAlign:[1,"_tooltip-align"],_touched:[1540],_value:[8],_variant:[1],state:[32],inputHasFocus:[32],getValue:[64],kolFocus:[64]},void 0,{_accessKey:["validateAccessKey"],_checked:["validateChecked"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_id:["validateId"],_indeterminate:["validateIndeterminate"],_label:["validateLabel"],_labelAlign:["validateLabelAlign"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_required:["validateRequired"],_shortKey:["validateShortKey"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"],_variant:["validateVariant"]}]);function defineCustomElement$1(){if("undefined"==typeof customElements)return;["kol-input-checkbox"].forEach(e=>{if("kol-input-checkbox"===e)customElements.get(e)||customElements.define(e,KolInputCheckbox$1)})}const KolInputCheckbox=KolInputCheckbox$1,defineCustomElement=defineCustomElement$1;export{KolInputCheckbox,defineCustomElement};