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.v22.segment;
035
036// import ca.uhn.hl7v2.model.v22.group.*;
037import ca.uhn.hl7v2.model.v22.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 RXA message segment (PHARMACY AADMINISTRATION). 
049 * This segment has the following fields:</p>
050 * <ul>
051     * <li>RXA-1: Give Sub-ID Counter (NM) <b> </b>
052     * <li>RXA-2: Administration Sub-ID Counter (NM) <b> </b>
053     * <li>RXA-3: Date / time start of administration (TS) <b> </b>
054     * <li>RXA-4: Date / time end of administration (TS) <b> </b>
055     * <li>RXA-5: Administered Code (CE) <b> </b>
056     * <li>RXA-6: Administered Amount (NM) <b> </b>
057     * <li>RXA-7: Administered Units (CE) <b>optional </b>
058     * <li>RXA-8: Administered Dosage Form (CE) <b>optional </b>
059     * <li>RXA-9: Administration Notes (ST) <b>optional </b>
060     * <li>RXA-10: Administering Provider (CN) <b>optional </b>
061     * <li>RXA-11: Administered-at Location (CM_LA1) <b>optional </b>
062     * <li>RXA-12: Administered Per (Time Unit) (ST) <b>optional </b>
063 * </ul>
064 */
065@SuppressWarnings("unused")
066public class RXA extends AbstractSegment {
067
068    /** 
069     * Creates a new RXA segment
070     */
071    public RXA(Group parent, ModelClassFactory factory) {
072       super(parent, factory);
073       init(factory);
074    }
075
076    private void init(ModelClassFactory factory) {
077       try {
078                                  this.add(NM.class, true, 1, 4, new Object[]{ getMessage() }, "Give Sub-ID Counter");
079                                  this.add(NM.class, true, 1, 4, new Object[]{ getMessage() }, "Administration Sub-ID Counter");
080                                  this.add(TS.class, true, 1, 26, new Object[]{ getMessage() }, "Date / time start of administration");
081                                  this.add(TS.class, true, 1, 26, new Object[]{ getMessage() }, "Date / time end of administration");
082                                  this.add(CE.class, true, 1, 100, new Object[]{ getMessage() }, "Administered Code");
083                                  this.add(NM.class, true, 1, 20, new Object[]{ getMessage() }, "Administered Amount");
084                                  this.add(CE.class, false, 1, 60, new Object[]{ getMessage() }, "Administered Units");
085                                  this.add(CE.class, false, 1, 60, new Object[]{ getMessage() }, "Administered Dosage Form");
086                                  this.add(ST.class, false, 1, 200, new Object[]{ getMessage() }, "Administration Notes");
087                                  this.add(CN.class, false, 1, 200, new Object[]{ getMessage() }, "Administering Provider");
088                                  this.add(CM_LA1.class, false, 1, 12, new Object[]{ getMessage() }, "Administered-at Location");
089                                  this.add(ST.class, false, 1, 20, new Object[]{ getMessage() }, "Administered Per (Time Unit)");
090       } catch(HL7Exception e) {
091          log.error("Unexpected error creating RXA - this is probably a bug in the source code generator.", e);
092       }
093    }
094
095
096
097    /**
098     * Returns
099     * RXA-1: "Give Sub-ID Counter" - creates it if necessary
100     */
101    public NM getGiveSubIDCounter() { 
102                NM retVal = this.getTypedField(1, 0);
103                return retVal;
104    }
105    
106    /**
107     * Returns
108     * RXA-1: "Give Sub-ID Counter" - creates it if necessary
109     */
110    public NM getRxa1_GiveSubIDCounter() { 
111                NM retVal = this.getTypedField(1, 0);
112                return retVal;
113    }
114
115
116
117    /**
118     * Returns
119     * RXA-2: "Administration Sub-ID Counter" - creates it if necessary
120     */
121    public NM getAdministrationSubIDCounter() { 
122                NM retVal = this.getTypedField(2, 0);
123                return retVal;
124    }
125    
126    /**
127     * Returns
128     * RXA-2: "Administration Sub-ID Counter" - creates it if necessary
129     */
130    public NM getRxa2_AdministrationSubIDCounter() { 
131                NM retVal = this.getTypedField(2, 0);
132                return retVal;
133    }
134
135
136
137    /**
138     * Returns
139     * RXA-3: "Date / time start of administration" - creates it if necessary
140     */
141    public TS getDateTimeStartOfAdministration() { 
142                TS retVal = this.getTypedField(3, 0);
143                return retVal;
144    }
145    
146    /**
147     * Returns
148     * RXA-3: "Date / time start of administration" - creates it if necessary
149     */
150    public TS getRxa3_DateTimeStartOfAdministration() { 
151                TS retVal = this.getTypedField(3, 0);
152                return retVal;
153    }
154
155
156
157    /**
158     * Returns
159     * RXA-4: "Date / time end of administration" - creates it if necessary
160     */
161    public TS getDateTimeEndOfAdministration() { 
162                TS retVal = this.getTypedField(4, 0);
163                return retVal;
164    }
165    
166    /**
167     * Returns
168     * RXA-4: "Date / time end of administration" - creates it if necessary
169     */
170    public TS getRxa4_DateTimeEndOfAdministration() { 
171                TS retVal = this.getTypedField(4, 0);
172                return retVal;
173    }
174
175
176
177    /**
178     * Returns
179     * RXA-5: "Administered Code" - creates it if necessary
180     */
181    public CE getAdministeredCode() { 
182                CE retVal = this.getTypedField(5, 0);
183                return retVal;
184    }
185    
186    /**
187     * Returns
188     * RXA-5: "Administered Code" - creates it if necessary
189     */
190    public CE getRxa5_AdministeredCode() { 
191                CE retVal = this.getTypedField(5, 0);
192                return retVal;
193    }
194
195
196
197    /**
198     * Returns
199     * RXA-6: "Administered Amount" - creates it if necessary
200     */
201    public NM getAdministeredAmount() { 
202                NM retVal = this.getTypedField(6, 0);
203                return retVal;
204    }
205    
206    /**
207     * Returns
208     * RXA-6: "Administered Amount" - creates it if necessary
209     */
210    public NM getRxa6_AdministeredAmount() { 
211                NM retVal = this.getTypedField(6, 0);
212                return retVal;
213    }
214
215
216
217    /**
218     * Returns
219     * RXA-7: "Administered Units" - creates it if necessary
220     */
221    public CE getAdministeredUnits() { 
222                CE retVal = this.getTypedField(7, 0);
223                return retVal;
224    }
225    
226    /**
227     * Returns
228     * RXA-7: "Administered Units" - creates it if necessary
229     */
230    public CE getRxa7_AdministeredUnits() { 
231                CE retVal = this.getTypedField(7, 0);
232                return retVal;
233    }
234
235
236
237    /**
238     * Returns
239     * RXA-8: "Administered Dosage Form" - creates it if necessary
240     */
241    public CE getAdministeredDosageForm() { 
242                CE retVal = this.getTypedField(8, 0);
243                return retVal;
244    }
245    
246    /**
247     * Returns
248     * RXA-8: "Administered Dosage Form" - creates it if necessary
249     */
250    public CE getRxa8_AdministeredDosageForm() { 
251                CE retVal = this.getTypedField(8, 0);
252                return retVal;
253    }
254
255
256
257    /**
258     * Returns
259     * RXA-9: "Administration Notes" - creates it if necessary
260     */
261    public ST getAdministrationNotes() { 
262                ST retVal = this.getTypedField(9, 0);
263                return retVal;
264    }
265    
266    /**
267     * Returns
268     * RXA-9: "Administration Notes" - creates it if necessary
269     */
270    public ST getRxa9_AdministrationNotes() { 
271                ST retVal = this.getTypedField(9, 0);
272                return retVal;
273    }
274
275
276
277    /**
278     * Returns
279     * RXA-10: "Administering Provider" - creates it if necessary
280     */
281    public CN getAdministeringProvider() { 
282                CN retVal = this.getTypedField(10, 0);
283                return retVal;
284    }
285    
286    /**
287     * Returns
288     * RXA-10: "Administering Provider" - creates it if necessary
289     */
290    public CN getRxa10_AdministeringProvider() { 
291                CN retVal = this.getTypedField(10, 0);
292                return retVal;
293    }
294
295
296
297    /**
298     * Returns
299     * RXA-11: "Administered-at Location" - creates it if necessary
300     */
301    public CM_LA1 getAdministeredAtLocation() { 
302                CM_LA1 retVal = this.getTypedField(11, 0);
303                return retVal;
304    }
305    
306    /**
307     * Returns
308     * RXA-11: "Administered-at Location" - creates it if necessary
309     */
310    public CM_LA1 getRxa11_AdministeredAtLocation() { 
311                CM_LA1 retVal = this.getTypedField(11, 0);
312                return retVal;
313    }
314
315
316
317    /**
318     * Returns
319     * RXA-12: "Administered Per (Time Unit)" - creates it if necessary
320     */
321    public ST getAdministeredPerTimeUnit() { 
322                ST retVal = this.getTypedField(12, 0);
323                return retVal;
324    }
325    
326    /**
327     * Returns
328     * RXA-12: "Administered Per (Time Unit)" - creates it if necessary
329     */
330    public ST getRxa12_AdministeredPerTimeUnit() { 
331                ST retVal = this.getTypedField(12, 0);
332                return retVal;
333    }
334
335
336
337
338
339    /** {@inheritDoc} */   
340    protected Type createNewTypeWithoutReflection(int field) {
341       switch (field) {
342          case 0: return new NM(getMessage());
343          case 1: return new NM(getMessage());
344          case 2: return new TS(getMessage());
345          case 3: return new TS(getMessage());
346          case 4: return new CE(getMessage());
347          case 5: return new NM(getMessage());
348          case 6: return new CE(getMessage());
349          case 7: return new CE(getMessage());
350          case 8: return new ST(getMessage());
351          case 9: return new CN(getMessage());
352          case 10: return new CM_LA1(getMessage());
353          case 11: return new ST(getMessage());
354          default: return null;
355       }
356   }
357
358
359}
360