@swisspost/design-system-components 1.6.2 → 1.7.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 (317) hide show
  1. package/dist/cjs/{check-non-empty-ae713942.js → check-non-empty-eeaa8f77.js} +4 -4
  2. package/dist/cjs/check-non-empty-eeaa8f77.js.map +1 -0
  3. package/dist/cjs/index-8c288b1a.js +45 -0
  4. package/dist/cjs/index-8c288b1a.js.map +1 -0
  5. package/dist/cjs/{index-e7618bb3.js → index-c07c0cdb.js} +79 -59
  6. package/dist/cjs/index-c07c0cdb.js.map +1 -0
  7. package/dist/cjs/index.cjs.js +17 -12
  8. package/dist/cjs/index.cjs.js.map +1 -1
  9. package/dist/cjs/loader.cjs.js +2 -2
  10. package/dist/cjs/package-cd0e9960.js +7 -0
  11. package/dist/cjs/package-cd0e9960.js.map +1 -0
  12. package/dist/cjs/post-accordion-f2e00198.js +87 -0
  13. package/dist/cjs/post-accordion-f2e00198.js.map +1 -0
  14. package/dist/cjs/post-accordion.cjs.entry.js +4 -80
  15. package/dist/cjs/post-accordion.cjs.entry.js.map +1 -1
  16. package/dist/cjs/post-alert-6d0b5e58.js +101 -0
  17. package/dist/cjs/{post-alert-1fb90f2d.js.map → post-alert-6d0b5e58.js.map} +1 -1
  18. package/dist/cjs/post-alert.cjs.entry.js +5 -6
  19. package/dist/cjs/post-alert.cjs.entry.js.map +1 -1
  20. package/dist/cjs/post-collapsible-0b8dce97.js +93 -0
  21. package/dist/cjs/post-collapsible-0b8dce97.js.map +1 -0
  22. package/dist/cjs/post-collapsible.cjs.entry.js +4 -5
  23. package/dist/cjs/post-collapsible.cjs.entry.js.map +1 -1
  24. package/dist/cjs/post-components.cjs.js +3 -3
  25. package/dist/cjs/post-components.cjs.js.map +1 -1
  26. package/dist/cjs/post-icon-3dbb7728.js +105 -0
  27. package/dist/cjs/post-icon-3dbb7728.js.map +1 -0
  28. package/dist/cjs/post-icon.cjs.entry.js +5 -6
  29. package/dist/cjs/post-icon.cjs.entry.js.map +1 -1
  30. package/dist/cjs/post-popover-ea22d235.js +118 -0
  31. package/dist/cjs/post-popover-ea22d235.js.map +1 -0
  32. package/dist/cjs/post-popover.cjs.entry.js +13 -0
  33. package/dist/cjs/post-popover.cjs.entry.js.map +1 -0
  34. package/dist/cjs/post-popovercontainer-42e4ab15.js +1878 -0
  35. package/dist/cjs/post-popovercontainer-42e4ab15.js.map +1 -0
  36. package/dist/cjs/post-popovercontainer.cjs.entry.js +13 -0
  37. package/dist/cjs/post-popovercontainer.cjs.entry.js.map +1 -0
  38. package/dist/cjs/post-tab-header-09074905.js +33 -0
  39. package/dist/cjs/{post-tab-header-a3845fe5.js.map → post-tab-header-09074905.js.map} +1 -1
  40. package/dist/cjs/post-tab-header.cjs.entry.js +4 -4
  41. package/dist/cjs/post-tab-panel-9547b9ac.js +27 -0
  42. package/dist/cjs/{post-tab-panel-b7326ff8.js.map → post-tab-panel-9547b9ac.js.map} +1 -1
  43. package/dist/cjs/post-tab-panel.cjs.entry.js +3 -3
  44. package/dist/cjs/post-tabs-2ec2778e.js +153 -0
  45. package/dist/cjs/post-tabs-2ec2778e.js.map +1 -0
  46. package/dist/cjs/post-tabs.cjs.entry.js +3 -3
  47. package/dist/cjs/{post-tooltip-2becc97a.js → post-tooltip-c802c51f.js} +78 -1754
  48. package/dist/cjs/post-tooltip-c802c51f.js.map +1 -0
  49. package/dist/cjs/post-tooltip.cjs.entry.js +3 -4
  50. package/dist/cjs/post-tooltip.cjs.entry.js.map +1 -1
  51. package/dist/collection/animations/collapse.js +5 -5
  52. package/dist/collection/animations/collapse.js.map +1 -1
  53. package/dist/collection/collection-manifest.json +5 -3
  54. package/dist/collection/components/post-accordion/post-accordion.js +167 -166
  55. package/dist/collection/components/post-accordion/post-accordion.js.map +1 -1
  56. package/dist/collection/components/post-alert/post-alert.css +2 -2
  57. package/dist/collection/components/post-alert/post-alert.js +246 -246
  58. package/dist/collection/components/post-alert/post-alert.js.map +1 -1
  59. package/dist/collection/components/post-collapsible/post-collapsible.css +1 -1
  60. package/dist/collection/components/post-collapsible/post-collapsible.js +170 -169
  61. package/dist/collection/components/post-collapsible/post-collapsible.js.map +1 -1
  62. package/dist/collection/components/post-icon/post-icon.css +1 -1
  63. package/dist/collection/components/post-icon/post-icon.js +250 -250
  64. package/dist/collection/components/post-icon/post-icon.js.map +1 -1
  65. package/dist/collection/components/post-popover/post-popover.css +3 -0
  66. package/dist/collection/components/post-popover/post-popover.js +267 -0
  67. package/dist/collection/components/post-popover/post-popover.js.map +1 -0
  68. package/dist/collection/components/post-popovercontainer/post-popovercontainer.css +1 -0
  69. package/dist/collection/components/post-popovercontainer/post-popovercontainer.js +288 -0
  70. package/dist/collection/components/post-popovercontainer/post-popovercontainer.js.map +1 -0
  71. package/dist/collection/components/post-tab-header/post-tab-header.css +1 -1
  72. package/dist/collection/components/post-tab-header/post-tab-header.js +62 -62
  73. package/dist/collection/components/post-tab-header/post-tab-header.js.map +1 -1
  74. package/dist/collection/components/post-tab-panel/post-tab-panel.js +50 -50
  75. package/dist/collection/components/post-tab-panel/post-tab-panel.js.map +1 -1
  76. package/dist/collection/components/post-tabs/post-tabs.css +1 -1
  77. package/dist/collection/components/post-tabs/post-tabs.js +224 -223
  78. package/dist/collection/components/post-tabs/post-tabs.js.map +1 -1
  79. package/dist/collection/components/post-tooltip/post-tooltip.css +1 -1
  80. package/dist/collection/components/post-tooltip/post-tooltip.js +192 -325
  81. package/dist/collection/components/post-tooltip/post-tooltip.js.map +1 -1
  82. package/dist/collection/index.js +3 -0
  83. package/dist/collection/index.js.map +1 -1
  84. package/dist/collection/utils/is-motion-reduced.js +1 -1
  85. package/dist/collection/utils/is-motion-reduced.js.map +1 -1
  86. package/dist/collection/utils/property-checkers/check-non-empty.js +3 -3
  87. package/dist/collection/utils/property-checkers/check-non-empty.js.map +1 -1
  88. package/dist/collection/utils/property-checkers/check-one-of.js +2 -2
  89. package/dist/collection/utils/property-checkers/check-one-of.js.map +1 -1
  90. package/dist/collection/utils/property-checkers/check-pattern.js +2 -2
  91. package/dist/collection/utils/property-checkers/check-pattern.js.map +1 -1
  92. package/dist/collection/utils/property-checkers/check-type.js +10 -10
  93. package/dist/collection/utils/property-checkers/check-type.js.map +1 -1
  94. package/dist/collection/utils/property-checkers/empty-or.js +5 -5
  95. package/dist/collection/utils/property-checkers/empty-or.js.map +1 -1
  96. package/dist/components/check-non-empty.js +3 -3
  97. package/dist/components/check-non-empty.js.map +1 -1
  98. package/dist/components/index.js +3 -0
  99. package/dist/components/index.js.map +1 -1
  100. package/dist/components/index2.js +22 -18
  101. package/dist/components/index2.js.map +1 -1
  102. package/dist/components/package.js +1 -1
  103. package/dist/components/post-accordion.d.ts +2 -2
  104. package/dist/components/post-accordion.js +1 -101
  105. package/dist/components/post-accordion.js.map +1 -1
  106. package/dist/components/post-accordion2.js +105 -0
  107. package/dist/components/post-accordion2.js.map +1 -0
  108. package/dist/components/post-alert.d.ts +2 -2
  109. package/dist/components/post-alert2.js +119 -119
  110. package/dist/components/post-alert2.js.map +1 -1
  111. package/dist/components/post-collapsible.d.ts +2 -2
  112. package/dist/components/post-collapsible2.js +91 -91
  113. package/dist/components/post-collapsible2.js.map +1 -1
  114. package/dist/components/post-icon.d.ts +2 -2
  115. package/dist/components/post-icon2.js +118 -118
  116. package/dist/components/post-icon2.js.map +1 -1
  117. package/dist/components/post-popover.d.ts +11 -0
  118. package/dist/components/post-popover.js +8 -0
  119. package/dist/components/post-popover.js.map +1 -0
  120. package/dist/components/post-popover2.js +144 -0
  121. package/dist/components/post-popover2.js.map +1 -0
  122. package/dist/components/post-popovercontainer.d.ts +11 -0
  123. package/dist/components/post-popovercontainer.js +8 -0
  124. package/dist/components/post-popovercontainer.js.map +1 -0
  125. package/dist/components/post-popovercontainer2.js +1897 -0
  126. package/dist/components/post-popovercontainer2.js.map +1 -0
  127. package/dist/components/post-tab-header.d.ts +2 -2
  128. package/dist/components/post-tab-header2.js +38 -38
  129. package/dist/components/post-tab-header2.js.map +1 -1
  130. package/dist/components/post-tab-panel.d.ts +2 -2
  131. package/dist/components/post-tab-panel2.js +30 -30
  132. package/dist/components/post-tab-panel2.js.map +1 -1
  133. package/dist/components/post-tabs.d.ts +2 -2
  134. package/dist/components/post-tabs2.js +147 -147
  135. package/dist/components/post-tabs2.js.map +1 -1
  136. package/dist/components/post-tooltip.d.ts +2 -2
  137. package/dist/components/post-tooltip2.js +100 -1774
  138. package/dist/components/post-tooltip2.js.map +1 -1
  139. package/dist/docs.d.ts +1 -21
  140. package/dist/docs.json +610 -78
  141. package/dist/esm/check-non-empty-58bd6b17.js +11 -0
  142. package/dist/esm/{check-non-empty-09c39561.js.map → check-non-empty-58bd6b17.js.map} +1 -1
  143. package/dist/esm/index-1427953c.js +40 -0
  144. package/dist/esm/index-1427953c.js.map +1 -0
  145. package/dist/esm/{index-08d62a75.js → index-35998e08.js} +79 -59
  146. package/dist/esm/index-35998e08.js.map +1 -0
  147. package/dist/esm/index.js +14 -12
  148. package/dist/esm/index.js.map +1 -1
  149. package/dist/esm/loader.js +3 -3
  150. package/dist/esm/package-337354c3.js +5 -0
  151. package/dist/esm/package-337354c3.js.map +1 -0
  152. package/dist/esm/post-accordion-c2013bb3.js +85 -0
  153. package/dist/esm/post-accordion-c2013bb3.js.map +1 -0
  154. package/dist/esm/post-accordion.entry.js +3 -83
  155. package/dist/esm/post-accordion.entry.js.map +1 -1
  156. package/dist/esm/post-alert-7254a70f.js +99 -0
  157. package/dist/esm/{post-alert-46926902.js.map → post-alert-7254a70f.js.map} +1 -1
  158. package/dist/esm/post-alert.entry.js +5 -6
  159. package/dist/esm/post-alert.entry.js.map +1 -1
  160. package/dist/esm/post-collapsible-4464cc98.js +91 -0
  161. package/dist/esm/post-collapsible-4464cc98.js.map +1 -0
  162. package/dist/esm/post-collapsible.entry.js +4 -5
  163. package/dist/esm/post-collapsible.entry.js.map +1 -1
  164. package/dist/esm/post-components.js +4 -4
  165. package/dist/esm/post-components.js.map +1 -1
  166. package/dist/esm/post-icon-e0bbf0f5.js +103 -0
  167. package/dist/esm/post-icon-e0bbf0f5.js.map +1 -0
  168. package/dist/esm/post-icon.entry.js +5 -6
  169. package/dist/esm/post-icon.entry.js.map +1 -1
  170. package/dist/esm/post-popover-25eb3f76.js +116 -0
  171. package/dist/esm/post-popover-25eb3f76.js.map +1 -0
  172. package/dist/esm/post-popover.entry.js +5 -0
  173. package/dist/esm/post-popover.entry.js.map +1 -0
  174. package/dist/esm/post-popovercontainer-54117eea.js +1876 -0
  175. package/dist/esm/post-popovercontainer-54117eea.js.map +1 -0
  176. package/dist/esm/post-popovercontainer.entry.js +5 -0
  177. package/dist/esm/post-popovercontainer.entry.js.map +1 -0
  178. package/dist/esm/post-tab-header-1684b507.js +31 -0
  179. package/dist/esm/{post-tab-header-84b12382.js.map → post-tab-header-1684b507.js.map} +1 -1
  180. package/dist/esm/post-tab-header.entry.js +4 -4
  181. package/dist/esm/post-tab-panel-add26fe5.js +25 -0
  182. package/dist/esm/{post-tab-panel-216c0b6e.js.map → post-tab-panel-add26fe5.js.map} +1 -1
  183. package/dist/esm/post-tab-panel.entry.js +3 -3
  184. package/dist/esm/post-tabs-d738e61f.js +151 -0
  185. package/dist/esm/post-tabs-d738e61f.js.map +1 -0
  186. package/dist/esm/post-tabs.entry.js +3 -3
  187. package/dist/esm/{post-tooltip-47f2146d.js → post-tooltip-57928808.js} +78 -1754
  188. package/dist/esm/post-tooltip-57928808.js.map +1 -0
  189. package/dist/esm/post-tooltip.entry.js +3 -4
  190. package/dist/esm/post-tooltip.entry.js.map +1 -1
  191. package/dist/post-components/index.esm.js +1 -1
  192. package/dist/post-components/p-05e85f2b.entry.js +2 -0
  193. package/dist/post-components/p-08abd53e.entry.js +2 -0
  194. package/dist/post-components/p-09892ad1.js +2 -0
  195. package/dist/post-components/{p-57b48dff.js.map → p-09892ad1.js.map} +1 -1
  196. package/dist/post-components/p-1e9ec4a9.entry.js +2 -0
  197. package/dist/post-components/p-1f55663e.js +2 -0
  198. package/dist/post-components/p-1f55663e.js.map +1 -0
  199. package/dist/post-components/p-30c60b6c.entry.js +2 -0
  200. package/dist/post-components/p-38d97f62.entry.js +2 -0
  201. package/dist/post-components/p-4c188911.entry.js +2 -0
  202. package/dist/post-components/p-568bb469.entry.js +2 -0
  203. package/dist/post-components/p-65c8bd5c.entry.js +2 -0
  204. package/dist/post-components/p-6e3158e8.js +2 -0
  205. package/dist/post-components/{p-21549a50.js.map → p-6e3158e8.js.map} +1 -1
  206. package/dist/post-components/p-7d32dfb7.js +2 -0
  207. package/dist/post-components/{p-57fdeeab.js.map → p-7d32dfb7.js.map} +1 -1
  208. package/dist/post-components/p-81591ad0.js +3 -0
  209. package/dist/post-components/p-81591ad0.js.map +1 -0
  210. package/dist/post-components/p-96f4ebc4.js +2 -0
  211. package/dist/post-components/p-96f4ebc4.js.map +1 -0
  212. package/dist/post-components/p-9bd5f824.js +2 -0
  213. package/dist/post-components/p-9bd5f824.js.map +1 -0
  214. package/dist/post-components/{p-b531475e.js → p-b095519d.js} +1 -1
  215. package/dist/post-components/p-b4b4f59a.js +2 -0
  216. package/dist/post-components/p-bd032124.js +2 -0
  217. package/dist/post-components/p-bd032124.js.map +1 -0
  218. package/dist/post-components/p-c5858d52.entry.js +2 -0
  219. package/dist/post-components/p-c5858d52.entry.js.map +1 -0
  220. package/dist/post-components/{p-ce907090.entry.js → p-dbd07f20.js} +2 -2
  221. package/dist/post-components/p-de493e36.js +2 -0
  222. package/dist/post-components/p-de493e36.js.map +1 -0
  223. package/dist/post-components/p-eaddd6cc.js +2 -0
  224. package/dist/post-components/p-eaddd6cc.js.map +1 -0
  225. package/dist/post-components/p-ed73d4c0.entry.js +2 -0
  226. package/dist/post-components/p-ed73d4c0.entry.js.map +1 -0
  227. package/dist/post-components/p-f994dce8.js +9 -0
  228. package/dist/post-components/p-f994dce8.js.map +1 -0
  229. package/dist/post-components/post-components.esm.js +1 -1
  230. package/dist/post-components/post-components.esm.js.map +1 -1
  231. package/dist/types/components/post-accordion/post-accordion.d.ts +26 -26
  232. package/dist/types/components/post-alert/post-alert.d.ts +45 -45
  233. package/dist/types/components/post-collapsible/post-collapsible.d.ts +31 -31
  234. package/dist/types/components/post-icon/post-icon.d.ts +43 -43
  235. package/dist/types/components/post-popover/post-popover.d.ts +53 -0
  236. package/dist/types/components/post-popovercontainer/post-popovercontainer.d.ts +62 -0
  237. package/dist/types/components/post-tab-header/post-tab-header.d.ts +9 -9
  238. package/dist/types/components/post-tab-panel/post-tab-panel.d.ts +8 -8
  239. package/dist/types/components/post-tabs/post-tabs.d.ts +32 -32
  240. package/dist/types/components/post-tooltip/post-tooltip.d.ts +35 -62
  241. package/dist/types/components.d.ts +115 -10
  242. package/dist/types/index.d.ts +3 -0
  243. package/dist/types/stencil-public-runtime.d.ts +8 -0
  244. package/package.json +16 -14
  245. package/dist/cjs/check-non-empty-ae713942.js.map +0 -1
  246. package/dist/cjs/check-one-of-27ad3154.js +0 -10
  247. package/dist/cjs/check-one-of-27ad3154.js.map +0 -1
  248. package/dist/cjs/index-b38a23e0.js +0 -41
  249. package/dist/cjs/index-b38a23e0.js.map +0 -1
  250. package/dist/cjs/index-e7618bb3.js.map +0 -1
  251. package/dist/cjs/package-041a8597.js +0 -7
  252. package/dist/cjs/package-041a8597.js.map +0 -1
  253. package/dist/cjs/post-alert-1fb90f2d.js +0 -101
  254. package/dist/cjs/post-collapsible-e46002bb.js +0 -93
  255. package/dist/cjs/post-collapsible-e46002bb.js.map +0 -1
  256. package/dist/cjs/post-icon-91f6603a.js +0 -105
  257. package/dist/cjs/post-icon-91f6603a.js.map +0 -1
  258. package/dist/cjs/post-tab-header-a3845fe5.js +0 -33
  259. package/dist/cjs/post-tab-panel-b7326ff8.js +0 -27
  260. package/dist/cjs/post-tabs-384a1fab.js +0 -153
  261. package/dist/cjs/post-tabs-384a1fab.js.map +0 -1
  262. package/dist/cjs/post-tooltip-2becc97a.js.map +0 -1
  263. package/dist/components/check-one-of.js +0 -8
  264. package/dist/components/check-one-of.js.map +0 -1
  265. package/dist/esm/check-non-empty-09c39561.js +0 -11
  266. package/dist/esm/check-one-of-74750af9.js +0 -8
  267. package/dist/esm/check-one-of-74750af9.js.map +0 -1
  268. package/dist/esm/index-08d62a75.js.map +0 -1
  269. package/dist/esm/index-35921354.js +0 -36
  270. package/dist/esm/index-35921354.js.map +0 -1
  271. package/dist/esm/package-a962a93d.js +0 -5
  272. package/dist/esm/package-a962a93d.js.map +0 -1
  273. package/dist/esm/post-alert-46926902.js +0 -99
  274. package/dist/esm/post-collapsible-f1b6592d.js +0 -91
  275. package/dist/esm/post-collapsible-f1b6592d.js.map +0 -1
  276. package/dist/esm/post-icon-fb627697.js +0 -103
  277. package/dist/esm/post-icon-fb627697.js.map +0 -1
  278. package/dist/esm/post-tab-header-84b12382.js +0 -31
  279. package/dist/esm/post-tab-panel-216c0b6e.js +0 -25
  280. package/dist/esm/post-tabs-e235d663.js +0 -151
  281. package/dist/esm/post-tabs-e235d663.js.map +0 -1
  282. package/dist/esm/post-tooltip-47f2146d.js.map +0 -1
  283. package/dist/post-components/p-03fe58da.js +0 -2
  284. package/dist/post-components/p-03fe58da.js.map +0 -1
  285. package/dist/post-components/p-1339f8cd.js +0 -2
  286. package/dist/post-components/p-1339f8cd.js.map +0 -1
  287. package/dist/post-components/p-151b55c0.entry.js +0 -2
  288. package/dist/post-components/p-21549a50.js +0 -2
  289. package/dist/post-components/p-4cb18ddf.js +0 -9
  290. package/dist/post-components/p-4cb18ddf.js.map +0 -1
  291. package/dist/post-components/p-4e24f13b.entry.js +0 -2
  292. package/dist/post-components/p-57b48dff.js +0 -2
  293. package/dist/post-components/p-57fdeeab.js +0 -2
  294. package/dist/post-components/p-58cc7b5a.entry.js +0 -2
  295. package/dist/post-components/p-6cafa644.entry.js +0 -2
  296. package/dist/post-components/p-7f370d77.entry.js +0 -2
  297. package/dist/post-components/p-7f4eba57.js +0 -2
  298. package/dist/post-components/p-8c006e7d.js +0 -3
  299. package/dist/post-components/p-8c006e7d.js.map +0 -1
  300. package/dist/post-components/p-aee47e1a.entry.js +0 -2
  301. package/dist/post-components/p-b5e1fd89.js +0 -2
  302. package/dist/post-components/p-b5e1fd89.js.map +0 -1
  303. package/dist/post-components/p-d13111f2.js +0 -2
  304. package/dist/post-components/p-dfe29f7f.js +0 -2
  305. package/dist/post-components/p-dfe29f7f.js.map +0 -1
  306. package/dist/post-components/p-f35c2075.entry.js +0 -2
  307. /package/dist/post-components/{p-151b55c0.entry.js.map → p-05e85f2b.entry.js.map} +0 -0
  308. /package/dist/post-components/{p-4e24f13b.entry.js.map → p-08abd53e.entry.js.map} +0 -0
  309. /package/dist/post-components/{p-58cc7b5a.entry.js.map → p-1e9ec4a9.entry.js.map} +0 -0
  310. /package/dist/post-components/{p-6cafa644.entry.js.map → p-30c60b6c.entry.js.map} +0 -0
  311. /package/dist/post-components/{p-7f370d77.entry.js.map → p-38d97f62.entry.js.map} +0 -0
  312. /package/dist/post-components/{p-aee47e1a.entry.js.map → p-4c188911.entry.js.map} +0 -0
  313. /package/dist/post-components/{p-d13111f2.js.map → p-568bb469.entry.js.map} +0 -0
  314. /package/dist/post-components/{p-f35c2075.entry.js.map → p-65c8bd5c.entry.js.map} +0 -0
  315. /package/dist/post-components/{p-b531475e.js.map → p-b095519d.js.map} +0 -0
  316. /package/dist/post-components/{p-7f4eba57.js.map → p-b4b4f59a.js.map} +0 -0
  317. /package/dist/post-components/{p-ce907090.entry.js.map → p-dbd07f20.js.map} +0 -0
