/* * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) * Copyright (C) $$Year-Rel$$ The Jalview Authors * * This file is part of Jalview. * * Jalview 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 3 * of the License, or (at your option) any later version. * * Jalview 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 Jalview. If not, see . * The Jalview Authors are detailed in the 'AUTHORS' file. */ package jalview.fts.service.pdb; import jalview.fts.api.FTSDataColumnI; import jalview.fts.api.FTSRestClientI; import jalview.fts.core.FTSRestRequest; import jalview.fts.core.FTSRestResponse; import jalview.fts.core.GFTSPanel; import jalview.gui.SequenceFetcher; import jalview.util.MessageManager; import java.util.HashSet; import javax.swing.table.DefaultTableModel; @SuppressWarnings("serial") public class PDBFTSPanel extends GFTSPanel { public PDBFTSPanel(SequenceFetcher seqFetcher) { this.seqFetcher = seqFetcher; this.progressIdicator = (seqFetcher == null) ? null : seqFetcher .getProgressIndicator(); } /** * Action performed when an input is detected on txt_search field. */ @Override public void txt_search_ActionPerformed() { new Thread() { @Override public void run() { lbl_loading.setVisible(false); errorWarning.setLength(0); lbl_warning.setVisible(false); btn_ok.setEnabled(false); boolean allowEmptySequence = false; mainFrame.setTitle(getFTSFrameTitle()); tbl_summary.setModel(new DefaultTableModel()); tbl_summary.setVisible(false); if (txt_search.getText().trim().length() > 0) { lbl_loading.setVisible(true); long startTime = System.currentTimeMillis(); String searchTarget = ((FTSDataColumnI) cmb_searchTarget .getSelectedItem()).getCode(); // wantedFields = FTSDataColumnPreferences.getSearchSummaryFields(); wantedFields = PDBFTSRestClient.getInstance() .getAllDefaulDisplayedDataColumns(); String searchTerm = decodeSearchTerm(txt_search.getText(), searchTarget); FTSRestRequest request = new FTSRestRequest(); request.setAllowEmptySeq(allowEmptySequence); request.setResponseSize(100); request.setFieldToSearchBy("(" + searchTarget + ":"); request.setSearchTerm(searchTerm + ")"); request.setWantedFields(wantedFields); // System.out.println(">>>>>>>>>>>>>> " + request.getQuery()); FTSRestClientI pdbRestCleint = PDBFTSRestClient.getInstance(); FTSRestResponse resultList; try { resultList = pdbRestCleint.executeRequest(request); } catch (Exception e) { // e.printStackTrace(); errorWarning.append(e.getMessage()); checkForErrors(); return; } if (resultList.getSearchSummary() != null) { tbl_summary.setModel(FTSRestResponse.getTableModel(request, resultList.getSearchSummary())); FTSRestResponse.configureTableColumn(tbl_summary, wantedFields); tbl_summary.setVisible(true); } long endTime = System.currentTimeMillis(); int resultSetCount = resultList.getNumberOfItemsFound(); String result = (resultSetCount > 1) ? MessageManager .getString("label.results") : MessageManager .getString("label.result"); mainFrame.setTitle(getFTSFrameTitle() + " - " + resultSetCount + " " + result + " (" + (endTime - startTime) + " milli secs)"); lbl_loading.setVisible(false); } } }.start(); } public static String decodeSearchTerm(String enteredText, String targetField) { String foundSearchTerms = enteredText; StringBuilder foundSearchTermsBuilder = new StringBuilder(); if (enteredText.contains(";")) { String[] searchTerms = enteredText.split(";"); for (String searchTerm : searchTerms) { if (searchTerm.contains(":")) { foundSearchTermsBuilder.append(targetField).append(":") .append(searchTerm.split(":")[0]).append(" OR "); } else { foundSearchTermsBuilder.append(targetField).append(":") .append(searchTerm).append(" OR "); } } int endIndex = foundSearchTermsBuilder.lastIndexOf(" OR "); foundSearchTerms = foundSearchTermsBuilder.toString(); if (foundSearchTerms.contains(" OR ")) { foundSearchTerms = foundSearchTerms.substring( targetField.length() + 1, endIndex); } } else if (enteredText.contains(":")) { foundSearchTerms = foundSearchTerms.split(":")[0]; } return foundSearchTerms; } @Override public void btn_ok_ActionPerformed() { // mainFrame.dispose(); disableActionButtons(); StringBuilder selectedIds = new StringBuilder(); HashSet selectedIdsSet = new HashSet(); int pdbIdCol = 0; try { pdbIdCol = getFTSRestClient().getPrimaryKeyColumIndex(wantedFields, false); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } int[] selectedRows = tbl_summary.getSelectedRows(); for (int summaryRow : selectedRows) { String idStr = tbl_summary.getValueAt(summaryRow, pdbIdCol) .toString(); String searchTerm = txt_search.getText(); selectedIdsSet.add(getPDBIdwithSpecifiedChain(idStr, searchTerm)); } for (String selectedId : selectedIdsSet) { selectedIds.append(selectedId).append(";"); } String ids = selectedIds.toString(); // System.out.println(">>>>>>>>>>>>>>>> selected Ids: " + ids); seqFetcher.getTextArea().setText(ids); Thread worker = new Thread(seqFetcher); worker.start(); delayAndEnableActionButtons(); } public static String getPDBIdwithSpecifiedChain(String pdbId, String searchTerm) { String pdbIdWithChainCode = ""; if (searchTerm.contains(";")) { String[] foundTerms = searchTerm.split(";"); for (String foundTerm : foundTerms) { if (foundTerm.contains(pdbId)) { pdbIdWithChainCode = foundTerm; } } } else if (searchTerm.contains(pdbId)) { pdbIdWithChainCode = searchTerm; } else { pdbIdWithChainCode = pdbId; } return pdbIdWithChainCode; } @Override public FTSRestClientI getFTSRestClient() { return PDBFTSRestClient.getInstance(); } @Override public String getFTSFrameTitle() { return MessageManager.getString("label.pdb_sequence_fetcher"); } }