Files
vscode/src/vs/workbench/common/component.ts
Johannes Rieken 6681a2a7d6 tsfmt - src
2016-10-08 09:53:13 +02:00

95 lines
3.0 KiB
TypeScript

/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
'use strict';
import { IDisposable, dispose, Disposable } from 'vs/base/common/lifecycle';
import { Scope, Memento } from 'vs/workbench/common/memento';
import { IStorageService } from 'vs/platform/storage/common/storage';
/**
* Base class of any core/ui component in the workbench. Examples include services, extensions, parts, viewlets and quick open.
* Provides some convinience methods to participate in the workbench lifecycle (dispose, shutdown) and
* loading and saving settings through memento.
*/
export interface IWorkbenchComponent extends IDisposable {
/**
* The unique identifier of this component.
*/
getId(): string;
/**
* Returns a JSON Object that represents the data of this memento. The optional
* parameter scope allows to specify the scope of the memento to load. If not
* provided, the scope will be global, Scope.WORKSPACE can be used to
* scope the memento to the workspace.
*
* Mementos are shared across components with the same id. This means that multiple components
* with the same id will store data into the same data structure.
*/
getMemento(storageService: IStorageService, scope?: Scope): any;
/**
* Saves all data of the mementos that have been loaded to the local storage. This includes
* global and workspace scope.
*
* Mementos are shared across components with the same id. This means that multiple components
* with the same id will store data into the same data structure.
*/
saveMemento(): void;
/**
* Called when the browser containing the container is closed.
*
* Use this function to store settings that you want to restore next time. Should not be used to free resources
* because dispose() is being called for this purpose and shutdown() has a chance to be vetoed by the user.
*/
shutdown(): void;
/**
* Called when the UI component is being removed from the container. Free up resources from here.
*/
dispose(): void;
}
export class WorkbenchComponent extends Disposable implements IWorkbenchComponent {
private _toUnbind: IDisposable[];
private id: string;
private componentMemento: Memento;
constructor(id: string) {
super();
this._toUnbind = [];
this.id = id;
this.componentMemento = new Memento(this.id);
}
public get toUnbind() {
return this._toUnbind;
}
public getId(): string {
return this.id;
}
public getMemento(storageService: IStorageService, scope: Scope = Scope.GLOBAL): any {
return this.componentMemento.getMemento(storageService, scope);
}
public saveMemento(): void {
this.componentMemento.saveMemento();
}
public shutdown(): void {
// Save Memento
this.saveMemento();
}
public dispose(): void {
this._toUnbind = dispose(this._toUnbind);
super.dispose();
}
}