123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- import {useTheme} from '@emotion/react';
- import MarkLine from 'sentry/components/charts/components/markLine';
- import {t} from 'sentry/locale';
- import type {Group} from 'sentry/types/group';
- import {escape} from 'sentry/utils';
- import {getFormattedDate} from 'sentry/utils/dates';
- import {useApiQuery} from 'sentry/utils/queryClient';
- import {useNavigate} from 'sentry/utils/useNavigate';
- import useOrganization from 'sentry/utils/useOrganization';
- import {formatVersion} from 'sentry/utils/versions/formatVersion';
- import {useIssueDetailsEventView} from 'sentry/views/issueDetails/streamline/hooks/useIssueDetailsDiscoverQuery';
- interface ReleaseStat {
- date: string;
- version: string;
- }
- export function useReleaseMarkLineSeries({group}: {group: Group}) {
- const navigate = useNavigate();
- const theme = useTheme();
- const eventView = useIssueDetailsEventView({group});
- const organization = useOrganization();
- const {
- data: releases = [],
- isPending: isLoadingReleases,
- error: releasesError,
- } = useApiQuery<ReleaseStat[]>(
- [
- `/organizations/${organization.slug}/releases/stats/`,
- {
- query: {
- project: eventView.project,
- environment: eventView.environment,
- start: eventView.start,
- end: eventView.end,
- statsPeriod: eventView.statsPeriod,
- },
- },
- ],
- {
- staleTime: 0,
- }
- );
- if (isLoadingReleases || releasesError) {
- return {
- seriesName: t('Releases'),
- markLine: {},
- data: [],
- };
- }
- const markLine = MarkLine({
- animation: false,
- lineStyle: {
- color: theme.purple300,
- opacity: 0.3,
- type: 'solid',
- },
- label: {
- show: false,
- },
- data: releases.map(release => ({
- xAxis: +new Date(release.date),
- name: formatVersion(release.version, true),
- value: formatVersion(release.version, true),
- onClick: () => {
- navigate({
- pathname: `/organizations/${
- organization.slug
- }/releases/${encodeURIComponent(release.version)}/`,
- });
- },
- label: {
- formatter: () => formatVersion(release.version, true),
- },
- })),
- tooltip: {
- trigger: 'item',
- formatter: ({data}: any) => {
- const time = getFormattedDate(data.value, 'MMM D, YYYY LT', {
- local: !eventView.utc,
- });
- const version = escape(formatVersion(data.name, true));
- return [
- '<div class="tooltip-series">',
- `<div><span class="tooltip-label"><strong>${t(
- 'Release'
- )}</strong></span> ${version}</div>`,
- '</div>',
- '<div class="tooltip-footer">',
- time,
- '</div>',
- '<div class="tooltip-arrow"></div>',
- ].join('');
- },
- },
- });
- return {
- seriesName: t('Releases'),
- data: [],
- markLine,
- color: theme.purple200,
- type: 'line',
- };
- }
|