dispatch/client/js/components/App.js

78 lines
1.8 KiB
JavaScript
Raw Normal View History

import React, { Suspense, lazy } 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 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
}) => {
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
maxDuration={1000}
fallback={<div className="suspense-fallback">...</div>}
>
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;