import { useStore } from 'App/mstore'; import React from 'react'; import { CodeBlock } from 'UI'; import ToggleContent from 'Components//shared/ToggleContent'; import DocLink from 'Shared/DocLink/DocLink'; import { observer } from 'mobx-react-lite'; import { useTranslation } from 'react-i18next'; function ZustandDoc(props) { const { t } = useTranslation(); const { integrationsStore, projectsStore } = useStore(); const sites = projectsStore.list; const { siteId } = integrationsStore.integrations; const projectKey = siteId ? sites.find((site) => site.id === siteId)?.projectKey : sites[0]?.projectKey; const usage = `import create from "zustand"; import { tracker } from '@openreplay/tracker'; import trackerZustand, { StateLogger } from '@openreplay/tracker-zustand'; tracker.configure({ projectKey: ${projectKey}, }); // as per https://docs.pmnd.rs/zustand/guides/typescript#middleware-that-doesn't-change-the-store-type // cast type to new one // but this seems to not be required and everything is working as is const zustandPlugin = tracker.use(trackerZustand()) as unknown as StateLogger const useBearStore = create( zustandPlugin((set: any) => ({ bears: 0, increasePopulation: () => set((state: any) => ({ bears: state.bears + 1 })), removeAllBears: () => set({ bears: 0 }), }), // store name is optional // and is randomly generated if undefined 'bear_store' ) ) `; const usageCjs = `import create from "zustand"; import { tracker } from '@openreplay/tracker/cjs'; // alternatively you can use dynamic import without /cjs suffix to prevent issues with window scope import trackerZustand, { StateLogger } from '@openreplay/tracker-zustand/cjs'; tracker.configure({ projectKey: ${projectKey}, }); // as per https://docs.pmnd.rs/zustand/guides/typescript#middleware-that-doesn't-change-the-store-type // cast type to new one // but this seems to not be required and everything is working as is const zustandPlugin = tracker.use(trackerZustand()) as unknown as StateLogger const useBearStore = create( zustandPlugin((set: any) => ({ bears: 0, increasePopulation: () => set((state: any) => ({ bears: state.bears + 1 })), removeAllBears: () => set({ bears: 0 }), }), // store name is optional // and is randomly generated if undefined 'bear_store' ) )`; return (

{t('Zustand')}

{t( 'This plugin allows you to capture Zustand mutations/state and inspect them later on while replaying session recordings. This is very useful for understanding and fixing issues.', )}
{t('Installation')}
{t('Usage')}

{t( 'Initialize the @openreplay/tracker package as usual and load the plugin into it. Then put the generated plugin into your plugins field of your store.', )}

} second={} />
); } ZustandDoc.displayName = 'ZustandDoc'; export default observer(ZustandDoc);