REload from URL
[jalview.git] / src / jalview / gui / AlignFrame.java
index 2b4b7e0..be46dfa 100755 (executable)
@@ -36,6 +36,8 @@ import jalview.schemes.*;
 import jalview.commands.*;
 import jalview.ws.*;
 import java.awt.dnd.*;
+import javax.swing.event.ChangeListener;
+import javax.swing.event.ChangeEvent;
 
 /**
  * DOCUMENT ME!
@@ -58,9 +60,10 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
 
 
   /** DOCUMENT ME!! */
-  public String currentFileFormat = null;
-  Stack historyList = new Stack();
-  Stack redoList = new Stack();
+  String currentFileFormat = null;
+
+  String fileName = null;
+
   private int treeCount = 0;
 
   /**
@@ -136,13 +139,22 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
      setGUINucleotide(viewport.alignment.isNucleotide());
    }
 
-   if (jalview.bin.Cache.getDefault("WRAP_ALIGNMENT", false))
+   setMenusFromViewport(viewport);
+
+   if (viewport.wrapAlignment)
    {
-     wrapMenuItem.setSelected(true);
      wrapMenuItem_actionPerformed(null);
    }
 
    addKeyListener();
+
+  }
+
+  public void setFileName(String file, String format)
+  {
+     fileName = file;
+     currentFileFormat = format;
+     reload.setEnabled(true);
   }
 
   void addKeyListener()
@@ -161,35 +173,6 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
 
           switch (evt.getKeyCode())
           {
-            case KeyEvent.VK_V:
-              if (!evt.isControlDown())
-              {
-                AlignmentI al;
-                if(viewport.hasHiddenRows)
-                {
-                  al = viewport.alignment.getHiddenSequences().getFullAlignment();
-                }
-                else
-                  al = new Alignment(viewport.alignment.getSequencesArray());
-
-                AlignViewport newview = new AlignViewport(al);
-
-                if(viewport.viewName==null)
-                  viewport.viewName="View 1";
-
-                newview.sequenceSetID = viewport.getSequenceSetId();
-                newview.viewName = "View " +
-                    (Desktop.getViewCount(viewport.getSequenceSetId())+1);
-
-                AlignmentPanel newap = new AlignmentPanel(af, newview);
-
-                PaintRefresher.Register(newap, viewport.getSequenceSetId());
-                PaintRefresher.Register(alignPanel, viewport.getSequenceSetId());
-
-                addAlignmentPanel(newap, true);
-                tabbedPane.setSelectedIndex(tabbedPane.getTabCount()-1);
-              }
-              break;
             case KeyEvent.VK_G:
               Desktop.instance.gatherViews(af);
               break;
@@ -416,8 +399,10 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
 
     if(newPanel)
     {
-      ap.av.updateConsensus(ap);
+      if (ap.av.padGaps)
+        ap.av.alignment.padGaps();
       ap.av.updateConservation(ap);
+      ap.av.updateConsensus(ap);
     }
   }
 
@@ -455,7 +440,7 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
       {
         // System.out.println("deregistering discoverer listener");
         Desktop.discoverer.removePropertyChangeListener(thisListener);
-        closeMenuItem_actionPerformed(null);
+        closeMenuItem_actionPerformed(true);
       }
       ;
     });
@@ -464,10 +449,8 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
   public void setGUINucleotide(boolean nucleotide)
   {
     showTranslation.setVisible( nucleotide );
-    //sequenceFeatures.setVisible(!nucleotide );
-    //featureSettings.setVisible( !nucleotide );
-    conservationMenuItem.setVisible( !nucleotide );
-    modifyConservation.setVisible(   !nucleotide );
+    conservationMenuItem.setEnabled( !nucleotide );
+    modifyConservation.setEnabled(   !nucleotide );
 
     //Remember AlignFrame always starts as protein
     if(!nucleotide)
@@ -476,6 +459,33 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
     }
   }
 
+  /**
+   * Need to call this method when tabs are selected for multiple views,
+   * or when loading from Jalview2XML.java
+   * @param av AlignViewport
+   */
+  void setMenusFromViewport(AlignViewport av)
+  {
+    colourTextMenuItem.setSelected(av.showColourText);
+    abovePIDThreshold.setSelected(av.getAbovePIDThreshold());
+    conservationMenuItem.setSelected(av.getConservationSelected());
+    seqLimits.setSelected(av.getShowJVSuffix());
+    renderGapsMenuItem.setSelected(av.renderGaps);
+    wrapMenuItem.setSelected(av.wrapAlignment);
+    annotationPanelMenuItem.setState(av.showAnnotation);
+    viewBoxesMenuItem.setSelected(av.showBoxes);
+    viewTextMenuItem.setSelected(av.showText);
+
+    setColourSelected(ColourSchemeProperty.
+                      getColourName(av.getGlobalColourScheme()));
+
+    showSeqFeatures.setSelected(av.showSequenceFeatures);
+    hiddenMarkers.setState(av.showHiddenMarkers);
+    applyToAllGroups.setState(av.colourAppliesToAllGroups);
+
+    updateEditMenuBar();
+  }
+
 
   Hashtable progressBars;
   public void setProgressBar(String message, long id)
