@universityofmaryland/web-elements-library 1.4.8 → 1.5.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 (1145) hide show
  1. package/README.md +1 -1
  2. package/dist/atomic/actions/icon.d.ts.map +1 -1
  3. package/dist/atomic/actions/icon.js +21 -22
  4. package/dist/atomic/actions/icon.js.map +1 -1
  5. package/dist/atomic/actions/icon.mjs +20 -21
  6. package/dist/atomic/actions/icon.mjs.map +1 -1
  7. package/dist/atomic/actions/text.d.ts.map +1 -1
  8. package/dist/atomic/actions/text.js +22 -19
  9. package/dist/atomic/actions/text.js.map +1 -1
  10. package/dist/atomic/actions/text.mjs +21 -19
  11. package/dist/atomic/actions/text.mjs.map +1 -1
  12. package/dist/atomic/animations/actions/indicator.d.ts.map +1 -1
  13. package/dist/atomic/animations/actions/indicator.js +32 -21
  14. package/dist/atomic/animations/actions/indicator.js.map +1 -1
  15. package/dist/atomic/animations/actions/indicator.mjs +3 -9
  16. package/dist/atomic/animations/actions/indicator.mjs.map +1 -1
  17. package/dist/atomic/animations/brand/card-stack.d.ts.map +1 -1
  18. package/dist/atomic/animations/brand/card-stack.js +42 -32
  19. package/dist/atomic/animations/brand/card-stack.js.map +1 -1
  20. package/dist/atomic/animations/brand/card-stack.mjs +21 -11
  21. package/dist/atomic/animations/brand/card-stack.mjs.map +1 -1
  22. package/dist/atomic/animations/brand/chevron-scroll.js +25 -8
  23. package/dist/atomic/animations/brand/chevron-scroll.js.map +1 -1
  24. package/dist/atomic/animations/brand/chevron-scroll.mjs +1 -1
  25. package/dist/atomic/animations/brand/chevron-scroll.mjs.map +1 -1
  26. package/dist/atomic/assets/image/gif.d.ts.map +1 -1
  27. package/dist/atomic/assets/image/gif.js +5 -8
  28. package/dist/atomic/assets/image/gif.js.map +1 -1
  29. package/dist/atomic/assets/image/gif.mjs +4 -7
  30. package/dist/atomic/assets/image/gif.mjs.map +1 -1
  31. package/dist/atomic/assets/video/observed-auto-play.js +2 -5
  32. package/dist/atomic/assets/video/observed-auto-play.js.map +1 -1
  33. package/dist/atomic/assets/video/observed-auto-play.mjs +2 -5
  34. package/dist/atomic/assets/video/observed-auto-play.mjs.map +1 -1
  35. package/dist/atomic/assets/video/toggle.d.ts.map +1 -1
  36. package/dist/atomic/assets/video/toggle.js +4 -7
  37. package/dist/atomic/assets/video/toggle.js.map +1 -1
  38. package/dist/atomic/assets/video/toggle.mjs +4 -7
  39. package/dist/atomic/assets/video/toggle.mjs.map +1 -1
  40. package/dist/atomic/buttons/fullscreen.js +2 -5
  41. package/dist/atomic/buttons/fullscreen.js.map +1 -1
  42. package/dist/atomic/buttons/fullscreen.mjs +2 -5
  43. package/dist/atomic/buttons/fullscreen.mjs.map +1 -1
  44. package/dist/atomic/events/meta.d.ts.map +1 -1
  45. package/dist/atomic/events/meta.js +8 -10
  46. package/dist/atomic/events/meta.js.map +1 -1
  47. package/dist/atomic/events/meta.mjs +5 -7
  48. package/dist/atomic/events/meta.mjs.map +1 -1
  49. package/dist/atomic/events/sign.js +19 -2
  50. package/dist/atomic/events/sign.js.map +1 -1
  51. package/dist/atomic/events/sign.mjs +2 -2
  52. package/dist/atomic/events/sign.mjs.map +1 -1
  53. package/dist/atomic/layout/block/stacked.d.ts.map +1 -1
  54. package/dist/atomic/layout/block/stacked.js +37 -55
  55. package/dist/atomic/layout/block/stacked.js.map +1 -1
  56. package/dist/atomic/layout/block/stacked.mjs +36 -54
  57. package/dist/atomic/layout/block/stacked.mjs.map +1 -1
  58. package/dist/atomic/layout/overlay/modal.d.ts.map +1 -1
  59. package/dist/atomic/layout/overlay/modal.js +22 -8
  60. package/dist/atomic/layout/overlay/modal.js.map +1 -1
  61. package/dist/atomic/layout/overlay/modal.mjs +3 -6
  62. package/dist/atomic/layout/overlay/modal.mjs.map +1 -1
  63. package/dist/atomic/layout/person/columns.d.ts.map +1 -1
  64. package/dist/atomic/layout/person/columns.js +36 -34
  65. package/dist/atomic/layout/person/columns.js.map +1 -1
  66. package/dist/atomic/layout/person/columns.mjs +35 -33
  67. package/dist/atomic/layout/person/columns.mjs.map +1 -1
  68. package/dist/atomic/text/stat.d.ts.map +1 -1
  69. package/dist/atomic/text/stat.js +47 -29
  70. package/dist/atomic/text/stat.js.map +1 -1
  71. package/dist/atomic/text/stat.mjs +30 -29
  72. package/dist/atomic/text/stat.mjs.map +1 -1
  73. package/dist/atomic/text-lockup/contact.d.ts.map +1 -1
  74. package/dist/atomic/text-lockup/contact.js +13 -15
  75. package/dist/atomic/text-lockup/contact.js.map +1 -1
  76. package/dist/atomic/text-lockup/contact.mjs +18 -20
  77. package/dist/atomic/text-lockup/contact.mjs.map +1 -1
  78. package/dist/atomic/text-lockup/date.d.ts.map +1 -1
  79. package/dist/atomic/text-lockup/date.js +24 -20
  80. package/dist/atomic/text-lockup/date.js.map +1 -1
  81. package/dist/atomic/text-lockup/date.mjs +11 -9
  82. package/dist/atomic/text-lockup/date.mjs.map +1 -1
  83. package/dist/atomic/text-lockup/large.js +7 -7
  84. package/dist/atomic/text-lockup/large.js.map +1 -1
  85. package/dist/atomic/text-lockup/large.mjs +6 -6
  86. package/dist/atomic/text-lockup/large.mjs.map +1 -1
  87. package/dist/atomic/text-lockup/medium.js +9 -9
  88. package/dist/atomic/text-lockup/medium.js.map +1 -1
  89. package/dist/atomic/text-lockup/medium.mjs +8 -8
  90. package/dist/atomic/text-lockup/medium.mjs.map +1 -1
  91. package/dist/atomic/text-lockup/person.js +5 -5
  92. package/dist/atomic/text-lockup/person.js.map +1 -1
  93. package/dist/atomic/text-lockup/person.mjs +4 -4
  94. package/dist/atomic/text-lockup/person.mjs.map +1 -1
  95. package/dist/atomic/text-lockup/small.d.ts.map +1 -1
  96. package/dist/atomic/text-lockup/small.js +15 -14
  97. package/dist/atomic/text-lockup/small.js.map +1 -1
  98. package/dist/atomic/text-lockup/small.mjs +3 -3
  99. package/dist/atomic/text-lockup/small.mjs.map +1 -1
  100. package/dist/composite/accordion/item.d.ts.map +1 -1
  101. package/dist/composite/accordion/item.js +5 -5
  102. package/dist/composite/accordion/item.js.map +1 -1
  103. package/dist/composite/accordion/item.mjs +4 -4
  104. package/dist/composite/accordion/item.mjs.map +1 -1
  105. package/dist/composite/alert/elements/text.d.ts.map +1 -1
  106. package/dist/composite/alert/elements/text.js +34 -14
  107. package/dist/composite/alert/elements/text.js.map +1 -1
  108. package/dist/composite/alert/elements/text.mjs +5 -3
  109. package/dist/composite/alert/elements/text.mjs.map +1 -1
  110. package/dist/composite/alert/page.d.ts.map +1 -1
  111. package/dist/composite/alert/page.js +37 -22
  112. package/dist/composite/alert/page.js.map +1 -1
  113. package/dist/composite/alert/page.mjs +6 -8
  114. package/dist/composite/alert/page.mjs.map +1 -1
  115. package/dist/composite/alert/site.d.ts.map +1 -1
  116. package/dist/composite/alert/site.js +46 -27
  117. package/dist/composite/alert/site.js.map +1 -1
  118. package/dist/composite/alert/site.mjs +10 -9
  119. package/dist/composite/alert/site.mjs.map +1 -1
  120. package/dist/composite/banner/promo.d.ts.map +1 -1
  121. package/dist/composite/banner/promo.js +12 -10
  122. package/dist/composite/banner/promo.js.map +1 -1
  123. package/dist/composite/banner/promo.mjs +12 -10
  124. package/dist/composite/banner/promo.mjs.map +1 -1
  125. package/dist/composite/card/block.js +21 -9
  126. package/dist/composite/card/block.js.map +1 -1
  127. package/dist/composite/card/block.mjs +20 -8
  128. package/dist/composite/card/block.mjs.map +1 -1
  129. package/dist/composite/card/list.d.ts.map +1 -1
  130. package/dist/composite/card/list.js +47 -48
  131. package/dist/composite/card/list.js.map +1 -1
  132. package/dist/composite/card/list.mjs +46 -47
  133. package/dist/composite/card/list.mjs.map +1 -1
  134. package/dist/composite/card/overlay/color.d.ts.map +1 -1
  135. package/dist/composite/card/overlay/color.js +24 -12
  136. package/dist/composite/card/overlay/color.js.map +1 -1
  137. package/dist/composite/card/overlay/color.mjs +22 -11
  138. package/dist/composite/card/overlay/color.mjs.map +1 -1
  139. package/dist/composite/card/overlay/icon.js +21 -10
  140. package/dist/composite/card/overlay/icon.js.map +1 -1
  141. package/dist/composite/card/overlay/icon.mjs +20 -9
  142. package/dist/composite/card/overlay/icon.mjs.map +1 -1
  143. package/dist/composite/card/overlay/image.d.ts.map +1 -1
  144. package/dist/composite/card/overlay/image.js +29 -20
  145. package/dist/composite/card/overlay/image.js.map +1 -1
  146. package/dist/composite/card/overlay/image.mjs +27 -18
  147. package/dist/composite/card/overlay/image.mjs.map +1 -1
  148. package/dist/composite/card/video/block.js +15 -4
  149. package/dist/composite/card/video/block.js.map +1 -1
  150. package/dist/composite/card/video/block.mjs +15 -4
  151. package/dist/composite/card/video/block.mjs.map +1 -1
  152. package/dist/composite/carousel/cards/index.js +6 -6
  153. package/dist/composite/carousel/cards/index.js.map +1 -1
  154. package/dist/composite/carousel/cards/index.mjs +6 -6
  155. package/dist/composite/carousel/cards/index.mjs.map +1 -1
  156. package/dist/composite/carousel/default/index.js +24 -7
  157. package/dist/composite/carousel/default/index.js.map +1 -1
  158. package/dist/composite/carousel/default/index.mjs +1 -1
  159. package/dist/composite/carousel/default/index.mjs.map +1 -1
  160. package/dist/composite/carousel/elements/blocks.d.ts.map +1 -1
  161. package/dist/composite/carousel/elements/blocks.js +20 -22
  162. package/dist/composite/carousel/elements/blocks.js.map +1 -1
  163. package/dist/composite/carousel/elements/blocks.mjs +11 -14
  164. package/dist/composite/carousel/elements/blocks.mjs.map +1 -1
  165. package/dist/composite/carousel/elements/full-screen.js +36 -8
  166. package/dist/composite/carousel/elements/full-screen.js.map +1 -1
  167. package/dist/composite/carousel/elements/full-screen.mjs +17 -6
  168. package/dist/composite/carousel/elements/full-screen.mjs.map +1 -1
  169. package/dist/composite/carousel/elements/image.d.ts.map +1 -1
  170. package/dist/composite/carousel/elements/image.js +32 -21
  171. package/dist/composite/carousel/elements/image.js.map +1 -1
  172. package/dist/composite/carousel/elements/image.mjs +8 -14
  173. package/dist/composite/carousel/elements/image.mjs.map +1 -1
  174. package/dist/composite/carousel/elements/overlay.js +19 -2
  175. package/dist/composite/carousel/elements/overlay.js.map +1 -1
  176. package/dist/composite/carousel/elements/overlay.mjs +1 -1
  177. package/dist/composite/carousel/elements/overlay.mjs.map +1 -1
  178. package/dist/composite/carousel/image/multiple.d.ts.map +1 -1
  179. package/dist/composite/carousel/image/multiple.js +24 -12
  180. package/dist/composite/carousel/image/multiple.js.map +1 -1
  181. package/dist/composite/carousel/image/multiple.mjs +17 -6
  182. package/dist/composite/carousel/image/multiple.mjs.map +1 -1
  183. package/dist/composite/carousel/image/standard.d.ts.map +1 -1
  184. package/dist/composite/carousel/image/standard.js +44 -47
  185. package/dist/composite/carousel/image/standard.js.map +1 -1
  186. package/dist/composite/carousel/image/standard.mjs +19 -5
  187. package/dist/composite/carousel/image/standard.mjs.map +1 -1
  188. package/dist/composite/carousel/thumbnail/index.js +29 -12
  189. package/dist/composite/carousel/thumbnail/index.js.map +1 -1
  190. package/dist/composite/carousel/thumbnail/index.mjs +1 -1
  191. package/dist/composite/carousel/thumbnail/index.mjs.map +1 -1
  192. package/dist/composite/carousel/wide/controls.d.ts.map +1 -1
  193. package/dist/composite/carousel/wide/controls.js +40 -30
  194. package/dist/composite/carousel/wide/controls.js.map +1 -1
  195. package/dist/composite/carousel/wide/controls.mjs +39 -29
  196. package/dist/composite/carousel/wide/controls.mjs.map +1 -1
  197. package/dist/composite/carousel/wide/frames.js +44 -33
  198. package/dist/composite/carousel/wide/frames.js.map +1 -1
  199. package/dist/composite/carousel/wide/frames.mjs +43 -32
  200. package/dist/composite/carousel/wide/frames.mjs.map +1 -1
  201. package/dist/composite/carousel/wide/index.d.ts.map +1 -1
  202. package/dist/composite/carousel/wide/index.js +17 -6
  203. package/dist/composite/carousel/wide/index.js.map +1 -1
  204. package/dist/composite/carousel/wide/index.mjs +16 -5
  205. package/dist/composite/carousel/wide/index.mjs.map +1 -1
  206. package/dist/composite/footer/elements/main-section/call-to-action.d.ts +5 -4
  207. package/dist/composite/footer/elements/main-section/call-to-action.d.ts.map +1 -1
  208. package/dist/composite/footer/elements/main-section/call-to-action.js +56 -37
  209. package/dist/composite/footer/elements/main-section/call-to-action.js.map +1 -1
  210. package/dist/composite/footer/elements/main-section/call-to-action.mjs +40 -37
  211. package/dist/composite/footer/elements/main-section/call-to-action.mjs.map +1 -1
  212. package/dist/composite/footer/elements/main-section/campaign.d.ts +3 -3
  213. package/dist/composite/footer/elements/main-section/campaign.d.ts.map +1 -1
  214. package/dist/composite/footer/elements/main-section/campaign.js +57 -22
  215. package/dist/composite/footer/elements/main-section/campaign.js.map +1 -1
  216. package/dist/composite/footer/elements/main-section/campaign.mjs +40 -22
  217. package/dist/composite/footer/elements/main-section/campaign.mjs.map +1 -1
  218. package/dist/composite/footer/elements/main-section/index.d.ts +3 -2
  219. package/dist/composite/footer/elements/main-section/index.d.ts.map +1 -1
  220. package/dist/composite/footer/elements/main-section/index.js +81 -94
  221. package/dist/composite/footer/elements/main-section/index.js.map +1 -1
  222. package/dist/composite/footer/elements/main-section/index.mjs +82 -95
  223. package/dist/composite/footer/elements/main-section/index.mjs.map +1 -1
  224. package/dist/composite/footer/elements/main-section/row-links/index.d.ts +5 -5
  225. package/dist/composite/footer/elements/main-section/row-links/index.d.ts.map +1 -1
  226. package/dist/composite/footer/elements/main-section/row-links/index.js +44 -72
  227. package/dist/composite/footer/elements/main-section/row-links/index.js.map +1 -1
  228. package/dist/composite/footer/elements/main-section/row-links/index.mjs +48 -75
  229. package/dist/composite/footer/elements/main-section/row-links/index.mjs.map +1 -1
  230. package/dist/composite/footer/elements/main-section/row-links/link-columns.d.ts +5 -3
  231. package/dist/composite/footer/elements/main-section/row-links/link-columns.d.ts.map +1 -1
  232. package/dist/composite/footer/elements/main-section/row-links/link-columns.js +178 -223
  233. package/dist/composite/footer/elements/main-section/row-links/link-columns.js.map +1 -1
  234. package/dist/composite/footer/elements/main-section/row-links/link-columns.mjs +180 -224
  235. package/dist/composite/footer/elements/main-section/row-links/link-columns.mjs.map +1 -1
  236. package/dist/composite/footer/elements/main-section/row-logo/contact.d.ts +5 -4
  237. package/dist/composite/footer/elements/main-section/row-logo/contact.d.ts.map +1 -1
  238. package/dist/composite/footer/elements/main-section/row-logo/contact.js +165 -199
  239. package/dist/composite/footer/elements/main-section/row-logo/contact.js.map +1 -1
  240. package/dist/composite/footer/elements/main-section/row-logo/contact.mjs +166 -199
  241. package/dist/composite/footer/elements/main-section/row-logo/contact.mjs.map +1 -1
  242. package/dist/composite/footer/elements/main-section/row-logo/index.d.ts +6 -3
  243. package/dist/composite/footer/elements/main-section/row-logo/index.d.ts.map +1 -1
  244. package/dist/composite/footer/elements/main-section/row-logo/index.js +54 -95
  245. package/dist/composite/footer/elements/main-section/row-logo/index.js.map +1 -1
  246. package/dist/composite/footer/elements/main-section/row-logo/index.mjs +59 -99
  247. package/dist/composite/footer/elements/main-section/row-logo/index.mjs.map +1 -1
  248. package/dist/composite/footer/elements/main-section/row-logo/logo.d.ts +4 -2
  249. package/dist/composite/footer/elements/main-section/row-logo/logo.d.ts.map +1 -1
  250. package/dist/composite/footer/elements/main-section/row-logo/logo.js +78 -71
  251. package/dist/composite/footer/elements/main-section/row-logo/logo.js.map +1 -1
  252. package/dist/composite/footer/elements/main-section/row-logo/logo.mjs +64 -74
  253. package/dist/composite/footer/elements/main-section/row-logo/logo.mjs.map +1 -1
  254. package/dist/composite/footer/elements/main-section/social.d.ts +5 -6
  255. package/dist/composite/footer/elements/main-section/social.d.ts.map +1 -1
  256. package/dist/composite/footer/elements/main-section/social.js +128 -202
  257. package/dist/composite/footer/elements/main-section/social.js.map +1 -1
  258. package/dist/composite/footer/elements/main-section/social.mjs +130 -203
  259. package/dist/composite/footer/elements/main-section/social.mjs.map +1 -1
  260. package/dist/composite/footer/elements/utility-section/index.d.ts +4 -2
  261. package/dist/composite/footer/elements/utility-section/index.d.ts.map +1 -1
  262. package/dist/composite/footer/elements/utility-section/index.js +107 -116
  263. package/dist/composite/footer/elements/utility-section/index.js.map +1 -1
  264. package/dist/composite/footer/elements/utility-section/index.mjs +109 -117
  265. package/dist/composite/footer/elements/utility-section/index.mjs.map +1 -1
  266. package/dist/composite/footer/globals.d.ts +0 -32
  267. package/dist/composite/footer/globals.d.ts.map +1 -1
  268. package/dist/composite/footer/globals.js +0 -19
  269. package/dist/composite/footer/globals.js.map +1 -1
  270. package/dist/composite/footer/globals.mjs +1 -20
  271. package/dist/composite/footer/globals.mjs.map +1 -1
  272. package/dist/composite/footer/options.d.ts +1 -1
  273. package/dist/composite/footer/options.d.ts.map +1 -1
  274. package/dist/composite/footer/options.js +52 -30
  275. package/dist/composite/footer/options.js.map +1 -1
  276. package/dist/composite/footer/options.mjs +37 -33
  277. package/dist/composite/footer/options.mjs.map +1 -1
  278. package/dist/composite/hero/custom/expand.d.ts.map +1 -1
  279. package/dist/composite/hero/custom/expand.js +36 -25
  280. package/dist/composite/hero/custom/expand.js.map +1 -1
  281. package/dist/composite/hero/custom/expand.mjs +30 -19
  282. package/dist/composite/hero/custom/expand.mjs.map +1 -1
  283. package/dist/composite/hero/custom/grid.d.ts.map +1 -1
  284. package/dist/composite/hero/custom/grid.js +48 -38
  285. package/dist/composite/hero/custom/grid.js.map +1 -1
  286. package/dist/composite/hero/custom/grid.mjs +35 -25
  287. package/dist/composite/hero/custom/grid.mjs.map +1 -1
  288. package/dist/composite/hero/custom/video-arrow.d.ts.map +1 -1
  289. package/dist/composite/hero/custom/video-arrow.js +23 -15
  290. package/dist/composite/hero/custom/video-arrow.js.map +1 -1
  291. package/dist/composite/hero/custom/video-arrow.mjs +20 -14
  292. package/dist/composite/hero/custom/video-arrow.mjs.map +1 -1
  293. package/dist/composite/hero/logo.d.ts.map +1 -1
  294. package/dist/composite/hero/logo.js +28 -16
  295. package/dist/composite/hero/logo.js.map +1 -1
  296. package/dist/composite/hero/logo.mjs +26 -15
  297. package/dist/composite/hero/logo.mjs.map +1 -1
  298. package/dist/composite/hero/minimal.d.ts.map +1 -1
  299. package/dist/composite/hero/minimal.js +33 -22
  300. package/dist/composite/hero/minimal.js.map +1 -1
  301. package/dist/composite/hero/minimal.mjs +32 -21
  302. package/dist/composite/hero/minimal.mjs.map +1 -1
  303. package/dist/composite/hero/overlay.d.ts.map +1 -1
  304. package/dist/composite/hero/overlay.js +32 -21
  305. package/dist/composite/hero/overlay.js.map +1 -1
  306. package/dist/composite/hero/overlay.mjs +30 -20
  307. package/dist/composite/hero/overlay.mjs.map +1 -1
  308. package/dist/composite/hero/stacked.d.ts.map +1 -1
  309. package/dist/composite/hero/stacked.js +45 -34
  310. package/dist/composite/hero/stacked.js.map +1 -1
  311. package/dist/composite/hero/stacked.mjs +40 -30
  312. package/dist/composite/hero/stacked.mjs.map +1 -1
  313. package/dist/composite/hero/standard.d.ts.map +1 -1
  314. package/dist/composite/hero/standard.js +38 -27
  315. package/dist/composite/hero/standard.js.map +1 -1
  316. package/dist/composite/hero/standard.mjs +36 -26
  317. package/dist/composite/hero/standard.mjs.map +1 -1
  318. package/dist/composite/layout/box/logo.d.ts.map +1 -1
  319. package/dist/composite/layout/box/logo.js +33 -14
  320. package/dist/composite/layout/box/logo.js.map +1 -1
  321. package/dist/composite/layout/box/logo.mjs +5 -4
  322. package/dist/composite/layout/box/logo.mjs.map +1 -1
  323. package/dist/composite/layout/image/expand.d.ts.map +1 -1
  324. package/dist/composite/layout/image/expand.js +32 -13
  325. package/dist/composite/layout/image/expand.js.map +1 -1
  326. package/dist/composite/layout/image/expand.mjs +7 -6
  327. package/dist/composite/layout/image/expand.mjs.map +1 -1
  328. package/dist/composite/layout/scroll-top/index.d.ts.map +1 -1
  329. package/dist/composite/layout/scroll-top/index.js +25 -11
  330. package/dist/composite/layout/scroll-top/index.js.map +1 -1
  331. package/dist/composite/layout/scroll-top/index.mjs +4 -7
  332. package/dist/composite/layout/scroll-top/index.mjs.map +1 -1
  333. package/dist/composite/layout/section-intro/small.d.ts.map +1 -1
  334. package/dist/composite/layout/section-intro/small.js +33 -14
  335. package/dist/composite/layout/section-intro/small.js.map +1 -1
  336. package/dist/composite/layout/section-intro/small.mjs +2 -1
  337. package/dist/composite/layout/section-intro/small.mjs.map +1 -1
  338. package/dist/composite/layout/section-intro/wide.js +20 -3
  339. package/dist/composite/layout/section-intro/wide.js.map +1 -1
  340. package/dist/composite/layout/section-intro/wide.mjs +1 -1
  341. package/dist/composite/layout/section-intro/wide.mjs.map +1 -1
  342. package/dist/composite/layout/sticky-columns/index.d.ts.map +1 -1
  343. package/dist/composite/layout/sticky-columns/index.js +26 -8
  344. package/dist/composite/layout/sticky-columns/index.js.map +1 -1
  345. package/dist/composite/layout/sticky-columns/index.mjs +4 -4
  346. package/dist/composite/layout/sticky-columns/index.mjs.map +1 -1
  347. package/dist/composite/media/elements/caption.d.ts.map +1 -1
  348. package/dist/composite/media/elements/caption.js +28 -9
  349. package/dist/composite/media/elements/caption.js.map +1 -1
  350. package/dist/composite/media/elements/caption.mjs +5 -4
  351. package/dist/composite/media/elements/caption.mjs.map +1 -1
  352. package/dist/composite/media/elements/gif.js +15 -4
  353. package/dist/composite/media/elements/gif.js.map +1 -1
  354. package/dist/composite/media/elements/gif.mjs +15 -4
  355. package/dist/composite/media/elements/gif.mjs.map +1 -1
  356. package/dist/composite/media/inline/caption.js +21 -8
  357. package/dist/composite/media/inline/caption.js.map +1 -1
  358. package/dist/composite/media/inline/caption.mjs +2 -6
  359. package/dist/composite/media/inline/caption.mjs.map +1 -1
  360. package/dist/composite/media/inline/wrapped.js +23 -10
  361. package/dist/composite/media/inline/wrapped.js.map +1 -1
  362. package/dist/composite/media/inline/wrapped.mjs +2 -6
  363. package/dist/composite/media/inline/wrapped.mjs.map +1 -1
  364. package/dist/composite/navigation/elements/breadcrumb/index.d.ts.map +1 -1
  365. package/dist/composite/navigation/elements/breadcrumb/index.js +35 -16
  366. package/dist/composite/navigation/elements/breadcrumb/index.js.map +1 -1
  367. package/dist/composite/navigation/elements/breadcrumb/index.mjs +7 -6
  368. package/dist/composite/navigation/elements/breadcrumb/index.mjs.map +1 -1
  369. package/dist/composite/navigation/elements/drawer/index.d.ts.map +1 -1
  370. package/dist/composite/navigation/elements/drawer/index.js +27 -13
  371. package/dist/composite/navigation/elements/drawer/index.js.map +1 -1
  372. package/dist/composite/navigation/elements/drawer/index.mjs +5 -8
  373. package/dist/composite/navigation/elements/drawer/index.mjs.map +1 -1
  374. package/dist/composite/navigation/elements/item/index.d.ts.map +1 -1
  375. package/dist/composite/navigation/elements/item/index.js +47 -28
  376. package/dist/composite/navigation/elements/item/index.js.map +1 -1
  377. package/dist/composite/navigation/elements/item/index.mjs +13 -12
  378. package/dist/composite/navigation/elements/item/index.mjs.map +1 -1
  379. package/dist/composite/navigation/elements/menu-button/index.js +20 -3
  380. package/dist/composite/navigation/elements/menu-button/index.js.map +1 -1
  381. package/dist/composite/navigation/elements/menu-button/index.mjs +1 -1
  382. package/dist/composite/navigation/elements/menu-button/index.mjs.map +1 -1
  383. package/dist/composite/navigation/elements/slider/action.d.ts.map +1 -1
  384. package/dist/composite/navigation/elements/slider/action.js +32 -13
  385. package/dist/composite/navigation/elements/slider/action.js.map +1 -1
  386. package/dist/composite/navigation/elements/slider/action.mjs +6 -5
  387. package/dist/composite/navigation/elements/slider/action.mjs.map +1 -1
  388. package/dist/composite/navigation/elements/slider/index.d.ts.map +1 -1
  389. package/dist/composite/navigation/elements/slider/index.js +35 -21
  390. package/dist/composite/navigation/elements/slider/index.js.map +1 -1
  391. package/dist/composite/navigation/elements/slider/index.mjs +3 -6
  392. package/dist/composite/navigation/elements/slider/index.mjs.map +1 -1
  393. package/dist/composite/navigation/elements/slider/slide-first.d.ts.map +1 -1
  394. package/dist/composite/navigation/elements/slider/slide-first.js +29 -10
  395. package/dist/composite/navigation/elements/slider/slide-first.js.map +1 -1
  396. package/dist/composite/navigation/elements/slider/slide-first.mjs +4 -3
  397. package/dist/composite/navigation/elements/slider/slide-first.mjs.map +1 -1
  398. package/dist/composite/navigation/elements/slider/slides.d.ts.map +1 -1
  399. package/dist/composite/navigation/elements/slider/slides.js +38 -19
  400. package/dist/composite/navigation/elements/slider/slides.js.map +1 -1
  401. package/dist/composite/navigation/elements/slider/slides.mjs +8 -7
  402. package/dist/composite/navigation/elements/slider/slides.mjs.map +1 -1
  403. package/dist/composite/navigation/elements/sticky/index.js +2 -5
  404. package/dist/composite/navigation/elements/sticky/index.js.map +1 -1
  405. package/dist/composite/navigation/elements/sticky/index.mjs +1 -4
  406. package/dist/composite/navigation/elements/sticky/index.mjs.map +1 -1
  407. package/dist/composite/navigation/header.d.ts.map +1 -1
  408. package/dist/composite/navigation/header.js +55 -36
  409. package/dist/composite/navigation/header.js.map +1 -1
  410. package/dist/composite/navigation/header.mjs +9 -8
  411. package/dist/composite/navigation/header.mjs.map +1 -1
  412. package/dist/composite/navigation/utility/alert.d.ts.map +1 -1
  413. package/dist/composite/navigation/utility/alert.js +18 -9
  414. package/dist/composite/navigation/utility/alert.js.map +1 -1
  415. package/dist/composite/navigation/utility/alert.mjs +18 -9
  416. package/dist/composite/navigation/utility/alert.mjs.map +1 -1
  417. package/dist/composite/navigation/utility/index.d.ts.map +1 -1
  418. package/dist/composite/navigation/utility/index.js +45 -41
  419. package/dist/composite/navigation/utility/index.js.map +1 -1
  420. package/dist/composite/navigation/utility/index.mjs +15 -13
  421. package/dist/composite/navigation/utility/index.mjs.map +1 -1
  422. package/dist/composite/navigation/utility/search.js +23 -6
  423. package/dist/composite/navigation/utility/search.js.map +1 -1
  424. package/dist/composite/navigation/utility/search.mjs +1 -1
  425. package/dist/composite/navigation/utility/search.mjs.map +1 -1
  426. package/dist/composite/pathway/_common.js +14 -3
  427. package/dist/composite/pathway/_common.js.map +1 -1
  428. package/dist/composite/pathway/_common.mjs +14 -3
  429. package/dist/composite/pathway/_common.mjs.map +1 -1
  430. package/dist/composite/pathway/hero.js +29 -19
  431. package/dist/composite/pathway/hero.js.map +1 -1
  432. package/dist/composite/pathway/hero.mjs +26 -16
  433. package/dist/composite/pathway/hero.mjs.map +1 -1
  434. package/dist/composite/pathway/highlight.js +21 -21
  435. package/dist/composite/pathway/highlight.js.map +1 -1
  436. package/dist/composite/pathway/highlight.mjs +20 -20
  437. package/dist/composite/pathway/highlight.mjs.map +1 -1
  438. package/dist/composite/pathway/overlay.js +19 -20
  439. package/dist/composite/pathway/overlay.js.map +1 -1
  440. package/dist/composite/pathway/overlay.mjs +14 -16
  441. package/dist/composite/pathway/overlay.mjs.map +1 -1
  442. package/dist/composite/pathway/standard.js +12 -15
  443. package/dist/composite/pathway/standard.js.map +1 -1
  444. package/dist/composite/pathway/standard.mjs +9 -12
  445. package/dist/composite/pathway/standard.mjs.map +1 -1
  446. package/dist/composite/pathway/sticky.d.ts.map +1 -1
  447. package/dist/composite/pathway/sticky.js +12 -10
  448. package/dist/composite/pathway/sticky.js.map +1 -1
  449. package/dist/composite/pathway/sticky.mjs +10 -9
  450. package/dist/composite/pathway/sticky.mjs.map +1 -1
  451. package/dist/composite/person/bio/full.d.ts.map +1 -1
  452. package/dist/composite/person/bio/full.js +24 -13
  453. package/dist/composite/person/bio/full.js.map +1 -1
  454. package/dist/composite/person/bio/full.mjs +22 -12
  455. package/dist/composite/person/bio/full.mjs.map +1 -1
  456. package/dist/composite/person/bio/small.js +33 -23
  457. package/dist/composite/person/bio/small.js.map +1 -1
  458. package/dist/composite/person/bio/small.mjs +32 -22
  459. package/dist/composite/person/bio/small.mjs.map +1 -1
  460. package/dist/composite/person/block.d.ts.map +1 -1
  461. package/dist/composite/person/block.js +26 -21
  462. package/dist/composite/person/block.js.map +1 -1
  463. package/dist/composite/person/block.mjs +24 -19
  464. package/dist/composite/person/block.mjs.map +1 -1
  465. package/dist/composite/person/hero.d.ts.map +1 -1
  466. package/dist/composite/person/hero.js +70 -43
  467. package/dist/composite/person/hero.js.map +1 -1
  468. package/dist/composite/person/hero.mjs +14 -4
  469. package/dist/composite/person/hero.mjs.map +1 -1
  470. package/dist/composite/person/list.d.ts.map +1 -1
  471. package/dist/composite/person/list.js +28 -21
  472. package/dist/composite/person/list.js.map +1 -1
  473. package/dist/composite/person/list.mjs +27 -20
  474. package/dist/composite/person/list.mjs.map +1 -1
  475. package/dist/composite/person/tabular.js +22 -11
  476. package/dist/composite/person/tabular.js.map +1 -1
  477. package/dist/composite/person/tabular.mjs +21 -10
  478. package/dist/composite/person/tabular.mjs.map +1 -1
  479. package/dist/composite/quote/_constants.d.ts +3 -0
  480. package/dist/composite/quote/_constants.d.ts.map +1 -0
  481. package/dist/composite/quote/_constants.js +7 -0
  482. package/dist/composite/quote/_constants.js.map +1 -0
  483. package/dist/composite/quote/_constants.mjs +7 -0
  484. package/dist/composite/quote/_constants.mjs.map +1 -0
  485. package/dist/composite/quote/_types.d.ts +24 -0
  486. package/dist/composite/quote/_types.d.ts.map +1 -0
  487. package/dist/composite/quote/elements/action.d.ts +11 -0
  488. package/dist/composite/quote/elements/action.d.ts.map +1 -0
  489. package/dist/composite/quote/elements/action.js +46 -0
  490. package/dist/composite/quote/elements/action.js.map +1 -0
  491. package/dist/composite/quote/elements/action.mjs +29 -0
  492. package/dist/composite/quote/elements/action.mjs.map +1 -0
  493. package/dist/composite/quote/elements/icon.d.ts +11 -0
  494. package/dist/composite/quote/elements/icon.d.ts.map +1 -0
  495. package/dist/composite/quote/elements/icon.js +74 -0
  496. package/dist/composite/quote/elements/icon.js.map +1 -0
  497. package/dist/composite/quote/elements/icon.mjs +58 -0
  498. package/dist/composite/quote/elements/icon.mjs.map +1 -0
  499. package/dist/composite/quote/elements/image.d.ts +7 -10
  500. package/dist/composite/quote/elements/image.d.ts.map +1 -1
  501. package/dist/composite/quote/elements/image.js +71 -12
  502. package/dist/composite/quote/elements/image.js.map +1 -1
  503. package/dist/composite/quote/elements/image.mjs +54 -12
  504. package/dist/composite/quote/elements/image.mjs.map +1 -1
  505. package/dist/composite/quote/elements/index.d.ts +5 -24
  506. package/dist/composite/quote/elements/index.d.ts.map +1 -1
  507. package/dist/composite/quote/elements/index.js +9 -5
  508. package/dist/composite/quote/elements/index.js.map +1 -1
  509. package/dist/composite/quote/elements/index.mjs +10 -7
  510. package/dist/composite/quote/elements/index.mjs.map +1 -1
  511. package/dist/composite/quote/elements/quote.d.ts +13 -0
  512. package/dist/composite/quote/elements/quote.d.ts.map +1 -0
  513. package/dist/composite/quote/elements/quote.js +114 -0
  514. package/dist/composite/quote/elements/quote.js.map +1 -0
  515. package/dist/composite/quote/elements/quote.mjs +97 -0
  516. package/dist/composite/quote/elements/quote.mjs.map +1 -0
  517. package/dist/composite/quote/elements/text.d.ts +5 -20
  518. package/dist/composite/quote/elements/text.d.ts.map +1 -1
  519. package/dist/composite/quote/elements/text.js +143 -189
  520. package/dist/composite/quote/elements/text.js.map +1 -1
  521. package/dist/composite/quote/elements/text.mjs +121 -185
  522. package/dist/composite/quote/elements/text.mjs.map +1 -1
  523. package/dist/composite/quote/featured.d.ts +7 -8
  524. package/dist/composite/quote/featured.d.ts.map +1 -1
  525. package/dist/composite/quote/featured.js +202 -243
  526. package/dist/composite/quote/featured.js.map +1 -1
  527. package/dist/composite/quote/featured.mjs +184 -242
  528. package/dist/composite/quote/featured.mjs.map +1 -1
  529. package/dist/composite/quote/helper/animation.d.ts +8 -0
  530. package/dist/composite/quote/helper/animation.d.ts.map +1 -0
  531. package/dist/composite/quote/helper/animation.js +105 -0
  532. package/dist/composite/quote/helper/animation.js.map +1 -0
  533. package/dist/composite/quote/helper/animation.mjs +105 -0
  534. package/dist/composite/quote/helper/animation.mjs.map +1 -0
  535. package/dist/composite/quote/index.d.ts +1 -1
  536. package/dist/composite/quote/index.d.ts.map +1 -1
  537. package/dist/composite/quote/index.mjs +6 -6
  538. package/dist/composite/quote/inline.d.ts +7 -9
  539. package/dist/composite/quote/inline.d.ts.map +1 -1
  540. package/dist/composite/quote/inline.js +79 -270
  541. package/dist/composite/quote/inline.js.map +1 -1
  542. package/dist/composite/quote/inline.mjs +63 -271
  543. package/dist/composite/quote/inline.mjs.map +1 -1
  544. package/dist/composite/quote/statement.d.ts +5 -7
  545. package/dist/composite/quote/statement.d.ts.map +1 -1
  546. package/dist/composite/slider/events.d.ts.map +1 -1
  547. package/dist/composite/slider/events.js +60 -46
  548. package/dist/composite/slider/events.js.map +1 -1
  549. package/dist/composite/slider/events.mjs +12 -16
  550. package/dist/composite/slider/events.mjs.map +1 -1
  551. package/dist/composite/social/sharing.d.ts.map +1 -1
  552. package/dist/composite/social/sharing.js +38 -23
  553. package/dist/composite/social/sharing.js.map +1 -1
  554. package/dist/composite/social/sharing.mjs +9 -11
  555. package/dist/composite/social/sharing.mjs.map +1 -1
  556. package/dist/composite/tabs/standard.d.ts.map +1 -1
  557. package/dist/composite/tabs/standard.js +44 -30
  558. package/dist/composite/tabs/standard.js.map +1 -1
  559. package/dist/composite/tabs/standard.mjs +9 -13
  560. package/dist/composite/tabs/standard.mjs.map +1 -1
  561. package/dist/index.d.ts +0 -1
  562. package/dist/index.d.ts.map +1 -1
  563. package/dist/index.js +0 -2
  564. package/dist/index.js.map +1 -1
  565. package/dist/index.mjs +1 -3
  566. package/dist/index.mjs.map +1 -1
  567. package/dist/layout/image.d.ts.map +1 -1
  568. package/dist/layout/image.js +25 -6
  569. package/dist/layout/image.js.map +1 -1
  570. package/dist/layout/image.mjs +4 -3
  571. package/dist/layout/image.mjs.map +1 -1
  572. package/dist/model/modifiers/index.d.ts +1 -1
  573. package/dist/model/modifiers/index.d.ts.map +1 -1
  574. package/dist/model/modifiers/index.js +12 -12
  575. package/dist/model/modifiers/index.js.map +1 -1
  576. package/dist/model/modifiers/index.mjs +2 -2
  577. package/dist/model/modifiers/index.mjs.map +1 -1
  578. package/dist/model/modifiers/style.js +7 -7
  579. package/dist/model/modifiers/style.js.map +1 -1
  580. package/dist/model/modifiers/style.mjs +2 -2
  581. package/dist/model/modifiers/style.mjs.map +1 -1
  582. package/package.json +17 -18
  583. package/dist/_virtual/___vite-browser-external.js +0 -8
  584. package/dist/_virtual/___vite-browser-external.js.map +0 -1
  585. package/dist/_virtual/___vite-browser-external.mjs +0 -7
  586. package/dist/_virtual/___vite-browser-external.mjs.map +0 -1
  587. package/dist/_virtual/__vite-browser-external.js +0 -4
  588. package/dist/_virtual/__vite-browser-external.js.map +0 -1
  589. package/dist/_virtual/__vite-browser-external.mjs +0 -5
  590. package/dist/_virtual/__vite-browser-external.mjs.map +0 -1
  591. package/dist/_virtual/_commonjsHelpers.js +0 -39
  592. package/dist/_virtual/_commonjsHelpers.js.map +0 -1
  593. package/dist/_virtual/_commonjsHelpers.mjs +0 -39
  594. package/dist/_virtual/_commonjsHelpers.mjs.map +0 -1
  595. package/dist/_virtual/attribute.js +0 -5
  596. package/dist/_virtual/attribute.js.map +0 -1
  597. package/dist/_virtual/attribute.mjs +0 -5
  598. package/dist/_virtual/attribute.mjs.map +0 -1
  599. package/dist/_virtual/className.js +0 -5
  600. package/dist/_virtual/className.js.map +0 -1
  601. package/dist/_virtual/className.mjs +0 -5
  602. package/dist/_virtual/className.mjs.map +0 -1
  603. package/dist/_virtual/combinator.js +0 -5
  604. package/dist/_virtual/combinator.js.map +0 -1
  605. package/dist/_virtual/combinator.mjs +0 -5
  606. package/dist/_virtual/combinator.mjs.map +0 -1
  607. package/dist/_virtual/comment.js +0 -5
  608. package/dist/_virtual/comment.js.map +0 -1
  609. package/dist/_virtual/comment.mjs +0 -5
  610. package/dist/_virtual/comment.mjs.map +0 -1
  611. package/dist/_virtual/constructors.js +0 -5
  612. package/dist/_virtual/constructors.js.map +0 -1
  613. package/dist/_virtual/constructors.mjs +0 -5
  614. package/dist/_virtual/constructors.mjs.map +0 -1
  615. package/dist/_virtual/container.js +0 -5
  616. package/dist/_virtual/container.js.map +0 -1
  617. package/dist/_virtual/container.mjs +0 -5
  618. package/dist/_virtual/container.mjs.map +0 -1
  619. package/dist/_virtual/ensureObject.js +0 -5
  620. package/dist/_virtual/ensureObject.js.map +0 -1
  621. package/dist/_virtual/ensureObject.mjs +0 -5
  622. package/dist/_virtual/ensureObject.mjs.map +0 -1
  623. package/dist/_virtual/getProp.js +0 -5
  624. package/dist/_virtual/getProp.js.map +0 -1
  625. package/dist/_virtual/getProp.mjs +0 -5
  626. package/dist/_virtual/getProp.mjs.map +0 -1
  627. package/dist/_virtual/guards.js +0 -5
  628. package/dist/_virtual/guards.js.map +0 -1
  629. package/dist/_virtual/guards.mjs +0 -5
  630. package/dist/_virtual/guards.mjs.map +0 -1
  631. package/dist/_virtual/id.js +0 -5
  632. package/dist/_virtual/id.js.map +0 -1
  633. package/dist/_virtual/id.mjs +0 -5
  634. package/dist/_virtual/id.mjs.map +0 -1
  635. package/dist/_virtual/index.js +0 -7
  636. package/dist/_virtual/index.js.map +0 -1
  637. package/dist/_virtual/index.mjs +0 -8
  638. package/dist/_virtual/index.mjs.map +0 -1
  639. package/dist/_virtual/index2.js +0 -7
  640. package/dist/_virtual/index2.js.map +0 -1
  641. package/dist/_virtual/index2.mjs +0 -8
  642. package/dist/_virtual/index2.mjs.map +0 -1
  643. package/dist/_virtual/index3.js +0 -5
  644. package/dist/_virtual/index3.js.map +0 -1
  645. package/dist/_virtual/index3.mjs +0 -5
  646. package/dist/_virtual/index3.mjs.map +0 -1
  647. package/dist/_virtual/index4.js +0 -5
  648. package/dist/_virtual/index4.js.map +0 -1
  649. package/dist/_virtual/index4.mjs +0 -5
  650. package/dist/_virtual/index4.mjs.map +0 -1
  651. package/dist/_virtual/index5.js +0 -5
  652. package/dist/_virtual/index5.js.map +0 -1
  653. package/dist/_virtual/index5.mjs +0 -5
  654. package/dist/_virtual/index5.mjs.map +0 -1
  655. package/dist/_virtual/namespace.js +0 -5
  656. package/dist/_virtual/namespace.js.map +0 -1
  657. package/dist/_virtual/namespace.mjs +0 -5
  658. package/dist/_virtual/namespace.mjs.map +0 -1
  659. package/dist/_virtual/nesting.js +0 -5
  660. package/dist/_virtual/nesting.js.map +0 -1
  661. package/dist/_virtual/nesting.mjs +0 -5
  662. package/dist/_virtual/nesting.mjs.map +0 -1
  663. package/dist/_virtual/node.js +0 -5
  664. package/dist/_virtual/node.js.map +0 -1
  665. package/dist/_virtual/node.mjs +0 -5
  666. package/dist/_virtual/node.mjs.map +0 -1
  667. package/dist/_virtual/parser.js +0 -5
  668. package/dist/_virtual/parser.js.map +0 -1
  669. package/dist/_virtual/parser.mjs +0 -5
  670. package/dist/_virtual/parser.mjs.map +0 -1
  671. package/dist/_virtual/picocolors.browser.js +0 -5
  672. package/dist/_virtual/picocolors.browser.js.map +0 -1
  673. package/dist/_virtual/picocolors.browser.mjs +0 -5
  674. package/dist/_virtual/picocolors.browser.mjs.map +0 -1
  675. package/dist/_virtual/postcss.js +0 -7
  676. package/dist/_virtual/postcss.js.map +0 -1
  677. package/dist/_virtual/postcss.mjs +0 -8
  678. package/dist/_virtual/postcss.mjs.map +0 -1
  679. package/dist/_virtual/processor.js +0 -5
  680. package/dist/_virtual/processor.js.map +0 -1
  681. package/dist/_virtual/processor.mjs +0 -5
  682. package/dist/_virtual/processor.mjs.map +0 -1
  683. package/dist/_virtual/pseudo.js +0 -5
  684. package/dist/_virtual/pseudo.js.map +0 -1
  685. package/dist/_virtual/pseudo.mjs +0 -5
  686. package/dist/_virtual/pseudo.mjs.map +0 -1
  687. package/dist/_virtual/root.js +0 -5
  688. package/dist/_virtual/root.js.map +0 -1
  689. package/dist/_virtual/root.mjs +0 -5
  690. package/dist/_virtual/root.mjs.map +0 -1
  691. package/dist/_virtual/selector.js +0 -5
  692. package/dist/_virtual/selector.js.map +0 -1
  693. package/dist/_virtual/selector.mjs +0 -5
  694. package/dist/_virtual/selector.mjs.map +0 -1
  695. package/dist/_virtual/sortAscending.js +0 -5
  696. package/dist/_virtual/sortAscending.js.map +0 -1
  697. package/dist/_virtual/sortAscending.mjs +0 -5
  698. package/dist/_virtual/sortAscending.mjs.map +0 -1
  699. package/dist/_virtual/string.js +0 -5
  700. package/dist/_virtual/string.js.map +0 -1
  701. package/dist/_virtual/string.mjs +0 -5
  702. package/dist/_virtual/string.mjs.map +0 -1
  703. package/dist/_virtual/stripComments.js +0 -5
  704. package/dist/_virtual/stripComments.js.map +0 -1
  705. package/dist/_virtual/stripComments.mjs +0 -5
  706. package/dist/_virtual/stripComments.mjs.map +0 -1
  707. package/dist/_virtual/symbols.js +0 -5
  708. package/dist/_virtual/symbols.js.map +0 -1
  709. package/dist/_virtual/symbols.mjs +0 -5
  710. package/dist/_virtual/symbols.mjs.map +0 -1
  711. package/dist/_virtual/tag.js +0 -5
  712. package/dist/_virtual/tag.js.map +0 -1
  713. package/dist/_virtual/tag.mjs +0 -5
  714. package/dist/_virtual/tag.mjs.map +0 -1
  715. package/dist/_virtual/tokenTypes.js +0 -5
  716. package/dist/_virtual/tokenTypes.js.map +0 -1
  717. package/dist/_virtual/tokenTypes.mjs +0 -5
  718. package/dist/_virtual/tokenTypes.mjs.map +0 -1
  719. package/dist/_virtual/tokenize.js +0 -5
  720. package/dist/_virtual/tokenize.js.map +0 -1
  721. package/dist/_virtual/tokenize.mjs +0 -5
  722. package/dist/_virtual/tokenize.mjs.map +0 -1
  723. package/dist/_virtual/types.js +0 -5
  724. package/dist/_virtual/types.js.map +0 -1
  725. package/dist/_virtual/types.mjs +0 -5
  726. package/dist/_virtual/types.mjs.map +0 -1
  727. package/dist/_virtual/unesc.js +0 -5
  728. package/dist/_virtual/unesc.js.map +0 -1
  729. package/dist/_virtual/unesc.mjs +0 -5
  730. package/dist/_virtual/unesc.mjs.map +0 -1
  731. package/dist/_virtual/universal.js +0 -5
  732. package/dist/_virtual/universal.js.map +0 -1
  733. package/dist/_virtual/universal.mjs +0 -5
  734. package/dist/_virtual/universal.mjs.map +0 -1
  735. package/dist/node_modules/@csstools/selector-specificity/dist/index.js +0 -96
  736. package/dist/node_modules/@csstools/selector-specificity/dist/index.js.map +0 -1
  737. package/dist/node_modules/@csstools/selector-specificity/dist/index.mjs +0 -96
  738. package/dist/node_modules/@csstools/selector-specificity/dist/index.mjs.map +0 -1
  739. package/dist/node_modules/camelcase-css/index-es5.js +0 -26
  740. package/dist/node_modules/camelcase-css/index-es5.js.map +0 -1
  741. package/dist/node_modules/camelcase-css/index-es5.mjs +0 -26
  742. package/dist/node_modules/camelcase-css/index-es5.mjs.map +0 -1
  743. package/dist/node_modules/cssesc/cssesc.js +0 -95
  744. package/dist/node_modules/cssesc/cssesc.js.map +0 -1
  745. package/dist/node_modules/cssesc/cssesc.mjs +0 -95
  746. package/dist/node_modules/cssesc/cssesc.mjs.map +0 -1
  747. package/dist/node_modules/nanoid/non-secure/index.js +0 -31
  748. package/dist/node_modules/nanoid/non-secure/index.js.map +0 -1
  749. package/dist/node_modules/nanoid/non-secure/index.mjs +0 -31
  750. package/dist/node_modules/nanoid/non-secure/index.mjs.map +0 -1
  751. package/dist/node_modules/picocolors/picocolors.browser.js +0 -17
  752. package/dist/node_modules/picocolors/picocolors.browser.js.map +0 -1
  753. package/dist/node_modules/picocolors/picocolors.browser.mjs +0 -17
  754. package/dist/node_modules/picocolors/picocolors.browser.mjs.map +0 -1
  755. package/dist/node_modules/postcss/lib/at-rule.js +0 -30
  756. package/dist/node_modules/postcss/lib/at-rule.js.map +0 -1
  757. package/dist/node_modules/postcss/lib/at-rule.mjs +0 -30
  758. package/dist/node_modules/postcss/lib/at-rule.mjs.map +0 -1
  759. package/dist/node_modules/postcss/lib/comment.js +0 -21
  760. package/dist/node_modules/postcss/lib/comment.js.map +0 -1
  761. package/dist/node_modules/postcss/lib/comment.mjs +0 -21
  762. package/dist/node_modules/postcss/lib/comment.mjs.map +0 -1
  763. package/dist/node_modules/postcss/lib/container.js +0 -383
  764. package/dist/node_modules/postcss/lib/container.js.map +0 -1
  765. package/dist/node_modules/postcss/lib/container.mjs +0 -383
  766. package/dist/node_modules/postcss/lib/container.mjs.map +0 -1
  767. package/dist/node_modules/postcss/lib/css-syntax-error.js +0 -92
  768. package/dist/node_modules/postcss/lib/css-syntax-error.js.map +0 -1
  769. package/dist/node_modules/postcss/lib/css-syntax-error.mjs +0 -92
  770. package/dist/node_modules/postcss/lib/css-syntax-error.mjs.map +0 -1
  771. package/dist/node_modules/postcss/lib/declaration.js +0 -27
  772. package/dist/node_modules/postcss/lib/declaration.js.map +0 -1
  773. package/dist/node_modules/postcss/lib/declaration.mjs +0 -27
  774. package/dist/node_modules/postcss/lib/declaration.mjs.map +0 -1
  775. package/dist/node_modules/postcss/lib/document.js +0 -34
  776. package/dist/node_modules/postcss/lib/document.js.map +0 -1
  777. package/dist/node_modules/postcss/lib/document.mjs +0 -34
  778. package/dist/node_modules/postcss/lib/document.mjs.map +0 -1
  779. package/dist/node_modules/postcss/lib/fromJSON.js +0 -67
  780. package/dist/node_modules/postcss/lib/fromJSON.js.map +0 -1
  781. package/dist/node_modules/postcss/lib/fromJSON.mjs +0 -67
  782. package/dist/node_modules/postcss/lib/fromJSON.mjs.map +0 -1
  783. package/dist/node_modules/postcss/lib/input.js +0 -216
  784. package/dist/node_modules/postcss/lib/input.js.map +0 -1
  785. package/dist/node_modules/postcss/lib/input.mjs +0 -216
  786. package/dist/node_modules/postcss/lib/input.mjs.map +0 -1
  787. package/dist/node_modules/postcss/lib/lazy-result.js +0 -467
  788. package/dist/node_modules/postcss/lib/lazy-result.js.map +0 -1
  789. package/dist/node_modules/postcss/lib/lazy-result.mjs +0 -467
  790. package/dist/node_modules/postcss/lib/lazy-result.mjs.map +0 -1
  791. package/dist/node_modules/postcss/lib/list.js +0 -60
  792. package/dist/node_modules/postcss/lib/list.js.map +0 -1
  793. package/dist/node_modules/postcss/lib/list.mjs +0 -60
  794. package/dist/node_modules/postcss/lib/list.mjs.map +0 -1
  795. package/dist/node_modules/postcss/lib/map-generator.js +0 -314
  796. package/dist/node_modules/postcss/lib/map-generator.js.map +0 -1
  797. package/dist/node_modules/postcss/lib/map-generator.mjs +0 -314
  798. package/dist/node_modules/postcss/lib/map-generator.mjs.map +0 -1
  799. package/dist/node_modules/postcss/lib/no-work-result.js +0 -113
  800. package/dist/node_modules/postcss/lib/no-work-result.js.map +0 -1
  801. package/dist/node_modules/postcss/lib/no-work-result.mjs +0 -113
  802. package/dist/node_modules/postcss/lib/no-work-result.mjs.map +0 -1
  803. package/dist/node_modules/postcss/lib/node.js +0 -335
  804. package/dist/node_modules/postcss/lib/node.js.map +0 -1
  805. package/dist/node_modules/postcss/lib/node.mjs +0 -335
  806. package/dist/node_modules/postcss/lib/node.mjs.map +0 -1
  807. package/dist/node_modules/postcss/lib/parse.js +0 -30
  808. package/dist/node_modules/postcss/lib/parse.js.map +0 -1
  809. package/dist/node_modules/postcss/lib/parse.mjs +0 -30
  810. package/dist/node_modules/postcss/lib/parse.mjs.map +0 -1
  811. package/dist/node_modules/postcss/lib/parser.js +0 -543
  812. package/dist/node_modules/postcss/lib/parser.js.map +0 -1
  813. package/dist/node_modules/postcss/lib/parser.mjs +0 -543
  814. package/dist/node_modules/postcss/lib/parser.mjs.map +0 -1
  815. package/dist/node_modules/postcss/lib/postcss.js +0 -28
  816. package/dist/node_modules/postcss/lib/postcss.js.map +0 -1
  817. package/dist/node_modules/postcss/lib/postcss.mjs +0 -29
  818. package/dist/node_modules/postcss/lib/postcss.mjs.map +0 -1
  819. package/dist/node_modules/postcss/lib/postcss2.js +0 -110
  820. package/dist/node_modules/postcss/lib/postcss2.js.map +0 -1
  821. package/dist/node_modules/postcss/lib/postcss2.mjs +0 -110
  822. package/dist/node_modules/postcss/lib/postcss2.mjs.map +0 -1
  823. package/dist/node_modules/postcss/lib/previous-map.js +0 -123
  824. package/dist/node_modules/postcss/lib/previous-map.js.map +0 -1
  825. package/dist/node_modules/postcss/lib/previous-map.mjs +0 -123
  826. package/dist/node_modules/postcss/lib/previous-map.mjs.map +0 -1
  827. package/dist/node_modules/postcss/lib/processor.js +0 -61
  828. package/dist/node_modules/postcss/lib/processor.js.map +0 -1
  829. package/dist/node_modules/postcss/lib/processor.mjs +0 -61
  830. package/dist/node_modules/postcss/lib/processor.mjs.map +0 -1
  831. package/dist/node_modules/postcss/lib/result.js +0 -44
  832. package/dist/node_modules/postcss/lib/result.js.map +0 -1
  833. package/dist/node_modules/postcss/lib/result.mjs +0 -44
  834. package/dist/node_modules/postcss/lib/result.mjs.map +0 -1
  835. package/dist/node_modules/postcss/lib/root.js +0 -58
  836. package/dist/node_modules/postcss/lib/root.js.map +0 -1
  837. package/dist/node_modules/postcss/lib/root.mjs +0 -58
  838. package/dist/node_modules/postcss/lib/root.mjs.map +0 -1
  839. package/dist/node_modules/postcss/lib/rule.js +0 -33
  840. package/dist/node_modules/postcss/lib/rule.js.map +0 -1
  841. package/dist/node_modules/postcss/lib/rule.mjs +0 -33
  842. package/dist/node_modules/postcss/lib/rule.mjs.map +0 -1
  843. package/dist/node_modules/postcss/lib/stringifier.js +0 -308
  844. package/dist/node_modules/postcss/lib/stringifier.js.map +0 -1
  845. package/dist/node_modules/postcss/lib/stringifier.mjs +0 -308
  846. package/dist/node_modules/postcss/lib/stringifier.mjs.map +0 -1
  847. package/dist/node_modules/postcss/lib/stringify.js +0 -19
  848. package/dist/node_modules/postcss/lib/stringify.js.map +0 -1
  849. package/dist/node_modules/postcss/lib/stringify.mjs +0 -19
  850. package/dist/node_modules/postcss/lib/stringify.mjs.map +0 -1
  851. package/dist/node_modules/postcss/lib/symbols.js +0 -13
  852. package/dist/node_modules/postcss/lib/symbols.js.map +0 -1
  853. package/dist/node_modules/postcss/lib/symbols.mjs +0 -13
  854. package/dist/node_modules/postcss/lib/symbols.mjs.map +0 -1
  855. package/dist/node_modules/postcss/lib/tokenize.js +0 -219
  856. package/dist/node_modules/postcss/lib/tokenize.js.map +0 -1
  857. package/dist/node_modules/postcss/lib/tokenize.mjs +0 -219
  858. package/dist/node_modules/postcss/lib/tokenize.mjs.map +0 -1
  859. package/dist/node_modules/postcss/lib/warning.js +0 -40
  860. package/dist/node_modules/postcss/lib/warning.js.map +0 -1
  861. package/dist/node_modules/postcss/lib/warning.mjs +0 -40
  862. package/dist/node_modules/postcss/lib/warning.mjs.map +0 -1
  863. package/dist/node_modules/postcss-js/async.js +0 -27
  864. package/dist/node_modules/postcss-js/async.js.map +0 -1
  865. package/dist/node_modules/postcss-js/async.mjs +0 -27
  866. package/dist/node_modules/postcss-js/async.mjs.map +0 -1
  867. package/dist/node_modules/postcss-js/index.js +0 -8
  868. package/dist/node_modules/postcss-js/index.js.map +0 -1
  869. package/dist/node_modules/postcss-js/index.mjs +0 -9
  870. package/dist/node_modules/postcss-js/index.mjs.map +0 -1
  871. package/dist/node_modules/postcss-js/index2.js +0 -25
  872. package/dist/node_modules/postcss-js/index2.js.map +0 -1
  873. package/dist/node_modules/postcss-js/index2.mjs +0 -25
  874. package/dist/node_modules/postcss-js/index2.mjs.map +0 -1
  875. package/dist/node_modules/postcss-js/objectifier.js +0 -92
  876. package/dist/node_modules/postcss-js/objectifier.js.map +0 -1
  877. package/dist/node_modules/postcss-js/objectifier.mjs +0 -92
  878. package/dist/node_modules/postcss-js/objectifier.mjs.map +0 -1
  879. package/dist/node_modules/postcss-js/parser.js +0 -102
  880. package/dist/node_modules/postcss-js/parser.js.map +0 -1
  881. package/dist/node_modules/postcss-js/parser.mjs +0 -102
  882. package/dist/node_modules/postcss-js/parser.mjs.map +0 -1
  883. package/dist/node_modules/postcss-js/process-result.js +0 -22
  884. package/dist/node_modules/postcss-js/process-result.js.map +0 -1
  885. package/dist/node_modules/postcss-js/process-result.mjs +0 -22
  886. package/dist/node_modules/postcss-js/process-result.mjs.map +0 -1
  887. package/dist/node_modules/postcss-js/sync.js +0 -24
  888. package/dist/node_modules/postcss-js/sync.js.map +0 -1
  889. package/dist/node_modules/postcss-js/sync.mjs +0 -24
  890. package/dist/node_modules/postcss-js/sync.mjs.map +0 -1
  891. package/dist/node_modules/postcss-nesting/dist/index.js +0 -267
  892. package/dist/node_modules/postcss-nesting/dist/index.js.map +0 -1
  893. package/dist/node_modules/postcss-nesting/dist/index.mjs +0 -268
  894. package/dist/node_modules/postcss-nesting/dist/index.mjs.map +0 -1
  895. package/dist/node_modules/postcss-selector-parser/dist/index.js +0 -67
  896. package/dist/node_modules/postcss-selector-parser/dist/index.js.map +0 -1
  897. package/dist/node_modules/postcss-selector-parser/dist/index.mjs +0 -67
  898. package/dist/node_modules/postcss-selector-parser/dist/index.mjs.map +0 -1
  899. package/dist/node_modules/postcss-selector-parser/dist/parser.js +0 -1038
  900. package/dist/node_modules/postcss-selector-parser/dist/parser.js.map +0 -1
  901. package/dist/node_modules/postcss-selector-parser/dist/parser.mjs +0 -1038
  902. package/dist/node_modules/postcss-selector-parser/dist/parser.mjs.map +0 -1
  903. package/dist/node_modules/postcss-selector-parser/dist/processor.js +0 -137
  904. package/dist/node_modules/postcss-selector-parser/dist/processor.js.map +0 -1
  905. package/dist/node_modules/postcss-selector-parser/dist/processor.mjs +0 -137
  906. package/dist/node_modules/postcss-selector-parser/dist/processor.mjs.map +0 -1
  907. package/dist/node_modules/postcss-selector-parser/dist/selectors/attribute.js +0 -404
  908. package/dist/node_modules/postcss-selector-parser/dist/selectors/attribute.js.map +0 -1
  909. package/dist/node_modules/postcss-selector-parser/dist/selectors/attribute.mjs +0 -404
  910. package/dist/node_modules/postcss-selector-parser/dist/selectors/attribute.mjs.map +0 -1
  911. package/dist/node_modules/postcss-selector-parser/dist/selectors/className.js +0 -89
  912. package/dist/node_modules/postcss-selector-parser/dist/selectors/className.js.map +0 -1
  913. package/dist/node_modules/postcss-selector-parser/dist/selectors/className.mjs +0 -89
  914. package/dist/node_modules/postcss-selector-parser/dist/selectors/className.mjs.map +0 -1
  915. package/dist/node_modules/postcss-selector-parser/dist/selectors/combinator.js +0 -46
  916. package/dist/node_modules/postcss-selector-parser/dist/selectors/combinator.js.map +0 -1
  917. package/dist/node_modules/postcss-selector-parser/dist/selectors/combinator.mjs +0 -46
  918. package/dist/node_modules/postcss-selector-parser/dist/selectors/combinator.mjs.map +0 -1
  919. package/dist/node_modules/postcss-selector-parser/dist/selectors/comment.js +0 -46
  920. package/dist/node_modules/postcss-selector-parser/dist/selectors/comment.js.map +0 -1
  921. package/dist/node_modules/postcss-selector-parser/dist/selectors/comment.mjs +0 -46
  922. package/dist/node_modules/postcss-selector-parser/dist/selectors/comment.mjs.map +0 -1
  923. package/dist/node_modules/postcss-selector-parser/dist/selectors/constructors.js +0 -88
  924. package/dist/node_modules/postcss-selector-parser/dist/selectors/constructors.js.map +0 -1
  925. package/dist/node_modules/postcss-selector-parser/dist/selectors/constructors.mjs +0 -88
  926. package/dist/node_modules/postcss-selector-parser/dist/selectors/constructors.mjs.map +0 -1
  927. package/dist/node_modules/postcss-selector-parser/dist/selectors/container.js +0 -391
  928. package/dist/node_modules/postcss-selector-parser/dist/selectors/container.js.map +0 -1
  929. package/dist/node_modules/postcss-selector-parser/dist/selectors/container.mjs +0 -391
  930. package/dist/node_modules/postcss-selector-parser/dist/selectors/container.mjs.map +0 -1
  931. package/dist/node_modules/postcss-selector-parser/dist/selectors/guards.js +0 -68
  932. package/dist/node_modules/postcss-selector-parser/dist/selectors/guards.js.map +0 -1
  933. package/dist/node_modules/postcss-selector-parser/dist/selectors/guards.mjs +0 -68
  934. package/dist/node_modules/postcss-selector-parser/dist/selectors/guards.mjs.map +0 -1
  935. package/dist/node_modules/postcss-selector-parser/dist/selectors/id.js +0 -50
  936. package/dist/node_modules/postcss-selector-parser/dist/selectors/id.js.map +0 -1
  937. package/dist/node_modules/postcss-selector-parser/dist/selectors/id.mjs +0 -50
  938. package/dist/node_modules/postcss-selector-parser/dist/selectors/id.mjs.map +0 -1
  939. package/dist/node_modules/postcss-selector-parser/dist/selectors/index.js +0 -35
  940. package/dist/node_modules/postcss-selector-parser/dist/selectors/index.js.map +0 -1
  941. package/dist/node_modules/postcss-selector-parser/dist/selectors/index.mjs +0 -35
  942. package/dist/node_modules/postcss-selector-parser/dist/selectors/index.mjs.map +0 -1
  943. package/dist/node_modules/postcss-selector-parser/dist/selectors/namespace.js +0 -117
  944. package/dist/node_modules/postcss-selector-parser/dist/selectors/namespace.js.map +0 -1
  945. package/dist/node_modules/postcss-selector-parser/dist/selectors/namespace.mjs +0 -117
  946. package/dist/node_modules/postcss-selector-parser/dist/selectors/namespace.mjs.map +0 -1
  947. package/dist/node_modules/postcss-selector-parser/dist/selectors/nesting.js +0 -47
  948. package/dist/node_modules/postcss-selector-parser/dist/selectors/nesting.js.map +0 -1
  949. package/dist/node_modules/postcss-selector-parser/dist/selectors/nesting.mjs +0 -47
  950. package/dist/node_modules/postcss-selector-parser/dist/selectors/nesting.mjs.map +0 -1
  951. package/dist/node_modules/postcss-selector-parser/dist/selectors/node.js +0 -183
  952. package/dist/node_modules/postcss-selector-parser/dist/selectors/node.js.map +0 -1
  953. package/dist/node_modules/postcss-selector-parser/dist/selectors/node.mjs +0 -183
  954. package/dist/node_modules/postcss-selector-parser/dist/selectors/node.mjs.map +0 -1
  955. package/dist/node_modules/postcss-selector-parser/dist/selectors/pseudo.js +0 -51
  956. package/dist/node_modules/postcss-selector-parser/dist/selectors/pseudo.js.map +0 -1
  957. package/dist/node_modules/postcss-selector-parser/dist/selectors/pseudo.mjs +0 -51
  958. package/dist/node_modules/postcss-selector-parser/dist/selectors/pseudo.mjs.map +0 -1
  959. package/dist/node_modules/postcss-selector-parser/dist/selectors/root.js +0 -81
  960. package/dist/node_modules/postcss-selector-parser/dist/selectors/root.js.map +0 -1
  961. package/dist/node_modules/postcss-selector-parser/dist/selectors/root.mjs +0 -81
  962. package/dist/node_modules/postcss-selector-parser/dist/selectors/root.mjs.map +0 -1
  963. package/dist/node_modules/postcss-selector-parser/dist/selectors/selector.js +0 -46
  964. package/dist/node_modules/postcss-selector-parser/dist/selectors/selector.js.map +0 -1
  965. package/dist/node_modules/postcss-selector-parser/dist/selectors/selector.mjs +0 -46
  966. package/dist/node_modules/postcss-selector-parser/dist/selectors/selector.mjs.map +0 -1
  967. package/dist/node_modules/postcss-selector-parser/dist/selectors/string.js +0 -46
  968. package/dist/node_modules/postcss-selector-parser/dist/selectors/string.js.map +0 -1
  969. package/dist/node_modules/postcss-selector-parser/dist/selectors/string.mjs +0 -46
  970. package/dist/node_modules/postcss-selector-parser/dist/selectors/string.mjs.map +0 -1
  971. package/dist/node_modules/postcss-selector-parser/dist/selectors/tag.js +0 -46
  972. package/dist/node_modules/postcss-selector-parser/dist/selectors/tag.js.map +0 -1
  973. package/dist/node_modules/postcss-selector-parser/dist/selectors/tag.mjs +0 -46
  974. package/dist/node_modules/postcss-selector-parser/dist/selectors/tag.mjs.map +0 -1
  975. package/dist/node_modules/postcss-selector-parser/dist/selectors/types.js +0 -37
  976. package/dist/node_modules/postcss-selector-parser/dist/selectors/types.js.map +0 -1
  977. package/dist/node_modules/postcss-selector-parser/dist/selectors/types.mjs +0 -37
  978. package/dist/node_modules/postcss-selector-parser/dist/selectors/types.mjs.map +0 -1
  979. package/dist/node_modules/postcss-selector-parser/dist/selectors/universal.js +0 -47
  980. package/dist/node_modules/postcss-selector-parser/dist/selectors/universal.js.map +0 -1
  981. package/dist/node_modules/postcss-selector-parser/dist/selectors/universal.mjs +0 -47
  982. package/dist/node_modules/postcss-selector-parser/dist/selectors/universal.mjs.map +0 -1
  983. package/dist/node_modules/postcss-selector-parser/dist/sortAscending.js +0 -21
  984. package/dist/node_modules/postcss-selector-parser/dist/sortAscending.js.map +0 -1
  985. package/dist/node_modules/postcss-selector-parser/dist/sortAscending.mjs +0 -21
  986. package/dist/node_modules/postcss-selector-parser/dist/sortAscending.mjs.map +0 -1
  987. package/dist/node_modules/postcss-selector-parser/dist/tokenTypes.js +0 -75
  988. package/dist/node_modules/postcss-selector-parser/dist/tokenTypes.js.map +0 -1
  989. package/dist/node_modules/postcss-selector-parser/dist/tokenTypes.mjs +0 -75
  990. package/dist/node_modules/postcss-selector-parser/dist/tokenTypes.mjs.map +0 -1
  991. package/dist/node_modules/postcss-selector-parser/dist/tokenize.js +0 -264
  992. package/dist/node_modules/postcss-selector-parser/dist/tokenize.js.map +0 -1
  993. package/dist/node_modules/postcss-selector-parser/dist/tokenize.mjs +0 -264
  994. package/dist/node_modules/postcss-selector-parser/dist/tokenize.mjs.map +0 -1
  995. package/dist/node_modules/postcss-selector-parser/dist/util/ensureObject.js +0 -28
  996. package/dist/node_modules/postcss-selector-parser/dist/util/ensureObject.js.map +0 -1
  997. package/dist/node_modules/postcss-selector-parser/dist/util/ensureObject.mjs +0 -28
  998. package/dist/node_modules/postcss-selector-parser/dist/util/ensureObject.mjs.map +0 -1
  999. package/dist/node_modules/postcss-selector-parser/dist/util/getProp.js +0 -29
  1000. package/dist/node_modules/postcss-selector-parser/dist/util/getProp.js.map +0 -1
  1001. package/dist/node_modules/postcss-selector-parser/dist/util/getProp.mjs +0 -29
  1002. package/dist/node_modules/postcss-selector-parser/dist/util/getProp.mjs.map +0 -1
  1003. package/dist/node_modules/postcss-selector-parser/dist/util/index.js +0 -28
  1004. package/dist/node_modules/postcss-selector-parser/dist/util/index.js.map +0 -1
  1005. package/dist/node_modules/postcss-selector-parser/dist/util/index.mjs +0 -28
  1006. package/dist/node_modules/postcss-selector-parser/dist/util/index.mjs.map +0 -1
  1007. package/dist/node_modules/postcss-selector-parser/dist/util/stripComments.js +0 -32
  1008. package/dist/node_modules/postcss-selector-parser/dist/util/stripComments.js.map +0 -1
  1009. package/dist/node_modules/postcss-selector-parser/dist/util/stripComments.mjs +0 -32
  1010. package/dist/node_modules/postcss-selector-parser/dist/util/stripComments.mjs.map +0 -1
  1011. package/dist/node_modules/postcss-selector-parser/dist/util/unesc.js +0 -68
  1012. package/dist/node_modules/postcss-selector-parser/dist/util/unesc.js.map +0 -1
  1013. package/dist/node_modules/postcss-selector-parser/dist/util/unesc.mjs +0 -68
  1014. package/dist/node_modules/postcss-selector-parser/dist/util/unesc.mjs.map +0 -1
  1015. package/dist/node_modules/util-deprecate/browser.js +0 -43
  1016. package/dist/node_modules/util-deprecate/browser.js.map +0 -1
  1017. package/dist/node_modules/util-deprecate/browser.mjs +0 -43
  1018. package/dist/node_modules/util-deprecate/browser.mjs.map +0 -1
  1019. package/dist/utilities/accessibility/index.d.ts +0 -13
  1020. package/dist/utilities/accessibility/index.d.ts.map +0 -1
  1021. package/dist/utilities/accessibility/index.js +0 -89
  1022. package/dist/utilities/accessibility/index.js.map +0 -1
  1023. package/dist/utilities/accessibility/index.mjs +0 -89
  1024. package/dist/utilities/accessibility/index.mjs.map +0 -1
  1025. package/dist/utilities/assets/icons.d.ts +0 -26
  1026. package/dist/utilities/assets/icons.d.ts.map +0 -1
  1027. package/dist/utilities/assets/icons.js +0 -53
  1028. package/dist/utilities/assets/icons.js.map +0 -1
  1029. package/dist/utilities/assets/icons.mjs +0 -53
  1030. package/dist/utilities/assets/icons.mjs.map +0 -1
  1031. package/dist/utilities/assets/index.d.ts +0 -4
  1032. package/dist/utilities/assets/index.d.ts.map +0 -1
  1033. package/dist/utilities/assets/index.js +0 -9
  1034. package/dist/utilities/assets/index.js.map +0 -1
  1035. package/dist/utilities/assets/index.mjs +0 -9
  1036. package/dist/utilities/assets/index.mjs.map +0 -1
  1037. package/dist/utilities/assets/logos.d.ts +0 -6
  1038. package/dist/utilities/assets/logos.d.ts.map +0 -1
  1039. package/dist/utilities/assets/logos.js +0 -14
  1040. package/dist/utilities/assets/logos.js.map +0 -1
  1041. package/dist/utilities/assets/logos.mjs +0 -14
  1042. package/dist/utilities/assets/logos.mjs.map +0 -1
  1043. package/dist/utilities/assets/social.d.ts +0 -8
  1044. package/dist/utilities/assets/social.d.ts.map +0 -1
  1045. package/dist/utilities/assets/social.js +0 -17
  1046. package/dist/utilities/assets/social.js.map +0 -1
  1047. package/dist/utilities/assets/social.mjs +0 -17
  1048. package/dist/utilities/assets/social.mjs.map +0 -1
  1049. package/dist/utilities/date.d.ts +0 -12
  1050. package/dist/utilities/date.d.ts.map +0 -1
  1051. package/dist/utilities/date.js +0 -36
  1052. package/dist/utilities/date.js.map +0 -1
  1053. package/dist/utilities/date.mjs +0 -36
  1054. package/dist/utilities/date.mjs.map +0 -1
  1055. package/dist/utilities/index.d.ts +0 -10
  1056. package/dist/utilities/index.d.ts.map +0 -1
  1057. package/dist/utilities/js-events/index.d.ts +0 -5
  1058. package/dist/utilities/js-events/index.d.ts.map +0 -1
  1059. package/dist/utilities/js-events/index.js +0 -37
  1060. package/dist/utilities/js-events/index.js.map +0 -1
  1061. package/dist/utilities/js-events/index.mjs +0 -37
  1062. package/dist/utilities/js-events/index.mjs.map +0 -1
  1063. package/dist/utilities/markup/create.d.ts +0 -13
  1064. package/dist/utilities/markup/create.d.ts.map +0 -1
  1065. package/dist/utilities/markup/create.js +0 -95
  1066. package/dist/utilities/markup/create.js.map +0 -1
  1067. package/dist/utilities/markup/create.mjs +0 -95
  1068. package/dist/utilities/markup/create.mjs.map +0 -1
  1069. package/dist/utilities/markup/get.d.ts +0 -4
  1070. package/dist/utilities/markup/get.d.ts.map +0 -1
  1071. package/dist/utilities/markup/get.js +0 -18
  1072. package/dist/utilities/markup/get.js.map +0 -1
  1073. package/dist/utilities/markup/get.mjs +0 -18
  1074. package/dist/utilities/markup/get.mjs.map +0 -1
  1075. package/dist/utilities/markup/index.d.ts +0 -5
  1076. package/dist/utilities/markup/index.d.ts.map +0 -1
  1077. package/dist/utilities/markup/index.js +0 -11
  1078. package/dist/utilities/markup/index.js.map +0 -1
  1079. package/dist/utilities/markup/index.mjs +0 -11
  1080. package/dist/utilities/markup/index.mjs.map +0 -1
  1081. package/dist/utilities/markup/locate.d.ts +0 -5
  1082. package/dist/utilities/markup/locate.d.ts.map +0 -1
  1083. package/dist/utilities/markup/locate.js +0 -26
  1084. package/dist/utilities/markup/locate.js.map +0 -1
  1085. package/dist/utilities/markup/locate.mjs +0 -26
  1086. package/dist/utilities/markup/locate.mjs.map +0 -1
  1087. package/dist/utilities/markup/modify.d.ts +0 -21
  1088. package/dist/utilities/markup/modify.d.ts.map +0 -1
  1089. package/dist/utilities/markup/modify.js +0 -93
  1090. package/dist/utilities/markup/modify.js.map +0 -1
  1091. package/dist/utilities/markup/modify.mjs +0 -93
  1092. package/dist/utilities/markup/modify.mjs.map +0 -1
  1093. package/dist/utilities/network/index.d.ts +0 -10
  1094. package/dist/utilities/network/index.d.ts.map +0 -1
  1095. package/dist/utilities/network/index.js +0 -35
  1096. package/dist/utilities/network/index.js.map +0 -1
  1097. package/dist/utilities/network/index.mjs +0 -35
  1098. package/dist/utilities/network/index.mjs.map +0 -1
  1099. package/dist/utilities/performance/index.d.ts +0 -2
  1100. package/dist/utilities/performance/index.d.ts.map +0 -1
  1101. package/dist/utilities/performance/index.js +0 -12
  1102. package/dist/utilities/performance/index.js.map +0 -1
  1103. package/dist/utilities/performance/index.mjs +0 -12
  1104. package/dist/utilities/performance/index.mjs.map +0 -1
  1105. package/dist/utilities/storage/index.d.ts +0 -2
  1106. package/dist/utilities/storage/index.d.ts.map +0 -1
  1107. package/dist/utilities/storage/index.js +0 -5
  1108. package/dist/utilities/storage/index.js.map +0 -1
  1109. package/dist/utilities/storage/index.mjs +0 -5
  1110. package/dist/utilities/storage/index.mjs.map +0 -1
  1111. package/dist/utilities/storage/local.d.ts +0 -7
  1112. package/dist/utilities/storage/local.d.ts.map +0 -1
  1113. package/dist/utilities/storage/local.js +0 -14
  1114. package/dist/utilities/storage/local.js.map +0 -1
  1115. package/dist/utilities/storage/local.mjs +0 -14
  1116. package/dist/utilities/storage/local.mjs.map +0 -1
  1117. package/dist/utilities/theme/animations.d.ts +0 -9
  1118. package/dist/utilities/theme/animations.d.ts.map +0 -1
  1119. package/dist/utilities/theme/animations.js +0 -70
  1120. package/dist/utilities/theme/animations.js.map +0 -1
  1121. package/dist/utilities/theme/animations.mjs +0 -70
  1122. package/dist/utilities/theme/animations.mjs.map +0 -1
  1123. package/dist/utilities/theme/assets.d.ts +0 -6
  1124. package/dist/utilities/theme/assets.d.ts.map +0 -1
  1125. package/dist/utilities/theme/assets.js +0 -17
  1126. package/dist/utilities/theme/assets.js.map +0 -1
  1127. package/dist/utilities/theme/assets.mjs +0 -17
  1128. package/dist/utilities/theme/assets.mjs.map +0 -1
  1129. package/dist/utilities/theme/index.d.ts +0 -11
  1130. package/dist/utilities/theme/index.d.ts.map +0 -1
  1131. package/dist/utilities/theme/index.js +0 -28
  1132. package/dist/utilities/theme/index.js.map +0 -1
  1133. package/dist/utilities/theme/index.mjs +0 -28
  1134. package/dist/utilities/theme/index.mjs.map +0 -1
  1135. package/dist/utilities/theme/media.d.ts +0 -12
  1136. package/dist/utilities/theme/media.d.ts.map +0 -1
  1137. package/dist/utilities/theme/media.js +0 -21
  1138. package/dist/utilities/theme/media.js.map +0 -1
  1139. package/dist/utilities/theme/media.mjs +0 -21
  1140. package/dist/utilities/theme/media.mjs.map +0 -1
  1141. package/dist/utilities.d.ts +0 -2
  1142. package/dist/utilities.js +0 -21
  1143. package/dist/utilities.js.map +0 -1
  1144. package/dist/utilities.mjs +0 -21
  1145. package/dist/utilities.mjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"frames.mjs","sources":["../../../../source/composite/carousel/wide/frames.ts"],"sourcesContent":["import * as Styles from '@universityofmaryland/web-styles-library';\nimport { assets } from 'atomic';\nimport { ElementModel } from 'model';\nimport { createElementWithRefs } from './_elementModel';\nimport { createControlButton } from './controls';\nimport { type ElementVisual } from '../../../_types';\nimport { type CarouselWideProps } from '../_types';\n\nconst ASPECT_RATIO = '16 / 9';\n\nconst createSlideContent = ({\n slide,\n isThemeDark,\n}: {\n slide: CarouselWideProps['slides'][0];\n isThemeDark?: boolean;\n}) => {\n const children: ElementVisual[] = [];\n\n // Create content container first to get reference\n let contentContainer: ElementVisual | null = null;\n\n const closeButton = ElementModel.create({\n element: document.createElement('button'),\n className: 'umd-carousel-wide__slide-content-close',\n attributes: [{ type: 'button' }, { 'aria-label': 'Close content' }],\n elementStyles: {\n element: {\n position: 'absolute',\n top: 0,\n right: 0,\n background: 'transparent',\n border: 'none',\n cursor: 'pointer',\n fontSize: '20px',\n fontWeight: 'bold',\n padding: Styles.token.spacing.min,\n lineHeight: 1,\n color: Styles.token.color.gray.dark,\n transition: 'color 0.2s ease',\n\n [`@media (${Styles.token.media.queries.large.max})`]: {\n display: 'none',\n },\n\n '&:hover, &:focus': {\n outline: `2px solid ${Styles.token.color.blue}`,\n },\n\n ...(isThemeDark && {\n color: Styles.token.color.gray.light,\n '&:hover': {\n color: Styles.token.color.white,\n },\n }),\n },\n },\n });\n\n closeButton.element.innerHTML = '×';\n\n closeButton.element.addEventListener('click', () => {\n if (contentContainer) contentContainer.element.style.display = 'none';\n });\n\n children.push(closeButton);\n\n if (slide.headline) {\n children.push(\n ElementModel.headline.sansLarge({\n element: slide.headline,\n elementStyles: {\n element: {\n color: `${Styles.token.color.black}`,\n },\n siblingAfter: {\n marginTop: Styles.token.spacing.sm,\n },\n },\n isThemeDark,\n }),\n );\n }\n\n if (slide.text) {\n children.push(\n ElementModel.richText.simple({\n element: slide.text,\n isThemeDark,\n }),\n );\n }\n\n if (children.length === 1) return null;\n\n contentContainer = ElementModel.createDiv({\n className: 'umd-carousel-wide__slide-content',\n children,\n elementStyles: {\n element: {\n backgroundColor: Styles.token.color.white,\n border: `1px solid ${Styles.token.color.gray.light}`,\n display: 'block',\n padding: Styles.token.spacing.md,\n width: '100%',\n position: 'relative',\n opacity: 0,\n transform: 'translateY(20px)',\n transition: 'opacity 0.6s ease-out, transform 0.6s ease-out',\n\n ...(isThemeDark && {\n backgroundColor: Styles.token.color.black,\n border: `1px solid ${Styles.token.color.gray.dark}`,\n }),\n\n [`@media (${Styles.token.media.queries.large.max})`]: {\n borderTop: 'none',\n },\n\n [`@media (${Styles.token.media.queries.tablet.min})`]: {\n border: 'none',\n boxShadow: '0 0 5px 0 rgba(0, 0, 0, 0.4)',\n maxWidth: '50%',\n position: 'absolute',\n bottom: Styles.token.spacing.sm,\n left: Styles.token.spacing.sm,\n\n ...(isThemeDark && {\n border: 'none',\n boxShadow: 'none',\n }),\n },\n },\n },\n });\n\n return contentContainer;\n};\n\nconst createMainFrameSlide = (\n slide: CarouselWideProps['slides'][0],\n index: number,\n isThemeDark?: boolean,\n) => {\n const children: ElementVisual[] = [];\n const slideContentWrapper = createSlideContent({ slide, isThemeDark });\n\n children.push(\n assets.image.background({\n element: slide.image,\n isScaled: true,\n }),\n );\n\n if (slideContentWrapper) children.push(slideContentWrapper);\n\n return ElementModel.create({\n element: document.createElement('figure'),\n className: 'umd-carousel-wide__slide',\n children,\n attributes: [{ 'data-index': `${index}` }],\n elementStyles: {\n element: {\n display: 'none',\n opacity: 0,\n transition: 'opacity 0.3s ease-in-out, transform 0.5s ease-in-out',\n transform: 'translateX(0)',\n aspectRatio: ASPECT_RATIO,\n\n [`@media (${Styles.token.media.queries.tablet.min})`]: {\n position: 'absolute',\n width: '100%',\n height: '100%',\n top: 0,\n left: 0,\n },\n\n '&[data-active=\"true\"]': {\n opacity: 1,\n transform: 'translateX(0)',\n zIndex: 2,\n display: 'block',\n },\n\n '&[data-animating=\"true\"]': {\n zIndex: 1,\n display: 'block',\n opacity: 1,\n\n [`@media (${Styles.token.media.queries.large.max})`]: {\n position: 'absolute',\n width: '100%',\n top: 0,\n left: 0,\n },\n },\n\n '&[data-direction=\"left\"]': {\n transform: 'translateX(-100%)',\n },\n\n '&[data-direction=\"right\"]': {\n transform: 'translateX(100%)',\n },\n\n '&[data-content-visible=\"true\"] .umd-carousel-wide__slide-content': {\n opacity: 1,\n transform: 'translateY(0)',\n },\n },\n },\n });\n};\n\nconst createPreviewContainer = (position: 'left' | 'right') => {\n const isPositionLeft = position === 'left';\n return ElementModel.createDiv({\n className: isPositionLeft\n ? 'umd-carousel-wide__preview--left'\n : 'umd-carousel-wide__preview--right',\n attributes: [{ 'aria-hidden': 'true' }, { role: 'presentation' }],\n elementStyles: {\n element: {\n display: 'none',\n overflow: 'hidden',\n position: 'relative',\n\n [`@media (${Styles.token.media.queries.tablet.min})`]: {\n display: 'flex',\n alignItems: 'flex-end',\n height: '100%',\n },\n\n ['& > * ']: {\n position: 'absolute !important',\n bottom: '0 !important',\n left: '0 !important',\n width: 'auto !important',\n height: '75% !important',\n display: 'block !important',\n aspectRatio: ASPECT_RATIO,\n\n ...(isPositionLeft && {\n right: '0 !important',\n left: 'auto !important',\n }),\n\n ['&:before ']: {\n content: '\"\"',\n position: 'absolute',\n top: '0',\n left: '0',\n right: '0',\n bottom: '0',\n background: Styles.token.color.gray.darker,\n opacity: 0.5,\n zIndex: 1,\n },\n },\n },\n },\n });\n};\n\nconst createMainContainer = (\n slides: CarouselWideProps['slides'],\n isThemeDark?: boolean,\n) => {\n const slideElements = slides.map((slide, index) => {\n return createMainFrameSlide(slide, index, isThemeDark);\n });\n\n // Set first slide as active and content visible\n if (slideElements.length > 0) {\n slideElements[0].element.setAttribute('data-active', 'true');\n slideElements[0].element.setAttribute('data-content-visible', 'true');\n }\n\n return {\n component: ElementModel.createDiv({\n className: 'umd-carousel-wide__main-container',\n children: slideElements,\n elementStyles: {\n element: {\n position: 'relative',\n overflow: 'hidden',\n },\n },\n }),\n refs: slideElements.map((el) => el.element),\n };\n};\n\nexport const createFramesContainer = (\n slides: CarouselWideProps['slides'],\n isThemeDark?: boolean,\n) => {\n const previewLeft = createPreviewContainer('left');\n const previewRight = createPreviewContainer('right');\n const previousButton = createControlButton('prev', isThemeDark);\n const nextButton = createControlButton('next', isThemeDark);\n const mainContainer = createMainContainer(slides, isThemeDark);\n\n return createElementWithRefs({\n className: 'umd-carousel-wide__frames-container',\n children: [\n previewLeft,\n mainContainer.component,\n previewRight,\n previousButton,\n nextButton,\n ],\n elementStyles: {\n element: {\n position: 'relative',\n\n [`@media (${Styles.token.media.queries.large.max})`]: {\n padding: `0 ${Styles.token.spacing.md}`,\n },\n\n [`@media (${Styles.token.media.queries.tablet.min})`]: {\n display: 'grid',\n gridTemplateColumns: '10vw 1fr 10vw',\n gridGap: Styles.token.spacing.md,\n height: '56vw',\n maxHeight: '60vh',\n },\n\n [`@media (${Styles.token.media.queries.desktop.min})`]: {\n gridTemplateColumns: '15vw 1fr 15vw',\n gridGap: Styles.token.spacing.lg,\n },\n\n [`@media (${Styles.token.media.queries.highDef.min})`]: {\n gridTemplateColumns: '20vw 1fr 20vw',\n },\n },\n },\n refs: {\n slidesContainer: mainContainer.component.element as HTMLDivElement,\n slides: mainContainer.refs,\n previews: {\n left: previewLeft.element as HTMLElement,\n right: previewRight.element as HTMLElement,\n },\n controls: {\n prev: previousButton.element as HTMLButtonElement,\n next: nextButton.element as HTMLButtonElement,\n },\n },\n });\n};\n"],"names":["ElementModel.create","ElementModel.headline.sansLarge","ElementModel.richText.simple","ElementModel.createDiv","index","assets.image.background"],"mappings":"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"}
