@swisspost/design-system-components 1.5.1 → 1.6.0

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 (294) hide show
  1. package/dist/cjs/check-non-empty-ae713942.js +13 -0
  2. package/dist/cjs/check-non-empty-ae713942.js.map +1 -0
  3. package/dist/cjs/{check-one-of-4c2e8b2e.js → check-one-of-27ad3154.js} +1 -1
  4. package/dist/cjs/check-one-of-27ad3154.js.map +1 -0
  5. package/dist/cjs/constants-238701d3.js +7 -0
  6. package/dist/cjs/constants-238701d3.js.map +1 -0
  7. package/dist/cjs/fade-35a3633a.js +12 -0
  8. package/dist/cjs/fade-35a3633a.js.map +1 -0
  9. package/dist/cjs/index-b38a23e0.js +41 -0
  10. package/dist/cjs/index-b38a23e0.js.map +1 -0
  11. package/dist/cjs/{index-12cc37c9.js → index-b619e205.js} +245 -41
  12. package/dist/cjs/index-b619e205.js.map +1 -0
  13. package/dist/cjs/index.cjs.js +26 -0
  14. package/dist/cjs/index.cjs.js.map +1 -1
  15. package/dist/cjs/loader.cjs.js +3 -12
  16. package/dist/cjs/loader.cjs.js.map +1 -1
  17. package/dist/cjs/package-7c4db872.js +7 -0
  18. package/dist/cjs/package-7c4db872.js.map +1 -0
  19. package/dist/cjs/post-accordion.cjs.entry.js +89 -0
  20. package/dist/cjs/post-accordion.cjs.entry.js.map +1 -0
  21. package/dist/cjs/post-alert-c037e6a3.js +101 -0
  22. package/dist/{post-components/p-7240ae7b.entry.js.map → cjs/post-alert-c037e6a3.js.map} +1 -1
  23. package/dist/cjs/post-alert.cjs.entry.js +9 -96
  24. package/dist/cjs/post-alert.cjs.entry.js.map +1 -1
  25. package/dist/cjs/post-collapsible-7c9d23a2.js +93 -0
  26. package/dist/cjs/post-collapsible-7c9d23a2.js.map +1 -0
  27. package/dist/cjs/post-collapsible.cjs.entry.js +7 -119
  28. package/dist/cjs/post-collapsible.cjs.entry.js.map +1 -1
  29. package/dist/cjs/post-components.cjs.js +3 -6
  30. package/dist/cjs/post-components.cjs.js.map +1 -1
  31. package/dist/cjs/post-icon-f418f76a.js +105 -0
  32. package/dist/cjs/post-icon-f418f76a.js.map +1 -0
  33. package/dist/cjs/post-icon.cjs.entry.js +8 -100
  34. package/dist/cjs/post-icon.cjs.entry.js.map +1 -1
  35. package/dist/cjs/post-tab-header-e08c2a42.js +33 -0
  36. package/dist/cjs/post-tab-header-e08c2a42.js.map +1 -0
  37. package/dist/cjs/post-tab-header.cjs.entry.js +6 -26
  38. package/dist/cjs/post-tab-header.cjs.entry.js.map +1 -1
  39. package/dist/cjs/post-tab-panel-721f7f32.js +27 -0
  40. package/dist/cjs/post-tab-panel-721f7f32.js.map +1 -0
  41. package/dist/cjs/post-tab-panel.cjs.entry.js +4 -20
  42. package/dist/cjs/post-tab-panel.cjs.entry.js.map +1 -1
  43. package/dist/cjs/post-tabs-4bcc867b.js +153 -0
  44. package/dist/cjs/post-tabs-4bcc867b.js.map +1 -0
  45. package/dist/cjs/post-tabs.cjs.entry.js +5 -146
  46. package/dist/cjs/post-tabs.cjs.entry.js.map +1 -1
  47. package/dist/cjs/post-tooltip-261c5cda.js +5095 -0
  48. package/dist/cjs/post-tooltip-261c5cda.js.map +1 -0
  49. package/dist/cjs/post-tooltip.cjs.entry.js +5 -5088
  50. package/dist/cjs/post-tooltip.cjs.entry.js.map +1 -1
  51. package/dist/collection/animations/collapse.js +13 -0
  52. package/dist/collection/animations/collapse.js.map +1 -0
  53. package/dist/collection/animations/fade.js +4 -4
  54. package/dist/collection/animations/fade.js.map +1 -1
  55. package/dist/collection/collection-manifest.json +10 -9
  56. package/dist/collection/components/post-accordion/post-accordion.css +1 -0
  57. package/dist/collection/components/post-accordion/post-accordion.js +178 -0
  58. package/dist/collection/components/post-accordion/post-accordion.js.map +1 -0
  59. package/dist/collection/components/post-alert/post-alert.css +1 -1
  60. package/dist/collection/components/post-alert/post-alert.js +9 -7
  61. package/dist/collection/components/post-alert/post-alert.js.map +1 -1
  62. package/dist/collection/components/post-collapsible/heading-levels.js +2 -0
  63. package/dist/collection/components/post-collapsible/heading-levels.js.map +1 -0
  64. package/dist/collection/components/post-collapsible/post-collapsible.css +1 -29
  65. package/dist/collection/components/post-collapsible/post-collapsible.js +65 -63
  66. package/dist/collection/components/post-collapsible/post-collapsible.js.map +1 -1
  67. package/dist/collection/components/post-icon/post-icon.js +5 -4
  68. package/dist/collection/components/post-icon/post-icon.js.map +1 -1
  69. package/dist/collection/components/post-tab-header/post-tab-header.css +1 -1
  70. package/dist/collection/components/post-tab-header/post-tab-header.js +5 -4
  71. package/dist/collection/components/post-tab-header/post-tab-header.js.map +1 -1
  72. package/dist/collection/components/post-tab-panel/post-tab-panel.js +2 -2
  73. package/dist/collection/components/post-tabs/post-tabs.js +11 -7
  74. package/dist/collection/components/post-tabs/post-tabs.js.map +1 -1
  75. package/dist/collection/components/post-tooltip/post-tooltip.js +22 -15
  76. package/dist/collection/components/post-tooltip/post-tooltip.js.map +1 -1
  77. package/dist/collection/index.js +8 -1
  78. package/dist/collection/index.js.map +1 -1
  79. package/dist/collection/utils/index.js +1 -3
  80. package/dist/collection/utils/index.js.map +1 -1
  81. package/dist/collection/utils/is-motion-reduced.js +4 -0
  82. package/dist/collection/utils/is-motion-reduced.js.map +1 -0
  83. package/dist/collection/utils/property-checkers/check-non-empty.js +1 -1
  84. package/dist/collection/utils/property-checkers/empty-or.js +1 -1
  85. package/dist/collection/utils/property-checkers/index.js +4 -4
  86. package/dist/components/check-non-empty.js +2 -2
  87. package/dist/components/check-non-empty.js.map +1 -1
  88. package/dist/components/check-one-of.js.map +1 -1
  89. package/dist/components/constants.js +5 -0
  90. package/dist/components/constants.js.map +1 -0
  91. package/dist/components/fade.js +4 -4
  92. package/dist/components/fade.js.map +1 -1
  93. package/dist/components/index.d.ts +6 -0
  94. package/dist/components/index.js +8 -1
  95. package/dist/components/index.js.map +1 -1
  96. package/dist/components/index2.js +36 -0
  97. package/dist/components/index2.js.map +1 -0
  98. package/dist/components/package.js +1 -1
  99. package/dist/components/post-accordion.d.ts +11 -0
  100. package/dist/components/post-accordion.js +108 -0
  101. package/dist/components/post-accordion.js.map +1 -0
  102. package/dist/components/post-alert.js +1 -128
  103. package/dist/components/post-alert.js.map +1 -1
  104. package/dist/components/post-alert2.js +138 -0
  105. package/dist/components/post-alert2.js.map +1 -0
  106. package/dist/components/post-collapsible.js +1 -146
  107. package/dist/components/post-collapsible.js.map +1 -1
  108. package/dist/components/post-collapsible2.js +117 -0
  109. package/dist/components/post-collapsible2.js.map +1 -0
  110. package/dist/components/post-icon2.js +11 -21
  111. package/dist/components/post-icon2.js.map +1 -1
  112. package/dist/components/post-tab-header.js +1 -45
  113. package/dist/components/post-tab-header.js.map +1 -1
  114. package/dist/components/post-tab-header2.js +51 -0
  115. package/dist/components/post-tab-header2.js.map +1 -0
  116. package/dist/components/post-tab-panel.js +1 -39
  117. package/dist/components/post-tab-panel.js.map +1 -1
  118. package/dist/components/post-tab-panel2.js +43 -0
  119. package/dist/components/post-tab-panel2.js.map +1 -0
  120. package/dist/components/post-tabs.js +1 -165
  121. package/dist/components/post-tabs.js.map +1 -1
  122. package/dist/components/post-tabs2.js +169 -0
  123. package/dist/components/post-tabs2.js.map +1 -0
  124. package/dist/components/post-tooltip.js +1 -5111
  125. package/dist/components/post-tooltip.js.map +1 -1
  126. package/dist/components/post-tooltip2.js +5117 -0
  127. package/dist/components/post-tooltip2.js.map +1 -0
  128. package/dist/docs.d.ts +334 -235
  129. package/dist/docs.json +458 -14
  130. package/dist/esm/check-non-empty-09c39561.js +11 -0
  131. package/dist/esm/check-non-empty-09c39561.js.map +1 -0
  132. package/dist/esm/{check-one-of-ded5e15e.js → check-one-of-74750af9.js} +1 -1
  133. package/dist/esm/check-one-of-74750af9.js.map +1 -0
  134. package/dist/esm/constants-8d548297.js +5 -0
  135. package/dist/esm/constants-8d548297.js.map +1 -0
  136. package/dist/esm/fade-7fd71785.js +9 -0
  137. package/dist/esm/fade-7fd71785.js.map +1 -0
  138. package/dist/esm/index-35921354.js +36 -0
  139. package/dist/esm/index-35921354.js.map +1 -0
  140. package/dist/esm/{index-5611074b.js → index-4eff5fc5.js} +245 -41
  141. package/dist/esm/index-4eff5fc5.js.map +1 -0
  142. package/dist/esm/index.js +14 -1
  143. package/dist/esm/index.js.map +1 -1
  144. package/dist/esm/loader.js +4 -13
  145. package/dist/esm/loader.js.map +1 -1
  146. package/dist/esm/package-3bbdb32c.js +5 -0
  147. package/dist/esm/package-3bbdb32c.js.map +1 -0
  148. package/dist/esm/post-accordion.entry.js +85 -0
  149. package/dist/esm/post-accordion.entry.js.map +1 -0
  150. package/dist/{post-components/p-7240ae7b.entry.js → esm/post-alert-5dd43c8b.js} +99 -2
  151. package/dist/esm/post-alert-5dd43c8b.js.map +1 -0
  152. package/dist/esm/post-alert.entry.js +8 -99
  153. package/dist/esm/post-alert.entry.js.map +1 -1
  154. package/dist/esm/post-collapsible-26dc2340.js +91 -0
  155. package/dist/esm/post-collapsible-26dc2340.js.map +1 -0
  156. package/dist/esm/post-collapsible.entry.js +6 -122
  157. package/dist/esm/post-collapsible.entry.js.map +1 -1
  158. package/dist/esm/post-components.js +4 -7
  159. package/dist/esm/post-components.js.map +1 -1
  160. package/dist/esm/post-icon-fb0eb8aa.js +103 -0
  161. package/dist/esm/post-icon-fb0eb8aa.js.map +1 -0
  162. package/dist/esm/post-icon.entry.js +7 -103
  163. package/dist/esm/post-icon.entry.js.map +1 -1
  164. package/dist/esm/post-tab-header-deebc551.js +31 -0
  165. package/dist/esm/post-tab-header-deebc551.js.map +1 -0
  166. package/dist/esm/post-tab-header.entry.js +5 -29
  167. package/dist/esm/post-tab-header.entry.js.map +1 -1
  168. package/dist/esm/post-tab-panel-4b820f71.js +25 -0
  169. package/dist/esm/post-tab-panel-4b820f71.js.map +1 -0
  170. package/dist/esm/post-tab-panel.entry.js +3 -23
  171. package/dist/esm/post-tab-panel.entry.js.map +1 -1
  172. package/dist/esm/post-tabs-2d8d6a33.js +151 -0
  173. package/dist/esm/post-tabs-2d8d6a33.js.map +1 -0
  174. package/dist/esm/post-tabs.entry.js +4 -149
  175. package/dist/esm/post-tabs.entry.js.map +1 -1
  176. package/dist/esm/post-tooltip-811309c5.js +5093 -0
  177. package/dist/esm/post-tooltip-811309c5.js.map +1 -0
  178. package/dist/esm/post-tooltip.entry.js +4 -5091
  179. package/dist/esm/post-tooltip.entry.js.map +1 -1
  180. package/dist/post-components/index.esm.js +1 -1
  181. package/dist/post-components/{p-8c386036.entry.js → p-01e8dfe6.js} +3 -3
  182. package/dist/post-components/p-01e8dfe6.js.map +1 -0
  183. package/dist/post-components/p-0a49c1a3.entry.js +2 -0
  184. package/dist/post-components/{p-bcc705f1.js → p-1339f8cd.js} +1 -1
  185. package/dist/post-components/p-1339f8cd.js.map +1 -0
  186. package/dist/post-components/{p-123bb6fb.entry.js → p-1a8a8ef2.js} +2 -2
  187. package/dist/post-components/p-1a8a8ef2.js.map +1 -0
  188. package/dist/post-components/p-27092ac3.entry.js +2 -0
  189. package/dist/post-components/p-27092ac3.entry.js.map +1 -0
  190. package/dist/post-components/{p-e5306504.js → p-2737eaf5.js} +1 -1
  191. package/dist/post-components/p-2737eaf5.js.map +1 -0
  192. package/dist/post-components/p-332eef46.js +2 -0
  193. package/dist/post-components/p-332eef46.js.map +1 -0
  194. package/dist/post-components/p-440193f4.js +2 -0
  195. package/dist/post-components/p-440193f4.js.map +1 -0
  196. package/dist/post-components/p-541142fd.js +2 -0
  197. package/dist/post-components/p-541142fd.js.map +1 -0
  198. package/dist/post-components/{p-0d37fe44.entry.js → p-574acdb0.js} +2 -2
  199. package/dist/post-components/p-574acdb0.js.map +1 -0
  200. package/dist/post-components/p-66460e3f.entry.js +2 -0
  201. package/dist/post-components/p-66460e3f.entry.js.map +1 -0
  202. package/dist/post-components/p-810ee105.entry.js +2 -0
  203. package/dist/post-components/p-810ee105.entry.js.map +1 -0
  204. package/dist/post-components/p-939df031.entry.js +2 -0
  205. package/dist/post-components/p-939df031.entry.js.map +1 -0
  206. package/dist/post-components/p-94b3f291.entry.js +2 -0
  207. package/dist/post-components/p-94b3f291.entry.js.map +1 -0
  208. package/dist/post-components/p-97000cb6.js +2 -0
  209. package/dist/post-components/p-97000cb6.js.map +1 -0
  210. package/dist/post-components/p-a7649277.js +3 -0
  211. package/dist/post-components/p-a7649277.js.map +1 -0
  212. package/dist/post-components/p-abd149b3.entry.js +2 -0
  213. package/dist/post-components/p-abd149b3.entry.js.map +1 -0
  214. package/dist/post-components/p-b531475e.js +2 -0
  215. package/dist/post-components/p-b531475e.js.map +1 -0
  216. package/dist/post-components/p-c6b73d6e.js +2 -0
  217. package/dist/post-components/p-c6b73d6e.js.map +1 -0
  218. package/dist/post-components/p-d4fb9f16.js +2 -0
  219. package/dist/post-components/p-d4fb9f16.js.map +1 -0
  220. package/dist/post-components/p-dfe29f7f.js +2 -0
  221. package/dist/post-components/p-dfe29f7f.js.map +1 -0
  222. package/dist/post-components/p-e9dc9039.entry.js +2 -0
  223. package/dist/post-components/p-e9dc9039.entry.js.map +1 -0
  224. package/dist/post-components/post-components.esm.js +1 -1
  225. package/dist/post-components/post-components.esm.js.map +1 -1
  226. package/dist/types/animations/collapse.d.ts +2 -0
  227. package/dist/types/components/post-accordion/post-accordion.d.ts +28 -0
  228. package/dist/types/components/post-alert/post-alert.d.ts +1 -1
  229. package/dist/types/components/post-collapsible/heading-levels.d.ts +2 -0
  230. package/dist/types/components/post-collapsible/post-collapsible.d.ts +16 -12
  231. package/dist/types/components.d.ts +79 -3
  232. package/dist/types/index.d.ts +7 -0
  233. package/dist/types/stencil-public-runtime.d.ts +38 -5
  234. package/dist/types/utils/index.d.ts +1 -3
  235. package/dist/types/utils/is-motion-reduced.d.ts +1 -0
  236. package/loader/index.d.ts +1 -1
  237. package/package.json +8 -8
  238. package/dist/cjs/check-non-empty-35b4d0b5.js +0 -14
  239. package/dist/cjs/check-non-empty-35b4d0b5.js.map +0 -1
  240. package/dist/cjs/check-one-of-4c2e8b2e.js.map +0 -1
  241. package/dist/cjs/check-type-508a21a5.js +0 -18
  242. package/dist/cjs/check-type-508a21a5.js.map +0 -1
  243. package/dist/cjs/fade-8c6d4fa7.js +0 -12
  244. package/dist/cjs/fade-8c6d4fa7.js.map +0 -1
  245. package/dist/cjs/index-12cc37c9.js.map +0 -1
  246. package/dist/cjs/index-f8f6f146.js +0 -28
  247. package/dist/cjs/index-f8f6f146.js.map +0 -1
  248. package/dist/cjs/package-112e1698.js +0 -7
  249. package/dist/cjs/package-112e1698.js.map +0 -1
  250. package/dist/collection/utils/get-element-height.js +0 -12
  251. package/dist/collection/utils/get-element-height.js.map +0 -1
  252. package/dist/collection/utils/on-transition-end.js +0 -15
  253. package/dist/collection/utils/on-transition-end.js.map +0 -1
  254. package/dist/collection/utils/should-reduce-motion.js +0 -4
  255. package/dist/collection/utils/should-reduce-motion.js.map +0 -1
  256. package/dist/components/check-type.js +0 -16
  257. package/dist/components/check-type.js.map +0 -1
  258. package/dist/esm/check-non-empty-554bdf88.js +0 -11
  259. package/dist/esm/check-non-empty-554bdf88.js.map +0 -1
  260. package/dist/esm/check-one-of-ded5e15e.js.map +0 -1
  261. package/dist/esm/check-type-18ebb4e7.js +0 -16
  262. package/dist/esm/check-type-18ebb4e7.js.map +0 -1
  263. package/dist/esm/fade-671f1489.js +0 -9
  264. package/dist/esm/fade-671f1489.js.map +0 -1
  265. package/dist/esm/index-5611074b.js.map +0 -1
  266. package/dist/esm/index-7f723686.js +0 -24
  267. package/dist/esm/index-7f723686.js.map +0 -1
  268. package/dist/esm/package-331628f1.js +0 -5
  269. package/dist/esm/package-331628f1.js.map +0 -1
  270. package/dist/esm/polyfills/css-shim.js +0 -1
  271. package/dist/post-components/p-0d37fe44.entry.js.map +0 -1
  272. package/dist/post-components/p-123bb6fb.entry.js.map +0 -1
  273. package/dist/post-components/p-15fc087f.js +0 -2
  274. package/dist/post-components/p-15fc087f.js.map +0 -1
  275. package/dist/post-components/p-65a9d1c2.entry.js +0 -2
  276. package/dist/post-components/p-65a9d1c2.entry.js.map +0 -1
  277. package/dist/post-components/p-75a7b352.js +0 -2
  278. package/dist/post-components/p-75a7b352.js.map +0 -1
  279. package/dist/post-components/p-8c386036.entry.js.map +0 -1
  280. package/dist/post-components/p-97a064da.entry.js +0 -2
  281. package/dist/post-components/p-97a064da.entry.js.map +0 -1
  282. package/dist/post-components/p-bcc705f1.js.map +0 -1
  283. package/dist/post-components/p-c8efe0ae.js +0 -2
  284. package/dist/post-components/p-c8efe0ae.js.map +0 -1
  285. package/dist/post-components/p-ccae1c68.entry.js +0 -2
  286. package/dist/post-components/p-ccae1c68.entry.js.map +0 -1
  287. package/dist/post-components/p-d94db268.js +0 -3
  288. package/dist/post-components/p-d94db268.js.map +0 -1
  289. package/dist/post-components/p-e5306504.js.map +0 -1
  290. package/dist/post-components/p-eb3ff4dc.js +0 -2
  291. package/dist/types/utils/get-element-height.d.ts +0 -3
  292. package/dist/types/utils/on-transition-end.d.ts +0 -1
  293. package/dist/types/utils/should-reduce-motion.d.ts +0 -1
  294. /package/dist/post-components/{p-eb3ff4dc.js.map → p-0a49c1a3.entry.js.map} +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"names":["postTabsCss","PostTabs","this","isLoaded","tabs","host","querySelectorAll","componentDidLoad","moveMisplacedTabs","enableTabs","initiallyActivePanel","activePanel","item","panel","show","async","panelName","_a","activeTab","previousTab","newTab","querySelector","activateTab","showing","effect","style","display","finish","hiding","hidePanel","finished","showSelectedPanel","tabChange","emit","forEach","tab","getAttribute","setAttribute","componentOnReady","tabTitle","shadowRoot","tabPanel","getPanel","id","addEventListener","key","navigateTabs","isConnected","classList","remove","removeAttribute","add","previousPanel","fadeOut","onfinish","fadeIn","name","activeTabIndex","Array","from","indexOf","nextTab","length","nextTabTitle","focus","render","h","Host","version","class","role","onSlotchange"],"sources":["./src/components/post-tabs/post-tabs.scss?tag=post-tabs&encapsulation=shadow","./src/components/post-tabs/post-tabs.tsx"],"sourcesContent":["@use '@swisspost/design-system-styles/components/tabs/tabs-wrapper';\n\n:host {\n display: block;\n}\n","import { Component, Element, Event, EventEmitter, h, Host, Method, Prop } from '@stencil/core';\nimport { version } from '../../../package.json';\nimport { fadeIn, fadeOut } from '../../animations';\n\n@Component({\n tag: 'post-tabs',\n styleUrl: 'post-tabs.scss',\n shadow: true,\n})\nexport class PostTabs {\n private activeTab: HTMLPostTabHeaderElement;\n private showing: Animation;\n private hiding: Animation;\n private isLoaded = false;\n\n private get tabs(): NodeListOf<HTMLPostTabHeaderElement> {\n return this.host.querySelectorAll('post-tab-header');\n }\n\n @Element() host: HTMLPostTabsElement;\n\n /**\n * The name of the panel that is initially shown.\n * If not specified, it defaults to the panel associated with the first tab.\n *\n * **Changing this value after initialization has no effect.**\n */\n @Prop() readonly activePanel: HTMLPostTabPanelElement['name'];\n\n /**\n * An event emitted after the active tab changes, when the fade in transition of its associated panel is finished.\n * The payload is the name of the newly shown panel.\n */\n @Event() tabChange: EventEmitter<HTMLPostTabPanelElement['name']>;\n\n componentDidLoad() {\n this.moveMisplacedTabs();\n this.enableTabs();\n\n const initiallyActivePanel = this.activePanel || this.tabs.item(0).panel;\n void this.show(initiallyActivePanel);\n\n this.isLoaded = true;\n }\n\n /**\n * Shows the panel with the given name and selects its associated tab.\n * Any other panel that was previously shown becomes hidden and its associated tab is unselected.\n */\n @Method()\n async show(panelName: string) {\n // do nothing if the tab is already active\n if (panelName === this.activeTab?.panel) {\n return;\n }\n\n const previousTab = this.activeTab;\n const newTab: HTMLPostTabHeaderElement = this.host.querySelector(\n `post-tab-header[panel=${panelName}]`,\n );\n this.activateTab(newTab);\n\n // if a panel is currently being displayed, remove it from the view and complete the associated animation\n if (this.showing) {\n this.showing.effect['target'].style.display = 'none';\n this.showing.finish();\n }\n\n // hide the currently visible panel only if no other animation is running\n if (previousTab && !this.showing && !this.hiding) {\n this.hidePanel(previousTab.panel);\n }\n\n // wait for any hiding animation to complete before showing the selected tab\n if (this.hiding) {\n await this.hiding.finished;\n }\n\n this.showSelectedPanel();\n\n // wait for any display animation to complete for the returned promise to fully resolve\n if (this.showing) {\n await this.showing.finished;\n }\n\n this.tabChange.emit(this.activeTab.panel);\n }\n\n private moveMisplacedTabs() {\n if (!this.tabs) return;\n\n this.tabs.forEach(tab => {\n if (tab.getAttribute('slot') === 'tabs') return;\n tab.setAttribute('slot', 'tabs');\n });\n }\n\n private enableTabs() {\n if (!this.tabs) return;\n\n this.tabs.forEach(async tab => {\n await tab.componentOnReady();\n\n const tabTitle = tab.shadowRoot.querySelector('.tab-title');\n\n // if the tab has an \"aria-controls\" attribute it was already linked to its panel: do nothing\n if (tabTitle.getAttribute('aria-controls')) return;\n\n const tabPanel = this.getPanel(tab.panel).shadowRoot.querySelector('.tab-pane');\n tabTitle.setAttribute('aria-controls', tabPanel.id);\n tabPanel.setAttribute('aria-labelledby', tabTitle.id);\n\n tab.addEventListener('click', () => {\n void this.show(tab.panel);\n });\n\n tab.addEventListener('keydown', ({ key }) => {\n if (key === 'ArrowRight' || key === 'ArrowLeft') this.navigateTabs(tab, key);\n });\n });\n\n // if the currently active tab was removed from the DOM then select the first one\n if (this.activeTab && !this.activeTab.isConnected) {\n void this.show(this.tabs.item(0).panel);\n }\n }\n\n private activateTab(tab: HTMLPostTabHeaderElement) {\n if (this.activeTab) {\n const tabTitle = this.activeTab.shadowRoot.querySelector('.tab-title');\n tabTitle.setAttribute('aria-selected', 'false');\n tabTitle.setAttribute('tabindex', '-1');\n tabTitle.classList.remove('active');\n }\n\n const tabTitle = tab.shadowRoot.querySelector('.tab-title');\n tabTitle.setAttribute('aria-selected', 'true');\n tabTitle.removeAttribute('tabindex');\n tabTitle.classList.add('active');\n\n this.activeTab = tab;\n }\n\n private hidePanel(panelName: HTMLPostTabPanelElement['name']) {\n const previousPanel = this.getPanel(panelName);\n\n if (!previousPanel) return;\n\n this.hiding = fadeOut(previousPanel);\n this.hiding.onfinish = () => {\n previousPanel.style.display = 'none';\n this.hiding = null;\n };\n }\n\n private showSelectedPanel() {\n const panel = this.getPanel(this.activeTab.panel);\n panel.style.display = 'block';\n\n // prevent the initially selected panel from fading in\n if (!this.isLoaded) return;\n\n this.showing = fadeIn(panel);\n this.showing.onfinish = () => {\n this.showing = null;\n };\n }\n\n private getPanel(name: string): HTMLPostTabPanelElement {\n return this.host.querySelector(`post-tab-panel[name=${name}]`);\n }\n\n private navigateTabs(tab: HTMLPostTabHeaderElement, key: 'ArrowRight' | 'ArrowLeft') {\n const activeTabIndex = Array.from(this.tabs).indexOf(tab);\n\n let nextTab: HTMLPostTabHeaderElement;\n if (key === 'ArrowRight') {\n nextTab = this.tabs[activeTabIndex + 1] || this.tabs[0];\n } else {\n nextTab = this.tabs[activeTabIndex - 1] || this.tabs[this.tabs.length - 1];\n }\n\n if (!nextTab) return;\n\n const nextTabTitle = nextTab.shadowRoot.querySelector('.tab-title') as HTMLAnchorElement;\n nextTabTitle.focus();\n }\n\n render() {\n return (\n <Host data-version={version}>\n <div class=\"tabs-wrapper\">\n <div class=\"tabs\" role=\"tablist\">\n <slot name=\"tabs\" onSlotchange={() => this.enableTabs()} />\n </div>\n </div>\n <div class=\"tab-content\">\n <slot onSlotchange={() => this.moveMisplacedTabs()} />\n </div>\n </Host>\n );\n }\n}\n"],"mappings":"+IAAA,MAAMA,EAAc,szD,MCSPC,EAAQ,M,8DAIXC,KAAAC,SAAW,M,2BAEPC,WACV,OAAOF,KAAKG,KAAKC,iBAAiB,kB,CAmBpCC,mBACEL,KAAKM,oBACLN,KAAKO,aAEL,MAAMC,EAAuBR,KAAKS,aAAeT,KAAKE,KAAKQ,KAAK,GAAGC,WAC9DX,KAAKY,KAAKJ,GAEfR,KAAKC,SAAW,I,CAQlBY,WAAWC,G,MAET,GAAIA,MAAcC,EAAAf,KAAKgB,aAAS,MAAAD,SAAA,SAAAA,EAAEJ,OAAO,CACvC,M,CAGF,MAAMM,EAAcjB,KAAKgB,UACzB,MAAME,EAAmClB,KAAKG,KAAKgB,cACjD,yBAAyBL,MAE3Bd,KAAKoB,YAAYF,GAGjB,GAAIlB,KAAKqB,QAAS,CAChBrB,KAAKqB,QAAQC,OAAO,UAAUC,MAAMC,QAAU,OAC9CxB,KAAKqB,QAAQI,Q,CAIf,GAAIR,IAAgBjB,KAAKqB,UAAYrB,KAAK0B,OAAQ,CAChD1B,KAAK2B,UAAUV,EAAYN,M,CAI7B,GAAIX,KAAK0B,OAAQ,OACT1B,KAAK0B,OAAOE,Q,CAGpB5B,KAAK6B,oBAGL,GAAI7B,KAAKqB,QAAS,OACVrB,KAAKqB,QAAQO,Q,CAGrB5B,KAAK8B,UAAUC,KAAK/B,KAAKgB,UAAUL,M,CAG7BL,oBACN,IAAKN,KAAKE,KAAM,OAEhBF,KAAKE,KAAK8B,SAAQC,IAChB,GAAIA,EAAIC,aAAa,UAAY,OAAQ,OACzCD,EAAIE,aAAa,OAAQ,OAAO,G,CAI5B5B,aACN,IAAKP,KAAKE,KAAM,OAEhBF,KAAKE,KAAK8B,SAAQnB,MAAMoB,UAChBA,EAAIG,mBAEV,MAAMC,EAAWJ,EAAIK,WAAWnB,cAAc,cAG9C,GAAIkB,EAASH,aAAa,iBAAkB,OAE5C,MAAMK,EAAWvC,KAAKwC,SAASP,EAAItB,OAAO2B,WAAWnB,cAAc,aACnEkB,EAASF,aAAa,gBAAiBI,EAASE,IAChDF,EAASJ,aAAa,kBAAmBE,EAASI,IAElDR,EAAIS,iBAAiB,SAAS,UACvB1C,KAAKY,KAAKqB,EAAItB,MAAM,IAG3BsB,EAAIS,iBAAiB,WAAW,EAAGC,UACjC,GAAIA,IAAQ,cAAgBA,IAAQ,YAAa3C,KAAK4C,aAAaX,EAAKU,EAAI,GAC5E,IAIJ,GAAI3C,KAAKgB,YAAchB,KAAKgB,UAAU6B,YAAa,MAC5C7C,KAAKY,KAAKZ,KAAKE,KAAKQ,KAAK,GAAGC,M,EAI7BS,YAAYa,GAClB,GAAIjC,KAAKgB,UAAW,CAClB,MAAMqB,EAAWrC,KAAKgB,UAAUsB,WAAWnB,cAAc,cACzDkB,EAASF,aAAa,gBAAiB,SACvCE,EAASF,aAAa,WAAY,MAClCE,EAASS,UAAUC,OAAO,S,CAG5B,MAAMV,EAAWJ,EAAIK,WAAWnB,cAAc,cAC9CkB,EAASF,aAAa,gBAAiB,QACvCE,EAASW,gBAAgB,YACzBX,EAASS,UAAUG,IAAI,UAEvBjD,KAAKgB,UAAYiB,C,CAGXN,UAAUb,GAChB,MAAMoC,EAAgBlD,KAAKwC,SAAS1B,GAEpC,IAAKoC,EAAe,OAEpBlD,KAAK0B,OAASyB,EAAQD,GACtBlD,KAAK0B,OAAO0B,SAAW,KACrBF,EAAc3B,MAAMC,QAAU,OAC9BxB,KAAK0B,OAAS,IAAI,C,CAIdG,oBACN,MAAMlB,EAAQX,KAAKwC,SAASxC,KAAKgB,UAAUL,OAC3CA,EAAMY,MAAMC,QAAU,QAGtB,IAAKxB,KAAKC,SAAU,OAEpBD,KAAKqB,QAAUgC,EAAO1C,GACtBX,KAAKqB,QAAQ+B,SAAW,KACtBpD,KAAKqB,QAAU,IAAI,C,CAIfmB,SAASc,GACf,OAAOtD,KAAKG,KAAKgB,cAAc,uBAAuBmC,K,CAGhDV,aAAaX,EAA+BU,GAClD,MAAMY,EAAiBC,MAAMC,KAAKzD,KAAKE,MAAMwD,QAAQzB,GAErD,IAAI0B,EACJ,GAAIhB,IAAQ,aAAc,CACxBgB,EAAU3D,KAAKE,KAAKqD,EAAiB,IAAMvD,KAAKE,KAAK,E,KAChD,CACLyD,EAAU3D,KAAKE,KAAKqD,EAAiB,IAAMvD,KAAKE,KAAKF,KAAKE,KAAK0D,OAAS,E,CAG1E,IAAKD,EAAS,OAEd,MAAME,EAAeF,EAAQrB,WAAWnB,cAAc,cACtD0C,EAAaC,O,CAGfC,SACE,OACEC,EAACC,EAAI,gBAAeC,GAClBF,EAAA,OAAKG,MAAM,gBACTH,EAAA,OAAKG,MAAM,OAAOC,KAAK,WACrBJ,EAAA,QAAMV,KAAK,OAAOe,aAAc,IAAMrE,KAAKO,iBAG/CyD,EAAA,OAAKG,MAAM,eACTH,EAAA,QAAMK,aAAc,IAAMrE,KAAKM,uB"}
