import "./command-container.scss"; import { action, observable } from "mobx"; import { observer } from "mobx-react"; import React from "react"; import { Dialog } from "../dialog"; import { EventEmitter } from "../../../common/event-emitter"; import { subscribeToBroadcast } from "../../../common/ipc"; import { CommandDialog } from "./command-dialog"; import { CommandRegistration, commandRegistry } from "../../../extensions/registries/command-registry"; import { clusterStore } from "../../../common/cluster-store"; import { workspaceStore } from "../../../common/workspace-store"; export type CommandDialogEvent = { component: React.ReactElement }; const commandDialogBus = new EventEmitter<[CommandDialogEvent]>(); export class CommandOverlay { static open(component: React.ReactElement) { commandDialogBus.emit({ component }); } static close() { commandDialogBus.emit({ component: null }); } } @observer export class CommandContainer extends React.Component<{ clusterId?: string }> { @observable.ref commandComponent: React.ReactElement; private escHandler(event: KeyboardEvent) { if (event.key === "Escape") { event.stopPropagation(); this.closeDialog(); } } @action private closeDialog() { this.commandComponent = null; } private findCommandById(commandId: string) { return commandRegistry.getItems().find((command) => command.id === commandId); } private runCommand(command: CommandRegistration) { command.action({ cluster: clusterStore.active, workspace: workspaceStore.currentWorkspace }); } componentDidMount() { if (this.props.clusterId) { subscribeToBroadcast(`command-palette:run-action:${this.props.clusterId}`, (event, commandId: string) => { const command = this.findCommandById(commandId); if (command) { this.runCommand(command); } }); } else { subscribeToBroadcast("command-palette:open", () => { CommandOverlay.open(); }); } window.addEventListener("keyup", (e) => this.escHandler(e), true); commandDialogBus.addListener((event) => { this.commandComponent = event.component; }); } render() { return ( this.commandComponent = null}>
{this.commandComponent}
); } }