partService.ts 2.7 KB
Newer Older
E
Erich Gamma 已提交
1 2 3 4 5 6
/*---------------------------------------------------------------------------------------------
 *  Copyright (c) Microsoft Corporation. All rights reserved.
 *  Licensed under the MIT License. See License.txt in the project root for license information.
 *--------------------------------------------------------------------------------------------*/
'use strict';

J
Johannes Rieken 已提交
7 8
import { TPromise } from 'vs/base/common/winjs.base';
import { createDecorator, ServiceIdentifier } from 'vs/platform/instantiation/common/instantiation';
E
Erich Gamma 已提交
9 10 11 12

export enum Parts {
	ACTIVITYBAR_PART,
	SIDEBAR_PART,
I
isidor 已提交
13
	PANEL_PART,
E
Erich Gamma 已提交
14
	EDITOR_PART,
B
Benjamin Pasero 已提交
15 16
	STATUSBAR_PART,
	TITLEBAR_PART
E
Erich Gamma 已提交
17 18 19 20 21 22 23
}

export enum Position {
	LEFT,
	RIGHT
}

B
Benjamin Pasero 已提交
24 25 26 27 28
export interface ILayoutOptions {
	forceStyleRecompute?: boolean;
	toggleMaximizedPanel?: boolean;
}

B
Benjamin Pasero 已提交
29
export const IPartService = createDecorator<IPartService>('partService');
E
Erich Gamma 已提交
30 31

export interface IPartService {
J
Johannes Rieken 已提交
32
	_serviceBrand: ServiceIdentifier<any>;
E
Erich Gamma 已提交
33 34 35 36

	/**
	 * Asks the part service to layout all parts.
	 */
B
Benjamin Pasero 已提交
37
	layout(options?: ILayoutOptions): void;
E
Erich Gamma 已提交
38 39 40 41 42 43 44 45 46 47 48 49

	/**
	 * Asks the part service to if all parts have been created.
	 */
	isCreated(): boolean;

	/**
	 * Promise is complete when all parts have been created.
	 */
	joinCreation(): TPromise<boolean>;

	/**
P
Pascal Borreli 已提交
50
	 * Returns whether the given part has the keyboard focus or not.
E
Erich Gamma 已提交
51 52 53
	 */
	hasFocus(part: Parts): boolean;

54 55 56 57 58
	/**
	 * Returns the parts HTML element, if there is one.
	 */
	getContainer(part: Parts): HTMLElement;

E
Erich Gamma 已提交
59 60 61 62 63
	/**
	 * Returns iff the part is visible.
	 */
	isVisible(part: Parts): boolean;

B
Benjamin Pasero 已提交
64
	/**
65
	 * Returns iff the custom titlebar part is visible.
B
Benjamin Pasero 已提交
66 67 68
	 */
	isTitleBarHidden(): boolean;

69 70 71 72 73
	/**
	 * Checks if the statusbar is currently hidden or not
	 */
	isStatusBarHidden(): boolean;

E
Erich Gamma 已提交
74 75 76 77 78 79 80 81 82 83
	/**
	 * Checks if the sidebar is currently hidden or not
	 */
	isSideBarHidden(): boolean;

	/**
	 * Set sidebar hidden or not
	 */
	setSideBarHidden(hidden: boolean): void;

I
isidor 已提交
84 85 86
	/**
	 * Checks if the panel part is currently hidden or not
	 */
I
isidor 已提交
87
	isPanelHidden(): boolean;
I
isidor 已提交
88 89 90 91

	/**
	 * Set panel part hidden or not
	 */
I
isidor 已提交
92
	setPanelHidden(hidden: boolean): void;
I
isidor 已提交
93

I
isidor 已提交
94 95 96 97 98 99
	/**
	 * 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;

E
Erich Gamma 已提交
100 101 102 103 104 105 106 107 108 109 110 111 112 113
	/**
	 * Gets the current side bar position. Note that the sidebar can be hidden too.
	 */
	getSideBarPosition(): Position;

	/**
	 * Adds a class to the workbench part.
	 */
	addClass(clazz: string): void;

	/**
	 * Removes a class from the workbench part.
	 */
	removeClass(clazz: string): void;
114 115 116 117 118

	/**
	 * Returns the identifier of the element that contains the workbench.
	 */
	getWorkbenchElementId(): string;
119 120 121 122 123

	/**
	 * Enables to restore the contents of the sidebar after a restart.
	 */
	setRestoreSidebar(): void;
E
Erich Gamma 已提交
124
}