import ExternalLink from 'sentry/components/links/externalLink'; import {Layout, LayoutProps} from 'sentry/components/onboarding/gettingStartedDoc/layout'; import {ModuleProps} from 'sentry/components/onboarding/gettingStartedDoc/sdkDocumentation'; import {StepType} from 'sentry/components/onboarding/gettingStartedDoc/step'; import {tct} from 'sentry/locale'; import type {Organization, PlatformKey} from 'sentry/types'; type StepProps = { newOrg: boolean; organization: Organization; platformKey: PlatformKey; projectId: string; sentryInitContent: string; }; // Configuration Start const replayIntegration = ` new Sentry.Replay(), `; const replayOtherConfig = ` // This sets the sample rate to be 10%. You may want this to be 100% while // in development and sample at a lower rate in production. replaysSessionSampleRate: 0.1, // If the entire session is not sampled, use the below sample rate to sample // sessions when an error occurs. replaysOnErrorSampleRate: 1.0, `; export const steps = ({ sentryInitContent, }: Partial = {}): LayoutProps['steps'] => [ { type: StepType.INSTALL, description: tct( 'For the Session Replay to work, you must have the Sentry browser SDK package, or an equivalent framework SDK (e.g. [code:@sentry/react]) installed, minimum version 7.27.0.', {code: } ), configurations: [ { language: 'bash', code: [ { label: 'npm', value: 'npm', language: 'bash', code: 'npm install --save @sentry/browser', }, { label: 'yarn', value: 'yarn', language: 'bash', code: 'yarn add @sentry/browser', }, ], }, ], }, { type: StepType.CONFIGURE, description: tct( 'Add the following to your SDK config. There are several privacy and sampling options available, all of which can be set using the [code:integrations] constructor. Learn more about configuring Session Replay by reading the [link:configuration docs].', { code: , link: ( ), } ), configurations: [ { language: 'javascript', code: ` import * as Sentry from "@sentry/browser"; Sentry.init({ ${sentryInitContent} }); `, }, ], }, ]; // Configuration End export function GettingStartedWithJavaScriptReplay({ dsn, organization, newOrg, platformKey, projectId, ...props }: ModuleProps) { const integrations = replayIntegration.trim(); const otherConfigs = replayOtherConfig.trim(); let sentryInitContent: string[] = [`dsn: "${dsn}",`]; sentryInitContent = sentryInitContent.concat('integrations: [', integrations, '],'); sentryInitContent = sentryInitContent.concat(otherConfigs); return ( ); } export default GettingStartedWithJavaScriptReplay;