@public-ui/components 1.7.19 → 1.7.21

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 (621) hide show
  1. package/custom-elements.json +3 -3
  2. package/dist/cjs/{a11y.tipps-afe428df.js → a11y.tipps-de60af32.js} +1 -1
  3. package/dist/cjs/{a11y.tipps-afe428df.js.map → a11y.tipps-de60af32.js.map} +1 -1
  4. package/dist/cjs/align-66d1c455.js +4 -0
  5. package/dist/cjs/{align-4d94a35f.js.map → align-66d1c455.js.map} +1 -1
  6. package/dist/cjs/{alignment-f99d73c0.js → alignment-b17857ef.js} +1 -1
  7. package/dist/cjs/{alignment-f99d73c0.js.map → alignment-b17857ef.js.map} +1 -1
  8. package/dist/cjs/{app-globals-51e08069.js → app-globals-89a36103.js} +1 -1
  9. package/dist/cjs/{app-globals-51e08069.js.map → app-globals-89a36103.js.map} +1 -1
  10. package/dist/cjs/{aria-current-a786da32.js → aria-current-065e4fcb.js} +1 -1
  11. package/dist/cjs/{aria-current-a786da32.js.map → aria-current-065e4fcb.js.map} +1 -1
  12. package/dist/cjs/{associated.controller-5de04c8b.js → associated.controller-46b5c82e.js} +1 -1
  13. package/dist/cjs/{associated.controller-5de04c8b.js.map → associated.controller-46b5c82e.js.map} +1 -1
  14. package/dist/cjs/{color-ac886346.js → color-60198a73.js} +1 -1
  15. package/dist/cjs/{color-ac886346.js.map → color-60198a73.js.map} +1 -1
  16. package/dist/cjs/{controller-f6000875.js → controller-02dd3be1.js} +1 -1
  17. package/dist/cjs/{controller-f6000875.js.map → controller-02dd3be1.js.map} +1 -1
  18. package/dist/cjs/{controller-bd4cf842.js → controller-52b374b1.js} +1 -1
  19. package/dist/cjs/{controller-bd4cf842.js.map → controller-52b374b1.js.map} +1 -1
  20. package/dist/cjs/controller-592fd301.js +4 -0
  21. package/dist/cjs/controller-592fd301.js.map +1 -0
  22. package/dist/cjs/{controller-bcebf476.js → controller-5e2d2585.js} +1 -1
  23. package/dist/cjs/{controller-bcebf476.js.map → controller-5e2d2585.js.map} +1 -1
  24. package/dist/cjs/{controller-c99812e7.js → controller-dea3127d.js} +1 -1
  25. package/dist/cjs/controller-dea3127d.js.map +1 -0
  26. package/dist/cjs/{controller-icon-fa43df86.js → controller-icon-c5c4bc3a.js} +1 -1
  27. package/dist/cjs/{controller-icon-fa43df86.js.map → controller-icon-c5c4bc3a.js.map} +1 -1
  28. package/dist/cjs/{custom-class-7651d477.js → custom-class-e4bd4874.js} +1 -1
  29. package/dist/cjs/{custom-class-7651d477.js.map → custom-class-e4bd4874.js.map} +1 -1
  30. package/dist/cjs/{dev.utils-334adaab.js → dev.utils-d5ef4f2b.js} +1 -1
  31. package/dist/cjs/{dev.utils-334adaab.js.map → dev.utils-d5ef4f2b.js.map} +1 -1
  32. package/dist/cjs/{devtools-900e9725.js → devtools-19dffa6e.js} +1 -1
  33. package/dist/cjs/{devtools-900e9725.js.map → devtools-19dffa6e.js.map} +1 -1
  34. package/dist/cjs/{form-field-msg-8043a6f2.js → form-field-msg-e309e898.js} +1 -1
  35. package/dist/cjs/{form-field-msg-8043a6f2.js.map → form-field-msg-e309e898.js.map} +1 -1
  36. package/dist/cjs/has-closer-b8fe05cc.js +4 -0
  37. package/dist/cjs/{has-closer-2cae00d9.js.map → has-closer-b8fe05cc.js.map} +1 -1
  38. package/dist/cjs/hide-label-50b53069.js +4 -0
  39. package/dist/cjs/{hide-label-b0beb21d.js.map → hide-label-50b53069.js.map} +1 -1
  40. package/dist/cjs/{i18n-2e2a9462.js → i18n-189d7d4c.js} +1 -1
  41. package/dist/cjs/{i18n-2e2a9462.js.map → i18n-189d7d4c.js.map} +1 -1
  42. package/dist/cjs/{i18n-c3fa5bd7.js → i18n-4d37a083.js} +1 -1
  43. package/dist/cjs/i18n-4d37a083.js.map +1 -0
  44. package/dist/cjs/{icons-ffb304ec.js → icons-532e8e6f.js} +1 -1
  45. package/dist/cjs/{icons-ffb304ec.js.map → icons-532e8e6f.js.map} +1 -1
  46. package/dist/cjs/image-source-83b8975d.js +4 -0
  47. package/dist/cjs/{image-source-7a3dc14e.js.map → image-source-83b8975d.js.map} +1 -1
  48. package/dist/cjs/index-f1a07668.js +4 -0
  49. package/dist/cjs/index-f1a07668.js.map +1 -0
  50. package/dist/cjs/index.cjs.js +1 -1
  51. package/dist/cjs/kol-abbr.cjs.entry.js +1 -1
  52. package/dist/cjs/kol-accordion.cjs.entry.js +1 -1
  53. package/dist/cjs/kol-alert-wc.cjs.entry.js +1 -1
  54. package/dist/cjs/kol-alert-wc.cjs.entry.js.map +1 -1
  55. package/dist/cjs/kol-alert.cjs.entry.js +1 -1
  56. package/dist/cjs/kol-avatar-wc.cjs.entry.js +1 -1
  57. package/dist/cjs/kol-avatar.cjs.entry.js +1 -1
  58. package/dist/cjs/kol-badge.cjs.entry.js +1 -1
  59. package/dist/cjs/kol-breadcrumb.cjs.entry.js +1 -1
  60. package/dist/cjs/kol-breadcrumb.cjs.entry.js.map +1 -1
  61. package/dist/cjs/kol-button-group-wc.cjs.entry.js +1 -1
  62. package/dist/cjs/kol-button-group.cjs.entry.js +1 -1
  63. package/dist/cjs/kol-button-link-text-switch.cjs.entry.js +1 -1
  64. package/dist/cjs/kol-button-link.cjs.entry.js +1 -1
  65. package/dist/cjs/kol-button-wc.cjs.entry.js +1 -1
  66. package/dist/cjs/kol-button.cjs.entry.js +1 -1
  67. package/dist/cjs/kol-card.cjs.entry.js +1 -1
  68. package/dist/cjs/kol-card.cjs.entry.js.map +1 -1
  69. package/dist/cjs/kol-details.cjs.entry.js +1 -1
  70. package/dist/cjs/kol-form.cjs.entry.js +1 -1
  71. package/dist/cjs/kol-form.cjs.entry.js.map +1 -1
  72. package/dist/cjs/kol-heading-wc.cjs.entry.js +1 -1
  73. package/dist/cjs/kol-heading.cjs.entry.js +1 -1
  74. package/dist/cjs/kol-icon-font-awesome.cjs.entry.js +1 -1
  75. package/dist/cjs/kol-icon-icofont.cjs.entry.js +1 -1
  76. package/dist/cjs/kol-icon.cjs.entry.js +1 -1
  77. package/dist/cjs/kol-image.cjs.entry.js +1 -1
  78. package/dist/cjs/kol-indented-text.cjs.entry.js +1 -1
  79. package/dist/cjs/kol-input-adapter-leanup.cjs.entry.js +1 -1
  80. package/dist/cjs/kol-input-checkbox.cjs.entry.js +1 -1
  81. package/dist/cjs/kol-input-checkbox.cjs.entry.js.map +1 -1
  82. package/dist/cjs/kol-input-color.cjs.entry.js +1 -1
  83. package/dist/cjs/kol-input-date.cjs.entry.js +1 -1
  84. package/dist/cjs/kol-input-email.cjs.entry.js +1 -1
  85. package/dist/cjs/kol-input-file.cjs.entry.js +1 -1
  86. package/dist/cjs/kol-input-number.cjs.entry.js +1 -1
  87. package/dist/cjs/kol-input-password.cjs.entry.js +1 -1
  88. package/dist/cjs/kol-input-radio-group.cjs.entry.js +1 -1
  89. package/dist/cjs/kol-input-radio.cjs.entry.js +1 -1
  90. package/dist/cjs/kol-input-radio.cjs.entry.js.map +1 -1
  91. package/dist/cjs/kol-input-range.cjs.entry.js +1 -1
  92. package/dist/cjs/kol-input-range.cjs.entry.js.map +1 -1
  93. package/dist/cjs/kol-input-text.cjs.entry.js +1 -1
  94. package/dist/cjs/kol-input.cjs.entry.js +1 -1
  95. package/dist/cjs/kol-input.cjs.entry.js.map +1 -1
  96. package/dist/cjs/kol-kolibri.cjs.entry.js +1 -1
  97. package/dist/cjs/kol-kolibri.cjs.entry.js.map +1 -1
  98. package/dist/cjs/kol-link-button.cjs.entry.js +1 -1
  99. package/dist/cjs/kol-link-group.cjs.entry.js +1 -1
  100. package/dist/cjs/kol-link-group.cjs.entry.js.map +1 -1
  101. package/dist/cjs/kol-link-wc.cjs.entry.js +1 -1
  102. package/dist/cjs/kol-link-wc.cjs.entry.js.map +1 -1
  103. package/dist/cjs/kol-link.cjs.entry.js +1 -1
  104. package/dist/cjs/kol-logo.cjs.entry.js +1 -1
  105. package/dist/cjs/kol-modal.cjs.entry.js +1 -1
  106. package/dist/cjs/kol-modal.cjs.entry.js.map +1 -1
  107. package/dist/cjs/kol-nav.cjs.entry.js +1 -1
  108. package/dist/cjs/kol-nav.cjs.entry.js.map +1 -1
  109. package/dist/cjs/kol-pagination.cjs.entry.js +1 -1
  110. package/dist/cjs/kol-pagination.cjs.entry.js.map +1 -1
  111. package/dist/cjs/kol-popover-wc.cjs.entry.js +1 -1
  112. package/dist/cjs/kol-progress.cjs.entry.js +1 -1
  113. package/dist/cjs/kol-quote.cjs.entry.js +1 -1
  114. package/dist/cjs/kol-quote.cjs.entry.js.map +1 -1
  115. package/dist/cjs/kol-select.cjs.entry.js +1 -1
  116. package/dist/cjs/kol-select.cjs.entry.js.map +1 -1
  117. package/dist/cjs/kol-skip-nav.cjs.entry.js +1 -1
  118. package/dist/cjs/kol-span-wc.cjs.entry.js +1 -1
  119. package/dist/cjs/kol-span-wc.cjs.entry.js.map +1 -1
  120. package/dist/cjs/kol-span.cjs.entry.js +1 -1
  121. package/dist/cjs/kol-spin.cjs.entry.js +1 -1
  122. package/dist/cjs/kol-split-button.cjs.entry.js +1 -1
  123. package/dist/cjs/kol-symbol.cjs.entry.js +1 -1
  124. package/dist/cjs/kol-table.cjs.entry.js +1 -1
  125. package/dist/cjs/kol-table.cjs.entry.js.map +1 -1
  126. package/dist/cjs/kol-tabs.cjs.entry.js +1 -1
  127. package/dist/cjs/kol-tabs.cjs.entry.js.map +1 -1
  128. package/dist/cjs/kol-textarea.cjs.entry.js +1 -1
  129. package/dist/cjs/kol-toast-container.cjs.entry.js +1 -1
  130. package/dist/cjs/kol-toast-container.cjs.entry.js.map +1 -1
  131. package/dist/cjs/kol-toast.cjs.entry.js +1 -1
  132. package/dist/cjs/kol-toast.cjs.entry.js.map +1 -1
  133. package/dist/cjs/kol-tooltip-wc.cjs.entry.js +1 -1
  134. package/dist/cjs/kol-tooltip-wc.cjs.entry.js.map +1 -1
  135. package/dist/cjs/kol-version.cjs.entry.js +1 -1
  136. package/dist/cjs/kolibri.cjs.js +1 -1
  137. package/dist/cjs/kolibri.cjs.js.map +1 -1
  138. package/dist/cjs/{label-2c4c9c06.js → label-6c2fcc6c.js} +1 -1
  139. package/dist/cjs/{label-2c4c9c06.js.map → label-6c2fcc6c.js.map} +1 -1
  140. package/dist/cjs/loader.cjs.js +1 -1
  141. package/dist/cjs/open-5d8dce09.js +4 -0
  142. package/dist/cjs/{open-1e28d73e.js.map → open-5d8dce09.js.map} +1 -1
  143. package/dist/cjs/{prop.validators-3d1d4699.js → prop.validators-e398c40b.js} +1 -1
  144. package/dist/cjs/{prop.validators-3d1d4699.js.map → prop.validators-e398c40b.js.map} +1 -1
  145. package/dist/cjs/rows-3d1fb229.js +4 -0
  146. package/dist/cjs/{rows-8d523947.js.map → rows-3d1fb229.js.map} +1 -1
  147. package/dist/cjs/show-5e4b5c4e.js +4 -0
  148. package/dist/cjs/{show-98b5bab8.js.map → show-5e4b5c4e.js.map} +1 -1
  149. package/dist/cjs/{suggestions-fea0cdcf.js → suggestions-32b90e73.js} +1 -1
  150. package/dist/cjs/{suggestions-fea0cdcf.js.map → suggestions-32b90e73.js.map} +1 -1
  151. package/dist/cjs/{tab-index-d6ae0846.js → tab-index-47dbd67b.js} +1 -1
  152. package/dist/cjs/{tab-index-d6ae0846.js.map → tab-index-47dbd67b.js.map} +1 -1
  153. package/dist/cjs/{tooltip-align-c87c6d36.js → tooltip-align-94c9bf86.js} +1 -1
  154. package/dist/cjs/{tooltip-align-c87c6d36.js.map → tooltip-align-94c9bf86.js.map} +1 -1
  155. package/dist/cjs/{validation-72e01bc7.js → validation-6499817f.js} +1 -1
  156. package/dist/cjs/{validation-72e01bc7.js.map → validation-6499817f.js.map} +1 -1
  157. package/dist/cjs/{validation-b9d08ddc.js → validation-89ceed98.js} +1 -1
  158. package/dist/cjs/{validation-b9d08ddc.js.map → validation-89ceed98.js.map} +1 -1
  159. package/dist/components/controller.js +1 -1
  160. package/dist/components/controller.js.map +1 -1
  161. package/dist/components/controller2.js +1 -1
  162. package/dist/components/controller2.js.map +1 -1
  163. package/dist/components/dev.utils.js +1 -1
  164. package/dist/components/dev.utils.js.map +1 -1
  165. package/dist/components/i18n.js +1 -1
  166. package/dist/components/i18n.js.map +1 -1
  167. package/dist/components/kol-abbr.js +1 -1
  168. package/dist/components/kol-accordion.js +1 -1
  169. package/dist/components/kol-alert-wc.js +1 -1
  170. package/dist/components/kol-alert-wc.js.map +1 -1
  171. package/dist/components/kol-alert.js +1 -1
  172. package/dist/components/kol-avatar-wc.js +1 -1
  173. package/dist/components/kol-avatar.js +1 -1
  174. package/dist/components/kol-badge.js +1 -1
  175. package/dist/components/kol-breadcrumb.js +1 -1
  176. package/dist/components/kol-breadcrumb.js.map +1 -1
  177. package/dist/components/kol-button-group-wc.js +1 -1
  178. package/dist/components/kol-button-group.js +1 -1
  179. package/dist/components/kol-button-link-text-switch.js +1 -1
  180. package/dist/components/kol-button-link.js +1 -1
  181. package/dist/components/kol-button-wc.js +1 -1
  182. package/dist/components/kol-button.js +1 -1
  183. package/dist/components/kol-card.js +1 -1
  184. package/dist/components/kol-card.js.map +1 -1
  185. package/dist/components/kol-details.js +1 -1
  186. package/dist/components/kol-form.js +1 -1
  187. package/dist/components/kol-form.js.map +1 -1
  188. package/dist/components/kol-heading-wc.js +1 -1
  189. package/dist/components/kol-heading.js +1 -1
  190. package/dist/components/kol-icon-font-awesome.js +1 -1
  191. package/dist/components/kol-icon-icofont.js +1 -1
  192. package/dist/components/kol-icon.js +1 -1
  193. package/dist/components/kol-image.js +1 -1
  194. package/dist/components/kol-indented-text.js +1 -1
  195. package/dist/components/kol-input-adapter-leanup.js +1 -1
  196. package/dist/components/kol-input-checkbox.js +1 -1
  197. package/dist/components/kol-input-checkbox.js.map +1 -1
  198. package/dist/components/kol-input-color.js +1 -1
  199. package/dist/components/kol-input-date.js +1 -1
  200. package/dist/components/kol-input-email.js +1 -1
  201. package/dist/components/kol-input-file.js +1 -1
  202. package/dist/components/kol-input-number.js +1 -1
  203. package/dist/components/kol-input-password.js +1 -1
  204. package/dist/components/kol-input-radio-group.js +1 -1
  205. package/dist/components/kol-input-radio.js +1 -1
  206. package/dist/components/kol-input-radio.js.map +1 -1
  207. package/dist/components/kol-input-range.js +1 -1
  208. package/dist/components/kol-input-range.js.map +1 -1
  209. package/dist/components/kol-input-text.js +1 -1
  210. package/dist/components/kol-input.js +1 -1
  211. package/dist/components/kol-input.js.map +1 -1
  212. package/dist/components/kol-kolibri.js +1 -1
  213. package/dist/components/kol-kolibri.js.map +1 -1
  214. package/dist/components/kol-link-button.js +1 -1
  215. package/dist/components/kol-link-group.js +1 -1
  216. package/dist/components/kol-link-group.js.map +1 -1
  217. package/dist/components/kol-link-wc.js +1 -1
  218. package/dist/components/kol-link-wc.js.map +1 -1
  219. package/dist/components/kol-link.js +1 -1
  220. package/dist/components/kol-logo.js +1 -1
  221. package/dist/components/kol-modal.js +1 -1
  222. package/dist/components/kol-modal.js.map +1 -1
  223. package/dist/components/kol-nav.js +1 -1
  224. package/dist/components/kol-nav.js.map +1 -1
  225. package/dist/components/kol-pagination.js +1 -1
  226. package/dist/components/kol-pagination.js.map +1 -1
  227. package/dist/components/kol-popover-wc.js +1 -1
  228. package/dist/components/kol-progress.js +1 -1
  229. package/dist/components/kol-quote.js +1 -1
  230. package/dist/components/kol-quote.js.map +1 -1
  231. package/dist/components/kol-select.js +1 -1
  232. package/dist/components/kol-select.js.map +1 -1
  233. package/dist/components/kol-skip-nav.js +1 -1
  234. package/dist/components/kol-span-wc.js +1 -1
  235. package/dist/components/kol-span-wc.js.map +1 -1
  236. package/dist/components/kol-span.js +1 -1
  237. package/dist/components/kol-spin.js +1 -1
  238. package/dist/components/kol-split-button.js +1 -1
  239. package/dist/components/kol-symbol.js +1 -1
  240. package/dist/components/kol-table.js +1 -1
  241. package/dist/components/kol-table.js.map +1 -1
  242. package/dist/components/kol-tabs.js +1 -1
  243. package/dist/components/kol-tabs.js.map +1 -1
  244. package/dist/components/kol-textarea.js +1 -1
  245. package/dist/components/kol-toast-container.js +1 -1
  246. package/dist/components/kol-toast-container.js.map +1 -1
  247. package/dist/components/kol-toast.js +1 -1
  248. package/dist/components/kol-toast.js.map +1 -1
  249. package/dist/components/kol-tooltip-wc.js +1 -1
  250. package/dist/components/kol-tooltip-wc.js.map +1 -1
  251. package/dist/components/kol-version.js +1 -1
  252. package/dist/esm/{a11y.tipps-798efb1a.js → a11y.tipps-477c41d6.js} +1 -1
  253. package/dist/esm/{a11y.tipps-798efb1a.js.map → a11y.tipps-477c41d6.js.map} +1 -1
  254. package/dist/esm/{align-beb00370.js → align-4bf3b7ec.js} +1 -1
  255. package/dist/esm/{align-beb00370.js.map → align-4bf3b7ec.js.map} +1 -1
  256. package/dist/esm/{alignment-4c0cd265.js → alignment-7c2e01fd.js} +1 -1
  257. package/dist/esm/{alignment-4c0cd265.js.map → alignment-7c2e01fd.js.map} +1 -1
  258. package/dist/esm/app-globals-70731b63.js +4 -0
  259. package/dist/esm/{app-globals-529eaac0.js.map → app-globals-70731b63.js.map} +1 -1
  260. package/dist/esm/{aria-current-09b1cf77.js → aria-current-2d66f536.js} +1 -1
  261. package/dist/esm/{aria-current-09b1cf77.js.map → aria-current-2d66f536.js.map} +1 -1
  262. package/dist/esm/{associated.controller-367d4241.js → associated.controller-8a07ed2c.js} +1 -1
  263. package/dist/esm/{associated.controller-367d4241.js.map → associated.controller-8a07ed2c.js.map} +1 -1
  264. package/dist/esm/{color-51fda110.js → color-2ac447e3.js} +1 -1
  265. package/dist/esm/{color-51fda110.js.map → color-2ac447e3.js.map} +1 -1
  266. package/dist/esm/{controller-4693379a.js → controller-01043b6c.js} +1 -1
  267. package/dist/esm/{controller-4693379a.js.map → controller-01043b6c.js.map} +1 -1
  268. package/dist/esm/{controller-67717038.js → controller-07d7750b.js} +1 -1
  269. package/dist/esm/{controller-67717038.js.map → controller-07d7750b.js.map} +1 -1
  270. package/dist/esm/{controller-d9f61e71.js → controller-144e628b.js} +1 -1
  271. package/dist/esm/controller-144e628b.js.map +1 -0
  272. package/dist/esm/{controller-09b624a5.js → controller-2680504a.js} +1 -1
  273. package/dist/esm/{controller-09b624a5.js.map → controller-2680504a.js.map} +1 -1
  274. package/dist/esm/controller-aed932e0.js +4 -0
  275. package/dist/esm/controller-aed932e0.js.map +1 -0
  276. package/dist/esm/{controller-icon-7d98b00e.js → controller-icon-d8edaf27.js} +1 -1
  277. package/dist/esm/{controller-icon-7d98b00e.js.map → controller-icon-d8edaf27.js.map} +1 -1
  278. package/dist/esm/{custom-class-76b06f69.js → custom-class-b9bd1dfe.js} +1 -1
  279. package/dist/esm/{custom-class-76b06f69.js.map → custom-class-b9bd1dfe.js.map} +1 -1
  280. package/dist/esm/{dev.utils-f829063f.js → dev.utils-1e8dd4a9.js} +1 -1
  281. package/dist/esm/{dev.utils-f829063f.js.map → dev.utils-1e8dd4a9.js.map} +1 -1
  282. package/dist/esm/{devtools-2bd953c4.js → devtools-49a4a7c8.js} +1 -1
  283. package/dist/esm/{devtools-2bd953c4.js.map → devtools-49a4a7c8.js.map} +1 -1
  284. package/dist/esm/form-field-msg-502ca78a.js +4 -0
  285. package/dist/esm/{form-field-msg-85face25.js.map → form-field-msg-502ca78a.js.map} +1 -1
  286. package/dist/esm/{has-closer-1a36473f.js → has-closer-e00fca00.js} +1 -1
  287. package/dist/esm/{has-closer-1a36473f.js.map → has-closer-e00fca00.js.map} +1 -1
  288. package/dist/esm/{hide-label-000c16f6.js → hide-label-16c3f288.js} +1 -1
  289. package/dist/esm/{hide-label-000c16f6.js.map → hide-label-16c3f288.js.map} +1 -1
  290. package/dist/esm/{i18n-ad947f60.js → i18n-8ac68853.js} +1 -1
  291. package/dist/esm/{i18n-ad947f60.js.map → i18n-8ac68853.js.map} +1 -1
  292. package/dist/esm/{i18n-fddf0324.js → i18n-a2f79a81.js} +1 -1
  293. package/dist/esm/i18n-a2f79a81.js.map +1 -0
  294. package/dist/esm/{icons-82e358f3.js → icons-c8b28f01.js} +1 -1
  295. package/dist/esm/{icons-82e358f3.js.map → icons-c8b28f01.js.map} +1 -1
  296. package/dist/esm/{image-source-8584365e.js → image-source-b82c30ce.js} +1 -1
  297. package/dist/esm/{image-source-8584365e.js.map → image-source-b82c30ce.js.map} +1 -1
  298. package/dist/esm/index-dfb131c4.js +4 -0
  299. package/dist/esm/index-dfb131c4.js.map +1 -0
  300. package/dist/esm/index.js +1 -1
  301. package/dist/esm/kol-abbr.entry.js +1 -1
  302. package/dist/esm/kol-accordion.entry.js +1 -1
  303. package/dist/esm/kol-alert-wc.entry.js +1 -1
  304. package/dist/esm/kol-alert-wc.entry.js.map +1 -1
  305. package/dist/esm/kol-alert.entry.js +1 -1
  306. package/dist/esm/kol-avatar-wc.entry.js +1 -1
  307. package/dist/esm/kol-avatar.entry.js +1 -1
  308. package/dist/esm/kol-badge.entry.js +1 -1
  309. package/dist/esm/kol-breadcrumb.entry.js +1 -1
  310. package/dist/esm/kol-breadcrumb.entry.js.map +1 -1
  311. package/dist/esm/kol-button-group-wc.entry.js +1 -1
  312. package/dist/esm/kol-button-group.entry.js +1 -1
  313. package/dist/esm/kol-button-link-text-switch.entry.js +1 -1
  314. package/dist/esm/kol-button-link.entry.js +1 -1
  315. package/dist/esm/kol-button-wc.entry.js +1 -1
  316. package/dist/esm/kol-button.entry.js +1 -1
  317. package/dist/esm/kol-card.entry.js +1 -1
  318. package/dist/esm/kol-card.entry.js.map +1 -1
  319. package/dist/esm/kol-details.entry.js +1 -1
  320. package/dist/esm/kol-form.entry.js +1 -1
  321. package/dist/esm/kol-form.entry.js.map +1 -1
  322. package/dist/esm/kol-heading-wc.entry.js +1 -1
  323. package/dist/esm/kol-heading.entry.js +1 -1
  324. package/dist/esm/kol-icon-font-awesome.entry.js +1 -1
  325. package/dist/esm/kol-icon-icofont.entry.js +1 -1
  326. package/dist/esm/kol-icon.entry.js +1 -1
  327. package/dist/esm/kol-image.entry.js +1 -1
  328. package/dist/esm/kol-indented-text.entry.js +1 -1
  329. package/dist/esm/kol-input-adapter-leanup.entry.js +1 -1
  330. package/dist/esm/kol-input-checkbox.entry.js +1 -1
  331. package/dist/esm/kol-input-checkbox.entry.js.map +1 -1
  332. package/dist/esm/kol-input-color.entry.js +1 -1
  333. package/dist/esm/kol-input-date.entry.js +1 -1
  334. package/dist/esm/kol-input-email.entry.js +1 -1
  335. package/dist/esm/kol-input-file.entry.js +1 -1
  336. package/dist/esm/kol-input-number.entry.js +1 -1
  337. package/dist/esm/kol-input-password.entry.js +1 -1
  338. package/dist/esm/kol-input-radio-group.entry.js +1 -1
  339. package/dist/esm/kol-input-radio.entry.js +1 -1
  340. package/dist/esm/kol-input-radio.entry.js.map +1 -1
  341. package/dist/esm/kol-input-range.entry.js +1 -1
  342. package/dist/esm/kol-input-range.entry.js.map +1 -1
  343. package/dist/esm/kol-input-text.entry.js +1 -1
  344. package/dist/esm/kol-input.entry.js +1 -1
  345. package/dist/esm/kol-input.entry.js.map +1 -1
  346. package/dist/esm/kol-kolibri.entry.js +1 -1
  347. package/dist/esm/kol-kolibri.entry.js.map +1 -1
  348. package/dist/esm/kol-link-button.entry.js +1 -1
  349. package/dist/esm/kol-link-group.entry.js +1 -1
  350. package/dist/esm/kol-link-group.entry.js.map +1 -1
  351. package/dist/esm/kol-link-wc.entry.js +1 -1
  352. package/dist/esm/kol-link-wc.entry.js.map +1 -1
  353. package/dist/esm/kol-link.entry.js +1 -1
  354. package/dist/esm/kol-logo.entry.js +1 -1
  355. package/dist/esm/kol-modal.entry.js +1 -1
  356. package/dist/esm/kol-modal.entry.js.map +1 -1
  357. package/dist/esm/kol-nav.entry.js +1 -1
  358. package/dist/esm/kol-nav.entry.js.map +1 -1
  359. package/dist/esm/kol-pagination.entry.js +1 -1
  360. package/dist/esm/kol-pagination.entry.js.map +1 -1
  361. package/dist/esm/kol-popover-wc.entry.js +1 -1
  362. package/dist/esm/kol-progress.entry.js +1 -1
  363. package/dist/esm/kol-quote.entry.js +1 -1
  364. package/dist/esm/kol-quote.entry.js.map +1 -1
  365. package/dist/esm/kol-select.entry.js +1 -1
  366. package/dist/esm/kol-select.entry.js.map +1 -1
  367. package/dist/esm/kol-skip-nav.entry.js +1 -1
  368. package/dist/esm/kol-span-wc.entry.js +1 -1
  369. package/dist/esm/kol-span-wc.entry.js.map +1 -1
  370. package/dist/esm/kol-span.entry.js +1 -1
  371. package/dist/esm/kol-spin.entry.js +1 -1
  372. package/dist/esm/kol-split-button.entry.js +1 -1
  373. package/dist/esm/kol-symbol.entry.js +1 -1
  374. package/dist/esm/kol-table.entry.js +1 -1
  375. package/dist/esm/kol-table.entry.js.map +1 -1
  376. package/dist/esm/kol-tabs.entry.js +1 -1
  377. package/dist/esm/kol-tabs.entry.js.map +1 -1
  378. package/dist/esm/kol-textarea.entry.js +1 -1
  379. package/dist/esm/kol-toast-container.entry.js +1 -1
  380. package/dist/esm/kol-toast-container.entry.js.map +1 -1
  381. package/dist/esm/kol-toast.entry.js +1 -1
  382. package/dist/esm/kol-toast.entry.js.map +1 -1
  383. package/dist/esm/kol-tooltip-wc.entry.js +1 -1
  384. package/dist/esm/kol-tooltip-wc.entry.js.map +1 -1
  385. package/dist/esm/kol-version.entry.js +1 -1
  386. package/dist/esm/kolibri.js +1 -1
  387. package/dist/esm/kolibri.js.map +1 -1
  388. package/dist/esm/{label-bce4f328.js → label-48b51f80.js} +1 -1
  389. package/dist/esm/{label-bce4f328.js.map → label-48b51f80.js.map} +1 -1
  390. package/dist/esm/loader.js +1 -1
  391. package/dist/esm/{open-e11c786d.js → open-21fd43f3.js} +1 -1
  392. package/dist/esm/{open-e11c786d.js.map → open-21fd43f3.js.map} +1 -1
  393. package/dist/esm/{prop.validators-3017e14b.js → prop.validators-a62aac63.js} +1 -1
  394. package/dist/esm/{prop.validators-3017e14b.js.map → prop.validators-a62aac63.js.map} +1 -1
  395. package/dist/esm/{rows-4627c8c8.js → rows-4f0d764d.js} +1 -1
  396. package/dist/esm/{rows-4627c8c8.js.map → rows-4f0d764d.js.map} +1 -1
  397. package/dist/esm/{show-418f2510.js → show-fbf4d497.js} +1 -1
  398. package/dist/esm/{show-418f2510.js.map → show-fbf4d497.js.map} +1 -1
  399. package/dist/esm/{suggestions-f022cab2.js → suggestions-d4f1737f.js} +1 -1
  400. package/dist/esm/{suggestions-f022cab2.js.map → suggestions-d4f1737f.js.map} +1 -1
  401. package/dist/esm/{tab-index-22839788.js → tab-index-6065fa94.js} +1 -1
  402. package/dist/esm/{tab-index-22839788.js.map → tab-index-6065fa94.js.map} +1 -1
  403. package/dist/esm/{tooltip-align-a16d498e.js → tooltip-align-960e84c4.js} +1 -1
  404. package/dist/esm/{tooltip-align-a16d498e.js.map → tooltip-align-960e84c4.js.map} +1 -1
  405. package/dist/esm/validation-13009299.js +4 -0
  406. package/dist/esm/{validation-8785c967.js.map → validation-13009299.js.map} +1 -1
  407. package/dist/esm/validation-a87d2ca3.js +4 -0
  408. package/dist/esm/{validation-f641b69f.js.map → validation-a87d2ca3.js.map} +1 -1
  409. package/dist/kolibri/{a11y.tipps-798efb1a.js → a11y.tipps-477c41d6.js} +1 -1
  410. package/dist/kolibri/align-4bf3b7ec.js +4 -0
  411. package/dist/kolibri/alignment-7c2e01fd.js +4 -0
  412. package/dist/kolibri/app-globals-70731b63.js +4 -0
  413. package/dist/kolibri/aria-current-2d66f536.js +4 -0
  414. package/dist/kolibri/{associated.controller-367d4241.js → associated.controller-8a07ed2c.js} +1 -1
  415. package/dist/kolibri/{color-51fda110.js → color-2ac447e3.js} +1 -1
  416. package/dist/kolibri/{controller-4693379a.js → controller-01043b6c.js} +1 -1
  417. package/dist/kolibri/{controller-67717038.js → controller-07d7750b.js} +1 -1
  418. package/dist/kolibri/{controller-d9f61e71.js → controller-144e628b.js} +1 -1
  419. package/dist/kolibri/{controller-d9f61e71.js.map → controller-144e628b.js.map} +1 -1
  420. package/dist/kolibri/{controller-09b624a5.js → controller-2680504a.js} +1 -1
  421. package/dist/kolibri/controller-aed932e0.js +4 -0
  422. package/dist/kolibri/controller-aed932e0.js.map +1 -0
  423. package/dist/kolibri/controller-icon-d8edaf27.js +4 -0
  424. package/dist/kolibri/{custom-class-76b06f69.js → custom-class-b9bd1dfe.js} +1 -1
  425. package/dist/kolibri/{dev.utils-f829063f.js → dev.utils-1e8dd4a9.js} +1 -1
  426. package/dist/kolibri/{dev.utils-f829063f.js.map → dev.utils-1e8dd4a9.js.map} +1 -1
  427. package/dist/kolibri/{devtools-2bd953c4.js → devtools-49a4a7c8.js} +1 -1
  428. package/dist/kolibri/form-field-msg-502ca78a.js +4 -0
  429. package/dist/kolibri/has-closer-e00fca00.js +4 -0
  430. package/dist/kolibri/{has-closer-1a36473f.js.map → has-closer-e00fca00.js.map} +1 -1
  431. package/dist/kolibri/hide-label-16c3f288.js +4 -0
  432. package/dist/kolibri/{i18n-ad947f60.js → i18n-8ac68853.js} +1 -1
  433. package/dist/kolibri/{i18n-fddf0324.js → i18n-a2f79a81.js} +1 -1
  434. package/dist/kolibri/i18n-a2f79a81.js.map +1 -0
  435. package/dist/kolibri/icons-c8b28f01.js +4 -0
  436. package/dist/kolibri/image-source-b82c30ce.js +4 -0
  437. package/dist/kolibri/index-dfb131c4.js +5 -0
  438. package/dist/kolibri/index-dfb131c4.js.map +1 -0
  439. package/dist/kolibri/index.esm.js +1 -1
  440. package/dist/kolibri/kol-abbr.entry.js +1 -1
  441. package/dist/kolibri/kol-accordion.entry.js +1 -1
  442. package/dist/kolibri/kol-alert-wc.entry.js +1 -1
  443. package/dist/kolibri/kol-alert-wc.entry.js.map +1 -1
  444. package/dist/kolibri/kol-alert.entry.js +1 -1
  445. package/dist/kolibri/kol-avatar-wc.entry.js +1 -1
  446. package/dist/kolibri/kol-avatar.entry.js +1 -1
  447. package/dist/kolibri/kol-badge.entry.js +1 -1
  448. package/dist/kolibri/kol-breadcrumb.entry.js +1 -1
  449. package/dist/kolibri/kol-breadcrumb.entry.js.map +1 -1
  450. package/dist/kolibri/kol-button-group-wc.entry.js +1 -1
  451. package/dist/kolibri/kol-button-group.entry.js +1 -1
  452. package/dist/kolibri/kol-button-link-text-switch.entry.js +1 -1
  453. package/dist/kolibri/kol-button-link.entry.js +1 -1
  454. package/dist/kolibri/kol-button-wc.entry.js +1 -1
  455. package/dist/kolibri/kol-button-wc.entry.js.map +1 -1
  456. package/dist/kolibri/kol-button.entry.js +1 -1
  457. package/dist/kolibri/kol-card.entry.js +1 -1
  458. package/dist/kolibri/kol-card.entry.js.map +1 -1
  459. package/dist/kolibri/kol-details.entry.js +1 -1
  460. package/dist/kolibri/kol-form.entry.js +1 -1
  461. package/dist/kolibri/kol-form.entry.js.map +1 -1
  462. package/dist/kolibri/kol-heading-wc.entry.js +1 -1
  463. package/dist/kolibri/kol-heading.entry.js +1 -1
  464. package/dist/kolibri/kol-icon-font-awesome.entry.js +1 -1
  465. package/dist/kolibri/kol-icon-icofont.entry.js +1 -1
  466. package/dist/kolibri/kol-icon.entry.js +1 -1
  467. package/dist/kolibri/kol-image.entry.js +1 -1
  468. package/dist/kolibri/kol-indented-text.entry.js +1 -1
  469. package/dist/kolibri/kol-input-adapter-leanup.entry.js +1 -1
  470. package/dist/kolibri/kol-input-checkbox.entry.js +1 -1
  471. package/dist/kolibri/kol-input-checkbox.entry.js.map +1 -1
  472. package/dist/kolibri/kol-input-color.entry.js +1 -1
  473. package/dist/kolibri/kol-input-date.entry.js +1 -1
  474. package/dist/kolibri/kol-input-email.entry.js +1 -1
  475. package/dist/kolibri/kol-input-file.entry.js +1 -1
  476. package/dist/kolibri/kol-input-number.entry.js +1 -1
  477. package/dist/kolibri/kol-input-password.entry.js +1 -1
  478. package/dist/kolibri/kol-input-radio-group.entry.js +1 -1
  479. package/dist/kolibri/kol-input-radio.entry.js +1 -1
  480. package/dist/kolibri/kol-input-radio.entry.js.map +1 -1
  481. package/dist/kolibri/kol-input-range.entry.js +1 -1
  482. package/dist/kolibri/kol-input-range.entry.js.map +1 -1
  483. package/dist/kolibri/kol-input-text.entry.js +1 -1
  484. package/dist/kolibri/kol-input.entry.js +1 -1
  485. package/dist/kolibri/kol-input.entry.js.map +1 -1
  486. package/dist/kolibri/kol-kolibri.entry.js +1 -1
  487. package/dist/kolibri/kol-kolibri.entry.js.map +1 -1
  488. package/dist/kolibri/kol-link-button.entry.js +1 -1
  489. package/dist/kolibri/kol-link-group.entry.js +1 -1
  490. package/dist/kolibri/kol-link-group.entry.js.map +1 -1
  491. package/dist/kolibri/kol-link-wc.entry.js +1 -1
  492. package/dist/kolibri/kol-link-wc.entry.js.map +1 -1
  493. package/dist/kolibri/kol-link.entry.js +1 -1
  494. package/dist/kolibri/kol-logo.entry.js +1 -1
  495. package/dist/kolibri/kol-modal.entry.js +1 -1
  496. package/dist/kolibri/kol-modal.entry.js.map +1 -1
  497. package/dist/kolibri/kol-nav.entry.js +1 -1
  498. package/dist/kolibri/kol-nav.entry.js.map +1 -1
  499. package/dist/kolibri/kol-pagination.entry.js +1 -1
  500. package/dist/kolibri/kol-pagination.entry.js.map +1 -1
  501. package/dist/kolibri/kol-popover-wc.entry.js +1 -1
  502. package/dist/kolibri/kol-progress.entry.js +1 -1
  503. package/dist/kolibri/kol-quote.entry.js +1 -1
  504. package/dist/kolibri/kol-quote.entry.js.map +1 -1
  505. package/dist/kolibri/kol-select.entry.js +1 -1
  506. package/dist/kolibri/kol-select.entry.js.map +1 -1
  507. package/dist/kolibri/kol-skip-nav.entry.js +1 -1
  508. package/dist/kolibri/kol-span-wc.entry.js +1 -1
  509. package/dist/kolibri/kol-span-wc.entry.js.map +1 -1
  510. package/dist/kolibri/kol-span.entry.js +1 -1
  511. package/dist/kolibri/kol-spin.entry.js +1 -1
  512. package/dist/kolibri/kol-split-button.entry.js +1 -1
  513. package/dist/kolibri/kol-symbol.entry.js +1 -1
  514. package/dist/kolibri/kol-table.entry.js +1 -1
  515. package/dist/kolibri/kol-table.entry.js.map +1 -1
  516. package/dist/kolibri/kol-tabs.entry.js +1 -1
  517. package/dist/kolibri/kol-tabs.entry.js.map +1 -1
  518. package/dist/kolibri/kol-textarea.entry.js +1 -1
  519. package/dist/kolibri/kol-toast-container.entry.js +1 -1
  520. package/dist/kolibri/kol-toast-container.entry.js.map +1 -1
  521. package/dist/kolibri/kol-toast.entry.js +1 -1
  522. package/dist/kolibri/kol-toast.entry.js.map +1 -1
  523. package/dist/kolibri/kol-tooltip-wc.entry.js +1 -1
  524. package/dist/kolibri/kol-tooltip-wc.entry.js.map +1 -1
  525. package/dist/kolibri/kol-version.entry.js +1 -1
  526. package/dist/kolibri/kolibri.esm.js +1 -1
  527. package/dist/kolibri/kolibri.esm.js.map +1 -1
  528. package/dist/kolibri/label-48b51f80.js +4 -0
  529. package/dist/kolibri/open-21fd43f3.js +4 -0
  530. package/dist/kolibri/{open-e11c786d.js.map → open-21fd43f3.js.map} +1 -1
  531. package/dist/kolibri/{prop.validators-3017e14b.js → prop.validators-a62aac63.js} +1 -1
  532. package/dist/kolibri/rows-4f0d764d.js +4 -0
  533. package/dist/kolibri/show-fbf4d497.js +4 -0
  534. package/dist/kolibri/{show-418f2510.js.map → show-fbf4d497.js.map} +1 -1
  535. package/dist/kolibri/suggestions-d4f1737f.js +4 -0
  536. package/dist/kolibri/tab-index-6065fa94.js +4 -0
  537. package/dist/kolibri/{tab-index-22839788.js.map → tab-index-6065fa94.js.map} +1 -1
  538. package/dist/kolibri/tooltip-align-960e84c4.js +4 -0
  539. package/dist/kolibri/validation-13009299.js +4 -0
  540. package/dist/kolibri/validation-a87d2ca3.js +4 -0
  541. package/dist/types/components/input-checkbox/component.d.ts +1 -0
  542. package/dist/types/components/input-radio/component.d.ts +1 -0
  543. package/dist/types/components/select/component.d.ts +1 -0
  544. package/dist/types/components/tabs/component.d.ts +0 -1
  545. package/dist/types/types/input/types.d.ts +1 -1
  546. package/doc/popover.md +2 -0
  547. package/doc/tooltip.md +1 -1
  548. package/package.json +1 -1
  549. package/vscode-custom-data.json +2 -2
  550. package/dist/cjs/align-4d94a35f.js +0 -4
  551. package/dist/cjs/controller-c99812e7.js.map +0 -1
  552. package/dist/cjs/controller-dbd30a67.js +0 -4
  553. package/dist/cjs/controller-dbd30a67.js.map +0 -1
  554. package/dist/cjs/has-closer-2cae00d9.js +0 -4
  555. package/dist/cjs/hide-label-b0beb21d.js +0 -4
  556. package/dist/cjs/i18n-c3fa5bd7.js.map +0 -1
  557. package/dist/cjs/image-source-7a3dc14e.js +0 -4
  558. package/dist/cjs/index-67d1914c.js +0 -4
  559. package/dist/cjs/index-67d1914c.js.map +0 -1
  560. package/dist/cjs/open-1e28d73e.js +0 -4
  561. package/dist/cjs/rows-8d523947.js +0 -4
  562. package/dist/cjs/show-98b5bab8.js +0 -4
  563. package/dist/esm/app-globals-529eaac0.js +0 -4
  564. package/dist/esm/controller-7832022a.js +0 -4
  565. package/dist/esm/controller-7832022a.js.map +0 -1
  566. package/dist/esm/controller-d9f61e71.js.map +0 -1
  567. package/dist/esm/form-field-msg-85face25.js +0 -4
  568. package/dist/esm/i18n-fddf0324.js.map +0 -1
  569. package/dist/esm/index-a051748e.js +0 -4
  570. package/dist/esm/index-a051748e.js.map +0 -1
  571. package/dist/esm/validation-8785c967.js +0 -4
  572. package/dist/esm/validation-f641b69f.js +0 -4
  573. package/dist/kolibri/align-beb00370.js +0 -4
  574. package/dist/kolibri/alignment-4c0cd265.js +0 -4
  575. package/dist/kolibri/app-globals-529eaac0.js +0 -4
  576. package/dist/kolibri/aria-current-09b1cf77.js +0 -4
  577. package/dist/kolibri/controller-7832022a.js +0 -4
  578. package/dist/kolibri/controller-7832022a.js.map +0 -1
  579. package/dist/kolibri/controller-icon-7d98b00e.js +0 -4
  580. package/dist/kolibri/form-field-msg-85face25.js +0 -4
  581. package/dist/kolibri/has-closer-1a36473f.js +0 -4
  582. package/dist/kolibri/hide-label-000c16f6.js +0 -4
  583. package/dist/kolibri/i18n-fddf0324.js.map +0 -1
  584. package/dist/kolibri/icons-82e358f3.js +0 -4
  585. package/dist/kolibri/image-source-8584365e.js +0 -4
  586. package/dist/kolibri/index-a051748e.js +0 -5
  587. package/dist/kolibri/index-a051748e.js.map +0 -1
  588. package/dist/kolibri/label-bce4f328.js +0 -4
  589. package/dist/kolibri/open-e11c786d.js +0 -4
  590. package/dist/kolibri/rows-4627c8c8.js +0 -4
  591. package/dist/kolibri/show-418f2510.js +0 -4
  592. package/dist/kolibri/suggestions-f022cab2.js +0 -4
  593. package/dist/kolibri/tab-index-22839788.js +0 -4
  594. package/dist/kolibri/tooltip-align-a16d498e.js +0 -4
  595. package/dist/kolibri/validation-8785c967.js +0 -4
  596. package/dist/kolibri/validation-f641b69f.js +0 -4
  597. /package/dist/kolibri/{a11y.tipps-798efb1a.js.map → a11y.tipps-477c41d6.js.map} +0 -0
  598. /package/dist/kolibri/{align-beb00370.js.map → align-4bf3b7ec.js.map} +0 -0
  599. /package/dist/kolibri/{alignment-4c0cd265.js.map → alignment-7c2e01fd.js.map} +0 -0
  600. /package/dist/kolibri/{app-globals-529eaac0.js.map → app-globals-70731b63.js.map} +0 -0
  601. /package/dist/kolibri/{aria-current-09b1cf77.js.map → aria-current-2d66f536.js.map} +0 -0
  602. /package/dist/kolibri/{associated.controller-367d4241.js.map → associated.controller-8a07ed2c.js.map} +0 -0
  603. /package/dist/kolibri/{color-51fda110.js.map → color-2ac447e3.js.map} +0 -0
  604. /package/dist/kolibri/{controller-4693379a.js.map → controller-01043b6c.js.map} +0 -0
  605. /package/dist/kolibri/{controller-67717038.js.map → controller-07d7750b.js.map} +0 -0
  606. /package/dist/kolibri/{controller-09b624a5.js.map → controller-2680504a.js.map} +0 -0
  607. /package/dist/kolibri/{controller-icon-7d98b00e.js.map → controller-icon-d8edaf27.js.map} +0 -0
  608. /package/dist/kolibri/{custom-class-76b06f69.js.map → custom-class-b9bd1dfe.js.map} +0 -0
  609. /package/dist/kolibri/{devtools-2bd953c4.js.map → devtools-49a4a7c8.js.map} +0 -0
  610. /package/dist/kolibri/{form-field-msg-85face25.js.map → form-field-msg-502ca78a.js.map} +0 -0
  611. /package/dist/kolibri/{hide-label-000c16f6.js.map → hide-label-16c3f288.js.map} +0 -0
  612. /package/dist/kolibri/{i18n-ad947f60.js.map → i18n-8ac68853.js.map} +0 -0
  613. /package/dist/kolibri/{icons-82e358f3.js.map → icons-c8b28f01.js.map} +0 -0
  614. /package/dist/kolibri/{image-source-8584365e.js.map → image-source-b82c30ce.js.map} +0 -0
  615. /package/dist/kolibri/{label-bce4f328.js.map → label-48b51f80.js.map} +0 -0
  616. /package/dist/kolibri/{prop.validators-3017e14b.js.map → prop.validators-a62aac63.js.map} +0 -0
  617. /package/dist/kolibri/{rows-4627c8c8.js.map → rows-4f0d764d.js.map} +0 -0
  618. /package/dist/kolibri/{suggestions-f022cab2.js.map → suggestions-d4f1737f.js.map} +0 -0
  619. /package/dist/kolibri/{tooltip-align-a16d498e.js.map → tooltip-align-960e84c4.js.map} +0 -0
  620. /package/dist/kolibri/{validation-8785c967.js.map → validation-13009299.js.map} +0 -0
  621. /package/dist/kolibri/{validation-f641b69f.js.map → validation-a87d2ca3.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"names":["ModalService","constructor","this","lockedElements","Map","modalStack","lockElement","htmlElement","tabIndex","getAttribute","HTMLAnchorElement","HTMLButtonElement","HTMLInputElement","HTMLSelectElement","HTMLTextAreaElement","dataset","kolModal","undefined","set","setAttribute","style","userSelect","unlockElement","value","removeAttribute","delete","unlockLockedElements","forEach","bind","lockFocus","hostElement","excludeElement","HTMLElement","ShadowRoot","shadowRoot","i","children","length","renderModalIfExists","activeElement","has","get","timeout","setTimeout","clearTimeout","focus","size","modalKeys","Array","from","keys","modalRef","_value","display","getDocument","body","maxHeight","overflow","openModal","Log","warn","closeModal","_a","defaultStyleCss","KolModalDefaultStyle0","modalService","KolModal","onKeyDown","event","code","_activeElement","_label","_width","componentDidRender","state","disconnectedCallback","render","h","Host","key","class","ref","el","width","role","validateActiveElement","watchValidator","Set","defaultValue","hooks","afterPatch","_on","onClose","validateAriaLabel","validateLabel","required","validateOn","featureHint","callbacks","setState","validateWidth","watchString","componentWillLoad","_ariaLabel"],"sources":["src/components/modal/service.ts","src/components/modal/style.scss?tag=kol-modal&mode=default&encapsulation=shadow","src/components/modal/component.tsx"],"sourcesContent":["import { getDocument, Log } from '../../utils/dev.utils';\n\ntype ModalContext = {\n\tactiveElement?: HTMLElement;\n};\n\ntype LockedElementContext = {\n\ttabIndex?: string;\n};\n\n/**\n * The modal service is only working client-side!\n */\nexport class ModalService {\n\tprivate lockedElements: Map<HTMLElement, LockedElementContext> = new Map();\n\tprivate modalStack: Map<HTMLElement, ModalContext> = new Map();\n\n\tprivate lockElement(htmlElement: HTMLElement) {\n\t\tconst tabIndex: string | null = htmlElement.getAttribute('tabindex');\n\t\tif (\n\t\t\thtmlElement instanceof HTMLAnchorElement ||\n\t\t\thtmlElement instanceof HTMLButtonElement ||\n\t\t\thtmlElement instanceof HTMLInputElement ||\n\t\t\thtmlElement instanceof HTMLSelectElement ||\n\t\t\thtmlElement instanceof HTMLTextAreaElement ||\n\t\t\ttypeof tabIndex === 'string' ||\n\t\t\thtmlElement.dataset.kolModal !== undefined\n\t\t) {\n\t\t\tif (typeof tabIndex === 'string') {\n\t\t\t\tthis.lockedElements.set(htmlElement, {\n\t\t\t\t\ttabIndex,\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tthis.lockedElements.set(htmlElement, {});\n\t\t\t}\n\t\t\thtmlElement.setAttribute('tabindex', '-1');\n\t\t\thtmlElement.setAttribute('aria-hidden', 'true');\n\t\t\thtmlElement.style.userSelect = 'none';\n\t\t}\n\t}\n\n\tprivate unlockElement(value: LockedElementContext, htmlElement: HTMLElement) {\n\t\tif (typeof value.tabIndex === 'string') {\n\t\t\thtmlElement.setAttribute('tabindex', value.tabIndex);\n\t\t} else {\n\t\t\thtmlElement.removeAttribute('tabindex');\n\t\t}\n\t\thtmlElement.removeAttribute('aria-hidden');\n\t\thtmlElement.style.userSelect = 'unset';\n\t\tthis.lockedElements.delete(htmlElement);\n\t}\n\n\tprivate unlockLockedElements(lockedElements: Map<HTMLElement, LockedElementContext>) {\n\t\tlockedElements.forEach(this.unlockElement.bind(this));\n\t}\n\n\tprivate lockFocus(hostElement: HTMLElement | ShadowRoot | null, excludeElement?: HTMLElement) {\n\t\tif (hostElement !== excludeElement && (hostElement instanceof HTMLElement || hostElement instanceof ShadowRoot)) {\n\t\t\tif (hostElement instanceof HTMLElement) {\n\t\t\t\tthis.lockElement(hostElement);\n\t\t\t\tthis.lockFocus(hostElement.shadowRoot, excludeElement);\n\t\t\t}\n\t\t\tfor (let i = 0; i < hostElement.children.length; i++) {\n\t\t\t\tthis.lockFocus(hostElement.children[i] as HTMLElement, excludeElement);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate renderModalIfExists(activeElement?: HTMLElement) {\n\t\tif (activeElement instanceof HTMLElement) {\n\t\t\tif (this.lockedElements.has(activeElement)) {\n\t\t\t\tthis.unlockElement(this.lockedElements.get(activeElement) as LockedElementContext, activeElement);\n\t\t\t}\n\t\t\tconst timeout = setTimeout(() => {\n\t\t\t\tclearTimeout(timeout);\n\t\t\t\tactiveElement.focus();\n\t\t\t}, 500);\n\t\t}\n\t\tthis.unlockLockedElements(this.lockedElements);\n\t\tif (this.modalStack.size > 0) {\n\t\t\tconst modalKeys = Array.from(this.modalStack.keys());\n\t\t\tconst modalRef = modalKeys[modalKeys.length - 1] as HTMLElement & {\n\t\t\t\t_activeElement: HTMLElement | null; // typo sugger\n\t\t\t};\n\t\t\tthis.modalStack.forEach((_value: ModalContext, htmlElement: HTMLElement) => {\n\t\t\t\tif (modalRef === htmlElement) {\n\t\t\t\t\thtmlElement.style.display = 'inline';\n\t\t\t\t} else {\n\t\t\t\t\thtmlElement.style.display = `none`;\n\t\t\t\t}\n\t\t\t});\n\t\t\tgetDocument().body.style.maxHeight = '100vh';\n\t\t\tgetDocument().body.style.overflow = 'hidden';\n\t\t\tthis.lockFocus(getDocument().body, modalRef);\n\t\t} else {\n\t\t\tgetDocument().body.style.maxHeight = 'unset';\n\t\t\tgetDocument().body.style.overflow = 'unset';\n\t\t}\n\t}\n\n\tpublic openModal(modalRef: HTMLElement, activeElement?: HTMLElement): void {\n\t\tif (modalRef instanceof HTMLElement === false) {\n\t\t\tLog.warn(`[KolModalService] Die DOM-Referenz des Modals ist nicht valide.`);\n\t\t} else {\n\t\t\tthis.modalStack.set(modalRef, {\n\t\t\t\tactiveElement,\n\t\t\t});\n\t\t\tthis.renderModalIfExists();\n\t\t}\n\t}\n\n\tpublic closeModal(modalRef: HTMLElement): void {\n\t\tif (modalRef instanceof HTMLElement === false) {\n\t\t\tLog.warn(`[KolModalService] Die DOM-Referenz des Modals ist nicht valide.`);\n\t\t} else {\n\t\t\tconst activeElement = this.modalStack.get(modalRef)?.activeElement;\n\t\t\tthis.modalStack.delete(modalRef);\n\t\t\tthis.renderModalIfExists(activeElement);\n\t\t}\n\t}\n}\n","@import '../style';\n\n.overlay {\n\tbackground-color: rgba(0, 0, 0, 0.33);\n\tdisplay: flex;\n\theight: 100%;\n\tinset: 0;\n\tposition: fixed;\n\twidth: 100%;\n\tz-index: 100;\n}\n\n.modal {\n\tmargin: auto;\n\tmax-height: 100%;\n\tmax-width: 100%;\n}\n","/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { KoliBriModalEventCallbacks } from '../../types/modal';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { featureHint } from '../../utils/a11y.tipps';\nimport { setState, watchString, watchValidator } from '../../utils/prop.validators';\nimport { API, States } from './types';\n\nimport { ModalService } from './service';\n\nconst modalService = new ModalService();\n\n/**\n * https://en.wikipedia.org/wiki/Modal_window\n * @deprecated use the native <dialog> instead\n */\n\n/**\n * @slot - Der Inhalt des Modals.\n */\n@Component({\n\ttag: 'kol-modal',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolModal implements API {\n\tprivate hostElement?: HTMLElement;\n\n\tpublic componentDidRender(): void {\n\t\tif (this.hostElement /* SSR instanceof HTMLElement */) {\n\t\t\tif (this.state._activeElement /* SSR instanceof HTMLElement */) {\n\t\t\t\tmodalService.openModal(this.hostElement, this.state._activeElement);\n\t\t\t} else {\n\t\t\t\tmodalService.closeModal(this.hostElement);\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tif (this.hostElement /* SSR instanceof HTMLElement */) {\n\t\t\tmodalService.closeModal(this.hostElement);\n\t\t}\n\t}\n\n\tprivate readonly onKeyDown = (event: KeyboardEvent) => {\n\t\tif (event && event.code === 'Escape') {\n\t\t\tthis._activeElement = null;\n\t\t}\n\t};\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host\n\t\t\t\tclass=\"kol-modal\"\n\t\t\t\tref={(el) => {\n\t\t\t\t\tthis.hostElement = el as HTMLElement;\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t{this.state._activeElement /* SSR instanceof HTMLElement */ && (\n\t\t\t\t\t<div class=\"overlay\">\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclass=\"modal\"\n\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\twidth: this.state._width,\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\taria-label={this.state._label}\n\t\t\t\t\t\t\taria-modal=\"true\"\n\t\t\t\t\t\t\trole=\"dialog\"\n\t\t\t\t\t\t\tonKeyDown={this.onKeyDown}\n\t\t\t\t\t\t\tref={(el) => {\n\t\t\t\t\t\t\t\tif (el /* SSR instanceof HTMLElement */) {\n\t\t\t\t\t\t\t\t\tel.setAttribute('tabindex', '0');\n\t\t\t\t\t\t\t\t\tsetTimeout(() => el.focus(), 250);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<slot />\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Gibt die Referenz auf das auslösende HTML-Element an, wodurch das Modal geöffnet wurde.\n\t */\n\t@Prop({ mutable: true }) public _activeElement?: HTMLElement | null;\n\n\t/**\n\t * Deprecated: Setzt die semantische Beschriftung der Komponente.\n\t *\n\t * @deprecated use _label instead\n\t */\n\t@Prop() public _ariaLabel?: string;\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; // TODO: required in v2\n\n\t/**\n\t * Gibt die EventCallback-Function für das Schließen des Modals an.\n\t */\n\t@Prop() public _on?: KoliBriModalEventCallbacks;\n\n\t/**\n\t * Defines the width of the modal. (max-width: 100%)\n\t */\n\t@Prop() public _width?: string = '100%';\n\n\t@State() public state: States = {\n\t\t_activeElement: null,\n\t\t_label: '…', // ⚠ required\n\t\t_width: '100%',\n\t};\n\n\t@Watch('_activeElement')\n\tpublic validateActiveElement(value?: HTMLElement | null): void {\n\t\twatchValidator(this, '_activeElement', (value): boolean => typeof value === 'object' || value === null, new Set(['HTMLElement', 'null']), value, {\n\t\t\tdefaultValue: null,\n\t\t\thooks: {\n\t\t\t\tafterPatch: () => {\n\t\t\t\t\t/* Call onClose event in the _activeElement watcher because activeElement can be set internally and from the outside and closes the modal when set to null. */\n\t\t\t\t\tif (this._activeElement === null && this.state._on?.onClose) {\n\t\t\t\t\t\tthis.state._on.onClose();\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\n\t */\n\t@Watch('_ariaLabel')\n\tpublic validateAriaLabel(value?: string): void {\n\t\tthis.validateLabel(value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: KoliBriModalEventCallbacks): void {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tfeatureHint('[KolTabs] Prüfen, wie man auch einen EventCallback einzeln ändern kann.');\n\t\t\tconst callbacks: KoliBriModalEventCallbacks = {};\n\t\t\tif (typeof value.onClose === 'function' || value.onClose === true) {\n\t\t\t\tcallbacks.onClose = value.onClose;\n\t\t\t}\n\t\t\tsetState<KoliBriModalEventCallbacks>(this, '_on', callbacks);\n\t\t}\n\t}\n\n\t@Watch('_width')\n\tpublic validateWidth(value?: string): void {\n\t\twatchString(this, '_width', value, {\n\t\t\tdefaultValue: '100%',\n\t\t});\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateActiveElement(this._activeElement);\n\t\tthis.validateLabel(this._label || this._ariaLabel);\n\t\tthis.validateOn(this._on);\n\t\tthis.validateWidth(this._width);\n\t}\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["ModalService","constructor","this","lockedElements","Map","modalStack","lockElement","htmlElement","tabIndex","getAttribute","HTMLAnchorElement","HTMLButtonElement","HTMLInputElement","HTMLSelectElement","HTMLTextAreaElement","dataset","kolModal","undefined","set","setAttribute","style","userSelect","unlockElement","value","removeAttribute","delete","unlockLockedElements","forEach","bind","lockFocus","hostElement","excludeElement","HTMLElement","ShadowRoot","shadowRoot","i","children","length","renderModalIfExists","activeElement","has","get","timeout","setTimeout","clearTimeout","focus","size","modalKeys","Array","from","keys","modalRef","_value","display","getDocument","body","maxHeight","overflow","openModal","Log","warn","closeModal","_a","defaultStyleCss","KolModalDefaultStyle0","modalService","KolModal","onKeyDown","event","code","_activeElement","_label","_width","componentDidRender","state","disconnectedCallback","render","h","Host","key","class","ref","el","width","role","validateActiveElement","watchValidator","Set","defaultValue","hooks","afterPatch","_on","onClose","validateAriaLabel","validateLabel","required","validateOn","featureHint","callbacks","setState","validateWidth","watchString","componentWillLoad","_ariaLabel"],"sources":["src/components/modal/service.ts","src/components/modal/style.scss?tag=kol-modal&mode=default&encapsulation=shadow","src/components/modal/component.tsx"],"sourcesContent":["import { getDocument, Log } from '../../utils/dev.utils';\n\ntype ModalContext = {\n\tactiveElement?: HTMLElement;\n};\n\ntype LockedElementContext = {\n\ttabIndex?: string;\n};\n\n/**\n * The modal service is only working client-side!\n */\nexport class ModalService {\n\tprivate lockedElements: Map<HTMLElement, LockedElementContext> = new Map();\n\tprivate modalStack: Map<HTMLElement, ModalContext> = new Map();\n\n\tprivate lockElement(htmlElement: HTMLElement) {\n\t\tconst tabIndex: string | null = htmlElement.getAttribute('tabindex');\n\t\tif (\n\t\t\thtmlElement instanceof HTMLAnchorElement ||\n\t\t\thtmlElement instanceof HTMLButtonElement ||\n\t\t\thtmlElement instanceof HTMLInputElement ||\n\t\t\thtmlElement instanceof HTMLSelectElement ||\n\t\t\thtmlElement instanceof HTMLTextAreaElement ||\n\t\t\ttypeof tabIndex === 'string' ||\n\t\t\thtmlElement.dataset.kolModal !== undefined\n\t\t) {\n\t\t\tif (typeof tabIndex === 'string') {\n\t\t\t\tthis.lockedElements.set(htmlElement, {\n\t\t\t\t\ttabIndex,\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tthis.lockedElements.set(htmlElement, {});\n\t\t\t}\n\t\t\thtmlElement.setAttribute('tabindex', '-1');\n\t\t\thtmlElement.setAttribute('aria-hidden', 'true');\n\t\t\thtmlElement.style.userSelect = 'none';\n\t\t}\n\t}\n\n\tprivate unlockElement(value: LockedElementContext, htmlElement: HTMLElement) {\n\t\tif (typeof value.tabIndex === 'string') {\n\t\t\thtmlElement.setAttribute('tabindex', value.tabIndex);\n\t\t} else {\n\t\t\thtmlElement.removeAttribute('tabindex');\n\t\t}\n\t\thtmlElement.removeAttribute('aria-hidden');\n\t\thtmlElement.style.userSelect = 'unset';\n\t\tthis.lockedElements.delete(htmlElement);\n\t}\n\n\tprivate unlockLockedElements(lockedElements: Map<HTMLElement, LockedElementContext>) {\n\t\tlockedElements.forEach(this.unlockElement.bind(this));\n\t}\n\n\tprivate lockFocus(hostElement: HTMLElement | ShadowRoot | null, excludeElement?: HTMLElement) {\n\t\tif (hostElement !== excludeElement && (hostElement instanceof HTMLElement || hostElement instanceof ShadowRoot)) {\n\t\t\tif (hostElement instanceof HTMLElement) {\n\t\t\t\tthis.lockElement(hostElement);\n\t\t\t\tthis.lockFocus(hostElement.shadowRoot, excludeElement);\n\t\t\t}\n\t\t\tfor (let i = 0; i < hostElement.children.length; i++) {\n\t\t\t\tthis.lockFocus(hostElement.children[i] as HTMLElement, excludeElement);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate renderModalIfExists(activeElement?: HTMLElement) {\n\t\tif (activeElement instanceof HTMLElement) {\n\t\t\tif (this.lockedElements.has(activeElement)) {\n\t\t\t\tthis.unlockElement(this.lockedElements.get(activeElement) as LockedElementContext, activeElement);\n\t\t\t}\n\t\t\tconst timeout = setTimeout(() => {\n\t\t\t\tclearTimeout(timeout);\n\t\t\t\tactiveElement.focus();\n\t\t\t}, 500);\n\t\t}\n\t\tthis.unlockLockedElements(this.lockedElements);\n\t\tif (this.modalStack.size > 0) {\n\t\t\tconst modalKeys = Array.from(this.modalStack.keys());\n\t\t\tconst modalRef = modalKeys[modalKeys.length - 1] as HTMLElement & {\n\t\t\t\t_activeElement: HTMLElement | null; // typo sugger\n\t\t\t};\n\t\t\tthis.modalStack.forEach((_value: ModalContext, htmlElement: HTMLElement) => {\n\t\t\t\tif (modalRef === htmlElement) {\n\t\t\t\t\thtmlElement.style.display = 'inline';\n\t\t\t\t} else {\n\t\t\t\t\thtmlElement.style.display = `none`;\n\t\t\t\t}\n\t\t\t});\n\t\t\tgetDocument().body.style.maxHeight = '100vh';\n\t\t\tgetDocument().body.style.overflow = 'hidden';\n\t\t\tthis.lockFocus(getDocument().body, modalRef);\n\t\t} else {\n\t\t\tgetDocument().body.style.maxHeight = 'unset';\n\t\t\tgetDocument().body.style.overflow = 'unset';\n\t\t}\n\t}\n\n\tpublic openModal(modalRef: HTMLElement, activeElement?: HTMLElement): void {\n\t\tif (modalRef instanceof HTMLElement === false) {\n\t\t\tLog.warn(`[KolModalService] Die DOM-Referenz des Modals ist nicht valide.`);\n\t\t} else {\n\t\t\tthis.modalStack.set(modalRef, {\n\t\t\t\tactiveElement,\n\t\t\t});\n\t\t\tthis.renderModalIfExists();\n\t\t}\n\t}\n\n\tpublic closeModal(modalRef: HTMLElement): void {\n\t\tif (modalRef instanceof HTMLElement === false) {\n\t\t\tLog.warn(`[KolModalService] Die DOM-Referenz des Modals ist nicht valide.`);\n\t\t} else {\n\t\t\tconst activeElement = this.modalStack.get(modalRef)?.activeElement;\n\t\t\tthis.modalStack.delete(modalRef);\n\t\t\tthis.renderModalIfExists(activeElement);\n\t\t}\n\t}\n}\n","@import '../style';\n\n.overlay {\n\tbackground-color: rgba(0, 0, 0, 0.33);\n\tdisplay: flex;\n\theight: 100%;\n\tinset: 0;\n\tposition: fixed;\n\twidth: 100%;\n\tz-index: 100;\n}\n\n.modal {\n\tmargin: auto;\n\tmax-height: 100%;\n\tmax-width: 100%;\n}\n","/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { KoliBriModalEventCallbacks } from '../../types/modal';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { featureHint } from '../../utils/a11y.tipps';\nimport { setState, watchString, watchValidator } from '../../utils/prop.validators';\nimport { API, States } from './types';\n\nimport { ModalService } from './service';\n\nconst modalService = new ModalService();\n\n/**\n * https://en.wikipedia.org/wiki/Modal_window\n * @deprecated use the native <dialog> instead\n */\n\n/**\n * @slot - Der Inhalt des Modals.\n */\n@Component({\n\ttag: 'kol-modal',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolModal implements API {\n\tprivate hostElement?: HTMLElement;\n\n\tpublic componentDidRender(): void {\n\t\tif (this.hostElement /* SSR instanceof HTMLElement */) {\n\t\t\tif (this.state._activeElement /* SSR instanceof HTMLElement */) {\n\t\t\t\tmodalService.openModal(this.hostElement, this.state._activeElement);\n\t\t\t} else {\n\t\t\t\tmodalService.closeModal(this.hostElement);\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tif (this.hostElement /* SSR instanceof HTMLElement */) {\n\t\t\tmodalService.closeModal(this.hostElement);\n\t\t}\n\t}\n\n\tprivate readonly onKeyDown = (event: KeyboardEvent) => {\n\t\tif (event && event.code === 'Escape') {\n\t\t\tthis._activeElement = null;\n\t\t}\n\t};\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host\n\t\t\t\tclass=\"kol-modal\"\n\t\t\t\tref={(el) => {\n\t\t\t\t\tthis.hostElement = el as HTMLElement;\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t{this.state._activeElement /* SSR instanceof HTMLElement */ && (\n\t\t\t\t\t<div class=\"overlay\">\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclass=\"modal\"\n\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\twidth: this.state._width,\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\taria-label={this.state._label}\n\t\t\t\t\t\t\taria-modal=\"true\"\n\t\t\t\t\t\t\trole=\"dialog\"\n\t\t\t\t\t\t\tonKeyDown={this.onKeyDown}\n\t\t\t\t\t\t\tref={(el) => {\n\t\t\t\t\t\t\t\tif (el /* SSR instanceof HTMLElement */) {\n\t\t\t\t\t\t\t\t\tel.setAttribute('tabindex', '0');\n\t\t\t\t\t\t\t\t\tsetTimeout(() => el.focus(), 250);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<slot />\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Gibt die Referenz auf das auslösende HTML-Element an, wodurch das Modal geöffnet wurde.\n\t */\n\t@Prop({ mutable: true }) public _activeElement?: HTMLElement | null;\n\n\t/**\n\t * Deprecated: Setzt die semantische Beschriftung der Komponente.\n\t *\n\t * @deprecated use _label instead\n\t */\n\t@Prop() public _ariaLabel?: string;\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; // TODO: required in v2\n\n\t/**\n\t * Gibt die EventCallback-Function für das Schließen des Modals an.\n\t */\n\t@Prop() public _on?: KoliBriModalEventCallbacks;\n\n\t/**\n\t * Defines the width of the modal. (max-width: 100%)\n\t */\n\t@Prop() public _width?: string = '100%';\n\n\t@State() public state: States = {\n\t\t_activeElement: null,\n\t\t_label: '…', // ⚠ required\n\t\t_width: '100%',\n\t};\n\n\t@Watch('_activeElement')\n\tpublic validateActiveElement(value?: HTMLElement | null): void {\n\t\twatchValidator(this, '_activeElement', (value): boolean => typeof value === 'object' || value === null, new Set(['HTMLElement', 'null']), value, {\n\t\t\tdefaultValue: null,\n\t\t\thooks: {\n\t\t\t\tafterPatch: () => {\n\t\t\t\t\t/* Call onClose event in the _activeElement watcher because activeElement can be set internally and from the outside and closes the modal when set to null. */\n\t\t\t\t\tif (this._activeElement === null && this.state._on?.onClose) {\n\t\t\t\t\t\tthis.state._on.onClose();\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\n\t */\n\t@Watch('_ariaLabel')\n\tpublic validateAriaLabel(value?: string): void {\n\t\tthis.validateLabel(value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: KoliBriModalEventCallbacks): void {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tfeatureHint('[KolTabs] Prüfen, wie man auch einen EventCallback einzeln ändern kann.');\n\t\t\tconst callbacks: KoliBriModalEventCallbacks = {};\n\t\t\tif (typeof value.onClose === 'function' || value.onClose === true) {\n\t\t\t\tcallbacks.onClose = value.onClose;\n\t\t\t}\n\t\t\tsetState<KoliBriModalEventCallbacks>(this, '_on', callbacks);\n\t\t}\n\t}\n\n\t@Watch('_width')\n\tpublic validateWidth(value?: string): void {\n\t\twatchString(this, '_width', value, {\n\t\t\tdefaultValue: '100%',\n\t\t});\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateActiveElement(this._activeElement);\n\t\tthis.validateLabel(this._label || this._ariaLabel);\n\t\tthis.validateOn(this._on);\n\t\tthis.validateWidth(this._width);\n\t}\n}\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{r as i,h as t,H as a}from"./index-a051748e.js";import{t as e}from"./i18n-ad947f60.js";import{a as n,w as s}from"./prop.validators-3017e14b.js";import{v as l}from"./hide-label-000c16f6.js";import{v as o}from"./label-bce4f328.js";import{h as r,b as d,d as c}from"./a11y.tipps-798efb1a.js";import{r as h,a as p}from"./unique-nav-labels-62d9802d.js";import{w as u}from"./validation-8785c967.js";import{o as b,d as v,p as m}from"./component-names-fed305c7.js";import"./i18n-fddf0324.js";import"./reuse-d79ab469.js";import"./index-117bd1aa.js";import"./dev.utils-f829063f.js";const f=(a,t)=>{n(a,"_collapsible",t)},_=(a,t)=>{n(a,"_hasCompactButton",t)},y=":host{--a11y-min-size:44px;background-color:white;color:black;font-family:Verdana}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role=button],button:not([role=link]),.kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}[hidden]{display:none !important}:host{max-width:100%}*{box-sizing:border-box}.kol-span-wc{display:grid;place-items:center}.kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}.icon-only>.kol-span-wc>span>span{display:none}.hidden{display:none;visibility:hidden}:host>div{display:grid;place-items:center}nav{width:100%}.list{display:flex;list-style:none;margin:0;padding:0}.list.vertical{flex-direction:column}.entry{display:flex}.entry .kol-button-wc:first-child,.entry .kol-link-wc,.entry .kol-span-wc{flex-grow:1}.entry .kol-span-wc{justify-items:start}",k=y,w=class{constructor(a){i(this,a),this.onClick=a=>{a._active=!a._active,this.state=Object.assign({},this.state)},this.hasActiveChild=a=>!!(Array.isArray(a._children)&&a._children.length>0)&&a._children.some(this.hasActiveChild),this.linkList=a=>t("ul",{class:"list "+(0===a.deep&&"horizontal"===a.orientation?" horizontal":" vertical"),"data-deep":a.deep},a.links.map(((t,i)=>this.li(a.collapsible,a.hideLabel,a.deep,i,t,a.orientation)))),this._ariaCurrentValue=!1,this._ariaLabel=void 0,this._collapsible=!0,this._compact=!1,this._hasCompactButton=!1,this._hideLabel=!1,this._label=void 0,this._links=void 0,this._orientation="vertical",this._variant="primary",this.state={_ariaCurrentValue:!1,_collapsible:!0,_hasCompactButton:!1,_hideLabel:!1,_label:"…",_links:[],_orientation:"vertical",_variant:"primary"}}entry(a,i,e,l,n){return t("div",{class:{entry:!0,"hide-label":i}},t(b,{_link:Object.assign(Object.assign({},l),{_hideLabel:i})}),e?this.expandButton(a,l,n):"")}expandButton(a,i,e){return t(v,{class:"expand-button",_ariaExpanded:e,_disabled:!a,_icons:"codicon codicon-"+(e?"remove":"add"),_hideLabel:!0,_label:`Untermenü zu ${i._label} ${e?"schließen":"öffnen"}`,_on:{onClick:()=>this.onClick(i)}})}li(a,i,e,l,n,s){const o=!!n._active,r=Array.isArray(n._children)&&n._children.length>0,d=r&&o;return t("li",{class:{active:o,expanded:d,"has-children":r,selected:d},key:l},this.entry(a,i,r,n,o),d?t(this.linkList,{collapsible:a,hideLabel:i,deep:e+1,links:n._children||[],orientation:s}):"")}render(){let i=this.state._hasCompactButton;"horizontal"===this.state._orientation&&!0===this.state._hasCompactButton&&(i=!1,r("[KolNav] Wenn eine horizontale Navigation verwendet wird, kann die Option _hasCompactButton nicht aktiviert werden."));const l=!0===this.state._collapsible,n=!0===this.state._hideLabel,s=this.state._orientation;return t(a,{key:"22d1f41175666b6e540c1d93a92a88283e6bfced",class:"kol-nav"},t("div",{key:"42dcf20c3d0d157f08f5a09a5a4566755288a5a0",class:{[s]:!0,[this.state._variant]:!0}},t("nav",{key:"86c2c08a34f26948b8054c5735c4a673e22a6ddc","aria-label":this.state._label,id:"nav"},t(this.linkList,{key:"fe334ca90260312723e146b5bcc5194c741cd828",collapsible:l,hideLabel:n,deep:0,links:this.state._links,orientation:s})),i&&t("div",{class:"compact"},t(m,{_ariaControls:"nav",_ariaExpanded:!n,_icons:n?"codicon codicon-chevron-right":"codicon codicon-chevron-left",_hideLabel:!0,_label:e(n?"kol-nav-maximize":"kol-nav-minimize"),_on:{onClick:()=>{this.state=Object.assign(Object.assign({},this.state),{_hideLabel:!1===this.state._hideLabel})}},_tooltipAlign:"right",_variant:"ghost"}))))}validateAriaCurrentValue(a){s(this,"_ariaCurrentValue",(a=>!0===a||"date"===a||"location"===a||"page"===a||"step"===a||"time"===a),new Set(["boolean","String {data, location, page, step, time}"]),a)}validateAriaLabel(a){this.validateLabel(a)}validateCollapsible(a){f(this,a)}validateCompact(a){this.validateHideLabel(a)}validateHasCompactButton(a){_(this,a)}validateHideLabel(a){l(this,a)}validateLabel(a,t,i=!1){i||h(this.state._label),o(this,a,{required:!0}),d(a),p(this.state._label)}validateLinks(a){u("KolNav",this,a),c("[KolNav] Die Navigationsstruktur wird noch nicht rekursiv validiert.")}validateOrientation(a){s(this,"_orientation",(a=>"horizontal"===a||"vertical"===a),new Set(["Orientation {horizontal, vertical}"]),a,{defaultValue:"vertical"})}validateVariant(a){s(this,"_variant",(a=>"primary"===a||"secondary"===a),new Set(["KoliBriNavVariant {primary, secondary}"]),a,{defaultValue:"primary"})}componentWillLoad(){this.validateAriaCurrentValue(this._ariaCurrentValue),this.validateCollapsible(this._collapsible),this.validateHideLabel(this._hideLabel||this._compact),this.validateHasCompactButton(this._hasCompactButton),this.validateLabel(this._label||this._ariaLabel,void 0,!0),this.validateLinks(this._links),this.validateOrientation(this._orientation),this.validateVariant(this._variant)}disconnectedCallback(){h(this.state._label)}static get watchers(){return{_ariaCurrentValue:["validateAriaCurrentValue"],_ariaLabel:["validateAriaLabel"],_collapsible:["validateCollapsible"],_compact:["validateCompact"],_hasCompactButton:["validateHasCompactButton"],_hideLabel:["validateHideLabel"],_label:["validateLabel"],_links:["validateLinks"],_orientation:["validateOrientation"],_variant:["validateVariant"]}}};w.style={default:k};export{w as kol_nav};
4
+ import{r as i,h as t,H as a}from"./index-dfb131c4.js";import{t as e}from"./i18n-8ac68853.js";import{a as n,w as s}from"./prop.validators-a62aac63.js";import{v as l}from"./hide-label-16c3f288.js";import{v as o}from"./label-48b51f80.js";import{h as r,b as d,d as c}from"./a11y.tipps-477c41d6.js";import{r as h,a as p}from"./unique-nav-labels-62d9802d.js";import{w as u}from"./validation-13009299.js";import{o as b,d as v,p as m}from"./component-names-fed305c7.js";import"./i18n-a2f79a81.js";import"./reuse-d79ab469.js";import"./index-117bd1aa.js";import"./dev.utils-1e8dd4a9.js";const f=(a,t)=>{n(a,"_collapsible",t)},y=(a,t)=>{n(a,"_hasCompactButton",t)},_=":host{--a11y-min-size:44px;background-color:white;color:black;font-family:Verdana}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role=button],button:not([role=link]),.kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}[hidden]{display:none !important}:host{max-width:100%}*{box-sizing:border-box}.kol-span-wc{display:grid;place-items:center}.kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}.icon-only>.kol-span-wc>span>span{display:none}.hidden{display:none;visibility:hidden}:host>div{display:grid;place-items:center}nav{width:100%}.list{display:flex;list-style:none;margin:0;padding:0}.list.vertical{flex-direction:column}.entry{display:flex}.entry .kol-button-wc:first-child,.entry .kol-link-wc,.entry .kol-span-wc{flex-grow:1}.entry .kol-span-wc{justify-items:start}",k=_,w=class{constructor(a){i(this,a),this.onClick=a=>{a._active=!a._active,this.state=Object.assign({},this.state)},this.hasActiveChild=a=>!!(Array.isArray(a._children)&&a._children.length>0)&&a._children.some(this.hasActiveChild),this.linkList=a=>t("ul",{class:"list "+(0===a.deep&&"horizontal"===a.orientation?" horizontal":" vertical"),"data-deep":a.deep},a.links.map(((t,i)=>this.li(a.collapsible,a.hideLabel,a.deep,i,t,a.orientation)))),this._ariaCurrentValue=!1,this._ariaLabel=void 0,this._collapsible=!0,this._compact=!1,this._hasCompactButton=!1,this._hideLabel=!1,this._label=void 0,this._links=void 0,this._orientation="vertical",this._variant="primary",this.state={_ariaCurrentValue:!1,_collapsible:!0,_hasCompactButton:!1,_hideLabel:!1,_label:"…",_links:[],_orientation:"vertical",_variant:"primary"}}entry(a,i,e,l,n){return t("div",{class:{entry:!0,"hide-label":i}},t(b,{_link:Object.assign(Object.assign({},l),{_hideLabel:i})}),e?this.expandButton(a,l,n):"")}expandButton(a,i,e){return t(v,{class:"expand-button",_ariaExpanded:e,_disabled:!a,_icons:"codicon codicon-"+(e?"remove":"add"),_hideLabel:!0,_label:`Untermenü zu ${i._label} ${e?"schließen":"öffnen"}`,_on:{onClick:()=>this.onClick(i)}})}li(a,i,e,l,n,s){const o=!!n._active,r=Array.isArray(n._children)&&n._children.length>0,d=r&&o;return t("li",{class:{active:o,expanded:d,"has-children":r,selected:d},key:l},this.entry(a,i,r,n,o),d?t(this.linkList,{collapsible:a,hideLabel:i,deep:e+1,links:n._children||[],orientation:s}):"")}render(){let i=this.state._hasCompactButton;"horizontal"===this.state._orientation&&!0===this.state._hasCompactButton&&(i=!1,r("[KolNav] Wenn eine horizontale Navigation verwendet wird, kann die Option _hasCompactButton nicht aktiviert werden."));const l=!0===this.state._collapsible,n=!0===this.state._hideLabel,s=this.state._orientation;return t(a,{key:"22d1f41175666b6e540c1d93a92a88283e6bfced",class:"kol-nav"},t("div",{key:"42dcf20c3d0d157f08f5a09a5a4566755288a5a0",class:{[s]:!0,[this.state._variant]:!0}},t("nav",{key:"86c2c08a34f26948b8054c5735c4a673e22a6ddc","aria-label":this.state._label,id:"nav"},t(this.linkList,{key:"fe334ca90260312723e146b5bcc5194c741cd828",collapsible:l,hideLabel:n,deep:0,links:this.state._links,orientation:s})),i&&t("div",{key:"54bd6c9a3c2a41c6c838c3762cc31005d794e1c3",class:"compact"},t(m,{key:"b549ce4b27d2fa882ea8b6bd6dd9852dbc441304",_ariaControls:"nav",_ariaExpanded:!n,_icons:n?"codicon codicon-chevron-right":"codicon codicon-chevron-left",_hideLabel:!0,_label:e(n?"kol-nav-maximize":"kol-nav-minimize"),_on:{onClick:()=>{this.state=Object.assign(Object.assign({},this.state),{_hideLabel:!1===this.state._hideLabel})}},_tooltipAlign:"right",_variant:"ghost"}))))}validateAriaCurrentValue(a){s(this,"_ariaCurrentValue",(a=>!0===a||"date"===a||"location"===a||"page"===a||"step"===a||"time"===a),new Set(["boolean","String {data, location, page, step, time}"]),a)}validateAriaLabel(a){this.validateLabel(a)}validateCollapsible(a){f(this,a)}validateCompact(a){this.validateHideLabel(a)}validateHasCompactButton(a){y(this,a)}validateHideLabel(a){l(this,a)}validateLabel(a,t,i=!1){i||h(this.state._label),o(this,a,{required:!0}),d(a),p(this.state._label)}validateLinks(a){u("KolNav",this,a),c("[KolNav] Die Navigationsstruktur wird noch nicht rekursiv validiert.")}validateOrientation(a){s(this,"_orientation",(a=>"horizontal"===a||"vertical"===a),new Set(["Orientation {horizontal, vertical}"]),a,{defaultValue:"vertical"})}validateVariant(a){s(this,"_variant",(a=>"primary"===a||"secondary"===a),new Set(["KoliBriNavVariant {primary, secondary}"]),a,{defaultValue:"primary"})}componentWillLoad(){this.validateAriaCurrentValue(this._ariaCurrentValue),this.validateCollapsible(this._collapsible),this.validateHideLabel(this._hideLabel||this._compact),this.validateHasCompactButton(this._hasCompactButton),this.validateLabel(this._label||this._ariaLabel,void 0,!0),this.validateLinks(this._links),this.validateOrientation(this._orientation),this.validateVariant(this._variant)}disconnectedCallback(){h(this.state._label)}static get watchers(){return{_ariaCurrentValue:["validateAriaCurrentValue"],_ariaLabel:["validateAriaLabel"],_collapsible:["validateCollapsible"],_compact:["validateCompact"],_hasCompactButton:["validateHasCompactButton"],_hideLabel:["validateHideLabel"],_label:["validateLabel"],_links:["validateLinks"],_orientation:["validateOrientation"],_variant:["validateVariant"]}}};w.style={default:k};export{w as kol_nav};
@@ -1 +1 @@
1
- {"version":3,"names":["validateCollapsible","component","value","watchBoolean","validateHasCompactButton","defaultStyleCss","KolNavDefaultStyle0","KolNav","this","onClick","link","_active","state","Object","assign","hasActiveChild","Array","isArray","_children","length","some","linkList","props","h","class","deep","orientation","links","map","index","li","collapsible","hideLabel","_ariaCurrentValue","_collapsible","_hasCompactButton","_hideLabel","_label","_links","_orientation","_variant","entry","hasChildren","expanded","KolButtonLinkTextSwitchTag","_link","expandButton","KolButtonWcTag","_ariaExpanded","_disabled","_icons","_on","active","selected","key","render","hasCompactButton","devWarning","Host","id","KolButtonTag","_ariaControls","translate","_tooltipAlign","validateAriaCurrentValue","watchValidator","Set","validateAriaLabel","validateLabel","validateCompact","validateHideLabel","_oldValue","initial","removeNavLabel","required","a11yHintLabelingLandmarks","addNavLabel","validateLinks","watchNavLinks","devHint","validateOrientation","defaultValue","validateVariant","componentWillLoad","_compact","_ariaLabel","undefined","disconnectedCallback"],"sources":["src/types/props/collapsible.ts","src/types/props/has-compact-button.ts","src/components/nav/style.scss?tag=kol-nav&mode=default&encapsulation=shadow","src/components/nav/component.tsx"],"sourcesContent":["import type { Generic } from 'adopted-style-sheets';\n\nimport { watchBoolean } from '../../utils/prop.validators';\n\n/* types */\nexport type CollapsiblePropType = boolean;\n\n/**\n * Defines if navigation nodes can be collapsed or not.\n */\nexport type PropCollapsible = {\n\tcollapsible: CollapsiblePropType;\n};\n\n/* validator */\nexport const validateCollapsible = (component: Generic.Element.Component, value?: CollapsiblePropType): void => {\n\twatchBoolean(component, '_collapsible', value);\n};\n","import type { Generic } from 'adopted-style-sheets';\n\nimport { watchBoolean } from '../../utils/prop.validators';\n\n/* types */\n/**\n * @deprecated\n */\nexport type HasCompactButtonPropType = boolean;\n\n/**\n * Creates a button below the navigation, that toggles _collapsible. Only available for _orientation=\"vertical\".\n * @deprecated\n */\nexport type PropHasCompactButton = {\n\thasCompactButton: HasCompactButtonPropType;\n};\n\n/* validator */\nexport const validateHasCompactButton = (component: Generic.Element.Component, value?: HasCompactButtonPropType): void => {\n\twatchBoolean(component, '_hasCompactButton', value);\n};\n","@import '../style';\n\n:host > div {\n\tdisplay: grid;\n\tplace-items: center;\n}\n\nnav {\n\twidth: 100%;\n}\n\n.list {\n\tdisplay: flex;\n\tlist-style: none;\n\tmargin: 0;\n\tpadding: 0;\n}\n\n.list.vertical {\n\tflex-direction: column;\n}\n\n.entry {\n\tdisplay: flex;\n}\n\n.entry .kol-button-wc:first-child,\n.entry .kol-link-wc,\n.entry .kol-span-wc {\n\tflex-grow: 1;\n}\n\n.entry .kol-span-wc {\n\tjustify-items: start;\n}\n","import { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\nimport { ButtonOrLinkOrTextWithChildrenProps, ButtonWithChildrenProps } from '../../types/button-link-text';\nimport { Stringified } from '../../types/common';\nimport { Orientation } from '../../types/orientation';\nimport { AriaCurrentPropType } from '../../types/props/aria-current';\nimport { CollapsiblePropType, validateCollapsible } from '../../types/props/collapsible';\nimport { validateHasCompactButton } from '../../types/props/has-compact-button';\nimport { HideLabelPropType, validateHideLabel } from '../../types/props/hide-label';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { a11yHintLabelingLandmarks, devHint, devWarning } from '../../utils/a11y.tipps';\nimport { watchValidator } from '../../utils/prop.validators';\nimport { addNavLabel, removeNavLabel } from '../../utils/unique-nav-labels';\nimport { API, States } from './types';\nimport { watchNavLinks } from './validation';\nimport { KolButtonLinkTextSwitchTag, KolButtonTag, KolButtonWcTag } from '../../core/component-names';\n\n/**\n * @deprecated Removed in v2\n */\nexport type KoliBriNavVariant = 'primary' | 'secondary';\n\nconst linkValidator = (link: ButtonOrLinkOrTextWithChildrenProps): boolean => {\n\tif (typeof link === 'object' && typeof link._label === 'string' /* && typeof newLink._href === 'string' */) {\n\t\tif (Array.isArray(link._children)) {\n\t\t\treturn linksValidator(link._children);\n\t\t}\n\t\treturn false;\n\t}\n\treturn true;\n};\n\nconst linksValidator = (links: ButtonOrLinkOrTextWithChildrenProps[]): boolean => {\n\tif (Array.isArray(links)) {\n\t\treturn links.find(linkValidator) !== undefined;\n\t}\n\treturn true;\n};\n\n@Component({\n\ttag: 'kol-nav',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolNav implements API {\n\tprivate readonly onClick = (link: ButtonOrLinkOrTextWithChildrenProps): void => {\n\t\tlink._active = !link._active;\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t};\n\t};\n\n\tprivate readonly hasActiveChild = (link: ButtonOrLinkOrTextWithChildrenProps): boolean => {\n\t\tif (Array.isArray(link._children) && link._children.length > 0) {\n\t\t\treturn link._children.some(this.hasActiveChild);\n\t\t}\n\n\t\treturn false;\n\t};\n\n\tprivate entry(\n\t\tcollapsible: boolean,\n\t\thideLabel: HideLabelPropType,\n\t\thasChildren: boolean,\n\t\tlink: ButtonOrLinkOrTextWithChildrenProps,\n\t\texpanded: boolean,\n\t): JSX.Element {\n\t\treturn (\n\t\t\t<div class={{ entry: true, 'hide-label': hideLabel }}>\n\t\t\t\t<KolButtonLinkTextSwitchTag\n\t\t\t\t\t_link={{\n\t\t\t\t\t\t...link,\n\t\t\t\t\t\t_hideLabel: hideLabel,\n\t\t\t\t\t}}\n\t\t\t\t/>\n\t\t\t\t{hasChildren ? this.expandButton(collapsible, link as ButtonWithChildrenProps, expanded) : ''}\n\t\t\t</div>\n\t\t);\n\t}\n\n\tprivate expandButton(collapsible: boolean, link: ButtonWithChildrenProps, expanded: boolean): JSX.Element {\n\t\treturn (\n\t\t\t<KolButtonWcTag\n\t\t\t\tclass=\"expand-button\"\n\t\t\t\t_ariaExpanded={expanded}\n\t\t\t\t_disabled={!collapsible}\n\t\t\t\t_icons={'codicon codicon-' + (expanded ? 'remove' : 'add')}\n\t\t\t\t_hideLabel\n\t\t\t\t_label={`Untermenü zu ${link._label} ${expanded ? 'schließen' : 'öffnen'}`}\n\t\t\t\t_on={{ onClick: () => this.onClick(link) }}\n\t\t\t></KolButtonWcTag>\n\t\t);\n\t}\n\n\tprivate li(\n\t\tcollapsible: boolean,\n\t\thideLabel: HideLabelPropType,\n\t\tdeep: number,\n\t\tindex: number,\n\t\tlink: ButtonOrLinkOrTextWithChildrenProps,\n\t\torientation: Orientation,\n\t): JSX.Element {\n\t\tconst active = !!link._active;\n\t\tconst hasChildren = Array.isArray(link._children) && link._children.length > 0;\n\t\tconst expanded = hasChildren && active;\n\t\treturn (\n\t\t\t<li\n\t\t\t\tclass={{\n\t\t\t\t\tactive,\n\t\t\t\t\texpanded,\n\t\t\t\t\t'has-children': hasChildren,\n\t\t\t\t\tselected: expanded, // TODO: remove in v2\n\t\t\t\t}}\n\t\t\t\tkey={index}\n\t\t\t>\n\t\t\t\t{this.entry(collapsible, hideLabel, hasChildren, link, active)}\n\t\t\t\t{expanded ? (\n\t\t\t\t\t<this.linkList collapsible={collapsible} hideLabel={hideLabel} deep={deep + 1} links={link._children || []} orientation={orientation} />\n\t\t\t\t) : (\n\t\t\t\t\t''\n\t\t\t\t)}\n\t\t\t</li>\n\t\t);\n\t}\n\n\tprivate linkList = (props: {\n\t\tcollapsible: boolean;\n\t\thideLabel: HideLabelPropType;\n\t\tdeep: number;\n\t\tlinks: ButtonOrLinkOrTextWithChildrenProps[];\n\t\torientation: Orientation;\n\t}): JSX.Element => {\n\t\treturn (\n\t\t\t<ul class={`list ${props.deep === 0 && props.orientation === 'horizontal' ? ' horizontal' : ' vertical'}`} data-deep={props.deep}>\n\t\t\t\t{props.links.map((link, index: number) => {\n\t\t\t\t\treturn this.li(props.collapsible, props.hideLabel, props.deep, index, link, props.orientation);\n\t\t\t\t})}\n\t\t\t</ul>\n\t\t);\n\t};\n\n\tpublic render(): JSX.Element {\n\t\tlet hasCompactButton = this.state._hasCompactButton;\n\t\tif (this.state._orientation === 'horizontal' && this.state._hasCompactButton === true) {\n\t\t\thasCompactButton = false;\n\t\t\tdevWarning(`[KolNav] Wenn eine horizontale Navigation verwendet wird, kann die Option _hasCompactButton nicht aktiviert werden.`);\n\t\t}\n\t\tconst collapsible = this.state._collapsible === true;\n\t\tconst hideLabel = this.state._hideLabel === true;\n\t\tconst orientation = this.state._orientation;\n\t\treturn (\n\t\t\t<Host class=\"kol-nav\">\n\t\t\t\t<div\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[orientation]: true,\n\t\t\t\t\t\t[this.state._variant]: true,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t<nav aria-label={this.state._label} id=\"nav\">\n\t\t\t\t\t\t<this.linkList collapsible={collapsible} hideLabel={hideLabel} deep={0} links={this.state._links} orientation={orientation}></this.linkList>\n\t\t\t\t\t</nav>\n\t\t\t\t\t{hasCompactButton && (\n\t\t\t\t\t\t<div class=\"compact\">\n\t\t\t\t\t\t\t<KolButtonTag\n\t\t\t\t\t\t\t\t_ariaControls=\"nav\"\n\t\t\t\t\t\t\t\t_ariaExpanded={!hideLabel}\n\t\t\t\t\t\t\t\t_icons={hideLabel ? 'codicon codicon-chevron-right' : 'codicon codicon-chevron-left'}\n\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t_label={translate(hideLabel ? 'kol-nav-maximize' : 'kol-nav-minimize')}\n\t\t\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\t\t\tonClick: (): void => {\n\t\t\t\t\t\t\t\t\t\tthis.state = {\n\t\t\t\t\t\t\t\t\t\t\t...this.state,\n\t\t\t\t\t\t\t\t\t\t\t_hideLabel: this.state._hideLabel === false,\n\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t_tooltipAlign=\"right\"\n\t\t\t\t\t\t\t\t_variant=\"ghost\"\n\t\t\t\t\t\t\t></KolButtonTag>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Defines the value of aria-current to be used with the current context within the navigation.\n\t */\n\t@Prop() public _ariaCurrentValue: AriaCurrentPropType = false;\n\n\t/**\n\t * Deprecated: Setzt die semantische Beschriftung der Komponente.\n\t *\n\t * @deprecated use _label instead\n\t */\n\t@Prop() public _ariaLabel?: string;\n\n\t/**\n\t * Defines if navigation nodes can be collapsed or not. Enabled by default.\n\t * @TODO: Change type back to `CollapsiblePropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _collapsible?: boolean = true;\n\n\t/**\n\t * Deprecated: Gibt an, ob die Navigation kompakt angezeigt wird.\n\t * @deprecated Use _hide-label\n\t */\n\t@Prop() public _compact?: boolean = false;\n\n\t/**\n\t * Deprecated: Gibt an, ob die Navigation eine zusätzliche Schaltfläche zum Aus- und Einklappen der Navigation anzeigen soll.\n\t * @deprecated Version 2\n\t */\n\t@Prop() public _hasCompactButton?: boolean = false;\n\n\t/**\n\t * Hides the caption by default and displays the caption text with a tooltip when the\n\t * interactive element is focused or the mouse is over it.\n\t * @TODO: Change type back to `HideLabelPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hideLabel?: boolean = false;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label?: LabelPropType; // TODO: required in v2\n\n\t/**\n\t * Defines the list of links, buttons or texts to render.\n\t */\n\t@Prop() public _links!: Stringified<ButtonOrLinkOrTextWithChildrenProps[]>;\n\n\t/**\n\t * Defines whether the orientation of the component is horizontal or vertical.\n\t */\n\t@Prop() public _orientation?: Orientation = 'vertical';\n\n\t/**\n\t * Deprecated: Defines which variant should be used for presentation.\n\t *\n\t * @deprecated This property is deprecated and will be removed in the next major version.\n\t */\n\t@Prop() public _variant?: KoliBriNavVariant = 'primary';\n\n\t@State() public state: States = {\n\t\t_ariaCurrentValue: false,\n\t\t_collapsible: true,\n\t\t_hasCompactButton: false,\n\t\t_hideLabel: false,\n\t\t_label: '…', // ⚠ required\n\t\t_links: [],\n\t\t_orientation: 'vertical',\n\t\t_variant: 'primary',\n\t};\n\n\t@Watch('_ariaCurrentValue')\n\tpublic validateAriaCurrentValue(value?: AriaCurrentPropType): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_ariaCurrentValue',\n\t\t\t(value) => value === true || value === 'date' || value === 'location' || value === 'page' || value === 'step' || value === 'time',\n\t\t\tnew Set(['boolean', 'String {data, location, page, step, time}']),\n\t\t\tvalue,\n\t\t);\n\t}\n\n\t/**\n\t * @deprecated\n\t */\n\t@Watch('_ariaLabel')\n\tpublic validateAriaLabel(value?: string): void {\n\t\tthis.validateLabel(value);\n\t}\n\n\t@Watch('_collapsible')\n\tpublic validateCollapsible(value?: CollapsiblePropType): void {\n\t\tvalidateCollapsible(this, value);\n\t}\n\n\t@Watch('_compact')\n\tpublic validateCompact(value?: boolean): void {\n\t\tthis.validateHideLabel(value);\n\t}\n\n\t/**\n\t * @deprecated Version 2\n\t */\n\t@Watch('_hasCompactButton')\n\tpublic validateHasCompactButton(value?: boolean): void {\n\t\tvalidateHasCompactButton(this, value);\n\t}\n\n\t@Watch('_hideLabel')\n\tpublic validateHideLabel(value?: HideLabelPropType) {\n\t\tvalidateHideLabel(this, value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType, _oldValue?: LabelPropType, initial = false): void {\n\t\tif (!initial) {\n\t\t\tremoveNavLabel(this.state._label); // remove the current\n\t\t}\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t\ta11yHintLabelingLandmarks(value);\n\t\taddNavLabel(this.state._label); // add the state instead of prop, because the prop could be invalid and not set as new label\n\t}\n\n\t@Watch('_links')\n\tpublic validateLinks(value?: Stringified<ButtonOrLinkOrTextWithChildrenProps[]>): void {\n\t\twatchNavLinks('KolNav', this, value);\n\t\tdevHint(`[KolNav] Die Navigationsstruktur wird noch nicht rekursiv validiert.`);\n\t}\n\n\t@Watch('_orientation')\n\tpublic validateOrientation(value?: Orientation): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_orientation',\n\t\t\t(value): boolean => value === 'horizontal' || value === 'vertical',\n\t\t\tnew Set(['Orientation {horizontal, vertical}']),\n\t\t\tvalue,\n\t\t\t{\n\t\t\t\tdefaultValue: 'vertical',\n\t\t\t},\n\t\t);\n\t}\n\n\t@Watch('_variant')\n\tpublic validateVariant(value?: KoliBriNavVariant): void {\n\t\twatchValidator(this, '_variant', (value) => value === 'primary' || value === 'secondary', new Set(['KoliBriNavVariant {primary, secondary}']), value, {\n\t\t\tdefaultValue: 'primary',\n\t\t});\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAriaCurrentValue(this._ariaCurrentValue);\n\t\tthis.validateCollapsible(this._collapsible);\n\t\tthis.validateHideLabel(this._hideLabel || this._compact);\n\t\tthis.validateHasCompactButton(this._hasCompactButton);\n\t\tthis.validateLabel(this._label || this._ariaLabel, undefined, true);\n\t\tthis.validateLinks(this._links);\n\t\tthis.validateOrientation(this._orientation);\n\t\tthis.validateVariant(this._variant);\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tremoveNavLabel(this.state._label);\n\t}\n}\n\n// console.log(\n// stringifyJson([\n// { _label: '1 Navigationspunkt', _href: '#abc', _icons: 'codicon codicon-folder-closed', _target: 'asdasd' },\n// { _label: '2 Navigationspunkt', _href: '#abc', _icons: 'codicon codicon-folder-closed' },\n// {\n// _active: true,\n// _label: '3 Navigationspunkt',\n// _href: '#abc',\n// _icons: 'codicon codicon-folder-closed',\n// _children: [\n// { _label: '3.1 Navigationspunkt', _href: '#abc', _icons: 'codicon codicon-folder-closed' },\n// { _label: '3.2 Navigationspunkt', _href: '#abc', _icons: 'codicon codicon-folder-closed', _target: 'asdasd' },\n// {\n// _active: true,\n// _label: '3.3 Navigationspunkt',\n// _href: '#abc',\n// _children: [\n// { _active: true, _label: '3.3.1 Navigationspunkt (aktiv)', _href: '#abc' },\n// { _label: '3.3.2 Navigationspunkt', _href: '#abc' },\n// ],\n// },\n// {\n// _label: '3.4 Navigationspunkt',\n// _href: '#abc',\n// _children: [\n// { _label: '3.4.1 Navigationspunkt', _href: '#abc' },\n// { _label: '3.4.2 Navigationspunkt', _href: '#abc' },\n// ],\n// },\n// { _label: '3.5 Navigationspunkt', _href: '#abc' },\n// ],\n// },\n// { _label: '4 Navigationspunkt', _href: '#abc' },\n// ])\n// );\n"],"mappings":"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"}
1
+ {"version":3,"names":["validateCollapsible","component","value","watchBoolean","validateHasCompactButton","defaultStyleCss","KolNavDefaultStyle0","KolNav","this","onClick","link","_active","state","Object","assign","hasActiveChild","Array","isArray","_children","length","some","linkList","props","h","class","deep","orientation","links","map","index","li","collapsible","hideLabel","_ariaCurrentValue","_collapsible","_hasCompactButton","_hideLabel","_label","_links","_orientation","_variant","entry","hasChildren","expanded","KolButtonLinkTextSwitchTag","_link","expandButton","KolButtonWcTag","_ariaExpanded","_disabled","_icons","_on","active","selected","key","render","hasCompactButton","devWarning","Host","id","KolButtonTag","_ariaControls","translate","_tooltipAlign","validateAriaCurrentValue","watchValidator","Set","validateAriaLabel","validateLabel","validateCompact","validateHideLabel","_oldValue","initial","removeNavLabel","required","a11yHintLabelingLandmarks","addNavLabel","validateLinks","watchNavLinks","devHint","validateOrientation","defaultValue","validateVariant","componentWillLoad","_compact","_ariaLabel","undefined","disconnectedCallback"],"sources":["src/types/props/collapsible.ts","src/types/props/has-compact-button.ts","src/components/nav/style.scss?tag=kol-nav&mode=default&encapsulation=shadow","src/components/nav/component.tsx"],"sourcesContent":["import type { Generic } from 'adopted-style-sheets';\n\nimport { watchBoolean } from '../../utils/prop.validators';\n\n/* types */\nexport type CollapsiblePropType = boolean;\n\n/**\n * Defines if navigation nodes can be collapsed or not.\n */\nexport type PropCollapsible = {\n\tcollapsible: CollapsiblePropType;\n};\n\n/* validator */\nexport const validateCollapsible = (component: Generic.Element.Component, value?: CollapsiblePropType): void => {\n\twatchBoolean(component, '_collapsible', value);\n};\n","import type { Generic } from 'adopted-style-sheets';\n\nimport { watchBoolean } from '../../utils/prop.validators';\n\n/* types */\n/**\n * @deprecated\n */\nexport type HasCompactButtonPropType = boolean;\n\n/**\n * Creates a button below the navigation, that toggles _collapsible. Only available for _orientation=\"vertical\".\n * @deprecated\n */\nexport type PropHasCompactButton = {\n\thasCompactButton: HasCompactButtonPropType;\n};\n\n/* validator */\nexport const validateHasCompactButton = (component: Generic.Element.Component, value?: HasCompactButtonPropType): void => {\n\twatchBoolean(component, '_hasCompactButton', value);\n};\n","@import '../style';\n\n:host > div {\n\tdisplay: grid;\n\tplace-items: center;\n}\n\nnav {\n\twidth: 100%;\n}\n\n.list {\n\tdisplay: flex;\n\tlist-style: none;\n\tmargin: 0;\n\tpadding: 0;\n}\n\n.list.vertical {\n\tflex-direction: column;\n}\n\n.entry {\n\tdisplay: flex;\n}\n\n.entry .kol-button-wc:first-child,\n.entry .kol-link-wc,\n.entry .kol-span-wc {\n\tflex-grow: 1;\n}\n\n.entry .kol-span-wc {\n\tjustify-items: start;\n}\n","import { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\nimport { ButtonOrLinkOrTextWithChildrenProps, ButtonWithChildrenProps } from '../../types/button-link-text';\nimport { Stringified } from '../../types/common';\nimport { Orientation } from '../../types/orientation';\nimport { AriaCurrentPropType } from '../../types/props/aria-current';\nimport { CollapsiblePropType, validateCollapsible } from '../../types/props/collapsible';\nimport { validateHasCompactButton } from '../../types/props/has-compact-button';\nimport { HideLabelPropType, validateHideLabel } from '../../types/props/hide-label';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { a11yHintLabelingLandmarks, devHint, devWarning } from '../../utils/a11y.tipps';\nimport { watchValidator } from '../../utils/prop.validators';\nimport { addNavLabel, removeNavLabel } from '../../utils/unique-nav-labels';\nimport { API, States } from './types';\nimport { watchNavLinks } from './validation';\nimport { KolButtonLinkTextSwitchTag, KolButtonTag, KolButtonWcTag } from '../../core/component-names';\n\n/**\n * @deprecated Removed in v2\n */\nexport type KoliBriNavVariant = 'primary' | 'secondary';\n\nconst linkValidator = (link: ButtonOrLinkOrTextWithChildrenProps): boolean => {\n\tif (typeof link === 'object' && typeof link._label === 'string' /* && typeof newLink._href === 'string' */) {\n\t\tif (Array.isArray(link._children)) {\n\t\t\treturn linksValidator(link._children);\n\t\t}\n\t\treturn false;\n\t}\n\treturn true;\n};\n\nconst linksValidator = (links: ButtonOrLinkOrTextWithChildrenProps[]): boolean => {\n\tif (Array.isArray(links)) {\n\t\treturn links.find(linkValidator) !== undefined;\n\t}\n\treturn true;\n};\n\n@Component({\n\ttag: 'kol-nav',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolNav implements API {\n\tprivate readonly onClick = (link: ButtonOrLinkOrTextWithChildrenProps): void => {\n\t\tlink._active = !link._active;\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t};\n\t};\n\n\tprivate readonly hasActiveChild = (link: ButtonOrLinkOrTextWithChildrenProps): boolean => {\n\t\tif (Array.isArray(link._children) && link._children.length > 0) {\n\t\t\treturn link._children.some(this.hasActiveChild);\n\t\t}\n\n\t\treturn false;\n\t};\n\n\tprivate entry(\n\t\tcollapsible: boolean,\n\t\thideLabel: HideLabelPropType,\n\t\thasChildren: boolean,\n\t\tlink: ButtonOrLinkOrTextWithChildrenProps,\n\t\texpanded: boolean,\n\t): JSX.Element {\n\t\treturn (\n\t\t\t<div class={{ entry: true, 'hide-label': hideLabel }}>\n\t\t\t\t<KolButtonLinkTextSwitchTag\n\t\t\t\t\t_link={{\n\t\t\t\t\t\t...link,\n\t\t\t\t\t\t_hideLabel: hideLabel,\n\t\t\t\t\t}}\n\t\t\t\t/>\n\t\t\t\t{hasChildren ? this.expandButton(collapsible, link as ButtonWithChildrenProps, expanded) : ''}\n\t\t\t</div>\n\t\t);\n\t}\n\n\tprivate expandButton(collapsible: boolean, link: ButtonWithChildrenProps, expanded: boolean): JSX.Element {\n\t\treturn (\n\t\t\t<KolButtonWcTag\n\t\t\t\tclass=\"expand-button\"\n\t\t\t\t_ariaExpanded={expanded}\n\t\t\t\t_disabled={!collapsible}\n\t\t\t\t_icons={'codicon codicon-' + (expanded ? 'remove' : 'add')}\n\t\t\t\t_hideLabel\n\t\t\t\t_label={`Untermenü zu ${link._label} ${expanded ? 'schließen' : 'öffnen'}`}\n\t\t\t\t_on={{ onClick: () => this.onClick(link) }}\n\t\t\t></KolButtonWcTag>\n\t\t);\n\t}\n\n\tprivate li(\n\t\tcollapsible: boolean,\n\t\thideLabel: HideLabelPropType,\n\t\tdeep: number,\n\t\tindex: number,\n\t\tlink: ButtonOrLinkOrTextWithChildrenProps,\n\t\torientation: Orientation,\n\t): JSX.Element {\n\t\tconst active = !!link._active;\n\t\tconst hasChildren = Array.isArray(link._children) && link._children.length > 0;\n\t\tconst expanded = hasChildren && active;\n\t\treturn (\n\t\t\t<li\n\t\t\t\tclass={{\n\t\t\t\t\tactive,\n\t\t\t\t\texpanded,\n\t\t\t\t\t'has-children': hasChildren,\n\t\t\t\t\tselected: expanded, // TODO: remove in v2\n\t\t\t\t}}\n\t\t\t\tkey={index}\n\t\t\t>\n\t\t\t\t{this.entry(collapsible, hideLabel, hasChildren, link, active)}\n\t\t\t\t{expanded ? (\n\t\t\t\t\t<this.linkList collapsible={collapsible} hideLabel={hideLabel} deep={deep + 1} links={link._children || []} orientation={orientation} />\n\t\t\t\t) : (\n\t\t\t\t\t''\n\t\t\t\t)}\n\t\t\t</li>\n\t\t);\n\t}\n\n\tprivate linkList = (props: {\n\t\tcollapsible: boolean;\n\t\thideLabel: HideLabelPropType;\n\t\tdeep: number;\n\t\tlinks: ButtonOrLinkOrTextWithChildrenProps[];\n\t\torientation: Orientation;\n\t}): JSX.Element => {\n\t\treturn (\n\t\t\t<ul class={`list ${props.deep === 0 && props.orientation === 'horizontal' ? ' horizontal' : ' vertical'}`} data-deep={props.deep}>\n\t\t\t\t{props.links.map((link, index: number) => {\n\t\t\t\t\treturn this.li(props.collapsible, props.hideLabel, props.deep, index, link, props.orientation);\n\t\t\t\t})}\n\t\t\t</ul>\n\t\t);\n\t};\n\n\tpublic render(): JSX.Element {\n\t\tlet hasCompactButton = this.state._hasCompactButton;\n\t\tif (this.state._orientation === 'horizontal' && this.state._hasCompactButton === true) {\n\t\t\thasCompactButton = false;\n\t\t\tdevWarning(`[KolNav] Wenn eine horizontale Navigation verwendet wird, kann die Option _hasCompactButton nicht aktiviert werden.`);\n\t\t}\n\t\tconst collapsible = this.state._collapsible === true;\n\t\tconst hideLabel = this.state._hideLabel === true;\n\t\tconst orientation = this.state._orientation;\n\t\treturn (\n\t\t\t<Host class=\"kol-nav\">\n\t\t\t\t<div\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[orientation]: true,\n\t\t\t\t\t\t[this.state._variant]: true,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t<nav aria-label={this.state._label} id=\"nav\">\n\t\t\t\t\t\t<this.linkList collapsible={collapsible} hideLabel={hideLabel} deep={0} links={this.state._links} orientation={orientation}></this.linkList>\n\t\t\t\t\t</nav>\n\t\t\t\t\t{hasCompactButton && (\n\t\t\t\t\t\t<div class=\"compact\">\n\t\t\t\t\t\t\t<KolButtonTag\n\t\t\t\t\t\t\t\t_ariaControls=\"nav\"\n\t\t\t\t\t\t\t\t_ariaExpanded={!hideLabel}\n\t\t\t\t\t\t\t\t_icons={hideLabel ? 'codicon codicon-chevron-right' : 'codicon codicon-chevron-left'}\n\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t_label={translate(hideLabel ? 'kol-nav-maximize' : 'kol-nav-minimize')}\n\t\t\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\t\t\tonClick: (): void => {\n\t\t\t\t\t\t\t\t\t\tthis.state = {\n\t\t\t\t\t\t\t\t\t\t\t...this.state,\n\t\t\t\t\t\t\t\t\t\t\t_hideLabel: this.state._hideLabel === false,\n\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t_tooltipAlign=\"right\"\n\t\t\t\t\t\t\t\t_variant=\"ghost\"\n\t\t\t\t\t\t\t></KolButtonTag>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Defines the value of aria-current to be used with the current context within the navigation.\n\t */\n\t@Prop() public _ariaCurrentValue: AriaCurrentPropType = false;\n\n\t/**\n\t * Deprecated: Setzt die semantische Beschriftung der Komponente.\n\t *\n\t * @deprecated use _label instead\n\t */\n\t@Prop() public _ariaLabel?: string;\n\n\t/**\n\t * Defines if navigation nodes can be collapsed or not. Enabled by default.\n\t * @TODO: Change type back to `CollapsiblePropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _collapsible?: boolean = true;\n\n\t/**\n\t * Deprecated: Gibt an, ob die Navigation kompakt angezeigt wird.\n\t * @deprecated Use _hide-label\n\t */\n\t@Prop() public _compact?: boolean = false;\n\n\t/**\n\t * Deprecated: Gibt an, ob die Navigation eine zusätzliche Schaltfläche zum Aus- und Einklappen der Navigation anzeigen soll.\n\t * @deprecated Version 2\n\t */\n\t@Prop() public _hasCompactButton?: boolean = false;\n\n\t/**\n\t * Hides the caption by default and displays the caption text with a tooltip when the\n\t * interactive element is focused or the mouse is over it.\n\t * @TODO: Change type back to `HideLabelPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hideLabel?: boolean = false;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label?: LabelPropType; // TODO: required in v2\n\n\t/**\n\t * Defines the list of links, buttons or texts to render.\n\t */\n\t@Prop() public _links!: Stringified<ButtonOrLinkOrTextWithChildrenProps[]>;\n\n\t/**\n\t * Defines whether the orientation of the component is horizontal or vertical.\n\t */\n\t@Prop() public _orientation?: Orientation = 'vertical';\n\n\t/**\n\t * Deprecated: Defines which variant should be used for presentation.\n\t *\n\t * @deprecated This property is deprecated and will be removed in the next major version.\n\t */\n\t@Prop() public _variant?: KoliBriNavVariant = 'primary';\n\n\t@State() public state: States = {\n\t\t_ariaCurrentValue: false,\n\t\t_collapsible: true,\n\t\t_hasCompactButton: false,\n\t\t_hideLabel: false,\n\t\t_label: '…', // ⚠ required\n\t\t_links: [],\n\t\t_orientation: 'vertical',\n\t\t_variant: 'primary',\n\t};\n\n\t@Watch('_ariaCurrentValue')\n\tpublic validateAriaCurrentValue(value?: AriaCurrentPropType): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_ariaCurrentValue',\n\t\t\t(value) => value === true || value === 'date' || value === 'location' || value === 'page' || value === 'step' || value === 'time',\n\t\t\tnew Set(['boolean', 'String {data, location, page, step, time}']),\n\t\t\tvalue,\n\t\t);\n\t}\n\n\t/**\n\t * @deprecated\n\t */\n\t@Watch('_ariaLabel')\n\tpublic validateAriaLabel(value?: string): void {\n\t\tthis.validateLabel(value);\n\t}\n\n\t@Watch('_collapsible')\n\tpublic validateCollapsible(value?: CollapsiblePropType): void {\n\t\tvalidateCollapsible(this, value);\n\t}\n\n\t@Watch('_compact')\n\tpublic validateCompact(value?: boolean): void {\n\t\tthis.validateHideLabel(value);\n\t}\n\n\t/**\n\t * @deprecated Version 2\n\t */\n\t@Watch('_hasCompactButton')\n\tpublic validateHasCompactButton(value?: boolean): void {\n\t\tvalidateHasCompactButton(this, value);\n\t}\n\n\t@Watch('_hideLabel')\n\tpublic validateHideLabel(value?: HideLabelPropType) {\n\t\tvalidateHideLabel(this, value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType, _oldValue?: LabelPropType, initial = false): void {\n\t\tif (!initial) {\n\t\t\tremoveNavLabel(this.state._label); // remove the current\n\t\t}\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t\ta11yHintLabelingLandmarks(value);\n\t\taddNavLabel(this.state._label); // add the state instead of prop, because the prop could be invalid and not set as new label\n\t}\n\n\t@Watch('_links')\n\tpublic validateLinks(value?: Stringified<ButtonOrLinkOrTextWithChildrenProps[]>): void {\n\t\twatchNavLinks('KolNav', this, value);\n\t\tdevHint(`[KolNav] Die Navigationsstruktur wird noch nicht rekursiv validiert.`);\n\t}\n\n\t@Watch('_orientation')\n\tpublic validateOrientation(value?: Orientation): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_orientation',\n\t\t\t(value): boolean => value === 'horizontal' || value === 'vertical',\n\t\t\tnew Set(['Orientation {horizontal, vertical}']),\n\t\t\tvalue,\n\t\t\t{\n\t\t\t\tdefaultValue: 'vertical',\n\t\t\t},\n\t\t);\n\t}\n\n\t@Watch('_variant')\n\tpublic validateVariant(value?: KoliBriNavVariant): void {\n\t\twatchValidator(this, '_variant', (value) => value === 'primary' || value === 'secondary', new Set(['KoliBriNavVariant {primary, secondary}']), value, {\n\t\t\tdefaultValue: 'primary',\n\t\t});\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAriaCurrentValue(this._ariaCurrentValue);\n\t\tthis.validateCollapsible(this._collapsible);\n\t\tthis.validateHideLabel(this._hideLabel || this._compact);\n\t\tthis.validateHasCompactButton(this._hasCompactButton);\n\t\tthis.validateLabel(this._label || this._ariaLabel, undefined, true);\n\t\tthis.validateLinks(this._links);\n\t\tthis.validateOrientation(this._orientation);\n\t\tthis.validateVariant(this._variant);\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tremoveNavLabel(this.state._label);\n\t}\n}\n\n// console.log(\n// stringifyJson([\n// { _label: '1 Navigationspunkt', _href: '#abc', _icons: 'codicon codicon-folder-closed', _target: 'asdasd' },\n// { _label: '2 Navigationspunkt', _href: '#abc', _icons: 'codicon codicon-folder-closed' },\n// {\n// _active: true,\n// _label: '3 Navigationspunkt',\n// _href: '#abc',\n// _icons: 'codicon codicon-folder-closed',\n// _children: [\n// { _label: '3.1 Navigationspunkt', _href: '#abc', _icons: 'codicon codicon-folder-closed' },\n// { _label: '3.2 Navigationspunkt', _href: '#abc', _icons: 'codicon codicon-folder-closed', _target: 'asdasd' },\n// {\n// _active: true,\n// _label: '3.3 Navigationspunkt',\n// _href: '#abc',\n// _children: [\n// { _active: true, _label: '3.3.1 Navigationspunkt (aktiv)', _href: '#abc' },\n// { _label: '3.3.2 Navigationspunkt', _href: '#abc' },\n// ],\n// },\n// {\n// _label: '3.4 Navigationspunkt',\n// _href: '#abc',\n// _children: [\n// { _label: '3.4.1 Navigationspunkt', _href: '#abc' },\n// { _label: '3.4.2 Navigationspunkt', _href: '#abc' },\n// ],\n// },\n// { _label: '3.5 Navigationspunkt', _href: '#abc' },\n// ],\n// },\n// { _label: '4 Navigationspunkt', _href: '#abc' },\n// ])\n// );\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{r as t,h as i,H as s}from"./index-a051748e.js";import{t as e}from"./i18n-ad947f60.js";import{v as a,a as o}from"./custom-class-76b06f69.js";import{v as n}from"./label-bce4f328.js";import{v as l}from"./tooltip-align-a16d498e.js";import{n as h}from"./dev.utils-f829063f.js";import{e as r,w as p,c,p as d}from"./prop.validators-3017e14b.js";import{r as u,a as _}from"./unique-nav-labels-62d9802d.js";import{S as f}from"./reuse-d79ab469.js";import{q as g,p as b,d as m}from"./component-names-fed305c7.js";import"./i18n-fddf0324.js";import"./a11y.tipps-798efb1a.js";import"./alignment-4c0cd265.js";import"./index-117bd1aa.js";const v=(t,a,i)=>{r(t,"_max",a,i)},y='@charset "UTF-8";:host{--a11y-min-size:44px;background-color:white;color:black;font-family:Verdana}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role=button],button:not([role=link]),.kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}[hidden]{display:none !important}:host{max-width:100%}*{box-sizing:border-box}.kol-span-wc{display:grid;place-items:center}.kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}.icon-only>.kol-span-wc>span>span{display:none}.hidden{display:none;visibility:hidden}.navigation-list{list-style:none}.separator:before{content:"•••"}',k=y,x={left:"codicon codicon-debug-reverse-continue"},C={left:"codicon codicon-chevron-left"},z={right:"codicon codicon-chevron-right"},S={right:"codicon codicon-debug-continue"},j=class{constructor(a){t(this,a),this.nonce=h(),this.calcCount=(t,a=1)=>Math.ceil(t/a),this.getCount=()=>this.calcCount(this.state._max,this.state._pageSize),this.onClick=(t,a)=>{"function"==typeof this.state._on.onClick&&this.state._on.onClick(t,a),this.onChangePage(t,a)},this.onChangePage=(t,a)=>{const i=setTimeout((()=>{clearTimeout(i),"function"==typeof this.state._on.onChangePage&&this.state._on.onChangePage(t,a)}))},this.onChangePageSize=(t,a)=>{if("number"==typeof(a=parseInt(a[0]))&&a>0&&this._pageSize!==a){this._pageSize=a;const i=setTimeout((()=>{clearTimeout(i),"function"==typeof this.state._on.onChangePageSize&&this.state._on.onChangePageSize(t,this._pageSize)}))}},this.onGoToFirst={onClick:t=>{this.onClick(t,1)}},this.onGoToEnd={onClick:t=>{this.onClick(t,this.getCount())}},this.onGoBackward={onClick:t=>{this.onClick(t,this.state._page-1)}},this.onGoForward={onClick:t=>{this.onClick(t,this.state._page+1)}},this.beforePageSize=(t,a)=>{let i=a.has("_pageSize")?a.get("_pageSize"):this.state._pageSize;const e=a.has("_pageSizeOptions")?a.get("_pageSizeOptions"):this.state._pageSizeOptions;if(Array.isArray(e)&&e.length>0){const t=e.find((t=>t.value===i));i=void 0===t?e[0].value:t.value,a.set("_pageSize",i)}const s=a.has("_page")?a.get("_page"):this.state._page,o=a.has("_max")?a.get("_max"):this.state._max;this.syncPage(a,s,a.get("_pageSize"),o)},this.syncPage=(t,a,i,e)=>{if(e>0){const s=this.calcCount(e,i);s>0&&(a>s?(t.set("_page",s),this.onChangePage(f,s)):a<1&&(t.set("_page",1),this.onChangePage(f,1)))}},this.beforePageSizeOptions=(t,a)=>{const i=[];if(Array.isArray(t))for(const a of t)"number"==typeof a&&i.push({label:e("kol-page-per-site",{placeholders:{entries:`${a}`}}),value:a});a.set("_pageSizeOptions",i),this.beforePageSize(i,a)},this._boundaryCount=1,this._customClass=void 0,this._label=void 0,this._hasButtons=!0,this._page=void 0,this._pageSize=1,this._pageSizeOptions=[],this._on=void 0,this._siblingCount=1,this._tooltipAlign="top",this._total=void 0,this._max=void 0,this._variant="normal",this.state={_boundaryCount:1,_label:e("kol-pagination"),_hasButtons:{first:!0,last:!0,next:!0,previous:!0},_on:{onClick:()=>null},_page:0,_pageSize:1,_pageSizeOptions:[],_siblingCount:1,_max:0,_variant:"normal"}}render(){var t;let a=!1;const o=this.getCount(),n=Array.from(Array(o).keys()).map((t=>t+1)).map((t=>t<=this.state._boundaryCount||t>o-this.state._boundaryCount||t>=this.state._page-this.state._siblingCount&&t<=this.state._page+this.state._siblingCount?(a=!0,this.state._page===t?this.getSelectedPageButton(t):this.getUnselectedPageButton(t)):!0===a?(a=!1,i("li",null,i("span",{class:"separator",key:`${this.nonce}-el-${t}`,"aria-hidden":"true"}))):null));return i(s,{class:"kol-pagination"},i("nav",{"aria-label":this.state._label},i("ul",{class:"navigation-list"},this.state._hasButtons.first&&i("li",null,i(b,{class:"first",exportparts:"icon",_customClass:this.state._customClass,_disabled:this.state._page<=1,_icon:x,_hideLabel:!0,_label:e("kol-page-first"),_on:this.onGoToFirst,_variant:this.state._variant,_tooltipAlign:this.state._tooltipAlign})),this.state._hasButtons.previous&&i("li",null,i(b,{class:"previous",exportparts:"icon",_customClass:this.state._customClass,_disabled:this.state._page<=1,_icon:C,_hideLabel:!0,_label:e("kol-page-back"),_on:this.onGoBackward,_variant:this.state._variant,_tooltipAlign:this.state._tooltipAlign})),n,this.state._hasButtons.next&&i("li",null,i(b,{class:"next",exportparts:"icon",_customClass:this.state._customClass,_disabled:o<=this.state._page,_icon:z,_hideLabel:!0,_label:e("kol-page-next"),_on:this.onGoForward,_variant:this.state._variant,_tooltipAlign:this.state._tooltipAlign})),this.state._hasButtons.last&&i("li",null,i(b,{class:"last",exportparts:"icon",_customClass:this.state._customClass,_disabled:o<=this.state._page,_icon:S,_hideLabel:!0,_label:e("kol-page-last"),_on:this.onGoToEnd,_variant:this.state._variant,_tooltipAlign:this.state._tooltipAlign})))),(null===(t=this.state._pageSizeOptions)||void 0===t?void 0:t.length)>0&&i(g,{_hideLabel:!0,_id:`pagination-size-${this.nonce}`,_label:e("kol-entries-per-site"),_list:this.state._pageSizeOptions,_on:{onChange:this.onChangePageSize},_value:[this.state._pageSize]}))}getUnselectedPageButton(t){return i("li",null,i(b,{exportparts:"icon",key:`${this.nonce}-${t}`,_customClass:this.state._customClass,_label:"",_on:{onClick:a=>{this.onClick(a,t)}},_variant:this.state._variant},i("span",{slot:"expert"},i("span",{class:"visually-hidden"},e("kol-page"))," ",t)))}getSelectedPageButton(t){return i("li",null,i(m,{class:"selected",key:`${this.nonce}-selected`,_customClass:this.state._customClass,_disabled:!0,_ariaCurrent:!0,_label:"",_variant:this.state._variant},i("span",{slot:"expert"},i("span",{class:"visually-hidden"},e("kol-page"))," ",t)))}validateBoundaryCount(t){r(this,"_boundaryCount",Math.max(0,null!=t?t:1))}validateCustomClass(t){a(this,t)}validateLabel(t,a,i=!1){i||u(this.state._label),n(this,t),_(this.state._label)}validateHasButtons(t){p(this,"_hasButtons",(t=>"boolean"==typeof t||"string"==typeof t||"object"==typeof t&&null!==t),new Set(["Boolean","PaginationHasButton"]),t,{hooks:{beforePatch:(t,a)=>{if("boolean"==typeof t)a.set("_hasButtons",{first:t,last:t,next:t,previous:t});else{if("string"==typeof t)try{t=d(t)}catch(t){a.delete("_hasButtons")}"object"==typeof t&&null!==t&&a.set("_hasButtons",Object.assign(Object.assign({},this.state._hasButtons),{first:"boolean"==typeof t.first?!0===t.first:this.state._hasButtons.first,last:"boolean"==typeof t.last?!0===t.last:this.state._hasButtons.last,next:"boolean"==typeof t.next?!0===t.next:this.state._hasButtons.next,previous:"boolean"==typeof t.previous?!0===t.previous:this.state._hasButtons.previous}))}}}})}validateOn(t){"object"==typeof t&&null!==t&&(this.state=Object.assign(Object.assign({},this.state),{_on:t}))}validatePage(t){r(this,"_page",t,{hooks:{beforePatch:(t,a)=>{const i=a.has("_pageSize")?a.get("_pageSize"):this.state._pageSize,e=a.has("_max")?a.get("_max"):this.state._max;this.syncPage(a,t,i,e)}}})}validatePageSize(t){r(this,"_pageSize",t,{hooks:{beforePatch:this.beforePageSize}})}validatePageSizeOptions(t){c(this,"_pageSizeOptions",(t=>"number"==typeof t),t,void 0,{hooks:{beforePatch:this.beforePageSizeOptions}})}validateSiblingCount(t){r(this,"_siblingCount",Math.max(0,null!=t?t:1))}validateTotal(t){this.validateMax(t)}validateMax(t){v(this,t,{hooks:{beforePatch:(t,a)=>{const i=a.has("_page")?a.get("_page"):this.state._page,e=a.has("_pageSize")?a.get("_pageSize"):this.state._pageSize;this.syncPage(a,i,e,t)}}})}validateTooltipAlign(t){l(this,t)}validateVariant(t){o(this,t)}componentWillLoad(){this.validateBoundaryCount(this._boundaryCount),this.validateCustomClass(this._customClass),this.validateHasButtons(this._hasButtons),this.validateLabel(this._label,void 0,!0),this.validateOn(this._on),this.validatePage(this._page),this.validatePageSize(this._pageSize),this.validatePageSizeOptions(this._pageSizeOptions),this.validateSiblingCount(this._siblingCount),this.validateTooltipAlign(this._tooltipAlign),this.validateMax(this._max||this._total),this.validateVariant(this._variant),this.validatePage(this._page)}disconnectedCallback(){u(this.state._label)}static get watchers(){return{_boundaryCount:["validateBoundaryCount"],_customClass:["validateCustomClass"],_label:["validateLabel"],_hasButtons:["validateHasButtons"],_on:["validateOn"],_page:["validatePage"],_pageSize:["validatePageSize"],_pageSizeOptions:["validatePageSizeOptions"],_siblingCount:["validateSiblingCount"],_total:["validateTotal"],_max:["validateMax"],_tooltipAlign:["validateTooltipAlign"],_variant:["validateVariant"]}}};j.style={default:k};export{j as kol_pagination};
4
+ import{r as t,h as i,H as s}from"./index-dfb131c4.js";import{t as e}from"./i18n-8ac68853.js";import{v as a,a as o}from"./custom-class-b9bd1dfe.js";import{v as n}from"./label-48b51f80.js";import{v as l}from"./tooltip-align-960e84c4.js";import{n as h}from"./dev.utils-1e8dd4a9.js";import{e as r,w as p,c,p as d}from"./prop.validators-a62aac63.js";import{r as u,a as _}from"./unique-nav-labels-62d9802d.js";import{S as f}from"./reuse-d79ab469.js";import{q as g,p as b,d as m}from"./component-names-fed305c7.js";import"./i18n-a2f79a81.js";import"./a11y.tipps-477c41d6.js";import"./alignment-7c2e01fd.js";import"./index-117bd1aa.js";const v=(t,a,i)=>{r(t,"_max",a,i)},y='@charset "UTF-8";:host{--a11y-min-size:44px;background-color:white;color:black;font-family:Verdana}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role=button],button:not([role=link]),.kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}[hidden]{display:none !important}:host{max-width:100%}*{box-sizing:border-box}.kol-span-wc{display:grid;place-items:center}.kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}.icon-only>.kol-span-wc>span>span{display:none}.hidden{display:none;visibility:hidden}.navigation-list{list-style:none}.separator:before{content:"•••"}',k=y,x={left:"codicon codicon-debug-reverse-continue"},C={left:"codicon codicon-chevron-left"},z={right:"codicon codicon-chevron-right"},S={right:"codicon codicon-debug-continue"},j=class{constructor(a){t(this,a),this.nonce=h(),this.calcCount=(t,a=1)=>Math.ceil(t/a),this.getCount=()=>this.calcCount(this.state._max,this.state._pageSize),this.onClick=(t,a)=>{"function"==typeof this.state._on.onClick&&this.state._on.onClick(t,a),this.onChangePage(t,a)},this.onChangePage=(t,a)=>{const i=setTimeout((()=>{clearTimeout(i),"function"==typeof this.state._on.onChangePage&&this.state._on.onChangePage(t,a)}))},this.onChangePageSize=(t,a)=>{if("number"==typeof(a=parseInt(a[0]))&&a>0&&this._pageSize!==a){this._pageSize=a;const i=setTimeout((()=>{clearTimeout(i),"function"==typeof this.state._on.onChangePageSize&&this.state._on.onChangePageSize(t,this._pageSize)}))}},this.onGoToFirst={onClick:t=>{this.onClick(t,1)}},this.onGoToEnd={onClick:t=>{this.onClick(t,this.getCount())}},this.onGoBackward={onClick:t=>{this.onClick(t,this.state._page-1)}},this.onGoForward={onClick:t=>{this.onClick(t,this.state._page+1)}},this.beforePageSize=(t,a)=>{let i=a.has("_pageSize")?a.get("_pageSize"):this.state._pageSize;const e=a.has("_pageSizeOptions")?a.get("_pageSizeOptions"):this.state._pageSizeOptions;if(Array.isArray(e)&&e.length>0){const t=e.find((t=>t.value===i));i=void 0===t?e[0].value:t.value,a.set("_pageSize",i)}const s=a.has("_page")?a.get("_page"):this.state._page,o=a.has("_max")?a.get("_max"):this.state._max;this.syncPage(a,s,a.get("_pageSize"),o)},this.syncPage=(t,a,i,e)=>{if(e>0){const s=this.calcCount(e,i);s>0&&(a>s?(t.set("_page",s),this.onChangePage(f,s)):a<1&&(t.set("_page",1),this.onChangePage(f,1)))}},this.beforePageSizeOptions=(t,a)=>{const i=[];if(Array.isArray(t))for(const a of t)"number"==typeof a&&i.push({label:e("kol-page-per-site",{placeholders:{entries:`${a}`}}),value:a});a.set("_pageSizeOptions",i),this.beforePageSize(i,a)},this._boundaryCount=1,this._customClass=void 0,this._label=void 0,this._hasButtons=!0,this._page=void 0,this._pageSize=1,this._pageSizeOptions=[],this._on=void 0,this._siblingCount=1,this._tooltipAlign="top",this._total=void 0,this._max=void 0,this._variant="normal",this.state={_boundaryCount:1,_label:e("kol-pagination"),_hasButtons:{first:!0,last:!0,next:!0,previous:!0},_on:{onClick:()=>null},_page:0,_pageSize:1,_pageSizeOptions:[],_siblingCount:1,_max:0,_variant:"normal"}}render(){var t;let a=!1;const o=this.getCount(),n=Array.from(Array(o).keys()).map((t=>t+1)).map((t=>t<=this.state._boundaryCount||t>o-this.state._boundaryCount||t>=this.state._page-this.state._siblingCount&&t<=this.state._page+this.state._siblingCount?(a=!0,this.state._page===t?this.getSelectedPageButton(t):this.getUnselectedPageButton(t)):!0===a?(a=!1,i("li",null,i("span",{class:"separator",key:`${this.nonce}-el-${t}`,"aria-hidden":"true"}))):null));return i(s,{class:"kol-pagination"},i("nav",{"aria-label":this.state._label},i("ul",{class:"navigation-list"},this.state._hasButtons.first&&i("li",null,i(b,{class:"first",exportparts:"icon",_customClass:this.state._customClass,_disabled:this.state._page<=1,_icon:x,_hideLabel:!0,_label:e("kol-page-first"),_on:this.onGoToFirst,_variant:this.state._variant,_tooltipAlign:this.state._tooltipAlign})),this.state._hasButtons.previous&&i("li",null,i(b,{class:"previous",exportparts:"icon",_customClass:this.state._customClass,_disabled:this.state._page<=1,_icon:C,_hideLabel:!0,_label:e("kol-page-back"),_on:this.onGoBackward,_variant:this.state._variant,_tooltipAlign:this.state._tooltipAlign})),n,this.state._hasButtons.next&&i("li",null,i(b,{class:"next",exportparts:"icon",_customClass:this.state._customClass,_disabled:o<=this.state._page,_icon:z,_hideLabel:!0,_label:e("kol-page-next"),_on:this.onGoForward,_variant:this.state._variant,_tooltipAlign:this.state._tooltipAlign})),this.state._hasButtons.last&&i("li",null,i(b,{class:"last",exportparts:"icon",_customClass:this.state._customClass,_disabled:o<=this.state._page,_icon:S,_hideLabel:!0,_label:e("kol-page-last"),_on:this.onGoToEnd,_variant:this.state._variant,_tooltipAlign:this.state._tooltipAlign})))),(null===(t=this.state._pageSizeOptions)||void 0===t?void 0:t.length)>0&&i(g,{_hideLabel:!0,_id:`pagination-size-${this.nonce}`,_label:e("kol-entries-per-site"),_list:this.state._pageSizeOptions,_on:{onChange:this.onChangePageSize},_value:[this.state._pageSize]}))}getUnselectedPageButton(t){return i("li",{key:`${this.nonce}-${t}`},i(b,{exportparts:"icon",_customClass:this.state._customClass,_label:"",_on:{onClick:a=>{this.onClick(a,t)}},_variant:this.state._variant},i("span",{slot:"expert"},i("span",{class:"visually-hidden"},e("kol-page"))," ",t)))}getSelectedPageButton(t){return i("li",{key:`${this.nonce}-selected`},i(m,{class:"selected",_customClass:this.state._customClass,_disabled:!0,_ariaCurrent:!0,_label:"",_variant:this.state._variant},i("span",{slot:"expert"},i("span",{class:"visually-hidden"},e("kol-page"))," ",t)))}validateBoundaryCount(t){r(this,"_boundaryCount",Math.max(0,null!=t?t:1))}validateCustomClass(t){a(this,t)}validateLabel(t,a,i=!1){i||u(this.state._label),n(this,t),_(this.state._label)}validateHasButtons(t){p(this,"_hasButtons",(t=>"boolean"==typeof t||"string"==typeof t||"object"==typeof t&&null!==t),new Set(["Boolean","PaginationHasButton"]),t,{hooks:{beforePatch:(t,a)=>{if("boolean"==typeof t)a.set("_hasButtons",{first:t,last:t,next:t,previous:t});else{if("string"==typeof t)try{t=d(t)}catch(t){a.delete("_hasButtons")}"object"==typeof t&&null!==t&&a.set("_hasButtons",Object.assign(Object.assign({},this.state._hasButtons),{first:"boolean"==typeof t.first?!0===t.first:this.state._hasButtons.first,last:"boolean"==typeof t.last?!0===t.last:this.state._hasButtons.last,next:"boolean"==typeof t.next?!0===t.next:this.state._hasButtons.next,previous:"boolean"==typeof t.previous?!0===t.previous:this.state._hasButtons.previous}))}}}})}validateOn(t){"object"==typeof t&&null!==t&&(this.state=Object.assign(Object.assign({},this.state),{_on:t}))}validatePage(t){r(this,"_page",t,{hooks:{beforePatch:(t,a)=>{const i=a.has("_pageSize")?a.get("_pageSize"):this.state._pageSize,e=a.has("_max")?a.get("_max"):this.state._max;this.syncPage(a,t,i,e)}}})}validatePageSize(t){r(this,"_pageSize",t,{hooks:{beforePatch:this.beforePageSize}})}validatePageSizeOptions(t){c(this,"_pageSizeOptions",(t=>"number"==typeof t),t,void 0,{hooks:{beforePatch:this.beforePageSizeOptions}})}validateSiblingCount(t){r(this,"_siblingCount",Math.max(0,null!=t?t:1))}validateTotal(t){this.validateMax(t)}validateMax(t){v(this,t,{hooks:{beforePatch:(t,a)=>{const i=a.has("_page")?a.get("_page"):this.state._page,e=a.has("_pageSize")?a.get("_pageSize"):this.state._pageSize;this.syncPage(a,i,e,t)}}})}validateTooltipAlign(t){l(this,t)}validateVariant(t){o(this,t)}componentWillLoad(){this.validateBoundaryCount(this._boundaryCount),this.validateCustomClass(this._customClass),this.validateHasButtons(this._hasButtons),this.validateLabel(this._label,void 0,!0),this.validateOn(this._on),this.validatePage(this._page),this.validatePageSize(this._pageSize),this.validatePageSizeOptions(this._pageSizeOptions),this.validateSiblingCount(this._siblingCount),this.validateTooltipAlign(this._tooltipAlign),this.validateMax(this._max||this._total),this.validateVariant(this._variant),this.validatePage(this._page)}disconnectedCallback(){u(this.state._label)}static get watchers(){return{_boundaryCount:["validateBoundaryCount"],_customClass:["validateCustomClass"],_label:["validateLabel"],_hasButtons:["validateHasButtons"],_on:["validateOn"],_page:["validatePage"],_pageSize:["validatePageSize"],_pageSizeOptions:["validatePageSizeOptions"],_siblingCount:["validateSiblingCount"],_total:["validateTotal"],_max:["validateMax"],_tooltipAlign:["validateTooltipAlign"],_variant:["validateVariant"]}}};j.style={default:k};export{j as kol_pagination};
@@ -1 +1 @@
1
- {"version":3,"names":["validateMax","component","value","options","watchNumber","defaultStyleCss","KolPaginationDefaultStyle0","leftDoubleArrowIcon","left","leftSingleArrow","rightSingleArrowIcon","right","rightDoubleArrowIcon","KolPagination","this","nonce","calcCount","total","pageSize","Math","ceil","getCount","state","_max","_pageSize","onClick","event","page","_on","onChangePage","timeout","setTimeout","clearTimeout","onChangePageSize","parseInt","onGoToFirst","onGoToEnd","onGoBackward","_page","onGoForward","beforePageSize","_nextValue","nextState","has","get","pageSizeOptions","_pageSizeOptions","Array","isArray","length","find","option","undefined","set","syncPage","count","STATE_CHANGE_EVENT","beforePageSizeOptions","nextValue","push","label","translate","placeholders","entries","_boundaryCount","_label","_hasButtons","first","last","next","previous","_siblingCount","_variant","render","ellipsis","pageButtons","from","keys","map","index","getSelectedPageButton","getUnselectedPageButton","h","class","key","Host","KolButtonTag","exportparts","_customClass","_disabled","_icon","_hideLabel","_tooltipAlign","_a","KolSelectTag","_id","_list","onChange","_value","slot","KolButtonWcTag","_ariaCurrent","validateBoundaryCount","max","validateCustomClass","validateLabel","_oldValue","initial","removeNavLabel","addNavLabel","validateHasButtons","watchValidator","Set","hooks","beforePatch","parseJson","e","delete","Object","assign","validateOn","validatePage","validatePageSize","validatePageSizeOptions","watchJsonArrayString","validateSiblingCount","validateTotal","validateTooltipAlign","validateVariant","validateButtonVariant","componentWillLoad","_total","disconnectedCallback"],"sources":["src/types/props/max.ts","src/components/pagination/style.scss?tag=kol-pagination&mode=default&encapsulation=shadow","src/components/pagination/component.tsx"],"sourcesContent":["import type { Generic } from 'adopted-style-sheets';\n\nimport { watchNumber, WatchNumberOptions } from '../../utils/prop.validators';\nimport { RowsPropType } from './rows';\n\n/* types */\nexport type MaxPropType = number;\n\n/**\n * Number of rows of the input element that should be visible at the same time.\n */\nexport type PropMax = {\n\tmax: MaxPropType;\n};\n\n/* validator */\nexport const validateMax = (component: Generic.Element.Component, value?: RowsPropType, options?: WatchNumberOptions): void => {\n\twatchNumber(component, '_max', value, options);\n};\n","@import '../style';\n\n.navigation-list {\n\tlist-style: none;\n}\n\n.separator:before {\n\tcontent: '•••';\n}\n","import { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\nimport { Stringified } from '../../types/common';\nimport { Option } from '../../types/input/types';\nimport { ButtonVariantPropType, validateButtonVariant } from '../../types/props/button-variant';\nimport { CustomClassPropType, validateCustomClass } from '../../types/props/custom-class';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { TooltipAlignPropType, validateTooltipAlign } from '../../types/props/tooltip-align';\nimport { nonce } from '../../utils/dev.utils';\nimport { parseJson, watchJsonArrayString, watchNumber, watchValidator } from '../../utils/prop.validators';\nimport { addNavLabel, removeNavLabel } from '../../utils/unique-nav-labels';\nimport { STATE_CHANGE_EVENT } from '../../utils/validator';\nimport { API, KoliBriPaginationButtonCallbacks, PaginationHasButton, States } from './types';\nimport { MaxPropType, validateMax } from '../../types/props/max';\nimport { KolButtonTag, KolButtonWcTag, KolSelectTag } from '../../core/component-names';\n\nconst leftDoubleArrowIcon = {\n\tleft: 'codicon codicon-debug-reverse-continue',\n};\nconst leftSingleArrow = {\n\tleft: 'codicon codicon-chevron-left',\n};\nconst rightSingleArrowIcon = {\n\tright: 'codicon codicon-chevron-right',\n};\nconst rightDoubleArrowIcon = {\n\tright: 'codicon codicon-debug-continue',\n};\n\n@Component({\n\ttag: 'kol-pagination',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolPagination implements API {\n\tprivate readonly nonce = nonce();\n\n\tprivate readonly calcCount = (total: number, pageSize = 1): number => Math.ceil(total / pageSize);\n\n\tprivate readonly getCount = (): number => this.calcCount(this.state._max, this.state._pageSize);\n\n\tpublic render(): JSX.Element {\n\t\tlet ellipsis = false;\n\t\tconst count = this.getCount();\n\t\tconst pageButtons = Array.from(Array(count).keys())\n\t\t\t.map((index: number) => index + 1)\n\t\t\t.map((page: number) => {\n\t\t\t\tif (\n\t\t\t\t\tpage <= this.state._boundaryCount ||\n\t\t\t\t\tpage > count - this.state._boundaryCount ||\n\t\t\t\t\t(page >= this.state._page - this.state._siblingCount && page <= this.state._page + this.state._siblingCount)\n\t\t\t\t) {\n\t\t\t\t\tellipsis = true;\n\t\t\t\t\tif (this.state._page === page) {\n\t\t\t\t\t\treturn this.getSelectedPageButton(page);\n\t\t\t\t\t} else {\n\t\t\t\t\t\treturn this.getUnselectedPageButton(page);\n\t\t\t\t\t}\n\t\t\t\t} else if (ellipsis === true) {\n\t\t\t\t\tellipsis = false;\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t<span class=\"separator\" key={`${this.nonce}-el-${page}`} aria-hidden=\"true\"></span>\n\t\t\t\t\t\t</li>\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\treturn null;\n\t\t\t\t}\n\t\t\t});\n\n\t\treturn (\n\t\t\t<Host class=\"kol-pagination\">\n\t\t\t\t<nav aria-label={this.state._label}>\n\t\t\t\t\t<ul class=\"navigation-list\">\n\t\t\t\t\t\t{this.state._hasButtons.first && (\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<KolButtonTag\n\t\t\t\t\t\t\t\t\tclass=\"first\"\n\t\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t\t\t\t\t_disabled={this.state._page <= 1}\n\t\t\t\t\t\t\t\t\t_icon={leftDoubleArrowIcon}\n\t\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t\t_label={translate('kol-page-first')}\n\t\t\t\t\t\t\t\t\t_on={this.onGoToFirst}\n\t\t\t\t\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t\t\t\t\t\t_tooltipAlign={this.state._tooltipAlign}\n\t\t\t\t\t\t\t\t></KolButtonTag>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t{this.state._hasButtons.previous && (\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<KolButtonTag\n\t\t\t\t\t\t\t\t\tclass=\"previous\"\n\t\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t\t\t\t\t_disabled={this.state._page <= 1}\n\t\t\t\t\t\t\t\t\t_icon={leftSingleArrow}\n\t\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t\t_label={translate('kol-page-back')}\n\t\t\t\t\t\t\t\t\t_on={this.onGoBackward}\n\t\t\t\t\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t\t\t\t\t\t_tooltipAlign={this.state._tooltipAlign}\n\t\t\t\t\t\t\t\t></KolButtonTag>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t{pageButtons}\n\t\t\t\t\t\t{this.state._hasButtons.next && (\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<KolButtonTag\n\t\t\t\t\t\t\t\t\tclass=\"next\"\n\t\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t\t\t\t\t_disabled={count <= this.state._page}\n\t\t\t\t\t\t\t\t\t_icon={rightSingleArrowIcon}\n\t\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t\t_label={translate('kol-page-next')}\n\t\t\t\t\t\t\t\t\t_on={this.onGoForward}\n\t\t\t\t\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t\t\t\t\t\t_tooltipAlign={this.state._tooltipAlign}\n\t\t\t\t\t\t\t\t></KolButtonTag>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t{this.state._hasButtons.last && (\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<KolButtonTag\n\t\t\t\t\t\t\t\t\tclass=\"last\"\n\t\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t\t\t\t\t_disabled={count <= this.state._page}\n\t\t\t\t\t\t\t\t\t_icon={rightDoubleArrowIcon}\n\t\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t\t_label={translate('kol-page-last')}\n\t\t\t\t\t\t\t\t\t_on={this.onGoToEnd}\n\t\t\t\t\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t\t\t\t\t\t_tooltipAlign={this.state._tooltipAlign}\n\t\t\t\t\t\t\t\t></KolButtonTag>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</ul>\n\t\t\t\t</nav>\n\t\t\t\t{this.state._pageSizeOptions?.length > 0 && (\n\t\t\t\t\t<KolSelectTag\n\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t_id={`pagination-size-${this.nonce}`}\n\t\t\t\t\t\t_label={translate('kol-entries-per-site')}\n\t\t\t\t\t\t_list={this.state._pageSizeOptions}\n\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\tonChange: this.onChangePageSize,\n\t\t\t\t\t\t}}\n\t\t\t\t\t\t_value={[this.state._pageSize]}\n\t\t\t\t\t></KolSelectTag>\n\t\t\t\t)}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Defines the amount of pages to show next to the outer arrow buttons.\n\t */\n\t@Prop() public _boundaryCount?: number = 1;\n\n\t/**\n\t * Defines the custom class attribute if _variant=\"custom\" is set.\n\t */\n\t@Prop() public _customClass?: CustomClassPropType;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label?: LabelPropType;\n\n\t/**\n\t * Defines which navigation buttons to render (first, last, next, previous buttons).\n\t */\n\t@Prop() public _hasButtons?: boolean | Stringified<PaginationHasButton> = true;\n\n\t/**\n\t * Defines the current page.\n\t */\n\t@Prop() public _page!: number;\n\n\t/**\n\t * Defines the amount of entries to show per page.\n\t */\n\t@Prop({ mutable: true, reflect: false }) public _pageSize = 1;\n\n\t/**\n\t * Defines the options for the page-size-select.\n\t */\n\t@Prop() public _pageSizeOptions: Stringified<number[]> = [];\n\n\t/**\n\t * Gibt an, auf welche Callback-Events reagiert werden.\n\t */\n\t@Prop() public _on!: KoliBriPaginationButtonCallbacks;\n\n\t/**\n\t * Defines the amount of pages to show next to the current page.\n\t */\n\t@Prop() public _siblingCount?: number = 1;\n\n\t/**\n\t * Defines where to show the Tooltip preferably: top, right, bottom or left.\n\t */\n\t@Prop() public _tooltipAlign?: TooltipAlignPropType = 'top';\n\n\t/**\n\t * Setzt die Gesamtanzahl der Seiten.\n\t * @deprecated Use _max.\n\t */\n\t@Prop() public _total?: number;\n\n\t/**\n\t * Defines the maximum number of pages.\n\t */\n\t@Prop() public _max?: MaxPropType;\n\n\t/**\n\t * Defines which variant should be used for presentation.\n\t */\n\t@Prop() public _variant?: ButtonVariantPropType = 'normal';\n\n\t@State() public state: States = {\n\t\t_boundaryCount: 1,\n\t\t_label: translate('kol-pagination'),\n\t\t_hasButtons: {\n\t\t\tfirst: true,\n\t\t\tlast: true,\n\t\t\tnext: true,\n\t\t\tprevious: true,\n\t\t},\n\t\t_on: {\n\t\t\tonClick: () => null,\n\t\t},\n\t\t_page: 0,\n\t\t_pageSize: 1,\n\t\t_pageSizeOptions: [],\n\t\t_siblingCount: 1,\n\t\t_max: 0,\n\t\t_variant: 'normal',\n\t};\n\n\tprivate onClick = (event: Event, page: number) => {\n\t\tif (typeof this.state._on.onClick === 'function') {\n\t\t\tthis.state._on.onClick(event, page);\n\t\t}\n\t\tthis.onChangePage(event, page);\n\t};\n\n\tprivate onChangePage = (event: Event, page: number) => {\n\t\tconst timeout = setTimeout(() => {\n\t\t\tclearTimeout(timeout);\n\t\t\tif (typeof this.state._on.onChangePage === 'function') {\n\t\t\t\tthis.state._on.onChangePage(event, page);\n\t\t\t}\n\t\t});\n\t};\n\n\tprivate onChangePageSize = (event: Event, value: unknown) => {\n\t\tvalue = parseInt((value as string[])[0]);\n\t\tif (typeof value === 'number' && value > 0 && this._pageSize !== value) {\n\t\t\tthis._pageSize = value;\n\t\t\tconst timeout = setTimeout(() => {\n\t\t\t\tclearTimeout(timeout);\n\t\t\t\tif (typeof this.state._on.onChangePageSize === 'function') {\n\t\t\t\t\tthis.state._on.onChangePageSize(event, this._pageSize);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t};\n\n\tprivate readonly onGoToFirst = {\n\t\tonClick: (event: Event) => {\n\t\t\tthis.onClick(event, 1);\n\t\t},\n\t};\n\tprivate readonly onGoToEnd = {\n\t\tonClick: (event: Event) => {\n\t\t\tthis.onClick(event, this.getCount());\n\t\t},\n\t};\n\tprivate readonly onGoBackward = {\n\t\tonClick: (event: Event) => {\n\t\t\tthis.onClick(event, this.state._page - 1);\n\t\t},\n\t};\n\tprivate readonly onGoForward = {\n\t\tonClick: (event: Event) => {\n\t\t\tthis.onClick(event, this.state._page + 1);\n\t\t},\n\t};\n\n\tprivate getUnselectedPageButton(page: number): JSX.Element {\n\t\treturn (\n\t\t\t<li>\n\t\t\t\t<KolButtonTag\n\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\tkey={`${this.nonce}-${page}`}\n\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t_label=\"\"\n\t\t\t\t\t_on={{\n\t\t\t\t\t\tonClick: (event: Event) => {\n\t\t\t\t\t\t\tthis.onClick(event, page);\n\t\t\t\t\t\t},\n\t\t\t\t\t}}\n\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t>\n\t\t\t\t\t<span slot=\"expert\">\n\t\t\t\t\t\t<span class=\"visually-hidden\">{translate('kol-page')}</span> {page}\n\t\t\t\t\t</span>\n\t\t\t\t</KolButtonTag>\n\t\t\t</li>\n\t\t);\n\t}\n\n\tprivate getSelectedPageButton(page: number): JSX.Element {\n\t\treturn (\n\t\t\t<li>\n\t\t\t\t<KolButtonWcTag\n\t\t\t\t\tclass=\"selected\"\n\t\t\t\t\tkey={`${this.nonce}-selected`}\n\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t_disabled={true}\n\t\t\t\t\t_ariaCurrent={true}\n\t\t\t\t\t_label=\"\"\n\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t>\n\t\t\t\t\t<span slot=\"expert\">\n\t\t\t\t\t\t<span class=\"visually-hidden\">{translate('kol-page')}</span> {page}\n\t\t\t\t\t</span>\n\t\t\t\t</KolButtonWcTag>\n\t\t\t</li>\n\t\t);\n\t}\n\n\t@Watch('_boundaryCount')\n\tpublic validateBoundaryCount(value?: number): void {\n\t\twatchNumber(this, '_boundaryCount', Math.max(0, value ?? 1));\n\t}\n\n\t@Watch('_customClass')\n\tpublic validateCustomClass(value?: CustomClassPropType): void {\n\t\tvalidateCustomClass(this, value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(label?: LabelPropType, _oldValue?: LabelPropType, initial = false) {\n\t\tif (!initial) {\n\t\t\tremoveNavLabel(this.state._label);\n\t\t}\n\t\tvalidateLabel(this, label);\n\t\taddNavLabel(this.state._label); // add the state instead of prop, because the prop could be invalid and not set as new label\n\t}\n\n\t@Watch('_hasButtons')\n\tpublic validateHasButtons(value?: string | boolean | Stringified<PaginationHasButton>): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_hasButtons',\n\t\t\t(value) => typeof value === 'boolean' || typeof value === 'string' || (typeof value === 'object' && value !== null),\n\t\t\tnew Set(['Boolean', 'PaginationHasButton']),\n\t\t\tvalue,\n\t\t\t{\n\t\t\t\thooks: {\n\t\t\t\t\tbeforePatch: (nextValue: unknown, nextState: Map<string, unknown>) => {\n\t\t\t\t\t\tif (typeof nextValue === 'boolean') {\n\t\t\t\t\t\t\tnextState.set('_hasButtons', {\n\t\t\t\t\t\t\t\tfirst: nextValue,\n\t\t\t\t\t\t\t\tlast: nextValue,\n\t\t\t\t\t\t\t\tnext: nextValue,\n\t\t\t\t\t\t\t\tprevious: nextValue,\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tif (typeof nextValue === 'string') {\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tnextValue = parseJson<PaginationHasButton>(nextValue);\n\t\t\t\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t\t\t\tnextState.delete('_hasButtons');\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\tif (typeof nextValue === 'object' && nextValue !== null) {\n\t\t\t\t\t\t\t\tnextState.set('_hasButtons', {\n\t\t\t\t\t\t\t\t\t...this.state._hasButtons,\n\t\t\t\t\t\t\t\t\tfirst:\n\t\t\t\t\t\t\t\t\t\ttypeof (nextValue as PaginationHasButton).first === 'boolean'\n\t\t\t\t\t\t\t\t\t\t\t? (nextValue as PaginationHasButton).first === true\n\t\t\t\t\t\t\t\t\t\t\t: this.state._hasButtons.first,\n\t\t\t\t\t\t\t\t\tlast:\n\t\t\t\t\t\t\t\t\t\ttypeof (nextValue as PaginationHasButton).last === 'boolean'\n\t\t\t\t\t\t\t\t\t\t\t? (nextValue as PaginationHasButton).last === true\n\t\t\t\t\t\t\t\t\t\t\t: this.state._hasButtons.last,\n\t\t\t\t\t\t\t\t\tnext:\n\t\t\t\t\t\t\t\t\t\ttypeof (nextValue as PaginationHasButton).next === 'boolean'\n\t\t\t\t\t\t\t\t\t\t\t? (nextValue as PaginationHasButton).next === true\n\t\t\t\t\t\t\t\t\t\t\t: this.state._hasButtons.next,\n\t\t\t\t\t\t\t\t\tprevious:\n\t\t\t\t\t\t\t\t\t\ttypeof (nextValue as PaginationHasButton).previous === 'boolean'\n\t\t\t\t\t\t\t\t\t\t\t? (nextValue as PaginationHasButton).previous === true\n\t\t\t\t\t\t\t\t\t\t\t: this.state._hasButtons.previous,\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('_on')\n\tpublic validateOn(value?: KoliBriPaginationButtonCallbacks): void {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tthis.state = {\n\t\t\t\t...this.state,\n\t\t\t\t_on: value,\n\t\t\t};\n\t\t}\n\t}\n\n\t@Watch('_page')\n\tpublic validatePage(value?: number): void {\n\t\twatchNumber(this, '_page', value, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: (_nextValue: unknown, nextState: Map<string, unknown>) => {\n\t\t\t\t\tconst pageSize = nextState.has('_pageSize') ? (nextState.get('_pageSize') as number) : this.state._pageSize;\n\t\t\t\t\tconst total = nextState.has('_max') ? (nextState.get('_max') as number) : this.state._max;\n\t\t\t\t\tthis.syncPage(nextState, _nextValue as number, pageSize, total);\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\t}\n\n\tprivate beforePageSize = (_nextValue: unknown, nextState: Map<string, unknown>) => {\n\t\tlet pageSize = nextState.has('_pageSize') ? (nextState.get('_pageSize') as number) : this.state._pageSize;\n\t\tconst pageSizeOptions = nextState.has('_pageSizeOptions') ? (nextState.get('_pageSizeOptions') as Option<number>[]) : this.state._pageSizeOptions;\n\t\tif (Array.isArray(pageSizeOptions) && pageSizeOptions.length > 0) {\n\t\t\tconst find = pageSizeOptions.find((option) => option.value === pageSize);\n\t\t\tif (find === undefined) {\n\t\t\t\tpageSize = pageSizeOptions[0].value;\n\t\t\t} else {\n\t\t\t\tpageSize = find.value;\n\t\t\t}\n\t\t\tnextState.set('_pageSize', pageSize);\n\t\t}\n\t\tconst page = nextState.has('_page') ? (nextState.get('_page') as number) : this.state._page;\n\t\tconst total = nextState.has('_max') ? (nextState.get('_max') as number) : this.state._max;\n\t\tthis.syncPage(nextState, page, nextState.get('_pageSize') as number, total);\n\t};\n\n\tprivate syncPage = (nextState: Map<string, unknown>, page: number, pageSize: number, total: number) => {\n\t\t// count === 0 means no data\n\t\tif (total > 0) {\n\t\t\tconst count = this.calcCount(total, pageSize);\n\t\t\tif (count > 0) {\n\t\t\t\tif (page > count) {\n\t\t\t\t\tnextState.set('_page', count);\n\t\t\t\t\tthis.onChangePage(STATE_CHANGE_EVENT, count);\n\t\t\t\t} else if (page < 1) {\n\t\t\t\t\tnextState.set('_page', 1);\n\t\t\t\t\tthis.onChangePage(STATE_CHANGE_EVENT, 1);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n\n\tprivate beforePageSizeOptions = (nextValue: unknown, nextState: Map<string, unknown>) => {\n\t\tconst options: Option<number>[] = [];\n\t\tif (Array.isArray(nextValue)) {\n\t\t\tfor (const value of nextValue) {\n\t\t\t\tif (typeof value === 'number') {\n\t\t\t\t\toptions.push({\n\t\t\t\t\t\tlabel: translate('kol-page-per-site', { placeholders: { entries: `${value}` } }),\n\t\t\t\t\t\tvalue: value,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tnextState.set('_pageSizeOptions', options);\n\t\tthis.beforePageSize(options, nextState);\n\t};\n\n\t@Watch('_pageSize')\n\tpublic validatePageSize(value?: number): void {\n\t\twatchNumber(this, '_pageSize', value, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: this.beforePageSize,\n\t\t\t},\n\t\t});\n\t}\n\n\t@Watch('_pageSizeOptions')\n\tpublic validatePageSizeOptions(value?: Stringified<number[]>): void {\n\t\twatchJsonArrayString(this, '_pageSizeOptions', (value) => typeof value === 'number', value, undefined, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: this.beforePageSizeOptions,\n\t\t\t},\n\t\t});\n\t}\n\n\t@Watch('_siblingCount')\n\tpublic validateSiblingCount(value?: number): void {\n\t\twatchNumber(this, '_siblingCount', Math.max(0, value ?? 1));\n\t}\n\n\t@Watch('_total')\n\tpublic validateTotal(value?: number): void {\n\t\tthis.validateMax(value);\n\t}\n\n\t@Watch('_max')\n\tpublic validateMax(value?: MaxPropType): void {\n\t\tvalidateMax(this, value, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: (_nextValue: unknown, nextState: Map<string, unknown>) => {\n\t\t\t\t\tconst page = nextState.has('_page') ? (nextState.get('_page') as number) : this.state._page;\n\t\t\t\t\tconst pageSize = nextState.has('_pageSize') ? (nextState.get('_pageSize') as number) : this.state._pageSize;\n\t\t\t\t\tthis.syncPage(nextState, page, pageSize, _nextValue as number);\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\t}\n\n\t@Watch('_tooltipAlign')\n\tpublic validateTooltipAlign(value?: TooltipAlignPropType): void {\n\t\tvalidateTooltipAlign(this, value);\n\t}\n\n\t@Watch('_variant')\n\tpublic validateVariant(value?: ButtonVariantPropType): void {\n\t\tvalidateButtonVariant(this, value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateBoundaryCount(this._boundaryCount);\n\t\tthis.validateCustomClass(this._customClass);\n\t\tthis.validateHasButtons(this._hasButtons);\n\t\tthis.validateLabel(this._label, undefined, true);\n\t\tthis.validateOn(this._on);\n\t\tthis.validatePage(this._page);\n\t\tthis.validatePageSize(this._pageSize);\n\t\tthis.validatePageSizeOptions(this._pageSizeOptions);\n\t\tthis.validateSiblingCount(this._siblingCount);\n\t\tthis.validateTooltipAlign(this._tooltipAlign);\n\t\tthis.validateMax(this._max || this._total);\n\t\tthis.validateVariant(this._variant);\n\n\t\t/**\n\t\t * Die Seite muss als letztes gesetzt werden, da sonst die Seite\n\t\t * nicht korrekt berechnet wird.\n\t\t */\n\t\tthis.validatePage(this._page);\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tremoveNavLabel(this.state._label);\n\t}\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["validateMax","component","value","options","watchNumber","defaultStyleCss","KolPaginationDefaultStyle0","leftDoubleArrowIcon","left","leftSingleArrow","rightSingleArrowIcon","right","rightDoubleArrowIcon","KolPagination","this","nonce","calcCount","total","pageSize","Math","ceil","getCount","state","_max","_pageSize","onClick","event","page","_on","onChangePage","timeout","setTimeout","clearTimeout","onChangePageSize","parseInt","onGoToFirst","onGoToEnd","onGoBackward","_page","onGoForward","beforePageSize","_nextValue","nextState","has","get","pageSizeOptions","_pageSizeOptions","Array","isArray","length","find","option","undefined","set","syncPage","count","STATE_CHANGE_EVENT","beforePageSizeOptions","nextValue","push","label","translate","placeholders","entries","_boundaryCount","_label","_hasButtons","first","last","next","previous","_siblingCount","_variant","render","ellipsis","pageButtons","from","keys","map","index","getSelectedPageButton","getUnselectedPageButton","h","class","key","Host","KolButtonTag","exportparts","_customClass","_disabled","_icon","_hideLabel","_tooltipAlign","_a","KolSelectTag","_id","_list","onChange","_value","slot","KolButtonWcTag","_ariaCurrent","validateBoundaryCount","max","validateCustomClass","validateLabel","_oldValue","initial","removeNavLabel","addNavLabel","validateHasButtons","watchValidator","Set","hooks","beforePatch","parseJson","e","delete","Object","assign","validateOn","validatePage","validatePageSize","validatePageSizeOptions","watchJsonArrayString","validateSiblingCount","validateTotal","validateTooltipAlign","validateVariant","validateButtonVariant","componentWillLoad","_total","disconnectedCallback"],"sources":["src/types/props/max.ts","src/components/pagination/style.scss?tag=kol-pagination&mode=default&encapsulation=shadow","src/components/pagination/component.tsx"],"sourcesContent":["import type { Generic } from 'adopted-style-sheets';\n\nimport { watchNumber, WatchNumberOptions } from '../../utils/prop.validators';\nimport { RowsPropType } from './rows';\n\n/* types */\nexport type MaxPropType = number;\n\n/**\n * Number of rows of the input element that should be visible at the same time.\n */\nexport type PropMax = {\n\tmax: MaxPropType;\n};\n\n/* validator */\nexport const validateMax = (component: Generic.Element.Component, value?: RowsPropType, options?: WatchNumberOptions): void => {\n\twatchNumber(component, '_max', value, options);\n};\n","@import '../style';\n\n.navigation-list {\n\tlist-style: none;\n}\n\n.separator:before {\n\tcontent: '•••';\n}\n","import { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\nimport { Stringified } from '../../types/common';\nimport { Option } from '../../types/input/types';\nimport { ButtonVariantPropType, validateButtonVariant } from '../../types/props/button-variant';\nimport { CustomClassPropType, validateCustomClass } from '../../types/props/custom-class';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { TooltipAlignPropType, validateTooltipAlign } from '../../types/props/tooltip-align';\nimport { nonce } from '../../utils/dev.utils';\nimport { parseJson, watchJsonArrayString, watchNumber, watchValidator } from '../../utils/prop.validators';\nimport { addNavLabel, removeNavLabel } from '../../utils/unique-nav-labels';\nimport { STATE_CHANGE_EVENT } from '../../utils/validator';\nimport { API, KoliBriPaginationButtonCallbacks, PaginationHasButton, States } from './types';\nimport { MaxPropType, validateMax } from '../../types/props/max';\nimport { KolButtonTag, KolButtonWcTag, KolSelectTag } from '../../core/component-names';\n\nconst leftDoubleArrowIcon = {\n\tleft: 'codicon codicon-debug-reverse-continue',\n};\nconst leftSingleArrow = {\n\tleft: 'codicon codicon-chevron-left',\n};\nconst rightSingleArrowIcon = {\n\tright: 'codicon codicon-chevron-right',\n};\nconst rightDoubleArrowIcon = {\n\tright: 'codicon codicon-debug-continue',\n};\n\n@Component({\n\ttag: 'kol-pagination',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolPagination implements API {\n\tprivate readonly nonce = nonce();\n\n\tprivate readonly calcCount = (total: number, pageSize = 1): number => Math.ceil(total / pageSize);\n\n\tprivate readonly getCount = (): number => this.calcCount(this.state._max, this.state._pageSize);\n\n\tpublic render(): JSX.Element {\n\t\tlet ellipsis = false;\n\t\tconst count = this.getCount();\n\t\tconst pageButtons = Array.from(Array(count).keys())\n\t\t\t.map((index: number) => index + 1)\n\t\t\t.map((page: number) => {\n\t\t\t\tif (\n\t\t\t\t\tpage <= this.state._boundaryCount ||\n\t\t\t\t\tpage > count - this.state._boundaryCount ||\n\t\t\t\t\t(page >= this.state._page - this.state._siblingCount && page <= this.state._page + this.state._siblingCount)\n\t\t\t\t) {\n\t\t\t\t\tellipsis = true;\n\t\t\t\t\tif (this.state._page === page) {\n\t\t\t\t\t\treturn this.getSelectedPageButton(page);\n\t\t\t\t\t} else {\n\t\t\t\t\t\treturn this.getUnselectedPageButton(page);\n\t\t\t\t\t}\n\t\t\t\t} else if (ellipsis === true) {\n\t\t\t\t\tellipsis = false;\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t<span class=\"separator\" key={`${this.nonce}-el-${page}`} aria-hidden=\"true\"></span>\n\t\t\t\t\t\t</li>\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\treturn null;\n\t\t\t\t}\n\t\t\t});\n\n\t\treturn (\n\t\t\t<Host class=\"kol-pagination\">\n\t\t\t\t<nav aria-label={this.state._label}>\n\t\t\t\t\t<ul class=\"navigation-list\">\n\t\t\t\t\t\t{this.state._hasButtons.first && (\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<KolButtonTag\n\t\t\t\t\t\t\t\t\tclass=\"first\"\n\t\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t\t\t\t\t_disabled={this.state._page <= 1}\n\t\t\t\t\t\t\t\t\t_icon={leftDoubleArrowIcon}\n\t\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t\t_label={translate('kol-page-first')}\n\t\t\t\t\t\t\t\t\t_on={this.onGoToFirst}\n\t\t\t\t\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t\t\t\t\t\t_tooltipAlign={this.state._tooltipAlign}\n\t\t\t\t\t\t\t\t></KolButtonTag>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t{this.state._hasButtons.previous && (\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<KolButtonTag\n\t\t\t\t\t\t\t\t\tclass=\"previous\"\n\t\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t\t\t\t\t_disabled={this.state._page <= 1}\n\t\t\t\t\t\t\t\t\t_icon={leftSingleArrow}\n\t\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t\t_label={translate('kol-page-back')}\n\t\t\t\t\t\t\t\t\t_on={this.onGoBackward}\n\t\t\t\t\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t\t\t\t\t\t_tooltipAlign={this.state._tooltipAlign}\n\t\t\t\t\t\t\t\t></KolButtonTag>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t{pageButtons}\n\t\t\t\t\t\t{this.state._hasButtons.next && (\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<KolButtonTag\n\t\t\t\t\t\t\t\t\tclass=\"next\"\n\t\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t\t\t\t\t_disabled={count <= this.state._page}\n\t\t\t\t\t\t\t\t\t_icon={rightSingleArrowIcon}\n\t\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t\t_label={translate('kol-page-next')}\n\t\t\t\t\t\t\t\t\t_on={this.onGoForward}\n\t\t\t\t\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t\t\t\t\t\t_tooltipAlign={this.state._tooltipAlign}\n\t\t\t\t\t\t\t\t></KolButtonTag>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t{this.state._hasButtons.last && (\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<KolButtonTag\n\t\t\t\t\t\t\t\t\tclass=\"last\"\n\t\t\t\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t\t\t\t\t_disabled={count <= this.state._page}\n\t\t\t\t\t\t\t\t\t_icon={rightDoubleArrowIcon}\n\t\t\t\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t\t\t\t_label={translate('kol-page-last')}\n\t\t\t\t\t\t\t\t\t_on={this.onGoToEnd}\n\t\t\t\t\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t\t\t\t\t\t_tooltipAlign={this.state._tooltipAlign}\n\t\t\t\t\t\t\t\t></KolButtonTag>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</ul>\n\t\t\t\t</nav>\n\t\t\t\t{this.state._pageSizeOptions?.length > 0 && (\n\t\t\t\t\t<KolSelectTag\n\t\t\t\t\t\t_hideLabel\n\t\t\t\t\t\t_id={`pagination-size-${this.nonce}`}\n\t\t\t\t\t\t_label={translate('kol-entries-per-site')}\n\t\t\t\t\t\t_list={this.state._pageSizeOptions}\n\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\tonChange: this.onChangePageSize,\n\t\t\t\t\t\t}}\n\t\t\t\t\t\t_value={[this.state._pageSize]}\n\t\t\t\t\t></KolSelectTag>\n\t\t\t\t)}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Defines the amount of pages to show next to the outer arrow buttons.\n\t */\n\t@Prop() public _boundaryCount?: number = 1;\n\n\t/**\n\t * Defines the custom class attribute if _variant=\"custom\" is set.\n\t */\n\t@Prop() public _customClass?: CustomClassPropType;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label?: LabelPropType;\n\n\t/**\n\t * Defines which navigation buttons to render (first, last, next, previous buttons).\n\t */\n\t@Prop() public _hasButtons?: boolean | Stringified<PaginationHasButton> = true;\n\n\t/**\n\t * Defines the current page.\n\t */\n\t@Prop() public _page!: number;\n\n\t/**\n\t * Defines the amount of entries to show per page.\n\t */\n\t@Prop({ mutable: true, reflect: false }) public _pageSize = 1;\n\n\t/**\n\t * Defines the options for the page-size-select.\n\t */\n\t@Prop() public _pageSizeOptions: Stringified<number[]> = [];\n\n\t/**\n\t * Gibt an, auf welche Callback-Events reagiert werden.\n\t */\n\t@Prop() public _on!: KoliBriPaginationButtonCallbacks;\n\n\t/**\n\t * Defines the amount of pages to show next to the current page.\n\t */\n\t@Prop() public _siblingCount?: number = 1;\n\n\t/**\n\t * Defines where to show the Tooltip preferably: top, right, bottom or left.\n\t */\n\t@Prop() public _tooltipAlign?: TooltipAlignPropType = 'top';\n\n\t/**\n\t * Setzt die Gesamtanzahl der Seiten.\n\t * @deprecated Use _max.\n\t */\n\t@Prop() public _total?: number;\n\n\t/**\n\t * Defines the maximum number of pages.\n\t */\n\t@Prop() public _max?: MaxPropType;\n\n\t/**\n\t * Defines which variant should be used for presentation.\n\t */\n\t@Prop() public _variant?: ButtonVariantPropType = 'normal';\n\n\t@State() public state: States = {\n\t\t_boundaryCount: 1,\n\t\t_label: translate('kol-pagination'),\n\t\t_hasButtons: {\n\t\t\tfirst: true,\n\t\t\tlast: true,\n\t\t\tnext: true,\n\t\t\tprevious: true,\n\t\t},\n\t\t_on: {\n\t\t\tonClick: () => null,\n\t\t},\n\t\t_page: 0,\n\t\t_pageSize: 1,\n\t\t_pageSizeOptions: [],\n\t\t_siblingCount: 1,\n\t\t_max: 0,\n\t\t_variant: 'normal',\n\t};\n\n\tprivate onClick = (event: Event, page: number) => {\n\t\tif (typeof this.state._on.onClick === 'function') {\n\t\t\tthis.state._on.onClick(event, page);\n\t\t}\n\t\tthis.onChangePage(event, page);\n\t};\n\n\tprivate onChangePage = (event: Event, page: number) => {\n\t\tconst timeout = setTimeout(() => {\n\t\t\tclearTimeout(timeout);\n\t\t\tif (typeof this.state._on.onChangePage === 'function') {\n\t\t\t\tthis.state._on.onChangePage(event, page);\n\t\t\t}\n\t\t});\n\t};\n\n\tprivate onChangePageSize = (event: Event, value: unknown) => {\n\t\tvalue = parseInt((value as string[])[0]);\n\t\tif (typeof value === 'number' && value > 0 && this._pageSize !== value) {\n\t\t\tthis._pageSize = value;\n\t\t\tconst timeout = setTimeout(() => {\n\t\t\t\tclearTimeout(timeout);\n\t\t\t\tif (typeof this.state._on.onChangePageSize === 'function') {\n\t\t\t\t\tthis.state._on.onChangePageSize(event, this._pageSize);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t};\n\n\tprivate readonly onGoToFirst = {\n\t\tonClick: (event: Event) => {\n\t\t\tthis.onClick(event, 1);\n\t\t},\n\t};\n\tprivate readonly onGoToEnd = {\n\t\tonClick: (event: Event) => {\n\t\t\tthis.onClick(event, this.getCount());\n\t\t},\n\t};\n\tprivate readonly onGoBackward = {\n\t\tonClick: (event: Event) => {\n\t\t\tthis.onClick(event, this.state._page - 1);\n\t\t},\n\t};\n\tprivate readonly onGoForward = {\n\t\tonClick: (event: Event) => {\n\t\t\tthis.onClick(event, this.state._page + 1);\n\t\t},\n\t};\n\n\tprivate getUnselectedPageButton(page: number): JSX.Element {\n\t\treturn (\n\t\t\t<li key={`${this.nonce}-${page}`}>\n\t\t\t\t<KolButtonTag\n\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t_customClass={this.state._customClass}\n\t\t\t\t\t_label=\"\"\n\t\t\t\t\t_on={{\n\t\t\t\t\t\tonClick: (event: Event) => {\n\t\t\t\t\t\t\tthis.onClick(event, page);\n\t\t\t\t\t\t},\n\t\t\t\t\t}}\n\t\t\t\t\t_variant={this.state._variant}\n\t\t\t\t>\n\t\t\t\t\t<span slot=\"expert\">\n\t\t\t\t\t\t<span class=\"visually-hidden\">{translate('kol-page')}</span> {page}\n\t\t\t\t\t</span>\n\t\t\t\t</KolButtonTag>\n\t\t\t</li>\n\t\t);\n\t}\n\n\tprivate getSelectedPageButton(page: number): JSX.Element {\n\t\treturn (\n\t\t\t<li key={`${this.nonce}-selected`}>\n\t\t\t\t<KolButtonWcTag class=\"selected\" _customClass={this.state._customClass} _disabled={true} _ariaCurrent={true} _label=\"\" _variant={this.state._variant}>\n\t\t\t\t\t<span slot=\"expert\">\n\t\t\t\t\t\t<span class=\"visually-hidden\">{translate('kol-page')}</span> {page}\n\t\t\t\t\t</span>\n\t\t\t\t</KolButtonWcTag>\n\t\t\t</li>\n\t\t);\n\t}\n\n\t@Watch('_boundaryCount')\n\tpublic validateBoundaryCount(value?: number): void {\n\t\twatchNumber(this, '_boundaryCount', Math.max(0, value ?? 1));\n\t}\n\n\t@Watch('_customClass')\n\tpublic validateCustomClass(value?: CustomClassPropType): void {\n\t\tvalidateCustomClass(this, value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(label?: LabelPropType, _oldValue?: LabelPropType, initial = false) {\n\t\tif (!initial) {\n\t\t\tremoveNavLabel(this.state._label);\n\t\t}\n\t\tvalidateLabel(this, label);\n\t\taddNavLabel(this.state._label); // add the state instead of prop, because the prop could be invalid and not set as new label\n\t}\n\n\t@Watch('_hasButtons')\n\tpublic validateHasButtons(value?: string | boolean | Stringified<PaginationHasButton>): void {\n\t\twatchValidator(\n\t\t\tthis,\n\t\t\t'_hasButtons',\n\t\t\t(value) => typeof value === 'boolean' || typeof value === 'string' || (typeof value === 'object' && value !== null),\n\t\t\tnew Set(['Boolean', 'PaginationHasButton']),\n\t\t\tvalue,\n\t\t\t{\n\t\t\t\thooks: {\n\t\t\t\t\tbeforePatch: (nextValue: unknown, nextState: Map<string, unknown>) => {\n\t\t\t\t\t\tif (typeof nextValue === 'boolean') {\n\t\t\t\t\t\t\tnextState.set('_hasButtons', {\n\t\t\t\t\t\t\t\tfirst: nextValue,\n\t\t\t\t\t\t\t\tlast: nextValue,\n\t\t\t\t\t\t\t\tnext: nextValue,\n\t\t\t\t\t\t\t\tprevious: nextValue,\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tif (typeof nextValue === 'string') {\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tnextValue = parseJson<PaginationHasButton>(nextValue);\n\t\t\t\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t\t\t\tnextState.delete('_hasButtons');\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\tif (typeof nextValue === 'object' && nextValue !== null) {\n\t\t\t\t\t\t\t\tnextState.set('_hasButtons', {\n\t\t\t\t\t\t\t\t\t...this.state._hasButtons,\n\t\t\t\t\t\t\t\t\tfirst:\n\t\t\t\t\t\t\t\t\t\ttypeof (nextValue as PaginationHasButton).first === 'boolean'\n\t\t\t\t\t\t\t\t\t\t\t? (nextValue as PaginationHasButton).first === true\n\t\t\t\t\t\t\t\t\t\t\t: this.state._hasButtons.first,\n\t\t\t\t\t\t\t\t\tlast:\n\t\t\t\t\t\t\t\t\t\ttypeof (nextValue as PaginationHasButton).last === 'boolean'\n\t\t\t\t\t\t\t\t\t\t\t? (nextValue as PaginationHasButton).last === true\n\t\t\t\t\t\t\t\t\t\t\t: this.state._hasButtons.last,\n\t\t\t\t\t\t\t\t\tnext:\n\t\t\t\t\t\t\t\t\t\ttypeof (nextValue as PaginationHasButton).next === 'boolean'\n\t\t\t\t\t\t\t\t\t\t\t? (nextValue as PaginationHasButton).next === true\n\t\t\t\t\t\t\t\t\t\t\t: this.state._hasButtons.next,\n\t\t\t\t\t\t\t\t\tprevious:\n\t\t\t\t\t\t\t\t\t\ttypeof (nextValue as PaginationHasButton).previous === 'boolean'\n\t\t\t\t\t\t\t\t\t\t\t? (nextValue as PaginationHasButton).previous === true\n\t\t\t\t\t\t\t\t\t\t\t: this.state._hasButtons.previous,\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('_on')\n\tpublic validateOn(value?: KoliBriPaginationButtonCallbacks): void {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tthis.state = {\n\t\t\t\t...this.state,\n\t\t\t\t_on: value,\n\t\t\t};\n\t\t}\n\t}\n\n\t@Watch('_page')\n\tpublic validatePage(value?: number): void {\n\t\twatchNumber(this, '_page', value, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: (_nextValue: unknown, nextState: Map<string, unknown>) => {\n\t\t\t\t\tconst pageSize = nextState.has('_pageSize') ? (nextState.get('_pageSize') as number) : this.state._pageSize;\n\t\t\t\t\tconst total = nextState.has('_max') ? (nextState.get('_max') as number) : this.state._max;\n\t\t\t\t\tthis.syncPage(nextState, _nextValue as number, pageSize, total);\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\t}\n\n\tprivate beforePageSize = (_nextValue: unknown, nextState: Map<string, unknown>) => {\n\t\tlet pageSize = nextState.has('_pageSize') ? (nextState.get('_pageSize') as number) : this.state._pageSize;\n\t\tconst pageSizeOptions = nextState.has('_pageSizeOptions') ? (nextState.get('_pageSizeOptions') as Option<number>[]) : this.state._pageSizeOptions;\n\t\tif (Array.isArray(pageSizeOptions) && pageSizeOptions.length > 0) {\n\t\t\tconst find = pageSizeOptions.find((option) => option.value === pageSize);\n\t\t\tif (find === undefined) {\n\t\t\t\tpageSize = pageSizeOptions[0].value;\n\t\t\t} else {\n\t\t\t\tpageSize = find.value;\n\t\t\t}\n\t\t\tnextState.set('_pageSize', pageSize);\n\t\t}\n\t\tconst page = nextState.has('_page') ? (nextState.get('_page') as number) : this.state._page;\n\t\tconst total = nextState.has('_max') ? (nextState.get('_max') as number) : this.state._max;\n\t\tthis.syncPage(nextState, page, nextState.get('_pageSize') as number, total);\n\t};\n\n\tprivate syncPage = (nextState: Map<string, unknown>, page: number, pageSize: number, total: number) => {\n\t\t// count === 0 means no data\n\t\tif (total > 0) {\n\t\t\tconst count = this.calcCount(total, pageSize);\n\t\t\tif (count > 0) {\n\t\t\t\tif (page > count) {\n\t\t\t\t\tnextState.set('_page', count);\n\t\t\t\t\tthis.onChangePage(STATE_CHANGE_EVENT, count);\n\t\t\t\t} else if (page < 1) {\n\t\t\t\t\tnextState.set('_page', 1);\n\t\t\t\t\tthis.onChangePage(STATE_CHANGE_EVENT, 1);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n\n\tprivate beforePageSizeOptions = (nextValue: unknown, nextState: Map<string, unknown>) => {\n\t\tconst options: Option<number>[] = [];\n\t\tif (Array.isArray(nextValue)) {\n\t\t\tfor (const value of nextValue) {\n\t\t\t\tif (typeof value === 'number') {\n\t\t\t\t\toptions.push({\n\t\t\t\t\t\tlabel: translate('kol-page-per-site', { placeholders: { entries: `${value}` } }),\n\t\t\t\t\t\tvalue: value,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tnextState.set('_pageSizeOptions', options);\n\t\tthis.beforePageSize(options, nextState);\n\t};\n\n\t@Watch('_pageSize')\n\tpublic validatePageSize(value?: number): void {\n\t\twatchNumber(this, '_pageSize', value, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: this.beforePageSize,\n\t\t\t},\n\t\t});\n\t}\n\n\t@Watch('_pageSizeOptions')\n\tpublic validatePageSizeOptions(value?: Stringified<number[]>): void {\n\t\twatchJsonArrayString(this, '_pageSizeOptions', (value) => typeof value === 'number', value, undefined, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: this.beforePageSizeOptions,\n\t\t\t},\n\t\t});\n\t}\n\n\t@Watch('_siblingCount')\n\tpublic validateSiblingCount(value?: number): void {\n\t\twatchNumber(this, '_siblingCount', Math.max(0, value ?? 1));\n\t}\n\n\t@Watch('_total')\n\tpublic validateTotal(value?: number): void {\n\t\tthis.validateMax(value);\n\t}\n\n\t@Watch('_max')\n\tpublic validateMax(value?: MaxPropType): void {\n\t\tvalidateMax(this, value, {\n\t\t\thooks: {\n\t\t\t\tbeforePatch: (_nextValue: unknown, nextState: Map<string, unknown>) => {\n\t\t\t\t\tconst page = nextState.has('_page') ? (nextState.get('_page') as number) : this.state._page;\n\t\t\t\t\tconst pageSize = nextState.has('_pageSize') ? (nextState.get('_pageSize') as number) : this.state._pageSize;\n\t\t\t\t\tthis.syncPage(nextState, page, pageSize, _nextValue as number);\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\t}\n\n\t@Watch('_tooltipAlign')\n\tpublic validateTooltipAlign(value?: TooltipAlignPropType): void {\n\t\tvalidateTooltipAlign(this, value);\n\t}\n\n\t@Watch('_variant')\n\tpublic validateVariant(value?: ButtonVariantPropType): void {\n\t\tvalidateButtonVariant(this, value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateBoundaryCount(this._boundaryCount);\n\t\tthis.validateCustomClass(this._customClass);\n\t\tthis.validateHasButtons(this._hasButtons);\n\t\tthis.validateLabel(this._label, undefined, true);\n\t\tthis.validateOn(this._on);\n\t\tthis.validatePage(this._page);\n\t\tthis.validatePageSize(this._pageSize);\n\t\tthis.validatePageSizeOptions(this._pageSizeOptions);\n\t\tthis.validateSiblingCount(this._siblingCount);\n\t\tthis.validateTooltipAlign(this._tooltipAlign);\n\t\tthis.validateMax(this._max || this._total);\n\t\tthis.validateVariant(this._variant);\n\n\t\t/**\n\t\t * Die Seite muss als letztes gesetzt werden, da sonst die Seite\n\t\t * nicht korrekt berechnet wird.\n\t\t */\n\t\tthis.validatePage(this._page);\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tremoveNavLabel(this.state._label);\n\t}\n}\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{r as i,h as t,H as s}from"./index-a051748e.js";import{o,f as e,s as a,a as n,c as h}from"./floating-ui.dom.esm-d8551a17.js";import{v as r}from"./align-beb00370.js";import{v as p}from"./show-418f2510.js";import{g as l}from"./dev.utils-f829063f.js";import{p as c}from"./reuse-d79ab469.js";import"./alignment-4c0cd265.js";import"./prop.validators-3017e14b.js";import"./index-117bd1aa.js";import"./a11y.tipps-798efb1a.js";const d=":host{--a11y-min-size:44px;background-color:white;color:black;font-family:Verdana}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role=button],button:not([role=link]),.kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}[hidden]{display:none !important}:host{max-width:100%}*{box-sizing:border-box}.kol-span-wc{display:grid;place-items:center}.kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}.icon-only>.kol-span-wc>span>span{display:none}.hidden{display:none;visibility:hidden}.kol-popover{height:0;position:absolute}.kol-popover .popover{background-color:#fff;min-height:max-content;min-width:max-content;opacity:0;position:absolute}.kol-popover .show{animation:0.3s ease-in forwards fadeInOpacity}.kol-popover .disappear{animation:0.3s ease-in backwards fadeInOpacity}.kol-popover .arrow{background-color:inherit;height:var(--font-size);position:absolute;rotate:0.125turn;width:var(--font-size);z-index:-1}@keyframes fadeInOpacity{0%{opacity:0}100%{opacity:1}}",f=d,b=class{constructor(t){i(this,t),this.alignPopover=t=>{setTimeout((()=>{var i;if("test"!==c&&this.triggerElement&&this.popoverElement){const s=this.triggerElement,r=this.popoverElement,l=this.arrowElement,p=[o(null!==(i=null==l?void 0:l.offsetHeight)&&void 0!==i?i:10),e(),a()];l&&p.push(n({element:l})),h(s,r,{placement:this.state._align,middleware:p}).then((({x:e,y:i,middlewareData:o,placement:s})=>{this.setPosition(e,i,o,s,t)}))}}))},this.showPopover=()=>{this.addListenersToBody(),this.alignPopover((()=>{this.state=Object.assign(Object.assign({},this.state),{_visible:!0})}))},this.hidePopoverByEscape=e=>{"Escape"===e.key&&this.hidePopover()},this.hidePopoverByClickOutside=e=>{this.host&&!this.host.contains(e.target)&&this.hidePopover()},this.catchHostAndTriggerElement=e=>{e&&(this.host=e,this.triggerElement=e.previousElementSibling)},this.catchPopoverElement=e=>{this.popoverElement=e},this.catchArrowElement=e=>{this.arrowElement=e},this._align="top",this._show=!1,this.state={_align:"top",_show:!1,_visible:!1}}setPosition(e,t,i,o,s){if(this.popoverElement){const a={left:this.popoverElement.style.left,top:this.popoverElement.style.top};if(Object.assign(this.popoverElement.style,{left:`${e}px`,top:`${t}px`}),this.arrowElement&&i.arrow)switch(o){case"top":this.arrowElement.style.inset=`100% auto auto ${i.arrow.x||0}px`,this.arrowElement.style.translate="0 -50%";break;case"right":this.arrowElement.style.inset=`${i.arrow.y||0}px 100% auto auto`,this.arrowElement.style.translate="50% 0";break;case"bottom":this.arrowElement.style.inset=`auto auto 100% ${i.arrow.x||0}px`,this.arrowElement.style.translate="0 50%";break;case"left":this.arrowElement.style.inset=`${i.arrow.y||0}px auto auto 100%`,this.arrowElement.style.translate="-50% 0"}a.left!==this.popoverElement.style.left||a.top!==this.popoverElement.style.top?this.alignPopover(s):"function"==typeof s&&s()}}hidePopover(){var e;this.state=Object.assign(Object.assign({},this.state),{_visible:!1}),this._show=!1,null===(e=this.triggerElement)||void 0===e||e.focus(),this.removeListenersToBody()}addListenersToBody(){var e;const t=l().body;t.addEventListener("keyup",this.hidePopoverByEscape),t.addEventListener("click",this.hidePopoverByClickOutside),null===(e=document.scrollingElement)||void 0===e||e.addEventListener("scroll",this.showPopover,{passive:!0})}removeListenersToBody(){var e;const t=l().body;t.removeEventListener("keyup",this.hidePopoverByEscape),t.removeEventListener("click",this.hidePopoverByClickOutside),null===(e=document.scrollingElement)||void 0===e||e.removeEventListener("scroll",this.showPopover)}render(){return t(s,{key:"d5c65c61cb64e0f597fcfa79bd6f3951ebae5d1b",ref:this.catchHostAndTriggerElement,class:"kol-popover-wc"},t("div",{key:"3e58c54f05c7781ac54ae1ff0be0af3eb842a7b5",class:{popover:!0,hidden:!this.state._show,show:this.state._visible},ref:this.catchPopoverElement},t("div",{key:"cf15e6cc22f5808bfba26a5584c25c44fdf16e18",class:`arrow ${this.state._align}`,ref:this.catchArrowElement}),t("slot",{key:"5747244f3908f76f236eb9633d2fc048aa4b8249"})))}validateAlign(e){r(this,e)}validateShow(e){p(this,e),e&&this.showPopover()}componentWillLoad(){this.validateAlign(this._align),this.validateShow(this._show)}static get watchers(){return{_align:["validateAlign"],_show:["validateShow"]}}};b.style=f;export{b as kol_popover_wc};
4
+ import{r as i,h as t,H as s}from"./index-dfb131c4.js";import{o,f as e,s as a,a as n,c as h}from"./floating-ui.dom.esm-d8551a17.js";import{v as r}from"./align-4bf3b7ec.js";import{v as p}from"./show-fbf4d497.js";import{g as d}from"./dev.utils-1e8dd4a9.js";import{p as l}from"./reuse-d79ab469.js";import"./alignment-7c2e01fd.js";import"./prop.validators-a62aac63.js";import"./index-117bd1aa.js";import"./a11y.tipps-477c41d6.js";const c=":host{--a11y-min-size:44px;background-color:white;color:black;font-family:Verdana}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role=button],button:not([role=link]),.kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}[hidden]{display:none !important}:host{max-width:100%}*{box-sizing:border-box}.kol-span-wc{display:grid;place-items:center}.kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}.icon-only>.kol-span-wc>span>span{display:none}.hidden{display:none;visibility:hidden}.kol-popover{height:0;position:absolute}.kol-popover .popover{background-color:#fff;min-height:max-content;min-width:max-content;opacity:0;position:absolute}.kol-popover .show{animation:0.3s ease-in forwards fadeInOpacity}.kol-popover .disappear{animation:0.3s ease-in backwards fadeInOpacity}.kol-popover .arrow{background-color:inherit;height:var(--font-size);position:absolute;rotate:0.125turn;width:var(--font-size);z-index:-1}@keyframes fadeInOpacity{0%{opacity:0}100%{opacity:1}}",f=c,b=class{constructor(t){i(this,t),this.alignPopover=t=>{setTimeout((()=>{var i;if("test"!==l&&this.triggerElement&&this.popoverElement){const s=this.triggerElement,r=this.popoverElement,l=this.arrowElement,p=[o(null!==(i=null==l?void 0:l.offsetHeight)&&void 0!==i?i:10),e(),a()];l&&p.push(n({element:l})),h(s,r,{placement:this.state._align,middleware:p}).then((({x:e,y:i,middlewareData:o,placement:s})=>{this.setPosition(e,i,o,s,t)}))}}))},this.showPopover=()=>{this.addListenersToBody(),this.alignPopover((()=>{this.state=Object.assign(Object.assign({},this.state),{_visible:!0})}))},this.hidePopoverByEscape=e=>{"Escape"===e.key&&this.hidePopover()},this.hidePopoverByClickOutside=e=>{this.host&&!this.host.contains(e.target)&&this.hidePopover()},this.catchHostAndTriggerElement=e=>{e&&(this.host=e,this.triggerElement=e.previousElementSibling)},this.catchPopoverElement=e=>{this.popoverElement=e},this.catchArrowElement=e=>{this.arrowElement=e},this._align="top",this._show=!1,this.state={_align:"top",_show:!1,_visible:!1}}setPosition(e,t,i,o,s){if(this.popoverElement){const a={left:this.popoverElement.style.left,top:this.popoverElement.style.top};if(Object.assign(this.popoverElement.style,{left:`${e}px`,top:`${t}px`}),this.arrowElement&&i.arrow)switch(o){case"top":this.arrowElement.style.inset=`100% auto auto ${i.arrow.x||0}px`,this.arrowElement.style.translate="0 -50%";break;case"right":this.arrowElement.style.inset=`${i.arrow.y||0}px 100% auto auto`,this.arrowElement.style.translate="50% 0";break;case"bottom":this.arrowElement.style.inset=`auto auto 100% ${i.arrow.x||0}px`,this.arrowElement.style.translate="0 50%";break;case"left":this.arrowElement.style.inset=`${i.arrow.y||0}px auto auto 100%`,this.arrowElement.style.translate="-50% 0"}a.left!==this.popoverElement.style.left||a.top!==this.popoverElement.style.top?this.alignPopover(s):"function"==typeof s&&s()}}hidePopover(){var e;this.state=Object.assign(Object.assign({},this.state),{_visible:!1}),this._show=!1,null===(e=this.triggerElement)||void 0===e||e.focus(),this.removeListenersToBody()}addListenersToBody(){var e;const t=d().body;t.addEventListener("keyup",this.hidePopoverByEscape),t.addEventListener("click",this.hidePopoverByClickOutside),null===(e=document.scrollingElement)||void 0===e||e.addEventListener("scroll",this.showPopover,{passive:!0})}removeListenersToBody(){var e;const t=d().body;t.removeEventListener("keyup",this.hidePopoverByEscape),t.removeEventListener("click",this.hidePopoverByClickOutside),null===(e=document.scrollingElement)||void 0===e||e.removeEventListener("scroll",this.showPopover)}render(){return t(s,{key:"8e23df026b2c5b42e397a35baf6d76df8be1c6e1",ref:this.catchHostAndTriggerElement,class:"kol-popover-wc"},t("div",{key:"e303984c79d1ab2d183aa30aaba27cbaba71e7eb",class:{popover:!0,hidden:!this.state._show,show:this.state._visible},ref:this.catchPopoverElement},t("div",{key:"62f97bf8492ba03054bdcf4e355e36af7b47a2b1",class:`arrow ${this.state._align}`,ref:this.catchArrowElement}),t("slot",{key:"02e2cfd49d178e08a3baf38d3c6f5dda33a62e08"})))}validateAlign(e){r(this,e)}validateShow(e){p(this,e),e&&this.showPopover()}componentWillLoad(){this.validateAlign(this._align),this.validateShow(this._show)}static get watchers(){return{_align:["validateAlign"],_show:["validateShow"]}}};b.style=f;export{b as kol_popover_wc};
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{r as e,h as t,H as r}from"./index-a051748e.js";import{v as i}from"./label-bce4f328.js";import{e as a,d as s,w as l}from"./prop.validators-3017e14b.js";import"./a11y.tipps-798efb1a.js";import"./dev.utils-f829063f.js";import"./reuse-d79ab469.js";import"./index-117bd1aa.js";var o;!function(t){t.bar="bar",t.cycle="cycle",t["cycle-value-label"]="cycle-value-label",t["cycle-label-value"]="cycle-label-value"}(o||(o={}));const n=":host{--a11y-min-size:44px;background-color:white;color:black;font-family:Verdana}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role=button],button:not([role=link]),.kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}[hidden]{display:none !important}:host{max-width:100%}*{box-sizing:border-box}.kol-span-wc{display:grid;place-items:center}.kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}.icon-only>.kol-span-wc>span>span{display:none}.hidden{display:none;visibility:hidden}progress{display:block;height:0;overflow:hidden;width:0}.bar .border{fill:transparent;stroke:black}.bar .background{fill:lightgray;stroke:white}.bar .progress{fill:#0075ff;stroke:transparent;transition:250ms ease-in-out 50ms}.cycle .background{fill:transparent;stroke:lightgray}.cycle .border{fill:transparent;stroke:black}.cycle .whitespace{fill:transparent;stroke:white}.cycle .progress{fill:transparent;stroke:#0075ff;transform-origin:50% 50%;transform:rotate(-90deg);transition:250ms ease-in-out 50ms}@media (prefers-reduced-motion){.progress{transition-duration:0s;transition-delay:0s}}",c=n,d=Object.keys(o),h=e=>{let a="43%",r=e._label?"57%":"50%";switch(e._variant){case"cycle-value-label":e._label&&(a="57%",r="43%");case"cycle":case"cycle-label-value":return t("svg",{class:"cycle",width:"100",viewBox:"0 0 120 120",xmlns:"http://www.w3.org/2000/svg"},t("circle",{class:"background",cx:"60",cy:"60",r:"54.5",fill:"currentColor",stroke:"currentColor","stroke-width":"8"}),t("circle",{class:"whitespace",cx:"60",cy:"60",r:"59",fill:"currentColor",stroke:"currentColor","stroke-width":"3"}),t("circle",{class:"border",cx:"60",cy:"60",r:"59",fill:"currentColor",stroke:"currentColor","stroke-width":"1"}),t("circle",{class:"whitespace",cx:"60",cy:"60",r:"51",fill:"currentColor",stroke:"currentColor","stroke-width":"1"}),t("circle",{class:"border",cx:"60",cy:"60",r:"50",fill:"currentColor",stroke:"currentColor","stroke-width":"1"}),t("circle",{class:"progress",fill:"currentColor",stroke:"currentColor","stroke-linecap":"round","stroke-dasharray":`${Math.round(e._value/e._max*342)}px 342px`,"stroke-width":"6",cx:"60",cy:"60",r:"54.5"}),e._label&&t("text",{"aria-hidden":"true",x:"50%",y:a,"text-anchor":"middle",fill:"currentColor"},e._label),t("text",{"aria-hidden":"true",x:"50%",y:r,"text-anchor":"middle",fill:"currentColor"},e._value,e._unit));default:return t("div",{class:"bar"},e._label&&t("div",null,e._label),t("div",{style:{display:"flex",gap:"0.3em"}},t("svg",{width:"100",viewBox:"0 0 102 8",xmlns:"http://www.w3.org/2000/svg"},t("rect",{class:"background",x:"1",y:"1",height:"10",rx:"5",fill:"currentColor",stroke:"currentColor","stroke-width":"3",width:"100"}),t("rect",{class:"progress",x:"2.5",y:"2.5",height:"7",rx:"3.5",fill:"currentColor",stroke:"currentColor","stroke-width":"3",width:e._value/e._max*95}),t("rect",{class:"border",x:"1",y:"1",height:"10",rx:"5",fill:"currentColor",stroke:"currentColor","stroke-width":"1",width:"100"})),t("text",{"aria-hidden":"true","text-anchor":"middle","dominant-baseline":"central",fill:"currentColor"},e._value,e._unit)))}},u=class{constructor(t){e(this,t),this._label=void 0,this._max=void 0,this._type=void 0,this._unit="%",this._value=void 0,this._variant=void 0,this.state={_max:100,_unit:"%",_value:0,_variant:"bar",_liveValue:0}}render(){return t(r,{key:"9a3251b27cf8b482660b5e62327333932813c062",class:"kol-progress"},h(this.state),t("progress",{key:"7acb30ddc705b0658dde62c8107331ed0dc125e7","aria-busy":this.state._value<this.state._max?"true":"false",max:this.state._max,value:this.state._value}),t("span",{key:"7985170fa0f249292a6b5bdff22a927bdc66f340","aria-live":"polite","aria-relevant":"removals text",hidden:!0},this.state._liveValue," von ",this.state._max," ",this.state._unit))}validateLabel(t){i(this,t)}validateMax(t){"number"!=typeof t&&(t=100),a(this,"_max",t,{required:!0})}validateType(t){this.validateVariant(t)}validateUnit(t){s(this,"_unit",t)}validateValue(t){"number"!=typeof t&&(t=0),a(this,"_value",t,{required:!0})}validateVariant(t){l(this,"_variant",(t=>"string"==typeof t&&d.includes(t)),new Set(d),t)}componentWillLoad(){this.validateLabel(this._label),this.validateMax(this._max),this.validateUnit(this._unit),this.validateValue(this._value),this.validateVariant(this._variant||this._type),this.interval=setInterval((()=>{this.state._liveValue!==this.state._value&&(this.state=Object.assign(Object.assign({},this.state),{_liveValue:this.state._value}))}),5e3)}disconnectedCallback(){clearInterval(this.interval)}static get watchers(){return{_label:["validateLabel"],_max:["validateMax"],_type:["validateType"],_unit:["validateUnit"],_value:["validateValue"],_variant:["validateVariant"]}}};u.style={default:c};export{u as kol_progress};
4
+ import{r as e,h as t,H as r}from"./index-dfb131c4.js";import{v as i}from"./label-48b51f80.js";import{e as a,d as s,w as l}from"./prop.validators-a62aac63.js";import"./a11y.tipps-477c41d6.js";import"./dev.utils-1e8dd4a9.js";import"./reuse-d79ab469.js";import"./index-117bd1aa.js";var o;!function(t){t.bar="bar",t.cycle="cycle",t["cycle-value-label"]="cycle-value-label",t["cycle-label-value"]="cycle-label-value"}(o||(o={}));const n=":host{--a11y-min-size:44px;background-color:white;color:black;font-family:Verdana}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role=button],button:not([role=link]),.kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}[hidden]{display:none !important}:host{max-width:100%}*{box-sizing:border-box}.kol-span-wc{display:grid;place-items:center}.kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}.icon-only>.kol-span-wc>span>span{display:none}.hidden{display:none;visibility:hidden}progress{display:block;height:0;overflow:hidden;width:0}.bar .border{fill:transparent;stroke:black}.bar .background{fill:lightgray;stroke:white}.bar .progress{fill:#0075ff;stroke:transparent;transition:250ms ease-in-out 50ms}.cycle .background{fill:transparent;stroke:lightgray}.cycle .border{fill:transparent;stroke:black}.cycle .whitespace{fill:transparent;stroke:white}.cycle .progress{fill:transparent;stroke:#0075ff;transform-origin:50% 50%;transform:rotate(-90deg);transition:250ms ease-in-out 50ms}@media (prefers-reduced-motion){.progress{transition-duration:0s;transition-delay:0s}}",c=n,d=Object.keys(o),h=e=>{let a="43%",r=e._label?"57%":"50%";switch(e._variant){case"cycle-value-label":e._label&&(a="57%",r="43%");case"cycle":case"cycle-label-value":return t("svg",{class:"cycle",width:"100",viewBox:"0 0 120 120",xmlns:"http://www.w3.org/2000/svg"},t("circle",{class:"background",cx:"60",cy:"60",r:"54.5",fill:"currentColor",stroke:"currentColor","stroke-width":"8"}),t("circle",{class:"whitespace",cx:"60",cy:"60",r:"59",fill:"currentColor",stroke:"currentColor","stroke-width":"3"}),t("circle",{class:"border",cx:"60",cy:"60",r:"59",fill:"currentColor",stroke:"currentColor","stroke-width":"1"}),t("circle",{class:"whitespace",cx:"60",cy:"60",r:"51",fill:"currentColor",stroke:"currentColor","stroke-width":"1"}),t("circle",{class:"border",cx:"60",cy:"60",r:"50",fill:"currentColor",stroke:"currentColor","stroke-width":"1"}),t("circle",{class:"progress",fill:"currentColor",stroke:"currentColor","stroke-linecap":"round","stroke-dasharray":`${Math.round(e._value/e._max*342)}px 342px`,"stroke-width":"6",cx:"60",cy:"60",r:"54.5"}),e._label&&t("text",{"aria-hidden":"true",x:"50%",y:a,"text-anchor":"middle",fill:"currentColor"},e._label),t("text",{"aria-hidden":"true",x:"50%",y:r,"text-anchor":"middle",fill:"currentColor"},e._value,e._unit));default:return t("div",{class:"bar"},e._label&&t("div",null,e._label),t("div",{style:{display:"flex",gap:"0.3em"}},t("svg",{width:"100",viewBox:"0 0 102 8",xmlns:"http://www.w3.org/2000/svg"},t("rect",{class:"background",x:"1",y:"1",height:"10",rx:"5",fill:"currentColor",stroke:"currentColor","stroke-width":"3",width:"100"}),t("rect",{class:"progress",x:"2.5",y:"2.5",height:"7",rx:"3.5",fill:"currentColor",stroke:"currentColor","stroke-width":"3",width:e._value/e._max*95}),t("rect",{class:"border",x:"1",y:"1",height:"10",rx:"5",fill:"currentColor",stroke:"currentColor","stroke-width":"1",width:"100"})),t("text",{"aria-hidden":"true","text-anchor":"middle","dominant-baseline":"central",fill:"currentColor"},e._value,e._unit)))}},u=class{constructor(t){e(this,t),this._label=void 0,this._max=void 0,this._type=void 0,this._unit="%",this._value=void 0,this._variant=void 0,this.state={_max:100,_unit:"%",_value:0,_variant:"bar",_liveValue:0}}render(){return t(r,{key:"47defb5309eea70ff5fde3e6f6ecf9d99644ec63",class:"kol-progress"},h(this.state),t("progress",{key:"c1afdb59cf40fbe18763637cae057c57153002d9","aria-busy":this.state._value<this.state._max?"true":"false",max:this.state._max,value:this.state._value}),t("span",{key:"3f51bc1fd04b896a9d785e6547d43a39a8170b50","aria-live":"polite","aria-relevant":"removals text",hidden:!0},this.state._liveValue," von ",this.state._max," ",this.state._unit))}validateLabel(t){i(this,t)}validateMax(t){"number"!=typeof t&&(t=100),a(this,"_max",t,{required:!0})}validateType(t){this.validateVariant(t)}validateUnit(t){s(this,"_unit",t)}validateValue(t){"number"!=typeof t&&(t=0),a(this,"_value",t,{required:!0})}validateVariant(t){l(this,"_variant",(t=>"string"==typeof t&&d.includes(t)),new Set(d),t)}componentWillLoad(){this.validateLabel(this._label),this.validateMax(this._max),this.validateUnit(this._unit),this.validateValue(this._value),this.validateVariant(this._variant||this._type),this.interval=setInterval((()=>{this.state._liveValue!==this.state._value&&(this.state=Object.assign(Object.assign({},this.state),{_liveValue:this.state._value}))}),5e3)}disconnectedCallback(){clearInterval(this.interval)}static get watchers(){return{_label:["validateLabel"],_max:["validateMax"],_type:["validateType"],_unit:["validateUnit"],_value:["validateValue"],_variant:["validateVariant"]}}};u.style={default:c};export{u as kol_progress};
@@ -1,4 +1,4 @@
1
1
  /*!
2
2
  * KoliBri - The accessible HTML-Standard
3
3
  */
4
- import{r as e,h as i,H as t}from"./index-a051748e.js";import{v as n}from"./label-bce4f328.js";import{d as a,w as o}from"./prop.validators-3017e14b.js";import{s}from"./reuse-d79ab469.js";import{i as r}from"./component-names-fed305c7.js";import"./a11y.tipps-798efb1a.js";import"./dev.utils-f829063f.js";import"./index-117bd1aa.js";const l='@charset "UTF-8";:host{--a11y-min-size:44px;background-color:white;color:black;font-family:Verdana}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role=button],button:not([role=link]),.kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}[hidden]{display:none !important}:host{max-width:100%}*{box-sizing:border-box}.kol-span-wc{display:grid;place-items:center}.kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}.icon-only>.kol-span-wc>span>span{display:none}.hidden{display:none;visibility:hidden}cite,figure,q+figcaption{display:inline;margin:0;padding:0}blockquote:before{content:open-quote}blockquote::after{content:close-quote}cite:before{content:"—"}.block cite:before{padding-right:0.5em}.inline cite:before{padding:0.5em}',d=l,h=class{constructor(t){e(this,t),this._caption=void 0,this._label=void 0,this._href=void 0,this._quote=void 0,this._variant="inline",this.state={_href:"",_quote:"",_variant:"inline"}}validateCaption(t){this.validateLabel(t)}validateLabel(t){n(this,t)}validateHref(t){a(this,"_href",t,{required:!0})}validateQuote(t){a(this,"_quote",t,{required:!0})}validateVariant(t){o(this,"_variant",(t=>"block"===t||"inline"===t),new Set(["block","inline"]),t)}componentWillLoad(){this.validateHref(this._href),this.validateLabel(this._label||this._caption),this.validateQuote(this._quote),this.validateVariant(this._variant)}render(){const e=s(this.state._quote);return i(t,{key:"6049061dced07c3e5e616f8b490cb627f534672f",class:"kol-quote"},i("figure",{key:"75f659f14469c7b337074ba17e669b8ecb621e05",class:{[this.state._variant]:!0}},"block"===this.state._variant?i("blockquote",{cite:this.state._href},this.state._quote,i("span",{"aria-hidden":e?void 0:"true",hidden:!e},i("slot",{name:"expert"}))):i("q",{cite:this.state._href},this.state._quote,i("span",{"aria-hidden":e?void 0:"true",hidden:!e},i("slot",{name:"expert"}))),"string"==typeof this.state._label&&this.state._label.length>0&&i("figcaption",null,i("cite",null,i(r,{_href:this.state._href,_label:this.state._label,_target:"_blank",class:"kol-link"})))))}static get watchers(){return{_caption:["validateCaption"],_label:["validateLabel"],_href:["validateHref"],_quote:["validateQuote"],_variant:["validateVariant"]}}};h.style={default:d};export{h as kol_quote};
4
+ import{r as e,h as i,H as t}from"./index-dfb131c4.js";import{v as a}from"./label-48b51f80.js";import{d as n,w as o}from"./prop.validators-a62aac63.js";import{s}from"./reuse-d79ab469.js";import{i as r}from"./component-names-fed305c7.js";import"./a11y.tipps-477c41d6.js";import"./dev.utils-1e8dd4a9.js";import"./index-117bd1aa.js";const d='@charset "UTF-8";:host{--a11y-min-size:44px;background-color:white;color:black;font-family:Verdana}*{hyphens:auto;letter-spacing:inherit;word-break:break-word;word-spacing:inherit}[role=button],button:not([role=link]),.kol-input .input{min-height:var(--a11y-min-size);min-width:var(--a11y-min-size)}a,button,h1,h2,h3,h4,h5,h6,input,option,select,textarea{font-family:inherit;font-size:inherit}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}:is(a,button){background-color:transparent;border:none;margin:0;padding:0;width:100%;}[hidden]{display:none !important}:host{max-width:100%}*{box-sizing:border-box}.kol-span-wc{display:grid;place-items:center}.kol-span-wc>span{display:flex;place-items:center}a,button{cursor:pointer}.icon-only>.kol-span-wc>span>span{display:none}.hidden{display:none;visibility:hidden}cite,figure,q+figcaption{display:inline;margin:0;padding:0}blockquote:before{content:open-quote}blockquote::after{content:close-quote}cite:before{content:"—"}.block cite:before{padding-right:0.5em}.inline cite:before{padding:0.5em}',l=d,h=class{constructor(t){e(this,t),this._caption=void 0,this._label=void 0,this._href=void 0,this._quote=void 0,this._variant="inline",this.state={_href:"",_quote:"",_variant:"inline"}}validateCaption(t){this.validateLabel(t)}validateLabel(t){a(this,t)}validateHref(t){n(this,"_href",t,{required:!0})}validateQuote(t){n(this,"_quote",t,{required:!0})}validateVariant(t){o(this,"_variant",(t=>"block"===t||"inline"===t),new Set(["block","inline"]),t)}componentWillLoad(){this.validateHref(this._href),this.validateLabel(this._label||this._caption),this.validateQuote(this._quote),this.validateVariant(this._variant)}render(){const e=s(this.state._quote);return i(t,{key:"fede296b285a0f185f73748fef071a0274e8c183",class:"kol-quote"},i("figure",{key:"d8092ac7ebace66a851e93479c47eb519c042014",class:{[this.state._variant]:!0}},"block"===this.state._variant?i("blockquote",{cite:this.state._href},this.state._quote,i("span",{"aria-hidden":e?void 0:"true",hidden:!e},i("slot",{name:"expert"}))):i("q",{cite:this.state._href},this.state._quote,i("span",{"aria-hidden":e?void 0:"true",hidden:!e},i("slot",{name:"expert"}))),"string"==typeof this.state._label&&this.state._label.length>0&&i("figcaption",{key:"372f2505524c4278bd9eb251e9063fd98d89f1ab"},i("cite",{key:"3e6163322a7da843257176e7af18878b8ecb6c12"},i(r,{key:"ad980fbc324774161d2bf3e4ef342a284d782ff9",_href:this.state._href,_label:this.state._label,_target:"_blank",class:"kol-link"})))))}static get watchers(){return{_caption:["validateCaption"],_label:["validateLabel"],_href:["validateHref"],_quote:["validateQuote"],_variant:["validateVariant"]}}};h.style={default:l};export{h as kol_quote};
@@ -1 +1 @@
1
- {"version":3,"names":["defaultStyleCss","KolQuoteDefaultStyle0","KolQuote","_href","_quote","_variant","validateCaption","value","this","validateLabel","validateHref","watchString","required","validateQuote","validateVariant","watchValidator","Set","componentWillLoad","_label","_caption","render","hasExpertSlot","showExpertSlot","state","h","Host","key","class","cite","undefined","hidden","name","length","KolLinkTag","_target"],"sources":["src/components/quote/style.scss?tag=kol-quote&mode=default&encapsulation=shadow","src/components/quote/shadow.tsx"],"sourcesContent":["@import '../style';\n\ncite,\nfigure,\nq + figcaption {\n\tdisplay: inline;\n\tmargin: 0;\n\tpadding: 0;\n}\n\nblockquote:before {\n\tcontent: open-quote;\n}\n\nblockquote::after {\n\tcontent: close-quote;\n}\n\ncite:before {\n\tcontent: '—';\n}\n\n.block cite:before {\n\tpadding-right: 0.5em;\n}\n\n.inline cite:before {\n\tpadding: 0.5em;\n}\n","import { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { HrefPropType } from '../../types/props/href';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { watchString, watchValidator } from '../../utils/prop.validators';\nimport { showExpertSlot } from '../../utils/reuse';\nimport { API, KoliBriQuoteVariant, States } from './types';\nimport { KolLinkTag } from '../../core/component-names';\n\n@Component({\n\ttag: 'kol-quote',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolQuote implements API {\n\t/**\n\t * Deprecated: Defines the visible caption of the component.\n\t * @deprecated Use _label.\n\t */\n\t@Prop() public _caption?: string;\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 * Sets the target URI of the link or citation source.\n\t */\n\t@Prop() public _href!: HrefPropType;\n\n\t/**\n\t * Defines the text of the quote.\n\t */\n\t@Prop() public _quote!: string;\n\n\t/**\n\t * Defines which variant should be used for presentation.\n\t */\n\t@Prop() public _variant?: KoliBriQuoteVariant = 'inline';\n\n\t@State() public state: States = {\n\t\t_href: '', // ⚠ required\n\t\t_quote: '', // ⚠ requireds\n\t\t_variant: 'inline',\n\t};\n\n\t@Watch('_caption')\n\tpublic validateCaption(value?: string): void {\n\t\tthis.validateLabel(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('_href')\n\tpublic validateHref(value?: HrefPropType): void {\n\t\twatchString(this, '_href', value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_quote')\n\tpublic validateQuote(value?: string): void {\n\t\twatchString(this, '_quote', value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_variant')\n\tpublic validateVariant(value?: KoliBriQuoteVariant): void {\n\t\twatchValidator(this, '_variant', (value) => value === 'block' || value === 'inline', new Set(['block', 'inline']), value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateHref(this._href);\n\t\tthis.validateLabel(this._label || this._caption);\n\t\tthis.validateQuote(this._quote);\n\t\tthis.validateVariant(this._variant);\n\t}\n\n\tpublic render(): JSX.Element {\n\t\tconst hasExpertSlot = showExpertSlot(this.state._quote); // _quote instead of _caption as _label\n\t\treturn (\n\t\t\t<Host class=\"kol-quote\">\n\t\t\t\t<figure\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[this.state._variant]: true,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t{this.state._variant === 'block' ? (\n\t\t\t\t\t\t<blockquote cite={this.state._href}>\n\t\t\t\t\t\t\t{this.state._quote}\n\t\t\t\t\t\t\t<span aria-hidden={!hasExpertSlot ? 'true' : undefined} hidden={!hasExpertSlot}>\n\t\t\t\t\t\t\t\t<slot name=\"expert\" />\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t</blockquote>\n\t\t\t\t\t) : (\n\t\t\t\t\t\t<q cite={this.state._href}>\n\t\t\t\t\t\t\t{this.state._quote}\n\t\t\t\t\t\t\t<span aria-hidden={!hasExpertSlot ? 'true' : undefined} hidden={!hasExpertSlot}>\n\t\t\t\t\t\t\t\t<slot name=\"expert\" />\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t</q>\n\t\t\t\t\t)}\n\t\t\t\t\t{typeof this.state._label === 'string' && this.state._label.length > 0 && (\n\t\t\t\t\t\t<figcaption>\n\t\t\t\t\t\t\t<cite>\n\t\t\t\t\t\t\t\t<KolLinkTag _href={this.state._href} _label={this.state._label} _target=\"_blank\" class=\"kol-link\" />\n\t\t\t\t\t\t\t</cite>\n\t\t\t\t\t\t</figcaption>\n\t\t\t\t\t)}\n\t\t\t\t</figure>\n\t\t\t</Host>\n\t\t);\n\t}\n}\n"],"mappings":";;;yUAAA,MAAMA,EAAkB,umCACxB,MAAAC,EAAeD,E,MCeFE,EAAQ,M,gIAyB4B,S,WAEhB,CAC/BC,MAAO,GACPC,OAAQ,GACRC,SAAU,S,CAIJ,eAAAC,CAAgBC,GACtBC,KAAKC,cAAcF,E,CAIb,aAAAE,CAAcF,GACpBE,EAAcD,KAAMD,E,CAId,YAAAG,CAAaH,GACnBI,EAAYH,KAAM,QAASD,EAAO,CACjCK,SAAU,M,CAKL,aAAAC,CAAcN,GACpBI,EAAYH,KAAM,SAAUD,EAAO,CAClCK,SAAU,M,CAKL,eAAAE,CAAgBP,GACtBQ,EAAeP,KAAM,YAAaD,GAAUA,IAAU,SAAWA,IAAU,UAAU,IAAIS,IAAI,CAAC,QAAS,WAAYT,E,CAG7G,iBAAAU,GACNT,KAAKE,aAAaF,KAAKL,OACvBK,KAAKC,cAAcD,KAAKU,QAAUV,KAAKW,UACvCX,KAAKK,cAAcL,KAAKJ,QACxBI,KAAKM,gBAAgBN,KAAKH,S,CAGpB,MAAAe,GACN,MAAMC,EAAgBC,EAAed,KAAKe,MAAMnB,QAChD,OACCoB,EAACC,EAAI,CAAAC,IAAA,2CAACC,MAAM,aACXH,EAAA,UAAAE,IAAA,2CACCC,MAAO,CACN,CAACnB,KAAKe,MAAMlB,UAAW,OAGvBG,KAAKe,MAAMlB,WAAa,QACxBmB,EAAA,cAAYI,KAAMpB,KAAKe,MAAMpB,OAC3BK,KAAKe,MAAMnB,OACZoB,EAAA,uBAAoBH,EAAgB,OAASQ,UAAWC,QAAST,GAChEG,EAAA,QAAMO,KAAK,aAIbP,EAAA,KAAGI,KAAMpB,KAAKe,MAAMpB,OAClBK,KAAKe,MAAMnB,OACZoB,EAAA,uBAAoBH,EAAgB,OAASQ,UAAWC,QAAST,GAChEG,EAAA,QAAMO,KAAK,oBAINvB,KAAKe,MAAML,SAAW,UAAYV,KAAKe,MAAML,OAAOc,OAAS,GACpER,EAAA,kBACCA,EAAA,YACCA,EAACS,EAAU,CAAC9B,MAAOK,KAAKe,MAAMpB,MAAOe,OAAQV,KAAKe,MAAML,OAAQgB,QAAQ,SAASP,MAAM,gB"}
1
+ {"version":3,"names":["defaultStyleCss","KolQuoteDefaultStyle0","KolQuote","_href","_quote","_variant","validateCaption","value","this","validateLabel","validateHref","watchString","required","validateQuote","validateVariant","watchValidator","Set","componentWillLoad","_label","_caption","render","hasExpertSlot","showExpertSlot","state","h","Host","key","class","cite","undefined","hidden","name","length","KolLinkTag","_target"],"sources":["src/components/quote/style.scss?tag=kol-quote&mode=default&encapsulation=shadow","src/components/quote/shadow.tsx"],"sourcesContent":["@import '../style';\n\ncite,\nfigure,\nq + figcaption {\n\tdisplay: inline;\n\tmargin: 0;\n\tpadding: 0;\n}\n\nblockquote:before {\n\tcontent: open-quote;\n}\n\nblockquote::after {\n\tcontent: close-quote;\n}\n\ncite:before {\n\tcontent: '—';\n}\n\n.block cite:before {\n\tpadding-right: 0.5em;\n}\n\n.inline cite:before {\n\tpadding: 0.5em;\n}\n","import { Component, h, Host, JSX, Prop, State, Watch } from '@stencil/core';\n\nimport { HrefPropType } from '../../types/props/href';\nimport { LabelPropType, validateLabel } from '../../types/props/label';\nimport { watchString, watchValidator } from '../../utils/prop.validators';\nimport { showExpertSlot } from '../../utils/reuse';\nimport { API, KoliBriQuoteVariant, States } from './types';\nimport { KolLinkTag } from '../../core/component-names';\n\n@Component({\n\ttag: 'kol-quote',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolQuote implements API {\n\t/**\n\t * Deprecated: Defines the visible caption of the component.\n\t * @deprecated Use _label.\n\t */\n\t@Prop() public _caption?: string;\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 * Sets the target URI of the link or citation source.\n\t */\n\t@Prop() public _href!: HrefPropType;\n\n\t/**\n\t * Defines the text of the quote.\n\t */\n\t@Prop() public _quote!: string;\n\n\t/**\n\t * Defines which variant should be used for presentation.\n\t */\n\t@Prop() public _variant?: KoliBriQuoteVariant = 'inline';\n\n\t@State() public state: States = {\n\t\t_href: '', // ⚠ required\n\t\t_quote: '', // ⚠ requireds\n\t\t_variant: 'inline',\n\t};\n\n\t@Watch('_caption')\n\tpublic validateCaption(value?: string): void {\n\t\tthis.validateLabel(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('_href')\n\tpublic validateHref(value?: HrefPropType): void {\n\t\twatchString(this, '_href', value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_quote')\n\tpublic validateQuote(value?: string): void {\n\t\twatchString(this, '_quote', value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_variant')\n\tpublic validateVariant(value?: KoliBriQuoteVariant): void {\n\t\twatchValidator(this, '_variant', (value) => value === 'block' || value === 'inline', new Set(['block', 'inline']), value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateHref(this._href);\n\t\tthis.validateLabel(this._label || this._caption);\n\t\tthis.validateQuote(this._quote);\n\t\tthis.validateVariant(this._variant);\n\t}\n\n\tpublic render(): JSX.Element {\n\t\tconst hasExpertSlot = showExpertSlot(this.state._quote); // _quote instead of _caption as _label\n\t\treturn (\n\t\t\t<Host class=\"kol-quote\">\n\t\t\t\t<figure\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[this.state._variant]: true,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t{this.state._variant === 'block' ? (\n\t\t\t\t\t\t<blockquote cite={this.state._href}>\n\t\t\t\t\t\t\t{this.state._quote}\n\t\t\t\t\t\t\t<span aria-hidden={!hasExpertSlot ? 'true' : undefined} hidden={!hasExpertSlot}>\n\t\t\t\t\t\t\t\t<slot name=\"expert\" />\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t</blockquote>\n\t\t\t\t\t) : (\n\t\t\t\t\t\t<q cite={this.state._href}>\n\t\t\t\t\t\t\t{this.state._quote}\n\t\t\t\t\t\t\t<span aria-hidden={!hasExpertSlot ? 'true' : undefined} hidden={!hasExpertSlot}>\n\t\t\t\t\t\t\t\t<slot name=\"expert\" />\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t</q>\n\t\t\t\t\t)}\n\t\t\t\t\t{typeof this.state._label === 'string' && this.state._label.length > 0 && (\n\t\t\t\t\t\t<figcaption>\n\t\t\t\t\t\t\t<cite>\n\t\t\t\t\t\t\t\t<KolLinkTag _href={this.state._href} _label={this.state._label} _target=\"_blank\" class=\"kol-link\" />\n\t\t\t\t\t\t\t</cite>\n\t\t\t\t\t\t</figcaption>\n\t\t\t\t\t)}\n\t\t\t\t</figure>\n\t\t\t</Host>\n\t\t);\n\t}\n}\n"],"mappings":";;;yUAAA,MAAMA,EAAkB,umCACxB,MAAAC,EAAeD,E,MCeFE,EAAQ,M,gIAyB4B,S,WAEhB,CAC/BC,MAAO,GACPC,OAAQ,GACRC,SAAU,S,CAIJ,eAAAC,CAAgBC,GACtBC,KAAKC,cAAcF,E,CAIb,aAAAE,CAAcF,GACpBE,EAAcD,KAAMD,E,CAId,YAAAG,CAAaH,GACnBI,EAAYH,KAAM,QAASD,EAAO,CACjCK,SAAU,M,CAKL,aAAAC,CAAcN,GACpBI,EAAYH,KAAM,SAAUD,EAAO,CAClCK,SAAU,M,CAKL,eAAAE,CAAgBP,GACtBQ,EAAeP,KAAM,YAAaD,GAAUA,IAAU,SAAWA,IAAU,UAAU,IAAIS,IAAI,CAAC,QAAS,WAAYT,E,CAG7G,iBAAAU,GACNT,KAAKE,aAAaF,KAAKL,OACvBK,KAAKC,cAAcD,KAAKU,QAAUV,KAAKW,UACvCX,KAAKK,cAAcL,KAAKJ,QACxBI,KAAKM,gBAAgBN,KAAKH,S,CAGpB,MAAAe,GACN,MAAMC,EAAgBC,EAAed,KAAKe,MAAMnB,QAChD,OACCoB,EAACC,EAAI,CAAAC,IAAA,2CAACC,MAAM,aACXH,EAAA,UAAAE,IAAA,2CACCC,MAAO,CACN,CAACnB,KAAKe,MAAMlB,UAAW,OAGvBG,KAAKe,MAAMlB,WAAa,QACxBmB,EAAA,cAAYI,KAAMpB,KAAKe,MAAMpB,OAC3BK,KAAKe,MAAMnB,OACZoB,EAAA,uBAAoBH,EAAgB,OAASQ,UAAWC,QAAST,GAChEG,EAAA,QAAMO,KAAK,aAIbP,EAAA,KAAGI,KAAMpB,KAAKe,MAAMpB,OAClBK,KAAKe,MAAMnB,OACZoB,EAAA,uBAAoBH,EAAgB,OAASQ,UAAWC,QAAST,GAChEG,EAAA,QAAMO,KAAK,oBAINvB,KAAKe,MAAML,SAAW,UAAYV,KAAKe,MAAML,OAAOc,OAAS,GACpER,EAAA,cAAAE,IAAA,4CACCF,EAAA,QAAAE,IAAA,4CACCF,EAACS,EAAU,CAAAP,IAAA,2CAACvB,MAAOK,KAAKe,MAAMpB,MAAOe,OAAQV,KAAKe,MAAML,OAAQgB,QAAQ,SAASP,MAAM,gB"}