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 ServiceReferralMethod {
037
038  /**
039   * Referrals may be accepted by fax.
040   */
041  FAX,
042  /**
043   * Referrals may be accepted over the phone from a practitioner.
044   */
045  PHONE,
046  /**
047   * Referrals may be accepted via a secure messaging system. To determine the
048   * types of secure messaging systems supported, refer to the identifiers
049   * collection. Callers will need to understand the specific identifier system
050   * used to know that they are able to transmit messages.
051   */
052  ELEC,
053  /**
054   * Referrals may be accepted via a secure email. To send please encrypt with the
055   * services public key.
056   */
057  SEMAIL,
058  /**
059   * Referrals may be accepted via regular postage (or hand delivered).
060   */
061  MAIL,
062  /**
063   * added to help the parsers
064   */
065  NULL;
066
067  public static ServiceReferralMethod fromCode(String codeString) throws FHIRException {
068    if (codeString == null || "".equals(codeString))
069      return null;
070    if ("fax".equals(codeString))
071      return FAX;
072    if ("phone".equals(codeString))
073      return PHONE;
074    if ("elec".equals(codeString))
075      return ELEC;
076    if ("semail".equals(codeString))
077      return SEMAIL;
078    if ("mail".equals(codeString))
079      return MAIL;
080    throw new FHIRException("Unknown ServiceReferralMethod code '" + codeString + "'");
081  }
082
083  public String toCode() {
084    switch (this) {
085    case FAX:
086      return "fax";
087    case PHONE:
088      return "phone";
089    case ELEC:
090      return "elec";
091    case SEMAIL:
092      return "semail";
093    case MAIL:
094      return "mail";
095    case NULL:
096      return null;
097    default:
098      return "?";
099    }
100  }
101
102  public String getSystem() {
103    return "http://terminology.hl7.org/CodeSystem/service-referral-method";
104  }
105
106  public String getDefinition() {
107    switch (this) {
108    case FAX:
109      return "Referrals may be accepted by fax.";
110    case PHONE:
111      return "Referrals may be accepted over the phone from a practitioner.";
112    case ELEC:
113      return "Referrals may be accepted via a secure messaging system. To determine the types of secure messaging systems supported, refer to the identifiers collection. Callers will need to understand the specific identifier system used to know that they are able to transmit messages.";
114    case SEMAIL:
115      return "Referrals may be accepted via a secure email. To send please encrypt with the services public key.";
116    case MAIL:
117      return "Referrals may be accepted via regular postage (or hand delivered).";
118    case NULL:
119      return null;
120    default:
121      return "?";
122    }
123  }
124
125  public String getDisplay() {
126    switch (this) {
127    case FAX:
128      return "Fax";
129    case PHONE:
130      return "Phone";
131    case ELEC:
132      return "Secure Messaging";
133    case SEMAIL:
134      return "Secure Email";
135    case MAIL:
136      return "Mail";
137    case NULL:
138      return null;
139    default:
140      return "?";
141    }
142  }
143
144}