The Notifications object now handles displaying multiple notifications.
[picture-display.git] / lib / Display / Plugins / MPD.pm
index edb62c7..13d92df 100644 (file)
@@ -1,27 +1,41 @@
 package Display::Plugins::MPD;
 
 use Clutter;
+use Carp;
 use Audio::MPD;
 use POSIX qw/strftime/;
-use base ('Display::Plugin');
+use POE::Session;
+use base ('Display::Plugins');
+use FindBin qw/$Bin/;
+use strict;
+
+my $delay = 5;
 
 sub new {
   my $proto = shift;
   my $class = ref($proto) || $proto;
 
   my $self = $class->SUPER::new(@_);
+  bless ($self, $class);
+
+  eval {
+    $self->{'mpd'} = Audio::MPD->new();
+  };
+  if ($@) {
+    carp "Failed to connect to MPD: $@";
+  } else {
+    $self->init_delay($delay, 'mpd_display');
+    $self->init();
+  }
 
-  $self->{'mpd'} = Audio::MPD->new();
   $self->{'file'} = '';
   $self->{'active'} = 0;
 
-  bless ($self, $class);
-  $self->init();
   return $self;
 }
 
 sub display {
-  my $self = shift;
+  my ($self, $kernel) = @_[OBJECT, KERNEL];
 
   my $current = $self->{'mpd'}->current();
 
@@ -31,24 +45,22 @@ sub display {
     push @lines, $current->album()  if defined $current->album();
     push @lines, $current->artist() if defined $current->artist();
 
-    $self->{'status'}->set_text(join("\n", @lines));
-
     $self->{'file'} = $current->file();
 
-    $self->{'notifications'}->add($self->{'status'});
+    $kernel->post('display', 'notifications_add', join("\n", @lines), $self->{'logo'});
   }
 
-  return 1;
+  $self->delay();
 }
 
 sub init {
   my $self = shift;
 
-  $self->{'status'} = Clutter::Label->new('Sans 20', "Song\nAlbum");
-  $self->{'status'}->set_color(Clutter::Color->parse('White'));
-  $self->{'status'}->set_ellipsize('end');
+  $self->{'kernel'}->state('mpd_display', $self, 'display');
+
+  $self->{'logo'} = "$Bin/share/MPD.png";
 
-  Glib::Timeout->add_seconds(5, $self->can('display'), $self);
+  $self->{'kernel'}->yield('mpd_display');
 }
 
 1;