mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-09 01:32:34 -05:00
117 lines
3.3 KiB
TypeScript
117 lines
3.3 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import { Registry } from 'vs/platform/registry/common/platform';
|
|
import { IPanel } from 'vs/workbench/common/panel';
|
|
import { Composite, CompositeDescriptor, CompositeRegistry } from 'vs/workbench/browser/composite';
|
|
import { Action } from 'vs/base/common/actions';
|
|
import { IPanelService } from 'vs/workbench/services/panel/common/panelService';
|
|
import { IWorkbenchLayoutService, Parts } from 'vs/workbench/services/layout/browser/layoutService';
|
|
import { IConstructorSignature0 } from 'vs/platform/instantiation/common/instantiation';
|
|
import { isAncestor } from 'vs/base/browser/dom';
|
|
|
|
export abstract class Panel extends Composite implements IPanel { }
|
|
|
|
/**
|
|
* A panel descriptor is a leightweight descriptor of a panel in the workbench.
|
|
*/
|
|
export class PanelDescriptor extends CompositeDescriptor<Panel> {
|
|
|
|
constructor(ctor: IConstructorSignature0<Panel>, id: string, name: string, cssClass?: string, order?: number, _commandId?: string) {
|
|
super(ctor, id, name, cssClass, order, _commandId);
|
|
}
|
|
}
|
|
|
|
export class PanelRegistry extends CompositeRegistry<Panel> {
|
|
private defaultPanelId: string;
|
|
|
|
/**
|
|
* Registers a panel to the platform.
|
|
*/
|
|
registerPanel(descriptor: PanelDescriptor): void {
|
|
super.registerComposite(descriptor);
|
|
}
|
|
|
|
/**
|
|
* Deregisters a panel to the platform.
|
|
*/
|
|
deregisterPanel(id: string): void {
|
|
super.deregisterComposite(id);
|
|
}
|
|
|
|
/**
|
|
* Returns an array of registered panels known to the platform.
|
|
*/
|
|
getPanels(): PanelDescriptor[] {
|
|
return this.getComposites();
|
|
}
|
|
|
|
/**
|
|
* Sets the id of the panel that should open on startup by default.
|
|
*/
|
|
setDefaultPanelId(id: string): void {
|
|
this.defaultPanelId = id;
|
|
}
|
|
|
|
/**
|
|
* Gets the id of the panel that should open on startup by default.
|
|
*/
|
|
getDefaultPanelId(): string {
|
|
return this.defaultPanelId;
|
|
}
|
|
|
|
/**
|
|
* Find out if a panel exists with the provided ID.
|
|
*/
|
|
hasPanel(id: string): boolean {
|
|
return this.getPanels().some(panel => panel.id === id);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* A reusable action to toggle a panel with a specific id depending on focus.
|
|
*/
|
|
export abstract class TogglePanelAction extends Action {
|
|
|
|
constructor(
|
|
id: string,
|
|
label: string,
|
|
private readonly panelId: string,
|
|
protected panelService: IPanelService,
|
|
private layoutService: IWorkbenchLayoutService,
|
|
cssClass?: string
|
|
) {
|
|
super(id, label, cssClass);
|
|
}
|
|
|
|
run(): Promise<any> {
|
|
if (this.isPanelFocused()) {
|
|
this.layoutService.setPanelHidden(true);
|
|
} else {
|
|
this.panelService.openPanel(this.panelId, true);
|
|
}
|
|
|
|
return Promise.resolve();
|
|
}
|
|
|
|
private isPanelActive(): boolean {
|
|
const activePanel = this.panelService.getActivePanel();
|
|
|
|
return !!activePanel && activePanel.getId() === this.panelId;
|
|
}
|
|
|
|
private isPanelFocused(): boolean {
|
|
const activeElement = document.activeElement;
|
|
|
|
return !!(this.isPanelActive() && activeElement && isAncestor(activeElement, this.layoutService.getContainer(Parts.PANEL_PART)));
|
|
}
|
|
}
|
|
|
|
export const Extensions = {
|
|
Panels: 'workbench.contributions.panels'
|
|
};
|
|
|
|
Registry.add(Extensions.Panels, new PanelRegistry());
|