提交 5290fc4d 编写于 作者: S Sandeep Somavarapu

Remove options from composite bar and use addComposite for adding

上级 d48541bb
...@@ -66,7 +66,6 @@ export class ActivitybarPart extends Part { ...@@ -66,7 +66,6 @@ export class ActivitybarPart extends Part {
icon: true, icon: true,
storageId: ActivitybarPart.PINNED_VIEWLETS, storageId: ActivitybarPart.PINNED_VIEWLETS,
orientation: ActionsOrientation.VERTICAL, orientation: ActionsOrientation.VERTICAL,
composites: this.viewletService.getViewlets().filter(v => this.canShow(v)),
openComposite: (compositeId: string) => this.viewletService.openViewlet(compositeId, true), openComposite: (compositeId: string) => this.viewletService.openViewlet(compositeId, true),
getActivityAction: (compositeId: string) => this.getCompositeActions(compositeId).activityAction, getActivityAction: (compositeId: string) => this.getCompositeActions(compositeId).activityAction,
getCompositePinnedAction: (compositeId: string) => this.getCompositeActions(compositeId).pinnedAction, getCompositePinnedAction: (compositeId: string) => this.getCompositeActions(compositeId).pinnedAction,
......
...@@ -25,7 +25,6 @@ export interface ICompositeBarOptions { ...@@ -25,7 +25,6 @@ export interface ICompositeBarOptions {
icon: boolean; icon: boolean;
storageId: string; storageId: string;
orientation: ActionsOrientation; orientation: ActionsOrientation;
composites: { id: string, name: string, order: number }[];
colors: ICompositeBarColors; colors: ICompositeBarColors;
compositeSize: number; compositeSize: number;
overflowActionSize: number; overflowActionSize: number;
...@@ -62,14 +61,6 @@ export class CompositeBar extends Widget implements ICompositeBar { ...@@ -62,14 +61,6 @@ export class CompositeBar extends Widget implements ICompositeBar {
this.storedState = this.loadCompositeItemsFromStorage(); this.storedState = this.loadCompositeItemsFromStorage();
this.visibleComposites = []; this.visibleComposites = [];
this.compositeSizeInBar = new Map<string, number>(); this.compositeSizeInBar = new Map<string, number>();
let index = 0;
for (const state of this.storedState) {
const composite = this.options.composites.filter(c => c.id === state.id)[0];
if (composite) {
this.addToModel(composite.id, composite.name, composite.order, state.pinned, index++);
}
}
} }
public create(parent: HTMLElement): HTMLElement { public create(parent: HTMLElement): HTMLElement {
...@@ -449,16 +440,8 @@ export class CompositeBar extends Widget implements ICompositeBar { ...@@ -449,16 +440,8 @@ export class CompositeBar extends Widget implements ICompositeBar {
private loadCompositeItemsFromStorage(): ISerializedCompositeBarItem[] { private loadCompositeItemsFromStorage(): ISerializedCompositeBarItem[] {
const storedStates = <Array<string | ISerializedCompositeBarItem>>JSON.parse(this.storageService.get(this.options.storageId, StorageScope.GLOBAL, '[]')); const storedStates = <Array<string | ISerializedCompositeBarItem>>JSON.parse(this.storageService.get(this.options.storageId, StorageScope.GLOBAL, '[]'));
const isOldData = storedStates && storedStates.length && typeof storedStates[0] === 'string';
const compositeStates = <ISerializedCompositeBarItem[]>storedStates.map(c => const compositeStates = <ISerializedCompositeBarItem[]>storedStates.map(c =>
typeof c === 'string' /* migration from pinned states to composites states */ ? { id: c, pinned: true } : c); typeof c === 'string' /* migration from pinned states to composites states */ ? { id: c, pinned: true } : c);
if (!isOldData) { /* Add new composites only if it is new data */
const newComposites = this.options.composites.filter(c => compositeStates.every(s => s.id !== c.id));
newComposites.sort((c1, c2) => c1.order < c2.order ? -1 : 1);
newComposites.forEach(c => compositeStates.push({ id: c.id, pinned: true, order: c.order /* new composites are pinned by default */ }));
}
return compositeStates; return compositeStates;
} }
......
...@@ -80,7 +80,6 @@ export class PanelPart extends CompositePart<Panel> implements IPanelService { ...@@ -80,7 +80,6 @@ export class PanelPart extends CompositePart<Panel> implements IPanelService {
icon: false, icon: false,
storageId: PanelPart.PINNED_PANELS, storageId: PanelPart.PINNED_PANELS,
orientation: ActionsOrientation.HORIZONTAL, orientation: ActionsOrientation.HORIZONTAL,
composites: this.getPanels(),
openComposite: (compositeId: string) => this.openPanel(compositeId, true), openComposite: (compositeId: string) => this.openPanel(compositeId, true),
getActivityAction: (compositeId: string) => this.getCompositeActions(compositeId).activityAction, getActivityAction: (compositeId: string) => this.getCompositeActions(compositeId).activityAction,
getCompositePinnedAction: (compositeId: string) => this.getCompositeActions(compositeId).pinnedAction, getCompositePinnedAction: (compositeId: string) => this.getCompositeActions(compositeId).pinnedAction,
...@@ -98,6 +97,9 @@ export class PanelPart extends CompositePart<Panel> implements IPanelService { ...@@ -98,6 +97,9 @@ export class PanelPart extends CompositePart<Panel> implements IPanelService {
} }
}); });
this.toUnbind.push(this.compositeBar); this.toUnbind.push(this.compositeBar);
for (const panel of this.getPanels()) {
this.compositeBar.addComposite(panel, false);
}
this.registerListeners(); this.registerListeners();
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册