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>
58 lines
1.5 KiB
TypeScript
58 lines
1.5 KiB
TypeScript
import type { LensExtensionId } from "./lens-extension";
|
|
import { BaseStore } from "../common/base-store";
|
|
import { action, computed, observable, toJS } from "mobx";
|
|
|
|
export interface LensExtensionsStoreModel {
|
|
extensions: Record<LensExtensionId, LensExtensionState>;
|
|
}
|
|
|
|
export interface LensExtensionState {
|
|
enabled?: boolean;
|
|
name: string;
|
|
}
|
|
|
|
export class ExtensionsStore extends BaseStore<LensExtensionsStoreModel> {
|
|
constructor() {
|
|
super({
|
|
configName: "lens-extensions",
|
|
});
|
|
}
|
|
|
|
@computed
|
|
get enabledExtensions() {
|
|
return Array.from(this.state.values())
|
|
.filter(({enabled}) => enabled)
|
|
.map(({name}) => name);
|
|
}
|
|
|
|
protected state = observable.map<LensExtensionId, LensExtensionState>();
|
|
|
|
isEnabled(extId: LensExtensionId): boolean {
|
|
const state = this.state.get(extId);
|
|
|
|
// By default false, so that copied extensions are disabled by default.
|
|
// If user installs the extension from the UI, the Extensions component will specifically enable it.
|
|
return Boolean(state?.enabled);
|
|
}
|
|
|
|
@action
|
|
mergeState(extensionsState: Record<LensExtensionId, LensExtensionState>) {
|
|
this.state.merge(extensionsState);
|
|
}
|
|
|
|
@action
|
|
protected fromStore({ extensions }: LensExtensionsStoreModel) {
|
|
this.state.merge(extensions);
|
|
}
|
|
|
|
toJSON(): LensExtensionsStoreModel {
|
|
return toJS({
|
|
extensions: this.state.toJSON(),
|
|
}, {
|
|
recurseEverything: true
|
|
});
|
|
}
|
|
}
|
|
|
|
export const extensionsStore = new ExtensionsStore();
|