123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205 |
- import type {Client} from 'sentry/api';
- import {joinQuery, parseSearch, Token} from 'sentry/components/searchSyntax/parser';
- import {t} from 'sentry/locale';
- import GroupStore from 'sentry/stores/groupStore';
- import type {PageFilters} from 'sentry/types/core';
- import type {Group} from 'sentry/types/group';
- import type {Organization} from 'sentry/types/organization';
- import {getIssueFieldRenderer} from 'sentry/utils/dashboards/issueFieldRenderers';
- import {getUtcDateString} from 'sentry/utils/dates';
- import type {TableData, TableDataRow} from 'sentry/utils/discover/discoverQuery';
- import type {OnDemandControlContext} from 'sentry/utils/performance/contexts/onDemandControl';
- import {
- DISCOVER_EXCLUSION_FIELDS,
- getSortLabel,
- IssueSortOptions,
- } from 'sentry/views/issueList/utils';
- import type {Widget, WidgetQuery} from '../types';
- import {DEFAULT_TABLE_LIMIT, DisplayType} from '../types';
- import {IssuesSearchBar} from '../widgetBuilder/buildSteps/filterResultsStep/issuesSearchBar';
- import {ISSUE_FIELD_TO_HEADER_MAP} from '../widgetBuilder/issueWidget/fields';
- import {generateIssueWidgetFieldOptions} from '../widgetBuilder/issueWidget/utils';
- import type {DatasetConfig} from './base';
- const DEFAULT_WIDGET_QUERY: WidgetQuery = {
- name: '',
- fields: ['issue', 'assignee', 'title'] as string[],
- columns: ['issue', 'assignee', 'title'],
- fieldAliases: [],
- aggregates: [],
- conditions: '',
- orderby: IssueSortOptions.DATE,
- };
- const DEFAULT_SORT = IssueSortOptions.DATE;
- const DEFAULT_EXPAND = ['owners'];
- type EndpointParams = Partial<PageFilters['datetime']> & {
- environment: string[];
- project: number[];
- collapse?: string[];
- cursor?: string;
- expand?: string[];
- groupStatsPeriod?: string | null;
- limit?: number;
- page?: number | string;
- query?: string;
- sort?: string;
- statsPeriod?: string | null;
- };
- export const IssuesConfig: DatasetConfig<never, Group[]> = {
- defaultWidgetQuery: DEFAULT_WIDGET_QUERY,
- enableEquations: false,
- disableSortOptions,
- getTableRequest,
- getCustomFieldRenderer: getIssueFieldRenderer,
- SearchBar: IssuesSearchBar,
- getTableSortOptions,
- getTableFieldOptions: (_organization: Organization) =>
- generateIssueWidgetFieldOptions(),
- getFieldHeaderMap: () => ISSUE_FIELD_TO_HEADER_MAP,
- supportedDisplayTypes: [DisplayType.TABLE],
- transformTable: transformIssuesResponseToTable,
- };
- function disableSortOptions(_widgetQuery: WidgetQuery) {
- return {
- disableSort: false,
- disableSortDirection: true,
- disableSortReason: t('Issues dataset does not yet support descending order'),
- };
- }
- function getTableSortOptions(_organization: Organization, _widgetQuery: WidgetQuery) {
- const sortOptions = [
- IssueSortOptions.DATE,
- IssueSortOptions.NEW,
- IssueSortOptions.TRENDS,
- IssueSortOptions.FREQ,
- IssueSortOptions.USER,
- ];
- return sortOptions.map(sortOption => ({
- label: getSortLabel(sortOption),
- value: sortOption,
- }));
- }
- export function transformIssuesResponseToTable(
- data: Group[],
- widgetQuery: WidgetQuery,
- _organization: Organization,
- pageFilters: PageFilters
- ): TableData {
- GroupStore.add(data);
- const transformedTableResults: TableDataRow[] = [];
- data.forEach(
- ({
- id,
- shortId,
- title,
- lifetime,
- filtered,
- count,
- userCount,
- project,
- annotations,
- ...resultProps
- }) => {
- const transformedResultProps: Omit<TableDataRow, 'id'> = {};
- Object.keys(resultProps)
- .filter(key => ['number', 'string'].includes(typeof resultProps[key]))
- .forEach(key => {
- transformedResultProps[key] = resultProps[key];
- });
- const transformedTableResult: TableDataRow = {
- ...transformedResultProps,
- events: count,
- users: userCount,
- id,
- 'issue.id': id,
- issue: shortId,
- title,
- project: project.slug,
- links: (annotations ?? []) as any,
- };
- // Get lifetime stats
- if (lifetime) {
- transformedTableResult.lifetimeEvents = lifetime?.count;
- transformedTableResult.lifetimeUsers = lifetime?.userCount;
- }
- // Get filtered stats
- if (filtered) {
- transformedTableResult.filteredEvents = filtered?.count;
- transformedTableResult.filteredUsers = filtered?.userCount;
- }
- // Discover Url properties
- const query = widgetQuery.conditions;
- const parsedResult = parseSearch(query);
- const filteredTerms = parsedResult?.filter(
- p => !(p.type === Token.FILTER && DISCOVER_EXCLUSION_FIELDS.includes(p.key.text))
- );
- transformedTableResult.discoverSearchQuery = joinQuery(filteredTerms, true);
- transformedTableResult.projectId = project.id;
- const {period, start, end} = pageFilters.datetime || {};
- if (start && end) {
- transformedTableResult.start = getUtcDateString(start);
- transformedTableResult.end = getUtcDateString(end);
- }
- transformedTableResult.period = period ?? '';
- transformedTableResults.push(transformedTableResult);
- }
- );
- return {data: transformedTableResults} as TableData;
- }
- function getTableRequest(
- api: Client,
- _: Widget,
- query: WidgetQuery,
- organization: Organization,
- pageFilters: PageFilters,
- __?: OnDemandControlContext,
- limit?: number,
- cursor?: string
- ) {
- const groupListUrl = `/organizations/${organization.slug}/issues/`;
- const params: EndpointParams = {
- project: pageFilters.projects ?? [],
- environment: pageFilters.environments ?? [],
- query: query.conditions,
- sort: query.orderby || DEFAULT_SORT,
- expand: DEFAULT_EXPAND,
- limit: limit ?? DEFAULT_TABLE_LIMIT,
- cursor,
- };
- if (pageFilters.datetime.period) {
- params.statsPeriod = pageFilters.datetime.period;
- }
- if (pageFilters.datetime.end) {
- params.end = getUtcDateString(pageFilters.datetime.end);
- }
- if (pageFilters.datetime.start) {
- params.start = getUtcDateString(pageFilters.datetime.start);
- }
- if (pageFilters.datetime.utc) {
- params.utc = pageFilters.datetime.utc;
- }
- return api.requestPromise(groupListUrl, {
- includeAllArgs: true,
- method: 'GET',
- data: {
- ...params,
- },
- });
- }
|