X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fjalview%2Fgui%2FWebserviceInfo.java;h=f6508078c7719edc36d2b704e217a4c93128e7ab;hb=fee1b781ca14aadea5d112fc554fe14879c787c5;hp=82350d1603ba5f8ec7c448886fe813a71078d2cd;hpb=6b908c927897408bf9c522f2d87a4cc98bed2325;p=jalview.git
diff --git a/src/jalview/gui/WebserviceInfo.java b/src/jalview/gui/WebserviceInfo.java
old mode 100755
new mode 100644
index 82350d1..f650807
--- a/src/jalview/gui/WebserviceInfo.java
+++ b/src/jalview/gui/WebserviceInfo.java
@@ -1,167 +1,912 @@
-package jalview.gui;
-
-import java.awt.*;
-import java.awt.event.*;
-import javax.swing.*;
-import jalview.jbgui.GWebserviceInfo;
-
-public class WebserviceInfo extends GWebserviceInfo
-{
-
- public static final int STATE_QUEUING = 0;
- public static final int STATE_RUNNING = 1;
- public static final int STATE_STOPPED_OK = 2;
- public static final int STATE_CANCELLED_OK = 3;
- public static final int STATE_STOPPED_ERROR = 4;
- public static final int STATE_STOPPED_SERVERERROR = 5;
- int currentStatus = STATE_QUEUING;
- Image image;
- int angle = 0;
-
- String title="";
- jalview.ws.WSClientI thisService;
- boolean serviceIsCancellable;
- public jalview.ws.WSClientI getthisService() {
- return thisService;
- }
- public void setthisService(jalview.ws.WSClientI newservice) {
- thisService = newservice;
- serviceIsCancellable = newservice.isCancellable();
- }
-
- public WebserviceInfo(String title, String info)
- {
- init(title, info, 520, 500);
- }
-
- public WebserviceInfo(String title, String info, int width, int height)
- {
- init(title, info, width, height);
- }
-
- void init(String title, String info, int width, int height)
- {
- JInternalFrame frame = new JInternalFrame();
- frame.setContentPane(this);
- Desktop.addInternalFrame(frame, title, width, height);
-
- this.title = title;
- setInfoText(info);
- java.net.URL url = getClass().getResource("/images/logo.gif");
- image = java.awt.Toolkit.getDefaultToolkit().createImage(url);
- MediaTracker mt = new MediaTracker(this);
- mt.addImage(image, 0);
- try
- {
- mt.waitForID(0);
- }
- catch (Exception ex)
- {}
-
-
- AnimatedPanel ap = new AnimatedPanel();
- titlePanel.add(ap, BorderLayout.CENTER);
- Thread thread = new Thread(ap);
- thread.start();
- }
-
- public void setStatus(int status)
- {
- currentStatus = status;
- }
-
- public String getInfoText()
- { return infoText.getText(); }
-
- public void setInfoText(String text)
- { infoText.setText(text); }
-
- public void appendInfoText(String text)
- { infoText.append(text); }
-
- public String getProgressText()
- { return progressText.getText(); }
-
- public void setProgressText(String text)
- { progressText.setText(text); }
-
- public void appendProgressText(String text)
- { progressText.append(text); }
-
- protected void cancel_actionPerformed(ActionEvent e)
- {
- if (!serviceIsCancellable)
- JOptionPane.showInternalMessageDialog(Desktop.desktop,
- "This job cannot be cancelled." ,
- "Cancel job"
- ,JOptionPane.WARNING_MESSAGE);
- else
- thisService.cancelJob();
- }
-
-
- class AnimatedPanel extends JPanel implements Runnable
- {
- long startTime=0;
- public void run()
- {
- startTime = System.currentTimeMillis();
- while(currentStatus.
+ * The Jalview Authors are detailed in the 'AUTHORS' file.
+ */
+package jalview.gui;
+
+import jalview.jbgui.GWebserviceInfo;
+import jalview.util.MessageManager;
+import jalview.ws.WSClientI;
+
+import java.awt.BorderLayout;
+import java.awt.Color;
+import java.awt.Font;
+import java.awt.Graphics;
+import java.awt.Graphics2D;
+import java.awt.GridLayout;
+import java.awt.Image;
+import java.awt.MediaTracker;
+import java.awt.event.ActionEvent;
+import java.awt.image.BufferedImage;
+import java.util.Vector;
+
+import javax.swing.JComponent;
+import javax.swing.JEditorPane;
+import javax.swing.JInternalFrame;
+import javax.swing.JOptionPane;
+import javax.swing.JPanel;
+import javax.swing.JScrollPane;
+import javax.swing.JTabbedPane;
+import javax.swing.JTextArea;
+import javax.swing.event.HyperlinkEvent;
+import javax.swing.event.HyperlinkListener;
+import javax.swing.text.html.HTMLEditorKit;
+import javax.swing.text.html.StyleSheet;
+
+/**
+ * Base class for web service client thread and gui TODO: create StAX parser to
+ * extract html body content reliably when preparing html formatted job statuses
+ *
+ * @author $author$
+ * @version $Revision$
+ */
+public class WebserviceInfo extends GWebserviceInfo implements
+ HyperlinkListener, IProgressIndicator
+{
+
+ /** Job is Queued */
+ public static final int STATE_QUEUING = 0;
+
+ /** Job is Running */
+ public static final int STATE_RUNNING = 1;
+
+ /** Job has finished with no errors */
+ public static final int STATE_STOPPED_OK = 2;
+
+ /** Job has been cancelled with no errors */
+ public static final int STATE_CANCELLED_OK = 3;
+
+ /** job has stopped because of some error */
+ public static final int STATE_STOPPED_ERROR = 4;
+
+ /** job has failed because of some unavoidable service interruption */
+ public static final int STATE_STOPPED_SERVERERROR = 5;
+
+ int currentStatus = STATE_QUEUING;
+
+ Image image;
+
+ int angle = 0;
+
+ String title = "";
+
+ jalview.ws.WSClientI thisService;
+
+ boolean serviceIsCancellable;
+
+ JInternalFrame frame;
+
+ private IProgressIndicator progressBar;
+
+ @Override
+ public void setVisible(boolean aFlag)
+ {
+ super.setVisible(aFlag);
+ frame.setVisible(aFlag);
+ };
+
+ JTabbedPane subjobs = null;
+
+ java.util.Vector jobPanes = null;
+
+ private boolean serviceCanMergeResults = false;
+
+ private boolean viewResultsImmediatly = true;
+
+ /**
+ * Get
+ *
+ * @param flag
+ * to indicate if results will be shown in a new window as soon as
+ * they are available.
+ */
+ public boolean isViewResultsImmediatly()
+ {
+ return viewResultsImmediatly;
+ }
+
+ /**
+ * Set
+ *
+ * @param flag
+ * to indicate if results will be shown in a new window as soon as
+ * they are available.
+ */
+ public void setViewResultsImmediatly(boolean viewResultsImmediatly)
+ {
+ this.viewResultsImmediatly = viewResultsImmediatly;
+ }
+
+ private StyleSheet getStyleSheet(HTMLEditorKit editorKit)
+ {
+
+ // Copied blatantly from
+ // http://www.velocityreviews.com/forums/t132265-string-into-htmldocument.html
+ StyleSheet myStyleSheet = new StyleSheet();
+
+ myStyleSheet.addStyleSheet(editorKit.getStyleSheet());
+
+ editorKit.setStyleSheet(myStyleSheet);
+
+ /*
+ * Set the style sheet rules here by reading them from the constants
+ * interface.
+ */
+ /*
+ * for (int ix=0; ixWS Job