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 15 16 17 18 19 20 21 22
	EDITOR_PART,
	STATUSBAR_PART
}

export enum Position {
	LEFT,
	RIGHT
}

B
Benjamin Pasero 已提交
23
export const IPartService = createDecorator<IPartService>('partService');
E
Erich Gamma 已提交
24 25

export interface IPartService {
J
Johannes Rieken 已提交
26
	_serviceBrand: ServiceIdentifier<any>;
E
Erich Gamma 已提交
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43

	/**
	 * Asks the part service to layout all parts.
	 */
	layout(): void;

	/**
	 * 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 已提交
44
	 * Returns whether the given part has the keyboard focus or not.
E
Erich Gamma 已提交
45 46 47
	 */
	hasFocus(part: Parts): boolean;

48 49 50 51 52
	/**
	 * Returns the parts HTML element, if there is one.
	 */
	getContainer(part: Parts): HTMLElement;

E
Erich Gamma 已提交
53 54 55 56 57
	/**
	 * Returns iff the part is visible.
	 */
	isVisible(part: Parts): boolean;

S
Sanders Lauture 已提交
58 59 60 61 62 63 64 65 66 67
	/**
	 * Checks if the activity bar is currently hidden or not
	 */
	isActivityBarHidden(): boolean;

	/**
	 * Set activity bar hidden or not
	 */
	setActivityBarHidden(hidden: boolean): void;

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

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

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

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

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

I
isidor 已提交
93 94 95 96 97 98
	/**
	 * 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 已提交
99 100 101 102 103 104 105 106 107 108 109 110 111 112
	/**
	 * 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;
113 114 115 116 117

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

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