extensionsList.ts 3.4 KB
Newer Older
J
Joao Moreno 已提交
1 2 3 4 5 6 7 8
/*---------------------------------------------------------------------------------------------
 *  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 { append, emmet as $, addClass, removeClass } from 'vs/base/browser/dom';
J
Joao Moreno 已提交
9 10
import { IDisposable, dispose } from 'vs/base/common/lifecycle';
import { ActionBar } from 'vs/base/browser/ui/actionbar/actionbar';
J
Joao Moreno 已提交
11 12 13
import { IInstantiationService } from 'vs/platform/instantiation/common/instantiation';
import { IDelegate } from 'vs/base/browser/ui/list/list';
import { IPagedRenderer } from 'vs/base/browser/ui/list/listPaging';
J
Joao Moreno 已提交
14 15
import { IExtension, ExtensionsModel } from './extensionsModel';
import { InstallAction } from './extensionsActions';
J
Joao Moreno 已提交
16 17

export interface ITemplateData {
J
Joao Moreno 已提交
18
	extension: IExtension;
J
Joao Moreno 已提交
19 20 21 22 23 24
	element: HTMLElement;
	icon: HTMLImageElement;
	name: HTMLElement;
	version: HTMLElement;
	author: HTMLElement;
	description: HTMLElement;
J
Joao Moreno 已提交
25 26
	actionbar: ActionBar;
	disposables: IDisposable[];
J
Joao Moreno 已提交
27 28
}

J
Joao Moreno 已提交
29
export class Delegate implements IDelegate<IExtension> {
J
Joao Moreno 已提交
30
	getHeight() { return 62; }
J
Joao Moreno 已提交
31 32 33
	getTemplateId() { return 'extension'; }
}

J
Joao Moreno 已提交
34
export class Renderer implements IPagedRenderer<IExtension, ITemplateData> {
J
Joao Moreno 已提交
35 36 37 38 39

	private _templates: ITemplateData[];
	get templates(): ITemplateData[] { return this._templates; }

	constructor(
J
Joao Moreno 已提交
40
		private model: ExtensionsModel,
J
Joao Moreno 已提交
41 42 43 44 45 46 47 48
		@IInstantiationService private instantiationService: IInstantiationService
	) {
		this._templates = [];
	}

	get templateId() { return 'extension'; }

	renderTemplate(root: HTMLElement): ITemplateData {
J
Joao Moreno 已提交
49 50 51 52 53 54 55 56
		const element = append(root, $('.extension'));
		const icon = append(element, $<HTMLImageElement>('img.icon'));
		const details = append(element, $('.details'));
		const header = append(details, $('.header'));
		const name = append(header, $('span.name.ellipsis'));
		const version = append(header, $('span.version.ellipsis'));
		const author = append(header, $('span.author.ellipsis'));
		const description = append(details, $('.description.ellipsis'));
J
Joao Moreno 已提交
57 58
		const actionbar = new ActionBar(details);
		const disposables = [];
J
Joao Moreno 已提交
59

J
Joao Moreno 已提交
60
		const result = { extension: null, element, icon, name, version, author, description, actionbar, disposables };
J
Joao Moreno 已提交
61 62 63 64 65
		this._templates.push(result);
		return result;
	}

	renderPlaceholder(index: number, data: ITemplateData): void {
J
Joao Moreno 已提交
66 67
		data.disposables = dispose(data.disposables);

J
Joao Moreno 已提交
68 69
		addClass(data.element, 'loading');
		data.extension = null;
J
Joao Moreno 已提交
70
		data.icon.src = '';
J
Joao Moreno 已提交
71 72 73 74
		data.name.textContent = '';
		data.version.textContent = '';
		data.author.textContent = '';
		data.description.textContent = '';
J
Joao Moreno 已提交
75
		data.actionbar.clear();
J
Joao Moreno 已提交
76 77
	}

J
Joao Moreno 已提交
78
	renderElement(extension: IExtension, index: number, data: ITemplateData): void {
J
Joao Moreno 已提交
79
		data.disposables = dispose(data.disposables);
J
Joao Moreno 已提交
80

J
Joao Moreno 已提交
81 82
		removeClass(data.element, 'loading');
		data.extension = extension;
J
Joao Moreno 已提交
83 84 85 86
		data.icon.src = extension.iconUrl;
		data.name.textContent = extension.displayName;
		data.version.textContent = extension.version;
		data.author.textContent = extension.publisherDisplayName;
J
Joao Moreno 已提交
87
		data.description.textContent = extension.description;
J
Joao Moreno 已提交
88 89
		data.actionbar.clear();
		data.actionbar.push(new InstallAction(this.model, extension));
J
Joao Moreno 已提交
90 91 92 93 94 95 96 97 98 99
	}

	disposeTemplate(data: ITemplateData): void {
		const index = this._templates.indexOf(data);

		if (index > -1) {
			this._templates.splice(index, 1);
		}
	}
}