001/* 002 * This class is an auto-generated source file for a HAPI 003 * HL7 v2.x standard structure class. 004 * 005 * For more information, visit: http://hl7api.sourceforge.net/ 006 * 007 * The contents of this file are subject to the Mozilla Public License Version 1.1 008 * (the "License"); you may not use this file except in compliance with the License. 009 * You may obtain a copy of the License at http://www.mozilla.org/MPL/ 010 * Software distributed under the License is distributed on an "AS IS" basis, 011 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the 012 * specific language governing rights and limitations under the License. 013 * 014 * The Original Code is "[file_name]". Description: 015 * "[one_line_description]" 016 * 017 * The Initial Developer of the Original Code is University Health Network. Copyright (C) 018 * 2012. All Rights Reserved. 019 * 020 * Contributor(s): ______________________________________. 021 * 022 * Alternatively, the contents of this file may be used under the terms of the 023 * GNU General Public License (the "GPL"), in which case the provisions of the GPL are 024 * applicable instead of those above. If you wish to allow use of your version of this 025 * file only under the terms of the GPL and not to allow others to use your version 026 * of this file under the MPL, indicate your decision by deleting the provisions above 027 * and replace them with the notice and other provisions required by the GPL License. 028 * If you do not delete the provisions above, a recipient may use your version of 029 * this file under either the MPL or the GPL. 030 * 031 */ 032 033 034package ca.uhn.hl7v2.model.v231.segment; 035 036// import ca.uhn.hl7v2.model.v231.group.*; 037import ca.uhn.hl7v2.model.v231.datatype.*; 038import ca.uhn.hl7v2.HL7Exception; 039import ca.uhn.hl7v2.parser.ModelClassFactory; 040import ca.uhn.hl7v2.parser.DefaultModelClassFactory; 041import ca.uhn.hl7v2.model.AbstractMessage; 042import ca.uhn.hl7v2.model.Group; 043import ca.uhn.hl7v2.model.Type; 044import ca.uhn.hl7v2.model.AbstractSegment; 045import ca.uhn.hl7v2.model.Varies; 046 047 048/** 049 *<p>Represents an HL7 DRG message segment (DRG - diagnosis related group segment). 050 * This segment has the following fields:</p> 051 * <ul> 052 * <li>DRG-1: Diagnostic Related Group (CE) <b>optional </b> 053 * <li>DRG-2: DRG Assigned Date/Time (TS) <b>optional </b> 054 * <li>DRG-3: DRG Approval Indicator (ID) <b>optional </b> 055 * <li>DRG-4: DRG Grouper Review Code (IS) <b>optional </b> 056 * <li>DRG-5: Outlier Type (CE) <b>optional </b> 057 * <li>DRG-6: Outlier Days (NM) <b>optional </b> 058 * <li>DRG-7: Outlier Cost (CP) <b>optional </b> 059 * <li>DRG-8: DRG Payor (IS) <b>optional </b> 060 * <li>DRG-9: Outlier Reimbursement (CP) <b>optional </b> 061 * <li>DRG-10: Confidential Indicator (ID) <b>optional </b> 062 * </ul> 063 */ 064@SuppressWarnings("unused") 065public class DRG extends AbstractSegment { 066 067 /** 068 * Creates a new DRG segment 069 */ 070 public DRG(Group parent, ModelClassFactory factory) { 071 super(parent, factory); 072 init(factory); 073 } 074 075 private void init(ModelClassFactory factory) { 076 try { 077 this.add(CE.class, false, 1, 60, new Object[]{ getMessage() }, "Diagnostic Related Group"); 078 this.add(TS.class, false, 1, 26, new Object[]{ getMessage() }, "DRG Assigned Date/Time"); 079 this.add(ID.class, false, 1, 1, new Object[]{ getMessage(), new Integer(136) }, "DRG Approval Indicator"); 080 this.add(IS.class, false, 1, 2, new Object[]{ getMessage(), new Integer(56) }, "DRG Grouper Review Code"); 081 this.add(CE.class, false, 1, 60, new Object[]{ getMessage() }, "Outlier Type"); 082 this.add(NM.class, false, 1, 3, new Object[]{ getMessage() }, "Outlier Days"); 083 this.add(CP.class, false, 1, 12, new Object[]{ getMessage() }, "Outlier Cost"); 084 this.add(IS.class, false, 1, 1, new Object[]{ getMessage(), new Integer(229) }, "DRG Payor"); 085 this.add(CP.class, false, 1, 9, new Object[]{ getMessage() }, "Outlier Reimbursement"); 086 this.add(ID.class, false, 1, 1, new Object[]{ getMessage(), new Integer(136) }, "Confidential Indicator"); 087 } catch(HL7Exception e) { 088 log.error("Unexpected error creating DRG - this is probably a bug in the source code generator.", e); 089 } 090 } 091 092 093 094 /** 095 * Returns 096 * DRG-1: "Diagnostic Related Group" - creates it if necessary 097 */ 098 public CE getDiagnosticRelatedGroup() { 099 CE retVal = this.getTypedField(1, 0); 100 return retVal; 101 } 102 103 /** 104 * Returns 105 * DRG-1: "Diagnostic Related Group" - creates it if necessary 106 */ 107 public CE getDrg1_DiagnosticRelatedGroup() { 108 CE retVal = this.getTypedField(1, 0); 109 return retVal; 110 } 111 112 113 114 /** 115 * Returns 116 * DRG-2: "DRG Assigned Date/Time" - creates it if necessary 117 */ 118 public TS getDRGAssignedDateTime() { 119 TS retVal = this.getTypedField(2, 0); 120 return retVal; 121 } 122 123 /** 124 * Returns 125 * DRG-2: "DRG Assigned Date/Time" - creates it if necessary 126 */ 127 public TS getDrg2_DRGAssignedDateTime() { 128 TS retVal = this.getTypedField(2, 0); 129 return retVal; 130 } 131 132 133 134 /** 135 * Returns 136 * DRG-3: "DRG Approval Indicator" - creates it if necessary 137 */ 138 public ID getDRGApprovalIndicator() { 139 ID retVal = this.getTypedField(3, 0); 140 return retVal; 141 } 142 143 /** 144 * Returns 145 * DRG-3: "DRG Approval Indicator" - creates it if necessary 146 */ 147 public ID getDrg3_DRGApprovalIndicator() { 148 ID retVal = this.getTypedField(3, 0); 149 return retVal; 150 } 151 152 153 154 /** 155 * Returns 156 * DRG-4: "DRG Grouper Review Code" - creates it if necessary 157 */ 158 public IS getDRGGrouperReviewCode() { 159 IS retVal = this.getTypedField(4, 0); 160 return retVal; 161 } 162 163 /** 164 * Returns 165 * DRG-4: "DRG Grouper Review Code" - creates it if necessary 166 */ 167 public IS getDrg4_DRGGrouperReviewCode() { 168 IS retVal = this.getTypedField(4, 0); 169 return retVal; 170 } 171 172 173 174 /** 175 * Returns 176 * DRG-5: "Outlier Type" - creates it if necessary 177 */ 178 public CE getOutlierType() { 179 CE retVal = this.getTypedField(5, 0); 180 return retVal; 181 } 182 183 /** 184 * Returns 185 * DRG-5: "Outlier Type" - creates it if necessary 186 */ 187 public CE getDrg5_OutlierType() { 188 CE retVal = this.getTypedField(5, 0); 189 return retVal; 190 } 191 192 193 194 /** 195 * Returns 196 * DRG-6: "Outlier Days" - creates it if necessary 197 */ 198 public NM getOutlierDays() { 199 NM retVal = this.getTypedField(6, 0); 200 return retVal; 201 } 202 203 /** 204 * Returns 205 * DRG-6: "Outlier Days" - creates it if necessary 206 */ 207 public NM getDrg6_OutlierDays() { 208 NM retVal = this.getTypedField(6, 0); 209 return retVal; 210 } 211 212 213 214 /** 215 * Returns 216 * DRG-7: "Outlier Cost" - creates it if necessary 217 */ 218 public CP getOutlierCost() { 219 CP retVal = this.getTypedField(7, 0); 220 return retVal; 221 } 222 223 /** 224 * Returns 225 * DRG-7: "Outlier Cost" - creates it if necessary 226 */ 227 public CP getDrg7_OutlierCost() { 228 CP retVal = this.getTypedField(7, 0); 229 return retVal; 230 } 231 232 233 234 /** 235 * Returns 236 * DRG-8: "DRG Payor" - creates it if necessary 237 */ 238 public IS getDRGPayor() { 239 IS retVal = this.getTypedField(8, 0); 240 return retVal; 241 } 242 243 /** 244 * Returns 245 * DRG-8: "DRG Payor" - creates it if necessary 246 */ 247 public IS getDrg8_DRGPayor() { 248 IS retVal = this.getTypedField(8, 0); 249 return retVal; 250 } 251 252 253 254 /** 255 * Returns 256 * DRG-9: "Outlier Reimbursement" - creates it if necessary 257 */ 258 public CP getOutlierReimbursement() { 259 CP retVal = this.getTypedField(9, 0); 260 return retVal; 261 } 262 263 /** 264 * Returns 265 * DRG-9: "Outlier Reimbursement" - creates it if necessary 266 */ 267 public CP getDrg9_OutlierReimbursement() { 268 CP retVal = this.getTypedField(9, 0); 269 return retVal; 270 } 271 272 273 274 /** 275 * Returns 276 * DRG-10: "Confidential Indicator" - creates it if necessary 277 */ 278 public ID getConfidentialIndicator() { 279 ID retVal = this.getTypedField(10, 0); 280 return retVal; 281 } 282 283 /** 284 * Returns 285 * DRG-10: "Confidential Indicator" - creates it if necessary 286 */ 287 public ID getDrg10_ConfidentialIndicator() { 288 ID retVal = this.getTypedField(10, 0); 289 return retVal; 290 } 291 292 293 294 295 296 /** {@inheritDoc} */ 297 protected Type createNewTypeWithoutReflection(int field) { 298 switch (field) { 299 case 0: return new CE(getMessage()); 300 case 1: return new TS(getMessage()); 301 case 2: return new ID(getMessage(), new Integer( 136 )); 302 case 3: return new IS(getMessage(), new Integer( 56 )); 303 case 4: return new CE(getMessage()); 304 case 5: return new NM(getMessage()); 305 case 6: return new CP(getMessage()); 306 case 7: return new IS(getMessage(), new Integer( 229 )); 307 case 8: return new CP(getMessage()); 308 case 9: return new ID(getMessage(), new Integer( 136 )); 309 default: return null; 310 } 311 } 312 313 314} 315