@@ -1,2 +0,0 @@
1
- import{E as o}from"./p-c8efe0ae.js";import{c as r}from"./p-bcc705f1.js";import{c as s}from"./p-75a7b352.js";function t(r){return(...s)=>{const t=s[0];if(!o.some((o=>o===t)))r(...s)}}function c(o,r,s){if(typeof o!=="string"||!r.test(o))throw new Error(s)}const n=t(r);const f=t(c);const a=t(s);export{n as a,a as b,f as c};
2
- //# sourceMappingURL=p-15fc087f.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["emptyOr","check","args","value","EMPTY_VALUES","some","v","checkPattern","pattern","errorMessage","test","Error","checkEmptyOrOneOf","checkOneOf","checkEmptyOrPattern","checkEmptyOrType","checkType"],"sources":["./src/utils/property-checkers/empty-or.ts","./src/utils/property-checkers/check-pattern.ts","./src/utils/property-checkers/index.ts"],"sourcesContent":["import { EMPTY_VALUES } from './constants';\n\nexport function emptyOr<T extends unknown[]>(check: (...args: T) => void) {\n return (...args: T) => {\n const value = args[0];\n if (!EMPTY_VALUES.some(v => v === value)) check(...args);\n };\n}\n","export function checkPattern(value: unknown, pattern: RegExp, errorMessage: string) {\n if (typeof value !== 'string' || !pattern.test(value)) throw new Error(errorMessage);\n}\n","import { emptyOr } from './empty-or';\nimport { checkOneOf } from './check-one-of';\nimport { checkPattern } from './check-pattern';\nimport { checkType } from './check-type';\n\nexport const checkEmptyOrOneOf = emptyOr(checkOneOf);\nexport const checkEmptyOrPattern = emptyOr(checkPattern);\nexport const checkEmptyOrType = emptyOr(checkType);\n\nexport * from './check-non-empty';\nexport * from './check-one-of';\nexport * from './check-pattern';\nexport * from './check-type';\n"],"mappings":"qHAEgBA,EAA6BC,GAC3C,MAAO,IAAIC,KACT,MAAMC,EAAQD,EAAK,GACnB,IAAKE,EAAaC,MAAKC,GAAKA,IAAMH,IAAQF,KAASC,EAAK,CAE5D,C,SCPgBK,EAAaJ,EAAgBK,EAAiBC,GAC5D,UAAWN,IAAU,WAAaK,EAAQE,KAAKP,GAAQ,MAAM,IAAIQ,MAAMF,EACzE,C,MCGaG,EAAoBZ,EAAQa,G,MAC5BC,EAAsBd,EAAQO,G,MAC9BQ,EAAmBf,EAAQgB,U"}
@@ -1,2 +0,0 @@
1
- import{r as s,h as t,H as n,g as o}from"./p-d94db268.js";import{v as e}from"./p-eb3ff4dc.js";const a=":host{display:none}";const r=class{constructor(t){s(this,t);this.panelId=undefined;this.name=undefined}componentWillLoad(){this.panelId=`panel-${this.host.id||crypto.randomUUID()}`}render(){return t(n,{"data-version":e},t("div",{class:"tab-pane",id:this.panelId,role:"tabpanel"},t("slot",null)))}get host(){return o(this)}};r.style=a;export{r as post_tab_panel};
2
- //# sourceMappingURL=p-65a9d1c2.entry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["postTabPanelCss","PostTabPanel","componentWillLoad","this","panelId","host","id","crypto","randomUUID","render","h","Host","version","class","role"],"sources":["./src/components/post-tab-panel/post-tab-panel.scss?tag=post-tab-panel&encapsulation=shadow","./src/components/post-tab-panel/post-tab-panel.tsx"],"sourcesContent":[":host {\n display: none;\n}\n","import { Component, Element, h, Host, Prop, State } from '@stencil/core';\nimport { version } from '../../../package.json';\n\n@Component({\n tag: 'post-tab-panel',\n styleUrl: 'post-tab-panel.scss',\n shadow: true,\n})\nexport class PostTabPanel {\n @Element() host: HTMLPostTabPanelElement;\n\n @State() panelId: string;\n\n /**\n * The name of the panel, used to associate it with a tab header.\n */\n @Prop() readonly name: string;\n\n componentWillLoad() {\n // get the id set on the host element or use a random id by default\n this.panelId = `panel-${this.host.id || crypto.randomUUID()}`;\n }\n\n render() {\n return (\n <Host data-version={version}>\n <div\n class=\"tab-pane\"\n id={this.panelId}\n role=\"tabpanel\"\n >\n <slot/>\n </div>\n </Host>\n );\n }\n}\n"],"mappings":"6FAAA,MAAMA,EAAkB,sB,MCQXC,EAAY,M,oEAUvBC,oBAEEC,KAAKC,QAAU,SAASD,KAAKE,KAAKC,IAAMC,OAAOC,c,CAGjDC,SACE,OACEC,EAACC,EAAI,gBAAeC,GAClBF,EAAA,OACEG,MAAM,WACNP,GAAIH,KAAKC,QACTU,KAAK,YAELJ,EAAA,c"}
@@ -1,2 +0,0 @@
1
- function r(r,o,t){const e=o==="array";const n=Array.isArray(r);if(e||n){if(n!==e)throw new Error(t)}else{if(typeof r!==o)throw new Error(t)}}export{r as c};
2
- //# sourceMappingURL=p-75a7b352.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["checkType","value","type","error","typeIsArray","valueIsArray","Array","isArray","Error"],"sources":["./src/utils/property-checkers/check-type.ts"],"sourcesContent":["export type PropertyType =\n | 'boolean'\n | 'number'\n | 'string'\n | 'array'\n | 'object'\n | 'function';\n\nexport function checkType(value: unknown, type: PropertyType, error: string) {\n const typeIsArray = type === 'array';\n const valueIsArray = Array.isArray(value);\n\n if (typeIsArray || valueIsArray) {\n if (valueIsArray !== typeIsArray) throw new Error(error);\n } else {\n if (typeof value !== type) throw new Error(error);\n }\n}\n"],"mappings":"SAQgBA,EAAUC,EAAgBC,EAAoBC,GAC5D,MAAMC,EAAcF,IAAS,QAC7B,MAAMG,EAAeC,MAAMC,QAAQN,GAEnC,GAAIG,GAAeC,EAAc,CAC/B,GAAIA,IAAiBD,EAAa,MAAM,IAAII,MAAML,E,KAC7C,CACL,UAAWF,IAAUC,EAAM,MAAM,IAAIM,MAAML,E,CAE/C,Q"}