@@ -3,113 +3,113 @@ import { v as version } from './package.js';
3
3
  import { d as checkEmptyOrType, b as checkEmptyOrOneOf } from './index2.js';
4
4
 
5
5
  function isMotionReduced() {
6
- return window.matchMedia('(prefers-reduced-motion: reduce)').matches;
6
+ return window.matchMedia('(prefers-reduced-motion: reduce)').matches;
7
7
  }
8
8
 
9
9
  const collapseDuration = 350;
10
10
  const collapseEasing = 'ease';
11
11
  const collapsedKeyframe = { height: '0', overflow: 'hidden' };
12
12
  const collapse = (el) => {
13
- const { height } = window.getComputedStyle(el);
14
- const expandedKeyframe = { height };
15
- return el.animate([expandedKeyframe, collapsedKeyframe], { duration: collapseDuration, easing: collapseEasing, fill: 'forwards' });
13
+ const { height } = window.getComputedStyle(el);
14
+ const expandedKeyframe = { height };
15
+ return el.animate([expandedKeyframe, collapsedKeyframe], { duration: collapseDuration, easing: collapseEasing, fill: 'forwards' });
16
16
  };
17
17
  const expand = (el) => {
18
- const expandedKeyframe = { height: `${el.scrollHeight}px` };
19
- return el.animate([collapsedKeyframe, expandedKeyframe], { duration: collapseDuration, easing: collapseEasing, fill: 'forwards' });
18
+ const expandedKeyframe = { height: `${el.scrollHeight}px` };
19
+ return el.animate([collapsedKeyframe, expandedKeyframe], { duration: collapseDuration, easing: collapseEasing, fill: 'forwards' });
20
20
  };
