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.v25.segment;
035
036// import ca.uhn.hl7v2.model.v25.group.*;
037import ca.uhn.hl7v2.model.v25.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 BHS message segment (Batch Header). 
049 * This segment has the following fields:</p>
050 * <ul>
051     * <li>BHS-1: Batch Field Separator (ST) <b> </b>
052     * <li>BHS-2: Batch Encoding Characters (ST) <b> </b>
053     * <li>BHS-3: Batch Sending Application (HD) <b>optional </b>
054     * <li>BHS-4: Batch Sending Facility (HD) <b>optional </b>
055     * <li>BHS-5: Batch Receiving Application (HD) <b>optional </b>
056     * <li>BHS-6: Batch Receiving Facility (HD) <b>optional </b>
057     * <li>BHS-7: Batch Creation Date/Time (TS) <b>optional </b>
058     * <li>BHS-8: Batch Security (ST) <b>optional </b>
059     * <li>BHS-9: Batch Name/ID/Type (ST) <b>optional </b>
060     * <li>BHS-10: Batch Comment (ST) <b>optional </b>
061     * <li>BHS-11: Batch Control ID (ST) <b>optional </b>
062     * <li>BHS-12: Reference Batch Control ID (ST) <b>optional </b>
063 * </ul>
064 */
065@SuppressWarnings("unused")
066public class BHS extends AbstractSegment {
067
068    /** 
069     * Creates a new BHS segment
070     */
071    public BHS(Group parent, ModelClassFactory factory) {
072       super(parent, factory);
073       init(factory);
074    }
075
076    private void init(ModelClassFactory factory) {
077       try {
078                                  this.add(ST.class, true, 1, 1, new Object[]{ getMessage() }, "Batch Field Separator");
079                                  this.add(ST.class, true, 1, 3, new Object[]{ getMessage() }, "Batch Encoding Characters");
080                                  this.add(HD.class, false, 1, 227, new Object[]{ getMessage() }, "Batch Sending Application");
081                                  this.add(HD.class, false, 1, 227, new Object[]{ getMessage() }, "Batch Sending Facility");
082                                  this.add(HD.class, false, 1, 227, new Object[]{ getMessage() }, "Batch Receiving Application");
083                                  this.add(HD.class, false, 1, 227, new Object[]{ getMessage() }, "Batch Receiving Facility");
084                                  this.add(TS.class, false, 1, 26, new Object[]{ getMessage() }, "Batch Creation Date/Time");
085                                  this.add(ST.class, false, 1, 40, new Object[]{ getMessage() }, "Batch Security");
086                                  this.add(ST.class, false, 1, 20, new Object[]{ getMessage() }, "Batch Name/ID/Type");
087                                  this.add(ST.class, false, 1, 80, new Object[]{ getMessage() }, "Batch Comment");
088                                  this.add(ST.class, false, 1, 20, new Object[]{ getMessage() }, "Batch Control ID");
089                                  this.add(ST.class, false, 1, 20, new Object[]{ getMessage() }, "Reference Batch Control ID");
090       } catch(HL7Exception e) {
091          log.error("Unexpected error creating BHS - this is probably a bug in the source code generator.", e);
092       }
093    }
094
095
096
097    /**
098     * Returns
099     * BHS-1: "Batch Field Separator" - creates it if necessary
100     */
101    public ST getBatchFieldSeparator() { 
102                ST retVal = this.getTypedField(1, 0);
103                return retVal;
104    }
105    
106    /**
107     * Returns
108     * BHS-1: "Batch Field Separator" - creates it if necessary
109     */
110    public ST getBhs1_BatchFieldSeparator() { 
111                ST retVal = this.getTypedField(1, 0);
112                return retVal;
113    }
114
115
116
117    /**
118     * Returns
119     * BHS-2: "Batch Encoding Characters" - creates it if necessary
120     */
121    public ST getBatchEncodingCharacters() { 
122                ST retVal = this.getTypedField(2, 0);
123                return retVal;
124    }
125    
126    /**
127     * Returns
128     * BHS-2: "Batch Encoding Characters" - creates it if necessary
129     */
130    public ST getBhs2_BatchEncodingCharacters() { 
131                ST retVal = this.getTypedField(2, 0);
132                return retVal;
133    }
134
135
136
137    /**
138     * Returns
139     * BHS-3: "Batch Sending Application" - creates it if necessary
140     */
141    public HD getBatchSendingApplication() { 
142                HD retVal = this.getTypedField(3, 0);
143                return retVal;
144    }
145    
146    /**
147     * Returns
148     * BHS-3: "Batch Sending Application" - creates it if necessary
149     */
150    public HD getBhs3_BatchSendingApplication() { 
151                HD retVal = this.getTypedField(3, 0);
152                return retVal;
153    }
154
155
156
157    /**
158     * Returns
159     * BHS-4: "Batch Sending Facility" - creates it if necessary
160     */
161    public HD getBatchSendingFacility() { 
162                HD retVal = this.getTypedField(4, 0);
163                return retVal;
164    }
165    
166    /**
167     * Returns
168     * BHS-4: "Batch Sending Facility" - creates it if necessary
169     */
170    public HD getBhs4_BatchSendingFacility() { 
171                HD retVal = this.getTypedField(4, 0);
172                return retVal;
173    }
174
175
176
177    /**
178     * Returns
179     * BHS-5: "Batch Receiving Application" - creates it if necessary
180     */
181    public HD getBatchReceivingApplication() { 
182                HD retVal = this.getTypedField(5, 0);
183                return retVal;
184    }
185    
186    /**
187     * Returns
188     * BHS-5: "Batch Receiving Application" - creates it if necessary
189     */
190    public HD getBhs5_BatchReceivingApplication() { 
191                HD retVal = this.getTypedField(5, 0);
192                return retVal;
193    }
194
195
196
197    /**
198     * Returns
199     * BHS-6: "Batch Receiving Facility" - creates it if necessary
200     */
201    public HD getBatchReceivingFacility() { 
202                HD retVal = this.getTypedField(6, 0);
203                return retVal;
204    }
205    
206    /**
207     * Returns
208     * BHS-6: "Batch Receiving Facility" - creates it if necessary
209     */
210    public HD getBhs6_BatchReceivingFacility() { 
211                HD retVal = this.getTypedField(6, 0);
212                return retVal;
213    }
214
215
216
217    /**
218     * Returns
219     * BHS-7: "Batch Creation Date/Time" - creates it if necessary
220     */
221    public TS getBatchCreationDateTime() { 
222                TS retVal = this.getTypedField(7, 0);
223                return retVal;
224    }
225    
226    /**
227     * Returns
228     * BHS-7: "Batch Creation Date/Time" - creates it if necessary
229     */
230    public TS getBhs7_BatchCreationDateTime() { 
231                TS retVal = this.getTypedField(7, 0);
232                return retVal;
233    }
234
235
236
237    /**
238     * Returns
239     * BHS-8: "Batch Security" - creates it if necessary
240     */
241    public ST getBatchSecurity() { 
242                ST retVal = this.getTypedField(8, 0);
243                return retVal;
244    }
245    
246    /**
247     * Returns
248     * BHS-8: "Batch Security" - creates it if necessary
249     */
250    public ST getBhs8_BatchSecurity() { 
251                ST retVal = this.getTypedField(8, 0);
252                return retVal;
253    }
254
255
256
257    /**
258     * Returns
259     * BHS-9: "Batch Name/ID/Type" - creates it if necessary
260     */
261    public ST getBatchNameIDType() { 
262                ST retVal = this.getTypedField(9, 0);
263                return retVal;
264    }
265    
266    /**
267     * Returns
268     * BHS-9: "Batch Name/ID/Type" - creates it if necessary
269     */
270    public ST getBhs9_BatchNameIDType() { 
271                ST retVal = this.getTypedField(9, 0);
272                return retVal;
273    }
274
275
276
277    /**
278     * Returns
279     * BHS-10: "Batch Comment" - creates it if necessary
280     */
281    public ST getBatchComment() { 
282                ST retVal = this.getTypedField(10, 0);
283                return retVal;
284    }
285    
286    /**
287     * Returns
288     * BHS-10: "Batch Comment" - creates it if necessary
289     */
290    public ST getBhs10_BatchComment() { 
291                ST retVal = this.getTypedField(10, 0);
292                return retVal;
293    }
294
295
296
297    /**
298     * Returns
299     * BHS-11: "Batch Control ID" - creates it if necessary
300     */
301    public ST getBatchControlID() { 
302                ST retVal = this.getTypedField(11, 0);
303                return retVal;
304    }
305    
306    /**
307     * Returns
308     * BHS-11: "Batch Control ID" - creates it if necessary
309     */
310    public ST getBhs11_BatchControlID() { 
311                ST retVal = this.getTypedField(11, 0);
312                return retVal;
313    }
314
315
316
317    /**
318     * Returns
319     * BHS-12: "Reference Batch Control ID" - creates it if necessary
320     */
321    public ST getReferenceBatchControlID() { 
322                ST retVal = this.getTypedField(12, 0);
323                return retVal;
324    }
325    
326    /**
327     * Returns
328     * BHS-12: "Reference Batch Control ID" - creates it if necessary
329     */
330    public ST getBhs12_ReferenceBatchControlID() { 
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 ST(getMessage());
343          case 1: return new ST(getMessage());
344          case 2: return new HD(getMessage());
345          case 3: return new HD(getMessage());
346          case 4: return new HD(getMessage());
347          case 5: return new HD(getMessage());
348          case 6: return new TS(getMessage());
349          case 7: return new ST(getMessage());
350          case 8: return new ST(getMessage());
351          case 9: return new ST(getMessage());
352          case 10: return new ST(getMessage());
353          case 11: return new ST(getMessage());
354          default: return null;
355       }
356   }
357
358
359}
360