dispatch/client/js/components/App.js

83 lines
2.0 KiB
JavaScript
Raw Normal View History

import React, { Suspense, lazy, useState } from 'react';
import Route from 'containers/Route';
2018-11-06 10:13:32 +00:00
import AppInfo from 'components/AppInfo';
import TabList from 'components/TabList';
2018-11-06 10:13:32 +00:00
import cn from 'classnames';
const Modals = lazy(() => import('components/modals'));
const Chat = lazy(() => import('containers/Chat'));
const Connect = lazy(() => import('containers/Connect'));
const Settings = lazy(() => import('containers/Settings'));
const App = ({
connected,
tab,
channels,
servers,
privateChats,
showTabList,
select,
push,
2018-11-06 10:13:32 +00:00
hideMenu,
newVersionAvailable,
hasOpenModals
}) => {
const [renderModals, setRenderModals] = useState(false);
if (!renderModals && hasOpenModals) {
setRenderModals(true);
}
2018-11-06 10:13:32 +00:00
const mainClass = cn('main-container', {
'off-canvas': showTabList
});
const handleClick = () => {
2017-05-29 01:02:39 +00:00
if (showTabList) {
hideMenu();
}
};
return (
<div className="wrap" onClick={handleClick}>
{!connected && (
2018-11-06 10:13:32 +00:00
<AppInfo type="error">
Connection lost, attempting to reconnect...
2018-11-06 10:13:32 +00:00
</AppInfo>
)}
{newVersionAvailable && (
<AppInfo dismissible>
A new version of dispatch just got installed, reload to start using
it!
</AppInfo>
)}
<div className="app-container">
<TabList
tab={tab}
channels={channels}
servers={servers}
privateChats={privateChats}
showTabList={showTabList}
select={select}
push={push}
/>
<div className={mainClass}>
<Suspense fallback={<div className="suspense-fallback">...</div>}>
{renderModals && <Modals />}
2018-04-05 23:46:22 +00:00
<Route name="chat">
<Chat />
</Route>
<Route name="connect">
<Connect />
</Route>
<Route name="settings">
<Settings />
</Route>
</Suspense>
2017-05-29 01:02:39 +00:00
</div>
</div>
</div>
);
};
export default App;