21
21
 
22
22
  const HEADING_LEVELS = [1, 2, 3, 4, 5, 6];
23
23
 
24
- const postCollapsibleCss = ".accordion-item{border-block-start:2px solid #e6e6e6}.accordion-header{font-size:1.0625rem;font-weight:700;line-height:1.5;margin:0}@media (min-width: 1024px){.accordion-header{font-size:1.25rem}}.accordion-button{padding:0;overflow:visible;border:0;background:none;color:inherit;font:inherit;-webkit-user-select:none;user-select:none;-webkit-appearance:button;appearance:button;width:100%;position:relative;padding-block:1rem;padding-inline-start:1rem;padding-inline-end:2.5rem;text-align:start}.accordion-button:not(:disabled){cursor:pointer}.accordion-button:disabled{opacity:.4}.accordion-button:focus{outline:none;box-shadow:0 0 0 .125rem rgba(51,51,51,.25)}.accordion-button::after{-webkit-mask-image:url(\"data:image/svg+xml,%3Csvg xml:space='preserve' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cg id='icon'%3E%3Cpath d='m23.6 18.3-.9.9-6.7-6.6-6.6 6.6-.9-.9 7.5-7.6 7.6 7.6z'/%3E%3C/g%3E%3C/svg%3E\");mask-image:url(\"data:image/svg+xml,%3Csvg xml:space='preserve' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cg id='icon'%3E%3Cpath d='m23.6 18.3-.9.9-6.7-6.6-6.6 6.6-.9-.9 7.5-7.6 7.6 7.6z'/%3E%3C/g%3E%3C/svg%3E\");background-color:currentColor;content:\"\";display:block;height:1.5rem;width:1.5rem;position:absolute;inset-inline-end:1rem;inset-block-start:50%;transform:translateY(-50%);transition:transform 250ms cubic-bezier(0.4, 0, 0.2, 1);border:1px solid rgb(var(--post-bg-rgb, 255, 255, 255))}.accordion-button.collapsed::after{transform:translateY(-50%) rotate(-180deg)}.accordion-button>.text-truncate{display:block}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.accordion-button:hover:not(:disabled),.accordion-button:focus-visible:not(:disabled){outline:2px solid Highlight}.accordion-button:disabled{opacity:1 !important}}.accordion-body{padding:.75rem 1rem 2.5rem;border-block-start:2px solid #e6e6e6}.accordion-body h1,.accordion-body .h1{font-size:1.0625rem;margin:2.5rem 0 0;font-weight:700}@media (min-width: 1024px){.accordion-body h1,.accordion-body .h1{font-size:1.25rem}}.accordion-body h2,.accordion-body .h2{font-size:1.0625rem;margin:2.5rem 0 0;font-weight:700}@media (min-width: 1024px){.accordion-body h2,.accordion-body .h2{font-size:1.25rem}}.accordion-body h3,.accordion-body .h3{font-size:1.0625rem;margin:2.5rem 0 0;font-weight:700}@media (min-width: 1024px){.accordion-body h3,.accordion-body .h3{font-size:1.25rem}}.accordion-body h4,.accordion-body .h4{font-size:1.0625rem;margin:2.5rem 0 0;font-weight:700}@media (min-width: 1024px){.accordion-body h4,.accordion-body .h4{font-size:1.25rem}}.accordion-body h5,.accordion-body .h5{font-size:1.0625rem;margin:2.5rem 0 0;font-weight:700}@media (min-width: 1024px){.accordion-body h5,.accordion-body .h5{font-size:1.25rem}}.accordion-body h6,.accordion-body .h6{font-size:1.0625rem;margin:2.5rem 0 0;font-weight:700}@media (min-width: 1024px){.accordion-body h6,.accordion-body .h6{font-size:1.25rem}}.accordion-button>:first-child,.accordion-body>:first-child{margin-block-start:0 !important}.accordion-button>:last-child,.accordion-body>:last-child{margin-block-end:0 !important}:host{display:block}:host .accordion-button>::slotted(.text-truncate){display:block}";
24
+ const postCollapsibleCss = ".accordion-item,.bg-light .accordion-item,.bg-gray .accordion-item{--post-bg-opacity:1;background-color:rgba(var(--post-bg-rgb), var(--post-bg-opacity)) !important;color:var(--post-contrast-color) !important}.accordion-item,.bg-light .accordion-item,.bg-gray .accordion-item{--post-contrast-color:#000;--post-contrast-color-inverted:#fff;--post-gray-10:hsl(0, 0%, 90%);--post-gray-20:hsl(0, 0%, 80%);--post-gray-40:hsl(0, 0%, 60%);--post-gray-60:hsl(0, 0%, 40%);--post-gray-80:hsl(0, 0%, 20%);--post-yellow:#fc0;--post-light:#faf9f8;--post-gray:#f4f3f1;--post-dark:hsl(0, 0%, 20%);--post-primary:hsl(0, 0%, 20%);--post-white:#fff;--post-black:#000;--post-info:#cce4ee;--post-success:#2c911c;--post-warning:#f49e00;--post-danger:#a51728;--post-nightblue:#004976;--post-nightblue-bright:#0076a8;--post-petrol:#006d68;--post-petrol-bright:#00968f;--post-coral:#9e2a2f;--post-coral-bright:#e03c31;--post-olive:#716135;--post-olive-bright:#aa9d2e;--post-purple:#80276c;--post-purple-bright:#c5299b;--post-aubergine:#523178;--post-aubergine-bright:#7566a0;--post-success-green:#2c871d;--post-error-red:#a51728;--post-warning-orange:#f49e00;--post-success-background:#c0debb;--post-error-background:#ffdade;--post-warning-background:#fce2b2;--post-contrast-color-rgb:0, 0, 0;--post-contrast-color-inverted-rgb:255, 255, 255;--post-gray-10-rgb:230, 230, 230;--post-gray-20-rgb:204, 204, 204;--post-gray-40-rgb:153, 153, 153;--post-gray-60-rgb:102, 102, 102;--post-gray-80-rgb:51, 51, 51;--post-yellow-rgb:255, 204, 0;--post-light-rgb:250, 249, 248;--post-gray-rgb:244, 243, 241;--post-dark-rgb:51, 51, 51;--post-primary-rgb:51, 51, 51;--post-white-rgb:255, 255, 255;--post-black-rgb:0, 0, 0;--post-info-rgb:204, 228, 238;--post-success-rgb:44, 145, 28;--post-warning-rgb:244, 158, 0;--post-danger-rgb:165, 23, 40;--post-nightblue-rgb:0, 73, 118;--post-nightblue-bright-rgb:0, 118, 168;--post-petrol-rgb:0, 109, 104;--post-petrol-bright-rgb:0, 150, 143;--post-coral-rgb:158, 42, 47;--post-coral-bright-rgb:224, 60, 49;--post-olive-rgb:113, 97, 53;--post-olive-bright-rgb:170, 157, 46;--post-purple-rgb:128, 39, 108;--post-purple-bright-rgb:197, 41, 155;--post-aubergine-rgb:82, 49, 120;--post-aubergine-bright-rgb:117, 102, 160;--post-success-green-rgb:44, 135, 29;--post-error-red-rgb:165, 23, 40;--post-warning-orange-rgb:244, 158, 0;--post-success-background-rgb:192, 222, 187;--post-error-background-rgb:255, 218, 222;--post-warning-background-rgb:252, 226, 178}.accordion-item{border-block:2px solid #666;--post-bg-rgb:244, 243, 241}.accordion-item+.accordion-item{border-block-start:0}.bg-light .accordion-item{--post-bg-rgb:255, 255, 255}.bg-gray .accordion-item{--post-bg-rgb:255, 255, 255}.accordion-header{color:#333;font-size:1rem;font-weight:700;line-height:1.5;margin:0}.accordion-button{padding:0;overflow:visible;border:0;background:none;color:inherit;font:inherit;-webkit-user-select:none;user-select:none;-webkit-appearance:button;appearance:button;outline:none;width:100%;position:relative;padding-block:1rem;padding-inline-start:1rem;padding-inline-end:3rem;text-align:start;transition:opacity 250ms,border-color 250ms,background-color 250ms,color 250ms}.accordion-button:focus-visible{outline:2px solid #1976c8}.accordion-button:hover{color:#000;background-color:#e6e6e6}.accordion-button:disabled{opacity:.4;pointer-events:none}.accordion-button::after{-webkit-mask-image:url(\"data:image/svg+xml,%3Csvg xml:space='preserve' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cg id='icon'%3E%3Cpath d='m23.6 18.3-.9.9-6.7-6.6-6.6 6.6-.9-.9 7.5-7.6z'/%3E%3C/g%3E%3C/svg%3E\");mask-image:url(\"data:image/svg+xml,%3Csvg xml:space='preserve' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cg id='icon'%3E%3Cpath d='m23.6 18.3-.9.9-6.7-6.6-6.6 6.6-.9-.9 7.5-7.6z'/%3E%3C/g%3E%3C/svg%3E\");background-color:currentColor;content:\"\";display:block;height:1.5rem;width:1.5rem;position:absolute;inset-inline-end:1rem;inset-block-start:50%;transform:translateY(-50%);transition:transform 250ms cubic-bezier(0.4, 0, 0.2, 1)}.accordion-button.collapsed::after{transform:translateY(-50%) rotate(-180deg)}.accordion-button>.text-truncate{display:block}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.accordion-button:hover:not(:disabled),.accordion-button:focus-visible:not(:disabled){outline:2px solid Highlight}.accordion-button:disabled{opacity:1 !important}}.accordion-body{padding:.5rem 1rem 1rem;font-weight:300}.accordion-button>*,.accordion-body>:first-child{margin-block-start:0 !important}.accordion-button>*,.accordion-body>:last-child{margin-block-end:0 !important}:host{display:block}.accordion-button{cursor:pointer}.accordion-button>::slotted(.text-truncate){display:block}post-collapsible+post-collapsible::part(accordion-item){border-block-start:0 !important}";
25
25
 
