mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
- Add lens:// protocol handling with a routing mechanism - document the methods in an extension guide - remove handlers when an extension is deactivated or removed - make sure that the found extension when routing a request is currently enabled (as a backup) - added documentation about the above behaviour to the guide - tweaked the naming convention so that it is clearer that the router uses extension names as not IDs (which currently are folder paths) - Convert the extension API to use an array for registering handlers - switch design to execute both main and renderer handlers simultaneously, without any overlap checking - change open to be a dev dep - improve docs, export types for extensions, skip integration tests - switch to event emitting renderer being ready - Add logging and fix renderer:loaded send to main Signed-off-by: Sebastian Malton <sebastian@malton.name>
52 lines
1.8 KiB
TypeScript
52 lines
1.8 KiB
TypeScript
import "../common/system-ca";
|
|
import React from "react";
|
|
import { Route, Router, Switch } from "react-router";
|
|
import { observer } from "mobx-react";
|
|
import { userStore } from "../common/user-store";
|
|
import { history } from "./navigation";
|
|
import { ClusterManager } from "./components/cluster-manager";
|
|
import { ErrorBoundary } from "./components/error-boundary";
|
|
import { WhatsNew, whatsNewRoute } from "./components/+whats-new";
|
|
import { Notifications } from "./components/notifications";
|
|
import { ConfirmDialog } from "./components/confirm-dialog";
|
|
import { extensionLoader } from "../extensions/extension-loader";
|
|
import { broadcastMessage } from "../common/ipc";
|
|
import { CommandContainer } from "./components/command-palette/command-container";
|
|
import { LensProtocolRouterRenderer } from "./protocol-handler/router";
|
|
import { registerIpcHandlers } from "./ipc";
|
|
import { ipcRenderer } from "electron";
|
|
|
|
@observer
|
|
export class LensApp extends React.Component {
|
|
static async init() {
|
|
extensionLoader.loadOnClusterManagerRenderer();
|
|
LensProtocolRouterRenderer.getInstance<LensProtocolRouterRenderer>().init();
|
|
window.addEventListener("offline", () => {
|
|
broadcastMessage("network:offline");
|
|
});
|
|
window.addEventListener("online", () => {
|
|
broadcastMessage("network:online");
|
|
});
|
|
|
|
registerIpcHandlers();
|
|
ipcRenderer.send("renderer:loaded");
|
|
}
|
|
|
|
render() {
|
|
return (
|
|
<Router history={history}>
|
|
<ErrorBoundary>
|
|
<Switch>
|
|
{userStore.isNewVersion && <Route component={WhatsNew}/>}
|
|
<Route component={WhatsNew} {...whatsNewRoute}/>
|
|
<Route component={ClusterManager}/>
|
|
</Switch>
|
|
</ErrorBoundary>
|
|
<Notifications/>
|
|
<ConfirmDialog/>
|
|
<CommandContainer />
|
|
</Router>
|
|
);
|
|
}
|
|
}
|