mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
118 lines
4.6 KiB
TypeScript
Executable File
118 lines
4.6 KiB
TypeScript
Executable File
import "./app.scss";
|
|
import React from "react";
|
|
import { disposeOnUnmount, observer } from "mobx-react";
|
|
import { Redirect, Route, Switch } from "react-router";
|
|
import { Notifications } from "./notifications";
|
|
import { NotFound } from "./+404";
|
|
import { UserManagement } from "./+user-management/user-management";
|
|
import { ConfirmDialog } from "./confirm-dialog";
|
|
import { usersManagementRoute } from "./+user-management/user-management.routes";
|
|
import { clusterRoute, clusterURL } from "./+cluster";
|
|
import { KubeConfigDialog } from "./kubeconfig-dialog/kubeconfig-dialog";
|
|
import { Nodes, nodesRoute } from "./+nodes";
|
|
import { Workloads, workloadsRoute, workloadsURL } from "./+workloads";
|
|
import { Namespaces, namespacesRoute } from "./+namespaces";
|
|
import { Network, networkRoute } from "./+network";
|
|
import { Storage, storageRoute } from "./+storage";
|
|
import { Cluster } from "./+cluster/cluster";
|
|
import { Config, configRoute } from "./+config";
|
|
import { Events } from "./+events/events";
|
|
import { eventRoute } from "./+events";
|
|
import { Apps, appsRoute } from "./+apps";
|
|
import { KubeObjectDetails } from "./kube-object/kube-object-details";
|
|
import { AddRoleBindingDialog } from "./+user-management-roles-bindings";
|
|
import { PodLogsDialog } from "./+workloads-pods/pod-logs-dialog";
|
|
import { DeploymentScaleDialog } from "./+workloads-deployments/deployment-scale-dialog";
|
|
import { CustomResources } from "./+custom-resources/custom-resources";
|
|
import { crdRoute } from "./+custom-resources";
|
|
import { isAllowedResource } from "../api/rbac";
|
|
import { AddCluster, addClusterRoute } from "./+add-cluster";
|
|
import { LandingPage, landingRoute, landingURL } from "./+landing-page";
|
|
import { ClusterSettings, clusterSettingsRoute } from "./+cluster-settings";
|
|
import { Workspaces, workspacesRoute } from "./+workspaces";
|
|
import { ErrorBoundary } from "./error-boundary";
|
|
import { computed, observable, reaction } from "mobx";
|
|
import { configStore } from "../config.store";
|
|
import { clusterIpc } from "../../common/cluster-ipc";
|
|
import { clusterStore } from "../../common/cluster-store";
|
|
import { ClusterStatus } from "./cluster-manager/cluster-status";
|
|
import { clusterStatusRoute, clusterStatusURL } from "./cluster-manager/cluster-status.route";
|
|
import { navigation } from "../navigation";
|
|
import { CubeSpinner } from "./spinner";
|
|
|
|
@observer
|
|
export class App extends React.Component {
|
|
@observable appReady = false;
|
|
|
|
@computed get clusterReady() {
|
|
const clusterId = location.hostname.split(".")[0];
|
|
return !!clusterStore.getById(clusterId)?.isReady;
|
|
}
|
|
|
|
async componentDidMount() {
|
|
await clusterIpc.activate.invokeFromRenderer();
|
|
await configStore.init();
|
|
this.appReady = true;
|
|
|
|
disposeOnUnmount(this, [
|
|
reaction(() => this.startURL, url => {
|
|
if (!this.clusterReady) {
|
|
navigation.replace(url);
|
|
}
|
|
}, {
|
|
fireImmediately: true
|
|
})
|
|
])
|
|
}
|
|
|
|
get startURL() {
|
|
if (!clusterStore.hasClusters()) {
|
|
return landingURL();
|
|
}
|
|
if (!this.clusterReady) {
|
|
return clusterStatusURL();
|
|
}
|
|
if (isAllowedResource(["events", "nodes", "pods"])) {
|
|
return clusterURL();
|
|
}
|
|
return workloadsURL();
|
|
}
|
|
|
|
render() {
|
|
if (!this.appReady) {
|
|
return <CubeSpinner className="box center"/>
|
|
}
|
|
return (
|
|
<ErrorBoundary>
|
|
<Switch>
|
|
<Route component={LandingPage} {...landingRoute}/>
|
|
<Route component={Workspaces} {...workspacesRoute}/>
|
|
<Route component={AddCluster} {...addClusterRoute}/>
|
|
<Route component={Cluster} {...clusterRoute}/>
|
|
<Route component={ClusterStatus} {...clusterStatusRoute}/>
|
|
<Route component={ClusterSettings} {...clusterSettingsRoute}/>
|
|
<Route component={Nodes} {...nodesRoute}/>
|
|
<Route component={Workloads} {...workloadsRoute}/>
|
|
<Route component={Config} {...configRoute}/>
|
|
<Route component={Network} {...networkRoute}/>
|
|
<Route component={Storage} {...storageRoute}/>
|
|
<Route component={Namespaces} {...namespacesRoute}/>
|
|
<Route component={Events} {...eventRoute}/>
|
|
<Route component={CustomResources} {...crdRoute}/>
|
|
<Route component={UserManagement} {...usersManagementRoute}/>
|
|
<Route component={Apps} {...appsRoute}/>
|
|
<Redirect exact from="/" to={this.startURL}/>
|
|
<Route component={NotFound}/>
|
|
</Switch>
|
|
<KubeObjectDetails/>
|
|
<Notifications/>
|
|
<ConfirmDialog/>
|
|
<KubeConfigDialog/>
|
|
<AddRoleBindingDialog/>
|
|
<PodLogsDialog/>
|
|
<DeploymentScaleDialog/>
|
|
</ErrorBoundary>
|
|
)
|
|
}
|
|
}
|