config.setSpecimenType(specimenType.equals(SpecimenOrObservationType.Unknown)?null:specimenType);//unknown := all types
config.setTitleSearchString(queryString);
if(selectedTaxon!=null){
- config.setRetrieveIndirectlyAssociatedSpecimens(true);
config.setSpecimenType(null);
}
Collection<TaxonBase<?>> associatedTaxa = CdmStore.getService(IOccurrenceService.class).listAssociatedTaxa(specimenOrObservationBase, null, null, null, null);
if(!associatedTaxa.isEmpty()){
specimenWithAssociations.add(specimenOrObservationBase);
+ specimenWithAssociations.addAll(CdmStore.getService(IOccurrenceService.class).getFieldUnits(specimenOrObservationBase.getUuid()));
}
}
}
if(selectionIndex==DerivateSearchComposite.UNASSIGNED_SPECIMENS){
- for (SpecimenOrObservationBase<?> specimenOrObservationBase : specimenWithAssociations) {
- derivativeEditor.removeHierarchy(specimenOrObservationBase);
- }
- derivativeEditor.updateRootEntities();
+ occurrences.removeAll(specimenWithAssociations);
}
- else{
- if(selectionIndex==DerivateSearchComposite.ASSIGNED_SPECIMENS){
- occurrences = new ArrayList<SpecimenOrObservationBase>(specimenWithAssociations);
- }
- List<UUID> derivateUuids = new ArrayList<UUID>();
- for (SpecimenOrObservationBase specimenOrObservationBase : occurrences) {
- derivateUuids.add(specimenOrObservationBase.getUuid());
- }
- derivativeEditor.updateRootEntities(derivateUuids);
+ else if(selectionIndex==DerivateSearchComposite.ASSIGNED_SPECIMENS){
+ occurrences = new ArrayList<SpecimenOrObservationBase>(specimenWithAssociations);
+ }
+ List<UUID> derivateUuids = new ArrayList<UUID>();
+ for (SpecimenOrObservationBase specimenOrObservationBase : occurrences) {
+ derivateUuids.add(specimenOrObservationBase.getUuid());
}
+ derivativeEditor.updateRootEntities(derivateUuids);
}
@Override