aboutsummaryrefslogtreecommitdiff
path: root/src/accounts-service-user.vala
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2014-03-21 14:34:52 -0500
committerTed Gould <ted@gould.cx>2014-03-21 14:34:52 -0500
commitd114c16f06803c8619d652b3a9dda31da3f1699a (patch)
tree6b51a460d49a87ed1f57c1792a1f232547dce443 /src/accounts-service-user.vala
parent831571ad497d790701d82305c57d8e69188a62ee (diff)
parentaee881c058971adcbe676d0d24d4924a0f38ef67 (diff)
downloadayatana-indicator-sound-d114c16f06803c8619d652b3a9dda31da3f1699a.tar.gz
ayatana-indicator-sound-d114c16f06803c8619d652b3a9dda31da3f1699a.tar.bz2
ayatana-indicator-sound-d114c16f06803c8619d652b3a9dda31da3f1699a.zip
Updating to latest export
Diffstat (limited to 'src/accounts-service-user.vala')
-rw-r--r--src/accounts-service-user.vala23
1 files changed, 19 insertions, 4 deletions
diff --git a/src/accounts-service-user.vala b/src/accounts-service-user.vala
index 052c7a0..c29842a 100644
--- a/src/accounts-service-user.vala
+++ b/src/accounts-service-user.vala
@@ -42,9 +42,18 @@ public class AccountsServiceUser : Object {
}
if (this._player == null) {
+ debug("Clearing player data in accounts service");
+
/* Clear it */
this.proxy.player_name = "";
this.proxy.timestamp = 0;
+ this.proxy.title = "";
+ this.proxy.artist = "";
+ this.proxy.album = "";
+ this.proxy.art_url = "";
+
+ var icon = new ThemedIcon.with_default_fallbacks ("application-default-icon");
+ this.proxy.player_icon = icon.serialize();
} else {
this.proxy.timestamp = GLib.get_monotonic_time();
this.proxy.player_name = this._player.name;
@@ -84,11 +93,16 @@ public class AccountsServiceUser : Object {
public AccountsServiceUser () {
user = accounts_manager.get_user(GLib.Environment.get_user_name());
- user.notify["is-loaded"].connect(() => {
- debug("User loaded");
+ user.notify["is-loaded"].connect(() => user_loaded_changed());
+ user_loaded_changed();
+ }
- this.proxy = null;
+ void user_loaded_changed () {
+ debug("User loaded changed");
+
+ this.proxy = null;
+ if (this.user.is_loaded) {
Bus.get_proxy.begin<AccountsServiceSoundSettings> (
BusType.SYSTEM,
"org.freedesktop.Accounts",
@@ -96,10 +110,11 @@ public class AccountsServiceUser : Object {
DBusProxyFlags.GET_INVALIDATED_PROPERTIES,
null,
new_proxy);
- });
+ }
}
~AccountsServiceUser () {
+ debug("Account Service Object Finalizing");
this.player = null;
if (this.timer != 0) {