26
26
  const PostCollapsible = /*@__PURE__*/ proxyCustomElement(class PostCollapsible extends HTMLElement {
27
- constructor() {
28
- super();
29
- this.__registerHost();
30
- this.__attachShadow();
31
- this.collapseChange = createEvent(this, "collapseChange", 7);
32
- this.isLoaded = false;
33
- this.id = undefined;
34
- this.isOpen = true;
35
- this.hasHeader = undefined;
36
- this.headingTag = undefined;
37
- this.collapsed = false;
38
- this.headingLevel = 2;
39
- }
40
- validateCollapsed(newValue = this.collapsed) {
41
- checkEmptyOrType(newValue, 'boolean', 'The `collapsed` property of the `post-collapsible` must be a boolean.');
42
- }
43
- validateHeadingLevel(newValue = this.headingLevel) {
44
- checkEmptyOrOneOf(newValue, HEADING_LEVELS, 'The `headingLevel` property of the `post-collapsible` must be a number between 1 and 6.');
45
- }
46
- connectedCallback() {
47
- this.validateCollapsed();
48
- this.validateHeadingLevel();
49
- }
50
- componentWillRender() {
51
- var _a;
52
- this.id = this.host.id || `c${crypto.randomUUID()}`;
53
- this.hasHeader = this.host.querySelectorAll('[slot="header"]').length > 0;
54
- this.headingTag = `h${(_a = this.headingLevel) !== null && _a !== void 0 ? _a : 2}`;
55
- }
56
- componentDidLoad() {
57
- if (this.collapsed)
58
- void this.toggle(false);
59
- this.isLoaded = true;
60
- }
61
- /**
62
- * Triggers the collapse programmatically.
63
- *
64
- * If there is a collapsing transition running already, it will be reversed.
65
- */
66
- async toggle(open = !this.isOpen) {
67
- if (open === this.isOpen)
68
- return open;
69
- this.isOpen = !this.isOpen;
70
- if (this.isLoaded)
71
- this.collapseChange.emit();
72
- const animation = open ? expand(this.collapsible) : collapse(this.collapsible);
73
- if (!this.isLoaded || isMotionReduced())
74
- animation.finish();
75
- await animation.finished;
76
- animation.commitStyles();
77
- return this.isOpen;
78
- }
79
- render() {
80
- const collapse = (h("div", { "aria-labelledby": this.hasHeader ? `${this.id}--header` : undefined, class: `collapse${this.hasHeader ? ' accordion-collapse' : ''}`, id: `${this.id}--collapse`, ref: el => this.collapsible = el }, this.hasHeader ? (h("div", { class: "accordion-body" }, h("slot", null))) : (h("slot", null))));
81
- return (h(Host, { id: this.id, "data-version": version }, this.hasHeader ? (h("div", { class: "accordion-item" }, h(this.headingTag, { class: "accordion-header", id: `${this.id}--header` }, h("button", { "aria-controls": `${this.id}--collapse`, "aria-expanded": `${this.isOpen}`, class: `accordion-button${this.isOpen ? '' : ' collapsed'}`, onClick: () => this.toggle(), type: "button" }, h("slot", { name: "header" }))), collapse)) : collapse));
82
- }
83
- get host() { return this; }
84
- static get watchers() { return {
85
- "collapsed": ["validateCollapsed"],
86
- "headingLevel": ["validateHeadingLevel"]
87
- }; }
88
- static get style() { return postCollapsibleCss; }
27
+ constructor() {
28
+ super();
29
+ this.__registerHost();
30
+ this.__attachShadow();
31
+ this.collapseChange = createEvent(this, "collapseChange", 7);
32
+ this.isLoaded = false;
33
+ this.id = undefined;
34
+ this.isOpen = true;
35
+ this.hasHeader = undefined;
36
+ this.headingTag = undefined;
37
+ this.collapsed = false;
38
+ this.headingLevel = 2;
39
+ }
40
+ validateCollapsed(newValue = this.collapsed) {
41
+ checkEmptyOrType(newValue, 'boolean', 'The `collapsed` property of the `post-collapsible` must be a boolean.');
42
+ }
43
+ validateHeadingLevel(newValue = this.headingLevel) {
44
+ checkEmptyOrOneOf(newValue, HEADING_LEVELS, 'The `headingLevel` property of the `post-collapsible` must be a number between 1 and 6.');
45
+ }
46
+ connectedCallback() {
47
+ this.validateCollapsed();
48
+ this.validateHeadingLevel();
49
+ }
50
+ componentWillRender() {
51
+ var _a;
52
+ this.id = this.host.id || `c${crypto.randomUUID()}`;
53
+ this.hasHeader = this.host.querySelectorAll('[slot="header"]').length > 0;
54
+ this.headingTag = `h${(_a = this.headingLevel) !== null && _a !== void 0 ? _a : 2}`;
55
+ }
56
+ componentDidLoad() {
57
+ if (this.collapsed)
58
+ void this.toggle(false);
59
+ this.isLoaded = true;
60
+ }
61
+ /**
62
+ * Triggers the collapse programmatically.
63
+ *
64
+ * If there is a collapsing transition running already, it will be reversed.
65
+ */
66
+ async toggle(open = !this.isOpen) {
67
+ if (open === this.isOpen)
68
+ return open;
69
+ this.isOpen = !this.isOpen;
70
+ if (this.isLoaded)
71
+ this.collapseChange.emit();
72
+ const animation = open ? expand(this.collapsible) : collapse(this.collapsible);
73
+ if (!this.isLoaded || isMotionReduced())
74
+ animation.finish();
75
+ await animation.finished;
76
+ animation.commitStyles();
77
+ return this.isOpen;
78
+ }
79
+ render() {
80
+ const collapse = (h("div", { "aria-labelledby": this.hasHeader ? `${this.id}--header` : undefined, class: `collapse${this.hasHeader ? ' accordion-collapse' : ''}`, id: `${this.id}--collapse`, ref: el => (this.collapsible = el) }, this.hasHeader ? (h("div", { class: "accordion-body" }, h("slot", null))) : (h("slot", null))));
81
+ return (h(Host, { id: this.id, "data-version": version }, this.hasHeader ? (h("div", { part: "accordion-item", class: "accordion-item" }, h(this.headingTag, { class: "accordion-header", id: `${this.id}--header` }, h("button", { "aria-controls": `${this.id}--collapse`, "aria-expanded": `${this.isOpen}`, class: `accordion-button${this.isOpen ? '' : ' collapsed'}`, onClick: () => this.toggle(), type: "button" }, h("slot", { name: "header" }))), collapse)) : (collapse)));
82
+ }
83
+ get host() { return this; }
84
+ static get watchers() { return {
85
+ "collapsed": ["validateCollapsed"],
86
+ "headingLevel": ["validateHeadingLevel"]
87
+ }; }
88
+ static get style() { return postCollapsibleCss; }
89
89
  }, [1, "post-collapsible", {
90
- "collapsed": [4],
91
- "headingLevel": [2, "heading-level"],
92
- "id": [32],
93
- "isOpen": [32],
94
- "hasHeader": [32],
95
- "headingTag": [32],
96
- "toggle": [64]
97
- }, undefined, {
98
- "collapsed": ["validateCollapsed"],
99
- "headingLevel": ["validateHeadingLevel"]
100
- }]);
90
+ "collapsed": [4],
91
+ "headingLevel": [2, "heading-level"],
92
+ "id": [32],
93
+ "isOpen": [32],
94
+ "hasHeader": [32],
95
+ "headingTag": [32],
96
+ "toggle": [64]
97
+ }, undefined, {
98
+ "collapsed": ["validateCollapsed"],
99
+ "headingLevel": ["validateHeadingLevel"]
100
+ }]);
101
101
  function defineCustomElement() {
102
- if (typeof customElements === "undefined") {
103
- return;
104
- }
105
- const components = ["post-collapsible"];
106
- components.forEach(tagName => { switch (tagName) {
107
- case "post-collapsible":
108
- if (!customElements.get(tagName)) {
109
- customElements.define(tagName, PostCollapsible);
110
- }
111
- break;
112
- } });
102
+ if (typeof customElements === "undefined") {
103
+ return;
104
+ }
105
+ const components = ["post-collapsible"];
106
+ components.forEach(tagName => { switch (tagName) {
107
+ case "post-collapsible":
108
+ if (!customElements.get(tagName)) {
109
+ customElements.define(tagName, PostCollapsible);
110
+ }
111
+ break;
112
+ } });
113
113
  }
114
114
 
115
115
  export { PostCollapsible as P, defineCustomElement as d };
