@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
@@ -0,0 +1 @@
1
+ {"file":"post-collapsible-0b8dce97.js","mappings":"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","names":["checkEmptyOrType","checkEmptyOrOneOf","h","Host","version"],"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,12 +2,11 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const postCollapsible = require('./post-collapsible-e46002bb.js');
6
- require('./index-e7618bb3.js');
7
- require('./package-041a8597.js');
8
- require('./index-b38a23e0.js');
5
+ const postCollapsible = require('./post-collapsible-0b8dce97.js');
6
+ require('./index-c07c0cdb.js');
7
+ require('./package-cd0e9960.js');
8
+ require('./index-8c288b1a.js');
9
9
  require('./constants-238701d3.js');
10
- require('./check-one-of-27ad3154.js');
11
10
 
12
11
 
13
12
 
@@ -1 +1 @@
1
- {"file":"post-collapsible.entry.cjs.js","mappings":";;;;;;;;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}
1
+ {"file":"post-collapsible.entry.cjs.js","mappings":";;;;;;;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}
@@ -2,10 +2,10 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-e7618bb3.js');
5
+ const index = require('./index-c07c0cdb.js');
6
6
 
7
7
  /*
8
- Stencil Client Patch Browser v4.7.0 | MIT Licensed | https://stenciljs.com
8
+ Stencil Client Patch Browser v4.9.0 | MIT Licensed | https://stenciljs.com
9
9
  */
10
10
  const patchBrowser = () => {
11
11
  const importMeta = (typeof document === 'undefined' ? new (require('u' + 'rl').URL)('file:' + __filename).href : (document.currentScript && document.currentScript.src || new URL('post-components.cjs.js', document.baseURI).href));
@@ -17,7 +17,7 @@ const patchBrowser = () => {
17
17
  };
18
18
 
19
19
  patchBrowser().then(options => {
20
- return index.bootstrapLazy([["post-alert.cjs",[[1,"post-alert",{"dismissible":[4],"dismissLabel":[1,"dismiss-label"],"fixed":[4],"icon":[1],"type":[1],"alertId":[32],"classes":[32],"hasActions":[32],"hasHeading":[32],"onDismissButtonClick":[32],"dismiss":[64]},null,{"dismissible":["validateDismissible"],"dismissLabel":["validateDismissLabel"],"fixed":["validateFixed"],"icon":["validateIcon"],"type":["validateType"]}]]],["post-accordion.cjs",[[1,"post-accordion",{"multiple":[4],"toggle":[64],"expandAll":[64],"collapseAll":[64]},[[0,"collapseChange","collapseChangeHandler"]]]]],["post-collapsible.cjs",[[1,"post-collapsible",{"collapsed":[4],"headingLevel":[2,"heading-level"],"id":[32],"isOpen":[32],"hasHeader":[32],"headingTag":[32],"toggle":[64]},null,{"collapsed":["validateCollapsed"],"headingLevel":["validateHeadingLevel"]}]]],["post-tab-header.cjs",[[1,"post-tab-header",{"panel":[1],"tabId":[32]},null,{"panel":["validateFor"]}]]],["post-tab-panel.cjs",[[1,"post-tab-panel",{"name":[1],"panelId":[32]}]]],["post-tabs.cjs",[[1,"post-tabs",{"activePanel":[1,"active-panel"],"show":[64]}]]],["post-tooltip.cjs",[[1,"post-tooltip",{"backgroundColor":[1,"background-color"],"placement":[1],"tooltipClasses":[32],"show":[64],"hide":[64],"toggle":[64]},null,{"backgroundColor":["validateBackgroundColor"]}]]],["post-icon.cjs",[[1,"post-icon",{"animation":[1],"base":[1],"flipH":[4,"flip-h"],"flipV":[4,"flip-v"],"name":[1],"rotate":[2],"scale":[2],"svgStyles":[32],"svgOutput":[32]},null,{"animation":["validateAnimation"],"base":["validateBase"],"flipH":["validateFlipH"],"flipV":["validateFlipV"],"name":["validateName"],"rotate":["validateRotate"],"scale":["validateScale"]}]]]], options);
20
+ return index.bootstrapLazy([["post-alert.cjs",[[1,"post-alert",{"dismissible":[4],"dismissLabel":[1,"dismiss-label"],"fixed":[4],"icon":[1],"type":[1],"alertId":[32],"classes":[32],"hasActions":[32],"hasHeading":[32],"onDismissButtonClick":[32],"dismiss":[64]},null,{"dismissible":["validateDismissible"],"dismissLabel":["validateDismissLabel"],"fixed":["validateFixed"],"icon":["validateIcon"],"type":["validateType"]}]]],["post-popover.cjs",[[1,"post-popover",{"placement":[1],"closeButtonCaption":[1,"close-button-caption"],"arrow":[4],"show":[64],"hide":[64],"toggle":[64]}]]],["post-tooltip.cjs",[[1,"post-tooltip",{"placement":[1],"show":[64],"hide":[64],"toggle":[64]}]]],["post-accordion.cjs",[[1,"post-accordion",{"multiple":[4],"toggle":[64],"expandAll":[64],"collapseAll":[64]},[[0,"collapseChange","collapseChangeHandler"]]]]],["post-collapsible.cjs",[[1,"post-collapsible",{"collapsed":[4],"headingLevel":[2,"heading-level"],"id":[32],"isOpen":[32],"hasHeader":[32],"headingTag":[32],"toggle":[64]},null,{"collapsed":["validateCollapsed"],"headingLevel":["validateHeadingLevel"]}]]],["post-tab-header.cjs",[[1,"post-tab-header",{"panel":[1],"tabId":[32]},null,{"panel":["validateFor"]}]]],["post-tab-panel.cjs",[[1,"post-tab-panel",{"name":[1],"panelId":[32]}]]],["post-tabs.cjs",[[1,"post-tabs",{"activePanel":[1,"active-panel"],"show":[64]}]]],["post-icon.cjs",[[1,"post-icon",{"animation":[1],"base":[1],"flipH":[4,"flip-h"],"flipV":[4,"flip-v"],"name":[1],"rotate":[2],"scale":[2],"svgStyles":[32],"svgOutput":[32]},null,{"animation":["validateAnimation"],"base":["validateBase"],"flipH":["validateFlipH"],"flipV":["validateFlipV"],"name":["validateName"],"rotate":["validateRotate"],"scale":["validateScale"]}]]],["post-popovercontainer.cjs",[[1,"post-popovercontainer",{"placement":[1],"arrow":[4],"show":[64],"hide":[64],"toggle":[64]}]]]], options);
21
21
  });
22
22
 
23
23
  exports.setNonce = index.setNonce;
@@ -1 +1 @@
1
- {"file":"post-components.cjs.js","mappings":";;;;;;AAAA;AACA;AACA;AAGA,MAAM,YAAY,GAAG,MAAM;AAa3B,IAAI,MAAM,UAAU,GAAG,iNAAe,CAAC;AACvC,IAAI,MAAM,IAAI,GAAiE,EAAE,CAAC;AAClF,IAAI,IAAI,UAAU,KAAK,EAAE,EAAE;AAC3B,QAAQ,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC;AAC1D,KAAK;AACL,IAAI,OAAOA,oBAAc,CAAC,IAAI,CAAC,CAAC;AAChC,CAAC;;ACpBD,YAAY,EAAE,CAAC,IAAI,CAAC,OAAO,IAAI;AAE/B,EAAE,OAAOC,mBAAa,CAAC,4BAA4B,EAAE,OAAO,CAAC,CAAC;AAC9D,CAAC,CAAC;;;;","names":["promiseResolve","bootstrapLazy"],"sources":["../../node_modules/.pnpm/@stencil+core@4.7.0/node_modules/@stencil/core/internal/client/patch-browser.js","@lazy-browser-entrypoint?app-data=conditional"],"sourcesContent":["/*\n Stencil Client Patch Browser v4.7.0 | MIT Licensed | https://stenciljs.com\n */\nimport { BUILD, NAMESPACE } from '@stencil/core/internal/app-data';\nimport { consoleDevInfo, doc, promiseResolve, H } from '@stencil/core';\nconst patchBrowser = () => {\n // NOTE!! This fn cannot use async/await!\n if (BUILD.isDev && !BUILD.isTesting) {\n consoleDevInfo('Running in development mode.');\n }\n if (BUILD.cloneNodeFix) {\n // opted-in to polyfill cloneNode() for slot polyfilled components\n patchCloneNodeFix(H.prototype);\n }\n const scriptElm = BUILD.scriptDataOpts\n ? Array.from(doc.querySelectorAll('script')).find((s) => new RegExp(`\\/${NAMESPACE}(\\\\.esm)?\\\\.js($|\\\\?|#)`).test(s.src) ||\n s.getAttribute('data-stencil-namespace') === NAMESPACE)\n : null;\n const importMeta = import.meta.url;\n const opts = BUILD.scriptDataOpts ? (scriptElm || {})['data-opts'] || {} : {};\n if (importMeta !== '') {\n opts.resourcesUrl = new URL('.', importMeta).href;\n }\n return promiseResolve(opts);\n};\nconst patchCloneNodeFix = (HTMLElementPrototype) => {\n const nativeCloneNodeFn = HTMLElementPrototype.cloneNode;\n HTMLElementPrototype.cloneNode = function (deep) {\n if (this.nodeName === 'TEMPLATE') {\n return nativeCloneNodeFn.call(this, deep);\n }\n const clonedNode = nativeCloneNodeFn.call(this, false);\n const srcChildNodes = this.childNodes;\n if (deep) {\n for (let i = 0; i < srcChildNodes.length; i++) {\n // Node.ATTRIBUTE_NODE === 2, and checking because IE11\n if (srcChildNodes[i].nodeType !== 2) {\n clonedNode.appendChild(srcChildNodes[i].cloneNode(true));\n }\n }\n }\n return clonedNode;\n };\n};\nexport { patchBrowser };\n","export { setNonce } from '@stencil/core';\nimport { bootstrapLazy } from '@stencil/core';\nimport { patchBrowser } from '@stencil/core/internal/client/patch-browser';\nimport { globalScripts } from '@stencil/core/internal/app-globals';\npatchBrowser().then(options => {\n globalScripts();\n return bootstrapLazy([/*!__STENCIL_LAZY_DATA__*/], options);\n});\n"],"version":3}
1
+ {"file":"post-components.cjs.js","mappings":";;;;;;AAAA;AACA;AACA;AAGA,MAAM,YAAY,GAAG,MAAM;AAa3B,IAAI,MAAM,UAAU,GAAG,iNAAe,CAAC;AACvC,IAAI,MAAM,IAAI,GAAiE,EAAE,CAAC;AAClF,IAAI,IAAI,UAAU,KAAK,EAAE,EAAE;AAC3B,QAAQ,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC;AAC1D,KAAK;AACL,IAAI,OAAOA,oBAAc,CAAC,IAAI,CAAC,CAAC;AAChC,CAAC;;ACpBD,YAAY,EAAE,CAAC,IAAI,CAAC,OAAO,IAAI;AAE/B,EAAE,OAAOC,mBAAa,CAAC,4BAA4B,EAAE,OAAO,CAAC,CAAC;AAC9D,CAAC,CAAC;;;;","names":["promiseResolve","bootstrapLazy"],"sources":["../../node_modules/.pnpm/@stencil+core@4.9.0/node_modules/@stencil/core/internal/client/patch-browser.js","@lazy-browser-entrypoint?app-data=conditional"],"sourcesContent":["/*\n Stencil Client Patch Browser v4.9.0 | MIT Licensed | https://stenciljs.com\n */\nimport { BUILD, NAMESPACE } from '@stencil/core/internal/app-data';\nimport { consoleDevInfo, doc, promiseResolve, H } from '@stencil/core';\nconst patchBrowser = () => {\n // NOTE!! This fn cannot use async/await!\n if (BUILD.isDev && !BUILD.isTesting) {\n consoleDevInfo('Running in development mode.');\n }\n if (BUILD.cloneNodeFix) {\n // opted-in to polyfill cloneNode() for slot polyfilled components\n patchCloneNodeFix(H.prototype);\n }\n const scriptElm = BUILD.scriptDataOpts\n ? Array.from(doc.querySelectorAll('script')).find((s) => new RegExp(`\\/${NAMESPACE}(\\\\.esm)?\\\\.js($|\\\\?|#)`).test(s.src) ||\n s.getAttribute('data-stencil-namespace') === NAMESPACE)\n : null;\n const importMeta = import.meta.url;\n const opts = BUILD.scriptDataOpts ? (scriptElm || {})['data-opts'] || {} : {};\n if (importMeta !== '') {\n opts.resourcesUrl = new URL('.', importMeta).href;\n }\n return promiseResolve(opts);\n};\nconst patchCloneNodeFix = (HTMLElementPrototype) => {\n const nativeCloneNodeFn = HTMLElementPrototype.cloneNode;\n HTMLElementPrototype.cloneNode = function (deep) {\n if (this.nodeName === 'TEMPLATE') {\n return nativeCloneNodeFn.call(this, deep);\n }\n const clonedNode = nativeCloneNodeFn.call(this, false);\n const srcChildNodes = this.childNodes;\n if (deep) {\n for (let i = 0; i < srcChildNodes.length; i++) {\n // Node.ATTRIBUTE_NODE === 2, and checking because IE11\n if (srcChildNodes[i].nodeType !== 2) {\n clonedNode.appendChild(srcChildNodes[i].cloneNode(true));\n }\n }\n }\n return clonedNode;\n };\n};\nexport { patchBrowser };\n","export { setNonce } from '@stencil/core';\nimport { bootstrapLazy } from '@stencil/core';\nimport { patchBrowser } from '@stencil/core/internal/client/patch-browser';\nimport { globalScripts } from '@stencil/core/internal/app-globals';\npatchBrowser().then(options => {\n globalScripts();\n return bootstrapLazy([/*!__STENCIL_LAZY_DATA__*/], options);\n});\n"],"version":3}
@@ -0,0 +1,105 @@
1
+ 'use strict';
2
+
3
+ const index = require('./index-c07c0cdb.js');
4
+ const index$1 = require('./index-8c288b1a.js');
5
+ const _package = require('./package-cd0e9960.js');
6
+ const checkNonEmpty = require('./check-non-empty-eeaa8f77.js');
7
+
8
+ 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)}}";
9
+
10
+ const CDN_URL = 'https://unpkg.com/@swisspost/design-system-icons/public/post-icons';
11
+ const ANIMATION_NAMES = [
12
+ 'cylon',
13
+ 'cylon-vertical',
14
+ 'spin',
15
+ 'spin-reverse',
16
+ 'fade',
17
+ 'throb',
18
+ ];
19
+ const ANIMATION_KEYS = [...ANIMATION_NAMES];
20
+ const PostIcon = class {
21
+ constructor(hostRef) {
22
+ index.registerInstance(this, hostRef);
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
+ index$1.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
+ index$1.checkEmptyOrType(newValue, 'string', 'The post-icon "base" prop should be a string.');
39
+ }
40
+ validateFlipH(newValue = this.flipH) {
41
+ index$1.checkEmptyOrType(newValue, 'boolean', 'The post-icon "flipH" prop should be a boolean.');
42
+ }
43
+ validateFlipV(newValue = this.flipV) {
44
+ index$1.checkEmptyOrType(newValue, 'boolean', 'The post-icon "flipV" prop should be a boolean.');
45
+ }
46
+ validateName(newValue = this.name) {
47
+ checkNonEmpty.checkNonEmpty(newValue, 'The post-icon "name" prop is required!.');
48
+ index$1.checkType(newValue, 'string', 'The post-icon "name" prop should be a string.');
49
+ }
50
+ validateRotate(newValue = this.rotate) {
51
+ index$1.checkEmptyOrType(newValue, 'number', 'The post-icon "rotate" prop should be a number.');
52
+ }
53
+ validateScale(newValue = this.scale) {
54
+ index$1.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 (index.h(index.Host, { "data-version": _package.version }, index.h("span", { style: svgStyles })));
89
+ }
90
+ get host() { return index.getElement(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
+ };
101
+ PostIcon.style = postIconCss;
102
+
103
+ exports.PostIcon = PostIcon;
104
+
105
+ //# sourceMappingURL=post-icon-3dbb7728.js.map
@@ -0,0 +1 @@
1
+ {"file":"post-icon-3dbb7728.js","mappings":"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","names":["checkEmptyOrOneOf","checkEmptyOrType","checkNonEmpty","checkType","h","Host","version"],"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}
@@ -2,13 +2,12 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const postIcon = require('./post-icon-91f6603a.js');
6
- require('./index-e7618bb3.js');
7
- require('./index-b38a23e0.js');
5
+ const postIcon = require('./post-icon-3dbb7728.js');
6
+ require('./index-c07c0cdb.js');
7
+ require('./index-8c288b1a.js');
8
8
  require('./constants-238701d3.js');
9
- require('./check-one-of-27ad3154.js');
10
- require('./package-041a8597.js');
11
- require('./check-non-empty-ae713942.js');
9
+ require('./package-cd0e9960.js');
10
+ require('./check-non-empty-eeaa8f77.js');
12
11
 
13
12
 
14
13
 
@@ -1 +1 @@
1
- {"file":"post-icon.entry.cjs.js","mappings":";;;;;;;;;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}
1
+ {"file":"post-icon.entry.cjs.js","mappings":";;;;;;;;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}
@@ -0,0 +1,118 @@
1
+ 'use strict';
2
+
3
+ const index = require('./index-c07c0cdb.js');
4
+ const _package = require('./package-cd0e9960.js');
5
+
6
+ const postPopoverCss = "/*!\n * Copyright 2021 by Swiss Post, Information Technology\n */.btn-close{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;outline-offset:2px;border-radius:4px;color:var(--post-gray-80);transition:opacity 250ms,border-color 250ms,background-color 250ms,color 250ms;cursor:pointer}.btn-close:is(:focus-visible,:focus-within,.pretend-focus){outline:2px solid var(--post-contrast-color)}.btn-close::before{-webkit-mask-image:url(\"data:image/svg+xml,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cg id='icon'%3E%3Cpath d='m16.267 16.667 6.667-6.533-.933-1.067-6.667 6.667-6.667-6.667-.933 1.067 6.667 6.533-6.667 6.667 1.067.933 6.533-6.667 6.667 6.667.933-1.067z'/%3E%3C/g%3E%3C/svg%3E\");mask-image:url(\"data:image/svg+xml,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cg id='icon'%3E%3Cpath d='m16.267 16.667 6.667-6.533-.933-1.067-6.667 6.667-6.667-6.667-.933 1.067 6.667 6.533-6.667 6.667 1.067.933 6.533-6.667 6.667 6.667.933-1.067z'/%3E%3C/g%3E%3C/svg%3E\");background-color:currentColor;content:\"\";display:block;height:1.5rem;width:1.5rem}.btn-close:focus,.btn-close:not(:disabled):hover,.pretend-hover.btn-close{color:var(--post-contrast-color)}.btn-close:disabled{color:var(--post-gray-40)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.btn-close{color:CanvasText;forced-color-adjust:none}}.btn-close-white{color:#e6e6e6}.btn-close-white:focus,.btn-close-white:not(:disabled):hover,.btn-close-white.pretend-hover{color:#fff}.btn-close-white:disabled{color:#999}*{box-sizing:border-box}:host{--post-contrast-color:#fff;--post-bg-rgb:51, 51, 51;display:block}.visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);border:0}.popover-container{display:flex;align-items:self-start;padding:.5em;max-width:min(66vw,60rem)}@media (max-width: 599.98px){.popover-container{max-width:100%}}.popover-content{padding:.5em}";
7
+
8
+ const PostPopover = class {
9
+ constructor(hostRef) {
10
+ index.registerInstance(this, hostRef);
11
+ this.placement = 'top';
12
+ this.closeButtonCaption = undefined;
13
+ this.arrow = true;
14
+ this.localTogglePopover = e => this.toggle(e.target);
15
+ this.localEnterTogglePopover = e => {
16
+ if (e.key === 'Enter')
17
+ this.toggle(e.target);
18
+ };
19
+ this.localTouchTogglePopover = e => {
20
+ e.preventDefault();
21
+ this.toggle(e.target);
22
+ };
23
+ }
24
+ connectedCallback() {
25
+ if (!this.triggers) {
26
+ throw new Error(`No trigger found for <post-popover popover-id="${this.host.id}`);
27
+ }
28
+ // As long as cross-shadow-boundary [popovertarget] and button.popoverTargetElement are not working
29
+ // we're left with listening to trigger events ourselves
30
+ // https://developer.mozilla.org/en-US/docs/Web/API/HTMLButtonElement/popoverTargetElement
31
+ // https://github.com/whatwg/html/issues/9109#issuecomment-1494030465 (does not seem to work for now)
32
+ // https://stackoverflow.com/questions/77324143/popovertargetelement-does-not-cross-shadow-boundaries?noredirect=1#comment136318281_77324143
33
+ this.triggers.forEach(trigger => {
34
+ // See this.onToggle for one time mouse event listener
35
+ trigger.addEventListener('mouseup', this.localTogglePopover, { once: true });
36
+ trigger.addEventListener('keypress', this.localEnterTogglePopover);
37
+ trigger.addEventListener('touch', this.localTouchTogglePopover, { once: true });
38
+ trigger.setAttribute('aria-expanded', 'false');
39
+ });
40
+ }
41
+ disconnectedCallback() {
42
+ this.triggers.forEach(trigger => {
43
+ trigger.removeEventListener('mouseup', this.localTogglePopover);
44
+ trigger.removeEventListener('keypress', this.localEnterTogglePopover);
45
+ trigger.removeEventListener('touch', this.localTouchTogglePopover);
46
+ trigger.removeAttribute('aria-expanded');
47
+ });
48
+ }
49
+ /**
50
+ * Programmatically display the popover
51
+ * @param target An element with [data-popover-target="id"] where the popover should be shown
52
+ */
53
+ async show(target) {
54
+ this.currentTarget = target;
55
+ this.popoverRef.show(target);
56
+ target.setAttribute('aria-expanded', 'true');
57
+ }
58
+ /**
59
+ * Programmatically hide this popover
60
+ */
61
+ async hide() {
62
+ this.popoverRef.hide();
63
+ this.triggers.forEach(trigger => trigger.setAttribute('aria-expanded', 'false'));
64
+ }
65
+ /**
66
+ * Toggle popover display
67
+ * @param target An element with [data-popover-target="id"] where the popover should be anchored to
68
+ * @param force Pass true to always show or false to always hide
69
+ */
70
+ async toggle(target, force) {
71
+ this.currentTarget = target;
72
+ const newState = await this.popoverRef.toggle(target, force);
73
+ target.setAttribute('aria-expanded', `${newState}`);
74
+ }
75
+ get triggers() {
76
+ return document.querySelectorAll(`[data-popover-target="${this.host.id}"]`);
77
+ }
78
+ /**
79
+ * One time event handler for click events
80
+ * A permanent event listener would prevent a toggle button from working properly:
81
+ * A click opens the popover, a second click first closes it (due to light dismiss), then directly
82
+ * opens it again because of the click listener on the button. Registering a new
83
+ * one time listener after a small timeout solves this issue.
84
+ * @param e toggle event from post-popovercontainer
85
+ */
86
+ onToggle(e) {
87
+ if (this.currentTarget) {
88
+ this.currentTarget.setAttribute('aria-expanded', `${e.detail}`);
89
+ }
90
+ if (!e.detail) {
91
+ window.requestAnimationFrame(() => {
92
+ this.triggers.forEach(trigger => {
93
+ trigger.addEventListener('mouseup', this.localTogglePopover, { once: true });
94
+ trigger.addEventListener('touch', this.localTouchTogglePopover, { once: true });
95
+ });
96
+ });
97
+ // Handle missing re-focusing logic after close. Can be removed as soon as popovertarget works correctly
98
+ if (this.currentTarget) {
99
+ this.currentTarget.focus();
100
+ this.currentTarget = null;
101
+ }
102
+ }
103
+ }
104
+ // Fix for firefox to prevent the following lines from triggering
105
+ // https://github.com/oddbird/popover-polyfill/blob/main/src/popover.ts#L338
106
+ stopImmediatePropagation(e) {
107
+ e.stopImmediatePropagation();
108
+ }
109
+ render() {
110
+ return (index.h(index.Host, { "data-version": _package.version }, index.h("post-popovercontainer", { arrow: this.arrow, placement: this.placement, ref: e => (this.popoverRef = e), onPostPopoverToggled: e => this.onToggle(e) }, index.h("div", { class: "popover-container", onPointerDown: e => this.stopImmediatePropagation(e), onPointerUp: e => this.stopImmediatePropagation(e) }, index.h("div", { class: "popover-content" }, index.h("slot", null)), index.h("button", { class: "btn-close", onClick: () => this.hide() }, index.h("span", { class: "visually-hidden" }, this.closeButtonCaption))))));
111
+ }
112
+ get host() { return index.getElement(this); }
113
+ };
114
+ PostPopover.style = postPopoverCss;
115
+
116
+ exports.PostPopover = PostPopover;
117
+
118
+ //# sourceMappingURL=post-popover-ea22d235.js.map
@@ -0,0 +1 @@
1
+ {"file":"post-popover-ea22d235.js","mappings":"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","names":["h","Host","version"],"sources":["src/components/post-popover/post-popover.scss?tag=post-popover&encapsulation=shadow","src/components/post-popover/post-popover.tsx"],"sourcesContent":["@use '@swisspost/design-system-styles/core' as post;\n@use '@swisspost/design-system-styles/components/close';\n\n* {\n box-sizing: border-box;\n}\n\n:host {\n --post-contrast-color: #{post.$white};\n --post-bg-rgb: #{post.rgb-values(post.$gray-80)};\n\n display: block;\n}\n\n.visually-hidden {\n @include post.visuallyhidden();\n}\n\n.popover-container {\n display: flex;\n align-items: self-start;\n padding: 0.5em;\n\n // Max 2/3 of the column width\n max-width: min(66vw, 60rem);\n\n // Max available width on mobile, popovercontainer will handle offsets\n @include post.media-breakpoint-down(rg) {\n max-width: 100%;\n }\n}\n\n.popover-content {\n padding: 0.5em;\n}\n","import { Component, Element, h, Host, Method, Prop } from '@stencil/core';\nimport { Placement } from '@floating-ui/dom';\n\nimport { version } from '../../../package.json';\n@Component({\n tag: 'post-popover',\n styleUrl: 'post-popover.scss',\n shadow: true,\n})\nexport class PostPopover {\n private popoverRef: HTMLPostPopovercontainerElement;\n private localTogglePopover: (e: Event) => Promise<void>;\n private localEnterTogglePopover: (e: KeyboardEvent) => void;\n private localTouchTogglePopover: (e: TouchEvent) => void;\n private currentTarget: HTMLElement;\n\n @Element() host: HTMLPostPopoverElement;\n\n /**\n * Defines the placement of the popover according to the floating-ui options available at https://floating-ui.com/docs/computePosition#placement.\n * Popoverss are automatically flipped to the opposite side if there is not enough available space and are shifted\n * towards the viewport if they would overlap edge boundaries.\n */\n @Prop() readonly placement?: Placement = 'top';\n\n /**\n * Define the caption of the close button for assistive technology\n */\n @Prop() readonly closeButtonCaption!: string;\n /**\n * Show a little indicator arrow\n */\n // eslint-disable-next-line @stencil-community/ban-default-true\n @Prop() readonly arrow?: boolean = true;\n\n constructor() {\n this.localTogglePopover = e => this.toggle(e.target as HTMLElement);\n this.localEnterTogglePopover = e => {\n if (e.key === 'Enter') this.toggle(e.target as HTMLElement);\n };\n this.localTouchTogglePopover = e => {\n e.preventDefault();\n this.toggle(e.target as HTMLElement);\n };\n }\n\n connectedCallback() {\n if (!this.triggers) {\n throw new Error(`No trigger found for <post-popover popover-id=\"${this.host.id}`);\n }\n\n // As long as cross-shadow-boundary [popovertarget] and button.popoverTargetElement are not working\n // we're left with listening to trigger events ourselves\n // https://developer.mozilla.org/en-US/docs/Web/API/HTMLButtonElement/popoverTargetElement\n // https://github.com/whatwg/html/issues/9109#issuecomment-1494030465 (does not seem to work for now)\n // https://stackoverflow.com/questions/77324143/popovertargetelement-does-not-cross-shadow-boundaries?noredirect=1#comment136318281_77324143\n this.triggers.forEach(trigger => {\n // See this.onToggle for one time mouse event listener\n trigger.addEventListener('mouseup', this.localTogglePopover, { once: true });\n trigger.addEventListener('keypress', this.localEnterTogglePopover);\n trigger.addEventListener('touch', this.localTouchTogglePopover, { once: true });\n trigger.setAttribute('aria-expanded', 'false');\n });\n }\n\n disconnectedCallback() {\n this.triggers.forEach(trigger => {\n trigger.removeEventListener('mouseup', this.localTogglePopover);\n trigger.removeEventListener('keypress', this.localEnterTogglePopover);\n trigger.removeEventListener('touch', this.localTouchTogglePopover);\n trigger.removeAttribute('aria-expanded');\n });\n }\n\n /**\n * Programmatically display the popover\n * @param target An element with [data-popover-target=\"id\"] where the popover should be shown\n */\n @Method()\n async show(target: HTMLElement) {\n this.currentTarget = target;\n this.popoverRef.show(target);\n target.setAttribute('aria-expanded', 'true');\n }\n\n /**\n * Programmatically hide this popover\n */\n @Method()\n async hide() {\n this.popoverRef.hide();\n this.triggers.forEach(trigger => trigger.setAttribute('aria-expanded', 'false'));\n }\n\n /**\n * Toggle popover display\n * @param target An element with [data-popover-target=\"id\"] where the popover should be anchored to\n * @param force Pass true to always show or false to always hide\n */\n @Method()\n async toggle(target: HTMLElement, force?: boolean) {\n this.currentTarget = target;\n const newState = await this.popoverRef.toggle(target, force);\n target.setAttribute('aria-expanded', `${newState}`);\n }\n\n private get triggers() {\n return document.querySelectorAll(`[data-popover-target=\"${this.host.id}\"]`);\n }\n\n /**\n * One time event handler for click events\n * A permanent event listener would prevent a toggle button from working properly:\n * A click opens the popover, a second click first closes it (due to light dismiss), then directly\n * opens it again because of the click listener on the button. Registering a new\n * one time listener after a small timeout solves this issue.\n * @param e toggle event from post-popovercontainer\n */\n private onToggle(e: CustomEvent<boolean>) {\n if (this.currentTarget) {\n this.currentTarget.setAttribute('aria-expanded', `${e.detail}`);\n }\n if (!e.detail) {\n window.requestAnimationFrame(() => {\n this.triggers.forEach(trigger => {\n trigger.addEventListener('mouseup', this.localTogglePopover, { once: true });\n trigger.addEventListener('touch', this.localTouchTogglePopover, { once: true });\n });\n });\n\n // Handle missing re-focusing logic after close. Can be removed as soon as popovertarget works correctly\n if (this.currentTarget) {\n this.currentTarget.focus();\n this.currentTarget = null;\n }\n }\n }\n\n // Fix for firefox to prevent the following lines from triggering\n // https://github.com/oddbird/popover-polyfill/blob/main/src/popover.ts#L338\n private stopImmediatePropagation(e: PointerEvent) {\n e.stopImmediatePropagation();\n }\n\n render() {\n return (\n <Host data-version={version}>\n <post-popovercontainer\n arrow={this.arrow}\n placement={this.placement}\n ref={e => (this.popoverRef = e)}\n onPostPopoverToggled={e => this.onToggle(e)}\n >\n <div\n class=\"popover-container\"\n onPointerDown={e => this.stopImmediatePropagation(e)}\n onPointerUp={e => this.stopImmediatePropagation(e)}\n >\n <div class=\"popover-content\">\n <slot></slot>\n </div>\n <button class=\"btn-close\" onClick={() => this.hide()}>\n <span class=\"visually-hidden\">{this.closeButtonCaption}</span>\n </button>\n </div>\n </post-popovercontainer>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,13 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const postPopover = require('./post-popover-ea22d235.js');
6
+ require('./index-c07c0cdb.js');
7
+ require('./package-cd0e9960.js');
8
+
9
+
10
+
11
+ exports.post_popover = postPopover.PostPopover;
12
+
13
+ //# sourceMappingURL=post-popover.cjs.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"post-popover.entry.cjs.js","mappings":";;;;;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}