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 AppointmentStatusEnum {
009
010        /**
011         * Display: <b>Proposed</b><br>
012         * Code Value: <b>proposed</b>
013         *
014         * None of the participant(s) have finalized their acceptance of the appointment request, and the start/end time may not be set yet.
015         */
016        PROPOSED("proposed", "http://hl7.org/fhir/appointmentstatus"),
017        
018        /**
019         * Display: <b>Pending</b><br>
020         * Code Value: <b>pending</b>
021         *
022         * Some or all of the participant(s) have not finalized their acceptance of the appointment request.
023         */
024        PENDING("pending", "http://hl7.org/fhir/appointmentstatus"),
025        
026        /**
027         * Display: <b>Booked</b><br>
028         * Code Value: <b>booked</b>
029         *
030         * All participant(s) have been considered and the appointment is confirmed to go ahead at the date/times specified.
031         */
032        BOOKED("booked", "http://hl7.org/fhir/appointmentstatus"),
033        
034        /**
035         * Display: <b>Arrived</b><br>
036         * Code Value: <b>arrived</b>
037         *
038         * Some of the patients have arrived.
039         */
040        ARRIVED("arrived", "http://hl7.org/fhir/appointmentstatus"),
041        
042        /**
043         * Display: <b>Fulfilled</b><br>
044         * Code Value: <b>fulfilled</b>
045         *
046         * This appointment has completed and may have resulted in an encounter.
047         */
048        FULFILLED("fulfilled", "http://hl7.org/fhir/appointmentstatus"),
049        
050        /**
051         * Display: <b>Cancelled</b><br>
052         * Code Value: <b>cancelled</b>
053         *
054         * The appointment has been cancelled.
055         */
056        CANCELLED("cancelled", "http://hl7.org/fhir/appointmentstatus"),
057        
058        /**
059         * Display: <b>No Show</b><br>
060         * Code Value: <b>noshow</b>
061         *
062         * Some or all of the participant(s) have not/did not appear for the appointment (usually the patient).
063         */
064        NO_SHOW("noshow", "http://hl7.org/fhir/appointmentstatus"),
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         * AppointmentStatus
077         */
078        public static final String VALUESET_NAME = "AppointmentStatus";
079
080        private static Map<String, AppointmentStatusEnum> CODE_TO_ENUM = new HashMap<String, AppointmentStatusEnum>();
081        private static Map<String, Map<String, AppointmentStatusEnum>> SYSTEM_TO_CODE_TO_ENUM = new HashMap<String, Map<String, AppointmentStatusEnum>>();
082        
083        private final String myCode;
084        private final String mySystem;
085        
086        static {
087                for (AppointmentStatusEnum next : AppointmentStatusEnum.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, AppointmentStatusEnum>());
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 AppointmentStatusEnum forCode(String theCode) {
115                AppointmentStatusEnum 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<AppointmentStatusEnum> VALUESET_BINDER = new IValueSetEnumBinder<AppointmentStatusEnum>() {
123                @Override
124                public String toCodeString(AppointmentStatusEnum theEnum) {
125                        return theEnum.getCode();
126                }
127
128                @Override
129                public String toSystemString(AppointmentStatusEnum theEnum) {
130                        return theEnum.getSystem();
131                }
132                
133                @Override
134                public AppointmentStatusEnum fromCodeString(String theCodeString) {
135                        return CODE_TO_ENUM.get(theCodeString);
136                }
137                
138                @Override
139                public AppointmentStatusEnum fromCodeString(String theCodeString, String theSystemString) {
140                        Map<String, AppointmentStatusEnum> 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        AppointmentStatusEnum(String theCode, String theSystem) {
153                myCode = theCode;
154                mySystem = theSystem;
155        }
156
157        
158}