@@ -1 +1 @@
1
- {"file":"post-collapsible2.js","mappings":";;;;SAAgB,eAAe;EAC7B,OAAO,MAAM,CAAC,UAAU,CAAC,kCAAkC,CAAC,CAAC,OAAO,CAAC;AACvE;;ACFA,MAAM,gBAAgB,GAAG,GAAG,CAAC;AAC7B,MAAM,cAAc,GAAG,MAAM,CAAC;AAC9B,MAAM,iBAAiB,GAAa,EAAE,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC;AAEjE,MAAM,QAAQ,GAAG,CAAC,EAAe;EACtC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC;EAC/C,MAAM,gBAAgB,GAAa,EAAE,MAAM,EAAE,CAAC;EAE9C,OAAO,EAAE,CAAC,OAAO,CACf,CAAC,gBAAgB,EAAE,iBAAiB,CAAC,EACrC,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,UAAU,EAAE,CACzE,CAAC;AACJ,CAAC,CAAC;AAEK,MAAM,MAAM,GAAG,CAAC,EAAe;EACpC,MAAM,gBAAgB,GAAa,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,YAAY,IAAI,EAAE,CAAC;EAEtE,OAAO,EAAE,CAAC,OAAO,CACf,CAAC,iBAAiB,EAAE,gBAAgB,CAAC,EACrC,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,UAAU,EAAE,CACzE,CAAC;AACJ,CAAC;;ACrBM,MAAM,cAAc,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAU;;ACAzD,MAAM,kBAAkB,GAAG,sqGAAsqG;;MCWprG,eAAe;;;;;;IAClB,aAAQ,GAAG,KAAK,CAAC;;kBAMP,IAAI;;;qBAOiB,KAAK;wBAUG,CAAC;;EAPhD,iBAAiB,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS;IACzC,gBAAgB,CAAC,QAAQ,EAAE,SAAS,EAAE,uEAAuE,CAAC,CAAC;GAChH;EAQD,oBAAoB,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY;IAC/C,iBAAiB,CAAC,QAAQ,EAAE,cAAc,EAAE,yFAAyF,CAAC,CAAC;GACxI;EAOD,iBAAiB;IACf,IAAI,CAAC,iBAAiB,EAAE,CAAC;IACzB,IAAI,CAAC,oBAAoB,EAAE,CAAC;GAC7B;EAED,mBAAmB;;IACjB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,IAAI,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC;IACpD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IAC1E,IAAI,CAAC,UAAU,GAAG,IAAI,MAAA,IAAI,CAAC,YAAY,mCAAI,CAAC,EAAE,CAAC;GAChD;EAED,gBAAgB;IACd,IAAI,IAAI,CAAC,SAAS;MAAE,KAAK,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC5C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;GACtB;;;;;;EAQD,MAAM,MAAM,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM;IAC9B,IAAI,IAAI,KAAK,IAAI,CAAC,MAAM;MAAE,OAAO,IAAI,CAAC;IAEtC,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC;IAC3B,IAAI,IAAI,CAAC,QAAQ;MAAE,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAE9C,MAAM,SAAS,GAAG,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,GAAE,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAE9E,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,eAAe,EAAE;MAAE,SAAS,CAAC,MAAM,EAAE,CAAC;IAE5D,MAAM,SAAS,CAAC,QAAQ,CAAC;IAEzB,SAAS,CAAC,YAAY,EAAE,CAAC;IAEzB,OAAO,IAAI,CAAC,MAAM,CAAC;GACpB;EAED,MAAM;IACJ,MAAM,QAAQ,IACZ,8BACmB,IAAI,CAAC,SAAS,GAAG,GAAG,IAAI,CAAC,EAAE,UAAU,GAAG,SAAS,EAClE,KAAK,EAAE,WAAW,IAAI,CAAC,SAAS,GAAG,qBAAqB,GAAG,EAAE,EAAE,EAC/D,EAAE,EAAE,GAAG,IAAI,CAAC,EAAE,YAAY,EAC1B,GAAG,EAAE,EAAE,IAAI,IAAI,CAAC,WAAW,GAAG,EAAE,IAE/B,IAAI,CAAC,SAAS,IACb,WAAK,KAAK,EAAC,gBAAgB,IACzB,eAAO,CACH,KAEN,eAAO,CACR,CACG,CACP,CAAC;IAEF,QACE,EAAC,IAAI,IAAC,EAAE,EAAE,IAAI,CAAC,EAAE,kBAAgB,OAAO,IACrC,IAAI,CAAC,SAAS,IACb,WAAK,KAAK,EAAC,gBAAgB,IACzB,EAAC,IAAI,CAAC,UAAU,IAAC,KAAK,EAAC,kBAAkB,EAAC,EAAE,EAAE,GAAG,IAAI,CAAC,EAAE,UAAU,IAChE,+BACiB,GAAG,IAAI,CAAC,EAAE,YAAY,mBACtB,GAAG,IAAI,CAAC,MAAM,EAAE,EAC/B,KAAK,EAAE,mBAAmB,IAAI,CAAC,MAAM,GAAG,EAAE,GAAG,YAAY,EAAE,EAC3D,OAAO,EAAE,MAAM,IAAI,CAAC,MAAM,EAAE,EAC5B,IAAI,EAAC,QAAQ,IAEb,YAAM,IAAI,EAAC,QAAQ,GAAE,CACd,CACO,EAEjB,QAAQ,CACL,IACJ,QAAQ,CACP,EACP;GACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":[],"sources":["src/utils/is-motion-reduced.ts","src/animations/collapse.ts","src/components/post-collapsible/heading-levels.ts","src/components/post-collapsible/post-collapsible.scss?tag=post-collapsible&encapsulation=shadow","src/components/post-collapsible/post-collapsible.tsx"],"sourcesContent":["export function isMotionReduced(): boolean {\n return window.matchMedia('(prefers-reduced-motion: reduce)').matches;\n}\n","const collapseDuration = 350;\nconst collapseEasing = 'ease';\nconst collapsedKeyframe: Keyframe = { height: '0', overflow: 'hidden' };\n\nexport const collapse = (el: HTMLElement): Animation => {\n const { height } = window.getComputedStyle(el);\n const expandedKeyframe: Keyframe = { height };\n\n return el.animate(\n [expandedKeyframe, collapsedKeyframe],\n { duration: collapseDuration, easing: collapseEasing, fill: 'forwards' },\n );\n};\n\nexport const expand = (el: HTMLElement): Animation => {\n const expandedKeyframe: Keyframe = { height: `${el.scrollHeight}px` };\n\n return el.animate(\n [collapsedKeyframe, expandedKeyframe],\n { duration: collapseDuration, easing: collapseEasing, fill: 'forwards' },\n );\n};\n","export const HEADING_LEVELS = [1, 2, 3, 4, 5, 6] as const;\n\nexport type HeadingLevel = typeof HEADING_LEVELS[number];\n","@use '@swisspost/design-system-styles/components/accordion';\n\n:host {\n display: block;\n\n .accordion-button > ::slotted(.text-truncate) {\n display: block;\n }\n}\n","import { Component, Element, Event, EventEmitter, h, Host, Method, Prop, State, Watch } from '@stencil/core';\nimport { version } from '../../../package.json';\nimport { collapse, expand } from '../../animations/collapse';\nimport { checkEmptyOrOneOf, checkEmptyOrType, isMotionReduced } from '../../utils';\nimport { HEADING_LEVELS, HeadingLevel } from './heading-levels';\n\n@Component({\n tag: 'post-collapsible',\n styleUrl: 'post-collapsible.scss',\n shadow: true,\n})\nexport class PostCollapsible {\n private isLoaded = false;\n private collapsible: HTMLElement;\n\n @Element() host: HTMLPostCollapsibleElement;\n\n @State() id: string;\n @State() isOpen = true;\n @State() hasHeader: boolean;\n @State() headingTag: string;\n\n /**\n * If `true`, the element is initially collapsed otherwise it is displayed.\n */\n @Prop() readonly collapsed?: boolean = false;\n\n @Watch('collapsed')\n validateCollapsed(newValue = this.collapsed) {\n checkEmptyOrType(newValue, 'boolean', 'The `collapsed` property of the `post-collapsible` must be a boolean.');\n }\n\n /**\n * Defines the hierarchical level of the collapsible header within the headings structure.\n */\n @Prop() readonly headingLevel?: HeadingLevel = 2;\n\n @Watch('headingLevel')\n validateHeadingLevel(newValue = this.headingLevel) {\n checkEmptyOrOneOf(newValue, HEADING_LEVELS, 'The `headingLevel` property of the `post-collapsible` must be a number between 1 and 6.');\n }\n\n /**\n * An event emitted when the collapse element is shown or hidden, before the transition. It has no payload.\n */\n @Event() collapseChange: EventEmitter<void>;\n\n connectedCallback() {\n this.validateCollapsed();\n this.validateHeadingLevel();\n }\n\n componentWillRender() {\n this.id = this.host.id || `c${crypto.randomUUID()}`;\n this.hasHeader = this.host.querySelectorAll('[slot=\"header\"]').length > 0;\n this.headingTag = `h${this.headingLevel ?? 2}`;\n }\n\n componentDidLoad() {\n if (this.collapsed) void this.toggle(false);\n this.isLoaded = true;\n }\n\n /**\n * Triggers the collapse programmatically.\n *\n * If there is a collapsing transition running already, it will be reversed.\n */\n @Method()\n async toggle(open = !this.isOpen): Promise<boolean> {\n if (open === this.isOpen) return open;\n\n this.isOpen = !this.isOpen;\n if (this.isLoaded) this.collapseChange.emit();\n\n const animation = open ? expand(this.collapsible): collapse(this.collapsible);\n\n if (!this.isLoaded || isMotionReduced()) animation.finish();\n\n await animation.finished;\n\n animation.commitStyles();\n\n return this.isOpen;\n }\n\n render() {\n const collapse = (\n <div\n aria-labelledby={this.hasHeader ? `${this.id}--header` : undefined}\n class={`collapse${this.hasHeader ? ' accordion-collapse' : ''}`}\n id={`${this.id}--collapse`}\n ref={el => this.collapsible = el}\n >\n {this.hasHeader ? (\n <div class=\"accordion-body\">\n <slot/>\n </div>\n ) : (\n <slot/>\n )}\n </div>\n );\n\n return (\n <Host id={this.id} data-version={version}>\n {this.hasHeader ? (\n <div class=\"accordion-item\">\n <this.headingTag class=\"accordion-header\" id={`${this.id}--header`}>\n <button\n aria-controls={`${this.id}--collapse`}\n aria-expanded={`${this.isOpen}`}\n class={`accordion-button${this.isOpen ? '' : ' collapsed'}`}\n onClick={() => this.toggle()}\n type=\"button\"\n >\n <slot name=\"header\"/>\n </button>\n </this.headingTag>\n\n {collapse}\n </div>\n ) : collapse}\n </Host>\n );\n }\n}\n"],"version":3}
1
+ {"file":"post-collapsible2.js","mappings":"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","names":[],"sources":["src/utils/is-motion-reduced.ts","src/animations/collapse.ts","src/components/post-collapsible/heading-levels.ts","src/components/post-collapsible/post-collapsible.scss?tag=post-collapsible&encapsulation=shadow","src/components/post-collapsible/post-collapsible.tsx"],"sourcesContent":["export function isMotionReduced(): boolean {\n return window.matchMedia('(prefers-reduced-motion: reduce)').matches;\n}\n","const collapseDuration = 350;\nconst collapseEasing = 'ease';\nconst collapsedKeyframe: Keyframe = { height: '0', overflow: 'hidden' };\n\nexport const collapse = (el: HTMLElement): Animation => {\n const { height } = window.getComputedStyle(el);\n const expandedKeyframe: Keyframe = { height };\n\n return el.animate(\n [expandedKeyframe, collapsedKeyframe],\n { duration: collapseDuration, easing: collapseEasing, fill: 'forwards' },\n );\n};\n\nexport const expand = (el: HTMLElement): Animation => {\n const expandedKeyframe: Keyframe = { height: `${el.scrollHeight}px` };\n\n return el.animate(\n [collapsedKeyframe, expandedKeyframe],\n { duration: collapseDuration, easing: collapseEasing, fill: 'forwards' },\n );\n};\n","export const HEADING_LEVELS = [1, 2, 3, 4, 5, 6] as const;\n\nexport type HeadingLevel = typeof HEADING_LEVELS[number];\n","@use '@swisspost/design-system-styles/components/accordion';\n\n:host {\n display: block;\n}\n\n.accordion-button {\n cursor: pointer;\n\n > ::slotted(.text-truncate) {\n display: block;\n }\n}\n\npost-collapsible + post-collapsible::part(accordion-item) {\n border-block-start: 0!important;\n}\n","import {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Method,\n Prop,\n State,\n Watch,\n} from '@stencil/core';\nimport { version } from '../../../package.json';\nimport { collapse, expand } from '../../animations/collapse';\nimport { checkEmptyOrOneOf, checkEmptyOrType, isMotionReduced } from '../../utils';\nimport { HEADING_LEVELS, HeadingLevel } from './heading-levels';\n\n@Component({\n tag: 'post-collapsible',\n styleUrl: 'post-collapsible.scss',\n shadow: true,\n})\nexport class PostCollapsible {\n private isLoaded = false;\n private collapsible: HTMLElement;\n\n @Element() host: HTMLPostCollapsibleElement;\n\n @State() id: string;\n @State() isOpen = true;\n @State() hasHeader: boolean;\n @State() headingTag: string;\n\n /**\n * If `true`, the element is initially collapsed otherwise it is displayed.\n */\n @Prop() readonly collapsed?: boolean = false;\n\n @Watch('collapsed')\n validateCollapsed(newValue = this.collapsed) {\n checkEmptyOrType(\n newValue,\n 'boolean',\n 'The `collapsed` property of the `post-collapsible` must be a boolean.',\n );\n }\n\n /**\n * Defines the hierarchical level of the collapsible header within the headings structure.\n */\n @Prop() readonly headingLevel?: HeadingLevel = 2;\n\n @Watch('headingLevel')\n validateHeadingLevel(newValue = this.headingLevel) {\n checkEmptyOrOneOf(\n newValue,\n HEADING_LEVELS,\n 'The `headingLevel` property of the `post-collapsible` must be a number between 1 and 6.',\n );\n }\n\n /**\n * An event emitted when the collapse element is shown or hidden, before the transition. It has no payload.\n */\n @Event() collapseChange: EventEmitter<void>;\n\n connectedCallback() {\n this.validateCollapsed();\n this.validateHeadingLevel();\n }\n\n componentWillRender() {\n this.id = this.host.id || `c${crypto.randomUUID()}`;\n this.hasHeader = this.host.querySelectorAll('[slot=\"header\"]').length > 0;\n this.headingTag = `h${this.headingLevel ?? 2}`;\n }\n\n componentDidLoad() {\n if (this.collapsed) void this.toggle(false);\n this.isLoaded = true;\n }\n\n /**\n * Triggers the collapse programmatically.\n *\n * If there is a collapsing transition running already, it will be reversed.\n */\n @Method()\n async toggle(open = !this.isOpen): Promise<boolean> {\n if (open === this.isOpen) return open;\n\n this.isOpen = !this.isOpen;\n if (this.isLoaded) this.collapseChange.emit();\n\n const animation = open ? expand(this.collapsible) : collapse(this.collapsible);\n\n if (!this.isLoaded || isMotionReduced()) animation.finish();\n\n await animation.finished;\n\n animation.commitStyles();\n\n return this.isOpen;\n }\n\n render() {\n const collapse = (\n <div\n aria-labelledby={this.hasHeader ? `${this.id}--header` : undefined}\n class={`collapse${this.hasHeader ? ' accordion-collapse' : ''}`}\n id={`${this.id}--collapse`}\n ref={el => (this.collapsible = el)}\n >\n {this.hasHeader ? (\n <div class=\"accordion-body\">\n <slot />\n </div>\n ) : (\n <slot />\n )}\n </div>\n );\n\n return (\n <Host id={this.id} data-version={version}>\n {this.hasHeader ? (\n <div part=\"accordion-item\" class=\"accordion-item\">\n <this.headingTag class=\"accordion-header\" id={`${this.id}--header`}>\n <button\n aria-controls={`${this.id}--collapse`}\n aria-expanded={`${this.isOpen}`}\n class={`accordion-button${this.isOpen ? '' : ' collapsed'}`}\n onClick={() => this.toggle()}\n type=\"button\"\n >\n <slot name=\"header\" />\n </button>\n </this.headingTag>\n\n {collapse}\n </div>\n ) : (\n collapse\n )}\n </Host>\n );\n }\n}\n"],"version":3}
@@ -2,8 +2,8 @@ import type { Components, JSX } from "../types/components";
2
2
 
