2 * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
3 * Copyright (C) $$Year-Rel$$ The Jalview Authors
5 * This file is part of Jalview.
7 * Jalview is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation, either version 3
10 * of the License, or (at your option) any later version.
12 * Jalview is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty
14 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with Jalview. If not, see <http://www.gnu.org/licenses/>.
19 * The Jalview Authors are detailed in the 'AUTHORS' file.
22 package jalview.fts.service.pdb;
24 import jalview.fts.api.FTSDataColumnI;
25 import jalview.fts.api.FTSRestClientI;
26 import jalview.fts.core.FTSRestRequest;
27 import jalview.fts.core.FTSRestResponse;
28 import jalview.fts.core.GFTSPanel;
29 import jalview.gui.SequenceFetcher;
30 import jalview.util.MessageManager;
32 import java.util.HashSet;
34 import javax.swing.table.DefaultTableModel;
36 @SuppressWarnings("serial")
37 public class PDBFTSPanel extends GFTSPanel
40 public PDBFTSPanel(SequenceFetcher seqFetcher)
42 this.seqFetcher = seqFetcher;
43 this.progressIdicator = (seqFetcher == null) ? null : seqFetcher
44 .getProgressIndicator();
49 * Action performed when an input is detected on txt_search field.
52 public void txt_search_ActionPerformed()
59 lbl_loading.setVisible(false);
60 errorWarning.setLength(0);
61 lbl_warning.setVisible(false);
62 btn_ok.setEnabled(false);
63 boolean allowEmptySequence = false;
64 mainFrame.setTitle(getFTSFrameTitle());
65 tbl_summary.setModel(new DefaultTableModel());
66 tbl_summary.setVisible(false);
67 if (txt_search.getText().trim().length() > 0)
69 lbl_loading.setVisible(true);
70 long startTime = System.currentTimeMillis();
72 String searchTarget = ((FTSDataColumnI) cmb_searchTarget
73 .getSelectedItem()).getCode();
75 // wantedFields = FTSDataColumnPreferences.getSearchSummaryFields();
76 wantedFields = PDBFTSRestClient.getInstance()
77 .getAllDefaulDisplayedDataColumns();
78 String searchTerm = decodeSearchTerm(txt_search.getText(),
81 FTSRestRequest request = new FTSRestRequest();
82 request.setAllowEmptySeq(allowEmptySequence);
83 request.setResponseSize(100);
84 request.setFieldToSearchBy("(" + searchTarget + ":");
85 request.setSearchTerm(searchTerm + ")");
86 request.setWantedFields(wantedFields);
87 // System.out.println(">>>>>>>>>>>>>> " + request.getQuery());
88 FTSRestClientI pdbRestCleint = PDBFTSRestClient.getInstance();
89 FTSRestResponse resultList;
92 resultList = pdbRestCleint.executeRequest(request);
95 // e.printStackTrace();
96 errorWarning.append(e.getMessage());
101 if (resultList.getSearchSummary() != null)
103 tbl_summary.setModel(FTSRestResponse.getTableModel(request,
104 resultList.getSearchSummary()));
105 FTSRestResponse.configureTableColumn(tbl_summary, wantedFields);
106 tbl_summary.setVisible(true);
110 long endTime = System.currentTimeMillis();
111 int resultSetCount = resultList.getNumberOfItemsFound();
112 String result = (resultSetCount > 1) ? MessageManager
113 .getString("label.results") : MessageManager
114 .getString("label.result");
115 mainFrame.setTitle(getFTSFrameTitle() + " - " + resultSetCount
117 + result + " (" + (endTime - startTime) + " milli secs)");
118 lbl_loading.setVisible(false);
124 public static String decodeSearchTerm(String enteredText,
127 String foundSearchTerms = enteredText;
128 StringBuilder foundSearchTermsBuilder = new StringBuilder();
129 if (enteredText.contains(";"))
131 String[] searchTerms = enteredText.split(";");
132 for (String searchTerm : searchTerms)
134 if (searchTerm.contains(":"))
136 foundSearchTermsBuilder.append(targetField).append(":")
137 .append(searchTerm.split(":")[0]).append(" OR ");
141 foundSearchTermsBuilder.append(targetField).append(":")
142 .append(searchTerm).append(" OR ");
145 int endIndex = foundSearchTermsBuilder.lastIndexOf(" OR ");
146 foundSearchTerms = foundSearchTermsBuilder.toString();
147 if (foundSearchTerms.contains(" OR "))
149 foundSearchTerms = foundSearchTerms.substring(
150 targetField.length() + 1, endIndex);
153 else if (enteredText.contains(":"))
155 foundSearchTerms = foundSearchTerms.split(":")[0];
157 return foundSearchTerms;
161 public void btn_ok_ActionPerformed()
163 // mainFrame.dispose();
164 disableActionButtons();
165 StringBuilder selectedIds = new StringBuilder();
166 HashSet<String> selectedIdsSet = new HashSet<String>();
170 pdbIdCol = getFTSRestClient().getPrimaryKeyColumIndex(wantedFields,
172 } catch (Exception e)
174 // TODO Auto-generated catch block
177 int[] selectedRows = tbl_summary.getSelectedRows();
178 for (int summaryRow : selectedRows)
180 String idStr = tbl_summary.getValueAt(summaryRow, pdbIdCol)
182 String searchTerm = txt_search.getText();
183 selectedIdsSet.add(getPDBIdwithSpecifiedChain(idStr, searchTerm));
186 for (String selectedId : selectedIdsSet)
188 selectedIds.append(selectedId).append(";");
191 String ids = selectedIds.toString();
192 // System.out.println(">>>>>>>>>>>>>>>> selected Ids: " + ids);
193 seqFetcher.getTextArea().setText(ids);
194 Thread worker = new Thread(seqFetcher);
196 delayAndEnableActionButtons();
200 public static String getPDBIdwithSpecifiedChain(String pdbId,
203 String pdbIdWithChainCode = "";
204 if (searchTerm.contains(";"))
206 String[] foundTerms = searchTerm.split(";");
207 for (String foundTerm : foundTerms)
209 if (foundTerm.contains(pdbId))
211 pdbIdWithChainCode = foundTerm;
215 else if (searchTerm.contains(pdbId))
217 pdbIdWithChainCode = searchTerm;
221 pdbIdWithChainCode = pdbId;
223 return pdbIdWithChainCode;
229 public FTSRestClientI getFTSRestClient()
231 return PDBFTSRestClient.getInstance();
235 public String getFTSFrameTitle()
237 return MessageManager.getString("label.pdb_sequence_fetcher");