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

Extract top menu item for navigating to back as OCP

Co-authored-by: Janne Savolainen <janne.savolainen@live.fi>

Signed-off-by: Iku-turso <mikko.aspiala@gmail.com>
This commit is contained in:
Iku-turso 2022-08-16 11:06:06 +03:00 committed by Janne Savolainen
parent 7eacdd164b
commit c132ceaf2b
No known key found for this signature in database
GPG Key ID: 8C6CFB2FFFE8F68A
8 changed files with 74 additions and 20 deletions

View File

@ -0,0 +1,8 @@
/**
* Copyright (c) OpenLens Authors. All rights reserved.
* Licensed under MIT License. See LICENSE in root directory for more information.
*/
import goBackInjectable from "./go-back.injectable";
import { getGlobalOverrideForFunction } from "../../../../../../../common/test-utils/get-global-override-for-function";
export default getGlobalOverrideForFunction(goBackInjectable);

View File

@ -3,8 +3,8 @@
* Licensed under MIT License. See LICENSE in root directory for more information.
*/
import { getInjectable } from "@ogre-tools/injectable";
import { WindowAction } from "../../../../common/ipc/window";
import { requestWindowAction } from "../../../ipc";
import { WindowAction } from "../../../../../../../common/ipc/window";
import { requestWindowAction } from "../../../../../../ipc";
const goBackInjectable = getInjectable({
id: "go-back",

View File

@ -0,0 +1,23 @@
/**
* 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 topBarItemInjectionToken from "../top-bar-item-injection-token";
import { NavigationToBack } from "./navigation-to-back";
const navigationToBackTopBarItemInjectable = getInjectable({
id: "navigation-to-back-top-bar-item",
instantiate: () => ({
id: "navigation-to-back",
isShown: computed(() => true),
orderNumber: 30,
Component: NavigationToBack,
}),
injectionToken: topBarItemInjectionToken,
});
export default navigationToBackTopBarItemInjectable;

View File

@ -0,0 +1,39 @@
/**
* Copyright (c) OpenLens Authors. All rights reserved.
* Licensed under MIT License. See LICENSE in root directory for more information.
*/
import React from "react";
import { withInjectables } from "@ogre-tools/injectable-react";
import type { IComputedValue } from "mobx";
import { Icon } from "../../../../icon";
import topBarPrevEnabledInjectable from "./prev-enabled.injectable";
import goBackInjectable from "./go-back/go-back.injectable";
import { observer } from "mobx-react";
interface Dependencies {
prevEnabled: IComputedValue<boolean>;
goBack: () => void;
}
const NonInjectedNavigationToBack = observer(({
prevEnabled,
goBack,
}: Dependencies) => (
<Icon
data-testid="history-back"
material="arrow_back"
onClick={goBack}
disabled={!prevEnabled.get()}
/>
));
export const NavigationToBack = withInjectables<Dependencies>(
NonInjectedNavigationToBack,
{
getProps: (di) => ({
prevEnabled: di.inject(topBarPrevEnabledInjectable),
goBack: di.inject(goBackInjectable),
}),
},
);

View File

@ -4,7 +4,7 @@
*/
import { getInjectable } from "@ogre-tools/injectable";
import { computed } from "mobx";
import topBarStateInjectable from "./state.injectable";
import topBarStateInjectable from "../../state.injectable";
const topBarPrevEnabledInjectable = getInjectable({
id: "top-bar-prev-enabled",

View File

@ -15,7 +15,7 @@ import topBarItemsInjectable from "./top-bar-items/top-bar-items.injectable";
import { computed, observable } from "mobx";
import rendererExtensionsInjectable from "../../../../extensions/renderer-extensions.injectable";
import closeWindowInjectable from "./close-window.injectable";
import goBackInjectable from "./go-back.injectable";
import goBackInjectable from "./top-bar-items/navigation-to-back/go-back/go-back.injectable";
import goForwardInjectable from "./go-forward.injectable";
import maximizeWindowInjectable from "./maximize-window.injectable";
import openAppContextMenuInjectable from "./top-bar-items/context-menu/open-app-context-menu/open-app-context-menu.injectable";

View File

@ -15,9 +15,7 @@ import type { TopBarRegistration } from "./top-bar-registration";
import isLinuxInjectable from "../../../../common/vars/is-linux.injectable";
import isWindowsInjectable from "../../../../common/vars/is-windows.injectable";
import { UpdateButton } from "../../../../features/application-update/child-features/application-update-using-top-bar/renderer/update-button";
import topBarPrevEnabledInjectable from "./prev-enabled.injectable";
import topBarNextEnabledInjectable from "./next-enabled.injectable";
import goBackInjectable from "./go-back.injectable";
import goForwardInjectable from "./go-forward.injectable";
import closeWindowInjectable from "./close-window.injectable";
import maximizeWindowInjectable from "./maximize-window.injectable";
@ -33,9 +31,7 @@ interface Dependencies {
items2: IComputedValue<TopBarItem[]>;
isWindows: boolean;
isLinux: boolean;
prevEnabled: IComputedValue<Boolean>;
nextEnabled: IComputedValue<Boolean>;
goBack: () => void;
goForward: () => void;
minimizeWindow: () => void;
toggleMaximizeWindow: () => void;
@ -48,9 +44,7 @@ const NonInjectedTopBar = observer(({
items2,
isWindows,
isLinux,
prevEnabled,
nextEnabled,
goBack,
goForward,
closeWindow,
minimizeWindow,
@ -79,12 +73,6 @@ const NonInjectedTopBar = observer(({
return <Component key={item.id} />;
})}
<Icon
data-testid="history-back"
material="arrow_back"
onClick={goBack}
disabled={!prevEnabled.get()}
/>
<Icon
data-testid="history-forward"
material="arrow_forward"
@ -160,9 +148,7 @@ export const TopBar = withInjectables<Dependencies>(NonInjectedTopBar, {
items2: di.inject(topBarItems2Injectable),
isLinux: di.inject(isLinuxInjectable),
isWindows: di.inject(isWindowsInjectable),
prevEnabled: di.inject(topBarPrevEnabledInjectable),
nextEnabled: di.inject(topBarNextEnabledInjectable),
goBack: di.inject(goBackInjectable),
goForward: di.inject(goForwardInjectable),
closeWindow: di.inject(closeWindowInjectable),
minimizeWindow: di.inject(maximizeWindowInjectable),

View File

@ -38,7 +38,6 @@ import platformInjectable from "../common/vars/platform.injectable";
import startTopbarStateSyncInjectable from "./components/layout/top-bar/start-state-sync.injectable";
import { registerMobX } from "@ogre-tools/injectable-extension-for-mobx";
import watchHistoryStateInjectable from "./remote-helpers/watch-history-state.injectable";
import goBackInjectable from "./components/layout/top-bar/go-back.injectable";
import goForwardInjectable from "./components/layout/top-bar/go-forward.injectable";
import closeWindowInjectable from "./components/layout/top-bar/close-window.injectable";
import maximizeWindowInjectable from "./components/layout/top-bar/maximize-window.injectable";
@ -148,7 +147,6 @@ export const getDiForUnitTesting = (
di.override(environmentVariablesInjectable, () => ({}));
di.override(watchHistoryStateInjectable, () => () => () => {});
di.override(goBackInjectable, () => () => {});
di.override(goForwardInjectable, () => () => {});
di.override(closeWindowInjectable, () => () => {});
di.override(maximizeWindowInjectable, () => () => {});