import { useStore } from 'App/mstore'; import React from 'react'; import { CodeBlock } from 'UI'; import ToggleContent from 'Shared/ToggleContent'; import DocLink from 'Shared/DocLink/DocLink'; import { observer } from 'mobx-react-lite'; import { useTranslation } from 'react-i18next'; function NgRxDoc() { 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 { StoreModule } from '@ngrx/store'; import { reducers } from './reducers'; import { tracker } from '@openreplay/tracker'; import trackerNgRx from '@openreplay/tracker-ngrx'; //... tracker.configure({ projectKey: '${projectKey}' }); tracker.start() //... const metaReducers = [tracker.use(trackerNgRx())]; // check list of available options below //... @NgModule({ imports: [StoreModule.forRoot(reducers, { metaReducers })] }) export class AppModule {}`; const usageCjs = `import { StoreModule } from '@ngrx/store'; import { reducers } from './reducers'; import { tracker } from '@openreplay/tracker/cjs'; // alternatively you can use dynamic import without /cjs suffix to prevent issues with window scope import trackerNgRx from '@openreplay/tracker-ngrx/cjs'; //... tracker.configure({ projectKey: '${projectKey}' }); //... function SomeFunctionalComponent() { useEffect(() => { // or componentDidMount in case of Class approach tracker.start() }, []) //... const metaReducers = [tracker.use(trackerNgRx())]; // check list of available options below //... @NgModule({ imports: [StoreModule.forRoot(reducers, { metaReducers })] }) export class AppModule {} }`; return (

{t('NgRx')}

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

{t( 'Add the generated meta-reducer into your imports. See NgRx documentation for more details.', )}

{t('Usage')}
} second={} />
); } NgRxDoc.displayName = 'NgRxDoc'; export default observer(NgRxDoc);