messageTray: Correct idleness
If the user is already active when the notification pops up, we won't get an idle watcher because there's no transition from active to idle or vice versa. Correct this by initializing the state correctly from XSync.
This commit is contained in:
parent
3da0e9e86a
commit
8f71920622
@ -39,6 +39,8 @@ const NOTIFICATION_ICON_SIZE = 24;
|
||||
// range from the point where it left the tray.
|
||||
const MOUSE_LEFT_ACTOR_THRESHOLD = 20;
|
||||
|
||||
const IDLE_TIME = 1000;
|
||||
|
||||
const State = {
|
||||
HIDDEN: 0,
|
||||
SHOWING: 1,
|
||||
@ -1979,8 +1981,8 @@ const MessageTray = new Lang.Class({
|
||||
|
||||
_showNotification: function(notification) {
|
||||
this._notification = notification;
|
||||
this._userActiveWhileNotificationShown = false;
|
||||
this._idleMonitorWatchId = this.idleMonitor.add_watch(1000,
|
||||
this._userActiveWhileNotificationShown = this.idleMonitor.get_idletime() <= IDLE_TIME;
|
||||
this._idleMonitorWatchId = this.idleMonitor.add_watch(IDLE_TIME,
|
||||
Lang.bind(this, this._onIdleMonitorWatch));
|
||||
this._notificationClickedId = this._notification.connect('done-displaying',
|
||||
Lang.bind(this, this._escapeTray));
|
||||
|
@ -416,3 +416,14 @@ shell_idle_monitor_remove_watch (ShellIdleMonitor *monitor,
|
||||
g_hash_table_remove (monitor->priv->watches,
|
||||
GUINT_TO_POINTER (id));
|
||||
}
|
||||
|
||||
gint64
|
||||
shell_idle_monitor_get_idletime (ShellIdleMonitor *monitor)
|
||||
{
|
||||
XSyncValue value;
|
||||
|
||||
if (!XSyncQueryCounter (monitor->priv->display, monitor->priv->counter, &value))
|
||||
return FALSE;
|
||||
|
||||
return _xsyncvalue_to_int64 (value);
|
||||
}
|
||||
|
@ -67,6 +67,8 @@ guint shell_idle_monitor_add_watch (ShellIdleMonitor *mo
|
||||
void shell_idle_monitor_remove_watch (ShellIdleMonitor *monitor,
|
||||
guint id);
|
||||
|
||||
gint64 shell_idle_monitor_get_idletime (ShellIdleMonitor *monitor);
|
||||
|
||||
G_END_DECLS
|
||||
|
||||
#endif /* __SHELL_IDLE_MONITOR_H */
|
||||
|
Loading…
Reference in New Issue
Block a user