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 PropertyRepresentation {
037
038  /**
039   * In XML, this property is represented as an attribute not an element.
040   */
041  XMLATTR,
042  /**
043   * This element is represented using the XML text attribute (primitives only).
044   */
045  XMLTEXT,
046  /**
047   * The type of this element is indicated using xsi:type.
048   */
049  TYPEATTR,
050  /**
051   * Use CDA narrative instead of XHTML.
052   */
053  CDATEXT,
054  /**
055   * The property is represented using XHTML.
056   */
057  XHTML,
058  /**
059   * added to help the parsers
060   */
061  NULL;
062
063  public static PropertyRepresentation fromCode(String codeString) throws FHIRException {
064    if (codeString == null || "".equals(codeString))
065      return null;
066    if ("xmlAttr".equals(codeString))
067      return XMLATTR;
068    if ("xmlText".equals(codeString))
069      return XMLTEXT;
070    if ("typeAttr".equals(codeString))
071      return TYPEATTR;
072    if ("cdaText".equals(codeString))
073      return CDATEXT;
074    if ("xhtml".equals(codeString))
075      return XHTML;
076    throw new FHIRException("Unknown PropertyRepresentation code '" + codeString + "'");
077  }
078
079  public String toCode() {
080    switch (this) {
081    case XMLATTR:
082      return "xmlAttr";
083    case XMLTEXT:
084      return "xmlText";
085    case TYPEATTR:
086      return "typeAttr";
087    case CDATEXT:
088      return "cdaText";
089    case XHTML:
090      return "xhtml";
091    case NULL:
092      return null;
093    default:
094      return "?";
095    }
096  }
097
098  public String getSystem() {
099    return "http://hl7.org/fhir/property-representation";
100  }
101
102  public String getDefinition() {
103    switch (this) {
104    case XMLATTR:
105      return "In XML, this property is represented as an attribute not an element.";
106    case XMLTEXT:
107      return "This element is represented using the XML text attribute (primitives only).";
108    case TYPEATTR:
109      return "The type of this element is indicated using xsi:type.";
110    case CDATEXT:
111      return "Use CDA narrative instead of XHTML.";
112    case XHTML:
113      return "The property is represented using XHTML.";
114    case NULL:
115      return null;
116    default:
117      return "?";
118    }
119  }
120
121  public String getDisplay() {
122    switch (this) {
123    case XMLATTR:
124      return "XML Attribute";
125    case XMLTEXT:
126      return "XML Text";
127    case TYPEATTR:
128      return "Type Attribute";
129    case CDATEXT:
130      return "CDA Text Format";
131    case XHTML:
132      return "XHTML";
133    case NULL:
134      return null;
135    default:
136      return "?";
137    }
138  }
139
140}