extensionsList.ts 3.8 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
import { IExtension, ExtensionsModel } from './extensionsModel';
J
Joao Moreno 已提交
15
import { CombinedInstallAction, UpdateAction } from './extensionsActions';
J
Joao Moreno 已提交
16
import { Label } from './extensionsWidgets';
J
Joao Moreno 已提交
17 18

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

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

J
Joao Moreno 已提交
35 36
const actionOptions = { icon: true, label: false };

J
Joao Moreno 已提交
37
export class Renderer implements IPagedRenderer<IExtension, ITemplateData> {
J
Joao Moreno 已提交
38 39 40 41 42

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

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

	get templateId() { return 'extension'; }

	renderTemplate(root: HTMLElement): ITemplateData {
J
Joao Moreno 已提交
52
		const element = append(root, $('.extension'));
J
Joao Moreno 已提交
53
		const icon = append(element, $('.icon'));
J
Joao Moreno 已提交
54 55 56 57 58 59
		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 已提交
60 61
		const actionbar = new ActionBar(details);
		const disposables = [];
J
Joao Moreno 已提交
62

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

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

J
Joao Moreno 已提交
71 72
		addClass(data.element, 'loading');
		data.extension = null;
J
Joao Moreno 已提交
73
		data.icon.style.backgroundImage = '';
J
Joao Moreno 已提交
74 75 76 77
		data.name.textContent = '';
		data.version.textContent = '';
		data.author.textContent = '';
		data.description.textContent = '';
J
Joao Moreno 已提交
78
		data.actionbar.clear();
J
Joao Moreno 已提交
79 80
	}

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

J
Joao Moreno 已提交
84 85
		removeClass(data.element, 'loading');
		data.extension = extension;
J
Joao Moreno 已提交
86
		data.icon.style.backgroundImage = `url("${ extension.iconUrl }")`;
J
Joao Moreno 已提交
87 88
		data.name.textContent = extension.displayName;
		data.author.textContent = extension.publisherDisplayName;
J
Joao Moreno 已提交
89
		data.description.textContent = extension.description;
J
Joao Moreno 已提交
90
		data.actionbar.clear();
J
Joao Moreno 已提交
91

J
Joao Moreno 已提交
92 93
		const version = new Label(data.version, this.model, extension, e => e.version);

J
Joao Moreno 已提交
94
		const installAction = new CombinedInstallAction(this.model, extension);
J
Joao Moreno 已提交
95 96
		const updateAction = new UpdateAction(this.model, extension);
		data.actionbar.push([updateAction, installAction], actionOptions);
J
Joao Moreno 已提交
97 98

		data.disposables.push(version, installAction, updateAction);
J
Joao Moreno 已提交
99 100 101 102 103 104 105 106 107 108
	}

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

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