mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Extract top menu item for navigating to forward 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:
parent
c132ceaf2b
commit
b8b14d82c3
@ -0,0 +1,8 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||||
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
|
*/
|
||||||
|
import goForwardInjectable from "./go-forward.injectable";
|
||||||
|
import { getGlobalOverrideForFunction } from "../../../../../../../common/test-utils/get-global-override-for-function";
|
||||||
|
|
||||||
|
export default getGlobalOverrideForFunction(goForwardInjectable);
|
||||||
@ -3,8 +3,8 @@
|
|||||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
*/
|
*/
|
||||||
import { getInjectable } from "@ogre-tools/injectable";
|
import { getInjectable } from "@ogre-tools/injectable";
|
||||||
import { WindowAction } from "../../../../common/ipc/window";
|
import { WindowAction } from "../../../../../../../common/ipc/window";
|
||||||
import { requestWindowAction } from "../../../ipc";
|
import { requestWindowAction } from "../../../../../../ipc";
|
||||||
|
|
||||||
const goForwardInjectable = getInjectable({
|
const goForwardInjectable = getInjectable({
|
||||||
id: "go-forward",
|
id: "go-forward",
|
||||||
@ -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 { NavigationToForward } from "./navigation-to-forward";
|
||||||
|
|
||||||
|
const navigationToForwardTopBarItemInjectable = getInjectable({
|
||||||
|
id: "navigation-to-forward-top-bar-item",
|
||||||
|
|
||||||
|
instantiate: () => ({
|
||||||
|
id: "navigation-to-forward",
|
||||||
|
isShown: computed(() => true),
|
||||||
|
orderNumber: 40,
|
||||||
|
Component: NavigationToForward,
|
||||||
|
}),
|
||||||
|
|
||||||
|
injectionToken: topBarItemInjectionToken,
|
||||||
|
});
|
||||||
|
|
||||||
|
export default navigationToForwardTopBarItemInjectable;
|
||||||
@ -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 topBarNextEnabledInjectable from "./next-enabled.injectable";
|
||||||
|
import goForwardInjectable from "./go-forward/go-forward.injectable";
|
||||||
|
import { observer } from "mobx-react";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
nextEnabled: IComputedValue<boolean>;
|
||||||
|
goForward: () => void;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedNavigationToForward = observer(({
|
||||||
|
nextEnabled,
|
||||||
|
goForward,
|
||||||
|
}: Dependencies) => (
|
||||||
|
<Icon
|
||||||
|
data-testid="history-forward"
|
||||||
|
material="arrow_forward"
|
||||||
|
onClick={goForward}
|
||||||
|
disabled={!nextEnabled.get()}
|
||||||
|
/>
|
||||||
|
));
|
||||||
|
|
||||||
|
export const NavigationToForward = withInjectables<Dependencies>(
|
||||||
|
NonInjectedNavigationToForward,
|
||||||
|
|
||||||
|
{
|
||||||
|
getProps: (di) => ({
|
||||||
|
nextEnabled: di.inject(topBarNextEnabledInjectable),
|
||||||
|
goForward: di.inject(goForwardInjectable),
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
);
|
||||||
@ -4,7 +4,7 @@
|
|||||||
*/
|
*/
|
||||||
import { getInjectable } from "@ogre-tools/injectable";
|
import { getInjectable } from "@ogre-tools/injectable";
|
||||||
import { computed } from "mobx";
|
import { computed } from "mobx";
|
||||||
import topBarStateInjectable from "./state.injectable";
|
import topBarStateInjectable from "../../state.injectable";
|
||||||
|
|
||||||
const topBarNextEnabledInjectable = getInjectable({
|
const topBarNextEnabledInjectable = getInjectable({
|
||||||
id: "top-bar-next-enabled",
|
id: "top-bar-next-enabled",
|
||||||
@ -16,12 +16,13 @@ import { computed, observable } from "mobx";
|
|||||||
import rendererExtensionsInjectable from "../../../../extensions/renderer-extensions.injectable";
|
import rendererExtensionsInjectable from "../../../../extensions/renderer-extensions.injectable";
|
||||||
import closeWindowInjectable from "./close-window.injectable";
|
import closeWindowInjectable from "./close-window.injectable";
|
||||||
import goBackInjectable from "./top-bar-items/navigation-to-back/go-back/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 maximizeWindowInjectable from "./maximize-window.injectable";
|
||||||
import openAppContextMenuInjectable from "./top-bar-items/context-menu/open-app-context-menu/open-app-context-menu.injectable";
|
import openAppContextMenuInjectable from "./top-bar-items/context-menu/open-app-context-menu/open-app-context-menu.injectable";
|
||||||
import toggleMaximizeWindowInjectable from "./toggle-maximize-window.injectable";
|
import toggleMaximizeWindowInjectable from "./toggle-maximize-window.injectable";
|
||||||
import topBarStateInjectable from "./state.injectable";
|
import topBarStateInjectable from "./state.injectable";
|
||||||
import platformInjectable from "../../../../common/vars/platform.injectable";
|
import platformInjectable from "../../../../common/vars/platform.injectable";
|
||||||
|
import goForwardInjectable
|
||||||
|
from "./top-bar-items/navigation-to-forward/go-forward/go-forward.injectable";
|
||||||
|
|
||||||
describe("<TopBar/>", () => {
|
describe("<TopBar/>", () => {
|
||||||
let di: DiContainer;
|
let di: DiContainer;
|
||||||
|
|||||||
@ -7,7 +7,6 @@ import styles from "./top-bar.module.scss";
|
|||||||
import React, { useEffect, useRef } from "react";
|
import React, { useEffect, useRef } from "react";
|
||||||
import { observer } from "mobx-react";
|
import { observer } from "mobx-react";
|
||||||
import type { IComputedValue } from "mobx";
|
import type { IComputedValue } from "mobx";
|
||||||
import { Icon } from "../../icon";
|
|
||||||
import { cssNames } from "../../../utils";
|
import { cssNames } from "../../../utils";
|
||||||
import topBarItemsInjectable from "./top-bar-items/top-bar-items.injectable";
|
import topBarItemsInjectable from "./top-bar-items/top-bar-items.injectable";
|
||||||
import { withInjectables } from "@ogre-tools/injectable-react";
|
import { withInjectables } from "@ogre-tools/injectable-react";
|
||||||
@ -15,8 +14,6 @@ import type { TopBarRegistration } from "./top-bar-registration";
|
|||||||
import isLinuxInjectable from "../../../../common/vars/is-linux.injectable";
|
import isLinuxInjectable from "../../../../common/vars/is-linux.injectable";
|
||||||
import isWindowsInjectable from "../../../../common/vars/is-windows.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 { UpdateButton } from "../../../../features/application-update/child-features/application-update-using-top-bar/renderer/update-button";
|
||||||
import topBarNextEnabledInjectable from "./next-enabled.injectable";
|
|
||||||
import goForwardInjectable from "./go-forward.injectable";
|
|
||||||
import closeWindowInjectable from "./close-window.injectable";
|
import closeWindowInjectable from "./close-window.injectable";
|
||||||
import maximizeWindowInjectable from "./maximize-window.injectable";
|
import maximizeWindowInjectable from "./maximize-window.injectable";
|
||||||
import toggleMaximizeWindowInjectable from "./toggle-maximize-window.injectable";
|
import toggleMaximizeWindowInjectable from "./toggle-maximize-window.injectable";
|
||||||
@ -31,8 +28,6 @@ interface Dependencies {
|
|||||||
items2: IComputedValue<TopBarItem[]>;
|
items2: IComputedValue<TopBarItem[]>;
|
||||||
isWindows: boolean;
|
isWindows: boolean;
|
||||||
isLinux: boolean;
|
isLinux: boolean;
|
||||||
nextEnabled: IComputedValue<Boolean>;
|
|
||||||
goForward: () => void;
|
|
||||||
minimizeWindow: () => void;
|
minimizeWindow: () => void;
|
||||||
toggleMaximizeWindow: () => void;
|
toggleMaximizeWindow: () => void;
|
||||||
closeWindow: () => void;
|
closeWindow: () => void;
|
||||||
@ -44,8 +39,6 @@ const NonInjectedTopBar = observer(({
|
|||||||
items2,
|
items2,
|
||||||
isWindows,
|
isWindows,
|
||||||
isLinux,
|
isLinux,
|
||||||
nextEnabled,
|
|
||||||
goForward,
|
|
||||||
closeWindow,
|
closeWindow,
|
||||||
minimizeWindow,
|
minimizeWindow,
|
||||||
toggleMaximizeWindow,
|
toggleMaximizeWindow,
|
||||||
@ -73,12 +66,6 @@ const NonInjectedTopBar = observer(({
|
|||||||
return <Component key={item.id} />;
|
return <Component key={item.id} />;
|
||||||
})}
|
})}
|
||||||
|
|
||||||
<Icon
|
|
||||||
data-testid="history-forward"
|
|
||||||
material="arrow_forward"
|
|
||||||
onClick={goForward}
|
|
||||||
disabled={!nextEnabled.get()}
|
|
||||||
/>
|
|
||||||
<UpdateButton />
|
<UpdateButton />
|
||||||
</div>
|
</div>
|
||||||
<div className={styles.items}>
|
<div className={styles.items}>
|
||||||
@ -148,8 +135,6 @@ export const TopBar = withInjectables<Dependencies>(NonInjectedTopBar, {
|
|||||||
items2: di.inject(topBarItems2Injectable),
|
items2: di.inject(topBarItems2Injectable),
|
||||||
isLinux: di.inject(isLinuxInjectable),
|
isLinux: di.inject(isLinuxInjectable),
|
||||||
isWindows: di.inject(isWindowsInjectable),
|
isWindows: di.inject(isWindowsInjectable),
|
||||||
nextEnabled: di.inject(topBarNextEnabledInjectable),
|
|
||||||
goForward: di.inject(goForwardInjectable),
|
|
||||||
closeWindow: di.inject(closeWindowInjectable),
|
closeWindow: di.inject(closeWindowInjectable),
|
||||||
minimizeWindow: di.inject(maximizeWindowInjectable),
|
minimizeWindow: di.inject(maximizeWindowInjectable),
|
||||||
toggleMaximizeWindow: di.inject(toggleMaximizeWindowInjectable),
|
toggleMaximizeWindow: di.inject(toggleMaximizeWindowInjectable),
|
||||||
|
|||||||
@ -38,7 +38,6 @@ import platformInjectable from "../common/vars/platform.injectable";
|
|||||||
import startTopbarStateSyncInjectable from "./components/layout/top-bar/start-state-sync.injectable";
|
import startTopbarStateSyncInjectable from "./components/layout/top-bar/start-state-sync.injectable";
|
||||||
import { registerMobX } from "@ogre-tools/injectable-extension-for-mobx";
|
import { registerMobX } from "@ogre-tools/injectable-extension-for-mobx";
|
||||||
import watchHistoryStateInjectable from "./remote-helpers/watch-history-state.injectable";
|
import watchHistoryStateInjectable from "./remote-helpers/watch-history-state.injectable";
|
||||||
import goForwardInjectable from "./components/layout/top-bar/go-forward.injectable";
|
|
||||||
import closeWindowInjectable from "./components/layout/top-bar/close-window.injectable";
|
import closeWindowInjectable from "./components/layout/top-bar/close-window.injectable";
|
||||||
import maximizeWindowInjectable from "./components/layout/top-bar/maximize-window.injectable";
|
import maximizeWindowInjectable from "./components/layout/top-bar/maximize-window.injectable";
|
||||||
import toggleMaximizeWindowInjectable from "./components/layout/top-bar/toggle-maximize-window.injectable";
|
import toggleMaximizeWindowInjectable from "./components/layout/top-bar/toggle-maximize-window.injectable";
|
||||||
@ -147,7 +146,6 @@ export const getDiForUnitTesting = (
|
|||||||
|
|
||||||
di.override(environmentVariablesInjectable, () => ({}));
|
di.override(environmentVariablesInjectable, () => ({}));
|
||||||
di.override(watchHistoryStateInjectable, () => () => () => {});
|
di.override(watchHistoryStateInjectable, () => () => () => {});
|
||||||
di.override(goForwardInjectable, () => () => {});
|
|
||||||
di.override(closeWindowInjectable, () => () => {});
|
di.override(closeWindowInjectable, () => () => {});
|
||||||
di.override(maximizeWindowInjectable, () => () => {});
|
di.override(maximizeWindowInjectable, () => () => {});
|
||||||
di.override(toggleMaximizeWindowInjectable, () => () => {});
|
di.override(toggleMaximizeWindowInjectable, () => () => {});
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user