import {Fragment} from 'react';
import ExternalLink from 'sentry/components/links/externalLink';
import List from 'sentry/components/list';
import ListItem from 'sentry/components/list/listItem';
import {StepType} from 'sentry/components/onboarding/gettingStartedDoc/step';
import {
Docs,
DocsParams,
OnboardingConfig,
} from 'sentry/components/onboarding/gettingStartedDoc/types';
import {
getReplayConfigureDescription,
getReplaySDKSetupSnippet,
} from 'sentry/components/onboarding/gettingStartedDoc/utils';
import {getJSMetricsOnboarding} from 'sentry/components/onboarding/gettingStartedDoc/utils/metricsOnboarding';
import {tracePropagationMessage} from 'sentry/components/replaysOnboarding/utils';
import {t, tct} from 'sentry/locale';
type Params = DocsParams;
const getInstallConfig = () => [
{
type: StepType.INSTALL,
configurations: [
{
description: tct(
'Configure your app automatically with the [wizardLink:Sentry wizard].',
{
wizardLink: (
),
}
),
language: 'bash',
code: `npx @sentry/wizard@latest -i remix`,
},
],
},
];
const onboarding: OnboardingConfig = {
introduction: () =>
tct("Sentry's integration with [remixLink:Remix] supports Remix 1.0.0 and above.", {
remixLink: ,
}),
install: () => getInstallConfig(),
configure: () => [
{
type: StepType.CONFIGURE,
description: t(
'The Sentry wizard will automatically add code to your project to inialize and configure the Sentry SDK:'
),
configurations: [
{
description: (
{tct(
"Create two files in the root directory of your project, [clientEntry:entry.client.tsx] and [serverEntry:entry.server.tsx] (if they don't already exist).",
{
clientEntry:
,
serverEntry:
,
}
)}
{tct(
'Add the default [sentryInitCode:Sentry.init] call to both, client and server entry files.',
{
sentryInitCode:
,
}
)}
{tct(
'Create a [cliRc:.sentryclirc] with an auth token to upload source maps (this file is automatically added to your [gitignore:.gitignore]).',
{
cliRc:
,
gitignore:
,
}
)}
{tct(
'Adjust your [buildscript:build] script in your [pkgJson:package.json] to automatically upload source maps to Sentry when you build your application.',
{
buildscript:
,
pkgJson:
,
}
)}
),
},
{
description: tct(
'You can also further [manualConfigure:configure your SDK] or [manualSetupLink:set it up manually], without the wizard.',
{
manualConfigure: (
),
manualSetupLink: (
),
}
),
},
],
},
],
verify: () => [],
nextSteps: () => [
{
id: 'performance-monitoring',
name: t('Performance Monitoring'),
description: t(
'Track down transactions to connect the dots between 10-second page loads and poor-performing API calls or slow database queries.'
),
link: 'https://docs.sentry.io/platforms/javascript/guides/remix/performance/',
},
{
id: 'session-replay',
name: t('Session Replay'),
description: t(
'Get to the root cause of an error or latency issue faster by seeing all the technical details related to that issue in one visual replay on your web application.'
),
link: 'https://docs.sentry.io/platforms/javascript/guides/remix/session-replay/',
},
],
};
const replayOnboarding: OnboardingConfig = {
install: () => getInstallConfig(),
configure: (params: Params) => [
{
type: StepType.CONFIGURE,
description: getReplayConfigureDescription({
link: 'https://docs.sentry.io/platforms/javascript/guides/remix/session-replay/',
}),
configurations: [
{
code: [
{
label: 'JavaScript',
value: 'javascript',
language: 'javascript',
code: getReplaySDKSetupSnippet({
importStatement: `import * as Sentry from "@sentry/remix";`,
dsn: params.dsn,
mask: params.replayOptions?.mask,
block: params.replayOptions?.block,
}),
},
],
},
],
additionalInfo: (
{tracePropagationMessage}
{tct(
'Note: The Replay integration only needs to be added to your [entryClient:entry.client.tsx] file. It will not run if it is added into [sentryServer:sentry.server.config.js].',
{entryClient:
, sentryServer:
}
)}
),
},
],
verify: () => [],
nextSteps: () => [],
};
const docs: Docs = {
onboarding,
replayOnboardingNpm: replayOnboarding,
customMetricsOnboarding: getJSMetricsOnboarding({getInstallConfig}),
};
export default docs;