3
3
  interface PostIcon extends Components.PostIcon, HTMLElement {}
4
4
  export const PostIcon: {
5
- prototype: PostIcon;
6
- new (): PostIcon;
5
+ prototype: PostIcon;
6
+ new (): PostIcon;
7
7
  };
8
8
  /**
9
9
  * Used to define this component and all nested components recursively.
@@ -3,132 +3,132 @@ import { b as checkEmptyOrOneOf, d as checkEmptyOrType, c as checkType } from '.
3
3
  import { v as version } from './package.js';
4
4
  import { c as checkNonEmpty } from './check-non-empty.js';
5
5
 
6
- const postIconCss = ":host{display:inline-block;width:1em;vertical-align:-0.15em}svg{display:block;width:100%;height:100%;fill:currentColor;background-color:currentColor;-webkit-mask-position:center center;mask-position:center center;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:100%;mask-size:100%}:host([flip-h]:not([flip-h=false])){scale:-1 1}:host([flip-v]:not([flip-v=false])){scale:1 -1}:host([flip-h][flip-v]:not([flip-h=false],[flip-v=false])){scale:-1}:host([animation]){transform-origin:center}:host([animation=cylon]){animation:icon-animation-cylon .75s ease-in-out infinite alternate}:host([animation=cylon-vertical]){animation:icon-animation-cylon-vertical .75s ease-in-out infinite alternate}:host([animation=spin]){animation:icon-animation-spin 2s linear infinite normal}:host([animation=spin-reverse]){animation:icon-animation-spin 2s linear infinite reverse}:host([animation=fade]){animation:icon-animation-fade .75s ease-in-out infinite alternate}:host([animation=throb]){animation:icon-animation-throb .75s ease-in-out infinite alternate}@keyframes icon-animation-cylon{from{transform:translateX(-25%)}to{transform:translateX(25%)}}@keyframes icon-animation-cylon-vertical{from{transform:translateY(25%)}to{transform:translateY(-25%)}}@keyframes icon-animation-fade{from{opacity:.1}to{opacity:1}}@keyframes icon-animation-spin{from{transform:rotate(0deg)}to{transform:rotate(359deg)}}@keyframes icon-animation-throb{from{opacity:.5;transform:scale(0.5)}to{opacity:1;transform:scale(1)}}";
6
+ const postIconCss = ":host{display:inline-block;width:1em;height:1em;vertical-align:-0.15em}span{display:block;width:100%;height:100%;fill:currentColor;background-color:currentColor;-webkit-mask-position:center center;mask-position:center center;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:100%;mask-size:100%}:host([flip-h]:not([flip-h=false])){scale:-1 1}:host([flip-v]:not([flip-v=false])){scale:1 -1}:host([flip-h][flip-v]:not([flip-h=false],[flip-v=false])){scale:-1}:host([animation]){transform-origin:center}:host([animation=cylon]){animation:icon-animation-cylon .75s ease-in-out infinite alternate}:host([animation=cylon-vertical]){animation:icon-animation-cylon-vertical .75s ease-in-out infinite alternate}:host([animation=spin]){animation:icon-animation-spin 2s linear infinite normal}:host([animation=spin-reverse]){animation:icon-animation-spin 2s linear infinite reverse}:host([animation=fade]){animation:icon-animation-fade .75s ease-in-out infinite alternate}:host([animation=throb]){animation:icon-animation-throb .75s ease-in-out infinite alternate}@keyframes icon-animation-cylon{from{transform:translateX(-25%)}to{transform:translateX(25%)}}@keyframes icon-animation-cylon-vertical{from{transform:translateY(25%)}to{transform:translateY(-25%)}}@keyframes icon-animation-fade{from{opacity:.1}to{opacity:1}}@keyframes icon-animation-spin{from{transform:rotate(0deg)}to{transform:rotate(359deg)}}@keyframes icon-animation-throb{from{opacity:.5;transform:scale(0.5)}to{opacity:1;transform:scale(1)}}";
7
7
 
8
8
  const CDN_URL = 'https://unpkg.com/@swisspost/design-system-icons/public/post-icons';
9
9
  const ANIMATION_NAMES = [
10
- 'cylon',
11
- 'cylon-vertical',
12
- 'spin',
13
- 'spin-reverse',
14
- 'fade',
15
- 'throb',
10
+ 'cylon',
11
+ 'cylon-vertical',
12
+ 'spin',
13
+ 'spin-reverse',
14
+ 'fade',
15
+ 'throb',
16
16
  ];
17
17
  const ANIMATION_KEYS = [...ANIMATION_NAMES];
18
18
  const PostIcon = /*@__PURE__*/ proxyCustomElement(class PostIcon extends HTMLElement {
19
- constructor() {
20
- super();
21
- this.__registerHost();
22
- this.__attachShadow();
23
- this.svgStyles = undefined;
24
- this.svgOutput = undefined;
25
- this.animation = null;
26
- this.base = null;
27
- this.flipH = false;
28
- this.flipV = false;
29
- this.name = undefined;
30
- this.rotate = null;
31
- this.scale = null;
32
- }
33
- validateAnimation(newValue = this.animation) {
34
- if (newValue !== undefined)
35
- checkEmptyOrOneOf(newValue, ANIMATION_KEYS, `The post-icon "animation" prop requires one of the following values: ${ANIMATION_KEYS.join(', ')}.`);
36
- }
37
- validateBase(newValue = this.base) {
38
- checkEmptyOrType(newValue, 'string', 'The post-icon "base" prop should be a string.');
39
- }
40
- validateFlipH(newValue = this.flipH) {
41
- checkEmptyOrType(newValue, 'boolean', 'The post-icon "flipH" prop should be a boolean.');
42
- }
43
- validateFlipV(newValue = this.flipV) {
44
- checkEmptyOrType(newValue, 'boolean', 'The post-icon "flipV" prop should be a boolean.');
45
- }
46
- validateName(newValue = this.name) {
47
- checkNonEmpty(newValue, 'The post-icon "name" prop is required!.');
48
- checkType(newValue, 'string', 'The post-icon "name" prop should be a string.');
49
- }
50
- validateRotate(newValue = this.rotate) {
51
- checkEmptyOrType(newValue, 'number', 'The post-icon "rotate" prop should be a number.');
52
- }
53
- validateScale(newValue = this.scale) {
54
- checkEmptyOrType(newValue, 'number', 'The post-icon "scale" prop should be a number.');
55
- }
56
- componentWillLoad() {
57
- this.validateBase();
58
- this.validateName();
59
- this.validateFlipH();
60
- this.validateFlipV();
61
- this.validateScale();
62
- this.validateRotate();
63
- this.validateAnimation();
64
- }
65
- componentWillRender() {
66
- this.setPath();
67
- }
68
- setPath() {
69
- var _a, _b, _c, _d;
70
- // Construct icon path from different possible sources
71
- const metaBase = (_b = (_a = document.head
72
- .querySelector('meta[name="design-system-settings"][data-post-icon-base]')) === null || _a === void 0 ? void 0 : _a.getAttribute('data-post-icon-base')) !== null && _b !== void 0 ? _b : null;
73
- const fileBase = `${(_d = (_c = this.base) !== null && _c !== void 0 ? _c : metaBase) !== null && _d !== void 0 ? _d : CDN_URL}/`.replace(/\/\/$/, '/');
74
- const fileName = `${this.name}.svg#icon`;
75
- const filePath = `${fileBase}${fileName}`;
76
- this.path = new URL(filePath, window.location.origin).toString();
77
- }
78
- render() {
79
- // create inline styles for some properties
80
- const svgStyles = Object.entries({
81
- '-webkit-mask-image': `url('${this.path}')`,
82
- 'mask-image': `url('${this.path}')`,
83
- 'scale': this.scale && !isNaN(Number(this.scale)) ? `${this.scale}` : null,
84
- 'rotate': this.rotate && !isNaN(Number(this.rotate)) ? `${this.rotate}deg` : null,
85
- })
86
- .filter(([_key, value]) => value !== null)
87
- .reduce((styles, [key, value]) => Object.assign(styles, { [key]: value }), {});
88
- return (h(Host, { "data-version": version }, h("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 32 32", style: svgStyles })));
89
- }
90
- get host() { return this; }
91
- static get watchers() { return {
92
- "animation": ["validateAnimation"],
93
- "base": ["validateBase"],
94
- "flipH": ["validateFlipH"],
95
- "flipV": ["validateFlipV"],
96
- "name": ["validateName"],
97
- "rotate": ["validateRotate"],
98
- "scale": ["validateScale"]
99
- }; }
100
- static get style() { return postIconCss; }
19
+ constructor() {
20
+ super();
21
+ this.__registerHost();
22
+ this.__attachShadow();
23
+ this.svgStyles = undefined;
24
+ this.svgOutput = undefined;
25
+ this.animation = null;
26
+ this.base = null;
27
+ this.flipH = false;
28
+ this.flipV = false;
29
+ this.name = undefined;
30
+ this.rotate = null;
31
+ this.scale = null;
32
+ }
33
+ validateAnimation(newValue = this.animation) {
34
+ if (newValue !== undefined)
35
+ checkEmptyOrOneOf(newValue, ANIMATION_KEYS, `The post-icon "animation" prop requires one of the following values: ${ANIMATION_KEYS.join(', ')}.`);
36
+ }
37
+ validateBase(newValue = this.base) {
38
+ checkEmptyOrType(newValue, 'string', 'The post-icon "base" prop should be a string.');
39
+ }
40
+ validateFlipH(newValue = this.flipH) {
41
+ checkEmptyOrType(newValue, 'boolean', 'The post-icon "flipH" prop should be a boolean.');
42
+ }
43
+ validateFlipV(newValue = this.flipV) {
44
+ checkEmptyOrType(newValue, 'boolean', 'The post-icon "flipV" prop should be a boolean.');
45
+ }
46
+ validateName(newValue = this.name) {
47
+ checkNonEmpty(newValue, 'The post-icon "name" prop is required!.');
48
+ checkType(newValue, 'string', 'The post-icon "name" prop should be a string.');
49
+ }
50
+ validateRotate(newValue = this.rotate) {
51
+ checkEmptyOrType(newValue, 'number', 'The post-icon "rotate" prop should be a number.');
52
+ }
53
+ validateScale(newValue = this.scale) {
54
+ checkEmptyOrType(newValue, 'number', 'The post-icon "scale" prop should be a number.');
55
+ }
56
+ componentWillLoad() {
57
+ this.validateBase();
58
+ this.validateName();
59
+ this.validateFlipH();
60
+ this.validateFlipV();
61
+ this.validateScale();
62
+ this.validateRotate();
63
+ this.validateAnimation();
64
+ }
65
+ componentWillRender() {
66
+ this.setPath();
67
+ }
68
+ setPath() {
69
+ var _a, _b, _c, _d;
70
+ // Construct icon path from different possible sources
71
+ const metaBase = (_b = (_a = document.head
72
+ .querySelector('meta[name="design-system-settings"][data-post-icon-base]')) === null || _a === void 0 ? void 0 : _a.getAttribute('data-post-icon-base')) !== null && _b !== void 0 ? _b : null;
73
+ const fileBase = `${(_d = (_c = this.base) !== null && _c !== void 0 ? _c : metaBase) !== null && _d !== void 0 ? _d : CDN_URL}/`.replace(/\/\/$/, '/');
74
+ const fileName = `${this.name}.svg#icon`;
75
+ const filePath = `${fileBase}${fileName}`;
76
+ this.path = new URL(filePath, window.location.origin).toString();
77
+ }
78
+ render() {
79
+ // create inline styles for some properties
80
+ const svgStyles = Object.entries({
81
+ '-webkit-mask-image': `url('${this.path}')`,
82
+ 'mask-image': `url('${this.path}')`,
83
+ 'transform': (this.scale && !isNaN(Number(this.scale)) ? 'scale(' + this.scale + ')' : '') +
84
+ (this.rotate && !isNaN(Number(this.rotate)) ? ' rotate(' + this.rotate + 'deg)' : ''),
85
+ })
86
+ .filter(([_key, value]) => value !== null)
87
+ .reduce((styles, [key, value]) => Object.assign(styles, { [key]: value }), {});
88
+ return (h(Host, { "data-version": version }, h("span", { style: svgStyles })));
89
+ }
90
+ get host() { return this; }
91
+ static get watchers() { return {
92
+ "animation": ["validateAnimation"],
93
+ "base": ["validateBase"],
94
+ "flipH": ["validateFlipH"],
95
+ "flipV": ["validateFlipV"],
96
+ "name": ["validateName"],
97
+ "rotate": ["validateRotate"],
98
+ "scale": ["validateScale"]
99
+ }; }
100
+ static get style() { return postIconCss; }
101
101
  }, [1, "post-icon", {
102
- "animation": [1],
103
- "base": [1],
104
- "flipH": [4, "flip-h"],
105
- "flipV": [4, "flip-v"],
106
- "name": [1],
107
- "rotate": [2],
108
- "scale": [2],
109
- "svgStyles": [32],
110
- "svgOutput": [32]
111
- }, undefined, {
112
- "animation": ["validateAnimation"],
113
- "base": ["validateBase"],
114
- "flipH": ["validateFlipH"],
115
- "flipV": ["validateFlipV"],
116
- "name": ["validateName"],
117
- "rotate": ["validateRotate"],
118
- "scale": ["validateScale"]
119
- }]);
102
+ "animation": [1],
103
+ "base": [1],
104
+ "flipH": [4, "flip-h"],
105
+ "flipV": [4, "flip-v"],
106
+ "name": [1],
107
+ "rotate": [2],
108
+ "scale": [2],
109
+ "svgStyles": [32],
110
+ "svgOutput": [32]
111
+ }, undefined, {
112
+ "animation": ["validateAnimation"],
113
+ "base": ["validateBase"],
114
+ "flipH": ["validateFlipH"],
115
+ "flipV": ["validateFlipV"],
116
+ "name": ["validateName"],
117
+ "rotate": ["validateRotate"],
118
+ "scale": ["validateScale"]
119
+ }]);
120
120
  function defineCustomElement() {
121
- if (typeof customElements === "undefined") {
122
- return;
123
- }
124
- const components = ["post-icon"];
125
- components.forEach(tagName => { switch (tagName) {
126
- case "post-icon":
127
- if (!customElements.get(tagName)) {
128
- customElements.define(tagName, PostIcon);
129
- }
130
- break;
131
- } });
121
+ if (typeof customElements === "undefined") {
122
+ return;
123
+ }
124
+ const components = ["post-icon"];
125
+ components.forEach(tagName => { switch (tagName) {
126
+ case "post-icon":
127
+ if (!customElements.get(tagName)) {
128
+ customElements.define(tagName, PostIcon);
129
+ }
130
+ break;
131
+ } });
132
132
  }
