@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
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ImageProps } from '../Image';
|
|
2
|
+
import { VideoProps } from '../Video';
|
|
3
|
+
import { ExternalVideoProps } from '../ExternalVideo';
|
|
4
|
+
import { Model3DProps } from '../Model3D';
|
|
5
|
+
import { Media as MediaType } from '../../graphql/types/types';
|
|
6
|
+
export declare type Media = Pick<MediaType, 'mediaContentType'>;
|
|
7
|
+
declare type ImageMedia = Media & ImageProps;
|
|
8
|
+
declare type Model3DMedia = Media & Model3DProps['model'];
|
|
9
|
+
declare type ExternalVideoMedia = Media & ExternalVideoProps['video'];
|
|
10
|
+
declare type VideoMedia = Media & VideoProps['video'];
|
|
11
|
+
export interface Props {
|
|
12
|
+
media: ImageMedia | Model3DMedia | ExternalVideoMedia | VideoMedia;
|
|
13
|
+
options?: ImageProps['options'] | VideoProps['options'] | ExternalVideoProps['options'];
|
|
14
|
+
}
|
|
15
|
+
export declare function MediaFile({ media, options, ...passthroughProps }: Props): JSX.Element | null;
|
|
16
|
+
export declare namespace MediaFile {
|
|
17
|
+
var Fragment: string;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { Image } from '../Image';
|
|
3
|
+
import { Video } from '../Video';
|
|
4
|
+
import { ExternalVideo } from '../ExternalVideo';
|
|
5
|
+
import { Model3D } from '../Model3D';
|
|
6
|
+
import { MediaFileFragment } from '../../graphql/graphql-constants';
|
|
7
|
+
export function MediaFile({ media, options, ...passthroughProps }) {
|
|
8
|
+
switch (media.mediaContentType) {
|
|
9
|
+
case 'IMAGE': {
|
|
10
|
+
return (React.createElement(Image, { ...passthroughProps, image: media.image, options: options }));
|
|
11
|
+
}
|
|
12
|
+
case 'VIDEO':
|
|
13
|
+
return (React.createElement(Video, { ...passthroughProps, video: media, options: options }));
|
|
14
|
+
case 'EXTERNAL_VIDEO':
|
|
15
|
+
return (React.createElement(ExternalVideo, { ...passthroughProps, video: media, options: options }));
|
|
16
|
+
case 'MODEL_3D':
|
|
17
|
+
return React.createElement(Model3D, { ...passthroughProps, model: media });
|
|
18
|
+
default:
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
MediaFile.Fragment = MediaFileFragment;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import * as Types from '../../graphql/types/types';
|
|
2
|
+
import { ImageFragmentFragment } from '../Image/ImageFragment';
|
|
3
|
+
import { VideoFragmentFragment } from '../Video/VideoFragment';
|
|
4
|
+
import { ExternalVideoFragmentFragment } from '../ExternalVideo/ExternalVideoFragment';
|
|
5
|
+
import { Model3DFragmentFragment } from '../Model3D/Model3DFragment';
|
|
6
|
+
export declare type MediaFileFragment_ExternalVideo_Fragment = {
|
|
7
|
+
__typename?: 'ExternalVideo';
|
|
8
|
+
} & Pick<Types.ExternalVideo, 'mediaContentType'> & ExternalVideoFragmentFragment;
|
|
9
|
+
export declare type MediaFileFragment_MediaImage_Fragment = {
|
|
10
|
+
__typename?: 'MediaImage';
|
|
11
|
+
} & Pick<Types.MediaImage, 'mediaContentType'> & {
|
|
12
|
+
image?: Types.Maybe<{
|
|
13
|
+
__typename?: 'Image';
|
|
14
|
+
} & ImageFragmentFragment>;
|
|
15
|
+
};
|
|
16
|
+
export declare type MediaFileFragment_Model3d_Fragment = {
|
|
17
|
+
__typename?: 'Model3d';
|
|
18
|
+
} & Pick<Types.Model3d, 'mediaContentType'> & Model3DFragmentFragment;
|
|
19
|
+
export declare type MediaFileFragment_Video_Fragment = {
|
|
20
|
+
__typename?: 'Video';
|
|
21
|
+
} & Pick<Types.Video, 'mediaContentType'> & VideoFragmentFragment;
|
|
22
|
+
export declare type MediaFileFragmentFragment = MediaFileFragment_ExternalVideo_Fragment | MediaFileFragment_MediaImage_Fragment | MediaFileFragment_Model3d_Fragment | MediaFileFragment_Video_Fragment;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { MediaFile, Props as MediaFileProps } from './MediaFile';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { MediaFile } from './MediaFile';
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ElementType, ReactElement } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
import { ParsedMetafield } from '../../types';
|
|
4
|
+
export interface MetafieldProps {
|
|
5
|
+
metafield: ParsedMetafield;
|
|
6
|
+
children?: (value: ParsedMetafield) => ReactElement;
|
|
7
|
+
}
|
|
8
|
+
export declare function Metafield<TTag extends ElementType>(props: Props<TTag> & MetafieldProps): JSX.Element | null;
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useShop } from '../../foundation';
|
|
3
|
+
import { getMeasurementAsString } from '../../utilities';
|
|
4
|
+
import { StarRating } from './components/StarRating';
|
|
5
|
+
import { RawHtml } from '../RawHtml';
|
|
6
|
+
export function Metafield(props) {
|
|
7
|
+
const { metafield, children, as, ...passthroughProps } = props;
|
|
8
|
+
const { locale } = useShop();
|
|
9
|
+
if (metafield.value == null) {
|
|
10
|
+
console.warn(`No metafield value for ${metafield}`);
|
|
11
|
+
return null;
|
|
12
|
+
}
|
|
13
|
+
if (typeof children === 'function') {
|
|
14
|
+
return children(metafield);
|
|
15
|
+
}
|
|
16
|
+
switch (metafield.type) {
|
|
17
|
+
case 'date': {
|
|
18
|
+
const Wrapper = as !== null && as !== void 0 ? as : 'time';
|
|
19
|
+
return (React.createElement(Wrapper, { ...passthroughProps }, metafield.value.toLocaleDateString(locale)));
|
|
20
|
+
}
|
|
21
|
+
case 'date_time': {
|
|
22
|
+
const Wrapper = as !== null && as !== void 0 ? as : 'time';
|
|
23
|
+
return (React.createElement(Wrapper, { ...passthroughProps }, metafield.value.toLocaleString(locale)));
|
|
24
|
+
}
|
|
25
|
+
case 'weight':
|
|
26
|
+
case 'dimension':
|
|
27
|
+
case 'volume': {
|
|
28
|
+
const Wrapper = as !== null && as !== void 0 ? as : 'span';
|
|
29
|
+
return (React.createElement(Wrapper, { ...passthroughProps }, getMeasurementAsString(metafield.value, locale)));
|
|
30
|
+
}
|
|
31
|
+
case 'rating': {
|
|
32
|
+
return (React.createElement(StarRating, { rating: metafield.value, ...passthroughProps }));
|
|
33
|
+
}
|
|
34
|
+
case 'single_line_text_field': {
|
|
35
|
+
return (React.createElement(RawHtml, { ...passthroughProps, as: as !== null && as !== void 0 ? as : 'span', string: metafield.value }));
|
|
36
|
+
}
|
|
37
|
+
case 'multi_line_text_field': {
|
|
38
|
+
return (React.createElement(RawHtml, { ...passthroughProps, as: as, string: metafield.value.split('\n').join('<br/>') }));
|
|
39
|
+
}
|
|
40
|
+
case 'url':
|
|
41
|
+
return (React.createElement("a", { href: metafield.value, ...passthroughProps }, metafield.value));
|
|
42
|
+
case 'json':
|
|
43
|
+
const Wrapper = as !== null && as !== void 0 ? as : 'span';
|
|
44
|
+
return (React.createElement(Wrapper, { ...passthroughProps }, JSON.stringify(metafield.value)));
|
|
45
|
+
default: {
|
|
46
|
+
const Wrapper = as !== null && as !== void 0 ? as : 'span';
|
|
47
|
+
return (React.createElement(Wrapper, { ...passthroughProps }, metafield.value.toString()));
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { ElementType } from 'react';
|
|
2
|
+
import { Props } from '../../../types';
|
|
3
|
+
import { Rating } from '../../../../types';
|
|
4
|
+
export declare const STAR_EMPTY = "\u2606";
|
|
5
|
+
export declare const STAR_FILLED = "\u2605";
|
|
6
|
+
export interface StarRatingProps {
|
|
7
|
+
rating: Rating;
|
|
8
|
+
}
|
|
9
|
+
export declare function StarRating<TTag extends ElementType>(props: Props<TTag> & StarRatingProps): JSX.Element;
|
|
10
|
+
export declare function Star({ percentFilled }: {
|
|
11
|
+
percentFilled: Number;
|
|
12
|
+
}): JSX.Element;
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import React, { useMemo } from 'react';
|
|
2
|
+
export const STAR_EMPTY = '☆';
|
|
3
|
+
export const STAR_FILLED = '★';
|
|
4
|
+
export function StarRating(props) {
|
|
5
|
+
const { as, rating, ...passthroughProps } = props;
|
|
6
|
+
const starsArray = useMemo(() => {
|
|
7
|
+
const ratingMin = Math.floor(rating.scale_min);
|
|
8
|
+
const ratingMax = Math.floor(rating.scale_max);
|
|
9
|
+
const ratingInteger = Math.floor(rating.value);
|
|
10
|
+
const ratingPercent = (rating.value % 1) * 100;
|
|
11
|
+
const stars = [];
|
|
12
|
+
for (let i = ratingMin; i <= ratingMax; i++) {
|
|
13
|
+
if (i <= ratingInteger) {
|
|
14
|
+
stars.push(React.createElement(Star, { key: i, percentFilled: 100 }));
|
|
15
|
+
}
|
|
16
|
+
else if (i > ratingInteger + 1) {
|
|
17
|
+
stars.push(React.createElement(Star, { key: i, percentFilled: 0 }));
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
stars.push(React.createElement(Star, { key: i, percentFilled: ratingPercent }));
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
return stars;
|
|
24
|
+
}, [rating.scale_min, rating.scale_max, rating.value]);
|
|
25
|
+
const Wrapper = as !== null && as !== void 0 ? as : 'div';
|
|
26
|
+
return React.createElement(Wrapper, { ...passthroughProps }, starsArray);
|
|
27
|
+
}
|
|
28
|
+
export function Star({ percentFilled }) {
|
|
29
|
+
if (percentFilled === 100) {
|
|
30
|
+
return React.createElement("span", null, STAR_FILLED);
|
|
31
|
+
}
|
|
32
|
+
if (percentFilled === 0) {
|
|
33
|
+
return React.createElement("span", null, STAR_EMPTY);
|
|
34
|
+
}
|
|
35
|
+
return (React.createElement("span", { style: {
|
|
36
|
+
position: 'relative',
|
|
37
|
+
display: 'inline-block',
|
|
38
|
+
} },
|
|
39
|
+
React.createElement("span", null, STAR_EMPTY),
|
|
40
|
+
React.createElement("span", { style: {
|
|
41
|
+
display: 'inline-block',
|
|
42
|
+
position: 'absolute',
|
|
43
|
+
top: '0',
|
|
44
|
+
left: '0',
|
|
45
|
+
width: `${percentFilled}%`,
|
|
46
|
+
overflow: 'hidden',
|
|
47
|
+
} }, STAR_FILLED)));
|
|
48
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { StarRating } from './StarRating';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { StarRating } from './StarRating';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { StarRating } from './StarRating';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { StarRating } from './StarRating';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { Metafield } from './Metafield.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { ReactNode, ElementType } from 'react';
|
|
2
|
+
import { Model3d as Model3DType, Model3dSource, Image } from '../../graphql/types/types';
|
|
3
|
+
import { Props } from '../types';
|
|
4
|
+
export interface Model3DProps {
|
|
5
|
+
children?: ReactNode;
|
|
6
|
+
model: {
|
|
7
|
+
id?: Model3DType['id'];
|
|
8
|
+
alt: Model3DType['alt'];
|
|
9
|
+
previewImage?: Pick<Image, 'originalSrc'>;
|
|
10
|
+
sources: Pick<Model3dSource, 'url'>[];
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
declare type PropsWeControl = 'src' | 'alt' | 'poster';
|
|
14
|
+
declare global {
|
|
15
|
+
namespace JSX {
|
|
16
|
+
interface IntrinsicElements {
|
|
17
|
+
'model-viewer': any;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
export declare function Model3D<TTag extends ElementType = 'div'>(props: Props<TTag, PropsWeControl> & Model3DProps): JSX.Element | null;
|
|
22
|
+
export declare namespace Model3D {
|
|
23
|
+
var Fragment: string;
|
|
24
|
+
}
|
|
25
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import React, { useState, useEffect } from 'react';
|
|
2
|
+
import { loadScript } from '../../utilities';
|
|
3
|
+
import { Model3DFragment } from '../../graphql/graphql-constants';
|
|
4
|
+
// TODO: Support binding to `model-viewer` events?
|
|
5
|
+
export function Model3D(props) {
|
|
6
|
+
var _a, _b, _c;
|
|
7
|
+
const { model, id = model.id, children, ...passthroughProps } = props;
|
|
8
|
+
const [modelViewerLoaded, setModelViewerLoaded] = useState(false);
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
// The ModelViewer library depends on `window` so
|
|
11
|
+
// we cannot use it server side, so we instead load
|
|
12
|
+
// it dynamically
|
|
13
|
+
async function loadModelViewer() {
|
|
14
|
+
const loaded = await loadScript('https://unpkg.com/@google/model-viewer/dist/model-viewer.min.js', {
|
|
15
|
+
module: true,
|
|
16
|
+
});
|
|
17
|
+
if (!loaded) {
|
|
18
|
+
console.warn('model-viewer library did not load');
|
|
19
|
+
}
|
|
20
|
+
setModelViewerLoaded(true);
|
|
21
|
+
}
|
|
22
|
+
loadModelViewer();
|
|
23
|
+
}, []);
|
|
24
|
+
if (!modelViewerLoaded) {
|
|
25
|
+
// TODO: What do we want to display while the model-viewer library loads?
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
return (React.createElement("model-viewer", { ...passthroughProps, id: id, src: model.sources[0].url, alt: model.alt, "camera-controls": (_a = passthroughProps.cameraControls) !== null && _a !== void 0 ? _a : true, poster: (_b = model.previewImage) === null || _b === void 0 ? void 0 : _b.originalSrc, autoplay: (_c = passthroughProps.autoplay) !== null && _c !== void 0 ? _c : true }, children));
|
|
29
|
+
}
|
|
30
|
+
Model3D.Fragment = Model3DFragment;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import * as Types from '../../graphql/types/types';
|
|
2
|
+
export declare type Model3DFragmentFragment = {
|
|
3
|
+
__typename?: 'Model3d';
|
|
4
|
+
} & Pick<Types.Model3d, 'id' | 'alt' | 'mediaContentType'> & {
|
|
5
|
+
previewImage?: Types.Maybe<{
|
|
6
|
+
__typename?: 'Image';
|
|
7
|
+
} & Pick<Types.Image, 'originalSrc'>>;
|
|
8
|
+
sources: Array<{
|
|
9
|
+
__typename?: 'Model3dSource';
|
|
10
|
+
} & Pick<Types.Model3dSource, 'url'>>;
|
|
11
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { Model3D, Model3DProps } from './Model3D.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { Model3D } from './Model3D.client';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ElementType } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
import { MoneyV2 } from '../../graphql/types/types';
|
|
4
|
+
export interface MoneyProps {
|
|
5
|
+
money: MoneyV2;
|
|
6
|
+
}
|
|
7
|
+
export declare function Money<TTag extends ElementType>(props: Props<TTag> & MoneyProps): JSX.Element;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useMoney } from '../../hooks';
|
|
3
|
+
export function Money(props) {
|
|
4
|
+
const { money, children, as, ...passthroughProps } = props;
|
|
5
|
+
const moneyObject = useMoney(money);
|
|
6
|
+
const Wrapper = as !== null && as !== void 0 ? as : 'div';
|
|
7
|
+
return (React.createElement(Wrapper, { ...passthroughProps }, typeof children === 'function'
|
|
8
|
+
? children(moneyObject)
|
|
9
|
+
: moneyObject.localizedString));
|
|
10
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { Money, MoneyProps } from './Money.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { Money } from './Money.client';
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { RawHtml } from '../RawHtml';
|
|
3
|
+
import { useProduct } from '../ProductProvider';
|
|
4
|
+
export function ProductDescription(props) {
|
|
5
|
+
const product = useProduct();
|
|
6
|
+
if (product == null) {
|
|
7
|
+
throw new Error('Expected a ProductProvider context, but none was found');
|
|
8
|
+
}
|
|
9
|
+
return product.descriptionHtml ? (React.createElement(RawHtml, { string: product.descriptionHtml, ...props })) : null;
|
|
10
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { ProductDescription } from './ProductDescription.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { ProductDescription } from './ProductDescription.client';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ElementType } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
export interface ProductMetafieldProps {
|
|
4
|
+
keyName: string;
|
|
5
|
+
namespace: string;
|
|
6
|
+
}
|
|
7
|
+
export declare function ProductMetafield<TTag extends ElementType>(props: Props<TTag> & ProductMetafieldProps): JSX.Element | null;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Metafield } from '../Metafield';
|
|
3
|
+
import { useProduct } from '../ProductProvider';
|
|
4
|
+
export function ProductMetafield(props) {
|
|
5
|
+
const product = useProduct();
|
|
6
|
+
if (product == null) {
|
|
7
|
+
throw new Error('Expected a ProductProvider context, but none was found');
|
|
8
|
+
}
|
|
9
|
+
if (product.metafields == null) {
|
|
10
|
+
console.warn('No metafields available for product');
|
|
11
|
+
return null;
|
|
12
|
+
}
|
|
13
|
+
const { namespace, keyName, ...passthroughProps } = props;
|
|
14
|
+
const field = product.metafields.find((metafield) => metafield.namespace === namespace && metafield.key === keyName);
|
|
15
|
+
return field ? React.createElement(Metafield, { metafield: field, ...passthroughProps }) : null;
|
|
16
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { ProductMetafield } from './ProductMetafield.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { ProductMetafield } from './ProductMetafield.client';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ElementType } from 'react';
|
|
2
|
+
import { Props } from '../types';
|
|
3
|
+
export interface ProductPriceProps {
|
|
4
|
+
priceType?: 'regular' | 'compareAt';
|
|
5
|
+
valueType?: 'max' | 'min';
|
|
6
|
+
}
|
|
7
|
+
export declare function ProductPrice<TTag extends ElementType>(props: Props<TTag> & ProductPriceProps): JSX.Element | null;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Money } from '../Money';
|
|
3
|
+
import { useProduct } from '../ProductProvider';
|
|
4
|
+
export function ProductPrice(props) {
|
|
5
|
+
var _a, _b, _c, _d;
|
|
6
|
+
const product = useProduct();
|
|
7
|
+
const { priceType = 'regular', valueType = 'min', ...passthroughProps } = props;
|
|
8
|
+
if (product == null) {
|
|
9
|
+
throw new Error('Expected a ProductProvider context, but none was found');
|
|
10
|
+
}
|
|
11
|
+
let price;
|
|
12
|
+
if (priceType === 'compareAt') {
|
|
13
|
+
if (valueType === 'max') {
|
|
14
|
+
price = (_a = product.compareAtPriceRange) === null || _a === void 0 ? void 0 : _a.maxVariantPrice;
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
price = (_b = product.compareAtPriceRange) === null || _b === void 0 ? void 0 : _b.minVariantPrice;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
if (valueType === 'max') {
|
|
22
|
+
price = (_c = product.priceRange) === null || _c === void 0 ? void 0 : _c.maxVariantPrice;
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
price = (_d = product.priceRange) === null || _d === void 0 ? void 0 : _d.minVariantPrice;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
if (price == null) {
|
|
29
|
+
return null;
|
|
30
|
+
}
|
|
31
|
+
return (React.createElement(Money, { ...passthroughProps, money: price }, props.children));
|
|
32
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { ProductPrice } from './ProductPrice.client';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { ProductPrice } from './ProductPrice.client';
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import React, { useMemo } from 'react';
|
|
2
|
+
import { useProductOptions, useParsedMetafields } from '../../hooks';
|
|
3
|
+
import { flattenConnection } from '../../utilities';
|
|
4
|
+
import { ProductContext } from './context';
|
|
5
|
+
export function ProductProvider({ children, product, initialVariantId, }) {
|
|
6
|
+
const { variants, options, selectedVariant, setSelectedVariant, selectedOptions, setSelectedOption, setSelectedOptions, isOptionInStock, selectedSellingPlan, selectedSellingPlanAllocation, setSelectedSellingPlan, sellingPlanGroups, } = useProductOptions({
|
|
7
|
+
// TODO: Fix this type to not need `as any`
|
|
8
|
+
variants: product.variants,
|
|
9
|
+
initialVariantId: initialVariantId,
|
|
10
|
+
});
|
|
11
|
+
const metafields = useParsedMetafields(product.metafields);
|
|
12
|
+
const providerValue = useMemo(() => {
|
|
13
|
+
return {
|
|
14
|
+
...product,
|
|
15
|
+
metafields,
|
|
16
|
+
metafieldsConnection: product.metafields,
|
|
17
|
+
media: product.media ? flattenConnection(product.media) : undefined,
|
|
18
|
+
mediaConnection: product.media,
|
|
19
|
+
variants: variants,
|
|
20
|
+
variantsConnection: product.variants,
|
|
21
|
+
options,
|
|
22
|
+
selectedVariant,
|
|
23
|
+
setSelectedVariant,
|
|
24
|
+
selectedOptions,
|
|
25
|
+
setSelectedOption,
|
|
26
|
+
setSelectedOptions,
|
|
27
|
+
isOptionInStock,
|
|
28
|
+
selectedSellingPlan,
|
|
29
|
+
selectedSellingPlanAllocation,
|
|
30
|
+
setSelectedSellingPlan,
|
|
31
|
+
sellingPlanGroups,
|
|
32
|
+
};
|
|
33
|
+
}, [isOptionInStock, metafields, options, product, selectedOptions, selectedSellingPlan, selectedSellingPlanAllocation, selectedVariant, sellingPlanGroups, setSelectedOption, setSelectedOptions, setSelectedSellingPlan, setSelectedVariant, variants]);
|
|
34
|
+
return (React.createElement(ProductContext.Provider, { value: providerValue }, children));
|
|
35
|
+
}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import * as Types from '../../graphql/types/types';
|
|
2
|
+
import { MediaFileFragment_ExternalVideo_Fragment, MediaFileFragment_MediaImage_Fragment, MediaFileFragment_Model3d_Fragment, MediaFileFragment_Video_Fragment } from '../MediaFile/MediaFileFragment';
|
|
3
|
+
import { MetafieldFragmentFragment } from '../Metafield/MetafieldFragment';
|
|
4
|
+
export declare type ProductProviderFragmentFragment = {
|
|
5
|
+
__typename?: 'Product';
|
|
6
|
+
} & Pick<Types.Product, 'availableForSale' | 'createdAt' | 'description' | 'descriptionHtml' | 'handle' | 'id' | 'onlineStoreUrl' | 'productType' | 'publishedAt' | 'requiresSellingPlan' | 'tags' | 'title' | 'totalInventory' | 'updatedAt' | 'vendor'> & {
|
|
7
|
+
compareAtPriceRange: {
|
|
8
|
+
__typename?: 'ProductPriceRange';
|
|
9
|
+
} & {
|
|
10
|
+
maxVariantPrice: {
|
|
11
|
+
__typename?: 'MoneyV2';
|
|
12
|
+
} & Pick<Types.MoneyV2, 'currencyCode' | 'amount'>;
|
|
13
|
+
minVariantPrice: {
|
|
14
|
+
__typename?: 'MoneyV2';
|
|
15
|
+
} & Pick<Types.MoneyV2, 'currencyCode' | 'amount'>;
|
|
16
|
+
};
|
|
17
|
+
media: {
|
|
18
|
+
__typename?: 'MediaConnection';
|
|
19
|
+
} & {
|
|
20
|
+
edges: Array<{
|
|
21
|
+
__typename?: 'MediaEdge';
|
|
22
|
+
} & {
|
|
23
|
+
node: ({
|
|
24
|
+
__typename?: 'ExternalVideo';
|
|
25
|
+
} & MediaFileFragment_ExternalVideo_Fragment) | ({
|
|
26
|
+
__typename?: 'MediaImage';
|
|
27
|
+
} & MediaFileFragment_MediaImage_Fragment) | ({
|
|
28
|
+
__typename?: 'Model3d';
|
|
29
|
+
} & MediaFileFragment_Model3d_Fragment) | ({
|
|
30
|
+
__typename?: 'Video';
|
|
31
|
+
} & MediaFileFragment_Video_Fragment);
|
|
32
|
+
}>;
|
|
33
|
+
};
|
|
34
|
+
metafields: {
|
|
35
|
+
__typename?: 'MetafieldConnection';
|
|
36
|
+
} & {
|
|
37
|
+
edges: Array<{
|
|
38
|
+
__typename?: 'MetafieldEdge';
|
|
39
|
+
} & {
|
|
40
|
+
node: {
|
|
41
|
+
__typename?: 'Metafield';
|
|
42
|
+
} & MetafieldFragmentFragment;
|
|
43
|
+
}>;
|
|
44
|
+
};
|
|
45
|
+
priceRange: {
|
|
46
|
+
__typename?: 'ProductPriceRange';
|
|
47
|
+
} & {
|
|
48
|
+
maxVariantPrice: {
|
|
49
|
+
__typename?: 'MoneyV2';
|
|
50
|
+
} & Pick<Types.MoneyV2, 'currencyCode' | 'amount'>;
|
|
51
|
+
minVariantPrice: {
|
|
52
|
+
__typename?: 'MoneyV2';
|
|
53
|
+
} & Pick<Types.MoneyV2, 'currencyCode' | 'amount'>;
|
|
54
|
+
};
|
|
55
|
+
variants: {
|
|
56
|
+
__typename?: 'ProductVariantConnection';
|
|
57
|
+
} & {
|
|
58
|
+
edges: Array<{
|
|
59
|
+
__typename?: 'ProductVariantEdge';
|
|
60
|
+
} & {
|
|
61
|
+
node: {
|
|
62
|
+
__typename?: 'ProductVariant';
|
|
63
|
+
} & Pick<Types.ProductVariant, 'id' | 'title' | 'availableForSale'> & {
|
|
64
|
+
image?: Types.Maybe<{
|
|
65
|
+
__typename?: 'Image';
|
|
66
|
+
} & Pick<Types.Image, 'originalSrc' | 'altText' | 'id'>>;
|
|
67
|
+
unitPriceMeasurement?: Types.Maybe<{
|
|
68
|
+
__typename?: 'UnitPriceMeasurement';
|
|
69
|
+
} & Pick<Types.UnitPriceMeasurement, 'measuredType' | 'quantityUnit' | 'quantityValue' | 'referenceUnit' | 'referenceValue'>>;
|
|
70
|
+
unitPrice?: Types.Maybe<{
|
|
71
|
+
__typename?: 'MoneyV2';
|
|
72
|
+
} & Pick<Types.MoneyV2, 'amount' | 'currencyCode'>>;
|
|
73
|
+
priceV2: {
|
|
74
|
+
__typename?: 'MoneyV2';
|
|
75
|
+
} & Pick<Types.MoneyV2, 'amount' | 'currencyCode'>;
|
|
76
|
+
compareAtPriceV2?: Types.Maybe<{
|
|
77
|
+
__typename?: 'MoneyV2';
|
|
78
|
+
} & Pick<Types.MoneyV2, 'amount' | 'currencyCode'>>;
|
|
79
|
+
selectedOptions: Array<{
|
|
80
|
+
__typename?: 'SelectedOption';
|
|
81
|
+
} & Pick<Types.SelectedOption, 'name' | 'value'>>;
|
|
82
|
+
metafields: {
|
|
83
|
+
__typename?: 'MetafieldConnection';
|
|
84
|
+
} & {
|
|
85
|
+
edges: Array<{
|
|
86
|
+
__typename?: 'MetafieldEdge';
|
|
87
|
+
} & {
|
|
88
|
+
node: {
|
|
89
|
+
__typename?: 'Metafield';
|
|
90
|
+
} & MetafieldFragmentFragment;
|
|
91
|
+
}>;
|
|
92
|
+
};
|
|
93
|
+
};
|
|
94
|
+
}>;
|
|
95
|
+
};
|
|
96
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ProductOptionsHookValue } from '../../hooks';
|
|
2
|
+
import { ParsedMetafield } from '../../types';
|
|
3
|
+
import { ProductProviderFragmentFragment } from './ProductProviderFragment';
|
|
4
|
+
import { Product } from './types';
|
|
5
|
+
export declare const ProductContext: import("react").Context<ProductContextType | null>;
|
|
6
|
+
export declare type ProductContextType = Omit<Product, 'variants' | 'media' | 'metafields'> & Omit<ProductOptionsHookValue, 'variants'> & {
|
|
7
|
+
media?: ProductProviderFragmentFragment['media']['edges'][0]['node'][];
|
|
8
|
+
mediaConnection?: ProductProviderFragmentFragment['media'];
|
|
9
|
+
variants?: ProductProviderFragmentFragment['variants']['edges'][0]['node'][];
|
|
10
|
+
variantConnection?: ProductProviderFragmentFragment['variants'];
|
|
11
|
+
metafields?: ParsedMetafield[];
|
|
12
|
+
metafieldsConnection?: ProductProviderFragmentFragment['metafields'];
|
|
13
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function useProduct(): import("./context").ProductContextType | null;
|