Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import {Fragment, useCallback, useEffect, useMemo, useRef, useState} from 'react';
import styled from '@emotion/styled';

import {openModal} from 'sentry/actionCreators/modal';
import {Button} from 'sentry/components/button';
import ButtonBar from 'sentry/components/buttonBar';
import EmptyStateWarning from 'sentry/components/emptyStateWarning';
Expand All @@ -11,10 +10,7 @@ import {
FeatureFlagDrawer,
} from 'sentry/components/events/featureFlags/featureFlagDrawer';
import FeatureFlagSort from 'sentry/components/events/featureFlags/featureFlagSort';
import {
modalCss,
SetupIntegrationModal,
} from 'sentry/components/events/featureFlags/setupIntegrationModal';
import {useFeatureFlagOnboarding} from 'sentry/components/events/featureFlags/useFeatureFlagOnboarding';
import {
FlagControlOptions,
OrderBy,
Expand Down Expand Up @@ -80,6 +76,7 @@ export function EventFeatureFlagList({
statsPeriod: eventView.statsPeriod,
},
});
const {activateSidebar} = useFeatureFlagOnboarding();

const {
suspectFlags,
Expand All @@ -95,13 +92,6 @@ export function EventFeatureFlagList({
const hasFlagContext = !!event.contexts.flags;
const hasFlags = Boolean(hasFlagContext && event?.contexts?.flags?.values.length);

function handleSetupButtonClick() {
trackAnalytics('flags.setup_modal_opened', {organization});
openModal(modalProps => <SetupIntegrationModal {...modalProps} />, {
modalCss,
});
}

const suspectFlagNames: Set<string> = useMemo(() => {
return isSuspectError || isSuspectPending
? new Set()
Expand Down Expand Up @@ -195,7 +185,7 @@ export function EventFeatureFlagList({
<Button
aria-label={t('Set Up Integration')}
size="xs"
onClick={handleSetupButtonClick}
onClick={activateSidebar}
>
{t('Set Up Integration')}
</Button>
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,119 @@
import {useMemo} from 'react';
import styled from '@emotion/styled';

import OnboardingIntegrationSection from 'sentry/components/events/featureFlags/onboardingIntegrationSection';
import {AuthTokenGeneratorProvider} from 'sentry/components/onboarding/gettingStartedDoc/authTokenGenerator';
import type {OnboardingLayoutProps} from 'sentry/components/onboarding/gettingStartedDoc/onboardingLayout';
import {Step} from 'sentry/components/onboarding/gettingStartedDoc/step';
import type {DocsParams} from 'sentry/components/onboarding/gettingStartedDoc/types';
import {useSourcePackageRegistries} from 'sentry/components/onboarding/gettingStartedDoc/useSourcePackageRegistries';
import {useUrlPlatformOptions} from 'sentry/components/onboarding/platformOptionsControl';
import ConfigStore from 'sentry/stores/configStore';
import {useLegacyStore} from 'sentry/stores/useLegacyStore';
import useApi from 'sentry/utils/useApi';
import useOrganization from 'sentry/utils/useOrganization';

interface FeatureFlagOnboardingLayoutProps extends OnboardingLayoutProps {
integration?: string;
provider?: string;
}

export function FeatureFlagOnboardingLayout({
docsConfig,
dsn,
platformKey,
projectId,
projectSlug,
projectKeyId,
configType = 'onboarding',
integration = '',
provider = '',
}: FeatureFlagOnboardingLayoutProps) {
const api = useApi();
const organization = useOrganization();
const {isPending: isLoadingRegistry, data: registryData} =
useSourcePackageRegistries(organization);
const selectedOptions = useUrlPlatformOptions(docsConfig.platformOptions);
const {isSelfHosted, urlPrefix} = useLegacyStore(ConfigStore);

const {steps} = useMemo(() => {
const doc = docsConfig[configType] ?? docsConfig.onboarding;

const docParams: DocsParams<any> = {
api,
projectKeyId,
dsn,
organization,
platformKey,
projectId,
projectSlug,
isFeedbackSelected: false,
isPerformanceSelected: false,
isProfilingSelected: false,
isReplaySelected: false,
sourcePackageRegistries: {
isLoading: isLoadingRegistry,
data: registryData,
},
platformOptions: selectedOptions,
isSelfHosted,
urlPrefix,
featureFlagOptions: {
integration,
},
};

return {
steps: [...doc.install(docParams), ...doc.configure(docParams)],
};
}, [
docsConfig,
dsn,
isLoadingRegistry,
organization,
platformKey,
projectId,
projectSlug,
registryData,
selectedOptions,
configType,
urlPrefix,
isSelfHosted,
api,
projectKeyId,
integration,
]);

return (
<AuthTokenGeneratorProvider projectSlug={projectSlug}>
<Wrapper>
<Steps>
{steps.map(step => (
<Step key={step.title ?? step.type} {...step} />
))}
</Steps>
<OnboardingIntegrationSection provider={provider} integration={integration} />
</Wrapper>
</AuthTokenGeneratorProvider>
);
}

const Steps = styled('div')`
display: flex;
flex-direction: column;
gap: 1.5rem;
`;

const Wrapper = styled('div')`
h4 {
margin-bottom: 0.5em;
}
&& {
p {
margin-bottom: 0;
}
h5 {
margin-bottom: 0;
}
}
`;
Loading
Loading