001package org.hl7.fhir.dstu3.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 Sat, Mar 25, 2017 21:03-0400 for FHIR v3.0.0
036
037
038import org.hl7.fhir.exceptions.FHIRException;
039
040public enum ContactPointSystem {
041
042        /**
043         * The value is a telephone number used for voice calls. Use of full international numbers starting with + is recommended to enable automatic dialing support but not required.
044         */
045        PHONE, 
046        /**
047         * The value is a fax machine. Use of full international numbers starting with + is recommended to enable automatic dialing support but not required.
048         */
049        FAX, 
050        /**
051         * The value is an email address.
052         */
053        EMAIL, 
054        /**
055         * The value is a pager number. These may be local pager numbers that are only usable on a particular pager system.
056         */
057        PAGER, 
058        /**
059         * A contact that is not a phone, fax, pager or email address and is expressed as a URL.  This is intended for various personal contacts including blogs, Skype, Twitter, Facebook, etc. Do not use for email addresses.
060         */
061        URL, 
062        /**
063         * A contact that can be used for sending an sms message (e.g. mobide phones, some landlines)
064         */
065        SMS, 
066        /**
067         * A contact that is not a phone, fax, page or email address and is not expressible as a URL.  E.g. Internal mail address.  This SHOULD NOT be used for contacts that are expressible as a URL (e.g. Skype, Twitter, Facebook, etc.)  Extensions may be used to distinguish "other" contact types.
068         */
069        OTHER, 
070        /**
071         * added to help the parsers
072         */
073        NULL;
074        public static ContactPointSystem fromCode(String codeString) throws FHIRException {
075            if (codeString == null || "".equals(codeString))
076                return null;
077        if ("phone".equals(codeString))
078          return PHONE;
079        if ("fax".equals(codeString))
080          return FAX;
081        if ("email".equals(codeString))
082          return EMAIL;
083        if ("pager".equals(codeString))
084          return PAGER;
085        if ("url".equals(codeString))
086          return URL;
087        if ("sms".equals(codeString))
088          return SMS;
089        if ("other".equals(codeString))
090          return OTHER;
091        throw new FHIRException("Unknown ContactPointSystem code '"+codeString+"'");
092        }
093        public String toCode() {
094          switch (this) {
095            case PHONE: return "phone";
096            case FAX: return "fax";
097            case EMAIL: return "email";
098            case PAGER: return "pager";
099            case URL: return "url";
100            case SMS: return "sms";
101            case OTHER: return "other";
102            case NULL: return null;
103            default: return "?";
104          }
105        }
106        public String getSystem() {
107          return "http://hl7.org/fhir/contact-point-system";
108        }
109        public String getDefinition() {
110          switch (this) {
111            case PHONE: return "The value is a telephone number used for voice calls. Use of full international numbers starting with + is recommended to enable automatic dialing support but not required.";
112            case FAX: return "The value is a fax machine. Use of full international numbers starting with + is recommended to enable automatic dialing support but not required.";
113            case EMAIL: return "The value is an email address.";
114            case PAGER: return "The value is a pager number. These may be local pager numbers that are only usable on a particular pager system.";
115            case URL: return "A contact that is not a phone, fax, pager or email address and is expressed as a URL.  This is intended for various personal contacts including blogs, Skype, Twitter, Facebook, etc. Do not use for email addresses.";
116            case SMS: return "A contact that can be used for sending an sms message (e.g. mobide phones, some landlines)";
117            case OTHER: return "A contact that is not a phone, fax, page or email address and is not expressible as a URL.  E.g. Internal mail address.  This SHOULD NOT be used for contacts that are expressible as a URL (e.g. Skype, Twitter, Facebook, etc.)  Extensions may be used to distinguish \"other\" contact types.";
118            case NULL: return null;
119            default: return "?";
120          }
121        }
122        public String getDisplay() {
123          switch (this) {
124            case PHONE: return "Phone";
125            case FAX: return "Fax";
126            case EMAIL: return "Email";
127            case PAGER: return "Pager";
128            case URL: return "URL";
129            case SMS: return "SMS";
130            case OTHER: return "Other";
131            case NULL: return null;
132            default: return "?";
133          }
134    }
135
136
137}