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 V3RoleStatus {
041
042        /**
043         * The 'typical' state. Excludes "nullified" which represents the termination state of a Role instance that was created in error.
044         */
045        NORMAL, 
046        /**
047         * The state representing the fact that the Entity is currently active in the Role.
048         */
049        ACTIVE, 
050        /**
051         * The terminal state resulting from cancellation of the role prior to activation.
052         */
053        CANCELLED, 
054        /**
055         * The state representing that fact that the role has not yet become active.
056         */
057        PENDING, 
058        /**
059         * The state that represents a suspension of the Entity playing the Role. This state is arrived at from the "active" state.
060         */
061        SUSPENDED, 
062        /**
063         * The state representing the successful termination of the Role.
064         */
065        TERMINATED, 
066        /**
067         * The state representing the termination of a Role instance that was created in error.
068         */
069        NULLIFIED, 
070        /**
071         * added to help the parsers
072         */
073        NULL;
074        public static V3RoleStatus fromCode(String codeString) throws FHIRException {
075            if (codeString == null || "".equals(codeString))
076                return null;
077        if ("normal".equals(codeString))
078          return NORMAL;
079        if ("active".equals(codeString))
080          return ACTIVE;
081        if ("cancelled".equals(codeString))
082          return CANCELLED;
083        if ("pending".equals(codeString))
084          return PENDING;
085        if ("suspended".equals(codeString))
086          return SUSPENDED;
087        if ("terminated".equals(codeString))
088          return TERMINATED;
089        if ("nullified".equals(codeString))
090          return NULLIFIED;
091        throw new FHIRException("Unknown V3RoleStatus code '"+codeString+"'");
092        }
093        public String toCode() {
094          switch (this) {
095            case NORMAL: return "normal";
096            case ACTIVE: return "active";
097            case CANCELLED: return "cancelled";
098            case PENDING: return "pending";
099            case SUSPENDED: return "suspended";
100            case TERMINATED: return "terminated";
101            case NULLIFIED: return "nullified";
102            default: return "?";
103          }
104        }
105        public String getSystem() {
106          return "http://terminology.hl7.org/CodeSystem/v3-RoleStatus";
107        }
108        public String getDefinition() {
109          switch (this) {
110            case NORMAL: return "The 'typical' state. Excludes \"nullified\" which represents the termination state of a Role instance that was created in error.";
111            case ACTIVE: return "The state representing the fact that the Entity is currently active in the Role.";
112            case CANCELLED: return "The terminal state resulting from cancellation of the role prior to activation.";
113            case PENDING: return "The state representing that fact that the role has not yet become active.";
114            case SUSPENDED: return "The state that represents a suspension of the Entity playing the Role. This state is arrived at from the \"active\" state.";
115            case TERMINATED: return "The state representing the successful termination of the Role.";
116            case NULLIFIED: return "The state representing the termination of a Role instance that was created in error.";
117            default: return "?";
118          }
119        }
120        public String getDisplay() {
121          switch (this) {
122            case NORMAL: return "normal";
123            case ACTIVE: return "active";
124            case CANCELLED: return "cancelled";
125            case PENDING: return "pending";
126            case SUSPENDED: return "suspended";
127            case TERMINATED: return "terminated";
128            case NULLIFIED: return "nullified";
129            default: return "?";
130          }
131    }
132
133
134}