Files
azuredatastudio/src/vs/workbench/services/layout/browser/layoutService.ts
Karl Burtram ce612a3d96 Merge from vscode 2c306f762bf9c3db82dc06c7afaa56ef46d72f79 (#14050)
* Merge from vscode 2c306f762bf9c3db82dc06c7afaa56ef46d72f79

* Fix breaks

* Extension management fixes

* Fix breaks in windows bundling

* Fix/skip failing tests

* Update distro

* Add clear to nuget.config

* Add hygiene task

* Bump distro

* Fix hygiene issue

* Add build to hygiene exclusion

* Update distro

* Update hygiene

* Hygiene exclusions

* Update tsconfig

* Bump distro for server breaks

* Update build config

* Update darwin path

* Add done calls to notebook tests

* Skip failing tests

* Disable smoke tests
2021-02-09 16:15:05 -08:00

262 lines
6.6 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 { createDecorator } from 'vs/platform/instantiation/common/instantiation';
import { Event } from 'vs/base/common/event';
import { MenuBarVisibility } from 'vs/platform/windows/common/windows';
import { ILayoutService } from 'vs/platform/layout/browser/layoutService';
import { Part } from 'vs/workbench/browser/part';
import { Dimension } from 'vs/base/browser/dom';
import { Direction } from 'vs/base/browser/ui/grid/grid';
export const IWorkbenchLayoutService = createDecorator<IWorkbenchLayoutService>('layoutService');
export const enum Parts {
TITLEBAR_PART = 'workbench.parts.titlebar',
ACTIVITYBAR_PART = 'workbench.parts.activitybar',
SIDEBAR_PART = 'workbench.parts.sidebar',
PANEL_PART = 'workbench.parts.panel',
EDITOR_PART = 'workbench.parts.editor',
STATUSBAR_PART = 'workbench.parts.statusbar'
}
export const enum Position {
LEFT,
RIGHT,
BOTTOM
}
export const enum PanelOpensMaximizedOptions {
ALWAYS,
NEVER,
REMEMBER_LAST
}
export function positionToString(position: Position): string {
switch (position) {
case Position.LEFT: return 'left';
case Position.RIGHT: return 'right';
case Position.BOTTOM: return 'bottom';
default: return 'bottom';
}
}
const positionsByString: { [key: string]: Position } = {
[positionToString(Position.LEFT)]: Position.LEFT,
[positionToString(Position.RIGHT)]: Position.RIGHT,
[positionToString(Position.BOTTOM)]: Position.BOTTOM
};
export function positionFromString(str: string): Position {
return positionsByString[str];
}
export function panelOpensMaximizedSettingToString(setting: PanelOpensMaximizedOptions): string {
switch (setting) {
case PanelOpensMaximizedOptions.ALWAYS: return 'always';
case PanelOpensMaximizedOptions.NEVER: return 'never';
case PanelOpensMaximizedOptions.REMEMBER_LAST: return 'preserve';
default: return 'preserve';
}
}
const panelOpensMaximizedByString: { [key: string]: PanelOpensMaximizedOptions } = {
[panelOpensMaximizedSettingToString(PanelOpensMaximizedOptions.ALWAYS)]: PanelOpensMaximizedOptions.ALWAYS,
[panelOpensMaximizedSettingToString(PanelOpensMaximizedOptions.NEVER)]: PanelOpensMaximizedOptions.NEVER,
[panelOpensMaximizedSettingToString(PanelOpensMaximizedOptions.REMEMBER_LAST)]: PanelOpensMaximizedOptions.REMEMBER_LAST
};
export function panelOpensMaximizedFromString(str: string): PanelOpensMaximizedOptions {
return panelOpensMaximizedByString[str];
}
export interface IWorkbenchLayoutService extends ILayoutService {
readonly _serviceBrand: undefined;
/**
* Emits when the zen mode is enabled or disabled.
*/
readonly onZenModeChange: Event<boolean>;
/**
* Emits when fullscreen is enabled or disabled.
*/
readonly onFullscreenChange: Event<boolean>;
/**
* Emits when the window is maximized or unmaximized.
*/
readonly onMaximizeChange: Event<boolean>;
/**
* Emits when centered layout is enabled or disabled.
*/
readonly onCenteredLayoutChange: Event<boolean>;
/**
* Emit when panel position changes.
*/
readonly onPanelPositionChange: Event<string>;
/**
* Emit when part visibility changes
*/
readonly onPartVisibilityChange: Event<void>;
/**
* Asks the part service if all parts have been fully restored. For editor part
* this means that the contents of editors have loaded.
*/
isRestored(): boolean;
/**
* Returns whether the given part has the keyboard focus or not.
*/
hasFocus(part: Parts): boolean;
/**
* Focuses the part. If the part is not visible this is a noop.
*/
focusPart(part: Parts): void;
/**
* Returns the parts HTML element, if there is one.
*/
getContainer(part: Parts): HTMLElement | undefined;
/**
* Returns if the part is visible.
*/
isVisible(part: Parts): boolean;
/**
* Returns if the part is visible.
*/
getDimension(part: Parts): Dimension | undefined;
/**
* Set activity bar hidden or not
*/
setActivityBarHidden(hidden: boolean): void;
/**
*
* Set editor area hidden or not
*/
setEditorHidden(hidden: boolean): void;
/**
* Set sidebar hidden or not
*/
setSideBarHidden(hidden: boolean): void;
/**
* Set panel part hidden or not
*/
setPanelHidden(hidden: boolean): void;
/**
* Maximizes the panel height if the panel is not already maximized.
* Shrinks the panel to the default starting size if the panel is maximized.
*/
toggleMaximizedPanel(): void;
/**
* Returns true if the window has a border.
*/
hasWindowBorder(): boolean;
/**
* Returns the window border width.
*/
getWindowBorderWidth(): number;
/**
* Returns the window border radius if any.
*/
getWindowBorderRadius(): string | undefined;
/**
* Returns true if the panel is maximized.
*/
isPanelMaximized(): boolean;
/**
* Gets the current side bar position. Note that the sidebar can be hidden too.
*/
getSideBarPosition(): Position;
/**
* Gets the current menubar visibility.
*/
getMenubarVisibility(): MenuBarVisibility;
/**
* Gets the current panel position. Note that the panel can be hidden too.
*/
getPanelPosition(): Position;
/**
* Sets the panel position.
*/
setPanelPosition(position: Position): void;
/**
* Gets the maximum possible size for editor.
*/
getMaximumEditorDimensions(): Dimension;
/**
* Returns the element that is parent of the workbench element.
*/
getWorkbenchContainer(): HTMLElement;
/**
* Toggles the workbench in and out of zen mode - parts get hidden and window goes fullscreen.
*/
toggleZenMode(): void;
/**
* Returns whether the centered editor layout is active.
*/
isEditorLayoutCentered(): boolean;
/**
* Sets the workbench in and out of centered editor layout.
*/
centerEditorLayout(active: boolean): void;
/**
* Resizes currently focused part on main access
*/
resizePart(part: Parts, sizeChangeWidth: number, sizeChangeHeight: number): void;
/**
* Register a part to participate in the layout.
*/
registerPart(part: Part): void;
/**
* Returns whether the window is maximized.
*/
isWindowMaximized(): boolean;
/**
* Updates the maximized state of the window.
*/
updateWindowMaximizedState(maximized: boolean): void;
/**
* Returns the next visible view part in a given direction
*/
getVisibleNeighborPart(part: Parts, direction: Direction): Parts | undefined;
/**
* True if a default layout with default editors was applied at startup
*/
readonly openedDefaultEditors: boolean;
}