63 lines
2.4 KiB
TypeScript
63 lines
2.4 KiB
TypeScript
|
|
'use client'
|
||
|
|
import { useRouter, useSearchParams } from 'next/navigation'
|
||
|
|
import type { FC } from 'react'
|
||
|
|
import React, { useCallback } from 'react'
|
||
|
|
import { useTranslation } from 'react-i18next'
|
||
|
|
import { useGlobalPublicStore } from '@/context/global-public-context'
|
||
|
|
import AppUnavailable from '@/app/components/base/app-unavailable'
|
||
|
|
import NormalForm from './normalForm'
|
||
|
|
import { AccessMode } from '@/models/access-control'
|
||
|
|
import ExternalMemberSsoAuth from './components/external-member-sso-auth'
|
||
|
|
import { useWebAppStore } from '@/context/web-app-context'
|
||
|
|
import { webAppLogout } from '@/service/webapp-auth'
|
||
|
|
|
||
|
|
const WebSSOForm: FC = () => {
|
||
|
|
const { t } = useTranslation()
|
||
|
|
const systemFeatures = useGlobalPublicStore(s => s.systemFeatures)
|
||
|
|
const webAppAccessMode = useWebAppStore(s => s.webAppAccessMode)
|
||
|
|
const searchParams = useSearchParams()
|
||
|
|
const router = useRouter()
|
||
|
|
|
||
|
|
const redirectUrl = searchParams.get('redirect_url')
|
||
|
|
|
||
|
|
const getSigninUrl = useCallback(() => {
|
||
|
|
const params = new URLSearchParams()
|
||
|
|
params.append('redirect_url', redirectUrl || '')
|
||
|
|
return `/webapp-signin?${params.toString()}`
|
||
|
|
}, [redirectUrl])
|
||
|
|
|
||
|
|
const shareCode = useWebAppStore(s => s.shareCode)
|
||
|
|
const backToHome = useCallback(async () => {
|
||
|
|
await webAppLogout(shareCode!)
|
||
|
|
const url = getSigninUrl()
|
||
|
|
router.replace(url)
|
||
|
|
}, [getSigninUrl, router, webAppLogout, shareCode])
|
||
|
|
|
||
|
|
if (!redirectUrl) {
|
||
|
|
return <div className='flex h-full items-center justify-center'>
|
||
|
|
<AppUnavailable code={t('share.common.appUnavailable')} unknownReason='redirect url is invalid.' />
|
||
|
|
</div>
|
||
|
|
}
|
||
|
|
|
||
|
|
if (!systemFeatures.webapp_auth.enabled) {
|
||
|
|
return <div className="flex h-full items-center justify-center">
|
||
|
|
<p className='system-xs-regular text-text-tertiary'>{t('login.webapp.disabled')}</p>
|
||
|
|
</div>
|
||
|
|
}
|
||
|
|
if (webAppAccessMode && (webAppAccessMode === AccessMode.ORGANIZATION || webAppAccessMode === AccessMode.SPECIFIC_GROUPS_MEMBERS)) {
|
||
|
|
return <div className='w-full max-w-[400px]'>
|
||
|
|
<NormalForm />
|
||
|
|
</div>
|
||
|
|
}
|
||
|
|
|
||
|
|
if (webAppAccessMode && webAppAccessMode === AccessMode.EXTERNAL_MEMBERS)
|
||
|
|
return <ExternalMemberSsoAuth />
|
||
|
|
|
||
|
|
return <div className='flex h-full flex-col items-center justify-center gap-y-4'>
|
||
|
|
<AppUnavailable className='h-auto w-auto' isUnknownReason={true} />
|
||
|
|
<span className='system-sm-regular cursor-pointer text-text-tertiary' onClick={backToHome}>{t('share.login.backToHome')}</span>
|
||
|
|
</div>
|
||
|
|
}
|
||
|
|
|
||
|
|
export default React.memo(WebSSOForm)
|