ddm.tsx 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. import {useEffect} from 'react';
  2. import styled from '@emotion/styled';
  3. import FeatureBadge from 'sentry/components/featureBadge';
  4. import FeedbackWidget from 'sentry/components/feedback/widget/feedbackWidget';
  5. import * as Layout from 'sentry/components/layouts/thirds';
  6. import {DatePageFilter} from 'sentry/components/organizations/datePageFilter';
  7. import {EnvironmentPageFilter} from 'sentry/components/organizations/environmentPageFilter';
  8. import PageFilterBar from 'sentry/components/organizations/pageFilterBar';
  9. import PageFiltersContainer from 'sentry/components/organizations/pageFilters/container';
  10. import {ProjectPageFilter} from 'sentry/components/organizations/projectPageFilter';
  11. import {PageHeadingQuestionTooltip} from 'sentry/components/pageHeadingQuestionTooltip';
  12. import SentryDocumentTitle from 'sentry/components/sentryDocumentTitle';
  13. import {t} from 'sentry/locale';
  14. import {space} from 'sentry/styles/space';
  15. import {trackAnalytics} from 'sentry/utils/analytics';
  16. import useOrganization from 'sentry/utils/useOrganization';
  17. import {MetricScratchpad} from 'sentry/views/ddm/scratchpad';
  18. import {ScratchpadSelector} from 'sentry/views/ddm/scratchpadSelector';
  19. import {TraceTable} from 'sentry/views/ddm/traceTable';
  20. function DDM() {
  21. const organization = useOrganization();
  22. useEffect(() => {
  23. trackAnalytics('ddm.page-view', {
  24. organization,
  25. });
  26. // eslint-disable-next-line react-hooks/exhaustive-deps
  27. }, []);
  28. return (
  29. <SentryDocumentTitle title={t('DDM')} orgSlug={organization.slug}>
  30. <PageFiltersContainer disablePersistence>
  31. <Layout.Page>
  32. <Layout.Header>
  33. <Layout.HeaderContent>
  34. <Layout.Title>
  35. {t('DDM')}
  36. <PageHeadingQuestionTooltip
  37. docsUrl="https://docs.sentry.io"
  38. title={t('Delightful Developer Metrics.')}
  39. />
  40. <FeatureBadge type="alpha" />
  41. </Layout.Title>
  42. </Layout.HeaderContent>
  43. <Layout.HeaderActions />
  44. </Layout.Header>
  45. <Layout.Body>
  46. <FeedbackWidget />
  47. <Layout.Main fullWidth>
  48. <PaddedContainer>
  49. <PageFilterBar condensed>
  50. <ProjectPageFilter />
  51. <EnvironmentPageFilter />
  52. <DatePageFilter />
  53. </PageFilterBar>
  54. <ScratchpadSelector />
  55. </PaddedContainer>
  56. <MetricScratchpad />
  57. <TraceTable />
  58. </Layout.Main>
  59. </Layout.Body>
  60. </Layout.Page>
  61. </PageFiltersContainer>
  62. </SentryDocumentTitle>
  63. );
  64. }
  65. export const PaddedContainer = styled('div')`
  66. margin-bottom: ${space(2)};
  67. display: grid;
  68. grid-template: 1fr / 1fr max-content;
  69. gap: ${space(1)};
  70. @media (max-width: ${props => props.theme.breakpoints.small}) {
  71. grid-template: 1fr 1fr / 1fr;
  72. }
  73. `;
  74. export default DDM;