ScreenShield: implement o.g.ScreenSaver.GetActiveTime

Part of the old gnome-screensaver interface, returns the number of seconds
that the screensaver has been active for.

https://bugzilla.gnome.org/show_bug.cgi?id=686064
This commit is contained in:
Giovanni Campagna
2012-10-16 16:38:32 +02:00
parent d3ba002313
commit 2a8a8065a8
2 changed files with 26 additions and 2 deletions

View File

@ -429,6 +429,7 @@ const ScreenShield = new Lang.Class({
this._isGreeter = false;
this._isActive = false;
this._inUnlockAnimation = false;
this._activationTime = 0;
this._lightbox = new Lightbox.Lightbox(Main.uiGroup,
{ inhibitEvents: true,
@ -556,8 +557,12 @@ const ScreenShield = new Lang.Class({
this._isModal = true;
}
if (!this._isActive)
if (!this._isActive) {
this._lightbox.show();
if (this._activationTime == 0)
this._activationTime = GLib.get_monotonic_time();
}
} else {
let lightboxWasShown = this._lightbox.shown;
this._lightbox.hide();
@ -774,6 +779,10 @@ const ScreenShield = new Lang.Class({
return this._isActive;
},
get activationTime() {
return this._activationTime;
},
_tweenUnlocked: function() {
this._inUnlockAnimation = true;
this.unlock();
@ -818,6 +827,7 @@ const ScreenShield = new Lang.Class({
if (Main.sessionMode.currentMode == 'unlock-dialog')
Main.sessionMode.popMode('unlock-dialog');
this._activationTime = 0;
this._isActive = false;
this.emit('lock-status-changed');
},
@ -828,6 +838,9 @@ const ScreenShield = new Lang.Class({
this._isModal = true;
}
if (this._activationTime == 0)
this._activationTime = GLib.get_monotonic_time();
this.actor.show();
if (Main.sessionMode.currentMode != 'unlock-dialog' &&