Analytics. Provider
Provides a context for tracking page views and cart events to send as analytics data to Shopify. This component is integrated with the Customer Privacy API for consent management. The provider can also be used to connect third-party analytics services through its subscribe and publish system. The hook provides access to the analytics provider context.
You can also listen to a document event for . It will be emitted when the Customer Privacy API is loaded.
Anchor to propsProps
- Anchor to cartcartcartPromise<CartReturn | null> | CartReturn | nullPromise<CartReturn | null> | CartReturn | nullrequiredrequired
The cart or cart promise to track for cart analytics. When there is a difference between the state of the cart,
will trigger aevent. It will also produceandbased on cart line quantity and cart line id changes.- Anchor to consentconsentconsentConsentConsentrequiredrequired
The customer privacy consent configuration and options.
- Anchor to shopshopshopPromise<ShopAnalytics | null> | ShopAnalytics | nullPromise<ShopAnalytics | null> | ShopAnalytics | nullrequiredrequired
- Anchor to canTrackcanTrackcanTrack() => boolean() => boolean
An optional function to set wether the user can be tracked. Defaults to Customer Privacy API's
.- Anchor to childrenchildrenchildrenReactNodeReactNode
React children to render.
- stringstring
The domain scope of the cookie set with
. *- Anchor to customDatacustomDatacustomDataRecord<string, unknown>Record<string, unknown>
An optional custom payload to pass to all events. e.g language/locale/currency.
- Anchor to disableThrowOnErrordisableThrowOnErrordisableThrowOnErrorbooleanbooleandeprecateddeprecated
- Deprecated
Disable throwing errors when required props are missing.
Deprecated:Disable throwing errors when required props are missing.
CartReturn
Cart & {
errors?: StorefrontApiErrors;
}Cart
StorefrontApiErrors
JsonGraphQLError[] | undefinedJsonGraphQLError
Consent
Partial<
Pick<
CustomerPrivacyApiProps,
| 'checkoutDomain'
| 'sameDomainForStorefrontApi'
| 'storefrontAccessToken'
| 'withPrivacyBanner'
| 'country'
>
> & {language?: LanguageCode}CustomerPrivacyApiProps
- checkoutDomain
The production shop checkout domain url.
string - country
Country code for the shop.
CountryCode - locale
Language code for the shop.
LanguageCode - onReady
Callback to be call when customer privacy api is ready.
() => void - onVisitorConsentCollected
Callback to be called when visitor consent is collected.
(consent: VisitorConsentCollected) => void - sameDomainForStorefrontApi
Whether consent libraries can use same-domain requests to the Storefront API. Defaults to true if the standard route proxy is enabled in Hydrogen server.
boolean - storefrontAccessToken
The storefront access token for the shop.
string - withPrivacyBanner
Whether to load the Shopify privacy banner as configured in Shopify admin. Defaults to true.
boolean
VisitorConsentCollected
- analyticsAllowed
boolean - firstPartyMarketingAllowed
boolean - marketingAllowed
boolean - preferencesAllowed
boolean - saleOfDataAllowed
boolean - thirdPartyMarketingAllowed
boolean
ShopAnalytics
- acceptedLanguage
The language code that is being displayed to user.
LanguageCode - currency
The currency code that is being displayed to user.
CurrencyCode - hydrogenSubchannelId
The Hydrogen subchannel ID generated by Oxygen in the environment variable.
string | '0' - shopId
The shop ID.
string
Examples
example
Description
This is the default example
JavaScript
import {Analytics, getShopAnalytics} from '@shopify/hydrogen'; import {Outlet, useLoaderData} from 'react-router'; export async function loader({context}) { const {cart, env} = context; const cartPromise = cart.get(); return { cart: cartPromise, shop: getShopAnalytics(context), consent: { checkoutDomain: env.PUBLIC_CHECKOUT_DOMAIN, storefrontAccessToken: env.PUBLIC_STOREFRONT_API_TOKEN, withPrivacyBanner: true, // false stops the privacy banner from being displayed // localize the privacy banner country: context.storefront.i18n.country, language: context.storefront.i18n.language, }, }; } export default function App() { const data = useLoaderData(); return ( <html lang="en"> <head> <meta charSet="utf-8" /> <meta name="viewport" content="width=device-width,initial-scale=1" /> </head> <body> <Analytics.Provider cart={data.cart} shop={data.shop} consent={data.consent} > <Outlet /> </Analytics.Provider> </body> </html> ); }TypeScript
import {Analytics, getShopAnalytics} from '@shopify/hydrogen'; import {type LoaderFunctionArgs} from 'react-router'; import {Outlet, useLoaderData} from 'react-router'; export async function loader({context}: LoaderFunctionArgs) { const {cart, env} = context; const cartPromise = cart.get(); return { cart: cartPromise, shop: getShopAnalytics({ storefront: context.storefront, publicStorefrontId: env.PUBLIC_STOREFRONT_ID, }), consent: { checkoutDomain: env.PUBLIC_CHECKOUT_DOMAIN, storefrontAccessToken: env.PUBLIC_STOREFRONT_API_TOKEN, withPrivacyBanner: true, // false stops the privacy banner from being displayed // localize the privacy banner country: context.storefront.i18n.country, language: context.storefront.i18n.language, }, }; } export default function App() { const data = useLoaderData<typeof loader>(); return ( <html lang="en"> <head> <meta charSet="utf-8" /> <meta name="viewport" content="width=device-width,initial-scale=1" /> </head> <body> <Analytics.Provider cart={data.cart} shop={data.shop} consent={data.consent} > <Outlet /> </Analytics.Provider> </body> </html> ); }