/*
* Copyright (c) 2011 by Stefan Laubenberger.
*
* Test is free software: you can redistribute it and/or modify
* it under the terms of the General Public License v2.0.
*
* Test is distributed together with Tyr in the hope that it
* will be useful, but WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* See the GNU General Public License for more details:
* <http://www.gnu.org/licenses>
*
* This distribution is available at:
* <http://code.google.com/p/tyr/>
* <http://dev.laubenberger.net/tyr/>
*
* Contact information:
* Stefan Laubenberger
* Bullingerstrasse 53
* CH-8004 Zuerich
*
* <http://www.laubenberger.net>
*
* <laubenberger@gmail.com>
*/
package net.laubenberger.tyr.module.test;
import java.awt.BorderLayout;
import java.awt.Insets;
import java.awt.event.ActionEvent;
import javax.swing.BorderFactory;
import javax.swing.JLabel;
import javax.swing.SwingUtilities;
import net.laubenberger.bogatyr.helper.HelperLog;
import net.laubenberger.bogatyr.helper.HelperString;
import net.laubenberger.bogatyr.misc.Event;
import net.laubenberger.bogatyr.service.localizer.Localizer;
import net.laubenberger.bogatyr.service.timer.ListenerTimer;
import net.laubenberger.bogatyr.service.timer.TimeMachine;
import net.laubenberger.bogatyr.service.timer.Timer;
import net.laubenberger.bogatyr.service.timer.TimerImpl;
import net.laubenberger.bogatyr.view.swing.ActionAbstract;
import net.laubenberger.bogatyr.view.swing.Button;
import net.laubenberger.bogatyr.view.swing.Dialog;
import net.laubenberger.bogatyr.view.swing.Group;
import net.laubenberger.bogatyr.view.swing.Label;
import net.laubenberger.bogatyr.view.swing.Panel;
import net.laubenberger.tyr.model.Icon;
import org.divxdede.swing.busy.JBusyComponent;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Dialog to display a working thread.
*
* @author Stefan Laubenberger
* @version 0.9.0 (20110214)
* @since 0.0.1
*/
public class DialogThread extends Dialog implements ListenerTimer {
private static final long serialVersionUID = 4161135982451721307L;
private static final Logger log = LoggerFactory.getLogger(DialogThread.class);
final Test test;
final Localizer localizer;
Label text;
Timer timer = new TimerImpl();
public DialogThread(final Test test) {
super(test.getOwner());
if (log.isTraceEnabled()) log.trace(HelperLog.constructor(test));
this.test = test;
localizer = test.getModel().getLocalizer();
timer.addListener(this);
}
{
// setAlwaysOnTop(true);
setDefaultCloseOperation(DISPOSE_ON_CLOSE);
}
/*
* Private methods
*/
private void createLayout() {
getContentPane().removeAll();
setTitle(test.getModel().getName() + HelperString.COLON + HelperString.SPACE
+ localizer.getValue(HelperResource.RES_ACTION_ABOUT));
final Panel panel = new Panel(new BorderLayout());
panel.setBorder(BorderFactory.createEmptyBorder(10, 10, 5, 10));
final Panel panelCenter = new Panel(new BorderLayout());
panelCenter.add(new JLabel(test.getCallback().getScaledIcon(Icons.THREAD)), BorderLayout.NORTH);
text = new Label(getClass().getName());
panelCenter.add(text, BorderLayout.SOUTH);
final JBusyComponent<Panel> busyComponent = new JBusyComponent<Panel>(panelCenter);
panel.add(busyComponent, BorderLayout.CENTER);
final Group group = new Group(new Insets(0, 0, 0, 0), new Button(new ActionClose()));
panel.add(group, BorderLayout.SOUTH);
getContentPane().add(panel);
busyComponent.setBusy(true);
// pack();
}
@Override
public void timeChanged(final Event<TimeMachine> arg0) {
if (log.isDebugEnabled()) log.debug(HelperLog.methodStart(arg0));
SwingUtilities.invokeLater(new Runnable() {
@Override
public void run() {
text.setText(getClass().getName() + HelperString.SPACE + arg0.getSource().getTime() / 1000L);
}
});
if (log.isDebugEnabled()) log.debug(HelperLog.methodExit());
}
@Override
public void timerStarted(final Event<TimeMachine> arg0) {
// do nothing
}
@Override
public void timerStopped(final Event<TimeMachine> arg0) {
// do nothing
}
/*
* Overridden methods
*/
@Override
public void createAndShowGUI() {
if (log.isDebugEnabled()) log.debug(HelperLog.methodStart());
createLayout();
pack();
test.getDialogs().add(this);
timer.start();
super.createAndShowGUI();
if (log.isDebugEnabled()) log.debug(HelperLog.methodExit());
}
@Override
public void clearAndHide() {
if (log.isDebugEnabled()) log.debug(HelperLog.methodStart());
test.getDialogs().remove(this);
timer.stop();
super.clearAndHide();
if (log.isDebugEnabled()) log.debug(HelperLog.methodExit());
}
/*
* Inner classes
*/
private class ActionClose extends ActionAbstract {
private static final long serialVersionUID = 3521248435384827073L;
public ActionClose() {
super(localizer.getValue(HelperResource.RES_ACTION_CLOSE), test.getCallback().getScaledIcon(Icon.OK),
localizer.getTooltip(HelperResource.RES_ACTION_CLOSE), localizer
.getMnemonic(HelperResource.RES_ACTION_CLOSE));
}
@Override
public void actionPerformed(final ActionEvent e) {
clearAndHide();
}
}
}