import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
-import java.util.UUID;
import org.eclipse.jface.dialogs.MessageDialog;
import org.eclipse.swt.widgets.Display;
import eu.etaxonomy.cdm.api.service.INameService;
import eu.etaxonomy.cdm.api.service.IOccurrenceService;
import eu.etaxonomy.cdm.api.service.IReferenceService;
-import eu.etaxonomy.cdm.api.service.IService;
import eu.etaxonomy.cdm.api.service.ITaxonService;
+import eu.etaxonomy.cdm.api.service.ITermService;
import eu.etaxonomy.cdm.api.service.IUserService;
import eu.etaxonomy.cdm.api.service.config.IFindTaxaAndNamesConfigurator;
import eu.etaxonomy.cdm.api.service.config.IIdentifiableEntityServiceConfigurator;
import eu.etaxonomy.cdm.model.agent.AgentBase;
import eu.etaxonomy.cdm.model.agent.TeamOrPersonBase;
-import eu.etaxonomy.cdm.model.common.Group;
-import eu.etaxonomy.cdm.model.common.ICdmBase;
import eu.etaxonomy.cdm.model.common.IdentifiableEntity;
-import eu.etaxonomy.cdm.model.common.RelationshipBase;
-import eu.etaxonomy.cdm.model.common.User;
+import eu.etaxonomy.cdm.model.location.NamedArea;
import eu.etaxonomy.cdm.model.media.Media;
import eu.etaxonomy.cdm.model.name.NameRelationship;
-import eu.etaxonomy.cdm.model.name.TaxonNameBase;
+import eu.etaxonomy.cdm.model.name.TaxonName;
import eu.etaxonomy.cdm.model.occurrence.SpecimenOrObservationBase;
+import eu.etaxonomy.cdm.model.permission.Group;
+import eu.etaxonomy.cdm.model.permission.User;
import eu.etaxonomy.cdm.model.reference.Reference;
import eu.etaxonomy.cdm.model.taxon.TaxonBase;
+import eu.etaxonomy.cdm.model.term.TermVocabulary;
import eu.etaxonomy.cdm.persistence.dto.UuidAndTitleCache;
import eu.etaxonomy.taxeditor.l10n.Messages;
import eu.etaxonomy.taxeditor.preference.IPreferenceKeys;
/**
* @author n.hoffmann
* @created Dec 8, 2010
- * @version 1.0
*/
public class SearchManager {
public static int NO_COUNT = -1;
+ private static final int MAX_RESULTS_BEFORE_WARNING = 500;
- // TODO make this configurable via preferences
- private static final int MAX_RESULTS_BEFORE_WARNING = 500;
-
- public List<TaxonNameBase> findNames(IIdentifiableEntityServiceConfigurator configurator, ConversationHolder conversation){
-
- if(checkLargeResult(CdmStore.getService(INameService.class).countByTitle(configurator))){
- List<TaxonNameBase> records = CdmStore.getService(INameService.class).findByTitle(configurator).getRecords();
- addUuidSearchResults(records, configurator, INameService.class);
- return records;
- }
- return NO_RESULTS;
+ public List<TaxonName> findNames(IIdentifiableEntityServiceConfigurator configurator, ConversationHolder conversation){
+ List<TaxonName> records = CdmStore.getService(INameService.class).findByTitle(configurator).getRecords();
+ return records;
}
public List<NameRelationship> findNameRelationships(
return NO_RESULTS;
}
- List<NameRelationship> relationships = new ArrayList<NameRelationship>();
- List<RelationshipBase> all = CdmStore.getService(INameService.class).getAllRelationships(0, 0);
+ List<NameRelationship> relationships = new ArrayList<>();
- for (RelationshipBase relationship : all){
- if(relationship instanceof NameRelationship){
- relationships.add((NameRelationship) relationship);
- }
- }
+// TODO: the method getAllRelationships does not exist anymore.
+// This method is not used anymore because there is no NameRelationship Bulkeditor
+
+ // List<RelationshipBase> all = CdmStore.getService(INameService.class).getAllRelationships(0, 0);
+//
+// for (RelationshipBase<?,?,?> relationship : all){
+// if(relationship instanceof NameRelationship){
+// relationships.add((NameRelationship) relationship);
+// }
+// }
return relationships;
}
- public List<UuidAndTitleCache<IdentifiableEntity>> findTaxaAndNames(IFindTaxaAndNamesConfigurator<TaxonBase> configurator){
+ public List<UuidAndTitleCache<? extends IdentifiableEntity>> findTaxaAndNames(IFindTaxaAndNamesConfigurator configurator){
return CdmStore.getService(ITaxonService.class).findTaxaAndNamesForEditor(configurator);
}
- public List<Reference> findReferences(IIdentifiableEntityServiceConfigurator configurator){
- if(checkLargeResult(CdmStore.getService(IReferenceService.class).countByTitle(configurator))){
- List<Reference> records = CdmStore.getService(IReferenceService.class).findByTitle(configurator).getRecords();
- addUuidSearchResults(records, configurator, IReferenceService.class);
- return records;
- }
- return NO_RESULTS;
+
+ @SuppressWarnings("unchecked")
+ public List<Reference> findReferences(IIdentifiableEntityServiceConfigurator configurator){
+ List<Reference> records = CdmStore.getService(IReferenceService.class).findByTitle(configurator).getRecords();
+ return records;
}
public List<AgentBase> findAgents(IIdentifiableEntityServiceConfigurator configurator){
- if(checkLargeResult(CdmStore.getService(IAgentService.class).countByTitle(configurator))){
- List<AgentBase> records = CdmStore.getService(IAgentService.class).findByTitle(configurator).getRecords();
- addUuidSearchResults(records, configurator, IAgentService.class);
- return records;
- }
- return NO_RESULTS;
+ List<AgentBase> records = CdmStore.getService(IAgentService.class).findByTitle(configurator).getRecords();
+ return records;
}
- /**
- * Check search string if it is a {@link UUID} and, if <code>true</code>, search for the corresponding entity.
- * @param records the list to which the search results are added
- * @param configurator the configurator holding the search string
- * @param service the service to use for searching
- */
- private <T extends ICdmBase> void addUuidSearchResults(List<T> records, IIdentifiableEntityServiceConfigurator configurator, Class<? extends IService<T>> service) {
- String titleSearchString = configurator.getTitleSearchString();
- try {
- UUID uuid = UUID.fromString(titleSearchString);
- T foundRecord = CdmStore.getService(service).load(uuid, configurator.getPropertyPaths());
- if(foundRecord!=null){
- records.add(foundRecord);
- }
- } catch (IllegalArgumentException e) {
- //search string was no UUID
- }
- }
-
@SuppressWarnings("unchecked")
public List<TeamOrPersonBase> findTeamOrPersons(IIdentifiableEntityServiceConfigurator configurator){
configurator.setClazz(TeamOrPersonBase.class);
* @param configurator the configurator to use for the search
* @return a list of the SpecimenOrObservationBases matching the search parameters found
*/
- public List<SpecimenOrObservationBase> findOccurrences(IIdentifiableEntityServiceConfigurator configurator){
+ public List<SpecimenOrObservationBase> findOccurrences(IIdentifiableEntityServiceConfigurator configurator, boolean showCountWarning){
// by default we do not show field units. This may be configured via preferences
- return findOccurrences(configurator, PreferencesUtil.getPreferenceStore().getBoolean(IPreferenceKeys.BULK_EDITOR_OCCURRENCE_SHOW_FIELD_UNITS));
+ return findOccurrences(configurator, PreferencesUtil.getBooleanValue(IPreferenceKeys.BULK_EDITOR_OCCURRENCE_SHOW_FIELD_UNITS), showCountWarning);
}
* @param showFieldUnits if <code>true</code> then also FieldUnits are searched
* @return
*/
- public List<SpecimenOrObservationBase> findOccurrences(IIdentifiableEntityServiceConfigurator<SpecimenOrObservationBase> configurator, boolean showFieldUnits){
+ public List<SpecimenOrObservationBase> findOccurrences(IIdentifiableEntityServiceConfigurator<SpecimenOrObservationBase> configurator, boolean showFieldUnits,
+ boolean showCountWarning){
List<SpecimenOrObservationBase> records = new ArrayList<SpecimenOrObservationBase>();
final List<String> BASE_OCCURRENCE_INIT_STRATEGY = Arrays.asList(new String[] {
"collection", //$NON-NLS-1$
}
configurator.setPropertyPaths(occurrencePropertyPaths);
- if(checkLargeResult(CdmStore.getService(IOccurrenceService.class).countOccurrences(configurator))){
- records = CdmStore.getService(IOccurrenceService.class).findByTitle(configurator).getRecords();
- }
- addUuidSearchResults(records, configurator, IOccurrenceService.class);
+ if(showCountWarning && checkLargeResult(CdmStore.getService(IOccurrenceService.class).countOccurrences(configurator))){
+ records = CdmStore.getService(IOccurrenceService.class).findByTitle(configurator).getRecords();
+ }
+ else{
+ records = CdmStore.getService(IOccurrenceService.class).findByTitle(configurator).getRecords();
+ }
return records;
}
public List<User> findUsers(IIdentifiableEntityServiceConfigurator configurator){
String userNameSearchString = sqlizeTitleSearchString(configurator);
// TODO why are users not identifiable entities?
- List<User> records = CdmStore.getService(IUserService.class).listByUsername(userNameSearchString, null, null, null, null, null, null);
- addUuidSearchResults(records, configurator, IUserService.class);
+ List<User> records = CdmStore.getService(IUserService.class).listByUsername(userNameSearchString,
+ configurator.getMatchMode(), configurator.getCriteria(), configurator.getPageSize(),
+ configurator.getPageNumber(), configurator.getOrderHints(), configurator.getPropertyPaths());
return records;
}
+
+ private boolean checkLargeResult(long count) {
+ return checkLargeResult(count, MAX_RESULTS_BEFORE_WARNING);
+ }
+
+ private boolean checkLargeResult(long count, int maxBeforWarning) {
+ if(count > maxBeforWarning){
+ return MessageDialog.openConfirm(Display.getDefault().getActiveShell(), Messages.SearchManager_LARGE_RESULT_EXPECTED,
+ String.format(Messages.SearchManager_LONG_SEARCH_WARNING, count));
+ }else{
+ return true;
+ }
+ }
+
public List<Group> findGroups(IIdentifiableEntityServiceConfigurator configurator){
String groupNameSearchString = sqlizeTitleSearchString(configurator);
// TODO why are groups not identifiable entities?
- List<Group> records = CdmStore.getService(IGroupService.class).listByName(groupNameSearchString, null, null, null, null, null, null);
- addUuidSearchResults(records, configurator, IGroupService.class);
+ List<Group> records = CdmStore.getService(IGroupService.class).listByName(groupNameSearchString,
+ configurator.getMatchMode(), configurator.getCriteria(), configurator.getPageSize(),
+ configurator.getPageNumber(), configurator.getOrderHints(), configurator.getPropertyPaths());
return records;
}
- private boolean checkLargeResult(int count) {
- return checkLargeResult(count, MAX_RESULTS_BEFORE_WARNING);
- }
-
- private boolean checkLargeResult(int count, int maxBeforWarning) {
- if(count > maxBeforWarning){
- return MessageDialog.openConfirm(Display.getDefault().getActiveShell(), Messages.SearchManager_LARGE_RESULT_EXPECTED,
- String.format(Messages.SearchManager_LONG_SEARCH_WARNING, count));
- }else{
- return true;
- }
- }
-
private String sqlizeTitleSearchString(IIdentifiableEntityServiceConfigurator configurator){
return configurator.getTitleSearchString().replace(WILDCARD, "%"); //$NON-NLS-1$
}
public List findTaxa(IIdentifiableEntityServiceConfigurator configurator) {
- if(checkLargeResult(CdmStore.getService(ITaxonService.class).countByTitle(configurator))){
- List<TaxonBase> records = CdmStore.getService(ITaxonService.class).findByTitle(configurator).getRecords();
- addUuidSearchResults(records, configurator, ITaxonService.class);
- return records;
- }
- return NO_RESULTS;
+ List<TaxonBase> records = CdmStore.getService(ITaxonService.class).findByTitle(configurator).getRecords();
+ return records;
}
public List findMedia(IIdentifiableEntityServiceConfigurator configurator) {
- if(checkLargeResult(CdmStore.getService(IMediaService.class).countByTitle(configurator))){
- List<Media> records = CdmStore.getService(IMediaService.class).findByTitle(configurator).getRecords();
- addUuidSearchResults(records, configurator, IMediaService.class);
- return records;
- }
- return NO_RESULTS;
+ List<Media> records = CdmStore.getService(IMediaService.class).findByTitle(configurator).getRecords();
+ return records;
}
+ /**
+ * @param searchConfigurator
+ * @return
+ */
+ public List<UuidAndTitleCache<NamedArea>> findNamedAreas(
+ IIdentifiableEntityServiceConfigurator searchConfigurator, List<TermVocabulary> vocs) {
+ List<UuidAndTitleCache<NamedArea>> entities = CdmStore.getService(ITermService.class).getUuidAndTitleCacheNamedArea(vocs, null, searchConfigurator.getTitleSearchString(), PreferencesUtil.getGlobalLanguage());
+ return entities;
+ }
}