@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,25 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import type { ImageAsset } from "../types";
|
|
3
|
+
export interface QuickViewProduct {
|
|
4
|
+
title: string;
|
|
5
|
+
images?: ImageAsset[];
|
|
6
|
+
price?: React.ReactNode;
|
|
7
|
+
description?: string;
|
|
8
|
+
href?: string;
|
|
9
|
+
}
|
|
10
|
+
export interface QuickViewProps {
|
|
11
|
+
open: boolean;
|
|
12
|
+
onOpenChange: (open: boolean) => void;
|
|
13
|
+
product: QuickViewProduct | null;
|
|
14
|
+
/** Presentation mode */
|
|
15
|
+
mode?: "sheet" | "modal";
|
|
16
|
+
/** Side when mode is "sheet" */
|
|
17
|
+
side?: "right" | "left";
|
|
18
|
+
/** Slot for variant selector, add-to-cart, wishlist, etc. */
|
|
19
|
+
children?: React.ReactNode;
|
|
20
|
+
/** Link label for "View full details" */
|
|
21
|
+
viewDetailsLabel?: string;
|
|
22
|
+
className?: string;
|
|
23
|
+
}
|
|
24
|
+
export declare function QuickView({ open, onOpenChange, product, mode, side, viewDetailsLabel, children, className, }: QuickViewProps): import("react/jsx-runtime").JSX.Element | null;
|
|
25
|
+
//# sourceMappingURL=quick-view.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"quick-view.d.ts","sourceRoot":"","sources":["../../../../src/client/storefront/components/quick-view.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAI3C,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,UAAU,EAAE,CAAC;IACtB,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,OAAO,CAAC;IACd,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACtC,OAAO,EAAE,gBAAgB,GAAG,IAAI,CAAC;IACjC,wBAAwB;IACxB,IAAI,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC;IACzB,gCAAgC;IAChC,IAAI,CAAC,EAAE,OAAO,GAAG,MAAM,CAAC;IACxB,6DAA6D;IAC7D,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,yCAAyC;IACzC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAID,wBAAgB,SAAS,CAAC,EACxB,IAAI,EACJ,YAAY,EACZ,OAAO,EACP,IAAc,EACd,IAAc,EACd,gBAAsC,EACtC,QAAQ,EACR,SAAS,GACV,EAAE,cAAc,kDAoEhB"}
|
|
@@ -0,0 +1,149 @@
|
|
|
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 { Sheet, SheetContent, SheetHeader, SheetTitle } from "../../ui-resolver/sheet";
|
|
7
|
+
function QuickView({
|
|
8
|
+
open,
|
|
9
|
+
onOpenChange,
|
|
10
|
+
product,
|
|
11
|
+
mode = "sheet",
|
|
12
|
+
side = "right",
|
|
13
|
+
viewDetailsLabel = "View full details",
|
|
14
|
+
children,
|
|
15
|
+
className
|
|
16
|
+
}) {
|
|
17
|
+
const CloseIcon = useIcon("close");
|
|
18
|
+
const titleId = React.useId();
|
|
19
|
+
if (!product) return null;
|
|
20
|
+
const { title, images = [], price, description, href } = product;
|
|
21
|
+
const imageContent = /* @__PURE__ */ jsx(QuickViewGallery, { images });
|
|
22
|
+
const content = /* @__PURE__ */ jsxs("div", { className: cn("flex flex-col gap-6", className), children: [
|
|
23
|
+
imageContent,
|
|
24
|
+
/* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-4 px-1", children: [
|
|
25
|
+
/* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-1", children: [
|
|
26
|
+
/* @__PURE__ */ jsx("h3", { id: titleId, className: "font-enad text-lg font-semibold leading-tight", children: title }),
|
|
27
|
+
price && /* @__PURE__ */ jsx("div", { className: "text-base", children: price })
|
|
28
|
+
] }),
|
|
29
|
+
description && /* @__PURE__ */ jsx("p", { className: "text-sm text-muted-foreground leading-relaxed", children: description }),
|
|
30
|
+
children,
|
|
31
|
+
href && /* @__PURE__ */ jsx(
|
|
32
|
+
"a",
|
|
33
|
+
{
|
|
34
|
+
href,
|
|
35
|
+
className: "mt-2 text-sm font-medium underline underline-offset-4 hover:text-primary transition-colors",
|
|
36
|
+
children: viewDetailsLabel
|
|
37
|
+
}
|
|
38
|
+
)
|
|
39
|
+
] })
|
|
40
|
+
] });
|
|
41
|
+
if (mode === "modal") {
|
|
42
|
+
return /* @__PURE__ */ jsx(ModalOverlay, { open, onOpenChange, labelId: titleId, children: /* @__PURE__ */ jsxs("div", { className: "relative max-h-[85vh] overflow-y-auto rounded-lg bg-background p-6 shadow-lg sm:max-w-lg w-full", children: [
|
|
43
|
+
/* @__PURE__ */ jsx(
|
|
44
|
+
"button",
|
|
45
|
+
{
|
|
46
|
+
type: "button",
|
|
47
|
+
onClick: () => onOpenChange(false),
|
|
48
|
+
className: "absolute right-4 top-4 z-10 rounded-sm p-1 opacity-70 hover:opacity-100 transition-opacity",
|
|
49
|
+
"aria-label": "Close",
|
|
50
|
+
children: /* @__PURE__ */ jsx(CloseIcon, { className: "size-4" })
|
|
51
|
+
}
|
|
52
|
+
),
|
|
53
|
+
content
|
|
54
|
+
] }) });
|
|
55
|
+
}
|
|
56
|
+
return /* @__PURE__ */ jsx(Sheet, { open, onOpenChange, children: /* @__PURE__ */ jsxs(SheetContent, { side, className: "overflow-y-auto sm:max-w-md", children: [
|
|
57
|
+
/* @__PURE__ */ jsx(SheetHeader, { children: /* @__PURE__ */ jsx(SheetTitle, { className: "sr-only", children: title }) }),
|
|
58
|
+
content
|
|
59
|
+
] }) });
|
|
60
|
+
}
|
|
61
|
+
function QuickViewGallery({ images }) {
|
|
62
|
+
const [activeIndex, setActiveIndex] = React.useState(0);
|
|
63
|
+
if (images.length === 0) {
|
|
64
|
+
return /* @__PURE__ */ jsx("div", { className: "aspect-[4/5] w-full rounded-md bg-muted" });
|
|
65
|
+
}
|
|
66
|
+
const active = images[activeIndex];
|
|
67
|
+
return /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-2", children: [
|
|
68
|
+
/* @__PURE__ */ jsx("div", { className: "relative aspect-[4/5] w-full overflow-hidden rounded-md bg-muted", children: /* @__PURE__ */ jsx("img", { src: active.src, alt: active.alt ?? "", className: "size-full object-cover" }) }),
|
|
69
|
+
images.length > 1 && /* @__PURE__ */ jsx("div", { className: "flex gap-2 overflow-x-auto pb-1", children: images.map((img, i) => /* @__PURE__ */ jsx(
|
|
70
|
+
"button",
|
|
71
|
+
{
|
|
72
|
+
type: "button",
|
|
73
|
+
onClick: () => setActiveIndex(i),
|
|
74
|
+
className: cn(
|
|
75
|
+
"relative size-14 shrink-0 overflow-hidden rounded-md border-2 transition-colors focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-1 focus-visible:outline-none",
|
|
76
|
+
i === activeIndex ? "border-primary" : "border-transparent hover:border-muted-foreground/30"
|
|
77
|
+
),
|
|
78
|
+
children: /* @__PURE__ */ jsx("img", { src: img.src, alt: img.alt ?? "", className: "size-full object-cover" })
|
|
79
|
+
},
|
|
80
|
+
i
|
|
81
|
+
)) })
|
|
82
|
+
] });
|
|
83
|
+
}
|
|
84
|
+
function ModalOverlay({
|
|
85
|
+
open,
|
|
86
|
+
onOpenChange,
|
|
87
|
+
children,
|
|
88
|
+
labelId
|
|
89
|
+
}) {
|
|
90
|
+
const overlayRef = React.useRef(null);
|
|
91
|
+
const previousFocusRef = React.useRef(null);
|
|
92
|
+
React.useEffect(() => {
|
|
93
|
+
if (open) {
|
|
94
|
+
previousFocusRef.current = document.activeElement;
|
|
95
|
+
requestAnimationFrame(() => overlayRef.current?.focus());
|
|
96
|
+
} else if (previousFocusRef.current) {
|
|
97
|
+
previousFocusRef.current.focus();
|
|
98
|
+
previousFocusRef.current = null;
|
|
99
|
+
}
|
|
100
|
+
}, [open]);
|
|
101
|
+
React.useEffect(() => {
|
|
102
|
+
if (!open) return;
|
|
103
|
+
const handleKey = (e) => {
|
|
104
|
+
if (e.key === "Escape") {
|
|
105
|
+
onOpenChange(false);
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
if (e.key === "Tab") {
|
|
109
|
+
const dialog = overlayRef.current;
|
|
110
|
+
if (!dialog) return;
|
|
111
|
+
const focusable = dialog.querySelectorAll(
|
|
112
|
+
'a[href], button:not([disabled]), textarea, input, select, [tabindex]:not([tabindex="-1"])'
|
|
113
|
+
);
|
|
114
|
+
if (focusable.length === 0) return;
|
|
115
|
+
const first = focusable[0];
|
|
116
|
+
const last = focusable[focusable.length - 1];
|
|
117
|
+
if (e.shiftKey && document.activeElement === first) {
|
|
118
|
+
e.preventDefault();
|
|
119
|
+
last.focus();
|
|
120
|
+
} else if (!e.shiftKey && document.activeElement === last) {
|
|
121
|
+
e.preventDefault();
|
|
122
|
+
first.focus();
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
};
|
|
126
|
+
document.addEventListener("keydown", handleKey);
|
|
127
|
+
return () => document.removeEventListener("keydown", handleKey);
|
|
128
|
+
}, [open, onOpenChange]);
|
|
129
|
+
if (!open) return null;
|
|
130
|
+
return /* @__PURE__ */ jsx(
|
|
131
|
+
"div",
|
|
132
|
+
{
|
|
133
|
+
ref: overlayRef,
|
|
134
|
+
role: "dialog",
|
|
135
|
+
"aria-modal": "true",
|
|
136
|
+
"aria-labelledby": labelId,
|
|
137
|
+
tabIndex: -1,
|
|
138
|
+
className: "fixed inset-0 z-50 flex items-center justify-center bg-black/50 backdrop-blur-[2px] outline-none",
|
|
139
|
+
onClick: (e) => {
|
|
140
|
+
if (e.target === overlayRef.current) onOpenChange(false);
|
|
141
|
+
},
|
|
142
|
+
children
|
|
143
|
+
}
|
|
144
|
+
);
|
|
145
|
+
}
|
|
146
|
+
export {
|
|
147
|
+
QuickView
|
|
148
|
+
};
|
|
149
|
+
//# sourceMappingURL=quick-view.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/client/storefront/components/quick-view.tsx"],"sourcesContent":["\"use client\";\n\nimport * as React from \"react\";\nimport { cn } from \"../../ui/utils\";\nimport { useIcon } from \"../../icons/icon-context\";\nimport { Sheet, SheetContent, SheetHeader, SheetTitle, SheetClose } from \"../../ui-resolver/sheet\";\nimport type { ImageAsset } from \"../types\";\n\n/* ─── Types ─── */\n\nexport interface QuickViewProduct {\n title: string;\n images?: ImageAsset[];\n price?: React.ReactNode;\n description?: string;\n href?: string;\n}\n\nexport interface QuickViewProps {\n open: boolean;\n onOpenChange: (open: boolean) => void;\n product: QuickViewProduct | null;\n /** Presentation mode */\n mode?: \"sheet\" | \"modal\";\n /** Side when mode is \"sheet\" */\n side?: \"right\" | \"left\";\n /** Slot for variant selector, add-to-cart, wishlist, etc. */\n children?: React.ReactNode;\n /** Link label for \"View full details\" */\n viewDetailsLabel?: string;\n className?: string;\n}\n\n/* ─── Component ─── */\n\nexport function QuickView({\n open,\n onOpenChange,\n product,\n mode = \"sheet\",\n side = \"right\",\n viewDetailsLabel = \"View full details\",\n children,\n className,\n}: QuickViewProps) {\n const CloseIcon = useIcon(\"close\");\n const titleId = React.useId();\n\n if (!product) return null;\n\n const { title, images = [], price, description, href } = product;\n\n const imageContent = <QuickViewGallery images={images} />;\n\n const content = (\n <div className={cn(\"flex flex-col gap-6\", className)}>\n {imageContent}\n\n <div className=\"flex flex-col gap-4 px-1\">\n <div className=\"flex flex-col gap-1\">\n <h3 id={titleId} className=\"font-enad text-lg font-semibold leading-tight\">\n {title}\n </h3>\n {price && <div className=\"text-base\">{price}</div>}\n </div>\n\n {description && (\n <p className=\"text-sm text-muted-foreground leading-relaxed\">{description}</p>\n )}\n\n {children}\n\n {href && (\n <a\n href={href}\n className=\"mt-2 text-sm font-medium underline underline-offset-4 hover:text-primary transition-colors\"\n >\n {viewDetailsLabel}\n </a>\n )}\n </div>\n </div>\n );\n\n if (mode === \"modal\") {\n return (\n <ModalOverlay open={open} onOpenChange={onOpenChange} labelId={titleId}>\n <div className=\"relative max-h-[85vh] overflow-y-auto rounded-lg bg-background p-6 shadow-lg sm:max-w-lg w-full\">\n <button\n type=\"button\"\n onClick={() => onOpenChange(false)}\n className=\"absolute right-4 top-4 z-10 rounded-sm p-1 opacity-70 hover:opacity-100 transition-opacity\"\n aria-label=\"Close\"\n >\n <CloseIcon className=\"size-4\" />\n </button>\n {content}\n </div>\n </ModalOverlay>\n );\n }\n\n return (\n <Sheet open={open} onOpenChange={onOpenChange}>\n <SheetContent side={side} className=\"overflow-y-auto sm:max-w-md\">\n <SheetHeader>\n <SheetTitle className=\"sr-only\">{title}</SheetTitle>\n </SheetHeader>\n {content}\n </SheetContent>\n </Sheet>\n );\n}\n\n/* ─── Gallery (internal) ─── */\n\nfunction QuickViewGallery({ images }: { images: ImageAsset[] }) {\n const [activeIndex, setActiveIndex] = React.useState(0);\n\n if (images.length === 0) {\n return <div className=\"aspect-[4/5] w-full rounded-md bg-muted\" />;\n }\n\n const active = images[activeIndex]!;\n\n return (\n <div className=\"flex flex-col gap-2\">\n <div className=\"relative aspect-[4/5] w-full overflow-hidden rounded-md bg-muted\">\n <img src={active.src} alt={active.alt ?? \"\"} className=\"size-full object-cover\" />\n </div>\n\n {images.length > 1 && (\n <div className=\"flex gap-2 overflow-x-auto pb-1\">\n {images.map((img, i) => (\n <button\n key={i}\n type=\"button\"\n onClick={() => setActiveIndex(i)}\n className={cn(\n \"relative size-14 shrink-0 overflow-hidden rounded-md border-2 transition-colors focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-1 focus-visible:outline-none\",\n i === activeIndex\n ? \"border-primary\"\n : \"border-transparent hover:border-muted-foreground/30\",\n )}\n >\n <img src={img.src} alt={img.alt ?? \"\"} className=\"size-full object-cover\" />\n </button>\n ))}\n </div>\n )}\n </div>\n );\n}\n\n/* ─── Modal overlay (internal) ─── */\n\nfunction ModalOverlay({\n open,\n onOpenChange,\n children,\n labelId,\n}: {\n open: boolean;\n onOpenChange: (open: boolean) => void;\n children: React.ReactNode;\n labelId?: string;\n}) {\n const overlayRef = React.useRef<HTMLDivElement>(null);\n const previousFocusRef = React.useRef<HTMLElement | null>(null);\n\n // Capture triggering element and manage focus\n React.useEffect(() => {\n if (open) {\n previousFocusRef.current = document.activeElement as HTMLElement | null;\n // Focus the dialog container after mount\n requestAnimationFrame(() => overlayRef.current?.focus());\n } else if (previousFocusRef.current) {\n previousFocusRef.current.focus();\n previousFocusRef.current = null;\n }\n }, [open]);\n\n React.useEffect(() => {\n if (!open) return;\n const handleKey = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") {\n onOpenChange(false);\n return;\n }\n // Focus trap: cycle Tab within the dialog\n if (e.key === \"Tab\") {\n const dialog = overlayRef.current;\n if (!dialog) return;\n const focusable = dialog.querySelectorAll<HTMLElement>(\n 'a[href], button:not([disabled]), textarea, input, select, [tabindex]:not([tabindex=\"-1\"])',\n );\n if (focusable.length === 0) return;\n const first = focusable[0]!;\n const last = focusable[focusable.length - 1]!;\n if (e.shiftKey && document.activeElement === first) {\n e.preventDefault();\n last.focus();\n } else if (!e.shiftKey && document.activeElement === last) {\n e.preventDefault();\n first.focus();\n }\n }\n };\n document.addEventListener(\"keydown\", handleKey);\n return () => document.removeEventListener(\"keydown\", handleKey);\n }, [open, onOpenChange]);\n\n if (!open) return null;\n\n return (\n <div\n ref={overlayRef}\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={labelId}\n tabIndex={-1}\n className=\"fixed inset-0 z-50 flex items-center justify-center bg-black/50 backdrop-blur-[2px] outline-none\"\n onClick={(e) => {\n if (e.target === overlayRef.current) onOpenChange(false);\n }}\n >\n {children}\n </div>\n );\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export interface ReviewDistribution {
|
|
2
|
+
/** Star count (1-5) */
|
|
3
|
+
stars: number;
|
|
4
|
+
/** Number of reviews with this rating */
|
|
5
|
+
count: number;
|
|
6
|
+
}
|
|
7
|
+
export interface ReviewSummaryProps {
|
|
8
|
+
averageRating: number;
|
|
9
|
+
totalReviews: number;
|
|
10
|
+
/** Distribution from 5 stars to 1 star. Missing entries default to 0. */
|
|
11
|
+
distribution: ReviewDistribution[];
|
|
12
|
+
/** Called when user clicks a distribution bar (for filtering) */
|
|
13
|
+
onBarClick?: (stars: number) => void;
|
|
14
|
+
className?: string;
|
|
15
|
+
}
|
|
16
|
+
export declare function ReviewSummary({ averageRating, totalReviews, distribution, onBarClick, className, }: ReviewSummaryProps): import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
//# sourceMappingURL=review-summary.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"review-summary.d.ts","sourceRoot":"","sources":["../../../../src/client/storefront/components/review-summary.tsx"],"names":[],"mappings":"AAOA,MAAM,WAAW,kBAAkB;IACjC,uBAAuB;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,yCAAyC;IACzC,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,kBAAkB;IACjC,aAAa,EAAE,MAAM,CAAC;IACtB,YAAY,EAAE,MAAM,CAAC;IACrB,yEAAyE;IACzE,YAAY,EAAE,kBAAkB,EAAE,CAAC;IACnC,iEAAiE;IACjE,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAID,wBAAgB,aAAa,CAAC,EAC5B,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,UAAU,EACV,SAAS,GACV,EAAE,kBAAkB,2CA2DpB"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { cn } from "../../ui/utils";
|
|
4
|
+
import { StarRating } from "./star-rating";
|
|
5
|
+
function ReviewSummary({
|
|
6
|
+
averageRating,
|
|
7
|
+
totalReviews,
|
|
8
|
+
distribution,
|
|
9
|
+
onBarClick,
|
|
10
|
+
className
|
|
11
|
+
}) {
|
|
12
|
+
const maxCount = Math.max(1, ...distribution.map((d) => d.count));
|
|
13
|
+
const distributionMap = new Map(distribution.map((d) => [d.stars, d.count]));
|
|
14
|
+
const rows = [5, 4, 3, 2, 1].map((stars) => ({
|
|
15
|
+
stars,
|
|
16
|
+
count: distributionMap.get(stars) ?? 0
|
|
17
|
+
}));
|
|
18
|
+
return /* @__PURE__ */ jsxs("div", { className: cn("flex flex-col gap-4 sm:flex-row sm:gap-8", className), children: [
|
|
19
|
+
/* @__PURE__ */ jsxs("div", { className: "flex flex-col items-center gap-1 sm:min-w-[120px]", children: [
|
|
20
|
+
/* @__PURE__ */ jsx("span", { className: "text-4xl font-bold font-enad tabular-nums", children: averageRating.toFixed(1) }),
|
|
21
|
+
/* @__PURE__ */ jsx(StarRating, { rating: averageRating, size: "sm" }),
|
|
22
|
+
/* @__PURE__ */ jsxs("span", { className: "text-sm text-muted-foreground", children: [
|
|
23
|
+
totalReviews.toLocaleString(),
|
|
24
|
+
" ",
|
|
25
|
+
totalReviews === 1 ? "review" : "reviews"
|
|
26
|
+
] })
|
|
27
|
+
] }),
|
|
28
|
+
/* @__PURE__ */ jsx("div", { className: "flex flex-1 flex-col gap-2", children: rows.map(({ stars, count }) => {
|
|
29
|
+
const pct = maxCount > 0 ? count / maxCount * 100 : 0;
|
|
30
|
+
const isClickable = onBarClick && count > 0;
|
|
31
|
+
const Tag = isClickable ? "button" : "div";
|
|
32
|
+
return /* @__PURE__ */ jsxs(
|
|
33
|
+
Tag,
|
|
34
|
+
{
|
|
35
|
+
...isClickable && {
|
|
36
|
+
type: "button",
|
|
37
|
+
onClick: () => onBarClick(stars)
|
|
38
|
+
},
|
|
39
|
+
className: cn(
|
|
40
|
+
"flex items-center gap-3 text-sm",
|
|
41
|
+
isClickable && "cursor-pointer hover:opacity-80 transition-opacity focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-1 rounded-sm"
|
|
42
|
+
),
|
|
43
|
+
children: [
|
|
44
|
+
/* @__PURE__ */ jsxs("span", { className: "w-8 shrink-0 text-right tabular-nums font-enad", children: [
|
|
45
|
+
stars,
|
|
46
|
+
"\u2605"
|
|
47
|
+
] }),
|
|
48
|
+
/* @__PURE__ */ jsx("div", { className: "relative h-2.5 flex-1 overflow-hidden rounded-full bg-muted", children: /* @__PURE__ */ jsx(
|
|
49
|
+
"div",
|
|
50
|
+
{
|
|
51
|
+
className: "absolute inset-y-0 left-0 rounded-full bg-(--enad-star-color) transition-all duration-300",
|
|
52
|
+
style: { width: `${pct}%` }
|
|
53
|
+
}
|
|
54
|
+
) }),
|
|
55
|
+
/* @__PURE__ */ jsx("span", { className: "w-10 shrink-0 text-right tabular-nums text-muted-foreground", children: count })
|
|
56
|
+
]
|
|
57
|
+
},
|
|
58
|
+
stars
|
|
59
|
+
);
|
|
60
|
+
}) })
|
|
61
|
+
] });
|
|
62
|
+
}
|
|
63
|
+
export {
|
|
64
|
+
ReviewSummary
|
|
65
|
+
};
|
|
66
|
+
//# sourceMappingURL=review-summary.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/client/storefront/components/review-summary.tsx"],"sourcesContent":["\"use client\";\n\nimport { cn } from \"../../ui/utils\";\nimport { StarRating } from \"./star-rating\";\n\n/* ─── Types ─── */\n\nexport interface ReviewDistribution {\n /** Star count (1-5) */\n stars: number;\n /** Number of reviews with this rating */\n count: number;\n}\n\nexport interface ReviewSummaryProps {\n averageRating: number;\n totalReviews: number;\n /** Distribution from 5 stars to 1 star. Missing entries default to 0. */\n distribution: ReviewDistribution[];\n /** Called when user clicks a distribution bar (for filtering) */\n onBarClick?: (stars: number) => void;\n className?: string;\n}\n\n/* ─── Component ─── */\n\nexport function ReviewSummary({\n averageRating,\n totalReviews,\n distribution,\n onBarClick,\n className,\n}: ReviewSummaryProps) {\n const maxCount = Math.max(1, ...distribution.map((d) => d.count));\n\n // Build full 5-to-1 distribution, filling missing entries with 0\n const distributionMap = new Map(distribution.map((d) => [d.stars, d.count]));\n const rows = [5, 4, 3, 2, 1].map((stars) => ({\n stars,\n count: distributionMap.get(stars) ?? 0,\n }));\n\n return (\n <div className={cn(\"flex flex-col gap-4 sm:flex-row sm:gap-8\", className)}>\n {/* Left: average */}\n <div className=\"flex flex-col items-center gap-1 sm:min-w-[120px]\">\n <span className=\"text-4xl font-bold font-enad tabular-nums\">\n {averageRating.toFixed(1)}\n </span>\n <StarRating rating={averageRating} size=\"sm\" />\n <span className=\"text-sm text-muted-foreground\">\n {totalReviews.toLocaleString()} {totalReviews === 1 ? \"review\" : \"reviews\"}\n </span>\n </div>\n\n {/* Right: distribution bars */}\n <div className=\"flex flex-1 flex-col gap-2\">\n {rows.map(({ stars, count }) => {\n const pct = maxCount > 0 ? (count / maxCount) * 100 : 0;\n const isClickable = onBarClick && count > 0;\n const Tag = isClickable ? \"button\" : \"div\";\n\n return (\n <Tag\n key={stars}\n {...(isClickable && {\n type: \"button\" as const,\n onClick: () => onBarClick(stars),\n })}\n className={cn(\n \"flex items-center gap-3 text-sm\",\n isClickable &&\n \"cursor-pointer hover:opacity-80 transition-opacity focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-1 rounded-sm\",\n )}\n >\n <span className=\"w-8 shrink-0 text-right tabular-nums font-enad\">{stars}★</span>\n <div className=\"relative h-2.5 flex-1 overflow-hidden rounded-full bg-muted\">\n <div\n className=\"absolute inset-y-0 left-0 rounded-full bg-(--enad-star-color) transition-all duration-300\"\n style={{ width: `${pct}%` }}\n />\n </div>\n <span className=\"w-10 shrink-0 text-right tabular-nums text-muted-foreground\">\n {count}\n </span>\n </Tag>\n );\n })}\n </div>\n </div>\n );\n}\n"],"mappings":";AA8CQ,cAIA,YAJA;AA5CR,SAAS,UAAU;AACnB,SAAS,kBAAkB;AAuBpB,SAAS,cAAc;AAAA,EAC5B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAuB;AACrB,QAAM,WAAW,KAAK,IAAI,GAAG,GAAG,aAAa,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC;AAGhE,QAAM,kBAAkB,IAAI,IAAI,aAAa,IAAI,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;AAC3E,QAAM,OAAO,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,EAAE,IAAI,CAAC,WAAW;AAAA,IAC3C;AAAA,IACA,OAAO,gBAAgB,IAAI,KAAK,KAAK;AAAA,EACvC,EAAE;AAEF,SACE,qBAAC,SAAI,WAAW,GAAG,4CAA4C,SAAS,GAEtE;AAAA,yBAAC,SAAI,WAAU,qDACb;AAAA,0BAAC,UAAK,WAAU,6CACb,wBAAc,QAAQ,CAAC,GAC1B;AAAA,MACA,oBAAC,cAAW,QAAQ,eAAe,MAAK,MAAK;AAAA,MAC7C,qBAAC,UAAK,WAAU,iCACb;AAAA,qBAAa,eAAe;AAAA,QAAE;AAAA,QAAE,iBAAiB,IAAI,WAAW;AAAA,SACnE;AAAA,OACF;AAAA,IAGA,oBAAC,SAAI,WAAU,8BACZ,eAAK,IAAI,CAAC,EAAE,OAAO,MAAM,MAAM;AAC9B,YAAM,MAAM,WAAW,IAAK,QAAQ,WAAY,MAAM;AACtD,YAAM,cAAc,cAAc,QAAQ;AAC1C,YAAM,MAAM,cAAc,WAAW;AAErC,aACE;AAAA,QAAC;AAAA;AAAA,UAEE,GAAI,eAAe;AAAA,YAClB,MAAM;AAAA,YACN,SAAS,MAAM,WAAW,KAAK;AAAA,UACjC;AAAA,UACA,WAAW;AAAA,YACT;AAAA,YACA,eACE;AAAA,UACJ;AAAA,UAEA;AAAA,iCAAC,UAAK,WAAU,kDAAkD;AAAA;AAAA,cAAM;AAAA,eAAC;AAAA,YACzE,oBAAC,SAAI,WAAU,+DACb;AAAA,cAAC;AAAA;AAAA,gBACC,WAAU;AAAA,gBACV,OAAO,EAAE,OAAO,GAAG,GAAG,IAAI;AAAA;AAAA,YAC5B,GACF;AAAA,YACA,oBAAC,UAAK,WAAU,+DACb,iBACH;AAAA;AAAA;AAAA,QApBK;AAAA,MAqBP;AAAA,IAEJ,CAAC,GACH;AAAA,KACF;AAEJ;","names":[]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export interface SearchSuggestion {
|
|
2
|
+
id: string;
|
|
3
|
+
label: string;
|
|
4
|
+
type?: "product" | "category" | "recent" | "suggestion";
|
|
5
|
+
imageUrl?: string;
|
|
6
|
+
meta?: string;
|
|
7
|
+
}
|
|
8
|
+
export interface SearchAutocompleteProps {
|
|
9
|
+
value?: string;
|
|
10
|
+
onValueChange?: (value: string) => void;
|
|
11
|
+
onSearch?: (query: string) => void;
|
|
12
|
+
onSelect?: (suggestion: SearchSuggestion) => void;
|
|
13
|
+
suggestions?: SearchSuggestion[];
|
|
14
|
+
loading?: boolean;
|
|
15
|
+
placeholder?: string;
|
|
16
|
+
debounceMs?: number;
|
|
17
|
+
className?: string;
|
|
18
|
+
labels?: {
|
|
19
|
+
clear?: string;
|
|
20
|
+
noResults?: string;
|
|
21
|
+
searching?: string;
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
export declare function SearchAutocomplete({ value: controlledValue, onValueChange, onSearch, onSelect, suggestions, loading, placeholder, debounceMs, className, labels, }: SearchAutocompleteProps): import("react/jsx-runtime").JSX.Element;
|
|
25
|
+
//# sourceMappingURL=search-autocomplete.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search-autocomplete.d.ts","sourceRoot":"","sources":["../../../../src/client/storefront/components/search-autocomplete.tsx"],"names":[],"mappings":"AAOA,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,SAAS,GAAG,UAAU,GAAG,QAAQ,GAAG,YAAY,CAAC;IACxD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,uBAAuB;IACtC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,QAAQ,CAAC,EAAE,CAAC,UAAU,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAClD,WAAW,CAAC,EAAE,gBAAgB,EAAE,CAAC;IACjC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE;QACP,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,SAAS,CAAC,EAAE,MAAM,CAAC;KACpB,CAAC;CACH;AAED,wBAAgB,kBAAkB,CAAC,EACjC,KAAK,EAAE,eAAe,EACtB,aAAa,EACb,QAAQ,EACR,QAAQ,EACR,WAAgB,EAChB,OAAe,EACf,WAAyB,EACzB,UAAgB,EAChB,SAAS,EACT,MAAW,GACZ,EAAE,uBAAuB,2CAgMzB"}
|
|
@@ -0,0 +1,183 @@
|
|
|
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-resolver/input";
|
|
7
|
+
function SearchAutocomplete({
|
|
8
|
+
value: controlledValue,
|
|
9
|
+
onValueChange,
|
|
10
|
+
onSearch,
|
|
11
|
+
onSelect,
|
|
12
|
+
suggestions = [],
|
|
13
|
+
loading = false,
|
|
14
|
+
placeholder = "Search...",
|
|
15
|
+
debounceMs = 300,
|
|
16
|
+
className,
|
|
17
|
+
labels = {}
|
|
18
|
+
}) {
|
|
19
|
+
const {
|
|
20
|
+
clear: clearLabel = "Clear",
|
|
21
|
+
noResults = "No results found",
|
|
22
|
+
searching: searchingLabel = "Searching..."
|
|
23
|
+
} = labels;
|
|
24
|
+
const SearchIcon = useIcon("search");
|
|
25
|
+
const CloseIcon = useIcon("close");
|
|
26
|
+
const listboxId = React.useId();
|
|
27
|
+
const [internalValue, setInternalValue] = React.useState("");
|
|
28
|
+
const value = controlledValue ?? internalValue;
|
|
29
|
+
const setValue = onValueChange ?? setInternalValue;
|
|
30
|
+
const [isOpen, setIsOpen] = React.useState(false);
|
|
31
|
+
const [activeIndex, setActiveIndex] = React.useState(-1);
|
|
32
|
+
const containerRef = React.useRef(null);
|
|
33
|
+
const inputRef = React.useRef(null);
|
|
34
|
+
const debounceRef = React.useRef(void 0);
|
|
35
|
+
const onSearchRef = React.useRef(onSearch);
|
|
36
|
+
onSearchRef.current = onSearch;
|
|
37
|
+
const showDropdown = isOpen && value.length > 0;
|
|
38
|
+
React.useEffect(() => {
|
|
39
|
+
if (!value.trim() || !onSearchRef.current) return;
|
|
40
|
+
clearTimeout(debounceRef.current);
|
|
41
|
+
debounceRef.current = setTimeout(() => {
|
|
42
|
+
onSearchRef.current?.(value.trim());
|
|
43
|
+
}, debounceMs);
|
|
44
|
+
return () => clearTimeout(debounceRef.current);
|
|
45
|
+
}, [value, debounceMs]);
|
|
46
|
+
React.useEffect(() => {
|
|
47
|
+
setActiveIndex(-1);
|
|
48
|
+
}, [suggestions]);
|
|
49
|
+
React.useEffect(() => {
|
|
50
|
+
function handleClick(e) {
|
|
51
|
+
if (containerRef.current && !containerRef.current.contains(e.target)) {
|
|
52
|
+
setIsOpen(false);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
document.addEventListener("mousedown", handleClick);
|
|
56
|
+
return () => document.removeEventListener("mousedown", handleClick);
|
|
57
|
+
}, []);
|
|
58
|
+
function handleKeyDown(e) {
|
|
59
|
+
if (!showDropdown) {
|
|
60
|
+
if (e.key === "ArrowDown" && value.length > 0) {
|
|
61
|
+
setIsOpen(true);
|
|
62
|
+
e.preventDefault();
|
|
63
|
+
}
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
switch (e.key) {
|
|
67
|
+
case "ArrowDown":
|
|
68
|
+
e.preventDefault();
|
|
69
|
+
setActiveIndex((i) => i < suggestions.length - 1 ? i + 1 : 0);
|
|
70
|
+
break;
|
|
71
|
+
case "ArrowUp":
|
|
72
|
+
e.preventDefault();
|
|
73
|
+
setActiveIndex((i) => i > 0 ? i - 1 : suggestions.length - 1);
|
|
74
|
+
break;
|
|
75
|
+
case "Enter":
|
|
76
|
+
e.preventDefault();
|
|
77
|
+
if (activeIndex >= 0 && suggestions[activeIndex]) {
|
|
78
|
+
onSelect?.(suggestions[activeIndex]);
|
|
79
|
+
setIsOpen(false);
|
|
80
|
+
} else if (onSearch) {
|
|
81
|
+
onSearch(value.trim());
|
|
82
|
+
setIsOpen(false);
|
|
83
|
+
}
|
|
84
|
+
break;
|
|
85
|
+
case "Escape":
|
|
86
|
+
setIsOpen(false);
|
|
87
|
+
inputRef.current?.blur();
|
|
88
|
+
break;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
return /* @__PURE__ */ jsxs("div", { ref: containerRef, className: cn("font-enad relative", className), children: [
|
|
92
|
+
/* @__PURE__ */ jsxs("div", { className: "relative", children: [
|
|
93
|
+
/* @__PURE__ */ jsx(SearchIcon, { className: "pointer-events-none absolute left-3 top-1/2 size-4 -translate-y-1/2 text-(--enad-text-muted-color)" }),
|
|
94
|
+
/* @__PURE__ */ jsx(
|
|
95
|
+
Input,
|
|
96
|
+
{
|
|
97
|
+
ref: inputRef,
|
|
98
|
+
type: "search",
|
|
99
|
+
value,
|
|
100
|
+
onChange: (e) => {
|
|
101
|
+
setValue(e.target.value);
|
|
102
|
+
setIsOpen(true);
|
|
103
|
+
},
|
|
104
|
+
onFocus: () => value.length > 0 && setIsOpen(true),
|
|
105
|
+
onKeyDown: handleKeyDown,
|
|
106
|
+
placeholder,
|
|
107
|
+
className: "pl-9 pr-9",
|
|
108
|
+
role: "combobox",
|
|
109
|
+
"aria-expanded": showDropdown,
|
|
110
|
+
"aria-autocomplete": "list",
|
|
111
|
+
"aria-controls": listboxId,
|
|
112
|
+
"aria-activedescendant": activeIndex >= 0 ? `${listboxId}-option-${activeIndex}` : void 0
|
|
113
|
+
}
|
|
114
|
+
),
|
|
115
|
+
value.length > 0 && /* @__PURE__ */ jsx(
|
|
116
|
+
"button",
|
|
117
|
+
{
|
|
118
|
+
type: "button",
|
|
119
|
+
onClick: () => {
|
|
120
|
+
setValue("");
|
|
121
|
+
setIsOpen(false);
|
|
122
|
+
inputRef.current?.focus();
|
|
123
|
+
},
|
|
124
|
+
className: "absolute right-3 top-1/2 -translate-y-1/2 text-(--enad-text-muted-color) hover:text-(--enad-text-primary-color)",
|
|
125
|
+
"aria-label": clearLabel,
|
|
126
|
+
children: /* @__PURE__ */ jsx(CloseIcon, { className: "size-4" })
|
|
127
|
+
}
|
|
128
|
+
)
|
|
129
|
+
] }),
|
|
130
|
+
showDropdown && /* @__PURE__ */ jsxs(
|
|
131
|
+
"ul",
|
|
132
|
+
{
|
|
133
|
+
id: listboxId,
|
|
134
|
+
role: "listbox",
|
|
135
|
+
className: cn(
|
|
136
|
+
"absolute z-50 mt-1 w-full overflow-hidden rounded-(--enad-card-radius) border border-(--enad-border-color)",
|
|
137
|
+
"bg-(--enad-surface) shadow-lg"
|
|
138
|
+
),
|
|
139
|
+
children: [
|
|
140
|
+
loading && /* @__PURE__ */ jsx("li", { className: "px-4 py-3 text-sm text-(--enad-text-muted-color) animate-pulse", children: searchingLabel }),
|
|
141
|
+
!loading && suggestions.length === 0 && /* @__PURE__ */ jsx("li", { className: "px-4 py-3 text-sm text-(--enad-text-muted-color)", children: noResults }),
|
|
142
|
+
!loading && suggestions.map((suggestion, index) => /* @__PURE__ */ jsxs(
|
|
143
|
+
"li",
|
|
144
|
+
{
|
|
145
|
+
id: `${listboxId}-option-${index}`,
|
|
146
|
+
role: "option",
|
|
147
|
+
"aria-selected": index === activeIndex,
|
|
148
|
+
onMouseEnter: () => setActiveIndex(index),
|
|
149
|
+
onClick: () => {
|
|
150
|
+
onSelect?.(suggestion);
|
|
151
|
+
setIsOpen(false);
|
|
152
|
+
},
|
|
153
|
+
className: cn(
|
|
154
|
+
"flex cursor-pointer items-center gap-3 px-4 py-2.5 text-sm transition-colors",
|
|
155
|
+
index === activeIndex ? "bg-(--enad-hover-bg)" : "hover:bg-(--enad-hover-bg)"
|
|
156
|
+
),
|
|
157
|
+
children: [
|
|
158
|
+
suggestion.imageUrl ? /* @__PURE__ */ jsx(
|
|
159
|
+
"img",
|
|
160
|
+
{
|
|
161
|
+
src: suggestion.imageUrl,
|
|
162
|
+
alt: "",
|
|
163
|
+
className: "size-8 shrink-0 rounded object-cover"
|
|
164
|
+
}
|
|
165
|
+
) : /* @__PURE__ */ jsx("span", { className: "flex size-8 shrink-0 items-center justify-center text-(--enad-text-muted-color)", children: /* @__PURE__ */ jsx(SearchIcon, { className: "size-4" }) }),
|
|
166
|
+
/* @__PURE__ */ jsxs("div", { className: "flex-1 min-w-0", children: [
|
|
167
|
+
/* @__PURE__ */ jsx("p", { className: "truncate text-(--enad-text-primary-color)", children: suggestion.label }),
|
|
168
|
+
suggestion.meta && /* @__PURE__ */ jsx("p", { className: "truncate text-xs text-(--enad-text-muted-color)", children: suggestion.meta })
|
|
169
|
+
] }),
|
|
170
|
+
suggestion.type && /* @__PURE__ */ jsx("span", { className: "shrink-0 rounded-full bg-(--enad-hover-bg) px-2 py-0.5 text-[10px] font-medium text-(--enad-text-muted-color) capitalize", children: suggestion.type })
|
|
171
|
+
]
|
|
172
|
+
},
|
|
173
|
+
suggestion.id
|
|
174
|
+
))
|
|
175
|
+
]
|
|
176
|
+
}
|
|
177
|
+
)
|
|
178
|
+
] });
|
|
179
|
+
}
|
|
180
|
+
export {
|
|
181
|
+
SearchAutocomplete
|
|
182
|
+
};
|
|
183
|
+
//# sourceMappingURL=search-autocomplete.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/client/storefront/components/search-autocomplete.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-resolver/input\";\n\nexport interface SearchSuggestion {\n id: string;\n label: string;\n type?: \"product\" | \"category\" | \"recent\" | \"suggestion\";\n imageUrl?: string;\n meta?: string;\n}\n\nexport interface SearchAutocompleteProps {\n value?: string;\n onValueChange?: (value: string) => void;\n onSearch?: (query: string) => void;\n onSelect?: (suggestion: SearchSuggestion) => void;\n suggestions?: SearchSuggestion[];\n loading?: boolean;\n placeholder?: string;\n debounceMs?: number;\n className?: string;\n labels?: {\n clear?: string;\n noResults?: string;\n searching?: string;\n };\n}\n\nexport function SearchAutocomplete({\n value: controlledValue,\n onValueChange,\n onSearch,\n onSelect,\n suggestions = [],\n loading = false,\n placeholder = \"Search...\",\n debounceMs = 300,\n className,\n labels = {},\n}: SearchAutocompleteProps) {\n const {\n clear: clearLabel = \"Clear\",\n noResults = \"No results found\",\n searching: searchingLabel = \"Searching...\",\n } = labels;\n\n const SearchIcon = useIcon(\"search\");\n const CloseIcon = useIcon(\"close\");\n\n const listboxId = React.useId();\n const [internalValue, setInternalValue] = React.useState(\"\");\n const value = controlledValue ?? internalValue;\n const setValue = onValueChange ?? setInternalValue;\n\n const [isOpen, setIsOpen] = React.useState(false);\n const [activeIndex, setActiveIndex] = React.useState(-1);\n const containerRef = React.useRef<HTMLDivElement>(null);\n const inputRef = React.useRef<HTMLInputElement>(null);\n const debounceRef = React.useRef<ReturnType<typeof setTimeout> | undefined>(undefined);\n const onSearchRef = React.useRef(onSearch);\n onSearchRef.current = onSearch;\n\n const showDropdown = isOpen && value.length > 0;\n\n React.useEffect(() => {\n if (!value.trim() || !onSearchRef.current) return;\n clearTimeout(debounceRef.current);\n debounceRef.current = setTimeout(() => {\n onSearchRef.current?.(value.trim());\n }, debounceMs);\n return () => clearTimeout(debounceRef.current);\n }, [value, debounceMs]);\n\n React.useEffect(() => {\n setActiveIndex(-1);\n }, [suggestions]);\n\n // Close on outside click\n React.useEffect(() => {\n function handleClick(e: MouseEvent) {\n if (containerRef.current && !containerRef.current.contains(e.target as Node)) {\n setIsOpen(false);\n }\n }\n document.addEventListener(\"mousedown\", handleClick);\n return () => document.removeEventListener(\"mousedown\", handleClick);\n }, []);\n\n function handleKeyDown(e: React.KeyboardEvent) {\n if (!showDropdown) {\n if (e.key === \"ArrowDown\" && value.length > 0) {\n setIsOpen(true);\n e.preventDefault();\n }\n return;\n }\n\n switch (e.key) {\n case \"ArrowDown\":\n e.preventDefault();\n setActiveIndex((i) => (i < suggestions.length - 1 ? i + 1 : 0));\n break;\n case \"ArrowUp\":\n e.preventDefault();\n setActiveIndex((i) => (i > 0 ? i - 1 : suggestions.length - 1));\n break;\n case \"Enter\":\n e.preventDefault();\n if (activeIndex >= 0 && suggestions[activeIndex]) {\n onSelect?.(suggestions[activeIndex]);\n setIsOpen(false);\n } else if (onSearch) {\n onSearch(value.trim());\n setIsOpen(false);\n }\n break;\n case \"Escape\":\n setIsOpen(false);\n inputRef.current?.blur();\n break;\n }\n }\n\n return (\n <div ref={containerRef} className={cn(\"font-enad relative\", className)}>\n <div className=\"relative\">\n <SearchIcon className=\"pointer-events-none absolute left-3 top-1/2 size-4 -translate-y-1/2 text-(--enad-text-muted-color)\" />\n <Input\n ref={inputRef}\n type=\"search\"\n value={value}\n onChange={(e) => {\n setValue(e.target.value);\n setIsOpen(true);\n }}\n onFocus={() => value.length > 0 && setIsOpen(true)}\n onKeyDown={handleKeyDown}\n placeholder={placeholder}\n className=\"pl-9 pr-9\"\n role=\"combobox\"\n aria-expanded={showDropdown}\n aria-autocomplete=\"list\"\n aria-controls={listboxId}\n aria-activedescendant={\n activeIndex >= 0 ? `${listboxId}-option-${activeIndex}` : undefined\n }\n />\n {value.length > 0 && (\n <button\n type=\"button\"\n onClick={() => {\n setValue(\"\");\n setIsOpen(false);\n inputRef.current?.focus();\n }}\n className=\"absolute right-3 top-1/2 -translate-y-1/2 text-(--enad-text-muted-color) hover:text-(--enad-text-primary-color)\"\n aria-label={clearLabel}\n >\n <CloseIcon className=\"size-4\" />\n </button>\n )}\n </div>\n\n {showDropdown && (\n <ul\n id={listboxId}\n role=\"listbox\"\n className={cn(\n \"absolute z-50 mt-1 w-full overflow-hidden rounded-(--enad-card-radius) border border-(--enad-border-color)\",\n \"bg-(--enad-surface) shadow-lg\",\n )}\n >\n {loading && (\n <li className=\"px-4 py-3 text-sm text-(--enad-text-muted-color) animate-pulse\">\n {searchingLabel}\n </li>\n )}\n\n {!loading && suggestions.length === 0 && (\n <li className=\"px-4 py-3 text-sm text-(--enad-text-muted-color)\">{noResults}</li>\n )}\n\n {!loading &&\n suggestions.map((suggestion, index) => (\n <li\n key={suggestion.id}\n id={`${listboxId}-option-${index}`}\n role=\"option\"\n aria-selected={index === activeIndex}\n onMouseEnter={() => setActiveIndex(index)}\n onClick={() => {\n onSelect?.(suggestion);\n setIsOpen(false);\n }}\n className={cn(\n \"flex cursor-pointer items-center gap-3 px-4 py-2.5 text-sm transition-colors\",\n index === activeIndex ? \"bg-(--enad-hover-bg)\" : \"hover:bg-(--enad-hover-bg)\",\n )}\n >\n {suggestion.imageUrl ? (\n <img\n src={suggestion.imageUrl}\n alt=\"\"\n className=\"size-8 shrink-0 rounded object-cover\"\n />\n ) : (\n <span className=\"flex size-8 shrink-0 items-center justify-center text-(--enad-text-muted-color)\">\n <SearchIcon className=\"size-4\" />\n </span>\n )}\n\n <div className=\"flex-1 min-w-0\">\n <p className=\"truncate text-(--enad-text-primary-color)\">{suggestion.label}</p>\n {suggestion.meta && (\n <p className=\"truncate text-xs text-(--enad-text-muted-color)\">\n {suggestion.meta}\n </p>\n )}\n </div>\n\n {suggestion.type && (\n <span className=\"shrink-0 rounded-full bg-(--enad-hover-bg) px-2 py-0.5 text-[10px] font-medium text-(--enad-text-muted-color) capitalize\">\n {suggestion.type}\n </span>\n )}\n </li>\n ))}\n </ul>\n )}\n </div>\n );\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
interface SectionLink {
|
|
2
|
+
label: string;
|
|
3
|
+
/** Anchor href, e.g. "#specs" */
|
|
4
|
+
href: string;
|
|
5
|
+
/** Optional group name for the overflow popover */
|
|
6
|
+
group?: string;
|
|
7
|
+
}
|
|
8
|
+
interface SectionNavProps {
|
|
9
|
+
links: SectionLink[];
|
|
10
|
+
/** How many pills to show inline before overflow (default: 4) */
|
|
11
|
+
visibleCount?: number;
|
|
12
|
+
/** Top offset in px for sticky positioning, e.g. header height (default: 0) */
|
|
13
|
+
stickyOffset?: number;
|
|
14
|
+
/** Label for the overflow trigger (default: "More") */
|
|
15
|
+
moreLabel?: string;
|
|
16
|
+
className?: string;
|
|
17
|
+
}
|
|
18
|
+
declare function SectionNav({ links, visibleCount, stickyOffset, moreLabel, className, }: SectionNavProps): import("react/jsx-runtime").JSX.Element;
|
|
19
|
+
export { SectionNav, type SectionLink, type SectionNavProps };
|
|
20
|
+
//# sourceMappingURL=section-nav.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"section-nav.d.ts","sourceRoot":"","sources":["../../../../src/client/storefront/components/section-nav.tsx"],"names":[],"mappings":"AASA,UAAU,WAAW;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,iCAAiC;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,mDAAmD;IACnD,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,UAAU,eAAe;IACvB,KAAK,EAAE,WAAW,EAAE,CAAC;IACrB,iEAAiE;IACjE,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,+EAA+E;IAC/E,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,uDAAuD;IACvD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,iBAAS,UAAU,CAAC,EAClB,KAAK,EACL,YAAgB,EAChB,YAAgB,EAChB,SAAkB,EAClB,SAAS,GACV,EAAE,eAAe,2CA2MjB;AAED,OAAO,EAAE,UAAU,EAAE,KAAK,WAAW,EAAE,KAAK,eAAe,EAAE,CAAC"}
|