mirror of
https://github.com/IT4Change/ohmyform-ui.git
synced 2025-12-13 09:45:50 +00:00
- add default page background - add environment list in [doc](doc/environment.md) - combined notificationts to become more versatile - use exported hooks for graphql - links at the bottom for new users - fixes for hide contrib setting - upgrad all packages
83 lines
2.0 KiB
TypeScript
83 lines
2.0 KiB
TypeScript
import { Layout } from 'antd'
|
|
import { AuthFooter } from 'components/auth/footer'
|
|
import { GetStaticProps, NextPage } from 'next'
|
|
import getConfig from 'next/config'
|
|
import { useRouter } from 'next/router'
|
|
import React, { useEffect, useState } from 'react'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { LoadingPage } from '../components/loading.page'
|
|
import { Omf } from '../components/omf'
|
|
import { NextConfigType } from '../next.config.type'
|
|
|
|
const { publicRuntimeConfig } = getConfig() as NextConfigType
|
|
|
|
const Index: NextPage = () => {
|
|
const router = useRouter()
|
|
const { t } = useTranslation()
|
|
const [loading, setLoading] = useState<boolean>(
|
|
publicRuntimeConfig.spa || (process.browser && router.pathname !== window.location.pathname)
|
|
)
|
|
|
|
useEffect(() => {
|
|
if (router.pathname !== window.location.pathname) {
|
|
let href = router.asPath
|
|
const as = router.asPath
|
|
const possible = [/(\/form\/)[^/]+/i, /(\/admin\/forms\/)[^/]+/i, /(\/admin\/users\/)[^/]+/i]
|
|
|
|
possible.forEach((r) => {
|
|
if (r.test(as)) {
|
|
href = href.replace(r, '$1[id]')
|
|
}
|
|
})
|
|
|
|
router.replace(href, as).catch((e: Error) => {
|
|
console.error('failed redirect', e)
|
|
})
|
|
}
|
|
})
|
|
|
|
useEffect(() => {
|
|
if (loading) {
|
|
setTimeout(() => {
|
|
setLoading(false)
|
|
}, 10000)
|
|
}
|
|
}, [loading])
|
|
|
|
if (loading) {
|
|
return <LoadingPage message={t('loading')} />
|
|
}
|
|
|
|
return (
|
|
<Layout
|
|
style={{
|
|
height: '100vh',
|
|
background: publicRuntimeConfig.mainBackground,
|
|
}}
|
|
>
|
|
<Omf />
|
|
<img
|
|
alt={'OhMyForm'}
|
|
style={{
|
|
margin: 'auto',
|
|
maxWidth: '90%',
|
|
width: 500,
|
|
textAlign: 'center',
|
|
}}
|
|
src={require('../assets/images/logo_white.png') as string}
|
|
/>
|
|
|
|
<AuthFooter />
|
|
</Layout>
|
|
)
|
|
}
|
|
|
|
export const getStaticProps: GetStaticProps = async () => {
|
|
return {
|
|
revalidate: 10,
|
|
props: {},
|
|
}
|
|
}
|
|
|
|
export default Index
|