import jalview.gui.SequenceFetcher;
import jalview.util.MessageManager;
+import java.util.HashMap;
import java.util.HashSet;
+import java.util.Map;
@SuppressWarnings("serial")
public class UniprotFTSPanel extends GFTSPanel
private String ftsFrameTitle = defaultFTSFrameTitle;
- private int resultSetCount;
-
- private int offSet;
-
- private static int pageLimit = UniProtFTSRestClient.getInstance()
- .getDefaultResponsePageSize();
+ private static Map<String, Integer> tempUserPrefs = new HashMap<String, Integer>();
public UniprotFTSPanel(SequenceFetcher seqFetcher)
{
+ super();
+ pageLimit = UniProtFTSRestClient.getInstance()
+ .getDefaultResponsePageSize();
this.seqFetcher = seqFetcher;
- this.progressIdicator = (seqFetcher == null) ? null : seqFetcher
+ this.progressIndicator = (seqFetcher == null) ? null : seqFetcher
.getProgressIndicator();
}
@Override
- public void searchAction()
- {
- offSet = 0;
- executeSearch();
- }
-
- public void executeSearch()
+ public void searchAction(boolean isFreshSearch)
{
+ if (isFreshSearch)
+ {
+ offSet = 0;
+ }
new Thread()
- {
+ {
@Override
public void run()
{
.getSelectedItem()).getAltCode();
wantedFields = UniProtFTSRestClient.getInstance()
- .getAllDefaulDisplayedDataColumns();
- String searchTerm = txt_search.getText();
+ .getAllDefaultDisplayedFTSDataColumns();
+ String searchTerm = decodeSearchTerm(txt_search.getText(),
+ searchTarget);
FTSRestRequest request = new FTSRestRequest();
request.setFieldToSearchBy(searchTarget);
FTSRestResponse.getTableModel(request,
resultList.getSearchSummary()));
FTSRestResponse.configureTableColumn(getResultTable(),
- wantedFields);
+ wantedFields, tempUserPrefs);
getResultTable().setVisible(true);
}
long endTime = System.currentTimeMillis();
- resultSetCount = resultList.getNumberOfItemsFound();
- String result = (resultSetCount > 1) ? MessageManager
+ totalResultSetCount = resultList.getNumberOfItemsFound();
+ resultSetCount = resultList.getSearchSummary() == null ? 0
+ : resultList.getSearchSummary().size();
+ String result = (resultSetCount > 0) ? MessageManager
.getString("label.results") : MessageManager
.getString("label.result");
- if (isPaginationEnabled() && resultSetCount > 1)
+ if (isPaginationEnabled() && resultSetCount > 0)
{
- updateSearchFrameTitle(defaultFTSFrameTitle + " - " + result
- + " " + offSet + " to " + (offSet + resultSetCount)
- + " " + " (" + (endTime - startTime) + " milli secs)");
+ updateSearchFrameTitle(defaultFTSFrameTitle
+ + " - "
+ + result
+ + " "
+ + totalNumberformatter.format((Number) (offSet + 1))
+ + " to "
+ + totalNumberformatter
+ .format((Number) (offSet + resultSetCount))
+ + " of "
+ + totalNumberformatter
+ .format((Number) totalResultSetCount) + " "
+ + " (" + (endTime - startTime) + " milli secs)");
}
else
{
}
setSearchInProgress(false);
refreshPaginatorState();
+ updateSummaryTableSelections();
}
}
}.start();
}
-
-
- public void refreshPaginatorState()
+ public String decodeSearchTerm(String enteredText, String targetField)
{
- // System.out.println("resultSet count : " + resultSetCount);
- // System.out.println("offSet : " + offSet);
- // System.out.println("page limit : " + pageLimit);
- setPrevPageButtonEnabled(false);
- setNextPageButtonEnabled(false);
- if (resultSetCount >= pageLimit)
- {
- setNextPageButtonEnabled(true);
- }
- if (offSet >= pageLimit)
+ int searchTargetLength = targetField.equalsIgnoreCase("Search All") ? 0
+ : targetField.length() + 1;
+ String searchTarget = targetField.equalsIgnoreCase("Search All") ? ""
+ : targetField + ":";
+ String foundSearchTerms = enteredText;
+ StringBuilder foundSearchTermsBuilder = new StringBuilder();
+ if (enteredText.contains(";"))
{
- setPrevPageButtonEnabled(true);
- }
- }
-
- @Override
- public void prevPageAction()
- {
- if (offSet >= pageLimit)
- {
- offSet = offSet - pageLimit;
- executeSearch();
- }else{
- refreshPaginatorState();
+ String[] searchTerms = enteredText.split(";");
+ for (String searchTerm : searchTerms)
+ {
+ foundSearchTermsBuilder.append(searchTarget).append(searchTerm)
+ .append(" OR ");
+ }
+ int endIndex = foundSearchTermsBuilder.lastIndexOf(" OR ");
+ foundSearchTerms = foundSearchTermsBuilder.toString();
+ if (foundSearchTerms.contains(" OR "))
+ {
+ foundSearchTerms = foundSearchTerms.substring(searchTargetLength,
+ endIndex);
+ }
}
- }
-
- @Override
- public void nextPageAction()
- {
- offSet = offSet + pageLimit;
- executeSearch();
-
+ return foundSearchTerms;
}
@Override
primaryKeyColIndex).toString();
selectedIdsSet.add(idStr);
}
-
+ selectedIdsSet.addAll(paginatorCart);
for (String selectedId : selectedIdsSet)
{
selectedIds.append(selectedId).append(";");
return ftsFrameTitle;
}
+ @Override
+ public Map<String, Integer> getTempUserPrefs()
+ {
+ return tempUserPrefs;
+ }
+
}