1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- import type {Organization, User} from 'sentry/types';
- import type {TimelineEvent} from './useTraceTimelineEvents';
- function getEventTimestamp(start: number, event: TimelineEvent) {
- return new Date(event.timestamp).getTime() - start;
- }
- export function getEventsByColumn(
- durationMs: number,
- events: TimelineEvent[],
- totalColumns: number,
- start: number
- ) {
- const eventsByColumn = events.reduce((map, event) => {
- const columnPositionCalc =
- Math.floor((getEventTimestamp(start, event) / durationMs) * (totalColumns - 1)) + 1;
- // Should start at minimum in the first column
- const column = Math.max(1, columnPositionCalc);
- if (map.has(column)) {
- map.get(column)!.push(event);
- } else {
- map.set(column, [event]);
- }
- return map;
- }, new Map<number, TimelineEvent[]>());
- return eventsByColumn;
- }
- export function getChunkTimeRange(
- startTimestamp: number,
- chunkIndex: number,
- chunkDurationMs: number
- ): [number, number] {
- // Calculate the absolute start time of the chunk in milliseconds
- const chunkStartMs = chunkIndex * chunkDurationMs;
- // Add the chunk start time to the overall start timestamp
- const chunkStartTimestamp = startTimestamp + chunkStartMs;
- // Calculate the end timestamp by adding the chunk duration
- const chunkEndTimestamp = chunkStartTimestamp + chunkDurationMs;
- // Round up and down to the nearest second
- return [Math.floor(chunkStartTimestamp), Math.floor(chunkEndTimestamp) + 1];
- }
- export function hasTraceTimelineFeature(
- organization: Organization | null,
- user: User | undefined
- ) {
- const newIssueExperienceEnabled = user?.options?.issueDetailsNewExperienceQ42023;
- const hasFeature = organization?.features?.includes('issues-trace-timeline');
- return !!(newIssueExperienceEnabled && hasFeature);
- }
|