@public-ui/components 1.5.0-rc.2 → 1.5.0-rc.20

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 (964) hide show
  1. package/assets/codicons/LICENSE +395 -0
  2. package/assets/codicons/LICENSE-CODE +21 -0
  3. package/assets/codicons/codicon.css +571 -0
  4. package/assets/codicons/codicon.csv +421 -0
  5. package/assets/codicons/codicon.html +3871 -0
  6. package/assets/codicons/codicon.svg +1 -0
  7. package/assets/codicons/codicon.ttf +0 -0
  8. package/assets/kolibri.ico +0 -0
  9. package/cheat-sheet.html +191 -179
  10. package/custom-elements.json +518 -3479
  11. package/dist/cjs/a11y.tipps-6f0ad06e.js +4 -0
  12. package/dist/cjs/a11y.tipps-6f0ad06e.js.map +1 -0
  13. package/dist/cjs/{app-globals-c6303780.js → app-globals-33f93589.js} +1 -1
  14. package/dist/cjs/{app-globals-c6303780.js.map → app-globals-33f93589.js.map} +1 -1
  15. package/dist/cjs/aria-selected-3280e495.js +4 -0
  16. package/dist/cjs/aria-selected-3280e495.js.map +1 -0
  17. package/dist/cjs/{button-link-89ed5382.js → button-link-19d8a9a8.js} +1 -1
  18. package/dist/cjs/button-link-19d8a9a8.js.map +1 -0
  19. package/dist/cjs/color-0b347424.js +4 -0
  20. package/dist/cjs/color-0b347424.js.map +1 -0
  21. package/dist/cjs/{controller-2405dd04.js → controller-43eacc77.js} +1 -1
  22. package/dist/cjs/controller-43eacc77.js.map +1 -0
  23. package/dist/cjs/controller-521c7ae9.js +4 -0
  24. package/dist/cjs/controller-521c7ae9.js.map +1 -0
  25. package/dist/cjs/{controller-ce13f0a2.js → controller-62ae6225.js} +1 -1
  26. package/dist/cjs/{controller-ce13f0a2.js.map → controller-62ae6225.js.map} +1 -1
  27. package/dist/cjs/{controller-94b357a3.js → controller-7f4b0caf.js} +1 -1
  28. package/dist/cjs/controller-7f4b0caf.js.map +1 -0
  29. package/dist/cjs/{controller-d0743a95.js → controller-87980d4a.js} +1 -1
  30. package/dist/cjs/controller-87980d4a.js.map +1 -0
  31. package/dist/cjs/controller-a753291e.js +4 -0
  32. package/dist/cjs/controller-a753291e.js.map +1 -0
  33. package/dist/cjs/{controller-icon-b87565c4.js → controller-icon-0a88c097.js} +1 -1
  34. package/dist/cjs/controller-icon-0a88c097.js.map +1 -0
  35. package/dist/cjs/{dev.utils-7123fb34.js → dev.utils-d69c0a9f.js} +1 -1
  36. package/dist/cjs/{dev.utils-7123fb34.js.map → dev.utils-d69c0a9f.js.map} +1 -1
  37. package/dist/cjs/{devtools-a9a95b0a.js → devtools-98551855.js} +1 -1
  38. package/dist/cjs/{devtools-a9a95b0a.js.map → devtools-98551855.js.map} +1 -1
  39. package/dist/cjs/disabled-2baca3c8.js +4 -0
  40. package/dist/cjs/disabled-2baca3c8.js.map +1 -0
  41. package/dist/cjs/floating-ui.dom.esm-a89c1e0e.js +4 -0
  42. package/dist/cjs/floating-ui.dom.esm-a89c1e0e.js.map +1 -0
  43. package/dist/cjs/hide-label-6f7c8326.js +4 -0
  44. package/dist/cjs/hide-label-6f7c8326.js.map +1 -0
  45. package/dist/cjs/{i18n-5d946612.js → i18n-c10806ae.js} +1 -1
  46. package/dist/cjs/{i18n-5d946612.js.map → i18n-c10806ae.js.map} +1 -1
  47. package/dist/cjs/{icon-ccf4ad42.js → icon-71b1bd66.js} +1 -1
  48. package/dist/cjs/icon-71b1bd66.js.map +1 -0
  49. package/dist/cjs/index-29c5d3c6.js.map +1 -1
  50. package/dist/cjs/index-b6484e6a.js +4 -0
  51. package/dist/cjs/index-b6484e6a.js.map +1 -0
  52. package/dist/cjs/index-eb52922f.js +4 -0
  53. package/dist/cjs/index-eb52922f.js.map +1 -0
  54. package/dist/cjs/index.cjs.js +1 -1
  55. package/dist/cjs/kol-abbr.cjs.entry.js +1 -1
  56. package/dist/cjs/kol-abbr.cjs.entry.js.map +1 -1
  57. package/dist/cjs/kol-accordion.cjs.entry.js +1 -1
  58. package/dist/cjs/kol-accordion.cjs.entry.js.map +1 -1
  59. package/dist/cjs/kol-alert-wc_2.cjs.entry.js +4 -0
  60. package/dist/cjs/kol-alert-wc_2.cjs.entry.js.map +1 -0
  61. package/dist/cjs/kol-alert.cjs.entry.js +1 -1
  62. package/dist/cjs/kol-alert.cjs.entry.js.map +1 -1
  63. package/dist/cjs/kol-badge.cjs.entry.js +1 -1
  64. package/dist/cjs/kol-badge.cjs.entry.js.map +1 -1
  65. package/dist/cjs/kol-breadcrumb.cjs.entry.js +1 -1
  66. package/dist/cjs/kol-breadcrumb.cjs.entry.js.map +1 -1
  67. package/dist/cjs/kol-button-group-wc.cjs.entry.js.map +1 -1
  68. package/dist/cjs/kol-button-group.cjs.entry.js +1 -1
  69. package/dist/cjs/kol-button-group.cjs.entry.js.map +1 -1
  70. package/dist/cjs/kol-button-link.cjs.entry.js +1 -1
  71. package/dist/cjs/kol-button-link.cjs.entry.js.map +1 -1
  72. package/dist/cjs/kol-button-wc_3.cjs.entry.js +4 -0
  73. package/dist/cjs/kol-button-wc_3.cjs.entry.js.map +1 -0
  74. package/dist/cjs/kol-button.cjs.entry.js +1 -1
  75. package/dist/cjs/kol-button.cjs.entry.js.map +1 -1
  76. package/dist/cjs/kol-card.cjs.entry.js +1 -1
  77. package/dist/cjs/kol-card.cjs.entry.js.map +1 -1
  78. package/dist/cjs/kol-details.cjs.entry.js +1 -1
  79. package/dist/cjs/kol-details.cjs.entry.js.map +1 -1
  80. package/dist/cjs/kol-form.cjs.entry.js +1 -1
  81. package/dist/cjs/kol-form.cjs.entry.js.map +1 -1
  82. package/dist/cjs/kol-heading.cjs.entry.js +1 -1
  83. package/dist/cjs/kol-heading.cjs.entry.js.map +1 -1
  84. package/dist/cjs/kol-icon-font-awesome.cjs.entry.js.map +1 -1
  85. package/dist/cjs/kol-icon-icofont.cjs.entry.js.map +1 -1
  86. package/dist/cjs/kol-icon.cjs.entry.js +1 -1
  87. package/dist/cjs/kol-icon.cjs.entry.js.map +1 -1
  88. package/dist/cjs/kol-image.cjs.entry.js +1 -1
  89. package/dist/cjs/kol-image.cjs.entry.js.map +1 -1
  90. package/dist/cjs/kol-indented-text.cjs.entry.js +1 -1
  91. package/dist/cjs/kol-indented-text.cjs.entry.js.map +1 -1
  92. package/dist/cjs/kol-input-adapter-leanup.cjs.entry.js +1 -1
  93. package/dist/cjs/kol-input-checkbox.cjs.entry.js +1 -1
  94. package/dist/cjs/kol-input-checkbox.cjs.entry.js.map +1 -1
  95. package/dist/cjs/kol-input-color.cjs.entry.js +1 -1
  96. package/dist/cjs/kol-input-color.cjs.entry.js.map +1 -1
  97. package/dist/cjs/kol-input-date.cjs.entry.js +1 -1
  98. package/dist/cjs/kol-input-date.cjs.entry.js.map +1 -1
  99. package/dist/cjs/kol-input-email.cjs.entry.js +1 -1
  100. package/dist/cjs/kol-input-email.cjs.entry.js.map +1 -1
  101. package/dist/cjs/kol-input-file.cjs.entry.js +1 -1
  102. package/dist/cjs/kol-input-file.cjs.entry.js.map +1 -1
  103. package/dist/cjs/kol-input-number.cjs.entry.js +1 -1
  104. package/dist/cjs/kol-input-number.cjs.entry.js.map +1 -1
  105. package/dist/cjs/kol-input-password.cjs.entry.js +1 -1
  106. package/dist/cjs/kol-input-password.cjs.entry.js.map +1 -1
  107. package/dist/cjs/kol-input-radio-group.cjs.entry.js +1 -1
  108. package/dist/cjs/kol-input-radio-group.cjs.entry.js.map +1 -1
  109. package/dist/cjs/kol-input-radio.cjs.entry.js +1 -1
  110. package/dist/cjs/kol-input-radio.cjs.entry.js.map +1 -1
  111. package/dist/cjs/kol-input-range.cjs.entry.js +1 -1
  112. package/dist/cjs/kol-input-range.cjs.entry.js.map +1 -1
  113. package/dist/cjs/kol-input-text.cjs.entry.js +1 -1
  114. package/dist/cjs/kol-input-text.cjs.entry.js.map +1 -1
  115. package/dist/cjs/kol-kolibri.cjs.entry.js +1 -1
  116. package/dist/cjs/kol-kolibri.cjs.entry.js.map +1 -1
  117. package/dist/cjs/kol-link-button.cjs.entry.js +1 -1
  118. package/dist/cjs/kol-link-button.cjs.entry.js.map +1 -1
  119. package/dist/cjs/kol-link-group.cjs.entry.js +1 -1
  120. package/dist/cjs/kol-link-group.cjs.entry.js.map +1 -1
  121. package/dist/cjs/kol-link-wc.cjs.entry.js +1 -1
  122. package/dist/cjs/kol-link-wc.cjs.entry.js.map +1 -1
  123. package/dist/cjs/kol-link.cjs.entry.js +1 -1
  124. package/dist/cjs/kol-link.cjs.entry.js.map +1 -1
  125. package/dist/cjs/kol-logo.cjs.entry.js +1 -1
  126. package/dist/cjs/kol-logo.cjs.entry.js.map +1 -1
  127. package/dist/cjs/kol-modal.cjs.entry.js +1 -1
  128. package/dist/cjs/kol-modal.cjs.entry.js.map +1 -1
  129. package/dist/cjs/kol-nav.cjs.entry.js +1 -1
  130. package/dist/cjs/kol-nav.cjs.entry.js.map +1 -1
  131. package/dist/cjs/kol-pagination.cjs.entry.js +1 -1
  132. package/dist/cjs/kol-pagination.cjs.entry.js.map +1 -1
  133. package/dist/cjs/kol-popover.cjs.entry.js +4 -0
  134. package/dist/cjs/kol-popover.cjs.entry.js.map +1 -0
  135. package/dist/cjs/kol-progress.cjs.entry.js +1 -1
  136. package/dist/cjs/kol-progress.cjs.entry.js.map +1 -1
  137. package/dist/cjs/kol-quote.cjs.entry.js +4 -0
  138. package/dist/cjs/kol-quote.cjs.entry.js.map +1 -0
  139. package/dist/cjs/kol-select.cjs.entry.js +1 -1
  140. package/dist/cjs/kol-select.cjs.entry.js.map +1 -1
  141. package/dist/cjs/kol-skip-nav.cjs.entry.js +1 -1
  142. package/dist/cjs/kol-skip-nav.cjs.entry.js.map +1 -1
  143. package/dist/cjs/kol-span.cjs.entry.js +1 -1
  144. package/dist/cjs/kol-span.cjs.entry.js.map +1 -1
  145. package/dist/cjs/kol-spin.cjs.entry.js +1 -1
  146. package/dist/cjs/kol-spin.cjs.entry.js.map +1 -1
  147. package/dist/cjs/kol-split-button.cjs.entry.js +4 -0
  148. package/dist/cjs/kol-split-button.cjs.entry.js.map +1 -0
  149. package/dist/cjs/kol-symbol.cjs.entry.js +1 -1
  150. package/dist/cjs/kol-symbol.cjs.entry.js.map +1 -1
  151. package/dist/cjs/kol-table.cjs.entry.js +1 -1
  152. package/dist/cjs/kol-table.cjs.entry.js.map +1 -1
  153. package/dist/cjs/kol-tabs.cjs.entry.js +1 -1
  154. package/dist/cjs/kol-tabs.cjs.entry.js.map +1 -1
  155. package/dist/cjs/kol-textarea.cjs.entry.js +1 -1
  156. package/dist/cjs/kol-textarea.cjs.entry.js.map +1 -1
  157. package/dist/cjs/kol-toast.cjs.entry.js +1 -1
  158. package/dist/cjs/kol-toast.cjs.entry.js.map +1 -1
  159. package/dist/cjs/kol-tooltip.cjs.entry.js +1 -1
  160. package/dist/cjs/kol-tooltip.cjs.entry.js.map +1 -1
  161. package/dist/cjs/kol-version.cjs.entry.js +1 -1
  162. package/dist/cjs/kol-version.cjs.entry.js.map +1 -1
  163. package/dist/cjs/kolibri.cjs.js +1 -1
  164. package/dist/cjs/kolibri.cjs.js.map +1 -1
  165. package/dist/cjs/label-dc5092d3.js +4 -0
  166. package/dist/cjs/label-dc5092d3.js.map +1 -0
  167. package/dist/cjs/loader.cjs.js +1 -1
  168. package/dist/cjs/loader.cjs.js.map +1 -1
  169. package/dist/cjs/prop.validators-dd1f7878.js +4 -0
  170. package/dist/cjs/prop.validators-dd1f7878.js.map +1 -0
  171. package/dist/cjs/reuse-0fe7470f.js +4 -0
  172. package/dist/cjs/{reuse-bbd0b4e7.js.map → reuse-0fe7470f.js.map} +1 -1
  173. package/dist/cjs/show-878e36a5.js +4 -0
  174. package/dist/cjs/show-878e36a5.js.map +1 -0
  175. package/dist/cjs/{tab-index-1d448ede.js → tab-index-7bf0cb35.js} +1 -1
  176. package/dist/cjs/{tab-index-1d448ede.js.map → tab-index-7bf0cb35.js.map} +1 -1
  177. package/dist/cjs/validation-55ae497d.js +4 -0
  178. package/dist/cjs/{validation-2b3c81d9.js.map → validation-55ae497d.js.map} +1 -1
  179. package/dist/cjs/{validation-1e8663e2.js → validation-60fd00e2.js} +1 -1
  180. package/dist/cjs/validation-60fd00e2.js.map +1 -0
  181. package/dist/components/aria-selected.js +4 -0
  182. package/dist/components/aria-selected.js.map +1 -0
  183. package/dist/components/color.js +4 -0
  184. package/dist/components/color.js.map +1 -0
  185. package/dist/components/component.js +1 -1
  186. package/dist/components/component.js.map +1 -1
  187. package/dist/components/component10.js +1 -1
  188. package/dist/components/component10.js.map +1 -1
  189. package/dist/components/component11.js +1 -1
  190. package/dist/components/component11.js.map +1 -1
  191. package/dist/components/component12.js +1 -1
  192. package/dist/components/component12.js.map +1 -1
  193. package/dist/components/component13.js +1 -1
  194. package/dist/components/component13.js.map +1 -1
  195. package/dist/components/component14.js +4 -0
  196. package/dist/components/component14.js.map +1 -0
  197. package/dist/components/component15.js +4 -0
  198. package/dist/components/component15.js.map +1 -0
  199. package/dist/components/component2.js +1 -1
  200. package/dist/components/component2.js.map +1 -1
  201. package/dist/components/component3.js +1 -1
  202. package/dist/components/component3.js.map +1 -1
  203. package/dist/components/component4.js +1 -1
  204. package/dist/components/component4.js.map +1 -1
  205. package/dist/components/component5.js +1 -1
  206. package/dist/components/component5.js.map +1 -1
  207. package/dist/components/component6.js +1 -1
  208. package/dist/components/component6.js.map +1 -1
  209. package/dist/components/component7.js +1 -1
  210. package/dist/components/component7.js.map +1 -1
  211. package/dist/components/component8.js +1 -1
  212. package/dist/components/component8.js.map +1 -1
  213. package/dist/components/component9.js +1 -1
  214. package/dist/components/component9.js.map +1 -1
  215. package/dist/components/controller-icon.js +1 -1
  216. package/dist/components/controller-icon.js.map +1 -1
  217. package/dist/components/controller.js +1 -1
  218. package/dist/components/controller.js.map +1 -1
  219. package/dist/components/controller2.js +1 -1
  220. package/dist/components/controller2.js.map +1 -1
  221. package/dist/components/controller3.js +1 -1
  222. package/dist/components/controller3.js.map +1 -1
  223. package/dist/components/controller4.js +1 -1
  224. package/dist/components/controller4.js.map +1 -1
  225. package/dist/components/devtools.js +1 -1
  226. package/dist/components/floating-ui.dom.esm.js +4 -0
  227. package/dist/components/floating-ui.dom.esm.js.map +1 -0
  228. package/dist/components/hide-label.js +4 -0
  229. package/dist/components/hide-label.js.map +1 -0
  230. package/dist/components/i18n.js +1 -1
  231. package/dist/components/i18n.js.map +1 -1
  232. package/dist/components/index.js +1 -1
  233. package/dist/components/kol-abbr.js +1 -1
  234. package/dist/components/kol-abbr.js.map +1 -1
  235. package/dist/components/kol-accordion.js +1 -1
  236. package/dist/components/kol-accordion.js.map +1 -1
  237. package/dist/components/kol-alert-wc.d.ts +11 -0
  238. package/dist/components/kol-alert-wc.js +4 -0
  239. package/dist/components/kol-alert-wc.js.map +1 -0
  240. package/dist/components/kol-alert.js +1 -1
  241. package/dist/components/kol-badge.js +1 -1
  242. package/dist/components/kol-breadcrumb.js +1 -1
  243. package/dist/components/kol-breadcrumb.js.map +1 -1
  244. package/dist/components/kol-button-group-wc.js +1 -1
  245. package/dist/components/kol-button-group.js +1 -1
  246. package/dist/components/kol-button-group.js.map +1 -1
  247. package/dist/components/kol-button-link.js +1 -1
  248. package/dist/components/kol-button-link.js.map +1 -1
  249. package/dist/components/kol-button-wc.js +1 -1
  250. package/dist/components/kol-button.js +1 -1
  251. package/dist/components/kol-card.js +1 -1
  252. package/dist/components/kol-card.js.map +1 -1
  253. package/dist/components/kol-details.js +1 -1
  254. package/dist/components/kol-details.js.map +1 -1
  255. package/dist/components/kol-form.js +1 -1
  256. package/dist/components/kol-form.js.map +1 -1
  257. package/dist/components/kol-heading.js +1 -1
  258. package/dist/components/kol-heading.js.map +1 -1
  259. package/dist/components/kol-icon-font-awesome.js.map +1 -1
  260. package/dist/components/kol-icon-icofont.js.map +1 -1
  261. package/dist/components/kol-image.js +1 -1
  262. package/dist/components/kol-image.js.map +1 -1
  263. package/dist/components/kol-indented-text.js +1 -1
  264. package/dist/components/kol-input-adapter-leanup.js +1 -1
  265. package/dist/components/kol-input-adapter-leanup.js.map +1 -1
  266. package/dist/components/kol-input-checkbox.js +1 -1
  267. package/dist/components/kol-input-checkbox.js.map +1 -1
  268. package/dist/components/kol-input-color.js +1 -1
  269. package/dist/components/kol-input-color.js.map +1 -1
  270. package/dist/components/kol-input-date.js +1 -1
  271. package/dist/components/kol-input-date.js.map +1 -1
  272. package/dist/components/kol-input-email.js +1 -1
  273. package/dist/components/kol-input-email.js.map +1 -1
  274. package/dist/components/kol-input-file.js +1 -1
  275. package/dist/components/kol-input-file.js.map +1 -1
  276. package/dist/components/kol-input-number.js +1 -1
  277. package/dist/components/kol-input-password.js +1 -1
  278. package/dist/components/kol-input-password.js.map +1 -1
  279. package/dist/components/kol-input-radio-group.js +1 -1
  280. package/dist/components/kol-input-radio-group.js.map +1 -1
  281. package/dist/components/kol-input-radio.js +1 -1
  282. package/dist/components/kol-input-range.js +1 -1
  283. package/dist/components/kol-input-range.js.map +1 -1
  284. package/dist/components/kol-input-text.js +1 -1
  285. package/dist/components/kol-input-text.js.map +1 -1
  286. package/dist/components/kol-input.js +1 -1
  287. package/dist/components/kol-kolibri.js +1 -1
  288. package/dist/components/kol-kolibri.js.map +1 -1
  289. package/dist/components/kol-link-button.js +1 -1
  290. package/dist/components/kol-link-button.js.map +1 -1
  291. package/dist/components/kol-link-group.js +1 -1
  292. package/dist/components/kol-link-group.js.map +1 -1
  293. package/dist/components/kol-link-wc.js +1 -1
  294. package/dist/components/kol-link.js +1 -1
  295. package/dist/components/kol-logo.js +1 -1
  296. package/dist/components/kol-logo.js.map +1 -1
  297. package/dist/components/kol-modal.js +1 -1
  298. package/dist/components/kol-modal.js.map +1 -1
  299. package/dist/components/kol-nav.js +1 -1
  300. package/dist/components/kol-nav.js.map +1 -1
  301. package/dist/components/kol-pagination.js +1 -1
  302. package/dist/components/kol-popover.d.ts +11 -0
  303. package/dist/components/kol-popover.js +4 -0
  304. package/dist/components/kol-popover.js.map +1 -0
  305. package/dist/components/kol-progress.js +1 -1
  306. package/dist/components/kol-progress.js.map +1 -1
  307. package/dist/components/kol-quote.d.ts +11 -0
  308. package/dist/components/kol-quote.js +4 -0
  309. package/dist/components/kol-quote.js.map +1 -0
  310. package/dist/components/kol-select.js +1 -1
  311. package/dist/components/kol-skip-nav.js +1 -1
  312. package/dist/components/kol-skip-nav.js.map +1 -1
  313. package/dist/components/kol-span.js +1 -1
  314. package/dist/components/kol-span.js.map +1 -1
  315. package/dist/components/kol-spin.js +1 -1
  316. package/dist/components/kol-spin.js.map +1 -1
  317. package/dist/components/kol-split-button.d.ts +11 -0
  318. package/dist/components/kol-split-button.js +4 -0
  319. package/dist/components/kol-split-button.js.map +1 -0
  320. package/dist/components/kol-symbol.js.map +1 -1
  321. package/dist/components/kol-table.js +1 -1
  322. package/dist/components/kol-table.js.map +1 -1
  323. package/dist/components/kol-tabs.js +1 -1
  324. package/dist/components/kol-tabs.js.map +1 -1
  325. package/dist/components/kol-textarea.js +1 -1
  326. package/dist/components/kol-textarea.js.map +1 -1
  327. package/dist/components/kol-toast.js +1 -1
  328. package/dist/components/kol-toast.js.map +1 -1
  329. package/dist/components/kol-tooltip.js +1 -1
  330. package/dist/components/kol-version.js +1 -1
  331. package/dist/components/kol-version.js.map +1 -1
  332. package/dist/components/prop.validators.js +1 -1
  333. package/dist/components/prop.validators.js.map +1 -1
  334. package/dist/components/shadow.js +1 -1
  335. package/dist/components/shadow.js.map +1 -1
  336. package/dist/components/shadow2.js +1 -1
  337. package/dist/components/shadow2.js.map +1 -1
  338. package/dist/components/shadow3.js +4 -0
  339. package/dist/components/shadow3.js.map +1 -0
  340. package/dist/components/show.js +4 -0
  341. package/dist/components/show.js.map +1 -0
  342. package/dist/components/tab-index.js +4 -0
  343. package/dist/components/tab-index.js.map +1 -0
  344. package/dist/components/validation.js +1 -1
  345. package/dist/components/validation.js.map +1 -1
  346. package/dist/esm/a11y.tipps-1cea9822.js +4 -0
  347. package/dist/esm/a11y.tipps-1cea9822.js.map +1 -0
  348. package/dist/esm/app-globals-e0ff5b32.js +4 -0
  349. package/dist/esm/{app-globals-81f5e91d.js.map → app-globals-e0ff5b32.js.map} +1 -1
  350. package/dist/esm/aria-selected-c27e9433.js +4 -0
  351. package/dist/esm/aria-selected-c27e9433.js.map +1 -0
  352. package/dist/esm/{button-link-3d1888e3.js → button-link-0f3cba87.js} +1 -1
  353. package/dist/esm/button-link-0f3cba87.js.map +1 -0
  354. package/dist/esm/color-a8bae36b.js +4 -0
  355. package/dist/esm/color-a8bae36b.js.map +1 -0
  356. package/dist/esm/{controller-5bd06546.js → controller-0b0c0e12.js} +1 -1
  357. package/dist/esm/{controller-5bd06546.js.map → controller-0b0c0e12.js.map} +1 -1
  358. package/dist/esm/{controller-9926eaee.js → controller-29e1bd76.js} +1 -1
  359. package/dist/esm/controller-29e1bd76.js.map +1 -0
  360. package/dist/esm/controller-37d0d40b.js +4 -0
  361. package/dist/esm/controller-37d0d40b.js.map +1 -0
  362. package/dist/esm/{controller-ea28fcf8.js → controller-38789301.js} +1 -1
  363. package/dist/esm/controller-38789301.js.map +1 -0
  364. package/dist/esm/controller-873db1b1.js +4 -0
  365. package/dist/esm/controller-873db1b1.js.map +1 -0
  366. package/dist/esm/{controller-04bee517.js → controller-c5b419c7.js} +1 -1
  367. package/dist/esm/controller-c5b419c7.js.map +1 -0
  368. package/dist/esm/{controller-icon-2a9f5c13.js → controller-icon-6249a817.js} +1 -1
  369. package/dist/esm/controller-icon-6249a817.js.map +1 -0
  370. package/dist/esm/{dev.utils-05f4e663.js → dev.utils-157f0499.js} +1 -1
  371. package/dist/esm/{dev.utils-05f4e663.js.map → dev.utils-157f0499.js.map} +1 -1
  372. package/dist/esm/{devtools-640ace8d.js → devtools-cb70c2f9.js} +1 -1
  373. package/dist/esm/{devtools-640ace8d.js.map → devtools-cb70c2f9.js.map} +1 -1
  374. package/dist/esm/disabled-52196242.js +4 -0
  375. package/dist/esm/disabled-52196242.js.map +1 -0
  376. package/dist/esm/floating-ui.dom.esm-735f9fad.js +4 -0
  377. package/dist/esm/floating-ui.dom.esm-735f9fad.js.map +1 -0
  378. package/dist/esm/hide-label-3335b848.js +4 -0
  379. package/dist/esm/hide-label-3335b848.js.map +1 -0
  380. package/dist/esm/{i18n-8e14d822.js → i18n-cbc21d6e.js} +1 -1
  381. package/dist/esm/{i18n-8e14d822.js.map → i18n-cbc21d6e.js.map} +1 -1
  382. package/dist/esm/{icon-cab2d129.js → icon-00018c54.js} +1 -1
  383. package/dist/esm/icon-00018c54.js.map +1 -0
  384. package/dist/esm/index-50adf9a0.js.map +1 -1
  385. package/dist/esm/index-81bd9b41.js +4 -0
  386. package/dist/esm/index-81bd9b41.js.map +1 -0
  387. package/dist/esm/index-fef6600b.js +4 -0
  388. package/dist/esm/index-fef6600b.js.map +1 -0
  389. package/dist/esm/index.js +1 -1
  390. package/dist/esm/kol-abbr.entry.js +1 -1
  391. package/dist/esm/kol-abbr.entry.js.map +1 -1
  392. package/dist/esm/kol-accordion.entry.js +1 -1
  393. package/dist/esm/kol-accordion.entry.js.map +1 -1
  394. package/dist/esm/kol-alert-wc_2.entry.js +4 -0
  395. package/dist/esm/kol-alert-wc_2.entry.js.map +1 -0
  396. package/dist/esm/kol-alert.entry.js +1 -1
  397. package/dist/esm/kol-alert.entry.js.map +1 -1
  398. package/dist/esm/kol-badge.entry.js +1 -1
  399. package/dist/esm/kol-badge.entry.js.map +1 -1
  400. package/dist/esm/kol-breadcrumb.entry.js +1 -1
  401. package/dist/esm/kol-breadcrumb.entry.js.map +1 -1
  402. package/dist/esm/kol-button-group-wc.entry.js.map +1 -1
  403. package/dist/esm/kol-button-group.entry.js +1 -1
  404. package/dist/esm/kol-button-group.entry.js.map +1 -1
  405. package/dist/esm/kol-button-link.entry.js +1 -1
  406. package/dist/esm/kol-button-link.entry.js.map +1 -1
  407. package/dist/esm/kol-button-wc_3.entry.js +4 -0
  408. package/dist/esm/kol-button-wc_3.entry.js.map +1 -0
  409. package/dist/esm/kol-button.entry.js +1 -1
  410. package/dist/esm/kol-button.entry.js.map +1 -1
  411. package/dist/esm/kol-card.entry.js +1 -1
  412. package/dist/esm/kol-card.entry.js.map +1 -1
  413. package/dist/esm/kol-details.entry.js +1 -1
  414. package/dist/esm/kol-details.entry.js.map +1 -1
  415. package/dist/esm/kol-form.entry.js +1 -1
  416. package/dist/esm/kol-form.entry.js.map +1 -1
  417. package/dist/esm/kol-heading.entry.js +1 -1
  418. package/dist/esm/kol-heading.entry.js.map +1 -1
  419. package/dist/esm/kol-icon-font-awesome.entry.js.map +1 -1
  420. package/dist/esm/kol-icon-icofont.entry.js.map +1 -1
  421. package/dist/esm/kol-icon.entry.js +1 -1
  422. package/dist/esm/kol-icon.entry.js.map +1 -1
  423. package/dist/esm/kol-image.entry.js +1 -1
  424. package/dist/esm/kol-image.entry.js.map +1 -1
  425. package/dist/esm/kol-indented-text.entry.js +1 -1
  426. package/dist/esm/kol-indented-text.entry.js.map +1 -1
  427. package/dist/esm/kol-input-adapter-leanup.entry.js +1 -1
  428. package/dist/esm/kol-input-checkbox.entry.js +1 -1
  429. package/dist/esm/kol-input-checkbox.entry.js.map +1 -1
  430. package/dist/esm/kol-input-color.entry.js +1 -1
  431. package/dist/esm/kol-input-color.entry.js.map +1 -1
  432. package/dist/esm/kol-input-date.entry.js +1 -1
  433. package/dist/esm/kol-input-date.entry.js.map +1 -1
  434. package/dist/esm/kol-input-email.entry.js +1 -1
  435. package/dist/esm/kol-input-email.entry.js.map +1 -1
  436. package/dist/esm/kol-input-file.entry.js +1 -1
  437. package/dist/esm/kol-input-file.entry.js.map +1 -1
  438. package/dist/esm/kol-input-number.entry.js +1 -1
  439. package/dist/esm/kol-input-number.entry.js.map +1 -1
  440. package/dist/esm/kol-input-password.entry.js +1 -1
  441. package/dist/esm/kol-input-password.entry.js.map +1 -1
  442. package/dist/esm/kol-input-radio-group.entry.js +1 -1
  443. package/dist/esm/kol-input-radio-group.entry.js.map +1 -1
  444. package/dist/esm/kol-input-radio.entry.js +1 -1
  445. package/dist/esm/kol-input-radio.entry.js.map +1 -1
  446. package/dist/esm/kol-input-range.entry.js +1 -1
  447. package/dist/esm/kol-input-range.entry.js.map +1 -1
  448. package/dist/esm/kol-input-text.entry.js +1 -1
  449. package/dist/esm/kol-input-text.entry.js.map +1 -1
  450. package/dist/esm/kol-kolibri.entry.js +1 -1
  451. package/dist/esm/kol-kolibri.entry.js.map +1 -1
  452. package/dist/esm/kol-link-button.entry.js +1 -1
  453. package/dist/esm/kol-link-button.entry.js.map +1 -1
  454. package/dist/esm/kol-link-group.entry.js +1 -1
  455. package/dist/esm/kol-link-group.entry.js.map +1 -1
  456. package/dist/esm/kol-link-wc.entry.js +1 -1
  457. package/dist/esm/kol-link-wc.entry.js.map +1 -1
  458. package/dist/esm/kol-link.entry.js +1 -1
  459. package/dist/esm/kol-link.entry.js.map +1 -1
  460. package/dist/esm/kol-logo.entry.js +1 -1
  461. package/dist/esm/kol-logo.entry.js.map +1 -1
  462. package/dist/esm/kol-modal.entry.js +1 -1
  463. package/dist/esm/kol-modal.entry.js.map +1 -1
  464. package/dist/esm/kol-nav.entry.js +1 -1
  465. package/dist/esm/kol-nav.entry.js.map +1 -1
  466. package/dist/esm/kol-pagination.entry.js +1 -1
  467. package/dist/esm/kol-pagination.entry.js.map +1 -1
  468. package/dist/esm/kol-popover.entry.js +4 -0
  469. package/dist/esm/kol-popover.entry.js.map +1 -0
  470. package/dist/esm/kol-progress.entry.js +1 -1
  471. package/dist/esm/kol-progress.entry.js.map +1 -1
  472. package/dist/esm/kol-quote.entry.js +4 -0
  473. package/dist/esm/kol-quote.entry.js.map +1 -0
  474. package/dist/esm/kol-select.entry.js +1 -1
  475. package/dist/esm/kol-select.entry.js.map +1 -1
  476. package/dist/esm/kol-skip-nav.entry.js +1 -1
  477. package/dist/esm/kol-skip-nav.entry.js.map +1 -1
  478. package/dist/esm/kol-span.entry.js +1 -1
  479. package/dist/esm/kol-span.entry.js.map +1 -1
  480. package/dist/esm/kol-spin.entry.js +1 -1
  481. package/dist/esm/kol-spin.entry.js.map +1 -1
  482. package/dist/esm/kol-split-button.entry.js +4 -0
  483. package/dist/esm/kol-split-button.entry.js.map +1 -0
  484. package/dist/esm/kol-symbol.entry.js +1 -1
  485. package/dist/esm/kol-symbol.entry.js.map +1 -1
  486. package/dist/esm/kol-table.entry.js +1 -1
  487. package/dist/esm/kol-table.entry.js.map +1 -1
  488. package/dist/esm/kol-tabs.entry.js +1 -1
  489. package/dist/esm/kol-tabs.entry.js.map +1 -1
  490. package/dist/esm/kol-textarea.entry.js +1 -1
  491. package/dist/esm/kol-textarea.entry.js.map +1 -1
  492. package/dist/esm/kol-toast.entry.js +1 -1
  493. package/dist/esm/kol-toast.entry.js.map +1 -1
  494. package/dist/esm/kol-tooltip.entry.js +1 -1
  495. package/dist/esm/kol-tooltip.entry.js.map +1 -1
  496. package/dist/esm/kol-version.entry.js +1 -1
  497. package/dist/esm/kol-version.entry.js.map +1 -1
  498. package/dist/esm/kolibri.js +1 -1
  499. package/dist/esm/kolibri.js.map +1 -1
  500. package/dist/esm/label-d51b1a57.js +4 -0
  501. package/dist/esm/label-d51b1a57.js.map +1 -0
  502. package/dist/esm/loader.js +1 -1
  503. package/dist/esm/loader.js.map +1 -1
  504. package/dist/esm/prop.validators-e402ad49.js +4 -0
  505. package/dist/esm/prop.validators-e402ad49.js.map +1 -0
  506. package/dist/esm/{reuse-56bb5a4b.js → reuse-3a02afb9.js} +1 -1
  507. package/dist/esm/{reuse-56bb5a4b.js.map → reuse-3a02afb9.js.map} +1 -1
  508. package/dist/esm/show-c455f9fd.js +4 -0
  509. package/dist/esm/show-c455f9fd.js.map +1 -0
  510. package/dist/esm/{tab-index-22c62334.js → tab-index-63d1379d.js} +1 -1
  511. package/dist/esm/{tab-index-22c62334.js.map → tab-index-63d1379d.js.map} +1 -1
  512. package/dist/esm/validation-a42d9cc9.js +4 -0
  513. package/dist/esm/{validation-d9821b54.js.map → validation-a42d9cc9.js.map} +1 -1
  514. package/dist/esm/validation-ab9a6c0d.js +4 -0
  515. package/dist/esm/validation-ab9a6c0d.js.map +1 -0
  516. package/dist/kolibri/a11y.tipps-1cea9822.js +4 -0
  517. package/dist/kolibri/a11y.tipps-1cea9822.js.map +1 -0
  518. package/dist/kolibri/app-globals-e0ff5b32.js +4 -0
  519. package/dist/kolibri/aria-selected-c27e9433.js +4 -0
  520. package/dist/kolibri/aria-selected-c27e9433.js.map +1 -0
  521. package/dist/kolibri/assets/bundes/style.css +4 -4
  522. package/dist/kolibri/assets/modal-simulation.js +1 -1
  523. package/dist/kolibri/assets/nav-simulation.js +1 -1
  524. package/dist/kolibri/assets/popover-simulation.js +1 -0
  525. package/dist/kolibri/assets/progress-simulation.js +1 -1
  526. package/dist/kolibri/assets/smart-button-simulation.js +1 -1
  527. package/dist/kolibri/assets/style.css +40 -12
  528. package/dist/kolibri/assets/table-simulation.js +1 -1
  529. package/dist/kolibri/assets/tabler-icons/fonts/tabler-icons.eot +0 -0
  530. package/dist/kolibri/assets/tabler-icons/fonts/tabler-icons.ttf +0 -0
  531. package/dist/kolibri/assets/tabler-icons/fonts/tabler-icons.woff +0 -0
  532. package/dist/kolibri/assets/tabler-icons/fonts/tabler-icons.woff2 +0 -0
  533. package/dist/kolibri/assets/tabler-icons/tabler-icons.css +16056 -0
  534. package/dist/kolibri/assets/tabler-icons/tabler-icons.html +36226 -0
  535. package/dist/kolibri/assets/tabler-icons/tabler-icons.min.css +4 -0
  536. package/dist/kolibri/assets/tabler-icons/tabler-icons.png +0 -0
  537. package/dist/kolibri/assets/tabler-icons/tabler-icons.scss +8058 -0
  538. package/dist/kolibri/assets/toast-simulation.js +1 -1
  539. package/dist/kolibri/assets/tooltip-simulation.js +1 -0
  540. package/dist/kolibri/button-link-0f3cba87.js +4 -0
  541. package/dist/kolibri/button-link-0f3cba87.js.map +1 -0
  542. package/dist/kolibri/color-a8bae36b.js +4 -0
  543. package/dist/kolibri/color-a8bae36b.js.map +1 -0
  544. package/dist/kolibri/controller-0b0c0e12.js +4 -0
  545. package/dist/kolibri/controller-29e1bd76.js +4 -0
  546. package/dist/kolibri/controller-29e1bd76.js.map +1 -0
  547. package/dist/kolibri/controller-37d0d40b.js +4 -0
  548. package/dist/kolibri/controller-37d0d40b.js.map +1 -0
  549. package/dist/kolibri/{controller-ea28fcf8.js → controller-38789301.js} +1 -1
  550. package/dist/kolibri/controller-38789301.js.map +1 -0
  551. package/dist/kolibri/{controller-32fdeebb.js → controller-873db1b1.js} +1 -1
  552. package/dist/kolibri/controller-873db1b1.js.map +1 -0
  553. package/dist/kolibri/{controller-04bee517.js → controller-c5b419c7.js} +1 -1
  554. package/dist/kolibri/controller-c5b419c7.js.map +1 -0
  555. package/dist/kolibri/{controller-icon-2a9f5c13.js → controller-icon-6249a817.js} +1 -1
  556. package/dist/kolibri/controller-icon-6249a817.js.map +1 -0
  557. package/dist/kolibri/{dev.utils-05f4e663.js → dev.utils-157f0499.js} +1 -1
  558. package/dist/kolibri/dev.utils-157f0499.js.map +1 -0
  559. package/dist/kolibri/{devtools-640ace8d.js → devtools-cb70c2f9.js} +1 -1
  560. package/dist/kolibri/disabled-52196242.js +4 -0
  561. package/dist/kolibri/disabled-52196242.js.map +1 -0
  562. package/dist/kolibri/floating-ui.dom.esm-735f9fad.js +4 -0
  563. package/dist/kolibri/floating-ui.dom.esm-735f9fad.js.map +1 -0
  564. package/dist/kolibri/hide-label-3335b848.js +4 -0
  565. package/dist/kolibri/hide-label-3335b848.js.map +1 -0
  566. package/dist/kolibri/{i18n-8e14d822.js → i18n-cbc21d6e.js} +1 -1
  567. package/dist/kolibri/{icon-cab2d129.js → icon-00018c54.js} +1 -1
  568. package/dist/kolibri/icon-00018c54.js.map +1 -0
  569. package/dist/kolibri/index-50adf9a0.js.map +1 -1
  570. package/dist/kolibri/index-81bd9b41.js +4 -0
  571. package/dist/kolibri/index-81bd9b41.js.map +1 -0
  572. package/dist/kolibri/index-fef6600b.js +4 -0
  573. package/dist/kolibri/index-fef6600b.js.map +1 -0
  574. package/dist/kolibri/index.esm.js +1 -1
  575. package/dist/kolibri/kol-abbr.entry.js +1 -1
  576. package/dist/kolibri/kol-abbr.entry.js.map +1 -1
  577. package/dist/kolibri/kol-accordion.entry.js +1 -1
  578. package/dist/kolibri/kol-accordion.entry.js.map +1 -1
  579. package/dist/kolibri/kol-alert-wc_2.entry.js +4 -0
  580. package/dist/kolibri/kol-alert-wc_2.entry.js.map +1 -0
  581. package/dist/kolibri/kol-alert.entry.js +1 -1
  582. package/dist/kolibri/kol-alert.entry.js.map +1 -1
  583. package/dist/kolibri/kol-badge.entry.js +1 -1
  584. package/dist/kolibri/kol-badge.entry.js.map +1 -1
  585. package/dist/kolibri/kol-breadcrumb.entry.js +1 -1
  586. package/dist/kolibri/kol-breadcrumb.entry.js.map +1 -1
  587. package/dist/kolibri/kol-button-group-wc.entry.js.map +1 -1
  588. package/dist/kolibri/kol-button-group.entry.js +1 -1
  589. package/dist/kolibri/kol-button-group.entry.js.map +1 -1
  590. package/dist/kolibri/kol-button-link.entry.js +1 -1
  591. package/dist/kolibri/kol-button-link.entry.js.map +1 -1
  592. package/dist/kolibri/kol-button-wc_3.entry.js +4 -0
  593. package/dist/kolibri/kol-button-wc_3.entry.js.map +1 -0
  594. package/dist/kolibri/kol-button.entry.js +1 -1
  595. package/dist/kolibri/kol-button.entry.js.map +1 -1
  596. package/dist/kolibri/kol-card.entry.js +1 -1
  597. package/dist/kolibri/kol-card.entry.js.map +1 -1
  598. package/dist/kolibri/kol-details.entry.js +1 -1
  599. package/dist/kolibri/kol-details.entry.js.map +1 -1
  600. package/dist/kolibri/kol-form.entry.js +1 -1
  601. package/dist/kolibri/kol-form.entry.js.map +1 -1
  602. package/dist/kolibri/kol-heading.entry.js +1 -1
  603. package/dist/kolibri/kol-heading.entry.js.map +1 -1
  604. package/dist/kolibri/kol-icon-font-awesome.entry.js.map +1 -1
  605. package/dist/kolibri/kol-icon-icofont.entry.js.map +1 -1
  606. package/dist/kolibri/kol-icon.entry.js +1 -1
  607. package/dist/kolibri/kol-icon.entry.js.map +1 -1
  608. package/dist/kolibri/kol-image.entry.js +1 -1
  609. package/dist/kolibri/kol-image.entry.js.map +1 -1
  610. package/dist/kolibri/kol-indented-text.entry.js +1 -1
  611. package/dist/kolibri/kol-indented-text.entry.js.map +1 -1
  612. package/dist/kolibri/kol-input-adapter-leanup.entry.js +1 -1
  613. package/dist/kolibri/kol-input-checkbox.entry.js +1 -1
  614. package/dist/kolibri/kol-input-checkbox.entry.js.map +1 -1
  615. package/dist/kolibri/kol-input-color.entry.js +1 -1
  616. package/dist/kolibri/kol-input-color.entry.js.map +1 -1
  617. package/dist/kolibri/kol-input-date.entry.js +1 -1
  618. package/dist/kolibri/kol-input-date.entry.js.map +1 -1
  619. package/dist/kolibri/kol-input-email.entry.js +1 -1
  620. package/dist/kolibri/kol-input-email.entry.js.map +1 -1
  621. package/dist/kolibri/kol-input-file.entry.js +1 -1
  622. package/dist/kolibri/kol-input-file.entry.js.map +1 -1
  623. package/dist/kolibri/kol-input-number.entry.js +1 -1
  624. package/dist/kolibri/kol-input-number.entry.js.map +1 -1
  625. package/dist/kolibri/kol-input-password.entry.js +1 -1
  626. package/dist/kolibri/kol-input-password.entry.js.map +1 -1
  627. package/dist/kolibri/kol-input-radio-group.entry.js +1 -1
  628. package/dist/kolibri/kol-input-radio-group.entry.js.map +1 -1
  629. package/dist/kolibri/kol-input-radio.entry.js +1 -1
  630. package/dist/kolibri/kol-input-radio.entry.js.map +1 -1
  631. package/dist/kolibri/kol-input-range.entry.js +1 -1
  632. package/dist/kolibri/kol-input-range.entry.js.map +1 -1
  633. package/dist/kolibri/kol-input-text.entry.js +1 -1
  634. package/dist/kolibri/kol-input-text.entry.js.map +1 -1
  635. package/dist/kolibri/kol-kolibri.entry.js +1 -1
  636. package/dist/kolibri/kol-kolibri.entry.js.map +1 -1
  637. package/dist/kolibri/kol-link-button.entry.js +1 -1
  638. package/dist/kolibri/kol-link-button.entry.js.map +1 -1
  639. package/dist/kolibri/kol-link-group.entry.js +1 -1
  640. package/dist/kolibri/kol-link-group.entry.js.map +1 -1
  641. package/dist/kolibri/kol-link-wc.entry.js +1 -1
  642. package/dist/kolibri/kol-link-wc.entry.js.map +1 -1
  643. package/dist/kolibri/kol-link.entry.js +1 -1
  644. package/dist/kolibri/kol-link.entry.js.map +1 -1
  645. package/dist/kolibri/kol-logo.entry.js +1 -1
  646. package/dist/kolibri/kol-logo.entry.js.map +1 -1
  647. package/dist/kolibri/kol-modal.entry.js +1 -1
  648. package/dist/kolibri/kol-modal.entry.js.map +1 -1
  649. package/dist/kolibri/kol-nav.entry.js +1 -1
  650. package/dist/kolibri/kol-nav.entry.js.map +1 -1
  651. package/dist/kolibri/kol-pagination.entry.js +1 -1
  652. package/dist/kolibri/kol-pagination.entry.js.map +1 -1
  653. package/dist/kolibri/kol-popover.entry.js +4 -0
  654. package/dist/kolibri/kol-popover.entry.js.map +1 -0
  655. package/dist/kolibri/kol-progress.entry.js +1 -1
  656. package/dist/kolibri/kol-progress.entry.js.map +1 -1
  657. package/dist/kolibri/kol-quote.entry.js +4 -0
  658. package/dist/kolibri/kol-quote.entry.js.map +1 -0
  659. package/dist/kolibri/kol-select.entry.js +1 -1
  660. package/dist/kolibri/kol-select.entry.js.map +1 -1
  661. package/dist/kolibri/kol-skip-nav.entry.js +1 -1
  662. package/dist/kolibri/kol-skip-nav.entry.js.map +1 -1
  663. package/dist/kolibri/kol-span.entry.js +1 -1
  664. package/dist/kolibri/kol-span.entry.js.map +1 -1
  665. package/dist/kolibri/kol-spin.entry.js +1 -1
  666. package/dist/kolibri/kol-spin.entry.js.map +1 -1
  667. package/dist/kolibri/kol-split-button.entry.js +4 -0
  668. package/dist/kolibri/kol-split-button.entry.js.map +1 -0
  669. package/dist/kolibri/kol-symbol.entry.js +1 -1
  670. package/dist/kolibri/kol-symbol.entry.js.map +1 -1
  671. package/dist/kolibri/kol-table.entry.js +1 -1
  672. package/dist/kolibri/kol-table.entry.js.map +1 -1
  673. package/dist/kolibri/kol-tabs.entry.js +1 -1
  674. package/dist/kolibri/kol-tabs.entry.js.map +1 -1
  675. package/dist/kolibri/kol-textarea.entry.js +1 -1
  676. package/dist/kolibri/kol-textarea.entry.js.map +1 -1
  677. package/dist/kolibri/kol-toast.entry.js +1 -1
  678. package/dist/kolibri/kol-toast.entry.js.map +1 -1
  679. package/dist/kolibri/kol-tooltip.entry.js +1 -1
  680. package/dist/kolibri/kol-tooltip.entry.js.map +1 -1
  681. package/dist/kolibri/kol-version.entry.js +1 -1
  682. package/dist/kolibri/kol-version.entry.js.map +1 -1
  683. package/dist/kolibri/kolibri.esm.js +1 -1
  684. package/dist/kolibri/kolibri.esm.js.map +1 -1
  685. package/dist/kolibri/label-d51b1a57.js +4 -0
  686. package/dist/kolibri/label-d51b1a57.js.map +1 -0
  687. package/dist/kolibri/prop.validators-e402ad49.js +4 -0
  688. package/dist/kolibri/prop.validators-e402ad49.js.map +1 -0
  689. package/dist/kolibri/reuse-3a02afb9.js.map +1 -0
  690. package/dist/kolibri/show-c455f9fd.js +4 -0
  691. package/dist/kolibri/show-c455f9fd.js.map +1 -0
  692. package/dist/kolibri/tab-index-63d1379d.js +4 -0
  693. package/dist/kolibri/validation-a42d9cc9.js +4 -0
  694. package/dist/kolibri/{validation-d9821b54.js.map → validation-a42d9cc9.js.map} +1 -1
  695. package/dist/kolibri/validation-ab9a6c0d.js +4 -0
  696. package/dist/kolibri/validation-ab9a6c0d.js.map +1 -0
  697. package/dist/loader/index.d.ts +1 -1
  698. package/dist/types/components/@deprecated/input/controller.d.ts +4 -0
  699. package/dist/types/components/abbr/component.d.ts +3 -14
  700. package/dist/types/components/abbr/test/html.mock.d.ts +1 -1
  701. package/dist/types/components/abbr/types.d.ts +14 -0
  702. package/dist/types/components/accordion/component.d.ts +2 -20
  703. package/dist/types/components/accordion/test/html.mock.d.ts +1 -1
  704. package/dist/types/components/accordion/types.d.ts +21 -0
  705. package/dist/types/components/alert/component.d.ts +2 -18
  706. package/dist/types/components/alert/shadow.d.ts +14 -0
  707. package/dist/types/components/alert/test/html.mock.d.ts +1 -1
  708. package/dist/types/components/alert/types.d.ts +24 -0
  709. package/dist/types/components/badge/component.d.ts +5 -8
  710. package/dist/types/components/breadcrumb/component.d.ts +5 -5
  711. package/dist/types/components/button/component.d.ts +2 -2
  712. package/dist/types/components/button/shadow.d.ts +2 -2
  713. package/dist/types/components/button/test/html.mock.d.ts +1 -1
  714. package/dist/types/components/button-link/component.d.ts +2 -2
  715. package/dist/types/components/card/component.d.ts +2 -2
  716. package/dist/types/components/form/controller.d.ts +2 -2
  717. package/dist/types/components/heading/component.d.ts +4 -4
  718. package/dist/types/components/heading/shadow.d.ts +1 -1
  719. package/dist/types/components/icon/component.d.ts +1 -1
  720. package/dist/types/components/image/test/html.mock.d.ts +2 -0
  721. package/dist/types/components/image/types.d.ts +1 -0
  722. package/dist/types/components/input/controller.d.ts +1 -1
  723. package/dist/types/components/input/types.d.ts +5 -8
  724. package/dist/types/components/input-checkbox/component.d.ts +2 -2
  725. package/dist/types/components/input-checkbox/controller.d.ts +1 -1
  726. package/dist/types/components/input-checkbox/types.d.ts +6 -9
  727. package/dist/types/components/input-color/component.d.ts +1 -1
  728. package/dist/types/components/input-date/component.d.ts +1 -1
  729. package/dist/types/components/input-date/types.d.ts +1 -1
  730. package/dist/types/components/input-email/component.d.ts +1 -1
  731. package/dist/types/components/input-email/types.d.ts +3 -2
  732. package/dist/types/components/input-file/component.d.ts +1 -1
  733. package/dist/types/components/input-number/component.d.ts +1 -1
  734. package/dist/types/components/input-number/types.d.ts +1 -0
  735. package/dist/types/components/input-password/component.d.ts +1 -1
  736. package/dist/types/components/input-password/types.d.ts +1 -0
  737. package/dist/types/components/input-radio/component.d.ts +1 -1
  738. package/dist/types/components/input-radio-group/component.d.ts +1 -1
  739. package/dist/types/components/input-range/component.d.ts +1 -1
  740. package/dist/types/components/input-text/component.d.ts +2 -2
  741. package/dist/types/components/input-text/controller.d.ts +2 -3
  742. package/dist/types/components/input-text/types.d.ts +3 -3
  743. package/dist/types/components/kolibri/component.d.ts +5 -3
  744. package/dist/types/components/link/component.d.ts +4 -8
  745. package/dist/types/components/link/shadow.d.ts +3 -2
  746. package/dist/types/components/link-button/component.d.ts +5 -12
  747. package/dist/types/components/link-group/component.d.ts +7 -7
  748. package/dist/types/components/modal/component.d.ts +0 -4
  749. package/dist/types/components/nav/component.d.ts +18 -19
  750. package/dist/types/components/nav/validation.d.ts +3 -3
  751. package/dist/types/components/pagination/component.d.ts +1 -1
  752. package/dist/types/components/popover/shadow.d.ts +37 -0
  753. package/dist/types/components/popover/test/html.mock.d.ts +4 -0
  754. package/dist/types/components/progress/component.d.ts +4 -1
  755. package/dist/types/components/quote/shadow.d.ts +15 -0
  756. package/dist/types/components/quote/test/html.mock.d.ts +6 -0
  757. package/dist/types/components/quote/types.d.ts +22 -0
  758. package/dist/types/components/select/component.d.ts +1 -1
  759. package/dist/types/components/select/types.d.ts +1 -0
  760. package/dist/types/components/skip-nav/component.d.ts +5 -5
  761. package/dist/types/components/split-button/component.d.ts +52 -0
  762. package/dist/types/components/split-button/types.d.ts +19 -0
  763. package/dist/types/components/tabs/component.d.ts +1 -1
  764. package/dist/types/components/textarea/component.d.ts +1 -1
  765. package/dist/types/components/textarea/types.d.ts +5 -6
  766. package/dist/types/components/toast/component.d.ts +3 -4
  767. package/dist/types/components/toast/toaster.d.ts +1 -1
  768. package/dist/types/components/tooltip/component.d.ts +1 -1
  769. package/dist/types/components.d.ts +722 -364
  770. package/dist/types/i18n.d.ts +1 -1
  771. package/dist/types/index.d.ts +1 -1
  772. package/dist/types/schema/index.d.ts +1 -1
  773. package/dist/types/types/button-link-text.d.ts +30 -0
  774. package/dist/types/types/button-link.d.ts +11 -29
  775. package/dist/types/types/icon.d.ts +10 -32
  776. package/dist/types/types/props/adjust-height.d.ts +5 -0
  777. package/dist/types/types/props/alert.d.ts +5 -0
  778. package/dist/types/types/props/alignment.d.ts +5 -0
  779. package/dist/types/types/props/aria-current.d.ts +6 -0
  780. package/dist/types/types/props/aria-expanded.d.ts +5 -0
  781. package/dist/types/types/props/aria-selected.d.ts +5 -0
  782. package/dist/types/types/props/checked.d.ts +5 -0
  783. package/dist/types/types/props/collapsible.d.ts +5 -0
  784. package/dist/types/types/props/color.d.ts +20 -0
  785. package/dist/types/types/props/compact.d.ts +5 -0
  786. package/dist/types/types/props/disabled.d.ts +5 -0
  787. package/dist/types/types/props/download.d.ts +5 -0
  788. package/dist/types/types/props/has-closer.d.ts +5 -0
  789. package/dist/types/types/props/has-compact-button.d.ts +5 -0
  790. package/dist/types/types/props/has-counter.d.ts +5 -0
  791. package/dist/types/types/props/has-footer.d.ts +5 -0
  792. package/dist/types/types/props/hide-label.d.ts +5 -0
  793. package/dist/types/{utils/validators → types/props}/icon.d.ts +6 -2
  794. package/dist/types/types/props/indeterminate.d.ts +5 -0
  795. package/dist/types/types/props/index.d.ts +1 -0
  796. package/dist/types/{utils/validators → types/props}/label.d.ts +7 -3
  797. package/dist/types/types/props/multiple.d.ts +5 -0
  798. package/dist/types/types/props/open.d.ts +5 -0
  799. package/dist/types/types/props/read-only.d.ts +5 -0
  800. package/dist/types/types/props/required.d.ts +5 -0
  801. package/dist/types/types/props/show.d.ts +6 -0
  802. package/dist/types/types/props/stealth.d.ts +5 -0
  803. package/dist/types/types/props/touched.d.ts +5 -0
  804. package/dist/types/utils/a11y.tipps.d.ts +1 -0
  805. package/dist/types/utils/prop.validators.d.ts +3 -3
  806. package/dist/types/utils/reuse.d.ts +1 -1
  807. package/dist/types/utils/validators/alignment.d.ts +1 -1
  808. package/doc/abbr.md +9 -34
  809. package/doc/accordion.md +51 -64
  810. package/doc/alert.md +20 -51
  811. package/doc/badge.md +21 -55
  812. package/doc/breadcrumb.md +14 -49
  813. package/doc/button-link.md +20 -47
  814. package/doc/button.md +45 -110
  815. package/doc/card.md +18 -94
  816. package/doc/components.md +3 -3
  817. package/doc/details.md +13 -35
  818. package/doc/form.md +4 -4
  819. package/doc/heading.md +20 -13
  820. package/doc/icon-font-awesome.md +3 -3
  821. package/doc/icon-icofont.md +2 -2
  822. package/doc/icon.md +23 -20
  823. package/doc/image.md +27 -20
  824. package/doc/indented-text.md +1 -32
  825. package/doc/input-adapter-leanup.md +5 -6
  826. package/doc/input-checkbox.md +33 -55
  827. package/doc/input-color.md +34 -63
  828. package/doc/input-date.md +33 -62
  829. package/doc/input-email.md +34 -59
  830. package/doc/input-file.md +28 -52
  831. package/doc/input-number.md +34 -89
  832. package/doc/input-password.md +29 -55
  833. package/doc/input-radio-group.md +20 -21
  834. package/doc/input-radio.md +42 -50
  835. package/doc/input-range.md +28 -57
  836. package/doc/input-text.md +37 -65
  837. package/doc/kolibri.md +17 -37
  838. package/doc/link-button.md +23 -56
  839. package/doc/link-group.md +21 -48
  840. package/doc/link.md +40 -96
  841. package/doc/logo.md +6 -35
  842. package/doc/modal.md +38 -82
  843. package/doc/nav.md +57 -75
  844. package/doc/pagination.md +27 -58
  845. package/doc/popover.md +19 -0
  846. package/doc/progress.md +13 -35
  847. package/doc/quote.md +52 -0
  848. package/doc/select.md +52 -76
  849. package/doc/skip-nav.md +14 -45
  850. package/doc/span.md +5 -30
  851. package/doc/spin.md +5 -31
  852. package/doc/split-button.md +83 -0
  853. package/doc/table.md +16 -94
  854. package/doc/tabs.md +28 -67
  855. package/doc/textarea.md +33 -60
  856. package/doc/toast.md +27 -46
  857. package/doc/tooltip.md +10 -37
  858. package/doc/version.md +6 -34
  859. package/jest-test-results.json +1 -1
  860. package/package.json +3 -2
  861. package/vscode-custom-data.json +469 -179
  862. package/dist/cjs/a11y.tipps-4af0092d.js +0 -4
  863. package/dist/cjs/a11y.tipps-4af0092d.js.map +0 -1
  864. package/dist/cjs/button-link-89ed5382.js.map +0 -1
  865. package/dist/cjs/controller-2405dd04.js.map +0 -1
  866. package/dist/cjs/controller-8e2cebc1.js +0 -4
  867. package/dist/cjs/controller-8e2cebc1.js.map +0 -1
  868. package/dist/cjs/controller-94b357a3.js.map +0 -1
  869. package/dist/cjs/controller-d0743a95.js.map +0 -1
  870. package/dist/cjs/controller-dbbddbe7.js +0 -4
  871. package/dist/cjs/controller-dbbddbe7.js.map +0 -1
  872. package/dist/cjs/controller-icon-b87565c4.js.map +0 -1
  873. package/dist/cjs/icon-ccf4ad42.js.map +0 -1
  874. package/dist/cjs/index-1266b30d.js +0 -4
  875. package/dist/cjs/index-1266b30d.js.map +0 -1
  876. package/dist/cjs/index-e9fcaeca.js +0 -4
  877. package/dist/cjs/index-e9fcaeca.js.map +0 -1
  878. package/dist/cjs/index-ecda65e0.js +0 -4
  879. package/dist/cjs/index-ecda65e0.js.map +0 -1
  880. package/dist/cjs/kol-button-wc_2.cjs.entry.js +0 -4
  881. package/dist/cjs/kol-button-wc_2.cjs.entry.js.map +0 -1
  882. package/dist/cjs/kol-heading-wc_2.cjs.entry.js +0 -4
  883. package/dist/cjs/kol-heading-wc_2.cjs.entry.js.map +0 -1
  884. package/dist/cjs/label-ce9fe285.js +0 -4
  885. package/dist/cjs/label-ce9fe285.js.map +0 -1
  886. package/dist/cjs/prop.validators-69d5cf89.js +0 -4
  887. package/dist/cjs/prop.validators-69d5cf89.js.map +0 -1
  888. package/dist/cjs/reuse-bbd0b4e7.js +0 -4
  889. package/dist/cjs/validation-1e8663e2.js.map +0 -1
  890. package/dist/cjs/validation-2b3c81d9.js +0 -4
  891. package/dist/components/index2.js +0 -4
  892. package/dist/components/index2.js.map +0 -1
  893. package/dist/esm/a11y.tipps-5cdbd5e2.js +0 -4
  894. package/dist/esm/a11y.tipps-5cdbd5e2.js.map +0 -1
  895. package/dist/esm/app-globals-81f5e91d.js +0 -4
  896. package/dist/esm/button-link-3d1888e3.js.map +0 -1
  897. package/dist/esm/controller-04bee517.js.map +0 -1
  898. package/dist/esm/controller-32fdeebb.js +0 -4
  899. package/dist/esm/controller-32fdeebb.js.map +0 -1
  900. package/dist/esm/controller-944c3e03.js +0 -4
  901. package/dist/esm/controller-944c3e03.js.map +0 -1
  902. package/dist/esm/controller-9926eaee.js.map +0 -1
  903. package/dist/esm/controller-ea28fcf8.js.map +0 -1
  904. package/dist/esm/controller-icon-2a9f5c13.js.map +0 -1
  905. package/dist/esm/icon-cab2d129.js.map +0 -1
  906. package/dist/esm/index-4f2a12cc.js +0 -4
  907. package/dist/esm/index-4f2a12cc.js.map +0 -1
  908. package/dist/esm/index-676dbf61.js +0 -4
  909. package/dist/esm/index-676dbf61.js.map +0 -1
  910. package/dist/esm/index-d14da386.js +0 -4
  911. package/dist/esm/index-d14da386.js.map +0 -1
  912. package/dist/esm/kol-button-wc_2.entry.js +0 -4
  913. package/dist/esm/kol-button-wc_2.entry.js.map +0 -1
  914. package/dist/esm/kol-heading-wc_2.entry.js +0 -4
  915. package/dist/esm/kol-heading-wc_2.entry.js.map +0 -1
  916. package/dist/esm/label-ea9f2a1a.js +0 -4
  917. package/dist/esm/label-ea9f2a1a.js.map +0 -1
  918. package/dist/esm/prop.validators-769a843a.js +0 -4
  919. package/dist/esm/prop.validators-769a843a.js.map +0 -1
  920. package/dist/esm/validation-d9821b54.js +0 -4
  921. package/dist/esm/validation-f13f1eed.js +0 -4
  922. package/dist/esm/validation-f13f1eed.js.map +0 -1
  923. package/dist/kolibri/a11y.tipps-5cdbd5e2.js +0 -4
  924. package/dist/kolibri/a11y.tipps-5cdbd5e2.js.map +0 -1
  925. package/dist/kolibri/app-globals-81f5e91d.js +0 -4
  926. package/dist/kolibri/button-link-3d1888e3.js +0 -4
  927. package/dist/kolibri/button-link-3d1888e3.js.map +0 -1
  928. package/dist/kolibri/controller-04bee517.js.map +0 -1
  929. package/dist/kolibri/controller-32fdeebb.js.map +0 -1
  930. package/dist/kolibri/controller-5bd06546.js +0 -4
  931. package/dist/kolibri/controller-944c3e03.js +0 -4
  932. package/dist/kolibri/controller-944c3e03.js.map +0 -1
  933. package/dist/kolibri/controller-9926eaee.js +0 -4
  934. package/dist/kolibri/controller-9926eaee.js.map +0 -1
  935. package/dist/kolibri/controller-ea28fcf8.js.map +0 -1
  936. package/dist/kolibri/controller-icon-2a9f5c13.js.map +0 -1
  937. package/dist/kolibri/dev.utils-05f4e663.js.map +0 -1
  938. package/dist/kolibri/icon-cab2d129.js.map +0 -1
  939. package/dist/kolibri/index-4f2a12cc.js +0 -4
  940. package/dist/kolibri/index-4f2a12cc.js.map +0 -1
  941. package/dist/kolibri/index-676dbf61.js +0 -4
  942. package/dist/kolibri/index-676dbf61.js.map +0 -1
  943. package/dist/kolibri/index-d14da386.js +0 -4
  944. package/dist/kolibri/index-d14da386.js.map +0 -1
  945. package/dist/kolibri/kol-button-wc_2.entry.js +0 -4
  946. package/dist/kolibri/kol-button-wc_2.entry.js.map +0 -1
  947. package/dist/kolibri/kol-heading-wc_2.entry.js +0 -4
  948. package/dist/kolibri/kol-heading-wc_2.entry.js.map +0 -1
  949. package/dist/kolibri/label-ea9f2a1a.js +0 -4
  950. package/dist/kolibri/label-ea9f2a1a.js.map +0 -1
  951. package/dist/kolibri/prop.validators-769a843a.js +0 -4
  952. package/dist/kolibri/prop.validators-769a843a.js.map +0 -1
  953. package/dist/kolibri/reuse-56bb5a4b.js.map +0 -1
  954. package/dist/kolibri/tab-index-22c62334.js +0 -4
  955. package/dist/kolibri/validation-d9821b54.js +0 -4
  956. package/dist/kolibri/validation-f13f1eed.js +0 -4
  957. package/dist/kolibri/validation-f13f1eed.js.map +0 -1
  958. package/dist/types/types/alert.d.ts +0 -6
  959. /package/dist/kolibri/{app-globals-81f5e91d.js.map → app-globals-e0ff5b32.js.map} +0 -0
  960. /package/dist/kolibri/{controller-5bd06546.js.map → controller-0b0c0e12.js.map} +0 -0
  961. /package/dist/kolibri/{devtools-640ace8d.js.map → devtools-cb70c2f9.js.map} +0 -0
  962. /package/dist/kolibri/{i18n-8e14d822.js.map → i18n-cbc21d6e.js.map} +0 -0
  963. /package/dist/kolibri/{reuse-56bb5a4b.js → reuse-3a02afb9.js} +0 -0
  964. /package/dist/kolibri/{tab-index-22c62334.js.map → tab-index-63d1379d.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"names":["KolLinkWc","this","nonce","catchRef","ref","propergateFocus","host","onClick","event","_a","state","_on","preventDefault","setEventTargetAndStopPropagation","_b","_href","getRenderValues","goToProps","_selector","role","tabIndex","scrollBySelector","onKeyPress","isExternal","_target","tagAttrs","href","length","target","undefined","rel","_useCase","_iconOnly","_ariaLabel","devHint","translate","_icon","_label","render","h","Host","Object","assign","_ariaControls","_ariaCurrent","mapBoolean2String","_ariaExpanded","_ariaSelected","class","disabled","_disabled","_stealth","_role","_tabIndex","name","slot","_targetDescription","_align","_tooltipAlign","_id","validateAriaControls","value","watchString","validateAriaCurrent","watchValidator","Set","validateAriaExpanded","watchBoolean","validateAriaLabel","validateAriaLabelWithLabel","validateAriaSelected","validateDisabled","a11yHintDisabled","validateHref","validateIcon","validateIconAlign","watchIconAlign","validateIconOnly","validateLabel","validateLabelWithAriaLabel","validateOn","prototype","hasOwnProperty","call","validateRole","validateSelector","validateStealth","validateTabIndex","validateTarget","validateTargetDescription","validateTooltipAlign","watchTooltipAlignment","validateUseCase","componentWillLoad","_iconAlign"],"sources":["./src/components/link/component.tsx"],"sourcesContent":["import { Component, Element, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { Generic } from '@a11y-ui/core';\nimport { translate } from '../../i18n';\nimport {\n\tAlternativButtonLinkRole,\n\tAriaCurrent,\n\tLinkOnCallbacks,\n\tLinkStates,\n\tLinkTarget,\n\tLinkUseCase,\n\tOptionalLinkProps,\n\tOptionalLinkStates,\n\tRequiredLinkProps,\n\tRequiredLinkStates,\n\twatchTooltipAlignment,\n} from '../../types/button-link';\nimport { Stringified } from '../../types/common';\nimport { KoliBriIconProp } from '../../types/icon';\nimport { Alignment } from '../../types/props/alignment';\nimport { a11yHintDisabled, devHint } from '../../utils/a11y.tipps';\nimport { nonce } from '../../utils/dev.utils';\nimport { mapBoolean2String, scrollBySelector, setEventTargetAndStopPropagation, watchBoolean, watchString, watchValidator } from '../../utils/prop.validators';\nimport { propergateFocus } from '../../utils/reuse';\nimport { validateIcon, watchIconAlign } from '../../utils/validators/icon';\nimport { validateAriaLabelWithLabel, validateLabelWithAriaLabel } from '../../utils/validators/label';\nimport { validateTabIndex } from '../../utils/validators/tab-index';\n\ntype RequiredNavLinkProps = RequiredLinkProps;\ntype OptionalNavLinkProps = OptionalLinkProps & {\n\tactive: boolean;\n};\nexport type NavLinkProps = Generic.Element.Members<RequiredNavLinkProps, OptionalNavLinkProps>;\n\n/**\n * @internal\n */\n@Component({\n\ttag: 'kol-link-wc',\n\tshadow: false,\n})\nexport class KolLinkWc implements Generic.Element.ComponentApi<RequiredLinkProps, OptionalLinkProps, RequiredLinkStates, OptionalLinkStates> {\n\t@Element() private readonly host?: HTMLKolLinkWcElement;\n\tprivate readonly nonce = nonce();\n\tprivate ref?: HTMLAnchorElement;\n\n\tprivate readonly catchRef = (ref?: HTMLAnchorElement) => {\n\t\tthis.ref = ref;\n\t\tpropergateFocus(this.host, this.ref);\n\t};\n\n\tprivate readonly onClick = (event: Event) => {\n\t\tif (typeof this.state._on?.onClick === 'function') {\n\t\t\tevent.preventDefault();\n\t\t\tsetEventTargetAndStopPropagation(event, this.ref);\n\t\t\tthis.state._on?.onClick(event, this.state._href);\n\t\t}\n\t};\n\n\tprivate readonly getRenderValues = () => {\n\t\t/**\n\t\t * DX\n\t\t * Das möchte ich ungern für HTML machen, sondern nur für Barrierefreiheitsthemen.\n\t\t */\n\t\t// if (typeof this.state._href === 'string' && this.state._href.length > 0) {\n\t\t// console.error('Setz den URL.');\n\t\t// throw new Error('Setz den URL.');\n\t\t// }\n\n\t\t// switch (this.state._target) {\n\t\t// case '_blank':\n\t\t// case '_self':\n\t\t// break;\n\t\t// default:\n\t\t// console.error('Fehlerhaftes Target.');\n\t\t// throw new Error('Fehlerhaftes Target.');\n\t\t// }\n\n\t\t// ROBUSTHEIT durch Validierung\n\t\tlet goToProps = {};\n\t\tif (typeof this.state._selector === 'string') {\n\t\t\tgoToProps = {\n\t\t\t\trole: 'link',\n\t\t\t\ttabIndex: 0,\n\t\t\t\tonClick: () => {\n\t\t\t\t\tscrollBySelector(this.state._selector as string);\n\t\t\t\t},\n\t\t\t\tonKeyPress: () => {\n\t\t\t\t\tscrollBySelector(this.state._selector as string);\n\t\t\t\t},\n\t\t\t};\n\t\t}\n\n\t\tconst isExternal = typeof this.state._target === 'string' && this.state._target !== '_self';\n\n\t\tconst tagAttrs = {\n\t\t\thref: typeof this.state._href === 'string' && this.state._href.length > 0 ? this.state._href : 'javascript:void(0)',\n\t\t\ttarget: typeof this.state._target === 'string' && this.state._target.length > 0 ? this.state._target : undefined,\n\t\t\trel: isExternal ? 'noopener' : undefined,\n\t\t};\n\n\t\tif (\n\t\t\t(this.state._useCase === 'image' || this.state._iconOnly === true) &&\n\t\t\t(typeof this.state._ariaLabel !== 'string' || this.state._ariaLabel.length === 0)\n\t\t) {\n\t\t\tdevHint(`[KolLink] Es muss ein Aria-Label gesetzt werden, wenn eine Grafik verlinkt oder der Icon-Only-Modus verwendet wird.`);\n\t\t}\n\t\treturn { isExternal, tagAttrs, goToProps };\n\t};\n\n\tpublic render(): JSX.Element {\n\t\tconst { isExternal, tagAttrs, goToProps } = this.getRenderValues();\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t<a\n\t\t\t\t\tref={this.catchRef}\n\t\t\t\t\t{...tagAttrs}\n\t\t\t\t\taria-controls={this.state._ariaControls}\n\t\t\t\t\taria-current={this.state._ariaCurrent}\n\t\t\t\t\taria-expanded={mapBoolean2String(this.state._ariaExpanded)}\n\t\t\t\t\taria-labelledby={this.state._useCase === 'image' || this.state._iconOnly === true ? this.nonce : undefined}\n\t\t\t\t\taria-selected={mapBoolean2String(this.state._ariaSelected)}\n\t\t\t\t\tclass={{\n\t\t\t\t\t\tdisabled: this.state._disabled === true,\n\t\t\t\t\t\t'skip ': this.state._stealth !== false,\n\t\t\t\t\t\t'icon-only': this.state._iconOnly === true,\n\t\t\t\t\t\t'external-link': isExternal,\n\t\t\t\t\t}}\n\t\t\t\t\t{...this.state._on}\n\t\t\t\t\t// https://github.com/jsx-eslint/eslint-plugin-jsx-a11y/blob/main/docs/rules/click-events-have-key-events.md\n\t\t\t\t\tonClick={this.onClick}\n\t\t\t\t\tonKeyPress={this.onClick}\n\t\t\t\t\t{...goToProps}\n\t\t\t\t\trole={this.state._role}\n\t\t\t\t\ttabIndex={this.state._tabIndex}\n\t\t\t\t>\n\t\t\t\t\t<kol-span-wc _icon={this._icon} _iconOnly={this._iconOnly} _label={this.state._label}>\n\t\t\t\t\t\t{/*\n\t\t\t\t\t\t\tEs ist keine gute Idee hier einen Slot einzufügen, da dadurch ermöglicht wird,\n\t\t\t\t\t\t\tdie Unterstützung hinsichtlich der Barrierefreiheit der Komponente zu umgehen.\n\t\t\t\t\t\t*/}\n\t\t\t\t\t\t<slot name=\"expert\" slot=\"expert\" />\n\t\t\t\t\t</kol-span-wc>\n\t\t\t\t\t{isExternal && <kol-icon class=\"external-link-icon\" _ariaLabel={this.state._targetDescription as string} _icon={'codicon codicon-link-external'} />}\n\t\t\t\t</a>\n\t\t\t\t{(this.state._iconOnly === true || this.state._useCase === 'image') && (\n\t\t\t\t\t<kol-tooltip\n\t\t\t\t\t\t/**\n\t\t\t\t\t\t * Dieses Aria-Hidden verhindert das doppelte Vorlesen des Labels,\n\t\t\t\t\t\t * verhindert aber nicht das Aria-Labelledby vorgelesen wird.\n\t\t\t\t\t\t */\n\t\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\t\t_align={this.state._tooltipAlign}\n\t\t\t\t\t\t_id={this.nonce}\n\t\t\t\t\t\t_label={this.state._ariaLabel || this.state._label}\n\t\t\t\t\t></kol-tooltip>\n\t\t\t\t)}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Gibt an, welche Elemente kontrolliert werden. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-controls)\n\t */\n\t@Prop() public _ariaControls?: string;\n\n\t/**\n\t * Gibt an, welchen aktuellen Auswahlstatus der Link hat. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)\n\t */\n\t@Prop() public _ariaCurrent?: AriaCurrent;\n\n\t/**\n\t * Gibt an, ob durch den Link etwas aufgeklappt wurde. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-expanded)\n\t */\n\t@Prop({ reflect: true }) public _ariaExpanded?: boolean;\n\n\t/**\n\t * Gibt einen beschreibenden Text des Links an. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-label)\n\t */\n\t@Prop() public _ariaLabel?: string;\n\n\t/**\n\t * Gibt an, ob Element ausgewählt ist (role=tab). (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-selected)\n\t */\n\t@Prop({ reflect: true }) public _ariaSelected?: boolean;\n\n\t/**\n\t * Gibt an, ob der Link deaktiviert ist.\n\t */\n\t@Prop({ reflect: true }) public _disabled?: boolean = false;\n\n\t/**\n\t * Gibt die Ziel-Url des Links an.\n\t */\n\t@Prop() public _href!: string;\n\n\t/**\n\t * Gibt den Class-Identifier eines Icons eine eingebunden Icofont an. (z.B. https://icofont.com/)\n\t */\n\t@Prop() public _icon?: Stringified<KoliBriIconProp>;\n\n\t/**\n\t * Gibt an, ob das Icon entweder links oder rechts dargestellt werden soll.\n\t *\n\t * @deprecated Wird durch das neue flexibleren Icon-Typ abgedeckt.\n\t */\n\t@Prop() public _iconAlign?: Alignment;\n\n\t/**\n\t * Gibt an, ob nur das Icon angezeigt wird.\n\t */\n\t@Prop({ reflect: true }) public _iconOnly?: boolean = false;\n\n\t/**\n\t * Gibt den Label für die Beschriftung der Schaltfläche an.\n\t */\n\t// - eslint-disable-next-line @stencil/strict-mutable\n\t@Prop({ mutable: true, reflect: false }) public _label!: string;\n\n\t/**\n\t * Gibt die EventCallback-Funktionen für den Link an.\n\t *\n\t * @deprecated Hierzu sollte statt Link- die ButtonLink-Komponente verwendet werden.\n\t */\n\t@Prop() public _on?: LinkOnCallbacks;\n\n\t/**\n\t * Gibt an, welche Role der Schalter hat.\n\t */\n\t@Prop() public _role?: AlternativButtonLinkRole;\n\n\t/**\n\t * Gibt die ID eines DOM-Elements, zu dem gesprungen werden soll, aus.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop() public _selector?: string;\n\n\t/**\n\t * Gibt an, ob der Link nur beim Fokus sichtbar ist.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop({ reflect: true }) public _stealth?: boolean = false;\n\n\t/**\n\t * Gibt an, welchen Tab-Index der Button hat. (https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex)\n\t */\n\t@Prop() public _tabIndex?: number;\n\n\t/**\n\t * Definiert das Verhalten, bei dem der Link geöffnet werden soll.\n\t */\n\t@Prop() public _target?: LinkTarget;\n\n\t/**\n\t * Gibt die Beschreibung an, wenn der Link in einem anderen Programm geöffnet wird.\n\t */\n\t@Prop() public _targetDescription?: string = translate('kol-open-link-in-tab');\n\n\t/**\n\t * Gibt an, ob der Tooltip entweder oben, rechts, unten oder links angezeigt werden soll.\n\t */\n\t@Prop() public _tooltipAlign?: Alignment = 'right';\n\n\t/**\n\t * Gibt den Verwendungsfall des Links an.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop() public _useCase?: LinkUseCase = 'text';\n\n\t/**\n\t * @see: components/abbr/component.tsx (@State)\n\t */\n\t@State() public state: LinkStates = {\n\t\t_href: 'javascript:void(0)',\n\t\t_icon: {},\n\t\t_label: '', // TODO: must removed to v2\n\t\t// _label: '…', // ⚠ required\n\t};\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_ariaControls')\n\tpublic validateAriaControls(value?: string): void {\n\t\twatchString(this, '_ariaControls', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_ariaCurrent')\n\tpublic validateAriaCurrent(value?: AriaCurrent): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_ariaCurrent',\n\t\t\t(value) => value === true || value === 'date' || value === 'location' || value === 'page' || value === 'step' || value === 'time',\n\t\t\tnew Set(['boolean', 'String {data, location, page, step, time}']),\n\t\t\tvalue\n\t\t);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_ariaExpanded')\n\tpublic validateAriaExpanded(value?: boolean): void {\n\t\twatchBoolean(this, '_ariaExpanded', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_ariaLabel')\n\tpublic validateAriaLabel(value?: string): void {\n\t\tvalidateAriaLabelWithLabel(this, value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_ariaSelected')\n\tpublic validateAriaSelected(value?: boolean): void {\n\t\twatchBoolean(this, '_ariaSelected', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_disabled')\n\tpublic validateDisabled(value?: boolean): void {\n\t\twatchBoolean(this, '_disabled', value);\n\t\tif (value === true) {\n\t\t\ta11yHintDisabled();\n\t\t}\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_href')\n\tpublic validateHref(value?: string): void {\n\t\twatchString(this, '_href', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_icon')\n\tpublic validateIcon(value?: KoliBriIconProp): void {\n\t\tvalidateIcon(this, value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t * @deprecated\n\t */\n\t@Watch('_iconAlign')\n\tpublic validateIconAlign(value?: Alignment): void {\n\t\twatchIconAlign(this, value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_iconOnly')\n\tpublic validateIconOnly(value?: boolean): void {\n\t\twatchBoolean(this, '_iconOnly', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_label')\n\tpublic validateLabel(value?: string): void {\n\t\tvalidateLabelWithAriaLabel(this, value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t * @deprecated\n\t */\n\t@Watch('_on')\n\tpublic validateOn(value?: LinkOnCallbacks): void {\n\t\tif (\n\t\t\ttypeof value === 'object' &&\n\t\t\tvalue !== null &&\n\t\t\t// https://eslint.org/docs/rules/no-prototype-builtins\n\t\t\tObject.prototype.hasOwnProperty.call(value, 'onClick') &&\n\t\t\ttypeof value.onClick === 'function'\n\t\t) {\n\t\t\tthis.state = {\n\t\t\t\t...this.state,\n\t\t\t\t_on: value,\n\t\t\t};\n\t\t}\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_role')\n\tpublic validateRole(value?: AlternativButtonLinkRole): void {\n\t\twatchString(this, '_role', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_selector')\n\tpublic validateSelector(value?: string): void {\n\t\twatchString(this, '_selector', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_stealth')\n\tpublic validateStealth(value?: boolean): void {\n\t\twatchBoolean(this, '_stealth', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_tabIndex')\n\tpublic validateTabIndex(value?: number): void {\n\t\tvalidateTabIndex(this, value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_target')\n\tpublic validateTarget(value?: LinkTarget): void {\n\t\twatchString(this, '_target', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_targetDescription')\n\tpublic validateTargetDescription(value?: string): void {\n\t\twatchString(this, '_targetDescription', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_tooltipAlign')\n\tpublic validateTooltipAlign(value?: Alignment): void {\n\t\twatchTooltipAlignment(this, '_tooltipAlign', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_useCase')\n\tpublic validateUseCase(value?: LinkUseCase): void {\n\t\tif (typeof value === 'string') {\n\t\t\tthis.state = {\n\t\t\t\t...this.state,\n\t\t\t\t_useCase: value,\n\t\t\t};\n\t\t}\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (componentWillLoad)\n\t */\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAriaControls(this._ariaControls);\n\t\tthis.validateAriaCurrent(this._ariaCurrent);\n\t\tthis.validateAriaExpanded(this._ariaExpanded);\n\t\tthis.validateAriaLabel(this._ariaLabel);\n\t\tthis.validateAriaSelected(this._ariaSelected);\n\t\tthis.validateDisabled(this._disabled);\n\t\tthis.validateHref(this._href);\n\t\tthis.validateIcon(this._icon);\n\t\tthis.validateIconAlign(this._iconAlign);\n\t\tthis.validateIconOnly(this._iconOnly);\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateOn(this._on);\n\t\tthis.validateRole(this._role);\n\t\tthis.validateSelector(this._selector);\n\t\tthis.validateStealth(this._stealth);\n\t\tthis.validateTabIndex(this._tabIndex);\n\t\tthis.validateTarget(this._target);\n\t\tthis.validateTargetDescription(this._targetDescription);\n\t\tthis.validateTooltipAlign(this._tooltipAlign);\n\t\tthis.validateUseCase(this._useCase);\n\t}\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["validateDownload","component","value","watchBoolean","watchString","validateStealth","KolLinkWc","this","nonce","catchRef","ref","propagateFocus","host","onClick","event","_a","state","_on","preventDefault","setEventTarget","_b","_href","getRenderValues","goToProps","_selector","role","tabIndex","scrollBySelector","onKeyPress","isExternal","_target","tagAttrs","href","length","target","undefined","rel","_useCase","_iconOnly","_ariaLabel","devHint","translate","_icon","_label","render","h","Host","Object","assign","_ariaControls","_ariaCurrent","mapBoolean2String","_ariaExpanded","_ariaSelected","class","disabled","_disabled","_stealth","_role","_tabIndex","name","slot","_targetDescription","_align","_tooltipAlign","_id","validateAriaControls","validateAriaCurrent","validateAriaExpanded","validateAriaLabel","validateAriaLabelWithLabel","validateAriaSelected","validateDisabled","a11yHintDisabled","validateHref","validateIcon","validateIconAlign","watchIconAlign","validateIconOnly","validateLabel","validateLabelWithAriaLabel","validateOn","prototype","hasOwnProperty","call","validateRole","validateSelector","validateTabIndex","validateTarget","validateTargetDescription","validateTooltipAlign","watchTooltipAlignment","validateUseCase","componentWillLoad","_download","_iconAlign"],"sources":["./src/types/props/download.ts","./src/types/props/stealth.ts","./src/components/link/component.tsx"],"sourcesContent":["import { Generic } from '@a11y-ui/core';\nimport { watchBoolean, watchString } from '../../utils/prop.validators';\n\n/* types */\n/** de\n * Teilt dem Browser mit, dass sich hinter dem Link eine Datei befindet. Setzt optional den Dateinamen.\n */\n/** en\n * Tells the browser that the link contains a file. Optionally sets the filename.\n */\nexport type PropDownload = {\n\tdownload?: boolean | string;\n};\n\n/* validator */\nexport const validateDownload = (component: Generic.Element.Component, value?: boolean | string): void => {\n\tif (typeof value === 'boolean') watchBoolean(component, '_download', value);\n\telse watchString(component, '_download', value);\n};\n","import { Generic } from '@a11y-ui/core';\nimport { watchBoolean } from '../../utils/prop.validators';\n\n/* types */\n/** de\n * Versteckt den Link und lässt ihn bei Fokussierung erscheinen.\n */\n/** en\n * Hides the link und makes it appear on focus.\n */\nexport type PropStealth = {\n\tstealth: boolean;\n};\n\n/* validator */\nexport const validateStealth = (component: Generic.Element.Component, value?: boolean): void => {\n\twatchBoolean(component, '_stealth', value);\n};\n","import { Component, Element, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { Generic } from '@a11y-ui/core';\nimport { translate } from '../../i18n';\nimport {\n\tAlternativButtonLinkRole,\n\tLinkOnCallbacks,\n\tLinkStates,\n\tLinkTarget,\n\tLinkUseCase,\n\tOptionalLinkProps,\n\tOptionalLinkStates,\n\tRequiredLinkProps,\n\tRequiredLinkStates,\n\twatchTooltipAlignment,\n} from '../../types/button-link';\nimport { Stringified } from '../../types/common';\nimport { KoliBriIconProp } from '../../types/icon';\nimport { AriaCurrent, Alignment, validateAriaCurrent, validateAriaSelected, validateStealth, validateDownload } from '../../types/props';\nimport { a11yHintDisabled, devHint } from '../../utils/a11y.tipps';\nimport { nonce } from '../../utils/dev.utils';\nimport { mapBoolean2String, scrollBySelector, setEventTarget, watchBoolean, watchString } from '../../utils/prop.validators';\nimport { propagateFocus } from '../../utils/reuse';\nimport { validateIcon, watchIconAlign } from '../../types/props/icon';\nimport { validateAriaLabelWithLabel, validateLabelWithAriaLabel } from '../../types/props/label';\nimport { validateTabIndex } from '../../utils/validators/tab-index';\n\n/**\n * @internal\n */\n@Component({\n\ttag: 'kol-link-wc',\n\tshadow: false,\n})\nexport class KolLinkWc implements Generic.Element.ComponentApi<RequiredLinkProps, OptionalLinkProps, RequiredLinkStates, OptionalLinkStates> {\n\t@Element() private readonly host?: HTMLKolLinkWcElement;\n\tprivate readonly nonce = nonce();\n\tprivate ref?: HTMLAnchorElement;\n\n\tprivate readonly catchRef = (ref?: HTMLAnchorElement) => {\n\t\tthis.ref = ref;\n\t\tpropagateFocus(this.host, this.ref);\n\t};\n\n\tprivate readonly onClick = (event: Event) => {\n\t\tif (typeof this.state._on?.onClick === 'function') {\n\t\t\tevent.preventDefault();\n\t\t\tsetEventTarget(event, this.ref);\n\t\t\tthis.state._on?.onClick(event, this.state._href);\n\t\t}\n\t};\n\n\tprivate readonly getRenderValues = () => {\n\t\t/**\n\t\t * DX\n\t\t * Das möchte ich ungern für HTML machen, sondern nur für Barrierefreiheitsthemen.\n\t\t */\n\t\t// if (typeof this.state._href === 'string' && this.state._href.length > 0) {\n\t\t// console.error('Setz den URL.');\n\t\t// throw new Error('Setz den URL.');\n\t\t// }\n\n\t\t// switch (this.state._target) {\n\t\t// case '_blank':\n\t\t// case '_self':\n\t\t// break;\n\t\t// default:\n\t\t// console.error('Fehlerhaftes Target.');\n\t\t// throw new Error('Fehlerhaftes Target.');\n\t\t// }\n\n\t\t// ROBUSTHEIT durch Validierung\n\t\tlet goToProps = {};\n\t\tif (typeof this.state._selector === 'string') {\n\t\t\tgoToProps = {\n\t\t\t\trole: 'link',\n\t\t\t\ttabIndex: 0,\n\t\t\t\tonClick: () => {\n\t\t\t\t\tscrollBySelector(this.state._selector as string);\n\t\t\t\t},\n\t\t\t\tonKeyPress: () => {\n\t\t\t\t\tscrollBySelector(this.state._selector as string);\n\t\t\t\t},\n\t\t\t};\n\t\t}\n\n\t\tconst isExternal = typeof this.state._target === 'string' && this.state._target !== '_self';\n\n\t\tconst tagAttrs = {\n\t\t\thref: typeof this.state._href === 'string' && this.state._href.length > 0 ? this.state._href : 'javascript:void(0)',\n\t\t\ttarget: typeof this.state._target === 'string' && this.state._target.length > 0 ? this.state._target : undefined,\n\t\t\trel: isExternal ? 'noopener' : undefined,\n\t\t};\n\n\t\tif (\n\t\t\t(this.state._useCase === 'image' || this.state._iconOnly === true) &&\n\t\t\t(typeof this.state._ariaLabel !== 'string' || this.state._ariaLabel.length === 0)\n\t\t) {\n\t\t\tdevHint(`[KolLink] Es muss ein Aria-Label gesetzt werden, wenn eine Grafik verlinkt oder der Icon-Only-Modus verwendet wird.`);\n\t\t}\n\t\treturn { isExternal, tagAttrs, goToProps };\n\t};\n\n\tpublic render(): JSX.Element {\n\t\tconst { isExternal, tagAttrs, goToProps } = this.getRenderValues();\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t<a\n\t\t\t\t\tref={this.catchRef}\n\t\t\t\t\t{...tagAttrs}\n\t\t\t\t\taria-controls={this.state._ariaControls}\n\t\t\t\t\taria-current={this.state._ariaCurrent}\n\t\t\t\t\taria-expanded={mapBoolean2String(this.state._ariaExpanded)}\n\t\t\t\t\taria-labelledby={this.state._useCase === 'image' || this.state._iconOnly === true ? this.nonce : undefined}\n\t\t\t\t\taria-selected={mapBoolean2String(this.state._ariaSelected)}\n\t\t\t\t\tclass={{\n\t\t\t\t\t\tdisabled: this.state._disabled === true,\n\t\t\t\t\t\t'skip ': this.state._stealth !== false,\n\t\t\t\t\t\t'icon-only': this.state._iconOnly === true,\n\t\t\t\t\t\t'external-link': isExternal,\n\t\t\t\t\t}}\n\t\t\t\t\t{...this.state._on}\n\t\t\t\t\t// https://github.com/jsx-eslint/eslint-plugin-jsx-a11y/blob/main/docs/rules/click-events-have-key-events.md\n\t\t\t\t\tonClick={this.onClick}\n\t\t\t\t\tonKeyPress={this.onClick}\n\t\t\t\t\t{...goToProps}\n\t\t\t\t\trole={this.state._role}\n\t\t\t\t\ttabIndex={this.state._tabIndex}\n\t\t\t\t>\n\t\t\t\t\t<kol-span-wc _icon={this._icon} _iconOnly={this._iconOnly} _label={this.state._label}>\n\t\t\t\t\t\t{/*\n\t\t\t\t\t\t\tEs ist keine gute Idee hier einen Slot einzufügen, da dadurch ermöglicht wird,\n\t\t\t\t\t\t\tdie Unterstützung hinsichtlich der Barrierefreiheit der Komponente zu umgehen.\n\t\t\t\t\t\t*/}\n\t\t\t\t\t\t<slot name=\"expert\" slot=\"expert\" />\n\t\t\t\t\t</kol-span-wc>\n\t\t\t\t\t{isExternal && <kol-icon class=\"external-link-icon\" _ariaLabel={this.state._targetDescription as string} _icon={'codicon codicon-link-external'} />}\n\t\t\t\t</a>\n\t\t\t\t{(this.state._iconOnly === true || this.state._useCase === 'image') && (\n\t\t\t\t\t<kol-tooltip\n\t\t\t\t\t\t/**\n\t\t\t\t\t\t * Dieses Aria-Hidden verhindert das doppelte Vorlesen des Labels,\n\t\t\t\t\t\t * verhindert aber nicht das Aria-Labelledby vorgelesen wird.\n\t\t\t\t\t\t */\n\t\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\t\t_align={this.state._tooltipAlign}\n\t\t\t\t\t\t_id={this.nonce}\n\t\t\t\t\t\t_label={this.state._ariaLabel || this.state._label}\n\t\t\t\t\t></kol-tooltip>\n\t\t\t\t)}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Gibt an, welche Elemente kontrolliert werden. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-controls)\n\t */\n\t@Prop() public _ariaControls?: string;\n\n\t/**\n\t * Gibt an, welchen aktuellen Auswahlstatus der Link hat. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)\n\t */\n\t@Prop() public _ariaCurrent?: AriaCurrent;\n\n\t/**\n\t * Gibt an, ob durch den Link etwas aufgeklappt wurde. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-expanded)\n\t */\n\t@Prop({ reflect: true }) public _ariaExpanded?: boolean;\n\n\t/**\n\t * Gibt einen beschreibenden Text des Links an. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-label)\n\t */\n\t@Prop() public _ariaLabel?: string;\n\n\t/**\n\t * Gibt an, ob Element ausgewählt ist (role=tab). (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-selected)\n\t */\n\t@Prop({ reflect: true }) public _ariaSelected?: boolean;\n\n\t/**\n\t * Gibt an, ob der Link deaktiviert ist.\n\t *\n\t * @deprecated Ein Link kann nicht deaktiviert werden, nutzen Sie den Button-Link stattdessen.\n\t */\n\t@Prop({ reflect: true }) public _disabled?: boolean = false;\n\n\t/**\n\t * Teilt dem Browser mit, dass sich hinter dem Link eine Datei befindet. Setzt optional den Dateinamen.\n\t */\n\t@Prop() public _download?: boolean | string = false;\n\n\t/**\n\t * Gibt die Ziel-Url des Links an.\n\t */\n\t@Prop() public _href!: string;\n\n\t/**\n\t * Iconklasse (z.B.: \"codicon codicon-home\")\n\t */\n\t@Prop() public _icon?: Stringified<KoliBriIconProp>;\n\n\t/**\n\t * Gibt an, ob das Icon entweder links oder rechts dargestellt werden soll.\n\t *\n\t * @deprecated Wird durch das neue flexibleren Icon-Typ abgedeckt.\n\t */\n\t@Prop() public _iconAlign?: Alignment;\n\n\t/**\n\t * Gibt an, ob nur das Icon angezeigt wird.\n\t */\n\t@Prop({ reflect: true }) public _iconOnly?: boolean = false;\n\n\t/**\n\t * Setzt den sichtbaren Text des Elements.\n\t */\n\t// - eslint-disable-next-line @stencil/strict-mutable\n\t@Prop({ mutable: true, reflect: false }) public _label!: string;\n\n\t/**\n\t * Gibt die EventCallback-Funktionen für den Link an.\n\t * @deprecated\n\t */\n\t@Prop() public _on?: LinkOnCallbacks;\n\n\t/**\n\t * Gibt an, welche Rolle der Schalter hat.\n\t */\n\t@Prop() public _role?: AlternativButtonLinkRole;\n\n\t/**\n\t * Gibt die ID eines DOM-Elements, zu dem gesprungen werden soll, aus.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop() public _selector?: string;\n\n\t/**\n\t * Gibt an, ob der Link nur beim Fokus sichtbar ist.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop({ reflect: true }) public _stealth?: boolean = false;\n\n\t/**\n\t * Gibt an, welchen Tab-Index der Button hat. (https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex)\n\t */\n\t@Prop() public _tabIndex?: number;\n\n\t/**\n\t * Gibt an wo der Link geöffnet werden soll.\n\t */\n\t@Prop() public _target?: LinkTarget;\n\n\t/**\n\t * Gibt die Beschreibung an, wenn der Link in einem anderen Programm geöffnet wird.\n\t */\n\t@Prop() public _targetDescription?: string = translate('kol-open-link-in-tab');\n\n\t/**\n\t * Gibt an, ob der Tooltip entweder oben, rechts, unten oder links angezeigt werden soll.\n\t */\n\t@Prop() public _tooltipAlign?: Alignment = 'right';\n\n\t/**\n\t * Gibt den Verwendungsfall des Links an.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop() public _useCase?: LinkUseCase = 'text';\n\n\t@State() public state: LinkStates = {\n\t\t_href: 'javascript:void(0)',\n\t\t_icon: {},\n\t\t_label: '', // TODO: must removed to v2\n\t\t// _label: '…', // ⚠ required\n\t};\n\n\t@Watch('_ariaControls')\n\tpublic validateAriaControls(value?: string): void {\n\t\twatchString(this, '_ariaControls', value);\n\t}\n\n\t@Watch('_ariaCurrent')\n\tpublic validateAriaCurrent(value?: AriaCurrent): void {\n\t\tvalidateAriaCurrent(this, value);\n\t}\n\n\t@Watch('_ariaExpanded')\n\tpublic validateAriaExpanded(value?: boolean): void {\n\t\twatchBoolean(this, '_ariaExpanded', value);\n\t}\n\n\t@Watch('_ariaLabel')\n\tpublic validateAriaLabel(value?: string): void {\n\t\tvalidateAriaLabelWithLabel(this, value);\n\t}\n\n\t@Watch('_ariaSelected')\n\tpublic validateAriaSelected(value?: boolean): void {\n\t\tvalidateAriaSelected(this, value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t *\n\t * @deprecated\n\t */\n\t@Watch('_disabled')\n\tpublic validateDisabled(value?: boolean): void {\n\t\twatchBoolean(this, '_disabled', value);\n\t\tif (value === true) {\n\t\t\ta11yHintDisabled();\n\t\t}\n\t}\n\n\t@Watch('_download')\n\tpublic validateDownload(value?: boolean | string): void {\n\t\tvalidateDownload(this, value);\n\t}\n\n\t@Watch('_href')\n\tpublic validateHref(value?: string): void {\n\t\twatchString(this, '_href', value);\n\t}\n\n\t@Watch('_icon')\n\tpublic validateIcon(value?: KoliBriIconProp): void {\n\t\tvalidateIcon(this, value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t * @deprecated\n\t */\n\t@Watch('_iconAlign')\n\tpublic validateIconAlign(value?: Alignment): void {\n\t\twatchIconAlign(this, value);\n\t}\n\n\t@Watch('_iconOnly')\n\tpublic validateIconOnly(value?: boolean): void {\n\t\twatchBoolean(this, '_iconOnly', value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: string): void {\n\t\tvalidateLabelWithAriaLabel(this, value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t * @deprecated\n\t */\n\t@Watch('_on')\n\tpublic validateOn(value?: LinkOnCallbacks): void {\n\t\tif (\n\t\t\ttypeof value === 'object' &&\n\t\t\tvalue !== null &&\n\t\t\t// https://eslint.org/docs/rules/no-prototype-builtins\n\t\t\tObject.prototype.hasOwnProperty.call(value, 'onClick') &&\n\t\t\ttypeof value.onClick === 'function'\n\t\t) {\n\t\t\tthis.state = {\n\t\t\t\t...this.state,\n\t\t\t\t_on: value,\n\t\t\t};\n\t\t}\n\t}\n\n\t@Watch('_role')\n\tpublic validateRole(value?: AlternativButtonLinkRole): void {\n\t\twatchString(this, '_role', value);\n\t}\n\n\t@Watch('_selector')\n\tpublic validateSelector(value?: string): void {\n\t\twatchString(this, '_selector', value);\n\t}\n\n\t@Watch('_stealth')\n\tpublic validateStealth(value?: boolean): void {\n\t\tvalidateStealth(this, value);\n\t}\n\n\t@Watch('_tabIndex')\n\tpublic validateTabIndex(value?: number): void {\n\t\tvalidateTabIndex(this, value);\n\t}\n\n\t@Watch('_target')\n\tpublic validateTarget(value?: LinkTarget): void {\n\t\twatchString(this, '_target', value);\n\t}\n\n\t@Watch('_targetDescription')\n\tpublic validateTargetDescription(value?: string): void {\n\t\twatchString(this, '_targetDescription', value);\n\t}\n\n\t@Watch('_tooltipAlign')\n\tpublic validateTooltipAlign(value?: Alignment): void {\n\t\twatchTooltipAlignment(this, '_tooltipAlign', value);\n\t}\n\n\t@Watch('_useCase')\n\tpublic validateUseCase(value?: LinkUseCase): void {\n\t\tif (typeof value === 'string') {\n\t\t\tthis.state = {\n\t\t\t\t...this.state,\n\t\t\t\t_useCase: value,\n\t\t\t};\n\t\t}\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAriaControls(this._ariaControls);\n\t\tthis.validateAriaCurrent(this._ariaCurrent);\n\t\tthis.validateAriaExpanded(this._ariaExpanded);\n\t\tthis.validateAriaLabel(this._ariaLabel);\n\t\tthis.validateAriaSelected(this._ariaSelected);\n\t\tthis.validateDisabled(this._disabled);\n\t\tthis.validateDownload(this._download);\n\t\tthis.validateHref(this._href);\n\t\tthis.validateIcon(this._icon);\n\t\tthis.validateIconAlign(this._iconAlign);\n\t\tthis.validateIconOnly(this._iconOnly);\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateOn(this._on);\n\t\tthis.validateRole(this._role);\n\t\tthis.validateSelector(this._selector);\n\t\tthis.validateStealth(this._stealth);\n\t\tthis.validateTabIndex(this._tabIndex);\n\t\tthis.validateTarget(this._target);\n\t\tthis.validateTargetDescription(this._targetDescription);\n\t\tthis.validateTooltipAlign(this._tooltipAlign);\n\t\tthis.validateUseCase(this._useCase);\n\t}\n}\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{r as i,h as e,H as o,g as t}from"./index-50adf9a0.js";import{a as n}from"./reuse-56bb5a4b.js";const r=":host{--kolibri-border-color:#666;--kolibri-border-radius:0.125rem;--kolibri-border-width:1px;--kolibri-color-black:#000;--kolibri-color-white:#fff;--kolibri-color-error:#f44336;--kolibri-color-info:#2196f3;--kolibri-color-success:#4caf50;--kolibri-color-warning:#ff9800;--kolibri-color-primary:#3f51b5;--kolibri-color-secondary:#ff4081;--kolibri-color-normal:#9e9e9e;--kolibri-color-danger:#f44336;--kolibri-color-ghost:#f5f5f5;--kolibri-color-disabled:#bdbdbd;--kolibri-color-text:#222222;--kolibri-color-visited:#9c27b0;--kolibri-font-family:Verdana, Arial, Tahoma, Helvetica, sans-serif;--kolibri-font-size:16px;--kolibri-spacing:0.25rem}:host *{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}:host{display:inline-flex}a,button{background-color:transparent;border:none;font-size:inherit;margin:0;padding:0;transition-duration:0.5s;transition-property:background-color, color, border-color;width:100%}kol-icon.external-link-icon{display:inline-flex}:host{font-family:var(--kolibri-font-family);font-size:var(--kolibri-font-size)}*{box-sizing:border-box}kol-span-wc{display:grid;gap:var(--kolibri-spacing);place-items:center}kol-span-wc>span{display:flex;gap:var(--kolibri-spacing);place-items:center}kol-span-wc kol-icon{display:contents;padding:0 var(--kolibri-spacing)}a,button,input,select,textarea{appearance:none;cursor:pointer;font-family:var(--kolibri-font-family)}.icon-only>kol-span-wc>span>span{display:none}a,button{text-align:left;text-decoration-line:underline}a{display:inline-flex;gap:var(--kolibri-spacing);place-items:center}:is(a,button):is(:focus,:hover){text-decoration-thickness:0.2em}.hidden{display:none;visibility:hidden}.skip{left:-99999px;overflow:hidden;position:absolute;z-index:9999999;line-height:1em}.skip:focus{background-color:white;box-shadow:0 0 calc(2 * var(--kolibri-spacing)) calc(2 * var(--kolibri-spacing)) white;left:unset;position:unset}",s=class{constructor(o){i(this,o),this.catchRef=i=>{this.ref=i,n(this.host,this.ref)},this._ariaControls=void 0,this._ariaCurrent=void 0,this._ariaExpanded=void 0,this._ariaLabel=void 0,this._ariaSelected=void 0,this._disabled=!1,this._href=void 0,this._icon=void 0,this._iconAlign=void 0,this._iconOnly=!1,this._label=void 0,this._on=void 0,this._role=void 0,this._selector=void 0,this._stealth=!1,this._tabIndex=void 0,this._target=void 0,this._targetDescription="Der Link wird in einem neuen Tab geöffnet.",this._tooltipAlign="right",this._useCase="text"}render(){return e(o,null,e("kol-link-wc",{ref:this.catchRef,_ariaControls:this._ariaControls,_ariaCurrent:this._ariaCurrent,_ariaExpanded:this._ariaExpanded,_ariaLabel:this._ariaLabel,_ariaSelected:this._ariaSelected,_disabled:this._disabled,_href:this._href,_icon:this._icon,_iconAlign:this._iconAlign,_iconOnly:this._iconOnly,_label:this._label,_on:this._on,_role:this._role,_selector:this._selector,_stealth:this._stealth,_tabIndex:this._tabIndex,_target:this._target,_targetDescription:this._targetDescription,_tooltipAlign:this._tooltipAlign,_useCase:this._useCase},e("slot",{name:"expert",slot:"expert"}),e("slot",{slot:"expert"})))}get host(){return t(this)}};s.style={default:r};export{s as kol_link};
4
+ import{r as i,h as t,H as e,g as n}from"./index-50adf9a0.js";import{a as s}from"./reuse-3a02afb9.js";const o=":host{--a11y-min-size:44px}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role='button'],button:not([role='link']),kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}:host{max-width:100%}*{box-sizing:border-box}kol-span-wc{display:grid;place-items:center}kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}a,button,input,option,select,textarea{font-family:inherit}.icon-only>kol-span-wc>span>span{display:none}:host{display:inline-block}:is(a,button){align-items:baseline;display:inline-flex;place-items:center;text-align:left;text-decoration-line:underline}:is(a,button):is(:focus,:hover){text-decoration-thickness:0.2em}.hidden{display:none;visibility:hidden}.skip{left:-99999px;overflow:hidden;position:absolute;z-index:9999999;line-height:1em}.skip:focus{background-color:#fff;left:unset;padding:1em;position:unset}kol-icon.external-link-icon{display:inline-flex}",a=class{constructor(t){i(this,t),this.catchRef=i=>{this.ref=i,s(this.host,this.ref)},this._ariaControls=void 0,this._ariaCurrent=void 0,this._ariaExpanded=void 0,this._ariaLabel=void 0,this._ariaSelected=void 0,this._disabled=!1,this._download=!1,this._href=void 0,this._icon=void 0,this._iconAlign=void 0,this._iconOnly=!1,this._label=void 0,this._on=void 0,this._role=void 0,this._selector=void 0,this._stealth=!1,this._tabIndex=void 0,this._target=void 0,this._targetDescription="Der Link wird in einem neuen Tab geöffnet.",this._tooltipAlign="right",this._useCase="text"}render(){return t(e,null,t("kol-link-wc",{ref:this.catchRef,_ariaControls:this._ariaControls,_ariaCurrent:this._ariaCurrent,_ariaExpanded:this._ariaExpanded,_ariaLabel:this._ariaLabel,_ariaSelected:this._ariaSelected,_disabled:this._disabled,_download:this._download,_href:this._href,_icon:this._icon,_iconAlign:this._iconAlign,_iconOnly:this._iconOnly,_label:this._label,_on:this._on,_role:this._role,_selector:this._selector,_stealth:this._stealth,_tabIndex:this._tabIndex,_target:this._target,_targetDescription:this._targetDescription,_tooltipAlign:this._tooltipAlign,_useCase:this._useCase},t("slot",{name:"expert",slot:"expert"}),t("slot",{slot:"expert"})))}get host(){return n(this)}};a.style={default:o};export{a as kol_link};
@@ -1 +1 @@
1
- {"version":3,"names":["defaultStyleCss","KolLink","this","catchRef","ref","propergateFocus","host","render","h","Host","_ariaControls","_ariaCurrent","_ariaExpanded","_ariaLabel","_ariaSelected","_disabled","_href","_icon","_iconAlign","_iconOnly","_label","_on","_role","_selector","_stealth","_tabIndex","_target","_targetDescription","_tooltipAlign","_useCase","name","slot"],"sources":["./src/components/link/style.css?tag=kol-link&mode=default&encapsulation=shadow","./src/components/link/shadow.tsx"],"sourcesContent":["@import '../link.css';\n","import { Generic } from '@a11y-ui/core';\nimport { Component, Element, h, Host, JSX, Prop } from '@stencil/core';\nimport { AlternativButtonLinkRole, AriaCurrent, LinkOnCallbacks, LinkTarget, LinkUseCase, OptionalLinkProps, RequiredLinkProps } from '../../types/button-link';\nimport { Stringified } from '../../types/common';\nimport { KoliBriIconProp } from '../../types/icon';\nimport { Alignment } from '../../types/props/alignment';\nimport { propergateFocus } from '../../utils/reuse';\n\n/**\n * @part link - Ermöglicht das Stylen des Links.\n * @part span - Ermöglicht das Stylen des Linktextes.\n * @part hidden - Ermöglicht das Ausblenden des Linktextes.\n */\n@Component({\n\ttag: 'kol-link',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolLink implements Generic.Element.Members<RequiredLinkProps, OptionalLinkProps> {\n\t@Element() private readonly host?: HTMLKolLinkElement;\n\tprivate ref?: HTMLKolLinkWcElement;\n\n\tprivate readonly catchRef = (ref?: HTMLKolLinkWcElement) => {\n\t\tthis.ref = ref;\n\t\tpropergateFocus(this.host, this.ref);\n\t};\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t<kol-link-wc\n\t\t\t\t\tref={this.catchRef}\n\t\t\t\t\t_ariaControls={this._ariaControls}\n\t\t\t\t\t_ariaCurrent={this._ariaCurrent}\n\t\t\t\t\t_ariaExpanded={this._ariaExpanded}\n\t\t\t\t\t_ariaLabel={this._ariaLabel}\n\t\t\t\t\t_ariaSelected={this._ariaSelected}\n\t\t\t\t\t_disabled={this._disabled}\n\t\t\t\t\t_href={this._href}\n\t\t\t\t\t_icon={this._icon}\n\t\t\t\t\t_iconAlign={this._iconAlign}\n\t\t\t\t\t_iconOnly={this._iconOnly}\n\t\t\t\t\t_label={this._label}\n\t\t\t\t\t_on={this._on}\n\t\t\t\t\t_role={this._role}\n\t\t\t\t\t_selector={this._selector}\n\t\t\t\t\t_stealth={this._stealth}\n\t\t\t\t\t_tabIndex={this._tabIndex}\n\t\t\t\t\t_target={this._target}\n\t\t\t\t\t_targetDescription={this._targetDescription}\n\t\t\t\t\t_tooltipAlign={this._tooltipAlign}\n\t\t\t\t\t_useCase={this._useCase}\n\t\t\t\t>\n\t\t\t\t\t{/*\n\t\t\t\t\t\tEs ist keine gute Idee hier einen Slot einzufügen, da dadurch ermöglicht wird,\n\t\t\t\t\t\tdie Unterstützung hinsichtlich der Barrierefreiheit der Komponente zu umgehen.\n\t\t\t\t\t*/}\n\t\t\t\t\t<slot name=\"expert\" slot=\"expert\" />\n\t\t\t\t\t{/* TODO: der folgende Slot ohne Name muss später entfernt werden */}\n\t\t\t\t\t<slot slot=\"expert\" />\n\t\t\t\t</kol-link-wc>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Gibt an, welche Elemente kontrolliert werden. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-controls)\n\t */\n\t@Prop() public _ariaControls?: string;\n\n\t/**\n\t * Gibt an, welchen aktuellen Auswahlstatus der Link hat. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)\n\t */\n\t@Prop() public _ariaCurrent?: AriaCurrent;\n\n\t/**\n\t * Gibt an, ob durch den Link etwas aufgeklappt wurde. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-expanded)\n\t */\n\t@Prop({ reflect: true }) public _ariaExpanded?: boolean;\n\n\t/**\n\t * Gibt einen beschreibenden Text des Links an. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-label)\n\t */\n\t@Prop() public _ariaLabel?: string;\n\n\t/**\n\t * Gibt an, ob der Link gerade ausgewählt ist. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-selected)\n\t */\n\t@Prop({ reflect: true }) public _ariaSelected?: boolean;\n\n\t/**\n\t * Gibt an, ob der Link deaktiviert ist.\n\t */\n\t@Prop({ reflect: true }) public _disabled?: boolean = false;\n\n\t/**\n\t * Gibt die Ziel-Url des Links an.\n\t */\n\t@Prop() public _href!: string;\n\n\t/**\n\t * Gibt den Class-Identifier eines Icons eine eingebunden Icofont an. (z.B. https://icofont.com/)\n\t */\n\t@Prop() public _icon?: Stringified<KoliBriIconProp>;\n\n\t/**\n\t * Gibt an, ob das Icon entweder links oder rechts dargestellt werden soll.\n\t *\n\t * @deprecated Wird durch das neue flexibleren Icon-Typ abgedeckt.\n\t */\n\t@Prop() public _iconAlign?: Alignment;\n\t/**\n\t * Gibt an, ob nur das Icon angezeigt wird.\n\t */\n\t@Prop({ reflect: true }) public _iconOnly?: boolean = false;\n\n\t/**\n\t * Gibt den Label für die Beschriftung der Schaltfläche an.\n\t */\n\t@Prop() public _label!: string;\n\n\t/**\n\t * Gibt die EventCallback-Funktionen für den Link an.\n\t */\n\t@Prop() public _on?: LinkOnCallbacks;\n\n\t/**\n\t * Gibt an, welche Role der Schalter hat.\n\t */\n\t@Prop() public _role?: AlternativButtonLinkRole;\n\n\t/**\n\t * Gibt die ID eines DOM-Elements, zu dem gesprungen werden soll, aus.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop() public _selector?: string;\n\n\t/**\n\t * Gibt an, ob der Link nur beim Fokus sichtbar ist.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop({ reflect: true }) public _stealth?: boolean = false;\n\n\t/**\n\t * Gibt an, welchen Tab-Index der Button hat. (https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex)\n\t */\n\t@Prop() public _tabIndex?: number;\n\n\t/**\n\t * Definiert das Verhalten, bei dem der Link geöffnet werden soll.\n\t */\n\t@Prop() public _target?: LinkTarget;\n\n\t/**\n\t * Gibt die Beschreibung an, wenn der Link in einem anderen Programm geöffnet wird.\n\t */\n\t@Prop() public _targetDescription?: string = 'Der Link wird in einem neuen Tab geöffnet.';\n\n\t/**\n\t * Gibt an, ob der Tooltip entweder oben, rechts, unten oder links angezeigt werden soll.\n\t */\n\t@Prop() public _tooltipAlign?: Alignment = 'right';\n\n\t/**\n\t * Gibt den Verwendungsfall des Links an.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop() public _useCase?: LinkUseCase = 'text';\n}\n"],"mappings":";;;qGAAA,MAAMA,EAAkB,63D,MCoBXC,EAAO,M,yBAIFC,KAAAC,SAAYC,IAC5BF,KAAKE,IAAMA,EACXC,EAAgBH,KAAKI,KAAMJ,KAAKE,IAAI,E,4JAqEiB,M,mFAqBA,M,qGA6BD,M,wEAeR,6C,mBAKF,Q,cAOH,M,CA/IjCG,SACN,OACCC,EAACC,EAAI,KACJD,EAAA,eACCJ,IAAKF,KAAKC,SACVO,cAAeR,KAAKQ,cACpBC,aAAcT,KAAKS,aACnBC,cAAeV,KAAKU,cACpBC,WAAYX,KAAKW,WACjBC,cAAeZ,KAAKY,cACpBC,UAAWb,KAAKa,UAChBC,MAAOd,KAAKc,MACZC,MAAOf,KAAKe,MACZC,WAAYhB,KAAKgB,WACjBC,UAAWjB,KAAKiB,UAChBC,OAAQlB,KAAKkB,OACbC,IAAKnB,KAAKmB,IACVC,MAAOpB,KAAKoB,MACZC,UAAWrB,KAAKqB,UAChBC,SAAUtB,KAAKsB,SACfC,UAAWvB,KAAKuB,UAChBC,QAASxB,KAAKwB,QACdC,mBAAoBzB,KAAKyB,mBACzBC,cAAe1B,KAAK0B,cACpBC,SAAU3B,KAAK2B,UAMfrB,EAAA,QAAMsB,KAAK,SAASC,KAAK,WAEzBvB,EAAA,QAAMuB,KAAK,Y"}
1
+ {"version":3,"names":["defaultStyleCss","KolLink","this","catchRef","ref","propagateFocus","host","render","h","Host","_ariaControls","_ariaCurrent","_ariaExpanded","_ariaLabel","_ariaSelected","_disabled","_download","_href","_icon","_iconAlign","_iconOnly","_label","_on","_role","_selector","_stealth","_tabIndex","_target","_targetDescription","_tooltipAlign","_useCase","name","slot"],"sources":["./src/components/link/style.css?tag=kol-link&mode=default&encapsulation=shadow","./src/components/link/shadow.tsx"],"sourcesContent":["@import url(../link.css);\n","import { Generic } from '@a11y-ui/core';\nimport { Component, Element, h, Host, JSX, Prop } from '@stencil/core';\nimport { AlternativButtonLinkRole, LinkOnCallbacks, LinkTarget, LinkUseCase, OptionalLinkProps, RequiredLinkProps } from '../../types/button-link';\nimport { Stringified } from '../../types/common';\nimport { KoliBriIconProp } from '../../types/icon';\nimport { AriaCurrent, Alignment } from '../../types/props';\nimport { propagateFocus } from '../../utils/reuse';\n\n@Component({\n\ttag: 'kol-link',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolLink implements Generic.Element.Members<RequiredLinkProps, OptionalLinkProps> {\n\t@Element() private readonly host?: HTMLKolLinkElement;\n\tprivate ref?: HTMLKolLinkWcElement;\n\n\tprivate readonly catchRef = (ref?: HTMLKolLinkWcElement) => {\n\t\tthis.ref = ref;\n\t\tpropagateFocus(this.host, this.ref);\n\t};\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t<kol-link-wc\n\t\t\t\t\tref={this.catchRef}\n\t\t\t\t\t_ariaControls={this._ariaControls}\n\t\t\t\t\t_ariaCurrent={this._ariaCurrent}\n\t\t\t\t\t_ariaExpanded={this._ariaExpanded}\n\t\t\t\t\t_ariaLabel={this._ariaLabel}\n\t\t\t\t\t_ariaSelected={this._ariaSelected}\n\t\t\t\t\t_disabled={this._disabled}\n\t\t\t\t\t_download={this._download}\n\t\t\t\t\t_href={this._href}\n\t\t\t\t\t_icon={this._icon}\n\t\t\t\t\t_iconAlign={this._iconAlign}\n\t\t\t\t\t_iconOnly={this._iconOnly}\n\t\t\t\t\t_label={this._label}\n\t\t\t\t\t_on={this._on}\n\t\t\t\t\t_role={this._role}\n\t\t\t\t\t_selector={this._selector}\n\t\t\t\t\t_stealth={this._stealth}\n\t\t\t\t\t_tabIndex={this._tabIndex}\n\t\t\t\t\t_target={this._target}\n\t\t\t\t\t_targetDescription={this._targetDescription}\n\t\t\t\t\t_tooltipAlign={this._tooltipAlign}\n\t\t\t\t\t_useCase={this._useCase}\n\t\t\t\t>\n\t\t\t\t\t{/*\n\t\t\t\t\t\tEs ist keine gute Idee hier einen Slot einzufügen, da dadurch ermöglicht wird,\n\t\t\t\t\t\tdie Unterstützung hinsichtlich der Barrierefreiheit der Komponente zu umgehen.\n\t\t\t\t\t*/}\n\t\t\t\t\t<slot name=\"expert\" slot=\"expert\" />\n\t\t\t\t\t{/* TODO: der folgende Slot ohne Name muss später entfernt werden */}\n\t\t\t\t\t<slot slot=\"expert\" />\n\t\t\t\t</kol-link-wc>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Gibt an, welche Elemente kontrolliert werden. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-controls)\n\t */\n\t@Prop() public _ariaControls?: string;\n\n\t/**\n\t * Gibt an, welchen aktuellen Auswahlstatus der Link hat. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)\n\t */\n\t@Prop() public _ariaCurrent?: AriaCurrent;\n\n\t/**\n\t * Gibt an, ob durch den Link etwas aufgeklappt wurde. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-expanded)\n\t */\n\t@Prop({ reflect: true }) public _ariaExpanded?: boolean;\n\n\t/**\n\t * Gibt einen beschreibenden Text des Links an. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-label)\n\t */\n\t@Prop() public _ariaLabel?: string;\n\n\t/**\n\t * Gibt an, ob der Link gerade ausgewählt ist. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-selected)\n\t */\n\t@Prop({ reflect: true }) public _ariaSelected?: boolean;\n\n\t/**\n\t * Gibt an, ob der Link deaktiviert ist.\n\t */\n\t@Prop({ reflect: true }) public _disabled?: boolean = false;\n\n\t/**\n\t * Teilt dem Browser mit, dass sich hinter dem Link eine Datei befindet. Setzt optional den Dateinamen.\n\t */\n\t@Prop() public _download?: boolean | string = false;\n\n\t/**\n\t * Gibt die Ziel-Url des Links an.\n\t */\n\t@Prop() public _href!: string;\n\n\t/**\n\t * Iconklasse (z.B.: \"codicon codicon-home\")\n\t */\n\t@Prop() public _icon?: Stringified<KoliBriIconProp>;\n\n\t/**\n\t * Gibt an, ob das Icon entweder links oder rechts dargestellt werden soll.\n\t *\n\t * @deprecated Wird durch das neue flexibleren Icon-Typ abgedeckt.\n\t */\n\t@Prop() public _iconAlign?: Alignment;\n\t/**\n\t * Gibt an, ob nur das Icon angezeigt wird.\n\t */\n\t@Prop({ reflect: true }) public _iconOnly?: boolean = false;\n\n\t/**\n\t * Setzt den sichtbaren Text des Elements.\n\t */\n\t@Prop() public _label!: string;\n\n\t/**\n\t * Gibt die EventCallback-Funktionen für den Link an.\n\t * @deprecated\n\t */\n\t@Prop() public _on?: LinkOnCallbacks;\n\n\t/**\n\t * Gibt an, welche Rolle das Element hat.\n\t */\n\t@Prop() public _role?: AlternativButtonLinkRole;\n\n\t/**\n\t * Gibt die ID eines DOM-Elements, zu dem gesprungen werden soll, aus.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop() public _selector?: string;\n\n\t/**\n\t * Gibt an, ob der Link nur beim Fokus sichtbar ist.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop({ reflect: true }) public _stealth?: boolean = false;\n\n\t/**\n\t * Gibt an, welchen Tab-Index der Button hat. (https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex)\n\t */\n\t@Prop() public _tabIndex?: number;\n\n\t/**\n\t * Gibt an wo der Link geöffnet werden soll.\n\t */\n\t@Prop() public _target?: LinkTarget;\n\n\t/**\n\t * Gibt die Beschreibung an, wenn der Link in einem anderen Programm geöffnet wird.\n\t */\n\t@Prop() public _targetDescription?: string = 'Der Link wird in einem neuen Tab geöffnet.';\n\n\t/**\n\t * Gibt an, ob der Tooltip entweder oben, rechts, unten oder links angezeigt werden soll.\n\t */\n\t@Prop() public _tooltipAlign?: Alignment = 'right';\n\n\t/**\n\t * Gibt den Verwendungsfall des Links an.\n\t *\n\t * @deprecated Das Styling sollte stets über CSS erfolgen.\n\t */\n\t@Prop() public _useCase?: LinkUseCase = 'text';\n}\n"],"mappings":";;;qGAAA,MAAMA,EAAkB,gnC,MCeXC,EAAO,M,yBAIFC,KAAAC,SAAYC,IAC5BF,KAAKE,IAAMA,EACXC,EAAeH,KAAKI,KAAMJ,KAAKE,IAAI,E,4JAsEkB,M,eAKR,M,mFAqBQ,M,qGA8BD,M,wEAeR,6C,mBAKF,Q,cAOH,M,CAtJjCG,SACN,OACCC,EAACC,EAAI,KACJD,EAAA,eACCJ,IAAKF,KAAKC,SACVO,cAAeR,KAAKQ,cACpBC,aAAcT,KAAKS,aACnBC,cAAeV,KAAKU,cACpBC,WAAYX,KAAKW,WACjBC,cAAeZ,KAAKY,cACpBC,UAAWb,KAAKa,UAChBC,UAAWd,KAAKc,UAChBC,MAAOf,KAAKe,MACZC,MAAOhB,KAAKgB,MACZC,WAAYjB,KAAKiB,WACjBC,UAAWlB,KAAKkB,UAChBC,OAAQnB,KAAKmB,OACbC,IAAKpB,KAAKoB,IACVC,MAAOrB,KAAKqB,MACZC,UAAWtB,KAAKsB,UAChBC,SAAUvB,KAAKuB,SACfC,UAAWxB,KAAKwB,UAChBC,QAASzB,KAAKyB,QACdC,mBAAoB1B,KAAK0B,mBACzBC,cAAe3B,KAAK2B,cACpBC,SAAU5B,KAAK4B,UAMftB,EAAA,QAAMuB,KAAK,SAASC,KAAK,WAEzBxB,EAAA,QAAMwB,KAAK,Y"}
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{r as c,h as i}from"./index-50adf9a0.js";import{d as n,B as o,b as r,f as l}from"./bund-fe1f3789.js";import{d as e}from"./a11y.tipps-5cdbd5e2.js";import{s as t}from"./prop.validators-769a843a.js";import{a}from"./i18n-8e14d822.js";import"./dev.utils-05f4e663.js";import"./reuse-56bb5a4b.js";import"./index-676dbf61.js";import"./index-4f2a12cc.js";const s=":host{--kolibri-border-color:#666;--kolibri-border-radius:0.125rem;--kolibri-border-width:1px;--kolibri-color-black:#000;--kolibri-color-white:#fff;--kolibri-color-error:#f44336;--kolibri-color-info:#2196f3;--kolibri-color-success:#4caf50;--kolibri-color-warning:#ff9800;--kolibri-color-primary:#3f51b5;--kolibri-color-secondary:#ff4081;--kolibri-color-normal:#9e9e9e;--kolibri-color-danger:#f44336;--kolibri-color-ghost:#f5f5f5;--kolibri-color-disabled:#bdbdbd;--kolibri-color-text:#222222;--kolibri-color-visited:#9c27b0;--kolibri-font-family:Verdana, Arial, Tahoma, Helvetica, sans-serif;--kolibri-font-size:16px;--kolibri-spacing:0.25rem}:host *{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}:host{display:inline-flex}a,button{background-color:transparent;border:none;font-size:inherit;margin:0;padding:0;transition-duration:0.5s;transition-property:background-color, color, border-color;width:100%}kol-icon.external-link-icon{display:inline-flex}:host{font-family:var(--kolibri-font-family);font-size:var(--kolibri-font-size)}*{box-sizing:border-box}kol-span-wc{display:grid;gap:var(--kolibri-spacing);place-items:center}kol-span-wc>span{display:flex;gap:var(--kolibri-spacing);place-items:center}kol-span-wc kol-icon{display:contents;padding:0 var(--kolibri-spacing)}a,button,input,select,textarea{appearance:none;cursor:pointer;font-family:var(--kolibri-font-family)}.icon-only>kol-span-wc>span>span{display:none}text{font-size:16px;letter-spacing:normal;word-spacing:normal}";function d(c,i=new Map){return Object.entries(c).map((([c,o])=>{i.set(o,c)})),i}const b=d(r,d(n,d(o)));function h(c){return b.has(c)?b.get(c):""}const f=()=>i("path",{d:"M21.72,12.77c0.04-0.33,0.06-0.67,0.06-1c0-0.2,0-0.43,0-0.69c3.06,0,5.74-2.25,5.74-4.78\nc-0.09-1.07-0.56-2.08-1.32-2.84l0.32-0.07c1,0.89,1.61,2.14,1.7,3.48c0,3-3,5.85-6.5,5.92 M18.64,2.21\nc-0.05-0.33-0.19-0.64-0.39-0.91c0-0.31,0.14-0.61,0.64-0.36c-0.27,0.27-0.06,0.76-0.06,0.76s0.55-0.26,0.44-0.62\nC20.09,1.28,19.5,2.38,18.64,2.21 M17.93,3.77c-0.12-0.47-0.34-0.9-0.64-1.27c-0.3-0.42-0.77-0.69-1.29-0.73\nc-0.34,0.03-0.68,0.12-1,0.25c-0.16-0.28-0.27-0.58-0.32-0.9c0-0.22,0.38-0.44,1.1-0.44c1.58,0,2.52,0.71,2.52,1.91\nC18.26,3.01,18.14,3.41,17.93,3.77 M22,24.16c0.13,0,0.26,0.02,0.38,0.07c0.64,1.3,1.4,2.53,2.29,3.68l0,0l0,0\nc0.81-0.14,1.63-0.22,2.45-0.24l0,0c0.1-0.01,0.2,0.01,0.28,0.07c0.07,0.09,0.1,0.2,0.09,0.31c-0.01,0.28-0.08,0.55-0.21,0.79\nc-0.46-0.4-1.07-0.59-1.68-0.51c-0.24,0.01-0.48,0.05-0.71,0.12h-0.07h-0.07l0.48,0.49c0.77,0.83,1.44,1.43,1.44,1.83\nc-0.04,0.31-0.22,0.58-0.48,0.74c-0.22-0.98-0.8-1.84-1.62-2.42h-0.06v0.27c0,0.19,0,0.47,0,0.77c0,1.49-0.15,1.72-0.67,1.72\nc-0.09,0.01-0.19,0.01-0.28,0c0.33-0.49,0.48-1.08,0.41-1.67v-0.7c0-0.27,0.03-0.53,0.06-0.8v-0.11h-0.08\nc-0.33-0.05-0.67-0.09-1-0.1c-0.57-0.07-1.14,0.07-1.6,0.41c-0.24-0.18-0.41-0.44-0.48-0.73c0-0.32,0.19-0.34,0.45-0.34\nc0.14-0.01,0.27-0.01,0.41,0c0.59,0.09,1.18,0.13,1.78,0.12h0.06v-0.06c-0.5-1.13-1.18-2.17-2-3.09c0.1-0.35,0.2-0.59,0.54-0.59\nM12.64,27.87v0.06h0.06c0.55-0.01,1.1-0.06,1.64-0.16c0.14-0.01,0.27-0.01,0.41,0c0.26,0,0.45,0,0.45,0.34\nc-0.07,0.29-0.24,0.55-0.48,0.73c-0.46-0.34-1.03-0.49-1.6-0.41c-0.33,0.01-0.67,0.05-1,0.1H12v0.11\nc0.03,0.27,0.06,0.53,0.06,0.8v0.7c-0.05,0.58,0.1,1.15,0.42,1.63c-0.09,0.01-0.19,0.01-0.28,0c-0.52,0-0.67-0.23-0.67-1.72\nc0-0.3,0-0.58,0-0.77V29l-0.06,0.05c-0.82,0.58-1.39,1.44-1.61,2.42c-0.28-0.14-0.47-0.4-0.53-0.7c0-0.43,0.65-1.07,1.39-1.81\nl0.43-0.43v-0.06h-0.14c-0.23-0.07-0.47-0.11-0.71-0.12c-0.61-0.08-1.22,0.11-1.68,0.51c-0.13-0.24-0.2-0.51-0.21-0.79\nc0.01-0.11,0.06-0.22,0.14-0.3c0.08-0.06,0.18-0.08,0.28-0.07l0,0c0.82,0.02,1.64,0.1,2.45,0.24l0,0l0,0\nc0.88-1.15,1.64-2.38,2.28-3.68c0.12-0.05,0.25-0.07,0.38-0.07c0.35,0,0.44,0.24,0.54,0.59c-0.82,0.92-1.5,1.96-2,3.09\nM7.78,6.87c0.08-1.36,0.7-2.62,1.72-3.52l0.32,0.07C9.06,4.19,8.6,5.19,8.51,6.26c0,2.56,2.73,4.78,5.82,4.78\nc0,0.22,0,0.45,0,0.69c-0.01,0.35,0,0.69,0.03,1.04c-3.5,0-6.58-2.86-6.58-5.92 M31.25,12.23c1.57,2.49,2.8,2.45,4.66,2.45\nc-1.19-0.97-2.21-2.14-3-3.46L30,6.65c-0.29-1.44-1.03-2.75-2.12-3.73c0.31-0.1,0.6-0.24,0.87-0.42c-1.88,0-3.73-1-4.75-1\nc-0.55-0.05-1.03,0.36-1.08,0.91c0,0.58,0.63,1.16,1.73,1.16c0.31,0,0.62-0.04,0.92-0.09c0.65,0.74,1.03,1.67,1.08,2.65\nc0,2-2.41,3.58-4.83,3.58h-0.41c-0.5-0.67-0.84-1.45-1-2.28c0-1.6,1.05-2.9,1.05-4.48c0-0.68-0.24-1.33-0.67-1.85\nc0.29-0.23,0.53-0.52,0.7-0.85c-0.22,0.08-0.45,0.11-0.68,0.09c-1.16,0-2.11-0.3-3-0.3c-0.53,0-0.67,0.16-0.67,0.31\nc-0.01,0.05-0.01,0.1,0,0.15c-0.19-0.08-0.39-0.13-0.59-0.17c-0.29-0.05-0.58-0.08-0.88-0.08c-1.13,0-1.52,0.47-1.52,0.87\nc0.07,0.52,0.27,1.01,0.57,1.44c0.4-0.2,0.84-0.31,1.28-0.34c0.6,0,1.13,0.57,1.41,1.24c-0.29,0.05-0.59,0.07-0.88,0.07\nc-0.68-0.03-1.36-0.16-2-0.39l0,0c0,0,0.31,0.56,0.92,0.78c0.72,0.22,1.46,0.37,2.21,0.45c-0.08,0.21-0.23,0.38-0.43,0.49\nc-0.05,0.02-0.09,0.02-0.14,0c-0.74-0.14-1.45-0.35-2.14-0.65H14.9c0,0.42,1.09,1.35,2.07,1.71c-1.06,1.1-1.87,2.41-2.39,3.85\nh-0.41c-2.42,0-4.82-1.57-4.82-3.58c0.05-0.98,0.43-1.91,1.07-2.65c0.3,0.05,0.61,0.09,0.92,0.09c1.1,0,1.69-0.58,1.74-1.16\nc-0.04-0.55-0.52-0.96-1.07-0.92c0,0,0,0-0.01,0c-1,0-2.88,1-4.76,1C7.51,2.73,7.8,2.87,8.11,2.97C7.03,3.94,6.29,5.23,6,6.65\nl-2.87,4.59c-0.79,1.32-1.81,2.49-3,3.46c1.86,0,3.09,0,4.66-2.45L6.26,9.9c0.11,0.31,0.24,0.61,0.4,0.9l-2.97,4.67\nc-0.79,1.32-1.8,2.49-3,3.46c1.85,0,3.08,0,4.65-2.44l2.52-4c0.19,0.2,0.39,0.4,0.6,0.58l-3.59,5.7c-0.79,1.32-1.8,2.49-3,3.45\nc1.85,0,3.08,0.05,4.65-2.44L10,14.2c0.22,0.14,0.46,0.28,0.7,0.41l-4.27,6.77c-0.79,1.31-1.81,2.48-3,3.45\nc1.85,0,3.08,0,4.65-2.44l4.36-7c0.25,0.1,0.51,0.2,0.78,0.28l-4.95,7.9c-0.79,1.31-1.81,2.48-3,3.45c1.85,0,3.08,0.05,4.65-2.43\nl5.24-8.39h0.16c0.14,0.42,0.22,0.86,0.24,1.3c0,2.64-1.73,5-3.8,6.76c0.19,0.06,0.38,0.09,0.58,0.08c0.3,0.01,0.6-0.01,0.9-0.05\nc-0.57,1.13-1.24,2.21-2,3.23c-0.77-0.13-1.54-0.2-2.32-0.22c-0.67,0-0.75,0.4-0.75,0.75c-0.01,0.53,0.22,1.03,0.62,1.38\nc0.13-0.31,0.38-0.73,1.63-0.73h0.13C10.11,29.13,9,30.06,9,30.77c0.06,0.66,0.59,1.18,1.25,1.24c-0.02-0.14-0.02-0.28,0-0.42\nc0.13-0.69,0.48-1.33,1-1.8c-0.01,0.1-0.01,0.2,0,0.3c0,1.43,0.13,2.08,1,2.08c0.31-0.01,0.61-0.12,0.86-0.31\nc-0.5-0.44-0.73-1.11-0.62-1.77c0-0.21,0-0.41,0-0.69c0.02-0.2,0.02-0.41,0-0.61c0.24-0.02,0.47-0.02,0.71,0\nc0,0,1.29-0.1,1.6,0.57c0.35-0.32,0.86-0.78,0.86-1.27c0-0.33-0.16-0.71-0.83-0.71c-0.25,0-1,0.16-1.7,0.16\nc0.48-0.84,1.04-1.64,1.66-2.39c0.1,0.39,0.31,0.74,0.62,1c0.12-1.17,0.54-2.28,1.21-3.24c0.16,0.93,0.24,1.87,0.23,2.82\nc0,3.55-0.85,6.17-2.66,6.67c0.26,0.46,0.73,0.75,1.25,0.78c0.66,0,1-0.75,1.39-1.46c0.19,0.53,0.72,1.8,1.25,1.8\ns1.06-1.27,1.25-1.8c0.37,0.71,0.73,1.46,1.39,1.46c0.52-0.03,1-0.33,1.26-0.78c-1.82-0.5-2.67-3.12-2.67-6.67\nc-0.01-0.95,0.07-1.89,0.23-2.82c0.68,0.96,1.1,2.07,1.21,3.24c0.31-0.26,0.53-0.61,0.63-1c0.61,0.75,1.15,1.54,1.62,2.38\nc-0.66,0-1.45-0.16-1.7-0.16c-0.67,0-0.82,0.38-0.82,0.71c0,0.49,0.51,1,0.86,1.27c0.3-0.67,1.59-0.57,1.59-0.57\nc0.24-0.02,0.47-0.02,0.71,0c-0.02,0.2-0.02,0.41,0,0.61v0.69c0.11,0.66-0.12,1.33-0.62,1.77c0.25,0.19,0.55,0.3,0.86,0.31\nc0.91,0,1-0.65,1-2.08c0.01-0.1,0.01-0.2,0-0.3c0.52,0.47,0.87,1.11,1,1.8c0.02,0.14,0.02,0.28,0,0.42\nc0.61-0.11,1.06-0.62,1.12-1.23c0-0.74-1.15-1.67-1.52-2.08h0.13c1.25,0,1.5,0.42,1.63,0.73c0.4-0.35,0.63-0.85,0.62-1.38\nc0-0.35-0.07-0.75-0.75-0.75c-0.78,0.02-1.55,0.09-2.32,0.22c-0.76-1.02-1.43-2.1-2-3.23c0.3,0.04,0.6,0.06,0.9,0.05\nc0.19,0.01,0.39-0.02,0.57-0.08c-2.07-1.79-3.8-4.12-3.8-6.76c0.02-0.44,0.1-0.88,0.24-1.3h0.16l5.24,8.39\nc1.57,2.48,2.8,2.43,4.65,2.43c-1.19-0.97-2.21-2.14-3-3.45l-4.92-7.87c0.27-0.08,0.53-0.18,0.79-0.28l4.35,7\nc1.57,2.48,2.8,2.44,4.65,2.44c-1.19-0.97-2.21-2.14-3-3.45l-4.23-6.77c0.24-0.13,0.48-0.27,0.7-0.41l3.42,5.55\nc1.57,2.49,2.8,2.44,4.65,2.44c-1.19-0.97-2.21-2.13-3-3.45l-3.55-5.69c0.2-0.18,0.4-0.38,0.59-0.58l2.52,4\nc1.57,2.48,2.8,2.44,4.65,2.44c-1.2-0.97-2.21-2.14-3-3.46l-2.99-4.7c0.16-0.29,0.29-0.59,0.4-0.9L31.25,12.23z"}),p=class{constructor(i){c(this,i),this._abbr=void 0,this._org=void 0,this.state={_org:n["Informationstechnikzentrum Bund"]}}validateAbbr(c){this.validateOrg(c)}validateOrg(c){"string"==typeof c&&b.has(c)?t(this,"_org",c):e(`Die verwendete Abkürzung (${c}) ist nicht definiert!`)}componentWillLoad(){this.validateOrg(this._org||this._abbr)}render(){var c;return i("svg",{"aria-label":a("kol-logo-description",{placeholders:{orgShort:this.state._org,orgLong:h(this.state._org)}}),role:"img",viewBox:"0 0 225 100"},i("rect",{width:"100%",height:"100%",fill:"white"}),i("svg",{x:"0",y:"4",height:"75"},i(f,null)),i("svg",{x:"40.5",y:"3.5",height:"100"},i("rect",{width:"5",height:"30"}),i("rect",{y:"30",width:"5",height:"30",fill:"red"}),i("rect",{y:"60",width:"5",height:"30",fill:"#fc0"})),i("svg",{x:"50",y:"0"},i("text",{x:"0",y:"-0.05em","font-family":"BundesSans Web",style:{backgroundColor:"white",color:"black"}},l.has(this.state._org)?i("tspan",null,null===(c=l.get(this.state._org))||void 0===c?void 0:c.map(((c,o)=>i("tspan",{x:"0",dy:"1.1em",key:`kol-logo-text-${o}`},c)))):i("tspan",{fill:"red"},i("tspan",{x:"0",dy:"1.1em"},"Der Schlüsselwert"),i("tspan",{x:"0",dy:"1.1em","font-weight":"bold"},"'",this.state._org,"'"),i("tspan",{x:"0",dy:"1.1em"},"ist nicht definiert."),i("tspan",{x:"0",dy:"1.1em"},"oder freigegeben.")))))}static get watchers(){return{_abbr:["validateAbbr"],_org:["validateOrg"]}}};p.style={default:s};export{p as kol_logo};
4
+ import{r as c,h as n}from"./index-50adf9a0.js";import{d as t,B as e,b as i,f as r}from"./bund-fe1f3789.js";import{d as o}from"./a11y.tipps-1cea9822.js";import{s}from"./prop.validators-e402ad49.js";import{a as l}from"./i18n-cbc21d6e.js";import"./dev.utils-157f0499.js";import"./reuse-3a02afb9.js";import"./index-81bd9b41.js";import"./index-fef6600b.js";const a=":host{--a11y-min-size:44px}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role='button'],button:not([role='link']),kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}:host{max-width:100%}*{box-sizing:border-box}kol-span-wc{display:grid;place-items:center}kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}a,button,input,option,select,textarea{font-family:inherit}.icon-only>kol-span-wc>span>span{display:none}text{font-size:16px;letter-spacing:normal;word-spacing:normal}";function h(c,n=new Map){return Object.entries(c).map((([c,t])=>{n.set(t,c)})),n}const d=h(i,h(t,h(e)));function p(c){return d.has(c)?d.get(c):""}const f=()=>n("path",{d:"M21.72,12.77c0.04-0.33,0.06-0.67,0.06-1c0-0.2,0-0.43,0-0.69c3.06,0,5.74-2.25,5.74-4.78\nc-0.09-1.07-0.56-2.08-1.32-2.84l0.32-0.07c1,0.89,1.61,2.14,1.7,3.48c0,3-3,5.85-6.5,5.92 M18.64,2.21\nc-0.05-0.33-0.19-0.64-0.39-0.91c0-0.31,0.14-0.61,0.64-0.36c-0.27,0.27-0.06,0.76-0.06,0.76s0.55-0.26,0.44-0.62\nC20.09,1.28,19.5,2.38,18.64,2.21 M17.93,3.77c-0.12-0.47-0.34-0.9-0.64-1.27c-0.3-0.42-0.77-0.69-1.29-0.73\nc-0.34,0.03-0.68,0.12-1,0.25c-0.16-0.28-0.27-0.58-0.32-0.9c0-0.22,0.38-0.44,1.1-0.44c1.58,0,2.52,0.71,2.52,1.91\nC18.26,3.01,18.14,3.41,17.93,3.77 M22,24.16c0.13,0,0.26,0.02,0.38,0.07c0.64,1.3,1.4,2.53,2.29,3.68l0,0l0,0\nc0.81-0.14,1.63-0.22,2.45-0.24l0,0c0.1-0.01,0.2,0.01,0.28,0.07c0.07,0.09,0.1,0.2,0.09,0.31c-0.01,0.28-0.08,0.55-0.21,0.79\nc-0.46-0.4-1.07-0.59-1.68-0.51c-0.24,0.01-0.48,0.05-0.71,0.12h-0.07h-0.07l0.48,0.49c0.77,0.83,1.44,1.43,1.44,1.83\nc-0.04,0.31-0.22,0.58-0.48,0.74c-0.22-0.98-0.8-1.84-1.62-2.42h-0.06v0.27c0,0.19,0,0.47,0,0.77c0,1.49-0.15,1.72-0.67,1.72\nc-0.09,0.01-0.19,0.01-0.28,0c0.33-0.49,0.48-1.08,0.41-1.67v-0.7c0-0.27,0.03-0.53,0.06-0.8v-0.11h-0.08\nc-0.33-0.05-0.67-0.09-1-0.1c-0.57-0.07-1.14,0.07-1.6,0.41c-0.24-0.18-0.41-0.44-0.48-0.73c0-0.32,0.19-0.34,0.45-0.34\nc0.14-0.01,0.27-0.01,0.41,0c0.59,0.09,1.18,0.13,1.78,0.12h0.06v-0.06c-0.5-1.13-1.18-2.17-2-3.09c0.1-0.35,0.2-0.59,0.54-0.59\nM12.64,27.87v0.06h0.06c0.55-0.01,1.1-0.06,1.64-0.16c0.14-0.01,0.27-0.01,0.41,0c0.26,0,0.45,0,0.45,0.34\nc-0.07,0.29-0.24,0.55-0.48,0.73c-0.46-0.34-1.03-0.49-1.6-0.41c-0.33,0.01-0.67,0.05-1,0.1H12v0.11\nc0.03,0.27,0.06,0.53,0.06,0.8v0.7c-0.05,0.58,0.1,1.15,0.42,1.63c-0.09,0.01-0.19,0.01-0.28,0c-0.52,0-0.67-0.23-0.67-1.72\nc0-0.3,0-0.58,0-0.77V29l-0.06,0.05c-0.82,0.58-1.39,1.44-1.61,2.42c-0.28-0.14-0.47-0.4-0.53-0.7c0-0.43,0.65-1.07,1.39-1.81\nl0.43-0.43v-0.06h-0.14c-0.23-0.07-0.47-0.11-0.71-0.12c-0.61-0.08-1.22,0.11-1.68,0.51c-0.13-0.24-0.2-0.51-0.21-0.79\nc0.01-0.11,0.06-0.22,0.14-0.3c0.08-0.06,0.18-0.08,0.28-0.07l0,0c0.82,0.02,1.64,0.1,2.45,0.24l0,0l0,0\nc0.88-1.15,1.64-2.38,2.28-3.68c0.12-0.05,0.25-0.07,0.38-0.07c0.35,0,0.44,0.24,0.54,0.59c-0.82,0.92-1.5,1.96-2,3.09\nM7.78,6.87c0.08-1.36,0.7-2.62,1.72-3.52l0.32,0.07C9.06,4.19,8.6,5.19,8.51,6.26c0,2.56,2.73,4.78,5.82,4.78\nc0,0.22,0,0.45,0,0.69c-0.01,0.35,0,0.69,0.03,1.04c-3.5,0-6.58-2.86-6.58-5.92 M31.25,12.23c1.57,2.49,2.8,2.45,4.66,2.45\nc-1.19-0.97-2.21-2.14-3-3.46L30,6.65c-0.29-1.44-1.03-2.75-2.12-3.73c0.31-0.1,0.6-0.24,0.87-0.42c-1.88,0-3.73-1-4.75-1\nc-0.55-0.05-1.03,0.36-1.08,0.91c0,0.58,0.63,1.16,1.73,1.16c0.31,0,0.62-0.04,0.92-0.09c0.65,0.74,1.03,1.67,1.08,2.65\nc0,2-2.41,3.58-4.83,3.58h-0.41c-0.5-0.67-0.84-1.45-1-2.28c0-1.6,1.05-2.9,1.05-4.48c0-0.68-0.24-1.33-0.67-1.85\nc0.29-0.23,0.53-0.52,0.7-0.85c-0.22,0.08-0.45,0.11-0.68,0.09c-1.16,0-2.11-0.3-3-0.3c-0.53,0-0.67,0.16-0.67,0.31\nc-0.01,0.05-0.01,0.1,0,0.15c-0.19-0.08-0.39-0.13-0.59-0.17c-0.29-0.05-0.58-0.08-0.88-0.08c-1.13,0-1.52,0.47-1.52,0.87\nc0.07,0.52,0.27,1.01,0.57,1.44c0.4-0.2,0.84-0.31,1.28-0.34c0.6,0,1.13,0.57,1.41,1.24c-0.29,0.05-0.59,0.07-0.88,0.07\nc-0.68-0.03-1.36-0.16-2-0.39l0,0c0,0,0.31,0.56,0.92,0.78c0.72,0.22,1.46,0.37,2.21,0.45c-0.08,0.21-0.23,0.38-0.43,0.49\nc-0.05,0.02-0.09,0.02-0.14,0c-0.74-0.14-1.45-0.35-2.14-0.65H14.9c0,0.42,1.09,1.35,2.07,1.71c-1.06,1.1-1.87,2.41-2.39,3.85\nh-0.41c-2.42,0-4.82-1.57-4.82-3.58c0.05-0.98,0.43-1.91,1.07-2.65c0.3,0.05,0.61,0.09,0.92,0.09c1.1,0,1.69-0.58,1.74-1.16\nc-0.04-0.55-0.52-0.96-1.07-0.92c0,0,0,0-0.01,0c-1,0-2.88,1-4.76,1C7.51,2.73,7.8,2.87,8.11,2.97C7.03,3.94,6.29,5.23,6,6.65\nl-2.87,4.59c-0.79,1.32-1.81,2.49-3,3.46c1.86,0,3.09,0,4.66-2.45L6.26,9.9c0.11,0.31,0.24,0.61,0.4,0.9l-2.97,4.67\nc-0.79,1.32-1.8,2.49-3,3.46c1.85,0,3.08,0,4.65-2.44l2.52-4c0.19,0.2,0.39,0.4,0.6,0.58l-3.59,5.7c-0.79,1.32-1.8,2.49-3,3.45\nc1.85,0,3.08,0.05,4.65-2.44L10,14.2c0.22,0.14,0.46,0.28,0.7,0.41l-4.27,6.77c-0.79,1.31-1.81,2.48-3,3.45\nc1.85,0,3.08,0,4.65-2.44l4.36-7c0.25,0.1,0.51,0.2,0.78,0.28l-4.95,7.9c-0.79,1.31-1.81,2.48-3,3.45c1.85,0,3.08,0.05,4.65-2.43\nl5.24-8.39h0.16c0.14,0.42,0.22,0.86,0.24,1.3c0,2.64-1.73,5-3.8,6.76c0.19,0.06,0.38,0.09,0.58,0.08c0.3,0.01,0.6-0.01,0.9-0.05\nc-0.57,1.13-1.24,2.21-2,3.23c-0.77-0.13-1.54-0.2-2.32-0.22c-0.67,0-0.75,0.4-0.75,0.75c-0.01,0.53,0.22,1.03,0.62,1.38\nc0.13-0.31,0.38-0.73,1.63-0.73h0.13C10.11,29.13,9,30.06,9,30.77c0.06,0.66,0.59,1.18,1.25,1.24c-0.02-0.14-0.02-0.28,0-0.42\nc0.13-0.69,0.48-1.33,1-1.8c-0.01,0.1-0.01,0.2,0,0.3c0,1.43,0.13,2.08,1,2.08c0.31-0.01,0.61-0.12,0.86-0.31\nc-0.5-0.44-0.73-1.11-0.62-1.77c0-0.21,0-0.41,0-0.69c0.02-0.2,0.02-0.41,0-0.61c0.24-0.02,0.47-0.02,0.71,0\nc0,0,1.29-0.1,1.6,0.57c0.35-0.32,0.86-0.78,0.86-1.27c0-0.33-0.16-0.71-0.83-0.71c-0.25,0-1,0.16-1.7,0.16\nc0.48-0.84,1.04-1.64,1.66-2.39c0.1,0.39,0.31,0.74,0.62,1c0.12-1.17,0.54-2.28,1.21-3.24c0.16,0.93,0.24,1.87,0.23,2.82\nc0,3.55-0.85,6.17-2.66,6.67c0.26,0.46,0.73,0.75,1.25,0.78c0.66,0,1-0.75,1.39-1.46c0.19,0.53,0.72,1.8,1.25,1.8\ns1.06-1.27,1.25-1.8c0.37,0.71,0.73,1.46,1.39,1.46c0.52-0.03,1-0.33,1.26-0.78c-1.82-0.5-2.67-3.12-2.67-6.67\nc-0.01-0.95,0.07-1.89,0.23-2.82c0.68,0.96,1.1,2.07,1.21,3.24c0.31-0.26,0.53-0.61,0.63-1c0.61,0.75,1.15,1.54,1.62,2.38\nc-0.66,0-1.45-0.16-1.7-0.16c-0.67,0-0.82,0.38-0.82,0.71c0,0.49,0.51,1,0.86,1.27c0.3-0.67,1.59-0.57,1.59-0.57\nc0.24-0.02,0.47-0.02,0.71,0c-0.02,0.2-0.02,0.41,0,0.61v0.69c0.11,0.66-0.12,1.33-0.62,1.77c0.25,0.19,0.55,0.3,0.86,0.31\nc0.91,0,1-0.65,1-2.08c0.01-0.1,0.01-0.2,0-0.3c0.52,0.47,0.87,1.11,1,1.8c0.02,0.14,0.02,0.28,0,0.42\nc0.61-0.11,1.06-0.62,1.12-1.23c0-0.74-1.15-1.67-1.52-2.08h0.13c1.25,0,1.5,0.42,1.63,0.73c0.4-0.35,0.63-0.85,0.62-1.38\nc0-0.35-0.07-0.75-0.75-0.75c-0.78,0.02-1.55,0.09-2.32,0.22c-0.76-1.02-1.43-2.1-2-3.23c0.3,0.04,0.6,0.06,0.9,0.05\nc0.19,0.01,0.39-0.02,0.57-0.08c-2.07-1.79-3.8-4.12-3.8-6.76c0.02-0.44,0.1-0.88,0.24-1.3h0.16l5.24,8.39\nc1.57,2.48,2.8,2.43,4.65,2.43c-1.19-0.97-2.21-2.14-3-3.45l-4.92-7.87c0.27-0.08,0.53-0.18,0.79-0.28l4.35,7\nc1.57,2.48,2.8,2.44,4.65,2.44c-1.19-0.97-2.21-2.14-3-3.45l-4.23-6.77c0.24-0.13,0.48-0.27,0.7-0.41l3.42,5.55\nc1.57,2.49,2.8,2.44,4.65,2.44c-1.19-0.97-2.21-2.13-3-3.45l-3.55-5.69c0.2-0.18,0.4-0.38,0.59-0.58l2.52,4\nc1.57,2.48,2.8,2.44,4.65,2.44c-1.2-0.97-2.21-2.14-3-3.46l-2.99-4.7c0.16-0.29,0.29-0.59,0.4-0.9L31.25,12.23z"}),g=class{constructor(n){c(this,n),this._abbr=void 0,this._org=void 0,this.state={_org:t["Informationstechnikzentrum Bund"]}}validateAbbr(c){this.validateOrg(c)}validateOrg(c){"string"==typeof c&&d.has(c)?s(this,"_org",c):o(`Die verwendete Abkürzung (${c}) ist nicht definiert!`)}componentWillLoad(){this.validateOrg(this._org||this._abbr)}render(){var c;return n("svg",{"aria-label":l("kol-logo-description",{placeholders:{orgShort:this.state._org,orgLong:p(this.state._org)}}),role:"img",viewBox:"0 0 225 100"},n("rect",{width:"100%",height:"100%",fill:"white"}),n("svg",{x:"0",y:"4",height:"75"},n(f,null)),n("svg",{x:"40.5",y:"3.5",height:"100"},n("rect",{width:"5",height:"30"}),n("rect",{y:"30",width:"5",height:"30",fill:"red"}),n("rect",{y:"60",width:"5",height:"30",fill:"#fc0"})),n("svg",{x:"50",y:"0"},n("text",{x:"0",y:"-0.05em","font-family":"BundesSans Web",style:{backgroundColor:"white",color:"black"}},r.has(this.state._org)?n("tspan",null,null===(c=r.get(this.state._org))||void 0===c?void 0:c.map(((c,t)=>n("tspan",{x:"0",dy:"1.1em",key:`kol-logo-text-${t}`},c)))):n("tspan",{fill:"red"},n("tspan",{x:"0",dy:"1.1em"},"Der Schlüsselwert"),n("tspan",{x:"0",dy:"1.1em","font-weight":"bold"},"'",this.state._org,"'"),n("tspan",{x:"0",dy:"1.1em"},"ist nicht definiert."),n("tspan",{x:"0",dy:"1.1em"},"oder freigegeben.")))))}static get watchers(){return{_abbr:["validateAbbr"],_org:["validateOrg"]}}};g.style={default:a};export{g as kol_logo};
@@ -1 +1 @@
1
- {"version":3,"names":["defaultStyleCss","enumToArray","enumeration","enumAsMap","Map","Object","entries","map","key","value","set","ENUM_AS_MAP","Bundesamt","Bundesanstalt","Bundesministerium","getAriaLabel","organ","has","get","Adler","h","d","KolLogo","_org","validateAbbr","this","validateOrg","setState","devHint","componentWillLoad","_abbr","render","translate","placeholders","orgShort","state","orgLong","role","viewBox","width","height","fill","x","y","style","backgroundColor","color","BUND_LOGO_TEXT_MAP","_a","text","index","dy"],"sources":["./src/components/logo/style.css?tag=kol-logo&mode=default&encapsulation=shadow","./src/components/logo/component.tsx"],"sourcesContent":["@import '../style.css';\n\ntext {\n\tfont-size: 16px;\n\tletter-spacing: normal;\n\tword-spacing: normal;\n}\n","import { Component, JSX, h, Prop, State, Watch } from '@stencil/core';\n\nimport { BUND_LOGO_TEXT_MAP, Bundesamt, Bundesanstalt, Bundesministerium } from '../../enums/bund';\nimport { Generic } from '@a11y-ui/core';\nimport { devHint } from '../../utils/a11y.tipps';\nimport { setState } from '../../utils/prop.validators';\nimport { translate } from '../../i18n';\n\nfunction enumToArray(enumeration: Record<string, string>, enumAsMap: Map<string, string> = new Map()): Map<string, string> {\n\tObject.entries(enumeration).map(([key, value]) => {\n\t\tenumAsMap.set(value, key);\n\t});\n\treturn enumAsMap;\n}\n\nconst ENUM_AS_MAP = enumToArray(Bundesamt, enumToArray(Bundesanstalt, enumToArray(Bundesministerium)));\n\nfunction getAriaLabel(organ: string): string {\n\tif (ENUM_AS_MAP.has(organ)) {\n\t\treturn ENUM_AS_MAP.get(organ) as string;\n\t} else {\n\t\treturn '';\n\t}\n}\n\n/**\n * API\n */\ntype RequiredProps = {\n\torg: Bundesministerium | Bundesamt | Bundesanstalt;\n};\ntype OptionalProps = {\n\tabbr: Bundesministerium | Bundesamt | Bundesanstalt;\n};\n// type Props = Generic.Element.Members<RequiredProps, OptionalProps>;\n\ntype RequiredStates = RequiredProps;\ntype OptionalStates = OptionalProps;\ntype States = Generic.Element.Members<RequiredStates, OptionalStates>;\n\nconst Adler = (): JSX.Element => (\n\t<path\n\t\td=\"M21.72,12.77c0.04-0.33,0.06-0.67,0.06-1c0-0.2,0-0.43,0-0.69c3.06,0,5.74-2.25,5.74-4.78\nc-0.09-1.07-0.56-2.08-1.32-2.84l0.32-0.07c1,0.89,1.61,2.14,1.7,3.48c0,3-3,5.85-6.5,5.92 M18.64,2.21\nc-0.05-0.33-0.19-0.64-0.39-0.91c0-0.31,0.14-0.61,0.64-0.36c-0.27,0.27-0.06,0.76-0.06,0.76s0.55-0.26,0.44-0.62\nC20.09,1.28,19.5,2.38,18.64,2.21 M17.93,3.77c-0.12-0.47-0.34-0.9-0.64-1.27c-0.3-0.42-0.77-0.69-1.29-0.73\nc-0.34,0.03-0.68,0.12-1,0.25c-0.16-0.28-0.27-0.58-0.32-0.9c0-0.22,0.38-0.44,1.1-0.44c1.58,0,2.52,0.71,2.52,1.91\nC18.26,3.01,18.14,3.41,17.93,3.77 M22,24.16c0.13,0,0.26,0.02,0.38,0.07c0.64,1.3,1.4,2.53,2.29,3.68l0,0l0,0\nc0.81-0.14,1.63-0.22,2.45-0.24l0,0c0.1-0.01,0.2,0.01,0.28,0.07c0.07,0.09,0.1,0.2,0.09,0.31c-0.01,0.28-0.08,0.55-0.21,0.79\nc-0.46-0.4-1.07-0.59-1.68-0.51c-0.24,0.01-0.48,0.05-0.71,0.12h-0.07h-0.07l0.48,0.49c0.77,0.83,1.44,1.43,1.44,1.83\nc-0.04,0.31-0.22,0.58-0.48,0.74c-0.22-0.98-0.8-1.84-1.62-2.42h-0.06v0.27c0,0.19,0,0.47,0,0.77c0,1.49-0.15,1.72-0.67,1.72\nc-0.09,0.01-0.19,0.01-0.28,0c0.33-0.49,0.48-1.08,0.41-1.67v-0.7c0-0.27,0.03-0.53,0.06-0.8v-0.11h-0.08\nc-0.33-0.05-0.67-0.09-1-0.1c-0.57-0.07-1.14,0.07-1.6,0.41c-0.24-0.18-0.41-0.44-0.48-0.73c0-0.32,0.19-0.34,0.45-0.34\nc0.14-0.01,0.27-0.01,0.41,0c0.59,0.09,1.18,0.13,1.78,0.12h0.06v-0.06c-0.5-1.13-1.18-2.17-2-3.09c0.1-0.35,0.2-0.59,0.54-0.59\nM12.64,27.87v0.06h0.06c0.55-0.01,1.1-0.06,1.64-0.16c0.14-0.01,0.27-0.01,0.41,0c0.26,0,0.45,0,0.45,0.34\nc-0.07,0.29-0.24,0.55-0.48,0.73c-0.46-0.34-1.03-0.49-1.6-0.41c-0.33,0.01-0.67,0.05-1,0.1H12v0.11\nc0.03,0.27,0.06,0.53,0.06,0.8v0.7c-0.05,0.58,0.1,1.15,0.42,1.63c-0.09,0.01-0.19,0.01-0.28,0c-0.52,0-0.67-0.23-0.67-1.72\nc0-0.3,0-0.58,0-0.77V29l-0.06,0.05c-0.82,0.58-1.39,1.44-1.61,2.42c-0.28-0.14-0.47-0.4-0.53-0.7c0-0.43,0.65-1.07,1.39-1.81\nl0.43-0.43v-0.06h-0.14c-0.23-0.07-0.47-0.11-0.71-0.12c-0.61-0.08-1.22,0.11-1.68,0.51c-0.13-0.24-0.2-0.51-0.21-0.79\nc0.01-0.11,0.06-0.22,0.14-0.3c0.08-0.06,0.18-0.08,0.28-0.07l0,0c0.82,0.02,1.64,0.1,2.45,0.24l0,0l0,0\nc0.88-1.15,1.64-2.38,2.28-3.68c0.12-0.05,0.25-0.07,0.38-0.07c0.35,0,0.44,0.24,0.54,0.59c-0.82,0.92-1.5,1.96-2,3.09\nM7.78,6.87c0.08-1.36,0.7-2.62,1.72-3.52l0.32,0.07C9.06,4.19,8.6,5.19,8.51,6.26c0,2.56,2.73,4.78,5.82,4.78\nc0,0.22,0,0.45,0,0.69c-0.01,0.35,0,0.69,0.03,1.04c-3.5,0-6.58-2.86-6.58-5.92 M31.25,12.23c1.57,2.49,2.8,2.45,4.66,2.45\nc-1.19-0.97-2.21-2.14-3-3.46L30,6.65c-0.29-1.44-1.03-2.75-2.12-3.73c0.31-0.1,0.6-0.24,0.87-0.42c-1.88,0-3.73-1-4.75-1\nc-0.55-0.05-1.03,0.36-1.08,0.91c0,0.58,0.63,1.16,1.73,1.16c0.31,0,0.62-0.04,0.92-0.09c0.65,0.74,1.03,1.67,1.08,2.65\nc0,2-2.41,3.58-4.83,3.58h-0.41c-0.5-0.67-0.84-1.45-1-2.28c0-1.6,1.05-2.9,1.05-4.48c0-0.68-0.24-1.33-0.67-1.85\nc0.29-0.23,0.53-0.52,0.7-0.85c-0.22,0.08-0.45,0.11-0.68,0.09c-1.16,0-2.11-0.3-3-0.3c-0.53,0-0.67,0.16-0.67,0.31\nc-0.01,0.05-0.01,0.1,0,0.15c-0.19-0.08-0.39-0.13-0.59-0.17c-0.29-0.05-0.58-0.08-0.88-0.08c-1.13,0-1.52,0.47-1.52,0.87\nc0.07,0.52,0.27,1.01,0.57,1.44c0.4-0.2,0.84-0.31,1.28-0.34c0.6,0,1.13,0.57,1.41,1.24c-0.29,0.05-0.59,0.07-0.88,0.07\nc-0.68-0.03-1.36-0.16-2-0.39l0,0c0,0,0.31,0.56,0.92,0.78c0.72,0.22,1.46,0.37,2.21,0.45c-0.08,0.21-0.23,0.38-0.43,0.49\nc-0.05,0.02-0.09,0.02-0.14,0c-0.74-0.14-1.45-0.35-2.14-0.65H14.9c0,0.42,1.09,1.35,2.07,1.71c-1.06,1.1-1.87,2.41-2.39,3.85\nh-0.41c-2.42,0-4.82-1.57-4.82-3.58c0.05-0.98,0.43-1.91,1.07-2.65c0.3,0.05,0.61,0.09,0.92,0.09c1.1,0,1.69-0.58,1.74-1.16\nc-0.04-0.55-0.52-0.96-1.07-0.92c0,0,0,0-0.01,0c-1,0-2.88,1-4.76,1C7.51,2.73,7.8,2.87,8.11,2.97C7.03,3.94,6.29,5.23,6,6.65\nl-2.87,4.59c-0.79,1.32-1.81,2.49-3,3.46c1.86,0,3.09,0,4.66-2.45L6.26,9.9c0.11,0.31,0.24,0.61,0.4,0.9l-2.97,4.67\nc-0.79,1.32-1.8,2.49-3,3.46c1.85,0,3.08,0,4.65-2.44l2.52-4c0.19,0.2,0.39,0.4,0.6,0.58l-3.59,5.7c-0.79,1.32-1.8,2.49-3,3.45\nc1.85,0,3.08,0.05,4.65-2.44L10,14.2c0.22,0.14,0.46,0.28,0.7,0.41l-4.27,6.77c-0.79,1.31-1.81,2.48-3,3.45\nc1.85,0,3.08,0,4.65-2.44l4.36-7c0.25,0.1,0.51,0.2,0.78,0.28l-4.95,7.9c-0.79,1.31-1.81,2.48-3,3.45c1.85,0,3.08,0.05,4.65-2.43\nl5.24-8.39h0.16c0.14,0.42,0.22,0.86,0.24,1.3c0,2.64-1.73,5-3.8,6.76c0.19,0.06,0.38,0.09,0.58,0.08c0.3,0.01,0.6-0.01,0.9-0.05\nc-0.57,1.13-1.24,2.21-2,3.23c-0.77-0.13-1.54-0.2-2.32-0.22c-0.67,0-0.75,0.4-0.75,0.75c-0.01,0.53,0.22,1.03,0.62,1.38\nc0.13-0.31,0.38-0.73,1.63-0.73h0.13C10.11,29.13,9,30.06,9,30.77c0.06,0.66,0.59,1.18,1.25,1.24c-0.02-0.14-0.02-0.28,0-0.42\nc0.13-0.69,0.48-1.33,1-1.8c-0.01,0.1-0.01,0.2,0,0.3c0,1.43,0.13,2.08,1,2.08c0.31-0.01,0.61-0.12,0.86-0.31\nc-0.5-0.44-0.73-1.11-0.62-1.77c0-0.21,0-0.41,0-0.69c0.02-0.2,0.02-0.41,0-0.61c0.24-0.02,0.47-0.02,0.71,0\nc0,0,1.29-0.1,1.6,0.57c0.35-0.32,0.86-0.78,0.86-1.27c0-0.33-0.16-0.71-0.83-0.71c-0.25,0-1,0.16-1.7,0.16\nc0.48-0.84,1.04-1.64,1.66-2.39c0.1,0.39,0.31,0.74,0.62,1c0.12-1.17,0.54-2.28,1.21-3.24c0.16,0.93,0.24,1.87,0.23,2.82\nc0,3.55-0.85,6.17-2.66,6.67c0.26,0.46,0.73,0.75,1.25,0.78c0.66,0,1-0.75,1.39-1.46c0.19,0.53,0.72,1.8,1.25,1.8\ns1.06-1.27,1.25-1.8c0.37,0.71,0.73,1.46,1.39,1.46c0.52-0.03,1-0.33,1.26-0.78c-1.82-0.5-2.67-3.12-2.67-6.67\nc-0.01-0.95,0.07-1.89,0.23-2.82c0.68,0.96,1.1,2.07,1.21,3.24c0.31-0.26,0.53-0.61,0.63-1c0.61,0.75,1.15,1.54,1.62,2.38\nc-0.66,0-1.45-0.16-1.7-0.16c-0.67,0-0.82,0.38-0.82,0.71c0,0.49,0.51,1,0.86,1.27c0.3-0.67,1.59-0.57,1.59-0.57\nc0.24-0.02,0.47-0.02,0.71,0c-0.02,0.2-0.02,0.41,0,0.61v0.69c0.11,0.66-0.12,1.33-0.62,1.77c0.25,0.19,0.55,0.3,0.86,0.31\nc0.91,0,1-0.65,1-2.08c0.01-0.1,0.01-0.2,0-0.3c0.52,0.47,0.87,1.11,1,1.8c0.02,0.14,0.02,0.28,0,0.42\nc0.61-0.11,1.06-0.62,1.12-1.23c0-0.74-1.15-1.67-1.52-2.08h0.13c1.25,0,1.5,0.42,1.63,0.73c0.4-0.35,0.63-0.85,0.62-1.38\nc0-0.35-0.07-0.75-0.75-0.75c-0.78,0.02-1.55,0.09-2.32,0.22c-0.76-1.02-1.43-2.1-2-3.23c0.3,0.04,0.6,0.06,0.9,0.05\nc0.19,0.01,0.39-0.02,0.57-0.08c-2.07-1.79-3.8-4.12-3.8-6.76c0.02-0.44,0.1-0.88,0.24-1.3h0.16l5.24,8.39\nc1.57,2.48,2.8,2.43,4.65,2.43c-1.19-0.97-2.21-2.14-3-3.45l-4.92-7.87c0.27-0.08,0.53-0.18,0.79-0.28l4.35,7\nc1.57,2.48,2.8,2.44,4.65,2.44c-1.19-0.97-2.21-2.14-3-3.45l-4.23-6.77c0.24-0.13,0.48-0.27,0.7-0.41l3.42,5.55\nc1.57,2.49,2.8,2.44,4.65,2.44c-1.19-0.97-2.21-2.13-3-3.45l-3.55-5.69c0.2-0.18,0.4-0.38,0.59-0.58l2.52,4\nc1.57,2.48,2.8,2.44,4.65,2.44c-1.2-0.97-2.21-2.14-3-3.46l-2.99-4.7c0.16-0.29,0.29-0.59,0.4-0.9L31.25,12.23z\"\n\t></path>\n);\n\n@Component({\n\ttag: 'kol-logo',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolLogo implements Generic.Element.ComponentApi<RequiredProps, OptionalProps, RequiredStates, OptionalStates> {\n\t/**\n\t * Gibt die Abkürzung eines Ministeriums, eines Amts oder einer Bundesanstalt an.\n\t *\n\t * @deprecated Verwende stattdessen das Property _org.\n\t */\n\t@Prop() public _abbr?: Bundesministerium | Bundesamt | Bundesanstalt;\n\n\t/**\n\t * Gibt die Abkürzung eines Ministeriums, eines Amts oder einer Bundesanstalt an.\n\t */\n\t@Prop() public _org!: Bundesministerium | Bundesamt | Bundesanstalt;\n\n\t/**\n\t * @see: components/abbr/component.tsx (@State)\n\t */\n\t@State() public state: States = {\n\t\t_org: Bundesanstalt['Informationstechnikzentrum Bund'],\n\t};\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_abbr')\n\tpublic validateAbbr(value?: Bundesministerium | Bundesamt | Bundesanstalt): void {\n\t\tthis.validateOrg(value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_org')\n\tpublic validateOrg(value?: Bundesministerium | Bundesamt | Bundesanstalt): void {\n\t\tif (typeof value === 'string' && ENUM_AS_MAP.has(value)) {\n\t\t\tsetState(this, '_org', value);\n\t\t} else {\n\t\t\tdevHint(`Die verwendete Abkürzung (${value as string}) ist nicht definiert!`);\n\t\t}\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (componentWillLoad)\n\t */\n\tpublic componentWillLoad(): void {\n\t\tthis.validateOrg(this._org || this._abbr);\n\t}\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<svg\n\t\t\t\taria-label={translate('kol-logo-description', { placeholders: { orgShort: this.state._org, orgLong: getAriaLabel(this.state._org) } })}\n\t\t\t\trole=\"img\"\n\t\t\t\tviewBox=\"0 0 225 100\"\n\t\t\t>\n\t\t\t\t<rect width=\"100%\" height=\"100%\" fill=\"white\"></rect>\n\t\t\t\t<svg x=\"0\" y=\"4\" height=\"75\">\n\t\t\t\t\t<Adler />\n\t\t\t\t</svg>\n\t\t\t\t<svg x=\"40.5\" y=\"3.5\" height=\"100\">\n\t\t\t\t\t<rect width=\"5\" height=\"30\"></rect>\n\t\t\t\t\t<rect y=\"30\" width=\"5\" height=\"30\" fill=\"red\"></rect>\n\t\t\t\t\t<rect y=\"60\" width=\"5\" height=\"30\" fill=\"#fc0\"></rect>\n\t\t\t\t</svg>\n\t\t\t\t<svg x=\"50\" y=\"0\">\n\t\t\t\t\t<text x=\"0\" y=\"-0.05em\" font-family=\"BundesSans Web\" style={{ backgroundColor: 'white', color: 'black' }}>\n\t\t\t\t\t\t{BUND_LOGO_TEXT_MAP.has(this.state._org) ? (\n\t\t\t\t\t\t\t<tspan>\n\t\t\t\t\t\t\t\t{BUND_LOGO_TEXT_MAP.get(this.state._org)?.map((text: string, index: number) => {\n\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t<tspan x=\"0\" dy=\"1.1em\" key={`kol-logo-text-${index}`}>\n\t\t\t\t\t\t\t\t\t\t\t{text}\n\t\t\t\t\t\t\t\t\t\t</tspan>\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</tspan>\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t<tspan fill=\"red\">\n\t\t\t\t\t\t\t\t<tspan x=\"0\" dy=\"1.1em\">\n\t\t\t\t\t\t\t\t\tDer Schlüsselwert\n\t\t\t\t\t\t\t\t</tspan>\n\t\t\t\t\t\t\t\t<tspan x=\"0\" dy=\"1.1em\" font-weight=\"bold\">\n\t\t\t\t\t\t\t\t\t'{this.state._org}'\n\t\t\t\t\t\t\t\t</tspan>\n\t\t\t\t\t\t\t\t<tspan x=\"0\" dy=\"1.1em\">\n\t\t\t\t\t\t\t\t\tist nicht definiert.\n\t\t\t\t\t\t\t\t</tspan>\n\t\t\t\t\t\t\t\t<tspan x=\"0\" dy=\"1.1em\">\n\t\t\t\t\t\t\t\t\toder freigegeben.\n\t\t\t\t\t\t\t\t</tspan>\n\t\t\t\t\t\t\t</tspan>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</text>\n\t\t\t\t</svg>\n\t\t\t</svg>\n\t\t);\n\t}\n}\n"],"mappings":";;;gWAAA,MAAMA,EAAkB,8+CCQxB,SAASC,EAAYC,EAAqCC,EAAiC,IAAIC,KAC9FC,OAAOC,QAAQJ,GAAaK,KAAI,EAAEC,EAAKC,MACtCN,EAAUO,IAAID,EAAOD,EAAI,IAE1B,OAAOL,CACR,CAEA,MAAMQ,EAAcV,EAAYW,EAAWX,EAAYY,EAAeZ,EAAYa,KAElF,SAASC,EAAaC,GACrB,GAAIL,EAAYM,IAAID,GAAQ,CAC3B,OAAOL,EAAYO,IAAIF,E,KACjB,CACN,MAAO,E,CAET,CAiBA,MAAMG,EAAQ,IACbC,EAAA,QACCC,EAAE,slM,MAiESC,EAAO,M,6EAgBa,CAC/BC,KAAMV,EAAc,mC,CAOdW,aAAaf,GACnBgB,KAAKC,YAAYjB,E,CAOXiB,YAAYjB,GAClB,UAAWA,IAAU,UAAYE,EAAYM,IAAIR,GAAQ,CACxDkB,EAASF,KAAM,OAAQhB,E,KACjB,CACNmB,EAAQ,6BAA6BnB,0B,EAOhCoB,oBACNJ,KAAKC,YAAYD,KAAKF,MAAQE,KAAKK,M,CAG7BC,S,MACN,OACCX,EAAA,oBACaY,EAAU,uBAAwB,CAAEC,aAAc,CAAEC,SAAUT,KAAKU,MAAMZ,KAAMa,QAASrB,EAAaU,KAAKU,MAAMZ,SAC5Hc,KAAK,MACLC,QAAQ,eAERlB,EAAA,QAAMmB,MAAM,OAAOC,OAAO,OAAOC,KAAK,UACtCrB,EAAA,OAAKsB,EAAE,IAAIC,EAAE,IAAIH,OAAO,MACvBpB,EAACD,EAAK,OAEPC,EAAA,OAAKsB,EAAE,OAAOC,EAAE,MAAMH,OAAO,OAC5BpB,EAAA,QAAMmB,MAAM,IAAIC,OAAO,OACvBpB,EAAA,QAAMuB,EAAE,KAAKJ,MAAM,IAAIC,OAAO,KAAKC,KAAK,QACxCrB,EAAA,QAAMuB,EAAE,KAAKJ,MAAM,IAAIC,OAAO,KAAKC,KAAK,UAEzCrB,EAAA,OAAKsB,EAAE,KAAKC,EAAE,KACbvB,EAAA,QAAMsB,EAAE,IAAIC,EAAE,UAAS,cAAa,iBAAiBC,MAAO,CAAEC,gBAAiB,QAASC,MAAO,UAC7FC,EAAmB9B,IAAIQ,KAAKU,MAAMZ,MAClCH,EAAA,cACE4B,EAAAD,EAAmB7B,IAAIO,KAAKU,MAAMZ,SAAK,MAAAyB,SAAA,SAAAA,EAAEzC,KAAI,CAAC0C,EAAcC,IAE3D9B,EAAA,SAAOsB,EAAE,IAAIS,GAAG,QAAQ3C,IAAK,iBAAiB0C,KAC5CD,MAML7B,EAAA,SAAOqB,KAAK,OACXrB,EAAA,SAAOsB,EAAE,IAAIS,GAAG,SAAO,qBAGvB/B,EAAA,SAAOsB,EAAE,IAAIS,GAAG,QAAO,cAAa,QAAM,IACvC1B,KAAKU,MAAMZ,KAAI,KAElBH,EAAA,SAAOsB,EAAE,IAAIS,GAAG,SAAO,wBAGvB/B,EAAA,SAAOsB,EAAE,IAAIS,GAAG,SAAO,wB"}
1
+ {"version":3,"names":["defaultStyleCss","enumToArray","enumeration","enumAsMap","Map","Object","entries","map","key","value","set","ENUM_AS_MAP","Bundesamt","Bundesanstalt","Bundesministerium","getAriaLabel","organ","has","get","Adler","h","d","KolLogo","_org","validateAbbr","this","validateOrg","setState","devHint","componentWillLoad","_abbr","render","translate","placeholders","orgShort","state","orgLong","role","viewBox","width","height","fill","x","y","style","backgroundColor","color","BUND_LOGO_TEXT_MAP","_a","text","index","dy"],"sources":["./src/components/logo/style.css?tag=kol-logo&mode=default&encapsulation=shadow","./src/components/logo/component.tsx"],"sourcesContent":["@import url(../style.css);\ntext {\n\tfont-size: 16px;\n\tletter-spacing: normal;\n\tword-spacing: normal;\n}\n","import { Component, JSX, h, Prop, State, Watch } from '@stencil/core';\n\nimport { BUND_LOGO_TEXT_MAP, Bundesamt, Bundesanstalt, Bundesministerium } from '../../enums/bund';\nimport { Generic } from '@a11y-ui/core';\nimport { devHint } from '../../utils/a11y.tipps';\nimport { setState } from '../../utils/prop.validators';\nimport { translate } from '../../i18n';\n\nfunction enumToArray(enumeration: Record<string, string>, enumAsMap: Map<string, string> = new Map()): Map<string, string> {\n\tObject.entries(enumeration).map(([key, value]) => {\n\t\tenumAsMap.set(value, key);\n\t});\n\treturn enumAsMap;\n}\n\nconst ENUM_AS_MAP = enumToArray(Bundesamt, enumToArray(Bundesanstalt, enumToArray(Bundesministerium)));\n\nfunction getAriaLabel(organ: string): string {\n\tif (ENUM_AS_MAP.has(organ)) {\n\t\treturn ENUM_AS_MAP.get(organ) as string;\n\t} else {\n\t\treturn '';\n\t}\n}\n\ntype RequiredProps = {\n\torg: Bundesministerium | Bundesamt | Bundesanstalt;\n};\ntype OptionalProps = {\n\tabbr: Bundesministerium | Bundesamt | Bundesanstalt;\n};\n// type Props = Generic.Element.Members<RequiredProps, OptionalProps>;\n\ntype RequiredStates = RequiredProps;\ntype OptionalStates = OptionalProps;\ntype States = Generic.Element.Members<RequiredStates, OptionalStates>;\n\nconst Adler = (): JSX.Element => (\n\t<path\n\t\td=\"M21.72,12.77c0.04-0.33,0.06-0.67,0.06-1c0-0.2,0-0.43,0-0.69c3.06,0,5.74-2.25,5.74-4.78\nc-0.09-1.07-0.56-2.08-1.32-2.84l0.32-0.07c1,0.89,1.61,2.14,1.7,3.48c0,3-3,5.85-6.5,5.92 M18.64,2.21\nc-0.05-0.33-0.19-0.64-0.39-0.91c0-0.31,0.14-0.61,0.64-0.36c-0.27,0.27-0.06,0.76-0.06,0.76s0.55-0.26,0.44-0.62\nC20.09,1.28,19.5,2.38,18.64,2.21 M17.93,3.77c-0.12-0.47-0.34-0.9-0.64-1.27c-0.3-0.42-0.77-0.69-1.29-0.73\nc-0.34,0.03-0.68,0.12-1,0.25c-0.16-0.28-0.27-0.58-0.32-0.9c0-0.22,0.38-0.44,1.1-0.44c1.58,0,2.52,0.71,2.52,1.91\nC18.26,3.01,18.14,3.41,17.93,3.77 M22,24.16c0.13,0,0.26,0.02,0.38,0.07c0.64,1.3,1.4,2.53,2.29,3.68l0,0l0,0\nc0.81-0.14,1.63-0.22,2.45-0.24l0,0c0.1-0.01,0.2,0.01,0.28,0.07c0.07,0.09,0.1,0.2,0.09,0.31c-0.01,0.28-0.08,0.55-0.21,0.79\nc-0.46-0.4-1.07-0.59-1.68-0.51c-0.24,0.01-0.48,0.05-0.71,0.12h-0.07h-0.07l0.48,0.49c0.77,0.83,1.44,1.43,1.44,1.83\nc-0.04,0.31-0.22,0.58-0.48,0.74c-0.22-0.98-0.8-1.84-1.62-2.42h-0.06v0.27c0,0.19,0,0.47,0,0.77c0,1.49-0.15,1.72-0.67,1.72\nc-0.09,0.01-0.19,0.01-0.28,0c0.33-0.49,0.48-1.08,0.41-1.67v-0.7c0-0.27,0.03-0.53,0.06-0.8v-0.11h-0.08\nc-0.33-0.05-0.67-0.09-1-0.1c-0.57-0.07-1.14,0.07-1.6,0.41c-0.24-0.18-0.41-0.44-0.48-0.73c0-0.32,0.19-0.34,0.45-0.34\nc0.14-0.01,0.27-0.01,0.41,0c0.59,0.09,1.18,0.13,1.78,0.12h0.06v-0.06c-0.5-1.13-1.18-2.17-2-3.09c0.1-0.35,0.2-0.59,0.54-0.59\nM12.64,27.87v0.06h0.06c0.55-0.01,1.1-0.06,1.64-0.16c0.14-0.01,0.27-0.01,0.41,0c0.26,0,0.45,0,0.45,0.34\nc-0.07,0.29-0.24,0.55-0.48,0.73c-0.46-0.34-1.03-0.49-1.6-0.41c-0.33,0.01-0.67,0.05-1,0.1H12v0.11\nc0.03,0.27,0.06,0.53,0.06,0.8v0.7c-0.05,0.58,0.1,1.15,0.42,1.63c-0.09,0.01-0.19,0.01-0.28,0c-0.52,0-0.67-0.23-0.67-1.72\nc0-0.3,0-0.58,0-0.77V29l-0.06,0.05c-0.82,0.58-1.39,1.44-1.61,2.42c-0.28-0.14-0.47-0.4-0.53-0.7c0-0.43,0.65-1.07,1.39-1.81\nl0.43-0.43v-0.06h-0.14c-0.23-0.07-0.47-0.11-0.71-0.12c-0.61-0.08-1.22,0.11-1.68,0.51c-0.13-0.24-0.2-0.51-0.21-0.79\nc0.01-0.11,0.06-0.22,0.14-0.3c0.08-0.06,0.18-0.08,0.28-0.07l0,0c0.82,0.02,1.64,0.1,2.45,0.24l0,0l0,0\nc0.88-1.15,1.64-2.38,2.28-3.68c0.12-0.05,0.25-0.07,0.38-0.07c0.35,0,0.44,0.24,0.54,0.59c-0.82,0.92-1.5,1.96-2,3.09\nM7.78,6.87c0.08-1.36,0.7-2.62,1.72-3.52l0.32,0.07C9.06,4.19,8.6,5.19,8.51,6.26c0,2.56,2.73,4.78,5.82,4.78\nc0,0.22,0,0.45,0,0.69c-0.01,0.35,0,0.69,0.03,1.04c-3.5,0-6.58-2.86-6.58-5.92 M31.25,12.23c1.57,2.49,2.8,2.45,4.66,2.45\nc-1.19-0.97-2.21-2.14-3-3.46L30,6.65c-0.29-1.44-1.03-2.75-2.12-3.73c0.31-0.1,0.6-0.24,0.87-0.42c-1.88,0-3.73-1-4.75-1\nc-0.55-0.05-1.03,0.36-1.08,0.91c0,0.58,0.63,1.16,1.73,1.16c0.31,0,0.62-0.04,0.92-0.09c0.65,0.74,1.03,1.67,1.08,2.65\nc0,2-2.41,3.58-4.83,3.58h-0.41c-0.5-0.67-0.84-1.45-1-2.28c0-1.6,1.05-2.9,1.05-4.48c0-0.68-0.24-1.33-0.67-1.85\nc0.29-0.23,0.53-0.52,0.7-0.85c-0.22,0.08-0.45,0.11-0.68,0.09c-1.16,0-2.11-0.3-3-0.3c-0.53,0-0.67,0.16-0.67,0.31\nc-0.01,0.05-0.01,0.1,0,0.15c-0.19-0.08-0.39-0.13-0.59-0.17c-0.29-0.05-0.58-0.08-0.88-0.08c-1.13,0-1.52,0.47-1.52,0.87\nc0.07,0.52,0.27,1.01,0.57,1.44c0.4-0.2,0.84-0.31,1.28-0.34c0.6,0,1.13,0.57,1.41,1.24c-0.29,0.05-0.59,0.07-0.88,0.07\nc-0.68-0.03-1.36-0.16-2-0.39l0,0c0,0,0.31,0.56,0.92,0.78c0.72,0.22,1.46,0.37,2.21,0.45c-0.08,0.21-0.23,0.38-0.43,0.49\nc-0.05,0.02-0.09,0.02-0.14,0c-0.74-0.14-1.45-0.35-2.14-0.65H14.9c0,0.42,1.09,1.35,2.07,1.71c-1.06,1.1-1.87,2.41-2.39,3.85\nh-0.41c-2.42,0-4.82-1.57-4.82-3.58c0.05-0.98,0.43-1.91,1.07-2.65c0.3,0.05,0.61,0.09,0.92,0.09c1.1,0,1.69-0.58,1.74-1.16\nc-0.04-0.55-0.52-0.96-1.07-0.92c0,0,0,0-0.01,0c-1,0-2.88,1-4.76,1C7.51,2.73,7.8,2.87,8.11,2.97C7.03,3.94,6.29,5.23,6,6.65\nl-2.87,4.59c-0.79,1.32-1.81,2.49-3,3.46c1.86,0,3.09,0,4.66-2.45L6.26,9.9c0.11,0.31,0.24,0.61,0.4,0.9l-2.97,4.67\nc-0.79,1.32-1.8,2.49-3,3.46c1.85,0,3.08,0,4.65-2.44l2.52-4c0.19,0.2,0.39,0.4,0.6,0.58l-3.59,5.7c-0.79,1.32-1.8,2.49-3,3.45\nc1.85,0,3.08,0.05,4.65-2.44L10,14.2c0.22,0.14,0.46,0.28,0.7,0.41l-4.27,6.77c-0.79,1.31-1.81,2.48-3,3.45\nc1.85,0,3.08,0,4.65-2.44l4.36-7c0.25,0.1,0.51,0.2,0.78,0.28l-4.95,7.9c-0.79,1.31-1.81,2.48-3,3.45c1.85,0,3.08,0.05,4.65-2.43\nl5.24-8.39h0.16c0.14,0.42,0.22,0.86,0.24,1.3c0,2.64-1.73,5-3.8,6.76c0.19,0.06,0.38,0.09,0.58,0.08c0.3,0.01,0.6-0.01,0.9-0.05\nc-0.57,1.13-1.24,2.21-2,3.23c-0.77-0.13-1.54-0.2-2.32-0.22c-0.67,0-0.75,0.4-0.75,0.75c-0.01,0.53,0.22,1.03,0.62,1.38\nc0.13-0.31,0.38-0.73,1.63-0.73h0.13C10.11,29.13,9,30.06,9,30.77c0.06,0.66,0.59,1.18,1.25,1.24c-0.02-0.14-0.02-0.28,0-0.42\nc0.13-0.69,0.48-1.33,1-1.8c-0.01,0.1-0.01,0.2,0,0.3c0,1.43,0.13,2.08,1,2.08c0.31-0.01,0.61-0.12,0.86-0.31\nc-0.5-0.44-0.73-1.11-0.62-1.77c0-0.21,0-0.41,0-0.69c0.02-0.2,0.02-0.41,0-0.61c0.24-0.02,0.47-0.02,0.71,0\nc0,0,1.29-0.1,1.6,0.57c0.35-0.32,0.86-0.78,0.86-1.27c0-0.33-0.16-0.71-0.83-0.71c-0.25,0-1,0.16-1.7,0.16\nc0.48-0.84,1.04-1.64,1.66-2.39c0.1,0.39,0.31,0.74,0.62,1c0.12-1.17,0.54-2.28,1.21-3.24c0.16,0.93,0.24,1.87,0.23,2.82\nc0,3.55-0.85,6.17-2.66,6.67c0.26,0.46,0.73,0.75,1.25,0.78c0.66,0,1-0.75,1.39-1.46c0.19,0.53,0.72,1.8,1.25,1.8\ns1.06-1.27,1.25-1.8c0.37,0.71,0.73,1.46,1.39,1.46c0.52-0.03,1-0.33,1.26-0.78c-1.82-0.5-2.67-3.12-2.67-6.67\nc-0.01-0.95,0.07-1.89,0.23-2.82c0.68,0.96,1.1,2.07,1.21,3.24c0.31-0.26,0.53-0.61,0.63-1c0.61,0.75,1.15,1.54,1.62,2.38\nc-0.66,0-1.45-0.16-1.7-0.16c-0.67,0-0.82,0.38-0.82,0.71c0,0.49,0.51,1,0.86,1.27c0.3-0.67,1.59-0.57,1.59-0.57\nc0.24-0.02,0.47-0.02,0.71,0c-0.02,0.2-0.02,0.41,0,0.61v0.69c0.11,0.66-0.12,1.33-0.62,1.77c0.25,0.19,0.55,0.3,0.86,0.31\nc0.91,0,1-0.65,1-2.08c0.01-0.1,0.01-0.2,0-0.3c0.52,0.47,0.87,1.11,1,1.8c0.02,0.14,0.02,0.28,0,0.42\nc0.61-0.11,1.06-0.62,1.12-1.23c0-0.74-1.15-1.67-1.52-2.08h0.13c1.25,0,1.5,0.42,1.63,0.73c0.4-0.35,0.63-0.85,0.62-1.38\nc0-0.35-0.07-0.75-0.75-0.75c-0.78,0.02-1.55,0.09-2.32,0.22c-0.76-1.02-1.43-2.1-2-3.23c0.3,0.04,0.6,0.06,0.9,0.05\nc0.19,0.01,0.39-0.02,0.57-0.08c-2.07-1.79-3.8-4.12-3.8-6.76c0.02-0.44,0.1-0.88,0.24-1.3h0.16l5.24,8.39\nc1.57,2.48,2.8,2.43,4.65,2.43c-1.19-0.97-2.21-2.14-3-3.45l-4.92-7.87c0.27-0.08,0.53-0.18,0.79-0.28l4.35,7\nc1.57,2.48,2.8,2.44,4.65,2.44c-1.19-0.97-2.21-2.14-3-3.45l-4.23-6.77c0.24-0.13,0.48-0.27,0.7-0.41l3.42,5.55\nc1.57,2.49,2.8,2.44,4.65,2.44c-1.19-0.97-2.21-2.13-3-3.45l-3.55-5.69c0.2-0.18,0.4-0.38,0.59-0.58l2.52,4\nc1.57,2.48,2.8,2.44,4.65,2.44c-1.2-0.97-2.21-2.14-3-3.46l-2.99-4.7c0.16-0.29,0.29-0.59,0.4-0.9L31.25,12.23z\"\n\t></path>\n);\n\n@Component({\n\ttag: 'kol-logo',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolLogo implements Generic.Element.ComponentApi<RequiredProps, OptionalProps, RequiredStates, OptionalStates> {\n\t/**\n\t * Gibt die Abkürzung eines Ministeriums, eines Amts oder einer Bundesanstalt an.\n\t *\n\t * @deprecated Verwende stattdessen das Property _org.\n\t */\n\t@Prop() public _abbr?: Bundesministerium | Bundesamt | Bundesanstalt;\n\n\t/**\n\t * Gibt die Abkürzung eines Ministeriums, eines Amts oder einer Bundesanstalt an.\n\t */\n\t@Prop() public _org!: Bundesministerium | Bundesamt | Bundesanstalt;\n\n\t@State() public state: States = {\n\t\t_org: Bundesanstalt['Informationstechnikzentrum Bund'],\n\t};\n\n\t@Watch('_abbr')\n\tpublic validateAbbr(value?: Bundesministerium | Bundesamt | Bundesanstalt): void {\n\t\tthis.validateOrg(value);\n\t}\n\n\t@Watch('_org')\n\tpublic validateOrg(value?: Bundesministerium | Bundesamt | Bundesanstalt): void {\n\t\tif (typeof value === 'string' && ENUM_AS_MAP.has(value)) {\n\t\t\tsetState(this, '_org', value);\n\t\t} else {\n\t\t\tdevHint(`Die verwendete Abkürzung (${value as string}) ist nicht definiert!`);\n\t\t}\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateOrg(this._org || this._abbr);\n\t}\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<svg\n\t\t\t\taria-label={translate('kol-logo-description', { placeholders: { orgShort: this.state._org, orgLong: getAriaLabel(this.state._org) } })}\n\t\t\t\trole=\"img\"\n\t\t\t\tviewBox=\"0 0 225 100\"\n\t\t\t>\n\t\t\t\t<rect width=\"100%\" height=\"100%\" fill=\"white\"></rect>\n\t\t\t\t<svg x=\"0\" y=\"4\" height=\"75\">\n\t\t\t\t\t<Adler />\n\t\t\t\t</svg>\n\t\t\t\t<svg x=\"40.5\" y=\"3.5\" height=\"100\">\n\t\t\t\t\t<rect width=\"5\" height=\"30\"></rect>\n\t\t\t\t\t<rect y=\"30\" width=\"5\" height=\"30\" fill=\"red\"></rect>\n\t\t\t\t\t<rect y=\"60\" width=\"5\" height=\"30\" fill=\"#fc0\"></rect>\n\t\t\t\t</svg>\n\t\t\t\t<svg x=\"50\" y=\"0\">\n\t\t\t\t\t<text x=\"0\" y=\"-0.05em\" font-family=\"BundesSans Web\" style={{ backgroundColor: 'white', color: 'black' }}>\n\t\t\t\t\t\t{BUND_LOGO_TEXT_MAP.has(this.state._org) ? (\n\t\t\t\t\t\t\t<tspan>\n\t\t\t\t\t\t\t\t{BUND_LOGO_TEXT_MAP.get(this.state._org)?.map((text: string, index: number) => {\n\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t<tspan x=\"0\" dy=\"1.1em\" key={`kol-logo-text-${index}`}>\n\t\t\t\t\t\t\t\t\t\t\t{text}\n\t\t\t\t\t\t\t\t\t\t</tspan>\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</tspan>\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t<tspan fill=\"red\">\n\t\t\t\t\t\t\t\t<tspan x=\"0\" dy=\"1.1em\">\n\t\t\t\t\t\t\t\t\tDer Schlüsselwert\n\t\t\t\t\t\t\t\t</tspan>\n\t\t\t\t\t\t\t\t<tspan x=\"0\" dy=\"1.1em\" font-weight=\"bold\">\n\t\t\t\t\t\t\t\t\t'{this.state._org}'\n\t\t\t\t\t\t\t\t</tspan>\n\t\t\t\t\t\t\t\t<tspan x=\"0\" dy=\"1.1em\">\n\t\t\t\t\t\t\t\t\tist nicht definiert.\n\t\t\t\t\t\t\t\t</tspan>\n\t\t\t\t\t\t\t\t<tspan x=\"0\" dy=\"1.1em\">\n\t\t\t\t\t\t\t\t\toder freigegeben.\n\t\t\t\t\t\t\t\t</tspan>\n\t\t\t\t\t\t\t</tspan>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</text>\n\t\t\t\t</svg>\n\t\t\t</svg>\n\t\t);\n\t}\n}\n"],"mappings":";;;gWAAA,MAAMA,EAAkB,quBCQxB,SAASC,EAAYC,EAAqCC,EAAiC,IAAIC,KAC9FC,OAAOC,QAAQJ,GAAaK,KAAI,EAAEC,EAAKC,MACtCN,EAAUO,IAAID,EAAOD,EAAI,IAE1B,OAAOL,CACR,CAEA,MAAMQ,EAAcV,EAAYW,EAAWX,EAAYY,EAAeZ,EAAYa,KAElF,SAASC,EAAaC,GACrB,GAAIL,EAAYM,IAAID,GAAQ,CAC3B,OAAOL,EAAYO,IAAIF,E,KACjB,CACN,MAAO,E,CAET,CAcA,MAAMG,EAAQ,IACbC,EAAA,QACCC,EAAE,slM,MAiESC,EAAO,M,6EAaa,CAC/BC,KAAMV,EAAc,mC,CAIdW,aAAaf,GACnBgB,KAAKC,YAAYjB,E,CAIXiB,YAAYjB,GAClB,UAAWA,IAAU,UAAYE,EAAYM,IAAIR,GAAQ,CACxDkB,EAASF,KAAM,OAAQhB,E,KACjB,CACNmB,EAAQ,6BAA6BnB,0B,EAIhCoB,oBACNJ,KAAKC,YAAYD,KAAKF,MAAQE,KAAKK,M,CAG7BC,S,MACN,OACCX,EAAA,oBACaY,EAAU,uBAAwB,CAAEC,aAAc,CAAEC,SAAUT,KAAKU,MAAMZ,KAAMa,QAASrB,EAAaU,KAAKU,MAAMZ,SAC5Hc,KAAK,MACLC,QAAQ,eAERlB,EAAA,QAAMmB,MAAM,OAAOC,OAAO,OAAOC,KAAK,UACtCrB,EAAA,OAAKsB,EAAE,IAAIC,EAAE,IAAIH,OAAO,MACvBpB,EAACD,EAAK,OAEPC,EAAA,OAAKsB,EAAE,OAAOC,EAAE,MAAMH,OAAO,OAC5BpB,EAAA,QAAMmB,MAAM,IAAIC,OAAO,OACvBpB,EAAA,QAAMuB,EAAE,KAAKJ,MAAM,IAAIC,OAAO,KAAKC,KAAK,QACxCrB,EAAA,QAAMuB,EAAE,KAAKJ,MAAM,IAAIC,OAAO,KAAKC,KAAK,UAEzCrB,EAAA,OAAKsB,EAAE,KAAKC,EAAE,KACbvB,EAAA,QAAMsB,EAAE,IAAIC,EAAE,UAAS,cAAa,iBAAiBC,MAAO,CAAEC,gBAAiB,QAASC,MAAO,UAC7FC,EAAmB9B,IAAIQ,KAAKU,MAAMZ,MAClCH,EAAA,cACE4B,EAAAD,EAAmB7B,IAAIO,KAAKU,MAAMZ,SAAK,MAAAyB,SAAA,SAAAA,EAAEzC,KAAI,CAAC0C,EAAcC,IAE3D9B,EAAA,SAAOsB,EAAE,IAAIS,GAAG,QAAQ3C,IAAK,iBAAiB0C,KAC5CD,MAML7B,EAAA,SAAOqB,KAAK,OACXrB,EAAA,SAAOsB,EAAE,IAAIS,GAAG,SAAO,qBAGvB/B,EAAA,SAAOsB,EAAE,IAAIS,GAAG,QAAO,cAAa,QAAM,IACvC1B,KAAKU,MAAMZ,KAAI,KAElBH,EAAA,SAAOsB,EAAE,IAAIS,GAAG,SAAO,wBAGvB/B,EAAA,SAAOsB,EAAE,IAAIS,GAAG,SAAO,wB"}
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{r as i,h as o,H as t}from"./index-50adf9a0.js";import{f as e}from"./a11y.tipps-5cdbd5e2.js";import{d as a}from"./dev.utils-05f4e663.js";import{a as l,w as r,s as n,b as s}from"./prop.validators-769a843a.js";import"./reuse-56bb5a4b.js";import"./index-676dbf61.js";const d=":host{--kolibri-border-color:#666;--kolibri-border-radius:0.125rem;--kolibri-border-width:1px;--kolibri-color-black:#000;--kolibri-color-white:#fff;--kolibri-color-error:#f44336;--kolibri-color-info:#2196f3;--kolibri-color-success:#4caf50;--kolibri-color-warning:#ff9800;--kolibri-color-primary:#3f51b5;--kolibri-color-secondary:#ff4081;--kolibri-color-normal:#9e9e9e;--kolibri-color-danger:#f44336;--kolibri-color-ghost:#f5f5f5;--kolibri-color-disabled:#bdbdbd;--kolibri-color-text:#222222;--kolibri-color-visited:#9c27b0;--kolibri-font-family:Verdana, Arial, Tahoma, Helvetica, sans-serif;--kolibri-font-size:16px;--kolibri-spacing:0.25rem}:host *{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}:host{display:inline-flex}a,button{background-color:transparent;border:none;font-size:inherit;margin:0;padding:0;transition-duration:0.5s;transition-property:background-color, color, border-color;width:100%}kol-icon.external-link-icon{display:inline-flex}:host{font-family:var(--kolibri-font-family);font-size:var(--kolibri-font-size)}*{box-sizing:border-box}kol-span-wc{display:grid;gap:var(--kolibri-spacing);place-items:center}kol-span-wc>span{display:flex;gap:var(--kolibri-spacing);place-items:center}kol-span-wc kol-icon{display:contents;padding:0 var(--kolibri-spacing)}a,button,input,select,textarea{appearance:none;cursor:pointer;font-family:var(--kolibri-font-family)}.icon-only>kol-span-wc>span>span{display:none}:host>div{width:100%;height:100%;z-index:100;position:fixed;left:0;top:0;background-color:rgba(0, 0, 0, 0.33)}:host>div>div{height:100%;padding:calc(4 * var(--kolibri-spacing));position:absolute;width:100%}:host>div>div>div{position:relative;max-height:100%;max-width:100%;overflow-x:hidden;overflow-y:auto;left:50%;top:50%;transform:translate(-50%, -50%)}",c=class{constructor(t){i(this,t),this.onKeyDown=i=>{i&&"Escape"===i.code&&(this._activeElement=null)},this._activeElement=void 0,this._ariaLabel=void 0,this._width="100%",this._on=void 0,this._show=!1,this.state={_activeElement:null,_ariaLabel:"…",_show:!1,_width:"100%"}}componentDidRender(){this.hostElement&&(this.state._activeElement?a().Modal.openModal(this.hostElement,this.state._activeElement):a().Modal.closeModal(this.hostElement))}disconnectedCallback(){this.hostElement&&a().Modal.closeModal(this.hostElement)}render(){return o(t,{ref:i=>{this.hostElement=i}},this.state._activeElement&&o("div",null,o("div",null,o("div",{style:{width:this.state._width},"aria-label":this.state._ariaLabel,"aria-modal":"true",role:"dialog",onKeyDown:this.onKeyDown,ref:i=>{i&&(i.setAttribute("tabindex","0"),setTimeout((()=>i.focus()),250))}},o("slot",null)))))}validateActiveElement(i){l(this,"_activeElement",(i=>"object"==typeof i||null===i),new Set(["HTMLElement","null"]),i,{defaultValue:null})}validateAriaLabel(i){r(this,"_ariaLabel",i,{required:!0})}validateOn(i){if("object"==typeof i&&null!==i){e("[KolTabs] Prüfen, wie man auch einen EventCallback einzeln ändern kann.");const t={};"function"!=typeof i.onClose&&!0!==i.onClose||(t.onClose=i.onClose),n(this,"_on",t)}}validateShow(i){s(this,"_show",i,{defaultValue:!1,hooks:{afterPatch:()=>{!1===this.state._show&&(this._activeElement=null)}}})}validateWidth(i){r(this,"_width",i,{defaultValue:"100%"})}componentWillLoad(){this.validateActiveElement(this._activeElement),this.validateAriaLabel(this._ariaLabel),this.validateOn(this._on),this.validateShow(this._show),this.validateWidth(this._width)}static get watchers(){return{_activeElement:["validateActiveElement"],_ariaLabel:["validateAriaLabel"],_on:["validateOn"],_show:["validateShow"],_width:["validateWidth"]}}};c.style={default:d};export{c as kol_modal};
4
+ import{r as t,h as i,H as e}from"./index-50adf9a0.js";import{f as a}from"./a11y.tipps-1cea9822.js";import{d as n}from"./dev.utils-157f0499.js";import{a as s,w as o,s as l}from"./prop.validators-e402ad49.js";import"./reuse-3a02afb9.js";import"./index-81bd9b41.js";const r=":host{--a11y-min-size:44px}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role='button'],button:not([role='link']),kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}:host{max-width:100%}*{box-sizing:border-box}kol-span-wc{display:grid;place-items:center}kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}a,button,input,option,select,textarea{font-family:inherit}.icon-only>kol-span-wc>span>span{display:none}.overlay{background-color:rgba(0, 0, 0, 0.33);display:grid;height:100%;inset:0;place-content:center;position:fixed;width:100%;z-index:100}.modal{max-height:100%;max-width:100%;overflow-x:hidden;overflow-y:auto}",d=class{constructor(e){t(this,e),this.onKeyDown=t=>{t&&"Escape"===t.code&&(this._activeElement=null)},this._activeElement=void 0,this._ariaLabel=void 0,this._width="100%",this._on=void 0,this.state={_activeElement:null,_ariaLabel:"…",_width:"100%"}}componentDidRender(){this.hostElement&&(this.state._activeElement?n().Modal.openModal(this.hostElement,this.state._activeElement):n().Modal.closeModal(this.hostElement))}disconnectedCallback(){this.hostElement&&n().Modal.closeModal(this.hostElement)}render(){return i(e,{ref:t=>{this.hostElement=t}},this.state._activeElement&&i("div",{class:"overlay"},i("div",{class:"modal",style:{width:this.state._width},"aria-label":this.state._ariaLabel,"aria-modal":"true",role:"dialog",onKeyDown:this.onKeyDown,ref:t=>{t&&(t.setAttribute("tabindex","0"),setTimeout((()=>t.focus()),250))}},i("slot",null))))}validateActiveElement(t){s(this,"_activeElement",(t=>"object"==typeof t||null===t),new Set(["HTMLElement","null"]),t,{defaultValue:null})}validateAriaLabel(t){o(this,"_ariaLabel",t,{required:!0})}validateOn(t){if("object"==typeof t&&null!==t){a("[KolTabs] Prüfen, wie man auch einen EventCallback einzeln ändern kann.");const e={};"function"!=typeof t.onClose&&!0!==t.onClose||(e.onClose=t.onClose),l(this,"_on",e)}}validateWidth(t){o(this,"_width",t,{defaultValue:"100%"})}componentWillLoad(){this.validateActiveElement(this._activeElement),this.validateAriaLabel(this._ariaLabel),this.validateOn(this._on),this.validateWidth(this._width)}static get watchers(){return{_activeElement:["validateActiveElement"],_ariaLabel:["validateAriaLabel"],_on:["validateOn"],_width:["validateWidth"]}}};d.style={default:r};export{d as kol_modal};
@@ -1 +1 @@
1
- {"version":3,"names":["defaultStyleCss","KolModal","this","onKeyDown","event","code","_activeElement","_ariaLabel","_show","_width","componentDidRender","hostElement","state","getKoliBri","Modal","openModal","closeModal","disconnectedCallback","render","h","Host","ref","el","style","width","role","setAttribute","setTimeout","focus","validateActiveElement","value","watchValidator","Set","defaultValue","validateAriaLabel","watchString","required","validateOn","featureHint","callbacks","onClose","setState","validateShow","watchBoolean","hooks","afterPatch","validateWidth","componentWillLoad","_on"],"sources":["./src/components/modal/style.css?tag=kol-modal&mode=default&encapsulation=shadow","./src/components/modal/component.tsx"],"sourcesContent":["@import '../style.css';\n\n:host > div {\n\twidth: 100%;\n\theight: 100%;\n\tz-index: 100;\n\tposition: fixed;\n\tleft: 0;\n\ttop: 0;\n\tbackground-color: rgba(0, 0, 0, 0.33);\n}\n:host > div > div {\n\theight: 100%;\n\tpadding: calc(4 * var(--kolibri-spacing));\n\tposition: absolute;\n\twidth: 100%;\n}\n:host > div > div > div {\n\tposition: relative;\n\tmax-height: 100%;\n\tmax-width: 100%;\n\toverflow-x: hidden;\n\toverflow-y: auto;\n\tleft: 50%;\n\ttop: 50%;\n\ttransform: translate(-50%, -50%);\n}\n","/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { Generic } from '@a11y-ui/core';\nimport { AriaLabel } from '../../types/aria-label';\nimport { KoliBriModalEventCallbacks } from '../../types/modal';\nimport { featureHint } from '../../utils/a11y.tipps';\nimport { getKoliBri } from '../../utils/dev.utils';\nimport { setState, watchBoolean, watchString, watchValidator } from '../../utils/prop.validators';\nimport { ModalService } from './service';\n\n/**\n * https://en.wikipedia.org/wiki/Modal_window\n */\n\n/**\n * API\n */\ntype RequiredProps = AriaLabel;\ntype OptionalProps = {\n\tactiveElement: HTMLElement | null;\n\ton: KoliBriModalEventCallbacks;\n\twidth: string;\n\tshow: boolean;\n};\n// type Props = Generic.Element.Members<RequiredProps, OptionalProps>;\n\ntype RequiredStates = AriaLabel & {\n\tactiveElement: HTMLElement | null;\n\twidth: string;\n};\ntype OptionalStates = {\n\ton: KoliBriModalEventCallbacks;\n\tshow: boolean;\n};\ntype States = Generic.Element.Members<RequiredStates, OptionalStates>;\n\n@Component({\n\ttag: 'kol-modal',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolModal implements Generic.Element.ComponentApi<RequiredProps, OptionalProps, RequiredStates, OptionalStates> {\n\tprivate hostElement?: HTMLElement;\n\n\tpublic componentDidRender(): void {\n\t\tif (this.hostElement /* SSR instanceof HTMLElement */) {\n\t\t\tif (this.state._activeElement /* SSR instanceof HTMLElement */) {\n\t\t\t\t(getKoliBri().Modal as ModalService).openModal(this.hostElement, this.state._activeElement);\n\t\t\t} else {\n\t\t\t\t(getKoliBri().Modal as ModalService).closeModal(this.hostElement);\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tif (this.hostElement /* SSR instanceof HTMLElement */) {\n\t\t\t(getKoliBri().Modal as ModalService).closeModal(this.hostElement);\n\t\t}\n\t}\n\n\tprivate readonly onKeyDown = (event: KeyboardEvent) => {\n\t\tif (event && event.code === 'Escape') {\n\t\t\tthis._activeElement = null;\n\t\t}\n\t};\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host\n\t\t\t\tref={(el) => {\n\t\t\t\t\tthis.hostElement = el as HTMLElement;\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t{this.state._activeElement /* SSR instanceof HTMLElement */ && (\n\t\t\t\t\t<div>\n\t\t\t\t\t\t<div>\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\twidth: this.state._width,\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\taria-label={this.state._ariaLabel}\n\t\t\t\t\t\t\t\taria-modal=\"true\"\n\t\t\t\t\t\t\t\trole=\"dialog\"\n\t\t\t\t\t\t\t\tonKeyDown={this.onKeyDown}\n\t\t\t\t\t\t\t\tref={(el) => {\n\t\t\t\t\t\t\t\t\tif (el /* SSR instanceof HTMLElement */) {\n\t\t\t\t\t\t\t\t\t\tel.setAttribute('tabindex', '0');\n\t\t\t\t\t\t\t\t\t\tsetTimeout(() => el.focus(), 250);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<slot />\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Gibt die Referenz auf das auslösende HTML-Element an, wodurch das Modal geöffnet wurde.\n\t */\n\t@Prop({ mutable: true }) public _activeElement?: HTMLElement | null;\n\n\t/**\n\t * Gibt den Text an, der die Navigation von anderen Navigationen differenziert.\n\t */\n\t@Prop() public _ariaLabel!: string;\n\n\t/**\n\t * Gibt an, wie breit der Anzeigebereich sein soll (<= max-width: 100%).\n\t */\n\t@Prop() public _width?: string = '100%';\n\n\t/**\n\t * Gibt die EventCallback-Function für das Schließen des Modals an.\n\t */\n\t@Prop() public _on?: KoliBriModalEventCallbacks;\n\n\t/**\n\t * Gibt an, ob das Modal angezeigt wird.\n\t */\n\t@Prop({ reflect: true }) public _show?: boolean = false;\n\n\t/**\n\t * @see: components/abbr/component.tsx (@State)\n\t */\n\t@State() public state: States = {\n\t\t_activeElement: null,\n\t\t_ariaLabel: '…',\n\t\t_show: false,\n\t\t_width: '100%',\n\t};\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_activeElement')\n\tpublic validateActiveElement(value?: HTMLElement | null): void {\n\t\twatchValidator(this, '_activeElement', (value): boolean => typeof value === 'object' || value === null, new Set(['HTMLElement', 'null']), value, {\n\t\t\tdefaultValue: null,\n\t\t});\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_ariaLabel')\n\tpublic validateAriaLabel(value?: string): void {\n\t\twatchString(this, '_ariaLabel', value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_on')\n\tpublic validateOn(value?: KoliBriModalEventCallbacks): void {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tfeatureHint('[KolTabs] Prüfen, wie man auch einen EventCallback einzeln ändern kann.');\n\t\t\tconst callbacks: KoliBriModalEventCallbacks = {};\n\t\t\tif (typeof value.onClose === 'function' || value.onClose === true) {\n\t\t\t\tcallbacks.onClose = value.onClose;\n\t\t\t}\n\t\t\tsetState<KoliBriModalEventCallbacks>(this, '_on', callbacks);\n\t\t}\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_show')\n\tpublic validateShow(value?: boolean): void {\n\t\twatchBoolean(this, '_show', value, {\n\t\t\tdefaultValue: false,\n\t\t\thooks: {\n\t\t\t\tafterPatch: () => {\n\t\t\t\t\tif (this.state._show === false) {\n\t\t\t\t\t\tthis._activeElement = null;\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_width')\n\tpublic validateWidth(value?: string): void {\n\t\twatchString(this, '_width', value, {\n\t\t\tdefaultValue: '100%',\n\t\t});\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (componentWillLoad)\n\t */\n\tpublic componentWillLoad(): void {\n\t\tthis.validateActiveElement(this._activeElement);\n\t\tthis.validateAriaLabel(this._ariaLabel);\n\t\tthis.validateOn(this._on);\n\t\tthis.validateShow(this._show);\n\t\tthis.validateWidth(this._width);\n\t}\n}\n"],"mappings":";;;8QAAA,MAAMA,EAAkB,oxD,MC4CXC,EAAQ,M,yBAmBHC,KAAAC,UAAaC,IAC7B,GAAIA,GAASA,EAAMC,OAAS,SAAU,CACrCH,KAAKI,eAAiB,I,uEAmDS,O,8BAUiB,M,WAKlB,CAC/BA,eAAgB,KAChBC,WAAY,IACZC,MAAO,MACPC,OAAQ,O,CAxFFC,qBACN,GAAIR,KAAKS,YAA8C,CACtD,GAAIT,KAAKU,MAAMN,eAAiD,CAC9DO,IAAaC,MAAuBC,UAAUb,KAAKS,YAAaT,KAAKU,MAAMN,e,KACtE,CACLO,IAAaC,MAAuBE,WAAWd,KAAKS,Y,GAKjDM,uBACN,GAAIf,KAAKS,YAA8C,CACrDE,IAAaC,MAAuBE,WAAWd,KAAKS,Y,EAUhDO,SACN,OACCC,EAACC,EAAI,CACJC,IAAMC,IACLpB,KAAKS,YAAcW,CAAiB,GAGpCpB,KAAKU,MAAMN,gBACXa,EAAA,WACCA,EAAA,WACCA,EAAA,OACCI,MAAO,CACNC,MAAOtB,KAAKU,MAAMH,QAClB,aACWP,KAAKU,MAAML,WAAU,aACtB,OACXkB,KAAK,SACLtB,UAAWD,KAAKC,UAChBkB,IAAMC,IACL,GAAIA,EAAqC,CACxCA,EAAGI,aAAa,WAAY,KAC5BC,YAAW,IAAML,EAAGM,SAAS,I,IAI/BT,EAAA,gB,CAgDAU,sBAAsBC,GAC5BC,EAAe7B,KAAM,kBAAmB4B,UAA0BA,IAAU,UAAYA,IAAU,MAAM,IAAIE,IAAI,CAAC,cAAe,SAAUF,EAAO,CAChJG,aAAc,M,CAQTC,kBAAkBJ,GACxBK,EAAYjC,KAAM,aAAc4B,EAAO,CACtCM,SAAU,M,CAQLC,WAAWP,GACjB,UAAWA,IAAU,UAAYA,IAAU,KAAM,CAChDQ,EAAY,2EACZ,MAAMC,EAAwC,GAC9C,UAAWT,EAAMU,UAAY,YAAcV,EAAMU,UAAY,KAAM,CAClED,EAAUC,QAAUV,EAAMU,O,CAE3BC,EAAqCvC,KAAM,MAAOqC,E,EAQ7CG,aAAaZ,GACnBa,EAAazC,KAAM,QAAS4B,EAAO,CAClCG,aAAc,MACdW,MAAO,CACNC,WAAY,KACX,GAAI3C,KAAKU,MAAMJ,QAAU,MAAO,CAC/BN,KAAKI,eAAiB,I,MAWpBwC,cAAchB,GACpBK,EAAYjC,KAAM,SAAU4B,EAAO,CAClCG,aAAc,Q,CAOTc,oBACN7C,KAAK2B,sBAAsB3B,KAAKI,gBAChCJ,KAAKgC,kBAAkBhC,KAAKK,YAC5BL,KAAKmC,WAAWnC,KAAK8C,KACrB9C,KAAKwC,aAAaxC,KAAKM,OACvBN,KAAK4C,cAAc5C,KAAKO,O"}
1
+ {"version":3,"names":["defaultStyleCss","KolModal","this","onKeyDown","event","code","_activeElement","_ariaLabel","_width","componentDidRender","hostElement","state","getKoliBri","Modal","openModal","closeModal","disconnectedCallback","render","h","Host","ref","el","class","style","width","role","setAttribute","setTimeout","focus","validateActiveElement","value","watchValidator","Set","defaultValue","validateAriaLabel","watchString","required","validateOn","featureHint","callbacks","onClose","setState","validateWidth","componentWillLoad","_on"],"sources":["./src/components/modal/style.css?tag=kol-modal&mode=default&encapsulation=shadow","./src/components/modal/component.tsx"],"sourcesContent":["@import url(../style.css);\n.overlay {\n\tbackground-color: rgba(0, 0, 0, 0.33);\n\tdisplay: grid;\n\theight: 100%;\n\tinset: 0;\n\tplace-content: center;\n\tposition: fixed;\n\twidth: 100%;\n\tz-index: 100;\n}\n.modal {\n\tmax-height: 100%;\n\tmax-width: 100%;\n\toverflow-x: hidden;\n\toverflow-y: auto;\n}\n","/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { Generic } from '@a11y-ui/core';\nimport { AriaLabel } from '../../types/aria-label';\nimport { KoliBriModalEventCallbacks } from '../../types/modal';\nimport { featureHint } from '../../utils/a11y.tipps';\nimport { getKoliBri } from '../../utils/dev.utils';\nimport { setState, watchString, watchValidator } from '../../utils/prop.validators';\nimport { ModalService } from './service';\n\n/**\n * https://en.wikipedia.org/wiki/Modal_window\n */\n\ntype RequiredProps = AriaLabel;\ntype OptionalProps = {\n\tactiveElement: HTMLElement | null;\n\ton: KoliBriModalEventCallbacks;\n\twidth: string;\n};\n// type Props = Generic.Element.Members<RequiredProps, OptionalProps>;\n\ntype RequiredStates = AriaLabel & {\n\tactiveElement: HTMLElement | null;\n\twidth: string;\n};\ntype OptionalStates = {\n\ton: KoliBriModalEventCallbacks;\n};\ntype States = Generic.Element.Members<RequiredStates, OptionalStates>;\n\n@Component({\n\ttag: 'kol-modal',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolModal implements Generic.Element.ComponentApi<RequiredProps, OptionalProps, RequiredStates, OptionalStates> {\n\tprivate hostElement?: HTMLElement;\n\n\tpublic componentDidRender(): void {\n\t\tif (this.hostElement /* SSR instanceof HTMLElement */) {\n\t\t\tif (this.state._activeElement /* SSR instanceof HTMLElement */) {\n\t\t\t\t(getKoliBri().Modal as ModalService).openModal(this.hostElement, this.state._activeElement);\n\t\t\t} else {\n\t\t\t\t(getKoliBri().Modal as ModalService).closeModal(this.hostElement);\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tif (this.hostElement /* SSR instanceof HTMLElement */) {\n\t\t\t(getKoliBri().Modal as ModalService).closeModal(this.hostElement);\n\t\t}\n\t}\n\n\tprivate readonly onKeyDown = (event: KeyboardEvent) => {\n\t\tif (event && event.code === 'Escape') {\n\t\t\tthis._activeElement = null;\n\t\t}\n\t};\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host\n\t\t\t\tref={(el) => {\n\t\t\t\t\tthis.hostElement = el as HTMLElement;\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t{this.state._activeElement /* SSR instanceof HTMLElement */ && (\n\t\t\t\t\t<div class=\"overlay\">\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclass=\"modal\"\n\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\twidth: this.state._width,\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\taria-label={this.state._ariaLabel}\n\t\t\t\t\t\t\taria-modal=\"true\"\n\t\t\t\t\t\t\trole=\"dialog\"\n\t\t\t\t\t\t\tonKeyDown={this.onKeyDown}\n\t\t\t\t\t\t\tref={(el) => {\n\t\t\t\t\t\t\t\tif (el /* SSR instanceof HTMLElement */) {\n\t\t\t\t\t\t\t\t\tel.setAttribute('tabindex', '0');\n\t\t\t\t\t\t\t\t\tsetTimeout(() => el.focus(), 250);\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\t<slot />\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Gibt die Referenz auf das auslösende HTML-Element an, wodurch das Modal geöffnet wurde.\n\t */\n\t@Prop({ mutable: true }) public _activeElement?: HTMLElement | null;\n\n\t/**\n\t * Gibt den Text an, der die Navigation von anderen Navigationen differenziert.\n\t */\n\t@Prop() public _ariaLabel!: string;\n\n\t/**\n\t * Setzt die Breite des Modals. (max-width: 100%).\n\t */\n\t@Prop() public _width?: string = '100%';\n\n\t/**\n\t * Gibt die EventCallback-Function für das Schließen des Modals an.\n\t */\n\t@Prop() public _on?: KoliBriModalEventCallbacks;\n\n\t@State() public state: States = {\n\t\t_activeElement: null,\n\t\t_ariaLabel: '…',\n\t\t_width: '100%',\n\t};\n\n\t@Watch('_activeElement')\n\tpublic validateActiveElement(value?: HTMLElement | null): void {\n\t\twatchValidator(this, '_activeElement', (value): boolean => typeof value === 'object' || value === null, new Set(['HTMLElement', 'null']), value, {\n\t\t\tdefaultValue: null,\n\t\t});\n\t}\n\n\t@Watch('_ariaLabel')\n\tpublic validateAriaLabel(value?: string): void {\n\t\twatchString(this, '_ariaLabel', value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: KoliBriModalEventCallbacks): void {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tfeatureHint('[KolTabs] Prüfen, wie man auch einen EventCallback einzeln ändern kann.');\n\t\t\tconst callbacks: KoliBriModalEventCallbacks = {};\n\t\t\tif (typeof value.onClose === 'function' || value.onClose === true) {\n\t\t\t\tcallbacks.onClose = value.onClose;\n\t\t\t}\n\t\t\tsetState<KoliBriModalEventCallbacks>(this, '_on', callbacks);\n\t\t}\n\t}\n\n\t@Watch('_width')\n\tpublic validateWidth(value?: string): void {\n\t\twatchString(this, '_width', value, {\n\t\t\tdefaultValue: '100%',\n\t\t});\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateActiveElement(this._activeElement);\n\t\tthis.validateAriaLabel(this._ariaLabel);\n\t\tthis.validateOn(this._on);\n\t\tthis.validateWidth(this._width);\n\t}\n}\n"],"mappings":";;;uQAAA,MAAMA,EAAkB,y3B,MCuCXC,EAAQ,M,yBAmBHC,KAAAC,UAAaC,IAC7B,GAAIA,GAASA,EAAMC,OAAS,SAAU,CACrCH,KAAKI,eAAiB,I,uEAkDS,O,8BAOD,CAC/BA,eAAgB,KAChBC,WAAY,IACZC,OAAQ,O,CA9EFC,qBACN,GAAIP,KAAKQ,YAA8C,CACtD,GAAIR,KAAKS,MAAML,eAAiD,CAC9DM,IAAaC,MAAuBC,UAAUZ,KAAKQ,YAAaR,KAAKS,MAAML,e,KACtE,CACLM,IAAaC,MAAuBE,WAAWb,KAAKQ,Y,GAKjDM,uBACN,GAAId,KAAKQ,YAA8C,CACrDE,IAAaC,MAAuBE,WAAWb,KAAKQ,Y,EAUhDO,SACN,OACCC,EAACC,EAAI,CACJC,IAAMC,IACLnB,KAAKQ,YAAcW,CAAiB,GAGpCnB,KAAKS,MAAML,gBACXY,EAAA,OAAKI,MAAM,WACVJ,EAAA,OACCI,MAAM,QACNC,MAAO,CACNC,MAAOtB,KAAKS,MAAMH,QAClB,aACWN,KAAKS,MAAMJ,WAAU,aACtB,OACXkB,KAAK,SACLtB,UAAWD,KAAKC,UAChBiB,IAAMC,IACL,GAAIA,EAAqC,CACxCA,EAAGK,aAAa,WAAY,KAC5BC,YAAW,IAAMN,EAAGO,SAAS,I,IAI/BV,EAAA,e,CAmCCW,sBAAsBC,GAC5BC,EAAe7B,KAAM,kBAAmB4B,UAA0BA,IAAU,UAAYA,IAAU,MAAM,IAAIE,IAAI,CAAC,cAAe,SAAUF,EAAO,CAChJG,aAAc,M,CAKTC,kBAAkBJ,GACxBK,EAAYjC,KAAM,aAAc4B,EAAO,CACtCM,SAAU,M,CAKLC,WAAWP,GACjB,UAAWA,IAAU,UAAYA,IAAU,KAAM,CAChDQ,EAAY,2EACZ,MAAMC,EAAwC,GAC9C,UAAWT,EAAMU,UAAY,YAAcV,EAAMU,UAAY,KAAM,CAClED,EAAUC,QAAUV,EAAMU,O,CAE3BC,EAAqCvC,KAAM,MAAOqC,E,EAK7CG,cAAcZ,GACpBK,EAAYjC,KAAM,SAAU4B,EAAO,CAClCG,aAAc,Q,CAITU,oBACNzC,KAAK2B,sBAAsB3B,KAAKI,gBAChCJ,KAAKgC,kBAAkBhC,KAAKK,YAC5BL,KAAKmC,WAAWnC,KAAK0C,KACrB1C,KAAKwC,cAAcxC,KAAKM,O"}
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{r as i,h as t,H as a}from"./index-50adf9a0.js";import{d as e,b as o}from"./a11y.tipps-5cdbd5e2.js";import{a as r,w as l,b as s}from"./prop.validators-769a843a.js";import{w as n}from"./validation-f13f1eed.js";import{a as c}from"./i18n-8e14d822.js";import"./dev.utils-05f4e663.js";import"./reuse-56bb5a4b.js";import"./index-676dbf61.js";import"./index-4f2a12cc.js";const d=":host{--kolibri-border-color:#666;--kolibri-border-radius:0.125rem;--kolibri-border-width:1px;--kolibri-color-black:#000;--kolibri-color-white:#fff;--kolibri-color-error:#f44336;--kolibri-color-info:#2196f3;--kolibri-color-success:#4caf50;--kolibri-color-warning:#ff9800;--kolibri-color-primary:#3f51b5;--kolibri-color-secondary:#ff4081;--kolibri-color-normal:#9e9e9e;--kolibri-color-danger:#f44336;--kolibri-color-ghost:#f5f5f5;--kolibri-color-disabled:#bdbdbd;--kolibri-color-text:#222222;--kolibri-color-visited:#9c27b0;--kolibri-font-family:Verdana, Arial, Tahoma, Helvetica, sans-serif;--kolibri-font-size:16px;--kolibri-spacing:0.25rem}:host *{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}:host{display:inline-flex}a,button{background-color:transparent;border:none;font-size:inherit;margin:0;padding:0;transition-duration:0.5s;transition-property:background-color, color, border-color;width:100%}kol-icon.external-link-icon{display:inline-flex}:host{font-family:var(--kolibri-font-family);font-size:var(--kolibri-font-size)}*{box-sizing:border-box}kol-span-wc{display:grid;gap:var(--kolibri-spacing);place-items:center}kol-span-wc>span{display:flex;gap:var(--kolibri-spacing);place-items:center}kol-span-wc kol-icon{display:contents;padding:0 var(--kolibri-spacing)}a,button,input,select,textarea{appearance:none;cursor:pointer;font-family:var(--kolibri-font-family)}.icon-only>kol-span-wc>span>span{display:none}:host>div{display:inline-block}",h=[],p=i=>{const t=h.indexOf(i);t>=0&&h.splice(t,1)},u=class{constructor(a){i(this,a),this.onClick=i=>{i._active=!1===i._active,this.state=Object.assign({},this.state)},this.hasActiveChild=i=>!!(Array.isArray(i._children)&&i._children.length>0)&&i._children.some(this.hasActiveChild),this.linkList=i=>t("ul",{class:{flex:0===i.deep&&"horizontal"===this.state._orientation},part:`nav ${this.state._orientation}`},i.links.map(((a,e)=>t("li",{key:e,part:`li ${0===i.deep?this.state._orientation:"vertical"}${a._active?" selected":""}${e<i.links.length-1?"":" last"}`},Array.isArray(a._children)&&a._children.length>0?t("div",{class:"h-full"},t("div",{class:{"h-full":!0}},t("kol-link-wc",{class:"block w-full h-full",exportparts:"icon,link,span"+(!0===a._active?",selected":""),_ariaLabel:!0===this.state._compact||!0===a._iconOnly?a._label:void 0,_ariaExpanded:!0===a._active,_disabled:a._disabled,_href:"javascript:void(0)",_icon:!0===this.state._collapsible?!0===a._active?"codicon codicon-remove":"codicon codicon-add":"string"==typeof a._icon?a._icon:"codicon codicon-symbol-event",_iconOnly:!0===this.state._compact||!0===a._iconOnly,_label:a._label,onClick:()=>this.onClick(a)})),!0===a._active&&t("div",{class:{expanded:!0,active:!0===a._active,"active-child":this.hasActiveChild(a),"absolute ":0===i.deep&&"horizontal"===this.state._orientation}},t(this.linkList,{links:a._children,deep:i.deep+1}))):t("div",{class:{"h-full":!0,"text-center":!0===this.state._compact||!0===a._iconOnly}},t("kol-link-wc",{class:{"block w-full h-full":!0,active:!0===a._active},exportparts:"icon,link,span"+(!0===a._active?",selected":""),_ariaCurrent:!0===a._active&&this.state._ariaCurrentValue,_ariaLabel:!0===this.state._compact||!0===a._iconOnly?a._label:void 0,_href:a._href,_icon:"string"==typeof a._icon?a._icon:"codicon codicon-symbol-event","_icon-only":!0===this.state._compact||!0===a._iconOnly,_label:a._label,_on:a._on,_selector:a._selector,_tooltipAlign:a._tooltipAlign,_target:a._target})))))),this._ariaCurrentValue=!1,this._ariaLabel=void 0,this._collapsible=!1,this._compact=!1,this._hasCompactButton=!1,this._orientation="vertical",this._links=void 0,this._variant="primary",this.state={_ariaCurrentValue:!1,_ariaLabel:"…",_collapsible:!0,_hasCompactButton:!1,_links:[],_orientation:"vertical",_variant:"primary"}}render(){let i=this.state._hasCompactButton;return"horizontal"===this.state._orientation&&!0===this.state._hasCompactButton&&(i=!1,e("[KolNav] Wenn eine horizontale Navigation verwendet wird, kann die Option _hasCompactButton nicht aktiviert werden.")),t(a,null,t("div",{class:{[this.state._orientation]:!0,"inline-block":!0===this.state._compact,[this.state._variant]:!0}},t("nav",{"aria-label":this.state._ariaLabel,id:"nav",part:"nav"},t(this.linkList,{links:this.state._links,deep:0})),i&&t("div",{class:"mt-2 w-full text-center"},t("kol-button",{exportparts:"button,ghost",_ariaControls:"nav",_ariaExpanded:!0===this.state._compact,_ariaLabel:c(this.state._compact?"kol-nav-maximize":"kol-nav-minimize"),_icon:this.state._compact?"codicon codicon-chevron-right":"codicon codicon-chevron-left",_iconOnly:!0,_label:c(this.state._compact?"kol-nav-maximize":"kol-nav-minimize"),_on:{onClick:()=>{this.state=Object.assign(Object.assign({},this.state),{_compact:!1===this.state._compact})}},_tooltipAlign:"right",_variant:"ghost"}))))}validateAriaCurrentValue(i){r(this,"_ariaCurrentValue",(i=>!0===i||"date"===i||"location"===i||"page"===i||"step"===i||"time"===i),new Set(["boolean","String {data, location, page, step, time}"]),i)}validateAriaLabel(i){l(this,"_ariaLabel",i,{hooks:{afterPatch:()=>{h.includes(this.state._ariaLabel)&&e(`[KolNav] Das Aria-Label "${this.state._ariaLabel}" wurde für die Rolle Navigation mehrfach verwendet!`),h.push(this.state._ariaLabel)},beforePatch:()=>{p(this.state._ariaLabel)}},required:!0}),o(i)}validateCollapsible(i){s(this,"_collapsible",i)}validateCompact(i){s(this,"_compact",i)}validateHasCompactButton(i){s(this,"_hasCompactButton",i)}validateLinks(i){n("KolNav",this,i),e("[KolNav] Die Navigationsstruktur wird noch nicht rekursiv validiert.")}validateOrientation(i){r(this,"_orientation",(i=>"horizontal"===i||"vertical"===i),new Set(["Orientation {horizontal, vertical}"]),i,{defaultValue:"vertical"})}validateVariant(i){r(this,"_variant",(i=>"primary"===i||"secondary"===i),new Set(["KoliBriNavVariant {primary, secondary}"]),i,{defaultValue:"primary"})}componentWillLoad(){this.validateAriaCurrentValue(this._ariaCurrentValue),this.validateAriaLabel(this._ariaLabel),this.validateCollapsible(this._collapsible),this.validateCompact(this._compact),this.validateHasCompactButton(this._hasCompactButton),this.validateLinks(this._links),this.validateOrientation(this._orientation),this.validateVariant(this._variant)}disconnectedCallback(){p(this.state._ariaLabel)}static get watchers(){return{_ariaCurrentValue:["validateAriaCurrentValue"],_ariaLabel:["validateAriaLabel"],_collapsible:["validateCollapsible"],_compact:["validateCompact"],_hasCompactButton:["validateHasCompactButton"],_links:["validateLinks"],_orientation:["validateOrientation"],_variant:["validateVariant"]}}};u.style={default:d};export{u as kol_nav};
4
+ import{r as t,h as i,H as a}from"./index-50adf9a0.js";import{a as e}from"./i18n-cbc21d6e.js";import{g as n,b as s,d as r}from"./a11y.tipps-1cea9822.js";import{b as o,a as l,w as c}from"./prop.validators-e402ad49.js";import{w as h}from"./validation-ab9a6c0d.js";import"./index-fef6600b.js";import"./index-81bd9b41.js";import"./dev.utils-157f0499.js";import"./reuse-3a02afb9.js";const d=(t,a)=>{o(t,"_collapsible",a)},p=(t,a)=>{o(t,"_compact",a)},u=(t,a)=>{o(t,"_hasCompactButton",a)},m=":host{--a11y-min-size:44px}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role='button'],button:not([role='link']),kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}:host{max-width:100%}*{box-sizing:border-box}kol-span-wc{display:grid;place-items:center}kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}a,button,input,option,select,textarea{font-family:inherit}.icon-only>kol-span-wc>span>span{display:none}:host>div{display:grid;place-items:center}.list{display:flex;list-style:none;margin:0;padding:0}.list.vertical{flex-direction:column}.entry{display:flex}.entry kol-button-wc:first-child,.entry kol-link-wc,.entry kol-span-wc{flex-grow:1}.entry kol-span-wc{justify-items:start}",v=[],b=t=>{const a=v.indexOf(t);a>=0&&v.splice(a,1)},_=class{constructor(a){t(this,a),this.onClick=t=>{t._active=!t._active,this.state=Object.assign({},this.state)},this.hasActiveChild=t=>!!(Array.isArray(t._children)&&t._children.length>0)&&t._children.some(this.hasActiveChild),this.linkList=t=>i("ul",{class:"list "+(0===t.deep&&"horizontal"===t.orientation?" horizontal":" vertical"),"data-deep":t.deep},t.links.map(((a,i)=>this.li(t.collapsible,t.compact,t.deep,i,a,t.orientation)))),this._ariaCurrentValue=!1,this._ariaLabel=void 0,this._collapsible=!0,this._compact=!1,this._hasCompactButton=!1,this._orientation="vertical",this._links=void 0,this._variant="primary",this.state={_ariaCurrentValue:!1,_ariaLabel:"",_collapsible:!0,_hasCompactButton:!1,_links:[],_orientation:"vertical",_variant:"primary"}}button(t,a,e,n,l,o){return i("kol-button-wc",{_ariaExpanded:t,_disabled:e,_icon:n||"-",_iconOnly:a,_label:l,_on:o})}text(t,a,e){return i("kol-span-wc",{_icon:a||"-",_iconOnly:t,_label:e})}entry(t,a,e,n,l,o,s){return i("div",{class:{entry:!0,"has-children":e,selected:o,expanded:l,"text-center":s}},this.buttonOrLinkOrText(a,n,o),e?this.expandButton(t,n,o):"")}expandButton(t,a,e){return i("kol-button-wc",{class:"expand-button",_disabled:!t,_icon:"codicon codicon-"+(e?"remove":"add"),_iconOnly:!0,_label:`Untermenü zu ${a._label} ${e?"schließen":"öffnen"}`,_on:{onClick:()=>this.onClick(a)}})}li(t,a,e,n,l,o){const s=Array.isArray(l._children)&&l._children.length>0,r=!!l._active,c=s&&!!l._active,h=a;return i("li",{class:{expanded:c,selected:r,"has-children":s},key:n},this.entry(t,a,s,l,c,r,h),s&&r?i(this.linkList,{collapsible:t,compact:a,deep:e+1,links:l._children||[],orientation:o}):"")}link(t,a,e,n,l){return i("kol-link-wc",{_ariaExpanded:t,_href:e,_icon:n||"-",_iconOnly:a,_label:l})}buttonOrLinkOrText(t,a,i){return a._on?this.button(i,t,!0===a._disabled,a._icon,a._label,a._on):a._href?this.link(i,t,a._href,a._icon,a._label):this.text(t,a._icon,a._label)}render(){let t=this.state._hasCompactButton;"horizontal"===this.state._orientation&&!0===this.state._hasCompactButton&&(t=!1,n("[KolNav] Wenn eine horizontale Navigation verwendet wird, kann die Option _hasCompactButton nicht aktiviert werden."));const l=!0===this.state._collapsible,o=!0===this.state._compact,s=this.state._orientation;return i(a,null,i("div",{class:{[s]:!0,[this.state._variant]:!0}},i("nav",{"aria-label":this.state._ariaLabel,id:"nav"},i(this.linkList,{collapsible:l,compact:o,deep:0,links:this.state._links,orientation:s})),t&&i("div",{class:"mt-2 w-full text-center"},i("kol-button",{_ariaControls:"nav",_ariaExpanded:o,_icon:o?"codicon codicon-chevron-right":"codicon codicon-chevron-left",_iconOnly:!0,_label:e(o?"kol-nav-maximize":"kol-nav-minimize"),_on:{onClick:()=>{this.state=Object.assign(Object.assign({},this.state),{_compact:!1===this.state._compact})}},_tooltipAlign:"right",_variant:"ghost"}))))}validateAriaCurrentValue(t){l(this,"_ariaCurrentValue",(t=>!0===t||"date"===t||"location"===t||"page"===t||"step"===t||"time"===t),new Set(["boolean","String {data, location, page, step, time}"]),t)}validateAriaLabel(t){c(this,"_ariaLabel",t,{hooks:{afterPatch:()=>{v.includes(this.state._ariaLabel)&&r(`[KolNav] Das Aria-Label "${this.state._ariaLabel}" wurde für die Rolle Navigation mehrfach verwendet!`),v.push(this.state._ariaLabel)},beforePatch:()=>{b(this.state._ariaLabel)}},required:!0}),s(t)}validateCollapsible(t){d(this,t)}validateCompact(t){p(this,t)}validateHasCompactButton(t){u(this,t)}validateLinks(t){h("KolNav",this,t),r("[KolNav] Die Navigationsstruktur wird noch nicht rekursiv validiert.")}validateOrientation(t){l(this,"_orientation",(t=>"horizontal"===t||"vertical"===t),new Set(["Orientation {horizontal, vertical}"]),t,{defaultValue:"vertical"})}validateVariant(t){l(this,"_variant",(t=>"primary"===t||"secondary"===t),new Set(["KoliBriNavVariant {primary, secondary}"]),t,{defaultValue:"primary"})}componentWillLoad(){this.validateAriaCurrentValue(this._ariaCurrentValue),this.validateAriaLabel(this._ariaLabel),this.validateCollapsible(this._collapsible),this.validateCompact(this._compact),this.validateHasCompactButton(this._hasCompactButton),this.validateLinks(this._links),this.validateOrientation(this._orientation),this.validateVariant(this._variant)}disconnectedCallback(){b(this.state._ariaLabel)}static get watchers(){return{_ariaCurrentValue:["validateAriaCurrentValue"],_ariaLabel:["validateAriaLabel"],_collapsible:["validateCollapsible"],_compact:["validateCompact"],_hasCompactButton:["validateHasCompactButton"],_links:["validateLinks"],_orientation:["validateOrientation"],_variant:["validateVariant"]}}};_.style={default:m};export{_ as kol_nav};
@@ -1 +1 @@
1
- {"version":3,"names":["defaultStyleCss","UNIQUE_ARIA_LABEL","removeAriaLabel","ariaLabel","index","indexOf","splice","KolNav","this","onClick","link","_active","state","Object","assign","hasActiveChild","Array","isArray","_children","length","some","linkList","props","h","class","flex","deep","_orientation","part","links","map","key","exportparts","_ariaLabel","_compact","_iconOnly","_label","undefined","_ariaExpanded","_disabled","_href","_icon","_collapsible","expanded","active","_ariaCurrent","_ariaCurrentValue","_on","_selector","_tooltipAlign","_target","_hasCompactButton","_links","_variant","render","hasCompactButton","devHint","Host","id","_ariaControls","translate","validateAriaCurrentValue","value","watchValidator","Set","validateAriaLabel","watchString","hooks","afterPatch","includes","push","beforePatch","required","a11yHintLabelingLandmarks","validateCollapsible","watchBoolean","validateCompact","validateHasCompactButton","validateLinks","watchNavLinks","validateOrientation","defaultValue","validateVariant","componentWillLoad","disconnectedCallback"],"sources":["./src/components/nav/style.css?tag=kol-nav&mode=default&encapsulation=shadow","./src/components/nav/component.tsx"],"sourcesContent":["@import '../style.css';\n\n:host > div {\n\tdisplay: inline-block;\n}\n","import { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\nimport { Generic } from '@a11y-ui/core';\nimport { Orientation } from '../../types/orientation';\nimport { a11yHintLabelingLandmarks, devHint } from '../../utils/a11y.tipps';\nimport { watchBoolean, watchString, watchValidator } from '../../utils/prop.validators';\nimport { NavLinkProps } from '../link/component';\nimport { watchNavLinks } from './validation';\nimport { Stringified } from '../../types/common';\nimport { AriaCurrent } from '../../types/button-link';\nimport { translate } from '../../i18n';\n\nexport type NavLinkWithChildrenProps = NavLinkProps & {\n\t_children?: NavLinkWithChildrenProps[];\n};\n\nexport type KoliBriNavVariant = 'primary' | 'secondary';\n\nconst UNIQUE_ARIA_LABEL: string[] = [];\nconst removeAriaLabel = (ariaLabel: string) => {\n\tconst index = UNIQUE_ARIA_LABEL.indexOf(ariaLabel);\n\tif (index >= 0) {\n\t\tUNIQUE_ARIA_LABEL.splice(index, 1);\n\t}\n};\n\nconst linkValidator = (link: NavLinkWithChildrenProps): boolean => {\n\tif (typeof link === 'object' && typeof link._label === 'string' /* && typeof newLink._href === 'string' */) {\n\t\tif (Array.isArray(link._children)) {\n\t\t\treturn linksValidator(link._children);\n\t\t}\n\t\treturn false;\n\t}\n\treturn true;\n};\n\nconst linksValidator = (links: NavLinkWithChildrenProps[]): boolean => {\n\tif (Array.isArray(links)) {\n\t\treturn links.find(linkValidator) !== undefined;\n\t}\n\treturn true;\n};\n\n/**\n * API\n */\ntype RequiredProps = {\n\tariaLabel: string;\n\tlinks: Stringified<NavLinkWithChildrenProps[]>;\n};\ntype OptionalProps = {\n\tariaCurrentValue: AriaCurrent;\n\tcollapsible: boolean;\n\tcompact: boolean;\n\thasCompactButton: boolean;\n\torientation: Orientation;\n\tvariant: KoliBriNavVariant;\n};\n// type Props = Generic.Element.Members<RequiredProps, OptionalProps>;\n\ntype RequiredStates = {\n\tariaCurrentValue: AriaCurrent;\n\tariaLabel: string;\n\tcollapsible: boolean;\n\thasCompactButton: boolean;\n\tlinks: NavLinkWithChildrenProps[];\n\torientation: Orientation;\n\tvariant: KoliBriNavVariant;\n};\ntype OptionalStates = {\n\tcompact: boolean;\n};\ntype States = Generic.Element.Members<RequiredStates, OptionalStates>;\n\n/**\n * @part nav - TBD\n */\n@Component({\n\ttag: 'kol-nav',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolNav implements Generic.Element.ComponentApi<RequiredProps, OptionalProps, RequiredStates, OptionalStates> {\n\tprivate readonly onClick = (link: NavLinkWithChildrenProps): void => {\n\t\tlink._active = link._active === false;\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t};\n\t};\n\n\tprivate readonly hasActiveChild = (link: NavLinkWithChildrenProps): boolean => {\n\t\tif (Array.isArray(link._children) && link._children.length > 0) {\n\t\t\treturn link._children.some(this.hasActiveChild);\n\t\t}\n\n\t\treturn false;\n\t};\n\n\tprivate linkList = (props: { links: NavLinkWithChildrenProps[]; deep: number }): JSX.Element => {\n\t\treturn (\n\t\t\t<ul\n\t\t\t\tclass={{\n\t\t\t\t\tflex: props.deep === 0 && this.state._orientation === 'horizontal',\n\t\t\t\t}}\n\t\t\t\tpart={`nav ${this.state._orientation}`}\n\t\t\t>\n\t\t\t\t{props.links.map((link, index: number) => {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<li\n\t\t\t\t\t\t\tkey={index}\n\t\t\t\t\t\t\tpart={`li ${props.deep === 0 ? this.state._orientation : 'vertical'}${link._active ? ' selected' : ''}${\n\t\t\t\t\t\t\t\tindex < props.links.length - 1 ? '' : ' last'\n\t\t\t\t\t\t\t}`}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{Array.isArray(link._children) && link._children.length > 0 ? (\n\t\t\t\t\t\t\t\t<div class=\"h-full\">\n\t\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t\t\t\t'h-full': true,\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\t\t<kol-link-wc\n\t\t\t\t\t\t\t\t\t\t\tclass=\"block w-full h-full\"\n\t\t\t\t\t\t\t\t\t\t\texportparts={`icon,link,span${link._active === true ? ',selected' : ''}`}\n\t\t\t\t\t\t\t\t\t\t\t// _ariaCurrent will not be set here, since it will be set on a child of this item.\n\t\t\t\t\t\t\t\t\t\t\t_ariaLabel={this.state._compact === true || link._iconOnly === true ? link._label : undefined}\n\t\t\t\t\t\t\t\t\t\t\t_ariaExpanded={link._active === true}\n\t\t\t\t\t\t\t\t\t\t\t_disabled={link._disabled}\n\t\t\t\t\t\t\t\t\t\t\t_href=\"javascript:void(0)\"\n\t\t\t\t\t\t\t\t\t\t\t_icon={\n\t\t\t\t\t\t\t\t\t\t\t\tthis.state._collapsible === true\n\t\t\t\t\t\t\t\t\t\t\t\t\t? link._active === true\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'codicon codicon-remove'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t: 'codicon codicon-add'\n\t\t\t\t\t\t\t\t\t\t\t\t\t: typeof link._icon === 'string'\n\t\t\t\t\t\t\t\t\t\t\t\t\t? link._icon\n\t\t\t\t\t\t\t\t\t\t\t\t\t: 'codicon codicon-symbol-event'\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t_iconOnly={this.state._compact === true || link._iconOnly === true}\n\t\t\t\t\t\t\t\t\t\t\t_label={link._label}\n\t\t\t\t\t\t\t\t\t\t\tonClick={() => this.onClick(link)}\n\t\t\t\t\t\t\t\t\t\t></kol-link-wc>\n\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t{link._active === true && (\n\t\t\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t\t\t\t\texpanded: true,\n\t\t\t\t\t\t\t\t\t\t\t\tactive: link._active === true,\n\t\t\t\t\t\t\t\t\t\t\t\t'active-child': this.hasActiveChild(link),\n\t\t\t\t\t\t\t\t\t\t\t\t'absolute ': props.deep === 0 && this.state._orientation === 'horizontal',\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\t\t<this.linkList links={link._children} deep={props.deep + 1} />\n\t\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t\t\t'h-full': true,\n\t\t\t\t\t\t\t\t\t\t'text-center': this.state._compact === true || link._iconOnly === true,\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\t\t<kol-link-wc\n\t\t\t\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t\t\t\t'block w-full h-full': true,\n\t\t\t\t\t\t\t\t\t\t\tactive: link._active === true,\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\texportparts={`icon,link,span${link._active === true ? ',selected' : ''}`}\n\t\t\t\t\t\t\t\t\t\t_ariaCurrent={link._active === true ? this.state._ariaCurrentValue : false}\n\t\t\t\t\t\t\t\t\t\t_ariaLabel={this.state._compact === true || link._iconOnly === true ? link._label : undefined}\n\t\t\t\t\t\t\t\t\t\t_href={link._href}\n\t\t\t\t\t\t\t\t\t\t_icon={typeof link._icon === 'string' ? link._icon : 'codicon codicon-symbol-event'}\n\t\t\t\t\t\t\t\t\t\t_icon-only={this.state._compact === true || link._iconOnly === true}\n\t\t\t\t\t\t\t\t\t\t_label={link._label}\n\t\t\t\t\t\t\t\t\t\t_on={link._on}\n\t\t\t\t\t\t\t\t\t\t_selector={link._selector}\n\t\t\t\t\t\t\t\t\t\t_tooltipAlign={link._tooltipAlign}\n\t\t\t\t\t\t\t\t\t\t_target={link._target}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t</li>\n\t\t\t\t\t);\n\t\t\t\t})}\n\t\t\t</ul>\n\t\t);\n\t};\n\n\tpublic render(): JSX.Element {\n\t\tlet hasCompactButton = this.state._hasCompactButton;\n\t\tif (this.state._orientation === 'horizontal' && this.state._hasCompactButton === true) {\n\t\t\thasCompactButton = false;\n\t\t\tdevHint(`[KolNav] Wenn eine horizontale Navigation verwendet wird, kann die Option _hasCompactButton nicht aktiviert werden.`);\n\t\t}\n\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t<div\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[this.state._orientation]: true,\n\t\t\t\t\t\t'inline-block': this.state._compact === true,\n\t\t\t\t\t\t[this.state._variant]: true,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t<nav aria-label={this.state._ariaLabel} id=\"nav\" part=\"nav\">\n\t\t\t\t\t\t<this.linkList links={this.state._links} deep={0}></this.linkList>\n\t\t\t\t\t</nav>\n\t\t\t\t\t{hasCompactButton && (\n\t\t\t\t\t\t<div class=\"mt-2 w-full text-center\">\n\t\t\t\t\t\t\t<kol-button\n\t\t\t\t\t\t\t\texportparts=\"button,ghost\"\n\t\t\t\t\t\t\t\t_ariaControls=\"nav\"\n\t\t\t\t\t\t\t\t_ariaExpanded={this.state._compact === true}\n\t\t\t\t\t\t\t\t_ariaLabel={translate(this.state._compact ? 'kol-nav-maximize' : 'kol-nav-minimize')}\n\t\t\t\t\t\t\t\t_icon={this.state._compact ? 'codicon codicon-chevron-right' : 'codicon codicon-chevron-left'}\n\t\t\t\t\t\t\t\t_iconOnly\n\t\t\t\t\t\t\t\t_label={translate(this.state._compact ? 'kol-nav-maximize' : 'kol-nav-minimize')}\n\t\t\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\t\t\tonClick: (): void => {\n\t\t\t\t\t\t\t\t\t\tthis.state = {\n\t\t\t\t\t\t\t\t\t\t\t...this.state,\n\t\t\t\t\t\t\t\t\t\t\t_compact: this.state._compact === false,\n\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t_tooltipAlign=\"right\"\n\t\t\t\t\t\t\t\t_variant=\"ghost\"\n\t\t\t\t\t\t\t></kol-button>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Gibt den Wert von aria-current an, der bei dem aktuellen Kontext innerhalb der Navigation verwendet werden soll.\n\t */\n\t@Prop() public _ariaCurrentValue: AriaCurrent = false;\n\n\t/**\n\t * Gibt den Text an, der die Navigation von anderen Navigationen differenziert.\n\t */\n\t@Prop() public _ariaLabel!: string;\n\n\t/**\n\t * Gibt an, ob Knoten in der Navigation zusammengeklappt werden können. Ist standardmäßig aktiv.\n\t */\n\t@Prop({ reflect: true }) public _collapsible?: boolean = false;\n\n\t/**\n\t * Gibt an, ob die Navigation kompakt angezeigt wird.\n\t */\n\t@Prop({ reflect: true }) public _compact?: boolean = false;\n\n\t/**\n\t * Gibt an, ob die Navigation eine zusätzliche Schaltfläche zum Aus- und Einklappen der Navigation anzeigen soll.\n\t */\n\t@Prop({ reflect: true }) public _hasCompactButton?: boolean = false;\n\n\t/**\n\t * Gibt die Ausrichtung der Navigation an.\n\t */\n\t@Prop() public _orientation?: Orientation = 'vertical';\n\n\t/**\n\t * Gibt die geordnete Liste der Seitenhierarchie an.\n\t */\n\t@Prop() public _links!: Stringified<NavLinkWithChildrenProps[]>;\n\n\t/**\n\t * Gibt an, welche Ausprägung der Button hat.\n\t */\n\t@Prop() public _variant?: KoliBriNavVariant = 'primary';\n\n\t/**\n\t * @see: components/abbr/component.tsx (@State)\n\t */\n\t@State() public state: States = {\n\t\t_ariaCurrentValue: false,\n\t\t_ariaLabel: '…', // '⚠'\n\t\t_collapsible: true,\n\t\t_hasCompactButton: false,\n\t\t_links: [],\n\t\t_orientation: 'vertical',\n\t\t_variant: 'primary',\n\t};\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_ariaCurrentValue')\n\tpublic validateAriaCurrentValue(value?: AriaCurrent): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_ariaCurrentValue',\n\t\t\t(value) => value === true || value === 'date' || value === 'location' || value === 'page' || value === 'step' || value === 'time',\n\t\t\tnew Set(['boolean', 'String {data, location, page, step, time}']),\n\t\t\tvalue\n\t\t);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_ariaLabel')\n\tpublic validateAriaLabel(value?: string): void {\n\t\twatchString(this, '_ariaLabel', value, {\n\t\t\thooks: {\n\t\t\t\tafterPatch: () => {\n\t\t\t\t\tif (UNIQUE_ARIA_LABEL.includes(this.state._ariaLabel)) {\n\t\t\t\t\t\tdevHint(`[KolNav] Das Aria-Label \"${this.state._ariaLabel}\" wurde für die Rolle Navigation mehrfach verwendet!`);\n\t\t\t\t\t}\n\t\t\t\t\tUNIQUE_ARIA_LABEL.push(this.state._ariaLabel);\n\t\t\t\t},\n\t\t\t\tbeforePatch: () => {\n\t\t\t\t\tremoveAriaLabel(this.state._ariaLabel);\n\t\t\t\t},\n\t\t\t},\n\t\t\trequired: true,\n\t\t});\n\t\ta11yHintLabelingLandmarks(value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_collapsible')\n\tpublic validateCollapsible(value?: boolean): void {\n\t\twatchBoolean(this, '_collapsible', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_compact')\n\tpublic validateCompact(value?: boolean): void {\n\t\twatchBoolean(this, '_compact', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_hasCompactButton')\n\tpublic validateHasCompactButton(value?: boolean): void {\n\t\twatchBoolean(this, '_hasCompactButton', value);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_links')\n\tpublic validateLinks(value?: Stringified<NavLinkWithChildrenProps[]>): void {\n\t\twatchNavLinks('KolNav', this, value);\n\t\tdevHint(`[KolNav] Die Navigationsstruktur wird noch nicht rekursiv validiert.`);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_orientation')\n\tpublic validateOrientation(value?: Orientation): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_orientation',\n\t\t\t(value): boolean => value === 'horizontal' || value === 'vertical',\n\t\t\tnew Set(['Orientation {horizontal, vertical}']),\n\t\t\tvalue,\n\t\t\t{\n\t\t\t\tdefaultValue: 'vertical',\n\t\t\t}\n\t\t);\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (@Watch)\n\t */\n\t@Watch('_variant')\n\tpublic validateVariant(value?: KoliBriNavVariant): void {\n\t\twatchValidator(this, '_variant', (value) => value === 'primary' || value === 'secondary', new Set(['KoliBriNavVariant {primary, secondary}']), value, {\n\t\t\tdefaultValue: 'primary',\n\t\t});\n\t}\n\n\t/**\n\t * @see: components/abbr/component.tsx (componentWillLoad)\n\t */\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAriaCurrentValue(this._ariaCurrentValue);\n\t\tthis.validateAriaLabel(this._ariaLabel);\n\t\tthis.validateCollapsible(this._collapsible);\n\t\tthis.validateCompact(this._compact);\n\t\tthis.validateHasCompactButton(this._hasCompactButton);\n\t\tthis.validateLinks(this._links);\n\t\tthis.validateOrientation(this._orientation);\n\t\tthis.validateVariant(this._variant);\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tremoveAriaLabel(this.state._ariaLabel);\n\t}\n}\n\n// console.log(\n// stringifyJson([\n// { _label: '1 Navigationspunkt', _href: '#abc', _icon: 'codicon codicon-folder-closed', _target: 'asdasd' },\n// { _label: '2 Navigationspunkt', _href: '#abc', _icon: 'codicon codicon-folder-closed' },\n// {\n// _active: true,\n// _label: '3 Navigationspunkt',\n// _href: '#abc',\n// _icon: 'codicon codicon-folder-closed',\n// _children: [\n// { _label: '3.1 Navigationspunkt', _href: '#abc', _icon: 'codicon codicon-folder-closed' },\n// { _label: '3.2 Navigationspunkt', _href: '#abc', _icon: 'codicon codicon-folder-closed', _target: 'asdasd' },\n// {\n// _active: true,\n// _label: '3.3 Navigationspunkt',\n// _href: '#abc',\n// _children: [\n// { _active: true, _label: '3.3.1 Navigationspunkt (aktiv)', _href: '#abc' },\n// { _label: '3.3.2 Navigationspunkt', _href: '#abc' },\n// ],\n// },\n// {\n// _label: '3.4 Navigationspunkt',\n// _href: '#abc',\n// _children: [\n// { _label: '3.4.1 Navigationspunkt', _href: '#abc' },\n// { _label: '3.4.2 Navigationspunkt', _href: '#abc' },\n// ],\n// },\n// { _label: '3.5 Navigationspunkt', _href: '#abc' },\n// ],\n// },\n// { _label: '4 Navigationspunkt', _href: '#abc' },\n// ])\n// );\n"],"mappings":"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"}
1
+ {"version":3,"names":["validateCollapsible","component","value","watchBoolean","validateCompact","validateHasCompactButton","defaultStyleCss","UNIQUE_ARIA_LABEL","removeAriaLabel","ariaLabel","index","indexOf","splice","KolNav","this","onClick","link","_active","state","Object","assign","hasActiveChild","Array","isArray","_children","length","some","linkList","props","h","class","deep","orientation","links","map","li","collapsible","compact","_ariaCurrentValue","_ariaLabel","_collapsible","_hasCompactButton","_links","_orientation","_variant","button","selected","disabled","icon","label","on","_ariaExpanded","_disabled","_icon","_iconOnly","_label","_on","text","entry","hasChildren","expanded","textCenter","buttonOrLinkOrText","expandButton","key","href","_href","render","hasCompactButton","devWarning","_compact","Host","id","_ariaControls","translate","_tooltipAlign","validateAriaCurrentValue","watchValidator","Set","validateAriaLabel","watchString","hooks","afterPatch","includes","devHint","push","beforePatch","required","a11yHintLabelingLandmarks","validateLinks","watchNavLinks","validateOrientation","defaultValue","validateVariant","componentWillLoad","disconnectedCallback"],"sources":["./src/types/props/collapsible.ts","./src/types/props/compact.ts","./src/types/props/has-compact-button.ts","./src/components/nav/style.css?tag=kol-nav&mode=default&encapsulation=shadow","./src/components/nav/component.tsx"],"sourcesContent":["import { Generic } from '@a11y-ui/core';\nimport { watchBoolean } from '../../utils/prop.validators';\n\n/* types */\n/** de\n * Wenn auf false gesetzt können Knoten in der Navigation nicht zugeklappt werden.\n */\n/** en\n * If set to false navigation nodes cannot be collapsed.\n */\nexport type PropCollapsible = {\n\tcollapsible: boolean;\n};\n\n/* validator */\nexport const validateCollapsible = (component: Generic.Element.Component, value?: boolean): void => {\n\twatchBoolean(component, '_collapsible', value);\n};\n","import { Generic } from '@a11y-ui/core';\nimport { watchBoolean } from '../../utils/prop.validators';\n\n/* types */\n/** de\n * Macht die Navigation kompakt.\n */\n/** en\n * Makes the navigation compact.\n */\nexport type PropCompact = {\n\tcompact: boolean;\n};\n\n/* validator */\nexport const validateCompact = (component: Generic.Element.Component, value?: boolean): void => {\n\twatchBoolean(component, '_compact', value);\n};\n","import { Generic } from '@a11y-ui/core';\nimport { watchBoolean } from '../../utils/prop.validators';\n\n/* types */\n/** de\n * Erzeugt eine Schaltfläche, die _collapsible umschaltet. Nur verfügbar bei _orientation=\"vertical\".\n */\n/** en\n * Creates a button below the navigation, that toggles _collapsible. Only available for _orientation=\"vertical\".\n */\nexport type PropHasCompactButton = {\n\thasCompactButton: boolean;\n};\n\n/* validator */\nexport const validateHasCompactButton = (component: Generic.Element.Component, value?: boolean): void => {\n\twatchBoolean(component, '_hasCompactButton', value);\n};\n","@import url(../style.css);\n:host > div {\n\tdisplay: grid;\n\tplace-items: center;\n}\n.list {\n\tdisplay: flex;\n\tlist-style: none;\n\tmargin: 0;\n\tpadding: 0;\n}\n.list.vertical {\n\tflex-direction: column;\n}\n.entry {\n\tdisplay: flex;\n}\n.entry kol-button-wc:first-child,\n.entry kol-link-wc,\n.entry kol-span-wc {\n\tflex-grow: 1;\n}\n.entry kol-span-wc {\n\tjustify-items: start;\n}\n","import { Generic } from '@a11y-ui/core';\nimport { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\nimport { translate } from '../../i18n';\nimport { KoliBriButtonCallbacks } from '../../types/button-link';\nimport { ButtonOrLinkOrTextWithChildrenProps, ButtonWithChildrenProps, LinkWithChildrenProps } from '../../types/button-link-text';\nimport { Stringified } from '../../types/common';\nimport { KoliBriIconProp } from '../../types/icon';\nimport { Orientation } from '../../types/orientation';\nimport {\n\tAriaCurrent,\n\tPropCollapsible,\n\tPropCompact,\n\tPropHasCompactButton,\n\tvalidateCollapsible,\n\tvalidateCompact,\n\tvalidateHasCompactButton,\n} from '../../types/props';\nimport { a11yHintLabelingLandmarks, devHint, devWarning } from '../../utils/a11y.tipps';\nimport { watchString, watchValidator } from '../../utils/prop.validators';\nimport { watchNavLinks } from './validation';\n\n/**\n * @deprecated\n */\nexport type KoliBriNavVariant = 'primary' | 'secondary';\n\nconst UNIQUE_ARIA_LABEL: string[] = [];\nconst removeAriaLabel = (ariaLabel: string) => {\n\tconst index = UNIQUE_ARIA_LABEL.indexOf(ariaLabel);\n\tif (index >= 0) {\n\t\tUNIQUE_ARIA_LABEL.splice(index, 1);\n\t}\n};\n\nconst linkValidator = (link: ButtonOrLinkOrTextWithChildrenProps): boolean => {\n\tif (typeof link === 'object' && typeof link._label === 'string' /* && typeof newLink._href === 'string' */) {\n\t\tif (Array.isArray(link._children)) {\n\t\t\treturn linksValidator(link._children);\n\t\t}\n\t\treturn false;\n\t}\n\treturn true;\n};\n\nconst linksValidator = (links: ButtonOrLinkOrTextWithChildrenProps[]): boolean => {\n\tif (Array.isArray(links)) {\n\t\treturn links.find(linkValidator) !== undefined;\n\t}\n\treturn true;\n};\n\ntype RequiredProps = {\n\tariaLabel: string;\n\tlinks: Stringified<ButtonOrLinkOrTextWithChildrenProps[]>;\n};\ntype OptionalProps = {\n\tariaCurrentValue: AriaCurrent;\n\torientation: Orientation;\n\t/**\n\t * @deprecated\n\t */\n\tvariant: KoliBriNavVariant;\n} & PropCollapsible &\n\tPropCompact &\n\tPropHasCompactButton;\n// type Props = Generic.Element.Members<RequiredProps, OptionalProps>;\n\ntype RequiredStates = {\n\tariaCurrentValue: AriaCurrent;\n\tariaLabel: string;\n\tcollapsible: boolean;\n\t/**\n\t * @deprecated Version 2\n\t */\n\thasCompactButton: boolean;\n\tlinks: ButtonOrLinkOrTextWithChildrenProps[];\n\torientation: Orientation;\n\t/**\n\t * @deprecated\n\t */\n\tvariant: KoliBriNavVariant;\n} & PropCollapsible &\n\tPropHasCompactButton;\ntype OptionalStates = PropCompact;\ntype States = Generic.Element.Members<RequiredStates, OptionalStates>;\n\n@Component({\n\ttag: 'kol-nav',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolNav implements Generic.Element.ComponentApi<RequiredProps, OptionalProps, RequiredStates, OptionalStates> {\n\tprivate readonly onClick = (link: ButtonOrLinkOrTextWithChildrenProps): void => {\n\t\tlink._active = !link._active;\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t};\n\t};\n\n\tprivate readonly hasActiveChild = (link: ButtonOrLinkOrTextWithChildrenProps): boolean => {\n\t\tif (Array.isArray(link._children) && link._children.length > 0) {\n\t\t\treturn link._children.some(this.hasActiveChild);\n\t\t}\n\n\t\treturn false;\n\t};\n\n\t/** Element creation functions */\n\tprivate button(\n\t\tselected: boolean,\n\t\tcompact: boolean,\n\t\tdisabled: boolean,\n\t\ticon: Stringified<KoliBriIconProp> | undefined,\n\t\tlabel: string,\n\t\ton: KoliBriButtonCallbacks<unknown>\n\t): JSX.Element {\n\t\treturn (\n\t\t\t<kol-button-wc\n\t\t\t\t// _ariaCurrent will not be set here, since it will be set on a child of this item.\n\t\t\t\t_ariaExpanded={selected}\n\t\t\t\t_disabled={disabled}\n\t\t\t\t_icon={icon || '-'}\n\t\t\t\t_iconOnly={compact}\n\t\t\t\t_label={label}\n\t\t\t\t_on={on}\n\t\t\t></kol-button-wc>\n\t\t);\n\t}\n\n\tprivate text(compact: boolean, icon: Stringified<KoliBriIconProp> | undefined, label: string): JSX.Element {\n\t\treturn <kol-span-wc _icon={icon || '-'} _iconOnly={compact} _label={label}></kol-span-wc>;\n\t}\n\n\tprivate entry(\n\t\tcollapsible: boolean,\n\t\tcompact: boolean,\n\t\thasChildren: boolean,\n\t\tlink: ButtonOrLinkOrTextWithChildrenProps,\n\t\texpanded: boolean,\n\t\tselected: boolean,\n\t\ttextCenter: boolean\n\t): JSX.Element {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tclass={{\n\t\t\t\t\tentry: true,\n\t\t\t\t\t'has-children': hasChildren,\n\t\t\t\t\tselected,\n\t\t\t\t\texpanded,\n\t\t\t\t\t'text-center': textCenter,\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t{this.buttonOrLinkOrText(compact, link, selected)}\n\t\t\t\t{hasChildren ? this.expandButton(collapsible, link, selected) : ''}\n\t\t\t</div>\n\t\t);\n\t}\n\n\tprivate expandButton(collapsible: boolean, link: ButtonOrLinkOrTextWithChildrenProps, selected: boolean): JSX.Element {\n\t\treturn (\n\t\t\t<kol-button-wc\n\t\t\t\tclass=\"expand-button\"\n\t\t\t\t_disabled={!collapsible}\n\t\t\t\t_icon={'codicon codicon-' + (selected ? 'remove' : 'add')}\n\t\t\t\t_iconOnly\n\t\t\t\t_label={`Untermenü zu ${link._label} ${selected ? 'schließen' : 'öffnen'}`}\n\t\t\t\t_on={{ onClick: () => this.onClick(link) }}\n\t\t\t></kol-button-wc>\n\t\t);\n\t}\n\n\tprivate li(\n\t\tcollapsible: boolean,\n\t\tcompact: boolean,\n\t\tdeep: number,\n\t\tindex: number,\n\t\tlink: ButtonOrLinkOrTextWithChildrenProps,\n\t\torientation: Orientation\n\t): JSX.Element {\n\t\tconst hasChildren = Array.isArray(link._children) && link._children.length > 0;\n\t\tconst selected = !!link._active;\n\t\tconst expanded = hasChildren && !!link._active;\n\t\tconst textCenter = compact;\n\t\treturn (\n\t\t\t<li class={{ expanded, selected, 'has-children': hasChildren }} key={index}>\n\t\t\t\t{this.entry(collapsible, compact, hasChildren, link, expanded, selected, textCenter)}\n\t\t\t\t{hasChildren && selected ? (\n\t\t\t\t\t<this.linkList collapsible={collapsible} compact={compact} deep={deep + 1} links={link._children || []} orientation={orientation} />\n\t\t\t\t) : (\n\t\t\t\t\t''\n\t\t\t\t)}\n\t\t\t</li>\n\t\t);\n\t}\n\n\tprivate link(selected: boolean, compact: boolean, href: string, icon: Stringified<KoliBriIconProp> | undefined, label: string): JSX.Element {\n\t\treturn (\n\t\t\t<kol-link-wc\n\t\t\t\t// _ariaCurrent will not be set here, since it will be set on a child of this item.\n\t\t\t\t_ariaExpanded={selected}\n\t\t\t\t_href={href}\n\t\t\t\t_icon={icon || '-'}\n\t\t\t\t_iconOnly={compact}\n\t\t\t\t_label={label}\n\t\t\t></kol-link-wc>\n\t\t);\n\t}\n\n\tprivate linkList = (props: {\n\t\tcollapsible: boolean;\n\t\tcompact: boolean;\n\t\tdeep: number;\n\t\tlinks: ButtonOrLinkOrTextWithChildrenProps[];\n\t\torientation: Orientation;\n\t}): JSX.Element => {\n\t\treturn (\n\t\t\t<ul class={`list ${props.deep === 0 && props.orientation === 'horizontal' ? ' horizontal' : ' vertical'}`} data-deep={props.deep}>\n\t\t\t\t{props.links.map((link, index: number) => {\n\t\t\t\t\treturn this.li(props.collapsible, props.compact, props.deep, index, link, props.orientation);\n\t\t\t\t})}\n\t\t\t</ul>\n\t\t);\n\t};\n\n\tprivate buttonOrLinkOrText(compact: boolean, link: ButtonOrLinkOrTextWithChildrenProps, selected: boolean): JSX.Element {\n\t\tif ((link as ButtonWithChildrenProps)._on) {\n\t\t\treturn this.button(\n\t\t\t\tselected,\n\t\t\t\tcompact,\n\t\t\t\t(link as ButtonWithChildrenProps)._disabled === true,\n\t\t\t\tlink._icon,\n\t\t\t\tlink._label,\n\t\t\t\t(link as ButtonWithChildrenProps)._on\n\t\t\t);\n\t\t} else if ((link as LinkWithChildrenProps)._href) {\n\t\t\treturn this.link(selected, compact, (link as LinkWithChildrenProps)._href, link._icon, link._label);\n\t\t} else {\n\t\t\treturn this.text(compact, link._icon, link._label);\n\t\t}\n\t}\n\n\tpublic render(): JSX.Element {\n\t\tlet hasCompactButton = this.state._hasCompactButton;\n\t\tif (this.state._orientation === 'horizontal' && this.state._hasCompactButton === true) {\n\t\t\thasCompactButton = false;\n\t\t\tdevWarning(`[KolNav] Wenn eine horizontale Navigation verwendet wird, kann die Option _hasCompactButton nicht aktiviert werden.`);\n\t\t}\n\t\tconst collapsible = this.state._collapsible === true;\n\t\tconst compact = this.state._compact === true;\n\t\tconst orientation = this.state._orientation;\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t<div\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[orientation]: true,\n\t\t\t\t\t\t[this.state._variant]: true,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t<nav aria-label={this.state._ariaLabel} id=\"nav\">\n\t\t\t\t\t\t<this.linkList collapsible={collapsible} compact={compact} deep={0} links={this.state._links} orientation={orientation}></this.linkList>\n\t\t\t\t\t</nav>\n\t\t\t\t\t{hasCompactButton && (\n\t\t\t\t\t\t<div class=\"mt-2 w-full text-center\">\n\t\t\t\t\t\t\t<kol-button\n\t\t\t\t\t\t\t\t_ariaControls=\"nav\"\n\t\t\t\t\t\t\t\t_ariaExpanded={compact}\n\t\t\t\t\t\t\t\t_icon={compact ? 'codicon codicon-chevron-right' : 'codicon codicon-chevron-left'}\n\t\t\t\t\t\t\t\t_iconOnly\n\t\t\t\t\t\t\t\t_label={translate(compact ? 'kol-nav-maximize' : 'kol-nav-minimize')}\n\t\t\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\t\t\tonClick: (): void => {\n\t\t\t\t\t\t\t\t\t\tthis.state = {\n\t\t\t\t\t\t\t\t\t\t\t...this.state,\n\t\t\t\t\t\t\t\t\t\t\t_compact: this.state._compact === false,\n\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t_tooltipAlign=\"right\"\n\t\t\t\t\t\t\t\t_variant=\"ghost\"\n\t\t\t\t\t\t\t></kol-button>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Gibt den Wert von aria-current an, der bei dem aktuellen Kontext innerhalb der Navigation verwendet werden soll.\n\t */\n\t@Prop() public _ariaCurrentValue: AriaCurrent = false;\n\n\t/**\n\t * Gibt den Text an, der die Navigation von anderen Navigationen differenziert.\n\t */\n\t@Prop() public _ariaLabel!: string;\n\n\t/**\n\t * Gibt an, ob Knoten in der Navigation zusammengeklappt werden können. Ist standardmäßig aktiv.\n\t */\n\t@Prop({ reflect: true }) public _collapsible?: boolean = true;\n\n\t/**\n\t * Gibt an, ob die Navigation kompakt angezeigt wird.\n\t */\n\t@Prop({ reflect: true }) public _compact?: boolean = false;\n\n\t/**\n\t * Gibt an, ob die Navigation eine zusätzliche Schaltfläche zum Aus- und Einklappen der Navigation anzeigen soll.\n\t * @deprecated Version 2\n\t */\n\t@Prop({ reflect: true }) public _hasCompactButton?: boolean = false;\n\n\t/**\n\t * Gibt die Ausrichtung der Navigation an.\n\t */\n\t@Prop() public _orientation?: Orientation = 'vertical';\n\n\t/**\n\t * Gibt die geordnete Liste der Seitenhierarchie an.\n\t */\n\t@Prop() public _links!: Stringified<ButtonOrLinkOrTextWithChildrenProps[]>;\n\n\t/**\n\t * Stellt verschiedene Varianten der Navigation zur Verfügung.\n\t *\n\t * @deprecated This property is deprecated and will be removed in the next major version.\n\t */\n\t@Prop() public _variant?: KoliBriNavVariant = 'primary';\n\n\t@State() public state: States = {\n\t\t_ariaCurrentValue: false,\n\t\t_ariaLabel: '…', // '⚠'\n\t\t_collapsible: true,\n\t\t_hasCompactButton: false,\n\t\t_links: [],\n\t\t_orientation: 'vertical',\n\t\t_variant: 'primary',\n\t};\n\n\t@Watch('_ariaCurrentValue')\n\tpublic validateAriaCurrentValue(value?: AriaCurrent): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_ariaCurrentValue',\n\t\t\t(value) => value === true || value === 'date' || value === 'location' || value === 'page' || value === 'step' || value === 'time',\n\t\t\tnew Set(['boolean', 'String {data, location, page, step, time}']),\n\t\t\tvalue\n\t\t);\n\t}\n\n\t@Watch('_ariaLabel')\n\tpublic validateAriaLabel(value?: string): void {\n\t\twatchString(this, '_ariaLabel', value, {\n\t\t\thooks: {\n\t\t\t\tafterPatch: () => {\n\t\t\t\t\tif (UNIQUE_ARIA_LABEL.includes(this.state._ariaLabel)) {\n\t\t\t\t\t\tdevHint(`[KolNav] Das Aria-Label \"${this.state._ariaLabel}\" wurde für die Rolle Navigation mehrfach verwendet!`);\n\t\t\t\t\t}\n\t\t\t\t\tUNIQUE_ARIA_LABEL.push(this.state._ariaLabel);\n\t\t\t\t},\n\t\t\t\tbeforePatch: () => {\n\t\t\t\t\tremoveAriaLabel(this.state._ariaLabel);\n\t\t\t\t},\n\t\t\t},\n\t\t\trequired: true,\n\t\t});\n\t\ta11yHintLabelingLandmarks(value);\n\t}\n\n\t@Watch('_collapsible')\n\tpublic validateCollapsible(value?: boolean): void {\n\t\tvalidateCollapsible(this, value);\n\t}\n\n\t@Watch('_compact')\n\tpublic validateCompact(value?: boolean): void {\n\t\tvalidateCompact(this, value);\n\t}\n\n\t/**\n\t * @deprecated Version 2\n\t */\n\t@Watch('_hasCompactButton')\n\tpublic validateHasCompactButton(value?: boolean): void {\n\t\tvalidateHasCompactButton(this, value);\n\t}\n\n\t@Watch('_links')\n\tpublic validateLinks(value?: Stringified<ButtonOrLinkOrTextWithChildrenProps[]>): void {\n\t\twatchNavLinks('KolNav', this, value);\n\t\tdevHint(`[KolNav] Die Navigationsstruktur wird noch nicht rekursiv validiert.`);\n\t}\n\n\t@Watch('_orientation')\n\tpublic validateOrientation(value?: Orientation): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_orientation',\n\t\t\t(value): boolean => value === 'horizontal' || value === 'vertical',\n\t\t\tnew Set(['Orientation {horizontal, vertical}']),\n\t\t\tvalue,\n\t\t\t{\n\t\t\t\tdefaultValue: 'vertical',\n\t\t\t}\n\t\t);\n\t}\n\n\t@Watch('_variant')\n\tpublic validateVariant(value?: KoliBriNavVariant): void {\n\t\twatchValidator(this, '_variant', (value) => value === 'primary' || value === 'secondary', new Set(['KoliBriNavVariant {primary, secondary}']), value, {\n\t\t\tdefaultValue: 'primary',\n\t\t});\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAriaCurrentValue(this._ariaCurrentValue);\n\t\tthis.validateAriaLabel(this._ariaLabel);\n\t\tthis.validateCollapsible(this._collapsible);\n\t\tthis.validateCompact(this._compact);\n\t\tthis.validateHasCompactButton(this._hasCompactButton);\n\t\tthis.validateLinks(this._links);\n\t\tthis.validateOrientation(this._orientation);\n\t\tthis.validateVariant(this._variant);\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tremoveAriaLabel(this.state._ariaLabel);\n\t}\n}\n"],"mappings":"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"}