001
002package ca.uhn.fhir.model.dstu2.valueset;
003
004import ca.uhn.fhir.model.api.*;
005import java.util.HashMap;
006import java.util.Map;
007
008public enum FlagCategoryCodesEnum {
009
010        /**
011         * Display: <b>Clinical</b><br>
012         * Code Value: <b>CL</b>
013         *
014         * Patient has special needs, limitations, or preferences that impact clinical treatment.
015         */
016        CLINICAL("CL", "http://hl7.org/fhir/flagCategory"),
017        
018        /**
019         * Display: <b>Behavioral</b><br>
020         * Code Value: <b>BH</b>
021         *
022         * Patient actions that pose risk or otherwise impact health or treatement, e.g. verbal threats, possession of weapons in a health care facility, acts of violence, history of suicidal behavior, drug-seeking behavior, or sexual harrassment.
023         */
024        BEHAVIORAL("BH", "http://hl7.org/fhir/flagCategory"),
025        
026        /**
027         * Display: <b>Research</b><br>
028         * Code Value: <b>RES</b>
029         *
030         * Patient is a participant in a research study.
031         */
032        RESEARCH("RES", "http://hl7.org/fhir/flagCategory"),
033        
034        /**
035         * Display: <b>Special Circumstances</b><br>
036         * Code Value: <b>SC</b>
037         *
038         * Special circumstances in terms of transportation, living situation, or communications.
039         */
040        SPECIAL_CIRCUMSTANCES("SC", "http://hl7.org/fhir/flagCategory"),
041        
042        /**
043         * Display: <b>Administrative</b><br>
044         * Code Value: <b>ADM</b>
045         *
046         * Special issues with respect to payment, insurance, or other administrative matters.
047         */
048        ADMINISTRATIVE("ADM", "http://hl7.org/fhir/flagCategory"),
049        
050        /**
051         * Display: <b>Advance Directive</b><br>
052         * Code Value: <b>ADV</b>
053         *
054         * Patient has advance directives.
055         */
056        ADVANCE_DIRECTIVE("ADV", "http://hl7.org/fhir/flagCategory"),
057        
058        /**
059         * Display: <b>Other</b><br>
060         * Code Value: <b>OT</b>
061         *
062         * Flag or alert not belonging to any other category.
063         */
064        OTHER("OT", "http://hl7.org/fhir/flagCategory"),
065        
066        ;
067        
068        /**
069         * Identifier for this Value Set:
070         * 
071         */
072        public static final String VALUESET_IDENTIFIER = "";
073
074        /**
075         * Name for this Value Set:
076         * Flag Category Codes
077         */
078        public static final String VALUESET_NAME = "Flag Category Codes";
079
080        private static Map<String, FlagCategoryCodesEnum> CODE_TO_ENUM = new HashMap<String, FlagCategoryCodesEnum>();
081        private static Map<String, Map<String, FlagCategoryCodesEnum>> SYSTEM_TO_CODE_TO_ENUM = new HashMap<String, Map<String, FlagCategoryCodesEnum>>();
082        
083        private final String myCode;
084        private final String mySystem;
085        
086        static {
087                for (FlagCategoryCodesEnum next : FlagCategoryCodesEnum.values()) {
088                        CODE_TO_ENUM.put(next.getCode(), next);
089                        
090                        if (!SYSTEM_TO_CODE_TO_ENUM.containsKey(next.getSystem())) {
091                                SYSTEM_TO_CODE_TO_ENUM.put(next.getSystem(), new HashMap<String, FlagCategoryCodesEnum>());
092                        }
093                        SYSTEM_TO_CODE_TO_ENUM.get(next.getSystem()).put(next.getCode(), next);                 
094                }
095        }
096        
097        /**
098         * Returns the code associated with this enumerated value
099         */
100        public String getCode() {
101                return myCode;
102        }
103        
104        /**
105         * Returns the code system associated with this enumerated value
106         */
107        public String getSystem() {
108                return mySystem;
109        }
110        
111        /**
112         * Returns the enumerated value associated with this code
113         */
114        public static FlagCategoryCodesEnum forCode(String theCode) {
115                FlagCategoryCodesEnum retVal = CODE_TO_ENUM.get(theCode);
116                return retVal;
117        }
118
119        /**
120         * Converts codes to their respective enumerated values
121         */
122        public static final IValueSetEnumBinder<FlagCategoryCodesEnum> VALUESET_BINDER = new IValueSetEnumBinder<FlagCategoryCodesEnum>() {
123                @Override
124                public String toCodeString(FlagCategoryCodesEnum theEnum) {
125                        return theEnum.getCode();
126                }
127
128                @Override
129                public String toSystemString(FlagCategoryCodesEnum theEnum) {
130                        return theEnum.getSystem();
131                }
132                
133                @Override
134                public FlagCategoryCodesEnum fromCodeString(String theCodeString) {
135                        return CODE_TO_ENUM.get(theCodeString);
136                }
137                
138                @Override
139                public FlagCategoryCodesEnum fromCodeString(String theCodeString, String theSystemString) {
140                        Map<String, FlagCategoryCodesEnum> map = SYSTEM_TO_CODE_TO_ENUM.get(theSystemString);
141                        if (map == null) {
142                                return null;
143                        }
144                        return map.get(theCodeString);
145                }
146                
147        };
148        
149        /** 
150         * Constructor
151         */
152        FlagCategoryCodesEnum(String theCode, String theSystem) {
153                myCode = theCode;
154                mySystem = theSystem;
155        }
156
157        
158}