001package org.hl7.fhir.r4.model.codesystems;
002
003/*
004  Copyright (c) 2011+, HL7, Inc.
005  All rights reserved.
006  
007  Redistribution and use in source and binary forms, with or without modification, 
008  are permitted provided that the following conditions are met:
009  
010   * Redistributions of source code must retain the above copyright notice, this 
011     list of conditions and the following disclaimer.
012   * Redistributions in binary form must reproduce the above copyright notice, 
013     this list of conditions and the following disclaimer in the documentation 
014     and/or other materials provided with the distribution.
015   * Neither the name of HL7 nor the names of its contributors may be used to 
016     endorse or promote products derived from this software without specific 
017     prior written permission.
018  
019  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
020  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
021  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
022  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
023  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
024  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
025  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
026  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
027  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
028  POSSIBILITY OF SUCH DAMAGE.
029  
030*/
031
032// Generated on Thu, Sep 13, 2018 09:04-0400 for FHIR v3.5.0
033
034
035import org.hl7.fhir.exceptions.FHIRException;
036
037public enum ObservationStatus {
038
039        /**
040         * The existence of the observation is registered, but there is no result yet available.
041         */
042        REGISTERED, 
043        /**
044         * This is an initial or interim observation: data may be incomplete or unverified.
045         */
046        PRELIMINARY, 
047        /**
048         * The observation is complete and there are no further actions needed. Additional information such "released", "signed", etc would be represented using [Provenance](provenance.html) which provides not only the act but also the actors and dates and other related data. These act states would be associated with an observation status of `preliminary` until they are all completed and then a status of `final` would be applied.
049         */
050        FINAL, 
051        /**
052         * Subsequent to being Final, the observation has been modified subsequent.  This includes updates/new information and corrections.
053         */
054        AMENDED, 
055        /**
056         * Subsequent to being Final, the observation has been modified to correct an error in the test result.
057         */
058        CORRECTED, 
059        /**
060         * The observation is unavailable because the measurement was not started or not completed (also sometimes called "aborted").
061         */
062        CANCELLED, 
063        /**
064         * The observation has been withdrawn following previous final release.  This electronic record should never have existed, though it is possible that real-world decisions were based on it. (If real-world activity has occurred, the status should be "cancelled" rather than "entered-in-error".).
065         */
066        ENTEREDINERROR, 
067        /**
068         * The authoring system does not know which of the status values currently applies for this request. Note: This concept is not to be used for "other" - one of the listed statuses is presumed to apply, but the authoring system does not know which.
069         */
070        UNKNOWN, 
071        /**
072         * added to help the parsers
073         */
074        NULL;
075        public static ObservationStatus fromCode(String codeString) throws FHIRException {
076            if (codeString == null || "".equals(codeString))
077                return null;
078        if ("registered".equals(codeString))
079          return REGISTERED;
080        if ("preliminary".equals(codeString))
081          return PRELIMINARY;
082        if ("final".equals(codeString))
083          return FINAL;
084        if ("amended".equals(codeString))
085          return AMENDED;
086        if ("corrected".equals(codeString))
087          return CORRECTED;
088        if ("cancelled".equals(codeString))
089          return CANCELLED;
090        if ("entered-in-error".equals(codeString))
091          return ENTEREDINERROR;
092        if ("unknown".equals(codeString))
093          return UNKNOWN;
094        throw new FHIRException("Unknown ObservationStatus code '"+codeString+"'");
095        }
096        public String toCode() {
097          switch (this) {
098            case REGISTERED: return "registered";
099            case PRELIMINARY: return "preliminary";
100            case FINAL: return "final";
101            case AMENDED: return "amended";
102            case CORRECTED: return "corrected";
103            case CANCELLED: return "cancelled";
104            case ENTEREDINERROR: return "entered-in-error";
105            case UNKNOWN: return "unknown";
106            default: return "?";
107          }
108        }
109        public String getSystem() {
110          return "http://hl7.org/fhir/observation-status";
111        }
112        public String getDefinition() {
113          switch (this) {
114            case REGISTERED: return "The existence of the observation is registered, but there is no result yet available.";
115            case PRELIMINARY: return "This is an initial or interim observation: data may be incomplete or unverified.";
116            case FINAL: return "The observation is complete and there are no further actions needed. Additional information such \"released\", \"signed\", etc would be represented using [Provenance](provenance.html) which provides not only the act but also the actors and dates and other related data. These act states would be associated with an observation status of `preliminary` until they are all completed and then a status of `final` would be applied.";
117            case AMENDED: return "Subsequent to being Final, the observation has been modified subsequent.  This includes updates/new information and corrections.";
118            case CORRECTED: return "Subsequent to being Final, the observation has been modified to correct an error in the test result.";
119            case CANCELLED: return "The observation is unavailable because the measurement was not started or not completed (also sometimes called \"aborted\").";
120            case ENTEREDINERROR: return "The observation has been withdrawn following previous final release.  This electronic record should never have existed, though it is possible that real-world decisions were based on it. (If real-world activity has occurred, the status should be \"cancelled\" rather than \"entered-in-error\".).";
121            case UNKNOWN: return "The authoring system does not know which of the status values currently applies for this request. Note: This concept is not to be used for \"other\" - one of the listed statuses is presumed to apply, but the authoring system does not know which.";
122            default: return "?";
123          }
124        }
125        public String getDisplay() {
126          switch (this) {
127            case REGISTERED: return "Registered";
128            case PRELIMINARY: return "Preliminary";
129            case FINAL: return "Final";
130            case AMENDED: return "Amended";
131            case CORRECTED: return "Corrected";
132            case CANCELLED: return "Cancelled";
133            case ENTEREDINERROR: return "Entered in Error";
134            case UNKNOWN: return "Unknown";
135            default: return "?";
136          }
137    }
138
139
140}
141