2019-11-04 00:17:50 -08:00
|
|
|
import React, { FC } from 'react';
|
2019-10-28 07:02:42 -07:00
|
|
|
import Navigation from './Navbar';
|
2019-10-27 14:03:39 -07:00
|
|
|
import { Container } from 'reactstrap';
|
2019-10-17 05:38:09 -07:00
|
|
|
|
|
|
|
import './App.css';
|
2019-11-04 00:17:50 -08:00
|
|
|
import { Router, Redirect } from '@reach/router';
|
2020-02-03 06:14:25 -08:00
|
|
|
import { Alerts, Config, Flags, Rules, ServiceDiscovery, Status, Targets, TSDBStatus, PanelList } from './pages';
|
2020-10-22 08:22:32 -07:00
|
|
|
import { PathPrefixContext } from './contexts/PathPrefixContext';
|
2019-10-17 05:38:09 -07:00
|
|
|
|
2020-02-08 02:00:48 -08:00
|
|
|
interface AppProps {
|
|
|
|
consolesLink: string | null;
|
|
|
|
}
|
|
|
|
|
2020-10-22 08:22:32 -07:00
|
|
|
const App: FC<AppProps> = ({ consolesLink }) => {
|
|
|
|
// This dynamically/generically determines the pathPrefix by stripping the first known
|
|
|
|
// endpoint suffix from the window location path. It works out of the box for both direct
|
|
|
|
// hosting and reverse proxy deployments with no additional configurations required.
|
|
|
|
let basePath = window.location.pathname;
|
|
|
|
const paths = [
|
|
|
|
'/graph',
|
|
|
|
'/alerts',
|
|
|
|
'/status',
|
|
|
|
'/tsdb-status',
|
|
|
|
'/flags',
|
|
|
|
'/config',
|
|
|
|
'/rules',
|
|
|
|
'/targets',
|
|
|
|
'/service-discovery',
|
|
|
|
];
|
|
|
|
if (basePath.endsWith('/')) {
|
|
|
|
basePath = basePath.slice(0, -1);
|
|
|
|
}
|
|
|
|
if (basePath.length > 1) {
|
|
|
|
for (let i = 0; i < paths.length; i++) {
|
|
|
|
if (basePath.endsWith(paths[i])) {
|
|
|
|
basePath = basePath.slice(0, basePath.length - paths[i].length);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-04 00:17:50 -08:00
|
|
|
return (
|
2020-10-22 08:22:32 -07:00
|
|
|
<PathPrefixContext.Provider value={basePath}>
|
|
|
|
<Navigation consolesLink={consolesLink} />
|
2019-11-04 00:17:50 -08:00
|
|
|
<Container fluid style={{ paddingTop: 70 }}>
|
2020-10-22 08:22:32 -07:00
|
|
|
<Router basepath={`${basePath}`}>
|
|
|
|
<Redirect from="/" to={`graph`} noThrow />
|
2019-11-20 06:50:52 -08:00
|
|
|
{/*
|
2020-10-22 08:22:32 -07:00
|
|
|
NOTE: Any route added here needs to also be added to the list of
|
|
|
|
React-handled router paths ("reactRouterPaths") in /web/web.go.
|
|
|
|
*/}
|
|
|
|
<PanelList path="/graph" />
|
|
|
|
<Alerts path="/alerts" />
|
|
|
|
<Config path="/config" />
|
|
|
|
<Flags path="/flags" />
|
|
|
|
<Rules path="/rules" />
|
|
|
|
<ServiceDiscovery path="/service-discovery" />
|
|
|
|
<Status path="/status" />
|
|
|
|
<TSDBStatus path="/tsdb-status" />
|
|
|
|
<Targets path="/targets" />
|
2019-11-04 00:17:50 -08:00
|
|
|
</Router>
|
|
|
|
</Container>
|
2020-10-22 08:22:32 -07:00
|
|
|
</PathPrefixContext.Provider>
|
2019-11-04 00:17:50 -08:00
|
|
|
);
|
|
|
|
};
|
2019-10-17 05:38:09 -07:00
|
|
|
|
|
|
|
export default App;
|