@@ -542,6 +552,44 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
     Desktop.instance.inputLocalFileMenuItem_actionPerformed(viewport);
   }
 
+  public void reload_actionPerformed(ActionEvent e)
+  {
+    if(fileName!=null)
+    {
+      if(currentFileFormat.equals("Jalview"))
+      {
+        this.closeMenuItem_actionPerformed(true);
+      }
+      else
+      {
+        viewport.alignment.deleteAllGroups();
+        viewport.sequenceColours=null;
+        while (viewport.alignment.getHeight() > 0)
+        {
+          viewport.alignment.deleteSequence(0);
+        }
+
+        viewport.historyList.clear();
+        viewport.redoList.clear();
+        Alignment dset = viewport.alignment.getDataset();
+        while (dset.getHeight() > 0)
+        {
+          dset.deleteSequence(0);
+        }
+
+        firePropertyChange("Alignment", null, null);
+
+        updateEditMenuBar();
+      }
+
+      FileLoader loader = new FileLoader();
+      String protocol = fileName.startsWith("http:")? "URL":"File";
+      loader.LoadFile(viewport, fileName, protocol, currentFileFormat);
+
+    }
+  }
+
+
   public void addFromText_actionPerformed(ActionEvent e)
   {
     Desktop.instance.inputTextboxMenuItem_actionPerformed(viewport);
@@ -552,12 +600,21 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
     Desktop.instance.inputURLMenuItem_actionPerformed(viewport);
   }
 
+
+  public void save_actionPerformed(ActionEvent e)
+  {
+    if(fileName==null || currentFileFormat==null)
+      saveAs_actionPerformed(null);
+    else
+      saveAlignment(fileName, currentFileFormat);
+  }
+
   /**
    * DOCUMENT ME!
    *
    * @param e DOCUMENT ME!
    */
-  public void saveAlignmentMenu_actionPerformed(ActionEvent e)
+  public void saveAs_actionPerformed(ActionEvent e)
   {
     JalviewFileChooser chooser = new JalviewFileChooser(jalview.bin.Cache.
         getProperty( "LAST_DIRECTORY"),
@@ -578,7 +635,6 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
     if (value == JalviewFileChooser.APPROVE_OPTION)
     {
         currentFileFormat = chooser.getSelectedFormat();
-
         if (currentFileFormat == null)
         {
           JOptionPane.showInternalMessageDialog(Desktop.desktop,
@@ -589,13 +645,14 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
           return;
         }
 
+        fileName = chooser.getSelectedFile().getPath();
+
       jalview.bin.Cache.setProperty("DEFAULT_FILE_FORMAT",
                                     currentFileFormat);
 
-      String choice = chooser.getSelectedFile().getPath();
-      jalview.bin.Cache.setProperty("LAST_DIRECTORY", choice);
+      jalview.bin.Cache.setProperty("LAST_DIRECTORY", fileName);
 
-      saveAlignment(choice, currentFileFormat);
+      saveAlignment(fileName, currentFileFormat);
     }
   }
 
@@ -613,6 +670,11 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
 
       new Jalview2XML().SaveAlignment(this, file, shortName);
 
+      statusBar.setText("Successfully saved to file: "
+                          +fileName+" in "
+                          +format +" format.");
+
+
       // USE Jalview2XML to save this file
       return true;
     }
@@ -651,6 +713,9 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
         out.print(output);
         out.close();
         this.setTitle(file);
+        statusBar.setText("Successfully saved to file: "
+                          +fileName+" in "
+                          +format +" format.");
         return true;
       }
       catch (Exception ex)
