allView, folderView: Only add icons once
FolderView and AllView currently check if the item is present in the BaseAppView._items map, in order to avoid adding the same icon multiple times. Now that BaseAppView._loadGrid() has a different role -- it returns a list with all app icons, and BaseAppView diffs with the current list of app icons -- checking the BaseAppView._items map is wrong. Make sure there are no duplicated items in the temporary array returned by all _loadGrid() implementations. Remove the now unused BaseAppView.hasItem() method. https://gitlab.gnome.org/GNOME/gnome-shell/merge_requests/645
This commit is contained in:
parent
c13efe96dc
commit
9da49606f7
@ -148,15 +148,8 @@ class BaseAppView {
|
|||||||
return this._allItems;
|
return this._allItems;
|
||||||
}
|
}
|
||||||
|
|
||||||
hasItem(id) {
|
|
||||||
return this._items[id] !== undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
addItem(icon) {
|
addItem(icon) {
|
||||||
let id = icon.id;
|
let id = icon.id;
|
||||||
if (this.hasItem(id))
|
|
||||||
throw new Error(`icon with id ${id} already added to view`);
|
|
||||||
|
|
||||||
this._allItems.push(icon);
|
this._allItems.push(icon);
|
||||||
this._items[id] = icon;
|
this._items[id] = icon;
|
||||||
}
|
}
|
||||||
@ -402,12 +395,13 @@ var AllView = class AllView extends BaseAppView {
|
|||||||
|
|
||||||
let folders = this._folderSettings.get_strv('folder-children');
|
let folders = this._folderSettings.get_strv('folder-children');
|
||||||
folders.forEach(id => {
|
folders.forEach(id => {
|
||||||
if (this.hasItem(id))
|
|
||||||
return;
|
|
||||||
let path = this._folderSettings.path + 'folders/' + id + '/';
|
let path = this._folderSettings.path + 'folders/' + id + '/';
|
||||||
let icon = new FolderIcon(id, path, this);
|
let icon = this._items[id];
|
||||||
|
if (!icon) {
|
||||||
|
icon = new FolderIcon(id, path, this);
|
||||||
icon.connect('name-changed', this._itemNameChanged.bind(this));
|
icon.connect('name-changed', this._itemNameChanged.bind(this));
|
||||||
icon.connect('apps-changed', this._refilterApps.bind(this));
|
icon.connect('apps-changed', this._refilterApps.bind(this));
|
||||||
|
}
|
||||||
newApps.push(icon);
|
newApps.push(icon);
|
||||||
this.folderIcons.push(icon);
|
this.folderIcons.push(icon);
|
||||||
});
|
});
|
||||||
@ -1160,9 +1154,6 @@ var FolderView = class FolderView extends BaseAppView {
|
|||||||
let excludedApps = this._folder.get_strv('excluded-apps');
|
let excludedApps = this._folder.get_strv('excluded-apps');
|
||||||
let appSys = Shell.AppSystem.get_default();
|
let appSys = Shell.AppSystem.get_default();
|
||||||
let addAppId = appId => {
|
let addAppId = appId => {
|
||||||
if (this.hasItem(id))
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (excludedApps.includes(appId))
|
if (excludedApps.includes(appId))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -1173,6 +1164,9 @@ var FolderView = class FolderView extends BaseAppView {
|
|||||||
if (!app.get_app_info().should_show())
|
if (!app.get_app_info().should_show())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (apps.some(appIcon => appIcon.id == appId))
|
||||||
|
return;
|
||||||
|
|
||||||
let icon = new AppIcon(app);
|
let icon = new AppIcon(app);
|
||||||
apps.push(icon);
|
apps.push(icon);
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user