/**********************************************************************
* $Source: /cvsroot/hibiscus/hibiscus/src/de/willuhn/jameica/hbci/messaging/MarkerUmsatzmessageConsumer.java,v $
* $Revision: 1.1 $
* $Date: 2011/06/30 16:29:42 $
* $Author: willuhn $
*
* Copyright (c) by willuhn - software & services
* All rights reserved
*
**********************************************************************/
package de.willuhn.jameica.hbci.messaging;
import org.eclipse.swt.widgets.Event;
import org.eclipse.swt.widgets.Listener;
import de.willuhn.datasource.GenericIterator;
import de.willuhn.datasource.GenericObject;
import de.willuhn.jameica.gui.GUI;
import de.willuhn.jameica.gui.util.DelayedListener;
import de.willuhn.jameica.hbci.rmi.Umsatz;
import de.willuhn.jameica.messaging.Message;
import de.willuhn.jameica.messaging.MessageConsumer;
import de.willuhn.jameica.system.Application;
import de.willuhn.logging.Level;
import de.willuhn.logging.Logger;
/**
* Markiert das Navigations-Element "Auswertungen->Kontoauszuege", wenn neue Umsaetze vorhanden sind.
*/
public class MarkerUmsatzmessageConsumer implements MessageConsumer
{
private DelayedListener listener = new DelayedListener(1000,new Worker());
/**
* @see de.willuhn.jameica.messaging.MessageConsumer#getExpectedMessageTypes()
*/
public Class[] getExpectedMessageTypes()
{
return new Class[]{ImportMessage.class,ObjectDeletedMessage.class};
}
/**
* @see de.willuhn.jameica.messaging.MessageConsumer#handleMessage(de.willuhn.jameica.messaging.Message)
*/
public void handleMessage(Message message) throws Exception
{
if (Application.inServerMode())
return;
GenericObject o = ((ObjectMessage)message).getObject();
if (o == null || !(o instanceof Umsatz))
return; // interessiert uns nicht
// wir machen das ganze verzoegert. Im Normalfall kommen ja eine ganze Reine
// von Umsaetzen in einem Rutsch. Und wir wollen das Update ja nicht unnoetig
// nach jedem Umsatz ausfuehren, wenn noch 100 weitere kommen.
listener.handleEvent(null);
}
/**
* @see de.willuhn.jameica.messaging.MessageConsumer#autoRegister()
*/
public boolean autoRegister()
{
return true;
}
/**
* Der eigentliche Worker.
*/
private class Worker implements Listener
{
/**
* @see org.eclipse.swt.widgets.Listener#handleEvent(org.eclipse.swt.widgets.Event)
*/
public void handleEvent(Event event)
{
try
{
GenericIterator i = NeueUmsaetze.getNeueUmsaetze();
final int size = i.size();
GUI.getNavigation().setUnreadCount("hibiscus.navi.reporting.kontoauszug",size);
}
catch (Throwable t) // wir fangen hier alles - fuer den Fall, dass die Jameica-Version noch kein "setUnreadCount" hat
{
Logger.write(Level.DEBUG,"unable to update navigation",t);
}
}
}
}
/**********************************************************************
* $Log: MarkerUmsatzmessageConsumer.java,v $
* Revision 1.1 2011/06/30 16:29:42 willuhn
* @N Unterstuetzung fuer neues UnreadCount-Feature
*
**********************************************************************/