@purpur/library 9.5.0 → 9.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.json +66 -0
- package/CHANGELOG.md +29 -1
- package/dist/LICENSE.txt +27 -6
- package/dist/ThemeProvider-D7oXcAde.js +2 -0
- package/dist/{ThemeProvider-Dy771oix.js.map → ThemeProvider-D7oXcAde.js.map} +1 -1
- package/dist/ThemeProvider-DiDBfyFA.mjs +348 -0
- package/dist/{ThemeProvider-CkX-BNWN.mjs.map → ThemeProvider-DiDBfyFA.mjs.map} +1 -1
- package/dist/avatar-CYnD57o4.js +2 -0
- package/dist/avatar-CYnD57o4.js.map +1 -0
- package/dist/avatar-CzbDD1MK.mjs +27 -0
- package/dist/avatar-CzbDD1MK.mjs.map +1 -0
- package/dist/avatar.cjs.js +2 -0
- package/dist/avatar.cjs.js.map +1 -0
- package/dist/avatar.es.js +5 -0
- package/dist/avatar.es.js.map +1 -0
- package/dist/carousel-BIKcwvYz.mjs +1658 -0
- package/dist/carousel-BIKcwvYz.mjs.map +1 -0
- package/dist/carousel-DnSaLDZf.js +2 -0
- package/dist/carousel-DnSaLDZf.js.map +1 -0
- package/dist/carousel.cjs.js +1 -1
- package/dist/carousel.es.js +1 -1
- package/dist/color-dot-BEE5rKco.js +2 -0
- package/dist/color-dot-BEE5rKco.js.map +1 -0
- package/dist/color-dot-Dz9yzVX3.mjs +28 -0
- package/dist/color-dot-Dz9yzVX3.mjs.map +1 -0
- package/dist/color-dot.cjs.js +1 -1
- package/dist/color-dot.es.js +4 -3
- package/dist/comparison-table-0UDB2BTU.js +2 -0
- package/dist/comparison-table-0UDB2BTU.js.map +1 -0
- package/dist/comparison-table-CjTE-fHN.mjs +292 -0
- package/dist/comparison-table-CjTE-fHN.mjs.map +1 -0
- package/dist/comparison-table.cjs.js +1 -1
- package/dist/comparison-table.es.js +1 -1
- package/dist/components/avatar/src/avatar-constants.d.ts +2 -0
- package/dist/components/avatar/src/avatar-constants.d.ts.map +1 -0
- package/dist/components/avatar/src/avatar.d.ts +26 -0
- package/dist/components/avatar/src/avatar.d.ts.map +1 -0
- package/dist/components/button/src/button.visual.fixtures.d.ts +43 -0
- package/dist/components/button/src/button.visual.fixtures.d.ts.map +1 -0
- package/dist/components/carousel/src/carousel.d.ts.map +1 -1
- package/dist/components/color-dot/src/color-dot.d.ts +18 -8
- package/dist/components/color-dot/src/color-dot.d.ts.map +1 -1
- package/dist/components/comparison-table/src/components/OptionCard/option-card.d.ts.map +1 -1
- package/dist/components/date-picker/src/date-picker.d.ts +8 -0
- package/dist/components/date-picker/src/date-picker.d.ts.map +1 -1
- package/dist/components/drawer/src/drawer-content.d.ts +21 -0
- package/dist/components/drawer/src/drawer-content.d.ts.map +1 -1
- package/dist/components/hero-banner/src/hero-banner.visual.fixtures.d.ts +14 -0
- package/dist/components/hero-banner/src/hero-banner.visual.fixtures.d.ts.map +1 -0
- package/dist/components/loading/src/loading-dots.d.ts +19 -0
- package/dist/components/loading/src/loading-dots.d.ts.map +1 -0
- package/dist/components/loading/src/loading-text.d.ts +21 -0
- package/dist/components/loading/src/loading-text.d.ts.map +1 -0
- package/dist/components/loading/src/loading.d.ts +10 -0
- package/dist/components/loading/src/loading.d.ts.map +1 -0
- package/dist/components/message/src/message-bubble.d.ts +22 -0
- package/dist/components/message/src/message-bubble.d.ts.map +1 -0
- package/dist/components/message/src/message-stamp.d.ts +26 -0
- package/dist/components/message/src/message-stamp.d.ts.map +1 -0
- package/dist/components/message/src/message-utils.d.ts +3 -0
- package/dist/components/message/src/message-utils.d.ts.map +1 -0
- package/dist/components/message/src/message.d.ts +42 -0
- package/dist/components/message/src/message.d.ts.map +1 -0
- package/dist/components/modal/src/modal-content.d.ts +21 -0
- package/dist/components/modal/src/modal-content.d.ts.map +1 -1
- package/dist/components/modal/src/modal.d.ts +2 -0
- package/dist/components/modal/src/modal.d.ts.map +1 -1
- package/dist/components/popover/src/popover-content.d.ts +14 -0
- package/dist/components/popover/src/popover-content.d.ts.map +1 -1
- package/dist/components/radio-card-group/src/is-radio-card-item.d.ts +4 -0
- package/dist/components/radio-card-group/src/is-radio-card-item.d.ts.map +1 -0
- package/dist/components/radio-card-group/src/radio-card-group.constants.d.ts +5 -0
- package/dist/components/radio-card-group/src/radio-card-group.constants.d.ts.map +1 -0
- package/dist/components/radio-card-group/src/radio-card-group.d.ts +5 -6
- package/dist/components/radio-card-group/src/radio-card-group.d.ts.map +1 -1
- package/dist/components/radio-card-group/src/radio-card-item.d.ts +1 -2
- package/dist/components/radio-card-group/src/radio-card-item.d.ts.map +1 -1
- package/dist/components/search-field/src/search-field-autocomplete.d.ts +6 -3
- package/dist/components/search-field/src/search-field-autocomplete.d.ts.map +1 -1
- package/dist/components/search-field/src/search-field-base.d.ts +10 -3
- package/dist/components/search-field/src/search-field-base.d.ts.map +1 -1
- package/dist/components/search-field/src/search-field-button.d.ts +3 -1
- package/dist/components/search-field/src/search-field-button.d.ts.map +1 -1
- package/dist/components/search-field/src/search-field.d.ts +12 -6
- package/dist/components/search-field/src/search-field.d.ts.map +1 -1
- package/dist/components/table/src/drag-indicator-circle.d.ts +8 -1
- package/dist/components/table/src/drag-indicator-circle.d.ts.map +1 -1
- package/dist/components/table/src/table.d.ts.map +1 -1
- package/dist/components/tooltip/src/tooltip.d.ts +21 -0
- package/dist/components/tooltip/src/tooltip.d.ts.map +1 -1
- package/dist/components-metadata.js +33 -4
- package/dist/date-picker-CIizn3Pv.js +2 -0
- package/dist/{date-picker-uyPKJulK.js.map → date-picker-CIizn3Pv.js.map} +1 -1
- package/dist/date-picker-DixxW60s.mjs +1617 -0
- package/dist/{date-picker-CzxhZxsw.mjs.map → date-picker-DixxW60s.mjs.map} +1 -1
- package/dist/date-picker.cjs.js +1 -1
- package/dist/date-picker.es.js +1 -1
- package/dist/drawer-BzkRd9F0.mjs +577 -0
- package/dist/drawer-BzkRd9F0.mjs.map +1 -0
- package/dist/drawer-DyhsP34o.js +2 -0
- package/dist/drawer-DyhsP34o.js.map +1 -0
- package/dist/drawer.cjs.js +1 -1
- package/dist/drawer.es.js +1 -1
- package/dist/{footer-D9AcPwlH.js → footer-3Y-664-8.js} +2 -2
- package/dist/{footer-D9AcPwlH.js.map → footer-3Y-664-8.js.map} +1 -1
- package/dist/{footer-BLPlXaZK.mjs → footer-DenAcikt.mjs} +3 -3
- package/dist/{footer-BLPlXaZK.mjs.map → footer-DenAcikt.mjs.map} +1 -1
- package/dist/footer.cjs.js +1 -1
- package/dist/footer.es.js +1 -1
- package/dist/{hero-banner-DkC_BqM7.mjs → hero-banner-B7xrDfzN.mjs} +2 -2
- package/dist/{hero-banner-DkC_BqM7.mjs.map → hero-banner-B7xrDfzN.mjs.map} +1 -1
- package/dist/{hero-banner-D1A-_qou.js → hero-banner-DthITuQ7.js} +2 -2
- package/dist/{hero-banner-D1A-_qou.js.map → hero-banner-DthITuQ7.js.map} +1 -1
- package/dist/hero-banner.cjs.js +1 -1
- package/dist/hero-banner.es.js +1 -1
- package/dist/libraries/library/src/avatar.d.ts +6 -0
- package/dist/libraries/library/src/avatar.d.ts.map +1 -0
- package/dist/libraries/library/src/library.d.ts +3 -0
- package/dist/libraries/library/src/library.d.ts.map +1 -1
- package/dist/libraries/library/src/loading.d.ts +6 -0
- package/dist/libraries/library/src/loading.d.ts.map +1 -0
- package/dist/libraries/library/src/message.d.ts +6 -0
- package/dist/libraries/library/src/message.d.ts.map +1 -0
- package/dist/libraries/theme/src/ThemeProvider.d.ts.map +1 -1
- package/dist/libraries/theme/src/theme.d.ts +1 -0
- package/dist/libraries/theme/src/theme.d.ts.map +1 -1
- package/dist/libraries/theme/src/types.d.ts +7 -0
- package/dist/libraries/theme/src/types.d.ts.map +1 -1
- package/dist/libraries/theme/src/useThemePortalContainer.d.ts +12 -0
- package/dist/libraries/theme/src/useThemePortalContainer.d.ts.map +1 -0
- package/dist/library.cjs.js +1 -1
- package/dist/library.es.js +630 -623
- package/dist/library.es.js.map +1 -1
- package/dist/loading-Dwtkjstg.js +2 -0
- package/dist/loading-Dwtkjstg.js.map +1 -0
- package/dist/loading-r23nxJSz.mjs +107 -0
- package/dist/loading-r23nxJSz.mjs.map +1 -0
- package/dist/loading.cjs.js +2 -0
- package/dist/loading.cjs.js.map +1 -0
- package/dist/loading.es.js +5 -0
- package/dist/loading.es.js.map +1 -0
- package/dist/message-0yTS5pOF.js +3 -0
- package/dist/message-0yTS5pOF.js.map +1 -0
- package/dist/message-D9CDwcw9.mjs +132 -0
- package/dist/message-D9CDwcw9.mjs.map +1 -0
- package/dist/message.cjs.js +2 -0
- package/dist/message.cjs.js.map +1 -0
- package/dist/message.es.js +5 -0
- package/dist/message.es.js.map +1 -0
- package/dist/modal-DJn9idcw.js +2 -0
- package/dist/modal-DJn9idcw.js.map +1 -0
- package/dist/{modal-fp37VbrH.mjs → modal-EIP36327.mjs} +83 -80
- package/dist/modal-EIP36327.mjs.map +1 -0
- package/dist/modal.cjs.js +1 -1
- package/dist/modal.es.js +1 -1
- package/dist/{popover-I26xNbTz.mjs → popover-DERrvReO.mjs} +328 -325
- package/dist/popover-DERrvReO.mjs.map +1 -0
- package/dist/popover-DnGgzfQr.js +2 -0
- package/dist/popover-DnGgzfQr.js.map +1 -0
- package/dist/popover.cjs.js +1 -1
- package/dist/popover.es.js +1 -1
- package/dist/{product-card-CoY1KggV.js → product-card-8X-Ld2d_.js} +2 -2
- package/dist/{product-card-CoY1KggV.js.map → product-card-8X-Ld2d_.js.map} +1 -1
- package/dist/{product-card-C3_N0t-R.mjs → product-card-Bt-F0wKr.mjs} +10 -10
- package/dist/{product-card-C3_N0t-R.mjs.map → product-card-Bt-F0wKr.mjs.map} +1 -1
- package/dist/product-card.cjs.js +1 -1
- package/dist/product-card.es.js +1 -1
- package/dist/{promotion-card-BiHnQvhn.mjs → promotion-card-BnzIVNQ4.mjs} +2 -2
- package/dist/{promotion-card-BiHnQvhn.mjs.map → promotion-card-BnzIVNQ4.mjs.map} +1 -1
- package/dist/{promotion-card-Bag64gqP.js → promotion-card-DKc2Cx1h.js} +2 -2
- package/dist/{promotion-card-Bag64gqP.js.map → promotion-card-DKc2Cx1h.js.map} +1 -1
- package/dist/promotion-card.cjs.js +1 -1
- package/dist/promotion-card.es.js +1 -1
- package/dist/purpur.css +1 -1
- package/dist/radio-card-group-ZBXjYcQs.mjs +166 -0
- package/dist/radio-card-group-ZBXjYcQs.mjs.map +1 -0
- package/dist/radio-card-group-nrDi5EPK.js +2 -0
- package/dist/radio-card-group-nrDi5EPK.js.map +1 -0
- package/dist/radio-card-group.cjs.js +1 -1
- package/dist/radio-card-group.es.js +3 -5
- package/dist/search-field-2vdDbiT0.js +2 -0
- package/dist/search-field-2vdDbiT0.js.map +1 -0
- package/dist/search-field-DKyNh7pE.mjs +167 -0
- package/dist/search-field-DKyNh7pE.mjs.map +1 -0
- package/dist/search-field.cjs.js +1 -1
- package/dist/search-field.es.js +1 -1
- package/dist/{stepper-CWR2vGPj.mjs → stepper-BDsSa6yr.mjs} +2 -2
- package/dist/{stepper-CWR2vGPj.mjs.map → stepper-BDsSa6yr.mjs.map} +1 -1
- package/dist/{stepper-Df4X7DDR.js → stepper-DpauItjx.js} +2 -2
- package/dist/{stepper-Df4X7DDR.js.map → stepper-DpauItjx.js.map} +1 -1
- package/dist/stepper.cjs.js +1 -1
- package/dist/stepper.es.js +1 -1
- package/dist/{table-gnGUejtb.js → table-BOCcBzSO.js} +4 -4
- package/dist/table-BOCcBzSO.js.map +1 -0
- package/dist/{table-g_n68i4s.mjs → table-i1Gs9e0e.mjs} +440 -440
- package/dist/table-i1Gs9e0e.mjs.map +1 -0
- package/dist/table.cjs.js +1 -1
- package/dist/table.es.js +1 -1
- package/dist/{text-area-peNKG7g4.js → text-area-D0truMT1.js} +2 -2
- package/dist/{text-area-peNKG7g4.js.map → text-area-D0truMT1.js.map} +1 -1
- package/dist/{text-area-kJvg6cFp.mjs → text-area-IVH-k4MM.mjs} +3 -3
- package/dist/{text-area-kJvg6cFp.mjs.map → text-area-IVH-k4MM.mjs.map} +1 -1
- package/dist/text-area.cjs.js +1 -1
- package/dist/text-area.es.js +1 -1
- package/dist/theme.cjs.js +1 -1
- package/dist/theme.es.js +8 -6
- package/dist/theme.es.js.map +1 -1
- package/dist/tooltip-CJGmJDFQ.js +2 -0
- package/dist/{tooltip-C8Zxnqdb.js.map → tooltip-CJGmJDFQ.js.map} +1 -1
- package/dist/{tooltip-LU2Cy-QC.mjs → tooltip-RA-03bKs.mjs} +277 -274
- package/dist/{tooltip-LU2Cy-QC.mjs.map → tooltip-RA-03bKs.mjs.map} +1 -1
- package/dist/tooltip.cjs.js +1 -1
- package/dist/tooltip.es.js +1 -1
- package/dist/{useColorScheme-tAkY9LHt.mjs → useColorScheme-B9DWd-LN.mjs} +2 -2
- package/dist/{useColorScheme-tAkY9LHt.mjs.map → useColorScheme-B9DWd-LN.mjs.map} +1 -1
- package/dist/useColorScheme-DbTQjxNB.js +2 -0
- package/dist/{useColorScheme-DNyjsWX9.js.map → useColorScheme-DbTQjxNB.js.map} +1 -1
- package/dist/useThemePortalContainer-D9BYjEvT.js +2 -0
- package/dist/useThemePortalContainer-D9BYjEvT.js.map +1 -0
- package/dist/useThemePortalContainer-tFLTaYKN.mjs +9 -0
- package/dist/useThemePortalContainer-tFLTaYKN.mjs.map +1 -0
- package/package.json +27 -24
- package/src/aliases.ts +12 -0
- package/src/avatar.ts +6 -0
- package/src/entries.js +3 -0
- package/src/library.ts +5 -68
- package/src/loading.ts +6 -0
- package/src/message.ts +6 -0
- package/dist/ThemeProvider-CkX-BNWN.mjs +0 -337
- package/dist/ThemeProvider-Dy771oix.js +0 -2
- package/dist/carousel-DLkTL9sj.mjs +0 -1633
- package/dist/carousel-DLkTL9sj.mjs.map +0 -1
- package/dist/carousel-DXrtxRz5.js +0 -2
- package/dist/carousel-DXrtxRz5.js.map +0 -1
- package/dist/color-dot-6Mxngvce.mjs +0 -34
- package/dist/color-dot-6Mxngvce.mjs.map +0 -1
- package/dist/color-dot-B9w_ucWb.js +0 -2
- package/dist/color-dot-B9w_ucWb.js.map +0 -1
- package/dist/comparison-table-C74IAVqz.js +0 -2
- package/dist/comparison-table-C74IAVqz.js.map +0 -1
- package/dist/comparison-table-DctKxmX9.mjs +0 -267
- package/dist/comparison-table-DctKxmX9.mjs.map +0 -1
- package/dist/date-picker-CzxhZxsw.mjs +0 -1611
- package/dist/date-picker-uyPKJulK.js +0 -2
- package/dist/drawer-8Acg4wkV.mjs +0 -574
- package/dist/drawer-8Acg4wkV.mjs.map +0 -1
- package/dist/drawer-BLHgcEqb.js +0 -2
- package/dist/drawer-BLHgcEqb.js.map +0 -1
- package/dist/modal-Baisuc6m.js +0 -2
- package/dist/modal-Baisuc6m.js.map +0 -1
- package/dist/modal-fp37VbrH.mjs.map +0 -1
- package/dist/popover-B0XJZ5mj.js +0 -2
- package/dist/popover-B0XJZ5mj.js.map +0 -1
- package/dist/popover-I26xNbTz.mjs.map +0 -1
- package/dist/radio-card-group-CneOprGY.mjs +0 -168
- package/dist/radio-card-group-CneOprGY.mjs.map +0 -1
- package/dist/radio-card-group-Ctuvg61o.js +0 -2
- package/dist/radio-card-group-Ctuvg61o.js.map +0 -1
- package/dist/search-field-CpkHGIYi.mjs +0 -151
- package/dist/search-field-CpkHGIYi.mjs.map +0 -1
- package/dist/search-field-Z0PqDARl.js +0 -2
- package/dist/search-field-Z0PqDARl.js.map +0 -1
- package/dist/table-g_n68i4s.mjs.map +0 -1
- package/dist/table-gnGUejtb.js.map +0 -1
- package/dist/tooltip-C8Zxnqdb.js +0 -2
- package/dist/useColorScheme-DNyjsWX9.js +0 -2
- package/tokens/_dark.scss +0 -9
- package/tokens/_index.scss +0 -9
- package/tokens/border/variables.css +0 -13
- package/tokens/border/variables.d.ts +0 -10
- package/tokens/border/variables.dark.css +0 -12
- package/tokens/border/variables.dark.d.ts +0 -10
- package/tokens/border/variables.dark.js +0 -10
- package/tokens/border/variables.dark.json +0 -18
- package/tokens/border/variables.dark.scss +0 -10
- package/tokens/border/variables.js +0 -10
- package/tokens/border/variables.json +0 -18
- package/tokens/border/variables.scss +0 -10
- package/tokens/breakpoint/variables.css +0 -11
- package/tokens/breakpoint/variables.d.ts +0 -8
- package/tokens/breakpoint/variables.dark.css +0 -10
- package/tokens/breakpoint/variables.dark.d.ts +0 -8
- package/tokens/breakpoint/variables.dark.js +0 -8
- package/tokens/breakpoint/variables.dark.json +0 -14
- package/tokens/breakpoint/variables.dark.scss +0 -8
- package/tokens/breakpoint/variables.js +0 -8
- package/tokens/breakpoint/variables.json +0 -14
- package/tokens/breakpoint/variables.scss +0 -8
- package/tokens/color/variables.css +0 -262
- package/tokens/color/variables.d.ts +0 -253
- package/tokens/color/variables.dark.css +0 -262
- package/tokens/color/variables.dark.d.ts +0 -252
- package/tokens/color/variables.dark.js +0 -252
- package/tokens/color/variables.dark.json +0 -306
- package/tokens/color/variables.dark.scss +0 -252
- package/tokens/color/variables.js +0 -253
- package/tokens/color/variables.json +0 -307
- package/tokens/color/variables.scss +0 -253
- package/tokens/dark.css +0 -9
- package/tokens/dark.d.ts +0 -9
- package/tokens/dark.js +0 -9
- package/tokens/filter/variables.css +0 -4
- package/tokens/filter/variables.d.ts +0 -1
- package/tokens/filter/variables.dark.css +0 -3
- package/tokens/filter/variables.dark.d.ts +0 -1
- package/tokens/filter/variables.dark.js +0 -1
- package/tokens/filter/variables.dark.json +0 -7
- package/tokens/filter/variables.dark.scss +0 -1
- package/tokens/filter/variables.js +0 -1
- package/tokens/filter/variables.json +0 -7
- package/tokens/filter/variables.scss +0 -1
- package/tokens/gradient/variables.css +0 -53
- package/tokens/gradient/variables.d.ts +0 -9
- package/tokens/gradient/variables.dark.css +0 -51
- package/tokens/gradient/variables.dark.d.ts +0 -9
- package/tokens/gradient/variables.dark.js +0 -18
- package/tokens/gradient/variables.dark.json +0 -27
- package/tokens/gradient/variables.dark.scss +0 -36
- package/tokens/gradient/variables.js +0 -18
- package/tokens/gradient/variables.json +0 -27
- package/tokens/gradient/variables.scss +0 -42
- package/tokens/index.css +0 -18
- package/tokens/index.d.ts +0 -9
- package/tokens/index.js +0 -9
- package/tokens/motion/variables.css +0 -14
- package/tokens/motion/variables.d.ts +0 -11
- package/tokens/motion/variables.dark.css +0 -13
- package/tokens/motion/variables.dark.d.ts +0 -11
- package/tokens/motion/variables.dark.js +0 -11
- package/tokens/motion/variables.dark.json +0 -19
- package/tokens/motion/variables.dark.scss +0 -11
- package/tokens/motion/variables.js +0 -11
- package/tokens/motion/variables.json +0 -19
- package/tokens/motion/variables.scss +0 -11
- package/tokens/shadow/variables.css +0 -11
- package/tokens/shadow/variables.d.ts +0 -4
- package/tokens/shadow/variables.dark.css +0 -10
- package/tokens/shadow/variables.dark.d.ts +0 -4
- package/tokens/shadow/variables.dark.js +0 -4
- package/tokens/shadow/variables.dark.json +0 -8
- package/tokens/shadow/variables.dark.scss +0 -4
- package/tokens/shadow/variables.js +0 -4
- package/tokens/shadow/variables.json +0 -8
- package/tokens/shadow/variables.scss +0 -4
- package/tokens/spacing/variables.css +0 -26
- package/tokens/spacing/variables.d.ts +0 -23
- package/tokens/spacing/variables.dark.css +0 -17
- package/tokens/spacing/variables.dark.d.ts +0 -15
- package/tokens/spacing/variables.dark.js +0 -15
- package/tokens/spacing/variables.dark.json +0 -19
- package/tokens/spacing/variables.dark.scss +0 -15
- package/tokens/spacing/variables.js +0 -23
- package/tokens/spacing/variables.json +0 -31
- package/tokens/spacing/variables.scss +0 -23
- package/tokens/typography/variables.css +0 -30
- package/tokens/typography/variables.d.ts +0 -26
- package/tokens/typography/variables.dark.css +0 -29
- package/tokens/typography/variables.dark.d.ts +0 -26
- package/tokens/typography/variables.dark.js +0 -28
- package/tokens/typography/variables.dark.json +0 -38
- package/tokens/typography/variables.dark.scss +0 -26
- package/tokens/typography/variables.js +0 -28
- package/tokens/typography/variables.json +0 -38
- package/tokens/typography/variables.scss +0 -26
|
@@ -1,267 +0,0 @@
|
|
|
1
|
-
import { jsx as e, jsxs as p } from "react/jsx-runtime";
|
|
2
|
-
import { isValidElement as q, useState as O, useCallback as S, useEffect as F, useId as B, useRef as L, createElement as H } from "react";
|
|
3
|
-
import { c as z } from "./bind-CU-R61T-.mjs";
|
|
4
|
-
import { a as K } from "./checkmark.es-DdgIZN2R.mjs";
|
|
5
|
-
import { e as W } from "./minus.es-BK9qA9iJ.mjs";
|
|
6
|
-
import { l as R } from "./chevron-down.es-PCIIj6oG.mjs";
|
|
7
|
-
import { P as j } from "./paragraph-DSxXmX_0.mjs";
|
|
8
|
-
import { a as G } from "./badge-DalD-yqG.mjs";
|
|
9
|
-
import { b as M } from "./button-4-yWOgtD.mjs";
|
|
10
|
-
import { H as J } from "./heading-xwBuT_-9.mjs";
|
|
11
|
-
import { l as Q } from "./arrow-left.es-DU-PX-Il.mjs";
|
|
12
|
-
import { i as U } from "./arrow-right.es-C7SkjAB6.mjs";
|
|
13
|
-
const X = {
|
|
14
|
-
"purpur-comparison-table__wrapper": "_purpur-comparison-table__wrapper_1udkj_1",
|
|
15
|
-
"purpur-comparison-table": "_purpur-comparison-table_1udkj_1",
|
|
16
|
-
"purpur-comparison-table--primary": "_purpur-comparison-table--primary_1udkj_11",
|
|
17
|
-
"purpur-comparison-table--secondary": "_purpur-comparison-table--secondary_1udkj_15",
|
|
18
|
-
"purpur-comparison-table__feature-row": "_purpur-comparison-table__feature-row_1udkj_32",
|
|
19
|
-
"purpur-comparison-table__cards": "_purpur-comparison-table__cards_1udkj_32",
|
|
20
|
-
"purpur-comparison-table__separator": "_purpur-comparison-table__separator_1udkj_49"
|
|
21
|
-
}, Y = {
|
|
22
|
-
"purpur-comparison-table-cell": "_purpur-comparison-table-cell_117pb_1",
|
|
23
|
-
"purpur-comparison-table-cell--check": "_purpur-comparison-table-cell--check_117pb_16",
|
|
24
|
-
"purpur-comparison-table-cell--minus": "_purpur-comparison-table-cell--minus_117pb_19",
|
|
25
|
-
"purpur-comparison-table-cell__icon": "_purpur-comparison-table-cell__icon_117pb_22"
|
|
26
|
-
}, A = z.bind(Y), D = "purpur-comparison-table-cell", Z = ({ value: a }) => {
|
|
27
|
-
const s = q(a) || ["string", "number"].includes(typeof a), t = A(D, [s ? "" : `${D}--${a ? "check" : "minus"}`]), N = a ? K : W;
|
|
28
|
-
return /* @__PURE__ */ e("span", { className: A(t), children: s ? a : /* @__PURE__ */ e(N, { size: "xs", className: A(`${D}__icon`) }) });
|
|
29
|
-
}, rr = {
|
|
30
|
-
"purpur-comparison-table-lead-cell": "_purpur-comparison-table-lead-cell_1vild_1",
|
|
31
|
-
"purpur-comparison-table-lead-cell__description": "_purpur-comparison-table-lead-cell__description_1vild_5",
|
|
32
|
-
"purpur-comparison-table-lead-cell__summary": "_purpur-comparison-table-lead-cell__summary_1vild_40",
|
|
33
|
-
"purpur-comparison-table-lead-cell__summary-title": "_purpur-comparison-table-lead-cell__summary-title_1vild_48",
|
|
34
|
-
"purpur-comparison-table-lead-cell__summary-icon": "_purpur-comparison-table-lead-cell__summary-icon_1vild_51"
|
|
35
|
-
}, k = z.bind(rr), C = "purpur-comparison-table-lead-cell", or = ({ title: a, description: s }) => {
|
|
36
|
-
const i = typeof s == "string", t = k(C);
|
|
37
|
-
return /* @__PURE__ */ p("details", { className: t, "data-is-expandable": i, children: [
|
|
38
|
-
/* @__PURE__ */ p("summary", { className: k(`${C}__summary`), tabIndex: i ? 0 : -1, children: [
|
|
39
|
-
/* @__PURE__ */ e(j, { className: k(`${C}__summary-title`), variant: "paragraph-100-bold", children: a }),
|
|
40
|
-
/* @__PURE__ */ e(R, { className: k(`${C}__summary-icon`), size: "sm" })
|
|
41
|
-
] }),
|
|
42
|
-
s && /* @__PURE__ */ e(j, { variant: "paragraph-100", className: k(`${C}__description`), children: s })
|
|
43
|
-
] });
|
|
44
|
-
}, er = {
|
|
45
|
-
"purpur-comparison-table-option-card": "_purpur-comparison-table-option-card_15113_1",
|
|
46
|
-
"purpur-comparison-table-option-card--highlighted": "_purpur-comparison-table-option-card--highlighted_15113_11",
|
|
47
|
-
"purpur-comparison-table-option-card__badge": "_purpur-comparison-table-option-card__badge_15113_14",
|
|
48
|
-
"purpur-comparison-table-option-card__main-content": "_purpur-comparison-table-option-card__main-content_15113_19",
|
|
49
|
-
"purpur-comparison-table-option-card__image": "_purpur-comparison-table-option-card__image_15113_25",
|
|
50
|
-
"purpur-comparison-table-option-card__body": "_purpur-comparison-table-option-card__body_15113_31",
|
|
51
|
-
"purpur-comparison-table-option-card__description": "_purpur-comparison-table-option-card__description_15113_36",
|
|
52
|
-
"purpur-comparison-table-option-card__description-text": "_purpur-comparison-table-option-card__description-text_15113_41",
|
|
53
|
-
"purpur-comparison-table-option-card__read-more": "_purpur-comparison-table-option-card__read-more_15113_50",
|
|
54
|
-
"purpur-comparison-table-option-card__read-more-icon": "_purpur-comparison-table-option-card__read-more-icon_15113_54",
|
|
55
|
-
"purpur-comparison-table-option-card__footer": "_purpur-comparison-table-option-card__footer_15113_62",
|
|
56
|
-
"purpur-comparison-table-option-card__price": "_purpur-comparison-table-option-card__price_15113_67",
|
|
57
|
-
"purpur-comparison-table-option-card--show-full-descriptions": "_purpur-comparison-table-option-card--show-full-descriptions_15113_74",
|
|
58
|
-
"purpur-comparison-table-option-card--first-card": "_purpur-comparison-table-option-card--first-card_15113_107"
|
|
59
|
-
}, d = z.bind(er), l = "purpur-comparison-table-option-card", ar = ({
|
|
60
|
-
id: a,
|
|
61
|
-
cardIndex: s,
|
|
62
|
-
description: i,
|
|
63
|
-
variablePriceText: t,
|
|
64
|
-
price: N,
|
|
65
|
-
isHighlighted: b,
|
|
66
|
-
ariaLabels: g,
|
|
67
|
-
badge: h,
|
|
68
|
-
actions: v,
|
|
69
|
-
isFirstCard: w,
|
|
70
|
-
image: r,
|
|
71
|
-
title: n,
|
|
72
|
-
showFullDescriptions: m,
|
|
73
|
-
toggleShowFullDescriptions: _
|
|
74
|
-
}) => {
|
|
75
|
-
const u = d(l, {
|
|
76
|
-
[`${l}--highlighted`]: b,
|
|
77
|
-
[`${l}--first-card`]: w,
|
|
78
|
-
[`${l}--show-full-descriptions`]: m
|
|
79
|
-
}), c = () => {
|
|
80
|
-
if (!i) return null;
|
|
81
|
-
const f = i.length > 50;
|
|
82
|
-
return /* @__PURE__ */ p("div", { className: d(`${l}__description`), children: [
|
|
83
|
-
/* @__PURE__ */ e(j, { variant: "paragraph-100", className: d(`${l}__description-text`), children: i }),
|
|
84
|
-
f && /* @__PURE__ */ p(
|
|
85
|
-
M,
|
|
86
|
-
{
|
|
87
|
-
variant: "text",
|
|
88
|
-
size: "xs",
|
|
89
|
-
className: d(`${l}__read-more`),
|
|
90
|
-
onClick: _,
|
|
91
|
-
children: [
|
|
92
|
-
/* @__PURE__ */ e("span", { className: d(`${l}__read-more-text`), children: m ? g.readLess : g.readMore }),
|
|
93
|
-
/* @__PURE__ */ e(R, { className: d(`${l}__read-more-icon`), size: "xs" })
|
|
94
|
-
]
|
|
95
|
-
}
|
|
96
|
-
)
|
|
97
|
-
] });
|
|
98
|
-
};
|
|
99
|
-
return /* @__PURE__ */ p("article", { className: u, "data-card-id": a, "data-card-index": s, children: [
|
|
100
|
-
h && /* @__PURE__ */ e(G, { ...h, className: d(`${l}__badge`) }),
|
|
101
|
-
/* @__PURE__ */ p("section", { className: d(`${l}__main-content`), children: [
|
|
102
|
-
/* @__PURE__ */ e("img", { src: r.src, alt: r.alt, className: d(`${l}__image`) }),
|
|
103
|
-
/* @__PURE__ */ p("div", { className: d(`${l}__body`), children: [
|
|
104
|
-
/* @__PURE__ */ e(J, { tag: "h3", variant: "title-200", className: d(`${l}__title`), children: n }),
|
|
105
|
-
c()
|
|
106
|
-
] })
|
|
107
|
-
] }),
|
|
108
|
-
/* @__PURE__ */ p("footer", { className: d(`${l}__footer`), children: [
|
|
109
|
-
/* @__PURE__ */ p("span", { className: d(`${l}__price`), id: a, children: [
|
|
110
|
-
/* @__PURE__ */ e(j, { variant: "paragraph-100", children: t }),
|
|
111
|
-
/* @__PURE__ */ e(j, { variant: "paragraph-100-bold", children: N })
|
|
112
|
-
] }),
|
|
113
|
-
v
|
|
114
|
-
] })
|
|
115
|
-
] });
|
|
116
|
-
}, tr = "_active_ybbe8_44", sr = {
|
|
117
|
-
"purpur-comparison-table-scroll-progress": "_purpur-comparison-table-scroll-progress_ybbe8_1",
|
|
118
|
-
"purpur-comparison-table-scroll-progress__indicators": "_purpur-comparison-table-scroll-progress__indicators_ybbe8_15",
|
|
119
|
-
"purpur-comparison-table-scroll-progress__indicator": "_purpur-comparison-table-scroll-progress__indicator_ybbe8_15",
|
|
120
|
-
active: tr,
|
|
121
|
-
"purpur-comparison-table-scroll-progress__buttons": "_purpur-comparison-table-scroll-progress__buttons_ybbe8_48",
|
|
122
|
-
"purpur-comparison-table-scroll-progress__button": "_purpur-comparison-table-scroll-progress__button_ybbe8_48",
|
|
123
|
-
"purpur-comparison-table-scroll-progress__button-icon": "_purpur-comparison-table-scroll-progress__button-icon_ybbe8_57"
|
|
124
|
-
}, y = z.bind(sr), $ = "purpur-comparison-table-scroll-progress", cr = ({ items: a, container: s, ariaLabels: i }) => {
|
|
125
|
-
const [t, N] = O(/* @__PURE__ */ new Set()), b = S(
|
|
126
|
-
(r) => {
|
|
127
|
-
const n = window.matchMedia("(prefers-reduced-motion: reduce)").matches;
|
|
128
|
-
s.current?.querySelector(
|
|
129
|
-
`[data-card-index="${r}"]`
|
|
130
|
-
)?.scrollIntoView({ behavior: n ? "instant" : "smooth", block: "nearest" });
|
|
131
|
-
},
|
|
132
|
-
[s]
|
|
133
|
-
), g = S(() => {
|
|
134
|
-
if (t.size === 0) return;
|
|
135
|
-
const n = Math.min(...Array.from(t)) - 1;
|
|
136
|
-
n < 0 || b(n);
|
|
137
|
-
}, [t, b]), h = S(() => {
|
|
138
|
-
if (t.size === 0) return;
|
|
139
|
-
const n = Math.max(...Array.from(t)) + 1;
|
|
140
|
-
n >= a.length || b(n);
|
|
141
|
-
}, [t, a.length, b]), v = S(
|
|
142
|
-
(r) => {
|
|
143
|
-
(r.key === "ArrowRight" || r.key === "ArrowLeft") && (r.preventDefault(), r.key === "ArrowRight" ? h() : r.key === "ArrowLeft" && g());
|
|
144
|
-
},
|
|
145
|
-
[h, g]
|
|
146
|
-
);
|
|
147
|
-
F(() => {
|
|
148
|
-
const r = s.current;
|
|
149
|
-
if (!r) return;
|
|
150
|
-
const n = new IntersectionObserver(
|
|
151
|
-
(m) => {
|
|
152
|
-
N((_) => {
|
|
153
|
-
const u = new Set(_);
|
|
154
|
-
return m.forEach((c) => {
|
|
155
|
-
const o = Number(c.target.getAttribute("data-card-index"));
|
|
156
|
-
Number.isNaN(o) || (c.isIntersecting ? u.add(o) : u.delete(o));
|
|
157
|
-
}), u;
|
|
158
|
-
});
|
|
159
|
-
},
|
|
160
|
-
{ root: r, threshold: 0.5 }
|
|
161
|
-
);
|
|
162
|
-
return a.forEach((m, _) => {
|
|
163
|
-
const u = r.querySelector(`[data-card-index="${_}"]`);
|
|
164
|
-
u && n.observe(u);
|
|
165
|
-
}), () => n.disconnect();
|
|
166
|
-
}, [s, a]), F(() => {
|
|
167
|
-
const r = s.current;
|
|
168
|
-
if (r)
|
|
169
|
-
return r.addEventListener("keydown", v), () => r.removeEventListener("keydown", v);
|
|
170
|
-
}, [s, v]);
|
|
171
|
-
const w = () => {
|
|
172
|
-
if (t.size === 0) return;
|
|
173
|
-
const r = [], n = t.size, m = Math.min(...Array.from(t)), _ = a.slice(0, m).length, u = a.slice(m + n).length;
|
|
174
|
-
let c = 0;
|
|
175
|
-
for (let o = 0; o < a.length; o++) {
|
|
176
|
-
if (_ + 1 !== o && _ <= o && o < a.length - u) continue;
|
|
177
|
-
let f = "active";
|
|
178
|
-
(o < _ || o > a.length - 1 - u) && (f = ""), r.push(
|
|
179
|
-
/* @__PURE__ */ e("li", { className: y(`${$}__indicator`, f) }, `indicator-${c++}`)
|
|
180
|
-
);
|
|
181
|
-
}
|
|
182
|
-
return r.length < 2 ? null : r;
|
|
183
|
-
};
|
|
184
|
-
return /* @__PURE__ */ p("li", { className: y($), children: [
|
|
185
|
-
/* @__PURE__ */ e("ul", { className: y(`${$}__indicators`), children: w() }),
|
|
186
|
-
/* @__PURE__ */ p("div", { className: y(`${$}__buttons`), children: [
|
|
187
|
-
/* @__PURE__ */ e(
|
|
188
|
-
M,
|
|
189
|
-
{
|
|
190
|
-
"aria-label": i.previous,
|
|
191
|
-
variant: "secondary",
|
|
192
|
-
iconOnly: !0,
|
|
193
|
-
className: y(`${$}__button`),
|
|
194
|
-
disabled: t.has(0),
|
|
195
|
-
onClick: g,
|
|
196
|
-
children: /* @__PURE__ */ e(Q, { className: y(`${$}__button-icon`), size: "xs" })
|
|
197
|
-
}
|
|
198
|
-
),
|
|
199
|
-
/* @__PURE__ */ e(
|
|
200
|
-
M,
|
|
201
|
-
{
|
|
202
|
-
"aria-label": i.next,
|
|
203
|
-
variant: "secondary",
|
|
204
|
-
iconOnly: !0,
|
|
205
|
-
className: y(`${$}__button`),
|
|
206
|
-
disabled: t.has(a.length - 1),
|
|
207
|
-
onClick: h,
|
|
208
|
-
children: /* @__PURE__ */ e(U, { className: y(`${$}__button-icon`), size: "xs" })
|
|
209
|
-
}
|
|
210
|
-
)
|
|
211
|
-
] })
|
|
212
|
-
] });
|
|
213
|
-
}, I = z.bind(X), x = "purpur-comparison-table", nr = ({
|
|
214
|
-
classname: a,
|
|
215
|
-
features: s,
|
|
216
|
-
items: i,
|
|
217
|
-
ariaLabels: t,
|
|
218
|
-
variant: N = "primary"
|
|
219
|
-
}) => {
|
|
220
|
-
const b = B(), g = I(a, x, `${x}--${N}`), h = L(null), [v, w] = O(!1), r = S(() => {
|
|
221
|
-
w((c) => !c);
|
|
222
|
-
}, []), n = () => /* @__PURE__ */ p("li", { className: I(`${x}__cards`), children: [
|
|
223
|
-
/* @__PURE__ */ e("div", { className: I(`${x}__separator`) }),
|
|
224
|
-
i.map((c, o) => /* @__PURE__ */ H(
|
|
225
|
-
ar,
|
|
226
|
-
{
|
|
227
|
-
...c,
|
|
228
|
-
showFullDescriptions: v,
|
|
229
|
-
toggleShowFullDescriptions: r,
|
|
230
|
-
key: o,
|
|
231
|
-
isFirstCard: o === 0,
|
|
232
|
-
ariaLabels: t,
|
|
233
|
-
cardIndex: o,
|
|
234
|
-
id: `${o}-${b}`
|
|
235
|
-
}
|
|
236
|
-
))
|
|
237
|
-
] }), m = () => Object.entries(s).map(([c, o], f) => /* @__PURE__ */ p("li", { className: I(`${x}__feature-row`), children: [
|
|
238
|
-
/* @__PURE__ */ e(or, { title: c, description: o }),
|
|
239
|
-
i.map((E, T) => /* @__PURE__ */ e(Z, { value: E.features[c] ?? !1 }, T))
|
|
240
|
-
] }, f)), _ = L(0), u = (c) => {
|
|
241
|
-
const o = c.currentTarget, f = o.querySelector("[data-card-id]")?.clientWidth ?? 0, E = Math.round(o.scrollLeft / f), T = E * f + E, P = c.timeStamp - _.current, V = Math.abs(o.scrollLeft - T);
|
|
242
|
-
_.current && P < 200 || V < 10 || (_.current = c.timeStamp, o.scrollTo({ left: T, behavior: "smooth" }));
|
|
243
|
-
};
|
|
244
|
-
return /* @__PURE__ */ e("div", { className: I(x + "__wrapper"), children: /* @__PURE__ */ p(
|
|
245
|
-
"ul",
|
|
246
|
-
{
|
|
247
|
-
id: x + `-${b}`,
|
|
248
|
-
ref: h,
|
|
249
|
-
className: g,
|
|
250
|
-
onScrollEnd: u,
|
|
251
|
-
style: {
|
|
252
|
-
// @ts-expect-error | Typescript doesn't recognize the CSS variable, but it works as intended
|
|
253
|
-
"--initial-columns": i.length + 1
|
|
254
|
-
},
|
|
255
|
-
children: [
|
|
256
|
-
/* @__PURE__ */ e(cr, { items: i, container: h, ariaLabels: t }),
|
|
257
|
-
n(),
|
|
258
|
-
m()
|
|
259
|
-
]
|
|
260
|
-
}
|
|
261
|
-
) });
|
|
262
|
-
};
|
|
263
|
-
nr.displayName = "ComparisonTable";
|
|
264
|
-
export {
|
|
265
|
-
nr as C
|
|
266
|
-
};
|
|
267
|
-
//# sourceMappingURL=comparison-table-DctKxmX9.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"comparison-table-DctKxmX9.mjs","sources":["../../../components/comparison-table/src/components/Cell/cell.tsx","../../../components/comparison-table/src/components/LeadCell/lead-cell.tsx","../../../components/comparison-table/src/components/OptionCard/option-card.tsx","../../../components/comparison-table/src/components/ScrollProgress/scroll-progress.tsx","../../../components/comparison-table/src/comparison-table.tsx"],"sourcesContent":["import React, { isValidElement, type ReactNode } from \"react\";\nimport { IconCheckmark } from \"@purpur/icon/checkmark\";\nimport { IconMinus } from \"@purpur/icon/minus\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./cell.module.scss\";\n\ntype CellProps = {\n value: boolean | ReactNode;\n};\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table-cell\";\n\nexport const Cell = ({ value }: CellProps) => {\n const isReactNode = isValidElement(value) || [\"string\", \"number\"].includes(typeof value);\n\n const getClassName = () => {\n if (isReactNode) return \"\";\n return `${rootClassName}--${value ? \"check\" : \"minus\"}`;\n };\n\n const classes = cx(rootClassName, [getClassName()]);\n\n const Icon = value ? IconCheckmark : IconMinus;\n\n return (\n <span className={cx(classes)}>\n {isReactNode ? value : <Icon size=\"xs\" className={cx(`${rootClassName}__icon`)} />}\n </span>\n );\n};\n","import React, { type ReactNode } from \"react\";\nimport { IconChevronDown } from \"@purpur/icon/chevron-down\";\nimport { Paragraph } from \"@purpur/paragraph\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./lead-cell.module.scss\";\n\ntype LeadCellProps = {\n title: string;\n description?: ReactNode;\n};\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table-lead-cell\";\n\nexport const LeadCell = ({ title, description }: LeadCellProps) => {\n const isExpandable = typeof description === \"string\";\n const classes = cx(rootClassName);\n\n return (\n <details className={classes} data-is-expandable={isExpandable}>\n <summary className={cx(`${rootClassName}__summary`)} tabIndex={isExpandable ? 0 : -1}>\n <Paragraph className={cx(`${rootClassName}__summary-title`)} variant=\"paragraph-100-bold\">\n {title}\n </Paragraph>\n <IconChevronDown className={cx(`${rootClassName}__summary-icon`)} size=\"sm\" />\n </summary>\n {description && (\n <Paragraph variant=\"paragraph-100\" className={cx(`${rootClassName}__description`)}>\n {description}\n </Paragraph>\n )}\n </details>\n );\n};\n","import React, { type ReactNode } from \"react\";\nimport { Badge, type BadgeProps } from \"@purpur/badge\";\nimport { Button } from \"@purpur/button\";\nimport { Heading } from \"@purpur/heading\";\nimport { IconChevronDown } from \"@purpur/icon/chevron-down\";\nimport { Paragraph } from \"@purpur/paragraph\";\nimport c from \"classnames/bind\";\n\nimport { type ComparisonTableProps } from \"../../comparison-table\";\nimport styles from \"./option-card.module.scss\";\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table-option-card\";\n\nexport type OptionCardProps = {\n image: {\n src: string;\n alt: string;\n };\n\n title: string;\n description: string;\n variablePriceText: string;\n price: string;\n\n actions: ReactNode;\n\n badge?: BadgeProps;\n isHighlighted?: boolean;\n};\n\ntype OptionCardPropsAdditions = {\n id: string;\n cardIndex: number;\n isFirstCard: boolean;\n ariaLabels: ComparisonTableProps[\"ariaLabels\"];\n\n showFullDescriptions: boolean;\n toggleShowFullDescriptions: () => void;\n};\n\nexport const OptionCard = ({\n id,\n cardIndex,\n description,\n variablePriceText,\n price,\n isHighlighted,\n ariaLabels,\n badge,\n actions,\n isFirstCard,\n image,\n title,\n showFullDescriptions,\n toggleShowFullDescriptions,\n}: OptionCardProps & OptionCardPropsAdditions) => {\n const classes = cx(rootClassName, {\n [`${rootClassName}--highlighted`]: isHighlighted,\n [`${rootClassName}--first-card`]: isFirstCard,\n [`${rootClassName}--show-full-descriptions`]: showFullDescriptions,\n });\n\n const renderDescription = () => {\n if (!description) return null;\n\n const longThreshold = 50;\n const longDescription = description.length > longThreshold;\n\n return (\n <div className={cx(`${rootClassName}__description`)}>\n <Paragraph variant=\"paragraph-100\" className={cx(`${rootClassName}__description-text`)}>\n {description}\n </Paragraph>\n {longDescription && (\n <Button\n variant=\"text\"\n size=\"xs\"\n className={cx(`${rootClassName}__read-more`)}\n onClick={toggleShowFullDescriptions}\n >\n <span className={cx(`${rootClassName}__read-more-text`)}>\n {showFullDescriptions ? ariaLabels.readLess : ariaLabels.readMore}\n </span>\n <IconChevronDown className={cx(`${rootClassName}__read-more-icon`)} size=\"xs\" />\n </Button>\n )}\n </div>\n );\n };\n\n return (\n <article className={classes} data-card-id={id} data-card-index={cardIndex}>\n {badge && <Badge {...badge} className={cx(`${rootClassName}__badge`)} />}\n\n <section className={cx(`${rootClassName}__main-content`)}>\n <img src={image.src} alt={image.alt} className={cx(`${rootClassName}__image`)} />\n\n <div className={cx(`${rootClassName}__body`)}>\n <Heading tag=\"h3\" variant=\"title-200\" className={cx(`${rootClassName}__title`)}>\n {title}\n </Heading>\n {renderDescription()}\n </div>\n </section>\n\n <footer className={cx(`${rootClassName}__footer`)}>\n <span className={cx(`${rootClassName}__price`)} id={id}>\n <Paragraph variant=\"paragraph-100\">{variablePriceText}</Paragraph>\n <Paragraph variant=\"paragraph-100-bold\">{price}</Paragraph>\n </span>\n\n {actions}\n </footer>\n </article>\n );\n};\n","import React, { type RefObject, useCallback, useEffect, useState } from \"react\";\nimport { Button } from \"@purpur/button\";\nimport { IconArrowLeft } from \"@purpur/icon/arrow-left\";\nimport { IconArrowRight } from \"@purpur/icon/arrow-right\";\nimport c from \"classnames/bind\";\n\nimport { type ComparisonTableProps, type Features, type Item } from \"../../comparison-table\";\nimport styles from \"./scroll-progress.module.scss\";\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-comparison-table-scroll-progress\";\n\ntype ScrollProgressProps = {\n items: Array<Item<Features>>;\n container: RefObject<HTMLUListElement | null>;\n ariaLabels: ComparisonTableProps[\"ariaLabels\"];\n};\n\nexport const ScrollProgress = ({ items, container, ariaLabels }: ScrollProgressProps) => {\n const [inViewSet, setInViewSet] = useState<Set<number>>(new Set());\n\n const scrollToCard = useCallback(\n (index: number) => {\n const reduceMotion = window.matchMedia(\"(prefers-reduced-motion: reduce)\").matches;\n\n const card = container.current?.querySelector(\n `[data-card-index=\"${index}\"]`\n ) as HTMLElement | null;\n card?.scrollIntoView({ behavior: reduceMotion ? \"instant\" : \"smooth\", block: \"nearest\" });\n },\n [container]\n );\n\n const previousCard = useCallback(() => {\n if (inViewSet.size === 0) return;\n\n const leftmostactiveIndex = Math.min(...Array.from(inViewSet));\n const targetIndex = leftmostactiveIndex - 1;\n\n if (targetIndex < 0) return;\n\n scrollToCard(targetIndex);\n }, [inViewSet, scrollToCard]);\n\n const nextCard = useCallback(() => {\n if (inViewSet.size === 0) return;\n\n const rightmostactiveIndex = Math.max(...Array.from(inViewSet));\n const targetIndex = rightmostactiveIndex + 1;\n\n if (targetIndex >= items.length) return;\n\n scrollToCard(targetIndex);\n }, [inViewSet, items.length, scrollToCard]);\n\n const handleKeyDown = useCallback(\n (e: KeyboardEvent) => {\n if (e.key === \"ArrowRight\" || e.key === \"ArrowLeft\") {\n e.preventDefault();\n\n if (e.key === \"ArrowRight\") nextCard();\n else if (e.key === \"ArrowLeft\") previousCard();\n }\n },\n [nextCard, previousCard]\n );\n\n useEffect(() => {\n const root = container.current;\n\n if (!root) return;\n\n const observer = new IntersectionObserver(\n (entries) => {\n setInViewSet((prev) => {\n const next = new Set(prev);\n\n entries.forEach((entry) => {\n const index = Number(entry.target.getAttribute(\"data-card-index\"));\n\n if (Number.isNaN(index)) return;\n\n if (entry.isIntersecting) {\n next.add(index);\n } else {\n next.delete(index);\n }\n });\n return next;\n });\n },\n { root, threshold: 0.5 }\n );\n\n items.forEach((_, index) => {\n const card = root.querySelector(`[data-card-index=\"${index}\"]`) as HTMLElement | null;\n\n if (card) observer.observe(card);\n });\n\n return () => observer.disconnect();\n }, [container, items]);\n\n useEffect(() => {\n const root = container.current;\n\n if (!root) return;\n\n root.addEventListener(\"keydown\", handleKeyDown);\n\n return () => root.removeEventListener(\"keydown\", handleKeyDown);\n }, [container, handleKeyDown]);\n\n const renderIndicators = () => {\n if (inViewSet.size === 0) return;\n\n const indicators = [];\n const viewCapacity = inViewSet.size;\n const leftmostActiveIndex = Math.min(...Array.from(inViewSet));\n const head = items.slice(0, leftmostActiveIndex).length;\n const trail = items.slice(leftmostActiveIndex + viewCapacity).length;\n\n let key = 0;\n\n for (let i = 0; i < items.length; i++) {\n if (head + 1 !== i && head <= i && i < items.length - trail) continue;\n\n let status = \"active\";\n\n if (i < head || i > items.length - 1 - trail) status = \"\";\n\n indicators.push(\n <li key={`indicator-${key++}`} className={cx(`${rootClassName}__indicator`, status)} />\n );\n }\n\n if (indicators.length < 2) return null;\n\n return indicators;\n };\n\n return (\n <li className={cx(rootClassName)}>\n <ul className={cx(`${rootClassName}__indicators`)}>{renderIndicators()}</ul>\n\n <div className={cx(`${rootClassName}__buttons`)}>\n <Button\n aria-label={ariaLabels.previous}\n variant=\"secondary\"\n iconOnly\n className={cx(`${rootClassName}__button`)}\n disabled={inViewSet.has(0)}\n onClick={previousCard}\n >\n <IconArrowLeft className={cx(`${rootClassName}__button-icon`)} size=\"xs\" />\n </Button>\n <Button\n aria-label={ariaLabels.next}\n variant=\"secondary\"\n iconOnly\n className={cx(`${rootClassName}__button`)}\n disabled={inViewSet.has(items.length - 1)}\n onClick={nextCard}\n >\n <IconArrowRight className={cx(`${rootClassName}__button-icon`)} size=\"xs\" />\n </Button>\n </div>\n </li>\n );\n};\n","import React, { type ReactNode, type UIEvent, useCallback, useId, useRef, useState } from \"react\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./comparison-table.module.scss\";\nimport { Cell } from \"./components/Cell/cell\";\nimport { LeadCell } from \"./components/LeadCell/lead-cell\";\nimport { OptionCard, type OptionCardProps } from \"./components/OptionCard/option-card\";\nimport { ScrollProgress } from \"./components/ScrollProgress/scroll-progress\";\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table\";\n\nexport type Features = Record<string, ReactNode | null>;\n\nexport type Item<TFeatures extends Features = Features> = OptionCardProps & {\n features: Partial<Record<keyof TFeatures, ReactNode | string | boolean>>;\n};\n\nexport type ComparisonTableProps<TFeatures extends Features = Features> = {\n /** List of features that can be supported by the comparison table\n *\n * string = description of the feature that can be viewed by expanding cell.\n *\n * null = no description\n *\n {\n [featureName]: ReactNode | null\n }\n */\n features: TFeatures;\n\n /** List of items to be displayed in the comparison table\n *\n *\n Item = {\n image: {\n src: string;\n alt: string;\n };\n\n title: string;\n description: string;\n variablePriceText: string;\n price: string;\n actions: ReactNode;\n badge?: BadgeProps;\n isHighlighted?: boolean;\n\n features: {\n [featureName in keyof Features]?: string | boolean;\n };\n }\n */\n items: Array<Item<TFeatures>>;\n\n /** Aria labels for the comparison table and various components\n *\n {\n previous: string;\n next: string;\n readMore: string;\n readLess: string;\n }\n */\n ariaLabels: {\n previous: string;\n next: string;\n readMore: string;\n readLess: string;\n };\n variant?: \"primary\" | \"secondary\";\n classname?: string;\n};\n\nexport const ComparisonTable = <TFeatures extends Features>({\n classname,\n features,\n items,\n ariaLabels,\n variant = \"primary\",\n}: ComparisonTableProps<TFeatures>) => {\n const id = useId();\n const classes = cx(classname, rootClassName, `${rootClassName}--${variant}`);\n const containerRef = useRef<HTMLUListElement>(null);\n const [showFullDescriptions, setShowFullDescriptions] = useState(false);\n\n const handleToggleShowFullDescriptions = useCallback(() => {\n setShowFullDescriptions((prev) => !prev);\n }, []);\n\n const renderCards = () => {\n return (\n <li className={cx(`${rootClassName}__cards`)}>\n <div className={cx(`${rootClassName}__separator`)} />\n {items.map((item, index) => (\n <OptionCard\n {...item}\n showFullDescriptions={showFullDescriptions}\n toggleShowFullDescriptions={handleToggleShowFullDescriptions}\n key={index}\n isFirstCard={index === 0}\n ariaLabels={ariaLabels}\n cardIndex={index}\n id={`${index}-${id}`}\n />\n ))}\n </li>\n );\n };\n\n const renderFeatures = () => {\n return Object.entries(features).map(([title, description], i) => (\n <li key={i} className={cx(`${rootClassName}__feature-row`)}>\n <LeadCell title={title} description={description} />\n {items.map((item, index) => (\n <Cell key={index} value={item.features[title as keyof TFeatures] ?? false} />\n ))}\n </li>\n ));\n };\n\n const deltaTime = useRef(0);\n\n const handleScrollEnd = (e: UIEvent<HTMLUListElement>) => {\n /**\n * This function makes sure that the scroll position is never stuck between two cards, since scroll snap is not fully reliable.\n */\n\n const target = e.currentTarget;\n const cardwidth = target.querySelector(\"[data-card-id]\")?.clientWidth ?? 0;\n const cardPos = Math.round(target.scrollLeft / cardwidth);\n const scrollTarget = cardPos * cardwidth + cardPos;\n const timeDiff = e.timeStamp - deltaTime.current;\n const scrollDiff = Math.abs(target.scrollLeft - scrollTarget);\n\n if (deltaTime.current && timeDiff < 200) return;\n if (scrollDiff < 10) return;\n\n deltaTime.current = e.timeStamp;\n\n target.scrollTo({ left: scrollTarget, behavior: \"smooth\" });\n };\n\n return (\n <div className={cx(rootClassName + \"__wrapper\")}>\n <ul\n id={rootClassName + `-${id}`}\n ref={containerRef}\n className={classes}\n // eslint-disable-next-line react/no-unknown-property\n onScrollEnd={handleScrollEnd}\n style={{\n // @ts-expect-error | Typescript doesn't recognize the CSS variable, but it works as intended\n [\"--initial-columns\"]: items.length + 1,\n }}\n >\n <ScrollProgress items={items} container={containerRef} ariaLabels={ariaLabels} />\n {renderCards()}\n {renderFeatures()}\n </ul>\n </div>\n );\n};\n\nComparisonTable.displayName = \"ComparisonTable\";\n"],"names":["cx","c","styles","rootClassName","Cell","value","isReactNode","isValidElement","classes","Icon","IconCheckmark","IconMinus","jsx","LeadCell","title","description","isExpandable","jsxs","Paragraph","IconChevronDown","OptionCard","id","cardIndex","variablePriceText","price","isHighlighted","ariaLabels","badge","actions","isFirstCard","image","showFullDescriptions","toggleShowFullDescriptions","renderDescription","longDescription","Button","Badge","Heading","ScrollProgress","items","container","inViewSet","setInViewSet","useState","scrollToCard","useCallback","index","reduceMotion","previousCard","targetIndex","nextCard","handleKeyDown","e","useEffect","root","observer","entries","prev","next","entry","_","card","renderIndicators","indicators","viewCapacity","leftmostActiveIndex","head","trail","key","i","status","IconArrowLeft","IconArrowRight","ComparisonTable","classname","features","variant","useId","containerRef","useRef","setShowFullDescriptions","handleToggleShowFullDescriptions","renderCards","item","createElement","renderFeatures","deltaTime","handleScrollEnd","target","cardwidth","cardPos","scrollTarget","timeDiff","scrollDiff"],"mappings":"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"}
|