@shopify/hydrogen 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +29 -0
- package/client.d.ts +1 -0
- package/client.js +1 -0
- package/dist/esnext/client.d.ts +7 -0
- package/dist/esnext/client.js +7 -0
- package/dist/esnext/components/AddToCartButton/AddToCartButton.client.d.ts +15 -0
- package/dist/esnext/components/AddToCartButton/AddToCartButton.client.js +44 -0
- package/dist/esnext/components/AddToCartButton/index.d.ts +1 -0
- package/dist/esnext/components/AddToCartButton/index.js +1 -0
- package/dist/esnext/components/BuyNowButton/BuyNowButton.d.ts +12 -0
- package/dist/esnext/components/BuyNowButton/BuyNowButton.js +29 -0
- package/dist/esnext/components/BuyNowButton/index.d.ts +1 -0
- package/dist/esnext/components/BuyNowButton/index.js +1 -0
- package/dist/esnext/components/CartCheckoutButton/CartCheckoutButton.client.d.ts +7 -0
- package/dist/esnext/components/CartCheckoutButton/CartCheckoutButton.client.js +14 -0
- package/dist/esnext/components/CartCheckoutButton/index.d.ts +1 -0
- package/dist/esnext/components/CartCheckoutButton/index.js +1 -0
- package/dist/esnext/components/CartContainer/CartContainer.client.d.ts +9 -0
- package/dist/esnext/components/CartContainer/CartContainer.client.js +24 -0
- package/dist/esnext/components/CartContainer/index.d.ts +1 -0
- package/dist/esnext/components/CartContainer/index.js +1 -0
- package/dist/esnext/components/CartLineAttributes/CartLineAttributes.client.d.ts +10 -0
- package/dist/esnext/components/CartLineAttributes/CartLineAttributes.client.js +9 -0
- package/dist/esnext/components/CartLineAttributes/index.d.ts +1 -0
- package/dist/esnext/components/CartLineAttributes/index.js +1 -0
- package/dist/esnext/components/CartLineImage/CartLineImage.client.d.ts +6 -0
- package/dist/esnext/components/CartLineImage/CartLineImage.client.js +8 -0
- package/dist/esnext/components/CartLineImage/index.d.ts +1 -0
- package/dist/esnext/components/CartLineImage/index.js +1 -0
- package/dist/esnext/components/CartLinePrice/CartLinePrice.client.d.ts +6 -0
- package/dist/esnext/components/CartLinePrice/CartLinePrice.client.js +17 -0
- package/dist/esnext/components/CartLinePrice/index.d.ts +1 -0
- package/dist/esnext/components/CartLinePrice/index.js +1 -0
- package/dist/esnext/components/CartLineProductTitle/CartLineProductTitle.client.d.ts +3 -0
- package/dist/esnext/components/CartLineProductTitle/CartLineProductTitle.client.js +8 -0
- package/dist/esnext/components/CartLineProductTitle/index.d.ts +1 -0
- package/dist/esnext/components/CartLineProductTitle/index.js +1 -0
- package/dist/esnext/components/CartLineProvider/CartLineProvider.client.d.ts +6 -0
- package/dist/esnext/components/CartLineProvider/CartLineProvider.client.js +5 -0
- package/dist/esnext/components/CartLineProvider/context.d.ts +26 -0
- package/dist/esnext/components/CartLineProvider/context.js +2 -0
- package/dist/esnext/components/CartLineProvider/hooks.d.ts +26 -0
- package/dist/esnext/components/CartLineProvider/hooks.js +9 -0
- package/dist/esnext/components/CartLineProvider/index.d.ts +2 -0
- package/dist/esnext/components/CartLineProvider/index.js +2 -0
- package/dist/esnext/components/CartLineQuantity/CartLineQuantity.client.d.ts +3 -0
- package/dist/esnext/components/CartLineQuantity/CartLineQuantity.client.js +8 -0
- package/dist/esnext/components/CartLineQuantity/index.d.ts +1 -0
- package/dist/esnext/components/CartLineQuantity/index.js +1 -0
- package/dist/esnext/components/CartLineQuantityAdjustButton/CartLineQuantityAdjustButton.d.ts +8 -0
- package/dist/esnext/components/CartLineQuantityAdjustButton/CartLineQuantityAdjustButton.js +17 -0
- package/dist/esnext/components/CartLineQuantityAdjustButton/index.d.ts +1 -0
- package/dist/esnext/components/CartLineQuantityAdjustButton/index.js +1 -0
- package/dist/esnext/components/CartLineSelectedOptions/CartLineSelectedOptions.client.d.ts +10 -0
- package/dist/esnext/components/CartLineSelectedOptions/CartLineSelectedOptions.client.js +9 -0
- package/dist/esnext/components/CartLineSelectedOptions/index.d.ts +1 -0
- package/dist/esnext/components/CartLineSelectedOptions/index.js +1 -0
- package/dist/esnext/components/CartLines/CartLines.d.ts +7 -0
- package/dist/esnext/components/CartLines/CartLines.js +15 -0
- package/dist/esnext/components/CartLines/index.d.ts +1 -0
- package/dist/esnext/components/CartLines/index.js +1 -0
- package/dist/esnext/components/CartProvider/CartProvider.client.d.ts +7 -0
- package/dist/esnext/components/CartProvider/CartProvider.client.js +422 -0
- package/dist/esnext/components/CartProvider/CartServerProvider.server.d.ts +11 -0
- package/dist/esnext/components/CartProvider/CartServerProvider.server.js +20 -0
- package/dist/esnext/components/CartProvider/constants.d.ts +2 -0
- package/dist/esnext/components/CartProvider/constants.js +2 -0
- package/dist/esnext/components/CartProvider/context.d.ts +2 -0
- package/dist/esnext/components/CartProvider/context.js +2 -0
- package/dist/esnext/components/CartProvider/graphql/CartAttributesUpdateMutation.d.ts +18 -0
- package/dist/esnext/components/CartProvider/graphql/CartAttributesUpdateMutation.js +1 -0
- package/dist/esnext/components/CartProvider/graphql/CartBuyerIdentityUpdateMutation.d.ts +18 -0
- package/dist/esnext/components/CartProvider/graphql/CartBuyerIdentityUpdateMutation.js +1 -0
- package/dist/esnext/components/CartProvider/graphql/CartCreateMutation.d.ts +17 -0
- package/dist/esnext/components/CartProvider/graphql/CartCreateMutation.js +1 -0
- package/dist/esnext/components/CartProvider/graphql/CartDiscountCodesUpdateMutation.d.ts +18 -0
- package/dist/esnext/components/CartProvider/graphql/CartDiscountCodesUpdateMutation.js +1 -0
- package/dist/esnext/components/CartProvider/graphql/CartFragment.d.ts +68 -0
- package/dist/esnext/components/CartProvider/graphql/CartFragment.js +1 -0
- package/dist/esnext/components/CartProvider/graphql/CartLineAddMutation.d.ts +18 -0
- package/dist/esnext/components/CartProvider/graphql/CartLineAddMutation.js +1 -0
- package/dist/esnext/components/CartProvider/graphql/CartLineRemoveMutation.d.ts +18 -0
- package/dist/esnext/components/CartProvider/graphql/CartLineRemoveMutation.js +1 -0
- package/dist/esnext/components/CartProvider/graphql/CartLineUpdateMutation.d.ts +18 -0
- package/dist/esnext/components/CartProvider/graphql/CartLineUpdateMutation.js +1 -0
- package/dist/esnext/components/CartProvider/graphql/CartNoteUpdateMutation.d.ts +18 -0
- package/dist/esnext/components/CartProvider/graphql/CartNoteUpdateMutation.js +1 -0
- package/dist/esnext/components/CartProvider/graphql/CartQuery.d.ts +13 -0
- package/dist/esnext/components/CartProvider/graphql/CartQuery.js +1 -0
- package/dist/esnext/components/CartProvider/hooks.d.ts +18 -0
- package/dist/esnext/components/CartProvider/hooks.js +79 -0
- package/dist/esnext/components/CartProvider/index.d.ts +4 -0
- package/dist/esnext/components/CartProvider/index.js +4 -0
- package/dist/esnext/components/CartProvider/types.d.ts +105 -0
- package/dist/esnext/components/CartProvider/types.js +1 -0
- package/dist/esnext/components/CartShopPayButton/CartShopPayButton.client.d.ts +2 -0
- package/dist/esnext/components/CartShopPayButton/CartShopPayButton.client.js +10 -0
- package/dist/esnext/components/CartShopPayButton/index.d.ts +1 -0
- package/dist/esnext/components/CartShopPayButton/index.js +1 -0
- package/dist/esnext/components/CartToggle/CartToggle.client.d.ts +8 -0
- package/dist/esnext/components/CartToggle/CartToggle.client.js +11 -0
- package/dist/esnext/components/CartToggle/index.d.ts +1 -0
- package/dist/esnext/components/CartToggle/index.js +1 -0
- package/dist/esnext/components/CartTotal/CartTotal.client.d.ts +3 -0
- package/dist/esnext/components/CartTotal/CartTotal.client.js +8 -0
- package/dist/esnext/components/CartTotal/index.d.ts +1 -0
- package/dist/esnext/components/CartTotal/index.js +1 -0
- package/dist/esnext/components/CartUIProvider/CartUIProvider.client.d.ts +5 -0
- package/dist/esnext/components/CartUIProvider/CartUIProvider.client.js +26 -0
- package/dist/esnext/components/CartUIProvider/context.d.ts +9 -0
- package/dist/esnext/components/CartUIProvider/context.js +2 -0
- package/dist/esnext/components/CartUIProvider/hooks.d.ts +1 -0
- package/dist/esnext/components/CartUIProvider/hooks.js +9 -0
- package/dist/esnext/components/CartUIProvider/index.d.ts +2 -0
- package/dist/esnext/components/CartUIProvider/index.js +2 -0
- package/dist/esnext/components/ExternalVideo/ExternalVideo.d.ts +14 -0
- package/dist/esnext/components/ExternalVideo/ExternalVideo.js +9 -0
- package/dist/esnext/components/ExternalVideo/ExternalVideoFragment.d.ts +4 -0
- package/dist/esnext/components/ExternalVideo/ExternalVideoFragment.js +1 -0
- package/dist/esnext/components/ExternalVideo/index.d.ts +1 -0
- package/dist/esnext/components/ExternalVideo/index.js +1 -0
- package/dist/esnext/components/Image/Image.d.ts +14 -0
- package/dist/esnext/components/Image/Image.js +10 -0
- package/dist/esnext/components/Image/ImageFragment.d.ts +4 -0
- package/dist/esnext/components/Image/ImageFragment.js +1 -0
- package/dist/esnext/components/Image/index.d.ts +1 -0
- package/dist/esnext/components/Image/index.js +1 -0
- package/dist/esnext/components/LocalizationProvider/LocalizationClientProvider.client.d.ts +6 -0
- package/dist/esnext/components/LocalizationProvider/LocalizationClientProvider.client.js +14 -0
- package/dist/esnext/components/LocalizationProvider/LocalizationContext.client.d.ts +8 -0
- package/dist/esnext/components/LocalizationProvider/LocalizationContext.client.js +2 -0
- package/dist/esnext/components/LocalizationProvider/LocalizationProvider.server.d.ts +4 -0
- package/dist/esnext/components/LocalizationProvider/LocalizationProvider.server.js +8 -0
- package/dist/esnext/components/LocalizationProvider/LocalizationQuery.d.ts +18 -0
- package/dist/esnext/components/LocalizationProvider/LocalizationQuery.js +1 -0
- package/dist/esnext/components/LocalizationProvider/hooks.d.ts +8 -0
- package/dist/esnext/components/LocalizationProvider/hooks.js +17 -0
- package/dist/esnext/components/LocalizationProvider/index.d.ts +2 -0
- package/dist/esnext/components/LocalizationProvider/index.js +2 -0
- package/dist/esnext/components/MediaFile/MediaFile.d.ts +19 -0
- package/dist/esnext/components/MediaFile/MediaFile.js +22 -0
- package/dist/esnext/components/MediaFile/MediaFileFragment.d.ts +22 -0
- package/dist/esnext/components/MediaFile/MediaFileFragment.js +1 -0
- package/dist/esnext/components/MediaFile/index.d.ts +1 -0
- package/dist/esnext/components/MediaFile/index.js +1 -0
- package/dist/esnext/components/Metafield/Metafield.client.d.ts +8 -0
- package/dist/esnext/components/Metafield/Metafield.client.js +50 -0
- package/dist/esnext/components/Metafield/MetafieldFragment.d.ts +4 -0
- package/dist/esnext/components/Metafield/MetafieldFragment.js +1 -0
- package/dist/esnext/components/Metafield/components/StarRating/StarRating.d.ts +12 -0
- package/dist/esnext/components/Metafield/components/StarRating/StarRating.js +48 -0
- package/dist/esnext/components/Metafield/components/StarRating/index.d.ts +1 -0
- package/dist/esnext/components/Metafield/components/StarRating/index.js +1 -0
- package/dist/esnext/components/Metafield/components/index.d.ts +1 -0
- package/dist/esnext/components/Metafield/components/index.js +1 -0
- package/dist/esnext/components/Metafield/index.d.ts +3 -0
- package/dist/esnext/components/Metafield/index.js +1 -0
- package/dist/esnext/components/Metafield/types.d.ts +4 -0
- package/dist/esnext/components/Metafield/types.js +1 -0
- package/dist/esnext/components/Model3D/Model3D.client.d.ts +25 -0
- package/dist/esnext/components/Model3D/Model3D.client.js +30 -0
- package/dist/esnext/components/Model3D/Model3DFragment.d.ts +11 -0
- package/dist/esnext/components/Model3D/Model3DFragment.js +1 -0
- package/dist/esnext/components/Model3D/index.d.ts +1 -0
- package/dist/esnext/components/Model3D/index.js +1 -0
- package/dist/esnext/components/Money/Money.client.d.ts +7 -0
- package/dist/esnext/components/Money/Money.client.js +10 -0
- package/dist/esnext/components/Money/index.d.ts +1 -0
- package/dist/esnext/components/Money/index.js +1 -0
- package/dist/esnext/components/ProductDescription/ProductDescription.client.d.ts +3 -0
- package/dist/esnext/components/ProductDescription/ProductDescription.client.js +10 -0
- package/dist/esnext/components/ProductDescription/index.d.ts +1 -0
- package/dist/esnext/components/ProductDescription/index.js +1 -0
- package/dist/esnext/components/ProductMetafield/ProductMetafield.client.d.ts +7 -0
- package/dist/esnext/components/ProductMetafield/ProductMetafield.client.js +16 -0
- package/dist/esnext/components/ProductMetafield/index.d.ts +1 -0
- package/dist/esnext/components/ProductMetafield/index.js +1 -0
- package/dist/esnext/components/ProductPrice/ProductPrice.client.d.ts +7 -0
- package/dist/esnext/components/ProductPrice/ProductPrice.client.js +32 -0
- package/dist/esnext/components/ProductPrice/index.d.ts +1 -0
- package/dist/esnext/components/ProductPrice/index.js +1 -0
- package/dist/esnext/components/ProductProvider/ProductProvider.client.d.ts +7 -0
- package/dist/esnext/components/ProductProvider/ProductProvider.client.js +35 -0
- package/dist/esnext/components/ProductProvider/ProductProviderFragment.d.ts +96 -0
- package/dist/esnext/components/ProductProvider/ProductProviderFragment.js +1 -0
- package/dist/esnext/components/ProductProvider/context.d.ts +13 -0
- package/dist/esnext/components/ProductProvider/context.js +2 -0
- package/dist/esnext/components/ProductProvider/hooks.d.ts +1 -0
- package/dist/esnext/components/ProductProvider/hooks.js +6 -0
- package/dist/esnext/components/ProductProvider/index.d.ts +2 -0
- package/dist/esnext/components/ProductProvider/index.js +2 -0
- package/dist/esnext/components/ProductProvider/types.d.ts +5 -0
- package/dist/esnext/components/ProductProvider/types.js +1 -0
- package/dist/esnext/components/ProductTitle/ProductTitle.client.d.ts +3 -0
- package/dist/esnext/components/ProductTitle/ProductTitle.client.js +11 -0
- package/dist/esnext/components/ProductTitle/index.d.ts +1 -0
- package/dist/esnext/components/ProductTitle/index.js +1 -0
- package/dist/esnext/components/RawHtml/RawHtml.d.ts +7 -0
- package/dist/esnext/components/RawHtml/RawHtml.js +13 -0
- package/dist/esnext/components/RawHtml/index.d.ts +1 -0
- package/dist/esnext/components/RawHtml/index.js +1 -0
- package/dist/esnext/components/SelectedVariantAddToCartButton/SelectedVariantAddToCartButton.client.d.ts +6 -0
- package/dist/esnext/components/SelectedVariantAddToCartButton/SelectedVariantAddToCartButton.client.js +12 -0
- package/dist/esnext/components/SelectedVariantAddToCartButton/index.d.ts +1 -0
- package/dist/esnext/components/SelectedVariantAddToCartButton/index.js +1 -0
- package/dist/esnext/components/SelectedVariantBuyNowButton/SelectedVariantBuyNowButton.d.ts +4 -0
- package/dist/esnext/components/SelectedVariantBuyNowButton/SelectedVariantBuyNowButton.js +12 -0
- package/dist/esnext/components/SelectedVariantBuyNowButton/index.d.ts +1 -0
- package/dist/esnext/components/SelectedVariantBuyNowButton/index.js +1 -0
- package/dist/esnext/components/SelectedVariantImage/SelectedVariantImage.client.d.ts +6 -0
- package/dist/esnext/components/SelectedVariantImage/SelectedVariantImage.client.js +12 -0
- package/dist/esnext/components/SelectedVariantImage/index.d.ts +1 -0
- package/dist/esnext/components/SelectedVariantImage/index.js +1 -0
- package/dist/esnext/components/SelectedVariantMetafield/SelectedVariantMetafield.client.d.ts +7 -0
- package/dist/esnext/components/SelectedVariantMetafield/SelectedVariantMetafield.client.js +15 -0
- package/dist/esnext/components/SelectedVariantMetafield/index.d.ts +1 -0
- package/dist/esnext/components/SelectedVariantMetafield/index.js +1 -0
- package/dist/esnext/components/SelectedVariantPrice/SelectedVariantPrice.client.d.ts +6 -0
- package/dist/esnext/components/SelectedVariantPrice/SelectedVariantPrice.client.js +18 -0
- package/dist/esnext/components/SelectedVariantPrice/index.d.ts +1 -0
- package/dist/esnext/components/SelectedVariantPrice/index.js +1 -0
- package/dist/esnext/components/SelectedVariantShopPayButton/SelectedVariantShopPayButton.client.d.ts +2 -0
- package/dist/esnext/components/SelectedVariantShopPayButton/SelectedVariantShopPayButton.client.js +12 -0
- package/dist/esnext/components/SelectedVariantShopPayButton/index.d.ts +1 -0
- package/dist/esnext/components/SelectedVariantShopPayButton/index.js +1 -0
- package/dist/esnext/components/SelectedVariantUnitPrice/SelectedVariantUnitPrice.client.d.ts +3 -0
- package/dist/esnext/components/SelectedVariantUnitPrice/SelectedVariantUnitPrice.client.js +12 -0
- package/dist/esnext/components/SelectedVariantUnitPrice/index.d.ts +1 -0
- package/dist/esnext/components/SelectedVariantUnitPrice/index.js +1 -0
- package/dist/esnext/components/ShopPayButton/ShopPayButton.client.d.ts +15 -0
- package/dist/esnext/components/ShopPayButton/ShopPayButton.client.js +32 -0
- package/dist/esnext/components/ShopPayButton/index.d.ts +1 -0
- package/dist/esnext/components/ShopPayButton/index.js +1 -0
- package/dist/esnext/components/UnitPrice/UnitPrice.client.d.ts +8 -0
- package/dist/esnext/components/UnitPrice/UnitPrice.client.js +16 -0
- package/dist/esnext/components/UnitPrice/index.d.ts +1 -0
- package/dist/esnext/components/UnitPrice/index.js +1 -0
- package/dist/esnext/components/Video/Video.d.ts +13 -0
- package/dist/esnext/components/Video/Video.js +8 -0
- package/dist/esnext/components/Video/VideoFragment.d.ts +11 -0
- package/dist/esnext/components/Video/VideoFragment.js +1 -0
- package/dist/esnext/components/Video/index.d.ts +1 -0
- package/dist/esnext/components/Video/index.js +1 -0
- package/dist/esnext/components/index.d.ts +41 -0
- package/dist/esnext/components/index.js +87 -0
- package/dist/esnext/components/types.d.ts +73 -0
- package/dist/esnext/components/types.js +10 -0
- package/dist/esnext/entry-client.d.ts +3 -0
- package/dist/esnext/entry-client.js +36 -0
- package/dist/esnext/entry-server.d.ts +3 -0
- package/dist/esnext/entry-server.js +286 -0
- package/dist/esnext/foundation/ClientMarker/ClientMarker.d.ts +10 -0
- package/dist/esnext/foundation/ClientMarker/ClientMarker.js +25 -0
- package/dist/esnext/foundation/ClientMarker/index.d.ts +1 -0
- package/dist/esnext/foundation/ClientMarker/index.js +1 -0
- package/dist/esnext/foundation/Hydration/Cache.client.d.ts +9 -0
- package/dist/esnext/foundation/Hydration/Cache.client.js +131 -0
- package/dist/esnext/foundation/Hydration/ClientComponents.server.d.ts +13 -0
- package/dist/esnext/foundation/Hydration/ClientComponents.server.js +18 -0
- package/dist/esnext/foundation/Hydration/Html.d.ts +5 -0
- package/dist/esnext/foundation/Hydration/Html.js +9 -0
- package/dist/esnext/foundation/Hydration/HydrationContext.server.d.ts +1 -0
- package/dist/esnext/foundation/Hydration/HydrationContext.server.js +2 -0
- package/dist/esnext/foundation/Hydration/ServerComponentRequest.server.d.ts +13 -0
- package/dist/esnext/foundation/Hydration/ServerComponentRequest.server.js +39 -0
- package/dist/esnext/foundation/Hydration/ServerComponentResponse.server.d.ts +18 -0
- package/dist/esnext/foundation/Hydration/ServerComponentResponse.server.js +35 -0
- package/dist/esnext/foundation/Hydration/react-utils.d.ts +5 -0
- package/dist/esnext/foundation/Hydration/react-utils.js +55 -0
- package/dist/esnext/foundation/Hydration/wire.server.d.ts +4 -0
- package/dist/esnext/foundation/Hydration/wire.server.js +75 -0
- package/dist/esnext/foundation/Hydration/writer.server.d.ts +14 -0
- package/dist/esnext/foundation/Hydration/writer.server.js +29 -0
- package/dist/esnext/foundation/Router/DefaultRoutes.d.ts +20 -0
- package/dist/esnext/foundation/Router/DefaultRoutes.js +54 -0
- package/dist/esnext/foundation/Router/ServerStateRouter.client.d.ts +6 -0
- package/dist/esnext/foundation/Router/ServerStateRouter.client.js +27 -0
- package/dist/esnext/foundation/Router/index.d.ts +1 -0
- package/dist/esnext/foundation/Router/index.js +1 -0
- package/dist/esnext/foundation/ServerStateProvider/ServerStateProvider.client.d.ts +11 -0
- package/dist/esnext/foundation/ServerStateProvider/ServerStateProvider.client.js +48 -0
- package/dist/esnext/foundation/ServerStateProvider/index.d.ts +1 -0
- package/dist/esnext/foundation/ServerStateProvider/index.js +1 -0
- package/dist/esnext/foundation/ShopifyProvider/ShopifyContext.d.ts +1 -0
- package/dist/esnext/foundation/ShopifyProvider/ShopifyContext.js +2 -0
- package/dist/esnext/foundation/ShopifyProvider/ShopifyProvider.d.ts +3 -0
- package/dist/esnext/foundation/ShopifyProvider/ShopifyProvider.js +11 -0
- package/dist/esnext/foundation/ShopifyProvider/ShopifyServerProvider.server.d.ts +8 -0
- package/dist/esnext/foundation/ShopifyProvider/ShopifyServerProvider.server.js +7 -0
- package/dist/esnext/foundation/ShopifyProvider/hooks.d.ts +2 -0
- package/dist/esnext/foundation/ShopifyProvider/hooks.js +9 -0
- package/dist/esnext/foundation/ShopifyProvider/index.d.ts +2 -0
- package/dist/esnext/foundation/ShopifyProvider/index.js +2 -0
- package/dist/esnext/foundation/ShopifyProvider/types.d.ts +12 -0
- package/dist/esnext/foundation/ShopifyProvider/types.js +1 -0
- package/dist/esnext/foundation/index.d.ts +4 -0
- package/dist/esnext/foundation/index.js +4 -0
- package/dist/esnext/framework/graphiql.d.ts +1 -0
- package/dist/esnext/framework/graphiql.js +39 -0
- package/dist/esnext/framework/middleware.d.ts +17 -0
- package/dist/esnext/framework/middleware.js +116 -0
- package/dist/esnext/framework/plugin.d.ts +3 -0
- package/dist/esnext/framework/plugin.js +14 -0
- package/dist/esnext/framework/plugins/vite-plugin-hydrogen-config.d.ts +3 -0
- package/dist/esnext/framework/plugins/vite-plugin-hydrogen-config.js +43 -0
- package/dist/esnext/framework/plugins/vite-plugin-hydrogen-middleware.d.ts +4 -0
- package/dist/esnext/framework/plugins/vite-plugin-hydrogen-middleware.js +28 -0
- package/dist/esnext/framework/plugins/vite-plugin-react-server-components-shim.d.ts +3 -0
- package/dist/esnext/framework/plugins/vite-plugin-react-server-components-shim.js +123 -0
- package/dist/esnext/framework/server-components.d.ts +12 -0
- package/dist/esnext/framework/server-components.js +72 -0
- package/dist/esnext/graphql/graphql-constants.d.ts +1295 -0
- package/dist/esnext/graphql/graphql-constants.js +2482 -0
- package/dist/esnext/graphql/types/types.d.ts +5583 -0
- package/dist/esnext/graphql/types/types.js +1414 -0
- package/dist/esnext/handle-event.d.ts +20 -0
- package/dist/esnext/handle-event.js +140 -0
- package/dist/esnext/handle-worker-event.d.ts +11 -0
- package/dist/esnext/handle-worker-event.js +14 -0
- package/dist/esnext/hooks/index.d.ts +5 -0
- package/dist/esnext/hooks/index.js +5 -0
- package/dist/esnext/hooks/useMeasurement/hooks.d.ts +9 -0
- package/dist/esnext/hooks/useMeasurement/hooks.js +13 -0
- package/dist/esnext/hooks/useMeasurement/index.d.ts +1 -0
- package/dist/esnext/hooks/useMeasurement/index.js +1 -0
- package/dist/esnext/hooks/useMoney/hooks.d.ts +11 -0
- package/dist/esnext/hooks/useMoney/hooks.js +33 -0
- package/dist/esnext/hooks/useMoney/index.d.ts +1 -0
- package/dist/esnext/hooks/useMoney/index.js +1 -0
- package/dist/esnext/hooks/useParsedMetafields/hooks.d.ts +3 -0
- package/dist/esnext/hooks/useParsedMetafields/hooks.js +15 -0
- package/dist/esnext/hooks/useParsedMetafields/index.d.ts +1 -0
- package/dist/esnext/hooks/useParsedMetafields/index.js +1 -0
- package/dist/esnext/hooks/useProductOptions/helpers.d.ts +4 -0
- package/dist/esnext/hooks/useProductOptions/helpers.js +33 -0
- package/dist/esnext/hooks/useProductOptions/index.d.ts +2 -0
- package/dist/esnext/hooks/useProductOptions/index.js +2 -0
- package/dist/esnext/hooks/useProductOptions/types.d.ts +50 -0
- package/dist/esnext/hooks/useProductOptions/types.js +1 -0
- package/dist/esnext/hooks/useProductOptions/useProductOptions.d.ts +23 -0
- package/dist/esnext/hooks/useProductOptions/useProductOptions.js +84 -0
- package/dist/esnext/hooks/useQuery/QueryProvider.d.ts +6 -0
- package/dist/esnext/hooks/useQuery/QueryProvider.js +13 -0
- package/dist/esnext/hooks/useQuery/hooks.d.ts +12 -0
- package/dist/esnext/hooks/useQuery/hooks.js +28 -0
- package/dist/esnext/hooks/useQuery/index.d.ts +2 -0
- package/dist/esnext/hooks/useQuery/index.js +2 -0
- package/dist/esnext/hooks/useShopQuery/hooks.d.ts +9 -0
- package/dist/esnext/hooks/useShopQuery/hooks.js +34 -0
- package/dist/esnext/hooks/useShopQuery/index.d.ts +1 -0
- package/dist/esnext/hooks/useShopQuery/index.js +1 -0
- package/dist/esnext/index.d.ts +9 -0
- package/dist/esnext/index.js +11 -0
- package/dist/esnext/types.d.ts +62 -0
- package/dist/esnext/types.js +1 -0
- package/dist/esnext/utilities/connections.d.ts +2 -0
- package/dist/esnext/utilities/connections.js +4 -0
- package/dist/esnext/utilities/environment.d.ts +2 -0
- package/dist/esnext/utilities/environment.js +2 -0
- package/dist/esnext/utilities/image_size.d.ts +17 -0
- package/dist/esnext/utilities/image_size.js +45 -0
- package/dist/esnext/utilities/index.d.ts +8 -0
- package/dist/esnext/utilities/index.js +8 -0
- package/dist/esnext/utilities/meaurement.d.ts +3 -0
- package/dist/esnext/utilities/meaurement.js +98 -0
- package/dist/esnext/utilities/metafields.d.ts +2 -0
- package/dist/esnext/utilities/metafields.js +32 -0
- package/dist/esnext/utilities/script_loader.d.ts +3 -0
- package/dist/esnext/utilities/script_loader.js +23 -0
- package/dist/esnext/utilities/suspense.d.ts +7 -0
- package/dist/esnext/utilities/suspense.js +32 -0
- package/dist/esnext/utilities/video_parameters.d.ts +47 -0
- package/dist/esnext/utilities/video_parameters.js +22 -0
- package/dist/esnext/version.d.ts +1 -0
- package/dist/esnext/version.js +1 -0
- package/dist/node/foundation/ClientMarker/ClientMarker.d.ts +10 -0
- package/dist/node/foundation/ClientMarker/ClientMarker.js +48 -0
- package/dist/node/foundation/ClientMarker/index.d.ts +1 -0
- package/dist/node/foundation/ClientMarker/index.js +13 -0
- package/dist/node/foundation/Hydration/HydrationContext.server.d.ts +1 -0
- package/dist/node/foundation/Hydration/HydrationContext.server.js +5 -0
- package/dist/node/foundation/Hydration/ServerComponentRequest.server.d.ts +13 -0
- package/dist/node/foundation/Hydration/ServerComponentRequest.server.js +43 -0
- package/dist/node/foundation/Hydration/ServerComponentResponse.server.d.ts +18 -0
- package/dist/node/foundation/Hydration/ServerComponentResponse.server.js +39 -0
- package/dist/node/foundation/Hydration/react-utils.d.ts +5 -0
- package/dist/node/foundation/Hydration/react-utils.js +63 -0
- package/dist/node/foundation/Router/DefaultRoutes.d.ts +20 -0
- package/dist/node/foundation/Router/DefaultRoutes.js +78 -0
- package/dist/node/foundation/Router/index.d.ts +1 -0
- package/dist/node/foundation/Router/index.js +5 -0
- package/dist/node/foundation/ShopifyProvider/ShopifyContext.d.ts +1 -0
- package/dist/node/foundation/ShopifyProvider/ShopifyContext.js +5 -0
- package/dist/node/foundation/ShopifyProvider/ShopifyProvider.d.ts +3 -0
- package/dist/node/foundation/ShopifyProvider/ShopifyProvider.js +34 -0
- package/dist/node/foundation/ShopifyProvider/ShopifyServerProvider.server.d.ts +8 -0
- package/dist/node/foundation/ShopifyProvider/ShopifyServerProvider.server.js +14 -0
- package/dist/node/foundation/ShopifyProvider/hooks.d.ts +2 -0
- package/dist/node/foundation/ShopifyProvider/hooks.js +13 -0
- package/dist/node/foundation/ShopifyProvider/index.d.ts +2 -0
- package/dist/node/foundation/ShopifyProvider/index.js +8 -0
- package/dist/node/foundation/ShopifyProvider/types.d.ts +12 -0
- package/dist/node/foundation/ShopifyProvider/types.js +2 -0
- package/dist/node/foundation/index.d.ts +4 -0
- package/dist/node/foundation/index.js +13 -0
- package/dist/node/framework/graphiql.d.ts +1 -0
- package/dist/node/framework/graphiql.js +43 -0
- package/dist/node/framework/middleware.d.ts +17 -0
- package/dist/node/framework/middleware.js +141 -0
- package/dist/node/framework/plugin.d.ts +3 -0
- package/dist/node/framework/plugin.js +19 -0
- package/dist/node/framework/plugins/vite-plugin-hydrogen-config.d.ts +3 -0
- package/dist/node/framework/plugins/vite-plugin-hydrogen-config.js +45 -0
- package/dist/node/framework/plugins/vite-plugin-hydrogen-middleware.d.ts +4 -0
- package/dist/node/framework/plugins/vite-plugin-hydrogen-middleware.js +33 -0
- package/dist/node/framework/plugins/vite-plugin-react-server-components-shim.d.ts +3 -0
- package/dist/node/framework/plugins/vite-plugin-react-server-components-shim.js +128 -0
- package/dist/node/framework/server-components.d.ts +12 -0
- package/dist/node/framework/server-components.js +77 -0
- package/dist/node/graphql/types/types.d.ts +5583 -0
- package/dist/node/graphql/types/types.js +1417 -0
- package/dist/node/handle-event.d.ts +20 -0
- package/dist/node/handle-event.js +143 -0
- package/dist/node/hooks/useQuery/QueryProvider.d.ts +6 -0
- package/dist/node/hooks/useQuery/QueryProvider.js +20 -0
- package/dist/node/hooks/useQuery/hooks.d.ts +12 -0
- package/dist/node/hooks/useQuery/hooks.js +32 -0
- package/dist/node/hooks/useQuery/index.d.ts +2 -0
- package/dist/node/hooks/useQuery/index.js +14 -0
- package/dist/node/types.d.ts +62 -0
- package/dist/node/types.js +2 -0
- package/dist/worker/foundation/Hydration/ServerComponentRequest.server.d.ts +13 -0
- package/dist/worker/foundation/Hydration/ServerComponentRequest.server.js +39 -0
- package/dist/worker/foundation/Hydration/ServerComponentResponse.server.d.ts +18 -0
- package/dist/worker/foundation/Hydration/ServerComponentResponse.server.js +35 -0
- package/dist/worker/graphql/types/types.d.ts +5583 -0
- package/dist/worker/graphql/types/types.js +1414 -0
- package/dist/worker/handle-event.d.ts +20 -0
- package/dist/worker/handle-event.js +140 -0
- package/dist/worker/handle-worker-event.d.ts +11 -0
- package/dist/worker/handle-worker-event.js +14 -0
- package/dist/worker/types.d.ts +62 -0
- package/dist/worker/types.js +1 -0
- package/entry-client.d.ts +1 -0
- package/entry-client.js +1 -0
- package/entry-server.d.ts +1 -0
- package/entry-server.js +1 -0
- package/marker.js +1 -0
- package/middleware.d.ts +1 -0
- package/middleware.js +1 -0
- package/package.json +98 -0
- package/plugin.d.ts +1 -0
- package/plugin.js +1 -0
- package/worker.js +1 -0
package/README.md
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
# Hydrogen
|
|
2
|
+
|
|
3
|
+
Hydrogen is a React framework and SDK that you can use to build fast and dynamic Shopify custom storefronts.
|
|
4
|
+
|
|
5
|
+
[Check out the docs](https://shopify.dev/beta/hydrogen)
|
|
6
|
+
|
|
7
|
+
## Getting started
|
|
8
|
+
|
|
9
|
+
**Requirements:**
|
|
10
|
+
|
|
11
|
+
- Node v14+
|
|
12
|
+
- Yarn
|
|
13
|
+
|
|
14
|
+
```bash
|
|
15
|
+
yarn
|
|
16
|
+
yarn dev
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
## Building for production
|
|
20
|
+
|
|
21
|
+
```bash
|
|
22
|
+
yarn build
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
Then, you can run a local `server.js` using the production build with:
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
yarn serve
|
|
29
|
+
```
|
package/client.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './dist/esnext/client';
|
package/client.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './dist/esnext/client';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './components';
|
|
2
|
+
export * from './hooks';
|
|
3
|
+
export * from './foundation/ShopifyProvider';
|
|
4
|
+
export { useServerResponse } from './foundation/Hydration/Cache.client';
|
|
5
|
+
export * from './foundation/ServerStateProvider';
|
|
6
|
+
export { ServerStateRouter } from './foundation/Router/ServerStateRouter.client';
|
|
7
|
+
export { Helmet } from 'react-helmet-async';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './components';
|
|
2
|
+
export * from './hooks';
|
|
3
|
+
export * from './foundation/ShopifyProvider';
|
|
4
|
+
export { useServerResponse } from './foundation/Hydration/Cache.client';
|
|
5
|
+
export * from './foundation/ServerStateProvider';
|
|
6
|
+
export { ServerStateRouter } from './foundation/Router/ServerStateRouter.client';
|
|
7
|
+
export { Helmet } from 'react-helmet-async';
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React, { ReactNode } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
export interface AddToCartButtonProps {
|
|
4
|
+
attributes?: {
|
|
5
|
+
key: string;
|
|
6
|
+
value: string;
|
|
7
|
+
}[];
|
|
8
|
+
variantID: string;
|
|
9
|
+
quantity?: number;
|
|
10
|
+
children: ReactNode;
|
|
11
|
+
accessibleAddingToCartLabel?: string;
|
|
12
|
+
}
|
|
13
|
+
declare type PropsWeControl = 'onClick';
|
|
14
|
+
export declare function AddToCartButton<TTag extends React.ElementType = 'button'>(props: Props<TTag, PropsWeControl> & AddToCartButtonProps): JSX.Element;
|
|
15
|
+
export {};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import React, { useEffect, useState } from 'react';
|
|
2
|
+
import { useCartLinesAddCallback, useCart, useCartCreateCallback, } from '../CartProvider';
|
|
3
|
+
import { useCartUI } from '../CartUIProvider';
|
|
4
|
+
export function AddToCartButton(props) {
|
|
5
|
+
const cartUI = useCartUI();
|
|
6
|
+
const [addingItem, setAddingItem] = useState(false);
|
|
7
|
+
const { variantID, quantity = 1, attributes, children, onAdd, accessibleAddingToCartLabel, ...passthroughProps } = props;
|
|
8
|
+
const { status, id } = useCart();
|
|
9
|
+
const createCart = useCartCreateCallback();
|
|
10
|
+
const addLines = useCartLinesAddCallback();
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
if (addingItem && status === 'idle') {
|
|
13
|
+
setAddingItem(false);
|
|
14
|
+
cartUI === null || cartUI === void 0 ? void 0 : cartUI.openCart();
|
|
15
|
+
}
|
|
16
|
+
}, [status, addingItem, cartUI]);
|
|
17
|
+
return (React.createElement(React.Fragment, null,
|
|
18
|
+
React.createElement("button", { ...passthroughProps, disabled: addingItem || passthroughProps.disabled, onClick: () => {
|
|
19
|
+
setAddingItem(true);
|
|
20
|
+
if (!id) {
|
|
21
|
+
createCart({
|
|
22
|
+
lines: [
|
|
23
|
+
{
|
|
24
|
+
quantity: quantity,
|
|
25
|
+
merchandiseId: variantID,
|
|
26
|
+
attributes: attributes,
|
|
27
|
+
},
|
|
28
|
+
],
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
addLines([
|
|
33
|
+
{
|
|
34
|
+
quantity: quantity,
|
|
35
|
+
merchandiseId: variantID,
|
|
36
|
+
attributes: attributes,
|
|
37
|
+
},
|
|
38
|
+
]);
|
|
39
|
+
}
|
|
40
|
+
} }, children),
|
|
41
|
+
React.createElement("p", { className: "sr-only", role: "alert", "aria-live": "assertive" }, addingItem
|
|
42
|
+
? accessibleAddingToCartLabel !== null && accessibleAddingToCartLabel !== void 0 ? accessibleAddingToCartLabel : 'Adding product to your cart'
|
|
43
|
+
: null)));
|
|
44
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { AddToCartButton, AddToCartButtonProps } from './AddToCartButton.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { AddToCartButton } from './AddToCartButton.client';
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { ElementType } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
export interface BuyNowButtonProps {
|
|
4
|
+
quantity?: number;
|
|
5
|
+
variantId: string;
|
|
6
|
+
attributes?: {
|
|
7
|
+
key: string;
|
|
8
|
+
value: string;
|
|
9
|
+
}[];
|
|
10
|
+
}
|
|
11
|
+
export declare type BuyNowButtonPropsWeControl = 'onClick';
|
|
12
|
+
export declare function BuyNowButton<TTag extends ElementType = 'button'>(props: Props<TTag, BuyNowButtonPropsWeControl> & BuyNowButtonProps): JSX.Element;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import React, { useEffect, useState } from 'react';
|
|
2
|
+
import { CartProvider, useCartCheckoutUrl, useCartCreateCallback, } from '../CartProvider';
|
|
3
|
+
export function BuyNowButton(props) {
|
|
4
|
+
return (React.createElement(CartProvider, null,
|
|
5
|
+
React.createElement(Button, { ...props })));
|
|
6
|
+
}
|
|
7
|
+
function Button(props) {
|
|
8
|
+
const createCart = useCartCreateCallback();
|
|
9
|
+
const checkoutUrl = useCartCheckoutUrl();
|
|
10
|
+
const [loading, setLoading] = useState(false);
|
|
11
|
+
const { quantity, variantId, attributes, children, ...passthroughProps } = props;
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
if (checkoutUrl) {
|
|
14
|
+
window.location.href = checkoutUrl;
|
|
15
|
+
}
|
|
16
|
+
}, [checkoutUrl]);
|
|
17
|
+
return (React.createElement("button", { disabled: loading !== null && loading !== void 0 ? loading : passthroughProps.disabled, ...passthroughProps, onClick: () => {
|
|
18
|
+
setLoading(true);
|
|
19
|
+
createCart({
|
|
20
|
+
lines: [
|
|
21
|
+
{
|
|
22
|
+
quantity: quantity !== null && quantity !== void 0 ? quantity : 1,
|
|
23
|
+
merchandiseId: variantId,
|
|
24
|
+
attributes,
|
|
25
|
+
},
|
|
26
|
+
],
|
|
27
|
+
});
|
|
28
|
+
} }, children));
|
|
29
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { BuyNowButton, BuyNowButtonProps, BuyNowButtonPropsWeControl, } from './BuyNowButton';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { BuyNowButton, } from './BuyNowButton';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React, { ReactNode } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
declare type PropsWeControl = 'onClick';
|
|
4
|
+
export declare function CartCheckoutButton<TTag extends React.ElementType = 'a'>(props: Props<TTag, PropsWeControl> & {
|
|
5
|
+
children: ReactNode;
|
|
6
|
+
}): JSX.Element;
|
|
7
|
+
export {};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React, { useEffect, useState } from 'react';
|
|
2
|
+
import { useCart, useCartCheckoutUrl } from '../CartProvider';
|
|
3
|
+
export function CartCheckoutButton(props) {
|
|
4
|
+
const [requestedCheckout, setRequestedCheckout] = useState(false);
|
|
5
|
+
const { status } = useCart();
|
|
6
|
+
const url = useCartCheckoutUrl();
|
|
7
|
+
const { children, ...passthroughProps } = props;
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
if (requestedCheckout && url && status === 'idle') {
|
|
10
|
+
window.location.href = url;
|
|
11
|
+
}
|
|
12
|
+
}, [requestedCheckout, status, url]);
|
|
13
|
+
return (React.createElement("button", { ...passthroughProps, disabled: requestedCheckout || passthroughProps.disabled, onClick: () => setRequestedCheckout(true) }, children));
|
|
14
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartCheckoutButton } from './CartCheckoutButton.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartCheckoutButton } from './CartCheckoutButton.client';
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React, { ReactNode } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
export interface CartContainerProps {
|
|
4
|
+
children: ReactNode;
|
|
5
|
+
id: string;
|
|
6
|
+
}
|
|
7
|
+
declare type PropsWeControl = 'ref' | 'id' | 'tabIndex' | 'aria-hidden';
|
|
8
|
+
export declare function CartContainer<TTag extends React.ElementType = 'aside'>(props: Props<TTag, PropsWeControl> & CartContainerProps): JSX.Element;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import React, { useEffect, useRef } from 'react';
|
|
2
|
+
import { useCartUI } from '../CartUIProvider/hooks';
|
|
3
|
+
import FocusTrap from 'focus-trap-react';
|
|
4
|
+
export function CartContainer(props) {
|
|
5
|
+
const cartUI = useCartUI();
|
|
6
|
+
if (props.id == null) {
|
|
7
|
+
console.warn('A CartContainer ID should be provided for accessibility purposes');
|
|
8
|
+
}
|
|
9
|
+
if (cartUI == null) {
|
|
10
|
+
throw new Error('CartContainer must be a descendent of CartUIProvider');
|
|
11
|
+
}
|
|
12
|
+
return React.createElement(Cart, { ...props });
|
|
13
|
+
}
|
|
14
|
+
function Cart(props) {
|
|
15
|
+
var _a;
|
|
16
|
+
const { children, id, ...passthroughProps } = props;
|
|
17
|
+
const { isCartOpen, setContainerID } = useCartUI();
|
|
18
|
+
const ref = useRef(null);
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
setContainerID(id);
|
|
21
|
+
}, [id, setContainerID]);
|
|
22
|
+
return (React.createElement(FocusTrap, { active: isCartOpen, focusTrapOptions: { allowOutsideClick: true } },
|
|
23
|
+
React.createElement("aside", { ...passthroughProps, ref: ref, id: id, tabIndex: -1, "aria-hidden": !isCartOpen, "aria-label": (_a = passthroughProps['aria-label']) !== null && _a !== void 0 ? _a : 'Cart' }, children)));
|
|
24
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartContainer } from './CartContainer.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartContainer } from './CartContainer.client';
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ReactElement, ElementType } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
interface AttributesRenderProps {
|
|
4
|
+
key: string;
|
|
5
|
+
value?: string | null;
|
|
6
|
+
}
|
|
7
|
+
export declare function CartLineAttributes<TTag extends ElementType>(props: Props<TTag> & {
|
|
8
|
+
children: (props: AttributesRenderProps) => ReactElement;
|
|
9
|
+
}): JSX.Element;
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React, { cloneElement, Fragment } from 'react';
|
|
2
|
+
import { useCartLine } from '../CartLineProvider';
|
|
3
|
+
export function CartLineAttributes(props) {
|
|
4
|
+
const cartLine = useCartLine();
|
|
5
|
+
const { as, children, ...passthroughProps } = props;
|
|
6
|
+
const Wrapper = as ? as : 'ul';
|
|
7
|
+
const ChildWrapper = Wrapper === 'ul' ? 'li' : Fragment;
|
|
8
|
+
return (React.createElement(Wrapper, { ...passthroughProps }, cartLine.attributes.map((attribute) => (React.createElement(ChildWrapper, { key: `${attribute.key}-${attribute.value}` }, cloneElement(children(attribute)))))));
|
|
9
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineAttributes } from './CartLineAttributes.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineAttributes } from './CartLineAttributes.client';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ElementType } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
import { ImageSizeOptions } from '../../utilities';
|
|
4
|
+
export declare function CartLineImage<TTag extends ElementType = 'img'>(props: Props<TTag> & {
|
|
5
|
+
options?: ImageSizeOptions;
|
|
6
|
+
}): JSX.Element | null;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useCartLine } from '../CartLineProvider';
|
|
3
|
+
import { Image as ImageComponent } from '../Image';
|
|
4
|
+
export function CartLineImage(props) {
|
|
5
|
+
const cartLine = useCartLine();
|
|
6
|
+
const { options, ...passthroughProps } = props;
|
|
7
|
+
return cartLine.merchandise.image ? (React.createElement(ImageComponent, { ...passthroughProps, image: cartLine.merchandise.image, options: options })) : null;
|
|
8
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineImage } from './CartLineImage.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineImage } from './CartLineImage.client';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ElementType } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
export interface CartLinePriceProps {
|
|
4
|
+
priceType?: 'regular' | 'compareAt';
|
|
5
|
+
}
|
|
6
|
+
export declare function CartLinePrice<TTag extends ElementType>(props: Props<TTag> & CartLinePriceProps): JSX.Element | null;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useCartLine } from '../CartLineProvider';
|
|
3
|
+
import { Money } from '../Money';
|
|
4
|
+
export function CartLinePrice(props) {
|
|
5
|
+
const cartLine = useCartLine();
|
|
6
|
+
const { priceType = 'regular', ...passthroughProps } = props;
|
|
7
|
+
const price = priceType === 'regular'
|
|
8
|
+
? cartLine.merchandise.priceV2
|
|
9
|
+
: cartLine.merchandise.compareAtPriceV2;
|
|
10
|
+
if (price == null) {
|
|
11
|
+
return null;
|
|
12
|
+
}
|
|
13
|
+
return (React.createElement(Money, { ...passthroughProps, money: {
|
|
14
|
+
amount: price.amount * cartLine.quantity,
|
|
15
|
+
currencyCode: price.currencyCode,
|
|
16
|
+
} }, props.children));
|
|
17
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLinePrice } from './CartLinePrice.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLinePrice } from './CartLinePrice.client';
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useCartLine } from '../CartLineProvider';
|
|
3
|
+
export function CartLineProductTitle(props) {
|
|
4
|
+
const cartLine = useCartLine();
|
|
5
|
+
const { as, ...passthroughProps } = props;
|
|
6
|
+
const Wrapper = as ? as : 'span';
|
|
7
|
+
return (React.createElement(Wrapper, { ...passthroughProps }, cartLine.merchandise.product.title));
|
|
8
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineProductTitle } from './CartLineProductTitle.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineProductTitle } from './CartLineProductTitle.client';
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export declare const CartLineContext: import("react").Context<({
|
|
2
|
+
__typename?: "CartLine" | undefined;
|
|
3
|
+
} & Pick<import("../../graphql/types/types").CartLine, "id" | "quantity"> & {
|
|
4
|
+
attributes: ({
|
|
5
|
+
__typename?: "Attribute" | undefined;
|
|
6
|
+
} & Pick<import("../../graphql/types/types").Attribute, "key" | "value">)[];
|
|
7
|
+
merchandise: {
|
|
8
|
+
__typename?: "ProductVariant" | undefined;
|
|
9
|
+
} & Pick<import("../../graphql/types/types").ProductVariant, "title" | "id" | "availableForSale" | "requiresShipping"> & {
|
|
10
|
+
compareAtPriceV2?: import("../../graphql/types/types").Maybe<{
|
|
11
|
+
__typename?: "MoneyV2" | undefined;
|
|
12
|
+
} & Pick<import("../../graphql/types/types").MoneyV2, "amount" | "currencyCode">> | undefined;
|
|
13
|
+
priceV2: {
|
|
14
|
+
__typename?: "MoneyV2" | undefined;
|
|
15
|
+
} & Pick<import("../../graphql/types/types").MoneyV2, "amount" | "currencyCode">;
|
|
16
|
+
image?: import("../../graphql/types/types").Maybe<{
|
|
17
|
+
__typename?: "Image" | undefined;
|
|
18
|
+
} & Pick<import("../../graphql/types/types").Image, "altText" | "originalSrc">> | undefined;
|
|
19
|
+
product: {
|
|
20
|
+
__typename?: "Product" | undefined;
|
|
21
|
+
} & Pick<import("../../graphql/types/types").Product, "title" | "handle">;
|
|
22
|
+
selectedOptions: ({
|
|
23
|
+
__typename?: "SelectedOption" | undefined;
|
|
24
|
+
} & Pick<import("../../graphql/types/types").SelectedOption, "value" | "name">)[];
|
|
25
|
+
};
|
|
26
|
+
}) | null>;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export declare function useCartLine(): {
|
|
2
|
+
__typename?: "CartLine" | undefined;
|
|
3
|
+
} & Pick<import("../../graphql/types/types").CartLine, "id" | "quantity"> & {
|
|
4
|
+
attributes: ({
|
|
5
|
+
__typename?: "Attribute" | undefined;
|
|
6
|
+
} & Pick<import("../../graphql/types/types").Attribute, "key" | "value">)[];
|
|
7
|
+
merchandise: {
|
|
8
|
+
__typename?: "ProductVariant" | undefined;
|
|
9
|
+
} & Pick<import("../../graphql/types/types").ProductVariant, "title" | "id" | "availableForSale" | "requiresShipping"> & {
|
|
10
|
+
compareAtPriceV2?: import("../../graphql/types/types").Maybe<{
|
|
11
|
+
__typename?: "MoneyV2" | undefined;
|
|
12
|
+
} & Pick<import("../../graphql/types/types").MoneyV2, "amount" | "currencyCode">> | undefined;
|
|
13
|
+
priceV2: {
|
|
14
|
+
__typename?: "MoneyV2" | undefined;
|
|
15
|
+
} & Pick<import("../../graphql/types/types").MoneyV2, "amount" | "currencyCode">;
|
|
16
|
+
image?: import("../../graphql/types/types").Maybe<{
|
|
17
|
+
__typename?: "Image" | undefined;
|
|
18
|
+
} & Pick<import("../../graphql/types/types").Image, "altText" | "originalSrc">> | undefined;
|
|
19
|
+
product: {
|
|
20
|
+
__typename?: "Product" | undefined;
|
|
21
|
+
} & Pick<import("../../graphql/types/types").Product, "title" | "handle">;
|
|
22
|
+
selectedOptions: ({
|
|
23
|
+
__typename?: "SelectedOption" | undefined;
|
|
24
|
+
} & Pick<import("../../graphql/types/types").SelectedOption, "value" | "name">)[];
|
|
25
|
+
};
|
|
26
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { useContext } from 'react';
|
|
2
|
+
import { CartLineContext } from './context';
|
|
3
|
+
export function useCartLine() {
|
|
4
|
+
const context = useContext(CartLineContext);
|
|
5
|
+
if (context == null) {
|
|
6
|
+
throw new Error('Expected a cart line context but none was found');
|
|
7
|
+
}
|
|
8
|
+
return context;
|
|
9
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useCartLine } from '../CartLineProvider';
|
|
3
|
+
export function CartLineQuantity(props) {
|
|
4
|
+
const cartLine = useCartLine();
|
|
5
|
+
const { as, ...passthroughProps } = props;
|
|
6
|
+
const Wrapper = as ? as : 'span';
|
|
7
|
+
return React.createElement(Wrapper, { ...passthroughProps }, cartLine.quantity);
|
|
8
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineQuantity } from './CartLineQuantity.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineQuantity } from './CartLineQuantity.client';
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ReactNode, ElementType } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
declare type PropsWeControl = 'onClick' | 'adjust';
|
|
4
|
+
export declare function CartLineQuantityAdjustButton<TTag extends ElementType = 'button'>(props: Props<TTag, PropsWeControl> & {
|
|
5
|
+
children: ReactNode;
|
|
6
|
+
adjust?: 'increase' | 'decrease' | 'remove';
|
|
7
|
+
}): JSX.Element;
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useCartLinesRemoveCallback, useCartLinesUpdateCallback, } from '../CartProvider';
|
|
3
|
+
import { useCartLine } from '../CartLineProvider';
|
|
4
|
+
export function CartLineQuantityAdjustButton(props) {
|
|
5
|
+
const updateLines = useCartLinesUpdateCallback();
|
|
6
|
+
const removeLines = useCartLinesRemoveCallback();
|
|
7
|
+
const cartLine = useCartLine();
|
|
8
|
+
const { children, adjust, ...passthroughProps } = props;
|
|
9
|
+
return (React.createElement("button", { onClick: () => {
|
|
10
|
+
if (adjust === 'remove') {
|
|
11
|
+
removeLines([cartLine.id]);
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
const quantity = adjust === 'decrease' ? cartLine.quantity - 1 : cartLine.quantity + 1;
|
|
15
|
+
updateLines([{ id: cartLine.id, quantity }]);
|
|
16
|
+
}, ...passthroughProps }, children));
|
|
17
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineQuantityAdjustButton } from './CartLineQuantityAdjustButton';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineQuantityAdjustButton } from './CartLineQuantityAdjustButton';
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ReactElement, ElementType } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
interface SelectedOptionsRenderProps {
|
|
4
|
+
name?: string;
|
|
5
|
+
value?: string;
|
|
6
|
+
}
|
|
7
|
+
export declare function CartLineSelectedOptions<TTag extends ElementType>(props: Props<TTag> & {
|
|
8
|
+
children: (props: SelectedOptionsRenderProps) => ReactElement;
|
|
9
|
+
}): JSX.Element;
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React, { cloneElement, Fragment } from 'react';
|
|
2
|
+
import { useCartLine } from '../CartLineProvider';
|
|
3
|
+
export function CartLineSelectedOptions(props) {
|
|
4
|
+
const cartLine = useCartLine();
|
|
5
|
+
const { as, children, ...passthroughProps } = props;
|
|
6
|
+
const Wrapper = as ? as : 'ul';
|
|
7
|
+
const ChildWrapper = Wrapper === 'ul' ? 'li' : Fragment;
|
|
8
|
+
return (React.createElement(Wrapper, { ...passthroughProps }, cartLine.merchandise.selectedOptions.map((option) => (React.createElement(ChildWrapper, { key: `${option.name}-${option.value}` }, cloneElement(children(option)))))));
|
|
9
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineSelectedOptions } from './CartLineSelectedOptions.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLineSelectedOptions } from './CartLineSelectedOptions.client';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ReactNode, ElementType } from 'react';
|
|
2
|
+
import { Cart } from '../CartProvider';
|
|
3
|
+
import { Props } from '../types';
|
|
4
|
+
export interface CartLinesProps {
|
|
5
|
+
children: ReactNode | ((line: Cart['lines'][1]) => ReactNode);
|
|
6
|
+
}
|
|
7
|
+
export declare function CartLines<TTag extends ElementType>(props: Props<TTag> & CartLinesProps): JSX.Element;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React, { cloneElement, Fragment } from 'react';
|
|
2
|
+
import { useCart } from '../CartProvider';
|
|
3
|
+
import { CartLineProvider } from '../CartLineProvider';
|
|
4
|
+
export function CartLines(props) {
|
|
5
|
+
const { lines } = useCart();
|
|
6
|
+
const { as, children, ...passthroughProps } = props;
|
|
7
|
+
const Wrapper = as !== null && as !== void 0 ? as : Fragment;
|
|
8
|
+
const ChildWrapper = Wrapper === 'ul' ? 'li' : Fragment;
|
|
9
|
+
return (React.createElement(Wrapper, { ...passthroughProps }, lines.map((line) => {
|
|
10
|
+
return (React.createElement(ChildWrapper, { key: line.id },
|
|
11
|
+
React.createElement(CartLineProvider, { line: line }, typeof children === 'function'
|
|
12
|
+
? cloneElement(children(line))
|
|
13
|
+
: children)));
|
|
14
|
+
})));
|
|
15
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLines } from './CartLines';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { CartLines } from './CartLines';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { CartFragmentFragment } from './graphql/CartFragment';
|
|
3
|
+
export declare function CartProvider({ children, cart, numCartLines, }: {
|
|
4
|
+
children: React.ReactNode;
|
|
5
|
+
cart?: CartFragmentFragment;
|
|
6
|
+
numCartLines?: number;
|
|
7
|
+
}): JSX.Element;
|