@@ -685,6 +750,7 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
     }
 
     CutAndPasteTransfer cap = new CutAndPasteTransfer();
+    cap.setForInput(null);
     Desktop.addInternalFrame(cap,
                              "Alignment output - " + e.getActionCommand(), 600,
                              500);
@@ -787,28 +853,45 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
    *
    * @param e DOCUMENT ME!
    */
-  public void closeMenuItem_actionPerformed(ActionEvent e)
+  public void closeMenuItem_actionPerformed(boolean closeAllTabs)
   {
+    if(alignPanels!=null && alignPanels.size()<2)
+      closeAllTabs = true;
+
     try
     {
       if(alignPanels!=null)
       {
-        for (int i = 0; i < alignPanels.size(); i++)
+        if (closeAllTabs)
+          for (int i = 0; i < alignPanels.size(); i++)
+          {
+            AlignmentPanel ap = (AlignmentPanel) alignPanels.elementAt(i);
+            PaintRefresher.RemoveComponent(ap.seqPanel.seqCanvas);
+            PaintRefresher.RemoveComponent(ap.idPanel.idCanvas);
+            PaintRefresher.RemoveComponent(ap);
+          }
+        else
         {
-          AlignmentPanel ap = (AlignmentPanel) alignPanels.elementAt(i);
-          PaintRefresher.RemoveComponent(ap.seqPanel.seqCanvas);
-          PaintRefresher.RemoveComponent(ap.idPanel.idCanvas);
-          PaintRefresher.RemoveComponent(ap);
+          int index = tabbedPane.getSelectedIndex();
+
+          tabbedPane.removeTabAt(index);
+          alignPanels.removeElement(alignPanel);
+          PaintRefresher.RemoveComponent(alignPanel.seqPanel.seqCanvas);
+          PaintRefresher.RemoveComponent(alignPanel.idPanel.idCanvas);
+          PaintRefresher.RemoveComponent(alignPanel);
+          alignPanel = null;
+          viewport = null;
+          tabbedPane.validate();
+
+          if(index==tabbedPane.getTabCount())
+            index --;
+
+          this.tabSelectionChanged(index);
         }
-      //  alignPanels = null;
       }
-      else
-        System.out.println("null one here");
 
-    //  alignPanel = null;
-    //  viewport = null;
-
-      this.setClosed(true);
+      if (closeAllTabs)
+        this.setClosed(true);
     }
     catch (Exception ex)
     {
@@ -823,10 +906,10 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
   void updateEditMenuBar()
   {
 
-    if (historyList.size() > 0)
+    if (viewport.historyList.size() > 0)
     {
       undoMenuItem.setEnabled(true);
-      CommandI command = (CommandI) historyList.peek();
+      CommandI command = (CommandI) viewport.historyList.peek();
       undoMenuItem.setText("Undo " + command.getDescription());
     }
     else
@@ -835,11 +918,11 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
       undoMenuItem.setText("Undo");
     }
 
-    if (redoList.size() > 0)
+    if (viewport.redoList.size() > 0)
     {
       redoMenuItem.setEnabled(true);
 
-      CommandI command = (CommandI) redoList.peek();
+      CommandI command = (CommandI) viewport.redoList.peek();
       redoMenuItem.setText("Redo " + command.getDescription());
     }
     else
@@ -854,8 +937,8 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
   {
     if(command.getSize()>0)
     {
-      historyList.push(command);
-      redoList.clear();
+      viewport.historyList.push(command);
+      viewport.redoList.clear();
       updateEditMenuBar();
       viewport.hasHiddenColumns = viewport.colSel.getHiddenColumns() != null;
     }
@@ -870,8 +953,8 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
    */
   protected void undoMenuItem_actionPerformed(ActionEvent e)
   {
-    CommandI command = (CommandI)historyList.pop();
-    redoList.push(command);
+    CommandI command = (CommandI)viewport.historyList.pop();
+    viewport.redoList.push(command);
     command.undoCommand();
 
     viewport.hasHiddenColumns = viewport.colSel.getHiddenColumns() != null;
@@ -887,8 +970,8 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
    */
   protected void redoMenuItem_actionPerformed(ActionEvent e)
   {
-    CommandI command = (CommandI) redoList.pop();
-    historyList.push(command);
+    CommandI command = (CommandI) viewport.redoList.pop();
+    viewport.historyList.push(command);
     command.doCommand();
     viewport.hasHiddenColumns = viewport.colSel.getHiddenColumns()!=null;
 
@@ -1259,7 +1342,7 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
    *
    * @param e DOCUMENT ME!
    */
-  protected void delete_actionPerformed(ActionEvent e)
+  protected void delete_actionPerformed(ActionEvent evt)
   {
 
     SequenceGroup sg = viewport.getSelectionGroup();
@@ -1331,6 +1414,7 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
   protected void deleteGroups_actionPerformed(ActionEvent e)
   {
     viewport.alignment.deleteAllGroups();
+    viewport.sequenceColours.clear();
     viewport.setSelectionGroup(null);
     PaintRefresher.Refresh(this, viewport.getSequenceSetId());
     alignPanel.repaint();
@@ -1459,6 +1543,7 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
                                     viewport.alignment,
                                     viewport.colSel,
                                     viewport.selectionGroup);
+        viewport.setStartRes(0);
       }
      else
      {
@@ -1489,7 +1574,8 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
         }
       }
 
-      viewport.firePropertyChange("alignment", null, viewport.getAlignment().getSequences());
+      viewport.firePropertyChange("alignment", null,
+                                  viewport.getAlignment().getSequences());
     }
   }
 
@@ -1600,6 +1686,29 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
     Desktop.addInternalFrame(frame, "Find", 340, 110);
   }
 
+  public void newView_actionPerformed(ActionEvent e)
+  {
+    AlignmentPanel newap =
+        new Jalview2XML().copyAlignPanel(alignPanel, true);
+
+    if (viewport.viewName == null)
+      viewport.viewName = "View 1";
+
+    newap.av.historyList = viewport.historyList;
+    newap.av.redoList = viewport.redoList;
+    newap.av.viewName = "View " +
+        (Desktop.getViewCount(viewport.getSequenceSetId()) + 1);
+
+    addAlignmentPanel(newap, false);
+
+    if(alignPanels.size()==2)
+    {
+      viewport.gatherViewsHere = true;
+    }
+    tabbedPane.setSelectedIndex(tabbedPane.getTabCount() - 1);
+  }
+
+
   /**
    * DOCUMENT ME!
    *
@@ -1610,13 +1719,6 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
     new FontChooser(alignPanel);
   }
 
-  public void smoothFont_actionPerformed(ActionEvent e)
-  {
-    viewport.antiAlias = smoothFont.isSelected();
-    alignPanel.annotationPanel.image = null;
-    alignPanel.repaint();
-  }
-
 
   /**
    * DOCUMENT ME!
@@ -1822,6 +1924,114 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
     alignPanel.setOverviewPanel(overview);
   }
 
+  public void textColour_actionPerformed(ActionEvent e)
+  {
+    int original1 = viewport.textColour.getRGB();
+    int original2 = viewport.textColour2.getRGB();
+    int thresh = viewport.thresholdTextColour;
+    final JSlider slider = new JSlider(0, 750, viewport.thresholdTextColour);
+    final JButton col1 = new JButton("DARK");
+    col1.setBackground(viewport.textColour);
+    col1.setForeground(viewport.textColour);
+    final JButton col2 = new JButton("LIGHT");
+    col2.setBackground(viewport.textColour2);
+    col2.setForeground(viewport.textColour2);
+    final JPanel bigpanel = new JPanel(new BorderLayout());
+    JPanel panel = new JPanel();
+    bigpanel.add(panel, BorderLayout.CENTER);
+    bigpanel.add(new JLabel(
+      "<html><i>Select a dark and light text colour, then set the threshold to"
+     +"<br>switch between colours, based on background colour</i></html>"),
+                 BorderLayout.NORTH);
+    panel.add(col1);
+    panel.add(slider);
+    panel.add(col2);
+
+    col1.addActionListener(new ActionListener()
+        {
+          public void actionPerformed(ActionEvent e)
+          {
+            Color col = JColorChooser.showDialog(bigpanel,
+                                                 "Select Colour for Text",
+                                                 viewport.textColour);
+            if (col != null)
+            {
+              viewport.textColour = col;
+              col1.setBackground(col);
+              col1.setForeground(col);
+              if(viewport.colourAppliesToAllGroups)
+                setGroupTextColour();
+            }
+            alignPanel.repaint();
+          }
+        });
+
+    col2.addActionListener(new ActionListener()
+    {
+      public void actionPerformed(ActionEvent e)
+      {
+        Color col = JColorChooser.showDialog(bigpanel,
+                                             "Select Colour for Text",
+                                             viewport.textColour);
+        if (col != null)
+        {
+          viewport.textColour2 = col;
+          col2.setBackground(col);
+          col2.setForeground(col);
+          if(viewport.colourAppliesToAllGroups)
+                setGroupTextColour();
+        }
+        alignPanel.repaint();
+      }
+    });
+
+
+    slider.addChangeListener(new ChangeListener()
+    {
+      public void stateChanged(ChangeEvent evt)
+      {
+        viewport.thresholdTextColour = slider.getValue();
+        if(viewport.colourAppliesToAllGroups)
+                setGroupTextColour();
+        alignPanel.repaint();
+      }
+    });
+
+    int reply = JOptionPane.showInternalOptionDialog(this,
+                                                 bigpanel,
+                                                 "Adjust Foreground Text Colour Threshold",
+                                                 JOptionPane.OK_CANCEL_OPTION,
+                                                 JOptionPane.QUESTION_MESSAGE,
+                                                 null,
+                                                 null, null);
+
+    if(reply==JOptionPane.CANCEL_OPTION)
+    {
+      viewport.textColour = new Color(original1);
+      viewport.textColour2 = new Color(original2);
+      viewport.thresholdTextColour = thresh;
+    }
+  }
+
+  void setGroupTextColour()
+  {
+    if(viewport.alignment.getGroups()==null)
+      return;
+
+    Vector groups = viewport.alignment.getGroups();
+
+    for(int i=0; i<groups.size(); i++)
+    {
+      SequenceGroup sg = (SequenceGroup)groups.elementAt(i);
+      sg.textColour = viewport.textColour;
+      sg.textColour2 = viewport.textColour2;
+      sg.thresholdTextColour = viewport.thresholdTextColour;
+    }
+
+
+  }
+
+
   /**
    * DOCUMENT ME!
    *
@@ -2034,8 +2244,8 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
                 viewport.getIgnoreGapsConsensus());
 
          sg.cs.setConsensus(AAFrequency.calculate(
-             sg.getSequences(true), 0,
-             sg.getWidth()));
+             sg.getSequences(true), sg.getStartRes(),
+             sg.getEndRes()+1));
        }
         else
           sg.cs.setThreshold(0, viewport.getIgnoreGapsConsensus());
@@ -2045,8 +2255,9 @@ public class AlignFrame extends GAlignFrame implements DropTargetListener
         {
           Conservation c = new Conservation("Group",
                                             ResidueProperties.propHash, 3,
-                                            sg.getSequences(true), 0,
-                                            viewport.alignment.getWidth() - 1);
+                                            sg.getSequences(true),
+                                            sg.getStartRes(),
+                                            sg.getEndRes()+1);
           c.calculate();
           c.verdict(false, viewport.ConsPercGaps);
           sg.cs.setConservation(c);
@@ -3100,6 +3311,7 @@ public void drop(DropTargetDropEvent evt)
     {
       alignPanel = (AlignmentPanel) alignPanels.elementAt(index);
       viewport = alignPanel.av;
+      setMenusFromViewport(viewport);
     }
   }