import React from 'react'; import Highlight from 'react-highlight'; import ToggleContent from '../../../shared/ToggleContent'; import DocLink from 'Shared/DocLink/DocLink'; import { connect } from 'react-redux'; const ZustandDoc = (props) => { const { projectKey } = props; return (

Zustand

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.
Installation
{`npm i @openreplay/tracker-zustand --save`}
Usage

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.

{`import create from "zustand"; import Tracker from '@openreplay/tracker'; import trackerZustand from '@openreplay/tracker-zustand'; const tracker = new Tracker({ projectKey: ${projectKey}, }); const zustandPlugin = tracker.use(trackerZustand()) // store name, optional // randomly generated if undefined const bearStoreLogger = zustandPlugin('bear_store') const useBearStore = create( bearStoreLogger((set: any) => ({ bears: 0, increasePopulation: () => set((state: any) => ({ bears: state.bears + 1 })), removeAllBears: () => set({ bears: 0 }), })) )`} } second={ {`import create from "zustand"; import Tracker from '@openreplay/tracker/cjs'; import trackerZustand from '@openreplay/tracker-zustand/cjs'; const tracker = new Tracker({ projectKey: ${projectKey}, }); const zustandPlugin = tracker.use(trackerZustand()) // store name, optional // randomly generated if undefined const bearStoreLogger = zustandPlugin('bear_store') const useBearStore = create( bearStoreLogger((set: any) => ({ bears: 0, increasePopulation: () => set((state: any) => ({ bears: state.bears + 1 })), removeAllBears: () => set({ bears: 0 }), })) )`} } />
); }; ZustandDoc.displayName = 'ZustandDoc'; export default connect((state) => { const siteId = state.getIn(['integrations', 'siteId']); const sites = state.getIn(['site', 'list']); return { projectKey: sites.find((site) => site.get('id') === siteId).get('projectKey'), }; })(ZustandDoc);