Fix potential NPE
[taxeditor.git] / eu.etaxonomy.taxeditor.store / src / main / java / eu / etaxonomy / taxeditor / view / derivateSearch / DerivateLabelProvider.java
1 // $Id$
2 /**
3 * Copyright (C) 2013 EDIT
4 * European Distributed Institute of Taxonomy
5 * http://www.e-taxonomy.eu
6 *
7 * The contents of this file are subject to the Mozilla Public License Version 1.1
8 * See LICENSE.TXT at the top of this package for the full license terms.
9 */
10 package eu.etaxonomy.taxeditor.view.derivateSearch;
11
12 import java.util.List;
13 import java.util.Set;
14 import java.util.UUID;
15
16 import org.eclipse.jface.viewers.ColumnLabelProvider;
17 import org.eclipse.jface.viewers.TreeNode;
18 import org.eclipse.swt.graphics.Image;
19 import org.hibernate.LazyInitializationException;
20
21 import eu.etaxonomy.cdm.api.conversation.ConversationHolder;
22 import eu.etaxonomy.cdm.hibernate.HibernateProxyHelper;
23 import eu.etaxonomy.cdm.model.common.CdmBase;
24 import eu.etaxonomy.cdm.model.common.DefinedTerm;
25 import eu.etaxonomy.cdm.model.common.Identifier;
26 import eu.etaxonomy.cdm.model.molecular.DnaSample;
27 import eu.etaxonomy.cdm.model.molecular.Sequence;
28 import eu.etaxonomy.cdm.model.molecular.SingleRead;
29 import eu.etaxonomy.cdm.model.occurrence.DerivedUnit;
30 import eu.etaxonomy.cdm.model.occurrence.FieldUnit;
31 import eu.etaxonomy.cdm.model.occurrence.GatheringEvent;
32 import eu.etaxonomy.cdm.model.occurrence.MediaSpecimen;
33 import eu.etaxonomy.cdm.model.occurrence.SpecimenOrObservationBase;
34 import eu.etaxonomy.cdm.model.occurrence.SpecimenOrObservationType;
35 import eu.etaxonomy.taxeditor.model.ImageResources;
36 import eu.etaxonomy.taxeditor.store.CdmStore;
37
38 /**
39 * Label provider for the views to show {@link SpecimenOrObservationBase}s.<br>
40 * <br>
41 * <b>Note:</b> If you use this label provider you need to assure that you
42 * created a {@link ConversationHolder} resp. have an open session because
43 * the labels are generated from various fields of the derivate hierarchy which
44 * are lazy loaded and could therefore throw a {@link LazyInitializationException}.<br>
45 * Use <b>{@link #setConversation(ConversationHolder)}</b> to assign the session to this provider.
46 */
47 public class DerivateLabelProvider extends ColumnLabelProvider {
48
49 private static final String NO_SAMPLE_DESIGNATION = "[no sample designation]";
50
51 private Set<SingleRead> multiLinkSingleReads;
52
53 private ConversationHolder conversation;
54
55 private static DefinedTerm photoTerm = null;
56 private static DefinedTerm drawingTerm = null;
57 private static DefinedTerm specimenScanTerm = null;
58 private static DefinedTerm detailImageTerm = null;
59 private static DefinedTerm sampleDesignationTerm = null;
60
61 //FIXME: move static term getters to new singleton utility class
62 private static void initializeTerms() {
63 List<DefinedTerm> preferredTerms = CdmStore.getTermManager().getPreferredTerms(DefinedTerm.class);
64 for (DefinedTerm definedTerm : preferredTerms) {
65 if(definedTerm.getUuid().equals(UUID.fromString("c5c59c42-f254-471e-96c6-09f459f7c903"))){
66 photoTerm = definedTerm;
67 }
68 else if(definedTerm.getUuid().equals(UUID.fromString("669b0409-4aa4-4695-aae4-a95ed27bad4c"))){
69 drawingTerm = definedTerm;
70 }
71 else if(definedTerm.getUuid().equals(UUID.fromString("acda15be-c0e2-4ea8-8783-b9b0c4ad7f03"))){
72 specimenScanTerm = definedTerm;
73 }
74 else if(definedTerm.getUuid().equals(UUID.fromString("31eb8d02-bf5d-437c-bcc6-87a626445f34"))){
75 detailImageTerm = definedTerm;
76 }
77 else if(definedTerm.getUuid().equals(UUID.fromString("fadeba12-1be3-4bc7-9ff5-361b088d86fc"))){
78 sampleDesignationTerm = definedTerm;
79 }
80 }
81 }
82
83 public static DefinedTerm getLivingPlantPhotoTerm(){
84 if(photoTerm==null){
85 initializeTerms();
86 }
87 return photoTerm;
88 }
89
90 public static DefinedTerm getArtworkTerm(){
91 if(drawingTerm==null){
92 initializeTerms();
93 }
94 return drawingTerm;
95 }
96
97 public static DefinedTerm getSpecimenScanTerm(){
98 if(specimenScanTerm==null){
99 initializeTerms();
100 }
101 return specimenScanTerm;
102 }
103
104 public static DefinedTerm getDetailImageTerm(){
105 if(detailImageTerm==null){
106 initializeTerms();
107 }
108 return detailImageTerm;
109 }
110
111 public static DefinedTerm getSampleDesignationTerm(){
112 if(sampleDesignationTerm==null){
113 initializeTerms();
114 }
115 return sampleDesignationTerm;
116 }
117
118
119 /** {@inheritDoc} */
120 @Override
121 public String getText(Object element) {
122 return getDerivateText(element);
123 }
124
125 /** {@inheritDoc} */
126 @Override
127 public String getToolTipText(Object element) {
128 return getDerivateText(element);
129 }
130
131 /**
132 * @param conversation the conversation to set
133 */
134 public void setConversation(ConversationHolder conversation) {
135 this.conversation = conversation;
136 }
137
138 public String getDerivateText(Object element){
139 return getDerivateText(element, conversation);
140 }
141
142 public static String getDerivateText(Object element, ConversationHolder conversation){
143 //TODO: use list of strings to assemble labels to avoid adding the separator every time and to allow null values
144 TreeNode parentNode = null;
145 TreeNode node = null;
146 Object derivate = element;
147 if(element instanceof TreeNode){
148 node = (TreeNode) element;
149 parentNode = node.getParent();
150 //unwrap specimen from TreeNode
151 derivate = node.getValue();
152 }
153
154 if(conversation!=null){
155 conversation.bind();
156 }
157
158 final String emptyString = "";
159 final String separator = " ";
160
161 String label = emptyString;
162
163 //Field Unit
164 if(derivate instanceof FieldUnit){
165 FieldUnit fieldUnit = (FieldUnit)derivate;
166 if(fieldUnit.getGatheringEvent()!=null){
167 GatheringEvent gatheringEvent = fieldUnit.getGatheringEvent();
168 label += gatheringEvent.getCountry()!=null?gatheringEvent.getCountry().getLabel()+separator:emptyString;
169 label += gatheringEvent.getLocality()!=null?gatheringEvent.getLocality().getText()+separator:emptyString;
170 label += gatheringEvent.getGatheringDate()!=null?gatheringEvent.getGatheringDate()+separator:emptyString;
171 label += gatheringEvent.getCollector()!=null?gatheringEvent.getCollector()+separator:emptyString;
172 }
173 label += fieldUnit.getFieldNumber()!=null?fieldUnit.getFieldNumber():emptyString;
174 }
175 //MediaSpecimen
176 else if(derivate instanceof MediaSpecimen){
177 MediaSpecimen mediaSpecimen = (MediaSpecimen)derivate;
178 if(mediaSpecimen.getMediaSpecimen()!=null){
179 label += mediaSpecimen.getMediaSpecimen().getTitle()!=null?mediaSpecimen.getMediaSpecimen().getTitle().getText()+separator:"[no motif]";
180 label += mediaSpecimen.getMediaSpecimen().getArtist()!=null?mediaSpecimen.getMediaSpecimen().getArtist()+separator:emptyString;
181 }
182 eu.etaxonomy.cdm.model.occurrence.Collection collection = mediaSpecimen.getCollection();
183 if(collection!=null){
184 label += collection.getName()!=null?collection.getName()+" ":emptyString;
185 label += collection.getCode()!=null?"("+collection.getCode()+")"+separator:emptyString;
186 }
187 label += mediaSpecimen.getAccessionNumber()!=null?mediaSpecimen.getAccessionNumber()+separator:emptyString;
188 label += mediaSpecimen.getBarcode()!=null?mediaSpecimen.getBarcode()+separator:emptyString;
189 }
190 //TissueSample + DnaSample
191 else if(derivate instanceof DnaSample){
192 DnaSample dnaSample = (DnaSample)derivate;
193 if(((DnaSample) derivate).getRecordBasis()==SpecimenOrObservationType.DnaSample){
194 Identifier<DnaSample> currentSampleDesignation = getCurrentSampleDesignation(dnaSample);
195 if(currentSampleDesignation!=null && currentSampleDesignation.getIdentifier()!=null){
196 label += currentSampleDesignation.getIdentifier()+separator;
197 }
198 else{
199 label += NO_SAMPLE_DESIGNATION+separator;
200 }
201 }
202 else if(((DnaSample) derivate).getRecordBasis()==SpecimenOrObservationType.TissueSample){
203 if(dnaSample.getKindOfUnit()!=null){
204 label += dnaSample.getKindOfUnit()+separator;
205 }
206 Identifier<DnaSample> currentSampleDesignation = getCurrentSampleDesignation(dnaSample);
207 if(currentSampleDesignation!=null && currentSampleDesignation.getIdentifier()!=null){
208 label += currentSampleDesignation.getIdentifier()+separator;
209 }
210 else{
211 label += NO_SAMPLE_DESIGNATION+separator;
212 }
213 }
214
215 }
216 //DerivedUnit + TissueSample
217 else if(derivate instanceof DerivedUnit){
218 DerivedUnit derivedUnit = (DerivedUnit)derivate;
219 if(derivedUnit.getRecordBasis()==SpecimenOrObservationType.PreservedSpecimen){
220 //java.util.Collection<FieldUnit> fieldUnits = CdmStore.getService(IOccurrenceService.class).getFieldUnits(derivedUnit.getUuid());
221 //TODO : This is not generic anymore for performance reasons
222 Set<SpecimenOrObservationBase> originals = derivedUnit.getOriginals();
223 if(originals!=null && originals.size() ==1) {
224 SpecimenOrObservationBase specimen = originals.iterator().next();
225 if(specimen instanceof FieldUnit) {
226 FieldUnit fieldUnit = (FieldUnit)specimen;
227 GatheringEvent gatheringEvent = fieldUnit.getGatheringEvent();
228 if(gatheringEvent!=null){
229 label += gatheringEvent.getCollector()!=null?gatheringEvent.getCollector()+separator:emptyString;
230 }
231 label += fieldUnit.getFieldNumber()!=null?fieldUnit.getFieldNumber()+separator:emptyString;
232 }
233 }
234
235 eu.etaxonomy.cdm.model.occurrence.Collection collection = derivedUnit.getCollection();
236 if(collection!=null){
237 label += collection.getCode()!=null?"("+collection.getCode()+")"+separator:emptyString;
238 }
239 String mostSignificantIdentifier = derivedUnit.getMostSignificantIdentifier();
240 label += mostSignificantIdentifier!=null?mostSignificantIdentifier+separator:emptyString;
241 }
242 else if(derivedUnit.getRecordBasis()==SpecimenOrObservationType.TissueSample){
243 //TissueSample should only be created by using it's own class
244 //in future using only one class with different SpecimenOrObservationTypes is desired
245 // label += derivedUnit.getKindOfUnit() + NO_SAMPLE_DESIGNATION;
246 }
247 }
248 //Sequence
249 else if(derivate instanceof Sequence){
250 Sequence sequence = (Sequence)derivate;
251 Identifier<DnaSample> currentSampleDesignation = getCurrentSampleDesignation(sequence);
252 if(currentSampleDesignation!=null && currentSampleDesignation.getIdentifier()!=null){
253 label += currentSampleDesignation.getIdentifier()+separator;
254 }
255 else{
256 label += NO_SAMPLE_DESIGNATION+separator;
257 }
258 label += sequence.getDnaMarker()!=null?sequence.getDnaMarker():emptyString;
259 }
260 //SingleRead
261 else if(derivate instanceof SingleRead){
262 SingleRead singleRead = (SingleRead)derivate;
263 if(parentNode!=null && parentNode.getValue() instanceof Sequence){
264 Sequence sequence = (Sequence) parentNode.getValue();
265 Identifier<DnaSample> currentSampleDesignation = getCurrentSampleDesignation(sequence);
266 if(currentSampleDesignation!=null && currentSampleDesignation.getIdentifier()!=null){
267 label = currentSampleDesignation.getIdentifier()+separator;
268 }
269 else{
270 label += NO_SAMPLE_DESIGNATION+separator;
271 }
272 label += singleRead.getPrimer()!=null?singleRead.getPrimer().getLabel()+separator:emptyString;
273 if(sequence!=null && sequence.getDnaMarker()!=null){
274 label += sequence.getDnaMarker()+separator;
275 }
276 if(singleRead.getAmplificationResult()!=null && singleRead.getAmplificationResult().getAmplification()!=null){
277 label += singleRead.getAmplificationResult().getAmplification().getLabelCache()+separator;
278 }
279 }
280 }
281 //SOOB
282 else if(derivate instanceof SpecimenOrObservationBase){
283 SpecimenOrObservationBase<?> specimen = (SpecimenOrObservationBase<?>) derivate;
284 SpecimenOrObservationType type = specimen.getRecordBasis();
285 return specimen.getTitleCache() + (type!=null?" ["+type.toString()+"]":emptyString);
286 }
287 if(label.isEmpty()){
288 label = derivate.toString();
289 }
290 //remove last comma
291 else if(label.endsWith(separator)){
292 label = label.substring(0, label.length()-separator.length());
293 }
294 return label;
295 }
296
297 /* (non-Javadoc)
298 * @see org.eclipse.jface.viewers.ColumnLabelProvider#getImage(java.lang.Object)
299 */
300 @Override
301 public Image getImage(Object element) {
302 if(element instanceof TreeNode){
303 element = ((TreeNode) element).getValue();
304 }
305 if(element instanceof CdmBase){
306 CdmBase cdmBase = (CdmBase)element;
307 boolean hasCharacterData = false;
308 if(cdmBase.isInstanceOf(SpecimenOrObservationBase.class)){
309 SpecimenOrObservationBase<?> specimen = HibernateProxyHelper.deproxy(cdmBase, SpecimenOrObservationBase.class);
310 if(specimen.hasCharacterData()){
311 hasCharacterData = true;
312 }
313 }
314 if(cdmBase.isInstanceOf(FieldUnit.class)){
315 return hasCharacterData?ImageResources.getImage(ImageResources.FIELD_UNIT_CHARACTER_DATA):ImageResources.getImage(ImageResources.FIELD_UNIT);
316 }
317 else if(cdmBase.isInstanceOf(DerivedUnit.class)){
318 DerivedUnit derivedUnit = HibernateProxyHelper.deproxy(element, DerivedUnit.class);
319 if(derivedUnit.getRecordBasis()==SpecimenOrObservationType.FieldUnit){
320 return hasCharacterData?ImageResources.getImage(ImageResources.FIELD_UNIT_CHARACTER_DATA):ImageResources.getImage(ImageResources.FIELD_UNIT);
321 }
322 else if(derivedUnit.getRecordBasis()==SpecimenOrObservationType.DnaSample){
323 return hasCharacterData?ImageResources.getImage(ImageResources.DNA_SAMPLE_DERIVATE_CHARACTER_DATA):ImageResources.getImage(ImageResources.DNA_SAMPLE_DERIVATE);
324 }
325 else if(derivedUnit.getRecordBasis()==SpecimenOrObservationType.TissueSample){
326 return hasCharacterData?ImageResources.getImage(ImageResources.TISSUE_SAMPLE_DERIVATE_CHARACTER_DATA):ImageResources.getImage(ImageResources.TISSUE_SAMPLE_DERIVATE);
327 }
328 else if(derivedUnit.getRecordBasis()==SpecimenOrObservationType.PreservedSpecimen){
329 return hasCharacterData?ImageResources.getImage(ImageResources.SPECIMEN_DERIVATE_CHARACTER_DATA):ImageResources.getImage(ImageResources.SPECIMEN_DERIVATE);
330 }
331 else if(derivedUnit.getRecordBasis()==SpecimenOrObservationType.Media){
332 if(derivedUnit.getKindOfUnit()!=null){
333 if(derivedUnit.getKindOfUnit().equals(getArtworkTerm())){
334 return hasCharacterData?ImageResources.getImage(ImageResources.ARTWORK_DERIVATE_CHARACTER_DATA):ImageResources.getImage(ImageResources.ARTWORK_DERIVATE);
335 }
336 else if(derivedUnit.getKindOfUnit().equals(getLivingPlantPhotoTerm())){
337 return hasCharacterData?ImageResources.getImage(ImageResources.LIVING_PLANT_PHOTO_DERIVATE_CHARACTER_DATA):ImageResources.getImage(ImageResources.LIVING_PLANT_PHOTO_DERIVATE);
338 }
339 else if(derivedUnit.getKindOfUnit().equals(getSpecimenScanTerm())){
340 return hasCharacterData?ImageResources.getImage(ImageResources.SPECIMEN_SCAN_DERIVATE_CHARACTER_DATA):ImageResources.getImage(ImageResources.SPECIMEN_SCAN_DERIVATE);
341 }
342 else if(derivedUnit.getKindOfUnit().equals(getDetailImageTerm())){
343 return hasCharacterData?ImageResources.getImage(ImageResources.DETAIL_IMAGE_DERIVATE_CHARACTER_DATA):ImageResources.getImage(ImageResources.DETAIL_IMAGE_DERIVATE);
344 }
345 }
346 }
347 }
348 else if(cdmBase.isInstanceOf(Sequence.class)){
349 return ImageResources.getImage(ImageResources.SEQUENCE_DERIVATE);
350 }
351
352 else if(cdmBase.isInstanceOf(SingleRead.class)){
353 if(multiLinkSingleReads!=null && multiLinkSingleReads.contains(element)){
354 return ImageResources.getImage(ImageResources.SINGLE_READ_DERIVATE_MULTILINK);
355 }
356 else{
357 return ImageResources.getImage(ImageResources.SINGLE_READ_DERIVATE);
358 }
359 }
360 }
361 return super.getImage(element);
362 }
363
364 public static Identifier<DnaSample> getCurrentSampleDesignation(CdmBase entity) {
365 if(entity.isInstanceOf(DnaSample.class)){
366 DnaSample dnaSample = HibernateProxyHelper.deproxy(entity, DnaSample.class);
367 for (Identifier<DnaSample> identifier : dnaSample.getIdentifiers()) {
368 if(identifier.getType()!=null && identifier.getType().equals(DerivateLabelProvider.getSampleDesignationTerm())){
369 //first sample designation is the current
370 return identifier;
371 }
372 }
373 }
374 else if(entity.isInstanceOf(Sequence.class)){
375 Sequence sequence = HibernateProxyHelper.deproxy(entity, Sequence.class);
376 if(sequence.getDnaSample()!=null){
377 return getCurrentSampleDesignation(sequence.getDnaSample());
378 }
379 }
380 return null;
381 }
382
383 /**
384 * @param multiLinkSingleReads2
385 */
386 public void setMultiLinkSingleReads(Set<SingleRead> multiLinkSingleReads) {
387 this.multiLinkSingleReads = multiLinkSingleReads;
388 }
389
390 }