Formatting
[jalview.git] / src / jalview / jbgui / GAlignFrame.java
index 304134c..1b89d71 100755 (executable)
@@ -1,6 +1,6 @@
 /*\r
  * Jalview - A Sequence Alignment Editor and Viewer\r
- * Copyright (C) 2006 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
+ * Copyright (C) 2007 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
  *\r
  * This program is free software; you can redistribute it and/or\r
  * modify it under the terms of the GNU General Public License\r
@@ -24,10 +24,6 @@ import javax.swing.*;
 import javax.swing.event.*;\r
 \r
 import jalview.schemes.*;\r
-import java.awt.BorderLayout;\r
-\r
-\r
-\r
 \r
 public class GAlignFrame\r
     extends JInternalFrame\r
@@ -58,7 +54,6 @@ public class GAlignFrame
   protected JMenuItem PCAMenuItem = new JMenuItem();\r
   protected JMenuItem averageDistanceTreeMenuItem = new JMenuItem();\r
   protected JMenuItem neighbourTreeMenuItem = new JMenuItem();\r
-  protected JMenuItem clustalAlignMenuItem = new JMenuItem();\r
   BorderLayout borderLayout1 = new BorderLayout();\r
   public JLabel statusBar = new JLabel();\r
   protected JMenuItem saveAs = new JMenuItem();\r
@@ -89,7 +84,6 @@ public class GAlignFrame
   JMenuItem printMenuItem = new JMenuItem();\r
   public JCheckBoxMenuItem renderGapsMenuItem = new JCheckBoxMenuItem();\r
   JMenuItem findMenuItem = new JMenuItem();\r
-  JMenu searchMenu = new JMenu();\r
   public JCheckBoxMenuItem abovePIDThreshold = new JCheckBoxMenuItem();\r
   public JCheckBoxMenuItem showSeqFeatures = new JCheckBoxMenuItem();\r
   protected JRadioButtonMenuItem nucleotideColour = new JRadioButtonMenuItem();\r
@@ -97,7 +91,7 @@ public class GAlignFrame
   JMenuItem delete = new JMenuItem();\r
   JMenuItem copy = new JMenuItem();\r
   JMenuItem cut = new JMenuItem();\r
-  JMenu jMenu1 = new JMenu();\r
+  JMenu pasteMenu = new JMenu();\r
   JMenuItem pasteNew = new JMenuItem();\r
   JMenuItem pasteThis = new JMenuItem();\r
   public JCheckBoxMenuItem applyToAllGroups = new JCheckBoxMenuItem();\r
@@ -121,7 +115,6 @@ public class GAlignFrame
   protected JMenuItem showTranslation = new JMenuItem();\r
   public JMenuItem featureSettings = new JMenuItem();\r
   JMenuItem fetchSequence = new JMenuItem();\r
-  protected JCheckBoxMenuItem smoothFont = new JCheckBoxMenuItem();\r
   JMenuItem annotationColour = new JMenuItem();\r
   JMenuItem associatedData = new JMenuItem();\r
   protected JCheckBoxMenuItem autoCalculate = new JCheckBoxMenuItem();\r
@@ -143,6 +136,15 @@ public class GAlignFrame
   JMenuItem invertColSel = new JMenuItem();\r
   protected JTabbedPane tabbedPane = new JTabbedPane();\r
   JMenuItem save = new JMenuItem();\r
+  protected JMenuItem reload = new JMenuItem();\r
+  JMenuItem newView = new JMenuItem();\r
+  JMenuItem textColour = new JMenuItem();\r
+  JMenu formatMenu = new JMenu();\r
+  JMenu selectMenu = new JMenu();\r
+  protected JCheckBoxMenuItem idRightAlign = new JCheckBoxMenuItem();\r
+  protected JMenuItem gatherViews = new JMenuItem();\r
+  protected JMenuItem expandViews = new JMenuItem();\r
+  JMenuItem pageSetup = new JMenuItem();\r
   public GAlignFrame()\r
   {\r
     try\r
@@ -153,7 +155,8 @@ public class GAlignFrame
       // dynamically fill save as menu with available formats\r
       for (int i = 0; i < jalview.io.FormatAdapter.WRITEABLE_FORMATS.length; i++)\r
       {\r
-        JMenuItem item = new JMenuItem( jalview.io.FormatAdapter.WRITEABLE_FORMATS[i] );\r
+        JMenuItem item = new JMenuItem(jalview.io.FormatAdapter.\r
+                                       WRITEABLE_FORMATS[i]);\r
 \r
         item.addActionListener(new java.awt.event.ActionListener()\r
         {\r
@@ -170,45 +173,61 @@ public class GAlignFrame
     {\r
     }\r
 \r
+    if (!System.getProperty("os.name").startsWith("Mac"))\r
+    {\r
+      closeMenuItem.setMnemonic('C');\r
+      outputTextboxMenu.setMnemonic('T');\r
+      undoMenuItem.setMnemonic('Z');\r
+      redoMenuItem.setMnemonic('0');\r
+      copy.setMnemonic('C');\r
+      cut.setMnemonic('U');\r
+      pasteMenu.setMnemonic('P');\r
+      reload.setMnemonic('R');\r
+    }\r
 \r
-    if(jalview.gui.UserDefinedColours.getUserColourSchemes()!=null)\r
+    if (jalview.gui.UserDefinedColours.getUserColourSchemes() != null)\r
     {\r
       java.util.Enumeration userColours = jalview.gui.UserDefinedColours.\r
           getUserColourSchemes().keys();\r
 \r
       while (userColours.hasMoreElements())\r
       {\r
-        final JRadioButtonMenuItem radioItem = new JRadioButtonMenuItem(userColours.\r
+        final JRadioButtonMenuItem radioItem = new JRadioButtonMenuItem(\r
+            userColours.\r
             nextElement().toString());\r
         radioItem.setName("USER_DEFINED");\r
         radioItem.addMouseListener(new MouseAdapter()\r
+        {\r
+          public void mousePressed(MouseEvent evt)\r
+          {\r
+            if (evt.isControlDown() || SwingUtilities.isRightMouseButton(evt))\r
             {\r
-              public void mousePressed(MouseEvent evt)\r
+              radioItem.removeActionListener(radioItem.getActionListeners()[0]);\r
+\r
+              int option = JOptionPane.showInternalConfirmDialog(jalview.gui.\r
+                  Desktop.desktop,\r
+                  "Remove from default list?",\r
+                  "Remove user defined colour",\r
+                  JOptionPane.YES_NO_OPTION);\r
+              if (option == JOptionPane.YES_OPTION)\r
               {\r
-                if(evt.isControlDown() || SwingUtilities.isRightMouseButton(evt))\r
+                jalview.gui.UserDefinedColours.removeColourFromDefaults(\r
+                    radioItem.getText());\r
+                colourMenu.remove(radioItem);\r
+              }\r
+              else\r
+              {\r
+                radioItem.addActionListener(new ActionListener()\r
                 {\r
-                  radioItem.removeActionListener(radioItem.getActionListeners()[0]);\r
-\r
-                  int option = JOptionPane.showInternalConfirmDialog(jalview.gui.Desktop.desktop,\r
-                      "Remove from default list?",\r
-                      "Remove user defined colour",\r
-                      JOptionPane.YES_NO_OPTION);\r
-                  if(option == JOptionPane.YES_OPTION)\r
+                  public void actionPerformed(ActionEvent evt)\r
                   {\r
-                    jalview.gui.UserDefinedColours.removeColourFromDefaults(radioItem.getText());\r
-                    colourMenu.remove(radioItem);\r
+                    userDefinedColour_actionPerformed(evt);\r
                   }\r
-                  else\r
-                    radioItem.addActionListener(new ActionListener()\r
-                    {\r
-                      public void actionPerformed(ActionEvent evt)\r
-                      {\r
-                        userDefinedColour_actionPerformed(evt);\r
-                      }\r
-                    });\r
-                }\r
+                });\r
               }\r
-            });\r
+            }\r
+          }\r
+        });\r
         radioItem.addActionListener(new ActionListener()\r
         {\r
           public void actionPerformed(ActionEvent evt)\r
@@ -236,7 +255,6 @@ public class GAlignFrame
 \r
     setColourSelected(jalview.bin.Cache.getDefault("DEFAULT_COLOUR", "None"));\r
 \r
-\r
   }\r
 \r
   public void setColourSelected(String defaultColour)\r
@@ -249,8 +267,8 @@ public class GAlignFrame
       switch (index)\r
       {\r
         case ColourSchemeProperty.NONE:\r
-              noColourmenuItem.setSelected(true);\r
-              break;\r
+          noColourmenuItem.setSelected(true);\r
+          break;\r
         case ColourSchemeProperty.CLUSTAL:\r
           clustalColour.setSelected(true);\r
 \r
@@ -318,9 +336,11 @@ public class GAlignFrame
       throws Exception\r
   {\r
     fileMenu.setText("File");\r
-    saveAs.setText("Save As ...");\r
+    saveAs.setText("Save As...");\r
     saveAs.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.event.\r
-        KeyEvent.VK_S, java.awt.event.KeyEvent.ALT_MASK, false));\r
+        KeyEvent.VK_S,\r
+        Toolkit.getDefaultToolkit().getMenuShortcutKeyMask() |\r
+        java.awt.event.KeyEvent.SHIFT_MASK, false));\r
     saveAs.addActionListener(new ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -328,15 +348,14 @@ public class GAlignFrame
         saveAs_actionPerformed(e);\r
       }\r
     });\r
-    closeMenuItem.setMnemonic('C');\r
     closeMenuItem.setText("Close");\r
     closeMenuItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.\r
-        event.KeyEvent.VK_W, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        event.KeyEvent.VK_W, Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     closeMenuItem.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
       {\r
-        closeMenuItem_actionPerformed(e);\r
+        closeMenuItem_actionPerformed(false);\r
       }\r
     });\r
     editMenu.setText("Edit");\r
@@ -344,7 +363,7 @@ public class GAlignFrame
     colourMenu.setText("Colour");\r
     calculateMenu.setText("Calculate");\r
     webService.setText("Web Service");\r
-    selectAllSequenceMenuItem.setText("Select all");\r
+    selectAllSequenceMenuItem.setText("Select All");\r
     selectAllSequenceMenuItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(\r
         java.awt.event.KeyEvent.VK_A,\r
         Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
@@ -371,7 +390,7 @@ public class GAlignFrame
     invertSequenceMenuItem.setText("Invert Sequence Selection");\r
     invertSequenceMenuItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(\r
         java.awt.event.KeyEvent.VK_I,\r
-        java.awt.event.KeyEvent.SHIFT_MASK, false));\r
+        Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     invertSequenceMenuItem.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -381,7 +400,8 @@ public class GAlignFrame
     });\r
     remove2LeftMenuItem.setText("Remove Left");\r
     remove2LeftMenuItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.\r
-        awt.event.KeyEvent.VK_L, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        awt.event.KeyEvent.VK_L,\r
+        Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     remove2LeftMenuItem.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -391,7 +411,8 @@ public class GAlignFrame
     });\r
     remove2RightMenuItem.setText("Remove Right");\r
     remove2RightMenuItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.\r
-        awt.event.KeyEvent.VK_R, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        awt.event.KeyEvent.VK_R,\r
+        Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     remove2RightMenuItem.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -402,7 +423,7 @@ public class GAlignFrame
     removeGappedColumnMenuItem.setText("Remove Empty Columns");\r
     removeGappedColumnMenuItem.setAccelerator(javax.swing.KeyStroke.\r
                                               getKeyStroke(java.awt.event.\r
-        KeyEvent.VK_E, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        KeyEvent.VK_E, Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     removeGappedColumnMenuItem.addActionListener(new java.awt.event.\r
                                                  ActionListener()\r
     {\r
@@ -413,7 +434,9 @@ public class GAlignFrame
     });\r
     removeAllGapsMenuItem.setText("Remove All Gaps");\r
     removeAllGapsMenuItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(\r
-        java.awt.event.KeyEvent.VK_G, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        java.awt.event.KeyEvent.VK_E,\r
+        Toolkit.getDefaultToolkit().getMenuShortcutKeyMask() |\r
+        java.awt.event.KeyEvent.SHIFT_MASK, false));\r
     removeAllGapsMenuItem.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -465,7 +488,8 @@ public class GAlignFrame
     });\r
     removeRedundancyMenuItem.setText("Remove Redundancy...");\r
     removeRedundancyMenuItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(\r
-        java.awt.event.KeyEvent.VK_R, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        java.awt.event.KeyEvent.VK_D,\r
+        Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     removeRedundancyMenuItem.addActionListener(new java.awt.event.\r
                                                ActionListener()\r
     {\r
@@ -515,7 +539,6 @@ public class GAlignFrame
     statusBar.setFont(new java.awt.Font("Verdana", 0, 11));\r
     statusBar.setBorder(BorderFactory.createLineBorder(Color.black));\r
     statusBar.setText("Status bar");\r
-    outputTextboxMenu.setMnemonic('T');\r
     outputTextboxMenu.setText("Output to Textbox");\r
     clustalColour.setText("Clustalx");\r
 \r
@@ -626,7 +649,8 @@ public class GAlignFrame
     });\r
     annotationPanelMenuItem.setActionCommand("");\r
     annotationPanelMenuItem.setText("Show Annotations");\r
-    annotationPanelMenuItem.setState( jalview.bin.Cache.getDefault("SHOW_ANNOTATIONS",true));\r
+    annotationPanelMenuItem.setState(jalview.bin.Cache.getDefault(\r
+        "SHOW_ANNOTATIONS", true));\r
     annotationPanelMenuItem.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -659,7 +683,6 @@ public class GAlignFrame
       }\r
     });\r
     undoMenuItem.setEnabled(false);\r
-    undoMenuItem.setMnemonic('Z');\r
     undoMenuItem.setText("Undo");\r
     undoMenuItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(\r
         java.awt.event.KeyEvent.VK_Z,\r
@@ -672,10 +695,9 @@ public class GAlignFrame
       }\r
     });\r
     redoMenuItem.setEnabled(false);\r
-    redoMenuItem.setMnemonic('0');\r
     redoMenuItem.setText("Redo");\r
     redoMenuItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.\r
-        event.KeyEvent.VK_Y, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        event.KeyEvent.VK_Y, Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     redoMenuItem.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -707,9 +729,9 @@ public class GAlignFrame
         wrapMenuItem_actionPerformed(e);\r
       }\r
     });\r
-    printMenuItem.setText("Print");\r
+    printMenuItem.setText("Print ...");\r
     printMenuItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.\r
-        event.KeyEvent.VK_P, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        event.KeyEvent.VK_P, Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     printMenuItem.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -737,8 +759,6 @@ public class GAlignFrame
         findMenuItem_actionPerformed(e);\r
       }\r
     });\r
-    searchMenu.setText("Search");\r
-\r
     abovePIDThreshold.setText("Above Identity Threshold");\r
     abovePIDThreshold.addActionListener(new java.awt.event.ActionListener()\r
     {\r
@@ -765,7 +785,7 @@ public class GAlignFrame
     });\r
     deleteGroups.setText("Undefine groups");\r
     deleteGroups.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.\r
-        event.KeyEvent.VK_U, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        event.KeyEvent.VK_U, Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     deleteGroups.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -777,7 +797,6 @@ public class GAlignFrame
     copy.setAccelerator(javax.swing.KeyStroke.getKeyStroke(\r
         java.awt.event.KeyEvent.VK_C,\r
         Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
-    copy.setMnemonic(KeyEvent.VK_C);\r
 \r
     copy.addActionListener(new java.awt.event.ActionListener()\r
     {\r
@@ -790,7 +809,6 @@ public class GAlignFrame
     cut.setAccelerator(javax.swing.KeyStroke.getKeyStroke(\r
         java.awt.event.KeyEvent.VK_X,\r
         Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
-    cut.setMnemonic(KeyEvent.VK_X);\r
     cut.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -799,6 +817,8 @@ public class GAlignFrame
       }\r
     });\r
     delete.setText("Delete");\r
+    delete.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.event.\r
+        KeyEvent.VK_BACK_SPACE, 0, false));\r
     delete.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -806,12 +826,12 @@ public class GAlignFrame
         delete_actionPerformed(e);\r
       }\r
     });\r
-    jMenu1.setMnemonic('V');\r
-    jMenu1.setText("Paste");\r
+    pasteMenu.setText("Paste");\r
     pasteNew.setText("To New Alignment");\r
     pasteNew.setAccelerator(javax.swing.KeyStroke.getKeyStroke(\r
         java.awt.event.KeyEvent.VK_V,\r
-        Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
+        Toolkit.getDefaultToolkit().getMenuShortcutKeyMask() |\r
+        java.awt.event.KeyEvent.SHIFT_MASK, false));\r
     pasteNew.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -820,6 +840,9 @@ public class GAlignFrame
       }\r
     });\r
     pasteThis.setText("Add To This Alignment");\r
+    pasteThis.setAccelerator(javax.swing.KeyStroke.getKeyStroke(\r
+        java.awt.event.KeyEvent.VK_V,\r
+        Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     pasteThis.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -854,7 +877,7 @@ public class GAlignFrame
     });\r
 \r
     seqLimits.setText("Show Sequence Limits");\r
-    seqLimits.setState( jalview.bin.Cache.getDefault("SHOW_JVSUFFIX",true));\r
+    seqLimits.setState(jalview.bin.Cache.getDefault("SHOW_JVSUFFIX", true));\r
     seqLimits.addActionListener(new java.awt.event.ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -926,11 +949,26 @@ public class GAlignFrame
     });\r
     sortByTreeMenu.setText("By Tree Order");\r
     sort.setText("Sort");\r
+    sort.addMenuListener(new MenuListener()\r
+    {\r
+      public void menuSelected(MenuEvent e)\r
+      {\r
+        buildTreeMenu();\r
+      }\r
+\r
+      public void menuDeselected(MenuEvent e)\r
+      {\r
+      }\r
+\r
+      public void menuCanceled(MenuEvent e)\r
+      {\r
+      }\r
+    });\r
     calculate.setText("Calculate Tree");\r
 \r
     jMenu2.setText("Export Image");\r
     padGapsMenuitem.setText("Pad Gaps");\r
-    padGapsMenuitem.setState( jalview.bin.Cache.getDefault("PAD_GAPS", false));\r
+    padGapsMenuitem.setState(jalview.bin.Cache.getDefault("PAD_GAPS", false));\r
     padGapsMenuitem.addActionListener(new ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -956,7 +994,6 @@ public class GAlignFrame
       }\r
     });\r
 \r
-\r
     featureSettings.setText("Feature Settings...");\r
     featureSettings.addActionListener(new ActionListener()\r
     {\r
@@ -973,14 +1010,6 @@ public class GAlignFrame
         fetchSequence_actionPerformed(e);\r
       }\r
     });\r
-    smoothFont.setText("Smooth Fonts");\r
-    smoothFont.addActionListener(new ActionListener()\r
-    {\r
-      public void actionPerformed(ActionEvent e)\r
-      {\r
-        smoothFont_actionPerformed(e);\r
-      }\r
-    });\r
 \r
     annotationColour.setText("By Annotation...");\r
     annotationColour.addActionListener(new ActionListener()\r
@@ -999,7 +1028,7 @@ public class GAlignFrame
       }\r
     });\r
     autoCalculate.setText("Autocalculate Consensus");\r
-    autoCalculate.setState( jalview.bin.Cache.getDefault("AUTO_CALC_CONSENSUS", true));\r
+    autoCalculate.setState(jalview.bin.Cache.getDefault("AUTO_CALC_CONSENSUS", true));\r
     autoCalculate.addActionListener(new ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -1083,7 +1112,7 @@ public class GAlignFrame
         hideSelColumns_actionPerformed(e);\r
       }\r
     });\r
-    hiddenMarkers.setText("Hidden Markers");\r
+    hiddenMarkers.setText("Show Hidden Markers");\r
     hiddenMarkers.addActionListener(new ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -1093,7 +1122,10 @@ public class GAlignFrame
     });\r
     invertColSel.setText("Invert Column Selection");\r
     invertColSel.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.\r
-        event.KeyEvent.VK_I, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        event.KeyEvent.VK_I,\r
+        Toolkit.getDefaultToolkit().getMenuShortcutKeyMask()\r
+        | java.awt.event.KeyEvent.ALT_MASK,\r
+        false));\r
     invertColSel.addActionListener(new ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -1103,12 +1135,12 @@ public class GAlignFrame
     });\r
     tabbedPane.addChangeListener(new javax.swing.event.ChangeListener()\r
     {\r
-        public void stateChanged(ChangeEvent evt)\r
-        {\r
-            JTabbedPane pane = (JTabbedPane)evt.getSource();\r
-            int sel = pane.getSelectedIndex();\r
-            tabSelectionChanged(sel);\r
-        }\r
+      public void stateChanged(ChangeEvent evt)\r
+      {\r
+        JTabbedPane pane = (JTabbedPane) evt.getSource();\r
+        int sel = pane.getSelectedIndex();\r
+        tabSelectionChanged(sel);\r
+      }\r
     });\r
     tabbedPane.addMouseListener(new MouseAdapter()\r
     {\r
@@ -1126,7 +1158,7 @@ public class GAlignFrame
     });\r
     save.setText("Save");\r
     save.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.event.\r
-        KeyEvent.VK_S, java.awt.event.KeyEvent.CTRL_MASK, false));\r
+        KeyEvent.VK_S, Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
     save.addActionListener(new ActionListener()\r
     {\r
       public void actionPerformed(ActionEvent e)\r
@@ -1134,21 +1166,94 @@ public class GAlignFrame
         save_actionPerformed(e);\r
       }\r
     });\r
+    reload.setEnabled(false);\r
+    reload.setText("Reload");\r
+    reload.addActionListener(new ActionListener()\r
+    {\r
+      public void actionPerformed(ActionEvent e)\r
+      {\r
+        reload_actionPerformed(e);\r
+      }\r
+    });\r
+    newView.setText("New View");\r
+    newView.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.event.\r
+        KeyEvent.VK_T, Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(), false));\r
+    newView.addActionListener(new ActionListener()\r
+    {\r
+      public void actionPerformed(ActionEvent e)\r
+      {\r
+        newView_actionPerformed(e);\r
+      }\r
+    });\r
+    tabbedPane.setToolTipText("<html><i> Right-click to rename tab"\r
+                              +\r
+        "<br> Press X to eXpand tabs, G to reGroup.</i></html>");\r
+    textColour.setText("Text Colour");\r
+    textColour.addActionListener(new ActionListener()\r
+    {\r
+      public void actionPerformed(ActionEvent e)\r
+      {\r
+        textColour_actionPerformed(e);\r
+      }\r
+    });\r
+    formatMenu.setText("Format");\r
+    selectMenu.setText("Select");\r
+    idRightAlign.setText("Right Align Sequence Id");\r
+    idRightAlign.addActionListener(new ActionListener()\r
+    {\r
+      public void actionPerformed(ActionEvent e)\r
+      {\r
+        idRightAlign_actionPerformed(e);\r
+      }\r
+    });\r
+    gatherViews.setEnabled(false);\r
+    gatherViews.setText("Gather Views");\r
+    gatherViews.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.\r
+        event.KeyEvent.VK_G, 0, false));\r
+    gatherViews.addActionListener(new ActionListener()\r
+    {\r
+      public void actionPerformed(ActionEvent e)\r
+      {\r
+        gatherViews_actionPerformed(e);\r
+      }\r
+    });\r
+    expandViews.setEnabled(false);\r
+    expandViews.setText("Expand Views");\r
+    expandViews.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.\r
+        event.KeyEvent.VK_X, 0, false));\r
+    expandViews.addActionListener(new ActionListener()\r
+    {\r
+      public void actionPerformed(ActionEvent e)\r
+      {\r
+        expandViews_actionPerformed(e);\r
+      }\r
+    });\r
+    pageSetup.setText("Page Setup ...");\r
+    pageSetup.addActionListener(new ActionListener()\r
+    {\r
+      public void actionPerformed(ActionEvent e)\r
+      {\r
+        pageSetup_actionPerformed(e);\r
+      }\r
+    });\r
 \r
     alignFrameMenuBar.add(fileMenu);\r
     alignFrameMenuBar.add(editMenu);\r
-    alignFrameMenuBar.add(searchMenu);\r
+    alignFrameMenuBar.add(selectMenu);\r
     alignFrameMenuBar.add(viewMenu);\r
+    alignFrameMenuBar.add(formatMenu);\r
     alignFrameMenuBar.add(colourMenu);\r
     alignFrameMenuBar.add(calculateMenu);\r
     alignFrameMenuBar.add(webService);\r
-    fileMenu.add(addSequenceMenu);\r
     fileMenu.add(fetchSequence);\r
+    fileMenu.add(addSequenceMenu);\r
+    fileMenu.add(reload);\r
     fileMenu.addSeparator();\r
     fileMenu.add(vamsasStore);\r
     fileMenu.add(save);\r
     fileMenu.add(saveAs);\r
     fileMenu.add(outputTextboxMenu);\r
+    fileMenu.add(pageSetup);\r
     fileMenu.add(printMenuItem);\r
     fileMenu.addSeparator();\r
     fileMenu.add(jMenu2);\r
@@ -1162,15 +1267,9 @@ public class GAlignFrame
     editMenu.add(redoMenuItem);\r
     editMenu.add(cut);\r
     editMenu.add(copy);\r
-    editMenu.add(jMenu1);\r
+    editMenu.add(pasteMenu);\r
     editMenu.add(delete);\r
     editMenu.addSeparator();\r
-    editMenu.add(selectAllSequenceMenuItem);\r
-    editMenu.add(deselectAllSequenceMenuItem);\r
-    editMenu.add(invertSequenceMenuItem);\r
-    editMenu.add(invertColSel);\r
-    editMenu.add(deleteGroups);\r
-    editMenu.addSeparator();\r
     editMenu.add(remove2LeftMenuItem);\r
     editMenu.add(remove2RightMenuItem);\r
     editMenu.add(removeGappedColumnMenuItem);\r
@@ -1178,23 +1277,13 @@ public class GAlignFrame
     editMenu.add(removeRedundancyMenuItem);\r
     editMenu.addSeparator();\r
     editMenu.add(padGapsMenuitem);\r
-    searchMenu.add(findMenuItem);\r
-    viewMenu.add(font);\r
-    viewMenu.add(smoothFont);\r
+    viewMenu.add(newView);\r
+    viewMenu.add(expandViews);\r
+    viewMenu.add(gatherViews);\r
     viewMenu.addSeparator();\r
     viewMenu.add(jMenu3);\r
     viewMenu.add(hideMenu);\r
-    viewMenu.add(hiddenMarkers);\r
     viewMenu.addSeparator();\r
-    viewMenu.add(wrapMenuItem);\r
-    viewMenu.add(seqLimits);\r
-    viewMenu.add(scaleAbove);\r
-    viewMenu.add(scaleLeft);\r
-    viewMenu.add(scaleRight);\r
-    viewMenu.add(viewBoxesMenuItem);\r
-    viewMenu.add(viewTextMenuItem);\r
-    viewMenu.add(colourTextMenuItem);\r
-    viewMenu.add(renderGapsMenuItem);\r
     viewMenu.add(annotationPanelMenuItem);\r
     viewMenu.addSeparator();\r
     viewMenu.add(showSeqFeatures);\r
@@ -1202,6 +1291,7 @@ public class GAlignFrame
     viewMenu.addSeparator();\r
     viewMenu.add(overviewMenuItem);\r
     colourMenu.add(applyToAllGroups);\r
+    colourMenu.add(textColour);\r
     colourMenu.addSeparator();\r
     colourMenu.add(noColourmenuItem);\r
     colourMenu.add(clustalColour);\r
@@ -1230,12 +1320,14 @@ public class GAlignFrame
     calculateMenu.addSeparator();\r
     calculateMenu.add(showTranslation);\r
     calculateMenu.add(autoCalculate);\r
-    webServiceNoServices=new JMenuItem("<No Services>");\r
-    webService.add(webServiceNoServices);jMenu1.add(pasteNew);\r
-    jMenu1.add(pasteThis);\r
+    webServiceNoServices = new JMenuItem("<No Services>");\r
+    webService.add(webServiceNoServices);\r
+    pasteMenu.add(pasteNew);\r
+    pasteMenu.add(pasteThis);\r
     sort.add(sortIDMenuItem);\r
     sort.add(sortGroupMenuItem);\r
     sort.add(sortPairwiseMenuItem);\r
+    sort.add(sortByTreeMenu);\r
     calculate.add(averageDistanceTreeMenuItem);\r
     calculate.add(neighbourTreeMenuItem);\r
     calculate.add(avDistanceTreeBlosumMenuItem);\r
@@ -1253,6 +1345,26 @@ public class GAlignFrame
     jMenu3.add(showAllSeqs);\r
     hideMenu.add(hideSelColumns);\r
     hideMenu.add(hideSelSequences);\r
+    formatMenu.add(font);\r
+    formatMenu.addSeparator();\r
+    formatMenu.add(wrapMenuItem);\r
+    formatMenu.add(scaleAbove);\r
+    formatMenu.add(scaleLeft);\r
+    formatMenu.add(scaleRight);\r
+    formatMenu.add(seqLimits);\r
+    formatMenu.add(idRightAlign);\r
+    formatMenu.add(hiddenMarkers);\r
+    formatMenu.add(viewBoxesMenuItem);\r
+    formatMenu.add(viewTextMenuItem);\r
+    formatMenu.add(colourTextMenuItem);\r
+    formatMenu.add(renderGapsMenuItem);\r
+    selectMenu.add(findMenuItem);\r
+    selectMenu.addSeparator();\r
+    selectMenu.add(selectAllSequenceMenuItem);\r
+    selectMenu.add(deselectAllSequenceMenuItem);\r
+    selectMenu.add(invertSequenceMenuItem);\r
+    selectMenu.add(invertColSel);\r
+    selectMenu.add(deleteGroups);\r
   }\r
 \r
   protected void outputText_actionPerformed(ActionEvent e)\r
@@ -1288,7 +1400,7 @@ public class GAlignFrame
   {\r
   }\r
 \r
-  protected void closeMenuItem_actionPerformed(ActionEvent e)\r
+  protected void closeMenuItem_actionPerformed(boolean b)\r
   {\r
   }\r
 \r
@@ -1513,7 +1625,6 @@ public class GAlignFrame
 \r
   }\r
 \r
-\r
   public void createEPS(java.io.File f)\r
   {\r
   }\r
@@ -1546,8 +1657,6 @@ public class GAlignFrame
   {\r
   }\r
 \r
-\r
-\r
   protected void saveAs_actionPerformed(ActionEvent e)\r
   {\r
   }\r
@@ -1556,7 +1665,6 @@ public class GAlignFrame
   {\r
   }\r
 \r
-\r
   public void vamsasStore_actionPerformed(ActionEvent e)\r
   {\r
 \r
@@ -1592,7 +1700,6 @@ public class GAlignFrame
 \r
   }\r
 \r
-\r
   public void associatedData_actionPerformed(ActionEvent e)\r
   {\r
 \r
@@ -1667,4 +1774,44 @@ public class GAlignFrame
   {\r
 \r
   }\r
+\r
+  public void reload_actionPerformed(ActionEvent e)\r
+  {\r
+\r
+  }\r
+\r
+  public void newView_actionPerformed(ActionEvent e)\r
+  {\r
+\r
+  }\r
+\r
+  public void textColour_actionPerformed(ActionEvent e)\r
+  {\r
+\r
+  }\r
+\r
+  public void idRightAlign_actionPerformed(ActionEvent e)\r
+  {\r
+\r
+  }\r
+\r
+  public void expandViews_actionPerformed(ActionEvent e)\r
+  {\r
+\r
+  }\r
+\r
+  public void gatherViews_actionPerformed(ActionEvent e)\r
+  {\r
+\r
+  }\r
+\r
+  public void buildTreeMenu()\r
+  {\r
+\r
+  }\r
+\r
+  public void pageSetup_actionPerformed(ActionEvent e)\r
+  {\r
+\r
+  }\r
 }\r