1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00

Switch to using react application root feature being more friendly to extending

Signed-off-by: Janne Savolainen <janne.savolainen@live.fi>
This commit is contained in:
Janne Savolainen 2023-03-30 14:45:45 +03:00
parent 716efc5691
commit 0b383eb2a2
No known key found for this signature in database
GPG Key ID: 8C6CFB2FFFE8F68A
9 changed files with 102 additions and 23 deletions

2
package-lock.json generated
View File

@ -34411,6 +34411,7 @@
"@hapi/subtext": "^7.1.0", "@hapi/subtext": "^7.1.0",
"@k8slens/cluster-settings": "^6.5.0-alpha.1", "@k8slens/cluster-settings": "^6.5.0-alpha.1",
"@k8slens/node-fetch": "^6.5.0-alpha.1", "@k8slens/node-fetch": "^6.5.0-alpha.1",
"@k8slens/react-application-root": "^1.0.0-alpha.0",
"@kubernetes/client-node": "^0.18.1", "@kubernetes/client-node": "^0.18.1",
"@material-ui/styles": "^4.11.5", "@material-ui/styles": "^4.11.5",
"@ogre-tools/fp": "^15.1.2", "@ogre-tools/fp": "^15.1.2",
@ -37620,6 +37621,7 @@
"@k8slens/messaging": "^1.0.0-alpha.1", "@k8slens/messaging": "^1.0.0-alpha.1",
"@k8slens/messaging-for-main": "^1.0.0-alpha.1", "@k8slens/messaging-for-main": "^1.0.0-alpha.1",
"@k8slens/messaging-for-renderer": "^1.0.0-alpha.1", "@k8slens/messaging-for-renderer": "^1.0.0-alpha.1",
"@k8slens/react-application-root": "^1.0.0-alpha.0",
"@k8slens/run-many": "^1.0.0-alpha.1", "@k8slens/run-many": "^1.0.0-alpha.1",
"@k8slens/startable-stoppable": "^1.0.0-alpha.1", "@k8slens/startable-stoppable": "^1.0.0-alpha.1",
"@k8slens/test-utils": "^1.0.0-alpha.1", "@k8slens/test-utils": "^1.0.0-alpha.1",

View File

@ -122,6 +122,7 @@
"@hapi/subtext": "^7.1.0", "@hapi/subtext": "^7.1.0",
"@k8slens/cluster-settings": "^6.5.0-alpha.1", "@k8slens/cluster-settings": "^6.5.0-alpha.1",
"@k8slens/node-fetch": "^6.5.0-alpha.1", "@k8slens/node-fetch": "^6.5.0-alpha.1",
"@k8slens/react-application-root": "^1.0.0-alpha.0",
"@kubernetes/client-node": "^0.18.1", "@kubernetes/client-node": "^0.18.1",
"@material-ui/styles": "^4.11.5", "@material-ui/styles": "^4.11.5",
"@ogre-tools/fp": "^15.1.2", "@ogre-tools/fp": "^15.1.2",

View File

@ -5,10 +5,7 @@
import "./components/app.scss"; import "./components/app.scss";
import React from "react"; import { unmountComponentAtNode } from "react-dom";
import { render, unmountComponentAtNode } from "react-dom";
import { DefaultProps } from "./mui-base-theme";
import { DiContextProvider } from "@ogre-tools/injectable-react";
import type { import type {
DiContainerForInjection, DiContainerForInjection,
} from "@ogre-tools/injectable"; } from "@ogre-tools/injectable";
@ -17,8 +14,6 @@ import extensionDiscoveryInjectable from "../extensions/extension-discovery/exte
import extensionInstallationStateStoreInjectable from "../extensions/extension-installation-state-store/extension-installation-state-store.injectable"; import extensionInstallationStateStoreInjectable from "../extensions/extension-installation-state-store/extension-installation-state-store.injectable";
import initRootFrameInjectable from "./frames/root-frame/init-root-frame.injectable"; import initRootFrameInjectable from "./frames/root-frame/init-root-frame.injectable";
import initClusterFrameInjectable from "./frames/cluster-frame/init-cluster-frame/init-cluster-frame.injectable"; import initClusterFrameInjectable from "./frames/cluster-frame/init-cluster-frame/init-cluster-frame.injectable";
import { Router } from "react-router";
import historyInjectable from "./navigation/history.injectable";
import assert from "assert"; import assert from "assert";
export async function bootstrap(di: DiContainerForInjection) { export async function bootstrap(di: DiContainerForInjection) {
@ -30,16 +25,13 @@ export async function bootstrap(di: DiContainerForInjection) {
await di.inject(extensionDiscoveryInjectable).init(); await di.inject(extensionDiscoveryInjectable).init();
di.inject(extensionInstallationStateStoreInjectable).bindIpcListeners(); di.inject(extensionInstallationStateStoreInjectable).bindIpcListeners();
let App;
let initializeApp; let initializeApp;
// TODO: Introduce proper architectural boundaries between root and cluster iframes // TODO: Introduce proper architectural boundaries between root and cluster iframes
if (process.isMainFrame) { if (process.isMainFrame) {
initializeApp = di.inject(initRootFrameInjectable); initializeApp = di.inject(initRootFrameInjectable);
App = (await import("./frames/root-frame/root-frame")).RootFrame;
} else { } else {
initializeApp = di.inject(initClusterFrameInjectable); initializeApp = di.inject(initClusterFrameInjectable);
App = (await import("./frames/cluster-frame/cluster-frame")).ClusterFrame;
} }
try { try {
@ -50,15 +42,4 @@ export async function bootstrap(di: DiContainerForInjection) {
isTopFrameView: process.isMainFrame, isTopFrameView: process.isMainFrame,
}); });
} }
const history = di.inject(historyInjectable);
render(
<DiContextProvider value={{ di }}>
<Router history={history}>
{DefaultProps(App)}
</Router>
</DiContextProvider>,
rootElem,
);
} }

