mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Dereference Extensions getProps() inner contents
Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com>
This commit is contained in:
parent
1ffb97587a
commit
4bb6ef1539
@ -0,0 +1,32 @@
|
|||||||
|
/**
|
||||||
|
* 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 { computed } from "mobx";
|
||||||
|
import rendererExtensionsInjectable from "../../../extensions/renderer-extensions.injectable";
|
||||||
|
import currentPathParametersInjectable from "../../routes/current-path-parameters.injectable";
|
||||||
|
import { getExtensionPreferenceItems } from "./get-extension-preference-items";
|
||||||
|
|
||||||
|
export const extensionPreferencesModelInjectable = getInjectable({
|
||||||
|
id: "extension-preferences-model",
|
||||||
|
|
||||||
|
instantiate: (di) => {
|
||||||
|
const pathParameters = di.inject(currentPathParametersInjectable);
|
||||||
|
const extensions = di.inject(rendererExtensionsInjectable);
|
||||||
|
|
||||||
|
return computed(() => {
|
||||||
|
const { extensionId, tabId } = pathParameters.get();
|
||||||
|
const targetExtension = extensions.get().find((extension) => extension.sanitizedExtensionId === extensionId);
|
||||||
|
|
||||||
|
if (!targetExtension) {
|
||||||
|
throw new Error('Tried to get extension preferences for extension that does not exist.')
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
extensionName: targetExtension.manifest.name,
|
||||||
|
preferenceItems: getExtensionPreferenceItems(targetExtension, tabId)
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
@ -4,19 +4,16 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import { withInjectables } from "@ogre-tools/injectable-react";
|
import { withInjectables } from "@ogre-tools/injectable-react";
|
||||||
import type { IComputedValue } from "mobx";
|
|
||||||
import { observer } from "mobx-react";
|
import { observer } from "mobx-react";
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import type { RegisteredAppPreference } from "./app-preferences/app-preference-registration";
|
import type { RegisteredAppPreference } from "./app-preferences/app-preference-registration";
|
||||||
|
import { extensionPreferencesModelInjectable } from "./extension-preference-model.injectable";
|
||||||
import { ExtensionSettings } from "./extension-settings";
|
import { ExtensionSettings } from "./extension-settings";
|
||||||
import { Preferences } from "./preferences";
|
import { Preferences } from "./preferences";
|
||||||
import extensionsPreferenceItemsInjectable from "./extension-preference-items.injectable";
|
|
||||||
import currentPathParametersInjectable from "../../routes/current-path-parameters.injectable";
|
|
||||||
import rendererExtensionsInjectable from "../../../extensions/renderer-extensions.injectable";
|
|
||||||
|
|
||||||
interface Dependencies {
|
interface Dependencies {
|
||||||
preferenceItems: IComputedValue<RegisteredAppPreference[]>;
|
preferenceItems: RegisteredAppPreference[];
|
||||||
extensionName?: string;
|
extensionName: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
const NonInjectedExtensions = ({ preferenceItems, extensionName }: Dependencies) => (
|
const NonInjectedExtensions = ({ preferenceItems, extensionName }: Dependencies) => (
|
||||||
@ -27,10 +24,7 @@ const NonInjectedExtensions = ({ preferenceItems, extensionName }: Dependencies)
|
|||||||
{" "}
|
{" "}
|
||||||
preferences
|
preferences
|
||||||
</h2>
|
</h2>
|
||||||
{!extensionName && (
|
{preferenceItems.map((preferenceItem, index) => (
|
||||||
<div className="flex items-center">No extension found</div>
|
|
||||||
)}
|
|
||||||
{preferenceItems.get().map((preferenceItem, index) => (
|
|
||||||
<ExtensionSettings
|
<ExtensionSettings
|
||||||
key={`${preferenceItem.id}-${index}`}
|
key={`${preferenceItem.id}-${index}`}
|
||||||
setting={preferenceItem}
|
setting={preferenceItem}
|
||||||
@ -47,14 +41,11 @@ export const Extensions = withInjectables<Dependencies>(
|
|||||||
|
|
||||||
{
|
{
|
||||||
getProps: (di) => {
|
getProps: (di) => {
|
||||||
const pathParameters = di.inject(currentPathParametersInjectable);
|
const { preferenceItems, extensionName } = di.inject(extensionPreferencesModelInjectable).get();
|
||||||
const extensionId = pathParameters.get().extensionId;
|
|
||||||
const extensions = di.inject(rendererExtensionsInjectable);
|
|
||||||
const extension = extensions.get().find((extension) => extension.sanitizedExtensionId === extensionId);
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
preferenceItems: di.inject(extensionsPreferenceItemsInjectable, pathParameters),
|
preferenceItems,
|
||||||
extensionName: extension?.manifest.name,
|
extensionName,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|||||||
@ -0,0 +1,20 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||||
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import type { LensRendererExtension } from "../../../extensions/lens-renderer-extension";
|
||||||
|
import type { RegisteredAppPreference } from "./app-preferences/app-preference-registration";
|
||||||
|
|
||||||
|
export function getExtensionPreferenceItems(extension: LensRendererExtension, tabId?: string): RegisteredAppPreference[] {
|
||||||
|
const preferences = extension.appPreferences.map(preference => ({
|
||||||
|
id: preference.id || preference.title,
|
||||||
|
...preference,
|
||||||
|
}));
|
||||||
|
|
||||||
|
if (tabId) {
|
||||||
|
return preferences.filter(preference => preference.showInPreferencesTab == tabId);
|
||||||
|
}
|
||||||
|
|
||||||
|
return preferences.filter(preference => !preference.showInPreferencesTab);
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue
Block a user