mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Fix external extensions not loading initially
Signed-off-by: Sebastian Malton <sebastian@malton.name>
This commit is contained in:
parent
aeea8640ce
commit
bf4b0f8994
@ -10,8 +10,6 @@ import { render, unmountComponentAtNode } from "react-dom";
|
|||||||
import { DefaultProps } from "./mui-base-theme";
|
import { DefaultProps } from "./mui-base-theme";
|
||||||
import { DiContextProvider } from "@ogre-tools/injectable-react";
|
import { DiContextProvider } from "@ogre-tools/injectable-react";
|
||||||
import type { DiContainer } from "@ogre-tools/injectable";
|
import type { DiContainer } from "@ogre-tools/injectable";
|
||||||
import extensionLoaderInjectable from "../extensions/extension-loader/extension-loader.injectable";
|
|
||||||
import extensionDiscoveryInjectable from "../extensions/extension-discovery/extension-discovery.injectable";
|
|
||||||
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";
|
||||||
@ -29,8 +27,6 @@ export async function bootstrap(di: DiContainer) {
|
|||||||
|
|
||||||
assert(rootElem, "#app MUST exist");
|
assert(rootElem, "#app MUST exist");
|
||||||
|
|
||||||
await di.inject(extensionLoaderInjectable).init();
|
|
||||||
await di.inject(extensionDiscoveryInjectable).init();
|
|
||||||
di.inject(extensionInstallationStateStoreInjectable).bindIpcListeners();
|
di.inject(extensionInstallationStateStoreInjectable).bindIpcListeners();
|
||||||
|
|
||||||
let App;
|
let App;
|
||||||
|
|||||||
@ -0,0 +1,24 @@
|
|||||||
|
/**
|
||||||
|
* 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 extensionDiscoveryInjectable from "../../extensions/extension-discovery/extension-discovery.injectable";
|
||||||
|
import { beforeFrameStartsSecondInjectionToken } from "../before-frame-starts/tokens";
|
||||||
|
import initializeExtensionLoaderInjectable from "../extension-loader/init.injectable";
|
||||||
|
|
||||||
|
const initializeExtensionDiscoveryInjectable = getInjectable({
|
||||||
|
id: "initialize-extension-discovery",
|
||||||
|
instantiate: (di) => ({
|
||||||
|
id: "initialize-extension-discovery",
|
||||||
|
run: async () => {
|
||||||
|
const extensionDiscovery = di.inject(extensionDiscoveryInjectable);
|
||||||
|
|
||||||
|
await extensionDiscovery.init();
|
||||||
|
},
|
||||||
|
runAfter: di.inject(initializeExtensionLoaderInjectable),
|
||||||
|
}),
|
||||||
|
injectionToken: beforeFrameStartsSecondInjectionToken,
|
||||||
|
});
|
||||||
|
|
||||||
|
export default initializeExtensionDiscoveryInjectable;
|
||||||
@ -0,0 +1,22 @@
|
|||||||
|
/**
|
||||||
|
* 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 extensionLoaderInjectable from "../../extensions/extension-loader/extension-loader.injectable";
|
||||||
|
import { beforeFrameStartsSecondInjectionToken } from "../before-frame-starts/tokens";
|
||||||
|
|
||||||
|
const initializeExtensionLoaderInjectable = getInjectable({
|
||||||
|
id: "initialize-extension-loader",
|
||||||
|
instantiate: (di) => ({
|
||||||
|
id: "initialize-extension-loader",
|
||||||
|
run: async () => {
|
||||||
|
const extensionLoader = di.inject(extensionLoaderInjectable);
|
||||||
|
|
||||||
|
await extensionLoader.init();
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
injectionToken: beforeFrameStartsSecondInjectionToken,
|
||||||
|
});
|
||||||
|
|
||||||
|
export default initializeExtensionLoaderInjectable;
|
||||||
Loading…
Reference in New Issue
Block a user