import {useEffect, useState} from 'react'; import {Client, ResponseMeta} from 'sentry/api'; import MemberListStore from 'sentry/stores/memberListStore'; import {Group, Organization, PageFilters} from 'sentry/types'; import getDynamicText from 'sentry/utils/getDynamicText'; import {IssuesConfig} from '../datasetConfig/issues'; import {DashboardFilters, Widget} from '../types'; import GenericWidgetQueries, { GenericWidgetQueriesChildrenProps, OnDataFetchedProps, } from './genericWidgetQueries'; type Props = { api: Client; children: (props: GenericWidgetQueriesChildrenProps) => JSX.Element; organization: Organization; selection: PageFilters; widget: Widget; cursor?: string; dashboardFilters?: DashboardFilters; limit?: number; onDataFetched?: (results: OnDataFetchedProps) => void; }; function IssueWidgetQueries({ children, api, organization, selection, widget, cursor, limit, dashboardFilters, onDataFetched, }: Props) { const [memberListStoreLoaded, setMemberListStoreLoaded] = useState(false); useEffect(() => { setMemberListStoreLoaded(!MemberListStore.state.loading); const unlistener = MemberListStore.listen(() => { setMemberListStoreLoaded(!MemberListStore.state.loading); }, undefined); return () => unlistener(); }, []); const config = IssuesConfig; const afterFetchTableData = (_rawResult: Group[], response?: ResponseMeta) => { return {totalIssuesCount: response?.getResponseHeader('X-Hits') ?? undefined}; }; return getDynamicText({ value: ( config={config} api={api} organization={organization} selection={selection} widget={widget} cursor={cursor} limit={limit} dashboardFilters={dashboardFilters} onDataFetched={onDataFetched} afterFetchTableData={afterFetchTableData} > {({loading, ...rest}) => children({ loading: loading || !memberListStoreLoaded, ...rest, }) } ), fixed:
, }); } export default IssueWidgetQueries;