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