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.v21.segment; 035 036// import ca.uhn.hl7v2.model.v21.group.*; 037import ca.uhn.hl7v2.model.v21.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 *<p>Represents an HL7 DG1 message segment (DIAGNOSIS). 049 * This segment has the following fields:</p> 050 * <ul> 051 * <li>DG1-1: SET ID - DIAGNOSIS (SI) <b> </b> 052 * <li>DG1-2: DIAGNOSIS CODING METHOD (ID) <b> </b> 053 * <li>DG1-3: DIAGNOSIS CODE (ID) <b>optional </b> 054 * <li>DG1-4: DIAGNOSIS DESCRIPTION (ST) <b>optional </b> 055 * <li>DG1-5: DIAGNOSIS DATE/TIME (TS) <b>optional </b> 056 * <li>DG1-6: DIAGNOSIS/DRG TYPE (ID) <b> </b> 057 * <li>DG1-7: MAJOR DIAGNOSTIC CATEGORY (ST) <b>optional </b> 058 * <li>DG1-8: DIAGNOSTIC RELATED GROUP (ID) <b>optional </b> 059 * <li>DG1-9: DRG APPROVAL INDICATOR (ID) <b>optional </b> 060 * <li>DG1-10: DRG GROUPER REVIEW CODE (ID) <b>optional </b> 061 * <li>DG1-11: OUTLIER TYPE (ID) <b>optional </b> 062 * <li>DG1-12: OUTLIER DAYS (NM) <b>optional </b> 063 * <li>DG1-13: OUTLIER COST (NM) <b>optional </b> 064 * <li>DG1-14: GROUPER VERSION AND TYPE (ST) <b>optional </b> 065 * </ul> 066 */ 067@SuppressWarnings("unused") 068public class DG1 extends AbstractSegment { 069 070 /** 071 * Creates a new DG1 segment 072 */ 073 public DG1(Group parent, ModelClassFactory factory) { 074 super(parent, factory); 075 init(factory); 076 } 077 078 private void init(ModelClassFactory factory) { 079 try { 080 this.add(SI.class, true, 1, 4, new Object[]{ getMessage() }, "SET ID - DIAGNOSIS"); 081 this.add(ID.class, true, 1, 2, new Object[]{ getMessage(), new Integer(53) }, "DIAGNOSIS CODING METHOD"); 082 this.add(ID.class, false, 1, 8, new Object[]{ getMessage(), new Integer(51) }, "DIAGNOSIS CODE"); 083 this.add(ST.class, false, 1, 40, new Object[]{ getMessage() }, "DIAGNOSIS DESCRIPTION"); 084 this.add(TS.class, false, 1, 19, new Object[]{ getMessage() }, "DIAGNOSIS DATE/TIME"); 085 this.add(ID.class, true, 1, 2, new Object[]{ getMessage(), new Integer(52) }, "DIAGNOSIS/DRG TYPE"); 086 this.add(ST.class, false, 1, 4, new Object[]{ getMessage() }, "MAJOR DIAGNOSTIC CATEGORY"); 087 this.add(ID.class, false, 1, 4, new Object[]{ getMessage(), new Integer(55) }, "DIAGNOSTIC RELATED GROUP"); 088 this.add(ID.class, false, 1, 2, new Object[]{ getMessage(), new Integer(0) }, "DRG APPROVAL INDICATOR"); 089 this.add(ID.class, false, 1, 2, new Object[]{ getMessage(), new Integer(56) }, "DRG GROUPER REVIEW CODE"); 090 this.add(ID.class, false, 1, 2, new Object[]{ getMessage(), new Integer(83) }, "OUTLIER TYPE"); 091 this.add(NM.class, false, 1, 3, new Object[]{ getMessage() }, "OUTLIER DAYS"); 092 this.add(NM.class, false, 1, 12, new Object[]{ getMessage() }, "OUTLIER COST"); 093 this.add(ST.class, false, 1, 4, new Object[]{ getMessage() }, "GROUPER VERSION AND TYPE"); 094 } catch(HL7Exception e) { 095 log.error("Unexpected error creating DG1 - this is probably a bug in the source code generator.", e); 096 } 097 } 098 099 100 101 /** 102 * Returns 103 * DG1-1: "SET ID - DIAGNOSIS" - creates it if necessary 104 */ 105 public SI getSETIDDIAGNOSIS() { 106 SI retVal = this.getTypedField(1, 0); 107 return retVal; 108 } 109 110 /** 111 * Returns 112 * DG1-1: "SET ID - DIAGNOSIS" - creates it if necessary 113 */ 114 public SI getDg11_SETIDDIAGNOSIS() { 115 SI retVal = this.getTypedField(1, 0); 116 return retVal; 117 } 118 119 120 121 /** 122 * Returns 123 * DG1-2: "DIAGNOSIS CODING METHOD" - creates it if necessary 124 */ 125 public ID getDIAGNOSISCODINGMETHOD() { 126 ID retVal = this.getTypedField(2, 0); 127 return retVal; 128 } 129 130 /** 131 * Returns 132 * DG1-2: "DIAGNOSIS CODING METHOD" - creates it if necessary 133 */ 134 public ID getDg12_DIAGNOSISCODINGMETHOD() { 135 ID retVal = this.getTypedField(2, 0); 136 return retVal; 137 } 138 139 140 141 /** 142 * Returns 143 * DG1-3: "DIAGNOSIS CODE" - creates it if necessary 144 */ 145 public ID getDIAGNOSISCODE() { 146 ID retVal = this.getTypedField(3, 0); 147 return retVal; 148 } 149 150 /** 151 * Returns 152 * DG1-3: "DIAGNOSIS CODE" - creates it if necessary 153 */ 154 public ID getDg13_DIAGNOSISCODE() { 155 ID retVal = this.getTypedField(3, 0); 156 return retVal; 157 } 158 159 160 161 /** 162 * Returns 163 * DG1-4: "DIAGNOSIS DESCRIPTION" - creates it if necessary 164 */ 165 public ST getDIAGNOSISDESCRIPTION() { 166 ST retVal = this.getTypedField(4, 0); 167 return retVal; 168 } 169 170 /** 171 * Returns 172 * DG1-4: "DIAGNOSIS DESCRIPTION" - creates it if necessary 173 */ 174 public ST getDg14_DIAGNOSISDESCRIPTION() { 175 ST retVal = this.getTypedField(4, 0); 176 return retVal; 177 } 178 179 180 181 /** 182 * Returns 183 * DG1-5: "DIAGNOSIS DATE/TIME" - creates it if necessary 184 */ 185 public TS getDIAGNOSISDATETIME() { 186 TS retVal = this.getTypedField(5, 0); 187 return retVal; 188 } 189 190 /** 191 * Returns 192 * DG1-5: "DIAGNOSIS DATE/TIME" - creates it if necessary 193 */ 194 public TS getDg15_DIAGNOSISDATETIME() { 195 TS retVal = this.getTypedField(5, 0); 196 return retVal; 197 } 198 199 200 201 /** 202 * Returns 203 * DG1-6: "DIAGNOSIS/DRG TYPE" - creates it if necessary 204 */ 205 public ID getDIAGNOSISDRGTYPE() { 206 ID retVal = this.getTypedField(6, 0); 207 return retVal; 208 } 209 210 /** 211 * Returns 212 * DG1-6: "DIAGNOSIS/DRG TYPE" - creates it if necessary 213 */ 214 public ID getDg16_DIAGNOSISDRGTYPE() { 215 ID retVal = this.getTypedField(6, 0); 216 return retVal; 217 } 218 219 220 221 /** 222 * Returns 223 * DG1-7: "MAJOR DIAGNOSTIC CATEGORY" - creates it if necessary 224 */ 225 public ST getMAJORDIAGNOSTICCATEGORY() { 226 ST retVal = this.getTypedField(7, 0); 227 return retVal; 228 } 229 230 /** 231 * Returns 232 * DG1-7: "MAJOR DIAGNOSTIC CATEGORY" - creates it if necessary 233 */ 234 public ST getDg17_MAJORDIAGNOSTICCATEGORY() { 235 ST retVal = this.getTypedField(7, 0); 236 return retVal; 237 } 238 239 240 241 /** 242 * Returns 243 * DG1-8: "DIAGNOSTIC RELATED GROUP" - creates it if necessary 244 */ 245 public ID getDIAGNOSTICRELATEDGROUP() { 246 ID retVal = this.getTypedField(8, 0); 247 return retVal; 248 } 249 250 /** 251 * Returns 252 * DG1-8: "DIAGNOSTIC RELATED GROUP" - creates it if necessary 253 */ 254 public ID getDg18_DIAGNOSTICRELATEDGROUP() { 255 ID retVal = this.getTypedField(8, 0); 256 return retVal; 257 } 258 259 260 261 /** 262 * Returns 263 * DG1-9: "DRG APPROVAL INDICATOR" - creates it if necessary 264 */ 265 public ID getDRGAPPROVALINDICATOR() { 266 ID retVal = this.getTypedField(9, 0); 267 return retVal; 268 } 269 270 /** 271 * Returns 272 * DG1-9: "DRG APPROVAL INDICATOR" - creates it if necessary 273 */ 274 public ID getDg19_DRGAPPROVALINDICATOR() { 275 ID retVal = this.getTypedField(9, 0); 276 return retVal; 277 } 278 279 280 281 /** 282 * Returns 283 * DG1-10: "DRG GROUPER REVIEW CODE" - creates it if necessary 284 */ 285 public ID getDRGGROUPERREVIEWCODE() { 286 ID retVal = this.getTypedField(10, 0); 287 return retVal; 288 } 289 290 /** 291 * Returns 292 * DG1-10: "DRG GROUPER REVIEW CODE" - creates it if necessary 293 */ 294 public ID getDg110_DRGGROUPERREVIEWCODE() { 295 ID retVal = this.getTypedField(10, 0); 296 return retVal; 297 } 298 299 300 301 /** 302 * Returns 303 * DG1-11: "OUTLIER TYPE" - creates it if necessary 304 */ 305 public ID getOUTLIERTYPE() { 306 ID retVal = this.getTypedField(11, 0); 307 return retVal; 308 } 309 310 /** 311 * Returns 312 * DG1-11: "OUTLIER TYPE" - creates it if necessary 313 */ 314 public ID getDg111_OUTLIERTYPE() { 315 ID retVal = this.getTypedField(11, 0); 316 return retVal; 317 } 318 319 320 321 /** 322 * Returns 323 * DG1-12: "OUTLIER DAYS" - creates it if necessary 324 */ 325 public NM getOUTLIERDAYS() { 326 NM retVal = this.getTypedField(12, 0); 327 return retVal; 328 } 329 330 /** 331 * Returns 332 * DG1-12: "OUTLIER DAYS" - creates it if necessary 333 */ 334 public NM getDg112_OUTLIERDAYS() { 335 NM retVal = this.getTypedField(12, 0); 336 return retVal; 337 } 338 339 340 341 /** 342 * Returns 343 * DG1-13: "OUTLIER COST" - creates it if necessary 344 */ 345 public NM getOUTLIERCOST() { 346 NM retVal = this.getTypedField(13, 0); 347 return retVal; 348 } 349 350 /** 351 * Returns 352 * DG1-13: "OUTLIER COST" - creates it if necessary 353 */ 354 public NM getDg113_OUTLIERCOST() { 355 NM retVal = this.getTypedField(13, 0); 356 return retVal; 357 } 358 359 360 361 /** 362 * Returns 363 * DG1-14: "GROUPER VERSION AND TYPE" - creates it if necessary 364 */ 365 public ST getGROUPERVERSIONANDTYPE() { 366 ST retVal = this.getTypedField(14, 0); 367 return retVal; 368 } 369 370 /** 371 * Returns 372 * DG1-14: "GROUPER VERSION AND TYPE" - creates it if necessary 373 */ 374 public ST getDg114_GROUPERVERSIONANDTYPE() { 375 ST retVal = this.getTypedField(14, 0); 376 return retVal; 377 } 378 379 380 381 382 383 /** {@inheritDoc} */ 384 protected Type createNewTypeWithoutReflection(int field) { 385 switch (field) { 386 case 0: return new SI(getMessage()); 387 case 1: return new ID(getMessage(), new Integer( 53 )); 388 case 2: return new ID(getMessage(), new Integer( 51 )); 389 case 3: return new ST(getMessage()); 390 case 4: return new TS(getMessage()); 391 case 5: return new ID(getMessage(), new Integer( 52 )); 392 case 6: return new ST(getMessage()); 393 case 7: return new ID(getMessage(), new Integer( 55 )); 394 case 8: return new ID(getMessage(), new Integer( 0 )); 395 case 9: return new ID(getMessage(), new Integer( 56 )); 396 case 10: return new ID(getMessage(), new Integer( 83 )); 397 case 11: return new NM(getMessage()); 398 case 12: return new NM(getMessage()); 399 case 13: return new ST(getMessage()); 400 default: return null; 401 } 402 } 403 404 405} 406