123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- import {navigateTo} from 'sentry/actionCreators/navigation';
- import Feature from 'sentry/components/acl/feature';
- import {Button} from 'sentry/components/button';
- import ButtonBar from 'sentry/components/buttonBar';
- import FeatureTourModal from 'sentry/components/modals/featureTourModal';
- import {t} from 'sentry/locale';
- import type {Organization} from 'sentry/types/organization';
- import {trackAnalytics} from 'sentry/utils/analytics';
- import useRouter from 'sentry/utils/useRouter';
- import {PERFORMANCE_TOUR_STEPS} from 'sentry/views/performance/onboarding';
- import {getPerformanceBaseUrl} from 'sentry/views/performance/utils';
- const DOCS_URL = 'https://docs.sentry.io/performance-monitoring/getting-started/';
- type Props = {
- organization: Organization;
- };
- function MissingPerformanceButtons({organization}: Props) {
- const router = useRouter();
- function handleTourAdvance(step: number, duration: number) {
- trackAnalytics('project_detail.performance_tour.advance', {
- organization,
- step,
- duration,
- });
- }
- function handleClose(step: number, duration: number) {
- trackAnalytics('project_detail.performance_tour.close', {
- organization,
- step,
- duration,
- });
- }
- return (
- <Feature
- hookName="feature-disabled:project-performance-score-card"
- features="performance-view"
- organization={organization}
- >
- <ButtonBar gap={1}>
- <Button
- size="sm"
- priority="primary"
- onClick={event => {
- event.preventDefault();
- // TODO: add analytics here for this specific action.
- navigateTo(
- `${getPerformanceBaseUrl(organization.slug)}/?project=:project#performance-sidequest`,
- router
- );
- }}
- >
- {t('Start Setup')}
- </Button>
- <FeatureTourModal
- steps={PERFORMANCE_TOUR_STEPS}
- onAdvance={handleTourAdvance}
- onCloseModal={handleClose}
- doneText={t('Start Setup')}
- doneUrl={DOCS_URL}
- >
- {({showModal}) => (
- <Button size="sm" onClick={showModal}>
- {t('Get Tour')}
- </Button>
- )}
- </FeatureTourModal>
- </ButtonBar>
- </Feature>
- );
- }
- export default MissingPerformanceButtons;
|