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 EpisodeOfCareStatus {
038
039        /**
040         * This episode of care is planned to start at the date specified in the period.start. During this status, an organization may perform assessments to determine if the patient is eligible to receive services, or be organizing to make resources available to provide care services.
041         */
042        PLANNED, 
043        /**
044         * This episode has been placed on a waitlist, pending the episode being made active (or cancelled).
045         */
046        WAITLIST, 
047        /**
048         * This episode of care is current.
049         */
050        ACTIVE, 
051        /**
052         * This episode of care is on hold, the organization has limited responsibility for the patient (such as while on respite).
053         */
054        ONHOLD, 
055        /**
056         * This episode of care is finished and the organization is not expecting to be providing further care to the patient. Can also be known as "closed", "completed" or other similar terms.
057         */
058        FINISHED, 
059        /**
060         * The episode of care was cancelled, or withdrawn from service, often selected during the planned stage as the patient may have gone elsewhere, or the circumstances have changed and the organization is unable to provide the care. It indicates that services terminated outside the planned/expected workflow.
061         */
062        CANCELLED, 
063        /**
064         * This instance should not have been part of this patient's medical record.
065         */
066        ENTEREDINERROR, 
067        /**
068         * added to help the parsers
069         */
070        NULL;
071        public static EpisodeOfCareStatus fromCode(String codeString) throws FHIRException {
072            if (codeString == null || "".equals(codeString))
073                return null;
074        if ("planned".equals(codeString))
075          return PLANNED;
076        if ("waitlist".equals(codeString))
077          return WAITLIST;
078        if ("active".equals(codeString))
079          return ACTIVE;
080        if ("onhold".equals(codeString))
081          return ONHOLD;
082        if ("finished".equals(codeString))
083          return FINISHED;
084        if ("cancelled".equals(codeString))
085          return CANCELLED;
086        if ("entered-in-error".equals(codeString))
087          return ENTEREDINERROR;
088        throw new FHIRException("Unknown EpisodeOfCareStatus code '"+codeString+"'");
089        }
090        public String toCode() {
091          switch (this) {
092            case PLANNED: return "planned";
093            case WAITLIST: return "waitlist";
094            case ACTIVE: return "active";
095            case ONHOLD: return "onhold";
096            case FINISHED: return "finished";
097            case CANCELLED: return "cancelled";
098            case ENTEREDINERROR: return "entered-in-error";
099            default: return "?";
100          }
101        }
102        public String getSystem() {
103          return "http://hl7.org/fhir/episode-of-care-status";
104        }
105        public String getDefinition() {
106          switch (this) {
107            case PLANNED: return "This episode of care is planned to start at the date specified in the period.start. During this status, an organization may perform assessments to determine if the patient is eligible to receive services, or be organizing to make resources available to provide care services.";
108            case WAITLIST: return "This episode has been placed on a waitlist, pending the episode being made active (or cancelled).";
109            case ACTIVE: return "This episode of care is current.";
110            case ONHOLD: return "This episode of care is on hold, the organization has limited responsibility for the patient (such as while on respite).";
111            case FINISHED: return "This episode of care is finished and the organization is not expecting to be providing further care to the patient. Can also be known as \"closed\", \"completed\" or other similar terms.";
112            case CANCELLED: return "The episode of care was cancelled, or withdrawn from service, often selected during the planned stage as the patient may have gone elsewhere, or the circumstances have changed and the organization is unable to provide the care. It indicates that services terminated outside the planned/expected workflow.";
113            case ENTEREDINERROR: return "This instance should not have been part of this patient's medical record.";
114            default: return "?";
115          }
116        }
117        public String getDisplay() {
118          switch (this) {
119            case PLANNED: return "Planned";
120            case WAITLIST: return "Waitlist";
121            case ACTIVE: return "Active";
122            case ONHOLD: return "On Hold";
123            case FINISHED: return "Finished";
124            case CANCELLED: return "Cancelled";
125            case ENTEREDINERROR: return "Entered in Error";
126            default: return "?";
127          }
128    }
129
130
131}
132