@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.
- package/README.md +1 -1
- package/dist/atomic/actions/icon.d.ts.map +1 -1
- package/dist/atomic/actions/icon.js +21 -22
- package/dist/atomic/actions/icon.js.map +1 -1
- package/dist/atomic/actions/icon.mjs +20 -21
- package/dist/atomic/actions/icon.mjs.map +1 -1
- package/dist/atomic/actions/text.d.ts.map +1 -1
- package/dist/atomic/actions/text.js +22 -19
- package/dist/atomic/actions/text.js.map +1 -1
- package/dist/atomic/actions/text.mjs +21 -19
- package/dist/atomic/actions/text.mjs.map +1 -1
- package/dist/atomic/animations/actions/indicator.d.ts.map +1 -1
- package/dist/atomic/animations/actions/indicator.js +32 -21
- package/dist/atomic/animations/actions/indicator.js.map +1 -1
- package/dist/atomic/animations/actions/indicator.mjs +3 -9
- package/dist/atomic/animations/actions/indicator.mjs.map +1 -1
- package/dist/atomic/animations/brand/card-stack.d.ts.map +1 -1
- package/dist/atomic/animations/brand/card-stack.js +42 -32
- package/dist/atomic/animations/brand/card-stack.js.map +1 -1
- package/dist/atomic/animations/brand/card-stack.mjs +21 -11
- package/dist/atomic/animations/brand/card-stack.mjs.map +1 -1
- package/dist/atomic/animations/brand/chevron-scroll.js +25 -8
- package/dist/atomic/animations/brand/chevron-scroll.js.map +1 -1
- package/dist/atomic/animations/brand/chevron-scroll.mjs +1 -1
- package/dist/atomic/animations/brand/chevron-scroll.mjs.map +1 -1
- package/dist/atomic/assets/image/gif.d.ts.map +1 -1
- package/dist/atomic/assets/image/gif.js +5 -8
- package/dist/atomic/assets/image/gif.js.map +1 -1
- package/dist/atomic/assets/image/gif.mjs +4 -7
- package/dist/atomic/assets/image/gif.mjs.map +1 -1
- package/dist/atomic/assets/video/observed-auto-play.js +2 -5
- package/dist/atomic/assets/video/observed-auto-play.js.map +1 -1
- package/dist/atomic/assets/video/observed-auto-play.mjs +2 -5
- package/dist/atomic/assets/video/observed-auto-play.mjs.map +1 -1
- package/dist/atomic/assets/video/toggle.d.ts.map +1 -1
- package/dist/atomic/assets/video/toggle.js +4 -7
- package/dist/atomic/assets/video/toggle.js.map +1 -1
- package/dist/atomic/assets/video/toggle.mjs +4 -7
- package/dist/atomic/assets/video/toggle.mjs.map +1 -1
- package/dist/atomic/buttons/fullscreen.js +2 -5
- package/dist/atomic/buttons/fullscreen.js.map +1 -1
- package/dist/atomic/buttons/fullscreen.mjs +2 -5
- package/dist/atomic/buttons/fullscreen.mjs.map +1 -1
- package/dist/atomic/events/meta.d.ts.map +1 -1
- package/dist/atomic/events/meta.js +8 -10
- package/dist/atomic/events/meta.js.map +1 -1
- package/dist/atomic/events/meta.mjs +5 -7
- package/dist/atomic/events/meta.mjs.map +1 -1
- package/dist/atomic/events/sign.js +19 -2
- package/dist/atomic/events/sign.js.map +1 -1
- package/dist/atomic/events/sign.mjs +2 -2
- package/dist/atomic/events/sign.mjs.map +1 -1
- package/dist/atomic/layout/block/stacked.d.ts.map +1 -1
- package/dist/atomic/layout/block/stacked.js +37 -55
- package/dist/atomic/layout/block/stacked.js.map +1 -1
- package/dist/atomic/layout/block/stacked.mjs +36 -54
- package/dist/atomic/layout/block/stacked.mjs.map +1 -1
- package/dist/atomic/layout/overlay/modal.d.ts.map +1 -1
- package/dist/atomic/layout/overlay/modal.js +22 -8
- package/dist/atomic/layout/overlay/modal.js.map +1 -1
- package/dist/atomic/layout/overlay/modal.mjs +3 -6
- package/dist/atomic/layout/overlay/modal.mjs.map +1 -1
- package/dist/atomic/layout/person/columns.d.ts.map +1 -1
- package/dist/atomic/layout/person/columns.js +36 -34
- package/dist/atomic/layout/person/columns.js.map +1 -1
- package/dist/atomic/layout/person/columns.mjs +35 -33
- package/dist/atomic/layout/person/columns.mjs.map +1 -1
- package/dist/atomic/text/stat.d.ts.map +1 -1
- package/dist/atomic/text/stat.js +47 -29
- package/dist/atomic/text/stat.js.map +1 -1
- package/dist/atomic/text/stat.mjs +30 -29
- package/dist/atomic/text/stat.mjs.map +1 -1
- package/dist/atomic/text-lockup/contact.d.ts.map +1 -1
- package/dist/atomic/text-lockup/contact.js +13 -15
- package/dist/atomic/text-lockup/contact.js.map +1 -1
- package/dist/atomic/text-lockup/contact.mjs +18 -20
- package/dist/atomic/text-lockup/contact.mjs.map +1 -1
- package/dist/atomic/text-lockup/date.d.ts.map +1 -1
- package/dist/atomic/text-lockup/date.js +24 -20
- package/dist/atomic/text-lockup/date.js.map +1 -1
- package/dist/atomic/text-lockup/date.mjs +11 -9
- package/dist/atomic/text-lockup/date.mjs.map +1 -1
- package/dist/atomic/text-lockup/large.js +7 -7
- package/dist/atomic/text-lockup/large.js.map +1 -1
- package/dist/atomic/text-lockup/large.mjs +6 -6
- package/dist/atomic/text-lockup/large.mjs.map +1 -1
- package/dist/atomic/text-lockup/medium.js +9 -9
- package/dist/atomic/text-lockup/medium.js.map +1 -1
- package/dist/atomic/text-lockup/medium.mjs +8 -8
- package/dist/atomic/text-lockup/medium.mjs.map +1 -1
- package/dist/atomic/text-lockup/person.js +5 -5
- package/dist/atomic/text-lockup/person.js.map +1 -1
- package/dist/atomic/text-lockup/person.mjs +4 -4
- package/dist/atomic/text-lockup/person.mjs.map +1 -1
- package/dist/atomic/text-lockup/small.d.ts.map +1 -1
- package/dist/atomic/text-lockup/small.js +15 -14
- package/dist/atomic/text-lockup/small.js.map +1 -1
- package/dist/atomic/text-lockup/small.mjs +3 -3
- package/dist/atomic/text-lockup/small.mjs.map +1 -1
- package/dist/composite/accordion/item.d.ts.map +1 -1
- package/dist/composite/accordion/item.js +5 -5
- package/dist/composite/accordion/item.js.map +1 -1
- package/dist/composite/accordion/item.mjs +4 -4
- package/dist/composite/accordion/item.mjs.map +1 -1
- package/dist/composite/alert/elements/text.d.ts.map +1 -1
- package/dist/composite/alert/elements/text.js +34 -14
- package/dist/composite/alert/elements/text.js.map +1 -1
- package/dist/composite/alert/elements/text.mjs +5 -3
- package/dist/composite/alert/elements/text.mjs.map +1 -1
- package/dist/composite/alert/page.d.ts.map +1 -1
- package/dist/composite/alert/page.js +37 -22
- package/dist/composite/alert/page.js.map +1 -1
- package/dist/composite/alert/page.mjs +6 -8
- package/dist/composite/alert/page.mjs.map +1 -1
- package/dist/composite/alert/site.d.ts.map +1 -1
- package/dist/composite/alert/site.js +46 -27
- package/dist/composite/alert/site.js.map +1 -1
- package/dist/composite/alert/site.mjs +10 -9
- package/dist/composite/alert/site.mjs.map +1 -1
- package/dist/composite/banner/promo.d.ts.map +1 -1
- package/dist/composite/banner/promo.js +12 -10
- package/dist/composite/banner/promo.js.map +1 -1
- package/dist/composite/banner/promo.mjs +12 -10
- package/dist/composite/banner/promo.mjs.map +1 -1
- package/dist/composite/card/block.js +21 -9
- package/dist/composite/card/block.js.map +1 -1
- package/dist/composite/card/block.mjs +20 -8
- package/dist/composite/card/block.mjs.map +1 -1
- package/dist/composite/card/list.d.ts.map +1 -1
- package/dist/composite/card/list.js +47 -48
- package/dist/composite/card/list.js.map +1 -1
- package/dist/composite/card/list.mjs +46 -47
- package/dist/composite/card/list.mjs.map +1 -1
- package/dist/composite/card/overlay/color.d.ts.map +1 -1
- package/dist/composite/card/overlay/color.js +24 -12
- package/dist/composite/card/overlay/color.js.map +1 -1
- package/dist/composite/card/overlay/color.mjs +22 -11
- package/dist/composite/card/overlay/color.mjs.map +1 -1
- package/dist/composite/card/overlay/icon.js +21 -10
- package/dist/composite/card/overlay/icon.js.map +1 -1
- package/dist/composite/card/overlay/icon.mjs +20 -9
- package/dist/composite/card/overlay/icon.mjs.map +1 -1
- package/dist/composite/card/overlay/image.d.ts.map +1 -1
- package/dist/composite/card/overlay/image.js +29 -20
- package/dist/composite/card/overlay/image.js.map +1 -1
- package/dist/composite/card/overlay/image.mjs +27 -18
- package/dist/composite/card/overlay/image.mjs.map +1 -1
- package/dist/composite/card/video/block.js +15 -4
- package/dist/composite/card/video/block.js.map +1 -1
- package/dist/composite/card/video/block.mjs +15 -4
- package/dist/composite/card/video/block.mjs.map +1 -1
- package/dist/composite/carousel/cards/index.js +6 -6
- package/dist/composite/carousel/cards/index.js.map +1 -1
- package/dist/composite/carousel/cards/index.mjs +6 -6
- package/dist/composite/carousel/cards/index.mjs.map +1 -1
- package/dist/composite/carousel/default/index.js +24 -7
- package/dist/composite/carousel/default/index.js.map +1 -1
- package/dist/composite/carousel/default/index.mjs +1 -1
- package/dist/composite/carousel/default/index.mjs.map +1 -1
- package/dist/composite/carousel/elements/blocks.d.ts.map +1 -1
- package/dist/composite/carousel/elements/blocks.js +20 -22
- package/dist/composite/carousel/elements/blocks.js.map +1 -1
- package/dist/composite/carousel/elements/blocks.mjs +11 -14
- package/dist/composite/carousel/elements/blocks.mjs.map +1 -1
- package/dist/composite/carousel/elements/full-screen.js +36 -8
- package/dist/composite/carousel/elements/full-screen.js.map +1 -1
- package/dist/composite/carousel/elements/full-screen.mjs +17 -6
- package/dist/composite/carousel/elements/full-screen.mjs.map +1 -1
- package/dist/composite/carousel/elements/image.d.ts.map +1 -1
- package/dist/composite/carousel/elements/image.js +32 -21
- package/dist/composite/carousel/elements/image.js.map +1 -1
- package/dist/composite/carousel/elements/image.mjs +8 -14
- package/dist/composite/carousel/elements/image.mjs.map +1 -1
- package/dist/composite/carousel/elements/overlay.js +19 -2
- package/dist/composite/carousel/elements/overlay.js.map +1 -1
- package/dist/composite/carousel/elements/overlay.mjs +1 -1
- package/dist/composite/carousel/elements/overlay.mjs.map +1 -1
- package/dist/composite/carousel/image/multiple.d.ts.map +1 -1
- package/dist/composite/carousel/image/multiple.js +24 -12
- package/dist/composite/carousel/image/multiple.js.map +1 -1
- package/dist/composite/carousel/image/multiple.mjs +17 -6
- package/dist/composite/carousel/image/multiple.mjs.map +1 -1
- package/dist/composite/carousel/image/standard.d.ts.map +1 -1
- package/dist/composite/carousel/image/standard.js +44 -47
- package/dist/composite/carousel/image/standard.js.map +1 -1
- package/dist/composite/carousel/image/standard.mjs +19 -5
- package/dist/composite/carousel/image/standard.mjs.map +1 -1
- package/dist/composite/carousel/thumbnail/index.js +29 -12
- package/dist/composite/carousel/thumbnail/index.js.map +1 -1
- package/dist/composite/carousel/thumbnail/index.mjs +1 -1
- package/dist/composite/carousel/thumbnail/index.mjs.map +1 -1
- package/dist/composite/carousel/wide/controls.d.ts.map +1 -1
- package/dist/composite/carousel/wide/controls.js +40 -30
- package/dist/composite/carousel/wide/controls.js.map +1 -1
- package/dist/composite/carousel/wide/controls.mjs +39 -29
- package/dist/composite/carousel/wide/controls.mjs.map +1 -1
- package/dist/composite/carousel/wide/frames.js +44 -33
- package/dist/composite/carousel/wide/frames.js.map +1 -1
- package/dist/composite/carousel/wide/frames.mjs +43 -32
- package/dist/composite/carousel/wide/frames.mjs.map +1 -1
- package/dist/composite/carousel/wide/index.d.ts.map +1 -1
- package/dist/composite/carousel/wide/index.js +17 -6
- package/dist/composite/carousel/wide/index.js.map +1 -1
- package/dist/composite/carousel/wide/index.mjs +16 -5
- package/dist/composite/carousel/wide/index.mjs.map +1 -1
- package/dist/composite/footer/elements/main-section/call-to-action.d.ts +5 -4
- package/dist/composite/footer/elements/main-section/call-to-action.d.ts.map +1 -1
- package/dist/composite/footer/elements/main-section/call-to-action.js +56 -37
- package/dist/composite/footer/elements/main-section/call-to-action.js.map +1 -1
- package/dist/composite/footer/elements/main-section/call-to-action.mjs +40 -37
- package/dist/composite/footer/elements/main-section/call-to-action.mjs.map +1 -1
- package/dist/composite/footer/elements/main-section/campaign.d.ts +3 -3
- package/dist/composite/footer/elements/main-section/campaign.d.ts.map +1 -1
- package/dist/composite/footer/elements/main-section/campaign.js +57 -22
- package/dist/composite/footer/elements/main-section/campaign.js.map +1 -1
- package/dist/composite/footer/elements/main-section/campaign.mjs +40 -22
- package/dist/composite/footer/elements/main-section/campaign.mjs.map +1 -1
- package/dist/composite/footer/elements/main-section/index.d.ts +3 -2
- package/dist/composite/footer/elements/main-section/index.d.ts.map +1 -1
- package/dist/composite/footer/elements/main-section/index.js +81 -94
- package/dist/composite/footer/elements/main-section/index.js.map +1 -1
- package/dist/composite/footer/elements/main-section/index.mjs +82 -95
- package/dist/composite/footer/elements/main-section/index.mjs.map +1 -1
- package/dist/composite/footer/elements/main-section/row-links/index.d.ts +5 -5
- package/dist/composite/footer/elements/main-section/row-links/index.d.ts.map +1 -1
- package/dist/composite/footer/elements/main-section/row-links/index.js +44 -72
- package/dist/composite/footer/elements/main-section/row-links/index.js.map +1 -1
- package/dist/composite/footer/elements/main-section/row-links/index.mjs +48 -75
- package/dist/composite/footer/elements/main-section/row-links/index.mjs.map +1 -1
- package/dist/composite/footer/elements/main-section/row-links/link-columns.d.ts +5 -3
- package/dist/composite/footer/elements/main-section/row-links/link-columns.d.ts.map +1 -1
- package/dist/composite/footer/elements/main-section/row-links/link-columns.js +178 -223
- package/dist/composite/footer/elements/main-section/row-links/link-columns.js.map +1 -1
- package/dist/composite/footer/elements/main-section/row-links/link-columns.mjs +180 -224
- package/dist/composite/footer/elements/main-section/row-links/link-columns.mjs.map +1 -1
- package/dist/composite/footer/elements/main-section/row-logo/contact.d.ts +5 -4
- package/dist/composite/footer/elements/main-section/row-logo/contact.d.ts.map +1 -1
- package/dist/composite/footer/elements/main-section/row-logo/contact.js +165 -199
- package/dist/composite/footer/elements/main-section/row-logo/contact.js.map +1 -1
- package/dist/composite/footer/elements/main-section/row-logo/contact.mjs +166 -199
- package/dist/composite/footer/elements/main-section/row-logo/contact.mjs.map +1 -1
- package/dist/composite/footer/elements/main-section/row-logo/index.d.ts +6 -3
- package/dist/composite/footer/elements/main-section/row-logo/index.d.ts.map +1 -1
- package/dist/composite/footer/elements/main-section/row-logo/index.js +54 -95
- package/dist/composite/footer/elements/main-section/row-logo/index.js.map +1 -1
- package/dist/composite/footer/elements/main-section/row-logo/index.mjs +59 -99
- package/dist/composite/footer/elements/main-section/row-logo/index.mjs.map +1 -1
- package/dist/composite/footer/elements/main-section/row-logo/logo.d.ts +4 -2
- package/dist/composite/footer/elements/main-section/row-logo/logo.d.ts.map +1 -1
- package/dist/composite/footer/elements/main-section/row-logo/logo.js +78 -71
- package/dist/composite/footer/elements/main-section/row-logo/logo.js.map +1 -1
- package/dist/composite/footer/elements/main-section/row-logo/logo.mjs +64 -74
- package/dist/composite/footer/elements/main-section/row-logo/logo.mjs.map +1 -1
- package/dist/composite/footer/elements/main-section/social.d.ts +5 -6
- package/dist/composite/footer/elements/main-section/social.d.ts.map +1 -1
- package/dist/composite/footer/elements/main-section/social.js +128 -202
- package/dist/composite/footer/elements/main-section/social.js.map +1 -1
- package/dist/composite/footer/elements/main-section/social.mjs +130 -203
- package/dist/composite/footer/elements/main-section/social.mjs.map +1 -1
- package/dist/composite/footer/elements/utility-section/index.d.ts +4 -2
- package/dist/composite/footer/elements/utility-section/index.d.ts.map +1 -1
- package/dist/composite/footer/elements/utility-section/index.js +107 -116
- package/dist/composite/footer/elements/utility-section/index.js.map +1 -1
- package/dist/composite/footer/elements/utility-section/index.mjs +109 -117
- package/dist/composite/footer/elements/utility-section/index.mjs.map +1 -1
- package/dist/composite/footer/globals.d.ts +0 -32
- package/dist/composite/footer/globals.d.ts.map +1 -1
- package/dist/composite/footer/globals.js +0 -19
- package/dist/composite/footer/globals.js.map +1 -1
- package/dist/composite/footer/globals.mjs +1 -20
- package/dist/composite/footer/globals.mjs.map +1 -1
- package/dist/composite/footer/options.d.ts +1 -1
- package/dist/composite/footer/options.d.ts.map +1 -1
- package/dist/composite/footer/options.js +52 -30
- package/dist/composite/footer/options.js.map +1 -1
- package/dist/composite/footer/options.mjs +37 -33
- package/dist/composite/footer/options.mjs.map +1 -1
- package/dist/composite/hero/custom/expand.d.ts.map +1 -1
- package/dist/composite/hero/custom/expand.js +36 -25
- package/dist/composite/hero/custom/expand.js.map +1 -1
- package/dist/composite/hero/custom/expand.mjs +30 -19
- package/dist/composite/hero/custom/expand.mjs.map +1 -1
- package/dist/composite/hero/custom/grid.d.ts.map +1 -1
- package/dist/composite/hero/custom/grid.js +48 -38
- package/dist/composite/hero/custom/grid.js.map +1 -1
- package/dist/composite/hero/custom/grid.mjs +35 -25
- package/dist/composite/hero/custom/grid.mjs.map +1 -1
- package/dist/composite/hero/custom/video-arrow.d.ts.map +1 -1
- package/dist/composite/hero/custom/video-arrow.js +23 -15
- package/dist/composite/hero/custom/video-arrow.js.map +1 -1
- package/dist/composite/hero/custom/video-arrow.mjs +20 -14
- package/dist/composite/hero/custom/video-arrow.mjs.map +1 -1
- package/dist/composite/hero/logo.d.ts.map +1 -1
- package/dist/composite/hero/logo.js +28 -16
- package/dist/composite/hero/logo.js.map +1 -1
- package/dist/composite/hero/logo.mjs +26 -15
- package/dist/composite/hero/logo.mjs.map +1 -1
- package/dist/composite/hero/minimal.d.ts.map +1 -1
- package/dist/composite/hero/minimal.js +33 -22
- package/dist/composite/hero/minimal.js.map +1 -1
- package/dist/composite/hero/minimal.mjs +32 -21
- package/dist/composite/hero/minimal.mjs.map +1 -1
- package/dist/composite/hero/overlay.d.ts.map +1 -1
- package/dist/composite/hero/overlay.js +32 -21
- package/dist/composite/hero/overlay.js.map +1 -1
- package/dist/composite/hero/overlay.mjs +30 -20
- package/dist/composite/hero/overlay.mjs.map +1 -1
- package/dist/composite/hero/stacked.d.ts.map +1 -1
- package/dist/composite/hero/stacked.js +45 -34
- package/dist/composite/hero/stacked.js.map +1 -1
- package/dist/composite/hero/stacked.mjs +40 -30
- package/dist/composite/hero/stacked.mjs.map +1 -1
- package/dist/composite/hero/standard.d.ts.map +1 -1
- package/dist/composite/hero/standard.js +38 -27
- package/dist/composite/hero/standard.js.map +1 -1
- package/dist/composite/hero/standard.mjs +36 -26
- package/dist/composite/hero/standard.mjs.map +1 -1
- package/dist/composite/layout/box/logo.d.ts.map +1 -1
- package/dist/composite/layout/box/logo.js +33 -14
- package/dist/composite/layout/box/logo.js.map +1 -1
- package/dist/composite/layout/box/logo.mjs +5 -4
- package/dist/composite/layout/box/logo.mjs.map +1 -1
- package/dist/composite/layout/image/expand.d.ts.map +1 -1
- package/dist/composite/layout/image/expand.js +32 -13
- package/dist/composite/layout/image/expand.js.map +1 -1
- package/dist/composite/layout/image/expand.mjs +7 -6
- package/dist/composite/layout/image/expand.mjs.map +1 -1
- package/dist/composite/layout/scroll-top/index.d.ts.map +1 -1
- package/dist/composite/layout/scroll-top/index.js +25 -11
- package/dist/composite/layout/scroll-top/index.js.map +1 -1
- package/dist/composite/layout/scroll-top/index.mjs +4 -7
- package/dist/composite/layout/scroll-top/index.mjs.map +1 -1
- package/dist/composite/layout/section-intro/small.d.ts.map +1 -1
- package/dist/composite/layout/section-intro/small.js +33 -14
- package/dist/composite/layout/section-intro/small.js.map +1 -1
- package/dist/composite/layout/section-intro/small.mjs +2 -1
- package/dist/composite/layout/section-intro/small.mjs.map +1 -1
- package/dist/composite/layout/section-intro/wide.js +20 -3
- package/dist/composite/layout/section-intro/wide.js.map +1 -1
- package/dist/composite/layout/section-intro/wide.mjs +1 -1
- package/dist/composite/layout/section-intro/wide.mjs.map +1 -1
- package/dist/composite/layout/sticky-columns/index.d.ts.map +1 -1
- package/dist/composite/layout/sticky-columns/index.js +26 -8
- package/dist/composite/layout/sticky-columns/index.js.map +1 -1
- package/dist/composite/layout/sticky-columns/index.mjs +4 -4
- package/dist/composite/layout/sticky-columns/index.mjs.map +1 -1
- package/dist/composite/media/elements/caption.d.ts.map +1 -1
- package/dist/composite/media/elements/caption.js +28 -9
- package/dist/composite/media/elements/caption.js.map +1 -1
- package/dist/composite/media/elements/caption.mjs +5 -4
- package/dist/composite/media/elements/caption.mjs.map +1 -1
- package/dist/composite/media/elements/gif.js +15 -4
- package/dist/composite/media/elements/gif.js.map +1 -1
- package/dist/composite/media/elements/gif.mjs +15 -4
- package/dist/composite/media/elements/gif.mjs.map +1 -1
- package/dist/composite/media/inline/caption.js +21 -8
- package/dist/composite/media/inline/caption.js.map +1 -1
- package/dist/composite/media/inline/caption.mjs +2 -6
- package/dist/composite/media/inline/caption.mjs.map +1 -1
- package/dist/composite/media/inline/wrapped.js +23 -10
- package/dist/composite/media/inline/wrapped.js.map +1 -1
- package/dist/composite/media/inline/wrapped.mjs +2 -6
- package/dist/composite/media/inline/wrapped.mjs.map +1 -1
- package/dist/composite/navigation/elements/breadcrumb/index.d.ts.map +1 -1
- package/dist/composite/navigation/elements/breadcrumb/index.js +35 -16
- package/dist/composite/navigation/elements/breadcrumb/index.js.map +1 -1
- package/dist/composite/navigation/elements/breadcrumb/index.mjs +7 -6
- package/dist/composite/navigation/elements/breadcrumb/index.mjs.map +1 -1
- package/dist/composite/navigation/elements/drawer/index.d.ts.map +1 -1
- package/dist/composite/navigation/elements/drawer/index.js +27 -13
- package/dist/composite/navigation/elements/drawer/index.js.map +1 -1
- package/dist/composite/navigation/elements/drawer/index.mjs +5 -8
- package/dist/composite/navigation/elements/drawer/index.mjs.map +1 -1
- package/dist/composite/navigation/elements/item/index.d.ts.map +1 -1
- package/dist/composite/navigation/elements/item/index.js +47 -28
- package/dist/composite/navigation/elements/item/index.js.map +1 -1
- package/dist/composite/navigation/elements/item/index.mjs +13 -12
- package/dist/composite/navigation/elements/item/index.mjs.map +1 -1
- package/dist/composite/navigation/elements/menu-button/index.js +20 -3
- package/dist/composite/navigation/elements/menu-button/index.js.map +1 -1
- package/dist/composite/navigation/elements/menu-button/index.mjs +1 -1
- package/dist/composite/navigation/elements/menu-button/index.mjs.map +1 -1
- package/dist/composite/navigation/elements/slider/action.d.ts.map +1 -1
- package/dist/composite/navigation/elements/slider/action.js +32 -13
- package/dist/composite/navigation/elements/slider/action.js.map +1 -1
- package/dist/composite/navigation/elements/slider/action.mjs +6 -5
- package/dist/composite/navigation/elements/slider/action.mjs.map +1 -1
- package/dist/composite/navigation/elements/slider/index.d.ts.map +1 -1
- package/dist/composite/navigation/elements/slider/index.js +35 -21
- package/dist/composite/navigation/elements/slider/index.js.map +1 -1
- package/dist/composite/navigation/elements/slider/index.mjs +3 -6
- package/dist/composite/navigation/elements/slider/index.mjs.map +1 -1
- package/dist/composite/navigation/elements/slider/slide-first.d.ts.map +1 -1
- package/dist/composite/navigation/elements/slider/slide-first.js +29 -10
- package/dist/composite/navigation/elements/slider/slide-first.js.map +1 -1
- package/dist/composite/navigation/elements/slider/slide-first.mjs +4 -3
- package/dist/composite/navigation/elements/slider/slide-first.mjs.map +1 -1
- package/dist/composite/navigation/elements/slider/slides.d.ts.map +1 -1
- package/dist/composite/navigation/elements/slider/slides.js +38 -19
- package/dist/composite/navigation/elements/slider/slides.js.map +1 -1
- package/dist/composite/navigation/elements/slider/slides.mjs +8 -7
- package/dist/composite/navigation/elements/slider/slides.mjs.map +1 -1
- package/dist/composite/navigation/elements/sticky/index.js +2 -5
- package/dist/composite/navigation/elements/sticky/index.js.map +1 -1
- package/dist/composite/navigation/elements/sticky/index.mjs +1 -4
- package/dist/composite/navigation/elements/sticky/index.mjs.map +1 -1
- package/dist/composite/navigation/header.d.ts.map +1 -1
- package/dist/composite/navigation/header.js +55 -36
- package/dist/composite/navigation/header.js.map +1 -1
- package/dist/composite/navigation/header.mjs +9 -8
- package/dist/composite/navigation/header.mjs.map +1 -1
- package/dist/composite/navigation/utility/alert.d.ts.map +1 -1
- package/dist/composite/navigation/utility/alert.js +18 -9
- package/dist/composite/navigation/utility/alert.js.map +1 -1
- package/dist/composite/navigation/utility/alert.mjs +18 -9
- package/dist/composite/navigation/utility/alert.mjs.map +1 -1
- package/dist/composite/navigation/utility/index.d.ts.map +1 -1
- package/dist/composite/navigation/utility/index.js +45 -41
- package/dist/composite/navigation/utility/index.js.map +1 -1
- package/dist/composite/navigation/utility/index.mjs +15 -13
- package/dist/composite/navigation/utility/index.mjs.map +1 -1
- package/dist/composite/navigation/utility/search.js +23 -6
- package/dist/composite/navigation/utility/search.js.map +1 -1
- package/dist/composite/navigation/utility/search.mjs +1 -1
- package/dist/composite/navigation/utility/search.mjs.map +1 -1
- package/dist/composite/pathway/_common.js +14 -3
- package/dist/composite/pathway/_common.js.map +1 -1
- package/dist/composite/pathway/_common.mjs +14 -3
- package/dist/composite/pathway/_common.mjs.map +1 -1
- package/dist/composite/pathway/hero.js +29 -19
- package/dist/composite/pathway/hero.js.map +1 -1
- package/dist/composite/pathway/hero.mjs +26 -16
- package/dist/composite/pathway/hero.mjs.map +1 -1
- package/dist/composite/pathway/highlight.js +21 -21
- package/dist/composite/pathway/highlight.js.map +1 -1
- package/dist/composite/pathway/highlight.mjs +20 -20
- package/dist/composite/pathway/highlight.mjs.map +1 -1
- package/dist/composite/pathway/overlay.js +19 -20
- package/dist/composite/pathway/overlay.js.map +1 -1
- package/dist/composite/pathway/overlay.mjs +14 -16
- package/dist/composite/pathway/overlay.mjs.map +1 -1
- package/dist/composite/pathway/standard.js +12 -15
- package/dist/composite/pathway/standard.js.map +1 -1
- package/dist/composite/pathway/standard.mjs +9 -12
- package/dist/composite/pathway/standard.mjs.map +1 -1
- package/dist/composite/pathway/sticky.d.ts.map +1 -1
- package/dist/composite/pathway/sticky.js +12 -10
- package/dist/composite/pathway/sticky.js.map +1 -1
- package/dist/composite/pathway/sticky.mjs +10 -9
- package/dist/composite/pathway/sticky.mjs.map +1 -1
- package/dist/composite/person/bio/full.d.ts.map +1 -1
- package/dist/composite/person/bio/full.js +24 -13
- package/dist/composite/person/bio/full.js.map +1 -1
- package/dist/composite/person/bio/full.mjs +22 -12
- package/dist/composite/person/bio/full.mjs.map +1 -1
- package/dist/composite/person/bio/small.js +33 -23
- package/dist/composite/person/bio/small.js.map +1 -1
- package/dist/composite/person/bio/small.mjs +32 -22
- package/dist/composite/person/bio/small.mjs.map +1 -1
- package/dist/composite/person/block.d.ts.map +1 -1
- package/dist/composite/person/block.js +26 -21
- package/dist/composite/person/block.js.map +1 -1
- package/dist/composite/person/block.mjs +24 -19
- package/dist/composite/person/block.mjs.map +1 -1
- package/dist/composite/person/hero.d.ts.map +1 -1
- package/dist/composite/person/hero.js +70 -43
- package/dist/composite/person/hero.js.map +1 -1
- package/dist/composite/person/hero.mjs +14 -4
- package/dist/composite/person/hero.mjs.map +1 -1
- package/dist/composite/person/list.d.ts.map +1 -1
- package/dist/composite/person/list.js +28 -21
- package/dist/composite/person/list.js.map +1 -1
- package/dist/composite/person/list.mjs +27 -20
- package/dist/composite/person/list.mjs.map +1 -1
- package/dist/composite/person/tabular.js +22 -11
- package/dist/composite/person/tabular.js.map +1 -1
- package/dist/composite/person/tabular.mjs +21 -10
- package/dist/composite/person/tabular.mjs.map +1 -1
- package/dist/composite/quote/_constants.d.ts +3 -0
- package/dist/composite/quote/_constants.d.ts.map +1 -0
- package/dist/composite/quote/_constants.js +7 -0
- package/dist/composite/quote/_constants.js.map +1 -0
- package/dist/composite/quote/_constants.mjs +7 -0
- package/dist/composite/quote/_constants.mjs.map +1 -0
- package/dist/composite/quote/_types.d.ts +24 -0
- package/dist/composite/quote/_types.d.ts.map +1 -0
- package/dist/composite/quote/elements/action.d.ts +11 -0
- package/dist/composite/quote/elements/action.d.ts.map +1 -0
- package/dist/composite/quote/elements/action.js +46 -0
- package/dist/composite/quote/elements/action.js.map +1 -0
- package/dist/composite/quote/elements/action.mjs +29 -0
- package/dist/composite/quote/elements/action.mjs.map +1 -0
- package/dist/composite/quote/elements/icon.d.ts +11 -0
- package/dist/composite/quote/elements/icon.d.ts.map +1 -0
- package/dist/composite/quote/elements/icon.js +74 -0
- package/dist/composite/quote/elements/icon.js.map +1 -0
- package/dist/composite/quote/elements/icon.mjs +58 -0
- package/dist/composite/quote/elements/icon.mjs.map +1 -0
- package/dist/composite/quote/elements/image.d.ts +7 -10
- package/dist/composite/quote/elements/image.d.ts.map +1 -1
- package/dist/composite/quote/elements/image.js +71 -12
- package/dist/composite/quote/elements/image.js.map +1 -1
- package/dist/composite/quote/elements/image.mjs +54 -12
- package/dist/composite/quote/elements/image.mjs.map +1 -1
- package/dist/composite/quote/elements/index.d.ts +5 -24
- package/dist/composite/quote/elements/index.d.ts.map +1 -1
- package/dist/composite/quote/elements/index.js +9 -5
- package/dist/composite/quote/elements/index.js.map +1 -1
- package/dist/composite/quote/elements/index.mjs +10 -7
- package/dist/composite/quote/elements/index.mjs.map +1 -1
- package/dist/composite/quote/elements/quote.d.ts +13 -0
- package/dist/composite/quote/elements/quote.d.ts.map +1 -0
- package/dist/composite/quote/elements/quote.js +114 -0
- package/dist/composite/quote/elements/quote.js.map +1 -0
- package/dist/composite/quote/elements/quote.mjs +97 -0
- package/dist/composite/quote/elements/quote.mjs.map +1 -0
- package/dist/composite/quote/elements/text.d.ts +5 -20
- package/dist/composite/quote/elements/text.d.ts.map +1 -1
- package/dist/composite/quote/elements/text.js +143 -189
- package/dist/composite/quote/elements/text.js.map +1 -1
- package/dist/composite/quote/elements/text.mjs +121 -185
- package/dist/composite/quote/elements/text.mjs.map +1 -1
- package/dist/composite/quote/featured.d.ts +7 -8
- package/dist/composite/quote/featured.d.ts.map +1 -1
- package/dist/composite/quote/featured.js +202 -243
- package/dist/composite/quote/featured.js.map +1 -1
- package/dist/composite/quote/featured.mjs +184 -242
- package/dist/composite/quote/featured.mjs.map +1 -1
- package/dist/composite/quote/helper/animation.d.ts +8 -0
- package/dist/composite/quote/helper/animation.d.ts.map +1 -0
- package/dist/composite/quote/helper/animation.js +105 -0
- package/dist/composite/quote/helper/animation.js.map +1 -0
- package/dist/composite/quote/helper/animation.mjs +105 -0
- package/dist/composite/quote/helper/animation.mjs.map +1 -0
- package/dist/composite/quote/index.d.ts +1 -1
- package/dist/composite/quote/index.d.ts.map +1 -1
- package/dist/composite/quote/index.mjs +6 -6
- package/dist/composite/quote/inline.d.ts +7 -9
- package/dist/composite/quote/inline.d.ts.map +1 -1
- package/dist/composite/quote/inline.js +79 -270
- package/dist/composite/quote/inline.js.map +1 -1
- package/dist/composite/quote/inline.mjs +63 -271
- package/dist/composite/quote/inline.mjs.map +1 -1
- package/dist/composite/quote/statement.d.ts +5 -7
- package/dist/composite/quote/statement.d.ts.map +1 -1
- package/dist/composite/slider/events.d.ts.map +1 -1
- package/dist/composite/slider/events.js +60 -46
- package/dist/composite/slider/events.js.map +1 -1
- package/dist/composite/slider/events.mjs +12 -16
- package/dist/composite/slider/events.mjs.map +1 -1
- package/dist/composite/social/sharing.d.ts.map +1 -1
- package/dist/composite/social/sharing.js +38 -23
- package/dist/composite/social/sharing.js.map +1 -1
- package/dist/composite/social/sharing.mjs +9 -11
- package/dist/composite/social/sharing.mjs.map +1 -1
- package/dist/composite/tabs/standard.d.ts.map +1 -1
- package/dist/composite/tabs/standard.js +44 -30
- package/dist/composite/tabs/standard.js.map +1 -1
- package/dist/composite/tabs/standard.mjs +9 -13
- package/dist/composite/tabs/standard.mjs.map +1 -1
- package/dist/index.d.ts +0 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +0 -2
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +1 -3
- package/dist/index.mjs.map +1 -1
- package/dist/layout/image.d.ts.map +1 -1
- package/dist/layout/image.js +25 -6
- package/dist/layout/image.js.map +1 -1
- package/dist/layout/image.mjs +4 -3
- package/dist/layout/image.mjs.map +1 -1
- package/dist/model/modifiers/index.d.ts +1 -1
- package/dist/model/modifiers/index.d.ts.map +1 -1
- package/dist/model/modifiers/index.js +12 -12
- package/dist/model/modifiers/index.js.map +1 -1
- package/dist/model/modifiers/index.mjs +2 -2
- package/dist/model/modifiers/index.mjs.map +1 -1
- package/dist/model/modifiers/style.js +7 -7
- package/dist/model/modifiers/style.js.map +1 -1
- package/dist/model/modifiers/style.mjs +2 -2
- package/dist/model/modifiers/style.mjs.map +1 -1
- package/package.json +17 -18
- package/dist/_virtual/___vite-browser-external.js +0 -8
- package/dist/_virtual/___vite-browser-external.js.map +0 -1
- package/dist/_virtual/___vite-browser-external.mjs +0 -7
- package/dist/_virtual/___vite-browser-external.mjs.map +0 -1
- package/dist/_virtual/__vite-browser-external.js +0 -4
- package/dist/_virtual/__vite-browser-external.js.map +0 -1
- package/dist/_virtual/__vite-browser-external.mjs +0 -5
- package/dist/_virtual/__vite-browser-external.mjs.map +0 -1
- package/dist/_virtual/_commonjsHelpers.js +0 -39
- package/dist/_virtual/_commonjsHelpers.js.map +0 -1
- package/dist/_virtual/_commonjsHelpers.mjs +0 -39
- package/dist/_virtual/_commonjsHelpers.mjs.map +0 -1
- package/dist/_virtual/attribute.js +0 -5
- package/dist/_virtual/attribute.js.map +0 -1
- package/dist/_virtual/attribute.mjs +0 -5
- package/dist/_virtual/attribute.mjs.map +0 -1
- package/dist/_virtual/className.js +0 -5
- package/dist/_virtual/className.js.map +0 -1
- package/dist/_virtual/className.mjs +0 -5
- package/dist/_virtual/className.mjs.map +0 -1
- package/dist/_virtual/combinator.js +0 -5
- package/dist/_virtual/combinator.js.map +0 -1
- package/dist/_virtual/combinator.mjs +0 -5
- package/dist/_virtual/combinator.mjs.map +0 -1
- package/dist/_virtual/comment.js +0 -5
- package/dist/_virtual/comment.js.map +0 -1
- package/dist/_virtual/comment.mjs +0 -5
- package/dist/_virtual/comment.mjs.map +0 -1
- package/dist/_virtual/constructors.js +0 -5
- package/dist/_virtual/constructors.js.map +0 -1
- package/dist/_virtual/constructors.mjs +0 -5
- package/dist/_virtual/constructors.mjs.map +0 -1
- package/dist/_virtual/container.js +0 -5
- package/dist/_virtual/container.js.map +0 -1
- package/dist/_virtual/container.mjs +0 -5
- package/dist/_virtual/container.mjs.map +0 -1
- package/dist/_virtual/ensureObject.js +0 -5
- package/dist/_virtual/ensureObject.js.map +0 -1
- package/dist/_virtual/ensureObject.mjs +0 -5
- package/dist/_virtual/ensureObject.mjs.map +0 -1
- package/dist/_virtual/getProp.js +0 -5
- package/dist/_virtual/getProp.js.map +0 -1
- package/dist/_virtual/getProp.mjs +0 -5
- package/dist/_virtual/getProp.mjs.map +0 -1
- package/dist/_virtual/guards.js +0 -5
- package/dist/_virtual/guards.js.map +0 -1
- package/dist/_virtual/guards.mjs +0 -5
- package/dist/_virtual/guards.mjs.map +0 -1
- package/dist/_virtual/id.js +0 -5
- package/dist/_virtual/id.js.map +0 -1
- package/dist/_virtual/id.mjs +0 -5
- package/dist/_virtual/id.mjs.map +0 -1
- package/dist/_virtual/index.js +0 -7
- package/dist/_virtual/index.js.map +0 -1
- package/dist/_virtual/index.mjs +0 -8
- package/dist/_virtual/index.mjs.map +0 -1
- package/dist/_virtual/index2.js +0 -7
- package/dist/_virtual/index2.js.map +0 -1
- package/dist/_virtual/index2.mjs +0 -8
- package/dist/_virtual/index2.mjs.map +0 -1
- package/dist/_virtual/index3.js +0 -5
- package/dist/_virtual/index3.js.map +0 -1
- package/dist/_virtual/index3.mjs +0 -5
- package/dist/_virtual/index3.mjs.map +0 -1
- package/dist/_virtual/index4.js +0 -5
- package/dist/_virtual/index4.js.map +0 -1
- package/dist/_virtual/index4.mjs +0 -5
- package/dist/_virtual/index4.mjs.map +0 -1
- package/dist/_virtual/index5.js +0 -5
- package/dist/_virtual/index5.js.map +0 -1
- package/dist/_virtual/index5.mjs +0 -5
- package/dist/_virtual/index5.mjs.map +0 -1
- package/dist/_virtual/namespace.js +0 -5
- package/dist/_virtual/namespace.js.map +0 -1
- package/dist/_virtual/namespace.mjs +0 -5
- package/dist/_virtual/namespace.mjs.map +0 -1
- package/dist/_virtual/nesting.js +0 -5
- package/dist/_virtual/nesting.js.map +0 -1
- package/dist/_virtual/nesting.mjs +0 -5
- package/dist/_virtual/nesting.mjs.map +0 -1
- package/dist/_virtual/node.js +0 -5
- package/dist/_virtual/node.js.map +0 -1
- package/dist/_virtual/node.mjs +0 -5
- package/dist/_virtual/node.mjs.map +0 -1
- package/dist/_virtual/parser.js +0 -5
- package/dist/_virtual/parser.js.map +0 -1
- package/dist/_virtual/parser.mjs +0 -5
- package/dist/_virtual/parser.mjs.map +0 -1
- package/dist/_virtual/picocolors.browser.js +0 -5
- package/dist/_virtual/picocolors.browser.js.map +0 -1
- package/dist/_virtual/picocolors.browser.mjs +0 -5
- package/dist/_virtual/picocolors.browser.mjs.map +0 -1
- package/dist/_virtual/postcss.js +0 -7
- package/dist/_virtual/postcss.js.map +0 -1
- package/dist/_virtual/postcss.mjs +0 -8
- package/dist/_virtual/postcss.mjs.map +0 -1
- package/dist/_virtual/processor.js +0 -5
- package/dist/_virtual/processor.js.map +0 -1
- package/dist/_virtual/processor.mjs +0 -5
- package/dist/_virtual/processor.mjs.map +0 -1
- package/dist/_virtual/pseudo.js +0 -5
- package/dist/_virtual/pseudo.js.map +0 -1
- package/dist/_virtual/pseudo.mjs +0 -5
- package/dist/_virtual/pseudo.mjs.map +0 -1
- package/dist/_virtual/root.js +0 -5
- package/dist/_virtual/root.js.map +0 -1
- package/dist/_virtual/root.mjs +0 -5
- package/dist/_virtual/root.mjs.map +0 -1
- package/dist/_virtual/selector.js +0 -5
- package/dist/_virtual/selector.js.map +0 -1
- package/dist/_virtual/selector.mjs +0 -5
- package/dist/_virtual/selector.mjs.map +0 -1
- package/dist/_virtual/sortAscending.js +0 -5
- package/dist/_virtual/sortAscending.js.map +0 -1
- package/dist/_virtual/sortAscending.mjs +0 -5
- package/dist/_virtual/sortAscending.mjs.map +0 -1
- package/dist/_virtual/string.js +0 -5
- package/dist/_virtual/string.js.map +0 -1
- package/dist/_virtual/string.mjs +0 -5
- package/dist/_virtual/string.mjs.map +0 -1
- package/dist/_virtual/stripComments.js +0 -5
- package/dist/_virtual/stripComments.js.map +0 -1
- package/dist/_virtual/stripComments.mjs +0 -5
- package/dist/_virtual/stripComments.mjs.map +0 -1
- package/dist/_virtual/symbols.js +0 -5
- package/dist/_virtual/symbols.js.map +0 -1
- package/dist/_virtual/symbols.mjs +0 -5
- package/dist/_virtual/symbols.mjs.map +0 -1
- package/dist/_virtual/tag.js +0 -5
- package/dist/_virtual/tag.js.map +0 -1
- package/dist/_virtual/tag.mjs +0 -5
- package/dist/_virtual/tag.mjs.map +0 -1
- package/dist/_virtual/tokenTypes.js +0 -5
- package/dist/_virtual/tokenTypes.js.map +0 -1
- package/dist/_virtual/tokenTypes.mjs +0 -5
- package/dist/_virtual/tokenTypes.mjs.map +0 -1
- package/dist/_virtual/tokenize.js +0 -5
- package/dist/_virtual/tokenize.js.map +0 -1
- package/dist/_virtual/tokenize.mjs +0 -5
- package/dist/_virtual/tokenize.mjs.map +0 -1
- package/dist/_virtual/types.js +0 -5
- package/dist/_virtual/types.js.map +0 -1
- package/dist/_virtual/types.mjs +0 -5
- package/dist/_virtual/types.mjs.map +0 -1
- package/dist/_virtual/unesc.js +0 -5
- package/dist/_virtual/unesc.js.map +0 -1
- package/dist/_virtual/unesc.mjs +0 -5
- package/dist/_virtual/unesc.mjs.map +0 -1
- package/dist/_virtual/universal.js +0 -5
- package/dist/_virtual/universal.js.map +0 -1
- package/dist/_virtual/universal.mjs +0 -5
- package/dist/_virtual/universal.mjs.map +0 -1
- package/dist/node_modules/@csstools/selector-specificity/dist/index.js +0 -96
- package/dist/node_modules/@csstools/selector-specificity/dist/index.js.map +0 -1
- package/dist/node_modules/@csstools/selector-specificity/dist/index.mjs +0 -96
- package/dist/node_modules/@csstools/selector-specificity/dist/index.mjs.map +0 -1
- package/dist/node_modules/camelcase-css/index-es5.js +0 -26
- package/dist/node_modules/camelcase-css/index-es5.js.map +0 -1
- package/dist/node_modules/camelcase-css/index-es5.mjs +0 -26
- package/dist/node_modules/camelcase-css/index-es5.mjs.map +0 -1
- package/dist/node_modules/cssesc/cssesc.js +0 -95
- package/dist/node_modules/cssesc/cssesc.js.map +0 -1
- package/dist/node_modules/cssesc/cssesc.mjs +0 -95
- package/dist/node_modules/cssesc/cssesc.mjs.map +0 -1
- package/dist/node_modules/nanoid/non-secure/index.js +0 -31
- package/dist/node_modules/nanoid/non-secure/index.js.map +0 -1
- package/dist/node_modules/nanoid/non-secure/index.mjs +0 -31
- package/dist/node_modules/nanoid/non-secure/index.mjs.map +0 -1
- package/dist/node_modules/picocolors/picocolors.browser.js +0 -17
- package/dist/node_modules/picocolors/picocolors.browser.js.map +0 -1
- package/dist/node_modules/picocolors/picocolors.browser.mjs +0 -17
- package/dist/node_modules/picocolors/picocolors.browser.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/at-rule.js +0 -30
- package/dist/node_modules/postcss/lib/at-rule.js.map +0 -1
- package/dist/node_modules/postcss/lib/at-rule.mjs +0 -30
- package/dist/node_modules/postcss/lib/at-rule.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/comment.js +0 -21
- package/dist/node_modules/postcss/lib/comment.js.map +0 -1
- package/dist/node_modules/postcss/lib/comment.mjs +0 -21
- package/dist/node_modules/postcss/lib/comment.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/container.js +0 -383
- package/dist/node_modules/postcss/lib/container.js.map +0 -1
- package/dist/node_modules/postcss/lib/container.mjs +0 -383
- package/dist/node_modules/postcss/lib/container.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/css-syntax-error.js +0 -92
- package/dist/node_modules/postcss/lib/css-syntax-error.js.map +0 -1
- package/dist/node_modules/postcss/lib/css-syntax-error.mjs +0 -92
- package/dist/node_modules/postcss/lib/css-syntax-error.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/declaration.js +0 -27
- package/dist/node_modules/postcss/lib/declaration.js.map +0 -1
- package/dist/node_modules/postcss/lib/declaration.mjs +0 -27
- package/dist/node_modules/postcss/lib/declaration.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/document.js +0 -34
- package/dist/node_modules/postcss/lib/document.js.map +0 -1
- package/dist/node_modules/postcss/lib/document.mjs +0 -34
- package/dist/node_modules/postcss/lib/document.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/fromJSON.js +0 -67
- package/dist/node_modules/postcss/lib/fromJSON.js.map +0 -1
- package/dist/node_modules/postcss/lib/fromJSON.mjs +0 -67
- package/dist/node_modules/postcss/lib/fromJSON.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/input.js +0 -216
- package/dist/node_modules/postcss/lib/input.js.map +0 -1
- package/dist/node_modules/postcss/lib/input.mjs +0 -216
- package/dist/node_modules/postcss/lib/input.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/lazy-result.js +0 -467
- package/dist/node_modules/postcss/lib/lazy-result.js.map +0 -1
- package/dist/node_modules/postcss/lib/lazy-result.mjs +0 -467
- package/dist/node_modules/postcss/lib/lazy-result.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/list.js +0 -60
- package/dist/node_modules/postcss/lib/list.js.map +0 -1
- package/dist/node_modules/postcss/lib/list.mjs +0 -60
- package/dist/node_modules/postcss/lib/list.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/map-generator.js +0 -314
- package/dist/node_modules/postcss/lib/map-generator.js.map +0 -1
- package/dist/node_modules/postcss/lib/map-generator.mjs +0 -314
- package/dist/node_modules/postcss/lib/map-generator.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/no-work-result.js +0 -113
- package/dist/node_modules/postcss/lib/no-work-result.js.map +0 -1
- package/dist/node_modules/postcss/lib/no-work-result.mjs +0 -113
- package/dist/node_modules/postcss/lib/no-work-result.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/node.js +0 -335
- package/dist/node_modules/postcss/lib/node.js.map +0 -1
- package/dist/node_modules/postcss/lib/node.mjs +0 -335
- package/dist/node_modules/postcss/lib/node.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/parse.js +0 -30
- package/dist/node_modules/postcss/lib/parse.js.map +0 -1
- package/dist/node_modules/postcss/lib/parse.mjs +0 -30
- package/dist/node_modules/postcss/lib/parse.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/parser.js +0 -543
- package/dist/node_modules/postcss/lib/parser.js.map +0 -1
- package/dist/node_modules/postcss/lib/parser.mjs +0 -543
- package/dist/node_modules/postcss/lib/parser.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/postcss.js +0 -28
- package/dist/node_modules/postcss/lib/postcss.js.map +0 -1
- package/dist/node_modules/postcss/lib/postcss.mjs +0 -29
- package/dist/node_modules/postcss/lib/postcss.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/postcss2.js +0 -110
- package/dist/node_modules/postcss/lib/postcss2.js.map +0 -1
- package/dist/node_modules/postcss/lib/postcss2.mjs +0 -110
- package/dist/node_modules/postcss/lib/postcss2.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/previous-map.js +0 -123
- package/dist/node_modules/postcss/lib/previous-map.js.map +0 -1
- package/dist/node_modules/postcss/lib/previous-map.mjs +0 -123
- package/dist/node_modules/postcss/lib/previous-map.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/processor.js +0 -61
- package/dist/node_modules/postcss/lib/processor.js.map +0 -1
- package/dist/node_modules/postcss/lib/processor.mjs +0 -61
- package/dist/node_modules/postcss/lib/processor.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/result.js +0 -44
- package/dist/node_modules/postcss/lib/result.js.map +0 -1
- package/dist/node_modules/postcss/lib/result.mjs +0 -44
- package/dist/node_modules/postcss/lib/result.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/root.js +0 -58
- package/dist/node_modules/postcss/lib/root.js.map +0 -1
- package/dist/node_modules/postcss/lib/root.mjs +0 -58
- package/dist/node_modules/postcss/lib/root.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/rule.js +0 -33
- package/dist/node_modules/postcss/lib/rule.js.map +0 -1
- package/dist/node_modules/postcss/lib/rule.mjs +0 -33
- package/dist/node_modules/postcss/lib/rule.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/stringifier.js +0 -308
- package/dist/node_modules/postcss/lib/stringifier.js.map +0 -1
- package/dist/node_modules/postcss/lib/stringifier.mjs +0 -308
- package/dist/node_modules/postcss/lib/stringifier.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/stringify.js +0 -19
- package/dist/node_modules/postcss/lib/stringify.js.map +0 -1
- package/dist/node_modules/postcss/lib/stringify.mjs +0 -19
- package/dist/node_modules/postcss/lib/stringify.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/symbols.js +0 -13
- package/dist/node_modules/postcss/lib/symbols.js.map +0 -1
- package/dist/node_modules/postcss/lib/symbols.mjs +0 -13
- package/dist/node_modules/postcss/lib/symbols.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/tokenize.js +0 -219
- package/dist/node_modules/postcss/lib/tokenize.js.map +0 -1
- package/dist/node_modules/postcss/lib/tokenize.mjs +0 -219
- package/dist/node_modules/postcss/lib/tokenize.mjs.map +0 -1
- package/dist/node_modules/postcss/lib/warning.js +0 -40
- package/dist/node_modules/postcss/lib/warning.js.map +0 -1
- package/dist/node_modules/postcss/lib/warning.mjs +0 -40
- package/dist/node_modules/postcss/lib/warning.mjs.map +0 -1
- package/dist/node_modules/postcss-js/async.js +0 -27
- package/dist/node_modules/postcss-js/async.js.map +0 -1
- package/dist/node_modules/postcss-js/async.mjs +0 -27
- package/dist/node_modules/postcss-js/async.mjs.map +0 -1
- package/dist/node_modules/postcss-js/index.js +0 -8
- package/dist/node_modules/postcss-js/index.js.map +0 -1
- package/dist/node_modules/postcss-js/index.mjs +0 -9
- package/dist/node_modules/postcss-js/index.mjs.map +0 -1
- package/dist/node_modules/postcss-js/index2.js +0 -25
- package/dist/node_modules/postcss-js/index2.js.map +0 -1
- package/dist/node_modules/postcss-js/index2.mjs +0 -25
- package/dist/node_modules/postcss-js/index2.mjs.map +0 -1
- package/dist/node_modules/postcss-js/objectifier.js +0 -92
- package/dist/node_modules/postcss-js/objectifier.js.map +0 -1
- package/dist/node_modules/postcss-js/objectifier.mjs +0 -92
- package/dist/node_modules/postcss-js/objectifier.mjs.map +0 -1
- package/dist/node_modules/postcss-js/parser.js +0 -102
- package/dist/node_modules/postcss-js/parser.js.map +0 -1
- package/dist/node_modules/postcss-js/parser.mjs +0 -102
- package/dist/node_modules/postcss-js/parser.mjs.map +0 -1
- package/dist/node_modules/postcss-js/process-result.js +0 -22
- package/dist/node_modules/postcss-js/process-result.js.map +0 -1
- package/dist/node_modules/postcss-js/process-result.mjs +0 -22
- package/dist/node_modules/postcss-js/process-result.mjs.map +0 -1
- package/dist/node_modules/postcss-js/sync.js +0 -24
- package/dist/node_modules/postcss-js/sync.js.map +0 -1
- package/dist/node_modules/postcss-js/sync.mjs +0 -24
- package/dist/node_modules/postcss-js/sync.mjs.map +0 -1
- package/dist/node_modules/postcss-nesting/dist/index.js +0 -267
- package/dist/node_modules/postcss-nesting/dist/index.js.map +0 -1
- package/dist/node_modules/postcss-nesting/dist/index.mjs +0 -268
- package/dist/node_modules/postcss-nesting/dist/index.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/index.js +0 -67
- package/dist/node_modules/postcss-selector-parser/dist/index.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/index.mjs +0 -67
- package/dist/node_modules/postcss-selector-parser/dist/index.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/parser.js +0 -1038
- package/dist/node_modules/postcss-selector-parser/dist/parser.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/parser.mjs +0 -1038
- package/dist/node_modules/postcss-selector-parser/dist/parser.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/processor.js +0 -137
- package/dist/node_modules/postcss-selector-parser/dist/processor.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/processor.mjs +0 -137
- package/dist/node_modules/postcss-selector-parser/dist/processor.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/attribute.js +0 -404
- package/dist/node_modules/postcss-selector-parser/dist/selectors/attribute.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/attribute.mjs +0 -404
- package/dist/node_modules/postcss-selector-parser/dist/selectors/attribute.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/className.js +0 -89
- package/dist/node_modules/postcss-selector-parser/dist/selectors/className.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/className.mjs +0 -89
- package/dist/node_modules/postcss-selector-parser/dist/selectors/className.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/combinator.js +0 -46
- package/dist/node_modules/postcss-selector-parser/dist/selectors/combinator.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/combinator.mjs +0 -46
- package/dist/node_modules/postcss-selector-parser/dist/selectors/combinator.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/comment.js +0 -46
- package/dist/node_modules/postcss-selector-parser/dist/selectors/comment.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/comment.mjs +0 -46
- package/dist/node_modules/postcss-selector-parser/dist/selectors/comment.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/constructors.js +0 -88
- package/dist/node_modules/postcss-selector-parser/dist/selectors/constructors.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/constructors.mjs +0 -88
- package/dist/node_modules/postcss-selector-parser/dist/selectors/constructors.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/container.js +0 -391
- package/dist/node_modules/postcss-selector-parser/dist/selectors/container.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/container.mjs +0 -391
- package/dist/node_modules/postcss-selector-parser/dist/selectors/container.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/guards.js +0 -68
- package/dist/node_modules/postcss-selector-parser/dist/selectors/guards.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/guards.mjs +0 -68
- package/dist/node_modules/postcss-selector-parser/dist/selectors/guards.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/id.js +0 -50
- package/dist/node_modules/postcss-selector-parser/dist/selectors/id.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/id.mjs +0 -50
- package/dist/node_modules/postcss-selector-parser/dist/selectors/id.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/index.js +0 -35
- package/dist/node_modules/postcss-selector-parser/dist/selectors/index.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/index.mjs +0 -35
- package/dist/node_modules/postcss-selector-parser/dist/selectors/index.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/namespace.js +0 -117
- package/dist/node_modules/postcss-selector-parser/dist/selectors/namespace.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/namespace.mjs +0 -117
- package/dist/node_modules/postcss-selector-parser/dist/selectors/namespace.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/nesting.js +0 -47
- package/dist/node_modules/postcss-selector-parser/dist/selectors/nesting.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/nesting.mjs +0 -47
- package/dist/node_modules/postcss-selector-parser/dist/selectors/nesting.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/node.js +0 -183
- package/dist/node_modules/postcss-selector-parser/dist/selectors/node.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/node.mjs +0 -183
- package/dist/node_modules/postcss-selector-parser/dist/selectors/node.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/pseudo.js +0 -51
- package/dist/node_modules/postcss-selector-parser/dist/selectors/pseudo.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/pseudo.mjs +0 -51
- package/dist/node_modules/postcss-selector-parser/dist/selectors/pseudo.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/root.js +0 -81
- package/dist/node_modules/postcss-selector-parser/dist/selectors/root.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/root.mjs +0 -81
- package/dist/node_modules/postcss-selector-parser/dist/selectors/root.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/selector.js +0 -46
- package/dist/node_modules/postcss-selector-parser/dist/selectors/selector.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/selector.mjs +0 -46
- package/dist/node_modules/postcss-selector-parser/dist/selectors/selector.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/string.js +0 -46
- package/dist/node_modules/postcss-selector-parser/dist/selectors/string.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/string.mjs +0 -46
- package/dist/node_modules/postcss-selector-parser/dist/selectors/string.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/tag.js +0 -46
- package/dist/node_modules/postcss-selector-parser/dist/selectors/tag.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/tag.mjs +0 -46
- package/dist/node_modules/postcss-selector-parser/dist/selectors/tag.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/types.js +0 -37
- package/dist/node_modules/postcss-selector-parser/dist/selectors/types.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/types.mjs +0 -37
- package/dist/node_modules/postcss-selector-parser/dist/selectors/types.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/universal.js +0 -47
- package/dist/node_modules/postcss-selector-parser/dist/selectors/universal.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/selectors/universal.mjs +0 -47
- package/dist/node_modules/postcss-selector-parser/dist/selectors/universal.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/sortAscending.js +0 -21
- package/dist/node_modules/postcss-selector-parser/dist/sortAscending.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/sortAscending.mjs +0 -21
- package/dist/node_modules/postcss-selector-parser/dist/sortAscending.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/tokenTypes.js +0 -75
- package/dist/node_modules/postcss-selector-parser/dist/tokenTypes.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/tokenTypes.mjs +0 -75
- package/dist/node_modules/postcss-selector-parser/dist/tokenTypes.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/tokenize.js +0 -264
- package/dist/node_modules/postcss-selector-parser/dist/tokenize.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/tokenize.mjs +0 -264
- package/dist/node_modules/postcss-selector-parser/dist/tokenize.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/util/ensureObject.js +0 -28
- package/dist/node_modules/postcss-selector-parser/dist/util/ensureObject.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/util/ensureObject.mjs +0 -28
- package/dist/node_modules/postcss-selector-parser/dist/util/ensureObject.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/util/getProp.js +0 -29
- package/dist/node_modules/postcss-selector-parser/dist/util/getProp.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/util/getProp.mjs +0 -29
- package/dist/node_modules/postcss-selector-parser/dist/util/getProp.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/util/index.js +0 -28
- package/dist/node_modules/postcss-selector-parser/dist/util/index.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/util/index.mjs +0 -28
- package/dist/node_modules/postcss-selector-parser/dist/util/index.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/util/stripComments.js +0 -32
- package/dist/node_modules/postcss-selector-parser/dist/util/stripComments.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/util/stripComments.mjs +0 -32
- package/dist/node_modules/postcss-selector-parser/dist/util/stripComments.mjs.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/util/unesc.js +0 -68
- package/dist/node_modules/postcss-selector-parser/dist/util/unesc.js.map +0 -1
- package/dist/node_modules/postcss-selector-parser/dist/util/unesc.mjs +0 -68
- package/dist/node_modules/postcss-selector-parser/dist/util/unesc.mjs.map +0 -1
- package/dist/node_modules/util-deprecate/browser.js +0 -43
- package/dist/node_modules/util-deprecate/browser.js.map +0 -1
- package/dist/node_modules/util-deprecate/browser.mjs +0 -43
- package/dist/node_modules/util-deprecate/browser.mjs.map +0 -1
- package/dist/utilities/accessibility/index.d.ts +0 -13
- package/dist/utilities/accessibility/index.d.ts.map +0 -1
- package/dist/utilities/accessibility/index.js +0 -89
- package/dist/utilities/accessibility/index.js.map +0 -1
- package/dist/utilities/accessibility/index.mjs +0 -89
- package/dist/utilities/accessibility/index.mjs.map +0 -1
- package/dist/utilities/assets/icons.d.ts +0 -26
- package/dist/utilities/assets/icons.d.ts.map +0 -1
- package/dist/utilities/assets/icons.js +0 -53
- package/dist/utilities/assets/icons.js.map +0 -1
- package/dist/utilities/assets/icons.mjs +0 -53
- package/dist/utilities/assets/icons.mjs.map +0 -1
- package/dist/utilities/assets/index.d.ts +0 -4
- package/dist/utilities/assets/index.d.ts.map +0 -1
- package/dist/utilities/assets/index.js +0 -9
- package/dist/utilities/assets/index.js.map +0 -1
- package/dist/utilities/assets/index.mjs +0 -9
- package/dist/utilities/assets/index.mjs.map +0 -1
- package/dist/utilities/assets/logos.d.ts +0 -6
- package/dist/utilities/assets/logos.d.ts.map +0 -1
- package/dist/utilities/assets/logos.js +0 -14
- package/dist/utilities/assets/logos.js.map +0 -1
- package/dist/utilities/assets/logos.mjs +0 -14
- package/dist/utilities/assets/logos.mjs.map +0 -1
- package/dist/utilities/assets/social.d.ts +0 -8
- package/dist/utilities/assets/social.d.ts.map +0 -1
- package/dist/utilities/assets/social.js +0 -17
- package/dist/utilities/assets/social.js.map +0 -1
- package/dist/utilities/assets/social.mjs +0 -17
- package/dist/utilities/assets/social.mjs.map +0 -1
- package/dist/utilities/date.d.ts +0 -12
- package/dist/utilities/date.d.ts.map +0 -1
- package/dist/utilities/date.js +0 -36
- package/dist/utilities/date.js.map +0 -1
- package/dist/utilities/date.mjs +0 -36
- package/dist/utilities/date.mjs.map +0 -1
- package/dist/utilities/index.d.ts +0 -10
- package/dist/utilities/index.d.ts.map +0 -1
- package/dist/utilities/js-events/index.d.ts +0 -5
- package/dist/utilities/js-events/index.d.ts.map +0 -1
- package/dist/utilities/js-events/index.js +0 -37
- package/dist/utilities/js-events/index.js.map +0 -1
- package/dist/utilities/js-events/index.mjs +0 -37
- package/dist/utilities/js-events/index.mjs.map +0 -1
- package/dist/utilities/markup/create.d.ts +0 -13
- package/dist/utilities/markup/create.d.ts.map +0 -1
- package/dist/utilities/markup/create.js +0 -95
- package/dist/utilities/markup/create.js.map +0 -1
- package/dist/utilities/markup/create.mjs +0 -95
- package/dist/utilities/markup/create.mjs.map +0 -1
- package/dist/utilities/markup/get.d.ts +0 -4
- package/dist/utilities/markup/get.d.ts.map +0 -1
- package/dist/utilities/markup/get.js +0 -18
- package/dist/utilities/markup/get.js.map +0 -1
- package/dist/utilities/markup/get.mjs +0 -18
- package/dist/utilities/markup/get.mjs.map +0 -1
- package/dist/utilities/markup/index.d.ts +0 -5
- package/dist/utilities/markup/index.d.ts.map +0 -1
- package/dist/utilities/markup/index.js +0 -11
- package/dist/utilities/markup/index.js.map +0 -1
- package/dist/utilities/markup/index.mjs +0 -11
- package/dist/utilities/markup/index.mjs.map +0 -1
- package/dist/utilities/markup/locate.d.ts +0 -5
- package/dist/utilities/markup/locate.d.ts.map +0 -1
- package/dist/utilities/markup/locate.js +0 -26
- package/dist/utilities/markup/locate.js.map +0 -1
- package/dist/utilities/markup/locate.mjs +0 -26
- package/dist/utilities/markup/locate.mjs.map +0 -1
- package/dist/utilities/markup/modify.d.ts +0 -21
- package/dist/utilities/markup/modify.d.ts.map +0 -1
- package/dist/utilities/markup/modify.js +0 -93
- package/dist/utilities/markup/modify.js.map +0 -1
- package/dist/utilities/markup/modify.mjs +0 -93
- package/dist/utilities/markup/modify.mjs.map +0 -1
- package/dist/utilities/network/index.d.ts +0 -10
- package/dist/utilities/network/index.d.ts.map +0 -1
- package/dist/utilities/network/index.js +0 -35
- package/dist/utilities/network/index.js.map +0 -1
- package/dist/utilities/network/index.mjs +0 -35
- package/dist/utilities/network/index.mjs.map +0 -1
- package/dist/utilities/performance/index.d.ts +0 -2
- package/dist/utilities/performance/index.d.ts.map +0 -1
- package/dist/utilities/performance/index.js +0 -12
- package/dist/utilities/performance/index.js.map +0 -1
- package/dist/utilities/performance/index.mjs +0 -12
- package/dist/utilities/performance/index.mjs.map +0 -1
- package/dist/utilities/storage/index.d.ts +0 -2
- package/dist/utilities/storage/index.d.ts.map +0 -1
- package/dist/utilities/storage/index.js +0 -5
- package/dist/utilities/storage/index.js.map +0 -1
- package/dist/utilities/storage/index.mjs +0 -5
- package/dist/utilities/storage/index.mjs.map +0 -1
- package/dist/utilities/storage/local.d.ts +0 -7
- package/dist/utilities/storage/local.d.ts.map +0 -1
- package/dist/utilities/storage/local.js +0 -14
- package/dist/utilities/storage/local.js.map +0 -1
- package/dist/utilities/storage/local.mjs +0 -14
- package/dist/utilities/storage/local.mjs.map +0 -1
- package/dist/utilities/theme/animations.d.ts +0 -9
- package/dist/utilities/theme/animations.d.ts.map +0 -1
- package/dist/utilities/theme/animations.js +0 -70
- package/dist/utilities/theme/animations.js.map +0 -1
- package/dist/utilities/theme/animations.mjs +0 -70
- package/dist/utilities/theme/animations.mjs.map +0 -1
- package/dist/utilities/theme/assets.d.ts +0 -6
- package/dist/utilities/theme/assets.d.ts.map +0 -1
- package/dist/utilities/theme/assets.js +0 -17
- package/dist/utilities/theme/assets.js.map +0 -1
- package/dist/utilities/theme/assets.mjs +0 -17
- package/dist/utilities/theme/assets.mjs.map +0 -1
- package/dist/utilities/theme/index.d.ts +0 -11
- package/dist/utilities/theme/index.d.ts.map +0 -1
- package/dist/utilities/theme/index.js +0 -28
- package/dist/utilities/theme/index.js.map +0 -1
- package/dist/utilities/theme/index.mjs +0 -28
- package/dist/utilities/theme/index.mjs.map +0 -1
- package/dist/utilities/theme/media.d.ts +0 -12
- package/dist/utilities/theme/media.d.ts.map +0 -1
- package/dist/utilities/theme/media.js +0 -21
- package/dist/utilities/theme/media.js.map +0 -1
- package/dist/utilities/theme/media.mjs +0 -21
- package/dist/utilities/theme/media.mjs.map +0 -1
- package/dist/utilities.d.ts +0 -2
- package/dist/utilities.js +0 -21
- package/dist/utilities.js.map +0 -1
- package/dist/utilities.mjs +0 -21
- 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;
|
|
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
|
|
3
|
-
require("
|
|
4
|
-
require("
|
|
5
|
-
require("
|
|
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
|
|
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 (${
|
|
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
|
|
2
|
-
import "
|
|
3
|
-
import "
|
|
4
|
-
import "
|
|
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 (${
|
|
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
|
-
|
|
2
|
-
|
|
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
|
-
|
|
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":"
|
|
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
|
-
|
|
3
|
-
const
|
|
4
|
-
const
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
|
|
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
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
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
|
|
37
|
-
const
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
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
|
|
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
|
|
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
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
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
|
|
35
|
-
const
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
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
|
-
|
|
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
|
|
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
|
-
|
|
3
|
-
export declare const CampaignStyles: string;
|
|
2
|
+
import { ElementVisual } from '../../../../_types';
|
|
4
3
|
export interface CampaignProps extends BaseProps {
|
|
5
4
|
}
|
|
6
|
-
|
|
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":"
|
|
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"}
|