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