1
+ {"version":3,"file":"frames.mjs","sources":["../../../../source/composite/carousel/wide/frames.ts"],"sourcesContent":["import * as token from '@universityofmaryland/web-styles-library/token';\nimport { assets } from 'atomic';\nimport { ElementModel } from 'model';\nimport { createElementWithRefs } from './_elementModel';\nimport { createControlButton } from './controls';\nimport { type ElementVisual } from '../../../_types';\nimport { type CarouselWideProps } from '../_types';\n\nconst ASPECT_RATIO = '16 / 9';\n\nconst createSlideContent = ({\n slide,\n isThemeDark,\n}: {\n slide: CarouselWideProps['slides'][0];\n isThemeDark?: boolean;\n}) => {\n const children: ElementVisual[] = [];\n\n // Create content container first to get reference\n let contentContainer: ElementVisual | null = null;\n\n const closeButton = ElementModel.create({\n element: document.createElement('button'),\n className: 'umd-carousel-wide__slide-content-close',\n attributes: [{ type: 'button' }, { 'aria-label': 'Close content' }],\n elementStyles: {\n element: {\n position: 'absolute',\n top: 0,\n right: 0,\n background: 'transparent',\n border: 'none',\n cursor: 'pointer',\n fontSize: '20px',\n fontWeight: 'bold',\n padding: token.spacing.min,\n lineHeight: 1,\n color: token.color.gray.dark,\n transition: 'color 0.2s ease',\n\n [`@media (${token.media.queries.large.max})`]: {\n display: 'none',\n },\n\n '&:hover, &:focus': {\n outline: `2px solid ${token.color.blue}`,\n },\n\n ...(isThemeDark && {\n color: token.color.gray.light,\n '&:hover': {\n color: token.color.white,\n },\n }),\n },\n },\n });\n\n closeButton.element.innerHTML = '×';\n\n closeButton.element.addEventListener('click', () => {\n if (contentContainer) contentContainer.element.style.display = 'none';\n });\n\n children.push(closeButton);\n\n if (slide.headline) {\n children.push(\n ElementModel.headline.sansLarge({\n element: slide.headline,\n elementStyles: {\n element: {\n color: `${token.color.black}`,\n },\n siblingAfter: {\n marginTop: token.spacing.sm,\n },\n },\n isThemeDark,\n }),\n );\n }\n\n if (slide.text) {\n children.push(\n ElementModel.richText.simple({\n element: slide.text,\n isThemeDark,\n }),\n );\n }\n\n if (children.length === 1) return null;\n\n contentContainer = ElementModel.createDiv({\n className: 'umd-carousel-wide__slide-content',\n children,\n elementStyles: {\n element: {\n backgroundColor: token.color.white,\n border: `1px solid ${token.color.gray.light}`,\n display: 'block',\n padding: token.spacing.md,\n width: '100%',\n position: 'relative',\n opacity: 0,\n transform: 'translateY(20px)',\n transition: 'opacity 0.6s ease-out, transform 0.6s ease-out',\n\n ...(isThemeDark && {\n backgroundColor: token.color.black,\n border: `1px solid ${token.color.gray.dark}`,\n }),\n\n [`@media (${token.media.queries.large.max})`]: {\n borderTop: 'none',\n },\n\n [`@media (${token.media.queries.tablet.min})`]: {\n border: 'none',\n boxShadow: '0 0 5px 0 rgba(0, 0, 0, 0.4)',\n maxWidth: '50%',\n position: 'absolute',\n bottom: token.spacing.sm,\n left: token.spacing.sm,\n\n ...(isThemeDark && {\n border: 'none',\n boxShadow: 'none',\n }),\n },\n },\n },\n });\n\n return contentContainer;\n};\n\nconst createMainFrameSlide = (\n slide: CarouselWideProps['slides'][0],\n index: number,\n isThemeDark?: boolean,\n) => {\n const children: ElementVisual[] = [];\n const slideContentWrapper = createSlideContent({ slide, isThemeDark });\n\n children.push(\n assets.image.background({\n element: slide.image,\n isScaled: true,\n }),\n );\n\n if (slideContentWrapper) children.push(slideContentWrapper);\n\n return ElementModel.create({\n element: document.createElement('figure'),\n className: 'umd-carousel-wide__slide',\n children,\n attributes: [{ 'data-index': `${index}` }],\n elementStyles: {\n element: {\n display: 'none',\n opacity: 0,\n transition: 'opacity 0.3s ease-in-out, transform 0.5s ease-in-out',\n transform: 'translateX(0)',\n aspectRatio: ASPECT_RATIO,\n\n [`@media (${token.media.queries.tablet.min})`]: {\n position: 'absolute',\n width: '100%',\n height: '100%',\n top: 0,\n left: 0,\n },\n\n '&[data-active=\"true\"]': {\n opacity: 1,\n transform: 'translateX(0)',\n zIndex: 2,\n display: 'block',\n },\n\n '&[data-animating=\"true\"]': {\n zIndex: 1,\n display: 'block',\n opacity: 1,\n\n [`@media (${token.media.queries.large.max})`]: {\n position: 'absolute',\n width: '100%',\n top: 0,\n left: 0,\n },\n },\n\n '&[data-direction=\"left\"]': {\n transform: 'translateX(-100%)',\n },\n\n '&[data-direction=\"right\"]': {\n transform: 'translateX(100%)',\n },\n\n '&[data-content-visible=\"true\"] .umd-carousel-wide__slide-content': {\n opacity: 1,\n transform: 'translateY(0)',\n },\n },\n },\n });\n};\n\nconst createPreviewContainer = (position: 'left' | 'right') => {\n const isPositionLeft = position === 'left';\n return ElementModel.createDiv({\n className: isPositionLeft\n ? 'umd-carousel-wide__preview--left'\n : 'umd-carousel-wide__preview--right',\n attributes: [{ 'aria-hidden': 'true' }, { role: 'presentation' }],\n elementStyles: {\n element: {\n display: 'none',\n overflow: 'hidden',\n position: 'relative',\n\n [`@media (${token.media.queries.tablet.min})`]: {\n display: 'flex',\n alignItems: 'flex-end',\n height: '100%',\n },\n\n ['& > * ']: {\n position: 'absolute !important',\n bottom: '0 !important',\n left: '0 !important',\n width: 'auto !important',\n height: '75% !important',\n display: 'block !important',\n aspectRatio: ASPECT_RATIO,\n\n ...(isPositionLeft && {\n right: '0 !important',\n left: 'auto !important',\n }),\n\n ['&:before ']: {\n content: '\"\"',\n position: 'absolute',\n top: '0',\n left: '0',\n right: '0',\n bottom: '0',\n background: token.color.gray.darker,\n opacity: 0.5,\n zIndex: 1,\n },\n },\n },\n },\n });\n};\n\nconst createMainContainer = (\n slides: CarouselWideProps['slides'],\n isThemeDark?: boolean,\n) => {\n const slideElements = slides.map((slide, index) => {\n return createMainFrameSlide(slide, index, isThemeDark);\n });\n\n // Set first slide as active and content visible\n if (slideElements.length > 0) {\n slideElements[0].element.setAttribute('data-active', 'true');\n slideElements[0].element.setAttribute('data-content-visible', 'true');\n }\n\n return {\n component: ElementModel.createDiv({\n className: 'umd-carousel-wide__main-container',\n children: slideElements,\n elementStyles: {\n element: {\n position: 'relative',\n overflow: 'hidden',\n },\n },\n }),\n refs: slideElements.map((el) => el.element),\n };\n};\n\nexport const createFramesContainer = (\n slides: CarouselWideProps['slides'],\n isThemeDark?: boolean,\n) => {\n const previewLeft = createPreviewContainer('left');\n const previewRight = createPreviewContainer('right');\n const previousButton = createControlButton('prev', isThemeDark);\n const nextButton = createControlButton('next', isThemeDark);\n const mainContainer = createMainContainer(slides, isThemeDark);\n\n return createElementWithRefs({\n className: 'umd-carousel-wide__frames-container',\n children: [\n previewLeft,\n mainContainer.component,\n previewRight,\n previousButton,\n nextButton,\n ],\n elementStyles: {\n element: {\n position: 'relative',\n\n [`@media (${token.media.queries.large.max})`]: {\n padding: `0 ${token.spacing.md}`,\n },\n\n [`@media (${token.media.queries.tablet.min})`]: {\n display: 'grid',\n gridTemplateColumns: '10vw 1fr 10vw',\n gridGap: token.spacing.md,\n height: '56vw',\n maxHeight: '60vh',\n },\n\n [`@media (${token.media.queries.desktop.min})`]: {\n gridTemplateColumns: '15vw 1fr 15vw',\n gridGap: token.spacing.lg,\n },\n\n [`@media (${token.media.queries.highDef.min})`]: {\n gridTemplateColumns: '20vw 1fr 20vw',\n },\n },\n },\n refs: {\n slidesContainer: mainContainer.component.element as HTMLDivElement,\n slides: mainContainer.refs,\n previews: {\n left: previewLeft.element as HTMLElement,\n right: previewRight.element as HTMLElement,\n },\n controls: {\n prev: previousButton.element as HTMLButtonElement,\n next: nextButton.element as HTMLButtonElement,\n },\n },\n });\n};\n"],"names":["ElementModel.create","ElementModel.headline.sansLarge","ElementModel.richText.simple","ElementModel.createDiv","index","assets.image.background"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../source/composite/carousel/wide/index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,iBAAiB,EAAE,MAAM,WAAW,CAAC;yBAwQnC,OAAO,iBAAiB;;;;;AAAxC,wBAiDE"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../source/composite/carousel/wide/index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,iBAAiB,EAAE,MAAM,WAAW,CAAC;yBAuQnC,OAAO,iBAAiB;;;;;AAAxC,wBAiDE"}
@@ -1,18 +1,29 @@
1
1
  "use strict";
2
- const Styles = require("@universityofmaryland/web-styles-library");
3
- require("../../../node_modules/postcss/lib/postcss.js");
4
- require("../../../node_modules/postcss-nesting/dist/index.js");
5
- require("../../../node_modules/postcss-js/index.js");
2
+ const token = require("@universityofmaryland/web-styles-library/token");
3
+ require("@universityofmaryland/web-styles-library/element");
4
+ require("@universityofmaryland/web-utilities-library/media");
5
+ require("@universityofmaryland/web-utilities-library/dom");
6
+ require("@universityofmaryland/web-icons-library/controls");
7
+ require("@universityofmaryland/web-icons-library/communication");
8
+ require("@universityofmaryland/web-icons-library/files");
9
+ require("@universityofmaryland/web-icons-library/brand");
6
10
  const index$1 = require("../../../model/elements/index.js");
11
+ require("@universityofmaryland/web-icons-library/arrows");
7
12
  require("../../../atomic/animations/actions/indicator.js");
8
13
  require("../../../atomic/animations/brand/chevron-scroll.js");
9
14
  require("../../../atomic/animations/brand/card-stack.js");
10
15
  const background = require("../../../atomic/assets/image/background.js");
16
+ require("@universityofmaryland/web-utilities-library/performance");
17
+ require("@universityofmaryland/web-utilities-library/accessibility");
18
+ require("@universityofmaryland/web-icons-library/location");
19
+ require("@universityofmaryland/web-icons-library/calendar");
11
20
  require("../../../atomic/layout/block/stacked.js");
12
21
  require("../../../atomic/layout/overlay/modal.js");
13
22
  require("../../../atomic/layout/person/columns.js");
23
+ require("@universityofmaryland/web-icons-library/social");
14
24
  require("../../../atomic/text-lockup/date.js");
15
25
  require("../../../atomic/text-lockup/small.js");
26
+ require("@universityofmaryland/web-styles-library/typography");
16
27
  const container = require("./container.js");
17
28
  function _interopNamespaceDefault(e) {
18
29
  const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
@@ -30,7 +41,7 @@ function _interopNamespaceDefault(e) {
30
41
  n.default = e;
31
42
  return Object.freeze(n);
32
43
  }
33
- const Styles__namespace = /* @__PURE__ */ _interopNamespaceDefault(Styles);
44
+ const token__namespace = /* @__PURE__ */ _interopNamespaceDefault(token);
34
45
  const ANIMATION_TIME = 500;
35
46
  const PREVIEW_ANIMATION_TIME = 440;
36
47
  const getAdjacentIndices = (currentIndex, totalSlides) => {
@@ -196,7 +207,7 @@ const index = (props) => {
196
207
  container: "umd-carousel-wide / inline-size",
197
208
  display: "block",
198
209
  position: "relative",
199
- [`@media (${Styles__namespace.token.media.queries.large.min})`]: {
210
+ [`@media (${token__namespace.media.queries.large.min})`]: {
200
211
  paddingBottom: 0
201
212
  }
202
213
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../source/composite/carousel/wide/index.ts"],"sourcesContent":["import * as Styles from '@universityofmaryland/web-styles-library';\nimport { assets } from 'atomic';\nimport { ElementModel } from 'model';\nimport { createContainer } from './container';\nimport { type CarouselWideProps } from '../_types';\n\n// Interfaces\ninterface CarouselState {\n currentIndex: number;\n isAnimating: boolean;\n slides: CarouselWideProps['slides'];\n}\n\ninterface CarouselRefs {\n container: HTMLElement;\n slidesContainer: HTMLDivElement;\n slides: HTMLElement[];\n previews: {\n left: HTMLElement;\n right: HTMLElement;\n };\n controls: {\n prev: HTMLButtonElement;\n next: HTMLButtonElement;\n };\n indicator: {\n element: HTMLElement;\n position: (index: number) => void;\n };\n info: HTMLParagraphElement;\n}\n\n// Constants\nconst ANIMATION_TIME: 500 = 500;\nconst PREVIEW_ANIMATION_TIME: 440 = 440; // 60ms faster than main animation\n\n// Pure animation functions\nconst getAdjacentIndices = (\n currentIndex: number,\n totalSlides: number,\n): { leftIndex: number; rightIndex: number } => {\n const lastIndex = totalSlides - 1;\n return {\n leftIndex: currentIndex === 0 ? lastIndex : currentIndex - 1,\n rightIndex: currentIndex === lastIndex ? 0 : currentIndex + 1,\n };\n};\n\nconst positionSlideOffScreen = (\n slide: HTMLElement,\n direction: 'left' | 'right',\n): void => {\n slide.setAttribute('data-direction', direction);\n slide.setAttribute('data-animating', 'true');\n slide.offsetHeight; // Force reflow\n};\n\nconst activateSlideTransition = (\n slide: HTMLElement,\n direction?: 'left' | 'right',\n): void => {\n if (direction) {\n slide.setAttribute('data-direction', direction);\n } else {\n slide.removeAttribute('data-direction');\n slide.setAttribute('data-active', 'true');\n }\n};\n\nconst cleanupSlideTransition = (slide: HTMLElement, isNew: boolean): void => {\n if (isNew) {\n slide.removeAttribute('data-animating');\n } else {\n slide.removeAttribute('data-active');\n slide.removeAttribute('data-direction');\n slide.removeAttribute('data-content-visible');\n }\n};\n\n// Pure preview functions\nconst createPreviewElement = (\n slide: CarouselWideProps['slides'][0],\n): HTMLElement => {\n const imageCopy = slide.image.cloneNode(true) as HTMLImageElement;\n const preview = assets.image.background({\n element: imageCopy,\n isScaled: true,\n });\n\n preview.element.style.transition = `transform ${PREVIEW_ANIMATION_TIME}ms ease-in-out`;\n return preview.element;\n};\n\nconst clearPreviewContainer = (container: HTMLElement): void => {\n while (container.firstChild) {\n container.removeChild(container.firstChild);\n }\n};\n\nconst appendPreviewWithAnimation = (\n container: HTMLElement,\n preview: HTMLElement,\n animationDirection: 'reverse' | 'advance',\n): void => {\n // Position off-screen initially based on animation direction\n // For advance (forward), new content comes from right\n // For reverse (backward), new content comes from left\n preview.style.transform =\n animationDirection === 'advance' ? 'translateX(100%)' : 'translateX(-100%)';\n\n container.appendChild(preview);\n\n // Trigger animation to slide in\n requestAnimationFrame(() => {\n preview.style.transform = 'translateX(0)';\n });\n};\n\nconst animatePreviewOut = (\n preview: HTMLElement,\n animationDirection: 'reverse' | 'advance',\n): Promise<void> => {\n return new Promise((resolve) => {\n // For advance (forward), old content exits to left\n // For reverse (backward), old content exits to right\n preview.style.transform =\n animationDirection === 'advance'\n ? 'translateX(-100%)'\n : 'translateX(100%)';\n\n setTimeout(() => {\n if (preview.parentNode) {\n preview.parentNode.removeChild(preview);\n }\n resolve();\n }, PREVIEW_ANIMATION_TIME);\n });\n};\n\n// State management\nconst updatePreviews = (\n refs: CarouselRefs,\n state: CarouselState,\n direction?: 'reverse' | 'advance',\n): void => {\n const { currentIndex, slides } = state;\n const { leftIndex, rightIndex } = getAdjacentIndices(\n currentIndex,\n slides.length,\n );\n\n // Handle left preview\n if (slides[leftIndex]) {\n const existingLeft = refs.previews.left.firstElementChild as HTMLElement;\n if (existingLeft && direction) {\n animatePreviewOut(existingLeft, direction);\n } else if (existingLeft) {\n clearPreviewContainer(refs.previews.left);\n }\n\n const leftPreview = createPreviewElement(slides[leftIndex]);\n if (direction) {\n appendPreviewWithAnimation(refs.previews.left, leftPreview, direction);\n } else {\n refs.previews.left.appendChild(leftPreview);\n }\n }\n\n // Handle right preview\n if (slides[rightIndex]) {\n const existingRight = refs.previews.right.firstElementChild as HTMLElement;\n if (existingRight && direction) {\n animatePreviewOut(existingRight, direction);\n } else if (existingRight) {\n clearPreviewContainer(refs.previews.right);\n }\n\n const rightPreview = createPreviewElement(slides[rightIndex]);\n if (direction) {\n appendPreviewWithAnimation(refs.previews.right, rightPreview, direction);\n } else {\n refs.previews.right.appendChild(rightPreview);\n }\n }\n};\n\nconst updateInfo = (refs: CarouselRefs, newIndex: number) => {\n refs.info.textContent = `Slide ${newIndex + 1} Selected`;\n};\n\nconst animateSlides = (\n refs: CarouselRefs,\n state: CarouselState,\n newIndex: number,\n direction: 'reverse' | 'advance',\n) => {\n if (state.isAnimating || state.currentIndex === newIndex) return;\n state.isAnimating = true;\n\n const currentSlide = refs.slides[state.currentIndex];\n const newSlide = refs.slides[newIndex];\n\n // Disable controls during animation\n refs.controls.prev.setAttribute('disabled', '');\n refs.controls.next.setAttribute('disabled', '');\n\n // Position new slide off-screen\n const newSlideDirection = direction === 'reverse' ? 'left' : 'right';\n positionSlideOffScreen(newSlide, newSlideDirection);\n\n // Update indicator position\n refs.indicator.position(newIndex);\n\n // Start synchronized animations for all frames\n requestAnimationFrame(() => {\n // Animate main slides\n activateSlideTransition(newSlide);\n const currentSlideDirection = direction === 'reverse' ? 'right' : 'left';\n activateSlideTransition(currentSlide, currentSlideDirection);\n\n // Update previews with animation (this will animate in sync)\n const nextState = { ...state, currentIndex: newIndex };\n updatePreviews(refs, nextState, direction);\n });\n\n // Clean up after animation\n setTimeout(() => {\n // Clean up main slides\n cleanupSlideTransition(currentSlide, false);\n cleanupSlideTransition(newSlide, true);\n\n // Show content with fade-in animation\n newSlide.setAttribute('data-content-visible', 'true');\n\n // Re-enable controls\n refs.controls.prev.removeAttribute('disabled');\n refs.controls.next.removeAttribute('disabled');\n\n // Update state\n state.currentIndex = newIndex;\n state.isAnimating = false;\n\n // Update accessibility info\n updateInfo(refs, newIndex);\n }, ANIMATION_TIME);\n};\n\nconst setupSliderControls = (refs: CarouselRefs, state: CarouselState) => {\n const lastIndex = state.slides.length - 1;\n\n refs.controls.prev.addEventListener('click', () => {\n if (state.isAnimating) return;\n\n const newIndex =\n state.currentIndex === lastIndex ? 0 : state.currentIndex + 1;\n animateSlides(refs, state, newIndex, 'advance');\n });\n\n refs.controls.next.addEventListener('click', () => {\n if (state.isAnimating) return;\n\n const newIndex =\n state.currentIndex === 0 ? lastIndex : state.currentIndex - 1;\n animateSlides(refs, state, newIndex, 'reverse');\n });\n};\n\n// Main component\nexport default (props: CarouselWideProps) => {\n const { title } = props;\n\n // Initialize state early\n const state: CarouselState = {\n currentIndex: 0,\n isAnimating: false,\n slides: props.slides,\n };\n\n const container = createContainer(props, (index: number) => {\n if (state.isAnimating || state.currentIndex === index) return;\n\n const direction = state.currentIndex > index ? 'reverse' : 'advance';\n animateSlides(refs, state, index, direction);\n });\n\n const composite = ElementModel.createDiv({\n className: 'umd-carousel-wide',\n children: [container],\n attributes: [\n ...(title ? [{ title }] : [{ title: 'Animated Image Carousel' }]),\n ],\n elementStyles: {\n element: {\n container: 'umd-carousel-wide / inline-size',\n display: 'block',\n position: 'relative',\n\n [`@media (${Styles.token.media.queries.large.min})`]: {\n paddingBottom: 0,\n },\n },\n },\n });\n\n // Initialize refs\n const refs: CarouselRefs = {\n container: composite.element,\n ...container.refs,\n };\n\n // Set up event handlers after DOM is ready\n requestAnimationFrame(() => {\n setupSliderControls(refs, state);\n updatePreviews(refs, state); // Initial preview setup without animation\n });\n\n return composite;\n};\n"],"names":["assets.image.background","container","createContainer","index","ElementModel.createDiv","Styles"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../../../source/composite/carousel/wide/index.ts"],"sourcesContent":["import * as token from '@universityofmaryland/web-styles-library/token';\nimport { assets } from 'atomic';\nimport { ElementModel } from 'model';\nimport { createContainer } from './container';\nimport { type CarouselWideProps } from '../_types';\n\ninterface CarouselState {\n currentIndex: number;\n isAnimating: boolean;\n slides: CarouselWideProps['slides'];\n}\n\ninterface CarouselRefs {\n container: HTMLElement;\n slidesContainer: HTMLDivElement;\n slides: HTMLElement[];\n previews: {\n left: HTMLElement;\n right: HTMLElement;\n };\n controls: {\n prev: HTMLButtonElement;\n next: HTMLButtonElement;\n };\n indicator: {\n element: HTMLElement;\n position: (index: number) => void;\n };\n info: HTMLParagraphElement;\n}\n\n// Constants\nconst ANIMATION_TIME: 500 = 500;\nconst PREVIEW_ANIMATION_TIME: 440 = 440; // 60ms faster than main animation\n\n// Pure animation functions\nconst getAdjacentIndices = (\n currentIndex: number,\n totalSlides: number,\n): { leftIndex: number; rightIndex: number } => {\n const lastIndex = totalSlides - 1;\n return {\n leftIndex: currentIndex === 0 ? lastIndex : currentIndex - 1,\n rightIndex: currentIndex === lastIndex ? 0 : currentIndex + 1,\n };\n};\n\nconst positionSlideOffScreen = (\n slide: HTMLElement,\n direction: 'left' | 'right',\n): void => {\n slide.setAttribute('data-direction', direction);\n slide.setAttribute('data-animating', 'true');\n slide.offsetHeight; // Force reflow\n};\n\nconst activateSlideTransition = (\n slide: HTMLElement,\n direction?: 'left' | 'right',\n): void => {\n if (direction) {\n slide.setAttribute('data-direction', direction);\n } else {\n slide.removeAttribute('data-direction');\n slide.setAttribute('data-active', 'true');\n }\n};\n\nconst cleanupSlideTransition = (slide: HTMLElement, isNew: boolean): void => {\n if (isNew) {\n slide.removeAttribute('data-animating');\n } else {\n slide.removeAttribute('data-active');\n slide.removeAttribute('data-direction');\n slide.removeAttribute('data-content-visible');\n }\n};\n\n// Pure preview functions\nconst createPreviewElement = (\n slide: CarouselWideProps['slides'][0],\n): HTMLElement => {\n const imageCopy = slide.image.cloneNode(true) as HTMLImageElement;\n const preview = assets.image.background({\n element: imageCopy,\n isScaled: true,\n });\n\n preview.element.style.transition = `transform ${PREVIEW_ANIMATION_TIME}ms ease-in-out`;\n return preview.element;\n};\n\nconst clearPreviewContainer = (container: HTMLElement): void => {\n while (container.firstChild) {\n container.removeChild(container.firstChild);\n }\n};\n\nconst appendPreviewWithAnimation = (\n container: HTMLElement,\n preview: HTMLElement,\n animationDirection: 'reverse' | 'advance',\n): void => {\n // Position off-screen initially based on animation direction\n // For advance (forward), new content comes from right\n // For reverse (backward), new content comes from left\n preview.style.transform =\n animationDirection === 'advance' ? 'translateX(100%)' : 'translateX(-100%)';\n\n container.appendChild(preview);\n\n // Trigger animation to slide in\n requestAnimationFrame(() => {\n preview.style.transform = 'translateX(0)';\n });\n};\n\nconst animatePreviewOut = (\n preview: HTMLElement,\n animationDirection: 'reverse' | 'advance',\n): Promise<void> => {\n return new Promise((resolve) => {\n // For advance (forward), old content exits to left\n // For reverse (backward), old content exits to right\n preview.style.transform =\n animationDirection === 'advance'\n ? 'translateX(-100%)'\n : 'translateX(100%)';\n\n setTimeout(() => {\n if (preview.parentNode) {\n preview.parentNode.removeChild(preview);\n }\n resolve();\n }, PREVIEW_ANIMATION_TIME);\n });\n};\n\n// State management\nconst updatePreviews = (\n refs: CarouselRefs,\n state: CarouselState,\n direction?: 'reverse' | 'advance',\n): void => {\n const { currentIndex, slides } = state;\n const { leftIndex, rightIndex } = getAdjacentIndices(\n currentIndex,\n slides.length,\n );\n\n // Handle left preview\n if (slides[leftIndex]) {\n const existingLeft = refs.previews.left.firstElementChild as HTMLElement;\n if (existingLeft && direction) {\n animatePreviewOut(existingLeft, direction);\n } else if (existingLeft) {\n clearPreviewContainer(refs.previews.left);\n }\n\n const leftPreview = createPreviewElement(slides[leftIndex]);\n if (direction) {\n appendPreviewWithAnimation(refs.previews.left, leftPreview, direction);\n } else {\n refs.previews.left.appendChild(leftPreview);\n }\n }\n\n // Handle right preview\n if (slides[rightIndex]) {\n const existingRight = refs.previews.right.firstElementChild as HTMLElement;\n if (existingRight && direction) {\n animatePreviewOut(existingRight, direction);\n } else if (existingRight) {\n clearPreviewContainer(refs.previews.right);\n }\n\n const rightPreview = createPreviewElement(slides[rightIndex]);\n if (direction) {\n appendPreviewWithAnimation(refs.previews.right, rightPreview, direction);\n } else {\n refs.previews.right.appendChild(rightPreview);\n }\n }\n};\n\nconst updateInfo = (refs: CarouselRefs, newIndex: number) => {\n refs.info.textContent = `Slide ${newIndex + 1} Selected`;\n};\n\nconst animateSlides = (\n refs: CarouselRefs,\n state: CarouselState,\n newIndex: number,\n direction: 'reverse' | 'advance',\n) => {\n if (state.isAnimating || state.currentIndex === newIndex) return;\n state.isAnimating = true;\n\n const currentSlide = refs.slides[state.currentIndex];\n const newSlide = refs.slides[newIndex];\n\n // Disable controls during animation\n refs.controls.prev.setAttribute('disabled', '');\n refs.controls.next.setAttribute('disabled', '');\n\n // Position new slide off-screen\n const newSlideDirection = direction === 'reverse' ? 'left' : 'right';\n positionSlideOffScreen(newSlide, newSlideDirection);\n\n // Update indicator position\n refs.indicator.position(newIndex);\n\n // Start synchronized animations for all frames\n requestAnimationFrame(() => {\n // Animate main slides\n activateSlideTransition(newSlide);\n const currentSlideDirection = direction === 'reverse' ? 'right' : 'left';\n activateSlideTransition(currentSlide, currentSlideDirection);\n\n // Update previews with animation (this will animate in sync)\n const nextState = { ...state, currentIndex: newIndex };\n updatePreviews(refs, nextState, direction);\n });\n\n // Clean up after animation\n setTimeout(() => {\n // Clean up main slides\n cleanupSlideTransition(currentSlide, false);\n cleanupSlideTransition(newSlide, true);\n\n // Show content with fade-in animation\n newSlide.setAttribute('data-content-visible', 'true');\n\n // Re-enable controls\n refs.controls.prev.removeAttribute('disabled');\n refs.controls.next.removeAttribute('disabled');\n\n // Update state\n state.currentIndex = newIndex;\n state.isAnimating = false;\n\n // Update accessibility info\n updateInfo(refs, newIndex);\n }, ANIMATION_TIME);\n};\n\nconst setupSliderControls = (refs: CarouselRefs, state: CarouselState) => {\n const lastIndex = state.slides.length - 1;\n\n refs.controls.prev.addEventListener('click', () => {\n if (state.isAnimating) return;\n\n const newIndex =\n state.currentIndex === lastIndex ? 0 : state.currentIndex + 1;\n animateSlides(refs, state, newIndex, 'advance');\n });\n\n refs.controls.next.addEventListener('click', () => {\n if (state.isAnimating) return;\n\n const newIndex =\n state.currentIndex === 0 ? lastIndex : state.currentIndex - 1;\n animateSlides(refs, state, newIndex, 'reverse');\n });\n};\n\n// Main component\nexport default (props: CarouselWideProps) => {\n const { title } = props;\n\n // Initialize state early\n const state: CarouselState = {\n currentIndex: 0,\n isAnimating: false,\n slides: props.slides,\n };\n\n const container = createContainer(props, (index: number) => {\n if (state.isAnimating || state.currentIndex === index) return;\n\n const direction = state.currentIndex > index ? 'reverse' : 'advance';\n animateSlides(refs, state, index, direction);\n });\n\n const composite = ElementModel.createDiv({\n className: 'umd-carousel-wide',\n children: [container],\n attributes: [\n ...(title ? [{ title }] : [{ title: 'Animated Image Carousel' }]),\n ],\n elementStyles: {\n element: {\n container: 'umd-carousel-wide / inline-size',\n display: 'block',\n position: 'relative',\n\n [`@media (${token.media.queries.large.min})`]: {\n paddingBottom: 0,\n },\n },\n },\n });\n\n // Initialize refs\n const refs: CarouselRefs = {\n container: composite.element,\n ...container.refs,\n };\n\n // Set up event handlers after DOM is ready\n requestAnimationFrame(() => {\n setupSliderControls(refs, state);\n updatePreviews(refs, state); // Initial preview setup without animation\n });\n\n return composite;\n};\n"],"names":["assets.image.background","container","createContainer","index","ElementModel.createDiv","token"],"mappings":"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"}
@@ -1,17 +1,28 @@
1
- import * as Styles from "@universityofmaryland/web-styles-library";
2
- import "../../../node_modules/postcss/lib/postcss.mjs";
3
- import "../../../node_modules/postcss-nesting/dist/index.mjs";
4
- import "../../../node_modules/postcss-js/index.mjs";
1
+ import * as token from "@universityofmaryland/web-styles-library/token";
2
+ import "@universityofmaryland/web-styles-library/element";
3
+ import "@universityofmaryland/web-utilities-library/media";
4
+ import "@universityofmaryland/web-utilities-library/dom";
5
+ import "@universityofmaryland/web-icons-library/controls";
6
+ import "@universityofmaryland/web-icons-library/communication";
7
+ import "@universityofmaryland/web-icons-library/files";
8
+ import "@universityofmaryland/web-icons-library/brand";
5
9
  import { createDiv } from "../../../model/elements/index.mjs";
10
+ import "@universityofmaryland/web-icons-library/arrows";
6
11
  import "../../../atomic/animations/actions/indicator.mjs";
7
12
  import "../../../atomic/animations/brand/chevron-scroll.mjs";
8
13
  import "../../../atomic/animations/brand/card-stack.mjs";
9
14
  import imageContainer from "../../../atomic/assets/image/background.mjs";
15
+ import "@universityofmaryland/web-utilities-library/performance";
16
+ import "@universityofmaryland/web-utilities-library/accessibility";
17
+ import "@universityofmaryland/web-icons-library/location";
18
+ import "@universityofmaryland/web-icons-library/calendar";
10
19
  import "../../../atomic/layout/block/stacked.mjs";
11
20
  import "../../../atomic/layout/overlay/modal.mjs";
12
21
  import "../../../atomic/layout/person/columns.mjs";
22
+ import "@universityofmaryland/web-icons-library/social";
13
23
  import "../../../atomic/text-lockup/date.mjs";
14
24
  import "../../../atomic/text-lockup/small.mjs";
25
+ import "@universityofmaryland/web-styles-library/typography";
15
26
  import { createContainer } from "./container.mjs";
16
27
  const ANIMATION_TIME = 500;
17
28
  const PREVIEW_ANIMATION_TIME = 440;
@@ -178,7 +189,7 @@ const index = (props) => {
178
189
  container: "umd-carousel-wide / inline-size",
179
190
  display: "block",
180
191
  position: "relative",
181
- [`@media (${Styles.token.media.queries.large.min})`]: {
192
+ [`@media (${token.media.queries.large.min})`]: {
182
193
  paddingBottom: 0
183
194
  }
184
195
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../../source/composite/carousel/wide/index.ts"],"sourcesContent":["import * as Styles from '@universityofmaryland/web-styles-library';\nimport { assets } from 'atomic';\nimport { ElementModel } from 'model';\nimport { createContainer } from './container';\nimport { type CarouselWideProps } from '../_types';\n\n// Interfaces\ninterface CarouselState {\n currentIndex: number;\n isAnimating: boolean;\n slides: CarouselWideProps['slides'];\n}\n\ninterface CarouselRefs {\n container: HTMLElement;\n slidesContainer: HTMLDivElement;\n slides: HTMLElement[];\n previews: {\n left: HTMLElement;\n right: HTMLElement;\n };\n controls: {\n prev: HTMLButtonElement;\n next: HTMLButtonElement;\n };\n indicator: {\n element: HTMLElement;\n position: (index: number) => void;\n };\n info: HTMLParagraphElement;\n}\n\n// Constants\nconst ANIMATION_TIME: 500 = 500;\nconst PREVIEW_ANIMATION_TIME: 440 = 440; // 60ms faster than main animation\n\n// Pure animation functions\nconst getAdjacentIndices = (\n currentIndex: number,\n totalSlides: number,\n): { leftIndex: number; rightIndex: number } => {\n const lastIndex = totalSlides - 1;\n return {\n leftIndex: currentIndex === 0 ? lastIndex : currentIndex - 1,\n rightIndex: currentIndex === lastIndex ? 0 : currentIndex + 1,\n };\n};\n\nconst positionSlideOffScreen = (\n slide: HTMLElement,\n direction: 'left' | 'right',\n): void => {\n slide.setAttribute('data-direction', direction);\n slide.setAttribute('data-animating', 'true');\n slide.offsetHeight; // Force reflow\n};\n\nconst activateSlideTransition = (\n slide: HTMLElement,\n direction?: 'left' | 'right',\n): void => {\n if (direction) {\n slide.setAttribute('data-direction', direction);\n } else {\n slide.removeAttribute('data-direction');\n slide.setAttribute('data-active', 'true');\n }\n};\n\nconst cleanupSlideTransition = (slide: HTMLElement, isNew: boolean): void => {\n if (isNew) {\n slide.removeAttribute('data-animating');\n } else {\n slide.removeAttribute('data-active');\n slide.removeAttribute('data-direction');\n slide.removeAttribute('data-content-visible');\n }\n};\n\n// Pure preview functions\nconst createPreviewElement = (\n slide: CarouselWideProps['slides'][0],\n): HTMLElement => {\n const imageCopy = slide.image.cloneNode(true) as HTMLImageElement;\n const preview = assets.image.background({\n element: imageCopy,\n isScaled: true,\n });\n\n preview.element.style.transition = `transform ${PREVIEW_ANIMATION_TIME}ms ease-in-out`;\n return preview.element;\n};\n\nconst clearPreviewContainer = (container: HTMLElement): void => {\n while (container.firstChild) {\n container.removeChild(container.firstChild);\n }\n};\n\nconst appendPreviewWithAnimation = (\n container: HTMLElement,\n preview: HTMLElement,\n animationDirection: 'reverse' | 'advance',\n): void => {\n // Position off-screen initially based on animation direction\n // For advance (forward), new content comes from right\n // For reverse (backward), new content comes from left\n preview.style.transform =\n animationDirection === 'advance' ? 'translateX(100%)' : 'translateX(-100%)';\n\n container.appendChild(preview);\n\n // Trigger animation to slide in\n requestAnimationFrame(() => {\n preview.style.transform = 'translateX(0)';\n });\n};\n\nconst animatePreviewOut = (\n preview: HTMLElement,\n animationDirection: 'reverse' | 'advance',\n): Promise<void> => {\n return new Promise((resolve) => {\n // For advance (forward), old content exits to left\n // For reverse (backward), old content exits to right\n preview.style.transform =\n animationDirection === 'advance'\n ? 'translateX(-100%)'\n : 'translateX(100%)';\n\n setTimeout(() => {\n if (preview.parentNode) {\n preview.parentNode.removeChild(preview);\n }\n resolve();\n }, PREVIEW_ANIMATION_TIME);\n });\n};\n\n// State management\nconst updatePreviews = (\n refs: CarouselRefs,\n state: CarouselState,\n direction?: 'reverse' | 'advance',\n): void => {\n const { currentIndex, slides } = state;\n const { leftIndex, rightIndex } = getAdjacentIndices(\n currentIndex,\n slides.length,\n );\n\n // Handle left preview\n if (slides[leftIndex]) {\n const existingLeft = refs.previews.left.firstElementChild as HTMLElement;\n if (existingLeft && direction) {\n animatePreviewOut(existingLeft, direction);\n } else if (existingLeft) {\n clearPreviewContainer(refs.previews.left);\n }\n\n const leftPreview = createPreviewElement(slides[leftIndex]);\n if (direction) {\n appendPreviewWithAnimation(refs.previews.left, leftPreview, direction);\n } else {\n refs.previews.left.appendChild(leftPreview);\n }\n }\n\n // Handle right preview\n if (slides[rightIndex]) {\n const existingRight = refs.previews.right.firstElementChild as HTMLElement;\n if (existingRight && direction) {\n animatePreviewOut(existingRight, direction);\n } else if (existingRight) {\n clearPreviewContainer(refs.previews.right);\n }\n\n const rightPreview = createPreviewElement(slides[rightIndex]);\n if (direction) {\n appendPreviewWithAnimation(refs.previews.right, rightPreview, direction);\n } else {\n refs.previews.right.appendChild(rightPreview);\n }\n }\n};\n\nconst updateInfo = (refs: CarouselRefs, newIndex: number) => {\n refs.info.textContent = `Slide ${newIndex + 1} Selected`;\n};\n\nconst animateSlides = (\n refs: CarouselRefs,\n state: CarouselState,\n newIndex: number,\n direction: 'reverse' | 'advance',\n) => {\n if (state.isAnimating || state.currentIndex === newIndex) return;\n state.isAnimating = true;\n\n const currentSlide = refs.slides[state.currentIndex];\n const newSlide = refs.slides[newIndex];\n\n // Disable controls during animation\n refs.controls.prev.setAttribute('disabled', '');\n refs.controls.next.setAttribute('disabled', '');\n\n // Position new slide off-screen\n const newSlideDirection = direction === 'reverse' ? 'left' : 'right';\n positionSlideOffScreen(newSlide, newSlideDirection);\n\n // Update indicator position\n refs.indicator.position(newIndex);\n\n // Start synchronized animations for all frames\n requestAnimationFrame(() => {\n // Animate main slides\n activateSlideTransition(newSlide);\n const currentSlideDirection = direction === 'reverse' ? 'right' : 'left';\n activateSlideTransition(currentSlide, currentSlideDirection);\n\n // Update previews with animation (this will animate in sync)\n const nextState = { ...state, currentIndex: newIndex };\n updatePreviews(refs, nextState, direction);\n });\n\n // Clean up after animation\n setTimeout(() => {\n // Clean up main slides\n cleanupSlideTransition(currentSlide, false);\n cleanupSlideTransition(newSlide, true);\n\n // Show content with fade-in animation\n newSlide.setAttribute('data-content-visible', 'true');\n\n // Re-enable controls\n refs.controls.prev.removeAttribute('disabled');\n refs.controls.next.removeAttribute('disabled');\n\n // Update state\n state.currentIndex = newIndex;\n state.isAnimating = false;\n\n // Update accessibility info\n updateInfo(refs, newIndex);\n }, ANIMATION_TIME);\n};\n\nconst setupSliderControls = (refs: CarouselRefs, state: CarouselState) => {\n const lastIndex = state.slides.length - 1;\n\n refs.controls.prev.addEventListener('click', () => {\n if (state.isAnimating) return;\n\n const newIndex =\n state.currentIndex === lastIndex ? 0 : state.currentIndex + 1;\n animateSlides(refs, state, newIndex, 'advance');\n });\n\n refs.controls.next.addEventListener('click', () => {\n if (state.isAnimating) return;\n\n const newIndex =\n state.currentIndex === 0 ? lastIndex : state.currentIndex - 1;\n animateSlides(refs, state, newIndex, 'reverse');\n });\n};\n\n// Main component\nexport default (props: CarouselWideProps) => {\n const { title } = props;\n\n // Initialize state early\n const state: CarouselState = {\n currentIndex: 0,\n isAnimating: false,\n slides: props.slides,\n };\n\n const container = createContainer(props, (index: number) => {\n if (state.isAnimating || state.currentIndex === index) return;\n\n const direction = state.currentIndex > index ? 'reverse' : 'advance';\n animateSlides(refs, state, index, direction);\n });\n\n const composite = ElementModel.createDiv({\n className: 'umd-carousel-wide',\n children: [container],\n attributes: [\n ...(title ? [{ title }] : [{ title: 'Animated Image Carousel' }]),\n ],\n elementStyles: {\n element: {\n container: 'umd-carousel-wide / inline-size',\n display: 'block',\n position: 'relative',\n\n [`@media (${Styles.token.media.queries.large.min})`]: {\n paddingBottom: 0,\n },\n },\n },\n });\n\n // Initialize refs\n const refs: CarouselRefs = {\n container: composite.element,\n ...container.refs,\n };\n\n // Set up event handlers after DOM is ready\n requestAnimationFrame(() => {\n setupSliderControls(refs, state);\n updatePreviews(refs, state); // Initial preview setup without animation\n });\n\n return composite;\n};\n"],"names":["assets.image.background","index","ElementModel.createDiv"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../../../../source/composite/carousel/wide/index.ts"],"sourcesContent":["import * as token from '@universityofmaryland/web-styles-library/token';\nimport { assets } from 'atomic';\nimport { ElementModel } from 'model';\nimport { createContainer } from './container';\nimport { type CarouselWideProps } from '../_types';\n\ninterface CarouselState {\n currentIndex: number;\n isAnimating: boolean;\n slides: CarouselWideProps['slides'];\n}\n\ninterface CarouselRefs {\n container: HTMLElement;\n slidesContainer: HTMLDivElement;\n slides: HTMLElement[];\n previews: {\n left: HTMLElement;\n right: HTMLElement;\n };\n controls: {\n prev: HTMLButtonElement;\n next: HTMLButtonElement;\n };\n indicator: {\n element: HTMLElement;\n position: (index: number) => void;\n };\n info: HTMLParagraphElement;\n}\n\n// Constants\nconst ANIMATION_TIME: 500 = 500;\nconst PREVIEW_ANIMATION_TIME: 440 = 440; // 60ms faster than main animation\n\n// Pure animation functions\nconst getAdjacentIndices = (\n currentIndex: number,\n totalSlides: number,\n): { leftIndex: number; rightIndex: number } => {\n const lastIndex = totalSlides - 1;\n return {\n leftIndex: currentIndex === 0 ? lastIndex : currentIndex - 1,\n rightIndex: currentIndex === lastIndex ? 0 : currentIndex + 1,\n };\n};\n\nconst positionSlideOffScreen = (\n slide: HTMLElement,\n direction: 'left' | 'right',\n): void => {\n slide.setAttribute('data-direction', direction);\n slide.setAttribute('data-animating', 'true');\n slide.offsetHeight; // Force reflow\n};\n\nconst activateSlideTransition = (\n slide: HTMLElement,\n direction?: 'left' | 'right',\n): void => {\n if (direction) {\n slide.setAttribute('data-direction', direction);\n } else {\n slide.removeAttribute('data-direction');\n slide.setAttribute('data-active', 'true');\n }\n};\n\nconst cleanupSlideTransition = (slide: HTMLElement, isNew: boolean): void => {\n if (isNew) {\n slide.removeAttribute('data-animating');\n } else {\n slide.removeAttribute('data-active');\n slide.removeAttribute('data-direction');\n slide.removeAttribute('data-content-visible');\n }\n};\n\n// Pure preview functions\nconst createPreviewElement = (\n slide: CarouselWideProps['slides'][0],\n): HTMLElement => {\n const imageCopy = slide.image.cloneNode(true) as HTMLImageElement;\n const preview = assets.image.background({\n element: imageCopy,\n isScaled: true,\n });\n\n preview.element.style.transition = `transform ${PREVIEW_ANIMATION_TIME}ms ease-in-out`;\n return preview.element;\n};\n\nconst clearPreviewContainer = (container: HTMLElement): void => {\n while (container.firstChild) {\n container.removeChild(container.firstChild);\n }\n};\n\nconst appendPreviewWithAnimation = (\n container: HTMLElement,\n preview: HTMLElement,\n animationDirection: 'reverse' | 'advance',\n): void => {\n // Position off-screen initially based on animation direction\n // For advance (forward), new content comes from right\n // For reverse (backward), new content comes from left\n preview.style.transform =\n animationDirection === 'advance' ? 'translateX(100%)' : 'translateX(-100%)';\n\n container.appendChild(preview);\n\n // Trigger animation to slide in\n requestAnimationFrame(() => {\n preview.style.transform = 'translateX(0)';\n });\n};\n\nconst animatePreviewOut = (\n preview: HTMLElement,\n animationDirection: 'reverse' | 'advance',\n): Promise<void> => {\n return new Promise((resolve) => {\n // For advance (forward), old content exits to left\n // For reverse (backward), old content exits to right\n preview.style.transform =\n animationDirection === 'advance'\n ? 'translateX(-100%)'\n : 'translateX(100%)';\n\n setTimeout(() => {\n if (preview.parentNode) {\n preview.parentNode.removeChild(preview);\n }\n resolve();\n }, PREVIEW_ANIMATION_TIME);\n });\n};\n\n// State management\nconst updatePreviews = (\n refs: CarouselRefs,\n state: CarouselState,\n direction?: 'reverse' | 'advance',\n): void => {\n const { currentIndex, slides } = state;\n const { leftIndex, rightIndex } = getAdjacentIndices(\n currentIndex,\n slides.length,\n );\n\n // Handle left preview\n if (slides[leftIndex]) {\n const existingLeft = refs.previews.left.firstElementChild as HTMLElement;\n if (existingLeft && direction) {\n animatePreviewOut(existingLeft, direction);\n } else if (existingLeft) {\n clearPreviewContainer(refs.previews.left);\n }\n\n const leftPreview = createPreviewElement(slides[leftIndex]);\n if (direction) {\n appendPreviewWithAnimation(refs.previews.left, leftPreview, direction);\n } else {\n refs.previews.left.appendChild(leftPreview);\n }\n }\n\n // Handle right preview\n if (slides[rightIndex]) {\n const existingRight = refs.previews.right.firstElementChild as HTMLElement;\n if (existingRight && direction) {\n animatePreviewOut(existingRight, direction);\n } else if (existingRight) {\n clearPreviewContainer(refs.previews.right);\n }\n\n const rightPreview = createPreviewElement(slides[rightIndex]);\n if (direction) {\n appendPreviewWithAnimation(refs.previews.right, rightPreview, direction);\n } else {\n refs.previews.right.appendChild(rightPreview);\n }\n }\n};\n\nconst updateInfo = (refs: CarouselRefs, newIndex: number) => {\n refs.info.textContent = `Slide ${newIndex + 1} Selected`;\n};\n\nconst animateSlides = (\n refs: CarouselRefs,\n state: CarouselState,\n newIndex: number,\n direction: 'reverse' | 'advance',\n) => {\n if (state.isAnimating || state.currentIndex === newIndex) return;\n state.isAnimating = true;\n\n const currentSlide = refs.slides[state.currentIndex];\n const newSlide = refs.slides[newIndex];\n\n // Disable controls during animation\n refs.controls.prev.setAttribute('disabled', '');\n refs.controls.next.setAttribute('disabled', '');\n\n // Position new slide off-screen\n const newSlideDirection = direction === 'reverse' ? 'left' : 'right';\n positionSlideOffScreen(newSlide, newSlideDirection);\n\n // Update indicator position\n refs.indicator.position(newIndex);\n\n // Start synchronized animations for all frames\n requestAnimationFrame(() => {\n // Animate main slides\n activateSlideTransition(newSlide);\n const currentSlideDirection = direction === 'reverse' ? 'right' : 'left';\n activateSlideTransition(currentSlide, currentSlideDirection);\n\n // Update previews with animation (this will animate in sync)\n const nextState = { ...state, currentIndex: newIndex };\n updatePreviews(refs, nextState, direction);\n });\n\n // Clean up after animation\n setTimeout(() => {\n // Clean up main slides\n cleanupSlideTransition(currentSlide, false);\n cleanupSlideTransition(newSlide, true);\n\n // Show content with fade-in animation\n newSlide.setAttribute('data-content-visible', 'true');\n\n // Re-enable controls\n refs.controls.prev.removeAttribute('disabled');\n refs.controls.next.removeAttribute('disabled');\n\n // Update state\n state.currentIndex = newIndex;\n state.isAnimating = false;\n\n // Update accessibility info\n updateInfo(refs, newIndex);\n }, ANIMATION_TIME);\n};\n\nconst setupSliderControls = (refs: CarouselRefs, state: CarouselState) => {\n const lastIndex = state.slides.length - 1;\n\n refs.controls.prev.addEventListener('click', () => {\n if (state.isAnimating) return;\n\n const newIndex =\n state.currentIndex === lastIndex ? 0 : state.currentIndex + 1;\n animateSlides(refs, state, newIndex, 'advance');\n });\n\n refs.controls.next.addEventListener('click', () => {\n if (state.isAnimating) return;\n\n const newIndex =\n state.currentIndex === 0 ? lastIndex : state.currentIndex - 1;\n animateSlides(refs, state, newIndex, 'reverse');\n });\n};\n\n// Main component\nexport default (props: CarouselWideProps) => {\n const { title } = props;\n\n // Initialize state early\n const state: CarouselState = {\n currentIndex: 0,\n isAnimating: false,\n slides: props.slides,\n };\n\n const container = createContainer(props, (index: number) => {\n if (state.isAnimating || state.currentIndex === index) return;\n\n const direction = state.currentIndex > index ? 'reverse' : 'advance';\n animateSlides(refs, state, index, direction);\n });\n\n const composite = ElementModel.createDiv({\n className: 'umd-carousel-wide',\n children: [container],\n attributes: [\n ...(title ? [{ title }] : [{ title: 'Animated Image Carousel' }]),\n ],\n elementStyles: {\n element: {\n container: 'umd-carousel-wide / inline-size',\n display: 'block',\n position: 'relative',\n\n [`@media (${token.media.queries.large.min})`]: {\n paddingBottom: 0,\n },\n },\n },\n });\n\n // Initialize refs\n const refs: CarouselRefs = {\n container: composite.element,\n ...container.refs,\n };\n\n // Set up event handlers after DOM is ready\n requestAnimationFrame(() => {\n setupSliderControls(refs, state);\n updatePreviews(refs, state); // Initial preview setup without animation\n });\n\n return composite;\n};\n"],"names":["assets.image.background","index","ElementModel.createDiv"],"mappings":"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"}
@@ -1,7 +1,8 @@
1
- export declare const CALL_TO_ACTION_CONTAINER = "umd-footer-call-to-action-container";
2
- export declare const CallToActionStyles: string;
3
- export interface CallToActionProps {
1
+ import { BaseProps } from '../../_types';
2
+ import { ElementVisual } from '../../../../_types';
3
+ export interface CallToActionProps extends BaseProps {
4
4
  slotCta?: HTMLAnchorElement;
5
5
  }
6
- export declare const createCallToAction: ({ slotCta }: CallToActionProps) => HTMLDivElement;
6
+ declare const _default: (props: CallToActionProps) => ElementVisual;
7
+ export default _default;
7
8
  //# sourceMappingURL=call-to-action.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"call-to-action.d.ts","sourceRoot":"","sources":["../../../../../source/composite/footer/elements/main-section/call-to-action.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,wBAAwB,wCAAwC,CAAC;AAE9E,eAAO,MAAM,kBAAkB,QAsB9B,CAAC;AAYF,MAAM,WAAW,iBAAiB;IAChC,OAAO,CAAC,EAAE,iBAAiB,CAAC;CAC7B;AAED,eAAO,MAAM,kBAAkB,GAAI,aAAa,iBAAiB,mBAYhE,CAAC"}
1
+ {"version":3,"file":"call-to-action.d.ts","sourceRoot":"","sources":["../../../../../source/composite/footer/elements/main-section/call-to-action.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAExD,MAAM,WAAW,iBAAkB,SAAQ,SAAS;IAClD,OAAO,CAAC,EAAE,iBAAiB,CAAC;CAC7B;yBA+Be,OAAO,iBAAiB,KAAG,aAAa;AAAxD,wBAwBE"}
@@ -1,30 +1,26 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const Styles = require("@universityofmaryland/web-styles-library");
4
- const CALL_TO_ACTION_CONTAINER = "umd-footer-call-to-action-container";
5
- const CallToActionStyles = `
6
- .${CALL_TO_ACTION_CONTAINER} {
7
- margin-left: auto;
2
+ const token = require("@universityofmaryland/web-styles-library/token");
3
+ const index = require("../../../../model/elements/index.js");
4
+ const globals = require("../../globals.js");
5
+ const actions = require("../../../../model/elements/actions.js");
6
+ function _interopNamespaceDefault(e) {
7
+ const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
8
+ if (e) {
9
+ for (const k in e) {
10
+ if (k !== "default") {
11
+ const d = Object.getOwnPropertyDescriptor(e, k);
12
+ Object.defineProperty(n, k, d.get ? d : {
13
+ enumerable: true,
14
+ get: () => e[k]
15
+ });
16
+ }
17
+ }
8
18
  }
9
-
10
- .${CALL_TO_ACTION_CONTAINER} a {
11
- display: inline-block;
12
- padding: ${Styles.token.spacing.xs} ${Styles.token.spacing["lg"]};
13
- background-color: ${Styles.token.color.red};
14
- color: ${Styles.token.color.white} !important;
15
- transition: background-color 0.3s ease-in-out;
16
- font-weight: 700;
17
- }
18
-
19
- .${CALL_TO_ACTION_CONTAINER} a:hover,
20
- .${CALL_TO_ACTION_CONTAINER} a:focus {
21
- background-color: ${Styles.token.color.redDark};
22
- }
23
-
24
- .${CALL_TO_ACTION_CONTAINER} a * {
25
- color: ${Styles.token.color.white} !important;
26
- }
27
- `;
19
+ n.default = e;
20
+ return Object.freeze(n);
21
+ }
22
+ const token__namespace = /* @__PURE__ */ _interopNamespaceDefault(token);
23
+ const { LARGE } = globals.BREAKPOINTS;
28
24
  const makeGivingLink = () => {
29
25
  const defaultLink = document.createElement("a");
30
26
  defaultLink.textContent = "Support UMD";
@@ -33,17 +29,40 @@ const makeGivingLink = () => {
33
29
  defaultLink.rel = "noopener noreferrer";
34
30
  return defaultLink;
35
31
  };
36
- const createCallToAction = ({ slotCta }) => {
37
- const container = document.createElement("div");
38
- container.classList.add(CALL_TO_ACTION_CONTAINER);
39
- if (slotCta) {
40
- container.appendChild(slotCta);
41
- } else {
42
- container.appendChild(makeGivingLink());
43
- }
44
- return container;
32
+ const createLinkElement = (props, link) => {
33
+ const { isThemeLight } = props;
34
+ return actions.primary({
35
+ element: link,
36
+ elementStyles: {
37
+ element: {
38
+ ...isThemeLight && {
39
+ color: `${token__namespace.color.white} !important`
40
+ }
41
+ }
42
+ }
43
+ });
44
+ };
45
+ const createCallToActionContainer = (props) => {
46
+ const { isTypeSimple, slotCta } = props;
47
+ const baseLink = slotCta ?? makeGivingLink();
48
+ const styledLink = createLinkElement(props, baseLink);
49
+ return index.createDiv({
50
+ className: "umd-footer-call-to-action-container",
51
+ children: [styledLink],
52
+ elementStyles: {
53
+ element: {
54
+ marginLeft: "auto",
55
+ ...isTypeSimple && {
56
+ display: "none"
57
+ },
58
+ [`@container (min-width: ${LARGE}px)`]: {
59
+ [`& .umd-footer-logo-container`]: {
60
+ display: "none"
61
+ }
62
+ }
63
+ }
64
+ }
65
+ });
45
66
  };
46
- exports.CALL_TO_ACTION_CONTAINER = CALL_TO_ACTION_CONTAINER;
47
- exports.CallToActionStyles = CallToActionStyles;
48
- exports.createCallToAction = createCallToAction;
67
+ module.exports = createCallToActionContainer;
49
68
  //# sourceMappingURL=call-to-action.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"call-to-action.js","sources":["../../../../../source/composite/footer/elements/main-section/call-to-action.ts"],"sourcesContent":["import { token } from '@universityofmaryland/web-styles-library';\n\nexport const CALL_TO_ACTION_CONTAINER = 'umd-footer-call-to-action-container';\n\nexport const CallToActionStyles = `\n .${CALL_TO_ACTION_CONTAINER} {\n margin-left: auto;\n }\n\n .${CALL_TO_ACTION_CONTAINER} a {\n display: inline-block;\n padding: ${token.spacing.xs} ${token.spacing['lg']};\n background-color: ${token.color.red};\n color: ${token.color.white} !important;\n transition: background-color 0.3s ease-in-out;\n font-weight: 700;\n }\n\n .${CALL_TO_ACTION_CONTAINER} a:hover,\n .${CALL_TO_ACTION_CONTAINER} a:focus {\n background-color: ${token.color.redDark};\n }\n\n .${CALL_TO_ACTION_CONTAINER} a * {\n color: ${token.color.white} !important;\n }\n`;\n\nconst makeGivingLink = () => {\n const defaultLink = document.createElement('a');\n defaultLink.textContent = 'Support UMD';\n defaultLink.href = 'https://giving.umd.edu/';\n defaultLink.target = '_blank';\n defaultLink.rel = 'noopener noreferrer';\n\n return defaultLink;\n};\n\nexport interface CallToActionProps {\n slotCta?: HTMLAnchorElement;\n}\n\nexport const createCallToAction = ({ slotCta }: CallToActionProps) => {\n const container = document.createElement('div');\n\n container.classList.add(CALL_TO_ACTION_CONTAINER);\n\n if (slotCta) {\n container.appendChild(slotCta);\n } else {\n container.appendChild(makeGivingLink());\n }\n\n return container;\n};\n"],"names":["token"],"mappings":";;;AAEO,MAAM,2BAA2B;AAEjC,MAAM,qBAAqB;AAAA,KAC7B,wBAAwB;AAAA;AAAA;AAAA;AAAA,KAIxB,wBAAwB;AAAA;AAAA,eAEdA,OAAAA,MAAM,QAAQ,EAAE,IAAIA,aAAM,QAAQ,IAAI,CAAC;AAAA,wBAC9BA,OAAAA,MAAM,MAAM,GAAG;AAAA,aAC1BA,OAAAA,MAAM,MAAM,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA,KAKzB,wBAAwB;AAAA,KACxB,wBAAwB;AAAA,wBACLA,OAAAA,MAAM,MAAM,OAAO;AAAA;AAAA;AAAA,KAGtC,wBAAwB;AAAA,aAChBA,OAAAA,MAAM,MAAM,KAAK;AAAA;AAAA;AAI9B,MAAM,iBAAiB,MAAM;AAC3B,QAAM,cAAc,SAAS,cAAc,GAAG;AAC9C,cAAY,cAAc;AAC1B,cAAY,OAAO;AACnB,cAAY,SAAS;AACrB,cAAY,MAAM;AAElB,SAAO;AACT;AAMO,MAAM,qBAAqB,CAAC,EAAE,cAAiC;AACpE,QAAM,YAAY,SAAS,cAAc,KAAK;AAE9C,YAAU,UAAU,IAAI,wBAAwB;AAEhD,MAAI,SAAS;AACX,cAAU,YAAY,OAAO;AAAA,EAC/B,OAAO;AACL,cAAU,YAAY,gBAAgB;AAAA,EACxC;AAEA,SAAO;AACT;;;;"}
1
+ {"version":3,"file":"call-to-action.js","sources":["../../../../../source/composite/footer/elements/main-section/call-to-action.ts"],"sourcesContent":["import * as token from '@universityofmaryland/web-styles-library/token';\nimport { ElementModel } from 'model';\nimport { BREAKPOINTS } from '../../globals';\nimport { BaseProps } from '../../_types';\nimport { type ElementVisual } from '../../../../_types';\n\nexport interface CallToActionProps extends BaseProps {\n slotCta?: HTMLAnchorElement;\n}\n\nconst { LARGE } = BREAKPOINTS;\n\nconst makeGivingLink = (): HTMLAnchorElement => {\n const defaultLink = document.createElement('a');\n defaultLink.textContent = 'Support UMD';\n defaultLink.href = 'https://giving.umd.edu/';\n defaultLink.target = '_blank';\n defaultLink.rel = 'noopener noreferrer';\n return defaultLink;\n};\n\nconst createLinkElement = (\n props: CallToActionProps,\n link: HTMLAnchorElement,\n): ElementVisual => {\n const { isThemeLight } = props;\n\n return ElementModel.actions.primary({\n element: link,\n elementStyles: {\n element: {\n ...(isThemeLight && {\n color: `${token.color.white} !important`,\n }),\n },\n },\n });\n};\n\nexport default (props: CallToActionProps): ElementVisual => {\n const { isTypeSimple, slotCta } = props;\n const baseLink = slotCta ?? makeGivingLink();\n const styledLink = createLinkElement(props, baseLink);\n\n return ElementModel.createDiv({\n className: 'umd-footer-call-to-action-container',\n children: [styledLink],\n elementStyles: {\n element: {\n marginLeft: 'auto',\n\n ...(isTypeSimple && {\n display: 'none',\n }),\n\n [`@container (min-width: ${LARGE}px)`]: {\n [`& .umd-footer-logo-container`]: {\n display: 'none',\n },\n },\n },\n },\n });\n};\n"],"names":["BREAKPOINTS","ElementModel.actions.primary","token","ElementModel.createDiv"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAUA,MAAM,EAAE,UAAUA,QAAAA;AAElB,MAAM,iBAAiB,MAAyB;AAC9C,QAAM,cAAc,SAAS,cAAc,GAAG;AAC9C,cAAY,cAAc;AAC1B,cAAY,OAAO;AACnB,cAAY,SAAS;AACrB,cAAY,MAAM;AAClB,SAAO;AACT;AAEA,MAAM,oBAAoB,CACxB,OACA,SACkB;AAClB,QAAM,EAAE,iBAAiB;AAEzB,SAAOC,gBAA6B;AAAA,IAClC,SAAS;AAAA,IACT,eAAe;AAAA,MACb,SAAS;AAAA,QACP,GAAI,gBAAgB;AAAA,UAClB,OAAO,GAAGC,iBAAM,MAAM,KAAK;AAAA,QAAA;AAAA,MAC7B;AAAA,IACF;AAAA,EACF,CACD;AACH;AAEA,MAAA,8BAAe,CAAC,UAA4C;AAC1D,QAAM,EAAE,cAAc,QAAA,IAAY;AAClC,QAAM,WAAW,WAAW,eAAA;AAC5B,QAAM,aAAa,kBAAkB,OAAO,QAAQ;AAEpD,SAAOC,gBAAuB;AAAA,IAC5B,WAAW;AAAA,IACX,UAAU,CAAC,UAAU;AAAA,IACrB,eAAe;AAAA,MACb,SAAS;AAAA,QACP,YAAY;AAAA,QAEZ,GAAI,gBAAgB;AAAA,UAClB,SAAS;AAAA,QAAA;AAAA,QAGX,CAAC,0BAA0B,KAAK,KAAK,GAAG;AAAA,UACtC,CAAC,8BAA8B,GAAG;AAAA,YAChC,SAAS;AAAA,UAAA;AAAA,QACX;AAAA,MACF;AAAA,IACF;AAAA,EACF,CACD;AACH;;"}
@@ -1,28 +1,8 @@
1
- import { token } from "@universityofmaryland/web-styles-library";
2
- const CALL_TO_ACTION_CONTAINER = "umd-footer-call-to-action-container";
3
- const CallToActionStyles = `
4
- .${CALL_TO_ACTION_CONTAINER} {
5
- margin-left: auto;
6
- }
7
-
8
- .${CALL_TO_ACTION_CONTAINER} a {
9
- display: inline-block;
10
- padding: ${token.spacing.xs} ${token.spacing["lg"]};
11
- background-color: ${token.color.red};
12
- color: ${token.color.white} !important;
13
- transition: background-color 0.3s ease-in-out;
14
- font-weight: 700;
15
- }
16
-
17
- .${CALL_TO_ACTION_CONTAINER} a:hover,
18
- .${CALL_TO_ACTION_CONTAINER} a:focus {
19
- background-color: ${token.color.redDark};
20
- }
21
-
22
- .${CALL_TO_ACTION_CONTAINER} a * {
23
- color: ${token.color.white} !important;
24
- }
25
- `;
1
+ import * as token from "@universityofmaryland/web-styles-library/token";
2
+ import { createDiv } from "../../../../model/elements/index.mjs";
3
+ import { BREAKPOINTS } from "../../globals.mjs";
4
+ import { primary } from "../../../../model/elements/actions.mjs";
5
+ const { LARGE } = BREAKPOINTS;
26
6
  const makeGivingLink = () => {
27
7
  const defaultLink = document.createElement("a");
28
8
  defaultLink.textContent = "Support UMD";
@@ -31,19 +11,42 @@ const makeGivingLink = () => {
31
11
  defaultLink.rel = "noopener noreferrer";
32
12
  return defaultLink;
33
13
  };
34
- const createCallToAction = ({ slotCta }) => {
35
- const container = document.createElement("div");
36
- container.classList.add(CALL_TO_ACTION_CONTAINER);
37
- if (slotCta) {
38
- container.appendChild(slotCta);
39
- } else {
40
- container.appendChild(makeGivingLink());
41
- }
42
- return container;
14
+ const createLinkElement = (props, link) => {
15
+ const { isThemeLight } = props;
16
+ return primary({
17
+ element: link,
18
+ elementStyles: {
19
+ element: {
20
+ ...isThemeLight && {
21
+ color: `${token.color.white} !important`
22
+ }
23
+ }
24
+ }
25
+ });
26
+ };
27
+ const createCallToActionContainer = (props) => {
28
+ const { isTypeSimple, slotCta } = props;
29
+ const baseLink = slotCta ?? makeGivingLink();
30
+ const styledLink = createLinkElement(props, baseLink);
31
+ return createDiv({
32
+ className: "umd-footer-call-to-action-container",
33
+ children: [styledLink],
34
+ elementStyles: {
35
+ element: {
36
+ marginLeft: "auto",
37
+ ...isTypeSimple && {
38
+ display: "none"
39
+ },
40
+ [`@container (min-width: ${LARGE}px)`]: {
41
+ [`& .umd-footer-logo-container`]: {
42
+ display: "none"
43
+ }
44
+ }
45
+ }
46
+ }
47
+ });
43
48
  };
44
49
  export {
45
- CALL_TO_ACTION_CONTAINER,
46
- CallToActionStyles,
47
- createCallToAction
50
+ createCallToActionContainer as default
48
51
  };
49
52
  //# sourceMappingURL=call-to-action.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"call-to-action.mjs","sources":["../../../../../source/composite/footer/elements/main-section/call-to-action.ts"],"sourcesContent":["import { token } from '@universityofmaryland/web-styles-library';\n\nexport const CALL_TO_ACTION_CONTAINER = 'umd-footer-call-to-action-container';\n\nexport const CallToActionStyles = `\n .${CALL_TO_ACTION_CONTAINER} {\n margin-left: auto;\n }\n\n .${CALL_TO_ACTION_CONTAINER} a {\n display: inline-block;\n padding: ${token.spacing.xs} ${token.spacing['lg']};\n background-color: ${token.color.red};\n color: ${token.color.white} !important;\n transition: background-color 0.3s ease-in-out;\n font-weight: 700;\n }\n\n .${CALL_TO_ACTION_CONTAINER} a:hover,\n .${CALL_TO_ACTION_CONTAINER} a:focus {\n background-color: ${token.color.redDark};\n }\n\n .${CALL_TO_ACTION_CONTAINER} a * {\n color: ${token.color.white} !important;\n }\n`;\n\nconst makeGivingLink = () => {\n const defaultLink = document.createElement('a');\n defaultLink.textContent = 'Support UMD';\n defaultLink.href = 'https://giving.umd.edu/';\n defaultLink.target = '_blank';\n defaultLink.rel = 'noopener noreferrer';\n\n return defaultLink;\n};\n\nexport interface CallToActionProps {\n slotCta?: HTMLAnchorElement;\n}\n\nexport const createCallToAction = ({ slotCta }: CallToActionProps) => {\n const container = document.createElement('div');\n\n container.classList.add(CALL_TO_ACTION_CONTAINER);\n\n if (slotCta) {\n container.appendChild(slotCta);\n } else {\n container.appendChild(makeGivingLink());\n }\n\n return container;\n};\n"],"names":[],"mappings":";AAEO,MAAM,2BAA2B;AAEjC,MAAM,qBAAqB;AAAA,KAC7B,wBAAwB;AAAA;AAAA;AAAA;AAAA,KAIxB,wBAAwB;AAAA;AAAA,eAEd,MAAM,QAAQ,EAAE,IAAI,MAAM,QAAQ,IAAI,CAAC;AAAA,wBAC9B,MAAM,MAAM,GAAG;AAAA,aAC1B,MAAM,MAAM,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA,KAKzB,wBAAwB;AAAA,KACxB,wBAAwB;AAAA,wBACL,MAAM,MAAM,OAAO;AAAA;AAAA;AAAA,KAGtC,wBAAwB;AAAA,aAChB,MAAM,MAAM,KAAK;AAAA;AAAA;AAI9B,MAAM,iBAAiB,MAAM;AAC3B,QAAM,cAAc,SAAS,cAAc,GAAG;AAC9C,cAAY,cAAc;AAC1B,cAAY,OAAO;AACnB,cAAY,SAAS;AACrB,cAAY,MAAM;AAElB,SAAO;AACT;AAMO,MAAM,qBAAqB,CAAC,EAAE,cAAiC;AACpE,QAAM,YAAY,SAAS,cAAc,KAAK;AAE9C,YAAU,UAAU,IAAI,wBAAwB;AAEhD,MAAI,SAAS;AACX,cAAU,YAAY,OAAO;AAAA,EAC/B,OAAO;AACL,cAAU,YAAY,gBAAgB;AAAA,EACxC;AAEA,SAAO;AACT;"}
1
+ {"version":3,"file":"call-to-action.mjs","sources":["../../../../../source/composite/footer/elements/main-section/call-to-action.ts"],"sourcesContent":["import * as token from '@universityofmaryland/web-styles-library/token';\nimport { ElementModel } from 'model';\nimport { BREAKPOINTS } from '../../globals';\nimport { BaseProps } from '../../_types';\nimport { type ElementVisual } from '../../../../_types';\n\nexport interface CallToActionProps extends BaseProps {\n slotCta?: HTMLAnchorElement;\n}\n\nconst { LARGE } = BREAKPOINTS;\n\nconst makeGivingLink = (): HTMLAnchorElement => {\n const defaultLink = document.createElement('a');\n defaultLink.textContent = 'Support UMD';\n defaultLink.href = 'https://giving.umd.edu/';\n defaultLink.target = '_blank';\n defaultLink.rel = 'noopener noreferrer';\n return defaultLink;\n};\n\nconst createLinkElement = (\n props: CallToActionProps,\n link: HTMLAnchorElement,\n): ElementVisual => {\n const { isThemeLight } = props;\n\n return ElementModel.actions.primary({\n element: link,\n elementStyles: {\n element: {\n ...(isThemeLight && {\n color: `${token.color.white} !important`,\n }),\n },\n },\n });\n};\n\nexport default (props: CallToActionProps): ElementVisual => {\n const { isTypeSimple, slotCta } = props;\n const baseLink = slotCta ?? makeGivingLink();\n const styledLink = createLinkElement(props, baseLink);\n\n return ElementModel.createDiv({\n className: 'umd-footer-call-to-action-container',\n children: [styledLink],\n elementStyles: {\n element: {\n marginLeft: 'auto',\n\n ...(isTypeSimple && {\n display: 'none',\n }),\n\n [`@container (min-width: ${LARGE}px)`]: {\n [`& .umd-footer-logo-container`]: {\n display: 'none',\n },\n },\n },\n },\n });\n};\n"],"names":["ElementModel.actions.primary","ElementModel.createDiv"],"mappings":";;;;AAUA,MAAM,EAAE,UAAU;AAElB,MAAM,iBAAiB,MAAyB;AAC9C,QAAM,cAAc,SAAS,cAAc,GAAG;AAC9C,cAAY,cAAc;AAC1B,cAAY,OAAO;AACnB,cAAY,SAAS;AACrB,cAAY,MAAM;AAClB,SAAO;AACT;AAEA,MAAM,oBAAoB,CACxB,OACA,SACkB;AAClB,QAAM,EAAE,iBAAiB;AAEzB,SAAOA,QAA6B;AAAA,IAClC,SAAS;AAAA,IACT,eAAe;AAAA,MACb,SAAS;AAAA,QACP,GAAI,gBAAgB;AAAA,UAClB,OAAO,GAAG,MAAM,MAAM,KAAK;AAAA,QAAA;AAAA,MAC7B;AAAA,IACF;AAAA,EACF,CACD;AACH;AAEA,MAAA,8BAAe,CAAC,UAA4C;AAC1D,QAAM,EAAE,cAAc,QAAA,IAAY;AAClC,QAAM,WAAW,WAAW,eAAA;AAC5B,QAAM,aAAa,kBAAkB,OAAO,QAAQ;AAEpD,SAAOC,UAAuB;AAAA,IAC5B,WAAW;AAAA,IACX,UAAU,CAAC,UAAU;AAAA,IACrB,eAAe;AAAA,MACb,SAAS;AAAA,QACP,YAAY;AAAA,QAEZ,GAAI,gBAAgB;AAAA,UAClB,SAAS;AAAA,QAAA;AAAA,QAGX,CAAC,0BAA0B,KAAK,KAAK,GAAG;AAAA,UACtC,CAAC,8BAA8B,GAAG;AAAA,YAChC,SAAS;AAAA,UAAA;AAAA,QACX;AAAA,MACF;AAAA,IACF;AAAA,EACF,CACD;AACH;"}
@@ -1,7 +1,7 @@
1
1
  import { BaseProps } from '../../_types';
2
- export declare const CAMPAIGN_COLUMN_WRAPPER = "campaign-column-wrapper";
3
- export declare const CampaignStyles: string;
2
+ import { ElementVisual } from '../../../../_types';
4
3
  export interface CampaignProps extends BaseProps {
5
4
  }
6
- export declare const createCampaign: ({ isThemeLight }: CampaignProps) => HTMLDivElement;
5
+ declare const _default: ({ isThemeLight }: CampaignProps) => ElementVisual;
6
+ export default _default;
7
7
  //# sourceMappingURL=campaign.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"campaign.d.ts","sourceRoot":"","sources":["../../../../../source/composite/footer/elements/main-section/campaign.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,eAAO,MAAM,uBAAuB,4BAA4B,CAAC;AAEjE,eAAO,MAAM,cAAc,QAM1B,CAAC;AAEF,MAAM,WAAW,aAAc,SAAQ,SAAS;CAAG;AAEnD,eAAO,MAAM,cAAc,GAAI,kBAAkB,aAAa,mBAmB7D,CAAC"}
1
+ {"version":3,"file":"campaign.d.ts","sourceRoot":"","sources":["../../../../../source/composite/footer/elements/main-section/campaign.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAExD,MAAM,WAAW,aAAc,SAAQ,SAAS;CAAG;yBAInC,kBAAkB,aAAa,KAAG,aAAa;AAA/D,wBA+CE"}