loginDialog: Defer loading user list until needed
Loading the user list can be expensive, for instance when there is a large number of users and/or their avatars have to be fetched over the network. In case the user list is disabled anyway, there is no point in doing that work just to hide it, so stop doing that. https://bugzilla.gnome.org/show_bug.cgi?id=725905
This commit is contained in:
parent
ef8123e3a2
commit
0ba05b29b9
@ -469,6 +469,17 @@ const LoginDialog = new Lang.Class({
|
|||||||
this._sessionMenuButton.actor.show();
|
this._sessionMenuButton.actor.show();
|
||||||
this._authPrompt.addActorToDefaultButtonWell(this._sessionMenuButton.actor);
|
this._authPrompt.addActorToDefaultButtonWell(this._sessionMenuButton.actor);
|
||||||
|
|
||||||
|
this._disableUserList = undefined;
|
||||||
|
this._userListLoaded = false;
|
||||||
|
|
||||||
|
// If the user list is enabled, it should take key focus; make sure the
|
||||||
|
// screen shield is initialized first to prevent it from stealing the
|
||||||
|
// focus later
|
||||||
|
Main.layoutManager.connect('startup-complete',
|
||||||
|
Lang.bind(this, this._updateDisableUserList));
|
||||||
|
},
|
||||||
|
|
||||||
|
_ensureUserListLoaded: function() {
|
||||||
if (!this._userManager.is_loaded)
|
if (!this._userManager.is_loaded)
|
||||||
this._userManagerLoadedId = this._userManager.connect('notify::is-loaded',
|
this._userManagerLoadedId = this._userManager.connect('notify::is-loaded',
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
@ -480,7 +491,6 @@ const LoginDialog = new Lang.Class({
|
|||||||
}));
|
}));
|
||||||
else
|
else
|
||||||
GLib.idle_add(GLib.PRIORITY_DEFAULT, Lang.bind(this, this._loadUserList));
|
GLib.idle_add(GLib.PRIORITY_DEFAULT, Lang.bind(this, this._loadUserList));
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateDisableUserList: function() {
|
_updateDisableUserList: function() {
|
||||||
@ -801,6 +811,7 @@ const LoginDialog = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_showUserList: function() {
|
_showUserList: function() {
|
||||||
|
this._ensureUserListLoaded();
|
||||||
this._authPrompt.hide();
|
this._authPrompt.hide();
|
||||||
this._sessionMenuButton.close();
|
this._sessionMenuButton.close();
|
||||||
this._setUserListExpanded(true);
|
this._setUserListExpanded(true);
|
||||||
@ -844,14 +855,17 @@ const LoginDialog = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_loadUserList: function() {
|
_loadUserList: function() {
|
||||||
|
if (this._userListLoaded)
|
||||||
|
return GLib.SOURCE_REMOVE;
|
||||||
|
|
||||||
|
this._userListLoaded = true;
|
||||||
|
|
||||||
let users = this._userManager.list_users();
|
let users = this._userManager.list_users();
|
||||||
|
|
||||||
for (let i = 0; i < users.length; i++) {
|
for (let i = 0; i < users.length; i++) {
|
||||||
this._userList.addUser(users[i]);
|
this._userList.addUser(users[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
this._updateDisableUserList();
|
|
||||||
|
|
||||||
this._userManager.connect('user-added',
|
this._userManager.connect('user-added',
|
||||||
Lang.bind(this, function(userManager, user) {
|
Lang.bind(this, function(userManager, user) {
|
||||||
this._userList.addUser(user);
|
this._userList.addUser(user);
|
||||||
|
Loading…
Reference in New Issue
Block a user