7d803555d5b01ffe18f33fd8eafd4b24b0dc3c41
2 * Copyright (C) 2007 EDIT
3 * European Distributed Institute of Taxonomy
4 * http://www.e-taxonomy.eu
6 * The contents of this file are subject to the Mozilla Public License Version 1.1
7 * See LICENSE.TXT at the top of this package for the full license terms.
10 package eu
.etaxonomy
.cdm
.model
.common
;
13 import java
.util
.HashMap
;
15 import java
.util
.UUID
;
17 import javax
.persistence
.Entity
;
18 import javax
.xml
.bind
.annotation
.XmlAccessType
;
19 import javax
.xml
.bind
.annotation
.XmlAccessorType
;
20 import javax
.xml
.bind
.annotation
.XmlRootElement
;
21 import javax
.xml
.bind
.annotation
.XmlType
;
23 import org
.apache
.log4j
.Logger
;
24 import org
.hibernate
.envers
.Audited
;
25 import org
.hibernate
.search
.annotations
.Indexed
;
28 * Annotation types ...
31 * @created 12-Nov-2008 15:37:33
33 @XmlAccessorType(XmlAccessType
.FIELD
)
34 @XmlType(name
= "AnnotationType")
35 @XmlRootElement(name
= "AnnotationType")
37 @Indexed(index
= "eu.etaxonomy.cdm.model.common.DefinedTermBase")
39 public class AnnotationType
extends DefinedTermBase
<AnnotationType
> {
40 private static final long serialVersionUID
= 49629121282854575L;
41 @SuppressWarnings("unused")
42 private static final Logger logger
= Logger
.getLogger(AnnotationType
.class);
44 protected static Map
<UUID
, AnnotationType
> termMap
= null;
46 private static final UUID uuidTechnical
= UUID
.fromString("6a5f9ea4-1bdd-4906-89ad-6e669f982d69");
47 private static final UUID uuidEditorial
= UUID
.fromString("e780d5fd-abfc-4025-938a-46deb751d808");
49 public static AnnotationType
NewInstance(String term
, String label
, String labelAbbrev
){
50 return new AnnotationType(term
, label
, labelAbbrev
);
58 public AnnotationType() {
66 protected AnnotationType(String term
, String label
, String labelAbbrev
) {
67 super(term
, label
, labelAbbrev
);
71 //************************** METHODS ********************************
73 protected static AnnotationType
getTermByUuid(UUID uuid
){
75 return null; //better return null then initialize the termMap in an unwanted way
77 return (AnnotationType
)termMap
.get(uuid
);
81 public static final AnnotationType
TECHNICAL(){
82 return getTermByUuid(uuidTechnical
);
85 public static final AnnotationType
EDITORIAL(){
86 return getTermByUuid(uuidEditorial
);
89 protected void setDefaultTerms(TermVocabulary
<AnnotationType
> termVocabulary
) {
90 termMap
= new HashMap
<UUID
, AnnotationType
>();
91 for (AnnotationType term
: termVocabulary
.getTerms()){
92 termMap
.put(term
.getUuid(), (AnnotationType
)term
);