Integração React
O ponto de entrada @converlay/sdk/react fornece um componente ConverlayProvider e um hook useConverlay() para aplicações React. Requer React 18 ou superior.
ConverlayProvider
Envolva sua aplicação com o provider para disponibilizar a instância do Converlay em toda a árvore de componentes.
ConverlayProvider props
<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()
Acesse a instância do Converlay a partir de qualquer componente filho.
useConverlay() hook
'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>
}O hook retorna a ConverlayInstance completa:
track(eventName, properties?)identify(data)setConsent(consent)flush()destroy()
Configuração por framework
Next.js App Router
Componente cliente obrigatório
O provider deve estar em um componente cliente ('use client'). Crie um componente Providers separado e importe-o no seu layout raiz.
Next.js App Router
// 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
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
Hydrogen (Remix)
// app/root.tsx
import { ConverlayProvider } from '@converlay/sdk/react'
export default function App() {
return (
<ConverlayProvider
shopDomain="my-store.myshopify.com"
autoPageView={true}
>
<Outlet />
</ConverlayProvider>
)
}Rastreamento de mudança de rota
Se autoPageView for true, o SDK dispara page_view uma vez ao montar. Para navegações no lado do cliente (SPA), adicione um rastreador de rotas:
Route tracker
'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
}