133
133
 
134
134
  export { PostIcon as P, defineCustomElement as d };
@@ -1 +1 @@
1
- {"file":"post-icon2.js","mappings":"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","names":[],"sources":["src/components/post-icon/post-icon.scss?tag=post-icon&encapsulation=shadow","src/components/post-icon/post-icon.tsx"],"sourcesContent":["@use 'sass:map';\n\n$post-icon-animations: (\n 'cylon': icon-animation-cylon 0.75s ease-in-out infinite alternate,\n 'cylon-vertical': icon-animation-cylon-vertical 0.75s ease-in-out infinite alternate,\n 'spin': icon-animation-spin 2s linear infinite normal,\n 'spin-reverse': icon-animation-spin 2s linear infinite reverse,\n 'fade': icon-animation-fade 0.75s ease-in-out infinite alternate,\n 'throb': icon-animation-throb 0.75s ease-in-out infinite alternate,\n);\n\n:host {\n display: inline-block;\n width: 1em;\n vertical-align: -0.15em;\n}\n\nsvg {\n display: block;\n width: 100%;\n height: 100%;\n fill: currentColor;\n background-color: currentColor;\n -webkit-mask-position: center center;\n mask-position: center center;\n -webkit-mask-repeat: no-repeat;\n mask-repeat: no-repeat;\n -webkit-mask-size: 100%;\n mask-size: 100%;\n}\n\n// flip\n\n:host([flip-h]:not([flip-h='false'])) {\n scale: -1 1;\n}\n\n:host([flip-v]:not([flip-v='false'])) {\n scale: 1 -1;\n}\n\n:host([flip-h][flip-v]:not([flip-h='false'], [flip-v='false'])) {\n scale: -1;\n}\n\n// scale\n// done with inline styling\n\n// rotate\n// done with inline styling\n\n// animation\n\n:host([animation]) {\n transform-origin: center;\n}\n\n@each $key, $value in $post-icon-animations {\n :host([animation='#{$key}']) {\n animation: $value;\n }\n}\n\n@keyframes icon-animation-cylon {\n from {\n transform: translateX(-25%);\n }\n to {\n transform: translateX(25%);\n }\n}\n\n@keyframes icon-animation-cylon-vertical {\n from {\n transform: translateY(25%);\n }\n to {\n transform: translateY(-25%);\n }\n}\n\n@keyframes icon-animation-fade {\n from {\n opacity: 0.1;\n }\n to {\n opacity: 1;\n }\n}\n\n@keyframes icon-animation-spin {\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(359deg);\n }\n}\n\n@keyframes icon-animation-throb {\n from {\n opacity: 0.5;\n transform: scale(0.5);\n }\n to {\n opacity: 1;\n transform: scale(1);\n }\n}\n","import { Component, Element, Host, h, Prop, State, Watch } from '@stencil/core';\nimport { checkNonEmpty, checkType, checkEmptyOrType, checkEmptyOrOneOf } from '../../utils';\nimport { version } from '../../../package.json';\n\nconst CDN_URL = 'https://unpkg.com/@swisspost/design-system-icons/public/post-icons';\nconst ANIMATION_NAMES = [\n 'cylon',\n 'cylon-vertical',\n 'spin',\n 'spin-reverse',\n 'fade',\n 'throb',\n] as const;\nconst ANIMATION_KEYS = [...ANIMATION_NAMES];\n\ntype Animation = (typeof ANIMATION_NAMES)[number];\n\n/**\n * @class PostIcon - representing a stencil component\n */\n@Component({\n tag: 'post-icon',\n styleUrl: 'post-icon.scss',\n shadow: true,\n})\nexport class PostIcon {\n private path: string;\n\n @Element() host: HTMLPostIconElement;\n\n @State() svgStyles: string;\n @State() svgOutput: string;\n\n /**\n * The name of the animation.\n */\n @Prop() readonly animation?: Animation | null = null;\n\n @Watch('animation')\n validateAnimation(newValue = this.animation) {\n if (newValue !== undefined)\n checkEmptyOrOneOf(\n newValue,\n ANIMATION_KEYS,\n `The post-icon \"animation\" prop requires one of the following values: ${ANIMATION_KEYS.join(\n ', ',\n )}.`,\n );\n }\n\n /**\n * The base path, where the icons are located (must be a public url).<br/>Leave this field empty to use the default cdn url.\n */\n @Prop() readonly base?: string | null = null;\n\n @Watch('base')\n validateBase(newValue = this.base) {\n checkEmptyOrType(newValue, 'string', 'The post-icon \"base\" prop should be a string.');\n }\n\n /**\n * When set to `true`, the icon will be flipped horizontally.\n */\n @Prop() readonly flipH?: boolean = false;\n\n @Watch('flipH')\n validateFlipH(newValue = this.flipH) {\n checkEmptyOrType(newValue, 'boolean', 'The post-icon \"flipH\" prop should be a boolean.');\n }\n\n /**\n * When set to `true`, the icon will be flipped vertically.\n */\n @Prop() readonly flipV?: boolean = false;\n\n @Watch('flipV')\n validateFlipV(newValue = this.flipV) {\n checkEmptyOrType(newValue, 'boolean', 'The post-icon \"flipV\" prop should be a boolean.');\n }\n\n /**\n * The name/id of the icon (e.g. 1000, 1001, ...).\n */\n @Prop() readonly name!: string;\n\n @Watch('name')\n validateName(newValue = this.name) {\n checkNonEmpty(newValue, 'The post-icon \"name\" prop is required!.');\n checkType(newValue, 'string', 'The post-icon \"name\" prop should be a string.');\n }\n\n /**\n * The number of degree for the css rotate transformation.\n */\n @Prop() readonly rotate?: number | null = null;\n\n @Watch('rotate')\n validateRotate(newValue = this.rotate) {\n checkEmptyOrType(newValue, 'number', 'The post-icon \"rotate\" prop should be a number.');\n }\n\n /**\n * The number for the css scale transformation.\n */\n @Prop() readonly scale?: number | null = null;\n\n @Watch('scale')\n validateScale(newValue = this.scale) {\n checkEmptyOrType(newValue, 'number', 'The post-icon \"scale\" prop should be a number.');\n }\n\n componentWillLoad() {\n this.validateBase();\n this.validateName();\n this.validateFlipH();\n this.validateFlipV();\n this.validateScale();\n this.validateRotate();\n this.validateAnimation();\n }\n\n componentWillRender() {\n this.setPath();\n }\n\n private setPath() {\n // Construct icon path from different possible sources\n const metaBase =\n document.head\n .querySelector('meta[name=\"design-system-settings\"][data-post-icon-base]')\n ?.getAttribute('data-post-icon-base') ?? null;\n\n const fileBase = `${this.base ?? metaBase ?? CDN_URL}/`.replace(/\\/\\/$/, '/');\n const fileName = `${this.name}.svg#icon`;\n const filePath = `${fileBase}${fileName}`;\n\n this.path = new URL(filePath, window.location.origin).toString();\n }\n\n render() {\n // create inline styles for some properties\n const svgStyles = Object.entries({\n '-webkit-mask-image': `url('${this.path}')`,\n 'mask-image': `url('${this.path}')`,\n 'scale': this.scale && !isNaN(Number(this.scale)) ? `${this.scale}` : null,\n 'rotate': this.rotate && !isNaN(Number(this.rotate)) ? `${this.rotate}deg` : null,\n })\n .filter(([_key, value]) => value !== null)\n .reduce((styles, [key, value]) => Object.assign(styles, { [key]: value }), {});\n\n return (\n <Host data-version={version}>\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 32 32\" style={svgStyles}>\n </svg>\n </Host>\n );\n }\n}\n"],"version":3}
1
+ {"file":"post-icon2.js","mappings":"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","names":[],"sources":["src/components/post-icon/post-icon.scss?tag=post-icon&encapsulation=shadow","src/components/post-icon/post-icon.tsx"],"sourcesContent":["@use 'sass:map';\n\n$post-icon-animations: (\n 'cylon': icon-animation-cylon 0.75s ease-in-out infinite alternate,\n 'cylon-vertical': icon-animation-cylon-vertical 0.75s ease-in-out infinite alternate,\n 'spin': icon-animation-spin 2s linear infinite normal,\n 'spin-reverse': icon-animation-spin 2s linear infinite reverse,\n 'fade': icon-animation-fade 0.75s ease-in-out infinite alternate,\n 'throb': icon-animation-throb 0.75s ease-in-out infinite alternate,\n);\n\n:host {\n display: inline-block;\n width: 1em;\n height: 1em;\n vertical-align: -0.15em;\n}\n\nspan {\n display: block;\n width: 100%;\n height: 100%;\n fill: currentColor;\n background-color: currentColor;\n -webkit-mask-position: center center;\n mask-position: center center;\n -webkit-mask-repeat: no-repeat;\n mask-repeat: no-repeat;\n -webkit-mask-size: 100%;\n mask-size: 100%;\n}\n\n// flip\n\n:host([flip-h]:not([flip-h='false'])) {\n scale: -1 1;\n}\n\n:host([flip-v]:not([flip-v='false'])) {\n scale: 1 -1;\n}\n\n:host([flip-h][flip-v]:not([flip-h='false'], [flip-v='false'])) {\n scale: -1;\n}\n\n// scale\n// done with inline styling\n\n// rotate\n// done with inline styling\n\n// animation\n\n:host([animation]) {\n transform-origin: center;\n}\n\n@each $key, $value in $post-icon-animations {\n :host([animation='#{$key}']) {\n animation: $value;\n }\n}\n\n@keyframes icon-animation-cylon {\n from {\n transform: translateX(-25%);\n }\n to {\n transform: translateX(25%);\n }\n}\n\n@keyframes icon-animation-cylon-vertical {\n from {\n transform: translateY(25%);\n }\n to {\n transform: translateY(-25%);\n }\n}\n\n@keyframes icon-animation-fade {\n from {\n opacity: 0.1;\n }\n to {\n opacity: 1;\n }\n}\n\n@keyframes icon-animation-spin {\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(359deg);\n }\n}\n\n@keyframes icon-animation-throb {\n from {\n opacity: 0.5;\n transform: scale(0.5);\n }\n to {\n opacity: 1;\n transform: scale(1);\n }\n}\n","import { Component, Element, Host, h, Prop, State, Watch } from '@stencil/core';\nimport { checkNonEmpty, checkType, checkEmptyOrType, checkEmptyOrOneOf } from '../../utils';\nimport { version } from '../../../package.json';\n\nconst CDN_URL = 'https://unpkg.com/@swisspost/design-system-icons/public/post-icons';\nconst ANIMATION_NAMES = [\n 'cylon',\n 'cylon-vertical',\n 'spin',\n 'spin-reverse',\n 'fade',\n 'throb',\n] as const;\nconst ANIMATION_KEYS = [...ANIMATION_NAMES];\n\ntype Animation = (typeof ANIMATION_NAMES)[number];\n\n/**\n * @class PostIcon - representing a stencil component\n */\n@Component({\n tag: 'post-icon',\n styleUrl: 'post-icon.scss',\n shadow: true,\n})\nexport class PostIcon {\n private path: string;\n\n @Element() host: HTMLPostIconElement;\n\n @State() svgStyles: string;\n @State() svgOutput: string;\n\n /**\n * The name of the animation.\n */\n @Prop() readonly animation?: Animation | null = null;\n\n @Watch('animation')\n validateAnimation(newValue = this.animation) {\n if (newValue !== undefined)\n checkEmptyOrOneOf(\n newValue,\n ANIMATION_KEYS,\n `The post-icon \"animation\" prop requires one of the following values: ${ANIMATION_KEYS.join(\n ', ',\n )}.`,\n );\n }\n\n /**\n * The base path, where the icons are located (must be a public url).<br/>Leave this field empty to use the default cdn url.\n */\n @Prop() readonly base?: string | null = null;\n\n @Watch('base')\n validateBase(newValue = this.base) {\n checkEmptyOrType(newValue, 'string', 'The post-icon \"base\" prop should be a string.');\n }\n\n /**\n * When set to `true`, the icon will be flipped horizontally.\n */\n @Prop() readonly flipH?: boolean = false;\n\n @Watch('flipH')\n validateFlipH(newValue = this.flipH) {\n checkEmptyOrType(newValue, 'boolean', 'The post-icon \"flipH\" prop should be a boolean.');\n }\n\n /**\n * When set to `true`, the icon will be flipped vertically.\n */\n @Prop() readonly flipV?: boolean = false;\n\n @Watch('flipV')\n validateFlipV(newValue = this.flipV) {\n checkEmptyOrType(newValue, 'boolean', 'The post-icon \"flipV\" prop should be a boolean.');\n }\n\n /**\n * The name/id of the icon (e.g. 1000, 1001, ...).\n */\n @Prop() readonly name!: string;\n\n @Watch('name')\n validateName(newValue = this.name) {\n checkNonEmpty(newValue, 'The post-icon \"name\" prop is required!.');\n checkType(newValue, 'string', 'The post-icon \"name\" prop should be a string.');\n }\n\n /**\n * The number of degree for the css rotate transformation.\n */\n @Prop() readonly rotate?: number | null = null;\n\n @Watch('rotate')\n validateRotate(newValue = this.rotate) {\n checkEmptyOrType(newValue, 'number', 'The post-icon \"rotate\" prop should be a number.');\n }\n\n /**\n * The number for the css scale transformation.\n */\n @Prop() readonly scale?: number | null = null;\n\n @Watch('scale')\n validateScale(newValue = this.scale) {\n checkEmptyOrType(newValue, 'number', 'The post-icon \"scale\" prop should be a number.');\n }\n\n componentWillLoad() {\n this.validateBase();\n this.validateName();\n this.validateFlipH();\n this.validateFlipV();\n this.validateScale();\n this.validateRotate();\n this.validateAnimation();\n }\n\n componentWillRender() {\n this.setPath();\n }\n\n private setPath() {\n // Construct icon path from different possible sources\n const metaBase =\n document.head\n .querySelector('meta[name=\"design-system-settings\"][data-post-icon-base]')\n ?.getAttribute('data-post-icon-base') ?? null;\n\n const fileBase = `${this.base ?? metaBase ?? CDN_URL}/`.replace(/\\/\\/$/, '/');\n const fileName = `${this.name}.svg#icon`;\n const filePath = `${fileBase}${fileName}`;\n\n this.path = new URL(filePath, window.location.origin).toString();\n }\n\n render() {\n // create inline styles for some properties\n const svgStyles = Object.entries({\n '-webkit-mask-image': `url('${this.path}')`,\n 'mask-image': `url('${this.path}')`,\n 'transform':\n (this.scale && !isNaN(Number(this.scale)) ? 'scale(' + this.scale + ')' : '') +\n (this.rotate && !isNaN(Number(this.rotate)) ? ' rotate(' + this.rotate + 'deg)' : ''),\n })\n .filter(([_key, value]) => value !== null)\n .reduce((styles, [key, value]) => Object.assign(styles, { [key]: value }), {});\n return (\n <Host data-version={version}>\n <span style={svgStyles}></span>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface PostPopover extends Components.PostPopover, HTMLElement {}
4
+ export const PostPopover: {
5
+ prototype: PostPopover;
6
+ new (): PostPopover;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,8 @@
1
+ import { P as PostPopover$1, d as defineCustomElement$1 } from './post-popover2.js';
2
+
3
+ const PostPopover = PostPopover$1;
4
+ const defineCustomElement = defineCustomElement$1;
5
+
6
+ export { PostPopover, defineCustomElement };
7
+
8
+ //# sourceMappingURL=post-popover.js.map
@@ -0,0 +1 @@
1
+ {"file":"post-popover.js","mappings":";;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}