52062d452d
* Remove showView and showBoard property drilling and migrate centerPanel to functional component * Make this backward compatible * Fixing linter warnings * Fixing call * Fixing typescript types * Addressing PR review comments * Fixing cypress tests
107 lines
4.2 KiB
TypeScript
107 lines
4.2 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
import React, {useState, useEffect} from 'react'
|
|
import {
|
|
BrowserRouter as Router,
|
|
Redirect,
|
|
Route,
|
|
Switch,
|
|
} from 'react-router-dom'
|
|
|
|
import {FlashMessages} from './components/flashMessages'
|
|
import {getCurrentLanguage, storeLanguage} from './i18n'
|
|
import {default as client} from './octoClient'
|
|
import BoardPage from './pages/boardPage'
|
|
import ChangePasswordPage from './pages/changePasswordPage'
|
|
import ErrorPage from './pages/errorPage'
|
|
import LoginPage from './pages/loginPage'
|
|
import RegisterPage from './pages/registerPage'
|
|
import {IUser} from './user'
|
|
import {Utils} from './utils'
|
|
import CombinedProviders from './combinedProviders'
|
|
import {importNativeAppSettings} from './nativeApp'
|
|
|
|
const App = React.memo((): JSX.Element => {
|
|
importNativeAppSettings()
|
|
|
|
const [language, setLanguage] = useState(getCurrentLanguage())
|
|
const [user, setUser] = useState<IUser|undefined>(undefined)
|
|
const [initialLoad, setInitialLoad] = useState(false)
|
|
|
|
useEffect(() => {
|
|
client.getMe().then((loadedUser?: IUser) => {
|
|
setUser(loadedUser)
|
|
setInitialLoad(true)
|
|
})
|
|
}, [])
|
|
|
|
const setAndStoreLanguage = (lang: string): void => {
|
|
storeLanguage(lang)
|
|
setLanguage(lang)
|
|
}
|
|
|
|
return (
|
|
<CombinedProviders
|
|
language={language}
|
|
user={user}
|
|
setLanguage={setAndStoreLanguage}
|
|
>
|
|
<FlashMessages milliseconds={2000}/>
|
|
<Router
|
|
forceRefresh={true}
|
|
basename={Utils.getBaseURL()}
|
|
>
|
|
<div id='frame'>
|
|
<div id='main'>
|
|
<Switch>
|
|
<Route path='/error'>
|
|
<ErrorPage/>
|
|
</Route>
|
|
<Route path='/login'>
|
|
<LoginPage/>
|
|
</Route>
|
|
<Route path='/register'>
|
|
<RegisterPage/>
|
|
</Route>
|
|
<Route path='/change_password'>
|
|
<ChangePasswordPage/>
|
|
</Route>
|
|
<Route path='/shared/:boardId?/:viewId?'>
|
|
<BoardPage readonly={true}/>
|
|
</Route>
|
|
<Route path='/board/:boardId?/:viewId?'>
|
|
{initialLoad && !user && <Redirect to='/login'/>}
|
|
<BoardPage/>
|
|
</Route>
|
|
<Route path='/workspace/:workspaceId/shared/:boardId?/:viewId?'>
|
|
<BoardPage readonly={true}/>
|
|
</Route>
|
|
<Route
|
|
path='/workspace/:workspaceId/:boardId?/:viewId?'
|
|
render={({match}) => {
|
|
if (initialLoad && !user) {
|
|
let redirectUrl = '/' + Utils.buildURL(`/workspace/${match.params.workspaceId}/`)
|
|
if (redirectUrl.indexOf('//') === 0) {
|
|
redirectUrl = redirectUrl.slice(1)
|
|
}
|
|
const loginUrl = `/login?r=${encodeURIComponent(redirectUrl)}`
|
|
return <Redirect to={loginUrl}/>
|
|
}
|
|
return (
|
|
<BoardPage/>
|
|
)
|
|
}}
|
|
/>
|
|
<Route path='/:boardId?/:viewId?'>
|
|
{initialLoad && !user && <Redirect to='/login'/>}
|
|
<BoardPage/>
|
|
</Route>
|
|
</Switch>
|
|
</div>
|
|
</div>
|
|
</Router>
|
|
</CombinedProviders>
|
|
)
|
|
})
|
|
|
|
export default App
|