{
private static final String AUTOSUPERIMPOSE = "AUTOSUPERIMPOSE";
+ /**
+ * transient combo box choice for initiating 3db fetch
+ */
+ private static final String VIEWS_QUERYING_TDB = "QUERY_3DB";
+
private SequenceI selectedSequence;
private SequenceI[] selectedSequences;
private Collection<FTSData> lastDiscoveredStructuresSet;
+ private boolean canQueryTDB = false;
+
+ private boolean notQueriedTDBYet = true;
+
+ List<SequenceI> seqsWithoutSourceDBRef = null;
+
private static StructureViewer lastTargetedView = null;
public StructureChooser(SequenceI[] selectedSeqs, SequenceI selectedSeq,
AlignmentPanel ap)
{
// which FTS engine to use
- data = StructureChooserQuerySource
- .getQuerySourceFor(selectedSeqs);
+ data = StructureChooserQuerySource.getQuerySourceFor(selectedSeqs);
initDialog();
-
+
this.ap = ap;
this.selectedSequence = selectedSeq;
this.selectedSequences = selectedSeqs;
this.progressIndicator = (ap == null) ? null : ap.alignFrame;
init();
-
+
}
/**
+ * sets canQueryTDB if protein sequences without a canonical uniprot ref or at
+ * least one structure are discovered.
+ */
+ private void populateSeqsWithoutSourceDBRef()
+ {
+ seqsWithoutSourceDBRef = new ArrayList<SequenceI>();
+ boolean needCanonical = false;
+ for (SequenceI seq : selectedSequences)
+ {
+ if (seq.isProtein())
+ {
+ int dbRef = ThreeDBStructureChooserQuerySource
+ .checkUniprotRefs(seq.getDBRefs());
+ if (dbRef < 0)
+ {
+ if (dbRef == -1)
+ {
+ // need to retrieve canonicals
+ needCanonical = true;
+ seqsWithoutSourceDBRef.add(seq);
+ }
+ else
+ {
+ // could be a sequence with pdb ref
+ if (seq.getAllPDBEntries() == null
+ || seq.getAllPDBEntries().size() == 0)
+ {
+ seqsWithoutSourceDBRef.add(seq);
+ }
+ }
+ }
+ }
+ }
+ // retrieve database refs for protein sequences
+ if (!seqsWithoutSourceDBRef.isEmpty())
+ {
+ canQueryTDB = true;
+ if (needCanonical)
+ {
+ notQueriedTDBYet = false;
+ }
+ }
+ };
+
+ /**
* Initializes parameters used by the Structure Chooser Panel
*/
protected void init()
chk_superpose.setSelected(Cache.getDefault(AUTOSUPERIMPOSE, true));
- final Runnable discoverPDBStructures = new Runnable()
+ Executors.defaultThreadFactory().newThread(new Runnable()
{
- @Override
public void run()
{
- // check which FTS engine to use
- data = StructureChooserQuerySource
- .getQuerySourceFor(selectedSequences);
+ populateSeqsWithoutSourceDBRef();
+ initialStructureDiscovery();
+ }
+
+ }).start();
- // ensure a filter option is in force for search
- populateFilterComboBox(true, cachedPDBExists);
+ }
- // looks for any existing structures already loaded
- // for the sequences (the cached ones)
- // then queries the StructureChooserQuerySource to
- // discover more structures.
- //
- // Possible optimisation is to only begin querying
- // the structure chooser if there are no cached structures.
+ // called by init
+ private void initialStructureDiscovery()
+ {
+ // check which FTS engine to use
+ data = StructureChooserQuerySource.getQuerySourceFor(selectedSequences);
- long startTime = System.currentTimeMillis();
- updateProgressIndicator(MessageManager
- .getString("status.loading_cached_pdb_entries"), startTime);
- loadLocalCachedPDBEntries();
- updateProgressIndicator(null, startTime);
- updateProgressIndicator(MessageManager.getString(
- "status.searching_for_pdb_structures"), startTime);
- fetchStructuresMetaData();
- // revise filter options if no results were found
- populateFilterComboBox(isStructuresDiscovered(), cachedPDBExists);
- discoverStructureViews();
- updateProgressIndicator(null, startTime);
- mainFrame.setVisible(true);
- updateCurrentView();
- }
- };
- final List<SequenceI> seqsWithoutSourceDBRef = new ArrayList<SequenceI>();
+ // ensure a filter option is in force for search
+ populateFilterComboBox(true, cachedPDBExists);
- final Runnable discoverCanonicalDBrefs = new Runnable()
+ // looks for any existing structures already loaded
+ // for the sequences (the cached ones)
+ // then queries the StructureChooserQuerySource to
+ // discover more structures.
+ //
+ // Possible optimisation is to only begin querying
+ // the structure chooser if there are no cached structures.
+
+ long startTime = System.currentTimeMillis();
+ updateProgressIndicator(
+ MessageManager.getString("status.loading_cached_pdb_entries"),
+ startTime);
+ loadLocalCachedPDBEntries();
+ updateProgressIndicator(null, startTime);
+ updateProgressIndicator(
+ MessageManager.getString("status.searching_for_pdb_structures"),
+ startTime);
+ fetchStructuresMetaData();
+ // revise filter options if no results were found
+ populateFilterComboBox(isStructuresDiscovered(), cachedPDBExists);
+ discoverStructureViews();
+ updateProgressIndicator(null, startTime);
+ mainFrame.setVisible(true);
+ updateCurrentView();
+ }
+
+ private void promptForTDBFetch()
+ {
+ final long progressId = System.currentTimeMillis();
+
+ // final action after prompting and discovering db refs
+ final Runnable strucDiscovery = new Runnable()
{
@Override
public void run()
{
- long progressId = System.currentTimeMillis();
-
- int y = seqsWithoutSourceDBRef.size();
-
- setProgressBar(MessageManager.formatMessage(
- "status.fetching_dbrefs_for_sequences_without_valid_refs",
- y), progressId);
- SequenceI[] seqWithoutSrcDBRef = seqsWithoutSourceDBRef
- .toArray(new SequenceI[y]);
+ // TODO: warn if no accessions discovered
+ populateSeqsWithoutSourceDBRef();
+ // redo initial discovery - this time with 3d beacons
+ // Executors.
+ previousWantedFields=null;
- DBRefFetcher dbRefFetcher = new DBRefFetcher(seqWithoutSrcDBRef,
- progressBar, new DbSourceProxy[]
- { new jalview.ws.dbsources.Uniprot() },
- null, false);
-
- dbRefFetcher.fetchDBRefs(true);
-
- setProgressBar("Fetch complete.", progressId); // todo i18n
-
- Executors.defaultThreadFactory().newThread(discoverPDBStructures).start();
+ initialStructureDiscovery();
}
};
- Executors.defaultThreadFactory().newThread(new Runnable()
+ // fetch db refs if OK pressed
+ final Runnable discoverCanonicalDBrefs = new Runnable()
{
+ @Override
public void run()
{
+ populateSeqsWithoutSourceDBRef();
- for (SequenceI seq : selectedSequences)
+ final int y = seqsWithoutSourceDBRef.size();
+ if (y > 0)
{
- if (seq.isProtein())
- {
- int dbRef = ThreeDBStructureChooserQuerySource
- .checkUniprotRefs(seq.getDBRefs());
- if (dbRef < 0)
+ SwingUtilities.invokeLater(new Runnable() {
+ @Override
+ public void run()
{
- if (seq.getAllPDBEntries()==null && seq.getAllPDBEntries().size()==0)
- {
- seqsWithoutSourceDBRef.add(seq);
- }
+ updateProgressIndicator(MessageManager.formatMessage(
+ "status.fetching_dbrefs_for_sequences_without_valid_refs",
+ y), progressId);
+
}
- }
+ });
+
+ final SequenceI[] seqWithoutSrcDBRef = seqsWithoutSourceDBRef
+ .toArray(new SequenceI[y]);
+ DBRefFetcher dbRefFetcher = new DBRefFetcher(seqWithoutSrcDBRef,
+ progressBar, new DbSourceProxy[]
+ { new jalview.ws.dbsources.Uniprot() }, null, false);
+
+ // ideally this would also gracefully run with callbacks
+ dbRefFetcher.fetchDBRefs(true);
}
- // retrieve database refs for protein sequences
- if (!seqsWithoutSourceDBRef.isEmpty())
- {
- // need cancel and no to result in the discoverPDB action - mocked is 'cancel'
- JvOptionPane.newOptionDialog(Desktop.getDesktop())
- .setResponseHandler(JvOptionPane.OK_OPTION, discoverCanonicalDBrefs)
- .setResponseHandler(JvOptionPane.CANCEL_OPTION, discoverPDBStructures)
- .setResponseHandler(JvOptionPane.NO_OPTION, discoverPDBStructures)
- .showDialog(MessageManager.formatMessage("label.fetch_references_for",
- seqsWithoutSourceDBRef.size()), MessageManager.getString(
- "label.fetch_uniprot_references"),
- JvOptionPane.YES_NO_OPTION,
- JvOptionPane.PLAIN_MESSAGE, null, new Object[]
- { MessageManager.getString("action.ok"),
- MessageManager.getString("action.cancel") },
- MessageManager.getString("action.ok"));
- } else {
- // get structures directly
- Executors.defaultThreadFactory().newThread(discoverPDBStructures).start();
+ SwingUtilities.invokeLater(new Runnable() {
+ @Override
+ public void run()
+ {
+ if (y>0) {
+ updateProgressIndicator("Fetch complete.", progressId); // todo i18n
+ }
+ // filter has been selected, so we set flag to remove ourselves
+ notQueriedTDBYet = false;
+
+ Executors.defaultThreadFactory().newThread(strucDiscovery).start();
+
+ }
+ });
+
+ }
+ };
+ final Runnable revertview = new Runnable() {
+ public void run() {
+ if (lastSelected!=null) {
+ cmb_filterOption.setSelectedItem(lastSelected);
}
};
- }).start();;
-
+ };
+ // need cancel and no to result in the discoverPDB action - mocked is
+ // 'cancel'
+ JvOptionPane.newOptionDialog(this)
+ .setResponseHandler(JvOptionPane.OK_OPTION,
+ discoverCanonicalDBrefs)
+ .setResponseHandler(JvOptionPane.CANCEL_OPTION, revertview)
+ .setResponseHandler(JvOptionPane.NO_OPTION, revertview)
+ .showDialog(
+ MessageManager.formatMessage(
+ "label.fetch_references_for_3dbeacons",
+ seqsWithoutSourceDBRef.size()),
+ MessageManager
+ .getString("label.3dbeacons"),
+ JvOptionPane.YES_NO_OPTION, JvOptionPane.PLAIN_MESSAGE,
+ null, new Object[]
+ { MessageManager.getString("action.ok"),
+ MessageManager.getString("action.cancel") },
+ MessageManager.getString("action.ok"));
}
/**
resultList = data.fetchStructuresMetaData(seq, wantedFields,
selectedFilterOpt, !chk_invertFilter.isSelected());
// null response means the FTSengine didn't yield a query for this
- // consider designing a special exception if we really wanted to be OOCrazy
- if (resultList==null)
+ // consider designing a special exception if we really wanted to be
+ // OOCrazy
+ if (resultList == null)
{
continue;
}
{
getResultTable()
.setModel(data.getTableModel(discoveredStructuresSet));
-
+
noOfStructuresFound = discoveredStructuresSet.size();
- lastDiscoveredStructuresSet=discoveredStructuresSet;
+ lastDiscoveredStructuresSet = discoveredStructuresSet;
mainFrame.setTitle(MessageManager.formatMessage(
"label.structure_chooser_no_of_structures",
noOfStructuresFound, totalTime));
FTSRestResponse resultList;
try
{
- resultList = data.selectFirstRankedQuery(seq, discoveredStructuresSet,wantedFields,
- fieldToFilterBy, !chk_invertFilter.isSelected());
+ resultList = data.selectFirstRankedQuery(seq,
+ discoveredStructuresSet, wantedFields, fieldToFilterBy,
+ !chk_invertFilter.isSelected());
} catch (Exception e)
{
reorderedStructuresSet.addAll(discoveredStructuresSet);
getResultTable()
.setModel(data.getTableModel(reorderedStructuresSet));
-
+
FTSRestResponse.configureTableColumn(getResultTable(),
wantedFields, tempUserPrefs);
getResultTable().getColumn("Ref Sequence").setPreferredWidth(120);
{
populateFilterComboBox(haveData, cachedPDBExist, null);
}
+
/**
* Populates the filter combo-box options dynamically depending on discovered
* structures
protected void populateFilterComboBox(boolean haveData,
boolean cachedPDBExist, FilterOption lastSel)
{
-
+
/*
* temporarily suspend the change listener behaviour
*/
cmb_filterOption.removeItemListener(this);
- int selSet=-1;
+ int selSet = -1;
cmb_filterOption.removeAllItems();
if (haveData)
{
- List<FilterOption> filters = data.getAvailableFilterOptions(VIEWS_FILTER);
- data.updateAvailableFilterOptions(VIEWS_FILTER, filters, lastDiscoveredStructuresSet);
- int p=0;
- for (FilterOption filter:filters)
+ List<FilterOption> filters = data
+ .getAvailableFilterOptions(VIEWS_FILTER);
+ data.updateAvailableFilterOptions(VIEWS_FILTER, filters,
+ lastDiscoveredStructuresSet);
+ int p = 0;
+ for (FilterOption filter : filters)
{
- if (lastSel!=null && filter.equals(lastSel)) {
- selSet=p;
+ if (lastSel != null && filter.equals(lastSel))
+ {
+ selSet = p;
}
p++;
cmb_filterOption.addItem(filter);
}
}
+
cmb_filterOption.addItem(
new FilterOption(MessageManager.getString("label.enter_pdb_id"),
- "-", VIEWS_ENTER_ID, false,null));
+ "-", VIEWS_ENTER_ID, false, null));
cmb_filterOption.addItem(
new FilterOption(MessageManager.getString("label.from_file"),
- "-", VIEWS_FROM_FILE, false,null));
+ "-", VIEWS_FROM_FILE, false, null));
+ if (canQueryTDB && notQueriedTDBYet)
+ {
+ FilterOption queryTDBOption = new FilterOption(
+ MessageManager.getString("label.search_3dbeacons"), "-",
+ VIEWS_QUERYING_TDB, false, null);
+ cmb_filterOption.addItem(queryTDBOption);
+ }
if (cachedPDBExist)
{
FilterOption cachedOption = new FilterOption(
MessageManager.getString("label.cached_structures"), "-",
- VIEWS_LOCAL_PDB, false,null);
+ VIEWS_LOCAL_PDB, false, null);
cmb_filterOption.addItem(cachedOption);
- if (selSet==-1) {
+ if (selSet == -1)
+ {
cmb_filterOption.setSelectedItem(cachedOption);
}
}
- if (selSet>-1)
+ if (selSet > -1)
{
cmb_filterOption.setSelectedIndex(selSet);
}
{
FilterOption selectedFilterOpt = ((FilterOption) cmb_filterOption
.getSelectedItem());
+
+ // first check if we need to rebuild dialog
+ if (selectedFilterOpt.getView() == VIEWS_QUERYING_TDB)
+ {
+ promptForTDBFetch();
+ return;
+ }
+ if (lastSelected == selectedFilterOpt)
+ {
+ // don't need to do anything, probably
+ return;
+ }
+ // otherwise, record selection
+ // and update the layout and dialog accordingly
+ lastSelected = selectedFilterOpt;
+
layout_switchableViews.show(pnl_switchableViews,
selectedFilterOpt.getView());
String filterTitle = mainFrame.getTitle();
mainFrame.setTitle(frameTitle);
chk_invertFilter.setVisible(false);
+
if (selectedFilterOpt.getView() == VIEWS_FILTER)
{
mainFrame.setTitle(filterTitle);
// TDB Query has no invert as yet
- chk_invertFilter.setVisible(selectedFilterOpt.getQuerySource() instanceof PDBStructureChooserQuerySource);
-
- if (data!=selectedFilterOpt.getQuerySource() || data.needsRefetch(selectedFilterOpt))
+ chk_invertFilter.setVisible(selectedFilterOpt
+ .getQuerySource() instanceof PDBStructureChooserQuerySource);
+
+ if (data != selectedFilterOpt.getQuerySource()
+ || data.needsRefetch(selectedFilterOpt))
{
data = selectedFilterOpt.getQuerySource();
// rebuild the views completely, since prefs will also change
tabRefresh();
return;
- } else {
+ }
+ else
+ {
filterResultSet(selectedFilterOpt.getValue());
}
}
{
validateSelections();
}
-
+ private FilterOption lastSelected=null;
/**
* Handles the state change event for the 'filter' combo-box and 'invert'
* check-box
int[] selectedRows = restable.getSelectedRows();
PDBEntry[] pdbEntriesToView = new PDBEntry[selectedRows.length];
List<SequenceI> selectedSeqsToView = new ArrayList<>();
- pdbEntriesToView = data.collectSelectedRows(restable,selectedRows,selectedSeqsToView);
+ pdbEntriesToView = data.collectSelectedRows(restable,
+ selectedRows, selectedSeqsToView);
SequenceI[] selectedSeqs = selectedSeqsToView
.toArray(new SequenceI[selectedSeqsToView.size()]);
List<SequenceI> selectedSeqsToView = new ArrayList<>();
for (int row : selectedRows)
{
- PDBEntry pdbEntry = ((PDBEntryTableModel) tbl_local_pdb.getModel()).getPDBEntryAt(row).getPdbEntry();
-
+ PDBEntry pdbEntry = ((PDBEntryTableModel) tbl_local_pdb
+ .getModel()).getPDBEntryAt(row).getPdbEntry();
+
pdbEntriesToView[count++] = pdbEntry;
SequenceI selectedSeq = (SequenceI) tbl_local_pdb
.getValueAt(row, refSeqColIndex);
public void run()
{
fetchStructuresMetaData();
- //populateFilterComboBox(true, cachedPDBExists);
+ // populateFilterComboBox(true, cachedPDBExists);
filterResultSet(
((FilterOption) cmb_filterOption.getSelectedItem())
{
if (pdbEntry.hasProvider())
{
- return pdbEntry.getProvider()+":"+pdbEntry.getId();
- }
+ return pdbEntry.getProvider() + ":" + pdbEntry.getId();
+ }
return pdbEntry.toString();
}
protected void setFTSDocFieldPrefs(FTSDataColumnPreferences newPrefs)
{
data.setDocFieldPrefs(newPrefs);
-
+
}
/**
*
- * @return true when all initialisation threads have finished and dialog is visible
+ * @return true when all initialisation threads have finished and dialog is
+ * visible
*/
public boolean isDialogVisible()
{