Newer
Older
/* GoBox.java
*
* created: 2007
*
* This file is part of Artemis
*
* Copyright (C) 2007 Genome Research Limited
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed 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.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
**/
package uk.ac.sanger.artemis.components.genebuilder.cv;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.MouseMotionAdapter;
import java.util.Vector;
import javax.swing.Box;
import javax.swing.JLabel;
import javax.swing.JTextField;
import org.gmod.schema.cv.CvTerm;
import uk.ac.sanger.artemis.components.genebuilder.JExtendedComboBox;
import uk.ac.sanger.artemis.components.SwingWorker;
import uk.ac.sanger.artemis.editor.BrowserControl;
import uk.ac.sanger.artemis.io.Qualifier;
import uk.ac.sanger.artemis.io.QualifierVector;
import uk.ac.sanger.artemis.util.DatabaseDocument;
import uk.ac.sanger.artemis.util.StringVector;
{"EXP", "IC", "IDA", "IEA", "IEP", "IGC", "IGI",
"IMP", "IPI", "ISA", "ISM", "ISO", "ISS",
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
{"EXP\t:: Inferred from Experiment",
"IC \t:: Inferred by Curator",
"IDA\t:: Inferred from Direct Assay",
"IEA\t:: Inferred from Electronic Annotation",
"IEP\t:: Inferred from Expression Pattern",
"IGC\t:: Inferred from Genomic Context",
"IGI\t:: Inferred from Genetic Interaction",
"IMP\t:: Inferred from Mutant Phenotype",
"IPI\t:: Inferred from Physical Interaction",
"ISA\t:: Inferred from Sequence Alignment",
"ISM\t:: Inferred from Sequence Model",
"ISO\t:: Inferred from Sequence Orthology",
"ISS\t:: Inferred from Sequence or Structural Similarity",
"NAS\t:: Non-traceable Author Statement",
"ND \t:: No biological Data available",
"RCA\t:: inferred from Reviewed Computational Analysis",
"TAS\t:: Traceable Author Statement",
"NR \t:: Not Recorded"},
{ "Inferred from Experiment",
"Inferred by Curator",
"Inferred from Direct Assay",
"Inferred from Electronic Annotation",
"Inferred from Expression Pattern",
"Inferred from Genomic Context",
"Inferred from Genetic Interaction",
"Inferred from Mutant Phenotype",
"Inferred from Physical Interaction",
"Inferred from Sequence Alignment",
"Inferred from Sequence Model",
"Inferred from Sequence Orthology",
"Inferred from Sequence or Structural Similarity",
"Non-traceable Author Statement",
"No biological Data available",
"inferred from Reviewed Computational Analysis",
"Traceable Author Statement",
"Not Recorded"}
private Box xBox;
private int value_index;
private JTextField withTextField;
private JTextField dbxrefTextField;
private JExtendedComboBox evidenceList;
private JTextField qualfTextField;
private String origQualifierString;
private Qualifier origQualifier;
private static Cursor cbusy = new Cursor(Cursor.WAIT_CURSOR);
private static Cursor cdone = new Cursor(Cursor.DEFAULT_CURSOR);
private static Cursor chand = new Cursor(Cursor.HAND_CURSOR);
private static String AMIGOURL;
protected GoBox(final Qualifier qualifier,
final String qualifierString,
final int value_index,
Dimension go_dimension, final Dimension dimension)
{
this.origQualifier = qualifier;
this.origQualifierString = qualifierString;
this.go_dimension = go_dimension;
this.value_index = value_index;
this.xBox = Box.createHorizontalBox();
Vector editable = new Vector(5);
String goId = getField("GOid=", qualifierString);
final String term = getField("term=", qualifierString);
CvTerm cvTerm = DatabaseDocument.getCvTermByCvTermName(term);
final JLabel goTermField = new JLabel(goId);
addGoLabelLiteners(goTermField);
JLabel goAspect = null;
Font font = goTermField.getFont().deriveFont(Font.BOLD);
if(cvTerm.getCv().getName().indexOf("molecular_function")>-1)
{
goAspect = new JLabel(" [F] ");
goAspect.setForeground(Color.RED);
goAspect.setFont(font);
}
else if(cvTerm.getCv().getName().indexOf("biological_process")>-1)
{
goAspect = new JLabel(" [P] ");
goAspect.setForeground(Color.GREEN);
goAspect.setFont(font);
}
else if(cvTerm.getCv().getName().indexOf("cellular_component")>-1)
{
goAspect = new JLabel(" [C] ");
goAspect.setForeground(Color.BLUE);
goAspect.setFont(font);
}
else
{
goAspect = new JLabel(" [?] ");
goAspect.setForeground(Color.BLACK);
goAspect.setFont(font);
}
this.go_dimension = new Dimension(goTermField.getPreferredSize().width+
goAspect.getPreferredSize().width,
goTermField.getPreferredSize().height);
goTermField.setToolTipText(term);
xBox.add(goTermField);
// the WITH column is associated with one or more FeatureCvTermDbXRef
String with = getField("with=", qualifierString);
withTextField = new JTextField(with);
withTextField.setPreferredSize(dimension);
withTextField.setMaximumSize(dimension);
withTextField.setActionCommand("with=");
editable.add(withTextField);
xBox.add(withTextField);
// N.B. for /GO the db_xref is a Pub (for primary pubs)
// or FeatureCvTermPub (for others) in /GO
String dbxref = getField("db_xref=", qualifierString);
dbxrefTextField = new JTextField(dbxref);
dbxrefTextField.setToolTipText("dbxref column");
dbxrefTextField.setPreferredSize(dimension);
dbxrefTextField.setMaximumSize(dimension);
dbxrefTextField.setActionCommand("db_xref=");
editable.add(dbxrefTextField);
xBox.add(dbxrefTextField);
// feature_cvterm_prop's
String evidence = getField("evidence=", qualifierString);
evidenceList = new JExtendedComboBox(evidenceCodes[1]);
evidenceList.setSelectedIndex( getEvidenceIndex(evidence) );
evidenceList.addActionListener(new ActionListener()
{
public void actionPerformed(ActionEvent e)
{
if(((String)evidenceList.getSelectedItem()).startsWith("NR \t::"))
JOptionPane.showMessageDialog(null,
"This evicence code is obsolete:\n"+
evidenceList.getSelectedItem(),
"Obsolete Evidence Code", JOptionPane.WARNING_MESSAGE);
}
});
evidenceListDimension = new Dimension(90,(int)evidenceListDimension.getHeight());
evidenceList.setPreferredSize(evidenceListDimension);
evidenceList.setMaximumSize(evidenceListDimension);
evidenceList.setActionCommand("evidence=");
editable.add(evidenceList);
xBox.add(evidenceList);
String qual = getField("qualifier=", qualifierString);
qualfTextField = new JTextField(qual);
qualfTextField.setToolTipText("qualifier column");
qualfTextField.setPreferredSize(dimension);
qualfTextField.setMaximumSize(dimension);
qualfTextField.setActionCommand("qualifier=");
editable.add(qualfTextField);
xBox.add(qualfTextField);
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
/**
* Add GO listeners for opening Amigo.
* @param goTermField
*/
private void addGoLabelLiteners(final JLabel goTermField)
{
setAmigoUrl();
goTermField.addMouseListener(new MouseAdapter()
{
public void mouseClicked(final MouseEvent e)
{
SwingWorker browserLaunch = new SwingWorker()
{
public Object construct()
{
if(e.getClickCount() == 1)
{
goTermField.setCursor(cbusy);
BrowserControl.displayURL(AMIGOURL+goTermField.getText());
goTermField.setCursor(cdone);
}
return null;
}
};
browserLaunch.start();
}
});
goTermField.addMouseMotionListener(new MouseMotionAdapter()
{
public void mouseMoved(MouseEvent e)
{
goTermField.setCursor(chand);
}
});
}
/**
* Set the Amigo URL for hyperlinking GO terms.
*/
private void setAmigoUrl()
{
if(AMIGOURL == null)
{
StringVector dbsLinks = Options.getOptions().getOptionValues("hyperlinks");
for(int i=0; i<dbsLinks.size(); i+=2)
{
if(dbsLinks.get(i).equals("GO"))
{
AMIGOURL = (String) dbsLinks.get(i+1);
return;
}
}
AMIGOURL = "http://amigo.geneontology.org/cgi-bin/amigo/term-details.cgi?term=";
}
}
{
for(int i=0; i<evidenceCodes[2].length; i++)
{
// look for full text or abbreviation of the code
if(evidenceCodes[2][i].equalsIgnoreCase(evidence) ||
evidenceCodes[0][i].equalsIgnoreCase(evidence))
// this is mainly to catch RCA
// - reviewed computational analysis (inferred from missing)
/*for(int i=0; i<evidenceCodes[2].length; i++)
{
if(evidenceCodes[2][i].indexOf(evidence) > -1)
return i;
}*/
protected Dimension getGoDimension()
{
return go_dimension;
}
protected Box getBox()
{
return xBox;
}
protected boolean isQualifierChanged()
{
String old = getField("with=", origQualifierString);
if(!old.equals(withTextField.getText().trim()))
return true;
old = getField("db_xref=", origQualifierString);
if(!old.equals(dbxrefTextField.getText().trim()))
return true;
old = getField("evidence=", origQualifierString);
if(evidenceList.getSelectedIndex() > -1 &&
!old.equalsIgnoreCase(evidenceCodes[2][ evidenceList.getSelectedIndex() ]))
return true;
old = getField("qualifier=", origQualifierString);
if(!old.equals(qualfTextField.getText()))
return true;
old = getField("date=", origQualifierString);
if(!old.equals(dateField.getText()))
return true;
return false;
}
protected int getValueIndex()
{
return value_index;
}
/**
* Update the qualifier from the GO form.
*/
protected void updateQualifier(final QualifierVector qv)
{
int index = qv.indexOfQualifierWithName(origQualifier.getName());
Qualifier newQualifier = qv.getQualifierByName(origQualifier.getName());
final String goId = getField("GOid=", origQualifierString);
StringVector values = newQualifier.getValues();
Vector values_index = new Vector();
for(int i=0; i<values.size(); i++)
{
String newGoId = getField("GOid=", (String)values.get(i));
if(newGoId.equals(goId))
values_index.add(new Integer(i));
}
int value_index = -99;
if(values_index.size() > 0)
{
if(values_index.size() == 1)
value_index = ((Integer)values_index.get(0)).intValue();
else
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
final String with = getField("with=", origQualifierString);
final String evidence = getField("evidence=", origQualifierString);
final String dbxref = getField("dbxref=", origQualifierString);
for(int i=0; i<values_index.size(); i++)
{
int ind = ((Integer)values_index.get(i)).intValue();
value_index = ind;
String value = (String) values.get(ind);
String thisEvidence = getField("evidence=", value);
if(thisEvidence.equals(evidence))
break;
if(!with.equals(""))
{
String thisWith = getField("with=", value);
if(thisWith.equals(with))
break;
}
if(!dbxref.equals(""))
{
String thisDbxref = getField("dbxref=", value);
if(thisDbxref.equals(dbxref))
break;
}
}
if(value_index > -1)
values.remove(value_index);
String updatedQualifierString = updateQualifierString();
Splash.logger4j.debug(origQualifierString);
Splash.logger4j.debug(updatedQualifierString);
values.add(value_index, updatedQualifierString);
origQualifier = new Qualifier(origQualifier.getName(), values);
qv.remove(index);
qv.add(index, origQualifier);
}
private String updateQualifierString()
{
String newQualifierString = origQualifierString;
String old = getField("with=", origQualifierString);
if(!old.equals(withTextField.getText().trim()))
{
newQualifierString = changeField("with=", withTextField.getText().trim(),
newQualifierString);
}
old = getField("db_xref=", origQualifierString);
if(!old.equals(dbxrefTextField.getText().trim()))
newQualifierString = changeField("db_xref=", dbxrefTextField.getText().trim(),
newQualifierString);
}
old = getField("evidence=", origQualifierString);
if(!old.equals(evidenceCodes[2][ evidenceList.getSelectedIndex() ]))
newQualifierString = changeField("evidence=", evidenceCodes[2][ evidenceList.getSelectedIndex() ],
newQualifierString);
}
old = getField("qualifier=", origQualifierString);
if(!old.equals(qualfTextField.getText()))
{
newQualifierString = changeField("qualifier=", qualfTextField.getText().trim(),
newQualifierString);
}
old = getField("date=", origQualifierString);
if(!old.equals(dateField.getText()))
{
newQualifierString = changeField("date=", dateField.getText().trim(),
newQualifierString);
}
return newQualifierString;
}
if(evidenceListDimension == null)
{
JExtendedComboBox evidenceList = new JExtendedComboBox(evidenceCodes[1]);
evidenceListDimension = evidenceList.getPreferredSize();
evidenceListDimension = new Dimension(80,(int)evidenceListDimension.getHeight());
}
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
/**
* Given the string:
* aspect=F;GOid=GO:0003674;term=molecular_function;evidence=No biological Data available
* return the string:
* aspect=F;GOid=GO:0003674;term=molecular_function;evidence=ND
* @param goText
* @return
*/
public static String getEvidenceCodeGoTextFromText(String goText)
{
final String oldEvidence = getField("evidence=", goText);
String newEvidence = oldEvidence;
for(int i=0; i<evidenceCodes[2].length; i++)
{
if(evidenceCodes[2][i].equalsIgnoreCase(oldEvidence.toLowerCase()))
{
newEvidence = evidenceCodes[0][i];
break;
}
}
if(!oldEvidence.equals(newEvidence))
goText = goText.replaceAll(oldEvidence, newEvidence);
return goText;
}