@enadhq/enad-react-sdk 0.0.6 → 1.0.2
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 +288 -0
- package/dist/client/cart/adapters/brink.d.ts +29 -0
- package/dist/client/cart/adapters/brink.d.ts.map +1 -0
- package/dist/client/cart/adapters/brink.mjs +154 -0
- package/dist/client/cart/adapters/brink.mjs.map +1 -0
- package/dist/client/cart/adapters/index.d.ts +3 -0
- package/dist/client/cart/adapters/index.d.ts.map +1 -0
- package/dist/client/cart/adapters/index.mjs +5 -0
- package/dist/client/cart/adapters/index.mjs.map +1 -0
- package/dist/client/cart/adapters/mock.d.ts +20 -0
- package/dist/client/cart/adapters/mock.d.ts.map +1 -0
- package/dist/client/cart/adapters/mock.mjs +76 -0
- package/dist/client/cart/adapters/mock.mjs.map +1 -0
- package/dist/client/cart/components/{cart-drawer.d.mts → cart-drawer.d.ts} +4 -6
- package/dist/client/cart/components/cart-drawer.d.ts.map +1 -0
- package/dist/client/cart/components/cart-drawer.mjs +269 -138
- package/dist/client/cart/components/cart-drawer.mjs.map +1 -1
- package/dist/client/cart/components/cart-trigger.d.ts +10 -0
- package/dist/client/cart/components/cart-trigger.d.ts.map +1 -0
- package/dist/client/cart/components/cart-trigger.mjs +26 -10
- package/dist/client/cart/components/cart-trigger.mjs.map +1 -1
- package/dist/client/cart/components/promo-code-input.d.ts +16 -0
- package/dist/client/cart/components/promo-code-input.d.ts.map +1 -0
- package/dist/client/cart/components/promo-code-input.mjs +92 -0
- package/dist/client/cart/components/promo-code-input.mjs.map +1 -0
- package/dist/client/cart/constants/session.d.ts +2 -0
- package/dist/client/cart/constants/session.d.ts.map +1 -0
- package/dist/client/cart/contexts/cart.d.ts +36 -0
- package/dist/client/cart/contexts/cart.d.ts.map +1 -0
- package/dist/client/cart/contexts/cart.mjs +14 -16
- package/dist/client/cart/contexts/cart.mjs.map +1 -1
- package/dist/client/cart/hooks/useCart.d.ts +26 -0
- package/dist/client/cart/hooks/useCart.d.ts.map +1 -0
- package/dist/client/cart/hooks/useCart.mjs +5 -6
- package/dist/client/cart/hooks/useCart.mjs.map +1 -1
- package/dist/client/cart/hooks/useCartActions.d.ts +25 -0
- package/dist/client/cart/hooks/useCartActions.d.ts.map +1 -0
- package/dist/client/cart/hooks/useCartActions.mjs +7 -16
- package/dist/client/cart/hooks/useCartActions.mjs.map +1 -1
- package/dist/client/cart/index.d.ts +12 -0
- package/dist/client/cart/index.d.ts.map +1 -0
- package/dist/client/cart/index.mjs +16 -0
- package/dist/client/cart/index.mjs.map +1 -0
- package/dist/client/cart/queries/addToCartQueryFn.d.ts +7 -0
- package/dist/client/cart/queries/addToCartQueryFn.d.ts.map +1 -0
- package/dist/client/cart/queries/addToCartQueryFn.mjs.map +1 -1
- package/dist/client/cart/queries/getCartQueryFn.d.ts +4 -0
- package/dist/client/cart/queries/getCartQueryFn.d.ts.map +1 -0
- package/dist/client/cart/queries/getCartQueryFn.mjs.map +1 -1
- package/dist/client/cart/queries/removeCartItemQueryFn.d.ts +6 -0
- package/dist/client/cart/queries/removeCartItemQueryFn.d.ts.map +1 -0
- package/dist/client/cart/queries/removeCartItemQueryFn.mjs.map +1 -1
- package/dist/client/cart/queries/updateCartItemQueryFn.d.ts +7 -0
- package/dist/client/cart/queries/updateCartItemQueryFn.d.ts.map +1 -0
- package/dist/client/cart/queries/updateCartItemQueryFn.mjs.map +1 -1
- package/dist/client/cart/types/adapter.d.ts +110 -0
- package/dist/client/cart/types/adapter.d.ts.map +1 -0
- package/dist/client/cart/types/adapter.mjs +12 -0
- package/dist/client/cart/types/adapter.mjs.map +1 -0
- package/dist/client/cart/types/{cart.d.mts → cart.d.ts} +21 -5
- package/dist/client/cart/types/cart.d.ts.map +1 -0
- package/dist/client/cart/utils/session.d.ts +5 -0
- package/dist/client/cart/utils/session.d.ts.map +1 -0
- package/dist/client/cart/utils/session.mjs +1 -1
- package/dist/client/cart/utils/session.mjs.map +1 -1
- package/dist/client/cms/storyblok/preview/registerStoryblokBridge.d.ts +7 -0
- package/dist/client/cms/storyblok/preview/registerStoryblokBridge.d.ts.map +1 -0
- package/dist/client/cms/storyblok/preview/registerStoryblokBridge.mjs +3 -2
- package/dist/client/cms/storyblok/preview/registerStoryblokBridge.mjs.map +1 -1
- package/dist/client/cms/storyblok/preview/{storyblok-preview-syncer.d.mts → storyblok-preview-syncer.d.ts} +4 -6
- package/dist/client/cms/storyblok/preview/storyblok-preview-syncer.d.ts.map +1 -0
- package/dist/client/cms/storyblok/preview/storyblok-preview-syncer.mjs.map +1 -1
- package/dist/client/global/auth/withAuth.d.ts +5 -0
- package/dist/client/global/auth/withAuth.d.ts.map +1 -0
- package/dist/client/global/components/error-boundary.d.ts +18 -0
- package/dist/client/global/components/error-boundary.d.ts.map +1 -0
- package/dist/client/global/components/error-boundary.mjs +41 -0
- package/dist/client/global/components/error-boundary.mjs.map +1 -0
- package/dist/client/global/config/{index.d.mts → index.d.ts} +3 -3
- package/dist/client/global/config/index.d.ts.map +1 -0
- package/dist/client/global/constants/{tags.d.mts → tags.d.ts} +2 -3
- package/dist/client/global/constants/tags.d.ts.map +1 -0
- package/dist/client/global/index.d.ts +6 -0
- package/dist/client/global/index.d.ts.map +1 -0
- package/dist/client/global/index.mjs +7 -0
- package/dist/client/global/index.mjs.map +1 -0
- package/dist/client/global/providers/enad-provider.d.ts +48 -0
- package/dist/client/global/providers/enad-provider.d.ts.map +1 -0
- package/dist/client/global/providers/enad-provider.mjs +32 -3
- package/dist/client/global/providers/enad-provider.mjs.map +1 -1
- package/dist/client/icons/adapters/hugeicons.d.ts +9 -0
- package/dist/client/icons/adapters/hugeicons.d.ts.map +1 -0
- package/dist/client/icons/adapters/hugeicons.mjs +117 -0
- package/dist/client/icons/adapters/hugeicons.mjs.map +1 -0
- package/dist/client/icons/adapters/lucide.d.ts +8 -0
- package/dist/client/icons/adapters/lucide.d.ts.map +1 -0
- package/dist/client/icons/adapters/lucide.mjs +108 -0
- package/dist/client/icons/adapters/lucide.mjs.map +1 -0
- package/dist/client/icons/adapters/phosphor.d.ts +11 -0
- package/dist/client/icons/adapters/phosphor.d.ts.map +1 -0
- package/dist/client/icons/adapters/phosphor.mjs +108 -0
- package/dist/client/icons/adapters/phosphor.mjs.map +1 -0
- package/dist/client/icons/icon-context.d.ts +13 -0
- package/dist/client/icons/icon-context.d.ts.map +1 -0
- package/dist/client/icons/icon-context.mjs +27 -0
- package/dist/client/icons/icon-context.mjs.map +1 -0
- package/dist/client/icons/index.d.ts +9 -0
- package/dist/client/icons/index.d.ts.map +1 -0
- package/dist/client/icons/index.mjs +16 -0
- package/dist/client/icons/index.mjs.map +1 -0
- package/dist/client/icons/types.d.ts +60 -0
- package/dist/client/icons/types.d.ts.map +1 -0
- package/dist/client/icons/types.mjs +1 -0
- package/dist/client/icons/types.mjs.map +1 -0
- package/dist/client/motion/config.d.ts +42 -0
- package/dist/client/motion/config.d.ts.map +1 -0
- package/dist/client/motion/config.mjs +44 -0
- package/dist/client/motion/config.mjs.map +1 -0
- package/dist/client/motion/hover.d.ts +36 -0
- package/dist/client/motion/hover.d.ts.map +1 -0
- package/dist/client/motion/hover.mjs +19 -0
- package/dist/client/motion/hover.mjs.map +1 -0
- package/dist/client/motion/index.d.ts +4 -0
- package/dist/client/motion/index.d.ts.map +1 -0
- package/dist/client/motion/index.mjs +13 -0
- package/dist/client/motion/index.mjs.map +1 -0
- package/dist/client/motion/stagger.d.ts +36 -0
- package/dist/client/motion/stagger.d.ts.map +1 -0
- package/dist/client/motion/stagger.mjs +17 -0
- package/dist/client/motion/stagger.mjs.map +1 -0
- package/dist/client/search/actions/searchAction.d.ts +2 -0
- package/dist/client/search/actions/searchAction.d.ts.map +1 -0
- package/dist/client/search/actions/searchAction.mjs.map +1 -1
- package/dist/client/search/components/search-bar.d.ts +8 -0
- package/dist/client/search/components/search-bar.d.ts.map +1 -0
- package/dist/client/search/components/search-bar.mjs +33 -0
- package/dist/client/search/components/search-bar.mjs.map +1 -1
- package/dist/client/search/hooks/useSearch.d.ts +14 -0
- package/dist/client/search/hooks/useSearch.d.ts.map +1 -0
- package/dist/client/search/hooks/useSearch.mjs +1 -1
- package/dist/client/search/hooks/useSearch.mjs.map +1 -1
- package/dist/client/search/index.d.ts +2 -0
- package/dist/client/search/index.d.ts.map +1 -0
- package/dist/client/search/index.mjs +5 -0
- package/dist/client/search/index.mjs.map +1 -0
- package/dist/client/storefront/blocks/accordion-block.d.ts +4 -0
- package/dist/client/storefront/blocks/accordion-block.d.ts.map +1 -0
- package/dist/client/storefront/blocks/accordion-block.mjs +43 -0
- package/dist/client/storefront/blocks/accordion-block.mjs.map +1 -0
- package/dist/client/storefront/blocks/card-image-with-caption.d.ts +4 -0
- package/dist/client/storefront/blocks/card-image-with-caption.d.ts.map +1 -0
- package/dist/client/storefront/blocks/card-image-with-caption.mjs +27 -0
- package/dist/client/storefront/blocks/card-image-with-caption.mjs.map +1 -0
- package/dist/client/storefront/blocks/card-video.d.ts +4 -0
- package/dist/client/storefront/blocks/card-video.d.ts.map +1 -0
- package/dist/client/storefront/blocks/card-video.mjs +43 -0
- package/dist/client/storefront/blocks/card-video.mjs.map +1 -0
- package/dist/client/storefront/blocks/content-with-gallery.d.ts +4 -0
- package/dist/client/storefront/blocks/content-with-gallery.d.ts.map +1 -0
- package/dist/client/storefront/blocks/content-with-gallery.mjs +48 -0
- package/dist/client/storefront/blocks/content-with-gallery.mjs.map +1 -0
- package/dist/client/storefront/blocks/content-with-image-product-data.d.ts +4 -0
- package/dist/client/storefront/blocks/content-with-image-product-data.d.ts.map +1 -0
- package/dist/client/storefront/blocks/content-with-image-product-data.mjs +45 -0
- package/dist/client/storefront/blocks/content-with-image-product-data.mjs.map +1 -0
- package/dist/client/storefront/blocks/gallery-with-caption.d.ts +4 -0
- package/dist/client/storefront/blocks/gallery-with-caption.d.ts.map +1 -0
- package/dist/client/storefront/blocks/gallery-with-caption.mjs +36 -0
- package/dist/client/storefront/blocks/gallery-with-caption.mjs.map +1 -0
- package/dist/client/storefront/blocks/gallery-with-link-blocks.d.ts +4 -0
- package/dist/client/storefront/blocks/gallery-with-link-blocks.d.ts.map +1 -0
- package/dist/client/storefront/blocks/gallery-with-link-blocks.mjs +24 -0
- package/dist/client/storefront/blocks/gallery-with-link-blocks.mjs.map +1 -0
- package/dist/client/storefront/blocks/gallery.d.ts +4 -0
- package/dist/client/storefront/blocks/gallery.d.ts.map +1 -0
- package/dist/client/storefront/blocks/gallery.mjs +47 -0
- package/dist/client/storefront/blocks/gallery.mjs.map +1 -0
- package/dist/client/storefront/blocks/hero.d.ts +4 -0
- package/dist/client/storefront/blocks/hero.d.ts.map +1 -0
- package/dist/client/storefront/blocks/hero.mjs +357 -0
- package/dist/client/storefront/blocks/hero.mjs.map +1 -0
- package/dist/client/storefront/blocks/image-block.d.ts +4 -0
- package/dist/client/storefront/blocks/image-block.d.ts.map +1 -0
- package/dist/client/storefront/blocks/image-block.mjs +29 -0
- package/dist/client/storefront/blocks/image-block.mjs.map +1 -0
- package/dist/client/storefront/blocks/index.d.ts +20 -0
- package/dist/client/storefront/blocks/index.d.ts.map +1 -0
- package/dist/client/storefront/blocks/index.mjs +41 -0
- package/dist/client/storefront/blocks/index.mjs.map +1 -0
- package/dist/client/storefront/blocks/link-block-small.d.ts +4 -0
- package/dist/client/storefront/blocks/link-block-small.d.ts.map +1 -0
- package/dist/client/storefront/blocks/link-block-small.mjs +35 -0
- package/dist/client/storefront/blocks/link-block-small.mjs.map +1 -0
- package/dist/client/storefront/blocks/link-block.d.ts +4 -0
- package/dist/client/storefront/blocks/link-block.d.ts.map +1 -0
- package/dist/client/storefront/blocks/link-block.mjs +150 -0
- package/dist/client/storefront/blocks/link-block.mjs.map +1 -0
- package/dist/client/storefront/blocks/product-card.d.ts +4 -0
- package/dist/client/storefront/blocks/product-card.d.ts.map +1 -0
- package/dist/client/storefront/blocks/product-card.mjs +228 -0
- package/dist/client/storefront/blocks/product-card.mjs.map +1 -0
- package/dist/client/storefront/blocks/product-image.d.ts +4 -0
- package/dist/client/storefront/blocks/product-image.d.ts.map +1 -0
- package/dist/client/storefront/blocks/product-image.mjs +109 -0
- package/dist/client/storefront/blocks/product-image.mjs.map +1 -0
- package/dist/client/storefront/blocks/spacer.d.ts +4 -0
- package/dist/client/storefront/blocks/spacer.d.ts.map +1 -0
- package/dist/client/storefront/blocks/spacer.mjs +14 -0
- package/dist/client/storefront/blocks/spacer.mjs.map +1 -0
- package/dist/client/storefront/blocks/text-content-with-image.d.ts +4 -0
- package/dist/client/storefront/blocks/text-content-with-image.d.ts.map +1 -0
- package/dist/client/storefront/blocks/text-content-with-image.mjs +225 -0
- package/dist/client/storefront/blocks/text-content-with-image.mjs.map +1 -0
- package/dist/client/storefront/blocks/text-content.d.ts +4 -0
- package/dist/client/storefront/blocks/text-content.d.ts.map +1 -0
- package/dist/client/storefront/blocks/text-content.mjs +150 -0
- package/dist/client/storefront/blocks/text-content.mjs.map +1 -0
- package/dist/client/storefront/blocks/truncated-text.d.ts +4 -0
- package/dist/client/storefront/blocks/truncated-text.d.ts.map +1 -0
- package/dist/client/storefront/blocks/truncated-text.mjs +36 -0
- package/dist/client/storefront/blocks/truncated-text.mjs.map +1 -0
- package/dist/client/storefront/blocks/variable-text-content.d.ts +4 -0
- package/dist/client/storefront/blocks/variable-text-content.d.ts.map +1 -0
- package/dist/client/storefront/blocks/variable-text-content.mjs +15 -0
- package/dist/client/storefront/blocks/variable-text-content.mjs.map +1 -0
- package/dist/client/storefront/carousel/index.d.ts +2 -0
- package/dist/client/storefront/carousel/index.d.ts.map +1 -0
- package/dist/client/storefront/carousel/index.mjs +5 -0
- package/dist/client/storefront/carousel/index.mjs.map +1 -0
- package/dist/client/storefront/carousel/swipeable-carousel.d.ts +14 -0
- package/dist/client/storefront/carousel/swipeable-carousel.d.ts.map +1 -0
- package/dist/client/storefront/carousel/swipeable-carousel.mjs +80 -0
- package/dist/client/storefront/carousel/swipeable-carousel.mjs.map +1 -0
- package/dist/client/storefront/checkout/address-form.d.ts +31 -0
- package/dist/client/storefront/checkout/address-form.d.ts.map +1 -0
- package/dist/client/storefront/checkout/address-form.mjs +124 -0
- package/dist/client/storefront/checkout/address-form.mjs.map +1 -0
- package/dist/client/storefront/checkout/cart-summary.d.ts +40 -0
- package/dist/client/storefront/checkout/cart-summary.d.ts.map +1 -0
- package/dist/client/storefront/checkout/cart-summary.mjs +150 -0
- package/dist/client/storefront/checkout/cart-summary.mjs.map +1 -0
- package/dist/client/storefront/checkout/checkout-stepper.d.ts +13 -0
- package/dist/client/storefront/checkout/checkout-stepper.d.ts.map +1 -0
- package/dist/client/storefront/checkout/checkout-stepper.mjs +58 -0
- package/dist/client/storefront/checkout/checkout-stepper.mjs.map +1 -0
- package/dist/client/storefront/checkout/index.d.ts +15 -0
- package/dist/client/storefront/checkout/index.d.ts.map +1 -0
- package/dist/client/storefront/checkout/index.mjs +17 -0
- package/dist/client/storefront/checkout/index.mjs.map +1 -0
- package/dist/client/storefront/checkout/order-confirmation.d.ts +10 -0
- package/dist/client/storefront/checkout/order-confirmation.d.ts.map +1 -0
- package/dist/client/storefront/checkout/order-confirmation.mjs +27 -0
- package/dist/client/storefront/checkout/order-confirmation.mjs.map +1 -0
- package/dist/client/storefront/checkout/order-summary.d.ts +29 -0
- package/dist/client/storefront/checkout/order-summary.d.ts.map +1 -0
- package/dist/client/storefront/checkout/order-summary.mjs +106 -0
- package/dist/client/storefront/checkout/order-summary.mjs.map +1 -0
- package/dist/client/storefront/checkout/payment-method-selector.d.ts +18 -0
- package/dist/client/storefront/checkout/payment-method-selector.d.ts.map +1 -0
- package/dist/client/storefront/checkout/payment-method-selector.mjs +61 -0
- package/dist/client/storefront/checkout/payment-method-selector.mjs.map +1 -0
- package/dist/client/storefront/checkout/shipping-method-selector.d.ts +23 -0
- package/dist/client/storefront/checkout/shipping-method-selector.d.ts.map +1 -0
- package/dist/client/storefront/checkout/shipping-method-selector.mjs +77 -0
- package/dist/client/storefront/checkout/shipping-method-selector.mjs.map +1 -0
- package/dist/client/storefront/components/badge.d.ts +8 -0
- package/dist/client/storefront/components/badge.d.ts.map +1 -0
- package/dist/client/storefront/components/badge.mjs +28 -0
- package/dist/client/storefront/components/badge.mjs.map +1 -0
- package/dist/client/storefront/components/country-redirect.d.ts +30 -0
- package/dist/client/storefront/components/country-redirect.d.ts.map +1 -0
- package/dist/client/storefront/components/country-redirect.mjs +121 -0
- package/dist/client/storefront/components/country-redirect.mjs.map +1 -0
- package/dist/client/storefront/components/empty-state.d.ts +38 -0
- package/dist/client/storefront/components/empty-state.d.ts.map +1 -0
- package/dist/client/storefront/components/empty-state.mjs +55 -0
- package/dist/client/storefront/components/empty-state.mjs.map +1 -0
- package/dist/client/storefront/components/image-lightbox.d.ts +13 -0
- package/dist/client/storefront/components/image-lightbox.d.ts.map +1 -0
- package/dist/client/storefront/components/image-lightbox.mjs +275 -0
- package/dist/client/storefront/components/image-lightbox.mjs.map +1 -0
- package/dist/client/storefront/components/infinite-scroll.d.ts +37 -0
- package/dist/client/storefront/components/infinite-scroll.d.ts.map +1 -0
- package/dist/client/storefront/components/infinite-scroll.mjs +83 -0
- package/dist/client/storefront/components/infinite-scroll.mjs.map +1 -0
- package/dist/client/storefront/components/language-selector.d.ts +5 -0
- package/dist/client/storefront/components/language-selector.d.ts.map +1 -0
- package/dist/client/storefront/components/language-selector.mjs +58 -0
- package/dist/client/storefront/components/language-selector.mjs.map +1 -0
- package/dist/client/storefront/components/newsletter-signup.d.ts +14 -0
- package/dist/client/storefront/components/newsletter-signup.d.ts.map +1 -0
- package/dist/client/storefront/components/newsletter-signup.mjs +81 -0
- package/dist/client/storefront/components/newsletter-signup.mjs.map +1 -0
- package/dist/client/storefront/components/price.d.ts +14 -0
- package/dist/client/storefront/components/price.d.ts.map +1 -0
- package/dist/client/storefront/components/price.mjs +46 -0
- package/dist/client/storefront/components/price.mjs.map +1 -0
- package/dist/client/storefront/components/product-recommendations.d.ts +18 -0
- package/dist/client/storefront/components/product-recommendations.d.ts.map +1 -0
- package/dist/client/storefront/components/product-recommendations.mjs +108 -0
- package/dist/client/storefront/components/product-recommendations.mjs.map +1 -0
- package/dist/client/storefront/components/product-tabs.d.ts +12 -0
- package/dist/client/storefront/components/product-tabs.d.ts.map +1 -0
- package/dist/client/storefront/components/product-tabs.mjs +64 -0
- package/dist/client/storefront/components/product-tabs.mjs.map +1 -0
- package/dist/client/storefront/components/quick-view.d.ts +25 -0
- package/dist/client/storefront/components/quick-view.d.ts.map +1 -0
- package/dist/client/storefront/components/quick-view.mjs +149 -0
- package/dist/client/storefront/components/quick-view.mjs.map +1 -0
- package/dist/client/storefront/components/review-summary.d.ts +17 -0
- package/dist/client/storefront/components/review-summary.d.ts.map +1 -0
- package/dist/client/storefront/components/review-summary.mjs +66 -0
- package/dist/client/storefront/components/review-summary.mjs.map +1 -0
- package/dist/client/storefront/components/search-autocomplete.d.ts +25 -0
- package/dist/client/storefront/components/search-autocomplete.d.ts.map +1 -0
- package/dist/client/storefront/components/search-autocomplete.mjs +183 -0
- package/dist/client/storefront/components/search-autocomplete.mjs.map +1 -0
- package/dist/client/storefront/components/section-nav.d.ts +20 -0
- package/dist/client/storefront/components/section-nav.d.ts.map +1 -0
- package/dist/client/storefront/components/section-nav.mjs +175 -0
- package/dist/client/storefront/components/section-nav.mjs.map +1 -0
- package/dist/client/storefront/components/share-button.d.ts +19 -0
- package/dist/client/storefront/components/share-button.d.ts.map +1 -0
- package/dist/client/storefront/components/share-button.mjs +95 -0
- package/dist/client/storefront/components/share-button.mjs.map +1 -0
- package/dist/client/storefront/components/skeleton.d.ts +12 -0
- package/dist/client/storefront/components/skeleton.d.ts.map +1 -0
- package/dist/client/storefront/components/skeleton.mjs +70 -0
- package/dist/client/storefront/components/skeleton.mjs.map +1 -0
- package/dist/client/storefront/components/star-rating.d.ts +13 -0
- package/dist/client/storefront/components/star-rating.d.ts.map +1 -0
- package/dist/client/storefront/components/star-rating.mjs +240 -0
- package/dist/client/storefront/components/star-rating.mjs.map +1 -0
- package/dist/client/storefront/components/testimonial.d.ts +20 -0
- package/dist/client/storefront/components/testimonial.d.ts.map +1 -0
- package/dist/client/storefront/components/testimonial.mjs +53 -0
- package/dist/client/storefront/components/testimonial.mjs.map +1 -0
- package/dist/client/storefront/components/trust-badges.d.ts +14 -0
- package/dist/client/storefront/components/trust-badges.d.ts.map +1 -0
- package/dist/client/storefront/components/trust-badges.mjs +25 -0
- package/dist/client/storefront/components/trust-badges.mjs.map +1 -0
- package/dist/client/storefront/components/variant-selector.d.ts +21 -0
- package/dist/client/storefront/components/variant-selector.d.ts.map +1 -0
- package/dist/client/storefront/components/variant-selector.mjs +41 -0
- package/dist/client/storefront/components/variant-selector.mjs.map +1 -0
- package/dist/client/storefront/components/wishlist-toggle.d.ts +12 -0
- package/dist/client/storefront/components/wishlist-toggle.d.ts.map +1 -0
- package/dist/client/storefront/components/wishlist-toggle.mjs +58 -0
- package/dist/client/storefront/components/wishlist-toggle.mjs.map +1 -0
- package/dist/client/storefront/filters/filter-chip.d.ts +10 -0
- package/dist/client/storefront/filters/filter-chip.d.ts.map +1 -0
- package/dist/client/storefront/filters/filter-chip.mjs +30 -0
- package/dist/client/storefront/filters/filter-chip.mjs.map +1 -0
- package/dist/client/storefront/filters/filter-group.d.ts +22 -0
- package/dist/client/storefront/filters/filter-group.d.ts.map +1 -0
- package/dist/client/storefront/filters/filter-group.mjs +102 -0
- package/dist/client/storefront/filters/filter-group.mjs.map +1 -0
- package/dist/client/storefront/filters/filter-panel.d.ts +25 -0
- package/dist/client/storefront/filters/filter-panel.d.ts.map +1 -0
- package/dist/client/storefront/filters/filter-panel.mjs +110 -0
- package/dist/client/storefront/filters/filter-panel.mjs.map +1 -0
- package/dist/client/storefront/filters/index.d.ts +6 -0
- package/dist/client/storefront/filters/index.d.ts.map +1 -0
- package/dist/client/storefront/filters/index.mjs +13 -0
- package/dist/client/storefront/filters/index.mjs.map +1 -0
- package/dist/client/storefront/filters/sort-select.d.ts +12 -0
- package/dist/client/storefront/filters/sort-select.d.ts.map +1 -0
- package/dist/client/storefront/filters/sort-select.mjs +34 -0
- package/dist/client/storefront/filters/sort-select.mjs.map +1 -0
- package/dist/client/storefront/filters/toggle-list-view.d.ts +8 -0
- package/dist/client/storefront/filters/toggle-list-view.d.ts.map +1 -0
- package/dist/client/storefront/filters/toggle-list-view.mjs +30 -0
- package/dist/client/storefront/filters/toggle-list-view.mjs.map +1 -0
- package/dist/client/storefront/hooks/use-section-observer.d.ts +12 -0
- package/dist/client/storefront/hooks/use-section-observer.d.ts.map +1 -0
- package/dist/client/storefront/hooks/use-section-observer.mjs +46 -0
- package/dist/client/storefront/hooks/use-section-observer.mjs.map +1 -0
- package/dist/client/storefront/index.d.ts +24 -0
- package/dist/client/storefront/index.d.ts.map +1 -0
- package/dist/client/storefront/index.mjs +26 -0
- package/dist/client/storefront/index.mjs.map +1 -0
- package/dist/client/storefront/layout/footer.d.ts +4 -0
- package/dist/client/storefront/layout/footer.d.ts.map +1 -0
- package/dist/client/storefront/layout/footer.mjs +56 -0
- package/dist/client/storefront/layout/footer.mjs.map +1 -0
- package/dist/client/storefront/layout/header.d.ts +4 -0
- package/dist/client/storefront/layout/header.d.ts.map +1 -0
- package/dist/client/storefront/layout/header.mjs +367 -0
- package/dist/client/storefront/layout/header.mjs.map +1 -0
- package/dist/client/storefront/layout/index.d.ts +5 -0
- package/dist/client/storefront/layout/index.d.ts.map +1 -0
- package/dist/client/storefront/layout/index.mjs +11 -0
- package/dist/client/storefront/layout/index.mjs.map +1 -0
- package/dist/client/storefront/layout/mobile-menu-drawer.d.ts +4 -0
- package/dist/client/storefront/layout/mobile-menu-drawer.d.ts.map +1 -0
- package/dist/client/storefront/layout/mobile-menu-drawer.mjs +93 -0
- package/dist/client/storefront/layout/mobile-menu-drawer.mjs.map +1 -0
- package/dist/client/storefront/layout/promotion-bar.d.ts +4 -0
- package/dist/client/storefront/layout/promotion-bar.d.ts.map +1 -0
- package/dist/client/storefront/layout/promotion-bar.mjs +79 -0
- package/dist/client/storefront/layout/promotion-bar.mjs.map +1 -0
- package/dist/client/storefront/primitives/breadcrumbs.d.ts +12 -0
- package/dist/client/storefront/primitives/breadcrumbs.d.ts.map +1 -0
- package/dist/client/storefront/primitives/breadcrumbs.mjs +37 -0
- package/dist/client/storefront/primitives/breadcrumbs.mjs.map +1 -0
- package/dist/client/storefront/primitives/button.d.ts +12 -0
- package/dist/client/storefront/primitives/button.d.ts.map +1 -0
- package/dist/client/storefront/primitives/button.mjs +51 -0
- package/dist/client/storefront/primitives/button.mjs.map +1 -0
- package/dist/client/storefront/primitives/checkbox.d.ts +10 -0
- package/dist/client/storefront/primitives/checkbox.d.ts.map +1 -0
- package/dist/client/storefront/primitives/checkbox.mjs +23 -0
- package/dist/client/storefront/primitives/checkbox.mjs.map +1 -0
- package/dist/client/storefront/primitives/download-item.d.ts +9 -0
- package/dist/client/storefront/primitives/download-item.d.ts.map +1 -0
- package/dist/client/storefront/primitives/download-item.mjs +28 -0
- package/dist/client/storefront/primitives/download-item.mjs.map +1 -0
- package/dist/client/storefront/primitives/index.d.ts +10 -0
- package/dist/client/storefront/primitives/index.d.ts.map +1 -0
- package/dist/client/storefront/primitives/index.mjs +21 -0
- package/dist/client/storefront/primitives/index.mjs.map +1 -0
- package/dist/client/storefront/primitives/input.d.ts +18 -0
- package/dist/client/storefront/primitives/input.d.ts.map +1 -0
- package/dist/client/storefront/primitives/input.mjs +118 -0
- package/dist/client/storefront/primitives/input.mjs.map +1 -0
- package/dist/client/storefront/primitives/pagination.d.ts +9 -0
- package/dist/client/storefront/primitives/pagination.d.ts.map +1 -0
- package/dist/client/storefront/primitives/pagination.mjs +86 -0
- package/dist/client/storefront/primitives/pagination.mjs.map +1 -0
- package/dist/client/storefront/primitives/quick-links.d.ts +11 -0
- package/dist/client/storefront/primitives/quick-links.d.ts.map +1 -0
- package/dist/client/storefront/primitives/quick-links.mjs +17 -0
- package/dist/client/storefront/primitives/quick-links.mjs.map +1 -0
- package/dist/client/storefront/primitives/select.d.ts +16 -0
- package/dist/client/storefront/primitives/select.d.ts.map +1 -0
- package/dist/client/storefront/primitives/select.mjs +35 -0
- package/dist/client/storefront/primitives/select.mjs.map +1 -0
- package/dist/client/storefront/primitives/text-link.d.ts +7 -0
- package/dist/client/storefront/primitives/text-link.d.ts.map +1 -0
- package/dist/client/storefront/primitives/text-link.mjs +10 -0
- package/dist/client/storefront/primitives/text-link.mjs.map +1 -0
- package/dist/client/storefront/product/color-swatch.d.ts +10 -0
- package/dist/client/storefront/product/color-swatch.d.ts.map +1 -0
- package/dist/client/storefront/product/color-swatch.mjs +32 -0
- package/dist/client/storefront/product/color-swatch.mjs.map +1 -0
- package/dist/client/storefront/product/index.d.ts +5 -0
- package/dist/client/storefront/product/index.d.ts.map +1 -0
- package/dist/client/storefront/product/index.mjs +11 -0
- package/dist/client/storefront/product/index.mjs.map +1 -0
- package/dist/client/storefront/product/material-selector.d.ts +15 -0
- package/dist/client/storefront/product/material-selector.d.ts.map +1 -0
- package/dist/client/storefront/product/material-selector.mjs +35 -0
- package/dist/client/storefront/product/material-selector.mjs.map +1 -0
- package/dist/client/storefront/product/product-usp.d.ts +7 -0
- package/dist/client/storefront/product/product-usp.d.ts.map +1 -0
- package/dist/client/storefront/product/product-usp.mjs +14 -0
- package/dist/client/storefront/product/product-usp.mjs.map +1 -0
- package/dist/client/storefront/product/quantity-picker.d.ts +10 -0
- package/dist/client/storefront/product/quantity-picker.d.ts.map +1 -0
- package/dist/client/storefront/product/quantity-picker.mjs +56 -0
- package/dist/client/storefront/product/quantity-picker.mjs.map +1 -0
- package/dist/client/storefront/types.d.ts +284 -0
- package/dist/client/storefront/types.d.ts.map +1 -0
- package/dist/client/storefront/types.mjs +20 -0
- package/dist/client/storefront/types.mjs.map +1 -0
- package/dist/client/theme/apply.d.ts +17 -0
- package/dist/client/theme/apply.d.ts.map +1 -0
- package/dist/client/theme/apply.mjs +133 -0
- package/dist/client/theme/apply.mjs.map +1 -0
- package/dist/client/theme/cli.d.ts +2 -0
- package/dist/client/theme/cli.d.ts.map +1 -0
- package/dist/client/theme/cli.mjs +453 -0
- package/dist/client/theme/cli.mjs.map +1 -0
- package/dist/client/theme/codec.d.ts +28 -0
- package/dist/client/theme/codec.d.ts.map +1 -0
- package/dist/client/theme/codec.mjs +88 -0
- package/dist/client/theme/codec.mjs.map +1 -0
- package/dist/client/theme/defaults.d.ts +64 -0
- package/dist/client/theme/defaults.d.ts.map +1 -0
- package/dist/client/theme/defaults.mjs +158 -0
- package/dist/client/theme/defaults.mjs.map +1 -0
- package/dist/client/theme/index.d.ts +8 -0
- package/dist/client/theme/index.d.ts.map +1 -0
- package/dist/client/theme/index.mjs +20 -0
- package/dist/client/theme/index.mjs.map +1 -0
- package/dist/client/theme/scan.d.ts +16 -0
- package/dist/client/theme/scan.d.ts.map +1 -0
- package/dist/client/theme/scan.mjs +25 -0
- package/dist/client/theme/scan.mjs.map +1 -0
- package/dist/client/ui/accordion.d.ts +8 -0
- package/dist/client/ui/accordion.d.ts.map +1 -0
- package/dist/client/ui/accordion.mjs +66 -0
- package/dist/client/ui/accordion.mjs.map +1 -0
- package/dist/client/ui/breadcrumb.d.ts +12 -0
- package/dist/client/ui/breadcrumb.d.ts.map +1 -0
- package/dist/client/ui/breadcrumb.mjs +104 -0
- package/dist/client/ui/breadcrumb.mjs.map +1 -0
- package/dist/client/ui/button.d.ts +11 -0
- package/dist/client/ui/button.d.ts.map +1 -0
- package/dist/client/ui/button.mjs +57 -0
- package/dist/client/ui/button.mjs.map +1 -0
- package/dist/client/ui/card.d.ts +10 -0
- package/dist/client/ui/card.d.ts.map +1 -0
- package/dist/client/ui/card.mjs +91 -0
- package/dist/client/ui/card.mjs.map +1 -0
- package/dist/client/ui/carousel.d.ts +20 -0
- package/dist/client/ui/carousel.d.ts.map +1 -0
- package/dist/client/ui/carousel.mjs +202 -0
- package/dist/client/ui/carousel.mjs.map +1 -0
- package/dist/client/ui/checkbox.d.ts +5 -0
- package/dist/client/ui/checkbox.d.ts.map +1 -0
- package/dist/client/ui/checkbox.mjs +34 -0
- package/dist/client/ui/checkbox.mjs.map +1 -0
- package/dist/client/ui/collapsible.d.ts +6 -0
- package/dist/client/ui/collapsible.d.ts.map +1 -0
- package/dist/client/ui/collapsible.mjs +36 -0
- package/dist/client/ui/collapsible.mjs.map +1 -0
- package/dist/client/ui/input.d.ts +4 -0
- package/dist/client/ui/input.d.ts.map +1 -0
- package/dist/client/ui/input.mjs +22 -0
- package/dist/client/ui/input.mjs.map +1 -0
- package/dist/client/ui/label.d.ts +5 -0
- package/dist/client/ui/label.d.ts.map +1 -0
- package/dist/client/ui/label.mjs +23 -0
- package/dist/client/ui/label.mjs.map +1 -0
- package/dist/client/ui/mid-truncate.d.ts +27 -0
- package/dist/client/ui/mid-truncate.d.ts.map +1 -0
- package/dist/client/ui/mid-truncate.mjs +25 -0
- package/dist/client/ui/mid-truncate.mjs.map +1 -0
- package/dist/client/ui/navigation-menu.d.ts +15 -0
- package/dist/client/ui/navigation-menu.d.ts.map +1 -0
- package/dist/client/ui/navigation-menu.mjs +172 -0
- package/dist/client/ui/navigation-menu.mjs.map +1 -0
- package/dist/client/ui/pagination.d.ts +14 -0
- package/dist/client/ui/pagination.d.ts.map +1 -0
- package/dist/client/ui/pagination.mjs +124 -0
- package/dist/client/ui/pagination.mjs.map +1 -0
- package/dist/client/ui/popover.d.ts +11 -0
- package/dist/client/ui/popover.d.ts.map +1 -0
- package/dist/client/ui/popover.mjs +82 -0
- package/dist/client/ui/popover.mjs.map +1 -0
- package/dist/client/ui/select.d.ts +16 -0
- package/dist/client/ui/select.d.ts.map +1 -0
- package/dist/client/ui/select.mjs +183 -0
- package/dist/client/ui/select.mjs.map +1 -0
- package/dist/client/ui/separator.d.ts +5 -0
- package/dist/client/ui/separator.d.ts.map +1 -0
- package/dist/client/ui/separator.mjs +27 -0
- package/dist/client/ui/separator.mjs.map +1 -0
- package/dist/client/ui/sheet.d.ts +15 -0
- package/dist/client/ui/sheet.d.ts.map +1 -0
- package/dist/client/ui/sheet.mjs +130 -0
- package/dist/client/ui/sheet.mjs.map +1 -0
- package/dist/client/ui/toggle-group.d.ts +10 -0
- package/dist/client/ui/toggle-group.d.ts.map +1 -0
- package/dist/client/ui/toggle-group.mjs +69 -0
- package/dist/client/ui/toggle-group.mjs.map +1 -0
- package/dist/client/ui/toggle.d.ts +10 -0
- package/dist/client/ui/toggle.d.ts.map +1 -0
- package/dist/client/ui/toggle.mjs +44 -0
- package/dist/client/ui/toggle.mjs.map +1 -0
- package/dist/client/ui/utils.d.ts +3 -0
- package/dist/client/ui/utils.d.ts.map +1 -0
- package/dist/client/ui/utils.mjs +9 -0
- package/dist/client/ui/utils.mjs.map +1 -0
- package/dist/client/ui-interfaces/accordion.d.ts +8 -0
- package/dist/client/ui-interfaces/accordion.d.ts.map +1 -0
- package/dist/client/ui-interfaces/accordion.mjs +72 -0
- package/dist/client/ui-interfaces/accordion.mjs.map +1 -0
- package/dist/client/ui-interfaces/breadcrumb.d.ts +12 -0
- package/dist/client/ui-interfaces/breadcrumb.d.ts.map +1 -0
- package/dist/client/ui-interfaces/breadcrumb.mjs +97 -0
- package/dist/client/ui-interfaces/breadcrumb.mjs.map +1 -0
- package/dist/client/ui-interfaces/button.d.ts +11 -0
- package/dist/client/ui-interfaces/button.d.ts.map +1 -0
- package/dist/client/ui-interfaces/button.mjs +57 -0
- package/dist/client/ui-interfaces/button.mjs.map +1 -0
- package/dist/client/ui-interfaces/card.d.ts +10 -0
- package/dist/client/ui-interfaces/card.d.ts.map +1 -0
- package/dist/client/ui-interfaces/card.mjs +78 -0
- package/dist/client/ui-interfaces/card.mjs.map +1 -0
- package/dist/client/ui-interfaces/carousel.d.ts +20 -0
- package/dist/client/ui-interfaces/carousel.d.ts.map +1 -0
- package/dist/client/ui-interfaces/carousel.mjs +188 -0
- package/dist/client/ui-interfaces/carousel.mjs.map +1 -0
- package/dist/client/ui-interfaces/checkbox.d.ts +5 -0
- package/dist/client/ui-interfaces/checkbox.d.ts.map +1 -0
- package/dist/client/ui-interfaces/checkbox.mjs +30 -0
- package/dist/client/ui-interfaces/checkbox.mjs.map +1 -0
- package/dist/client/ui-interfaces/collapsible.d.ts +7 -0
- package/dist/client/ui-interfaces/collapsible.d.ts.map +1 -0
- package/dist/client/ui-interfaces/collapsible.mjs +42 -0
- package/dist/client/ui-interfaces/collapsible.mjs.map +1 -0
- package/dist/client/ui-interfaces/index.d.ts +18 -0
- package/dist/client/ui-interfaces/index.d.ts.map +1 -0
- package/dist/client/ui-interfaces/index.mjs +18 -0
- package/dist/client/ui-interfaces/index.mjs.map +1 -0
- package/dist/client/ui-interfaces/input.d.ts +7 -0
- package/dist/client/ui-interfaces/input.d.ts.map +1 -0
- package/dist/client/ui-interfaces/input.mjs +39 -0
- package/dist/client/ui-interfaces/input.mjs.map +1 -0
- package/dist/client/ui-interfaces/label.d.ts +5 -0
- package/dist/client/ui-interfaces/label.d.ts.map +1 -0
- package/dist/client/ui-interfaces/label.mjs +23 -0
- package/dist/client/ui-interfaces/label.mjs.map +1 -0
- package/dist/client/ui-interfaces/navigation-menu.d.ts +15 -0
- package/dist/client/ui-interfaces/navigation-menu.d.ts.map +1 -0
- package/dist/client/ui-interfaces/navigation-menu.mjs +163 -0
- package/dist/client/ui-interfaces/navigation-menu.mjs.map +1 -0
- package/dist/client/ui-interfaces/pagination.d.ts +14 -0
- package/dist/client/ui-interfaces/pagination.d.ts.map +1 -0
- package/dist/client/ui-interfaces/pagination.mjs +103 -0
- package/dist/client/ui-interfaces/pagination.mjs.map +1 -0
- package/dist/client/ui-interfaces/popover.d.ts +8 -0
- package/dist/client/ui-interfaces/popover.d.ts.map +1 -0
- package/dist/client/ui-interfaces/popover.mjs +50 -0
- package/dist/client/ui-interfaces/popover.mjs.map +1 -0
- package/dist/client/ui-interfaces/select.d.ts +16 -0
- package/dist/client/ui-interfaces/select.d.ts.map +1 -0
- package/dist/client/ui-interfaces/select.mjs +159 -0
- package/dist/client/ui-interfaces/select.mjs.map +1 -0
- package/dist/client/ui-interfaces/separator.d.ts +5 -0
- package/dist/client/ui-interfaces/separator.d.ts.map +1 -0
- package/dist/client/ui-interfaces/separator.mjs +28 -0
- package/dist/client/ui-interfaces/separator.mjs.map +1 -0
- package/dist/client/ui-interfaces/sheet.d.ts +14 -0
- package/dist/client/ui-interfaces/sheet.d.ts.map +1 -0
- package/dist/client/ui-interfaces/sheet.mjs +140 -0
- package/dist/client/ui-interfaces/sheet.mjs.map +1 -0
- package/dist/client/ui-interfaces/toggle-group.d.ts +10 -0
- package/dist/client/ui-interfaces/toggle-group.d.ts.map +1 -0
- package/dist/client/ui-interfaces/toggle-group.mjs +67 -0
- package/dist/client/ui-interfaces/toggle-group.mjs.map +1 -0
- package/dist/client/ui-interfaces/toggle.d.ts +10 -0
- package/dist/client/ui-interfaces/toggle.d.ts.map +1 -0
- package/dist/client/ui-interfaces/toggle.mjs +45 -0
- package/dist/client/ui-interfaces/toggle.mjs.map +1 -0
- package/dist/client/ui-resolver/accordion.d.ts +11 -0
- package/dist/client/ui-resolver/accordion.d.ts.map +1 -0
- package/dist/client/ui-resolver/accordion.mjs +35 -0
- package/dist/client/ui-resolver/accordion.mjs.map +1 -0
- package/dist/client/ui-resolver/breadcrumb.d.ts +14 -0
- package/dist/client/ui-resolver/breadcrumb.d.ts.map +1 -0
- package/dist/client/ui-resolver/breadcrumb.mjs +53 -0
- package/dist/client/ui-resolver/breadcrumb.mjs.map +1 -0
- package/dist/client/ui-resolver/button.d.ts +12 -0
- package/dist/client/ui-resolver/button.d.ts.map +1 -0
- package/dist/client/ui-resolver/button.mjs +25 -0
- package/dist/client/ui-resolver/button.mjs.map +1 -0
- package/dist/client/ui-resolver/card.d.ts +14 -0
- package/dist/client/ui-resolver/card.d.ts.map +1 -0
- package/dist/client/ui-resolver/card.mjs +53 -0
- package/dist/client/ui-resolver/card.mjs.map +1 -0
- package/dist/client/ui-resolver/carousel.d.ts +13 -0
- package/dist/client/ui-resolver/carousel.d.ts.map +1 -0
- package/dist/client/ui-resolver/carousel.mjs +41 -0
- package/dist/client/ui-resolver/carousel.mjs.map +1 -0
- package/dist/client/ui-resolver/checkbox.d.ts +8 -0
- package/dist/client/ui-resolver/checkbox.d.ts.map +1 -0
- package/dist/client/ui-resolver/checkbox.mjs +17 -0
- package/dist/client/ui-resolver/checkbox.mjs.map +1 -0
- package/dist/client/ui-resolver/collapsible.d.ts +10 -0
- package/dist/client/ui-resolver/collapsible.d.ts.map +1 -0
- package/dist/client/ui-resolver/collapsible.mjs +29 -0
- package/dist/client/ui-resolver/collapsible.mjs.map +1 -0
- package/dist/client/ui-resolver/context.d.ts +10 -0
- package/dist/client/ui-resolver/context.d.ts.map +1 -0
- package/dist/client/ui-resolver/context.mjs +28 -0
- package/dist/client/ui-resolver/context.mjs.map +1 -0
- package/dist/client/ui-resolver/index.d.ts +19 -0
- package/dist/client/ui-resolver/index.d.ts.map +1 -0
- package/dist/client/ui-resolver/index.mjs +156 -0
- package/dist/client/ui-resolver/index.mjs.map +1 -0
- package/dist/client/ui-resolver/input.d.ts +8 -0
- package/dist/client/ui-resolver/input.d.ts.map +1 -0
- package/dist/client/ui-resolver/input.mjs +17 -0
- package/dist/client/ui-resolver/input.mjs.map +1 -0
- package/dist/client/ui-resolver/label.d.ts +8 -0
- package/dist/client/ui-resolver/label.d.ts.map +1 -0
- package/dist/client/ui-resolver/label.mjs +17 -0
- package/dist/client/ui-resolver/label.mjs.map +1 -0
- package/dist/client/ui-resolver/navigation-menu.d.ts +16 -0
- package/dist/client/ui-resolver/navigation-menu.d.ts.map +1 -0
- package/dist/client/ui-resolver/navigation-menu.mjs +64 -0
- package/dist/client/ui-resolver/navigation-menu.mjs.map +1 -0
- package/dist/client/ui-resolver/pagination.d.ts +14 -0
- package/dist/client/ui-resolver/pagination.d.ts.map +1 -0
- package/dist/client/ui-resolver/pagination.mjs +53 -0
- package/dist/client/ui-resolver/pagination.mjs.map +1 -0
- package/dist/client/ui-resolver/popover.d.ts +11 -0
- package/dist/client/ui-resolver/popover.d.ts.map +1 -0
- package/dist/client/ui-resolver/popover.mjs +35 -0
- package/dist/client/ui-resolver/popover.mjs.map +1 -0
- package/dist/client/ui-resolver/select.d.ts +15 -0
- package/dist/client/ui-resolver/select.d.ts.map +1 -0
- package/dist/client/ui-resolver/select.mjs +59 -0
- package/dist/client/ui-resolver/select.mjs.map +1 -0
- package/dist/client/ui-resolver/separator.d.ts +8 -0
- package/dist/client/ui-resolver/separator.d.ts.map +1 -0
- package/dist/client/ui-resolver/separator.mjs +17 -0
- package/dist/client/ui-resolver/separator.mjs.map +1 -0
- package/dist/client/ui-resolver/sheet.d.ts +15 -0
- package/dist/client/ui-resolver/sheet.d.ts.map +1 -0
- package/dist/client/ui-resolver/sheet.mjs +59 -0
- package/dist/client/ui-resolver/sheet.mjs.map +1 -0
- package/dist/client/ui-resolver/toggle-group.d.ts +9 -0
- package/dist/client/ui-resolver/toggle-group.d.ts.map +1 -0
- package/dist/client/ui-resolver/toggle-group.mjs +23 -0
- package/dist/client/ui-resolver/toggle-group.mjs.map +1 -0
- package/dist/client/ui-resolver/toggle.d.ts +12 -0
- package/dist/client/ui-resolver/toggle.d.ts.map +1 -0
- package/dist/client/ui-resolver/toggle.mjs +25 -0
- package/dist/client/ui-resolver/toggle.mjs.map +1 -0
- package/dist/client/user/actions/createResetPasswordLinkAction.d.ts +14 -0
- package/dist/client/user/actions/createResetPasswordLinkAction.d.ts.map +1 -0
- package/dist/client/user/actions/createResetPasswordLinkAction.mjs +1 -1
- package/dist/client/user/actions/createResetPasswordLinkAction.mjs.map +1 -1
- package/dist/client/user/actions/getUserAction.d.ts +3 -0
- package/dist/client/user/actions/getUserAction.d.ts.map +1 -0
- package/dist/client/user/actions/getUserAction.mjs.map +1 -1
- package/dist/client/user/actions/{logInUserAction.d.mts → logInUserAction.d.ts} +3 -3
- package/dist/client/user/actions/logInUserAction.d.ts.map +1 -0
- package/dist/client/user/actions/logoutUserAction.d.ts +2 -0
- package/dist/client/user/actions/logoutUserAction.d.ts.map +1 -0
- package/dist/client/user/actions/registerOrganisationAction.d.ts +9 -0
- package/dist/client/user/actions/registerOrganisationAction.d.ts.map +1 -0
- package/dist/client/user/actions/registerOrganisationAction.mjs.map +1 -1
- package/dist/client/user/actions/{registerUserAction.d.mts → registerUserAction.d.ts} +3 -3
- package/dist/client/user/actions/registerUserAction.d.ts.map +1 -0
- package/dist/client/user/actions/registerUserAction.mjs +1 -1
- package/dist/client/user/actions/registerUserAction.mjs.map +1 -1
- package/dist/client/user/actions/{registerUserWithoutRedirectAction.d.mts → registerUserWithoutRedirectAction.d.ts} +3 -6
- package/dist/client/user/actions/registerUserWithoutRedirectAction.d.ts.map +1 -0
- package/dist/client/user/actions/{updatePasswordAction.d.mts → updatePasswordAction.d.ts} +3 -3
- package/dist/client/user/actions/updatePasswordAction.d.ts.map +1 -0
- package/dist/client/user/actions/updatePasswordAction.mjs +1 -1
- package/dist/client/user/actions/updatePasswordAction.mjs.map +1 -1
- package/dist/client/user/api/userRoute.d.ts +7 -0
- package/dist/client/user/api/userRoute.d.ts.map +1 -0
- package/dist/client/user/clients/enad.d.ts +4 -0
- package/dist/client/user/clients/enad.d.ts.map +1 -0
- package/dist/client/user/components/login-form.d.ts +23 -0
- package/dist/client/user/components/login-form.d.ts.map +1 -0
- package/dist/client/user/components/login-form.mjs +77 -73
- package/dist/client/user/components/login-form.mjs.map +1 -1
- package/dist/client/user/components/reset-password-form.d.ts +20 -0
- package/dist/client/user/components/reset-password-form.d.ts.map +1 -0
- package/dist/client/user/components/reset-password-form.mjs +57 -50
- package/dist/client/user/components/reset-password-form.mjs.map +1 -1
- package/dist/client/user/components/sign-out.d.ts +8 -0
- package/dist/client/user/components/sign-out.d.ts.map +1 -0
- package/dist/client/user/components/sign-out.mjs +6 -3
- package/dist/client/user/components/sign-out.mjs.map +1 -1
- package/dist/client/user/components/signup-form.d.ts +27 -0
- package/dist/client/user/components/signup-form.d.ts.map +1 -0
- package/dist/client/user/components/signup-form.mjs +153 -120
- package/dist/client/user/components/signup-form.mjs.map +1 -1
- package/dist/client/user/components/signup-organisation-form.d.ts +55 -0
- package/dist/client/user/components/signup-organisation-form.d.ts.map +1 -0
- package/dist/client/user/components/signup-organisation-form.mjs +713 -662
- package/dist/client/user/components/signup-organisation-form.mjs.map +1 -1
- package/dist/client/user/components/update-password-form.d.ts +17 -0
- package/dist/client/user/components/update-password-form.d.ts.map +1 -0
- package/dist/client/user/components/update-password-form.mjs +26 -35
- package/dist/client/user/components/update-password-form.mjs.map +1 -1
- package/dist/client/user/hooks/index.d.ts +2 -0
- package/dist/client/user/hooks/index.d.ts.map +1 -0
- package/dist/client/user/hooks/useUser.d.ts +12 -0
- package/dist/client/user/hooks/useUser.d.ts.map +1 -0
- package/dist/client/user/hooks/useUser.mjs +1 -1
- package/dist/client/user/hooks/useUser.mjs.map +1 -1
- package/dist/client/user/index.d.ts +9 -0
- package/dist/client/user/index.d.ts.map +1 -0
- package/dist/client/user/index.mjs +17 -0
- package/dist/client/user/index.mjs.map +1 -0
- package/dist/client/user/types/{user.d.mts → user.d.ts} +25 -26
- package/dist/client/user/types/user.d.ts.map +1 -0
- package/dist/client/user/utils/{userCookieService.d.mts → userCookieService.d.ts} +2 -3
- package/dist/client/user/utils/userCookieService.d.ts.map +1 -0
- package/dist/client/wishlist/actions/addItemsToWishlistAction.d.ts +5 -0
- package/dist/client/wishlist/actions/addItemsToWishlistAction.d.ts.map +1 -0
- package/dist/client/wishlist/actions/addItemsToWishlistAction.mjs.map +1 -1
- package/dist/client/wishlist/actions/createOrGetShareTokenAction.d.ts +3 -0
- package/dist/client/wishlist/actions/createOrGetShareTokenAction.d.ts.map +1 -0
- package/dist/client/wishlist/actions/createOrGetShareTokenAction.mjs.map +1 -1
- package/dist/client/wishlist/actions/createWishlistAction.d.ts +3 -0
- package/dist/client/wishlist/actions/createWishlistAction.d.ts.map +1 -0
- package/dist/client/wishlist/actions/createWishlistAction.mjs.map +1 -1
- package/dist/client/wishlist/actions/deleteItemsFromWishlistAction.d.ts +5 -0
- package/dist/client/wishlist/actions/deleteItemsFromWishlistAction.d.ts.map +1 -0
- package/dist/client/wishlist/actions/deleteItemsFromWishlistAction.mjs.map +1 -1
- package/dist/client/wishlist/actions/deleteWishlistAction.d.ts +4 -0
- package/dist/client/wishlist/actions/deleteWishlistAction.d.ts.map +1 -0
- package/dist/client/wishlist/actions/getSharedWishlistAction.d.ts +3 -0
- package/dist/client/wishlist/actions/getSharedWishlistAction.d.ts.map +1 -0
- package/dist/client/wishlist/actions/getSharedWishlistAction.mjs.map +1 -1
- package/dist/client/wishlist/actions/getSpecificWishlistAction.d.ts +3 -0
- package/dist/client/wishlist/actions/getSpecificWishlistAction.d.ts.map +1 -0
- package/dist/client/wishlist/actions/getSpecificWishlistAction.mjs.map +1 -1
- package/dist/client/wishlist/actions/getUserWishlists.d.ts +4 -0
- package/dist/client/wishlist/actions/getUserWishlists.d.ts.map +1 -0
- package/dist/client/wishlist/actions/getUserWishlists.mjs.map +1 -1
- package/dist/client/wishlist/actions/revokeShareTokenAction.d.ts +4 -0
- package/dist/client/wishlist/actions/revokeShareTokenAction.d.ts.map +1 -0
- package/dist/client/wishlist/actions/updateWishlistAction.d.ts +3 -0
- package/dist/client/wishlist/actions/updateWishlistAction.d.ts.map +1 -0
- package/dist/client/wishlist/actions/updateWishlistAction.mjs.map +1 -1
- package/dist/client/wishlist/hooks/index.d.ts +2 -0
- package/dist/client/wishlist/hooks/index.d.ts.map +1 -0
- package/dist/client/wishlist/hooks/useWishlist.d.ts +95 -0
- package/dist/client/wishlist/hooks/useWishlist.d.ts.map +1 -0
- package/dist/client/wishlist/hooks/useWishlist.mjs +14 -4
- package/dist/client/wishlist/hooks/useWishlist.mjs.map +1 -1
- package/dist/client/wishlist/hooks/useWishlistActions.d.ts +44 -0
- package/dist/client/wishlist/hooks/useWishlistActions.d.ts.map +1 -0
- package/dist/client/wishlist/hooks/useWishlistActions.mjs.map +1 -1
- package/dist/client/wishlist/index.d.ts +5 -0
- package/dist/client/wishlist/index.d.ts.map +1 -0
- package/dist/client/wishlist/index.mjs +9 -0
- package/dist/client/wishlist/index.mjs.map +1 -0
- package/dist/client/wishlist/wishlist-drawer.d.ts +17 -0
- package/dist/client/wishlist/wishlist-drawer.d.ts.map +1 -0
- package/dist/client/wishlist/wishlist-drawer.mjs +189 -170
- package/dist/client/wishlist/wishlist-drawer.mjs.map +1 -1
- package/dist/styles.css +1 -958
- package/package.json +107 -33
- package/dist/client/cart/components/cart-trigger.d.mts +0 -5
- package/dist/client/cart/constants/session.d.mts +0 -3
- package/dist/client/cart/contexts/cart.d.mts +0 -27
- package/dist/client/cart/hooks/useCart.d.mts +0 -29
- package/dist/client/cart/hooks/useCartActions.d.mts +0 -26
- package/dist/client/cart/queries/addToCartQueryFn.d.mts +0 -10
- package/dist/client/cart/queries/getCartQueryFn.d.mts +0 -7
- package/dist/client/cart/queries/removeCartItemQueryFn.d.mts +0 -9
- package/dist/client/cart/queries/updateCartItemQueryFn.d.mts +0 -10
- package/dist/client/cart/utils/session.d.mts +0 -6
- package/dist/client/cms/storyblok/preview/registerStoryblokBridge.d.mts +0 -6
- package/dist/client/global/auth/withAuth.d.mts +0 -6
- package/dist/client/global/providers/enad-provider.d.mts +0 -23
- package/dist/client/search/actions/searchAction.d.mts +0 -5
- package/dist/client/search/components/search-bar.d.mts +0 -2
- package/dist/client/search/hooks/useSearch.d.mts +0 -18
- package/dist/client/user/actions/createResetPasswordLinkAction.d.mts +0 -14
- package/dist/client/user/actions/getUserAction.d.mts +0 -5
- package/dist/client/user/actions/logoutUserAction.d.mts +0 -3
- package/dist/client/user/actions/registerOrganisationAction.d.mts +0 -12
- package/dist/client/user/api/userRoute.d.mts +0 -9
- package/dist/client/user/clients/enad.d.mts +0 -6
- package/dist/client/user/components/login-form.d.mts +0 -20
- package/dist/client/user/components/reset-password-form.d.mts +0 -15
- package/dist/client/user/components/sign-out.d.mts +0 -5
- package/dist/client/user/components/signup-form.d.mts +0 -15
- package/dist/client/user/components/signup-organisation-form.d.mts +0 -20
- package/dist/client/user/components/update-password-form.d.mts +0 -11
- package/dist/client/user/hooks/index.d.mts +0 -3
- package/dist/client/user/hooks/useUser.d.mts +0 -16
- package/dist/client/wishlist/actions/addItemsToWishlistAction.d.mts +0 -7
- package/dist/client/wishlist/actions/createOrGetShareTokenAction.d.mts +0 -6
- package/dist/client/wishlist/actions/createWishlistAction.d.mts +0 -6
- package/dist/client/wishlist/actions/deleteItemsFromWishlistAction.d.mts +0 -7
- package/dist/client/wishlist/actions/deleteWishlistAction.d.mts +0 -5
- package/dist/client/wishlist/actions/getSharedWishlistAction.d.mts +0 -6
- package/dist/client/wishlist/actions/getSpecificWishlistAction.d.mts +0 -6
- package/dist/client/wishlist/actions/getUserWishlists.d.mts +0 -7
- package/dist/client/wishlist/actions/revokeShareTokenAction.d.mts +0 -5
- package/dist/client/wishlist/actions/updateWishlistAction.d.mts +0 -6
- package/dist/client/wishlist/hooks/index.d.mts +0 -3
- package/dist/client/wishlist/hooks/useWishlist.d.mts +0 -98
- package/dist/client/wishlist/hooks/useWishlistActions.d.mts +0 -48
- package/dist/client/wishlist/wishlist-drawer.d.mts +0 -19
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
+
import * as React from "react";
|
|
4
|
+
import { cn } from "../../ui/utils";
|
|
5
|
+
function useInfiniteScroll({
|
|
6
|
+
onLoadMore,
|
|
7
|
+
hasMore,
|
|
8
|
+
loading = false,
|
|
9
|
+
threshold = "200px",
|
|
10
|
+
root
|
|
11
|
+
}) {
|
|
12
|
+
const observerRef = React.useRef(null);
|
|
13
|
+
const callbackRef = React.useRef(onLoadMore);
|
|
14
|
+
callbackRef.current = onLoadMore;
|
|
15
|
+
const sentinelRef = React.useCallback(
|
|
16
|
+
(node) => {
|
|
17
|
+
if (observerRef.current) {
|
|
18
|
+
observerRef.current.disconnect();
|
|
19
|
+
observerRef.current = null;
|
|
20
|
+
}
|
|
21
|
+
if (!node || !hasMore || loading) return;
|
|
22
|
+
observerRef.current = new IntersectionObserver(
|
|
23
|
+
(entries) => {
|
|
24
|
+
if (entries[0]?.isIntersecting) {
|
|
25
|
+
callbackRef.current();
|
|
26
|
+
}
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
rootMargin: threshold,
|
|
30
|
+
root: root?.current ?? null
|
|
31
|
+
}
|
|
32
|
+
);
|
|
33
|
+
observerRef.current.observe(node);
|
|
34
|
+
},
|
|
35
|
+
[hasMore, loading, threshold, root]
|
|
36
|
+
);
|
|
37
|
+
React.useEffect(() => {
|
|
38
|
+
return () => {
|
|
39
|
+
observerRef.current?.disconnect();
|
|
40
|
+
};
|
|
41
|
+
}, []);
|
|
42
|
+
return { sentinelRef, loading, hasMore };
|
|
43
|
+
}
|
|
44
|
+
function InfiniteScroll({
|
|
45
|
+
onLoadMore,
|
|
46
|
+
hasMore,
|
|
47
|
+
loading = false,
|
|
48
|
+
threshold = "200px",
|
|
49
|
+
showLoadMoreButton = false,
|
|
50
|
+
loadMoreLabel = "Load more",
|
|
51
|
+
loadingIndicator,
|
|
52
|
+
endIndicator,
|
|
53
|
+
children,
|
|
54
|
+
className
|
|
55
|
+
}) {
|
|
56
|
+
const { sentinelRef } = useInfiniteScroll({
|
|
57
|
+
onLoadMore,
|
|
58
|
+
hasMore,
|
|
59
|
+
loading,
|
|
60
|
+
threshold
|
|
61
|
+
});
|
|
62
|
+
const defaultLoadingIndicator = /* @__PURE__ */ jsx("div", { className: "flex justify-center py-8", children: /* @__PURE__ */ jsx("div", { className: "size-6 animate-spin rounded-full border-2 border-muted-foreground/30 border-t-foreground" }) });
|
|
63
|
+
return /* @__PURE__ */ jsxs("div", { className: cn("flex flex-col", className), children: [
|
|
64
|
+
children,
|
|
65
|
+
hasMore && !showLoadMoreButton && /* @__PURE__ */ jsx("div", { ref: sentinelRef, className: "h-px w-full", "aria-hidden": "true" }),
|
|
66
|
+
hasMore && showLoadMoreButton && !loading && /* @__PURE__ */ jsx("div", { className: "flex justify-center py-6", children: /* @__PURE__ */ jsx(
|
|
67
|
+
"button",
|
|
68
|
+
{
|
|
69
|
+
type: "button",
|
|
70
|
+
onClick: onLoadMore,
|
|
71
|
+
className: "rounded-md border border-border px-6 py-2 text-sm font-medium hover:bg-muted transition-colors",
|
|
72
|
+
children: loadMoreLabel
|
|
73
|
+
}
|
|
74
|
+
) }),
|
|
75
|
+
/* @__PURE__ */ jsx("div", { role: "status", "aria-live": "polite", children: loading && (loadingIndicator ?? defaultLoadingIndicator) }),
|
|
76
|
+
!hasMore && !loading && endIndicator
|
|
77
|
+
] });
|
|
78
|
+
}
|
|
79
|
+
export {
|
|
80
|
+
InfiniteScroll,
|
|
81
|
+
useInfiniteScroll
|
|
82
|
+
};
|
|
83
|
+
//# sourceMappingURL=infinite-scroll.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/client/storefront/components/infinite-scroll.tsx"],"sourcesContent":["\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../ui/utils\";\n\n/* ─── Hook ─── */\n\nexport interface UseInfiniteScrollOptions {\n /** Called when sentinel enters viewport */\n onLoadMore: () => void;\n /** Whether more items can be loaded */\n hasMore: boolean;\n /** Whether currently loading */\n loading?: boolean;\n /** IntersectionObserver rootMargin — controls how early to trigger */\n threshold?: string;\n /** Root element for intersection (defaults to viewport) */\n root?: React.RefObject<Element | null>;\n}\n\nexport interface UseInfiniteScrollReturn {\n sentinelRef: React.RefCallback<HTMLElement>;\n loading: boolean;\n hasMore: boolean;\n}\n\nexport function useInfiniteScroll({\n onLoadMore,\n hasMore,\n loading = false,\n threshold = \"200px\",\n root,\n}: UseInfiniteScrollOptions): UseInfiniteScrollReturn {\n const observerRef = React.useRef<IntersectionObserver | null>(null);\n const callbackRef = React.useRef(onLoadMore);\n callbackRef.current = onLoadMore;\n\n const sentinelRef = React.useCallback(\n (node: HTMLElement | null) => {\n if (observerRef.current) {\n observerRef.current.disconnect();\n observerRef.current = null;\n }\n\n if (!node || !hasMore || loading) return;\n\n observerRef.current = new IntersectionObserver(\n (entries) => {\n if (entries[0]?.isIntersecting) {\n callbackRef.current();\n }\n },\n {\n rootMargin: threshold,\n root: root?.current ?? null,\n },\n );\n\n observerRef.current.observe(node);\n },\n [hasMore, loading, threshold, root],\n );\n\n // Cleanup on unmount\n React.useEffect(() => {\n return () => {\n observerRef.current?.disconnect();\n };\n }, []);\n\n return { sentinelRef, loading, hasMore };\n}\n\n/* ─── Component ─── */\n\nexport interface InfiniteScrollProps {\n onLoadMore: () => void;\n hasMore: boolean;\n loading?: boolean;\n /** IntersectionObserver rootMargin */\n threshold?: string;\n /** Fallback \"Load more\" button for accessibility */\n showLoadMoreButton?: boolean;\n loadMoreLabel?: string;\n /** Loading indicator slot */\n loadingIndicator?: React.ReactNode;\n /** End-of-list indicator slot */\n endIndicator?: React.ReactNode;\n children: React.ReactNode;\n className?: string;\n}\n\nexport function InfiniteScroll({\n onLoadMore,\n hasMore,\n loading = false,\n threshold = \"200px\",\n showLoadMoreButton = false,\n loadMoreLabel = \"Load more\",\n loadingIndicator,\n endIndicator,\n children,\n className,\n}: InfiniteScrollProps) {\n const { sentinelRef } = useInfiniteScroll({\n onLoadMore,\n hasMore,\n loading,\n threshold,\n });\n\n const defaultLoadingIndicator = (\n <div className=\"flex justify-center py-8\">\n <div className=\"size-6 animate-spin rounded-full border-2 border-muted-foreground/30 border-t-foreground\" />\n </div>\n );\n\n return (\n <div className={cn(\"flex flex-col\", className)}>\n {children}\n\n {/* Sentinel for IntersectionObserver */}\n {hasMore && !showLoadMoreButton && (\n <div ref={sentinelRef} className=\"h-px w-full\" aria-hidden=\"true\" />\n )}\n\n {/* Manual load-more button fallback */}\n {hasMore && showLoadMoreButton && !loading && (\n <div className=\"flex justify-center py-6\">\n <button\n type=\"button\"\n onClick={onLoadMore}\n className=\"rounded-md border border-border px-6 py-2 text-sm font-medium hover:bg-muted transition-colors\"\n >\n {loadMoreLabel}\n </button>\n </div>\n )}\n\n {/* Loading state */}\n <div role=\"status\" aria-live=\"polite\">\n {loading && (loadingIndicator ?? defaultLoadingIndicator)}\n </div>\n\n {/* End of list */}\n {!hasMore && !loading && endIndicator}\n </div>\n );\n}\n"],"mappings":";AAiHM,cAKF,YALE;AA/GN,YAAY,WAAW;AACvB,SAAS,UAAU;AAuBZ,SAAS,kBAAkB;AAAA,EAChC;AAAA,EACA;AAAA,EACA,UAAU;AAAA,EACV,YAAY;AAAA,EACZ;AACF,GAAsD;AACpD,QAAM,cAAc,MAAM,OAAoC,IAAI;AAClE,QAAM,cAAc,MAAM,OAAO,UAAU;AAC3C,cAAY,UAAU;AAEtB,QAAM,cAAc,MAAM;AAAA,IACxB,CAAC,SAA6B;AAC5B,UAAI,YAAY,SAAS;AACvB,oBAAY,QAAQ,WAAW;AAC/B,oBAAY,UAAU;AAAA,MACxB;AAEA,UAAI,CAAC,QAAQ,CAAC,WAAW,QAAS;AAElC,kBAAY,UAAU,IAAI;AAAA,QACxB,CAAC,YAAY;AACX,cAAI,QAAQ,CAAC,GAAG,gBAAgB;AAC9B,wBAAY,QAAQ;AAAA,UACtB;AAAA,QACF;AAAA,QACA;AAAA,UACE,YAAY;AAAA,UACZ,MAAM,MAAM,WAAW;AAAA,QACzB;AAAA,MACF;AAEA,kBAAY,QAAQ,QAAQ,IAAI;AAAA,IAClC;AAAA,IACA,CAAC,SAAS,SAAS,WAAW,IAAI;AAAA,EACpC;AAGA,QAAM,UAAU,MAAM;AACpB,WAAO,MAAM;AACX,kBAAY,SAAS,WAAW;AAAA,IAClC;AAAA,EACF,GAAG,CAAC,CAAC;AAEL,SAAO,EAAE,aAAa,SAAS,QAAQ;AACzC;AAqBO,SAAS,eAAe;AAAA,EAC7B;AAAA,EACA;AAAA,EACA,UAAU;AAAA,EACV,YAAY;AAAA,EACZ,qBAAqB;AAAA,EACrB,gBAAgB;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAwB;AACtB,QAAM,EAAE,YAAY,IAAI,kBAAkB;AAAA,IACxC;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAED,QAAM,0BACJ,oBAAC,SAAI,WAAU,4BACb,8BAAC,SAAI,WAAU,4FAA2F,GAC5G;AAGF,SACE,qBAAC,SAAI,WAAW,GAAG,iBAAiB,SAAS,GAC1C;AAAA;AAAA,IAGA,WAAW,CAAC,sBACX,oBAAC,SAAI,KAAK,aAAa,WAAU,eAAc,eAAY,QAAO;AAAA,IAInE,WAAW,sBAAsB,CAAC,WACjC,oBAAC,SAAI,WAAU,4BACb;AAAA,MAAC;AAAA;AAAA,QACC,MAAK;AAAA,QACL,SAAS;AAAA,QACT,WAAU;AAAA,QAET;AAAA;AAAA,IACH,GACF;AAAA,IAIF,oBAAC,SAAI,MAAK,UAAS,aAAU,UAC1B,sBAAY,oBAAoB,0BACnC;AAAA,IAGC,CAAC,WAAW,CAAC,WAAW;AAAA,KAC3B;AAEJ;","names":[]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { LanguageSelectorProps, LanguageOption } from "../types";
|
|
2
|
+
declare function LanguageSelector({ languages, value, onValueChange, variant, size, className, labels, }: LanguageSelectorProps): import("react/jsx-runtime").JSX.Element;
|
|
3
|
+
export { LanguageSelector };
|
|
4
|
+
export type { LanguageSelectorProps, LanguageOption };
|
|
5
|
+
//# sourceMappingURL=language-selector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"language-selector.d.ts","sourceRoot":"","sources":["../../../../src/client/storefront/components/language-selector.tsx"],"names":[],"mappings":"AAYA,OAAO,KAAK,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,UAAU,CAAA;AAuBrE,iBAAS,gBAAgB,CAAC,EACxB,SAAS,EACT,KAAK,EACL,aAAa,EACb,OAAgB,EAChB,IAAgB,EAChB,SAAS,EACT,MAAM,GACP,EAAE,qBAAqB,2CAsCvB;AAED,OAAO,EAAE,gBAAgB,EAAE,CAAA;AAC3B,YAAY,EAAE,qBAAqB,EAAE,cAAc,EAAE,CAAA"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useIcon } from "../../icons/icon-context";
|
|
4
|
+
import {
|
|
5
|
+
Select,
|
|
6
|
+
SelectContent,
|
|
7
|
+
SelectItem,
|
|
8
|
+
SelectTrigger,
|
|
9
|
+
SelectValue
|
|
10
|
+
} from "../../ui/select";
|
|
11
|
+
import { cn } from "../../ui/utils";
|
|
12
|
+
function LanguageItemContent({
|
|
13
|
+
language,
|
|
14
|
+
variant
|
|
15
|
+
}) {
|
|
16
|
+
if (variant === "code") {
|
|
17
|
+
return /* @__PURE__ */ jsx("span", { children: language.code.toUpperCase() });
|
|
18
|
+
}
|
|
19
|
+
return /* @__PURE__ */ jsxs("span", { className: "flex items-center gap-2", children: [
|
|
20
|
+
variant === "icon" && language.icon && /* @__PURE__ */ jsx("span", { className: "inline-flex shrink-0", children: language.icon }),
|
|
21
|
+
language.label
|
|
22
|
+
] });
|
|
23
|
+
}
|
|
24
|
+
function LanguageSelector({
|
|
25
|
+
languages,
|
|
26
|
+
value,
|
|
27
|
+
onValueChange,
|
|
28
|
+
variant = "full",
|
|
29
|
+
size = "default",
|
|
30
|
+
className,
|
|
31
|
+
labels
|
|
32
|
+
}) {
|
|
33
|
+
const GlobeIcon = useIcon("globe");
|
|
34
|
+
const selected = languages.find((l) => l.code === value);
|
|
35
|
+
return /* @__PURE__ */ jsxs(Select, { value, onValueChange, children: [
|
|
36
|
+
/* @__PURE__ */ jsx(
|
|
37
|
+
SelectTrigger,
|
|
38
|
+
{
|
|
39
|
+
size,
|
|
40
|
+
className: cn(
|
|
41
|
+
variant === "code" && "border-none shadow-none bg-transparent px-1.5 gap-1",
|
|
42
|
+
className
|
|
43
|
+
),
|
|
44
|
+
"aria-label": labels?.changeLanguage ?? "Change language",
|
|
45
|
+
children: /* @__PURE__ */ jsx(SelectValue, { children: selected && /* @__PURE__ */ jsxs("span", { className: "flex items-center gap-2", children: [
|
|
46
|
+
variant === "icon" && selected.icon && /* @__PURE__ */ jsx("span", { className: "inline-flex shrink-0", children: selected.icon }),
|
|
47
|
+
variant === "code" && /* @__PURE__ */ jsx(GlobeIcon, { className: "size-4" }),
|
|
48
|
+
variant === "code" ? selected.code.toUpperCase() : selected.label
|
|
49
|
+
] }) })
|
|
50
|
+
}
|
|
51
|
+
),
|
|
52
|
+
/* @__PURE__ */ jsx(SelectContent, { position: "popper", align: "end", children: languages.map((lang) => /* @__PURE__ */ jsx(SelectItem, { value: lang.code, children: /* @__PURE__ */ jsx(LanguageItemContent, { language: lang, variant }) }, lang.code)) })
|
|
53
|
+
] });
|
|
54
|
+
}
|
|
55
|
+
export {
|
|
56
|
+
LanguageSelector
|
|
57
|
+
};
|
|
58
|
+
//# sourceMappingURL=language-selector.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/client/storefront/components/language-selector.tsx"],"sourcesContent":["\"use client\"\n\nimport * as React from \"react\"\nimport { useIcon } from \"../../icons/icon-context\"\nimport {\n Select,\n SelectContent,\n SelectItem,\n SelectTrigger,\n SelectValue,\n} from \"../../ui/select\"\nimport { cn } from \"../../ui/utils\"\nimport type { LanguageSelectorProps, LanguageOption } from \"../types\"\n\nfunction LanguageItemContent({\n language,\n variant,\n}: {\n language: LanguageOption\n variant: \"code\" | \"full\" | \"icon\"\n}) {\n if (variant === \"code\") {\n return <span>{language.code.toUpperCase()}</span>\n }\n\n return (\n <span className=\"flex items-center gap-2\">\n {variant === \"icon\" && language.icon && (\n <span className=\"inline-flex shrink-0\">{language.icon}</span>\n )}\n {language.label}\n </span>\n )\n}\n\nfunction LanguageSelector({\n languages,\n value,\n onValueChange,\n variant = \"full\",\n size = \"default\",\n className,\n labels,\n}: LanguageSelectorProps) {\n const GlobeIcon = useIcon(\"globe\")\n\n const selected = languages.find((l) => l.code === value)\n\n return (\n <Select value={value} onValueChange={onValueChange}>\n <SelectTrigger\n size={size}\n className={cn(\n variant === \"code\" && \"border-none shadow-none bg-transparent px-1.5 gap-1\",\n className,\n )}\n aria-label={labels?.changeLanguage ?? \"Change language\"}\n >\n <SelectValue>\n {selected && (\n <span className=\"flex items-center gap-2\">\n {variant === \"icon\" && selected.icon && (\n <span className=\"inline-flex shrink-0\">{selected.icon}</span>\n )}\n {variant === \"code\" && (\n <GlobeIcon className=\"size-4\" />\n )}\n {variant === \"code\" ? selected.code.toUpperCase() : selected.label}\n </span>\n )}\n </SelectValue>\n </SelectTrigger>\n <SelectContent position=\"popper\" align=\"end\">\n {languages.map((lang) => (\n <SelectItem key={lang.code} value={lang.code}>\n <LanguageItemContent language={lang} variant={variant} />\n </SelectItem>\n ))}\n </SelectContent>\n </Select>\n )\n}\n\nexport { LanguageSelector }\nexport type { LanguageSelectorProps, LanguageOption }\n"],"mappings":";AAsBW,cAIP,YAJO;AAnBX,SAAS,eAAe;AACxB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,UAAU;AAGnB,SAAS,oBAAoB;AAAA,EAC3B;AAAA,EACA;AACF,GAGG;AACD,MAAI,YAAY,QAAQ;AACtB,WAAO,oBAAC,UAAM,mBAAS,KAAK,YAAY,GAAE;AAAA,EAC5C;AAEA,SACE,qBAAC,UAAK,WAAU,2BACb;AAAA,gBAAY,UAAU,SAAS,QAC9B,oBAAC,UAAK,WAAU,wBAAwB,mBAAS,MAAK;AAAA,IAEvD,SAAS;AAAA,KACZ;AAEJ;AAEA,SAAS,iBAAiB;AAAA,EACxB;AAAA,EACA;AAAA,EACA;AAAA,EACA,UAAU;AAAA,EACV,OAAO;AAAA,EACP;AAAA,EACA;AACF,GAA0B;AACxB,QAAM,YAAY,QAAQ,OAAO;AAEjC,QAAM,WAAW,UAAU,KAAK,CAAC,MAAM,EAAE,SAAS,KAAK;AAEvD,SACE,qBAAC,UAAO,OAAc,eACpB;AAAA;AAAA,MAAC;AAAA;AAAA,QACC;AAAA,QACA,WAAW;AAAA,UACT,YAAY,UAAU;AAAA,UACtB;AAAA,QACF;AAAA,QACA,cAAY,QAAQ,kBAAkB;AAAA,QAEtC,8BAAC,eACE,sBACC,qBAAC,UAAK,WAAU,2BACb;AAAA,sBAAY,UAAU,SAAS,QAC9B,oBAAC,UAAK,WAAU,wBAAwB,mBAAS,MAAK;AAAA,UAEvD,YAAY,UACX,oBAAC,aAAU,WAAU,UAAS;AAAA,UAE/B,YAAY,SAAS,SAAS,KAAK,YAAY,IAAI,SAAS;AAAA,WAC/D,GAEJ;AAAA;AAAA,IACF;AAAA,IACA,oBAAC,iBAAc,UAAS,UAAS,OAAM,OACpC,oBAAU,IAAI,CAAC,SACd,oBAAC,cAA2B,OAAO,KAAK,MACtC,8BAAC,uBAAoB,UAAU,MAAM,SAAkB,KADxC,KAAK,IAEtB,CACD,GACH;AAAA,KACF;AAEJ;","names":[]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export interface NewsletterSignupProps {
|
|
2
|
+
onSubmit: (email: string) => void | Promise<void>;
|
|
3
|
+
placeholder?: string;
|
|
4
|
+
buttonLabel?: string;
|
|
5
|
+
successMessage?: string;
|
|
6
|
+
errorMessage?: string;
|
|
7
|
+
labels?: {
|
|
8
|
+
heading?: string;
|
|
9
|
+
description?: string;
|
|
10
|
+
};
|
|
11
|
+
className?: string;
|
|
12
|
+
}
|
|
13
|
+
export declare function NewsletterSignup({ onSubmit, placeholder, buttonLabel, successMessage, errorMessage, labels, className, }: NewsletterSignupProps): import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
//# sourceMappingURL=newsletter-signup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"newsletter-signup.d.ts","sourceRoot":"","sources":["../../../../src/client/storefront/components/newsletter-signup.tsx"],"names":[],"mappings":"AAQA,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACjD,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,MAAM,CAAC,EAAE;QACP,OAAO,CAAC,EAAE,MAAM,CAAA;QAChB,WAAW,CAAC,EAAE,MAAM,CAAA;KACrB,CAAA;IACD,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB;AAED,wBAAgB,gBAAgB,CAAC,EAC/B,QAAQ,EACR,WAAgC,EAChC,WAAyB,EACzB,cAA0C,EAC1C,YAAY,EACZ,MAAW,EACX,SAAS,GACV,EAAE,qBAAqB,2CA4EvB"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
+
import * as React from "react";
|
|
4
|
+
import { cn } from "../../ui/utils";
|
|
5
|
+
import { useIcon } from "../../icons/icon-context";
|
|
6
|
+
import { Input } from "../../ui/input";
|
|
7
|
+
import { StorefrontButton } from "../primitives/button";
|
|
8
|
+
function NewsletterSignup({
|
|
9
|
+
onSubmit,
|
|
10
|
+
placeholder = "Enter your email",
|
|
11
|
+
buttonLabel = "Subscribe",
|
|
12
|
+
successMessage = "Thanks for subscribing!",
|
|
13
|
+
errorMessage,
|
|
14
|
+
labels = {},
|
|
15
|
+
className
|
|
16
|
+
}) {
|
|
17
|
+
const MailIcon = useIcon("mail");
|
|
18
|
+
const [email, setEmail] = React.useState("");
|
|
19
|
+
const [status, setStatus] = React.useState("idle");
|
|
20
|
+
const [error, setError] = React.useState(errorMessage);
|
|
21
|
+
React.useEffect(() => {
|
|
22
|
+
setError(errorMessage);
|
|
23
|
+
if (errorMessage) setStatus("error");
|
|
24
|
+
}, [errorMessage]);
|
|
25
|
+
const handleSubmit = async (e) => {
|
|
26
|
+
e.preventDefault();
|
|
27
|
+
if (!email.trim() || status === "loading") return;
|
|
28
|
+
setStatus("loading");
|
|
29
|
+
setError(void 0);
|
|
30
|
+
try {
|
|
31
|
+
await onSubmit(email.trim());
|
|
32
|
+
setStatus("success");
|
|
33
|
+
setEmail("");
|
|
34
|
+
} catch (err) {
|
|
35
|
+
setStatus("error");
|
|
36
|
+
setError(err instanceof Error ? err.message : "Something went wrong. Please try again.");
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
if (status === "success") {
|
|
40
|
+
return /* @__PURE__ */ jsxs("div", { className: cn("font-enad", className), children: [
|
|
41
|
+
labels.heading && /* @__PURE__ */ jsx("p", { className: "text-sm font-heading font-medium text-(--enad-text-primary-color) mb-1", children: labels.heading }),
|
|
42
|
+
/* @__PURE__ */ jsx("p", { className: "text-sm text-(--enad-text-muted-color)", children: successMessage })
|
|
43
|
+
] });
|
|
44
|
+
}
|
|
45
|
+
return /* @__PURE__ */ jsxs("div", { className: cn("font-enad", className), children: [
|
|
46
|
+
labels.heading && /* @__PURE__ */ jsx("p", { className: "text-sm font-heading font-medium text-(--enad-text-primary-color) mb-1", children: labels.heading }),
|
|
47
|
+
labels.description && /* @__PURE__ */ jsx("p", { className: "text-sm text-(--enad-text-muted-color) mb-3", children: labels.description }),
|
|
48
|
+
/* @__PURE__ */ jsxs("form", { onSubmit: handleSubmit, className: "flex gap-2", children: [
|
|
49
|
+
/* @__PURE__ */ jsxs("div", { className: "relative flex-1", children: [
|
|
50
|
+
/* @__PURE__ */ jsx(MailIcon, { className: "absolute left-3 top-1/2 -translate-y-1/2 size-4 text-(--enad-text-muted-color) z-10" }),
|
|
51
|
+
/* @__PURE__ */ jsx(
|
|
52
|
+
Input,
|
|
53
|
+
{
|
|
54
|
+
type: "email",
|
|
55
|
+
required: true,
|
|
56
|
+
value: email,
|
|
57
|
+
onChange: (e) => setEmail(e.target.value),
|
|
58
|
+
placeholder,
|
|
59
|
+
"aria-label": placeholder,
|
|
60
|
+
"aria-describedby": error ? "newsletter-error" : void 0,
|
|
61
|
+
disabled: status === "loading",
|
|
62
|
+
className: "w-full pl-9"
|
|
63
|
+
}
|
|
64
|
+
)
|
|
65
|
+
] }),
|
|
66
|
+
/* @__PURE__ */ jsx(
|
|
67
|
+
StorefrontButton,
|
|
68
|
+
{
|
|
69
|
+
type: "submit",
|
|
70
|
+
disabled: status === "loading",
|
|
71
|
+
children: status === "loading" ? "..." : buttonLabel
|
|
72
|
+
}
|
|
73
|
+
)
|
|
74
|
+
] }),
|
|
75
|
+
error && /* @__PURE__ */ jsx("p", { id: "newsletter-error", className: "mt-1.5 text-xs text-(--enad-error-color)", role: "alert", children: error })
|
|
76
|
+
] });
|
|
77
|
+
}
|
|
78
|
+
export {
|
|
79
|
+
NewsletterSignup
|
|
80
|
+
};
|
|
81
|
+
//# sourceMappingURL=newsletter-signup.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/client/storefront/components/newsletter-signup.tsx"],"sourcesContent":["\"use client\"\n\nimport * as React from \"react\"\nimport { cn } from \"../../ui/utils\"\nimport { useIcon } from \"../../icons/icon-context\"\nimport { Input } from \"../../ui/input\"\nimport { StorefrontButton } from \"../primitives/button\"\n\nexport interface NewsletterSignupProps {\n onSubmit: (email: string) => void | Promise<void>\n placeholder?: string\n buttonLabel?: string\n successMessage?: string\n errorMessage?: string\n labels?: {\n heading?: string\n description?: string\n }\n className?: string\n}\n\nexport function NewsletterSignup({\n onSubmit,\n placeholder = \"Enter your email\",\n buttonLabel = \"Subscribe\",\n successMessage = \"Thanks for subscribing!\",\n errorMessage,\n labels = {},\n className,\n}: NewsletterSignupProps) {\n const MailIcon = useIcon(\"mail\")\n const [email, setEmail] = React.useState(\"\")\n const [status, setStatus] = React.useState<\"idle\" | \"loading\" | \"success\" | \"error\">(\"idle\")\n const [error, setError] = React.useState<string | undefined>(errorMessage)\n\n React.useEffect(() => {\n setError(errorMessage)\n if (errorMessage) setStatus(\"error\")\n }, [errorMessage])\n\n const handleSubmit = async (e: React.FormEvent) => {\n e.preventDefault()\n if (!email.trim() || status === \"loading\") return\n\n setStatus(\"loading\")\n setError(undefined)\n\n try {\n await onSubmit(email.trim())\n setStatus(\"success\")\n setEmail(\"\")\n } catch (err) {\n setStatus(\"error\")\n setError(err instanceof Error ? err.message : \"Something went wrong. Please try again.\")\n }\n }\n\n if (status === \"success\") {\n return (\n <div className={cn(\"font-enad\", className)}>\n {labels.heading && (\n <p className=\"text-sm font-heading font-medium text-(--enad-text-primary-color) mb-1\">{labels.heading}</p>\n )}\n <p className=\"text-sm text-(--enad-text-muted-color)\">{successMessage}</p>\n </div>\n )\n }\n\n return (\n <div className={cn(\"font-enad\", className)}>\n {labels.heading && (\n <p className=\"text-sm font-heading font-medium text-(--enad-text-primary-color) mb-1\">{labels.heading}</p>\n )}\n {labels.description && (\n <p className=\"text-sm text-(--enad-text-muted-color) mb-3\">{labels.description}</p>\n )}\n <form onSubmit={handleSubmit} className=\"flex gap-2\">\n <div className=\"relative flex-1\">\n <MailIcon className=\"absolute left-3 top-1/2 -translate-y-1/2 size-4 text-(--enad-text-muted-color) z-10\" />\n <Input\n type=\"email\"\n required\n value={email}\n onChange={(e) => setEmail(e.target.value)}\n placeholder={placeholder}\n aria-label={placeholder}\n aria-describedby={error ? \"newsletter-error\" : undefined}\n disabled={status === \"loading\"}\n className=\"w-full pl-9\"\n />\n </div>\n <StorefrontButton\n type=\"submit\"\n disabled={status === \"loading\"}\n >\n {status === \"loading\" ? \"...\" : buttonLabel}\n </StorefrontButton>\n </form>\n {error && (\n <p id=\"newsletter-error\" className=\"mt-1.5 text-xs text-(--enad-error-color)\" role=\"alert\">\n {error}\n </p>\n )}\n </div>\n )\n}\n"],"mappings":";AA2DM,SAEI,KAFJ;AAzDN,YAAY,WAAW;AACvB,SAAS,UAAU;AACnB,SAAS,eAAe;AACxB,SAAS,aAAa;AACtB,SAAS,wBAAwB;AAe1B,SAAS,iBAAiB;AAAA,EAC/B;AAAA,EACA,cAAc;AAAA,EACd,cAAc;AAAA,EACd,iBAAiB;AAAA,EACjB;AAAA,EACA,SAAS,CAAC;AAAA,EACV;AACF,GAA0B;AACxB,QAAM,WAAW,QAAQ,MAAM;AAC/B,QAAM,CAAC,OAAO,QAAQ,IAAI,MAAM,SAAS,EAAE;AAC3C,QAAM,CAAC,QAAQ,SAAS,IAAI,MAAM,SAAmD,MAAM;AAC3F,QAAM,CAAC,OAAO,QAAQ,IAAI,MAAM,SAA6B,YAAY;AAEzE,QAAM,UAAU,MAAM;AACpB,aAAS,YAAY;AACrB,QAAI,aAAc,WAAU,OAAO;AAAA,EACrC,GAAG,CAAC,YAAY,CAAC;AAEjB,QAAM,eAAe,OAAO,MAAuB;AACjD,MAAE,eAAe;AACjB,QAAI,CAAC,MAAM,KAAK,KAAK,WAAW,UAAW;AAE3C,cAAU,SAAS;AACnB,aAAS,MAAS;AAElB,QAAI;AACF,YAAM,SAAS,MAAM,KAAK,CAAC;AAC3B,gBAAU,SAAS;AACnB,eAAS,EAAE;AAAA,IACb,SAAS,KAAK;AACZ,gBAAU,OAAO;AACjB,eAAS,eAAe,QAAQ,IAAI,UAAU,yCAAyC;AAAA,IACzF;AAAA,EACF;AAEA,MAAI,WAAW,WAAW;AACxB,WACE,qBAAC,SAAI,WAAW,GAAG,aAAa,SAAS,GACtC;AAAA,aAAO,WACN,oBAAC,OAAE,WAAU,0EAA0E,iBAAO,SAAQ;AAAA,MAExG,oBAAC,OAAE,WAAU,0CAA0C,0BAAe;AAAA,OACxE;AAAA,EAEJ;AAEA,SACE,qBAAC,SAAI,WAAW,GAAG,aAAa,SAAS,GACtC;AAAA,WAAO,WACN,oBAAC,OAAE,WAAU,0EAA0E,iBAAO,SAAQ;AAAA,IAEvG,OAAO,eACN,oBAAC,OAAE,WAAU,+CAA+C,iBAAO,aAAY;AAAA,IAEjF,qBAAC,UAAK,UAAU,cAAc,WAAU,cACtC;AAAA,2BAAC,SAAI,WAAU,mBACb;AAAA,4BAAC,YAAS,WAAU,uFAAsF;AAAA,QAC1G;AAAA,UAAC;AAAA;AAAA,YACC,MAAK;AAAA,YACL,UAAQ;AAAA,YACR,OAAO;AAAA,YACP,UAAU,CAAC,MAAM,SAAS,EAAE,OAAO,KAAK;AAAA,YACxC;AAAA,YACA,cAAY;AAAA,YACZ,oBAAkB,QAAQ,qBAAqB;AAAA,YAC/C,UAAU,WAAW;AAAA,YACrB,WAAU;AAAA;AAAA,QACZ;AAAA,SACF;AAAA,MACA;AAAA,QAAC;AAAA;AAAA,UACC,MAAK;AAAA,UACL,UAAU,WAAW;AAAA,UAEpB,qBAAW,YAAY,QAAQ;AAAA;AAAA,MAClC;AAAA,OACF;AAAA,IACC,SACC,oBAAC,OAAE,IAAG,oBAAmB,WAAU,4CAA2C,MAAK,SAChF,iBACH;AAAA,KAEJ;AAEJ;","names":[]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export interface PriceProps {
|
|
2
|
+
amount: number;
|
|
3
|
+
currency?: string;
|
|
4
|
+
original?: number;
|
|
5
|
+
discountPercent?: number;
|
|
6
|
+
locale?: string;
|
|
7
|
+
className?: string;
|
|
8
|
+
/** Show the -X% discount badge. Default: true */
|
|
9
|
+
showDiscountBadge?: boolean;
|
|
10
|
+
/** Apply colored background to the sale price. Default: true */
|
|
11
|
+
colorSalePrice?: boolean;
|
|
12
|
+
}
|
|
13
|
+
export declare function Price({ amount, currency, original, discountPercent, locale, className, showDiscountBadge, colorSalePrice, }: PriceProps): import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
//# sourceMappingURL=price.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"price.d.ts","sourceRoot":"","sources":["../../../../src/client/storefront/components/price.tsx"],"names":[],"mappings":"AAAA,MAAM,WAAW,UAAU;IACzB,MAAM,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,iDAAiD;IACjD,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,gEAAgE;IAChE,cAAc,CAAC,EAAE,OAAO,CAAA;CACzB;AAWD,wBAAgB,KAAK,CAAC,EACpB,MAAM,EACN,QAAgB,EAChB,QAAQ,EACR,eAAe,EACf,MAAgB,EAChB,SAAc,EACd,iBAAwB,EACxB,cAAqB,GACtB,EAAE,UAAU,2CAoCZ"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
function formatCurrency(amount, currency, locale) {
|
|
3
|
+
return new Intl.NumberFormat(locale, {
|
|
4
|
+
style: "currency",
|
|
5
|
+
currency,
|
|
6
|
+
minimumFractionDigits: 0,
|
|
7
|
+
maximumFractionDigits: 2
|
|
8
|
+
}).format(amount);
|
|
9
|
+
}
|
|
10
|
+
function Price({
|
|
11
|
+
amount,
|
|
12
|
+
currency = "SEK",
|
|
13
|
+
original,
|
|
14
|
+
discountPercent,
|
|
15
|
+
locale = "sv-SE",
|
|
16
|
+
className = "",
|
|
17
|
+
showDiscountBadge = true,
|
|
18
|
+
colorSalePrice = true
|
|
19
|
+
}) {
|
|
20
|
+
const formattedAmount = formatCurrency(amount, currency, locale);
|
|
21
|
+
const hasDiscount = original !== void 0 && original !== amount;
|
|
22
|
+
if (!hasDiscount) {
|
|
23
|
+
return /* @__PURE__ */ jsx("span", { className: `text-(--enad-text-primary-color) ${className}`, children: formattedAmount });
|
|
24
|
+
}
|
|
25
|
+
const formattedOriginal = formatCurrency(original, currency, locale);
|
|
26
|
+
const percent = discountPercent ?? (original > 0 ? Math.round((1 - amount / original) * 100) : void 0);
|
|
27
|
+
return /* @__PURE__ */ jsxs("span", { className: `inline-flex items-center gap-2 ${className}`, children: [
|
|
28
|
+
/* @__PURE__ */ jsx("span", { className: "text-(--enad-text-muted-color) line-through text-sm", children: formattedOriginal }),
|
|
29
|
+
/* @__PURE__ */ jsx(
|
|
30
|
+
"span",
|
|
31
|
+
{
|
|
32
|
+
className: colorSalePrice ? "rounded-md bg-(--enad-error-color)/10 px-1.5 py-0.5 text-(--enad-error-color) font-semibold" : "font-semibold text-(--enad-text-primary-color)",
|
|
33
|
+
children: formattedAmount
|
|
34
|
+
}
|
|
35
|
+
),
|
|
36
|
+
showDiscountBadge && percent != null && percent > 0 && /* @__PURE__ */ jsxs("span", { className: "rounded-full bg-(--enad-error-color) px-2 py-0.5 text-xs font-semibold text-white", children: [
|
|
37
|
+
"-",
|
|
38
|
+
percent,
|
|
39
|
+
"%"
|
|
40
|
+
] })
|
|
41
|
+
] });
|
|
42
|
+
}
|
|
43
|
+
export {
|
|
44
|
+
Price
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=price.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/client/storefront/components/price.tsx"],"sourcesContent":["export interface PriceProps {\n amount: number\n currency?: string\n original?: number\n discountPercent?: number\n locale?: string\n className?: string\n /** Show the -X% discount badge. Default: true */\n showDiscountBadge?: boolean\n /** Apply colored background to the sale price. Default: true */\n colorSalePrice?: boolean\n}\n\nfunction formatCurrency(amount: number, currency: string, locale: string): string {\n return new Intl.NumberFormat(locale, {\n style: \"currency\",\n currency,\n minimumFractionDigits: 0,\n maximumFractionDigits: 2,\n }).format(amount)\n}\n\nexport function Price({\n amount,\n currency = \"SEK\",\n original,\n discountPercent,\n locale = \"sv-SE\",\n className = \"\",\n showDiscountBadge = true,\n colorSalePrice = true,\n}: PriceProps) {\n const formattedAmount = formatCurrency(amount, currency, locale)\n const hasDiscount = original !== undefined && original !== amount\n\n if (!hasDiscount) {\n return (\n <span className={`text-(--enad-text-primary-color) ${className}`}>\n {formattedAmount}\n </span>\n )\n }\n\n const formattedOriginal = formatCurrency(original, currency, locale)\n const percent = discountPercent ?? (original > 0 ? Math.round((1 - amount / original) * 100) : undefined)\n\n return (\n <span className={`inline-flex items-center gap-2 ${className}`}>\n <span className=\"text-(--enad-text-muted-color) line-through text-sm\">\n {formattedOriginal}\n </span>\n <span\n className={\n colorSalePrice\n ? \"rounded-md bg-(--enad-error-color)/10 px-1.5 py-0.5 text-(--enad-error-color) font-semibold\"\n : \"font-semibold text-(--enad-text-primary-color)\"\n }\n >\n {formattedAmount}\n </span>\n {showDiscountBadge && percent != null && percent > 0 && (\n <span className=\"rounded-full bg-(--enad-error-color) px-2 py-0.5 text-xs font-semibold text-white\">\n -{percent}%\n </span>\n )}\n </span>\n )\n}\n"],"mappings":"AAqCM,cAwBE,YAxBF;AAxBN,SAAS,eAAe,QAAgB,UAAkB,QAAwB;AAChF,SAAO,IAAI,KAAK,aAAa,QAAQ;AAAA,IACnC,OAAO;AAAA,IACP;AAAA,IACA,uBAAuB;AAAA,IACvB,uBAAuB;AAAA,EACzB,CAAC,EAAE,OAAO,MAAM;AAClB;AAEO,SAAS,MAAM;AAAA,EACpB;AAAA,EACA,WAAW;AAAA,EACX;AAAA,EACA;AAAA,EACA,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,oBAAoB;AAAA,EACpB,iBAAiB;AACnB,GAAe;AACb,QAAM,kBAAkB,eAAe,QAAQ,UAAU,MAAM;AAC/D,QAAM,cAAc,aAAa,UAAa,aAAa;AAE3D,MAAI,CAAC,aAAa;AAChB,WACE,oBAAC,UAAK,WAAW,oCAAoC,SAAS,IAC3D,2BACH;AAAA,EAEJ;AAEA,QAAM,oBAAoB,eAAe,UAAU,UAAU,MAAM;AACnE,QAAM,UAAU,oBAAoB,WAAW,IAAI,KAAK,OAAO,IAAI,SAAS,YAAY,GAAG,IAAI;AAE/F,SACE,qBAAC,UAAK,WAAW,kCAAkC,SAAS,IAC1D;AAAA,wBAAC,UAAK,WAAU,uDACb,6BACH;AAAA,IACA;AAAA,MAAC;AAAA;AAAA,QACC,WACE,iBACI,gGACA;AAAA,QAGL;AAAA;AAAA,IACH;AAAA,IACC,qBAAqB,WAAW,QAAQ,UAAU,KACjD,qBAAC,UAAK,WAAU,qFAAoF;AAAA;AAAA,MAChG;AAAA,MAAQ;AAAA,OACZ;AAAA,KAEJ;AAEJ;","names":[]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
export interface ProductRecommendationsProps {
|
|
3
|
+
title?: string;
|
|
4
|
+
/** Optional variant label for styling/semantics */
|
|
5
|
+
variant?: "related" | "recent" | "complete-the-look";
|
|
6
|
+
/** Product cards to render — pass <ProductCard> elements */
|
|
7
|
+
children: React.ReactNode;
|
|
8
|
+
/** "View all" link */
|
|
9
|
+
viewAllHref?: string;
|
|
10
|
+
viewAllLabel?: string;
|
|
11
|
+
/** Show navigation arrows on desktop */
|
|
12
|
+
showArrows?: boolean;
|
|
13
|
+
/** Delight level (0-100) for stagger entry animation. 0 = no animation. */
|
|
14
|
+
delight?: number;
|
|
15
|
+
className?: string;
|
|
16
|
+
}
|
|
17
|
+
export declare function ProductRecommendations({ title, children, viewAllHref, viewAllLabel, showArrows, delight, className, }: ProductRecommendationsProps): import("react/jsx-runtime").JSX.Element;
|
|
18
|
+
//# sourceMappingURL=product-recommendations.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"product-recommendations.d.ts","sourceRoot":"","sources":["../../../../src/client/storefront/components/product-recommendations.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAQ/B,MAAM,WAAW,2BAA2B;IAC1C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,mDAAmD;IACnD,OAAO,CAAC,EAAE,SAAS,GAAG,QAAQ,GAAG,mBAAmB,CAAC;IACrD,4DAA4D;IAC5D,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,sBAAsB;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,wCAAwC;IACxC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,2EAA2E;IAC3E,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAID,wBAAgB,sBAAsB,CAAC,EACrC,KAAK,EACL,QAAQ,EACR,WAAW,EACX,YAAyB,EACzB,UAAiB,EACjB,OAAW,EACX,SAAS,GACV,EAAE,2BAA2B,2CAmG7B"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
+
import * as React from "react";
|
|
4
|
+
import { cn } from "../../ui/utils";
|
|
5
|
+
import { useIcon } from "../../icons/icon-context";
|
|
6
|
+
import { getMotionConfig } from "../../motion/config";
|
|
7
|
+
import { staggerEntryClass, staggerChildStyle } from "../../motion/stagger";
|
|
8
|
+
function ProductRecommendations({
|
|
9
|
+
title,
|
|
10
|
+
children,
|
|
11
|
+
viewAllHref,
|
|
12
|
+
viewAllLabel = "View all",
|
|
13
|
+
showArrows = true,
|
|
14
|
+
delight = 0,
|
|
15
|
+
className
|
|
16
|
+
}) {
|
|
17
|
+
const scrollRef = React.useRef(null);
|
|
18
|
+
const motion = React.useMemo(() => getMotionConfig(delight), [delight]);
|
|
19
|
+
const [canScrollLeft, setCanScrollLeft] = React.useState(false);
|
|
20
|
+
const [canScrollRight, setCanScrollRight] = React.useState(false);
|
|
21
|
+
const ChevronLeftIcon = useIcon("chevronLeft");
|
|
22
|
+
const ChevronRightIcon = useIcon("chevronRight");
|
|
23
|
+
const updateScrollState = React.useCallback(() => {
|
|
24
|
+
const el = scrollRef.current;
|
|
25
|
+
if (!el) return;
|
|
26
|
+
setCanScrollLeft(el.scrollLeft > 1);
|
|
27
|
+
setCanScrollRight(el.scrollLeft + el.clientWidth < el.scrollWidth - 1);
|
|
28
|
+
}, []);
|
|
29
|
+
React.useEffect(() => {
|
|
30
|
+
const el = scrollRef.current;
|
|
31
|
+
if (!el) return;
|
|
32
|
+
updateScrollState();
|
|
33
|
+
el.addEventListener("scroll", updateScrollState, { passive: true });
|
|
34
|
+
const ro = new ResizeObserver(updateScrollState);
|
|
35
|
+
ro.observe(el);
|
|
36
|
+
return () => {
|
|
37
|
+
el.removeEventListener("scroll", updateScrollState);
|
|
38
|
+
ro.disconnect();
|
|
39
|
+
};
|
|
40
|
+
}, [updateScrollState]);
|
|
41
|
+
const scroll = (direction) => {
|
|
42
|
+
const el = scrollRef.current;
|
|
43
|
+
if (!el) return;
|
|
44
|
+
const distance = el.clientWidth * 0.8;
|
|
45
|
+
el.scrollBy({
|
|
46
|
+
left: direction === "left" ? -distance : distance,
|
|
47
|
+
behavior: "smooth"
|
|
48
|
+
});
|
|
49
|
+
};
|
|
50
|
+
return /* @__PURE__ */ jsxs("section", { className: cn("flex flex-col gap-4", className), children: [
|
|
51
|
+
(title || viewAllHref) && /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between", children: [
|
|
52
|
+
title && /* @__PURE__ */ jsx("h2", { className: "font-enad text-xl font-semibold", children: title }),
|
|
53
|
+
viewAllHref && /* @__PURE__ */ jsx(
|
|
54
|
+
"a",
|
|
55
|
+
{
|
|
56
|
+
href: viewAllHref,
|
|
57
|
+
className: "text-sm font-medium underline underline-offset-4 hover:text-(--enad-button-bg) transition-colors",
|
|
58
|
+
children: viewAllLabel
|
|
59
|
+
}
|
|
60
|
+
)
|
|
61
|
+
] }),
|
|
62
|
+
/* @__PURE__ */ jsxs("div", { className: "relative group/recs", children: [
|
|
63
|
+
showArrows && canScrollLeft && /* @__PURE__ */ jsx(
|
|
64
|
+
"button",
|
|
65
|
+
{
|
|
66
|
+
type: "button",
|
|
67
|
+
onClick: () => scroll("left"),
|
|
68
|
+
className: "absolute left-0 top-1/2 -translate-y-1/2 z-10 hidden md:flex size-10 items-center justify-center rounded-full bg-(--enad-surface)/90 shadow-md border border-(--enad-border-color)/50 opacity-0 group-hover/recs:opacity-100 focus-visible:opacity-100 focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 transition-opacity hover:bg-(--enad-surface)",
|
|
69
|
+
"aria-label": "Scroll left",
|
|
70
|
+
children: /* @__PURE__ */ jsx(ChevronLeftIcon, { className: "size-5" })
|
|
71
|
+
}
|
|
72
|
+
),
|
|
73
|
+
/* @__PURE__ */ jsx(
|
|
74
|
+
"div",
|
|
75
|
+
{
|
|
76
|
+
ref: scrollRef,
|
|
77
|
+
className: "flex gap-4 overflow-x-auto scroll-smooth snap-x snap-mandatory scrollbar-none pb-1",
|
|
78
|
+
children: React.Children.map(children, (child, i) => /* @__PURE__ */ jsx(
|
|
79
|
+
"div",
|
|
80
|
+
{
|
|
81
|
+
className: cn(
|
|
82
|
+
"w-[260px] shrink-0 snap-start sm:w-[280px] lg:w-[300px]",
|
|
83
|
+
staggerEntryClass(motion)
|
|
84
|
+
),
|
|
85
|
+
style: staggerChildStyle(i, motion),
|
|
86
|
+
children: child
|
|
87
|
+
},
|
|
88
|
+
i
|
|
89
|
+
))
|
|
90
|
+
}
|
|
91
|
+
),
|
|
92
|
+
showArrows && canScrollRight && /* @__PURE__ */ jsx(
|
|
93
|
+
"button",
|
|
94
|
+
{
|
|
95
|
+
type: "button",
|
|
96
|
+
onClick: () => scroll("right"),
|
|
97
|
+
className: "absolute right-0 top-1/2 -translate-y-1/2 z-10 hidden md:flex size-10 items-center justify-center rounded-full bg-(--enad-surface)/90 shadow-md border border-(--enad-border-color)/50 opacity-0 group-hover/recs:opacity-100 focus-visible:opacity-100 focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 transition-opacity hover:bg-(--enad-surface)",
|
|
98
|
+
"aria-label": "Scroll right",
|
|
99
|
+
children: /* @__PURE__ */ jsx(ChevronRightIcon, { className: "size-5" })
|
|
100
|
+
}
|
|
101
|
+
)
|
|
102
|
+
] })
|
|
103
|
+
] });
|
|
104
|
+
}
|
|
105
|
+
export {
|
|
106
|
+
ProductRecommendations
|
|
107
|
+
};
|
|
108
|
+
//# sourceMappingURL=product-recommendations.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/client/storefront/components/product-recommendations.tsx"],"sourcesContent":["\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../ui/utils\";\nimport { useIcon } from \"../../icons/icon-context\";\nimport { getMotionConfig, type MotionConfig } from \"../../motion/config\";\nimport { staggerEntryClass, staggerChildStyle } from \"../../motion/stagger\";\n\n/* ─── Types ─── */\n\nexport interface ProductRecommendationsProps {\n title?: string;\n /** Optional variant label for styling/semantics */\n variant?: \"related\" | \"recent\" | \"complete-the-look\";\n /** Product cards to render — pass <ProductCard> elements */\n children: React.ReactNode;\n /** \"View all\" link */\n viewAllHref?: string;\n viewAllLabel?: string;\n /** Show navigation arrows on desktop */\n showArrows?: boolean;\n /** Delight level (0-100) for stagger entry animation. 0 = no animation. */\n delight?: number;\n className?: string;\n}\n\n/* ─── Component ─── */\n\nexport function ProductRecommendations({\n title,\n children,\n viewAllHref,\n viewAllLabel = \"View all\",\n showArrows = true,\n delight = 0,\n className,\n}: ProductRecommendationsProps) {\n const scrollRef = React.useRef<HTMLDivElement>(null);\n const motion = React.useMemo(() => getMotionConfig(delight), [delight]);\n const [canScrollLeft, setCanScrollLeft] = React.useState(false);\n const [canScrollRight, setCanScrollRight] = React.useState(false);\n const ChevronLeftIcon = useIcon(\"chevronLeft\");\n const ChevronRightIcon = useIcon(\"chevronRight\");\n\n const updateScrollState = React.useCallback(() => {\n const el = scrollRef.current;\n if (!el) return;\n setCanScrollLeft(el.scrollLeft > 1);\n setCanScrollRight(el.scrollLeft + el.clientWidth < el.scrollWidth - 1);\n }, []);\n\n React.useEffect(() => {\n const el = scrollRef.current;\n if (!el) return;\n updateScrollState();\n el.addEventListener(\"scroll\", updateScrollState, { passive: true });\n const ro = new ResizeObserver(updateScrollState);\n ro.observe(el);\n return () => {\n el.removeEventListener(\"scroll\", updateScrollState);\n ro.disconnect();\n };\n }, [updateScrollState]);\n\n const scroll = (direction: \"left\" | \"right\") => {\n const el = scrollRef.current;\n if (!el) return;\n const distance = el.clientWidth * 0.8;\n el.scrollBy({\n left: direction === \"left\" ? -distance : distance,\n behavior: \"smooth\",\n });\n };\n\n return (\n <section className={cn(\"flex flex-col gap-4\", className)}>\n {/* Header */}\n {(title || viewAllHref) && (\n <div className=\"flex items-center justify-between\">\n {title && <h2 className=\"font-enad text-xl font-semibold\">{title}</h2>}\n {viewAllHref && (\n <a\n href={viewAllHref}\n className=\"text-sm font-medium underline underline-offset-4 hover:text-(--enad-button-bg) transition-colors\"\n >\n {viewAllLabel}\n </a>\n )}\n </div>\n )}\n\n {/* Scrollable row */}\n <div className=\"relative group/recs\">\n {showArrows && canScrollLeft && (\n <button\n type=\"button\"\n onClick={() => scroll(\"left\")}\n className=\"absolute left-0 top-1/2 -translate-y-1/2 z-10 hidden md:flex size-10 items-center justify-center rounded-full bg-(--enad-surface)/90 shadow-md border border-(--enad-border-color)/50 opacity-0 group-hover/recs:opacity-100 focus-visible:opacity-100 focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 transition-opacity hover:bg-(--enad-surface)\"\n aria-label=\"Scroll left\"\n >\n <ChevronLeftIcon className=\"size-5\" />\n </button>\n )}\n\n <div\n ref={scrollRef}\n className=\"flex gap-4 overflow-x-auto scroll-smooth snap-x snap-mandatory scrollbar-none pb-1\"\n >\n {React.Children.map(children, (child, i) => (\n <div\n key={i}\n className={cn(\n \"w-[260px] shrink-0 snap-start sm:w-[280px] lg:w-[300px]\",\n staggerEntryClass(motion),\n )}\n style={staggerChildStyle(i, motion)}\n >\n {child}\n </div>\n ))}\n </div>\n\n {showArrows && canScrollRight && (\n <button\n type=\"button\"\n onClick={() => scroll(\"right\")}\n className=\"absolute right-0 top-1/2 -translate-y-1/2 z-10 hidden md:flex size-10 items-center justify-center rounded-full bg-(--enad-surface)/90 shadow-md border border-(--enad-border-color)/50 opacity-0 group-hover/recs:opacity-100 focus-visible:opacity-100 focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 transition-opacity hover:bg-(--enad-surface)\"\n aria-label=\"Scroll right\"\n >\n <ChevronRightIcon className=\"size-5\" />\n </button>\n )}\n </div>\n </section>\n );\n}\n"],"mappings":";AA8EQ,SACY,KADZ;AA5ER,YAAY,WAAW;AACvB,SAAS,UAAU;AACnB,SAAS,eAAe;AACxB,SAAS,uBAA0C;AACnD,SAAS,mBAAmB,yBAAyB;AAsB9C,SAAS,uBAAuB;AAAA,EACrC;AAAA,EACA;AAAA,EACA;AAAA,EACA,eAAe;AAAA,EACf,aAAa;AAAA,EACb,UAAU;AAAA,EACV;AACF,GAAgC;AAC9B,QAAM,YAAY,MAAM,OAAuB,IAAI;AACnD,QAAM,SAAS,MAAM,QAAQ,MAAM,gBAAgB,OAAO,GAAG,CAAC,OAAO,CAAC;AACtE,QAAM,CAAC,eAAe,gBAAgB,IAAI,MAAM,SAAS,KAAK;AAC9D,QAAM,CAAC,gBAAgB,iBAAiB,IAAI,MAAM,SAAS,KAAK;AAChE,QAAM,kBAAkB,QAAQ,aAAa;AAC7C,QAAM,mBAAmB,QAAQ,cAAc;AAE/C,QAAM,oBAAoB,MAAM,YAAY,MAAM;AAChD,UAAM,KAAK,UAAU;AACrB,QAAI,CAAC,GAAI;AACT,qBAAiB,GAAG,aAAa,CAAC;AAClC,sBAAkB,GAAG,aAAa,GAAG,cAAc,GAAG,cAAc,CAAC;AAAA,EACvE,GAAG,CAAC,CAAC;AAEL,QAAM,UAAU,MAAM;AACpB,UAAM,KAAK,UAAU;AACrB,QAAI,CAAC,GAAI;AACT,sBAAkB;AAClB,OAAG,iBAAiB,UAAU,mBAAmB,EAAE,SAAS,KAAK,CAAC;AAClE,UAAM,KAAK,IAAI,eAAe,iBAAiB;AAC/C,OAAG,QAAQ,EAAE;AACb,WAAO,MAAM;AACX,SAAG,oBAAoB,UAAU,iBAAiB;AAClD,SAAG,WAAW;AAAA,IAChB;AAAA,EACF,GAAG,CAAC,iBAAiB,CAAC;AAEtB,QAAM,SAAS,CAAC,cAAgC;AAC9C,UAAM,KAAK,UAAU;AACrB,QAAI,CAAC,GAAI;AACT,UAAM,WAAW,GAAG,cAAc;AAClC,OAAG,SAAS;AAAA,MACV,MAAM,cAAc,SAAS,CAAC,WAAW;AAAA,MACzC,UAAU;AAAA,IACZ,CAAC;AAAA,EACH;AAEA,SACE,qBAAC,aAAQ,WAAW,GAAG,uBAAuB,SAAS,GAEnD;AAAA,cAAS,gBACT,qBAAC,SAAI,WAAU,qCACZ;AAAA,eAAS,oBAAC,QAAG,WAAU,mCAAmC,iBAAM;AAAA,MAChE,eACC;AAAA,QAAC;AAAA;AAAA,UACC,MAAM;AAAA,UACN,WAAU;AAAA,UAET;AAAA;AAAA,MACH;AAAA,OAEJ;AAAA,IAIF,qBAAC,SAAI,WAAU,uBACZ;AAAA,oBAAc,iBACb;AAAA,QAAC;AAAA;AAAA,UACC,MAAK;AAAA,UACL,SAAS,MAAM,OAAO,MAAM;AAAA,UAC5B,WAAU;AAAA,UACV,cAAW;AAAA,UAEX,8BAAC,mBAAgB,WAAU,UAAS;AAAA;AAAA,MACtC;AAAA,MAGF;AAAA,QAAC;AAAA;AAAA,UACC,KAAK;AAAA,UACL,WAAU;AAAA,UAET,gBAAM,SAAS,IAAI,UAAU,CAAC,OAAO,MACpC;AAAA,YAAC;AAAA;AAAA,cAEC,WAAW;AAAA,gBACT;AAAA,gBACA,kBAAkB,MAAM;AAAA,cAC1B;AAAA,cACA,OAAO,kBAAkB,GAAG,MAAM;AAAA,cAEjC;AAAA;AAAA,YAPI;AAAA,UAQP,CACD;AAAA;AAAA,MACH;AAAA,MAEC,cAAc,kBACb;AAAA,QAAC;AAAA;AAAA,UACC,MAAK;AAAA,UACL,SAAS,MAAM,OAAO,OAAO;AAAA,UAC7B,WAAU;AAAA,UACV,cAAW;AAAA,UAEX,8BAAC,oBAAiB,WAAU,UAAS;AAAA;AAAA,MACvC;AAAA,OAEJ;AAAA,KACF;AAEJ;","names":[]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export interface ProductTab {
|
|
2
|
+
id: string;
|
|
3
|
+
label: string;
|
|
4
|
+
content: React.ReactNode;
|
|
5
|
+
}
|
|
6
|
+
export interface ProductTabsProps {
|
|
7
|
+
tabs: ProductTab[];
|
|
8
|
+
defaultTab?: string;
|
|
9
|
+
className?: string;
|
|
10
|
+
}
|
|
11
|
+
export declare function ProductTabs({ tabs, defaultTab, className }: ProductTabsProps): import("react/jsx-runtime").JSX.Element | null;
|
|
12
|
+
//# sourceMappingURL=product-tabs.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"product-tabs.d.ts","sourceRoot":"","sources":["../../../../src/client/storefront/components/product-tabs.tsx"],"names":[],"mappings":"AAIA,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAA;IACV,KAAK,EAAE,MAAM,CAAA;IACb,OAAO,EAAE,KAAK,CAAC,SAAS,CAAA;CACzB;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,UAAU,EAAE,CAAA;IAClB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB;AAED,wBAAgB,WAAW,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,SAAc,EAAE,EAAE,gBAAgB,kDAwEjF"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useState } from "react";
|
|
4
|
+
function ProductTabs({ tabs, defaultTab, className = "" }) {
|
|
5
|
+
const [activeTab, setActiveTab] = useState(() => defaultTab || tabs[0]?.id || "");
|
|
6
|
+
if (tabs.length === 0) return null;
|
|
7
|
+
const activePanel = tabs.find((tab) => tab.id === activeTab);
|
|
8
|
+
return /* @__PURE__ */ jsxs("div", { className: `font-enad ${className}`, children: [
|
|
9
|
+
/* @__PURE__ */ jsx("div", { className: "flex border-b border-(--enad-border-color)", role: "tablist", children: tabs.map((tab) => {
|
|
10
|
+
const isActive = tab.id === activeTab;
|
|
11
|
+
return /* @__PURE__ */ jsx(
|
|
12
|
+
"button",
|
|
13
|
+
{
|
|
14
|
+
role: "tab",
|
|
15
|
+
id: `tab-${tab.id}`,
|
|
16
|
+
"aria-selected": isActive,
|
|
17
|
+
"aria-controls": `panel-${tab.id}`,
|
|
18
|
+
tabIndex: isActive ? 0 : -1,
|
|
19
|
+
onClick: () => setActiveTab(tab.id),
|
|
20
|
+
onKeyDown: (e) => {
|
|
21
|
+
const currentIndex = tabs.findIndex((t) => t.id === activeTab);
|
|
22
|
+
let nextIndex;
|
|
23
|
+
if (e.key === "ArrowRight") {
|
|
24
|
+
nextIndex = (currentIndex + 1) % tabs.length;
|
|
25
|
+
} else if (e.key === "ArrowLeft") {
|
|
26
|
+
nextIndex = (currentIndex - 1 + tabs.length) % tabs.length;
|
|
27
|
+
} else if (e.key === "Home") {
|
|
28
|
+
nextIndex = 0;
|
|
29
|
+
} else if (e.key === "End") {
|
|
30
|
+
nextIndex = tabs.length - 1;
|
|
31
|
+
}
|
|
32
|
+
if (nextIndex !== void 0) {
|
|
33
|
+
e.preventDefault();
|
|
34
|
+
const nextTab = tabs[nextIndex];
|
|
35
|
+
if (nextTab) {
|
|
36
|
+
setActiveTab(nextTab.id);
|
|
37
|
+
const el = document.getElementById(`tab-${nextTab.id}`);
|
|
38
|
+
el?.focus();
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
className: `px-4 py-3 text-sm font-medium transition-colors border-b-2 -mb-px ${isActive ? "border-(--enad-button-bg) text-(--enad-text-primary-color)" : "border-transparent text-(--enad-text-muted-color) hover:text-(--enad-text-primary-color) hover:border-(--enad-border-color)"}`,
|
|
43
|
+
children: tab.label
|
|
44
|
+
},
|
|
45
|
+
tab.id
|
|
46
|
+
);
|
|
47
|
+
}) }),
|
|
48
|
+
activePanel && /* @__PURE__ */ jsx(
|
|
49
|
+
"div",
|
|
50
|
+
{
|
|
51
|
+
role: "tabpanel",
|
|
52
|
+
id: `panel-${activePanel.id}`,
|
|
53
|
+
"aria-labelledby": `tab-${activePanel.id}`,
|
|
54
|
+
tabIndex: 0,
|
|
55
|
+
className: "py-4 text-(--enad-text-primary-color)",
|
|
56
|
+
children: activePanel.content
|
|
57
|
+
}
|
|
58
|
+
)
|
|
59
|
+
] });
|
|
60
|
+
}
|
|
61
|
+
export {
|
|
62
|
+
ProductTabs
|
|
63
|
+
};
|
|
64
|
+
//# sourceMappingURL=product-tabs.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/client/storefront/components/product-tabs.tsx"],"sourcesContent":["\"use client\"\n\nimport { useState } from \"react\"\n\nexport interface ProductTab {\n id: string\n label: string\n content: React.ReactNode\n}\n\nexport interface ProductTabsProps {\n tabs: ProductTab[]\n defaultTab?: string\n className?: string\n}\n\nexport function ProductTabs({ tabs, defaultTab, className = \"\" }: ProductTabsProps) {\n const [activeTab, setActiveTab] = useState(() => defaultTab || tabs[0]?.id || \"\")\n\n if (tabs.length === 0) return null\n\n const activePanel = tabs.find((tab) => tab.id === activeTab)\n\n return (\n <div className={`font-enad ${className}`}>\n {/* Tab list */}\n <div className=\"flex border-b border-(--enad-border-color)\" role=\"tablist\">\n {tabs.map((tab) => {\n const isActive = tab.id === activeTab\n return (\n <button\n key={tab.id}\n role=\"tab\"\n id={`tab-${tab.id}`}\n aria-selected={isActive}\n aria-controls={`panel-${tab.id}`}\n tabIndex={isActive ? 0 : -1}\n onClick={() => setActiveTab(tab.id)}\n onKeyDown={(e) => {\n const currentIndex = tabs.findIndex((t) => t.id === activeTab)\n let nextIndex: number | undefined\n\n if (e.key === \"ArrowRight\") {\n nextIndex = (currentIndex + 1) % tabs.length\n } else if (e.key === \"ArrowLeft\") {\n nextIndex = (currentIndex - 1 + tabs.length) % tabs.length\n } else if (e.key === \"Home\") {\n nextIndex = 0\n } else if (e.key === \"End\") {\n nextIndex = tabs.length - 1\n }\n\n if (nextIndex !== undefined) {\n e.preventDefault()\n const nextTab = tabs[nextIndex]\n if (nextTab) {\n setActiveTab(nextTab.id)\n const el = document.getElementById(`tab-${nextTab.id}`)\n el?.focus()\n }\n }\n }}\n className={`px-4 py-3 text-sm font-medium transition-colors border-b-2 -mb-px ${\n isActive\n ? \"border-(--enad-button-bg) text-(--enad-text-primary-color)\"\n : \"border-transparent text-(--enad-text-muted-color) hover:text-(--enad-text-primary-color) hover:border-(--enad-border-color)\"\n }`}\n >\n {tab.label}\n </button>\n )\n })}\n </div>\n\n {/* Tab panel */}\n {activePanel && (\n <div\n role=\"tabpanel\"\n id={`panel-${activePanel.id}`}\n aria-labelledby={`tab-${activePanel.id}`}\n tabIndex={0}\n className=\"py-4 text-(--enad-text-primary-color)\"\n >\n {activePanel.content}\n </div>\n )}\n </div>\n )\n}\n"],"mappings":";AAwBI,SAMQ,KANR;AAtBJ,SAAS,gBAAgB;AAclB,SAAS,YAAY,EAAE,MAAM,YAAY,YAAY,GAAG,GAAqB;AAClF,QAAM,CAAC,WAAW,YAAY,IAAI,SAAS,MAAM,cAAc,KAAK,CAAC,GAAG,MAAM,EAAE;AAEhF,MAAI,KAAK,WAAW,EAAG,QAAO;AAE9B,QAAM,cAAc,KAAK,KAAK,CAAC,QAAQ,IAAI,OAAO,SAAS;AAE3D,SACE,qBAAC,SAAI,WAAW,aAAa,SAAS,IAEpC;AAAA,wBAAC,SAAI,WAAU,8CAA6C,MAAK,WAC9D,eAAK,IAAI,CAAC,QAAQ;AACjB,YAAM,WAAW,IAAI,OAAO;AAC5B,aACE;AAAA,QAAC;AAAA;AAAA,UAEC,MAAK;AAAA,UACL,IAAI,OAAO,IAAI,EAAE;AAAA,UACjB,iBAAe;AAAA,UACf,iBAAe,SAAS,IAAI,EAAE;AAAA,UAC9B,UAAU,WAAW,IAAI;AAAA,UACzB,SAAS,MAAM,aAAa,IAAI,EAAE;AAAA,UAClC,WAAW,CAAC,MAAM;AAChB,kBAAM,eAAe,KAAK,UAAU,CAAC,MAAM,EAAE,OAAO,SAAS;AAC7D,gBAAI;AAEJ,gBAAI,EAAE,QAAQ,cAAc;AAC1B,2BAAa,eAAe,KAAK,KAAK;AAAA,YACxC,WAAW,EAAE,QAAQ,aAAa;AAChC,2BAAa,eAAe,IAAI,KAAK,UAAU,KAAK;AAAA,YACtD,WAAW,EAAE,QAAQ,QAAQ;AAC3B,0BAAY;AAAA,YACd,WAAW,EAAE,QAAQ,OAAO;AAC1B,0BAAY,KAAK,SAAS;AAAA,YAC5B;AAEA,gBAAI,cAAc,QAAW;AAC3B,gBAAE,eAAe;AACjB,oBAAM,UAAU,KAAK,SAAS;AAC9B,kBAAI,SAAS;AACX,6BAAa,QAAQ,EAAE;AACvB,sBAAM,KAAK,SAAS,eAAe,OAAO,QAAQ,EAAE,EAAE;AACtD,oBAAI,MAAM;AAAA,cACZ;AAAA,YACF;AAAA,UACF;AAAA,UACA,WAAW,qEACT,WACI,+DACA,6HACN;AAAA,UAEC,cAAI;AAAA;AAAA,QArCA,IAAI;AAAA,MAsCX;AAAA,IAEJ,CAAC,GACH;AAAA,IAGC,eACC;AAAA,MAAC;AAAA;AAAA,QACC,MAAK;AAAA,QACL,IAAI,SAAS,YAAY,EAAE;AAAA,QAC3B,mBAAiB,OAAO,YAAY,EAAE;AAAA,QACtC,UAAU;AAAA,QACV,WAAU;AAAA,QAET,sBAAY;AAAA;AAAA,IACf;AAAA,KAEJ;AAEJ;","names":[]}
|