'use client' import { useRouter, useSearchParams } from 'next/navigation' import type { FC } from 'react' import { useCallback } from 'react' import { useState } from 'react' import { useTranslation } from 'react-i18next' import { Lock01 } from '@/app/components/base/icons/src/vender/solid/security' import Toast from '@/app/components/base/toast' import Button from '@/app/components/base/button' import { SSOProtocol } from '@/types/feature' import { fetchMembersOAuth2SSOUrl, fetchMembersOIDCSSOUrl, fetchMembersSAMLSSOUrl } from '@/service/share' type SSOAuthProps = { protocol: SSOProtocol | '' } const SSOAuth: FC = ({ protocol, }) => { const router = useRouter() const { t } = useTranslation() const searchParams = useSearchParams() const redirectUrl = searchParams.get('redirect_url') const getAppCodeFromRedirectUrl = useCallback(() => { if (!redirectUrl) return null const url = new URL(`${window.location.origin}${decodeURIComponent(redirectUrl)}`) const appCode = url.pathname.split('/').pop() if (!appCode) return null return appCode }, [redirectUrl]) const [isLoading, setIsLoading] = useState(false) const handleSSOLogin = () => { const appCode = getAppCodeFromRedirectUrl() if (!redirectUrl || !appCode) { Toast.notify({ type: 'error', message: 'invalid redirect URL or app code', }) return } setIsLoading(true) if (protocol === SSOProtocol.SAML) { fetchMembersSAMLSSOUrl(appCode, redirectUrl).then((res) => { router.push(res.url) }).finally(() => { setIsLoading(false) }) } else if (protocol === SSOProtocol.OIDC) { fetchMembersOIDCSSOUrl(appCode, redirectUrl).then((res) => { router.push(res.url) }).finally(() => { setIsLoading(false) }) } else if (protocol === SSOProtocol.OAuth2) { fetchMembersOAuth2SSOUrl(appCode, redirectUrl).then((res) => { router.push(res.url) }).finally(() => { setIsLoading(false) }) } else { Toast.notify({ type: 'error', message: 'invalid SSO protocol', }) setIsLoading(false) } } return ( ) } export default SSOAuth