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 Thu, Sep 13, 2018 09:04-0400 for FHIR v3.5.0
033
034
035import org.hl7.fhir.exceptions.FHIRException;
036
037public enum ListOrder {
038
039        /**
040         * The list was sorted by a user. The criteria the user used are not specified.
041         */
042        USER, 
043        /**
044         * The list was sorted by the system. The criteria the user used are not specified; define additional codes to specify a particular order (or use other defined codes).
045         */
046        SYSTEM, 
047        /**
048         * The list is sorted by the data of the event. This can be used when the list has items which are dates with past or future events.
049         */
050        EVENTDATE, 
051        /**
052         * The list is sorted by the date the item was added to the list. Note that the date added to the list is not explicit in the list itself.
053         */
054        ENTRYDATE, 
055        /**
056         * The list is sorted by priority. The exact method in which priority has been determined is not specified.
057         */
058        PRIORITY, 
059        /**
060         * The list is sorted alphabetically by an unspecified property of the items in the list.
061         */
062        ALPHABETIC, 
063        /**
064         * The list is sorted categorically by an unspecified property of the items in the list.
065         */
066        CATEGORY, 
067        /**
068         * The list is sorted by patient, with items for each patient grouped together.
069         */
070        PATIENT, 
071        /**
072         * added to help the parsers
073         */
074        NULL;
075        public static ListOrder fromCode(String codeString) throws FHIRException {
076            if (codeString == null || "".equals(codeString))
077                return null;
078        if ("user".equals(codeString))
079          return USER;
080        if ("system".equals(codeString))
081          return SYSTEM;
082        if ("event-date".equals(codeString))
083          return EVENTDATE;
084        if ("entry-date".equals(codeString))
085          return ENTRYDATE;
086        if ("priority".equals(codeString))
087          return PRIORITY;
088        if ("alphabetic".equals(codeString))
089          return ALPHABETIC;
090        if ("category".equals(codeString))
091          return CATEGORY;
092        if ("patient".equals(codeString))
093          return PATIENT;
094        throw new FHIRException("Unknown ListOrder code '"+codeString+"'");
095        }
096        public String toCode() {
097          switch (this) {
098            case USER: return "user";
099            case SYSTEM: return "system";
100            case EVENTDATE: return "event-date";
101            case ENTRYDATE: return "entry-date";
102            case PRIORITY: return "priority";
103            case ALPHABETIC: return "alphabetic";
104            case CATEGORY: return "category";
105            case PATIENT: return "patient";
106            default: return "?";
107          }
108        }
109        public String getSystem() {
110          return "http://terminology.hl7.org/CodeSystem/list-order";
111        }
112        public String getDefinition() {
113          switch (this) {
114            case USER: return "The list was sorted by a user. The criteria the user used are not specified.";
115            case SYSTEM: return "The list was sorted by the system. The criteria the user used are not specified; define additional codes to specify a particular order (or use other defined codes).";
116            case EVENTDATE: return "The list is sorted by the data of the event. This can be used when the list has items which are dates with past or future events.";
117            case ENTRYDATE: return "The list is sorted by the date the item was added to the list. Note that the date added to the list is not explicit in the list itself.";
118            case PRIORITY: return "The list is sorted by priority. The exact method in which priority has been determined is not specified.";
119            case ALPHABETIC: return "The list is sorted alphabetically by an unspecified property of the items in the list.";
120            case CATEGORY: return "The list is sorted categorically by an unspecified property of the items in the list.";
121            case PATIENT: return "The list is sorted by patient, with items for each patient grouped together.";
122            default: return "?";
123          }
124        }
125        public String getDisplay() {
126          switch (this) {
127            case USER: return "Sorted by User";
128            case SYSTEM: return "Sorted by System";
129            case EVENTDATE: return "Sorted by Event Date";
130            case ENTRYDATE: return "Sorted by Item Date";
131            case PRIORITY: return "Sorted by Priority";
132            case ALPHABETIC: return "Sorted Alphabetically";
133            case CATEGORY: return "Sorted by Category";
134            case PATIENT: return "Sorted by Patient";
135            default: return "?";
136          }
137    }
138
139
140}
141