mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Preserve preference URLs (#6501)
* Add line breaks for readability of a long warning message Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Preserve URLs leading to extension preferences Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Tweak variable name for readability Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com>
This commit is contained in:
parent
5ae60e218c
commit
bf11a482c2
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,21 @@
|
||||
/**
|
||||
* 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 { frontEndRouteInjectionToken } from "../../../common/front-end-routing/front-end-route-injection-token";
|
||||
|
||||
const preferencesRouteForLegacyExtensionsInjectable = getInjectable({
|
||||
id: "preferences-route-for-legacy-extensions",
|
||||
|
||||
instantiate: () => ({
|
||||
path: "/preferences/extension/:extensionId/:preferenceTabId?",
|
||||
clusterFrame: false,
|
||||
isEnabled: computed(() => true),
|
||||
}),
|
||||
|
||||
injectionToken: frontEndRouteInjectionToken,
|
||||
});
|
||||
|
||||
export default preferencesRouteForLegacyExtensionsInjectable;
|
||||
@ -6,21 +6,44 @@ import { getInjectable } from "@ogre-tools/injectable";
|
||||
import { computed } from "mobx";
|
||||
import preferencesRouteInjectable from "../../common/preferences-route.injectable";
|
||||
import routePathParametersInjectable from "../../../../renderer/routes/route-path-parameters.injectable";
|
||||
import preferencesRouteForLegacyExtensionsInjectable from "../../common/preferences-route-for-legacy-extensions.injectable";
|
||||
|
||||
const currentPreferenceTabIdInjectable = getInjectable({
|
||||
id: "current-preference-tab-id",
|
||||
|
||||
instantiate: (di) => {
|
||||
const preferencesRoute = di.inject(preferencesRouteInjectable);
|
||||
const preferencesRouteForLegacyExtensions = di.inject(preferencesRouteForLegacyExtensionsInjectable);
|
||||
|
||||
const routePathParameters = di.inject(
|
||||
const nonLegacyRoutePathParameters = di.inject(
|
||||
routePathParametersInjectable,
|
||||
preferencesRoute,
|
||||
);
|
||||
|
||||
return computed(
|
||||
() => routePathParameters.get().preferenceTabId || "app",
|
||||
const legacyRoutePathParameters = di.inject(
|
||||
routePathParametersInjectable,
|
||||
preferencesRouteForLegacyExtensions,
|
||||
);
|
||||
|
||||
return computed(() => {
|
||||
const nonLegacyPreferenceTabId = nonLegacyRoutePathParameters.get().preferenceTabId;
|
||||
|
||||
if (nonLegacyPreferenceTabId) {
|
||||
return nonLegacyPreferenceTabId;
|
||||
}
|
||||
|
||||
const legacyParameters = legacyRoutePathParameters.get();
|
||||
|
||||
if (legacyParameters.extensionId) {
|
||||
if (legacyParameters.preferenceTabId) {
|
||||
return `extension-${legacyParameters.extensionId}-${legacyParameters.preferenceTabId}`;
|
||||
}
|
||||
|
||||
return legacyParameters.extensionId;
|
||||
}
|
||||
|
||||
return "app";
|
||||
});
|
||||
},
|
||||
});
|
||||
|
||||
|
||||
@ -31,7 +31,7 @@ const preferencesCompositeInjectable = getInjectable({
|
||||
logError(
|
||||
`Tried to create preferences, but encountered references to unknown ids: "${ids.missingParentIds.join(
|
||||
'", "',
|
||||
)}". Available ids are: "${ids.availableParentIds.join('", "')}"`,
|
||||
)}".\n\nAvailable ids are:\n\n${ids.availableParentIds.join("\n")}`,
|
||||
);
|
||||
},
|
||||
|
||||
|
||||
@ -0,0 +1,21 @@
|
||||
/**
|
||||
* 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 { routeSpecificComponentInjectionToken } from "../../../renderer/routes/route-specific-component-injection-token";
|
||||
import preferencesRouteForLegacyExtensions from "../common/preferences-route-for-legacy-extensions.injectable";
|
||||
import { Preferences } from "./preferences";
|
||||
|
||||
const preferencesRouteComponentInjectable = getInjectable({
|
||||
id: "preferences-route-component-for-legacy-extensions",
|
||||
|
||||
instantiate: (di) => ({
|
||||
route: di.inject(preferencesRouteForLegacyExtensions),
|
||||
Component: Preferences,
|
||||
}),
|
||||
|
||||
injectionToken: routeSpecificComponentInjectionToken,
|
||||
});
|
||||
|
||||
export default preferencesRouteComponentInjectable;
|
||||
330
src/features/preferences/urls-of-legacy-extensions.test.tsx
Normal file
330
src/features/preferences/urls-of-legacy-extensions.test.tsx
Normal file
@ -0,0 +1,330 @@
|
||||
/**
|
||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||
*/
|
||||
import type { RenderResult } from "@testing-library/react";
|
||||
import type { ApplicationBuilder } from "../../renderer/components/test-utils/get-application-builder";
|
||||
import { getApplicationBuilder } from "../../renderer/components/test-utils/get-application-builder";
|
||||
import type { Discover } from "../../renderer/components/test-utils/discovery-of-html-elements";
|
||||
import { discoverFor } from "../../renderer/components/test-utils/discovery-of-html-elements";
|
||||
import React from "react";
|
||||
import type { Navigate } from "../../renderer/navigation/navigate.injectable";
|
||||
import navigateInjectable from "../../renderer/navigation/navigate.injectable";
|
||||
|
||||
describe("preferences: URLs of legacy extensions", () => {
|
||||
let builder: ApplicationBuilder;
|
||||
|
||||
beforeEach(() => {
|
||||
builder = getApplicationBuilder();
|
||||
});
|
||||
|
||||
describe("given extension with custom preferences and a custom preference tab", () => {
|
||||
let rendered: RenderResult;
|
||||
let discover: Discover;
|
||||
let navigate: Navigate;
|
||||
|
||||
beforeEach(async () => {
|
||||
rendered = await builder.render();
|
||||
|
||||
discover = discoverFor(() => rendered);
|
||||
|
||||
const testExtension = {
|
||||
id: "some-extension-id",
|
||||
name: "some-extension",
|
||||
|
||||
rendererOptions: {
|
||||
appPreferenceTabs: [
|
||||
{
|
||||
title: "Some title",
|
||||
id: "some-preference-tab-id",
|
||||
orderNumber: 1,
|
||||
},
|
||||
|
||||
{
|
||||
title: "Some other title",
|
||||
id: "some-other-preference-tab-id",
|
||||
orderNumber: 2,
|
||||
},
|
||||
],
|
||||
|
||||
appPreferences: [
|
||||
{
|
||||
title: "some-title",
|
||||
id: "some-preference-item-id",
|
||||
showInPreferencesTab: "some-preference-tab-id",
|
||||
|
||||
components: {
|
||||
Hint: () => <div />,
|
||||
Input: () => <div data-some-preference-test="some-preference" />,
|
||||
},
|
||||
},
|
||||
|
||||
{
|
||||
title: "some-other-title",
|
||||
id: "some-other-preference-item-id",
|
||||
showInPreferencesTab: "some-other-preference-tab-id",
|
||||
|
||||
components: {
|
||||
Hint: () => <div />,
|
||||
Input: () => <div data-some-preference-test="some-other-preference" />,
|
||||
},
|
||||
},
|
||||
],
|
||||
},
|
||||
};
|
||||
|
||||
builder.extensions.enable(testExtension);
|
||||
|
||||
navigate = builder.applicationWindow.only.di.inject(navigateInjectable);
|
||||
});
|
||||
|
||||
describe("when navigating to specific custom preference tab using magic string URL", () => {
|
||||
beforeEach(() => {
|
||||
navigate("/preferences/extension/some-extension/some-preference-tab-id");
|
||||
});
|
||||
|
||||
it("renders", () => {
|
||||
expect(rendered.baseElement).toMatchSnapshot();
|
||||
});
|
||||
|
||||
it("shows the custom preference page for the custom preference tab", () => {
|
||||
const { discovered } = discover.getSingleElement(
|
||||
"preference-page",
|
||||
"preference-item-for-extension-some-extension-additional-page-some-preference-tab-id",
|
||||
);
|
||||
|
||||
expect(discovered).not.toBeNull();
|
||||
});
|
||||
|
||||
it("shows the custom preferences", () => {
|
||||
const { discovered } = discover.getSingleElement(
|
||||
"some-preference",
|
||||
);
|
||||
|
||||
expect(discovered).not.toBeNull();
|
||||
});
|
||||
});
|
||||
|
||||
describe("when navigating to unspecified custom preferences tab using magic string URL", () => {
|
||||
beforeEach(() => {
|
||||
navigate("/preferences/extension/some-extension");
|
||||
});
|
||||
|
||||
it("renders", () => {
|
||||
expect(rendered.baseElement).toMatchSnapshot();
|
||||
});
|
||||
|
||||
it("cannot find contents of the arbitrary custom preference tabs", () => {
|
||||
const { discovered } = discover.querySingleElement(
|
||||
"some-preference",
|
||||
);
|
||||
|
||||
expect(discovered).toBeNull();
|
||||
});
|
||||
|
||||
it("shows the empty default preference page for the extension", () => {
|
||||
const { discovered } = discover.getSingleElement(
|
||||
"preference-page",
|
||||
"preference-item-for-extension-some-extension-page",
|
||||
);
|
||||
|
||||
expect(discovered).not.toBeNull();
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe("given extension with custom preferences but without a custom preference tab", () => {
|
||||
let rendered: RenderResult;
|
||||
let discover: Discover;
|
||||
let navigate: Navigate;
|
||||
|
||||
beforeEach(async () => {
|
||||
rendered = await builder.render();
|
||||
|
||||
discover = discoverFor(() => rendered);
|
||||
|
||||
const testExtension = {
|
||||
id: "some-extension-id",
|
||||
name: "some-extension",
|
||||
|
||||
rendererOptions: {
|
||||
appPreferences: [
|
||||
{
|
||||
title: "some-title",
|
||||
id: "some-preference-item-id",
|
||||
|
||||
components: {
|
||||
Hint: () => <div />,
|
||||
Input: () => <div data-some-preference-test />,
|
||||
},
|
||||
},
|
||||
],
|
||||
},
|
||||
};
|
||||
|
||||
builder.extensions.enable(testExtension);
|
||||
|
||||
navigate = builder.applicationWindow.only.di.inject(navigateInjectable);
|
||||
});
|
||||
|
||||
describe("when navigating to the default preference tab using magic string URL", () => {
|
||||
beforeEach(() => {
|
||||
navigate("/preferences/extension/some-extension");
|
||||
});
|
||||
|
||||
it("renders", () => {
|
||||
expect(rendered.baseElement).toMatchSnapshot();
|
||||
});
|
||||
|
||||
it("shows the preference page for the custom preferences", () => {
|
||||
const { discovered } = discover.getSingleElement(
|
||||
"preference-page",
|
||||
"preference-item-for-extension-some-extension-page",
|
||||
);
|
||||
|
||||
expect(discovered).not.toBeNull();
|
||||
});
|
||||
|
||||
it("shows the custom preferences", () => {
|
||||
const { discovered } = discover.getSingleElement("some-preference");
|
||||
|
||||
expect(discovered).not.toBeNull();
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe("given extension with both custom preference tabs and content for the default tab", () => {
|
||||
let rendered: RenderResult;
|
||||
let discover: Discover;
|
||||
let navigate: Navigate;
|
||||
|
||||
beforeEach(async () => {
|
||||
rendered = await builder.render();
|
||||
|
||||
discover = discoverFor(() => rendered);
|
||||
|
||||
const testExtension = {
|
||||
id: "some-extension-id",
|
||||
name: "some-extension",
|
||||
|
||||
rendererOptions: {
|
||||
appPreferenceTabs: [
|
||||
{
|
||||
title: "Some title",
|
||||
id: "some-preference-tab-id",
|
||||
orderNumber: 1,
|
||||
},
|
||||
|
||||
{
|
||||
title: "Some other title",
|
||||
id: "some-other-preference-tab-id",
|
||||
orderNumber: 2,
|
||||
},
|
||||
],
|
||||
|
||||
appPreferences: [
|
||||
{
|
||||
title: "some-title",
|
||||
id: "some-preference-item-id",
|
||||
showInPreferencesTab: "some-preference-tab-id",
|
||||
|
||||
components: {
|
||||
Hint: () => <div />,
|
||||
Input: () => <div data-some-preference-test="some-preference-in-custom-tab" />,
|
||||
},
|
||||
},
|
||||
|
||||
{
|
||||
title: "some-other-title",
|
||||
id: "some-other-preference-item-id",
|
||||
showInPreferencesTab: "some-other-preference-tab-id",
|
||||
|
||||
components: {
|
||||
Hint: () => <div />,
|
||||
Input: () => <div data-some-preference-test="some-preference-in-custom-tab" />,
|
||||
},
|
||||
},
|
||||
|
||||
{
|
||||
title: "some-title-in-default-tab",
|
||||
id: "some-preference-item-id-in-default-tab",
|
||||
|
||||
components: {
|
||||
Hint: () => <div />,
|
||||
Input: () => <div data-some-preference-test="some-preference-in-default-tab" />,
|
||||
},
|
||||
},
|
||||
],
|
||||
},
|
||||
};
|
||||
|
||||
builder.extensions.enable(testExtension);
|
||||
|
||||
navigate = builder.applicationWindow.only.di.inject(navigateInjectable);
|
||||
});
|
||||
|
||||
describe("when navigating to specific custom preference tab using magic string URL", () => {
|
||||
beforeEach(() => {
|
||||
navigate("/preferences/extension/some-extension/some-preference-tab-id");
|
||||
});
|
||||
|
||||
it("renders", () => {
|
||||
expect(rendered.baseElement).toMatchSnapshot();
|
||||
});
|
||||
|
||||
it("shows the custom preference page for the custom preference tab", () => {
|
||||
const { discovered } = discover.getSingleElement(
|
||||
"preference-page",
|
||||
"preference-item-for-extension-some-extension-additional-page-some-preference-tab-id",
|
||||
);
|
||||
|
||||
expect(discovered).not.toBeNull();
|
||||
});
|
||||
|
||||
it("shows the custom preferences", () => {
|
||||
const { discovered } = discover.getSingleElement(
|
||||
"some-preference",
|
||||
);
|
||||
|
||||
expect(discovered).not.toBeNull();
|
||||
});
|
||||
});
|
||||
|
||||
describe("when navigating to unspecified custom preferences tab using magic string URL", () => {
|
||||
beforeEach(() => {
|
||||
navigate("/preferences/extension/some-extension");
|
||||
});
|
||||
|
||||
it("renders", () => {
|
||||
expect(rendered.baseElement).toMatchSnapshot();
|
||||
});
|
||||
|
||||
it("cannot find contents of the arbitrary custom preference tabs", () => {
|
||||
const { discovered } = discover.querySingleElement(
|
||||
"some-preference",
|
||||
"some-preference-in-custom-tab",
|
||||
);
|
||||
|
||||
expect(discovered).toBeNull();
|
||||
});
|
||||
|
||||
it("shows the default preference page for the extension", () => {
|
||||
const { discovered } = discover.getSingleElement(
|
||||
"preference-page",
|
||||
"preference-item-for-extension-some-extension-page",
|
||||
);
|
||||
|
||||
expect(discovered).not.toBeNull();
|
||||
});
|
||||
|
||||
it("shows preferences of default preference page of the extension", () => {
|
||||
const { discovered } = discover.getSingleElement(
|
||||
"some-preference",
|
||||
"some-preference-in-default-tab",
|
||||
);
|
||||
|
||||
expect(discovered).not.toBeNull();
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
Loading…
Reference in New Issue
Block a user