+\r
+ void hideSequences(boolean representGroup)\r
+ {\r
+ SequenceGroup sg = ap.av.getSelectionGroup();\r
+ if(sg==null || sg.getSize(false)<1)\r
+ {\r
+ ap.av.hideSequence(sequence);\r
+ return;\r
+ }\r
+\r
+ int index = 0;\r
+ while(index < sg.getSize(false))\r
+ {\r
+ if(representGroup && sg.getSequenceAt(index)!=sequence)\r
+ {\r
+ sequence.addHiddenSequence(sg.getSequenceAt(index));\r
+ ap.av.hideSequence(sg.getSequenceAt(index));\r
+ }\r
+ else if(!representGroup)\r
+ {\r
+ ap.av.hideSequence(sg.getSequenceAt(index));\r
+ }\r
+ index ++;\r
+ }\r
+\r
+ ap.av.setSelectionGroup(null);\r
+ }\r
+\r
+ public void copy_actionPerformed(ActionEvent e)\r
+ {\r
+ ap.alignFrame.copy_actionPerformed(null);\r
+ }\r
+\r
+ public void cut_actionPerformed(ActionEvent e)\r
+ {\r
+ ap.alignFrame.cut_actionPerformed(null);\r
+ }\r
+\r
+ public void upperCase_actionPerformed(ActionEvent e)\r
+ {\r
+ SequenceGroup sg = ap.av.getSelectionGroup();\r
+ if(sg==null)\r
+ return;\r
+\r
+ for(int g=0; g<sg.getSize(true); g++)\r
+ {\r
+ ( (SequenceI)sg.getSequences(true).elementAt(g))\r
+ .changeCase(true, sg.getStartRes(), sg.getEndRes()+1);\r
+ }\r
+ ap.repaint();\r
+ }\r
+\r
+ public void lowerCase_actionPerformed(ActionEvent e)\r
+ {\r
+ SequenceGroup sg = ap.av.getSelectionGroup();\r
+ if(sg==null)\r
+ return;\r
+\r
+ for(int g=0; g<sg.getSize(true); g++)\r
+ {\r
+ ( (SequenceI)sg.getSequences(true).elementAt(g))\r
+ .changeCase(false, sg.getStartRes(), sg.getEndRes()+1);\r
+ }\r
+ ap.repaint();\r
+ }\r
+\r
+ public void toggle_actionPerformed(ActionEvent e)\r
+ {\r
+ SequenceGroup sg = ap.av.getSelectionGroup();\r
+ if (sg == null)\r
+ return;\r
+\r
+ for (int g = 0; g < sg.getSize(true); g++)\r
+ {\r
+ ( (SequenceI)sg.getSequences(true).elementAt(g))\r
+ .toggleCase(sg.getStartRes(), sg.getEndRes() + 1);\r
+ }\r
+\r
+ ap.repaint();\r
+ }\r
+\r
+ public void outputText_actionPerformed(ActionEvent e)\r
+ {\r
+ CutAndPasteTransfer cap = new CutAndPasteTransfer();\r
+ Desktop.addInternalFrame(cap,\r
+ "Alignment output - " + e.getActionCommand(), 600,\r
+ 500);\r
+\r
+ String [] omitHidden = null;\r
+\r
+ if(ap.av.hasHiddenColumns)\r
+ {\r
+ System.out.println("PROMPT USER HERE");\r
+ omitHidden = ap.av.getViewAsString(true);\r
+ }\r
+\r
+ cap.setText(new FormatAdapter().formatSequences(\r
+ e.getActionCommand(),\r
+ ap.av.getSelectionAsNewSequence(),\r
+ omitHidden));\r
+ }\r
+\r
+\r
+ public void pdbFromFile_actionPerformed(ActionEvent e)\r
+ {\r
+ jalview.io.JalviewFileChooser chooser\r
+ = new jalview.io.JalviewFileChooser(jalview.bin.Cache.\r
+ getProperty(\r
+ "LAST_DIRECTORY"));\r
+ chooser.setFileView(new jalview.io.JalviewFileView());\r
+ chooser.setDialogTitle("Select a PDB file");\r
+ chooser.setToolTipText("Load a PDB file");\r
+\r
+ int value = chooser.showOpenDialog(null);\r
+\r
+ if (value == jalview.io.JalviewFileChooser.APPROVE_OPTION)\r
+ {\r
+ PDBEntry entry = new PDBEntry();\r
+ String choice = chooser.getSelectedFile().getPath();\r
+ jalview.bin.Cache.setProperty("LAST_DIRECTORY", choice);\r
+ try\r
+ {\r
+ MCview.PDBfile pdbfile = new MCview.PDBfile(choice,\r
+ jalview.io.AppletFormatAdapter.FILE);\r
+\r
+ if (pdbfile.id == null)\r
+ {\r
+ String reply = JOptionPane.showInternalInputDialog(\r
+ Desktop.desktop,\r
+ "Couldn't find a PDB id in the file supplied."\r
+ + "Please enter an Id to identify this structure.",\r
+ "No PDB Id in File", JOptionPane.QUESTION_MESSAGE);\r
+ if (reply == null)\r
+ return;\r
+\r
+ entry.setId(reply);\r
+ }\r
+ else\r
+ entry.setId(pdbfile.id);\r
+ }\r
+ catch (java.io.IOException ex)\r
+ {\r
+ ex.printStackTrace();\r
+ }\r
+\r
+ entry.setFile(choice);\r
+ sequence.getDatasetSequence().addPDBId(entry);\r
+ }\r
+\r
+ }\r
+\r
+ public void enterPDB_actionPerformed(ActionEvent e)\r
+ {\r
+ String id = JOptionPane.showInternalInputDialog(Desktop.desktop,\r
+ "Enter PDB Id", "Enter PDB Id", JOptionPane.QUESTION_MESSAGE);\r
+\r
+ if (id != null && id.length() > 0)\r
+ {\r
+ PDBEntry entry = new PDBEntry();\r
+ entry.setId(id);\r
+ sequence.getDatasetSequence()\r
+ .addPDBId(entry);\r
+ }\r
+ }\r
+\r
+ public void discoverPDB_actionPerformed(ActionEvent e)\r
+ {\r
+ new jalview.io.DBRefFetcher(\r
+ ap.av.getAlignment(), ap.alignFrame).fetchDBRefs(false);\r
+ }\r