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 Sun, May 6, 2018 17:51-0400 for FHIR v3.4.0
033
034
035import org.hl7.fhir.exceptions.FHIRException;
036
037public enum PlanDefinitionType {
038
039        /**
040         * A pre-defined and approved group of orders related to a particular clinical condition (e.g. hypertension treatment and monitoring) or stage of care (e.g. hospital admission to Coronary Care Unit). An order set is used as a checklist for the clinician when managing a patient with a specific condition. It is a structured collection of orders relevant to that condition and presented to the clinician in a computerized provider order entry (CPOE) system
041         */
042        ORDERSET, 
043        /**
044         * Defines a desired/typical sequence of clinical activities including preconditions, triggers and temporal relationships
045         */
046        CLINICALPROTOCOL, 
047        /**
048         * A decision support rule of the form [on Event] if Condition then Action. It is intended to be a shareable, computable definition of actions that should be taken whenever some condition is met in response to a particular event or events
049         */
050        ECARULE, 
051        /**
052         * Defines the steps for a group of one or more systems in an event flow process along with the step constraints, sequence, pre-conditions and decision points to complete a particular objective
053         */
054        WORKFLOWDEFINITION, 
055        /**
056         * added to help the parsers
057         */
058        NULL;
059        public static PlanDefinitionType fromCode(String codeString) throws FHIRException {
060            if (codeString == null || "".equals(codeString))
061                return null;
062        if ("order-set".equals(codeString))
063          return ORDERSET;
064        if ("clinical-protocol".equals(codeString))
065          return CLINICALPROTOCOL;
066        if ("eca-rule".equals(codeString))
067          return ECARULE;
068        if ("workflow-definition".equals(codeString))
069          return WORKFLOWDEFINITION;
070        throw new FHIRException("Unknown PlanDefinitionType code '"+codeString+"'");
071        }
072        public String toCode() {
073          switch (this) {
074            case ORDERSET: return "order-set";
075            case CLINICALPROTOCOL: return "clinical-protocol";
076            case ECARULE: return "eca-rule";
077            case WORKFLOWDEFINITION: return "workflow-definition";
078            default: return "?";
079          }
080        }
081        public String getSystem() {
082          return "http://hl7.org/fhir/plan-definition-type";
083        }
084        public String getDefinition() {
085          switch (this) {
086            case ORDERSET: return "A pre-defined and approved group of orders related to a particular clinical condition (e.g. hypertension treatment and monitoring) or stage of care (e.g. hospital admission to Coronary Care Unit). An order set is used as a checklist for the clinician when managing a patient with a specific condition. It is a structured collection of orders relevant to that condition and presented to the clinician in a computerized provider order entry (CPOE) system";
087            case CLINICALPROTOCOL: return "Defines a desired/typical sequence of clinical activities including preconditions, triggers and temporal relationships";
088            case ECARULE: return "A decision support rule of the form [on Event] if Condition then Action. It is intended to be a shareable, computable definition of actions that should be taken whenever some condition is met in response to a particular event or events";
089            case WORKFLOWDEFINITION: return "Defines the steps for a group of one or more systems in an event flow process along with the step constraints, sequence, pre-conditions and decision points to complete a particular objective";
090            default: return "?";
091          }
092        }
093        public String getDisplay() {
094          switch (this) {
095            case ORDERSET: return "Order Set";
096            case CLINICALPROTOCOL: return "Clinical Protocol";
097            case ECARULE: return "ECA Rule";
098            case WORKFLOWDEFINITION: return "Workflow Definition";
099            default: return "?";
100          }
101    }
102
103
104}
105