extensionsList.ts 5.4 KB
Newer Older
J
Joao Moreno 已提交
1 2 3 4 5 6 7
/*---------------------------------------------------------------------------------------------
 *  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
Joao Moreno 已提交
8
import { append, $, 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
import { IInstantiationService } from 'vs/platform/instantiation/common/instantiation';
12
import { IMessageService, Severity } from 'vs/platform/message/common/message';
J
Joao Moreno 已提交
13 14
import { IDelegate } from 'vs/base/browser/ui/list/list';
import { IPagedRenderer } from 'vs/base/browser/ui/list/listPaging';
15 16
import { once } from 'vs/base/common/event';
import { domEvent } from 'vs/base/browser/event';
17
import { IExtension } from './extensions';
J
Joao Moreno 已提交
18
import { CombinedInstallAction, UpdateAction, EnableAction, BuiltinStatusLabelAction } from './extensionsActions';
19
import { Label, RatingsWidget, InstallWidget } from './extensionsWidgets';
20
import { EventType } from 'vs/base/common/events';
J
Joao Moreno 已提交
21 22 23

export interface ITemplateData {
	element: HTMLElement;
24
	icon: HTMLImageElement;
J
Joao Moreno 已提交
25
	name: HTMLElement;
26 27
	installCount: HTMLElement;
	ratings: HTMLElement;
J
Joao Moreno 已提交
28 29
	author: HTMLElement;
	description: HTMLElement;
J
Joao Moreno 已提交
30
	extension: IExtension;
J
Joao Moreno 已提交
31
	disposables: IDisposable[];
32
	extensionDisposables: IDisposable[];
J
Joao Moreno 已提交
33 34
}

J
Joao Moreno 已提交
35
export class Delegate implements IDelegate<IExtension> {
J
Joao Moreno 已提交
36
	getHeight() { return 62; }
J
Joao Moreno 已提交
37 38 39
	getTemplateId() { return 'extension'; }
}

J
Joao Moreno 已提交
40
const actionOptions = { icon: true, label: true };
J
Joao Moreno 已提交
41

J
Joao Moreno 已提交
42
export class Renderer implements IPagedRenderer<IExtension, ITemplateData> {
J
Joao Moreno 已提交
43

44 45 46 47
	constructor(
		@IInstantiationService private instantiationService: IInstantiationService,
		@IMessageService private messageService: IMessageService
	) {}
J
Joao Moreno 已提交
48 49 50 51

	get templateId() { return 'extension'; }

	renderTemplate(root: HTMLElement): ITemplateData {
J
Joao Moreno 已提交
52
		const element = append(root, $('.extension'));
53
		const icon = append(element, $<HTMLImageElement>('img.icon'));
J
Joao Moreno 已提交
54 55
		const details = append(element, $('.details'));
		const header = append(details, $('.header'));
56
		const name = append(header, $('span.name'));
J
Joao Moreno 已提交
57
		const version = append(header, $('span.version'));
58
		const installCount = append(header, $('span.install-count'));
J
Joao Moreno 已提交
59
		const ratings = append(header, $('span.ratings'));
J
Joao Moreno 已提交
60
		const description = append(details, $('.description.ellipsis'));
J
Joao Moreno 已提交
61
		const footer = append(details, $('.footer'));
62
		const author = append(footer, $('.author.ellipsis'));
J
Joao Moreno 已提交
63
		const actionbar = new ActionBar(footer, { animated: false });
J
Joao Moreno 已提交
64

65 66
		actionbar.addListener2(EventType.RUN, ({ error }) => error && this.messageService.show(Severity.Error, error));

J
Joao Moreno 已提交
67 68 69 70
		const versionWidget = this.instantiationService.createInstance(Label, version, e => e.version);
		const installCountWidget = this.instantiationService.createInstance(InstallWidget, installCount, { small: true });
		const ratingsWidget = this.instantiationService.createInstance(RatingsWidget, ratings, { small: true });

J
Joao Moreno 已提交
71
		const builtinStatusAction = this.instantiationService.createInstance(BuiltinStatusLabelAction);
J
Joao Moreno 已提交
72 73 74 75
		const installAction = this.instantiationService.createInstance(CombinedInstallAction);
		const updateAction = this.instantiationService.createInstance(UpdateAction);
		const restartAction = this.instantiationService.createInstance(EnableAction);

J
Joao Moreno 已提交
76 77
		actionbar.push([restartAction, updateAction, installAction, builtinStatusAction], actionOptions);
		const disposables = [versionWidget, installCountWidget, ratingsWidget, installAction, builtinStatusAction, updateAction, restartAction, actionbar];
J
Joao Moreno 已提交
78

J
Joao Moreno 已提交
79
		return {
J
Joao Moreno 已提交
80
			element, icon, name, installCount, ratings, author, description, disposables,
81
			extensionDisposables: [],
J
Joao Moreno 已提交
82 83 84 85
			set extension(extension: IExtension) {
				versionWidget.extension = extension;
				installCountWidget.extension = extension;
				ratingsWidget.extension = extension;
J
Joao Moreno 已提交
86
				builtinStatusAction.extension = extension;
J
Joao Moreno 已提交
87 88 89 90
				installAction.extension = extension;
				updateAction.extension = extension;
				restartAction.extension = extension;
			}
J
Joao Moreno 已提交
91
		};
J
Joao Moreno 已提交
92 93 94 95
	}

	renderPlaceholder(index: number, data: ITemplateData): void {
		addClass(data.element, 'loading');
96 97

		data.extensionDisposables = dispose(data.extensionDisposables);
98
		data.icon.src = '';
J
Joao Moreno 已提交
99 100 101
		data.name.textContent = '';
		data.author.textContent = '';
		data.description.textContent = '';
J
Joao Moreno 已提交
102 103 104
		data.installCount.style.display = 'none';
		data.ratings.style.display = 'none';
		data.extension = null;
J
Joao Moreno 已提交
105 106
	}

J
Joao Moreno 已提交
107
	renderElement(extension: IExtension, index: number, data: ITemplateData): void {
J
Joao Moreno 已提交
108
		removeClass(data.element, 'loading');
109 110 111 112 113

		data.extensionDisposables = dispose(data.extensionDisposables);

		const onError = once(domEvent(data.icon, 'error'));
		onError(() => data.icon.src = extension.iconUrlFallback, null, data.extensionDisposables);
114 115 116 117 118 119 120 121 122
		data.icon.src = extension.iconUrl;

		if (!data.icon.complete) {
			data.icon.style.visibility = 'hidden';
			data.icon.onload = () => data.icon.style.visibility = 'inherit';
		} else {
			data.icon.style.visibility = 'inherit';
		}

J
Joao Moreno 已提交
123 124
		data.name.textContent = extension.displayName;
		data.author.textContent = extension.publisherDisplayName;
J
Joao Moreno 已提交
125
		data.description.textContent = extension.description;
J
Joao Moreno 已提交
126 127
		data.installCount.style.display = '';
		data.ratings.style.display = '';
J
Joao Moreno 已提交
128
		data.extension = extension;
J
Joao Moreno 已提交
129 130 131
	}

	disposeTemplate(data: ITemplateData): void {
J
Joao Moreno 已提交
132
		data.disposables = dispose(data.disposables);
J
Joao Moreno 已提交
133 134
	}
}