import {useCallback, useEffect, useState} from 'react'; import {promptsCheck, promptsUpdate} from 'sentry/actionCreators/prompts'; import {Organization} from 'sentry/types'; import {promptIsDismissed} from 'sentry/utils/promptIsDismissed'; import useApi from 'sentry/utils/useApi'; type Opts = { feature: string; organization: Organization; projectId: string; }; function usePromptCheck({feature, organization, projectId}: Opts) { const api = useApi(); const [shouldShowPrompt, setShouldShow] = useState(null); useEffect(() => { promptsCheck(api, { organizationId: organization.id, projectId, feature, }).then(data => { setShouldShow(!promptIsDismissed(data ?? {}, 30)); }); }, [api, feature, organization, projectId]); const snoozePrompt = useCallback(async () => { const data = { projectId, organizationId: organization.id, feature, status: 'snoozed' as const, }; await promptsUpdate(api, data); setShouldShow(false); }, [api, feature, organization, projectId]); return { shouldShowPrompt, snoozePrompt, }; } export default usePromptCheck;