mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-12-11 02:09:53 -06:00
69 lines
2.2 KiB
TypeScript
69 lines
2.2 KiB
TypeScript
import classNames from 'classnames';
|
|
import type { FC } from 'react';
|
|
import { useEffect } from 'react';
|
|
import { Route, Routes, useLocation } from 'react-router-dom';
|
|
import type { Settings } from '../../shlink-web-component/src';
|
|
import { AppUpdateBanner } from '../common/AppUpdateBanner';
|
|
import { NotFound } from '../common/NotFound';
|
|
import type { ServersMap } from '../servers/data';
|
|
import { forceUpdate } from '../utils/helpers/sw';
|
|
import { changeThemeInMarkup } from '../utils/theme';
|
|
import './App.scss';
|
|
|
|
interface AppProps {
|
|
fetchServers: () => void;
|
|
servers: ServersMap;
|
|
settings: Settings;
|
|
resetAppUpdate: () => void;
|
|
appUpdated: boolean;
|
|
}
|
|
|
|
export const App = (
|
|
MainHeader: FC,
|
|
Home: FC,
|
|
ShlinkWebComponentContainer: FC,
|
|
CreateServer: FC,
|
|
EditServer: FC,
|
|
SettingsComp: FC,
|
|
ManageServers: FC,
|
|
ShlinkVersionsContainer: FC,
|
|
) => ({ fetchServers, servers, settings, appUpdated, resetAppUpdate }: AppProps) => {
|
|
const location = useLocation();
|
|
const isHome = location.pathname === '/';
|
|
|
|
useEffect(() => {
|
|
// On first load, try to fetch the remote servers if the list is empty
|
|
if (Object.keys(servers).length === 0) {
|
|
fetchServers();
|
|
}
|
|
|
|
changeThemeInMarkup(settings.ui?.theme ?? 'light');
|
|
}, []);
|
|
|
|
return (
|
|
<div className="container-fluid app-container">
|
|
<MainHeader />
|
|
|
|
<div className="app">
|
|
<div className={classNames('shlink-wrapper', { 'd-flex d-md-block align-items-center': isHome })}>
|
|
<Routes>
|
|
<Route index element={<Home />} />
|
|
<Route path="/settings/*" element={<SettingsComp />} />
|
|
<Route path="/manage-servers" element={<ManageServers />} />
|
|
<Route path="/server/create" element={<CreateServer />} />
|
|
<Route path="/server/:serverId/edit" element={<EditServer />} />
|
|
<Route path="/server/:serverId/*" element={<ShlinkWebComponentContainer />} />
|
|
<Route path="*" element={<NotFound />} />
|
|
</Routes>
|
|
</div>
|
|
|
|
<div className="shlink-footer">
|
|
<ShlinkVersionsContainer />
|
|
</div>
|
|
</div>
|
|
|
|
<AppUpdateBanner isOpen={appUpdated} toggle={resetAppUpdate} forceUpdate={forceUpdate} />
|
|
</div>
|
|
);
|
|
};
|