diff --git a/apps/app/components/integration/slack/select-channel.tsx b/apps/app/components/integration/slack/select-channel.tsx index 621245dc8..c116992a8 100644 --- a/apps/app/components/integration/slack/select-channel.tsx +++ b/apps/app/components/integration/slack/select-channel.tsx @@ -5,14 +5,13 @@ import { useRouter } from "next/router"; import useSWR, { mutate } from "swr"; // services import appinstallationsService from "services/app-installations.service"; - // ui import { Loader } from "components/ui"; // hooks import useToast from "hooks/use-toast"; import useIntegrationPopup from "hooks/use-integration-popup"; // types -import { IWorkspaceIntegration } from "types"; +import { IWorkspaceIntegration, ISlackIntegration } from "types"; // fetch-keys import { SLACK_CHANNEL_INFO } from "constants/fetch-keys"; @@ -21,7 +20,9 @@ type Props = { }; export const SelectChannel: React.FC = ({ integration }) => { - const [deletingProjectSync, setDeletingProjectSync] = useState(false); + const [slackChannelAvailabilityToggle, setSlackChannelAvailabilityToggle] = + useState(false); + const [slackChannel, setSlackChannel] = useState(null); const router = useRouter(); const { workspaceSlug, projectId } = router.query; @@ -43,33 +44,38 @@ export const SelectChannel: React.FC = ({ integration }) => { ); useEffect(() => { - if (projectIntegration?.length > 0) { - setDeletingProjectSync(true); + if (projectId && projectIntegration && projectIntegration.length > 0) { + const projectSlackIntegrationCheck: ISlackIntegration | undefined = projectIntegration.find( + (_slack: ISlackIntegration) => _slack.project === projectId + ); + if (projectSlackIntegrationCheck) { + setSlackChannel(() => projectSlackIntegrationCheck); + setSlackChannelAvailabilityToggle(true); + } } - if (projectIntegration?.length === 0) { - setDeletingProjectSync(false); - } - }, [projectIntegration]); + }, [projectIntegration, projectId]); const handleDelete = async () => { if (projectIntegration.length === 0) return; mutate(SLACK_CHANNEL_INFO, (prevData: any) => { if (!prevData) return; return prevData.id !== integration.id; - }).then(() => setDeletingProjectSync(false)); + }).then(() => { + setSlackChannelAvailabilityToggle(false); + setSlackChannel(null); + }); appinstallationsService .removeSlackChannel( workspaceSlug as string, projectId as string, integration.id as string, - projectIntegration?.[0]?.id + slackChannel?.id ) .catch((err) => console.log(err)); }; const handleAuth = async () => { await startAuth(); - setDeletingProjectSync(true); }; return ( @@ -78,20 +84,18 @@ export const SelectChannel: React.FC = ({ integration }) => { diff --git a/apps/app/types/integration.d.ts b/apps/app/types/integration.d.ts index b499d743f..bb76f9fc0 100644 --- a/apps/app/types/integration.d.ts +++ b/apps/app/types/integration.d.ts @@ -33,3 +33,44 @@ export interface IWorkspaceIntegration { updated_by: string; workspace: string; } + +// slack integration +export interface ISlackIntegration { + id: string; + created_at: string; + updated_at: string; + access_token: string; + scopes: string; + bot_user_id: string; + webhook_url: string; + data: ISlackIntegrationData; + team_id: string; + team_name: string; + created_by: string; + updated_by: string; + project: string; + workspace: string; + workspace_integration: string; +} + +export interface ISlackIntegrationData { + ok: boolean; + team: { + id: string; + name: string; + }; + scope: string; + app_id: string; + enterprise: any; + token_type: string; + authed_user: string; + bot_user_id: string; + access_token: string; + incoming_webhook: { + url: string; + channel: string; + channel_id: string; + configuration_url: string; + }; + is_enterprise_install: boolean; +}