React-Integration
Der Einstiegspunkt @converlay/sdk/react bietet eine ConverlayProvider-Komponente und einen useConverlay()-Hook für React-Anwendungen. Erfordert React 18 oder höher.
ConverlayProvider
Umschließen Sie Ihre Anwendung mit dem Provider, um die Converlay-Instanz im gesamten Komponentenbaum verfügbar zu machen.
<ConverlayProvider
shopDomain="my-store.myshopify.com" // Required
autoPageView={true} // Auto page_view on mount
debug={false} // Console logging
endpoint="..." // Custom endpoint
consent={{ analytics: true, marketing: true }}
>
{children}
</ConverlayProvider>useConverlay()
Greifen Sie von jeder untergeordneten Komponente auf die Converlay-Instanz zu.
'use client'
import { useConverlay } from '@converlay/sdk/react'
function ProductPage({ product }) {
const { track, identify, setConsent, flush, destroy } = useConverlay()
useEffect(() => {
track('view_item', {
ecommerce: {
items: [{
item_id: product.id,
item_name: product.title,
price: product.price,
quantity: 1,
}],
},
})
}, [product.id])
return <div>{/* ... */}</div>
}Der Hook gibt die vollständige ConverlayInstance zurück:
track(eventName, properties?)identify(data)setConsent(consent)flush()destroy()
Framework-Setup
Next.js App Router
Client-Komponente erforderlich
Der Provider muss in einer Client-Komponente sein ('use client'). Erstellen Sie eine separate Providers-Komponente und importieren Sie diese in Ihr Root-Layout.
// app/providers.tsx
'use client'
import { ConverlayProvider } from '@converlay/sdk/react'
export function Providers({ children }: { children: React.ReactNode }) {
return (
<ConverlayProvider
shopDomain="my-store.myshopify.com"
autoPageView={true}
>
{children}
</ConverlayProvider>
)
}
// app/layout.tsx
import { Providers } from './providers'
export default function RootLayout({ children }) {
return (
<html>
<body>
<Providers>{children}</Providers>
</body>
</html>
)
}Next.js Pages Router
// pages/_app.tsx
import { ConverlayProvider } from '@converlay/sdk/react'
export default function App({ Component, pageProps }) {
return (
<ConverlayProvider
shopDomain="my-store.myshopify.com"
autoPageView={true}
>
<Component {...pageProps} />
</ConverlayProvider>
)
}Shopify Hydrogen
// app/root.tsx
import { ConverlayProvider } from '@converlay/sdk/react'
export default function App() {
return (
<ConverlayProvider
shopDomain="my-store.myshopify.com"
autoPageView={true}
>
<Outlet />
</ConverlayProvider>
)
}Routenwechsel-Tracking
Wenn autoPageView auf true gesetzt ist, löst das SDK beim Mounten einmal page_view aus. Für clientseitige Navigationen (SPA) fügen Sie einen Route-Tracker hinzu:
'use client'
import { usePathname } from 'next/navigation'
import { useConverlay } from '@converlay/sdk/react'
import { useEffect } from 'react'
export function RouteTracker() {
const pathname = usePathname()
const { track } = useConverlay()
useEffect(() => {
track('page_view')
}, [pathname])
return null
}