View File

@ -0,0 +1,31 @@
/**
* Copyright (c) OpenLens Authors. All rights reserved.
* Licensed under MIT License. See LICENSE in root directory for more information.
*/
import { getInjectable } from "@ogre-tools/injectable";
import {
reactApplicationChildrenInjectionToken,
} from "@k8slens/react-application-root";
import { computed } from "mobx";
const frameApplicationRootInjectable = getInjectable({
id: "frame-application-root",
instantiate: () => {
const Frame = process.isMainFrame
? require("./root-frame/root-frame").RootFrame
: require("./cluster-frame/cluster-frame").ClusterFrame;
return {
id: "frame-application-root",
Component: Frame,
enabled: computed(() => true),
};
},
causesSideEffects: true,
injectionToken: reactApplicationChildrenInjectionToken,
});
export default frameApplicationRootInjectable;

View File

@ -0,0 +1,30 @@
/**
* Copyright (c) OpenLens Authors. All rights reserved.
* Licensed under MIT License. See LICENSE in root directory for more information.
*/
import { getInjectable } from "@ogre-tools/injectable";
import { Router } from "react-router";
import historyInjectable from "../navigation/history.injectable";
import React from "react";
import {
reactApplicationWrapperInjectionToken,
} from "@k8slens/react-application-root";
const routingApplicationRootWrapperInjectable = getInjectable({
id: "routing-application-root-wrapper",
instantiate: (di) => {
const history = di.inject(historyInjectable);
return (Component) => () =>
(
<Router history={history}>
<Component />
</Router>
);
},
injectionToken: reactApplicationWrapperInjectionToken,
});
export default routingApplicationRootWrapperInjectable;

View File

@ -0,0 +1,26 @@
/**
* Copyright (c) OpenLens Authors. All rights reserved.
* Licensed under MIT License. See LICENSE in root directory for more information.
*/
import { getInjectable } from "@ogre-tools/injectable";
import React from "react";
import {
reactApplicationWrapperInjectionToken,
} from "@k8slens/react-application-root";
import { ThemeProvider } from "@material-ui/core";
import { defaultMuiBaseTheme } from "../mui-base-theme";
const themeProviderApplicationRootWrapperInjectable = getInjectable({
id: "theme-provider-application-root-wrapper",
instantiate: () => (Component) => () =>
(
<ThemeProvider theme={defaultMuiBaseTheme}>
<Component />
</ThemeProvider>
),
injectionToken: reactApplicationWrapperInjectionToken,
});
export default themeProviderApplicationRootWrapperInjectable;

View File

@ -6,7 +6,7 @@
import React from "react"; import React from "react";
import { createTheme, ThemeProvider } from "@material-ui/core"; import { createTheme, ThemeProvider } from "@material-ui/core";
const defaultTheme = createTheme({ export const defaultMuiBaseTheme = createTheme({
props: { props: {
MuiIconButton: { MuiIconButton: {
color: "inherit", color: "inherit",
@ -32,7 +32,7 @@ const defaultTheme = createTheme({
export function DefaultProps(App: React.ComponentType | React.FunctionComponent) { export function DefaultProps(App: React.ComponentType | React.FunctionComponent) {
return ( return (
<ThemeProvider theme= { defaultTheme } > <ThemeProvider theme= { defaultMuiBaseTheme } >
<App /> <App />
</ThemeProvider> </ThemeProvider>
); );

View File

@ -206,6 +206,7 @@
"@k8slens/messaging": "^1.0.0-alpha.1", "@k8slens/messaging": "^1.0.0-alpha.1",
"@k8slens/messaging-for-main": "^1.0.0-alpha.1", "@k8slens/messaging-for-main": "^1.0.0-alpha.1",
"@k8slens/messaging-for-renderer": "^1.0.0-alpha.1", "@k8slens/messaging-for-renderer": "^1.0.0-alpha.1",
"@k8slens/react-application-root": "^1.0.0-alpha.0",
"@k8slens/run-many": "^1.0.0-alpha.1", "@k8slens/run-many": "^1.0.0-alpha.1",
"@k8slens/startable-stoppable": "^1.0.0-alpha.1", "@k8slens/startable-stoppable": "^1.0.0-alpha.1",
"@k8slens/test-utils": "^1.0.0-alpha.1", "@k8slens/test-utils": "^1.0.0-alpha.1",

View File

@ -15,6 +15,7 @@ import { createContainer } from "@ogre-tools/injectable";
import { registerMobX } from "@ogre-tools/injectable-extension-for-mobx"; import { registerMobX } from "@ogre-tools/injectable-extension-for-mobx";
import { registerInjectableReact } from "@ogre-tools/injectable-react"; import { registerInjectableReact } from "@ogre-tools/injectable-react";
import { messagingFeatureForRenderer } from "@k8slens/messaging-for-renderer"; import { messagingFeatureForRenderer } from "@k8slens/messaging-for-renderer";
import { reactApplicationRootFeature } from "@k8slens/react-application-root";
const environment = "renderer"; const environment = "renderer";
@ -24,7 +25,13 @@ runInAction(() => {
registerMobX(di); registerMobX(di);
registerInjectableReact(di); registerInjectableReact(di);
registerLensCore(di, environment); registerLensCore(di, environment);
registerFeature(di, applicationFeature, messagingFeatureForRenderer);
registerFeature(
di,
applicationFeature,
messagingFeatureForRenderer,
reactApplicationRootFeature
);
autoRegister({ autoRegister({
di, di,