@public-ui/components 2.0.0-rc.11 → 2.0.0-rc.13

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 (1120) hide show
  1. package/custom-elements.json +1 -1
  2. package/dist/cjs/{InternalUnderlinedAccessKey-1daef254.js → InternalUnderlinedAccessKey-13d98585.js} +1 -1
  3. package/dist/cjs/{InternalUnderlinedAccessKey-1daef254.js.map → InternalUnderlinedAccessKey-13d98585.js.map} +1 -1
  4. package/dist/cjs/{a11y.tipps-1c165956.js → a11y.tipps-b3982a25.js} +1 -1
  5. package/dist/cjs/{a11y.tipps-1c165956.js.map → a11y.tipps-b3982a25.js.map} +1 -1
  6. package/dist/cjs/access-key-d0f673ba.js +4 -0
  7. package/dist/cjs/{access-key-30674e1a.js.map → access-key-d0f673ba.js.map} +1 -1
  8. package/dist/cjs/{align-floating-elements-01d5ad38.js → align-floating-elements-dca98687.js} +1 -1
  9. package/dist/cjs/align-floating-elements-dca98687.js.map +1 -0
  10. package/dist/cjs/{alignment-d8b351ab.js → alignment-3a6152b8.js} +1 -1
  11. package/dist/cjs/{alignment-d8b351ab.js.map → alignment-3a6152b8.js.map} +1 -1
  12. package/dist/cjs/alternative-button-link-role-98fa09d2.js +4 -0
  13. package/dist/cjs/{alternative-button-link-role-e188938c.js.map → alternative-button-link-role-98fa09d2.js.map} +1 -1
  14. package/dist/cjs/{app-globals-fcc1963e.js → app-globals-776b0638.js} +1 -1
  15. package/dist/cjs/app-globals-776b0638.js.map +1 -0
  16. package/dist/cjs/{ariaCurrentService-d894e18d.js.map → ariaCurrentService-53afa476.js.map} +1 -1
  17. package/dist/cjs/{associated.controller-b5e04826.js → associated.controller-fa58e0c8.js} +1 -1
  18. package/dist/cjs/associated.controller-fa58e0c8.js.map +1 -0
  19. package/dist/cjs/{bund-f5184e9e.js.map → bund-4be96755.js.map} +1 -1
  20. package/dist/cjs/{color-ccd88de4.js → color-a858d579.js} +1 -1
  21. package/dist/cjs/color-a858d579.js.map +1 -0
  22. package/dist/cjs/controller-5143eb33.js +4 -0
  23. package/dist/cjs/controller-5143eb33.js.map +1 -0
  24. package/dist/cjs/controller-556b9964.js +4 -0
  25. package/dist/cjs/controller-556b9964.js.map +1 -0
  26. package/dist/cjs/controller-8b63c1fa.js +4 -0
  27. package/dist/cjs/controller-8b63c1fa.js.map +1 -0
  28. package/dist/cjs/controller-e52029f2.js +4 -0
  29. package/dist/cjs/controller-e52029f2.js.map +1 -0
  30. package/dist/cjs/{controller-b37efa9f.js → controller-f90bffd1.js} +1 -1
  31. package/dist/cjs/controller-f90bffd1.js.map +1 -0
  32. package/dist/cjs/{controller-icon-1d1188c3.js → controller-icon-532551c7.js} +1 -1
  33. package/dist/cjs/controller-icon-532551c7.js.map +1 -0
  34. package/dist/cjs/custom-class-ac05e68b.js +4 -0
  35. package/dist/cjs/{custom-class-4a4b8f5f.js.map → custom-class-ac05e68b.js.map} +1 -1
  36. package/dist/cjs/{details-synced-open-state-01d46fbc.js.map → details-synced-open-state-e88811c7.js.map} +1 -1
  37. package/dist/cjs/{dev.utils-a3fa0ded.js → dev.utils-ca7b2abc.js} +1 -1
  38. package/dist/cjs/dev.utils-ca7b2abc.js.map +1 -0
  39. package/dist/cjs/{devtools-37eef902.js → devtools-3ce5a951.js} +1 -1
  40. package/dist/cjs/devtools-3ce5a951.js.map +1 -0
  41. package/dist/cjs/{events-a0c291ce.js.map → events-e348a615.js.map} +1 -1
  42. package/dist/cjs/has-closer-4c571429.js +4 -0
  43. package/dist/cjs/{has-closer-c17cc0bc.js.map → has-closer-4c571429.js.map} +1 -1
  44. package/dist/cjs/hide-label-c3a74e0a.js +4 -0
  45. package/dist/cjs/{hide-label-1eab3780.js.map → hide-label-c3a74e0a.js.map} +1 -1
  46. package/dist/cjs/{i18n-f7771d30.js → i18n-0c5384c9.js} +1 -1
  47. package/dist/cjs/{i18n-f7771d30.js.map → i18n-0c5384c9.js.map} +1 -1
  48. package/dist/cjs/{icons-92e34672.js → icons-b655df0f.js} +1 -1
  49. package/dist/cjs/icons-b655df0f.js.map +1 -0
  50. package/dist/cjs/image-source-ba4489d3.js +4 -0
  51. package/dist/cjs/{image-source-51299edf.js.map → image-source-ba4489d3.js.map} +1 -1
  52. package/dist/cjs/index-2e4226da.js +4 -0
  53. package/dist/cjs/index-2e4226da.js.map +1 -0
  54. package/dist/cjs/index-759bf886.js +4 -0
  55. package/dist/cjs/{index-07f69fb0.js.map → index-759bf886.js.map} +1 -1
  56. package/dist/cjs/index-a2400b65.js +5 -0
  57. package/dist/cjs/index-a2400b65.js.map +1 -0
  58. package/dist/cjs/index.cjs.js +1 -1
  59. package/dist/cjs/kol-abbr.cjs.entry.js +1 -1
  60. package/dist/cjs/kol-abbr.cjs.entry.js.map +1 -1
  61. package/dist/cjs/kol-accordion.cjs.entry.js +1 -1
  62. package/dist/cjs/kol-accordion.cjs.entry.js.map +1 -1
  63. package/dist/cjs/kol-alert-wc_2.cjs.entry.js +1 -1
  64. package/dist/cjs/kol-alert-wc_2.cjs.entry.js.map +1 -1
  65. package/dist/cjs/kol-alert.cjs.entry.js +1 -1
  66. package/dist/cjs/kol-alert.cjs.entry.js.map +1 -1
  67. package/dist/cjs/kol-avatar-wc.cjs.entry.js +1 -1
  68. package/dist/cjs/kol-avatar-wc.cjs.entry.js.map +1 -1
  69. package/dist/cjs/kol-avatar.cjs.entry.js +1 -1
  70. package/dist/cjs/kol-avatar.cjs.entry.js.map +1 -1
  71. package/dist/cjs/kol-badge.cjs.entry.js +1 -1
  72. package/dist/cjs/kol-badge.cjs.entry.js.map +1 -1
  73. package/dist/cjs/kol-breadcrumb.cjs.entry.js +1 -1
  74. package/dist/cjs/kol-breadcrumb.cjs.entry.js.map +1 -1
  75. package/dist/cjs/kol-button-group-wc.cjs.entry.js +1 -1
  76. package/dist/cjs/kol-button-group-wc.cjs.entry.js.map +1 -1
  77. package/dist/cjs/kol-button-group.cjs.entry.js +1 -1
  78. package/dist/cjs/kol-button-group.cjs.entry.js.map +1 -1
  79. package/dist/cjs/kol-button-link-text-switch.cjs.entry.js +1 -1
  80. package/dist/cjs/kol-button-link-text-switch.cjs.entry.js.map +1 -1
  81. package/dist/cjs/kol-button-link.cjs.entry.js +1 -1
  82. package/dist/cjs/kol-button-link.cjs.entry.js.map +1 -1
  83. package/dist/cjs/kol-button-wc_2.cjs.entry.js +1 -1
  84. package/dist/cjs/kol-button-wc_2.cjs.entry.js.map +1 -1
  85. package/dist/cjs/kol-button.cjs.entry.js +1 -1
  86. package/dist/cjs/kol-button.cjs.entry.js.map +1 -1
  87. package/dist/cjs/kol-card.cjs.entry.js +1 -1
  88. package/dist/cjs/kol-card.cjs.entry.js.map +1 -1
  89. package/dist/cjs/kol-details.cjs.entry.js +1 -1
  90. package/dist/cjs/kol-details.cjs.entry.js.map +1 -1
  91. package/dist/cjs/kol-form.cjs.entry.js +1 -1
  92. package/dist/cjs/kol-form.cjs.entry.js.map +1 -1
  93. package/dist/cjs/kol-heading.cjs.entry.js +1 -1
  94. package/dist/cjs/kol-heading.cjs.entry.js.map +1 -1
  95. package/dist/cjs/kol-icon.cjs.entry.js +1 -1
  96. package/dist/cjs/kol-icon.cjs.entry.js.map +1 -1
  97. package/dist/cjs/kol-image.cjs.entry.js +1 -1
  98. package/dist/cjs/kol-image.cjs.entry.js.map +1 -1
  99. package/dist/cjs/kol-indented-text.cjs.entry.js +1 -1
  100. package/dist/cjs/kol-indented-text.cjs.entry.js.map +1 -1
  101. package/dist/cjs/kol-input-checkbox.cjs.entry.js +1 -1
  102. package/dist/cjs/kol-input-checkbox.cjs.entry.js.map +1 -1
  103. package/dist/cjs/kol-input-color.cjs.entry.js +1 -1
  104. package/dist/cjs/kol-input-color.cjs.entry.js.map +1 -1
  105. package/dist/cjs/kol-input-date.cjs.entry.js +1 -1
  106. package/dist/cjs/kol-input-date.cjs.entry.js.map +1 -1
  107. package/dist/cjs/kol-input-email.cjs.entry.js +1 -1
  108. package/dist/cjs/kol-input-email.cjs.entry.js.map +1 -1
  109. package/dist/cjs/kol-input-file.cjs.entry.js +1 -1
  110. package/dist/cjs/kol-input-file.cjs.entry.js.map +1 -1
  111. package/dist/cjs/kol-input-number.cjs.entry.js +1 -1
  112. package/dist/cjs/kol-input-number.cjs.entry.js.map +1 -1
  113. package/dist/cjs/kol-input-password.cjs.entry.js +1 -1
  114. package/dist/cjs/kol-input-password.cjs.entry.js.map +1 -1
  115. package/dist/cjs/kol-input-radio.cjs.entry.js +1 -1
  116. package/dist/cjs/kol-input-radio.cjs.entry.js.map +1 -1
  117. package/dist/cjs/kol-input-range.cjs.entry.js +1 -1
  118. package/dist/cjs/kol-input-range.cjs.entry.js.map +1 -1
  119. package/dist/cjs/kol-input-text.cjs.entry.js +1 -1
  120. package/dist/cjs/kol-input-text.cjs.entry.js.map +1 -1
  121. package/dist/cjs/kol-input.cjs.entry.js +1 -1
  122. package/dist/cjs/kol-input.cjs.entry.js.map +1 -1
  123. package/dist/cjs/kol-kolibri.cjs.entry.js +1 -1
  124. package/dist/cjs/kol-kolibri.cjs.entry.js.map +1 -1
  125. package/dist/cjs/kol-link-button.cjs.entry.js +1 -1
  126. package/dist/cjs/kol-link-button.cjs.entry.js.map +1 -1
  127. package/dist/cjs/kol-link-group.cjs.entry.js +1 -1
  128. package/dist/cjs/kol-link-group.cjs.entry.js.map +1 -1
  129. package/dist/cjs/kol-link-wc.cjs.entry.js +1 -1
  130. package/dist/cjs/kol-link-wc.cjs.entry.js.map +1 -1
  131. package/dist/cjs/kol-link.cjs.entry.js +1 -1
  132. package/dist/cjs/kol-link.cjs.entry.js.map +1 -1
  133. package/dist/cjs/kol-logo.cjs.entry.js +1 -1
  134. package/dist/cjs/kol-logo.cjs.entry.js.map +1 -1
  135. package/dist/cjs/kol-modal.cjs.entry.js +1 -1
  136. package/dist/cjs/kol-modal.cjs.entry.js.map +1 -1
  137. package/dist/cjs/kol-nav.cjs.entry.js +1 -1
  138. package/dist/cjs/kol-nav.cjs.entry.js.map +1 -1
  139. package/dist/cjs/kol-pagination.cjs.entry.js +1 -1
  140. package/dist/cjs/kol-pagination.cjs.entry.js.map +1 -1
  141. package/dist/cjs/kol-popover-wc.cjs.entry.js +1 -1
  142. package/dist/cjs/kol-popover-wc.cjs.entry.js.map +1 -1
  143. package/dist/cjs/kol-progress.cjs.entry.js +1 -1
  144. package/dist/cjs/kol-progress.cjs.entry.js.map +1 -1
  145. package/dist/cjs/kol-quote.cjs.entry.js +1 -1
  146. package/dist/cjs/kol-quote.cjs.entry.js.map +1 -1
  147. package/dist/cjs/kol-select.cjs.entry.js +1 -1
  148. package/dist/cjs/kol-select.cjs.entry.js.map +1 -1
  149. package/dist/cjs/kol-skip-nav.cjs.entry.js +1 -1
  150. package/dist/cjs/kol-skip-nav.cjs.entry.js.map +1 -1
  151. package/dist/cjs/kol-span-wc.cjs.entry.js +1 -1
  152. package/dist/cjs/kol-span-wc.cjs.entry.js.map +1 -1
  153. package/dist/cjs/kol-span.cjs.entry.js +1 -1
  154. package/dist/cjs/kol-span.cjs.entry.js.map +1 -1
  155. package/dist/cjs/kol-spin.cjs.entry.js +1 -1
  156. package/dist/cjs/kol-spin.cjs.entry.js.map +1 -1
  157. package/dist/cjs/kol-split-button.cjs.entry.js +1 -1
  158. package/dist/cjs/kol-split-button.cjs.entry.js.map +1 -1
  159. package/dist/cjs/kol-symbol.cjs.entry.js +1 -1
  160. package/dist/cjs/kol-symbol.cjs.entry.js.map +1 -1
  161. package/dist/cjs/kol-table.cjs.entry.js +1 -1
  162. package/dist/cjs/kol-table.cjs.entry.js.map +1 -1
  163. package/dist/cjs/kol-tabs.cjs.entry.js +1 -1
  164. package/dist/cjs/kol-tabs.cjs.entry.js.map +1 -1
  165. package/dist/cjs/kol-textarea.cjs.entry.js +1 -1
  166. package/dist/cjs/kol-textarea.cjs.entry.js.map +1 -1
  167. package/dist/cjs/kol-toast-container.cjs.entry.js +1 -1
  168. package/dist/cjs/kol-toast-container.cjs.entry.js.map +1 -1
  169. package/dist/cjs/kol-version.cjs.entry.js +1 -1
  170. package/dist/cjs/kol-version.cjs.entry.js.map +1 -1
  171. package/dist/cjs/kolibri.cjs.js +1 -1
  172. package/dist/cjs/kolibri.cjs.js.map +1 -1
  173. package/dist/cjs/{label-5a44a87d.js → label-be2680d5.js} +1 -1
  174. package/dist/cjs/label-be2680d5.js.map +1 -0
  175. package/dist/cjs/loader.cjs.js +1 -1
  176. package/dist/cjs/open-209d7b48.js +4 -0
  177. package/dist/cjs/{open-1740dbfd.js.map → open-209d7b48.js.map} +1 -1
  178. package/dist/cjs/{prop.validators-249e288b.js → prop.validators-fc705472.js} +1 -1
  179. package/dist/cjs/prop.validators-fc705472.js.map +1 -0
  180. package/dist/cjs/reprod-accordion-does-not-toggle-with-open-092e559d.js.map +1 -0
  181. package/dist/cjs/reuse-a4c8450e.js.map +1 -0
  182. package/dist/cjs/rows-0e012f6a.js +4 -0
  183. package/dist/cjs/{rows-d8f6b3fe.js.map → rows-0e012f6a.js.map} +1 -1
  184. package/dist/cjs/show-ce43c5e0.js +4 -0
  185. package/dist/cjs/{show-4f692c20.js.map → show-ce43c5e0.js.map} +1 -1
  186. package/dist/cjs/{suggestions-b89272cd.js → suggestions-7845aa6e.js} +1 -1
  187. package/dist/cjs/suggestions-7845aa6e.js.map +1 -0
  188. package/dist/cjs/{tab-index-b0756f58.js → tab-index-fd9004fc.js} +1 -1
  189. package/dist/cjs/tab-index-fd9004fc.js.map +1 -0
  190. package/dist/cjs/toaster-29a344ee.js +4 -0
  191. package/dist/cjs/toaster-29a344ee.js.map +1 -0
  192. package/dist/cjs/{toaster-e3a1416c.js → toaster-693c93ec.js} +1 -1
  193. package/dist/cjs/{toaster-e3a1416c.js.map → toaster-693c93ec.js.map} +1 -1
  194. package/dist/cjs/{tooltip-align-a6de4888.js → tooltip-align-7dde9e3b.js} +1 -1
  195. package/dist/cjs/{tooltip-align-a6de4888.js.map → tooltip-align-7dde9e3b.js.map} +1 -1
  196. package/dist/cjs/{unique-nav-labels-9784a4c5.js.map → unique-nav-labels-363e1d71.js.map} +1 -1
  197. package/dist/cjs/{validation-b0d8cbc5.js → validation-981717a8.js} +1 -1
  198. package/dist/cjs/{validation-b0d8cbc5.js.map → validation-981717a8.js.map} +1 -1
  199. package/dist/cjs/{validation-1a059073.js → validation-98a73edd.js} +1 -1
  200. package/dist/cjs/{validation-1a059073.js.map → validation-98a73edd.js.map} +1 -1
  201. package/dist/components/align-floating-elements.js.map +1 -1
  202. package/dist/components/ariaCurrentService.js.map +1 -1
  203. package/dist/components/bund.js.map +1 -1
  204. package/dist/components/color.js.map +1 -1
  205. package/dist/components/component.js.map +1 -1
  206. package/dist/components/component10.js.map +1 -1
  207. package/dist/components/component11.js.map +1 -1
  208. package/dist/components/component12.js +1 -1
  209. package/dist/components/component12.js.map +1 -1
  210. package/dist/components/component13.js +1 -1
  211. package/dist/components/component13.js.map +1 -1
  212. package/dist/components/component14.js +1 -1
  213. package/dist/components/component14.js.map +1 -1
  214. package/dist/components/component15.js +1 -1
  215. package/dist/components/component15.js.map +1 -1
  216. package/dist/components/component2.js.map +1 -1
  217. package/dist/components/component3.js +1 -1
  218. package/dist/components/component3.js.map +1 -1
  219. package/dist/components/component4.js.map +1 -1
  220. package/dist/components/component5.js.map +1 -1
  221. package/dist/components/component6.js +1 -1
  222. package/dist/components/component6.js.map +1 -1
  223. package/dist/components/component7.js.map +1 -1
  224. package/dist/components/component8.js +1 -1
  225. package/dist/components/component8.js.map +1 -1
  226. package/dist/components/component9.js.map +1 -1
  227. package/dist/components/controller-icon.js.map +1 -1
  228. package/dist/components/controller.js +1 -1
  229. package/dist/components/controller.js.map +1 -1
  230. package/dist/components/controller2.js +1 -1
  231. package/dist/components/controller2.js.map +1 -1
  232. package/dist/components/controller3.js +1 -1
  233. package/dist/components/controller3.js.map +1 -1
  234. package/dist/components/controller4.js +1 -1
  235. package/dist/components/controller4.js.map +1 -1
  236. package/dist/components/details-synced-open-state.js.map +1 -1
  237. package/dist/components/devtools.js.map +1 -1
  238. package/dist/components/events.js.map +1 -1
  239. package/dist/components/has-closer.js.map +1 -1
  240. package/dist/components/i18n.js +1 -1
  241. package/dist/components/i18n.js.map +1 -1
  242. package/dist/components/image-source.js.map +1 -1
  243. package/dist/components/index.js +1 -1
  244. package/dist/components/index.js.map +1 -1
  245. package/dist/components/index2.js.map +1 -1
  246. package/dist/components/kol-abbr.d.ts +2 -2
  247. package/dist/components/kol-abbr.js +1 -1
  248. package/dist/components/kol-abbr.js.map +1 -1
  249. package/dist/components/kol-accordion.d.ts +2 -2
  250. package/dist/components/kol-accordion.js +1 -1
  251. package/dist/components/kol-accordion.js.map +1 -1
  252. package/dist/components/kol-alert-wc.d.ts +2 -2
  253. package/dist/components/kol-alert.d.ts +2 -2
  254. package/dist/components/kol-avatar-wc.d.ts +2 -2
  255. package/dist/components/kol-avatar.d.ts +2 -2
  256. package/dist/components/kol-avatar.js +1 -1
  257. package/dist/components/kol-avatar.js.map +1 -1
  258. package/dist/components/kol-badge.d.ts +2 -2
  259. package/dist/components/kol-breadcrumb.d.ts +2 -2
  260. package/dist/components/kol-breadcrumb.js +1 -1
  261. package/dist/components/kol-breadcrumb.js.map +1 -1
  262. package/dist/components/kol-button-group-wc.d.ts +2 -2
  263. package/dist/components/kol-button-group.d.ts +2 -2
  264. package/dist/components/kol-button-group.js +1 -1
  265. package/dist/components/kol-button-group.js.map +1 -1
  266. package/dist/components/kol-button-link-text-switch.d.ts +2 -2
  267. package/dist/components/kol-button-link.d.ts +2 -2
  268. package/dist/components/kol-button-link.js +1 -1
  269. package/dist/components/kol-button-link.js.map +1 -1
  270. package/dist/components/kol-button-wc.d.ts +2 -2
  271. package/dist/components/kol-button.d.ts +2 -2
  272. package/dist/components/kol-card.d.ts +2 -2
  273. package/dist/components/kol-card.js +1 -1
  274. package/dist/components/kol-card.js.map +1 -1
  275. package/dist/components/kol-details.d.ts +2 -2
  276. package/dist/components/kol-details.js +1 -1
  277. package/dist/components/kol-details.js.map +1 -1
  278. package/dist/components/kol-form.d.ts +2 -2
  279. package/dist/components/kol-form.js.map +1 -1
  280. package/dist/components/kol-heading-wc.d.ts +2 -2
  281. package/dist/components/kol-heading.d.ts +2 -2
  282. package/dist/components/kol-heading.js +1 -1
  283. package/dist/components/kol-heading.js.map +1 -1
  284. package/dist/components/kol-icon.d.ts +2 -2
  285. package/dist/components/kol-image.d.ts +2 -2
  286. package/dist/components/kol-image.js.map +1 -1
  287. package/dist/components/kol-indented-text.d.ts +2 -2
  288. package/dist/components/kol-input-checkbox.d.ts +2 -2
  289. package/dist/components/kol-input-checkbox.js +1 -1
  290. package/dist/components/kol-input-checkbox.js.map +1 -1
  291. package/dist/components/kol-input-color.d.ts +2 -2
  292. package/dist/components/kol-input-color.js +1 -1
  293. package/dist/components/kol-input-color.js.map +1 -1
  294. package/dist/components/kol-input-date.d.ts +2 -2
  295. package/dist/components/kol-input-date.js +1 -1
  296. package/dist/components/kol-input-date.js.map +1 -1
  297. package/dist/components/kol-input-email.d.ts +2 -2
  298. package/dist/components/kol-input-email.js +1 -1
  299. package/dist/components/kol-input-email.js.map +1 -1
  300. package/dist/components/kol-input-file.d.ts +2 -2
  301. package/dist/components/kol-input-file.js +1 -1
  302. package/dist/components/kol-input-file.js.map +1 -1
  303. package/dist/components/kol-input-number.d.ts +2 -2
  304. package/dist/components/kol-input-number.js +1 -1
  305. package/dist/components/kol-input-number.js.map +1 -1
  306. package/dist/components/kol-input-password.d.ts +2 -2
  307. package/dist/components/kol-input-password.js +1 -1
  308. package/dist/components/kol-input-password.js.map +1 -1
  309. package/dist/components/kol-input-radio.d.ts +2 -2
  310. package/dist/components/kol-input-radio.js +1 -1
  311. package/dist/components/kol-input-radio.js.map +1 -1
  312. package/dist/components/kol-input-range.d.ts +2 -2
  313. package/dist/components/kol-input-range.js +1 -1
  314. package/dist/components/kol-input-range.js.map +1 -1
  315. package/dist/components/kol-input-text.d.ts +2 -2
  316. package/dist/components/kol-input-text.js +1 -1
  317. package/dist/components/kol-input-text.js.map +1 -1
  318. package/dist/components/kol-input.d.ts +2 -2
  319. package/dist/components/kol-kolibri.d.ts +2 -2
  320. package/dist/components/kol-kolibri.js +1 -1
  321. package/dist/components/kol-kolibri.js.map +1 -1
  322. package/dist/components/kol-link-button.d.ts +2 -2
  323. package/dist/components/kol-link-button.js +1 -1
  324. package/dist/components/kol-link-button.js.map +1 -1
  325. package/dist/components/kol-link-group.d.ts +2 -2
  326. package/dist/components/kol-link-group.js +1 -1
  327. package/dist/components/kol-link-group.js.map +1 -1
  328. package/dist/components/kol-link-wc.d.ts +2 -2
  329. package/dist/components/kol-link.d.ts +2 -2
  330. package/dist/components/kol-logo.d.ts +2 -2
  331. package/dist/components/kol-logo.js +1 -1
  332. package/dist/components/kol-logo.js.map +1 -1
  333. package/dist/components/kol-modal.d.ts +2 -2
  334. package/dist/components/kol-modal.js +1 -1
  335. package/dist/components/kol-modal.js.map +1 -1
  336. package/dist/components/kol-nav.d.ts +2 -2
  337. package/dist/components/kol-nav.js +1 -1
  338. package/dist/components/kol-nav.js.map +1 -1
  339. package/dist/components/kol-pagination.d.ts +2 -2
  340. package/dist/components/kol-popover-wc.d.ts +2 -2
  341. package/dist/components/kol-popover-wc.js +1 -1
  342. package/dist/components/kol-popover-wc.js.map +1 -1
  343. package/dist/components/kol-progress.d.ts +2 -2
  344. package/dist/components/kol-progress.js +1 -1
  345. package/dist/components/kol-progress.js.map +1 -1
  346. package/dist/components/kol-quote.d.ts +2 -2
  347. package/dist/components/kol-quote.js +1 -1
  348. package/dist/components/kol-quote.js.map +1 -1
  349. package/dist/components/kol-select.d.ts +2 -2
  350. package/dist/components/kol-skip-nav.d.ts +2 -2
  351. package/dist/components/kol-skip-nav.js +1 -1
  352. package/dist/components/kol-skip-nav.js.map +1 -1
  353. package/dist/components/kol-span-wc.d.ts +2 -2
  354. package/dist/components/kol-span.d.ts +2 -2
  355. package/dist/components/kol-span.js +1 -1
  356. package/dist/components/kol-span.js.map +1 -1
  357. package/dist/components/kol-spin.d.ts +2 -2
  358. package/dist/components/kol-spin.js +1 -1
  359. package/dist/components/kol-spin.js.map +1 -1
  360. package/dist/components/kol-split-button.d.ts +2 -2
  361. package/dist/components/kol-split-button.js +1 -1
  362. package/dist/components/kol-split-button.js.map +1 -1
  363. package/dist/components/kol-symbol.d.ts +2 -2
  364. package/dist/components/kol-symbol.js.map +1 -1
  365. package/dist/components/kol-table.d.ts +2 -2
  366. package/dist/components/kol-table.js +1 -1
  367. package/dist/components/kol-table.js.map +1 -1
  368. package/dist/components/kol-tabs.d.ts +2 -2
  369. package/dist/components/kol-tabs.js +1 -1
  370. package/dist/components/kol-tabs.js.map +1 -1
  371. package/dist/components/kol-textarea.d.ts +2 -2
  372. package/dist/components/kol-textarea.js +1 -1
  373. package/dist/components/kol-textarea.js.map +1 -1
  374. package/dist/components/kol-toast-container.d.ts +2 -2
  375. package/dist/components/kol-toast-container.js +1 -1
  376. package/dist/components/kol-toast-container.js.map +1 -1
  377. package/dist/components/kol-tooltip-wc.d.ts +2 -2
  378. package/dist/components/kol-version.d.ts +2 -2
  379. package/dist/components/kol-version.js +1 -1
  380. package/dist/components/kol-version.js.map +1 -1
  381. package/dist/components/label.js.map +1 -1
  382. package/dist/components/open.js.map +1 -1
  383. package/dist/components/prop.validators.js +1 -1
  384. package/dist/components/prop.validators.js.map +1 -1
  385. package/dist/components/reprod-accordion-does-not-toggle-with-open.js.map +1 -1
  386. package/dist/components/rows.js.map +1 -1
  387. package/dist/components/shadow.js +1 -1
  388. package/dist/components/shadow.js.map +1 -1
  389. package/dist/components/shadow2.js +1 -1
  390. package/dist/components/shadow2.js.map +1 -1
  391. package/dist/components/shadow3.js +1 -1
  392. package/dist/components/shadow3.js.map +1 -1
  393. package/dist/components/show.js.map +1 -1
  394. package/dist/components/suggestions.js.map +1 -1
  395. package/dist/components/tab-index.js.map +1 -1
  396. package/dist/components/toaster.js.map +1 -1
  397. package/dist/components/tooltip-align.js.map +1 -1
  398. package/dist/components/unique-nav-labels.js.map +1 -1
  399. package/dist/components/validation.js.map +1 -1
  400. package/dist/esm/{InternalUnderlinedAccessKey-8b996006.js → InternalUnderlinedAccessKey-2c5af489.js} +1 -1
  401. package/dist/esm/{InternalUnderlinedAccessKey-8b996006.js.map → InternalUnderlinedAccessKey-2c5af489.js.map} +1 -1
  402. package/dist/esm/{a11y.tipps-68791110.js → a11y.tipps-76f7d989.js} +1 -1
  403. package/dist/esm/{a11y.tipps-68791110.js.map → a11y.tipps-76f7d989.js.map} +1 -1
  404. package/dist/esm/{access-key-c2c8b712.js → access-key-bbc98ec1.js} +1 -1
  405. package/dist/esm/{access-key-c2c8b712.js.map → access-key-bbc98ec1.js.map} +1 -1
  406. package/dist/esm/{align-floating-elements-ebf0712d.js → align-floating-elements-cadb5c5b.js} +1 -1
  407. package/dist/esm/align-floating-elements-cadb5c5b.js.map +1 -0
  408. package/dist/esm/{alignment-cb8fa342.js → alignment-d30f46a0.js} +1 -1
  409. package/dist/esm/{alignment-cb8fa342.js.map → alignment-d30f46a0.js.map} +1 -1
  410. package/dist/esm/alternative-button-link-role-8441bb1d.js +4 -0
  411. package/dist/esm/{alternative-button-link-role-641ea928.js.map → alternative-button-link-role-8441bb1d.js.map} +1 -1
  412. package/dist/esm/app-globals-9bc7e8f5.js +4 -0
  413. package/dist/esm/app-globals-9bc7e8f5.js.map +1 -0
  414. package/dist/esm/{ariaCurrentService-2ef83ca8.js.map → ariaCurrentService-6fe36ebc.js.map} +1 -1
  415. package/dist/esm/{associated.controller-d463ef08.js → associated.controller-3ce25c94.js} +1 -1
  416. package/dist/esm/associated.controller-3ce25c94.js.map +1 -0
  417. package/dist/esm/{bund-056aa89a.js.map → bund-ad41b762.js.map} +1 -1
  418. package/dist/esm/{color-eb9db629.js → color-e1efb3bd.js} +1 -1
  419. package/dist/esm/color-e1efb3bd.js.map +1 -0
  420. package/dist/esm/controller-190730e1.js +4 -0
  421. package/dist/esm/controller-190730e1.js.map +1 -0
  422. package/dist/esm/{controller-5ca8ac64.js → controller-3123ae49.js} +1 -1
  423. package/dist/esm/controller-3123ae49.js.map +1 -0
  424. package/dist/esm/controller-788d8028.js +4 -0
  425. package/dist/esm/controller-788d8028.js.map +1 -0
  426. package/dist/esm/controller-a3de638f.js +4 -0
  427. package/dist/esm/controller-a3de638f.js.map +1 -0
  428. package/dist/esm/controller-afeea78c.js +4 -0
  429. package/dist/esm/controller-afeea78c.js.map +1 -0
  430. package/dist/esm/{controller-icon-f63e0f2d.js → controller-icon-458bfe0e.js} +1 -1
  431. package/dist/esm/controller-icon-458bfe0e.js.map +1 -0
  432. package/dist/esm/custom-class-4e4950dc.js +4 -0
  433. package/dist/esm/{custom-class-66c19712.js.map → custom-class-4e4950dc.js.map} +1 -1
  434. package/dist/esm/{details-synced-open-state-66c07ea5.js.map → details-synced-open-state-45ecc035.js.map} +1 -1
  435. package/dist/esm/{dev.utils-8202a1bc.js → dev.utils-b86b7cfe.js} +1 -1
  436. package/dist/esm/dev.utils-b86b7cfe.js.map +1 -0
  437. package/dist/esm/{devtools-4ca02a9a.js → devtools-e4239884.js} +1 -1
  438. package/dist/esm/devtools-e4239884.js.map +1 -0
  439. package/dist/esm/{events-2bb1065b.js.map → events-fa760b68.js.map} +1 -1
  440. package/dist/esm/{has-closer-2bb6b735.js → has-closer-08a41ac1.js} +1 -1
  441. package/dist/esm/{has-closer-2bb6b735.js.map → has-closer-08a41ac1.js.map} +1 -1
  442. package/dist/esm/{hide-label-fbf92ea1.js → hide-label-084e2864.js} +1 -1
  443. package/dist/esm/{hide-label-fbf92ea1.js.map → hide-label-084e2864.js.map} +1 -1
  444. package/dist/esm/{i18n-99b63f3a.js → i18n-4c7dd514.js} +1 -1
  445. package/dist/esm/{i18n-99b63f3a.js.map → i18n-4c7dd514.js.map} +1 -1
  446. package/dist/esm/{icons-cfc259bf.js → icons-5c25417f.js} +1 -1
  447. package/dist/esm/icons-5c25417f.js.map +1 -0
  448. package/dist/esm/{image-source-e19536fa.js → image-source-b96eb44d.js} +1 -1
  449. package/dist/esm/{image-source-e19536fa.js.map → image-source-b96eb44d.js.map} +1 -1
  450. package/dist/esm/index-5c4aa7d8.js +4 -0
  451. package/dist/esm/index-5c4aa7d8.js.map +1 -0
  452. package/dist/esm/index-a4a4df51.js +4 -0
  453. package/dist/esm/{index-9b519d08.js.map → index-a4a4df51.js.map} +1 -1
  454. package/dist/esm/index-e9d20d00.js +5 -0
  455. package/dist/esm/index-e9d20d00.js.map +1 -0
  456. package/dist/esm/index.js +1 -1
  457. package/dist/esm/kol-abbr.entry.js +1 -1
  458. package/dist/esm/kol-abbr.entry.js.map +1 -1
  459. package/dist/esm/kol-accordion.entry.js +1 -1
  460. package/dist/esm/kol-accordion.entry.js.map +1 -1
  461. package/dist/esm/kol-alert-wc_2.entry.js +1 -1
  462. package/dist/esm/kol-alert-wc_2.entry.js.map +1 -1
  463. package/dist/esm/kol-alert.entry.js +1 -1
  464. package/dist/esm/kol-alert.entry.js.map +1 -1
  465. package/dist/esm/kol-avatar-wc.entry.js +1 -1
  466. package/dist/esm/kol-avatar-wc.entry.js.map +1 -1
  467. package/dist/esm/kol-avatar.entry.js +1 -1
  468. package/dist/esm/kol-avatar.entry.js.map +1 -1
  469. package/dist/esm/kol-badge.entry.js +1 -1
  470. package/dist/esm/kol-badge.entry.js.map +1 -1
  471. package/dist/esm/kol-breadcrumb.entry.js +1 -1
  472. package/dist/esm/kol-breadcrumb.entry.js.map +1 -1
  473. package/dist/esm/kol-button-group-wc.entry.js +1 -1
  474. package/dist/esm/kol-button-group-wc.entry.js.map +1 -1
  475. package/dist/esm/kol-button-group.entry.js +1 -1
  476. package/dist/esm/kol-button-group.entry.js.map +1 -1
  477. package/dist/esm/kol-button-link-text-switch.entry.js +1 -1
  478. package/dist/esm/kol-button-link-text-switch.entry.js.map +1 -1
  479. package/dist/esm/kol-button-link.entry.js +1 -1
  480. package/dist/esm/kol-button-link.entry.js.map +1 -1
  481. package/dist/esm/kol-button-wc_2.entry.js +1 -1
  482. package/dist/esm/kol-button-wc_2.entry.js.map +1 -1
  483. package/dist/esm/kol-button.entry.js +1 -1
  484. package/dist/esm/kol-button.entry.js.map +1 -1
  485. package/dist/esm/kol-card.entry.js +1 -1
  486. package/dist/esm/kol-card.entry.js.map +1 -1
  487. package/dist/esm/kol-details.entry.js +1 -1
  488. package/dist/esm/kol-details.entry.js.map +1 -1
  489. package/dist/esm/kol-form.entry.js +1 -1
  490. package/dist/esm/kol-form.entry.js.map +1 -1
  491. package/dist/esm/kol-heading.entry.js +1 -1
  492. package/dist/esm/kol-heading.entry.js.map +1 -1
  493. package/dist/esm/kol-icon.entry.js +1 -1
  494. package/dist/esm/kol-icon.entry.js.map +1 -1
  495. package/dist/esm/kol-image.entry.js +1 -1
  496. package/dist/esm/kol-image.entry.js.map +1 -1
  497. package/dist/esm/kol-indented-text.entry.js +1 -1
  498. package/dist/esm/kol-indented-text.entry.js.map +1 -1
  499. package/dist/esm/kol-input-checkbox.entry.js +1 -1
  500. package/dist/esm/kol-input-checkbox.entry.js.map +1 -1
  501. package/dist/esm/kol-input-color.entry.js +1 -1
  502. package/dist/esm/kol-input-color.entry.js.map +1 -1
  503. package/dist/esm/kol-input-date.entry.js +1 -1
  504. package/dist/esm/kol-input-date.entry.js.map +1 -1
  505. package/dist/esm/kol-input-email.entry.js +1 -1
  506. package/dist/esm/kol-input-email.entry.js.map +1 -1
  507. package/dist/esm/kol-input-file.entry.js +1 -1
  508. package/dist/esm/kol-input-file.entry.js.map +1 -1
  509. package/dist/esm/kol-input-number.entry.js +1 -1
  510. package/dist/esm/kol-input-number.entry.js.map +1 -1
  511. package/dist/esm/kol-input-password.entry.js +1 -1
  512. package/dist/esm/kol-input-password.entry.js.map +1 -1
  513. package/dist/esm/kol-input-radio.entry.js +1 -1
  514. package/dist/esm/kol-input-radio.entry.js.map +1 -1
  515. package/dist/esm/kol-input-range.entry.js +1 -1
  516. package/dist/esm/kol-input-range.entry.js.map +1 -1
  517. package/dist/esm/kol-input-text.entry.js +1 -1
  518. package/dist/esm/kol-input-text.entry.js.map +1 -1
  519. package/dist/esm/kol-input.entry.js +1 -1
  520. package/dist/esm/kol-input.entry.js.map +1 -1
  521. package/dist/esm/kol-kolibri.entry.js +1 -1
  522. package/dist/esm/kol-kolibri.entry.js.map +1 -1
  523. package/dist/esm/kol-link-button.entry.js +1 -1
  524. package/dist/esm/kol-link-button.entry.js.map +1 -1
  525. package/dist/esm/kol-link-group.entry.js +1 -1
  526. package/dist/esm/kol-link-group.entry.js.map +1 -1
  527. package/dist/esm/kol-link-wc.entry.js +1 -1
  528. package/dist/esm/kol-link-wc.entry.js.map +1 -1
  529. package/dist/esm/kol-link.entry.js +1 -1
  530. package/dist/esm/kol-link.entry.js.map +1 -1
  531. package/dist/esm/kol-logo.entry.js +1 -1
  532. package/dist/esm/kol-logo.entry.js.map +1 -1
  533. package/dist/esm/kol-modal.entry.js +1 -1
  534. package/dist/esm/kol-modal.entry.js.map +1 -1
  535. package/dist/esm/kol-nav.entry.js +1 -1
  536. package/dist/esm/kol-nav.entry.js.map +1 -1
  537. package/dist/esm/kol-pagination.entry.js +1 -1
  538. package/dist/esm/kol-pagination.entry.js.map +1 -1
  539. package/dist/esm/kol-popover-wc.entry.js +1 -1
  540. package/dist/esm/kol-popover-wc.entry.js.map +1 -1
  541. package/dist/esm/kol-progress.entry.js +1 -1
  542. package/dist/esm/kol-progress.entry.js.map +1 -1
  543. package/dist/esm/kol-quote.entry.js +1 -1
  544. package/dist/esm/kol-quote.entry.js.map +1 -1
  545. package/dist/esm/kol-select.entry.js +1 -1
  546. package/dist/esm/kol-select.entry.js.map +1 -1
  547. package/dist/esm/kol-skip-nav.entry.js +1 -1
  548. package/dist/esm/kol-skip-nav.entry.js.map +1 -1
  549. package/dist/esm/kol-span-wc.entry.js +1 -1
  550. package/dist/esm/kol-span-wc.entry.js.map +1 -1
  551. package/dist/esm/kol-span.entry.js +1 -1
  552. package/dist/esm/kol-span.entry.js.map +1 -1
  553. package/dist/esm/kol-spin.entry.js +1 -1
  554. package/dist/esm/kol-spin.entry.js.map +1 -1
  555. package/dist/esm/kol-split-button.entry.js +1 -1
  556. package/dist/esm/kol-split-button.entry.js.map +1 -1
  557. package/dist/esm/kol-symbol.entry.js +1 -1
  558. package/dist/esm/kol-symbol.entry.js.map +1 -1
  559. package/dist/esm/kol-table.entry.js +1 -1
  560. package/dist/esm/kol-table.entry.js.map +1 -1
  561. package/dist/esm/kol-tabs.entry.js +1 -1
  562. package/dist/esm/kol-tabs.entry.js.map +1 -1
  563. package/dist/esm/kol-textarea.entry.js +1 -1
  564. package/dist/esm/kol-textarea.entry.js.map +1 -1
  565. package/dist/esm/kol-toast-container.entry.js +1 -1
  566. package/dist/esm/kol-toast-container.entry.js.map +1 -1
  567. package/dist/esm/kol-version.entry.js +1 -1
  568. package/dist/esm/kol-version.entry.js.map +1 -1
  569. package/dist/esm/kolibri.js +1 -1
  570. package/dist/esm/kolibri.js.map +1 -1
  571. package/dist/esm/{label-7afcc6a9.js → label-9700d24c.js} +1 -1
  572. package/dist/esm/label-9700d24c.js.map +1 -0
  573. package/dist/esm/loader.js +1 -1
  574. package/dist/esm/{open-9f31cf4e.js → open-35a03ecf.js} +1 -1
  575. package/dist/esm/{open-9f31cf4e.js.map → open-35a03ecf.js.map} +1 -1
  576. package/dist/esm/{prop.validators-3fb6bedf.js → prop.validators-17590a9e.js} +1 -1
  577. package/dist/esm/prop.validators-17590a9e.js.map +1 -0
  578. package/dist/esm/reprod-accordion-does-not-toggle-with-open-930fccf8.js.map +1 -0
  579. package/dist/esm/reuse-d79ab469.js.map +1 -0
  580. package/dist/esm/{rows-051ae081.js → rows-94cb79bb.js} +1 -1
  581. package/dist/esm/{rows-051ae081.js.map → rows-94cb79bb.js.map} +1 -1
  582. package/dist/esm/{show-cc5fafc8.js → show-c076dba9.js} +1 -1
  583. package/dist/esm/{show-cc5fafc8.js.map → show-c076dba9.js.map} +1 -1
  584. package/dist/esm/{suggestions-50aff467.js → suggestions-75157988.js} +1 -1
  585. package/dist/esm/suggestions-75157988.js.map +1 -0
  586. package/dist/esm/{tab-index-95df106a.js → tab-index-fbb584a0.js} +1 -1
  587. package/dist/esm/tab-index-fbb584a0.js.map +1 -0
  588. package/dist/esm/toaster-bd34d3c2.js +4 -0
  589. package/dist/esm/toaster-bd34d3c2.js.map +1 -0
  590. package/dist/esm/{toaster-ce50f062.js → toaster-f89ddf4f.js} +1 -1
  591. package/dist/esm/{toaster-ce50f062.js.map → toaster-f89ddf4f.js.map} +1 -1
  592. package/dist/esm/{tooltip-align-36725992.js → tooltip-align-37f47613.js} +1 -1
  593. package/dist/esm/{tooltip-align-36725992.js.map → tooltip-align-37f47613.js.map} +1 -1
  594. package/dist/esm/{unique-nav-labels-c6750f60.js.map → unique-nav-labels-62d9802d.js.map} +1 -1
  595. package/dist/esm/validation-10927214.js +4 -0
  596. package/dist/esm/{validation-7b943391.js.map → validation-10927214.js.map} +1 -1
  597. package/dist/esm/{validation-5f69c40a.js → validation-d70ea075.js} +1 -1
  598. package/dist/esm/{validation-5f69c40a.js.map → validation-d70ea075.js.map} +1 -1
  599. package/dist/kolibri/{InternalUnderlinedAccessKey-8b996006.js → InternalUnderlinedAccessKey-2c5af489.js} +1 -1
  600. package/dist/kolibri/{a11y.tipps-68791110.js → a11y.tipps-76f7d989.js} +1 -1
  601. package/dist/kolibri/access-key-bbc98ec1.js +4 -0
  602. package/dist/kolibri/{align-floating-elements-ebf0712d.js → align-floating-elements-cadb5c5b.js} +1 -1
  603. package/dist/kolibri/alignment-d30f46a0.js +4 -0
  604. package/dist/kolibri/alternative-button-link-role-8441bb1d.js +4 -0
  605. package/dist/kolibri/app-globals-9bc7e8f5.js +4 -0
  606. package/dist/kolibri/{associated.controller-d463ef08.js → associated.controller-3ce25c94.js} +1 -1
  607. package/dist/kolibri/{color-eb9db629.js → color-e1efb3bd.js} +1 -1
  608. package/dist/kolibri/controller-190730e1.js +4 -0
  609. package/dist/kolibri/controller-190730e1.js.map +1 -0
  610. package/dist/kolibri/{controller-5ca8ac64.js → controller-3123ae49.js} +1 -1
  611. package/dist/kolibri/controller-788d8028.js +4 -0
  612. package/dist/kolibri/controller-788d8028.js.map +1 -0
  613. package/dist/kolibri/controller-a3de638f.js +4 -0
  614. package/dist/kolibri/controller-a3de638f.js.map +1 -0
  615. package/dist/kolibri/controller-afeea78c.js +4 -0
  616. package/dist/kolibri/controller-afeea78c.js.map +1 -0
  617. package/dist/kolibri/{controller-icon-f63e0f2d.js → controller-icon-458bfe0e.js} +1 -1
  618. package/dist/kolibri/custom-class-4e4950dc.js +4 -0
  619. package/dist/kolibri/{dev.utils-8202a1bc.js → dev.utils-b86b7cfe.js} +1 -1
  620. package/dist/kolibri/{dev.utils-8202a1bc.js.map → dev.utils-b86b7cfe.js.map} +1 -1
  621. package/dist/kolibri/{devtools-4ca02a9a.js → devtools-e4239884.js} +1 -1
  622. package/dist/kolibri/has-closer-08a41ac1.js +4 -0
  623. package/dist/kolibri/{has-closer-2bb6b735.js.map → has-closer-08a41ac1.js.map} +1 -1
  624. package/dist/kolibri/hide-label-084e2864.js +4 -0
  625. package/dist/kolibri/{i18n-99b63f3a.js → i18n-4c7dd514.js} +1 -1
  626. package/dist/kolibri/icons-5c25417f.js +4 -0
  627. package/dist/kolibri/{icons-cfc259bf.js.map → icons-5c25417f.js.map} +1 -1
  628. package/dist/kolibri/image-source-b96eb44d.js +4 -0
  629. package/dist/kolibri/index-5c4aa7d8.js +4 -0
  630. package/dist/kolibri/index-5c4aa7d8.js.map +1 -0
  631. package/dist/kolibri/index-a4a4df51.js +4 -0
  632. package/dist/kolibri/index-e9d20d00.js +5 -0
  633. package/dist/kolibri/index-e9d20d00.js.map +1 -0
  634. package/dist/kolibri/index.esm.js +1 -1
  635. package/dist/kolibri/kol-abbr.entry.js +1 -1
  636. package/dist/kolibri/kol-abbr.entry.js.map +1 -1
  637. package/dist/kolibri/kol-accordion.entry.js +1 -1
  638. package/dist/kolibri/kol-accordion.entry.js.map +1 -1
  639. package/dist/kolibri/kol-alert-wc_2.entry.js +1 -1
  640. package/dist/kolibri/kol-alert-wc_2.entry.js.map +1 -1
  641. package/dist/kolibri/kol-alert.entry.js +1 -1
  642. package/dist/kolibri/kol-alert.entry.js.map +1 -1
  643. package/dist/kolibri/kol-avatar-wc.entry.js +1 -1
  644. package/dist/kolibri/kol-avatar.entry.js +1 -1
  645. package/dist/kolibri/kol-avatar.entry.js.map +1 -1
  646. package/dist/kolibri/kol-badge.entry.js +1 -1
  647. package/dist/kolibri/kol-badge.entry.js.map +1 -1
  648. package/dist/kolibri/kol-breadcrumb.entry.js +1 -1
  649. package/dist/kolibri/kol-breadcrumb.entry.js.map +1 -1
  650. package/dist/kolibri/kol-button-group-wc.entry.js +1 -1
  651. package/dist/kolibri/kol-button-group.entry.js +1 -1
  652. package/dist/kolibri/kol-button-group.entry.js.map +1 -1
  653. package/dist/kolibri/kol-button-link-text-switch.entry.js +1 -1
  654. package/dist/kolibri/kol-button-link.entry.js +1 -1
  655. package/dist/kolibri/kol-button-link.entry.js.map +1 -1
  656. package/dist/kolibri/kol-button-wc_2.entry.js +1 -1
  657. package/dist/kolibri/kol-button-wc_2.entry.js.map +1 -1
  658. package/dist/kolibri/kol-button.entry.js +1 -1
  659. package/dist/kolibri/kol-button.entry.js.map +1 -1
  660. package/dist/kolibri/kol-card.entry.js +1 -1
  661. package/dist/kolibri/kol-card.entry.js.map +1 -1
  662. package/dist/kolibri/kol-details.entry.js +1 -1
  663. package/dist/kolibri/kol-details.entry.js.map +1 -1
  664. package/dist/kolibri/kol-form.entry.js +1 -1
  665. package/dist/kolibri/kol-heading.entry.js +1 -1
  666. package/dist/kolibri/kol-heading.entry.js.map +1 -1
  667. package/dist/kolibri/kol-icon.entry.js +1 -1
  668. package/dist/kolibri/kol-image.entry.js +1 -1
  669. package/dist/kolibri/kol-indented-text.entry.js +1 -1
  670. package/dist/kolibri/kol-indented-text.entry.js.map +1 -1
  671. package/dist/kolibri/kol-input-checkbox.entry.js +1 -1
  672. package/dist/kolibri/kol-input-checkbox.entry.js.map +1 -1
  673. package/dist/kolibri/kol-input-color.entry.js +1 -1
  674. package/dist/kolibri/kol-input-color.entry.js.map +1 -1
  675. package/dist/kolibri/kol-input-date.entry.js +1 -1
  676. package/dist/kolibri/kol-input-date.entry.js.map +1 -1
  677. package/dist/kolibri/kol-input-email.entry.js +1 -1
  678. package/dist/kolibri/kol-input-email.entry.js.map +1 -1
  679. package/dist/kolibri/kol-input-file.entry.js +1 -1
  680. package/dist/kolibri/kol-input-file.entry.js.map +1 -1
  681. package/dist/kolibri/kol-input-number.entry.js +1 -1
  682. package/dist/kolibri/kol-input-number.entry.js.map +1 -1
  683. package/dist/kolibri/kol-input-password.entry.js +1 -1
  684. package/dist/kolibri/kol-input-password.entry.js.map +1 -1
  685. package/dist/kolibri/kol-input-radio.entry.js +1 -1
  686. package/dist/kolibri/kol-input-radio.entry.js.map +1 -1
  687. package/dist/kolibri/kol-input-range.entry.js +1 -1
  688. package/dist/kolibri/kol-input-range.entry.js.map +1 -1
  689. package/dist/kolibri/kol-input-text.entry.js +1 -1
  690. package/dist/kolibri/kol-input-text.entry.js.map +1 -1
  691. package/dist/kolibri/kol-input.entry.js +1 -1
  692. package/dist/kolibri/kol-input.entry.js.map +1 -1
  693. package/dist/kolibri/kol-kolibri.entry.js +1 -1
  694. package/dist/kolibri/kol-kolibri.entry.js.map +1 -1
  695. package/dist/kolibri/kol-link-button.entry.js +1 -1
  696. package/dist/kolibri/kol-link-button.entry.js.map +1 -1
  697. package/dist/kolibri/kol-link-group.entry.js +1 -1
  698. package/dist/kolibri/kol-link-group.entry.js.map +1 -1
  699. package/dist/kolibri/kol-link-wc.entry.js +1 -1
  700. package/dist/kolibri/kol-link.entry.js +1 -1
  701. package/dist/kolibri/kol-link.entry.js.map +1 -1
  702. package/dist/kolibri/kol-logo.entry.js +1 -1
  703. package/dist/kolibri/kol-logo.entry.js.map +1 -1
  704. package/dist/kolibri/kol-modal.entry.js +1 -1
  705. package/dist/kolibri/kol-modal.entry.js.map +1 -1
  706. package/dist/kolibri/kol-nav.entry.js +1 -1
  707. package/dist/kolibri/kol-nav.entry.js.map +1 -1
  708. package/dist/kolibri/kol-pagination.entry.js +1 -1
  709. package/dist/kolibri/kol-pagination.entry.js.map +1 -1
  710. package/dist/kolibri/kol-popover-wc.entry.js +1 -1
  711. package/dist/kolibri/kol-popover-wc.entry.js.map +1 -1
  712. package/dist/kolibri/kol-progress.entry.js +1 -1
  713. package/dist/kolibri/kol-progress.entry.js.map +1 -1
  714. package/dist/kolibri/kol-quote.entry.js +1 -1
  715. package/dist/kolibri/kol-quote.entry.js.map +1 -1
  716. package/dist/kolibri/kol-select.entry.js +1 -1
  717. package/dist/kolibri/kol-select.entry.js.map +1 -1
  718. package/dist/kolibri/kol-skip-nav.entry.js +1 -1
  719. package/dist/kolibri/kol-skip-nav.entry.js.map +1 -1
  720. package/dist/kolibri/kol-span-wc.entry.js +1 -1
  721. package/dist/kolibri/kol-span.entry.js +1 -1
  722. package/dist/kolibri/kol-span.entry.js.map +1 -1
  723. package/dist/kolibri/kol-spin.entry.js +1 -1
  724. package/dist/kolibri/kol-spin.entry.js.map +1 -1
  725. package/dist/kolibri/kol-split-button.entry.js +1 -1
  726. package/dist/kolibri/kol-split-button.entry.js.map +1 -1
  727. package/dist/kolibri/kol-symbol.entry.js +1 -1
  728. package/dist/kolibri/kol-symbol.entry.js.map +1 -1
  729. package/dist/kolibri/kol-table.entry.js +1 -1
  730. package/dist/kolibri/kol-table.entry.js.map +1 -1
  731. package/dist/kolibri/kol-tabs.entry.js +1 -1
  732. package/dist/kolibri/kol-tabs.entry.js.map +1 -1
  733. package/dist/kolibri/kol-textarea.entry.js +1 -1
  734. package/dist/kolibri/kol-textarea.entry.js.map +1 -1
  735. package/dist/kolibri/kol-toast-container.entry.js +1 -1
  736. package/dist/kolibri/kol-toast-container.entry.js.map +1 -1
  737. package/dist/kolibri/kol-version.entry.js +1 -1
  738. package/dist/kolibri/kol-version.entry.js.map +1 -1
  739. package/dist/kolibri/kolibri.esm.js +1 -1
  740. package/dist/kolibri/kolibri.esm.js.map +1 -1
  741. package/dist/kolibri/{label-7afcc6a9.js → label-9700d24c.js} +1 -1
  742. package/dist/kolibri/open-35a03ecf.js +4 -0
  743. package/dist/kolibri/{prop.validators-3fb6bedf.js → prop.validators-17590a9e.js} +1 -1
  744. package/dist/kolibri/rows-94cb79bb.js +4 -0
  745. package/dist/kolibri/show-c076dba9.js +4 -0
  746. package/dist/kolibri/{suggestions-50aff467.js → suggestions-75157988.js} +1 -1
  747. package/dist/kolibri/{tab-index-95df106a.js → tab-index-fbb584a0.js} +1 -1
  748. package/dist/kolibri/toaster-bd34d3c2.js +4 -0
  749. package/dist/kolibri/toaster-bd34d3c2.js.map +1 -0
  750. package/dist/kolibri/toaster-f89ddf4f.js +4 -0
  751. package/dist/kolibri/tooltip-align-37f47613.js +4 -0
  752. package/dist/kolibri/validation-10927214.js +4 -0
  753. package/dist/kolibri/{validation-5f69c40a.js → validation-d70ea075.js} +1 -1
  754. package/dist/types/components/@deprecated/input/controller-icon.d.ts +5 -5
  755. package/dist/types/components/@deprecated/input/controller.d.ts +28 -27
  756. package/dist/types/components/@deprecated/input/types-icon.d.ts +2 -2
  757. package/dist/types/components/@deprecated/input/types.d.ts +12 -11
  758. package/dist/types/components/@else/all/component.d.ts +2 -2
  759. package/dist/types/components/@else/counter/component.d.ts +6 -6
  760. package/dist/types/components/abbr/component.d.ts +8 -8
  761. package/dist/types/components/accordion/component.d.ts +15 -15
  762. package/dist/types/components/accordion/test/html.mock.d.ts +2 -2
  763. package/dist/types/components/accordion/types.d.ts +3 -3
  764. package/dist/types/components/alert/component.d.ts +20 -20
  765. package/dist/types/components/alert/shadow.d.ts +9 -9
  766. package/dist/types/components/alert/types.d.ts +5 -5
  767. package/dist/types/components/avatar/component.d.ts +7 -7
  768. package/dist/types/components/avatar/shadow.d.ts +3 -3
  769. package/dist/types/components/badge/component.d.ts +14 -14
  770. package/dist/types/components/badge/contrast.d.ts +3 -3
  771. package/dist/types/components/badge/types.d.ts +5 -5
  772. package/dist/types/components/breadcrumb/component.d.ts +9 -9
  773. package/dist/types/components/breadcrumb/types.d.ts +2 -2
  774. package/dist/types/components/button/component.d.ts +47 -47
  775. package/dist/types/components/button/shadow.d.ts +23 -23
  776. package/dist/types/components/button/test/html.mock.d.ts +1 -1
  777. package/dist/types/components/button/types.d.ts +3 -3
  778. package/dist/types/components/button-group/component.d.ts +2 -2
  779. package/dist/types/components/button-group/shadow.d.ts +1 -1
  780. package/dist/types/components/button-link/component.d.ts +21 -21
  781. package/dist/types/components/button-link-text-switch/component.d.ts +6 -6
  782. package/dist/types/components/button-link-text-switch/types.d.ts +3 -3
  783. package/dist/types/components/card/component.d.ts +14 -14
  784. package/dist/types/components/card/types.d.ts +3 -3
  785. package/dist/types/components/details/DetailsAnimationController.d.ts +13 -13
  786. package/dist/types/components/details/component.d.ts +17 -17
  787. package/dist/types/components/details/test/html.mock.d.ts +1 -1
  788. package/dist/types/components/details/types.d.ts +2 -2
  789. package/dist/types/components/form/component.d.ts +9 -9
  790. package/dist/types/components/form/controller.d.ts +4 -4
  791. package/dist/types/components/form/types.d.ts +4 -4
  792. package/dist/types/components/heading/component.d.ts +13 -13
  793. package/dist/types/components/heading/shadow.d.ts +5 -5
  794. package/dist/types/components/heading/test/html.mock.d.ts +2 -2
  795. package/dist/types/components/heading/types.d.ts +4 -4
  796. package/dist/types/components/icon/component.d.ts +7 -7
  797. package/dist/types/components/icon/types.d.ts +1 -1
  798. package/dist/types/components/image/shadow.d.ts +13 -13
  799. package/dist/types/components/image/types.d.ts +7 -7
  800. package/dist/types/components/indented-text/component.d.ts +2 -2
  801. package/dist/types/components/indented-text/test/html.mock.d.ts +1 -1
  802. package/dist/types/components/input/component.d.ts +27 -27
  803. package/dist/types/components/input/controller.d.ts +7 -7
  804. package/dist/types/components/input/types.d.ts +7 -7
  805. package/dist/types/components/input-adapter-leanup/associated.controller.d.ts +15 -15
  806. package/dist/types/components/input-adapter-leanup/controller.d.ts +5 -5
  807. package/dist/types/components/input-adapter-leanup/types.d.ts +2 -2
  808. package/dist/types/components/input-checkbox/component.d.ts +51 -52
  809. package/dist/types/components/input-checkbox/controller.d.ts +9 -11
  810. package/dist/types/components/input-checkbox/types.d.ts +31 -31
  811. package/dist/types/components/input-color/component.d.ts +48 -48
  812. package/dist/types/components/input-color/controller.d.ts +6 -8
  813. package/dist/types/components/input-color/types.d.ts +22 -22
  814. package/dist/types/components/input-date/component.d.ts +61 -61
  815. package/dist/types/components/input-date/controller.d.ts +24 -26
  816. package/dist/types/components/input-date/types.d.ts +18 -18
  817. package/dist/types/components/input-email/component.d.ts +63 -63
  818. package/dist/types/components/input-email/controller.d.ts +4 -6
  819. package/dist/types/components/input-email/types.d.ts +29 -29
  820. package/dist/types/components/input-file/component.d.ts +51 -51
  821. package/dist/types/components/input-file/controller.d.ts +7 -9
  822. package/dist/types/components/input-file/types.d.ts +20 -20
  823. package/dist/types/components/input-number/component.d.ts +61 -61
  824. package/dist/types/components/input-number/controller.d.ts +17 -19
  825. package/dist/types/components/input-number/types.d.ts +17 -17
  826. package/dist/types/components/input-password/component.d.ts +59 -59
  827. package/dist/types/components/input-password/controller.d.ts +14 -16
  828. package/dist/types/components/input-password/types.d.ts +28 -28
  829. package/dist/types/components/input-radio/component.d.ts +47 -47
  830. package/dist/types/components/input-radio/controller.d.ts +16 -18
  831. package/dist/types/components/input-radio/types.d.ts +17 -17
  832. package/dist/types/components/input-range/component.d.ts +55 -55
  833. package/dist/types/components/input-range/controller.d.ts +9 -11
  834. package/dist/types/components/input-range/types.d.ts +25 -25
  835. package/dist/types/components/input-text/component.d.ts +66 -66
  836. package/dist/types/components/input-text/controller.d.ts +11 -13
  837. package/dist/types/components/input-text/types.d.ts +31 -31
  838. package/dist/types/components/kolibri/component.d.ts +13 -13
  839. package/dist/types/components/kolibri/types.d.ts +10 -10
  840. package/dist/types/components/link/component.d.ts +36 -36
  841. package/dist/types/components/link/shadow.d.ts +16 -16
  842. package/dist/types/components/link/types.d.ts +3 -3
  843. package/dist/types/components/link-button/component.d.ts +18 -18
  844. package/dist/types/components/link-group/component.d.ts +13 -13
  845. package/dist/types/components/link-group/types.d.ts +6 -6
  846. package/dist/types/components/logo/component.d.ts +5 -5
  847. package/dist/types/components/logo/types.d.ts +1 -1
  848. package/dist/types/components/modal/component.d.ts +15 -15
  849. package/dist/types/components/modal/service.d.ts +9 -9
  850. package/dist/types/components/modal/types.d.ts +6 -6
  851. package/dist/types/components/nav/component.d.ts +22 -22
  852. package/dist/types/components/nav/types.d.ts +4 -4
  853. package/dist/types/components/nav/validation.d.ts +3 -3
  854. package/dist/types/components/pagination/component.d.ts +41 -41
  855. package/dist/types/components/pagination/types.d.ts +21 -21
  856. package/dist/types/components/popover/component.d.ts +20 -20
  857. package/dist/types/components/popover/test/html.mock.d.ts +1 -1
  858. package/dist/types/components/popover/types.d.ts +1 -1
  859. package/dist/types/components/progress/component.d.ts +15 -15
  860. package/dist/types/components/progress/types.d.ts +7 -7
  861. package/dist/types/components/quote/shadow.d.ts +11 -11
  862. package/dist/types/components/quote/test/html.mock.d.ts +1 -1
  863. package/dist/types/components/quote/types.d.ts +4 -4
  864. package/dist/types/components/select/component.d.ts +52 -52
  865. package/dist/types/components/select/controller.d.ts +14 -16
  866. package/dist/types/components/select/types.d.ts +18 -18
  867. package/dist/types/components/skip-nav/component.d.ts +8 -8
  868. package/dist/types/components/skip-nav/types.d.ts +2 -2
  869. package/dist/types/components/span/InternalUnderlinedAccessKey.d.ts +2 -2
  870. package/dist/types/components/span/component.d.ts +13 -13
  871. package/dist/types/components/span/shadow.d.ts +5 -5
  872. package/dist/types/components/span/test/html.mock.d.ts +4 -4
  873. package/dist/types/components/span/types.d.ts +9 -9
  874. package/dist/types/components/spin/component.d.ts +8 -8
  875. package/dist/types/components/split-button/component.d.ts +28 -28
  876. package/dist/types/components/split-button/types.d.ts +1 -1
  877. package/dist/types/components/symbol/component.d.ts +7 -7
  878. package/dist/types/components/symbol/types.d.ts +1 -1
  879. package/dist/types/components/table/component.d.ts +42 -42
  880. package/dist/types/components/table/types.d.ts +37 -37
  881. package/dist/types/components/tabs/component.d.ts +32 -32
  882. package/dist/types/components/tabs/types.d.ts +12 -12
  883. package/dist/types/components/textarea/component.d.ts +57 -57
  884. package/dist/types/components/textarea/controller.d.ts +12 -14
  885. package/dist/types/components/textarea/types.d.ts +23 -23
  886. package/dist/types/components/toaster/InternalToast.d.ts +3 -3
  887. package/dist/types/components/toaster/component.d.ts +5 -5
  888. package/dist/types/components/toaster/toaster.d.ts +10 -9
  889. package/dist/types/components/toaster/types.d.ts +15 -11
  890. package/dist/types/components/tooltip/component.d.ts +34 -34
  891. package/dist/types/components/version/component.d.ts +5 -5
  892. package/dist/types/core/i18n.d.ts +13 -13
  893. package/dist/types/enums/bund.d.ts +58 -58
  894. package/dist/types/enums/events.d.ts +17 -17
  895. package/dist/types/i18n.d.ts +4 -4
  896. package/dist/types/index.d.ts +11 -1
  897. package/dist/types/locales/de.d.ts +39 -39
  898. package/dist/types/locales/en.d.ts +39 -39
  899. package/dist/types/stencil-public-runtime.d.ts +8 -0
  900. package/dist/types/types/button-link-text.d.ts +5 -5
  901. package/dist/types/types/icons.d.ts +6 -6
  902. package/dist/types/types/input/control/number.d.ts +19 -19
  903. package/dist/types/types/input/types.d.ts +10 -10
  904. package/dist/types/types/modal.d.ts +1 -1
  905. package/dist/types/types/progress.d.ts +4 -4
  906. package/dist/types/types/props/access-key.d.ts +1 -1
  907. package/dist/types/types/props/adjust-height.d.ts +1 -1
  908. package/dist/types/types/props/alert.d.ts +1 -1
  909. package/dist/types/types/props/align.d.ts +1 -1
  910. package/dist/types/types/props/alternative-button-link-role.d.ts +1 -1
  911. package/dist/types/types/props/aria-controls.d.ts +1 -1
  912. package/dist/types/types/props/aria-current-value.d.ts +1 -1
  913. package/dist/types/types/props/aria-expanded.d.ts +1 -1
  914. package/dist/types/types/props/aria-selected.d.ts +1 -1
  915. package/dist/types/types/props/button-callbacks.d.ts +3 -3
  916. package/dist/types/types/props/button-type.d.ts +1 -1
  917. package/dist/types/types/props/button-variant.d.ts +1 -1
  918. package/dist/types/types/props/checked.d.ts +1 -1
  919. package/dist/types/types/props/collapsible.d.ts +1 -1
  920. package/dist/types/types/props/color.d.ts +5 -5
  921. package/dist/types/types/props/custom-class.d.ts +1 -1
  922. package/dist/types/types/props/disabled.d.ts +1 -1
  923. package/dist/types/types/props/download.d.ts +1 -1
  924. package/dist/types/types/props/has-closer.d.ts +1 -1
  925. package/dist/types/types/props/has-compact-button.d.ts +1 -1
  926. package/dist/types/types/props/has-counter.d.ts +1 -1
  927. package/dist/types/types/props/heading-variant.d.ts +1 -1
  928. package/dist/types/types/props/hide-error.d.ts +1 -1
  929. package/dist/types/types/props/hide-label.d.ts +1 -1
  930. package/dist/types/types/props/href.d.ts +1 -1
  931. package/dist/types/types/props/icons.d.ts +1 -1
  932. package/dist/types/types/props/id.d.ts +1 -1
  933. package/dist/types/types/props/image-source.d.ts +1 -1
  934. package/dist/types/types/props/indeterminate.d.ts +1 -1
  935. package/dist/types/types/props/label.d.ts +2 -2
  936. package/dist/types/types/props/link-on-callbacks.d.ts +2 -2
  937. package/dist/types/types/props/link-target.d.ts +1 -1
  938. package/dist/types/types/props/max.d.ts +1 -1
  939. package/dist/types/types/props/multiple.d.ts +1 -1
  940. package/dist/types/types/props/name.d.ts +1 -1
  941. package/dist/types/types/props/open.d.ts +1 -1
  942. package/dist/types/types/props/options.d.ts +2 -2
  943. package/dist/types/types/props/read-only.d.ts +1 -1
  944. package/dist/types/types/props/required.d.ts +1 -1
  945. package/dist/types/types/props/rows.d.ts +1 -1
  946. package/dist/types/types/props/show.d.ts +1 -1
  947. package/dist/types/types/props/suggestions.d.ts +1 -1
  948. package/dist/types/types/props/sync-value-by-selector.d.ts +1 -1
  949. package/dist/types/types/props/tooltip-align.d.ts +1 -1
  950. package/dist/types/types/props/touched.d.ts +1 -1
  951. package/dist/types/types/props/variant/spin.d.ts +1 -1
  952. package/dist/types/utils/a11y.tipps.d.ts +2 -2
  953. package/dist/types/utils/align-floating-elements.d.ts +4 -4
  954. package/dist/types/utils/color.utils.d.ts +8 -8
  955. package/dist/types/utils/dev.utils.d.ts +13 -13
  956. package/dist/types/utils/prop.validators.d.ts +25 -25
  957. package/doc/alert.md +2 -2
  958. package/doc/components.md +40 -2
  959. package/doc/toaster.md +4 -1
  960. package/doc/tooltip.md +11 -0
  961. package/package.json +1 -1
  962. package/dist/cjs/access-key-30674e1a.js +0 -4
  963. package/dist/cjs/align-floating-elements-01d5ad38.js.map +0 -1
  964. package/dist/cjs/alternative-button-link-role-e188938c.js +0 -4
  965. package/dist/cjs/app-globals-fcc1963e.js.map +0 -1
  966. package/dist/cjs/associated.controller-b5e04826.js.map +0 -1
  967. package/dist/cjs/color-ccd88de4.js.map +0 -1
  968. package/dist/cjs/controller-20b8c73c.js +0 -4
  969. package/dist/cjs/controller-20b8c73c.js.map +0 -1
  970. package/dist/cjs/controller-5e7966e3.js +0 -4
  971. package/dist/cjs/controller-5e7966e3.js.map +0 -1
  972. package/dist/cjs/controller-98ced69a.js +0 -4
  973. package/dist/cjs/controller-98ced69a.js.map +0 -1
  974. package/dist/cjs/controller-b37efa9f.js.map +0 -1
  975. package/dist/cjs/controller-dd37111e.js +0 -4
  976. package/dist/cjs/controller-dd37111e.js.map +0 -1
  977. package/dist/cjs/controller-icon-1d1188c3.js.map +0 -1
  978. package/dist/cjs/custom-class-4a4b8f5f.js +0 -4
  979. package/dist/cjs/dev.utils-a3fa0ded.js.map +0 -1
  980. package/dist/cjs/devtools-37eef902.js.map +0 -1
  981. package/dist/cjs/has-closer-c17cc0bc.js +0 -4
  982. package/dist/cjs/hide-label-1eab3780.js +0 -4
  983. package/dist/cjs/icons-92e34672.js.map +0 -1
  984. package/dist/cjs/image-source-51299edf.js +0 -4
  985. package/dist/cjs/index-07f69fb0.js +0 -4
  986. package/dist/cjs/index-a0085191.js +0 -5
  987. package/dist/cjs/index-a0085191.js.map +0 -1
  988. package/dist/cjs/index-b786e835.js +0 -4
  989. package/dist/cjs/index-b786e835.js.map +0 -1
  990. package/dist/cjs/label-5a44a87d.js.map +0 -1
  991. package/dist/cjs/open-1740dbfd.js +0 -4
  992. package/dist/cjs/prop.validators-249e288b.js.map +0 -1
  993. package/dist/cjs/reprod-accordion-does-not-toggle-with-open-53004853.js.map +0 -1
  994. package/dist/cjs/reuse-786396d6.js.map +0 -1
  995. package/dist/cjs/rows-d8f6b3fe.js +0 -4
  996. package/dist/cjs/show-4f692c20.js +0 -4
  997. package/dist/cjs/suggestions-b89272cd.js.map +0 -1
  998. package/dist/cjs/tab-index-b0756f58.js.map +0 -1
  999. package/dist/cjs/toaster-812c9c9b.js +0 -4
  1000. package/dist/cjs/toaster-812c9c9b.js.map +0 -1
  1001. package/dist/esm/align-floating-elements-ebf0712d.js.map +0 -1
  1002. package/dist/esm/alternative-button-link-role-641ea928.js +0 -4
  1003. package/dist/esm/app-globals-7879f3fb.js +0 -4
  1004. package/dist/esm/app-globals-7879f3fb.js.map +0 -1
  1005. package/dist/esm/associated.controller-d463ef08.js.map +0 -1
  1006. package/dist/esm/color-eb9db629.js.map +0 -1
  1007. package/dist/esm/controller-00d56583.js +0 -4
  1008. package/dist/esm/controller-00d56583.js.map +0 -1
  1009. package/dist/esm/controller-5838290e.js +0 -4
  1010. package/dist/esm/controller-5838290e.js.map +0 -1
  1011. package/dist/esm/controller-5ca8ac64.js.map +0 -1
  1012. package/dist/esm/controller-70bc75df.js +0 -4
  1013. package/dist/esm/controller-70bc75df.js.map +0 -1
  1014. package/dist/esm/controller-8b71bf6d.js +0 -4
  1015. package/dist/esm/controller-8b71bf6d.js.map +0 -1
  1016. package/dist/esm/controller-icon-f63e0f2d.js.map +0 -1
  1017. package/dist/esm/custom-class-66c19712.js +0 -4
  1018. package/dist/esm/dev.utils-8202a1bc.js.map +0 -1
  1019. package/dist/esm/devtools-4ca02a9a.js.map +0 -1
  1020. package/dist/esm/icons-cfc259bf.js.map +0 -1
  1021. package/dist/esm/index-0bc40dc4.js +0 -5
  1022. package/dist/esm/index-0bc40dc4.js.map +0 -1
  1023. package/dist/esm/index-9b519d08.js +0 -4
  1024. package/dist/esm/index-a4b1e92f.js +0 -4
  1025. package/dist/esm/index-a4b1e92f.js.map +0 -1
  1026. package/dist/esm/label-7afcc6a9.js.map +0 -1
  1027. package/dist/esm/prop.validators-3fb6bedf.js.map +0 -1
  1028. package/dist/esm/reprod-accordion-does-not-toggle-with-open-542a45b3.js.map +0 -1
  1029. package/dist/esm/reuse-b3566e4c.js.map +0 -1
  1030. package/dist/esm/suggestions-50aff467.js.map +0 -1
  1031. package/dist/esm/tab-index-95df106a.js.map +0 -1
  1032. package/dist/esm/toaster-eb99e2fa.js +0 -4
  1033. package/dist/esm/toaster-eb99e2fa.js.map +0 -1
  1034. package/dist/esm/validation-7b943391.js +0 -4
  1035. package/dist/kolibri/access-key-c2c8b712.js +0 -4
  1036. package/dist/kolibri/alignment-cb8fa342.js +0 -4
  1037. package/dist/kolibri/alternative-button-link-role-641ea928.js +0 -4
  1038. package/dist/kolibri/app-globals-7879f3fb.js +0 -4
  1039. package/dist/kolibri/controller-00d56583.js +0 -4
  1040. package/dist/kolibri/controller-00d56583.js.map +0 -1
  1041. package/dist/kolibri/controller-5838290e.js +0 -4
  1042. package/dist/kolibri/controller-5838290e.js.map +0 -1
  1043. package/dist/kolibri/controller-70bc75df.js +0 -4
  1044. package/dist/kolibri/controller-70bc75df.js.map +0 -1
  1045. package/dist/kolibri/controller-8b71bf6d.js +0 -4
  1046. package/dist/kolibri/controller-8b71bf6d.js.map +0 -1
  1047. package/dist/kolibri/custom-class-66c19712.js +0 -4
  1048. package/dist/kolibri/has-closer-2bb6b735.js +0 -4
  1049. package/dist/kolibri/hide-label-fbf92ea1.js +0 -4
  1050. package/dist/kolibri/icons-cfc259bf.js +0 -4
  1051. package/dist/kolibri/image-source-e19536fa.js +0 -4
  1052. package/dist/kolibri/index-0bc40dc4.js +0 -5
  1053. package/dist/kolibri/index-0bc40dc4.js.map +0 -1
  1054. package/dist/kolibri/index-9b519d08.js +0 -4
  1055. package/dist/kolibri/index-a4b1e92f.js +0 -4
  1056. package/dist/kolibri/index-a4b1e92f.js.map +0 -1
  1057. package/dist/kolibri/open-9f31cf4e.js +0 -4
  1058. package/dist/kolibri/rows-051ae081.js +0 -4
  1059. package/dist/kolibri/show-cc5fafc8.js +0 -4
  1060. package/dist/kolibri/toaster-ce50f062.js +0 -4
  1061. package/dist/kolibri/toaster-eb99e2fa.js +0 -4
  1062. package/dist/kolibri/toaster-eb99e2fa.js.map +0 -1
  1063. package/dist/kolibri/tooltip-align-36725992.js +0 -4
  1064. package/dist/kolibri/validation-7b943391.js +0 -4
  1065. /package/dist/cjs/{ariaCurrentService-d894e18d.js → ariaCurrentService-53afa476.js} +0 -0
  1066. /package/dist/cjs/{bund-f5184e9e.js → bund-4be96755.js} +0 -0
  1067. /package/dist/cjs/{details-synced-open-state-01d46fbc.js → details-synced-open-state-e88811c7.js} +0 -0
  1068. /package/dist/cjs/{events-a0c291ce.js → events-e348a615.js} +0 -0
  1069. /package/dist/cjs/{reprod-accordion-does-not-toggle-with-open-53004853.js → reprod-accordion-does-not-toggle-with-open-092e559d.js} +0 -0
  1070. /package/dist/cjs/{reuse-786396d6.js → reuse-a4c8450e.js} +0 -0
  1071. /package/dist/cjs/{unique-nav-labels-9784a4c5.js → unique-nav-labels-363e1d71.js} +0 -0
  1072. /package/dist/esm/{ariaCurrentService-2ef83ca8.js → ariaCurrentService-6fe36ebc.js} +0 -0
  1073. /package/dist/esm/{bund-056aa89a.js → bund-ad41b762.js} +0 -0
  1074. /package/dist/esm/{details-synced-open-state-66c07ea5.js → details-synced-open-state-45ecc035.js} +0 -0
  1075. /package/dist/esm/{events-2bb1065b.js → events-fa760b68.js} +0 -0
  1076. /package/dist/esm/{reprod-accordion-does-not-toggle-with-open-542a45b3.js → reprod-accordion-does-not-toggle-with-open-930fccf8.js} +0 -0
  1077. /package/dist/esm/{reuse-b3566e4c.js → reuse-d79ab469.js} +0 -0
  1078. /package/dist/esm/{unique-nav-labels-c6750f60.js → unique-nav-labels-62d9802d.js} +0 -0
  1079. /package/dist/kolibri/{InternalUnderlinedAccessKey-8b996006.js.map → InternalUnderlinedAccessKey-2c5af489.js.map} +0 -0
  1080. /package/dist/kolibri/{a11y.tipps-68791110.js.map → a11y.tipps-76f7d989.js.map} +0 -0
  1081. /package/dist/kolibri/{access-key-c2c8b712.js.map → access-key-bbc98ec1.js.map} +0 -0
  1082. /package/dist/kolibri/{align-floating-elements-ebf0712d.js.map → align-floating-elements-cadb5c5b.js.map} +0 -0
  1083. /package/dist/kolibri/{alignment-cb8fa342.js.map → alignment-d30f46a0.js.map} +0 -0
  1084. /package/dist/kolibri/{alternative-button-link-role-641ea928.js.map → alternative-button-link-role-8441bb1d.js.map} +0 -0
  1085. /package/dist/kolibri/{app-globals-7879f3fb.js.map → app-globals-9bc7e8f5.js.map} +0 -0
  1086. /package/dist/kolibri/{ariaCurrentService-2ef83ca8.js → ariaCurrentService-6fe36ebc.js} +0 -0
  1087. /package/dist/kolibri/{ariaCurrentService-2ef83ca8.js.map → ariaCurrentService-6fe36ebc.js.map} +0 -0
  1088. /package/dist/kolibri/{associated.controller-d463ef08.js.map → associated.controller-3ce25c94.js.map} +0 -0
  1089. /package/dist/kolibri/{bund-056aa89a.js → bund-ad41b762.js} +0 -0
  1090. /package/dist/kolibri/{bund-056aa89a.js.map → bund-ad41b762.js.map} +0 -0
  1091. /package/dist/kolibri/{color-eb9db629.js.map → color-e1efb3bd.js.map} +0 -0
  1092. /package/dist/kolibri/{controller-5ca8ac64.js.map → controller-3123ae49.js.map} +0 -0
  1093. /package/dist/kolibri/{controller-icon-f63e0f2d.js.map → controller-icon-458bfe0e.js.map} +0 -0
  1094. /package/dist/kolibri/{custom-class-66c19712.js.map → custom-class-4e4950dc.js.map} +0 -0
  1095. /package/dist/kolibri/{details-synced-open-state-66c07ea5.js → details-synced-open-state-45ecc035.js} +0 -0
  1096. /package/dist/kolibri/{details-synced-open-state-66c07ea5.js.map → details-synced-open-state-45ecc035.js.map} +0 -0
  1097. /package/dist/kolibri/{devtools-4ca02a9a.js.map → devtools-e4239884.js.map} +0 -0
  1098. /package/dist/kolibri/{events-2bb1065b.js → events-fa760b68.js} +0 -0
  1099. /package/dist/kolibri/{events-2bb1065b.js.map → events-fa760b68.js.map} +0 -0
  1100. /package/dist/kolibri/{hide-label-fbf92ea1.js.map → hide-label-084e2864.js.map} +0 -0
  1101. /package/dist/kolibri/{i18n-99b63f3a.js.map → i18n-4c7dd514.js.map} +0 -0
  1102. /package/dist/kolibri/{image-source-e19536fa.js.map → image-source-b96eb44d.js.map} +0 -0
  1103. /package/dist/kolibri/{index-9b519d08.js.map → index-a4a4df51.js.map} +0 -0
  1104. /package/dist/kolibri/{label-7afcc6a9.js.map → label-9700d24c.js.map} +0 -0
  1105. /package/dist/kolibri/{open-9f31cf4e.js.map → open-35a03ecf.js.map} +0 -0
  1106. /package/dist/kolibri/{prop.validators-3fb6bedf.js.map → prop.validators-17590a9e.js.map} +0 -0
  1107. /package/dist/kolibri/{reprod-accordion-does-not-toggle-with-open-542a45b3.js → reprod-accordion-does-not-toggle-with-open-930fccf8.js} +0 -0
  1108. /package/dist/kolibri/{reprod-accordion-does-not-toggle-with-open-542a45b3.js.map → reprod-accordion-does-not-toggle-with-open-930fccf8.js.map} +0 -0
  1109. /package/dist/kolibri/{reuse-b3566e4c.js → reuse-d79ab469.js} +0 -0
  1110. /package/dist/kolibri/{reuse-b3566e4c.js.map → reuse-d79ab469.js.map} +0 -0
  1111. /package/dist/kolibri/{rows-051ae081.js.map → rows-94cb79bb.js.map} +0 -0
  1112. /package/dist/kolibri/{show-cc5fafc8.js.map → show-c076dba9.js.map} +0 -0
  1113. /package/dist/kolibri/{suggestions-50aff467.js.map → suggestions-75157988.js.map} +0 -0
  1114. /package/dist/kolibri/{tab-index-95df106a.js.map → tab-index-fbb584a0.js.map} +0 -0
  1115. /package/dist/kolibri/{toaster-ce50f062.js.map → toaster-f89ddf4f.js.map} +0 -0
  1116. /package/dist/kolibri/{tooltip-align-36725992.js.map → tooltip-align-37f47613.js.map} +0 -0
  1117. /package/dist/kolibri/{unique-nav-labels-c6750f60.js → unique-nav-labels-62d9802d.js} +0 -0
  1118. /package/dist/kolibri/{unique-nav-labels-c6750f60.js.map → unique-nav-labels-62d9802d.js.map} +0 -0
  1119. /package/dist/kolibri/{validation-7b943391.js.map → validation-10927214.js.map} +0 -0
  1120. /package/dist/kolibri/{validation-5f69c40a.js.map → validation-d70ea075.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"names":["defaultStyleCss","PAGINATION_OPTIONS","CELL_REFS","Map","KolTable","this","horizontal","sortDirections","sortData","showPagination","pageStartSlice","pageEndSlice","disableSort","sortedColumnHead","label","key","sortDirection","ariaLive","setSortDirection","sort","direction","clear","set","sortFunction","handlePagination","onClick","event","page","_a","state","_pagination","_on","setState","Object","assign","_page","onChangePage","onChangePageSize","pageSize","_pageSize","beforePatchPagination","nextValue","_nextState","_component","updateSortedData","cell","_data","sortedData","length","a","b","index","data","result","compareFn","translate","placeholders","column","multi","sortText","get","reverse","renderTableRow","row","rowIndex","h","map","col","colIndex","renderTableCell","asTd","headerCell","undefined","shortSortDirection","sortButtonIcon","find","value","scope","rowSpan","colSpan","style","textAlign","width","class","exportparts","_icons","_hideLabel","_label","colLabel","changeCellSort","_variant","ref","render","el","cellRender","renderFoot","rows","createDataField","_dataFoot","_headers","_allowMultiSort","vertical","_max","_sortedData","validateAllowMultiSort","watchValidator","Set","defaultValue","validateData","emptyStringByArrayHandler","objectObjectHandler","parseJson","e","Array","isArray","dataTupel","afterPatch","setTimeout","validateDataFoot","findIndex","settings","splice","push","validateHeaders","hooks","beforePatch","applySort","headers","hasSortedCells","forEach","_b","_c","_d","devHint","validateLabel","validateMinWidth","watchString","validatePagination","componentWillLoad","_minWidth","getNumberOfCols","horizontalHeaders","max","count","getNumberOfRows","verticalHeaders","filterHeaderKeys","primaryHeader","cells","getPrimaryHeader","isFoot","maxCols","maxRows","startRow","dataField","rowCount","rowSpans","_row","i","dataRow","headerCells","rowsTotal","k","j","colspan","rowspan","emptyCell","Math","selectDisplayedData","slice","clearTimeout","html","textContent","displayedData","Host","height","overflow","_boundaryCount","_customClass","_pageSizeOptions","_siblingCount","_tooltipAlign","tabindex","minWidth","cols"],"sources":["src/components/table/style.css?tag=kol-table&mode=default&encapsulation=shadow","src/components/table/component.tsx"],"sourcesContent":["@import url(../style.css);\n@import url(../host-display-block.css);\n@layer kol-component {\n\t:host {\n\t\tdisplay: grid;\n\t}\n\n\t:host > div.table {\n\t\tmax-width: 100%;\n\t\torder: 1;\n\t\toverflow-x: auto;\n\t\toverflow-y: hidden;\n\t}\n\n\t:host > div.table table {\n\t\twidth: 100%;\n\t}\n\n\tth > div {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: 1fr auto;\n\t\tplace-items: center;\n\t}\n\n\tdiv.pagination {\n\t\torder: 2;\n\t}\n\n\tdiv.pagination,\n\tdiv.pagination > div:last-child {\n\t\tdisplay: grid;\n\t\tplace-items: center;\n\t}\n\n\t@media (min-width: 1024px) {\n\t\tdiv.pagination,\n\t\tdiv.pagination > div:last-child {\n\t\t\tgrid-auto-flow: column;\n\t\t}\n\n\t\tdiv.pagination kol-pagination {\n\t\t\tdisplay: flex;\n\t\t}\n\t}\n}\n","/* eslint-disable jsx-a11y/no-noninteractive-tabindex */\nimport { Generic } from '@a11y-ui/core';\nimport { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\nimport { Stringified } from '../../types/common';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { devHint } from '../../utils/a11y.tipps';\nimport { emptyStringByArrayHandler, objectObjectHandler, parseJson, setState, watchString, watchValidator } from '../../utils/prop.validators';\nimport { KoliBriPaginationButtonCallbacks } from '../pagination/types';\nimport {\n\tAPI,\n\tKoliBriDataCompareFn,\n\tKoliBriSortDirection,\n\tKoliBriSortFunction,\n\tKoliBriTableCell,\n\tKoliBriTableDataType,\n\tKoliBriTableHeaderCell,\n\tKoliBriTableHeaderCellAndData,\n\tKoliBriTableHeaders,\n\tKoliBriTablePaginationProps,\n\tKoliBriTableRender,\n\tKoliBriTableSelectedHead,\n\tStates,\n} from './types';\n\nconst PAGINATION_OPTIONS = [10, 20, 50, 100];\n\nconst CELL_REFS = new Map<HTMLElement, ReturnType<typeof setTimeout>>();\n\ntype SortData = {\n\tlabel: string;\n\tkey: string;\n\tcompareFn: KoliBriDataCompareFn;\n\tdirection: KoliBriSortDirection;\n};\n\n@Component({\n\ttag: 'kol-table',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolTable implements API {\n\tprivate horizontal = true;\n\t/**\n\t * @deprecated only for backward compatibility\n\t */\n\tprivate sortFunction?: KoliBriSortFunction;\n\t/**\n\t * @deprecated only for backward compatibility\n\t */\n\tprivate sortDirections: Map<KoliBriSortFunction, KoliBriSortDirection> = new Map();\n\tprivate sortData: SortData[] = [];\n\tprivate showPagination = false;\n\tprivate pageStartSlice = 0;\n\tprivate pageEndSlice = 10;\n\tprivate disableSort = false;\n\n\t/**\n\t * @deprecated only for backward compatibility\n\t */\n\tprivate sortedColumnHead: KoliBriTableSelectedHead = { label: '', key: '', sortDirection: 'NOS' };\n\tprivate ariaLive = '';\n\n\t/**\n\t * Defines whether to allow multi sort.\n\t */\n\t@Prop() public _allowMultiSort?: boolean;\n\n\t/**\n\t * Defines the primary table data.\n\t */\n\t@Prop() public _data!: Stringified<KoliBriTableDataType[]>;\n\n\t/**\n\t * Defines the data for the table footer.\n\t */\n\t@Prop() public _dataFoot?: Stringified<KoliBriTableDataType[]>;\n\n\t/**\n\t * Defines the horizontal and vertical table headers.\n\t */\n\t@Prop() public _headers!: Stringified<KoliBriTableHeaders>;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: string;\n\n\t/**\n\t * Defines the table min-width.\n\t */\n\t@Prop() public _minWidth?: string;\n\n\t/**\n\t * Defines whether to show the data distributed over multiple pages.\n\t */\n\t@Prop() public _pagination?: boolean | Stringified<KoliBriTablePaginationProps>;\n\n\t@State() public state: States = {\n\t\t_allowMultiSort: false,\n\t\t_label: '…', // ⚠ required\n\t\t_data: [],\n\t\t_dataFoot: [],\n\t\t_headers: {\n\t\t\thorizontal: [],\n\t\t\tvertical: [],\n\t\t},\n\t\t_pagination: {\n\t\t\t_page: 1,\n\t\t\t_pageSize: 10,\n\t\t\t_max: 0,\n\t\t},\n\t\t_sortedData: [],\n\t};\n\n\t@Watch('_allowMultiSort')\n\tpublic validateAllowMultiSort(value?: boolean): void {\n\t\twatchValidator(this, '_allowMultiSort', () => true, new Set(['boolean']), value, {\n\t\t\tdefaultValue: false,\n\t\t});\n\t}\n\n\t@Watch('_data')\n\tpublic validateData(value?: Stringified<KoliBriTableDataType[]>): void {\n\t\temptyStringByArrayHandler(value, () => {\n\t\t\tobjectObjectHandler(value, () => {\n\t\t\t\tif (typeof value === 'undefined') {\n\t\t\t\t\tvalue = [];\n\t\t\t\t}\n\t\t\t\ttry {\n\t\t\t\t\tvalue = parseJson<KoliBriTableDataType[]>(value);\n\t\t\t\t\t// eslint-disable-next-line no-empty\n\t\t\t\t} catch (e) {\n\t\t\t\t\t// value behält den ursprünglichen Wert\n\t\t\t\t}\n\t\t\t\tif (Array.isArray(value) && value.find((dataTupel: KoliBriTableDataType) => !(typeof dataTupel === 'object' && dataTupel !== null)) === undefined) {\n\t\t\t\t\tsetState(this, '_data', value, {\n\t\t\t\t\t\tafterPatch: () => {\n\t\t\t\t\t\t\t// TODO: kein guter Hack (endless loop)\n\t\t\t\t\t\t\tsetTimeout(this.updateSortedData);\n\t\t\t\t\t\t},\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\t@Watch('_dataFoot')\n\tpublic validateDataFoot(value?: Stringified<KoliBriTableDataType[]>): void {\n\t\temptyStringByArrayHandler(value, () => {\n\t\t\tobjectObjectHandler(value, () => {\n\t\t\t\tif (typeof value === 'undefined') {\n\t\t\t\t\tvalue = [];\n\t\t\t\t}\n\t\t\t\ttry {\n\t\t\t\t\tvalue = parseJson<KoliBriTableDataType[]>(value);\n\t\t\t\t\t// eslint-disable-next-line no-empty\n\t\t\t\t} catch (e) {\n\t\t\t\t\t// value behält den ursprünglichen Wert\n\t\t\t\t}\n\t\t\t\tif (Array.isArray(value) && value.find((dataTupel: KoliBriTableDataType) => !(typeof dataTupel === 'object' && dataTupel !== null)) === undefined) {\n\t\t\t\t\tsetState(this, '_dataFoot', value, {\n\t\t\t\t\t\tafterPatch: () => {\n\t\t\t\t\t\t\tsetTimeout(this.updateSortedData);\n\t\t\t\t\t\t},\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 * @deprecated only for backward compatibility\n\t */\n\tprivate setSortDirection = (sort: KoliBriSortFunction, direction: KoliBriSortDirection) => {\n\t\t/**\n\t\t * Durch des Clearen, ist es nicht möglich eine Mehr-Spalten-Sortierung\n\t\t * darzustellen. Das wäre der Fall, wenn man ggf. Daten in außerhalb der\n\t\t * Komponente sortiert und diese sortiert von außen rein gibt und der\n\t\t * Sortierungsalgorithmus mehrere Spalten zusammen sortierte.\n\t\t *\n\t\t * Beachte auch col.sort !== this.sortFunction\n\t\t */\n\t\tthis.sortDirections.clear();\n\t\tthis.sortDirections.set(sort, direction);\n\t\tthis.sortFunction = sort;\n\t};\n\n\tprivate changeCellSort(headerCell: KoliBriTableHeaderCell) {\n\t\tif (typeof headerCell.compareFn === 'function') {\n\t\t\tif (!this.state._allowMultiSort && headerCell.key != this.sortData[0]?.key) {\n\t\t\t\t// clear when another column is sorted and multi sort is not allowed\n\t\t\t\tthis.sortData = [];\n\t\t\t}\n\n\t\t\tconst index = this.sortData.findIndex((value) => value.key === headerCell.key);\n\t\t\tif (index >= 0) {\n\t\t\t\tconst settings = this.sortData[index];\n\t\t\t\tswitch (settings.direction) {\n\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\tsettings.direction = 'DESC';\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\tthis.sortData.splice(index, 1);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tsettings.direction = 'ASC';\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t} else if (headerCell.key) {\n\t\t\t\tthis.sortData.push({\n\t\t\t\t\tlabel: headerCell.label,\n\t\t\t\t\tkey: headerCell.key,\n\t\t\t\t\tcompareFn: headerCell.compareFn,\n\t\t\t\t\tdirection: 'ASC',\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tthis.updateSortedData(headerCell as KoliBriTableSelectedHead);\n\t\t} else if (typeof headerCell.sort === 'function') {\n\t\t\tthis.sortFunction = headerCell.sort;\n\t\t\tswitch (this.sortDirections.get(this.sortFunction)) {\n\t\t\t\tcase 'ASC':\n\t\t\t\t\tthis.setSortDirection(this.sortFunction, 'DESC');\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'DESC':\n\t\t\t\t\tthis.setSortDirection(this.sortFunction, 'NOS');\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\tthis.setSortDirection(this.sortFunction, 'ASC');\n\t\t\t}\n\t\t\tthis.updateSortedData(headerCell as KoliBriTableSelectedHead);\n\t\t}\n\t}\n\n\t@Watch('_headers')\n\tpublic validateHeaders(value?: Stringified<KoliBriTableHeaders>): void {\n\t\t/**\n\t\t * - es darf maximal ein Header als primary markiert werden (last win)\n\t\t * - der primary-Header entscheidet implizit über _order und _orientation\n\t\t * - primary-Headers müssen das key-Property setzen\n\t\t * - nicht primary-Headers müssen das key-Property nicht setzen (wird ignoriert)\n\t\t * - _order: wird durch den primary-Header geregelt\n\t\t * - _orientation: wird durch den primary-Header geregelt\n\t\t * - sobald ein Header sortierbar ist, darf es nur noch entweder horizontale\n\t\t * oder vertikale Header geben, aber nicht mehr beides\n\t\t */\n\t\temptyStringByArrayHandler(value, () => {\n\t\t\tobjectObjectHandler(value, () => {\n\t\t\t\ttry {\n\t\t\t\t\tvalue = parseJson<KoliBriTableHeaders>(value);\n\t\t\t\t\t// eslint-disable-next-line no-empty\n\t\t\t\t} catch (e) {\n\t\t\t\t\t// value behält den ursprünglichen Wert\n\t\t\t\t}\n\t\t\t\twatchValidator(this, '_headers', (value): boolean => typeof value === 'object' && value !== null, new Set(['KoliBriTableHeaders']), value, {\n\t\t\t\t\thooks: {\n\t\t\t\t\t\tbeforePatch: (nextValue: unknown) => {\n\t\t\t\t\t\t\tconst applySort = (headers: KoliBriTableHeaderCell[]) => {\n\t\t\t\t\t\t\t\tlet hasSortedCells = false;\n\t\t\t\t\t\t\t\theaders.forEach((cell) => {\n\t\t\t\t\t\t\t\t\tconst key = cell.key;\n\t\t\t\t\t\t\t\t\tif (!key) {\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tconst sortDirection = cell.sortDirection;\n\t\t\t\t\t\t\t\t\tif (sortDirection === 'ASC' || sortDirection === 'DESC') {\n\t\t\t\t\t\t\t\t\t\tif (typeof cell.compareFn === 'function') {\n\t\t\t\t\t\t\t\t\t\t\tif (this.state._allowMultiSort || this.sortData.length === 0) {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.sortData.push({ label: cell.label, key, compareFn: cell.compareFn, direction: sortDirection });\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\thasSortedCells = true;\n\t\t\t\t\t\t\t\t\t\t} else if (typeof cell.sort === 'function') {\n\t\t\t\t\t\t\t\t\t\t\tthis.setSortDirection(cell.sort, sortDirection);\n\t\t\t\t\t\t\t\t\t\t\tsetTimeout(() => this.updateSortedData({ key, label: cell.label, sortDirection }));\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\tif (hasSortedCells) {\n\t\t\t\t\t\t\t\t\tsetTimeout(() => this.updateSortedData());\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\tconst headers: KoliBriTableHeaders = nextValue as KoliBriTableHeaders;\n\t\t\t\t\t\t\theaders.horizontal?.forEach(applySort);\n\t\t\t\t\t\t\theaders.vertical?.forEach(applySort);\n\n\t\t\t\t\t\t\tif (headers.horizontal && headers.vertical && headers.horizontal?.length > 0 && headers.vertical?.length > 0) {\n\t\t\t\t\t\t\t\tthis.disableSort = true;\n\t\t\t\t\t\t\t\tdevHint(\n\t\t\t\t\t\t\t\t\t`Table: You can not sort the table data, if horizontal and vertical headers are defined at the same time. (https://github.com/public-ui/kolibri/issues/2372)`\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},\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value);\n\t}\n\n\t@Watch('_minWidth')\n\tpublic validateMinWidth(value?: string): void {\n\t\twatchString(this, '_minWidth', value, {\n\t\t\tdefaultValue: undefined,\n\t\t});\n\t}\n\n\tprivate readonly handlePagination: KoliBriPaginationButtonCallbacks = {\n\t\tonClick: (event: Event, page: number) => {\n\t\t\tif (typeof this.state._pagination._on?.onClick === 'function') {\n\t\t\t\tthis.state._pagination._on.onClick(event, page);\n\t\t\t}\n\t\t\tsetState(this, '_pagination', {\n\t\t\t\t...this.state._pagination,\n\t\t\t\t_page: page,\n\t\t\t});\n\t\t},\n\t\tonChangePage: (event: Event, page: number) => {\n\t\t\tif (typeof this.state._pagination._on?.onChangePage === 'function') {\n\t\t\t\tthis.state._pagination._on.onChangePage(event, page);\n\t\t\t}\n\t\t\tsetState(this, '_pagination', {\n\t\t\t\t...this.state._pagination,\n\t\t\t\t_page: page,\n\t\t\t});\n\t\t},\n\t\tonChangePageSize: (event: Event, pageSize: number) => {\n\t\t\tif (typeof this.state._pagination._on?.onChangePageSize === 'function') {\n\t\t\t\tthis.state._pagination._on.onChangePageSize(event, pageSize);\n\t\t\t}\n\t\t\tsetState(this, '_pagination', {\n\t\t\t\t...this.state._pagination,\n\t\t\t\t_pageSize: pageSize,\n\t\t\t});\n\t\t\tsetState(this, '_pageSize', pageSize);\n\t\t},\n\t};\n\n\tprivate readonly beforePatchPagination: Generic.Element.NextStateHooksCallback = (nextValue, _nextState, _component, key): void => {\n\t\tif (key === '_pagination') {\n\t\t\tthis.showPagination = nextValue === true || nextValue === '' /* true */ || (typeof nextValue === 'object' && nextValue !== null);\n\t\t}\n\t};\n\n\t@Watch('_pagination')\n\tpublic validatePagination(value?: boolean | Stringified<KoliBriTablePaginationProps>): void {\n\t\ttry {\n\t\t\tvalue = parseJson<KoliBriTablePaginationProps>(value);\n\t\t\t// eslint-disable-next-line no-empty\n\t\t} catch (e) {\n\t\t\t// value behält den ursprünglichen Wert\n\t\t}\n\t\twatchValidator(this, '_pagination', () => true, new Set(['boolean', 'KoliBriTablePagination']), value, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: this.beforePatchPagination,\n\t\t\t},\n\t\t});\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAllowMultiSort(this._allowMultiSort);\n\t\tthis.validateData(this._data);\n\t\tthis.validateDataFoot(this._dataFoot);\n\t\tthis.validateHeaders(this._headers);\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateMinWidth(this._minWidth);\n\t\tthis.validatePagination(this._pagination);\n\t}\n\n\tprivate getNumberOfCols(horizontalHeaders: KoliBriTableHeaderCell[][], data: KoliBriTableDataType[]): number {\n\t\tlet max = 0;\n\t\thorizontalHeaders.forEach((row) => {\n\t\t\tlet count = 0;\n\t\t\trow.forEach((col) => (count += col.colSpan ?? 1));\n\t\t\tif (max < count) {\n\t\t\t\tmax = count;\n\t\t\t}\n\t\t});\n\t\tif (max === 0) {\n\t\t\tmax = data.length;\n\t\t}\n\t\treturn max;\n\t}\n\n\tprivate getNumberOfRows(verticalHeaders: KoliBriTableHeaderCell[][], data: KoliBriTableDataType[]): number {\n\t\tlet max = 0;\n\t\tverticalHeaders.forEach((col) => {\n\t\t\tlet count = 0;\n\t\t\tcol.forEach((row) => (count += row.rowSpan ?? 1));\n\t\t\tif (max < count) {\n\t\t\t\tmax = count;\n\t\t\t}\n\t\t});\n\t\tif (max === 0) {\n\t\t\tmax = data.length;\n\t\t} else {\n\t\t\tmax -= this.state._dataFoot.length;\n\t\t}\n\t\treturn max;\n\t}\n\n\tprivate filterHeaderKeys(headers: KoliBriTableHeaderCell[][]): KoliBriTableHeaderCell[] {\n\t\tconst primaryHeader: KoliBriTableHeaderCell[] = [];\n\t\theaders.forEach((cells) => {\n\t\t\tcells.forEach((cell) => {\n\t\t\t\tif (typeof cell.key === 'string') {\n\t\t\t\t\tprimaryHeader.push(cell);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t\treturn primaryHeader;\n\t}\n\n\tprivate getPrimaryHeader(headers: KoliBriTableHeaders): KoliBriTableHeaderCell[] {\n\t\tlet primaryHeader: KoliBriTableHeaderCell[] = this.filterHeaderKeys(headers.horizontal ?? []);\n\t\tthis.horizontal = true;\n\t\tif (primaryHeader.length === 0) {\n\t\t\tprimaryHeader = this.filterHeaderKeys(headers.vertical ?? []);\n\t\t\tif (primaryHeader.length > 0) {\n\t\t\t\tthis.horizontal = false;\n\t\t\t}\n\t\t}\n\t\treturn primaryHeader;\n\t}\n\n\tprivate createDataField(data: KoliBriTableDataType[], headers: KoliBriTableHeaders, isFoot?: boolean): KoliBriTableCell[][] {\n\t\theaders.horizontal = Array.isArray(headers?.horizontal) ? headers.horizontal : [];\n\t\theaders.vertical = Array.isArray(headers?.vertical) ? headers.vertical : [];\n\t\tconst primaryHeader = this.getPrimaryHeader(headers);\n\t\tconst maxCols = this.getNumberOfCols(headers.horizontal, data);\n\t\tlet maxRows = this.getNumberOfRows(headers.vertical, data);\n\t\tlet startRow = 0;\n\t\tif (isFoot) {\n\t\t\tstartRow = maxRows;\n\t\t\tmaxRows += this.state._dataFoot.length;\n\t\t}\n\t\tconst dataField: KoliBriTableCell[][] = [];\n\n\t\tconst rowCount: number[] = [];\n\t\tconst rowSpans: number[][] = [];\n\t\theaders.vertical.forEach((_row, index) => {\n\t\t\trowCount[index] = 0;\n\t\t\trowSpans[index] = [];\n\t\t});\n\n\t\tfor (let i = startRow; i < maxRows; i++) {\n\t\t\tconst dataRow: KoliBriTableHeaderCellAndData[] = [];\n\t\t\theaders.vertical.forEach((headerCells, index) => {\n\t\t\t\tlet rowsTotal = 0;\n\t\t\t\trowSpans[index].forEach((value) => (rowsTotal += value));\n\t\t\t\tif (rowsTotal <= i) {\n\t\t\t\t\tconst rows = headerCells[i - rowsTotal + rowCount[index]];\n\t\t\t\t\tif (typeof rows === 'object') {\n\t\t\t\t\t\tdataRow.push({\n\t\t\t\t\t\t\t...rows,\n\t\t\t\t\t\t\tasTd: false,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\t\t\t\tdata: {} as KoliBriTableDataType,\n\t\t\t\t\t\t});\n\t\t\t\t\t\tlet rowSpan = 1;\n\t\t\t\t\t\tif (typeof rows.rowSpan === 'number' && rows.rowSpan > 1) {\n\t\t\t\t\t\t\trowSpan = rows.rowSpan;\n\t\t\t\t\t\t}\n\t\t\t\t\t\trowSpans[index].push(rowSpan);\n\t\t\t\t\t\tif (typeof rows.colSpan === 'number' && rows.colSpan > 1) {\n\t\t\t\t\t\t\tfor (let k = 1; k < rows.colSpan; k++) {\n\t\t\t\t\t\t\t\trowSpans[index + k].push(rowSpan);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\trowCount[index]++;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t\tfor (let j = 0; j < maxCols; j++) {\n\t\t\t\tif (this.horizontal === true) {\n\t\t\t\t\tconst row = isFoot ? this.state._dataFoot[i - startRow] : data[i];\n\t\t\t\t\tif (\n\t\t\t\t\t\ttypeof primaryHeader[j] === 'object' &&\n\t\t\t\t\t\tprimaryHeader[j] !== null &&\n\t\t\t\t\t\ttypeof primaryHeader[j].key === 'string' &&\n\t\t\t\t\t\ttypeof row === 'object' &&\n\t\t\t\t\t\trow !== null\n\t\t\t\t\t) {\n\t\t\t\t\t\tdataRow.push({\n\t\t\t\t\t\t\t...primaryHeader[j],\n\t\t\t\t\t\t\tcolSpan: undefined,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\t\t\t\tdata: row,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n\t\t\t\t\t\t\tlabel: row[primaryHeader[j].key as unknown as string] as string,\n\t\t\t\t\t\t\trowSpan: undefined,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tif (\n\t\t\t\t\t\ttypeof primaryHeader[i] === 'object' &&\n\t\t\t\t\t\tprimaryHeader[i] !== null &&\n\t\t\t\t\t\ttypeof primaryHeader[i].key === 'string' &&\n\t\t\t\t\t\ttypeof data[j] === 'object' &&\n\t\t\t\t\t\tdata[j] !== null\n\t\t\t\t\t) {\n\t\t\t\t\t\tdataRow.push({\n\t\t\t\t\t\t\t...primaryHeader[i],\n\t\t\t\t\t\t\tcolSpan: undefined,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\t\t\t\tdata: data[j],\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n\t\t\t\t\t\t\tlabel: data[j][primaryHeader[i].key as unknown as number] as string,\n\t\t\t\t\t\t\trowSpan: undefined,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tdataField.push(dataRow);\n\t\t}\n\t\tif (data.length === 0) {\n\t\t\tlet colspan = 0;\n\t\t\tlet rowspan = 0;\n\t\t\tif (Array.isArray(headers.horizontal) && headers.horizontal.length > 0) {\n\t\t\t\theaders.horizontal[0].forEach((col) => {\n\t\t\t\t\tcolspan += col.colSpan || 1;\n\t\t\t\t});\n\t\t\t}\n\t\t\tif (Array.isArray(headers.vertical) && headers.vertical.length > 0) {\n\t\t\t\tcolspan -= headers.vertical.length;\n\t\t\t\theaders.vertical[0].forEach((row) => {\n\t\t\t\t\trowspan += row.rowSpan || 1;\n\t\t\t\t});\n\t\t\t}\n\t\t\tconst emptyCell = {\n\t\t\t\tcolSpan: colspan,\n\t\t\t\tlabel: translate('kol-no-entries'),\n\t\t\t\trender: undefined,\n\t\t\t\trowSpan: Math.max(rowspan, 1),\n\t\t\t};\n\t\t\tif (dataField.length === 0) {\n\t\t\t\tdataField.push([emptyCell]);\n\t\t\t} else {\n\t\t\t\tdataField[0].push(emptyCell);\n\t\t\t}\n\t\t}\n\t\treturn dataField;\n\t}\n\n\tprivate selectDisplayedData(data: KoliBriTableDataType[], pageSize: number, page: number): KoliBriTableDataType[] {\n\t\tif (typeof pageSize === 'number' && pageSize > 0 && typeof page === 'number' && page > 0) {\n\t\t\tthis.pageStartSlice = pageSize * (page - 1);\n\t\t\tthis.pageEndSlice = pageSize * page > data.length ? data.length : pageSize * page;\n\t\t\treturn data.slice(this.pageStartSlice, this.pageEndSlice);\n\t\t} else {\n\t\t\tthis.pageStartSlice = 0;\n\t\t\tthis.pageEndSlice = data.length;\n\t\t\treturn data;\n\t\t}\n\t}\n\n\tprivate cellRender(col: KoliBriTableHeaderCellAndData & { render: KoliBriTableRender }, el?: HTMLElement): void {\n\t\tif (el /* SSR instanceof HTMLElement */) {\n\t\t\tclearTimeout(CELL_REFS.get(el));\n\t\t\tCELL_REFS.set(\n\t\t\t\tel,\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tclearTimeout(CELL_REFS.get(el));\n\t\t\t\t\tconst html = col.render(\n\t\t\t\t\t\tel,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tasTd: col.asTd,\n\t\t\t\t\t\t\tlabel: col.label,\n\t\t\t\t\t\t\ttextAlign: col.textAlign,\n\t\t\t\t\t\t\twidth: col.width,\n\t\t\t\t\t\t} as KoliBriTableHeaderCell,\n\t\t\t\t\t\tcol.data,\n\t\t\t\t\t\tthis.state._data\n\t\t\t\t\t);\n\t\t\t\t\tif (typeof html === 'string') {\n\t\t\t\t\t\tel.textContent = html;\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 *\n\t * @param cell only used for old single sort. Can be removed when sort is removed.\n\t */\n\tprivate updateSortedData = (cell: KoliBriTableSelectedHead = this.sortedColumnHead) => {\n\t\tif (this.disableSort) {\n\t\t\tsetState(this, '_sortedData', this.state._data);\n\t\t\treturn;\n\t\t}\n\n\t\tlet sortedData: KoliBriTableDataType[] = this.state._data;\n\t\tif (this.sortData.length > 0) {\n\t\t\tsortedData = this.state._data.sort((a: KoliBriTableDataType, b: KoliBriTableDataType) => {\n\t\t\t\tfor (let index = 0; index < this.sortData.length; index++) {\n\t\t\t\t\tconst data = this.sortData[index];\n\t\t\t\t\tconst result = data.compareFn(a, b);\n\t\t\t\t\tif (result !== 0) {\n\t\t\t\t\t\treturn data.direction === 'ASC' ? result : -result;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn 0;\n\t\t\t});\n\n\t\t\tif (this.sortData.length === 1) {\n\t\t\t\tthis.ariaLive = translate(`kol-sort-${this.sortData[0].direction === 'ASC' ? 'ascending' : 'descending'}`, {\n\t\t\t\t\tplaceholders: { column: this.sortData[0].label, multi: '' },\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tlet sortText = '';\n\t\t\t\tfor (let index = 1; index < this.sortData.length - 1; index++) {\n\t\t\t\t\tconst data = this.sortData[index];\n\t\t\t\t\tsortText += translate(`kol-sort-then-${data.direction === 'ASC' ? 'ascending' : 'descending'}`, { placeholders: { column: data.label } });\n\t\t\t\t}\n\t\t\t\tsortText += translate(`kol-sort-then-last-${this.sortData[this.sortData.length - 1].direction === 'ASC' ? 'ascending' : 'descending'}`, {\n\t\t\t\t\tplaceholders: { column: this.sortData[this.sortData.length - 1].label },\n\t\t\t\t});\n\t\t\t\tthis.ariaLive = translate(`kol-sort-${this.sortData[0].direction === 'ASC' ? 'ascending' : 'descending'}`, {\n\t\t\t\t\tplaceholders: { column: this.sortData[0].label, multi: sortText },\n\t\t\t\t});\n\t\t\t}\n\t\t} else if (typeof this.sortFunction === 'function') {\n\t\t\tswitch (this.sortDirections.get(this.sortFunction)) {\n\t\t\t\tcase 'ASC':\n\t\t\t\t\tsortedData = this.sortFunction([...this.state._data]);\n\t\t\t\t\tthis.ariaLive = translate('kol-sort-ascending', { placeholders: { column: cell.label } });\n\t\t\t\t\tthis.sortedColumnHead = { label: cell.label, key: cell.key, sortDirection: 'ASC' };\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'DESC':\n\t\t\t\t\tsortedData = this.sortFunction([...this.state._data]).reverse();\n\t\t\t\t\tthis.ariaLive = translate('kol-sort-descending', { placeholders: { column: cell.label } });\n\t\t\t\t\tthis.sortedColumnHead = { label: cell.label, key: cell.key, sortDirection: 'DESC' };\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'NOS':\n\t\t\t\tdefault:\n\t\t\t\t\tsortedData = [...this.state._data];\n\t\t\t\t\tthis.sortedColumnHead = { label: '', key: '', sortDirection: 'NOS' };\n\t\t\t\t\tthis.ariaLive = translate('kol-sort-none', { placeholders: { column: cell.label } });\n\t\t\t}\n\t\t} else {\n\t\t\tthis.ariaLive = translate('kol-table-sort-none');\n\t\t}\n\t\tsetState(this, '_sortedData', sortedData);\n\t};\n\n\tprivate readonly renderTableRow = (row: KoliBriTableCell[], rowIndex: number): JSX.Element => {\n\t\treturn <tr key={`tbody-${rowIndex}`}>{row.map((col, colIndex) => this.renderTableCell(col, rowIndex, colIndex))}</tr>;\n\t};\n\tprivate readonly renderTableCell = (cell: KoliBriTableCell, rowIndex: number, colIndex: number): JSX.Element => {\n\t\tif (cell.asTd === false) {\n\t\t\tconst headerCell: KoliBriTableHeaderCell = cell;\n\t\t\tlet sortDirection = undefined;\n\t\t\tlet shortSortDirection: KoliBriSortDirection = 'NOS';\n\t\t\tlet sortButtonIcon = 'codicon codicon-fold';\n\t\t\tif (!this.disableSort) {\n\t\t\t\tif (headerCell.key) {\n\t\t\t\t\tconst data = this.sortData.find((value) => value.key === headerCell.key);\n\t\t\t\t\tif (data) {\n\t\t\t\t\t\tshortSortDirection = data.direction;\n\t\t\t\t\t\tswitch (data.direction) {\n\t\t\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-up';\n\t\t\t\t\t\t\t\tsortDirection = 'ascending';\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-down';\n\t\t\t\t\t\t\t\tsortDirection = 'descending';\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (headerCell.key === this.sortedColumnHead.key) {\n\t\t\t\t\tshortSortDirection = this.sortedColumnHead.sortDirection;\n\t\t\t\t\tswitch (this.sortedColumnHead.sortDirection) {\n\t\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-up';\n\t\t\t\t\t\t\tsortDirection = 'ascending';\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-down';\n\t\t\t\t\t\t\tsortDirection = 'descending';\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn (\n\t\t\t\t<th // role=\"rowheader\"\n\t\t\t\t\tkey={`tbody-${rowIndex}-${colIndex}-${headerCell.label}`}\n\t\t\t\t\tscope={typeof headerCell.rowSpan === 'number' && headerCell.rowSpan > 1 ? 'rowgroup' : 'row'}\n\t\t\t\t\tcolSpan={headerCell.colSpan}\n\t\t\t\t\trowSpan={headerCell.rowSpan}\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\ttextAlign: headerCell.textAlign,\n\t\t\t\t\t\twidth: headerCell.width,\n\t\t\t\t\t}}\n\t\t\t\t\taria-sort={sortDirection}\n\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n\t\t\t\t\tdata-sort={`sort-${shortSortDirection}`}\n\t\t\t\t>\n\t\t\t\t\t<div class=\"w-full flex gap-1 items-center\">\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t'w-full': true,\n\t\t\t\t\t\t\t\t[headerCell.textAlign as string]: typeof headerCell.textAlign === 'string' && headerCell.textAlign.length > 0,\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\tstyle={{ textAlign: headerCell.textAlign }}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{headerCell.label}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t\t{!this.disableSort && (typeof headerCell.compareFn === 'function' || typeof headerCell.sort === 'function') && (\n\t\t\t\t\t\t\t<kol-button\n\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t_icons={sortButtonIcon}\n\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t_label={translate('kol-change-order', { placeholders: { colLabel: headerCell.label } })}\n\t\t\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\t\t\tonClick: () => this.changeCellSort(headerCell),\n\t\t\t\t\t\t\t\t}}\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)}\n\t\t\t\t\t</div>\n\t\t\t\t</th>\n\t\t\t);\n\t\t} else {\n\t\t\treturn (\n\t\t\t\t<td // role=\"gridcell\"\n\t\t\t\t\tkey={`tbody-${rowIndex}-${colIndex}-${cell.label}`}\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[cell.textAlign as string]: typeof cell.textAlign === 'string' && cell.textAlign.length > 0,\n\t\t\t\t\t}}\n\t\t\t\t\tcolSpan={cell.colSpan}\n\t\t\t\t\trowSpan={cell.rowSpan}\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\ttextAlign: cell.textAlign,\n\t\t\t\t\t\twidth: cell.width,\n\t\t\t\t\t}}\n\t\t\t\t\tref={\n\t\t\t\t\t\ttypeof cell.render === 'function'\n\t\t\t\t\t\t\t? (el) => {\n\t\t\t\t\t\t\t\t\tthis.cellRender(cell as KoliBriTableHeaderCellAndData & { render: KoliBriTableRender }, el);\n\t\t\t\t\t\t\t }\n\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t}\n\t\t\t\t>\n\t\t\t\t\t{typeof cell.render !== 'function' ? cell.label : ''}\n\t\t\t\t</td>\n\t\t\t);\n\t\t}\n\t};\n\n\tprivate readonly renderFoot = (): JSX.Element => {\n\t\tconst rows: KoliBriTableCell[][] = this.createDataField(this.state._dataFoot, this.state._headers, true);\n\t\treturn <tfoot>{rows.map(this.renderTableRow)}</tfoot>;\n\t};\n\n\tpublic render(): JSX.Element {\n\t\tconst displayedData: KoliBriTableDataType[] = this.selectDisplayedData(\n\t\t\tthis.state._sortedData,\n\t\t\tthis.showPagination ? this.state._pagination?._pageSize ?? 10 : this.state._sortedData.length,\n\t\t\tthis.state._pagination._page || 1\n\t\t);\n\t\tconst dataField = this.createDataField(displayedData, this.state._headers);\n\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t<div style={{ height: '0', width: '0', overflow: 'hidden' }} aria-live=\"assertive\">\n\t\t\t\t\t{this.ariaLive}\n\t\t\t\t</div>\n\t\t\t\t{this.pageEndSlice > 0 && this.showPagination && (\n\t\t\t\t\t<div class=\"pagination\">\n\t\t\t\t\t\t<span>\n\t\t\t\t\t\t\tEinträge {this.pageEndSlice > 0 ? this.pageStartSlice + 1 : 0} bis {this.pageEndSlice} von{' '}\n\t\t\t\t\t\t\t{this.state._pagination._max || (Array.isArray(this.state._data) ? this.state._data.length : 0)} angezeigt\n\t\t\t\t\t\t</span>\n\t\t\t\t\t\t<div>\n\t\t\t\t\t\t\t<kol-pagination\n\t\t\t\t\t\t\t\t_boundaryCount={this.state._pagination._boundaryCount}\n\t\t\t\t\t\t\t\t_customClass={this.state._pagination._customClass}\n\t\t\t\t\t\t\t\t_on={this.handlePagination}\n\t\t\t\t\t\t\t\t_page={this.state._pagination._page}\n\t\t\t\t\t\t\t\t_pageSize={this.state._pagination._pageSize}\n\t\t\t\t\t\t\t\t_pageSizeOptions={this.state._pagination._pageSizeOptions || PAGINATION_OPTIONS}\n\t\t\t\t\t\t\t\t_siblingCount={this.state._pagination._siblingCount}\n\t\t\t\t\t\t\t\t_tooltipAlign=\"bottom\"\n\t\t\t\t\t\t\t\t_max={this.state._pagination._max || this.state._pagination._max || this.state._data.length}\n\t\t\t\t\t\t\t\t_label={translate('kol-table-pagination-label', { placeholders: { label: this.state._label } })}\n\t\t\t\t\t\t\t></kol-pagination>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t\t<div class=\"table\" tabindex=\"0\">\n\t\t\t\t\t<table\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tminWidth: this.state._minWidth,\n\t\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t\t<caption>{this.state._label}</caption>\n\t\t\t\t\t\t{Array.isArray(this.state._headers.horizontal) && (\n\t\t\t\t\t\t\t<thead>\n\t\t\t\t\t\t\t\t{this.state._headers.horizontal.map((cols, rowIndex) => (\n\t\t\t\t\t\t\t\t\t<tr key={`thead-${rowIndex}`}>\n\t\t\t\t\t\t\t\t\t\t{cols.map((col, colIndex) => {\n\t\t\t\t\t\t\t\t\t\t\tif (col.asTd === true) {\n\t\t\t\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t\t\t\t<td // role=\"gridcell\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tkey={`thead-${rowIndex}-${colIndex}-${col.label}`}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t[col.textAlign as string]: typeof col.textAlign === 'string' && col.textAlign.length > 0,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcolSpan={col.colSpan}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trowSpan={col.rowSpan}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign: col.textAlign,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\twidth: col.width,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tref={\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttypeof col.render === 'function'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? (el) => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tthis.cellRender(col as KoliBriTableHeaderCellAndData & { render: KoliBriTableRender }, el);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t }\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{typeof col.render !== 'function' ? col.label : ''}\n\t\t\t\t\t\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t\t\tconst headerCell: KoliBriTableHeaderCell = col;\n\t\t\t\t\t\t\t\t\t\t\t\tlet sortDirection = undefined;\n\t\t\t\t\t\t\t\t\t\t\t\tlet shortSortDirection: KoliBriSortDirection = 'NOS';\n\t\t\t\t\t\t\t\t\t\t\t\tlet sortButtonIcon = 'codicon codicon-fold';\n\t\t\t\t\t\t\t\t\t\t\t\tif (headerCell.key) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tconst data = this.sortData.find((value) => value.key === headerCell.key);\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (data) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tshortSortDirection = data.direction;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tswitch (data.direction) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-up';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortDirection = 'ascending';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-down';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortDirection = 'descending';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\tif (headerCell.key === this.sortedColumnHead.key) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tshortSortDirection = this.sortedColumnHead.sortDirection;\n\t\t\t\t\t\t\t\t\t\t\t\t\tswitch (this.sortedColumnHead.sortDirection) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-up';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortDirection = 'ascending';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-down';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortDirection = 'descending';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t\t\t\t<th // role=\"columnheader\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tkey={`thead-${rowIndex}-${colIndex}-${headerCell.label}`}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tscope={typeof headerCell.colSpan === 'number' && headerCell.colSpan > 1 ? 'colgroup' : 'col'}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcolSpan={headerCell.colSpan}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trowSpan={headerCell.rowSpan}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign: col.textAlign,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\twidth: col.width,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\taria-sort={sortDirection}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdata-sort={`sort-${shortSortDirection}`}\n\t\t\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<div class=\"w-full flex gap-1 items-center\">\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t'w-full': true,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t[col.textAlign as string]: typeof col.textAlign === 'string' && col.textAlign.length > 0,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign: col.textAlign,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t{col.label}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t{!this.disableSort && (typeof headerCell.compareFn === 'function' || typeof headerCell.sort === 'function') && (\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<kol-button\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t_icons={sortButtonIcon}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t_label={translate('kol-change-order', { placeholders: { colLabel: col.label } })}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tonClick: () => this.changeCellSort(headerCell),\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t_variant=\"ghost\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t></kol-button>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t\t\t\t\t</th>\n\t\t\t\t\t\t\t\t\t\t\t\t);\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</tr>\n\t\t\t\t\t\t\t\t))}\n\t\t\t\t\t\t\t</thead>\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t<tbody>{dataField.map(this.renderTableRow)}</tbody>\n\t\t\t\t\t\t{this.state._dataFoot.length > 0 ? this.renderFoot() : ''}\n\t\t\t\t\t</table>\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["defaultStyleCss","PAGINATION_OPTIONS","CELL_REFS","Map","KolTable","this","horizontal","sortDirections","sortData","showPagination","pageStartSlice","pageEndSlice","disableSort","sortedColumnHead","label","key","sortDirection","ariaLive","setSortDirection","sort","direction","clear","set","sortFunction","handlePagination","onClick","event","page","_a","state","_pagination","_on","setState","Object","assign","_page","onChangePage","onChangePageSize","pageSize","_pageSize","beforePatchPagination","nextValue","_nextState","_component","updateSortedData","cell","_data","sortedData","length","a","b","index","data","result","compareFn","translate","placeholders","column","multi","sortText","get","reverse","renderTableRow","row","rowIndex","h","map","col","colIndex","renderTableCell","asTd","headerCell","undefined","shortSortDirection","sortButtonIcon","find","value","scope","rowSpan","colSpan","style","textAlign","width","class","exportparts","_icons","_hideLabel","_label","colLabel","changeCellSort","_variant","ref","render","el","cellRender","renderFoot","rows","createDataField","_dataFoot","_headers","_allowMultiSort","vertical","_max","_sortedData","validateAllowMultiSort","watchValidator","Set","defaultValue","validateData","emptyStringByArrayHandler","objectObjectHandler","parseJson","e","Array","isArray","dataTupel","afterPatch","setTimeout","validateDataFoot","findIndex","settings","splice","push","validateHeaders","hooks","beforePatch","applySort","headers","hasSortedCells","forEach","_b","_c","_d","devHint","validateLabel","validateMinWidth","watchString","validatePagination","componentWillLoad","_minWidth","getNumberOfCols","horizontalHeaders","max","count","getNumberOfRows","verticalHeaders","filterHeaderKeys","primaryHeader","cells","getPrimaryHeader","isFoot","maxCols","maxRows","startRow","dataField","rowCount","rowSpans","_row","i","dataRow","headerCells","rowsTotal","k","j","colspan","rowspan","emptyCell","Math","selectDisplayedData","slice","clearTimeout","html","textContent","displayedData","Host","height","overflow","_boundaryCount","_customClass","_pageSizeOptions","_siblingCount","_tooltipAlign","tabindex","minWidth","cols"],"sources":["src/components/table/style.css?tag=kol-table&mode=default&encapsulation=shadow","src/components/table/component.tsx"],"sourcesContent":["@import url(../style.css);\n@import url(../host-display-block.css);\n@layer kol-component {\n\t:host {\n\t\tdisplay: grid;\n\t}\n\n\t:host > div.table {\n\t\tmax-width: 100%;\n\t\torder: 1;\n\t\toverflow-x: auto;\n\t\toverflow-y: hidden;\n\t}\n\n\t:host > div.table table {\n\t\twidth: 100%;\n\t}\n\n\tth > div {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: 1fr auto;\n\t\tplace-items: center;\n\t}\n\n\tdiv.pagination {\n\t\torder: 2;\n\t}\n\n\tdiv.pagination,\n\tdiv.pagination > div:last-child {\n\t\tdisplay: grid;\n\t\tplace-items: center;\n\t}\n\n\t@media (min-width: 1024px) {\n\t\tdiv.pagination,\n\t\tdiv.pagination > div:last-child {\n\t\t\tgrid-auto-flow: column;\n\t\t}\n\n\t\tdiv.pagination kol-pagination {\n\t\t\tdisplay: flex;\n\t\t}\n\t}\n}\n","/* eslint-disable jsx-a11y/no-noninteractive-tabindex */\nimport { Generic } from '@a11y-ui/core';\nimport { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\nimport { Stringified } from '../../types/common';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { devHint } from '../../utils/a11y.tipps';\nimport { emptyStringByArrayHandler, objectObjectHandler, parseJson, setState, watchString, watchValidator } from '../../utils/prop.validators';\nimport { KoliBriPaginationButtonCallbacks } from '../pagination/types';\nimport {\n\tAPI,\n\tKoliBriDataCompareFn,\n\tKoliBriSortDirection,\n\tKoliBriSortFunction,\n\tKoliBriTableCell,\n\tKoliBriTableDataType,\n\tKoliBriTableHeaderCell,\n\tKoliBriTableHeaderCellAndData,\n\tKoliBriTableHeaders,\n\tKoliBriTablePaginationProps,\n\tKoliBriTableRender,\n\tKoliBriTableSelectedHead,\n\tStates,\n} from './types';\n\nconst PAGINATION_OPTIONS = [10, 20, 50, 100];\n\nconst CELL_REFS = new Map<HTMLElement, ReturnType<typeof setTimeout>>();\n\ntype SortData = {\n\tlabel: string;\n\tkey: string;\n\tcompareFn: KoliBriDataCompareFn;\n\tdirection: KoliBriSortDirection;\n};\n\n@Component({\n\ttag: 'kol-table',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolTable implements API {\n\tprivate horizontal = true;\n\t/**\n\t * @deprecated only for backward compatibility\n\t */\n\tprivate sortFunction?: KoliBriSortFunction;\n\t/**\n\t * @deprecated only for backward compatibility\n\t */\n\tprivate sortDirections: Map<KoliBriSortFunction, KoliBriSortDirection> = new Map();\n\tprivate sortData: SortData[] = [];\n\tprivate showPagination = false;\n\tprivate pageStartSlice = 0;\n\tprivate pageEndSlice = 10;\n\tprivate disableSort = false;\n\n\t/**\n\t * @deprecated only for backward compatibility\n\t */\n\tprivate sortedColumnHead: KoliBriTableSelectedHead = { label: '', key: '', sortDirection: 'NOS' };\n\tprivate ariaLive = '';\n\n\t/**\n\t * Defines whether to allow multi sort.\n\t */\n\t@Prop() public _allowMultiSort?: boolean;\n\n\t/**\n\t * Defines the primary table data.\n\t */\n\t@Prop() public _data!: Stringified<KoliBriTableDataType[]>;\n\n\t/**\n\t * Defines the data for the table footer.\n\t */\n\t@Prop() public _dataFoot?: Stringified<KoliBriTableDataType[]>;\n\n\t/**\n\t * Defines the horizontal and vertical table headers.\n\t */\n\t@Prop() public _headers!: Stringified<KoliBriTableHeaders>;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: string;\n\n\t/**\n\t * Defines the table min-width.\n\t */\n\t@Prop() public _minWidth?: string;\n\n\t/**\n\t * Defines whether to show the data distributed over multiple pages.\n\t */\n\t@Prop() public _pagination?: boolean | Stringified<KoliBriTablePaginationProps>;\n\n\t@State() public state: States = {\n\t\t_allowMultiSort: false,\n\t\t_label: '…', // ⚠ required\n\t\t_data: [],\n\t\t_dataFoot: [],\n\t\t_headers: {\n\t\t\thorizontal: [],\n\t\t\tvertical: [],\n\t\t},\n\t\t_pagination: {\n\t\t\t_page: 1,\n\t\t\t_pageSize: 10,\n\t\t\t_max: 0,\n\t\t},\n\t\t_sortedData: [],\n\t};\n\n\t@Watch('_allowMultiSort')\n\tpublic validateAllowMultiSort(value?: boolean): void {\n\t\twatchValidator(this, '_allowMultiSort', () => true, new Set(['boolean']), value, {\n\t\t\tdefaultValue: false,\n\t\t});\n\t}\n\n\t@Watch('_data')\n\tpublic validateData(value?: Stringified<KoliBriTableDataType[]>): void {\n\t\temptyStringByArrayHandler(value, () => {\n\t\t\tobjectObjectHandler(value, () => {\n\t\t\t\tif (typeof value === 'undefined') {\n\t\t\t\t\tvalue = [];\n\t\t\t\t}\n\t\t\t\ttry {\n\t\t\t\t\tvalue = parseJson<KoliBriTableDataType[]>(value);\n\t\t\t\t\t// eslint-disable-next-line no-empty\n\t\t\t\t} catch (e) {\n\t\t\t\t\t// value behält den ursprünglichen Wert\n\t\t\t\t}\n\t\t\t\tif (Array.isArray(value) && value.find((dataTupel: KoliBriTableDataType) => !(typeof dataTupel === 'object' && dataTupel !== null)) === undefined) {\n\t\t\t\t\tsetState(this, '_data', value, {\n\t\t\t\t\t\tafterPatch: () => {\n\t\t\t\t\t\t\t// TODO: kein guter Hack (endless loop)\n\t\t\t\t\t\t\tsetTimeout(this.updateSortedData);\n\t\t\t\t\t\t},\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\t@Watch('_dataFoot')\n\tpublic validateDataFoot(value?: Stringified<KoliBriTableDataType[]>): void {\n\t\temptyStringByArrayHandler(value, () => {\n\t\t\tobjectObjectHandler(value, () => {\n\t\t\t\tif (typeof value === 'undefined') {\n\t\t\t\t\tvalue = [];\n\t\t\t\t}\n\t\t\t\ttry {\n\t\t\t\t\tvalue = parseJson<KoliBriTableDataType[]>(value);\n\t\t\t\t\t// eslint-disable-next-line no-empty\n\t\t\t\t} catch (e) {\n\t\t\t\t\t// value behält den ursprünglichen Wert\n\t\t\t\t}\n\t\t\t\tif (Array.isArray(value) && value.find((dataTupel: KoliBriTableDataType) => !(typeof dataTupel === 'object' && dataTupel !== null)) === undefined) {\n\t\t\t\t\tsetState(this, '_dataFoot', value, {\n\t\t\t\t\t\tafterPatch: () => {\n\t\t\t\t\t\t\tsetTimeout(this.updateSortedData);\n\t\t\t\t\t\t},\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 * @deprecated only for backward compatibility\n\t */\n\tprivate setSortDirection = (sort: KoliBriSortFunction, direction: KoliBriSortDirection) => {\n\t\t/**\n\t\t * Durch des Clearen, ist es nicht möglich eine Mehr-Spalten-Sortierung\n\t\t * darzustellen. Das wäre der Fall, wenn man ggf. Daten in außerhalb der\n\t\t * Komponente sortiert und diese sortiert von außen rein gibt und der\n\t\t * Sortierungsalgorithmus mehrere Spalten zusammen sortierte.\n\t\t *\n\t\t * Beachte auch col.sort !== this.sortFunction\n\t\t */\n\t\tthis.sortDirections.clear();\n\t\tthis.sortDirections.set(sort, direction);\n\t\tthis.sortFunction = sort;\n\t};\n\n\tprivate changeCellSort(headerCell: KoliBriTableHeaderCell) {\n\t\tif (typeof headerCell.compareFn === 'function') {\n\t\t\tif (!this.state._allowMultiSort && headerCell.key != this.sortData[0]?.key) {\n\t\t\t\t// clear when another column is sorted and multi sort is not allowed\n\t\t\t\tthis.sortData = [];\n\t\t\t}\n\n\t\t\tconst index = this.sortData.findIndex((value) => value.key === headerCell.key);\n\t\t\tif (index >= 0) {\n\t\t\t\tconst settings = this.sortData[index];\n\t\t\t\tswitch (settings.direction) {\n\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\tsettings.direction = 'DESC';\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\tthis.sortData.splice(index, 1);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tsettings.direction = 'ASC';\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t} else if (headerCell.key) {\n\t\t\t\tthis.sortData.push({\n\t\t\t\t\tlabel: headerCell.label,\n\t\t\t\t\tkey: headerCell.key,\n\t\t\t\t\tcompareFn: headerCell.compareFn,\n\t\t\t\t\tdirection: 'ASC',\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tthis.updateSortedData(headerCell as KoliBriTableSelectedHead);\n\t\t} else if (typeof headerCell.sort === 'function') {\n\t\t\tthis.sortFunction = headerCell.sort;\n\t\t\tswitch (this.sortDirections.get(this.sortFunction)) {\n\t\t\t\tcase 'ASC':\n\t\t\t\t\tthis.setSortDirection(this.sortFunction, 'DESC');\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'DESC':\n\t\t\t\t\tthis.setSortDirection(this.sortFunction, 'NOS');\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\tthis.setSortDirection(this.sortFunction, 'ASC');\n\t\t\t}\n\t\t\tthis.updateSortedData(headerCell as KoliBriTableSelectedHead);\n\t\t}\n\t}\n\n\t@Watch('_headers')\n\tpublic validateHeaders(value?: Stringified<KoliBriTableHeaders>): void {\n\t\t/**\n\t\t * - es darf maximal ein Header als primary markiert werden (last win)\n\t\t * - der primary-Header entscheidet implizit über _order und _orientation\n\t\t * - primary-Headers müssen das key-Property setzen\n\t\t * - nicht primary-Headers müssen das key-Property nicht setzen (wird ignoriert)\n\t\t * - _order: wird durch den primary-Header geregelt\n\t\t * - _orientation: wird durch den primary-Header geregelt\n\t\t * - sobald ein Header sortierbar ist, darf es nur noch entweder horizontale\n\t\t * oder vertikale Header geben, aber nicht mehr beides\n\t\t */\n\t\temptyStringByArrayHandler(value, () => {\n\t\t\tobjectObjectHandler(value, () => {\n\t\t\t\ttry {\n\t\t\t\t\tvalue = parseJson<KoliBriTableHeaders>(value);\n\t\t\t\t\t// eslint-disable-next-line no-empty\n\t\t\t\t} catch (e) {\n\t\t\t\t\t// value behält den ursprünglichen Wert\n\t\t\t\t}\n\t\t\t\twatchValidator(this, '_headers', (value): boolean => typeof value === 'object' && value !== null, new Set(['KoliBriTableHeaders']), value, {\n\t\t\t\t\thooks: {\n\t\t\t\t\t\tbeforePatch: (nextValue: unknown) => {\n\t\t\t\t\t\t\tconst applySort = (headers: KoliBriTableHeaderCell[]) => {\n\t\t\t\t\t\t\t\tlet hasSortedCells = false;\n\t\t\t\t\t\t\t\theaders.forEach((cell) => {\n\t\t\t\t\t\t\t\t\tconst key = cell.key;\n\t\t\t\t\t\t\t\t\tif (!key) {\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tconst sortDirection = cell.sortDirection;\n\t\t\t\t\t\t\t\t\tif (sortDirection === 'ASC' || sortDirection === 'DESC') {\n\t\t\t\t\t\t\t\t\t\tif (typeof cell.compareFn === 'function') {\n\t\t\t\t\t\t\t\t\t\t\tif (this.state._allowMultiSort || this.sortData.length === 0) {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.sortData.push({ label: cell.label, key, compareFn: cell.compareFn, direction: sortDirection });\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\thasSortedCells = true;\n\t\t\t\t\t\t\t\t\t\t} else if (typeof cell.sort === 'function') {\n\t\t\t\t\t\t\t\t\t\t\tthis.setSortDirection(cell.sort, sortDirection);\n\t\t\t\t\t\t\t\t\t\t\tsetTimeout(() => this.updateSortedData({ key, label: cell.label, sortDirection }));\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\tif (hasSortedCells) {\n\t\t\t\t\t\t\t\t\tsetTimeout(() => this.updateSortedData());\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\tconst headers: KoliBriTableHeaders = nextValue as KoliBriTableHeaders;\n\t\t\t\t\t\t\theaders.horizontal?.forEach(applySort);\n\t\t\t\t\t\t\theaders.vertical?.forEach(applySort);\n\n\t\t\t\t\t\t\tif (headers.horizontal && headers.vertical && headers.horizontal?.length > 0 && headers.vertical?.length > 0) {\n\t\t\t\t\t\t\t\tthis.disableSort = true;\n\t\t\t\t\t\t\t\tdevHint(\n\t\t\t\t\t\t\t\t\t`Table: You can not sort the table data, if horizontal and vertical headers are defined at the same time. (https://github.com/public-ui/kolibri/issues/2372)`\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},\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value);\n\t}\n\n\t@Watch('_minWidth')\n\tpublic validateMinWidth(value?: string): void {\n\t\twatchString(this, '_minWidth', value, {\n\t\t\tdefaultValue: undefined,\n\t\t});\n\t}\n\n\tprivate readonly handlePagination: KoliBriPaginationButtonCallbacks = {\n\t\tonClick: (event: Event, page: number) => {\n\t\t\tif (typeof this.state._pagination._on?.onClick === 'function') {\n\t\t\t\tthis.state._pagination._on.onClick(event, page);\n\t\t\t}\n\t\t\tsetState(this, '_pagination', {\n\t\t\t\t...this.state._pagination,\n\t\t\t\t_page: page,\n\t\t\t});\n\t\t},\n\t\tonChangePage: (event: Event, page: number) => {\n\t\t\tif (typeof this.state._pagination._on?.onChangePage === 'function') {\n\t\t\t\tthis.state._pagination._on.onChangePage(event, page);\n\t\t\t}\n\t\t\tsetState(this, '_pagination', {\n\t\t\t\t...this.state._pagination,\n\t\t\t\t_page: page,\n\t\t\t});\n\t\t},\n\t\tonChangePageSize: (event: Event, pageSize: number) => {\n\t\t\tif (typeof this.state._pagination._on?.onChangePageSize === 'function') {\n\t\t\t\tthis.state._pagination._on.onChangePageSize(event, pageSize);\n\t\t\t}\n\t\t\tsetState(this, '_pagination', {\n\t\t\t\t...this.state._pagination,\n\t\t\t\t_pageSize: pageSize,\n\t\t\t});\n\t\t\tsetState(this, '_pageSize', pageSize);\n\t\t},\n\t};\n\n\tprivate readonly beforePatchPagination: Generic.Element.NextStateHooksCallback = (nextValue, _nextState, _component, key): void => {\n\t\tif (key === '_pagination') {\n\t\t\tthis.showPagination = nextValue === true || nextValue === '' /* true */ || (typeof nextValue === 'object' && nextValue !== null);\n\t\t}\n\t};\n\n\t@Watch('_pagination')\n\tpublic validatePagination(value?: boolean | Stringified<KoliBriTablePaginationProps>): void {\n\t\ttry {\n\t\t\tvalue = parseJson<KoliBriTablePaginationProps>(value);\n\t\t\t// eslint-disable-next-line no-empty\n\t\t} catch (e) {\n\t\t\t// value behält den ursprünglichen Wert\n\t\t}\n\t\twatchValidator(this, '_pagination', () => true, new Set(['boolean', 'KoliBriTablePagination']), value, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: this.beforePatchPagination,\n\t\t\t},\n\t\t});\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAllowMultiSort(this._allowMultiSort);\n\t\tthis.validateData(this._data);\n\t\tthis.validateDataFoot(this._dataFoot);\n\t\tthis.validateHeaders(this._headers);\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateMinWidth(this._minWidth);\n\t\tthis.validatePagination(this._pagination);\n\t}\n\n\tprivate getNumberOfCols(horizontalHeaders: KoliBriTableHeaderCell[][], data: KoliBriTableDataType[]): number {\n\t\tlet max = 0;\n\t\thorizontalHeaders.forEach((row) => {\n\t\t\tlet count = 0;\n\t\t\trow.forEach((col) => (count += col.colSpan ?? 1));\n\t\t\tif (max < count) {\n\t\t\t\tmax = count;\n\t\t\t}\n\t\t});\n\t\tif (max === 0) {\n\t\t\tmax = data.length;\n\t\t}\n\t\treturn max;\n\t}\n\n\tprivate getNumberOfRows(verticalHeaders: KoliBriTableHeaderCell[][], data: KoliBriTableDataType[]): number {\n\t\tlet max = 0;\n\t\tverticalHeaders.forEach((col) => {\n\t\t\tlet count = 0;\n\t\t\tcol.forEach((row) => (count += row.rowSpan ?? 1));\n\t\t\tif (max < count) {\n\t\t\t\tmax = count;\n\t\t\t}\n\t\t});\n\t\tif (max === 0) {\n\t\t\tmax = data.length;\n\t\t} else {\n\t\t\tmax -= this.state._dataFoot.length;\n\t\t}\n\t\treturn max;\n\t}\n\n\tprivate filterHeaderKeys(headers: KoliBriTableHeaderCell[][]): KoliBriTableHeaderCell[] {\n\t\tconst primaryHeader: KoliBriTableHeaderCell[] = [];\n\t\theaders.forEach((cells) => {\n\t\t\tcells.forEach((cell) => {\n\t\t\t\tif (typeof cell.key === 'string') {\n\t\t\t\t\tprimaryHeader.push(cell);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t\treturn primaryHeader;\n\t}\n\n\tprivate getPrimaryHeader(headers: KoliBriTableHeaders): KoliBriTableHeaderCell[] {\n\t\tlet primaryHeader: KoliBriTableHeaderCell[] = this.filterHeaderKeys(headers.horizontal ?? []);\n\t\tthis.horizontal = true;\n\t\tif (primaryHeader.length === 0) {\n\t\t\tprimaryHeader = this.filterHeaderKeys(headers.vertical ?? []);\n\t\t\tif (primaryHeader.length > 0) {\n\t\t\t\tthis.horizontal = false;\n\t\t\t}\n\t\t}\n\t\treturn primaryHeader;\n\t}\n\n\tprivate createDataField(data: KoliBriTableDataType[], headers: KoliBriTableHeaders, isFoot?: boolean): KoliBriTableCell[][] {\n\t\theaders.horizontal = Array.isArray(headers?.horizontal) ? headers.horizontal : [];\n\t\theaders.vertical = Array.isArray(headers?.vertical) ? headers.vertical : [];\n\t\tconst primaryHeader = this.getPrimaryHeader(headers);\n\t\tconst maxCols = this.getNumberOfCols(headers.horizontal, data);\n\t\tlet maxRows = this.getNumberOfRows(headers.vertical, data);\n\t\tlet startRow = 0;\n\t\tif (isFoot) {\n\t\t\tstartRow = maxRows;\n\t\t\tmaxRows += this.state._dataFoot.length;\n\t\t}\n\t\tconst dataField: KoliBriTableCell[][] = [];\n\n\t\tconst rowCount: number[] = [];\n\t\tconst rowSpans: number[][] = [];\n\t\theaders.vertical.forEach((_row, index) => {\n\t\t\trowCount[index] = 0;\n\t\t\trowSpans[index] = [];\n\t\t});\n\n\t\tfor (let i = startRow; i < maxRows; i++) {\n\t\t\tconst dataRow: KoliBriTableHeaderCellAndData[] = [];\n\t\t\theaders.vertical.forEach((headerCells, index) => {\n\t\t\t\tlet rowsTotal = 0;\n\t\t\t\trowSpans[index].forEach((value) => (rowsTotal += value));\n\t\t\t\tif (rowsTotal <= i) {\n\t\t\t\t\tconst rows = headerCells[i - rowsTotal + rowCount[index]];\n\t\t\t\t\tif (typeof rows === 'object') {\n\t\t\t\t\t\tdataRow.push({\n\t\t\t\t\t\t\t...rows,\n\t\t\t\t\t\t\tasTd: false,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\t\t\t\tdata: {} as KoliBriTableDataType,\n\t\t\t\t\t\t});\n\t\t\t\t\t\tlet rowSpan = 1;\n\t\t\t\t\t\tif (typeof rows.rowSpan === 'number' && rows.rowSpan > 1) {\n\t\t\t\t\t\t\trowSpan = rows.rowSpan;\n\t\t\t\t\t\t}\n\t\t\t\t\t\trowSpans[index].push(rowSpan);\n\t\t\t\t\t\tif (typeof rows.colSpan === 'number' && rows.colSpan > 1) {\n\t\t\t\t\t\t\tfor (let k = 1; k < rows.colSpan; k++) {\n\t\t\t\t\t\t\t\trowSpans[index + k].push(rowSpan);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\trowCount[index]++;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t\tfor (let j = 0; j < maxCols; j++) {\n\t\t\t\tif (this.horizontal === true) {\n\t\t\t\t\tconst row = isFoot ? this.state._dataFoot[i - startRow] : data[i];\n\t\t\t\t\tif (\n\t\t\t\t\t\ttypeof primaryHeader[j] === 'object' &&\n\t\t\t\t\t\tprimaryHeader[j] !== null &&\n\t\t\t\t\t\ttypeof primaryHeader[j].key === 'string' &&\n\t\t\t\t\t\ttypeof row === 'object' &&\n\t\t\t\t\t\trow !== null\n\t\t\t\t\t) {\n\t\t\t\t\t\tdataRow.push({\n\t\t\t\t\t\t\t...primaryHeader[j],\n\t\t\t\t\t\t\tcolSpan: undefined,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\t\t\t\tdata: row,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n\t\t\t\t\t\t\tlabel: row[primaryHeader[j].key as unknown as string] as string,\n\t\t\t\t\t\t\trowSpan: undefined,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tif (\n\t\t\t\t\t\ttypeof primaryHeader[i] === 'object' &&\n\t\t\t\t\t\tprimaryHeader[i] !== null &&\n\t\t\t\t\t\ttypeof primaryHeader[i].key === 'string' &&\n\t\t\t\t\t\ttypeof data[j] === 'object' &&\n\t\t\t\t\t\tdata[j] !== null\n\t\t\t\t\t) {\n\t\t\t\t\t\tdataRow.push({\n\t\t\t\t\t\t\t...primaryHeader[i],\n\t\t\t\t\t\t\tcolSpan: undefined,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\t\t\t\tdata: data[j],\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n\t\t\t\t\t\t\tlabel: data[j][primaryHeader[i].key as unknown as number] as string,\n\t\t\t\t\t\t\trowSpan: undefined,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tdataField.push(dataRow);\n\t\t}\n\t\tif (data.length === 0) {\n\t\t\tlet colspan = 0;\n\t\t\tlet rowspan = 0;\n\t\t\tif (Array.isArray(headers.horizontal) && headers.horizontal.length > 0) {\n\t\t\t\theaders.horizontal[0].forEach((col) => {\n\t\t\t\t\tcolspan += col.colSpan || 1;\n\t\t\t\t});\n\t\t\t}\n\t\t\tif (Array.isArray(headers.vertical) && headers.vertical.length > 0) {\n\t\t\t\tcolspan -= headers.vertical.length;\n\t\t\t\theaders.vertical[0].forEach((row) => {\n\t\t\t\t\trowspan += row.rowSpan || 1;\n\t\t\t\t});\n\t\t\t}\n\t\t\tconst emptyCell = {\n\t\t\t\tcolSpan: colspan,\n\t\t\t\tlabel: translate('kol-no-entries'),\n\t\t\t\trender: undefined,\n\t\t\t\trowSpan: Math.max(rowspan, 1),\n\t\t\t};\n\t\t\tif (dataField.length === 0) {\n\t\t\t\tdataField.push([emptyCell]);\n\t\t\t} else {\n\t\t\t\tdataField[0].push(emptyCell);\n\t\t\t}\n\t\t}\n\t\treturn dataField;\n\t}\n\n\tprivate selectDisplayedData(data: KoliBriTableDataType[], pageSize: number, page: number): KoliBriTableDataType[] {\n\t\tif (typeof pageSize === 'number' && pageSize > 0 && typeof page === 'number' && page > 0) {\n\t\t\tthis.pageStartSlice = pageSize * (page - 1);\n\t\t\tthis.pageEndSlice = pageSize * page > data.length ? data.length : pageSize * page;\n\t\t\treturn data.slice(this.pageStartSlice, this.pageEndSlice);\n\t\t} else {\n\t\t\tthis.pageStartSlice = 0;\n\t\t\tthis.pageEndSlice = data.length;\n\t\t\treturn data;\n\t\t}\n\t}\n\n\tprivate cellRender(col: KoliBriTableHeaderCellAndData & { render: KoliBriTableRender }, el?: HTMLElement): void {\n\t\tif (el /* SSR instanceof HTMLElement */) {\n\t\t\tclearTimeout(CELL_REFS.get(el));\n\t\t\tCELL_REFS.set(\n\t\t\t\tel,\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tclearTimeout(CELL_REFS.get(el));\n\t\t\t\t\tconst html = col.render(\n\t\t\t\t\t\tel,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tasTd: col.asTd,\n\t\t\t\t\t\t\tlabel: col.label,\n\t\t\t\t\t\t\ttextAlign: col.textAlign,\n\t\t\t\t\t\t\twidth: col.width,\n\t\t\t\t\t\t} as KoliBriTableHeaderCell,\n\t\t\t\t\t\tcol.data,\n\t\t\t\t\t\tthis.state._data\n\t\t\t\t\t);\n\t\t\t\t\tif (typeof html === 'string') {\n\t\t\t\t\t\tel.textContent = html;\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 *\n\t * @param cell only used for old single sort. Can be removed when sort is removed.\n\t */\n\tprivate updateSortedData = (cell: KoliBriTableSelectedHead = this.sortedColumnHead) => {\n\t\tif (this.disableSort) {\n\t\t\tsetState(this, '_sortedData', this.state._data);\n\t\t\treturn;\n\t\t}\n\n\t\tlet sortedData: KoliBriTableDataType[] = this.state._data;\n\t\tif (this.sortData.length > 0) {\n\t\t\tsortedData = this.state._data.sort((a: KoliBriTableDataType, b: KoliBriTableDataType) => {\n\t\t\t\tfor (let index = 0; index < this.sortData.length; index++) {\n\t\t\t\t\tconst data = this.sortData[index];\n\t\t\t\t\tconst result = data.compareFn(a, b);\n\t\t\t\t\tif (result !== 0) {\n\t\t\t\t\t\treturn data.direction === 'ASC' ? result : -result;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn 0;\n\t\t\t});\n\n\t\t\tif (this.sortData.length === 1) {\n\t\t\t\tthis.ariaLive = translate(`kol-sort-${this.sortData[0].direction === 'ASC' ? 'ascending' : 'descending'}`, {\n\t\t\t\t\tplaceholders: { column: this.sortData[0].label, multi: '' },\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tlet sortText = '';\n\t\t\t\tfor (let index = 1; index < this.sortData.length - 1; index++) {\n\t\t\t\t\tconst data = this.sortData[index];\n\t\t\t\t\tsortText += translate(`kol-sort-then-${data.direction === 'ASC' ? 'ascending' : 'descending'}`, { placeholders: { column: data.label } });\n\t\t\t\t}\n\t\t\t\tsortText += translate(`kol-sort-then-last-${this.sortData[this.sortData.length - 1].direction === 'ASC' ? 'ascending' : 'descending'}`, {\n\t\t\t\t\tplaceholders: { column: this.sortData[this.sortData.length - 1].label },\n\t\t\t\t});\n\t\t\t\tthis.ariaLive = translate(`kol-sort-${this.sortData[0].direction === 'ASC' ? 'ascending' : 'descending'}`, {\n\t\t\t\t\tplaceholders: { column: this.sortData[0].label, multi: sortText },\n\t\t\t\t});\n\t\t\t}\n\t\t} else if (typeof this.sortFunction === 'function') {\n\t\t\tswitch (this.sortDirections.get(this.sortFunction)) {\n\t\t\t\tcase 'ASC':\n\t\t\t\t\tsortedData = this.sortFunction([...this.state._data]);\n\t\t\t\t\tthis.ariaLive = translate('kol-sort-ascending', { placeholders: { column: cell.label } });\n\t\t\t\t\tthis.sortedColumnHead = { label: cell.label, key: cell.key, sortDirection: 'ASC' };\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'DESC':\n\t\t\t\t\tsortedData = this.sortFunction([...this.state._data]).reverse();\n\t\t\t\t\tthis.ariaLive = translate('kol-sort-descending', { placeholders: { column: cell.label } });\n\t\t\t\t\tthis.sortedColumnHead = { label: cell.label, key: cell.key, sortDirection: 'DESC' };\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'NOS':\n\t\t\t\tdefault:\n\t\t\t\t\tsortedData = [...this.state._data];\n\t\t\t\t\tthis.sortedColumnHead = { label: '', key: '', sortDirection: 'NOS' };\n\t\t\t\t\tthis.ariaLive = translate('kol-sort-none', { placeholders: { column: cell.label } });\n\t\t\t}\n\t\t} else {\n\t\t\tthis.ariaLive = translate('kol-table-sort-none');\n\t\t}\n\t\tsetState(this, '_sortedData', sortedData);\n\t};\n\n\tprivate readonly renderTableRow = (row: KoliBriTableCell[], rowIndex: number): JSX.Element => {\n\t\treturn <tr key={`tbody-${rowIndex}`}>{row.map((col, colIndex) => this.renderTableCell(col, rowIndex, colIndex))}</tr>;\n\t};\n\tprivate readonly renderTableCell = (cell: KoliBriTableCell, rowIndex: number, colIndex: number): JSX.Element => {\n\t\tif (cell.asTd === false) {\n\t\t\tconst headerCell: KoliBriTableHeaderCell = cell;\n\t\t\tlet sortDirection = undefined;\n\t\t\tlet shortSortDirection: KoliBriSortDirection = 'NOS';\n\t\t\tlet sortButtonIcon = 'codicon codicon-fold';\n\t\t\tif (!this.disableSort) {\n\t\t\t\tif (headerCell.key) {\n\t\t\t\t\tconst data = this.sortData.find((value) => value.key === headerCell.key);\n\t\t\t\t\tif (data) {\n\t\t\t\t\t\tshortSortDirection = data.direction;\n\t\t\t\t\t\tswitch (data.direction) {\n\t\t\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-up';\n\t\t\t\t\t\t\t\tsortDirection = 'ascending';\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-down';\n\t\t\t\t\t\t\t\tsortDirection = 'descending';\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (headerCell.key === this.sortedColumnHead.key) {\n\t\t\t\t\tshortSortDirection = this.sortedColumnHead.sortDirection;\n\t\t\t\t\tswitch (this.sortedColumnHead.sortDirection) {\n\t\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-up';\n\t\t\t\t\t\t\tsortDirection = 'ascending';\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-down';\n\t\t\t\t\t\t\tsortDirection = 'descending';\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn (\n\t\t\t\t<th // role=\"rowheader\"\n\t\t\t\t\tkey={`tbody-${rowIndex}-${colIndex}-${headerCell.label}`}\n\t\t\t\t\tscope={typeof headerCell.rowSpan === 'number' && headerCell.rowSpan > 1 ? 'rowgroup' : 'row'}\n\t\t\t\t\tcolSpan={headerCell.colSpan}\n\t\t\t\t\trowSpan={headerCell.rowSpan}\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\ttextAlign: headerCell.textAlign,\n\t\t\t\t\t\twidth: headerCell.width,\n\t\t\t\t\t}}\n\t\t\t\t\taria-sort={sortDirection}\n\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n\t\t\t\t\tdata-sort={`sort-${shortSortDirection}`}\n\t\t\t\t>\n\t\t\t\t\t<div class=\"w-full flex gap-1 items-center\">\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t'w-full': true,\n\t\t\t\t\t\t\t\t[headerCell.textAlign as string]: typeof headerCell.textAlign === 'string' && headerCell.textAlign.length > 0,\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\tstyle={{ textAlign: headerCell.textAlign }}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{headerCell.label}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t\t{!this.disableSort && (typeof headerCell.compareFn === 'function' || typeof headerCell.sort === 'function') && (\n\t\t\t\t\t\t\t<kol-button\n\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t_icons={sortButtonIcon}\n\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t_label={translate('kol-change-order', { placeholders: { colLabel: headerCell.label } })}\n\t\t\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\t\t\tonClick: () => this.changeCellSort(headerCell),\n\t\t\t\t\t\t\t\t}}\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)}\n\t\t\t\t\t</div>\n\t\t\t\t</th>\n\t\t\t);\n\t\t} else {\n\t\t\treturn (\n\t\t\t\t<td // role=\"gridcell\"\n\t\t\t\t\tkey={`tbody-${rowIndex}-${colIndex}-${cell.label}`}\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[cell.textAlign as string]: typeof cell.textAlign === 'string' && cell.textAlign.length > 0,\n\t\t\t\t\t}}\n\t\t\t\t\tcolSpan={cell.colSpan}\n\t\t\t\t\trowSpan={cell.rowSpan}\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\ttextAlign: cell.textAlign,\n\t\t\t\t\t\twidth: cell.width,\n\t\t\t\t\t}}\n\t\t\t\t\tref={\n\t\t\t\t\t\ttypeof cell.render === 'function'\n\t\t\t\t\t\t\t? (el) => {\n\t\t\t\t\t\t\t\t\tthis.cellRender(cell as KoliBriTableHeaderCellAndData & { render: KoliBriTableRender }, el);\n\t\t\t\t\t\t\t }\n\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t}\n\t\t\t\t>\n\t\t\t\t\t{typeof cell.render !== 'function' ? cell.label : ''}\n\t\t\t\t</td>\n\t\t\t);\n\t\t}\n\t};\n\n\tprivate readonly renderFoot = (): JSX.Element => {\n\t\tconst rows: KoliBriTableCell[][] = this.createDataField(this.state._dataFoot, this.state._headers, true);\n\t\treturn <tfoot>{rows.map(this.renderTableRow)}</tfoot>;\n\t};\n\n\tpublic render(): JSX.Element {\n\t\tconst displayedData: KoliBriTableDataType[] = this.selectDisplayedData(\n\t\t\tthis.state._sortedData,\n\t\t\tthis.showPagination ? this.state._pagination?._pageSize ?? 10 : this.state._sortedData.length,\n\t\t\tthis.state._pagination._page || 1\n\t\t);\n\t\tconst dataField = this.createDataField(displayedData, this.state._headers);\n\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t<div style={{ height: '0', width: '0', overflow: 'hidden' }} aria-live=\"assertive\">\n\t\t\t\t\t{this.ariaLive}\n\t\t\t\t</div>\n\t\t\t\t{this.pageEndSlice > 0 && this.showPagination && (\n\t\t\t\t\t<div class=\"pagination\">\n\t\t\t\t\t\t<span>\n\t\t\t\t\t\t\tEinträge {this.pageEndSlice > 0 ? this.pageStartSlice + 1 : 0} bis {this.pageEndSlice} von{' '}\n\t\t\t\t\t\t\t{this.state._pagination._max || (Array.isArray(this.state._data) ? this.state._data.length : 0)} angezeigt\n\t\t\t\t\t\t</span>\n\t\t\t\t\t\t<div>\n\t\t\t\t\t\t\t<kol-pagination\n\t\t\t\t\t\t\t\t_boundaryCount={this.state._pagination._boundaryCount}\n\t\t\t\t\t\t\t\t_customClass={this.state._pagination._customClass}\n\t\t\t\t\t\t\t\t_on={this.handlePagination}\n\t\t\t\t\t\t\t\t_page={this.state._pagination._page}\n\t\t\t\t\t\t\t\t_pageSize={this.state._pagination._pageSize}\n\t\t\t\t\t\t\t\t_pageSizeOptions={this.state._pagination._pageSizeOptions || PAGINATION_OPTIONS}\n\t\t\t\t\t\t\t\t_siblingCount={this.state._pagination._siblingCount}\n\t\t\t\t\t\t\t\t_tooltipAlign=\"bottom\"\n\t\t\t\t\t\t\t\t_max={this.state._pagination._max || this.state._pagination._max || this.state._data.length}\n\t\t\t\t\t\t\t\t_label={translate('kol-table-pagination-label', { placeholders: { label: this.state._label } })}\n\t\t\t\t\t\t\t></kol-pagination>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t\t<div class=\"table\" tabindex=\"0\">\n\t\t\t\t\t<table\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tminWidth: this.state._minWidth,\n\t\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t\t<caption>{this.state._label}</caption>\n\t\t\t\t\t\t{Array.isArray(this.state._headers.horizontal) && (\n\t\t\t\t\t\t\t<thead>\n\t\t\t\t\t\t\t\t{this.state._headers.horizontal.map((cols, rowIndex) => (\n\t\t\t\t\t\t\t\t\t<tr key={`thead-${rowIndex}`}>\n\t\t\t\t\t\t\t\t\t\t{cols.map((col, colIndex) => {\n\t\t\t\t\t\t\t\t\t\t\tif (col.asTd === true) {\n\t\t\t\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t\t\t\t<td // role=\"gridcell\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tkey={`thead-${rowIndex}-${colIndex}-${col.label}`}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t[col.textAlign as string]: typeof col.textAlign === 'string' && col.textAlign.length > 0,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcolSpan={col.colSpan}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trowSpan={col.rowSpan}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign: col.textAlign,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\twidth: col.width,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tref={\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttypeof col.render === 'function'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? (el) => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tthis.cellRender(col as KoliBriTableHeaderCellAndData & { render: KoliBriTableRender }, el);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t }\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{typeof col.render !== 'function' ? col.label : ''}\n\t\t\t\t\t\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t\t\tconst headerCell: KoliBriTableHeaderCell = col;\n\t\t\t\t\t\t\t\t\t\t\t\tlet sortDirection = undefined;\n\t\t\t\t\t\t\t\t\t\t\t\tlet shortSortDirection: KoliBriSortDirection = 'NOS';\n\t\t\t\t\t\t\t\t\t\t\t\tlet sortButtonIcon = 'codicon codicon-fold';\n\t\t\t\t\t\t\t\t\t\t\t\tif (headerCell.key) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tconst data = this.sortData.find((value) => value.key === headerCell.key);\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (data) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tshortSortDirection = data.direction;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tswitch (data.direction) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-up';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortDirection = 'ascending';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-down';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortDirection = 'descending';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\tif (headerCell.key === this.sortedColumnHead.key) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tshortSortDirection = this.sortedColumnHead.sortDirection;\n\t\t\t\t\t\t\t\t\t\t\t\t\tswitch (this.sortedColumnHead.sortDirection) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-up';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortDirection = 'ascending';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-down';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsortDirection = 'descending';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t\t\t\t<th // role=\"columnheader\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tkey={`thead-${rowIndex}-${colIndex}-${headerCell.label}`}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tscope={typeof headerCell.colSpan === 'number' && headerCell.colSpan > 1 ? 'colgroup' : 'col'}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcolSpan={headerCell.colSpan}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trowSpan={headerCell.rowSpan}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign: col.textAlign,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\twidth: col.width,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\taria-sort={sortDirection}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdata-sort={`sort-${shortSortDirection}`}\n\t\t\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<div class=\"w-full flex gap-1 items-center\">\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t'w-full': true,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t[col.textAlign as string]: typeof col.textAlign === 'string' && col.textAlign.length > 0,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign: col.textAlign,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t{col.label}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t{!this.disableSort && (typeof headerCell.compareFn === 'function' || typeof headerCell.sort === 'function') && (\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<kol-button\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t_icons={sortButtonIcon}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t_label={translate('kol-change-order', { placeholders: { colLabel: col.label } })}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tonClick: () => this.changeCellSort(headerCell),\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t_variant=\"ghost\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t></kol-button>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t\t\t\t\t</th>\n\t\t\t\t\t\t\t\t\t\t\t\t);\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</tr>\n\t\t\t\t\t\t\t\t))}\n\t\t\t\t\t\t\t</thead>\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t<tbody>{dataField.map(this.renderTableRow)}</tbody>\n\t\t\t\t\t\t{this.state._dataFoot.length > 0 ? this.renderFoot() : ''}\n\t\t\t\t\t</table>\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\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 t,h as n,H as i,g as e}from"./index-0bc40dc4.js";import{a as o}from"./i18n-99b63f3a.js";import{a as s}from"./alignment-cb8fa342.js";import{v as l}from"./label-7afcc6a9.js";import{d as a,f as r,c as h}from"./a11y.tipps-68791110.js";import{L as d}from"./dev.utils-8202a1bc.js";import{s as b,e as u,c,k as f}from"./prop.validators-3fb6bedf.js";import"./index-a4b1e92f.js";import"./reuse-b3566e4c.js";const p="/*\n * This file contains all rules for accessibility.\n */\n@layer kol-global {\n\t:host {\n\t\t/*\n\t\t * Minimum size of interactive elements.\n\t\t */\n\t\t--a11y-min-size: 44px;\n\t\t/*\n\t\t * Verdana is an accessible font that can be used without requiring additional loading time.\n\t\t */\n\t\tfont-family: Verdana;\n\t}\n\n\t* {\n\t\t/*\n\t\t * This rule enables the word dividing for all texts. That is important for high zoom levels.\n\t\t */\n\t\thyphens: auto;\n\t\t/*\n\t\t * Letter spacing is required for all texts.\n\t\t */\n\t\tletter-spacing: inherit;\n\t\t/*\n\t\t * This rule enables the word dividing for all texts. That is important for high zoom levels.\n\t\t */\n\t\tword-break: break-word;\n\t\t/*\n\t\t * Word spacing is required for all texts.\n\t\t */\n\t\tword-spacing: inherit;\n\t}\n\n\t/*\n\t * All interactive elements should have a minimum size of 44px.\n\t */\n\t/* input:not([type='checkbox'], [type='radio'], [type='range']), */\n\t/* option, */\n\t/* select, */\n\t/* textarea, */\n\t[role='button'],\n\tbutton:not([role='link']),\n\tkol-input .input {\n\t\tmin-height: var(--a11y-min-size);\n\t\tmin-width: var(--a11y-min-size);\n\t}\n\n\t/*\n\t * Some interactive elements should not inherit the font-family and font-size.\n\t */\n\ta,\n\tbutton,\n\th1,\n\th2,\n\th3,\n\th4,\n\th5,\n\th6,\n\tinput,\n\toption,\n\tselect,\n\ttextarea {\n\t\t/*\n\t\t * All elements should inherit the font family from his parent element.\n\t\t */\n\t\tfont-family: inherit;\n\t\t/*\n\t\t * All elements should inherit the font size from his parent element.\n\t\t */\n\t\tfont-size: inherit;\n\t}\n}\n\n@layer kol-global {\n\t/*\n\t * Dieses CSS stellt sicher, dass der Standard-Style\n\t * von A und Button resettet werden.\n\t */\n\t:is(a, button) {\n\t\tbackground-color: transparent;\n\t\tborder: none;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\twidth: 100%; /* 100% needed for custom width from outside */\n\t}\n}\n\n@layer kol-global {\n\t:host {\n\t\t/*\n\t\t * The max-width is needed to prevent the table from overflowing the\n\t\t * parent node, if the table is wider than the parent node.\n\t\t */\n\t\tmax-width: 100%;\n\t}\n\n\t* {\n\t\t/*\n\t\t * We prefer to box-sizing: border-box for all elements.\n\t\t */\n\t\tbox-sizing: border-box;\n\t}\n\n\t/* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n\tkol-span-wc {\n\t\tdisplay: grid;\n\t\tplace-items: center;\n\t}\n\n\t/* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n\tkol-span-wc > span {\n\t\tdisplay: flex;\n\t\tplace-items: center;\n\t}\n\n\ta,\n\tbutton {\n\t\tcursor: pointer;\n\t}\n\n\t/* This is the text label. */\n\t.icon-only > kol-span-wc > span > span {\n\t\tdisplay: none;\n\t}\n}\n\n@layer kol-component {\n\t:host {\n\t\tdisplay: block;\n\t}\n}\n\n@layer kol-component {\n\tkol-button-group-wc {\n\t\tdisplay: inline-flex;\n\t\tflex-wrap: wrap;\n\t}\n\n\tkol-button-group-wc button {\n\t\tborder-bottom-color: transparent;\n\t\tborder-bottom-style: solid;\n\t\tdisplay: block;\n\t}\n\n\tdiv.grid,\n\tdiv[role='tabpanel'] {\n\t\theight: 100%;\n\t}\n\n\t:host > .tabs-align-right {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: 1fr auto;\n\t}\n\n\t:host > .tabs-align-right kol-button-group-wc {\n\t\tdisplay: grid;\n\t\torder: 2;\n\t}\n\n\t:host > .tabs-align-left {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: auto 1fr;\n\t}\n\n\t:host > .tabs-align-left kol-button-group-wc {\n\t\tdisplay: grid;\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-bottom {\n\t\tdisplay: grid;\n\t\tgrid-template-rows: 1fr auto;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc {\n\t\torder: 2;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc > div {\n\t\tdisplay: flex;\n\t}\n\n\t:host > .tabs-align-bottom > kol-button-group-wc > div > div:first-child {\n\t\tmargin: 0 1em 0 0;\n\t}\n\n\t:host > .tabs-align-bottom > kol-button-group-wc > div > div {\n\t\tmargin: 0 1em;\n\t}\n\n\t:host > .tabs-align-top {\n\t\tdisplay: grid;\n\t\tgrid-template-rows: auto 1fr;\n\t}\n\n\t:host > .tabs-align-top kol-button-group-wc {\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-top kol-button-group-wc > div {\n\t\tdisplay: flex;\n\t}\n\n\t:host > .tabs-align-top > kol-button-group-wc > div > div:first-child {\n\t\tmargin: 0 1em 0 0;\n\t}\n\n\t:host > .tabs-align-top > kol-button-group-wc > div > div {\n\t\tmargin: 0 1em;\n\t}\n\n\t:host > div {\n\t\tdisplay: grid;\n\t}\n\n\t:host > .tabs-align-left kol-button-group-wc,\n\t:host > .tabs-align-top kol-button-group-wc {\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc,\n\t:host > .tabs-align-right kol-button-group-wc {\n\t\torder: 1;\n\t}\n\n\t:host > div.tabs-align-left kol-button-group-wc > div,\n\t:host > div.tabs-align-left kol-button-group-wc > div > div,\n\t:host > div.tabs-align-right kol-button-group-wc > div,\n\t:host > div.tabs-align-right kol-button-group-wc > div > div {\n\t\tdisplay: grid;\n\t}\n\n\t:host > div.tabs-align-left kol-button-group-wc > div > div kol-button-wc,\n\t:host > div.tabs-align-right kol-button-group-wc > div > div kol-button-wc {\n\t\twidth: 100%;\n\t}\n\n\t:host > div.tabs-align-bottom kol-button-group-wc div,\n\t:host > div.tabs-align-top kol-button-group-wc div {\n\t\tdisplay: flex;\n\t\tflex-wrap: wrap;\n\t}\n}\n",g=class{constructor(n){t(this,n),this.onCreateLabel=`${o("kol-new")} …`,this.showCreateTab=!1,this.nextPossibleTabIndex=(t,n,e)=>{if(e>0){if(n+e<t.length)return t[n+e]._disabled?this.nextPossibleTabIndex(t,n,e+1):n+e}else if(e<0&&n+e>=0)return t[n+e]._disabled?this.nextPossibleTabIndex(t,n,e-1):n+e;return n},this.onKeyDown=t=>{const n=setTimeout((()=>{clearTimeout(n);let e=null;switch(t.key){case"ArrowRight":e=this.nextPossibleTabIndex(this.state._tabs,this.state._selected,1);break;case"ArrowLeft":e=this.nextPossibleTabIndex(this.state._tabs,this.state._selected,-1)}null!==e&&this.onSelect(t,e,!0)}),250)},this.onClickSelect=(t,n)=>{this.onSelect(t,n,!0)},this.onMouseDown=t=>{t.preventDefault(),t.stopPropagation()},this.callbacks={onClick:this.onClickSelect,onMouseDown:this.onMouseDown},this.catchTabPanelHost=t=>{this.tabPanelHost=t},this.selectNextNotDisabledTab=(t,n,e=!0,i)=>{if(t>n.length-1&&(t=n.length-1),t<0&&(t=0),Array.isArray(n)&&n[t]&&n[t]._disabled){if(!0===e){if(t<n.length-1)return this.selectNextNotDisabledTab(t+1,n,!0,i||t);t=i||t,e=!1}if(!1===e){if(t>0)return this.selectNextNotDisabledTab(t-1,n,!1,i||t);a("[KolTabs] Alle Tabs sind deaktiviert und somit kann kein Tab angezeigt werden.")}}return t},this.syncSelectedAndTabs=(t,n,e,i)=>{let a,o;a="_selected"===i?t:this.state._selected,o="_tabs"===i?t:this.state._tabs,o.length>0&&n.set("_selected",this.selectNextNotDisabledTab(a,o))},this.handleTabPanels=()=>{var t,n,e;if(this.tabPanelHost instanceof HTMLDivElement)for(let i=this.tabPanelHost.children.length;i<this.state._tabs.length;i++){const a=document.createElement("div");a.setAttribute("aria-labelledby",`${this.state._label.replace(/\s/g,"-")}-tab-${i}`),a.setAttribute("id",`tabpanel-${i}`),a.setAttribute("role","tabpanel"),a.setAttribute("hidden","");const o=document.createElement("slot");o.setAttribute("name",`tabpanel-slot-${i}`),a.appendChild(o),this.tabPanelHost.appendChild(a),(null===(t=this.host)||void 0===t?void 0:t.children)instanceof HTMLCollection&&(null===(n=this.host)||void 0===n?void 0:n.children[i])&&(null===(e=this.host)||void 0===e||e.children[i].setAttribute("slot",`tabpanel-slot-${i}`))}},this.onCreate=t=>{var n,e;t.preventDefault(),t.stopPropagation(),"function"==typeof(null===(n=this.state._on)||void 0===n?void 0:n.onCreate)&&(null===(e=this.state._on)||void 0===e||e.onCreate(t))},this._align="top",this._label=void 0,this._on=void 0,this._selected=0,this._tabs=void 0,this.state={_align:"top",_label:"…",_selected:0,_tabs:[]}}renderButtonGroup(){return n("kol-button-group-wc",{role:"tablist","aria-label":this.state._label,onKeyDown:this.onKeyDown},this.state._tabs.map(((t,e)=>n("kol-button-wc",{_disabled:t._disabled,_icons:t._icons,_hideLabel:t._hideLabel,_label:t._label,_on:this.callbacks,_tabIndex:this.state._selected===e?0:-1,_tooltipAlign:t._tooltipAlign,_variant:this.state._selected===e?"custom":void 0,_customClass:this.state._selected===e?"selected":void 0,_ariaControls:`tabpanel-${e}`,_ariaSelected:this.state._selected===e,_id:`${this.state._label.replace(/\s/g,"-")}-tab-${e}`,_role:"tab",_value:e}))),this.showCreateTab&&n("kol-button-wc",{class:"create-button",_label:this.onCreateLabel,_on:{onClick:this.onCreate}}))}render(){return n(i,null,n("div",{ref:t=>{this.tabPanelsElement=t},class:{[`tabs-align-${this.state._align}`]:!0}},this.renderButtonGroup(),n("div",{ref:this.catchTabPanelHost})))}validateAlign(t){s(this,t)}validateLabel(t){l(this,t)}validateOn(t){if("object"==typeof t&&null!==t){r("[KolTabs] Prüfen, wie man auch einen EventCallback einzeln ändern kann.");const n={};"function"!=typeof t.onCreate&&"object"!=typeof t.onCreate||("object"==typeof t.onCreate?("string"==typeof t.onCreate.label&&t.onCreate.label.length>0?this.onCreateLabel=t.onCreate.label:d.debug("[KolTabs] Der Label-Text für Neu in {\n onCreate: {\n label: string (!),\n callback: Function\n }\n} ist nicht korrekt gesetzt."),"function"==typeof t.onCreate.callback?n.onCreate=t.onCreate.callback:d.debug("[KolTabs] Die onCreate-Callback-Funktion für Neu in {\n onCreate: {\n label: string,\n callback: Function (!)\n }\n} ist nicht korrekt gesetzt.")):n.onCreate=t.onCreate,this.showCreateTab="function"==typeof n.onCreate),"function"==typeof t.onSelect&&(n.onSelect=t.onSelect),b(this,"_on",n)}}validateSelected(t){u(this,"_selected",t,{hooks:{beforePatch:this.syncSelectedAndTabs}})}validateTabs(t){c(this,"_tabs",(t=>"object"==typeof t&&null!==t&&"string"==typeof t._label&&t._label.length>0),t,void 0,{hooks:{beforePatch:this.syncSelectedAndTabs}}),h("KolTabs",this.state._tabs.length)}componentWillLoad(){this.validateAlign(this._align),this.validateLabel(this._label),this.validateOn(this._on),this.validateSelected(this._selected),this.validateTabs(this._tabs)}componentDidRender(){if(this.handleTabPanels(),this.tabPanelHost instanceof HTMLDivElement)for(let t=0;t<this.tabPanelHost.children.length;t++)t!==this.state._selected?this.tabPanelHost.children[t].setAttribute("hidden",""):this.tabPanelHost.children[t].removeAttribute("hidden")}onSelect(t,n,e=!1){var i,a;this._selected=n,"function"==typeof(null===(i=this._on)||void 0===i?void 0:i.onSelect)&&(null===(a=this._on)||void 0===a||a.onSelect(t,n)),!0===e&&(this.selectedTimeout=setTimeout((()=>{if(clearTimeout(this.selectedTimeout),this.tabPanelsElement){const t=f(`button#${this.state._label.replace(/\s/g,"-")}-tab-${n}`,this.tabPanelsElement);null==t||t.focus()}}),250))}get host(){return e(this)}static get watchers(){return{_align:["validateAlign"],_label:["validateLabel"],_on:["validateOn"],_selected:["validateSelected"],_tabs:["validateTabs"]}}};g.style={default:p};export{g as kol_tabs};
4
+ import{r as t,h as n,H as i,g as e}from"./index-e9d20d00.js";import{a as o}from"./i18n-4c7dd514.js";import{a as s}from"./alignment-d30f46a0.js";import{v as a}from"./label-9700d24c.js";import{d as l,f as r,c as d}from"./a11y.tipps-76f7d989.js";import{L as h}from"./dev.utils-b86b7cfe.js";import{s as u,e as c,c as b,k as p}from"./prop.validators-17590a9e.js";import"./index-5c4aa7d8.js";import"./reuse-d79ab469.js";const f="/*\n * This file contains all rules for accessibility.\n */\n@layer kol-global {\n\t:host {\n\t\t/*\n\t\t * Minimum size of interactive elements.\n\t\t */\n\t\t--a11y-min-size: 44px;\n\t\t/*\n\t\t * No element should be used without a background and font color whose contrast ratio has\n\t\t * not been checked. By initially setting the background color to white and the font color\n\t\t * to black, the contrast ratio is ensured and explicit adjustment is forced.\n\t\t */\n\t\tbackground-color: white;\n\t\tcolor: black;\n\t\t/*\n\t\t * Verdana is an accessible font that can be used without requiring additional loading time.\n\t\t */\n\t\tfont-family: Verdana;\n\t}\n\n\t* {\n\t\t/*\n\t\t * This rule enables the word dividing for all texts. That is important for high zoom levels.\n\t\t */\n\t\thyphens: auto;\n\t\t/*\n\t\t * Letter spacing is required for all texts.\n\t\t */\n\t\tletter-spacing: inherit;\n\t\t/*\n\t\t * This rule enables the word dividing for all texts. That is important for high zoom levels.\n\t\t */\n\t\tword-break: break-word;\n\t\t/*\n\t\t * Word spacing is required for all texts.\n\t\t */\n\t\tword-spacing: inherit;\n\t}\n\n\t/*\n\t * All interactive elements should have a minimum size of 44px.\n\t */\n\t/* input:not([type='checkbox'], [type='radio'], [type='range']), */\n\t/* option, */\n\t/* select, */\n\t/* textarea, */\n\t[role='button'],\n\tbutton:not([role='link']),\n\tkol-input .input {\n\t\tmin-height: var(--a11y-min-size);\n\t\tmin-width: var(--a11y-min-size);\n\t}\n\n\t/*\n\t * Some interactive elements should not inherit the font-family and font-size.\n\t */\n\ta,\n\tbutton,\n\th1,\n\th2,\n\th3,\n\th4,\n\th5,\n\th6,\n\tinput,\n\toption,\n\tselect,\n\ttextarea {\n\t\t/*\n\t\t * All elements should inherit the font family from his parent element.\n\t\t */\n\t\tfont-family: inherit;\n\t\t/*\n\t\t * All elements should inherit the font size from his parent element.\n\t\t */\n\t\tfont-size: inherit;\n\t}\n}\n\n/**\n * Sometimes we need the semantic element for accessibility reasons,\n * but we don't want to show it.\n *\n * - https://www.a11yproject.com/posts/how-to-hide-content/\n */\n.visually-hidden {\n\tclip: rect(0 0 0 0);\n\tclip-path: inset(50%);\n\theight: 1px;\n\toverflow: hidden;\n\tposition: absolute;\n\twhite-space: nowrap;\n\twidth: 1px;\n}\n\n@layer kol-global {\n\t/*\n\t * Dieses CSS stellt sicher, dass der Standard-Style\n\t * von A und Button resettet werden.\n\t */\n\t:is(a, button) {\n\t\tbackground-color: transparent;\n\t\tborder: none;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\twidth: 100%; /* 100% needed for custom width from outside */\n\t}\n\n\t/*\n\t * Ensure elements with hidden attribute to be actually not visible\n\t * @see https://meowni.ca/hidden.is.a.lie.html\n\t */\n\t[hidden] {\n\t\tdisplay: none !important;\n\t}\n}\n\n@layer kol-global {\n\t:host {\n\t\t/*\n\t\t * The max-width is needed to prevent the table from overflowing the\n\t\t * parent node, if the table is wider than the parent node.\n\t\t */\n\t\tmax-width: 100%;\n\t}\n\n\t* {\n\t\t/*\n\t\t * We prefer to box-sizing: border-box for all elements.\n\t\t */\n\t\tbox-sizing: border-box;\n\t}\n\n\t/* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n\tkol-span-wc {\n\t\tdisplay: grid;\n\t\tplace-items: center;\n\t}\n\n\t/* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n\tkol-span-wc > span {\n\t\tdisplay: flex;\n\t\tplace-items: center;\n\t}\n\n\ta,\n\tbutton {\n\t\tcursor: pointer;\n\t}\n\n\t/* This is the text label. */\n\t.icon-only > kol-span-wc > span > span {\n\t\tdisplay: none;\n\t}\n}\n\n@layer kol-component {\n\t:host {\n\t\tdisplay: block;\n\t}\n}\n\n@layer kol-component {\n\tkol-button-group-wc {\n\t\tdisplay: inline-flex;\n\t\tflex-wrap: wrap;\n\t}\n\n\tkol-button-group-wc button {\n\t\tborder-bottom-color: transparent;\n\t\tborder-bottom-style: solid;\n\t\tdisplay: block;\n\t}\n\n\tdiv.grid,\n\tdiv[role='tabpanel'] {\n\t\theight: 100%;\n\t}\n\n\t:host > .tabs-align-right {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: 1fr auto;\n\t}\n\n\t:host > .tabs-align-right kol-button-group-wc {\n\t\tdisplay: grid;\n\t\torder: 2;\n\t}\n\n\t:host > .tabs-align-left {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: auto 1fr;\n\t}\n\n\t:host > .tabs-align-left kol-button-group-wc {\n\t\tdisplay: grid;\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-bottom {\n\t\tdisplay: grid;\n\t\tgrid-template-rows: 1fr auto;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc {\n\t\torder: 2;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc > div {\n\t\tdisplay: flex;\n\t}\n\n\t:host > .tabs-align-bottom > kol-button-group-wc > div > div:first-child {\n\t\tmargin: 0 1em 0 0;\n\t}\n\n\t:host > .tabs-align-bottom > kol-button-group-wc > div > div {\n\t\tmargin: 0 1em;\n\t}\n\n\t:host > .tabs-align-top {\n\t\tdisplay: grid;\n\t\tgrid-template-rows: auto 1fr;\n\t}\n\n\t:host > .tabs-align-top kol-button-group-wc {\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-top kol-button-group-wc > div {\n\t\tdisplay: flex;\n\t}\n\n\t:host > .tabs-align-top > kol-button-group-wc > div > div:first-child {\n\t\tmargin: 0 1em 0 0;\n\t}\n\n\t:host > .tabs-align-top > kol-button-group-wc > div > div {\n\t\tmargin: 0 1em;\n\t}\n\n\t:host > div {\n\t\tdisplay: grid;\n\t}\n\n\t:host > .tabs-align-left kol-button-group-wc,\n\t:host > .tabs-align-top kol-button-group-wc {\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc,\n\t:host > .tabs-align-right kol-button-group-wc {\n\t\torder: 1;\n\t}\n\n\t:host > div.tabs-align-left kol-button-group-wc > div,\n\t:host > div.tabs-align-left kol-button-group-wc > div > div,\n\t:host > div.tabs-align-right kol-button-group-wc > div,\n\t:host > div.tabs-align-right kol-button-group-wc > div > div {\n\t\tdisplay: grid;\n\t}\n\n\t:host > div.tabs-align-left kol-button-group-wc > div > div kol-button-wc,\n\t:host > div.tabs-align-right kol-button-group-wc > div > div kol-button-wc {\n\t\twidth: 100%;\n\t}\n\n\t:host > div.tabs-align-bottom kol-button-group-wc div,\n\t:host > div.tabs-align-top kol-button-group-wc div {\n\t\tdisplay: flex;\n\t\tflex-wrap: wrap;\n\t}\n}\n",g=class{constructor(n){t(this,n),this.onCreateLabel=`${o("kol-new")} …`,this.showCreateTab=!1,this.nextPossibleTabIndex=(t,n,e)=>{if(e>0){if(n+e<t.length)return t[n+e]._disabled?this.nextPossibleTabIndex(t,n,e+1):n+e}else if(e<0&&n+e>=0)return t[n+e]._disabled?this.nextPossibleTabIndex(t,n,e-1):n+e;return n},this.onKeyDown=t=>{const n=setTimeout((()=>{clearTimeout(n);let e=null;switch(t.key){case"ArrowRight":e=this.nextPossibleTabIndex(this.state._tabs,this.state._selected,1);break;case"ArrowLeft":e=this.nextPossibleTabIndex(this.state._tabs,this.state._selected,-1)}null!==e&&this.onSelect(t,e,!0)}),250)},this.onClickSelect=(t,n)=>{this.onSelect(t,n,!0)},this.onMouseDown=t=>{t.preventDefault(),t.stopPropagation()},this.callbacks={onClick:this.onClickSelect,onMouseDown:this.onMouseDown},this.catchTabPanelHost=t=>{this.tabPanelHost=t},this.selectNextNotDisabledTab=(t,n,e=!0,i)=>{if(t>n.length-1&&(t=n.length-1),t<0&&(t=0),Array.isArray(n)&&n[t]&&n[t]._disabled){if(!0===e){if(t<n.length-1)return this.selectNextNotDisabledTab(t+1,n,!0,i||t);t=i||t,e=!1}if(!1===e){if(t>0)return this.selectNextNotDisabledTab(t-1,n,!1,i||t);l("[KolTabs] Alle Tabs sind deaktiviert und somit kann kein Tab angezeigt werden.")}}return t},this.syncSelectedAndTabs=(t,n,e,i)=>{let o,a;o="_selected"===i?t:this.state._selected,a="_tabs"===i?t:this.state._tabs,a.length>0&&n.set("_selected",this.selectNextNotDisabledTab(o,a))},this.handleTabPanels=()=>{var t,n,e;if(this.tabPanelHost instanceof HTMLDivElement)for(let i=this.tabPanelHost.children.length;i<this.state._tabs.length;i++){const o=document.createElement("div");o.setAttribute("aria-labelledby",`${this.state._label.replace(/\s/g,"-")}-tab-${i}`),o.setAttribute("id",`tabpanel-${i}`),o.setAttribute("role","tabpanel"),o.setAttribute("hidden","");const a=document.createElement("slot");a.setAttribute("name",`tabpanel-slot-${i}`),o.appendChild(a),this.tabPanelHost.appendChild(o),(null===(t=this.host)||void 0===t?void 0:t.children)instanceof HTMLCollection&&(null===(n=this.host)||void 0===n?void 0:n.children[i])&&(null===(e=this.host)||void 0===e||e.children[i].setAttribute("slot",`tabpanel-slot-${i}`))}},this.onCreate=t=>{var n,e;t.preventDefault(),t.stopPropagation(),"function"==typeof(null===(n=this.state._on)||void 0===n?void 0:n.onCreate)&&(null===(e=this.state._on)||void 0===e||e.onCreate(t))},this._align="top",this._label=void 0,this._on=void 0,this._selected=0,this._tabs=void 0,this.state={_align:"top",_label:"…",_selected:0,_tabs:[]}}renderButtonGroup(){return n("kol-button-group-wc",{class:"tabs-button-group",role:"tablist","aria-label":this.state._label,onKeyDown:this.onKeyDown},this.state._tabs.map(((t,e)=>n("kol-button-wc",{_disabled:t._disabled,_icons:t._icons,_hideLabel:t._hideLabel,_label:t._label,_on:this.callbacks,_tabIndex:this.state._selected===e?0:-1,_tooltipAlign:t._tooltipAlign,_variant:this.state._selected===e?"custom":void 0,_customClass:this.state._selected===e?"selected":void 0,_ariaControls:`tabpanel-${e}`,_ariaSelected:this.state._selected===e,_id:`${this.state._label.replace(/\s/g,"-")}-tab-${e}`,_role:"tab",_value:e}))),this.showCreateTab&&n("kol-button-wc",{class:"create-button",_label:this.onCreateLabel,_on:{onClick:this.onCreate}}))}render(){return n(i,null,n("div",{ref:t=>{this.tabPanelsElement=t},class:{[`tabs-align-${this.state._align}`]:!0}},this.renderButtonGroup(),n("div",{class:"tabs-content",ref:this.catchTabPanelHost})))}validateAlign(t){s(this,t)}validateLabel(t){a(this,t)}validateOn(t){if("object"==typeof t&&null!==t){r("[KolTabs] Prüfen, wie man auch einen EventCallback einzeln ändern kann.");const n={};"function"!=typeof t.onCreate&&"object"!=typeof t.onCreate||("object"==typeof t.onCreate?("string"==typeof t.onCreate.label&&t.onCreate.label.length>0?this.onCreateLabel=t.onCreate.label:h.debug("[KolTabs] Der Label-Text für Neu in {\n onCreate: {\n label: string (!),\n callback: Function\n }\n} ist nicht korrekt gesetzt."),"function"==typeof t.onCreate.callback?n.onCreate=t.onCreate.callback:h.debug("[KolTabs] Die onCreate-Callback-Funktion für Neu in {\n onCreate: {\n label: string,\n callback: Function (!)\n }\n} ist nicht korrekt gesetzt.")):n.onCreate=t.onCreate,this.showCreateTab="function"==typeof n.onCreate),"function"==typeof t.onSelect&&(n.onSelect=t.onSelect),u(this,"_on",n)}}validateSelected(t){c(this,"_selected",t,{hooks:{beforePatch:this.syncSelectedAndTabs}})}validateTabs(t){b(this,"_tabs",(t=>"object"==typeof t&&null!==t&&"string"==typeof t._label&&t._label.length>0),t,void 0,{hooks:{beforePatch:this.syncSelectedAndTabs}}),d("KolTabs",this.state._tabs.length)}componentWillLoad(){this.validateAlign(this._align),this.validateLabel(this._label),this.validateOn(this._on),this.validateSelected(this._selected),this.validateTabs(this._tabs)}componentDidRender(){if(this.handleTabPanels(),this.tabPanelHost instanceof HTMLDivElement)for(let t=0;t<this.tabPanelHost.children.length;t++)t!==this.state._selected?this.tabPanelHost.children[t].setAttribute("hidden",""):this.tabPanelHost.children[t].removeAttribute("hidden")}onSelect(t,n,e=!1){var i,o;this._selected=n,"function"==typeof(null===(i=this._on)||void 0===i?void 0:i.onSelect)&&(null===(o=this._on)||void 0===o||o.onSelect(t,n)),!0===e&&(this.selectedTimeout=setTimeout((()=>{if(clearTimeout(this.selectedTimeout),this.tabPanelsElement){const t=p(`button#${this.state._label.replace(/\s/g,"-")}-tab-${n}`,this.tabPanelsElement);null==t||t.focus()}}),250))}get host(){return e(this)}static get watchers(){return{_align:["validateAlign"],_label:["validateLabel"],_on:["validateOn"],_selected:["validateSelected"],_tabs:["validateTabs"]}}};g.style={default:f};export{g as kol_tabs};
@@ -1 +1 @@
1
- {"version":3,"names":["defaultStyleCss","KolTabs","this","onCreateLabel","translate","showCreateTab","nextPossibleTabIndex","tabs","offset","step","length","_disabled","onKeyDown","event","timeout","setTimeout","clearTimeout","selectedIndex","key","state","_tabs","_selected","onSelect","onClickSelect","index","onMouseDown","preventDefault","stopPropagation","callbacks","onClick","catchTabPanelHost","el","tabPanelHost","selectNextNotDisabledTab","selected","upOrDown","initialSelected","Array","isArray","devHint","syncSelectedAndTabs","nextValue","nextState","_component","set","handleTabPanels","HTMLDivElement","i","children","div","document","createElement","setAttribute","_label","replace","slot","appendChild","_a","host","HTMLCollection","_b","_c","onCreate","_on","_align","renderButtonGroup","h","role","map","button","_icons","_hideLabel","_tabIndex","_tooltipAlign","_variant","undefined","_customClass","_ariaControls","_ariaSelected","_id","_role","_value","class","render","Host","ref","tabPanelsElement","validateAlign","value","validateLabel","validateOn","featureHint","label","Log","debug","callback","setState","validateSelected","watchNumber","hooks","beforePatch","validateTabs","watchJsonArrayString","item","uiUxHintMillerscheZahl","componentWillLoad","componentDidRender","removeAttribute","focus","selectedTimeout","koliBriQuerySelector"],"sources":["src/components/tabs/style.css?tag=kol-tabs&mode=default&encapsulation=shadow","src/components/tabs/component.tsx"],"sourcesContent":["@import url(../style.css);\n@import url(../host-display-block.css);\n@layer kol-component {\n\tkol-button-group-wc {\n\t\tdisplay: inline-flex;\n\t\tflex-wrap: wrap;\n\t}\n\n\tkol-button-group-wc button {\n\t\tborder-bottom-color: transparent;\n\t\tborder-bottom-style: solid;\n\t\tdisplay: block;\n\t}\n\n\tdiv.grid,\n\tdiv[role='tabpanel'] {\n\t\theight: 100%;\n\t}\n\n\t:host > .tabs-align-right {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: 1fr auto;\n\t}\n\n\t:host > .tabs-align-right kol-button-group-wc {\n\t\tdisplay: grid;\n\t\torder: 2;\n\t}\n\n\t:host > .tabs-align-left {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: auto 1fr;\n\t}\n\n\t:host > .tabs-align-left kol-button-group-wc {\n\t\tdisplay: grid;\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-bottom {\n\t\tdisplay: grid;\n\t\tgrid-template-rows: 1fr auto;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc {\n\t\torder: 2;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc > div {\n\t\tdisplay: flex;\n\t}\n\n\t:host > .tabs-align-bottom > kol-button-group-wc > div > div:first-child {\n\t\tmargin: 0 1em 0 0;\n\t}\n\n\t:host > .tabs-align-bottom > kol-button-group-wc > div > div {\n\t\tmargin: 0 1em;\n\t}\n\n\t:host > .tabs-align-top {\n\t\tdisplay: grid;\n\t\tgrid-template-rows: auto 1fr;\n\t}\n\n\t:host > .tabs-align-top kol-button-group-wc {\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-top kol-button-group-wc > div {\n\t\tdisplay: flex;\n\t}\n\n\t:host > .tabs-align-top > kol-button-group-wc > div > div:first-child {\n\t\tmargin: 0 1em 0 0;\n\t}\n\n\t:host > .tabs-align-top > kol-button-group-wc > div > div {\n\t\tmargin: 0 1em;\n\t}\n\n\t:host > div {\n\t\tdisplay: grid;\n\t}\n\n\t:host > .tabs-align-left kol-button-group-wc,\n\t:host > .tabs-align-top kol-button-group-wc {\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc,\n\t:host > .tabs-align-right kol-button-group-wc {\n\t\torder: 1;\n\t}\n\n\t:host > div.tabs-align-left kol-button-group-wc > div,\n\t:host > div.tabs-align-left kol-button-group-wc > div > div,\n\t:host > div.tabs-align-right kol-button-group-wc > div,\n\t:host > div.tabs-align-right kol-button-group-wc > div > div {\n\t\tdisplay: grid;\n\t}\n\n\t:host > div.tabs-align-left kol-button-group-wc > div > div kol-button-wc,\n\t:host > div.tabs-align-right kol-button-group-wc > div > div kol-button-wc {\n\t\twidth: 100%;\n\t}\n\n\t:host > div.tabs-align-bottom kol-button-group-wc div,\n\t:host > div.tabs-align-top kol-button-group-wc div {\n\t\tdisplay: flex;\n\t\tflex-wrap: wrap;\n\t}\n}\n","import { Generic } from '@a11y-ui/core';\nimport { Component, Element, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\nimport { Stringified } from '../../types/common';\nimport { AlignPropType, validateAlign } from '../../types/props/align';\nimport { ButtonCallbacksPropType } from '../../types/props/button-callbacks';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { StencilUnknown } from '../../types/unknown';\nimport { devHint, featureHint, uiUxHintMillerscheZahl } from '../../utils/a11y.tipps';\nimport { Log } from '../../utils/dev.utils';\nimport { koliBriQuerySelector, setState, watchJsonArrayString, watchNumber } from '../../utils/prop.validators';\nimport { API, KoliBriTabsCallbacks, States, TabButtonProps } from './types';\n\n// https://www.w3.org/TR/wai-aria-practices-1.1/examples/tabs/tabs-2/tabs.html\n\n@Component({\n\ttag: 'kol-tabs',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolTabs implements API {\n\t@Element() private readonly host?: HTMLKolTabsElement;\n\tprivate tabPanelsElement?: HTMLElement;\n\tprivate onCreateLabel = `${translate('kol-new')} …`;\n\tprivate showCreateTab = false;\n\tprivate selectedTimeout?: ReturnType<typeof setTimeout>;\n\n\tprivate nextPossibleTabIndex = (tabs: TabButtonProps[], offset: number, step: number): number => {\n\t\tif (step > 0) {\n\t\t\tif (offset + step < tabs.length) {\n\t\t\t\tif (tabs[offset + step]._disabled) {\n\t\t\t\t\treturn this.nextPossibleTabIndex(tabs, offset, step + 1);\n\t\t\t\t}\n\t\t\t\treturn offset + step;\n\t\t\t}\n\t\t} else if (step < 0) {\n\t\t\tif (offset + step >= 0) {\n\t\t\t\tif (tabs[offset + step]._disabled) {\n\t\t\t\t\treturn this.nextPossibleTabIndex(tabs, offset, step - 1);\n\t\t\t\t}\n\t\t\t\treturn offset + step;\n\t\t\t}\n\t\t}\n\t\treturn offset;\n\t};\n\n\tprivate onKeyDown = (event: KeyboardEvent) => {\n\t\tconst timeout = setTimeout(() => {\n\t\t\tclearTimeout(timeout);\n\t\t\tlet selectedIndex: number | null = null;\n\t\t\tswitch (event.key) {\n\t\t\t\tcase 'ArrowRight':\n\t\t\t\t\tselectedIndex = this.nextPossibleTabIndex(this.state._tabs, this.state._selected, 1);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'ArrowLeft':\n\t\t\t\t\tselectedIndex = this.nextPossibleTabIndex(this.state._tabs, this.state._selected, -1);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif (selectedIndex !== null) {\n\t\t\t\tthis.onSelect(event, selectedIndex, true);\n\t\t\t}\n\t\t}, 250);\n\t};\n\n\tprivate readonly onClickSelect = (event: MouseEvent, index: number): void => {\n\t\tthis.onSelect(event, index, true);\n\t};\n\n\t// private readonly onClickClose = (event: Event, button: TabButtonProps, index: number) => {\n\t// \tevent.preventDefault();\n\t// \tevent.stopPropagation();\n\t// \tthis.onClose(button, event, index);\n\t// };\n\n\tprivate readonly onMouseDown = (event: Event): void => {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t};\n\n\tprivate readonly callbacks: ButtonCallbacksPropType<number> = {\n\t\tonClick: this.onClickSelect,\n\t\tonMouseDown: this.onMouseDown,\n\t};\n\n\tprivate renderButtonGroup() {\n\t\treturn (\n\t\t\t<kol-button-group-wc role=\"tablist\" aria-label={this.state._label} onKeyDown={this.onKeyDown}>\n\t\t\t\t{this.state._tabs.map((button: TabButtonProps, index: number) => (\n\t\t\t\t\t<kol-button-wc\n\t\t\t\t\t\t_disabled={button._disabled}\n\t\t\t\t\t\t_icons={button._icons}\n\t\t\t\t\t\t_hideLabel={button._hideLabel}\n\t\t\t\t\t\t_label={button._label} // TODO: ariaLabel-Konzept prüfen\n\t\t\t\t\t\t_on={this.callbacks as ButtonCallbacksPropType<StencilUnknown>}\n\t\t\t\t\t\t_tabIndex={this.state._selected === index ? 0 : -1}\n\t\t\t\t\t\t_tooltipAlign={button._tooltipAlign}\n\t\t\t\t\t\t_variant={this.state._selected === index ? 'custom' : undefined}\n\t\t\t\t\t\t_customClass={this.state._selected === index ? 'selected' : undefined}\n\t\t\t\t\t\t_ariaControls={`tabpanel-${index}`}\n\t\t\t\t\t\t_ariaSelected={this.state._selected === index}\n\t\t\t\t\t\t_id={`${this.state._label.replace(/\\s/g, '-')}-tab-${index}`}\n\t\t\t\t\t\t_role=\"tab\"\n\t\t\t\t\t\t_value={index}\n\t\t\t\t\t></kol-button-wc>\n\t\t\t\t))}\n\t\t\t\t{this.showCreateTab && (\n\t\t\t\t\t<kol-button-wc\n\t\t\t\t\t\tclass=\"create-button\"\n\t\t\t\t\t\t_label={this.onCreateLabel}\n\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\tonClick: this.onCreate,\n\t\t\t\t\t\t}}\n\t\t\t\t\t></kol-button-wc>\n\t\t\t\t)}\n\t\t\t</kol-button-group-wc>\n\t\t);\n\t}\n\n\tprivate tabPanelHost?: HTMLDivElement;\n\n\tprivate readonly catchTabPanelHost = (el?: HTMLDivElement) => {\n\t\tthis.tabPanelHost = el;\n\t};\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t<div\n\t\t\t\t\tref={(el) => {\n\t\t\t\t\t\tthis.tabPanelsElement = el as HTMLElement;\n\t\t\t\t\t}}\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[`tabs-align-${this.state._align}`]: true,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t{this.renderButtonGroup()}\n\t\t\t\t\t<div ref={this.catchTabPanelHost}>{/* <slot /> */}</div>\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Defines the position of the tab captions.\n\t */\n\t@Prop() public _align?: AlignPropType = 'top';\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: LabelPropType;\n\n\t/**\n\t * Gibt die Liste der Callback-Funktionen an, die auf Events aufgerufen werden sollen.\n\t */\n\t@Prop() public _on?: KoliBriTabsCallbacks;\n\n\t/**\n\t * Defines which tab is active.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _selected?: number = 0;\n\n\t/**\n\t * Defines the tab captions.\n\t */\n\t@Prop() public _tabs!: Stringified<TabButtonProps[]>;\n\n\t@State() public state: States = {\n\t\t_align: 'top',\n\t\t_label: '…', // ⚠ required\n\t\t_selected: 0,\n\t\t_tabs: [],\n\t};\n\n\tprivate selectNextNotDisabledTab = (selected: number, tabs: TabButtonProps[], upOrDown = true, initialSelected?: number): number => {\n\t\tif (selected > tabs.length - 1) {\n\t\t\tselected = tabs.length - 1;\n\t\t}\n\t\tif (selected < 0) {\n\t\t\tselected = 0;\n\t\t}\n\t\tif (Array.isArray(tabs) && tabs[selected]) {\n\t\t\tif (tabs[selected]._disabled) {\n\t\t\t\tif (upOrDown === true) {\n\t\t\t\t\tif (selected < tabs.length - 1) {\n\t\t\t\t\t\treturn this.selectNextNotDisabledTab(selected + 1, tabs, true, initialSelected || selected);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tselected = initialSelected || selected;\n\t\t\t\t\t\tupOrDown = false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (upOrDown === false) {\n\t\t\t\t\tif (selected > 0) {\n\t\t\t\t\t\treturn this.selectNextNotDisabledTab(selected - 1, tabs, false, initialSelected || selected);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdevHint(`[KolTabs] Alle Tabs sind deaktiviert und somit kann kein Tab angezeigt werden.`);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn selected;\n\t};\n\n\tprivate syncSelectedAndTabs = (nextValue: unknown, nextState: Map<string, unknown>, _component: Generic.Element.Component, key: string) => {\n\t\tlet selected: number;\n\t\tif (key === '_selected') {\n\t\t\tselected = nextValue as number;\n\t\t} else {\n\t\t\tselected = this.state._selected;\n\t\t}\n\t\tlet tabs: TabButtonProps[];\n\t\tif (key === '_tabs') {\n\t\t\ttabs = nextValue as TabButtonProps[];\n\t\t} else {\n\t\t\ttabs = this.state._tabs;\n\t\t}\n\t\tif (tabs.length > 0) {\n\t\t\tnextState.set('_selected', this.selectNextNotDisabledTab(selected, tabs));\n\t\t}\n\t};\n\n\t@Watch('_align')\n\tpublic validateAlign(value?: AlignPropType) {\n\t\tvalidateAlign(this, value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value);\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: KoliBriTabsCallbacks): 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: KoliBriTabsCallbacks = {};\n\t\t\tif (typeof value.onCreate === 'function' || typeof value.onCreate === 'object') {\n\t\t\t\tif (typeof value.onCreate === 'object') {\n\t\t\t\t\tif (typeof value.onCreate.label === 'string' && value.onCreate.label.length > 0) {\n\t\t\t\t\t\tthis.onCreateLabel = value.onCreate.label;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tLog.debug(\n\t\t\t\t\t\t\t`[KolTabs] Der Label-Text für Neu in {\n onCreate: {\n label: string (!),\n callback: Function\n }\n} ist nicht korrekt gesetzt.`\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t\tif (typeof value.onCreate.callback === 'function') {\n\t\t\t\t\t\tcallbacks.onCreate = value.onCreate.callback;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tLog.debug(\n\t\t\t\t\t\t\t`[KolTabs] Die onCreate-Callback-Funktion für Neu in {\n onCreate: {\n label: string,\n callback: Function (!)\n }\n} ist nicht korrekt gesetzt.`\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tcallbacks.onCreate = value.onCreate;\n\t\t\t\t}\n\t\t\t\tthis.showCreateTab = typeof callbacks.onCreate === 'function';\n\t\t\t}\n\t\t\tif (typeof value.onSelect === 'function') {\n\t\t\t\tcallbacks.onSelect = value.onSelect;\n\t\t\t}\n\t\t\tsetState<KoliBriTabsCallbacks>(this, '_on', callbacks);\n\t\t}\n\t}\n\n\t@Watch('_selected')\n\tpublic validateSelected(value?: number): void {\n\t\twatchNumber(this, '_selected', value, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: this.syncSelectedAndTabs,\n\t\t\t},\n\t\t});\n\t}\n\n\t@Watch('_tabs')\n\tpublic validateTabs(value?: Stringified<TabButtonProps[]>): void {\n\t\twatchJsonArrayString(\n\t\t\tthis,\n\t\t\t'_tabs',\n\t\t\t(item: TabButtonProps) => typeof item === 'object' && item !== null && typeof item._label === 'string' && item._label.length > 0,\n\t\t\tvalue,\n\t\t\tundefined,\n\t\t\t{\n\t\t\t\thooks: {\n\t\t\t\t\tbeforePatch: this.syncSelectedAndTabs,\n\t\t\t\t},\n\t\t\t}\n\t\t);\n\t\tuiUxHintMillerscheZahl('KolTabs', this.state._tabs.length);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAlign(this._align);\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateOn(this._on);\n\t\tthis.validateSelected(this._selected);\n\t\tthis.validateTabs(this._tabs);\n\t}\n\n\tprivate readonly handleTabPanels = () => {\n\t\tif (this.tabPanelHost instanceof HTMLDivElement) {\n\t\t\tfor (let i = this.tabPanelHost.children.length; i < this.state._tabs.length; i++) {\n\t\t\t\tconst div = document.createElement('div');\n\t\t\t\tdiv.setAttribute('aria-labelledby', `${this.state._label.replace(/\\s/g, '-')}-tab-${i}`);\n\t\t\t\tdiv.setAttribute('id', `tabpanel-${i}`);\n\t\t\t\tdiv.setAttribute('role', 'tabpanel');\n\t\t\t\tdiv.setAttribute('hidden', '');\n\t\t\t\tconst slot = document.createElement('slot');\n\t\t\t\tslot.setAttribute('name', `tabpanel-slot-${i}`);\n\t\t\t\tdiv.appendChild(slot);\n\t\t\t\tthis.tabPanelHost.appendChild(div);\n\t\t\t\tif (this.host?.children instanceof HTMLCollection && this.host?.children[i] /* SSR instanceof HTMLElement */) {\n\t\t\t\t\t// div.appendChild(this.host?.children[0]);\n\t\t\t\t\tthis.host?.children[i].setAttribute('slot', `tabpanel-slot-${i}`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n\n\tpublic componentDidRender(): void {\n\t\tthis.handleTabPanels();\n\t\tif (this.tabPanelHost instanceof HTMLDivElement) {\n\t\t\tfor (let i = 0; i < this.tabPanelHost.children.length; i++) {\n\t\t\t\tif (i !== this.state._selected) {\n\t\t\t\t\tthis.tabPanelHost.children[i].setAttribute('hidden', '');\n\t\t\t\t} else {\n\t\t\t\t\tthis.tabPanelHost.children[i].removeAttribute('hidden');\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate onSelect(event: CustomEvent | KeyboardEvent | MouseEvent | PointerEvent, index: number, focus = false): void {\n\t\tthis._selected = index;\n\t\tif (typeof this._on?.onSelect === 'function') {\n\t\t\tthis._on?.onSelect(event, index);\n\t\t}\n\t\tif (focus === true) {\n\t\t\t// TODO: prüfen, ob hier noch was offen ist\n\t\t\t// devHint('[KolTabs] Tab-Fokus-verschieben geht im Moment nicht.');\n\t\t\tthis.selectedTimeout = setTimeout(() => {\n\t\t\t\tclearTimeout(this.selectedTimeout);\n\t\t\t\tif (this.tabPanelsElement /* SSR instanceof HTMLElement */) {\n\t\t\t\t\tconst button: HTMLElement | null = koliBriQuerySelector(`button#${this.state._label.replace(/\\s/g, '-')}-tab-${index}`, this.tabPanelsElement);\n\t\t\t\t\tbutton?.focus();\n\t\t\t\t}\n\t\t\t}, 250);\n\t\t}\n\t}\n\n\tprivate onCreate = (event: Event) => {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\tif (typeof this.state._on?.onCreate === 'function') {\n\t\t\tthis.state._on?.onCreate(event);\n\t\t}\n\t};\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["defaultStyleCss","KolTabs","this","onCreateLabel","translate","showCreateTab","nextPossibleTabIndex","tabs","offset","step","length","_disabled","onKeyDown","event","timeout","setTimeout","clearTimeout","selectedIndex","key","state","_tabs","_selected","onSelect","onClickSelect","index","onMouseDown","preventDefault","stopPropagation","callbacks","onClick","catchTabPanelHost","el","tabPanelHost","selectNextNotDisabledTab","selected","upOrDown","initialSelected","Array","isArray","devHint","syncSelectedAndTabs","nextValue","nextState","_component","set","handleTabPanels","HTMLDivElement","i","children","div","document","createElement","setAttribute","_label","replace","slot","appendChild","_a","host","HTMLCollection","_b","_c","onCreate","_on","_align","renderButtonGroup","h","class","role","map","button","_icons","_hideLabel","_tabIndex","_tooltipAlign","_variant","undefined","_customClass","_ariaControls","_ariaSelected","_id","_role","_value","render","Host","ref","tabPanelsElement","validateAlign","value","validateLabel","validateOn","featureHint","label","Log","debug","callback","setState","validateSelected","watchNumber","hooks","beforePatch","validateTabs","watchJsonArrayString","item","uiUxHintMillerscheZahl","componentWillLoad","componentDidRender","removeAttribute","focus","selectedTimeout","koliBriQuerySelector"],"sources":["src/components/tabs/style.css?tag=kol-tabs&mode=default&encapsulation=shadow","src/components/tabs/component.tsx"],"sourcesContent":["@import url(../style.css);\n@import url(../host-display-block.css);\n@layer kol-component {\n\tkol-button-group-wc {\n\t\tdisplay: inline-flex;\n\t\tflex-wrap: wrap;\n\t}\n\n\tkol-button-group-wc button {\n\t\tborder-bottom-color: transparent;\n\t\tborder-bottom-style: solid;\n\t\tdisplay: block;\n\t}\n\n\tdiv.grid,\n\tdiv[role='tabpanel'] {\n\t\theight: 100%;\n\t}\n\n\t:host > .tabs-align-right {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: 1fr auto;\n\t}\n\n\t:host > .tabs-align-right kol-button-group-wc {\n\t\tdisplay: grid;\n\t\torder: 2;\n\t}\n\n\t:host > .tabs-align-left {\n\t\tdisplay: grid;\n\t\tgrid-template-columns: auto 1fr;\n\t}\n\n\t:host > .tabs-align-left kol-button-group-wc {\n\t\tdisplay: grid;\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-bottom {\n\t\tdisplay: grid;\n\t\tgrid-template-rows: 1fr auto;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc {\n\t\torder: 2;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc > div {\n\t\tdisplay: flex;\n\t}\n\n\t:host > .tabs-align-bottom > kol-button-group-wc > div > div:first-child {\n\t\tmargin: 0 1em 0 0;\n\t}\n\n\t:host > .tabs-align-bottom > kol-button-group-wc > div > div {\n\t\tmargin: 0 1em;\n\t}\n\n\t:host > .tabs-align-top {\n\t\tdisplay: grid;\n\t\tgrid-template-rows: auto 1fr;\n\t}\n\n\t:host > .tabs-align-top kol-button-group-wc {\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-top kol-button-group-wc > div {\n\t\tdisplay: flex;\n\t}\n\n\t:host > .tabs-align-top > kol-button-group-wc > div > div:first-child {\n\t\tmargin: 0 1em 0 0;\n\t}\n\n\t:host > .tabs-align-top > kol-button-group-wc > div > div {\n\t\tmargin: 0 1em;\n\t}\n\n\t:host > div {\n\t\tdisplay: grid;\n\t}\n\n\t:host > .tabs-align-left kol-button-group-wc,\n\t:host > .tabs-align-top kol-button-group-wc {\n\t\torder: 0;\n\t}\n\n\t:host > .tabs-align-bottom kol-button-group-wc,\n\t:host > .tabs-align-right kol-button-group-wc {\n\t\torder: 1;\n\t}\n\n\t:host > div.tabs-align-left kol-button-group-wc > div,\n\t:host > div.tabs-align-left kol-button-group-wc > div > div,\n\t:host > div.tabs-align-right kol-button-group-wc > div,\n\t:host > div.tabs-align-right kol-button-group-wc > div > div {\n\t\tdisplay: grid;\n\t}\n\n\t:host > div.tabs-align-left kol-button-group-wc > div > div kol-button-wc,\n\t:host > div.tabs-align-right kol-button-group-wc > div > div kol-button-wc {\n\t\twidth: 100%;\n\t}\n\n\t:host > div.tabs-align-bottom kol-button-group-wc div,\n\t:host > div.tabs-align-top kol-button-group-wc div {\n\t\tdisplay: flex;\n\t\tflex-wrap: wrap;\n\t}\n}\n","import { Generic } from '@a11y-ui/core';\nimport { Component, Element, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\nimport { Stringified } from '../../types/common';\nimport { AlignPropType, validateAlign } from '../../types/props/align';\nimport { ButtonCallbacksPropType } from '../../types/props/button-callbacks';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { StencilUnknown } from '../../types/unknown';\nimport { devHint, featureHint, uiUxHintMillerscheZahl } from '../../utils/a11y.tipps';\nimport { Log } from '../../utils/dev.utils';\nimport { koliBriQuerySelector, setState, watchJsonArrayString, watchNumber } from '../../utils/prop.validators';\nimport { API, KoliBriTabsCallbacks, States, TabButtonProps } from './types';\n\n// https://www.w3.org/TR/wai-aria-practices-1.1/examples/tabs/tabs-2/tabs.html\n\n@Component({\n\ttag: 'kol-tabs',\n\tstyleUrls: {\n\t\tdefault: './style.css',\n\t},\n\tshadow: true,\n})\nexport class KolTabs implements API {\n\t@Element() private readonly host?: HTMLKolTabsElement;\n\tprivate tabPanelsElement?: HTMLElement;\n\tprivate onCreateLabel = `${translate('kol-new')} …`;\n\tprivate showCreateTab = false;\n\tprivate selectedTimeout?: ReturnType<typeof setTimeout>;\n\n\tprivate nextPossibleTabIndex = (tabs: TabButtonProps[], offset: number, step: number): number => {\n\t\tif (step > 0) {\n\t\t\tif (offset + step < tabs.length) {\n\t\t\t\tif (tabs[offset + step]._disabled) {\n\t\t\t\t\treturn this.nextPossibleTabIndex(tabs, offset, step + 1);\n\t\t\t\t}\n\t\t\t\treturn offset + step;\n\t\t\t}\n\t\t} else if (step < 0) {\n\t\t\tif (offset + step >= 0) {\n\t\t\t\tif (tabs[offset + step]._disabled) {\n\t\t\t\t\treturn this.nextPossibleTabIndex(tabs, offset, step - 1);\n\t\t\t\t}\n\t\t\t\treturn offset + step;\n\t\t\t}\n\t\t}\n\t\treturn offset;\n\t};\n\n\tprivate onKeyDown = (event: KeyboardEvent) => {\n\t\tconst timeout = setTimeout(() => {\n\t\t\tclearTimeout(timeout);\n\t\t\tlet selectedIndex: number | null = null;\n\t\t\tswitch (event.key) {\n\t\t\t\tcase 'ArrowRight':\n\t\t\t\t\tselectedIndex = this.nextPossibleTabIndex(this.state._tabs, this.state._selected, 1);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'ArrowLeft':\n\t\t\t\t\tselectedIndex = this.nextPossibleTabIndex(this.state._tabs, this.state._selected, -1);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif (selectedIndex !== null) {\n\t\t\t\tthis.onSelect(event, selectedIndex, true);\n\t\t\t}\n\t\t}, 250);\n\t};\n\n\tprivate readonly onClickSelect = (event: MouseEvent, index: number): void => {\n\t\tthis.onSelect(event, index, true);\n\t};\n\n\t// private readonly onClickClose = (event: Event, button: TabButtonProps, index: number) => {\n\t// \tevent.preventDefault();\n\t// \tevent.stopPropagation();\n\t// \tthis.onClose(button, event, index);\n\t// };\n\n\tprivate readonly onMouseDown = (event: Event): void => {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t};\n\n\tprivate readonly callbacks: ButtonCallbacksPropType<number> = {\n\t\tonClick: this.onClickSelect,\n\t\tonMouseDown: this.onMouseDown,\n\t};\n\n\tprivate renderButtonGroup() {\n\t\treturn (\n\t\t\t<kol-button-group-wc class=\"tabs-button-group\" role=\"tablist\" aria-label={this.state._label} onKeyDown={this.onKeyDown}>\n\t\t\t\t{this.state._tabs.map((button: TabButtonProps, index: number) => (\n\t\t\t\t\t<kol-button-wc\n\t\t\t\t\t\t_disabled={button._disabled}\n\t\t\t\t\t\t_icons={button._icons}\n\t\t\t\t\t\t_hideLabel={button._hideLabel}\n\t\t\t\t\t\t_label={button._label} // TODO: ariaLabel-Konzept prüfen\n\t\t\t\t\t\t_on={this.callbacks as ButtonCallbacksPropType<StencilUnknown>}\n\t\t\t\t\t\t_tabIndex={this.state._selected === index ? 0 : -1}\n\t\t\t\t\t\t_tooltipAlign={button._tooltipAlign}\n\t\t\t\t\t\t_variant={this.state._selected === index ? 'custom' : undefined}\n\t\t\t\t\t\t_customClass={this.state._selected === index ? 'selected' : undefined}\n\t\t\t\t\t\t_ariaControls={`tabpanel-${index}`}\n\t\t\t\t\t\t_ariaSelected={this.state._selected === index}\n\t\t\t\t\t\t_id={`${this.state._label.replace(/\\s/g, '-')}-tab-${index}`}\n\t\t\t\t\t\t_role=\"tab\"\n\t\t\t\t\t\t_value={index}\n\t\t\t\t\t></kol-button-wc>\n\t\t\t\t))}\n\t\t\t\t{this.showCreateTab && (\n\t\t\t\t\t<kol-button-wc\n\t\t\t\t\t\tclass=\"create-button\"\n\t\t\t\t\t\t_label={this.onCreateLabel}\n\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\tonClick: this.onCreate,\n\t\t\t\t\t\t}}\n\t\t\t\t\t></kol-button-wc>\n\t\t\t\t)}\n\t\t\t</kol-button-group-wc>\n\t\t);\n\t}\n\n\tprivate tabPanelHost?: HTMLDivElement;\n\n\tprivate readonly catchTabPanelHost = (el?: HTMLDivElement) => {\n\t\tthis.tabPanelHost = el;\n\t};\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t<div\n\t\t\t\t\tref={(el) => {\n\t\t\t\t\t\tthis.tabPanelsElement = el as HTMLElement;\n\t\t\t\t\t}}\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[`tabs-align-${this.state._align}`]: true,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t{this.renderButtonGroup()}\n\t\t\t\t\t<div class=\"tabs-content\" ref={this.catchTabPanelHost}>\n\t\t\t\t\t\t{/* <slot /> */}\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Defines the position of the tab captions.\n\t */\n\t@Prop() public _align?: AlignPropType = 'top';\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: LabelPropType;\n\n\t/**\n\t * Gibt die Liste der Callback-Funktionen an, die auf Events aufgerufen werden sollen.\n\t */\n\t@Prop() public _on?: KoliBriTabsCallbacks;\n\n\t/**\n\t * Defines which tab is active.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _selected?: number = 0;\n\n\t/**\n\t * Defines the tab captions.\n\t */\n\t@Prop() public _tabs!: Stringified<TabButtonProps[]>;\n\n\t@State() public state: States = {\n\t\t_align: 'top',\n\t\t_label: '…', // ⚠ required\n\t\t_selected: 0,\n\t\t_tabs: [],\n\t};\n\n\tprivate selectNextNotDisabledTab = (selected: number, tabs: TabButtonProps[], upOrDown = true, initialSelected?: number): number => {\n\t\tif (selected > tabs.length - 1) {\n\t\t\tselected = tabs.length - 1;\n\t\t}\n\t\tif (selected < 0) {\n\t\t\tselected = 0;\n\t\t}\n\t\tif (Array.isArray(tabs) && tabs[selected]) {\n\t\t\tif (tabs[selected]._disabled) {\n\t\t\t\tif (upOrDown === true) {\n\t\t\t\t\tif (selected < tabs.length - 1) {\n\t\t\t\t\t\treturn this.selectNextNotDisabledTab(selected + 1, tabs, true, initialSelected || selected);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tselected = initialSelected || selected;\n\t\t\t\t\t\tupOrDown = false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (upOrDown === false) {\n\t\t\t\t\tif (selected > 0) {\n\t\t\t\t\t\treturn this.selectNextNotDisabledTab(selected - 1, tabs, false, initialSelected || selected);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdevHint(`[KolTabs] Alle Tabs sind deaktiviert und somit kann kein Tab angezeigt werden.`);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn selected;\n\t};\n\n\tprivate syncSelectedAndTabs = (nextValue: unknown, nextState: Map<string, unknown>, _component: Generic.Element.Component, key: string) => {\n\t\tlet selected: number;\n\t\tif (key === '_selected') {\n\t\t\tselected = nextValue as number;\n\t\t} else {\n\t\t\tselected = this.state._selected;\n\t\t}\n\t\tlet tabs: TabButtonProps[];\n\t\tif (key === '_tabs') {\n\t\t\ttabs = nextValue as TabButtonProps[];\n\t\t} else {\n\t\t\ttabs = this.state._tabs;\n\t\t}\n\t\tif (tabs.length > 0) {\n\t\t\tnextState.set('_selected', this.selectNextNotDisabledTab(selected, tabs));\n\t\t}\n\t};\n\n\t@Watch('_align')\n\tpublic validateAlign(value?: AlignPropType) {\n\t\tvalidateAlign(this, value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value);\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: KoliBriTabsCallbacks): 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: KoliBriTabsCallbacks = {};\n\t\t\tif (typeof value.onCreate === 'function' || typeof value.onCreate === 'object') {\n\t\t\t\tif (typeof value.onCreate === 'object') {\n\t\t\t\t\tif (typeof value.onCreate.label === 'string' && value.onCreate.label.length > 0) {\n\t\t\t\t\t\tthis.onCreateLabel = value.onCreate.label;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tLog.debug(\n\t\t\t\t\t\t\t`[KolTabs] Der Label-Text für Neu in {\n onCreate: {\n label: string (!),\n callback: Function\n }\n} ist nicht korrekt gesetzt.`\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t\tif (typeof value.onCreate.callback === 'function') {\n\t\t\t\t\t\tcallbacks.onCreate = value.onCreate.callback;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tLog.debug(\n\t\t\t\t\t\t\t`[KolTabs] Die onCreate-Callback-Funktion für Neu in {\n onCreate: {\n label: string,\n callback: Function (!)\n }\n} ist nicht korrekt gesetzt.`\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tcallbacks.onCreate = value.onCreate;\n\t\t\t\t}\n\t\t\t\tthis.showCreateTab = typeof callbacks.onCreate === 'function';\n\t\t\t}\n\t\t\tif (typeof value.onSelect === 'function') {\n\t\t\t\tcallbacks.onSelect = value.onSelect;\n\t\t\t}\n\t\t\tsetState<KoliBriTabsCallbacks>(this, '_on', callbacks);\n\t\t}\n\t}\n\n\t@Watch('_selected')\n\tpublic validateSelected(value?: number): void {\n\t\twatchNumber(this, '_selected', value, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: this.syncSelectedAndTabs,\n\t\t\t},\n\t\t});\n\t}\n\n\t@Watch('_tabs')\n\tpublic validateTabs(value?: Stringified<TabButtonProps[]>): void {\n\t\twatchJsonArrayString(\n\t\t\tthis,\n\t\t\t'_tabs',\n\t\t\t(item: TabButtonProps) => typeof item === 'object' && item !== null && typeof item._label === 'string' && item._label.length > 0,\n\t\t\tvalue,\n\t\t\tundefined,\n\t\t\t{\n\t\t\t\thooks: {\n\t\t\t\t\tbeforePatch: this.syncSelectedAndTabs,\n\t\t\t\t},\n\t\t\t}\n\t\t);\n\t\tuiUxHintMillerscheZahl('KolTabs', this.state._tabs.length);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAlign(this._align);\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateOn(this._on);\n\t\tthis.validateSelected(this._selected);\n\t\tthis.validateTabs(this._tabs);\n\t}\n\n\tprivate readonly handleTabPanels = () => {\n\t\tif (this.tabPanelHost instanceof HTMLDivElement) {\n\t\t\tfor (let i = this.tabPanelHost.children.length; i < this.state._tabs.length; i++) {\n\t\t\t\tconst div = document.createElement('div');\n\t\t\t\tdiv.setAttribute('aria-labelledby', `${this.state._label.replace(/\\s/g, '-')}-tab-${i}`);\n\t\t\t\tdiv.setAttribute('id', `tabpanel-${i}`);\n\t\t\t\tdiv.setAttribute('role', 'tabpanel');\n\t\t\t\tdiv.setAttribute('hidden', '');\n\t\t\t\tconst slot = document.createElement('slot');\n\t\t\t\tslot.setAttribute('name', `tabpanel-slot-${i}`);\n\t\t\t\tdiv.appendChild(slot);\n\t\t\t\tthis.tabPanelHost.appendChild(div);\n\t\t\t\tif (this.host?.children instanceof HTMLCollection && this.host?.children[i] /* SSR instanceof HTMLElement */) {\n\t\t\t\t\t// div.appendChild(this.host?.children[0]);\n\t\t\t\t\tthis.host?.children[i].setAttribute('slot', `tabpanel-slot-${i}`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n\n\tpublic componentDidRender(): void {\n\t\tthis.handleTabPanels();\n\t\tif (this.tabPanelHost instanceof HTMLDivElement) {\n\t\t\tfor (let i = 0; i < this.tabPanelHost.children.length; i++) {\n\t\t\t\tif (i !== this.state._selected) {\n\t\t\t\t\tthis.tabPanelHost.children[i].setAttribute('hidden', '');\n\t\t\t\t} else {\n\t\t\t\t\tthis.tabPanelHost.children[i].removeAttribute('hidden');\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate onSelect(event: CustomEvent | KeyboardEvent | MouseEvent | PointerEvent, index: number, focus = false): void {\n\t\tthis._selected = index;\n\t\tif (typeof this._on?.onSelect === 'function') {\n\t\t\tthis._on?.onSelect(event, index);\n\t\t}\n\t\tif (focus === true) {\n\t\t\t// TODO: prüfen, ob hier noch was offen ist\n\t\t\t// devHint('[KolTabs] Tab-Fokus-verschieben geht im Moment nicht.');\n\t\t\tthis.selectedTimeout = setTimeout(() => {\n\t\t\t\tclearTimeout(this.selectedTimeout);\n\t\t\t\tif (this.tabPanelsElement /* SSR instanceof HTMLElement */) {\n\t\t\t\t\tconst button: HTMLElement | null = koliBriQuerySelector(`button#${this.state._label.replace(/\\s/g, '-')}-tab-${index}`, this.tabPanelsElement);\n\t\t\t\t\tbutton?.focus();\n\t\t\t\t}\n\t\t\t}, 250);\n\t\t}\n\t}\n\n\tprivate onCreate = (event: Event) => {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\tif (typeof this.state._on?.onCreate === 'function') {\n\t\t\tthis.state._on?.onCreate(event);\n\t\t}\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{h as t,F as e,H as n,r as i,g as a}from"./index-0bc40dc4.js";import{n as s}from"./dev.utils-8202a1bc.js";import{a as l,e as r,d as o,w as h,s as d}from"./prop.validators-3fb6bedf.js";import{a as p,s as u}from"./reuse-b3566e4c.js";import{I as c,v as f,g as m}from"./controller-8b71bf6d.js";import{I as y}from"./InternalUnderlinedAccessKey-8b996006.js";import{v}from"./rows-051ae081.js";import{a as b}from"./a11y.tipps-68791110.js";import"./hide-label-fbf92ea1.js";import"./label-7afcc6a9.js";import"./events-2bb1065b.js";import"./tab-index-95df106a.js";import"./associated.controller-d463ef08.js";const g=["both","horizontal","vertical","none"];class _ extends c{constructor(t,e,n){super(t,e,n),this.afterSyncCharCounter=()=>{"string"==typeof this.component._value&&this.component._value.length>0&&(this.component.state._currentLength=this.component._value.length)},this.component=t}validateHasCounter(t){l(this.component,"_hasCounter",t,{hooks:{afterPatch:this.afterSyncCharCounter}})}validateHideError(t){f(this.component,t,{hooks:{afterPatch:()=>{this.component.state._hideError&&b("Property hide-error for inputs: Only use when the error message is shown outside of the input component.")}}})}validateMaxLength(t){r(this.component,"_maxLength",t,{hooks:{afterPatch:this.afterSyncCharCounter},min:0})}validatePlaceholder(t){o(this.component,"_placeholder",t)}validateReadOnly(t){l(this.component,"_readOnly",t)}validateResize(t){h(this.component,"_resize",(t=>"string"==typeof t&&g.includes(t)),new Set(`String {${g.join(", ")}`),t)}validateRequired(t){l(this.component,"_required",t)}validateRows(t){v(this.component,t)}validateValue(t){o(this.component,"_value",t,{hooks:{afterPatch:this.afterSyncCharCounter}}),this.setFormAssociatedValue(this.component._value)}componentWillLoad(){super.componentWillLoad(),this.validateHasCounter(this.component._hasCounter),this.validateHideError(this.component._hideError),this.validateMaxLength(this.component._maxLength),this.validatePlaceholder(this.component._placeholder),this.validateReadOnly(this.component._readOnly),this.validateResize(this.component._resize),this.validateRequired(this.component._required),this.validateRows(this.component._rows),this.validateValue(this.component._value)}}const x="/*\n * This file contains all rules for accessibility.\n */\n@layer kol-global {\n\t:host {\n\t\t/*\n\t\t * Minimum size of interactive elements.\n\t\t */\n\t\t--a11y-min-size: 44px;\n\t\t/*\n\t\t * Verdana is an accessible font that can be used without requiring additional loading time.\n\t\t */\n\t\tfont-family: Verdana;\n\t}\n\n\t* {\n\t\t/*\n\t\t * This rule enables the word dividing for all texts. That is important for high zoom levels.\n\t\t */\n\t\thyphens: auto;\n\t\t/*\n\t\t * Letter spacing is required for all texts.\n\t\t */\n\t\tletter-spacing: inherit;\n\t\t/*\n\t\t * This rule enables the word dividing for all texts. That is important for high zoom levels.\n\t\t */\n\t\tword-break: break-word;\n\t\t/*\n\t\t * Word spacing is required for all texts.\n\t\t */\n\t\tword-spacing: inherit;\n\t}\n\n\t/*\n\t * All interactive elements should have a minimum size of 44px.\n\t */\n\t/* input:not([type='checkbox'], [type='radio'], [type='range']), */\n\t/* option, */\n\t/* select, */\n\t/* textarea, */\n\t[role='button'],\n\tbutton:not([role='link']),\n\tkol-input .input {\n\t\tmin-height: var(--a11y-min-size);\n\t\tmin-width: var(--a11y-min-size);\n\t}\n\n\t/*\n\t * Some interactive elements should not inherit the font-family and font-size.\n\t */\n\ta,\n\tbutton,\n\th1,\n\th2,\n\th3,\n\th4,\n\th5,\n\th6,\n\tinput,\n\toption,\n\tselect,\n\ttextarea {\n\t\t/*\n\t\t * All elements should inherit the font family from his parent element.\n\t\t */\n\t\tfont-family: inherit;\n\t\t/*\n\t\t * All elements should inherit the font size from his parent element.\n\t\t */\n\t\tfont-size: inherit;\n\t}\n}\n\n@layer kol-global {\n\t/*\n\t * Dieses CSS stellt sicher, dass der Standard-Style\n\t * von A und Button resettet werden.\n\t */\n\t:is(a, button) {\n\t\tbackground-color: transparent;\n\t\tborder: none;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\twidth: 100%; /* 100% needed for custom width from outside */\n\t}\n}\n\n@layer kol-global {\n\t:host {\n\t\t/*\n\t\t * The max-width is needed to prevent the table from overflowing the\n\t\t * parent node, if the table is wider than the parent node.\n\t\t */\n\t\tmax-width: 100%;\n\t}\n\n\t* {\n\t\t/*\n\t\t * We prefer to box-sizing: border-box for all elements.\n\t\t */\n\t\tbox-sizing: border-box;\n\t}\n\n\t/* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n\tkol-span-wc {\n\t\tdisplay: grid;\n\t\tplace-items: center;\n\t}\n\n\t/* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n\tkol-span-wc > span {\n\t\tdisplay: flex;\n\t\tplace-items: center;\n\t}\n\n\ta,\n\tbutton {\n\t\tcursor: pointer;\n\t}\n\n\t/* This is the text label. */\n\t.icon-only > kol-span-wc > span > span {\n\t\tdisplay: none;\n\t}\n}\n\n@layer kol-component {\n\t.required label > span::after,\n\t.required legend > span::after {\n\t\tcontent: '*';\n\t}\n}\n\n@layer kol-component {\n\t:host {\n\t\tdisplay: block;\n\t}\n}\n\n@layer kol-component {\n\tinput,\n\ttextarea {\n\t\tcursor: text;\n\t}\n\n\tinput[type='checkbox'],\n\tinput[type='color'],\n\tinput[type='file'],\n\tinput[type='radio'],\n\tinput[type='range'],\n\tlabel,\n\toption,\n\tselect {\n\t\tcursor: pointer;\n\t}\n\n\t/* input[type='checkbox'], */\n\t/* input[type='radio'], */\n\t/* input[type='range'], */\n\tinput[type='color'],\n\tinput[type='date'],\n\tinput[type='datetime-local'],\n\tinput[type='email'],\n\tinput[type='file'],\n\tinput[type='month'],\n\tinput[type='number'],\n\tinput[type='password'],\n\tinput[type='search'],\n\tinput[type='tel'],\n\tinput[type='text'],\n\tinput[type='time'],\n\tinput[type='url'],\n\tinput[type='week'],\n\tselect,\n\tselect[multiple] option,\n\ttextarea {\n\t\tfont-size: 1rem;\n\t\twidth: 100%;\n\t}\n\n\t/* needed hack for vertical alignment */\n\tinput[type='file'] {\n\t\tpadding: calc((var(--a11y-min-size) - 1rem) / 10) 0.5em;\n\t}\n\n\t/* needed hack for vertical alignment */\n\tselect[multiple] option {\n\t\tpadding: calc((var(--a11y-min-size) - 1rem) / 2) 0.5em;\n\t}\n\n\tkol-input.disabled :is(button, input, label, option, select, textarea) {\n\t\tcursor: not-allowed;\n\t\topacity: 0.5;\n\t}\n}\n\n@layer kol-component {\n\tkol-input {\n\t\tdisplay: grid;\n\t}\n\n\tkol-input .input-slot {\n\t\tflex-grow: 1;\n\t}\n\n\tinput:not([type='checkbox'], [type='radio']),\n\tselect:not([multiple], [size]) {\n\t\theight: 2.75em;\n\t}\n\n\tinput:focus,\n\toption:focus,\n\tselect:focus,\n\ttextarea:focus {\n\t\toutline: 0;\n\t}\n\n\t.input {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t}\n\n\t.input > kol-icon {\n\t\tdisplay: grid;\n\t\theight: var(--a11y-min-size);\n\t\tplace-items: center;\n\t}\n\n\tkol-input.required .input-tooltip .span-label::after {\n\t\tcontent: '*';\n\t}\n}\n\n@layer kol-component {\n\t.error.hidden {\n\t\tdisplay: none;\n\t}\n}\n",k=t=>{t.style.overflow="hidden";const e=t.rows,n=t.clientHeight/e;t.rows=1;const a=Math.round(t.scrollHeight/n);return t.rows=e,a},w=class{async getValue(){var t;return null===(t=this.ref)||void 0===t?void 0:t.value}render(){const{ariaDescribedBy:a}=m(this.state),i=u(this.state._label);return t(n,{class:{"has-value":this.state._hasValue}},t("kol-input",{class:{textarea:!0,"hide-label":!!this.state._hideLabel,"has-counter":!!this.state._hasCounter},_accessKey:this.state._accessKey,_alert:this.state._alert,_currentLength:this.state._currentLength,_disabled:this.state._disabled,_error:this.state._error,_hideError:this.state._hideError,_hasCounter:this.state._hasCounter,_hideLabel:this.state._hideLabel,_hint:this.state._hint,_id:this.state._id,_label:this.state._label,_maxLength:this.state._maxLength,_readOnly:this.state._readOnly,_required:this.state._required,_tooltipAlign:this._tooltipAlign,_touched:this.state._touched,onClick:()=>{var t;return null===(t=this.ref)||void 0===t?void 0:t.focus()}},t("span",{slot:"label"},i?t("slot",{name:"expert"}):"string"==typeof this.state._accessKey?t(e,null,t(y,{accessKey:this.state._accessKey,label:this.state._label})," ",t("span",{class:"access-key-hint","aria-hidden":"true"},this.state._accessKey)):t("span",null,this.state._label)),t("div",{slot:"input"},t("textarea",Object.assign({ref:this.catchRef,title:"",accessKey:this.state._accessKey,"aria-describedby":a.length>0?a.join(" "):void 0,"aria-label":this.state._hideLabel&&"string"==typeof this.state._label?this.state._label:void 0,autoCapitalize:"off",autoCorrect:"off",disabled:this.state._disabled,id:this.state._id,maxlength:this.state._maxLength,name:this.state._name,readOnly:this.state._readOnly,required:this.state._required,rows:this.state._rows,placeholder:this.state._placeholder,spellcheck:"false"},this.controller.onFacade,{onKeyUp:this.onKeyUp,style:{resize:this.state._resize},value:this.state._value})))))}constructor(t){i(this,t),this.catchRef=t=>{this.ref=t,p(this.host,this.ref)},this.onKeyUp=()=>{this.ref instanceof HTMLTextAreaElement&&(d(this,"_currentLength",this.ref.value.length),this.state._adjustHeight&&(this._rows=k(this.ref)))},this._accessKey=void 0,this._adjustHeight=!1,this._alert=!0,this._disabled=!1,this._error=void 0,this._hasCounter=!1,this._hideError=!1,this._hideLabel=!1,this._hint="",this._id=void 0,this._label=void 0,this._maxLength=void 0,this._name=void 0,this._on=void 0,this._placeholder=void 0,this._readOnly=!1,this._resize="vertical",this._required=!1,this._rows=void 0,this._syncValueBySelector=void 0,this._tabIndex=void 0,this._tooltipAlign="top",this._touched=!1,this._value=void 0,this.state={_adjustHeight:!1,_currentLength:0,_hasValue:!1,_hideError:!1,_id:`id-${s()}`,_label:"",_resize:"vertical"},this.controller=new _(this,"textarea",this.host)}validateAccessKey(t){this.controller.validateAccessKey(t)}validateAdjustHeight(t){this.controller.validateAdjustHeight(t)}validateAlert(t){this.controller.validateAlert(t)}validateDisabled(t){this.controller.validateDisabled(t)}validateError(t){this.controller.validateError(t)}validateHasCounter(t){this.controller.validateHasCounter(t)}validateHideError(t){this.controller.validateHideError(t)}validateHideLabel(t){this.controller.validateHideLabel(t)}validateHint(t){this.controller.validateHint(t)}validateId(t){this.controller.validateId(t)}validateLabel(t){this.controller.validateLabel(t)}validateMaxLength(t){this.controller.validateMaxLength(t)}validateName(t){this.controller.validateName(t)}validateOn(t){this.controller.validateOn(t)}validatePlaceholder(t){this.controller.validatePlaceholder(t)}validateReadOnly(t){this.controller.validateReadOnly(t)}validateResize(t){this.controller.validateResize(t)}validateRequired(t){this.controller.validateRequired(t)}validateRows(t){this.controller.validateRows(t)}validateSyncValueBySelector(t){this.controller.validateSyncValueBySelector(t)}validateTabIndex(t){this.controller.validateTabIndex(t)}validateTouched(t){this.controller.validateTouched(t)}validateValue(t){this.controller.validateValue(t)}componentWillLoad(){this._alert=!0===this._alert,this._touched=!0===this._touched,this.controller.componentWillLoad(),this.state._hasValue=!!this.state._value,this.controller.addValueChangeListener((t=>this.state._hasValue=!!t))}get host(){return a(this)}static get watchers(){return{_accessKey:["validateAccessKey"],_adjustHeight:["validateAdjustHeight"],_alert:["validateAlert"],_disabled:["validateDisabled"],_error:["validateError"],_hasCounter:["validateHasCounter"],_hideError:["validateHideError"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_id:["validateId"],_label:["validateLabel"],_maxLength:["validateMaxLength"],_name:["validateName"],_on:["validateOn"],_placeholder:["validatePlaceholder"],_readOnly:["validateReadOnly"],_resize:["validateResize"],_required:["validateRequired"],_rows:["validateRows"],_syncValueBySelector:["validateSyncValueBySelector"],_tabIndex:["validateTabIndex"],_touched:["validateTouched"],_value:["validateValue"]}}};w.style={default:x};export{w as kol_textarea};
4
+ import{h as t,F as e,H as n,r as i,g as a}from"./index-e9d20d00.js";import{n as s}from"./dev.utils-b86b7cfe.js";import{a as l,e as o,d as r,w as h,s as d}from"./prop.validators-17590a9e.js";import{a as c,s as p}from"./reuse-d79ab469.js";import{I as u,g as m}from"./controller-a3de638f.js";import{I as f}from"./InternalUnderlinedAccessKey-2c5af489.js";import{v as y}from"./rows-94cb79bb.js";import"./a11y.tipps-76f7d989.js";import"./hide-label-084e2864.js";import"./label-9700d24c.js";import"./events-fa760b68.js";import"./tab-index-fbb584a0.js";import"./associated.controller-3ce25c94.js";const v=["both","horizontal","vertical","none"];class b extends u{constructor(t,e,n){super(t,e,n),this.afterSyncCharCounter=()=>{"string"==typeof this.component._value&&this.component._value.length>0&&(this.component.state._currentLength=this.component._value.length)},this.component=t}validateHasCounter(t){l(this.component,"_hasCounter",t,{hooks:{afterPatch:this.afterSyncCharCounter}})}validateMaxLength(t){o(this.component,"_maxLength",t,{hooks:{afterPatch:this.afterSyncCharCounter},min:0})}validatePlaceholder(t){r(this.component,"_placeholder",t)}validateReadOnly(t){l(this.component,"_readOnly",t)}validateResize(t){h(this.component,"_resize",(t=>"string"==typeof t&&v.includes(t)),new Set(`String {${v.join(", ")}`),t)}validateRequired(t){l(this.component,"_required",t)}validateRows(t){y(this.component,t)}validateValue(t){r(this.component,"_value",t,{hooks:{afterPatch:this.afterSyncCharCounter}}),this.setFormAssociatedValue(this.component._value)}componentWillLoad(){super.componentWillLoad(),this.validateHasCounter(this.component._hasCounter),this.validateMaxLength(this.component._maxLength),this.validatePlaceholder(this.component._placeholder),this.validateReadOnly(this.component._readOnly),this.validateResize(this.component._resize),this.validateRequired(this.component._required),this.validateRows(this.component._rows),this.validateValue(this.component._value)}}const g="/*\n * This file contains all rules for accessibility.\n */\n@layer kol-global {\n\t:host {\n\t\t/*\n\t\t * Minimum size of interactive elements.\n\t\t */\n\t\t--a11y-min-size: 44px;\n\t\t/*\n\t\t * No element should be used without a background and font color whose contrast ratio has\n\t\t * not been checked. By initially setting the background color to white and the font color\n\t\t * to black, the contrast ratio is ensured and explicit adjustment is forced.\n\t\t */\n\t\tbackground-color: white;\n\t\tcolor: black;\n\t\t/*\n\t\t * Verdana is an accessible font that can be used without requiring additional loading time.\n\t\t */\n\t\tfont-family: Verdana;\n\t}\n\n\t* {\n\t\t/*\n\t\t * This rule enables the word dividing for all texts. That is important for high zoom levels.\n\t\t */\n\t\thyphens: auto;\n\t\t/*\n\t\t * Letter spacing is required for all texts.\n\t\t */\n\t\tletter-spacing: inherit;\n\t\t/*\n\t\t * This rule enables the word dividing for all texts. That is important for high zoom levels.\n\t\t */\n\t\tword-break: break-word;\n\t\t/*\n\t\t * Word spacing is required for all texts.\n\t\t */\n\t\tword-spacing: inherit;\n\t}\n\n\t/*\n\t * All interactive elements should have a minimum size of 44px.\n\t */\n\t/* input:not([type='checkbox'], [type='radio'], [type='range']), */\n\t/* option, */\n\t/* select, */\n\t/* textarea, */\n\t[role='button'],\n\tbutton:not([role='link']),\n\tkol-input .input {\n\t\tmin-height: var(--a11y-min-size);\n\t\tmin-width: var(--a11y-min-size);\n\t}\n\n\t/*\n\t * Some interactive elements should not inherit the font-family and font-size.\n\t */\n\ta,\n\tbutton,\n\th1,\n\th2,\n\th3,\n\th4,\n\th5,\n\th6,\n\tinput,\n\toption,\n\tselect,\n\ttextarea {\n\t\t/*\n\t\t * All elements should inherit the font family from his parent element.\n\t\t */\n\t\tfont-family: inherit;\n\t\t/*\n\t\t * All elements should inherit the font size from his parent element.\n\t\t */\n\t\tfont-size: inherit;\n\t}\n}\n\n/**\n * Sometimes we need the semantic element for accessibility reasons,\n * but we don't want to show it.\n *\n * - https://www.a11yproject.com/posts/how-to-hide-content/\n */\n.visually-hidden {\n\tclip: rect(0 0 0 0);\n\tclip-path: inset(50%);\n\theight: 1px;\n\toverflow: hidden;\n\tposition: absolute;\n\twhite-space: nowrap;\n\twidth: 1px;\n}\n\n@layer kol-global {\n\t/*\n\t * Dieses CSS stellt sicher, dass der Standard-Style\n\t * von A und Button resettet werden.\n\t */\n\t:is(a, button) {\n\t\tbackground-color: transparent;\n\t\tborder: none;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\twidth: 100%; /* 100% needed for custom width from outside */\n\t}\n\n\t/*\n\t * Ensure elements with hidden attribute to be actually not visible\n\t * @see https://meowni.ca/hidden.is.a.lie.html\n\t */\n\t[hidden] {\n\t\tdisplay: none !important;\n\t}\n}\n\n@layer kol-global {\n\t:host {\n\t\t/*\n\t\t * The max-width is needed to prevent the table from overflowing the\n\t\t * parent node, if the table is wider than the parent node.\n\t\t */\n\t\tmax-width: 100%;\n\t}\n\n\t* {\n\t\t/*\n\t\t * We prefer to box-sizing: border-box for all elements.\n\t\t */\n\t\tbox-sizing: border-box;\n\t}\n\n\t/* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n\tkol-span-wc {\n\t\tdisplay: grid;\n\t\tplace-items: center;\n\t}\n\n\t/* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n\tkol-span-wc > span {\n\t\tdisplay: flex;\n\t\tplace-items: center;\n\t}\n\n\ta,\n\tbutton {\n\t\tcursor: pointer;\n\t}\n\n\t/* This is the text label. */\n\t.icon-only > kol-span-wc > span > span {\n\t\tdisplay: none;\n\t}\n}\n\n@layer kol-component {\n\t.required label > span::after,\n\t.required legend > span::after {\n\t\tcontent: '*';\n\t}\n}\n\n@layer kol-component {\n\t:host {\n\t\tdisplay: block;\n\t}\n}\n\n@layer kol-component {\n\tinput,\n\ttextarea {\n\t\tcursor: text;\n\t}\n\n\tinput[type='checkbox'],\n\tinput[type='color'],\n\tinput[type='file'],\n\tinput[type='radio'],\n\tinput[type='range'],\n\tlabel,\n\toption,\n\tselect {\n\t\tcursor: pointer;\n\t}\n\n\t/* input[type='checkbox'], */\n\t/* input[type='radio'], */\n\t/* input[type='range'], */\n\tinput[type='color'],\n\tinput[type='date'],\n\tinput[type='datetime-local'],\n\tinput[type='email'],\n\tinput[type='file'],\n\tinput[type='month'],\n\tinput[type='number'],\n\tinput[type='password'],\n\tinput[type='search'],\n\tinput[type='tel'],\n\tinput[type='text'],\n\tinput[type='time'],\n\tinput[type='url'],\n\tinput[type='week'],\n\tselect,\n\tselect[multiple] option,\n\ttextarea {\n\t\tfont-size: 1rem;\n\t\twidth: 100%;\n\t}\n\n\t/* needed hack for vertical alignment */\n\tinput[type='file'] {\n\t\tpadding: calc((var(--a11y-min-size) - 1rem) / 10) 0.5em;\n\t}\n\n\t/* needed hack for vertical alignment */\n\tselect[multiple] option {\n\t\tpadding: calc((var(--a11y-min-size) - 1rem) / 2) 0.5em;\n\t}\n\n\tkol-input.disabled :is(button, input, option, select, textarea, .input-label) {\n\t\tcursor: not-allowed;\n\t\topacity: 0.5;\n\t}\n}\n\n@layer kol-component {\n\tkol-input {\n\t\tdisplay: grid;\n\t}\n\n\tkol-input .input-slot {\n\t\tflex-grow: 1;\n\t}\n\n\tinput:not([type='checkbox'], [type='radio']),\n\tselect:not([multiple], [size]) {\n\t\theight: 2.75em;\n\t}\n\n\tinput:focus,\n\toption:focus,\n\tselect:focus,\n\ttextarea:focus {\n\t\toutline: 0;\n\t}\n\n\t.input {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t}\n\n\t.input > kol-icon {\n\t\tdisplay: grid;\n\t\theight: var(--a11y-min-size);\n\t\tplace-items: center;\n\t}\n\n\tkol-input.required .input-tooltip .span-label::after {\n\t\tcontent: '*';\n\t}\n}\n\n@layer kol-component {\n\t.error.hidden {\n\t\tdisplay: none;\n\t}\n}\n",_=t=>{t.style.overflow="hidden";const e=t.rows,n=t.clientHeight/e;t.rows=1;const a=Math.round(t.scrollHeight/n);return t.rows=e,a},x=class{async getValue(){var t;return null===(t=this.ref)||void 0===t?void 0:t.value}render(){const{ariaDescribedBy:a}=m(this.state),i=p(this.state._label);return t(n,{class:{"has-value":this.state._hasValue}},t("kol-input",{class:{textarea:!0,"hide-label":!!this.state._hideLabel,"has-counter":!!this.state._hasCounter},_accessKey:this.state._accessKey,_alert:this.state._alert,_currentLength:this.state._currentLength,_disabled:this.state._disabled,_error:this.state._error,_hideError:this.state._hideError,_hasCounter:this.state._hasCounter,_hideLabel:this.state._hideLabel,_hint:this.state._hint,_id:this.state._id,_label:this.state._label,_maxLength:this.state._maxLength,_readOnly:this.state._readOnly,_required:this.state._required,_tooltipAlign:this._tooltipAlign,_touched:this.state._touched,onClick:()=>{var t;return null===(t=this.ref)||void 0===t?void 0:t.focus()}},t("span",{slot:"label"},i?t("slot",{name:"expert"}):"string"==typeof this.state._accessKey?t(e,null,t(f,{accessKey:this.state._accessKey,label:this.state._label})," ",t("span",{class:"access-key-hint","aria-hidden":"true"},this.state._accessKey)):t("span",null,this.state._label)),t("div",{slot:"input"},t("textarea",Object.assign({ref:this.catchRef,title:"",accessKey:this.state._accessKey,"aria-describedby":a.length>0?a.join(" "):void 0,"aria-label":this.state._hideLabel&&"string"==typeof this.state._label?this.state._label:void 0,autoCapitalize:"off",autoCorrect:"off",disabled:this.state._disabled,id:this.state._id,maxlength:this.state._maxLength,name:this.state._name,readOnly:this.state._readOnly,required:this.state._required,rows:this.state._rows,placeholder:this.state._placeholder,spellcheck:"false"},this.controller.onFacade,{onKeyUp:this.onKeyUp,style:{resize:this.state._resize},value:this.state._value})))))}constructor(t){i(this,t),this.catchRef=t=>{this.ref=t,c(this.host,this.ref)},this.onKeyUp=()=>{this.ref instanceof HTMLTextAreaElement&&(d(this,"_currentLength",this.ref.value.length),this.state._adjustHeight&&(this._rows=_(this.ref)))},this._accessKey=void 0,this._adjustHeight=!1,this._alert=!0,this._disabled=!1,this._error=void 0,this._hasCounter=!1,this._hideError=!1,this._hideLabel=!1,this._hint="",this._id=void 0,this._label=void 0,this._maxLength=void 0,this._name=void 0,this._on=void 0,this._placeholder=void 0,this._readOnly=!1,this._resize="vertical",this._required=!1,this._rows=void 0,this._syncValueBySelector=void 0,this._tabIndex=void 0,this._tooltipAlign="top",this._touched=!1,this._value=void 0,this.state={_adjustHeight:!1,_currentLength:0,_hasValue:!1,_hideError:!1,_id:`id-${s()}`,_label:"",_resize:"vertical"},this.controller=new b(this,"textarea",this.host)}validateAccessKey(t){this.controller.validateAccessKey(t)}validateAdjustHeight(t){this.controller.validateAdjustHeight(t)}validateAlert(t){this.controller.validateAlert(t)}validateDisabled(t){this.controller.validateDisabled(t)}validateError(t){this.controller.validateError(t)}validateHasCounter(t){this.controller.validateHasCounter(t)}validateHideError(t){this.controller.validateHideError(t)}validateHideLabel(t){this.controller.validateHideLabel(t)}validateHint(t){this.controller.validateHint(t)}validateId(t){this.controller.validateId(t)}validateLabel(t){this.controller.validateLabel(t)}validateMaxLength(t){this.controller.validateMaxLength(t)}validateName(t){this.controller.validateName(t)}validateOn(t){this.controller.validateOn(t)}validatePlaceholder(t){this.controller.validatePlaceholder(t)}validateReadOnly(t){this.controller.validateReadOnly(t)}validateResize(t){this.controller.validateResize(t)}validateRequired(t){this.controller.validateRequired(t)}validateRows(t){this.controller.validateRows(t)}validateSyncValueBySelector(t){this.controller.validateSyncValueBySelector(t)}validateTabIndex(t){this.controller.validateTabIndex(t)}validateTouched(t){this.controller.validateTouched(t)}validateValue(t){this.controller.validateValue(t)}componentWillLoad(){this._alert=!0===this._alert,this._touched=!0===this._touched,this.controller.componentWillLoad(),this.state._hasValue=!!this.state._value,this.controller.addValueChangeListener((t=>this.state._hasValue=!!t))}get host(){return a(this)}static get watchers(){return{_accessKey:["validateAccessKey"],_adjustHeight:["validateAdjustHeight"],_alert:["validateAlert"],_disabled:["validateDisabled"],_error:["validateError"],_hasCounter:["validateHasCounter"],_hideError:["validateHideError"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_id:["validateId"],_label:["validateLabel"],_maxLength:["validateMaxLength"],_name:["validateName"],_on:["validateOn"],_placeholder:["validatePlaceholder"],_readOnly:["validateReadOnly"],_resize:["validateResize"],_required:["validateRequired"],_rows:["validateRows"],_syncValueBySelector:["validateSyncValueBySelector"],_tabIndex:["validateTabIndex"],_touched:["validateTouched"],_value:["validateValue"]}}};x.style={default:g};export{x as kol_textarea};