import styled from '@emotion/styled';
import beautify from 'js-beautify';
import Alert from 'sentry/components/alert';
import ExternalLink from 'sentry/components/links/externalLink';
import tracePropagationMessage from 'sentry/components/onboarding/gettingStartedDoc/replay/tracePropagationMessage';
import {StepType} from 'sentry/components/onboarding/gettingStartedDoc/step';
import type {
DocsParams,
OnboardingConfig,
} from 'sentry/components/onboarding/gettingStartedDoc/types';
import {
getReplayConfigureDescription,
getReplayJsLoaderSdkSetupSnippet,
} from 'sentry/components/onboarding/gettingStartedDoc/utils/replayOnboarding';
import {t, tct} from 'sentry/locale';
import {normalizeUrl} from 'sentry/utils/withDomainRequired';
type Params = DocsParams;
const getInstallConfig = (params: Params) => [
{
type: StepType.INSTALL,
configurations: [
{
description: t('Add this script tag to the top of the page:'),
language: 'html',
code: beautify.html(
``,
{indent_size: 2, wrap_attributes: 'force-expand-multiline'}
),
additionalInfo: (
{tct(
'Make sure that Session Replay is enabled in your [link:project settings].',
{
link: (
),
}
)}
),
},
],
},
];
const replayOnboardingJsLoader: OnboardingConfig = {
install: (params: Params) => getInstallConfig(params),
configure: (params: Params) => [
{
type: StepType.CONFIGURE,
description: getReplayConfigureDescription({
link: 'https://docs.sentry.io/platforms/javascript/session-replay/',
}),
configurations: [
{
language: 'html',
code: getReplayJsLoaderSdkSetupSnippet(params),
},
],
isOptional: true,
additionalInfo: tracePropagationMessage,
},
],
verify: () => [],
nextSteps: () => [],
};
const StyledAlert = styled(Alert)`
margin: 0;
`;
export default replayOnboardingJsLoader;