revite/src/pages/RevoltApp.tsx

136 lines
5.4 KiB
TypeScript
Raw Normal View History

import { Docked, OverlappingPanels, ShowIf } from "react-overlapping-panels";
import { Switch, Route, useLocation } from "react-router-dom";
2021-06-19 15:00:30 -04:00
import styled from "styled-components";
2021-06-19 07:34:53 -04:00
2021-06-19 15:24:11 -04:00
import ContextMenus from "../lib/ContextMenus";
2021-07-05 06:23:23 -04:00
import { isTouchscreenDevice } from "../lib/isTouchscreenDevice";
import Popovers from "../context/intermediate/Popovers";
import Notifications from "../context/revoltjs/Notifications";
2021-07-05 06:23:23 -04:00
import StateMonitor from "../context/revoltjs/StateMonitor";
import SyncManager from "../context/revoltjs/SyncManager";
2021-06-19 15:24:11 -04:00
2021-08-01 13:11:18 -04:00
import { Titlebar } from "../components/native/Titlebar";
2021-07-05 06:23:23 -04:00
import BottomNavigation from "../components/navigation/BottomNavigation";
2021-06-19 10:29:04 -04:00
import LeftSidebar from "../components/navigation/LeftSidebar";
import RightSidebar from "../components/navigation/RightSidebar";
import Open from "./Open";
import Channel from "./channels/Channel";
2021-06-19 15:24:11 -04:00
import Developer from "./developer/Developer";
2021-07-05 06:23:23 -04:00
import Friends from "./friends/Friends";
import Home from "./home/Home";
import Invite from "./invite/Invite";
2021-08-12 11:07:41 -04:00
import InviteBot from "./invite/InviteBot";
2021-06-19 17:37:12 -04:00
import ChannelSettings from "./settings/ChannelSettings";
2021-07-05 06:23:23 -04:00
import ServerSettings from "./settings/ServerSettings";
import Settings from "./settings/Settings";
2021-06-19 15:00:30 -04:00
const Routes = styled.div`
2021-07-05 06:25:20 -04:00
min-width: 0;
display: flex;
overflow: hidden;
flex-direction: column;
background: var(--primary-background);
2021-06-19 15:00:30 -04:00
`;
2021-06-19 07:34:53 -04:00
export default function App() {
2021-07-05 06:25:20 -04:00
const path = useLocation().pathname;
const fixedBottomNav =
path === "/" || path === "/settings" || path.startsWith("/friends");
const inChannel = path.includes("/channel");
const inSpecial =
(path.startsWith("/friends") && isTouchscreenDevice) ||
path.startsWith("/invite") ||
path.includes("/settings");
2021-07-05 06:23:23 -04:00
2021-07-05 06:25:20 -04:00
return (
2021-08-01 09:22:08 -04:00
<>
2021-08-01 13:11:18 -04:00
{window.isNative && !window.native.getConfig().frame && (
<Titlebar />
)}
2021-08-01 09:22:08 -04:00
<OverlappingPanels
width="100vw"
height={
window.isNative && !window.native.getConfig().frame
2021-08-01 11:44:51 -04:00
? "calc(var(--app-height) - var(--titlebar-height))"
2021-08-01 09:22:08 -04:00
: "var(--app-height)"
}
leftPanel={
inSpecial
? undefined
: { width: 288, component: <LeftSidebar /> }
2021-08-01 09:22:08 -04:00
}
rightPanel={
!inSpecial && inChannel
2021-12-20 08:56:37 -05:00
? { width: 236, component: <RightSidebar /> }
2021-08-01 09:22:08 -04:00
: undefined
}
bottomNav={{
component: <BottomNavigation />,
showIf: fixedBottomNav ? ShowIf.Always : ShowIf.Left,
height: 50,
}}
docked={isTouchscreenDevice ? Docked.None : Docked.Left}>
<Routes>
<Switch>
<Route
path="/server/:server/channel/:channel/settings/:page"
component={ChannelSettings}
/>
<Route
path="/server/:server/channel/:channel/settings"
component={ChannelSettings}
/>
<Route
path="/server/:server/settings/:page"
component={ServerSettings}
/>
<Route
path="/server/:server/settings"
component={ServerSettings}
/>
<Route
path="/channel/:channel/settings/:page"
component={ChannelSettings}
/>
<Route
path="/channel/:channel/settings"
component={ChannelSettings}
/>
2021-08-01 09:22:08 -04:00
<Route
path="/channel/:channel/:message"
component={Channel}
/>
<Route
path="/server/:server/channel/:channel/:message"
component={Channel}
/>
2021-07-08 17:47:56 -04:00
2021-08-01 09:22:08 -04:00
<Route
path="/server/:server/channel/:channel"
component={Channel}
/>
<Route path="/server/:server" component={Channel} />
2021-08-01 09:22:08 -04:00
<Route path="/channel/:channel" component={Channel} />
2021-08-01 09:22:08 -04:00
<Route path="/settings/:page" component={Settings} />
<Route path="/settings" component={Settings} />
2021-06-19 15:24:11 -04:00
2021-08-01 09:22:08 -04:00
<Route path="/dev" component={Developer} />
<Route path="/friends" component={Friends} />
<Route path="/open/:id" component={Open} />
2021-08-12 11:07:41 -04:00
<Route path="/bot/:id" component={InviteBot} />
2021-09-08 13:35:53 -04:00
<Route path="/invite/:code?" component={Invite} />
2021-08-01 09:22:08 -04:00
<Route path="/" component={Home} />
</Switch>
</Routes>
<ContextMenus />
<Popovers />
<Notifications />
<StateMonitor />
</OverlappingPanels>
</>
2021-07-05 06:25:20 -04:00
);
2021-07-05 06:23:23 -04:00
}