001package org.hl7.fhir.r4.model;
002
003import java.math.BigDecimal;
004
005/*
006  Copyright (c) 2011+, HL7, Inc.
007  All rights reserved.
008  
009  Redistribution and use in source and binary forms, with or without modification, 
010  are permitted provided that the following conditions are met:
011  
012   * Redistributions of source code must retain the above copyright notice, this 
013     list of conditions and the following disclaimer.
014   * Redistributions in binary form must reproduce the above copyright notice, 
015     this list of conditions and the following disclaimer in the documentation 
016     and/or other materials provided with the distribution.
017   * Neither the name of HL7 nor the names of its contributors may be used to 
018     endorse or promote products derived from this software without specific 
019     prior written permission.
020  
021  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
022  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
023  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
024  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
025  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
026  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
027  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
028  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
029  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
030  POSSIBILITY OF SUCH DAMAGE.
031  
032*/
033
034// Generated on Tue, May 12, 2020 07:26+1000 for FHIR v4.0.1
035import java.util.ArrayList;
036import java.util.Date;
037import java.util.List;
038
039import org.hl7.fhir.exceptions.FHIRException;
040import org.hl7.fhir.instance.model.api.IBaseBackboneElement;
041import org.hl7.fhir.r4.model.Enumerations.NoteType;
042import org.hl7.fhir.r4.model.Enumerations.NoteTypeEnumFactory;
043import org.hl7.fhir.utilities.Utilities;
044
045import ca.uhn.fhir.model.api.annotation.Block;
046import ca.uhn.fhir.model.api.annotation.Child;
047import ca.uhn.fhir.model.api.annotation.Description;
048import ca.uhn.fhir.model.api.annotation.ResourceDef;
049import ca.uhn.fhir.model.api.annotation.SearchParamDefinition;
050
051/**
052 * This resource provides: the claim details; adjudication details from the
053 * processing of a Claim; and optionally account balance information, for
054 * informing the subscriber of the benefits provided.
055 */
056@ResourceDef(name = "ExplanationOfBenefit", profile = "http://hl7.org/fhir/StructureDefinition/ExplanationOfBenefit")
057public class ExplanationOfBenefit extends DomainResource {
058
059  public enum ExplanationOfBenefitStatus {
060    /**
061     * The resource instance is currently in-force.
062     */
063    ACTIVE,
064    /**
065     * The resource instance is withdrawn, rescinded or reversed.
066     */
067    CANCELLED,
068    /**
069     * A new resource instance the contents of which is not complete.
070     */
071    DRAFT,
072    /**
073     * The resource instance was entered in error.
074     */
075    ENTEREDINERROR,
076    /**
077     * added to help the parsers with the generic types
078     */
079    NULL;
080
081    public static ExplanationOfBenefitStatus fromCode(String codeString) throws FHIRException {
082      if (codeString == null || "".equals(codeString))
083        return null;
084      if ("active".equals(codeString))
085        return ACTIVE;
086      if ("cancelled".equals(codeString))
087        return CANCELLED;
088      if ("draft".equals(codeString))
089        return DRAFT;
090      if ("entered-in-error".equals(codeString))
091        return ENTEREDINERROR;
092      if (Configuration.isAcceptInvalidEnums())
093        return null;
094      else
095        throw new FHIRException("Unknown ExplanationOfBenefitStatus code '" + codeString + "'");
096    }
097
098    public String toCode() {
099      switch (this) {
100      case ACTIVE:
101        return "active";
102      case CANCELLED:
103        return "cancelled";
104      case DRAFT:
105        return "draft";
106      case ENTEREDINERROR:
107        return "entered-in-error";
108      case NULL:
109        return null;
110      default:
111        return "?";
112      }
113    }
114
115    public String getSystem() {
116      switch (this) {
117      case ACTIVE:
118        return "http://hl7.org/fhir/explanationofbenefit-status";
119      case CANCELLED:
120        return "http://hl7.org/fhir/explanationofbenefit-status";
121      case DRAFT:
122        return "http://hl7.org/fhir/explanationofbenefit-status";
123      case ENTEREDINERROR:
124        return "http://hl7.org/fhir/explanationofbenefit-status";
125      case NULL:
126        return null;
127      default:
128        return "?";
129      }
130    }
131
132    public String getDefinition() {
133      switch (this) {
134      case ACTIVE:
135        return "The resource instance is currently in-force.";
136      case CANCELLED:
137        return "The resource instance is withdrawn, rescinded or reversed.";
138      case DRAFT:
139        return "A new resource instance the contents of which is not complete.";
140      case ENTEREDINERROR:
141        return "The resource instance was entered in error.";
142      case NULL:
143        return null;
144      default:
145        return "?";
146      }
147    }
148
149    public String getDisplay() {
150      switch (this) {
151      case ACTIVE:
152        return "Active";
153      case CANCELLED:
154        return "Cancelled";
155      case DRAFT:
156        return "Draft";
157      case ENTEREDINERROR:
158        return "Entered In Error";
159      case NULL:
160        return null;
161      default:
162        return "?";
163      }
164    }
165  }
166
167  public static class ExplanationOfBenefitStatusEnumFactory implements EnumFactory<ExplanationOfBenefitStatus> {
168    public ExplanationOfBenefitStatus fromCode(String codeString) throws IllegalArgumentException {
169      if (codeString == null || "".equals(codeString))
170        if (codeString == null || "".equals(codeString))
171          return null;
172      if ("active".equals(codeString))
173        return ExplanationOfBenefitStatus.ACTIVE;
174      if ("cancelled".equals(codeString))
175        return ExplanationOfBenefitStatus.CANCELLED;
176      if ("draft".equals(codeString))
177        return ExplanationOfBenefitStatus.DRAFT;
178      if ("entered-in-error".equals(codeString))
179        return ExplanationOfBenefitStatus.ENTEREDINERROR;
180      throw new IllegalArgumentException("Unknown ExplanationOfBenefitStatus code '" + codeString + "'");
181    }
182
183    public Enumeration<ExplanationOfBenefitStatus> fromType(PrimitiveType<?> code) throws FHIRException {
184      if (code == null)
185        return null;
186      if (code.isEmpty())
187        return new Enumeration<ExplanationOfBenefitStatus>(this, ExplanationOfBenefitStatus.NULL, code);
188      String codeString = code.asStringValue();
189      if (codeString == null || "".equals(codeString))
190        return new Enumeration<ExplanationOfBenefitStatus>(this, ExplanationOfBenefitStatus.NULL, code);
191      if ("active".equals(codeString))
192        return new Enumeration<ExplanationOfBenefitStatus>(this, ExplanationOfBenefitStatus.ACTIVE, code);
193      if ("cancelled".equals(codeString))
194        return new Enumeration<ExplanationOfBenefitStatus>(this, ExplanationOfBenefitStatus.CANCELLED, code);
195      if ("draft".equals(codeString))
196        return new Enumeration<ExplanationOfBenefitStatus>(this, ExplanationOfBenefitStatus.DRAFT, code);
197      if ("entered-in-error".equals(codeString))
198        return new Enumeration<ExplanationOfBenefitStatus>(this, ExplanationOfBenefitStatus.ENTEREDINERROR, code);
199      throw new FHIRException("Unknown ExplanationOfBenefitStatus code '" + codeString + "'");
200    }
201
202    public String toCode(ExplanationOfBenefitStatus code) {
203       if (code == ExplanationOfBenefitStatus.NULL)
204           return null;
205       if (code == ExplanationOfBenefitStatus.ACTIVE)
206        return "active";
207      if (code == ExplanationOfBenefitStatus.CANCELLED)
208        return "cancelled";
209      if (code == ExplanationOfBenefitStatus.DRAFT)
210        return "draft";
211      if (code == ExplanationOfBenefitStatus.ENTEREDINERROR)
212        return "entered-in-error";
213      return "?";
214   }
215
216    public String toSystem(ExplanationOfBenefitStatus code) {
217      return code.getSystem();
218    }
219  }
220
221  public enum Use {
222    /**
223     * The treatment is complete and this represents a Claim for the services.
224     */
225    CLAIM,
226    /**
227     * The treatment is proposed and this represents a Pre-authorization for the
228     * services.
229     */
230    PREAUTHORIZATION,
231    /**
232     * The treatment is proposed and this represents a Pre-determination for the
233     * services.
234     */
235    PREDETERMINATION,
236    /**
237     * added to help the parsers with the generic types
238     */
239    NULL;
240
241    public static Use fromCode(String codeString) throws FHIRException {
242      if (codeString == null || "".equals(codeString))
243        return null;
244      if ("claim".equals(codeString))
245        return CLAIM;
246      if ("preauthorization".equals(codeString))
247        return PREAUTHORIZATION;
248      if ("predetermination".equals(codeString))
249        return PREDETERMINATION;
250      if (Configuration.isAcceptInvalidEnums())
251        return null;
252      else
253        throw new FHIRException("Unknown Use code '" + codeString + "'");
254    }
255
256    public String toCode() {
257      switch (this) {
258      case CLAIM:
259        return "claim";
260      case PREAUTHORIZATION:
261        return "preauthorization";
262      case PREDETERMINATION:
263        return "predetermination";
264      case NULL:
265        return null;
266      default:
267        return "?";
268      }
269    }
270
271    public String getSystem() {
272      switch (this) {
273      case CLAIM:
274        return "http://hl7.org/fhir/claim-use";
275      case PREAUTHORIZATION:
276        return "http://hl7.org/fhir/claim-use";
277      case PREDETERMINATION:
278        return "http://hl7.org/fhir/claim-use";
279      case NULL:
280        return null;
281      default:
282        return "?";
283      }
284    }
285
286    public String getDefinition() {
287      switch (this) {
288      case CLAIM:
289        return "The treatment is complete and this represents a Claim for the services.";
290      case PREAUTHORIZATION:
291        return "The treatment is proposed and this represents a Pre-authorization for the services.";
292      case PREDETERMINATION:
293        return "The treatment is proposed and this represents a Pre-determination for the services.";
294      case NULL:
295        return null;
296      default:
297        return "?";
298      }
299    }
300
301    public String getDisplay() {
302      switch (this) {
303      case CLAIM:
304        return "Claim";
305      case PREAUTHORIZATION:
306        return "Preauthorization";
307      case PREDETERMINATION:
308        return "Predetermination";
309      case NULL:
310        return null;
311      default:
312        return "?";
313      }
314    }
315  }
316
317  public static class UseEnumFactory implements EnumFactory<Use> {
318    public Use fromCode(String codeString) throws IllegalArgumentException {
319      if (codeString == null || "".equals(codeString))
320        if (codeString == null || "".equals(codeString))
321          return null;
322      if ("claim".equals(codeString))
323        return Use.CLAIM;
324      if ("preauthorization".equals(codeString))
325        return Use.PREAUTHORIZATION;
326      if ("predetermination".equals(codeString))
327        return Use.PREDETERMINATION;
328      throw new IllegalArgumentException("Unknown Use code '" + codeString + "'");
329    }
330
331    public Enumeration<Use> fromType(PrimitiveType<?> code) throws FHIRException {
332      if (code == null)
333        return null;
334      if (code.isEmpty())
335        return new Enumeration<Use>(this, Use.NULL, code);
336      String codeString = code.asStringValue();
337      if (codeString == null || "".equals(codeString))
338        return new Enumeration<Use>(this, Use.NULL, code);
339      if ("claim".equals(codeString))
340        return new Enumeration<Use>(this, Use.CLAIM, code);
341      if ("preauthorization".equals(codeString))
342        return new Enumeration<Use>(this, Use.PREAUTHORIZATION, code);
343      if ("predetermination".equals(codeString))
344        return new Enumeration<Use>(this, Use.PREDETERMINATION, code);
345      throw new FHIRException("Unknown Use code '" + codeString + "'");
346    }
347
348    public String toCode(Use code) {
349       if (code == Use.NULL)
350           return null;
351       if (code == Use.CLAIM)
352        return "claim";
353      if (code == Use.PREAUTHORIZATION)
354        return "preauthorization";
355      if (code == Use.PREDETERMINATION)
356        return "predetermination";
357      return "?";
358   }
359
360    public String toSystem(Use code) {
361      return code.getSystem();
362    }
363  }
364
365  public enum RemittanceOutcome {
366    /**
367     * The Claim/Pre-authorization/Pre-determination has been received but
368     * processing has not begun.
369     */
370    QUEUED,
371    /**
372     * The processing has completed without errors
373     */
374    COMPLETE,
375    /**
376     * One or more errors have been detected in the Claim
377     */
378    ERROR,
379    /**
380     * No errors have been detected in the Claim and some of the adjudication has
381     * been performed.
382     */
383    PARTIAL,
384    /**
385     * added to help the parsers with the generic types
386     */
387    NULL;
388
389    public static RemittanceOutcome fromCode(String codeString) throws FHIRException {
390      if (codeString == null || "".equals(codeString))
391        return null;
392      if ("queued".equals(codeString))
393        return QUEUED;
394      if ("complete".equals(codeString))
395        return COMPLETE;
396      if ("error".equals(codeString))
397        return ERROR;
398      if ("partial".equals(codeString))
399        return PARTIAL;
400      if (Configuration.isAcceptInvalidEnums())
401        return null;
402      else
403        throw new FHIRException("Unknown RemittanceOutcome code '" + codeString + "'");
404    }
405
406    public String toCode() {
407      switch (this) {
408      case QUEUED:
409        return "queued";
410      case COMPLETE:
411        return "complete";
412      case ERROR:
413        return "error";
414      case PARTIAL:
415        return "partial";
416      case NULL:
417        return null;
418      default:
419        return "?";
420      }
421    }
422
423    public String getSystem() {
424      switch (this) {
425      case QUEUED:
426        return "http://hl7.org/fhir/remittance-outcome";
427      case COMPLETE:
428        return "http://hl7.org/fhir/remittance-outcome";
429      case ERROR:
430        return "http://hl7.org/fhir/remittance-outcome";
431      case PARTIAL:
432        return "http://hl7.org/fhir/remittance-outcome";
433      case NULL:
434        return null;
435      default:
436        return "?";
437      }
438    }
439
440    public String getDefinition() {
441      switch (this) {
442      case QUEUED:
443        return "The Claim/Pre-authorization/Pre-determination has been received but processing has not begun.";
444      case COMPLETE:
445        return "The processing has completed without errors";
446      case ERROR:
447        return "One or more errors have been detected in the Claim";
448      case PARTIAL:
449        return "No errors have been detected in the Claim and some of the adjudication has been performed.";
450      case NULL:
451        return null;
452      default:
453        return "?";
454      }
455    }
456
457    public String getDisplay() {
458      switch (this) {
459      case QUEUED:
460        return "Queued";
461      case COMPLETE:
462        return "Processing Complete";
463      case ERROR:
464        return "Error";
465      case PARTIAL:
466        return "Partial Processing";
467      case NULL:
468        return null;
469      default:
470        return "?";
471      }
472    }
473  }
474
475  public static class RemittanceOutcomeEnumFactory implements EnumFactory<RemittanceOutcome> {
476    public RemittanceOutcome fromCode(String codeString) throws IllegalArgumentException {
477      if (codeString == null || "".equals(codeString))
478        if (codeString == null || "".equals(codeString))
479          return null;
480      if ("queued".equals(codeString))
481        return RemittanceOutcome.QUEUED;
482      if ("complete".equals(codeString))
483        return RemittanceOutcome.COMPLETE;
484      if ("error".equals(codeString))
485        return RemittanceOutcome.ERROR;
486      if ("partial".equals(codeString))
487        return RemittanceOutcome.PARTIAL;
488      throw new IllegalArgumentException("Unknown RemittanceOutcome code '" + codeString + "'");
489    }
490
491    public Enumeration<RemittanceOutcome> fromType(PrimitiveType<?> code) throws FHIRException {
492      if (code == null)
493        return null;
494      if (code.isEmpty())
495        return new Enumeration<RemittanceOutcome>(this, RemittanceOutcome.NULL, code);
496      String codeString = code.asStringValue();
497      if (codeString == null || "".equals(codeString))
498        return new Enumeration<RemittanceOutcome>(this, RemittanceOutcome.NULL, code);
499      if ("queued".equals(codeString))
500        return new Enumeration<RemittanceOutcome>(this, RemittanceOutcome.QUEUED, code);
501      if ("complete".equals(codeString))
502        return new Enumeration<RemittanceOutcome>(this, RemittanceOutcome.COMPLETE, code);
503      if ("error".equals(codeString))
504        return new Enumeration<RemittanceOutcome>(this, RemittanceOutcome.ERROR, code);
505      if ("partial".equals(codeString))
506        return new Enumeration<RemittanceOutcome>(this, RemittanceOutcome.PARTIAL, code);
507      throw new FHIRException("Unknown RemittanceOutcome code '" + codeString + "'");
508    }
509
510    public String toCode(RemittanceOutcome code) {
511       if (code == RemittanceOutcome.NULL)
512           return null;
513       if (code == RemittanceOutcome.QUEUED)
514        return "queued";
515      if (code == RemittanceOutcome.COMPLETE)
516        return "complete";
517      if (code == RemittanceOutcome.ERROR)
518        return "error";
519      if (code == RemittanceOutcome.PARTIAL)
520        return "partial";
521      return "?";
522   }
523
524    public String toSystem(RemittanceOutcome code) {
525      return code.getSystem();
526    }
527  }
528
529  @Block()
530  public static class RelatedClaimComponent extends BackboneElement implements IBaseBackboneElement {
531    /**
532     * Reference to a related claim.
533     */
534    @Child(name = "claim", type = { Claim.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
535    @Description(shortDefinition = "Reference to the related claim", formalDefinition = "Reference to a related claim.")
536    protected Reference claim;
537
538    /**
539     * The actual object that is the target of the reference (Reference to a related
540     * claim.)
541     */
542    protected Claim claimTarget;
543
544    /**
545     * A code to convey how the claims are related.
546     */
547    @Child(name = "relationship", type = {
548        CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
549    @Description(shortDefinition = "How the reference claim is related", formalDefinition = "A code to convey how the claims are related.")
550    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/related-claim-relationship")
551    protected CodeableConcept relationship;
552
553    /**
554     * An alternate organizational reference to the case or file to which this
555     * particular claim pertains.
556     */
557    @Child(name = "reference", type = {
558        Identifier.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
559    @Description(shortDefinition = "File or case reference", formalDefinition = "An alternate organizational reference to the case or file to which this particular claim pertains.")
560    protected Identifier reference;
561
562    private static final long serialVersionUID = -379338905L;
563
564    /**
565     * Constructor
566     */
567    public RelatedClaimComponent() {
568      super();
569    }
570
571    /**
572     * @return {@link #claim} (Reference to a related claim.)
573     */
574    public Reference getClaim() {
575      if (this.claim == null)
576        if (Configuration.errorOnAutoCreate())
577          throw new Error("Attempt to auto-create RelatedClaimComponent.claim");
578        else if (Configuration.doAutoCreate())
579          this.claim = new Reference(); // cc
580      return this.claim;
581    }
582
583    public boolean hasClaim() {
584      return this.claim != null && !this.claim.isEmpty();
585    }
586
587    /**
588     * @param value {@link #claim} (Reference to a related claim.)
589     */
590    public RelatedClaimComponent setClaim(Reference value) {
591      this.claim = value;
592      return this;
593    }
594
595    /**
596     * @return {@link #claim} The actual object that is the target of the reference.
597     *         The reference library doesn't populate this, but you can use it to
598     *         hold the resource if you resolve it. (Reference to a related claim.)
599     */
600    public Claim getClaimTarget() {
601      if (this.claimTarget == null)
602        if (Configuration.errorOnAutoCreate())
603          throw new Error("Attempt to auto-create RelatedClaimComponent.claim");
604        else if (Configuration.doAutoCreate())
605          this.claimTarget = new Claim(); // aa
606      return this.claimTarget;
607    }
608
609    /**
610     * @param value {@link #claim} The actual object that is the target of the
611     *              reference. The reference library doesn't use these, but you can
612     *              use it to hold the resource if you resolve it. (Reference to a
613     *              related claim.)
614     */
615    public RelatedClaimComponent setClaimTarget(Claim value) {
616      this.claimTarget = value;
617      return this;
618    }
619
620    /**
621     * @return {@link #relationship} (A code to convey how the claims are related.)
622     */
623    public CodeableConcept getRelationship() {
624      if (this.relationship == null)
625        if (Configuration.errorOnAutoCreate())
626          throw new Error("Attempt to auto-create RelatedClaimComponent.relationship");
627        else if (Configuration.doAutoCreate())
628          this.relationship = new CodeableConcept(); // cc
629      return this.relationship;
630    }
631
632    public boolean hasRelationship() {
633      return this.relationship != null && !this.relationship.isEmpty();
634    }
635
636    /**
637     * @param value {@link #relationship} (A code to convey how the claims are
638     *              related.)
639     */
640    public RelatedClaimComponent setRelationship(CodeableConcept value) {
641      this.relationship = value;
642      return this;
643    }
644
645    /**
646     * @return {@link #reference} (An alternate organizational reference to the case
647     *         or file to which this particular claim pertains.)
648     */
649    public Identifier getReference() {
650      if (this.reference == null)
651        if (Configuration.errorOnAutoCreate())
652          throw new Error("Attempt to auto-create RelatedClaimComponent.reference");
653        else if (Configuration.doAutoCreate())
654          this.reference = new Identifier(); // cc
655      return this.reference;
656    }
657
658    public boolean hasReference() {
659      return this.reference != null && !this.reference.isEmpty();
660    }
661
662    /**
663     * @param value {@link #reference} (An alternate organizational reference to the
664     *              case or file to which this particular claim pertains.)
665     */
666    public RelatedClaimComponent setReference(Identifier value) {
667      this.reference = value;
668      return this;
669    }
670
671    protected void listChildren(List<Property> children) {
672      super.listChildren(children);
673      children.add(new Property("claim", "Reference(Claim)", "Reference to a related claim.", 0, 1, claim));
674      children.add(new Property("relationship", "CodeableConcept", "A code to convey how the claims are related.", 0, 1,
675          relationship));
676      children.add(new Property("reference", "Identifier",
677          "An alternate organizational reference to the case or file to which this particular claim pertains.", 0, 1,
678          reference));
679    }
680
681    @Override
682    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
683      switch (_hash) {
684      case 94742588:
685        /* claim */ return new Property("claim", "Reference(Claim)", "Reference to a related claim.", 0, 1, claim);
686      case -261851592:
687        /* relationship */ return new Property("relationship", "CodeableConcept",
688            "A code to convey how the claims are related.", 0, 1, relationship);
689      case -925155509:
690        /* reference */ return new Property("reference", "Identifier",
691            "An alternate organizational reference to the case or file to which this particular claim pertains.", 0, 1,
692            reference);
693      default:
694        return super.getNamedProperty(_hash, _name, _checkValid);
695      }
696
697    }
698
699    @Override
700    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
701      switch (hash) {
702      case 94742588:
703        /* claim */ return this.claim == null ? new Base[0] : new Base[] { this.claim }; // Reference
704      case -261851592:
705        /* relationship */ return this.relationship == null ? new Base[0] : new Base[] { this.relationship }; // CodeableConcept
706      case -925155509:
707        /* reference */ return this.reference == null ? new Base[0] : new Base[] { this.reference }; // Identifier
708      default:
709        return super.getProperty(hash, name, checkValid);
710      }
711
712    }
713
714    @Override
715    public Base setProperty(int hash, String name, Base value) throws FHIRException {
716      switch (hash) {
717      case 94742588: // claim
718        this.claim = castToReference(value); // Reference
719        return value;
720      case -261851592: // relationship
721        this.relationship = castToCodeableConcept(value); // CodeableConcept
722        return value;
723      case -925155509: // reference
724        this.reference = castToIdentifier(value); // Identifier
725        return value;
726      default:
727        return super.setProperty(hash, name, value);
728      }
729
730    }
731
732    @Override
733    public Base setProperty(String name, Base value) throws FHIRException {
734      if (name.equals("claim")) {
735        this.claim = castToReference(value); // Reference
736      } else if (name.equals("relationship")) {
737        this.relationship = castToCodeableConcept(value); // CodeableConcept
738      } else if (name.equals("reference")) {
739        this.reference = castToIdentifier(value); // Identifier
740      } else
741        return super.setProperty(name, value);
742      return value;
743    }
744
745  @Override
746  public void removeChild(String name, Base value) throws FHIRException {
747      if (name.equals("claim")) {
748        this.claim = null;
749      } else if (name.equals("relationship")) {
750        this.relationship = null;
751      } else if (name.equals("reference")) {
752        this.reference = null;
753      } else
754        super.removeChild(name, value);
755      
756    }
757
758    @Override
759    public Base makeProperty(int hash, String name) throws FHIRException {
760      switch (hash) {
761      case 94742588:
762        return getClaim();
763      case -261851592:
764        return getRelationship();
765      case -925155509:
766        return getReference();
767      default:
768        return super.makeProperty(hash, name);
769      }
770
771    }
772
773    @Override
774    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
775      switch (hash) {
776      case 94742588:
777        /* claim */ return new String[] { "Reference" };
778      case -261851592:
779        /* relationship */ return new String[] { "CodeableConcept" };
780      case -925155509:
781        /* reference */ return new String[] { "Identifier" };
782      default:
783        return super.getTypesForProperty(hash, name);
784      }
785
786    }
787
788    @Override
789    public Base addChild(String name) throws FHIRException {
790      if (name.equals("claim")) {
791        this.claim = new Reference();
792        return this.claim;
793      } else if (name.equals("relationship")) {
794        this.relationship = new CodeableConcept();
795        return this.relationship;
796      } else if (name.equals("reference")) {
797        this.reference = new Identifier();
798        return this.reference;
799      } else
800        return super.addChild(name);
801    }
802
803    public RelatedClaimComponent copy() {
804      RelatedClaimComponent dst = new RelatedClaimComponent();
805      copyValues(dst);
806      return dst;
807    }
808
809    public void copyValues(RelatedClaimComponent dst) {
810      super.copyValues(dst);
811      dst.claim = claim == null ? null : claim.copy();
812      dst.relationship = relationship == null ? null : relationship.copy();
813      dst.reference = reference == null ? null : reference.copy();
814    }
815
816    @Override
817    public boolean equalsDeep(Base other_) {
818      if (!super.equalsDeep(other_))
819        return false;
820      if (!(other_ instanceof RelatedClaimComponent))
821        return false;
822      RelatedClaimComponent o = (RelatedClaimComponent) other_;
823      return compareDeep(claim, o.claim, true) && compareDeep(relationship, o.relationship, true)
824          && compareDeep(reference, o.reference, true);
825    }
826
827    @Override
828    public boolean equalsShallow(Base other_) {
829      if (!super.equalsShallow(other_))
830        return false;
831      if (!(other_ instanceof RelatedClaimComponent))
832        return false;
833      RelatedClaimComponent o = (RelatedClaimComponent) other_;
834      return true;
835    }
836
837    public boolean isEmpty() {
838      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(claim, relationship, reference);
839    }
840
841    public String fhirType() {
842      return "ExplanationOfBenefit.related";
843
844    }
845
846  }
847
848  @Block()
849  public static class PayeeComponent extends BackboneElement implements IBaseBackboneElement {
850    /**
851     * Type of Party to be reimbursed: Subscriber, provider, other.
852     */
853    @Child(name = "type", type = {
854        CodeableConcept.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
855    @Description(shortDefinition = "Category of recipient", formalDefinition = "Type of Party to be reimbursed: Subscriber, provider, other.")
856    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/payeetype")
857    protected CodeableConcept type;
858
859    /**
860     * Reference to the individual or organization to whom any payment will be made.
861     */
862    @Child(name = "party", type = { Practitioner.class, PractitionerRole.class, Organization.class, Patient.class,
863        RelatedPerson.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
864    @Description(shortDefinition = "Recipient reference", formalDefinition = "Reference to the individual or organization to whom any payment will be made.")
865    protected Reference party;
866
867    /**
868     * The actual object that is the target of the reference (Reference to the
869     * individual or organization to whom any payment will be made.)
870     */
871    protected Resource partyTarget;
872
873    private static final long serialVersionUID = 1609484699L;
874
875    /**
876     * Constructor
877     */
878    public PayeeComponent() {
879      super();
880    }
881
882    /**
883     * @return {@link #type} (Type of Party to be reimbursed: Subscriber, provider,
884     *         other.)
885     */
886    public CodeableConcept getType() {
887      if (this.type == null)
888        if (Configuration.errorOnAutoCreate())
889          throw new Error("Attempt to auto-create PayeeComponent.type");
890        else if (Configuration.doAutoCreate())
891          this.type = new CodeableConcept(); // cc
892      return this.type;
893    }
894
895    public boolean hasType() {
896      return this.type != null && !this.type.isEmpty();
897    }
898
899    /**
900     * @param value {@link #type} (Type of Party to be reimbursed: Subscriber,
901     *              provider, other.)
902     */
903    public PayeeComponent setType(CodeableConcept value) {
904      this.type = value;
905      return this;
906    }
907
908    /**
909     * @return {@link #party} (Reference to the individual or organization to whom
910     *         any payment will be made.)
911     */
912    public Reference getParty() {
913      if (this.party == null)
914        if (Configuration.errorOnAutoCreate())
915          throw new Error("Attempt to auto-create PayeeComponent.party");
916        else if (Configuration.doAutoCreate())
917          this.party = new Reference(); // cc
918      return this.party;
919    }
920
921    public boolean hasParty() {
922      return this.party != null && !this.party.isEmpty();
923    }
924
925    /**
926     * @param value {@link #party} (Reference to the individual or organization to
927     *              whom any payment will be made.)
928     */
929    public PayeeComponent setParty(Reference value) {
930      this.party = value;
931      return this;
932    }
933
934    /**
935     * @return {@link #party} The actual object that is the target of the reference.
936     *         The reference library doesn't populate this, but you can use it to
937     *         hold the resource if you resolve it. (Reference to the individual or
938     *         organization to whom any payment will be made.)
939     */
940    public Resource getPartyTarget() {
941      return this.partyTarget;
942    }
943
944    /**
945     * @param value {@link #party} The actual object that is the target of the
946     *              reference. The reference library doesn't use these, but you can
947     *              use it to hold the resource if you resolve it. (Reference to the
948     *              individual or organization to whom any payment will be made.)
949     */
950    public PayeeComponent setPartyTarget(Resource value) {
951      this.partyTarget = value;
952      return this;
953    }
954
955    protected void listChildren(List<Property> children) {
956      super.listChildren(children);
957      children.add(new Property("type", "CodeableConcept",
958          "Type of Party to be reimbursed: Subscriber, provider, other.", 0, 1, type));
959      children.add(new Property("party", "Reference(Practitioner|PractitionerRole|Organization|Patient|RelatedPerson)",
960          "Reference to the individual or organization to whom any payment will be made.", 0, 1, party));
961    }
962
963    @Override
964    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
965      switch (_hash) {
966      case 3575610:
967        /* type */ return new Property("type", "CodeableConcept",
968            "Type of Party to be reimbursed: Subscriber, provider, other.", 0, 1, type);
969      case 106437350:
970        /* party */ return new Property("party",
971            "Reference(Practitioner|PractitionerRole|Organization|Patient|RelatedPerson)",
972            "Reference to the individual or organization to whom any payment will be made.", 0, 1, party);
973      default:
974        return super.getNamedProperty(_hash, _name, _checkValid);
975      }
976
977    }
978
979    @Override
980    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
981      switch (hash) {
982      case 3575610:
983        /* type */ return this.type == null ? new Base[0] : new Base[] { this.type }; // CodeableConcept
984      case 106437350:
985        /* party */ return this.party == null ? new Base[0] : new Base[] { this.party }; // Reference
986      default:
987        return super.getProperty(hash, name, checkValid);
988      }
989
990    }
991
992    @Override
993    public Base setProperty(int hash, String name, Base value) throws FHIRException {
994      switch (hash) {
995      case 3575610: // type
996        this.type = castToCodeableConcept(value); // CodeableConcept
997        return value;
998      case 106437350: // party
999        this.party = castToReference(value); // Reference
1000        return value;
1001      default:
1002        return super.setProperty(hash, name, value);
1003      }
1004
1005    }
1006
1007    @Override
1008    public Base setProperty(String name, Base value) throws FHIRException {
1009      if (name.equals("type")) {
1010        this.type = castToCodeableConcept(value); // CodeableConcept
1011      } else if (name.equals("party")) {
1012        this.party = castToReference(value); // Reference
1013      } else
1014        return super.setProperty(name, value);
1015      return value;
1016    }
1017
1018  @Override
1019  public void removeChild(String name, Base value) throws FHIRException {
1020      if (name.equals("type")) {
1021        this.type = null;
1022      } else if (name.equals("party")) {
1023        this.party = null;
1024      } else
1025        super.removeChild(name, value);
1026      
1027    }
1028
1029    @Override
1030    public Base makeProperty(int hash, String name) throws FHIRException {
1031      switch (hash) {
1032      case 3575610:
1033        return getType();
1034      case 106437350:
1035        return getParty();
1036      default:
1037        return super.makeProperty(hash, name);
1038      }
1039
1040    }
1041
1042    @Override
1043    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
1044      switch (hash) {
1045      case 3575610:
1046        /* type */ return new String[] { "CodeableConcept" };
1047      case 106437350:
1048        /* party */ return new String[] { "Reference" };
1049      default:
1050        return super.getTypesForProperty(hash, name);
1051      }
1052
1053    }
1054
1055    @Override
1056    public Base addChild(String name) throws FHIRException {
1057      if (name.equals("type")) {
1058        this.type = new CodeableConcept();
1059        return this.type;
1060      } else if (name.equals("party")) {
1061        this.party = new Reference();
1062        return this.party;
1063      } else
1064        return super.addChild(name);
1065    }
1066
1067    public PayeeComponent copy() {
1068      PayeeComponent dst = new PayeeComponent();
1069      copyValues(dst);
1070      return dst;
1071    }
1072
1073    public void copyValues(PayeeComponent dst) {
1074      super.copyValues(dst);
1075      dst.type = type == null ? null : type.copy();
1076      dst.party = party == null ? null : party.copy();
1077    }
1078
1079    @Override
1080    public boolean equalsDeep(Base other_) {
1081      if (!super.equalsDeep(other_))
1082        return false;
1083      if (!(other_ instanceof PayeeComponent))
1084        return false;
1085      PayeeComponent o = (PayeeComponent) other_;
1086      return compareDeep(type, o.type, true) && compareDeep(party, o.party, true);
1087    }
1088
1089    @Override
1090    public boolean equalsShallow(Base other_) {
1091      if (!super.equalsShallow(other_))
1092        return false;
1093      if (!(other_ instanceof PayeeComponent))
1094        return false;
1095      PayeeComponent o = (PayeeComponent) other_;
1096      return true;
1097    }
1098
1099    public boolean isEmpty() {
1100      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(type, party);
1101    }
1102
1103    public String fhirType() {
1104      return "ExplanationOfBenefit.payee";
1105
1106    }
1107
1108  }
1109
1110  @Block()
1111  public static class CareTeamComponent extends BackboneElement implements IBaseBackboneElement {
1112    /**
1113     * A number to uniquely identify care team entries.
1114     */
1115    @Child(name = "sequence", type = {
1116        PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
1117    @Description(shortDefinition = "Order of care team", formalDefinition = "A number to uniquely identify care team entries.")
1118    protected PositiveIntType sequence;
1119
1120    /**
1121     * Member of the team who provided the product or service.
1122     */
1123    @Child(name = "provider", type = { Practitioner.class, PractitionerRole.class,
1124        Organization.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
1125    @Description(shortDefinition = "Practitioner or organization", formalDefinition = "Member of the team who provided the product or service.")
1126    protected Reference provider;
1127
1128    /**
1129     * The actual object that is the target of the reference (Member of the team who
1130     * provided the product or service.)
1131     */
1132    protected Resource providerTarget;
1133
1134    /**
1135     * The party who is billing and/or responsible for the claimed products or
1136     * services.
1137     */
1138    @Child(name = "responsible", type = {
1139        BooleanType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
1140    @Description(shortDefinition = "Indicator of the lead practitioner", formalDefinition = "The party who is billing and/or responsible for the claimed products or services.")
1141    protected BooleanType responsible;
1142
1143    /**
1144     * The lead, assisting or supervising practitioner and their discipline if a
1145     * multidisciplinary team.
1146     */
1147    @Child(name = "role", type = {
1148        CodeableConcept.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
1149    @Description(shortDefinition = "Function within the team", formalDefinition = "The lead, assisting or supervising practitioner and their discipline if a multidisciplinary team.")
1150    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-careteamrole")
1151    protected CodeableConcept role;
1152
1153    /**
1154     * The qualification of the practitioner which is applicable for this service.
1155     */
1156    @Child(name = "qualification", type = {
1157        CodeableConcept.class }, order = 5, min = 0, max = 1, modifier = false, summary = false)
1158    @Description(shortDefinition = "Practitioner credential or specialization", formalDefinition = "The qualification of the practitioner which is applicable for this service.")
1159    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/provider-qualification")
1160    protected CodeableConcept qualification;
1161
1162    private static final long serialVersionUID = 1758966968L;
1163
1164    /**
1165     * Constructor
1166     */
1167    public CareTeamComponent() {
1168      super();
1169    }
1170
1171    /**
1172     * Constructor
1173     */
1174    public CareTeamComponent(PositiveIntType sequence, Reference provider) {
1175      super();
1176      this.sequence = sequence;
1177      this.provider = provider;
1178    }
1179
1180    /**
1181     * @return {@link #sequence} (A number to uniquely identify care team entries.).
1182     *         This is the underlying object with id, value and extensions. The
1183     *         accessor "getSequence" gives direct access to the value
1184     */
1185    public PositiveIntType getSequenceElement() {
1186      if (this.sequence == null)
1187        if (Configuration.errorOnAutoCreate())
1188          throw new Error("Attempt to auto-create CareTeamComponent.sequence");
1189        else if (Configuration.doAutoCreate())
1190          this.sequence = new PositiveIntType(); // bb
1191      return this.sequence;
1192    }
1193
1194    public boolean hasSequenceElement() {
1195      return this.sequence != null && !this.sequence.isEmpty();
1196    }
1197
1198    public boolean hasSequence() {
1199      return this.sequence != null && !this.sequence.isEmpty();
1200    }
1201
1202    /**
1203     * @param value {@link #sequence} (A number to uniquely identify care team
1204     *              entries.). This is the underlying object with id, value and
1205     *              extensions. The accessor "getSequence" gives direct access to
1206     *              the value
1207     */
1208    public CareTeamComponent setSequenceElement(PositiveIntType value) {
1209      this.sequence = value;
1210      return this;
1211    }
1212
1213    /**
1214     * @return A number to uniquely identify care team entries.
1215     */
1216    public int getSequence() {
1217      return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
1218    }
1219
1220    /**
1221     * @param value A number to uniquely identify care team entries.
1222     */
1223    public CareTeamComponent setSequence(int value) {
1224      if (this.sequence == null)
1225        this.sequence = new PositiveIntType();
1226      this.sequence.setValue(value);
1227      return this;
1228    }
1229
1230    /**
1231     * @return {@link #provider} (Member of the team who provided the product or
1232     *         service.)
1233     */
1234    public Reference getProvider() {
1235      if (this.provider == null)
1236        if (Configuration.errorOnAutoCreate())
1237          throw new Error("Attempt to auto-create CareTeamComponent.provider");
1238        else if (Configuration.doAutoCreate())
1239          this.provider = new Reference(); // cc
1240      return this.provider;
1241    }
1242
1243    public boolean hasProvider() {
1244      return this.provider != null && !this.provider.isEmpty();
1245    }
1246
1247    /**
1248     * @param value {@link #provider} (Member of the team who provided the product
1249     *              or service.)
1250     */
1251    public CareTeamComponent setProvider(Reference value) {
1252      this.provider = value;
1253      return this;
1254    }
1255
1256    /**
1257     * @return {@link #provider} The actual object that is the target of the
1258     *         reference. The reference library doesn't populate this, but you can
1259     *         use it to hold the resource if you resolve it. (Member of the team
1260     *         who provided the product or service.)
1261     */
1262    public Resource getProviderTarget() {
1263      return this.providerTarget;
1264    }
1265
1266    /**
1267     * @param value {@link #provider} The actual object that is the target of the
1268     *              reference. The reference library doesn't use these, but you can
1269     *              use it to hold the resource if you resolve it. (Member of the
1270     *              team who provided the product or service.)
1271     */
1272    public CareTeamComponent setProviderTarget(Resource value) {
1273      this.providerTarget = value;
1274      return this;
1275    }
1276
1277    /**
1278     * @return {@link #responsible} (The party who is billing and/or responsible for
1279     *         the claimed products or services.). This is the underlying object
1280     *         with id, value and extensions. The accessor "getResponsible" gives
1281     *         direct access to the value
1282     */
1283    public BooleanType getResponsibleElement() {
1284      if (this.responsible == null)
1285        if (Configuration.errorOnAutoCreate())
1286          throw new Error("Attempt to auto-create CareTeamComponent.responsible");
1287        else if (Configuration.doAutoCreate())
1288          this.responsible = new BooleanType(); // bb
1289      return this.responsible;
1290    }
1291
1292    public boolean hasResponsibleElement() {
1293      return this.responsible != null && !this.responsible.isEmpty();
1294    }
1295
1296    public boolean hasResponsible() {
1297      return this.responsible != null && !this.responsible.isEmpty();
1298    }
1299
1300    /**
1301     * @param value {@link #responsible} (The party who is billing and/or
1302     *              responsible for the claimed products or services.). This is the
1303     *              underlying object with id, value and extensions. The accessor
1304     *              "getResponsible" gives direct access to the value
1305     */
1306    public CareTeamComponent setResponsibleElement(BooleanType value) {
1307      this.responsible = value;
1308      return this;
1309    }
1310
1311    /**
1312     * @return The party who is billing and/or responsible for the claimed products
1313     *         or services.
1314     */
1315    public boolean getResponsible() {
1316      return this.responsible == null || this.responsible.isEmpty() ? false : this.responsible.getValue();
1317    }
1318
1319    /**
1320     * @param value The party who is billing and/or responsible for the claimed
1321     *              products or services.
1322     */
1323    public CareTeamComponent setResponsible(boolean value) {
1324      if (this.responsible == null)
1325        this.responsible = new BooleanType();
1326      this.responsible.setValue(value);
1327      return this;
1328    }
1329
1330    /**
1331     * @return {@link #role} (The lead, assisting or supervising practitioner and
1332     *         their discipline if a multidisciplinary team.)
1333     */
1334    public CodeableConcept getRole() {
1335      if (this.role == null)
1336        if (Configuration.errorOnAutoCreate())
1337          throw new Error("Attempt to auto-create CareTeamComponent.role");
1338        else if (Configuration.doAutoCreate())
1339          this.role = new CodeableConcept(); // cc
1340      return this.role;
1341    }
1342
1343    public boolean hasRole() {
1344      return this.role != null && !this.role.isEmpty();
1345    }
1346
1347    /**
1348     * @param value {@link #role} (The lead, assisting or supervising practitioner
1349     *              and their discipline if a multidisciplinary team.)
1350     */
1351    public CareTeamComponent setRole(CodeableConcept value) {
1352      this.role = value;
1353      return this;
1354    }
1355
1356    /**
1357     * @return {@link #qualification} (The qualification of the practitioner which
1358     *         is applicable for this service.)
1359     */
1360    public CodeableConcept getQualification() {
1361      if (this.qualification == null)
1362        if (Configuration.errorOnAutoCreate())
1363          throw new Error("Attempt to auto-create CareTeamComponent.qualification");
1364        else if (Configuration.doAutoCreate())
1365          this.qualification = new CodeableConcept(); // cc
1366      return this.qualification;
1367    }
1368
1369    public boolean hasQualification() {
1370      return this.qualification != null && !this.qualification.isEmpty();
1371    }
1372
1373    /**
1374     * @param value {@link #qualification} (The qualification of the practitioner
1375     *              which is applicable for this service.)
1376     */
1377    public CareTeamComponent setQualification(CodeableConcept value) {
1378      this.qualification = value;
1379      return this;
1380    }
1381
1382    protected void listChildren(List<Property> children) {
1383      super.listChildren(children);
1384      children.add(
1385          new Property("sequence", "positiveInt", "A number to uniquely identify care team entries.", 0, 1, sequence));
1386      children.add(new Property("provider", "Reference(Practitioner|PractitionerRole|Organization)",
1387          "Member of the team who provided the product or service.", 0, 1, provider));
1388      children.add(new Property("responsible", "boolean",
1389          "The party who is billing and/or responsible for the claimed products or services.", 0, 1, responsible));
1390      children.add(new Property("role", "CodeableConcept",
1391          "The lead, assisting or supervising practitioner and their discipline if a multidisciplinary team.", 0, 1,
1392          role));
1393      children.add(new Property("qualification", "CodeableConcept",
1394          "The qualification of the practitioner which is applicable for this service.", 0, 1, qualification));
1395    }
1396
1397    @Override
1398    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
1399      switch (_hash) {
1400      case 1349547969:
1401        /* sequence */ return new Property("sequence", "positiveInt",
1402            "A number to uniquely identify care team entries.", 0, 1, sequence);
1403      case -987494927:
1404        /* provider */ return new Property("provider", "Reference(Practitioner|PractitionerRole|Organization)",
1405            "Member of the team who provided the product or service.", 0, 1, provider);
1406      case 1847674614:
1407        /* responsible */ return new Property("responsible", "boolean",
1408            "The party who is billing and/or responsible for the claimed products or services.", 0, 1, responsible);
1409      case 3506294:
1410        /* role */ return new Property("role", "CodeableConcept",
1411            "The lead, assisting or supervising practitioner and their discipline if a multidisciplinary team.", 0, 1,
1412            role);
1413      case -631333393:
1414        /* qualification */ return new Property("qualification", "CodeableConcept",
1415            "The qualification of the practitioner which is applicable for this service.", 0, 1, qualification);
1416      default:
1417        return super.getNamedProperty(_hash, _name, _checkValid);
1418      }
1419
1420    }
1421
1422    @Override
1423    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
1424      switch (hash) {
1425      case 1349547969:
1426        /* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
1427      case -987494927:
1428        /* provider */ return this.provider == null ? new Base[0] : new Base[] { this.provider }; // Reference
1429      case 1847674614:
1430        /* responsible */ return this.responsible == null ? new Base[0] : new Base[] { this.responsible }; // BooleanType
1431      case 3506294:
1432        /* role */ return this.role == null ? new Base[0] : new Base[] { this.role }; // CodeableConcept
1433      case -631333393:
1434        /* qualification */ return this.qualification == null ? new Base[0] : new Base[] { this.qualification }; // CodeableConcept
1435      default:
1436        return super.getProperty(hash, name, checkValid);
1437      }
1438
1439    }
1440
1441    @Override
1442    public Base setProperty(int hash, String name, Base value) throws FHIRException {
1443      switch (hash) {
1444      case 1349547969: // sequence
1445        this.sequence = castToPositiveInt(value); // PositiveIntType
1446        return value;
1447      case -987494927: // provider
1448        this.provider = castToReference(value); // Reference
1449        return value;
1450      case 1847674614: // responsible
1451        this.responsible = castToBoolean(value); // BooleanType
1452        return value;
1453      case 3506294: // role
1454        this.role = castToCodeableConcept(value); // CodeableConcept
1455        return value;
1456      case -631333393: // qualification
1457        this.qualification = castToCodeableConcept(value); // CodeableConcept
1458        return value;
1459      default:
1460        return super.setProperty(hash, name, value);
1461      }
1462
1463    }
1464
1465    @Override
1466    public Base setProperty(String name, Base value) throws FHIRException {
1467      if (name.equals("sequence")) {
1468        this.sequence = castToPositiveInt(value); // PositiveIntType
1469      } else if (name.equals("provider")) {
1470        this.provider = castToReference(value); // Reference
1471      } else if (name.equals("responsible")) {
1472        this.responsible = castToBoolean(value); // BooleanType
1473      } else if (name.equals("role")) {
1474        this.role = castToCodeableConcept(value); // CodeableConcept
1475      } else if (name.equals("qualification")) {
1476        this.qualification = castToCodeableConcept(value); // CodeableConcept
1477      } else
1478        return super.setProperty(name, value);
1479      return value;
1480    }
1481
1482  @Override
1483  public void removeChild(String name, Base value) throws FHIRException {
1484      if (name.equals("sequence")) {
1485        this.sequence = null;
1486      } else if (name.equals("provider")) {
1487        this.provider = null;
1488      } else if (name.equals("responsible")) {
1489        this.responsible = null;
1490      } else if (name.equals("role")) {
1491        this.role = null;
1492      } else if (name.equals("qualification")) {
1493        this.qualification = null;
1494      } else
1495        super.removeChild(name, value);
1496      
1497    }
1498
1499    @Override
1500    public Base makeProperty(int hash, String name) throws FHIRException {
1501      switch (hash) {
1502      case 1349547969:
1503        return getSequenceElement();
1504      case -987494927:
1505        return getProvider();
1506      case 1847674614:
1507        return getResponsibleElement();
1508      case 3506294:
1509        return getRole();
1510      case -631333393:
1511        return getQualification();
1512      default:
1513        return super.makeProperty(hash, name);
1514      }
1515
1516    }
1517
1518    @Override
1519    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
1520      switch (hash) {
1521      case 1349547969:
1522        /* sequence */ return new String[] { "positiveInt" };
1523      case -987494927:
1524        /* provider */ return new String[] { "Reference" };
1525      case 1847674614:
1526        /* responsible */ return new String[] { "boolean" };
1527      case 3506294:
1528        /* role */ return new String[] { "CodeableConcept" };
1529      case -631333393:
1530        /* qualification */ return new String[] { "CodeableConcept" };
1531      default:
1532        return super.getTypesForProperty(hash, name);
1533      }
1534
1535    }
1536
1537    @Override
1538    public Base addChild(String name) throws FHIRException {
1539      if (name.equals("sequence")) {
1540        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
1541      } else if (name.equals("provider")) {
1542        this.provider = new Reference();
1543        return this.provider;
1544      } else if (name.equals("responsible")) {
1545        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.responsible");
1546      } else if (name.equals("role")) {
1547        this.role = new CodeableConcept();
1548        return this.role;
1549      } else if (name.equals("qualification")) {
1550        this.qualification = new CodeableConcept();
1551        return this.qualification;
1552      } else
1553        return super.addChild(name);
1554    }
1555
1556    public CareTeamComponent copy() {
1557      CareTeamComponent dst = new CareTeamComponent();
1558      copyValues(dst);
1559      return dst;
1560    }
1561
1562    public void copyValues(CareTeamComponent dst) {
1563      super.copyValues(dst);
1564      dst.sequence = sequence == null ? null : sequence.copy();
1565      dst.provider = provider == null ? null : provider.copy();
1566      dst.responsible = responsible == null ? null : responsible.copy();
1567      dst.role = role == null ? null : role.copy();
1568      dst.qualification = qualification == null ? null : qualification.copy();
1569    }
1570
1571    @Override
1572    public boolean equalsDeep(Base other_) {
1573      if (!super.equalsDeep(other_))
1574        return false;
1575      if (!(other_ instanceof CareTeamComponent))
1576        return false;
1577      CareTeamComponent o = (CareTeamComponent) other_;
1578      return compareDeep(sequence, o.sequence, true) && compareDeep(provider, o.provider, true)
1579          && compareDeep(responsible, o.responsible, true) && compareDeep(role, o.role, true)
1580          && compareDeep(qualification, o.qualification, true);
1581    }
1582
1583    @Override
1584    public boolean equalsShallow(Base other_) {
1585      if (!super.equalsShallow(other_))
1586        return false;
1587      if (!(other_ instanceof CareTeamComponent))
1588        return false;
1589      CareTeamComponent o = (CareTeamComponent) other_;
1590      return compareValues(sequence, o.sequence, true) && compareValues(responsible, o.responsible, true);
1591    }
1592
1593    public boolean isEmpty() {
1594      return super.isEmpty()
1595          && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, provider, responsible, role, qualification);
1596    }
1597
1598    public String fhirType() {
1599      return "ExplanationOfBenefit.careTeam";
1600
1601    }
1602
1603  }
1604
1605  @Block()
1606  public static class SupportingInformationComponent extends BackboneElement implements IBaseBackboneElement {
1607    /**
1608     * A number to uniquely identify supporting information entries.
1609     */
1610    @Child(name = "sequence", type = {
1611        PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
1612    @Description(shortDefinition = "Information instance identifier", formalDefinition = "A number to uniquely identify supporting information entries.")
1613    protected PositiveIntType sequence;
1614
1615    /**
1616     * The general class of the information supplied: information; exception;
1617     * accident, employment; onset, etc.
1618     */
1619    @Child(name = "category", type = {
1620        CodeableConcept.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
1621    @Description(shortDefinition = "Classification of the supplied information", formalDefinition = "The general class of the information supplied: information; exception; accident, employment; onset, etc.")
1622    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-informationcategory")
1623    protected CodeableConcept category;
1624
1625    /**
1626     * System and code pertaining to the specific information regarding special
1627     * conditions relating to the setting, treatment or patient for which care is
1628     * sought.
1629     */
1630    @Child(name = "code", type = {
1631        CodeableConcept.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
1632    @Description(shortDefinition = "Type of information", formalDefinition = "System and code pertaining to the specific information regarding special conditions relating to the setting, treatment or patient  for which care is sought.")
1633    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-exception")
1634    protected CodeableConcept code;
1635
1636    /**
1637     * The date when or period to which this information refers.
1638     */
1639    @Child(name = "timing", type = { DateType.class,
1640        Period.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
1641    @Description(shortDefinition = "When it occurred", formalDefinition = "The date when or period to which this information refers.")
1642    protected Type timing;
1643
1644    /**
1645     * Additional data or information such as resources, documents, images etc.
1646     * including references to the data or the actual inclusion of the data.
1647     */
1648    @Child(name = "value", type = { BooleanType.class, StringType.class, Quantity.class, Attachment.class,
1649        Reference.class }, order = 5, min = 0, max = 1, modifier = false, summary = false)
1650    @Description(shortDefinition = "Data to be provided", formalDefinition = "Additional data or information such as resources, documents, images etc. including references to the data or the actual inclusion of the data.")
1651    protected Type value;
1652
1653    /**
1654     * Provides the reason in the situation where a reason code is required in
1655     * addition to the content.
1656     */
1657    @Child(name = "reason", type = { Coding.class }, order = 6, min = 0, max = 1, modifier = false, summary = false)
1658    @Description(shortDefinition = "Explanation for the information", formalDefinition = "Provides the reason in the situation where a reason code is required in addition to the content.")
1659    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/missing-tooth-reason")
1660    protected Coding reason;
1661
1662    private static final long serialVersionUID = -410136661L;
1663
1664    /**
1665     * Constructor
1666     */
1667    public SupportingInformationComponent() {
1668      super();
1669    }
1670
1671    /**
1672     * Constructor
1673     */
1674    public SupportingInformationComponent(PositiveIntType sequence, CodeableConcept category) {
1675      super();
1676      this.sequence = sequence;
1677      this.category = category;
1678    }
1679
1680    /**
1681     * @return {@link #sequence} (A number to uniquely identify supporting
1682     *         information entries.). This is the underlying object with id, value
1683     *         and extensions. The accessor "getSequence" gives direct access to the
1684     *         value
1685     */
1686    public PositiveIntType getSequenceElement() {
1687      if (this.sequence == null)
1688        if (Configuration.errorOnAutoCreate())
1689          throw new Error("Attempt to auto-create SupportingInformationComponent.sequence");
1690        else if (Configuration.doAutoCreate())
1691          this.sequence = new PositiveIntType(); // bb
1692      return this.sequence;
1693    }
1694
1695    public boolean hasSequenceElement() {
1696      return this.sequence != null && !this.sequence.isEmpty();
1697    }
1698
1699    public boolean hasSequence() {
1700      return this.sequence != null && !this.sequence.isEmpty();
1701    }
1702
1703    /**
1704     * @param value {@link #sequence} (A number to uniquely identify supporting
1705     *              information entries.). This is the underlying object with id,
1706     *              value and extensions. The accessor "getSequence" gives direct
1707     *              access to the value
1708     */
1709    public SupportingInformationComponent setSequenceElement(PositiveIntType value) {
1710      this.sequence = value;
1711      return this;
1712    }
1713
1714    /**
1715     * @return A number to uniquely identify supporting information entries.
1716     */
1717    public int getSequence() {
1718      return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
1719    }
1720
1721    /**
1722     * @param value A number to uniquely identify supporting information entries.
1723     */
1724    public SupportingInformationComponent setSequence(int value) {
1725      if (this.sequence == null)
1726        this.sequence = new PositiveIntType();
1727      this.sequence.setValue(value);
1728      return this;
1729    }
1730
1731    /**
1732     * @return {@link #category} (The general class of the information supplied:
1733     *         information; exception; accident, employment; onset, etc.)
1734     */
1735    public CodeableConcept getCategory() {
1736      if (this.category == null)
1737        if (Configuration.errorOnAutoCreate())
1738          throw new Error("Attempt to auto-create SupportingInformationComponent.category");
1739        else if (Configuration.doAutoCreate())
1740          this.category = new CodeableConcept(); // cc
1741      return this.category;
1742    }
1743
1744    public boolean hasCategory() {
1745      return this.category != null && !this.category.isEmpty();
1746    }
1747
1748    /**
1749     * @param value {@link #category} (The general class of the information
1750     *              supplied: information; exception; accident, employment; onset,
1751     *              etc.)
1752     */
1753    public SupportingInformationComponent setCategory(CodeableConcept value) {
1754      this.category = value;
1755      return this;
1756    }
1757
1758    /**
1759     * @return {@link #code} (System and code pertaining to the specific information
1760     *         regarding special conditions relating to the setting, treatment or
1761     *         patient for which care is sought.)
1762     */
1763    public CodeableConcept getCode() {
1764      if (this.code == null)
1765        if (Configuration.errorOnAutoCreate())
1766          throw new Error("Attempt to auto-create SupportingInformationComponent.code");
1767        else if (Configuration.doAutoCreate())
1768          this.code = new CodeableConcept(); // cc
1769      return this.code;
1770    }
1771
1772    public boolean hasCode() {
1773      return this.code != null && !this.code.isEmpty();
1774    }
1775
1776    /**
1777     * @param value {@link #code} (System and code pertaining to the specific
1778     *              information regarding special conditions relating to the
1779     *              setting, treatment or patient for which care is sought.)
1780     */
1781    public SupportingInformationComponent setCode(CodeableConcept value) {
1782      this.code = value;
1783      return this;
1784    }
1785
1786    /**
1787     * @return {@link #timing} (The date when or period to which this information
1788     *         refers.)
1789     */
1790    public Type getTiming() {
1791      return this.timing;
1792    }
1793
1794    /**
1795     * @return {@link #timing} (The date when or period to which this information
1796     *         refers.)
1797     */
1798    public DateType getTimingDateType() throws FHIRException {
1799      if (this.timing == null)
1800        this.timing = new DateType();
1801      if (!(this.timing instanceof DateType))
1802        throw new FHIRException("Type mismatch: the type DateType was expected, but " + this.timing.getClass().getName()
1803            + " was encountered");
1804      return (DateType) this.timing;
1805    }
1806
1807    public boolean hasTimingDateType() {
1808      return this != null && this.timing instanceof DateType;
1809    }
1810
1811    /**
1812     * @return {@link #timing} (The date when or period to which this information
1813     *         refers.)
1814     */
1815    public Period getTimingPeriod() throws FHIRException {
1816      if (this.timing == null)
1817        this.timing = new Period();
1818      if (!(this.timing instanceof Period))
1819        throw new FHIRException("Type mismatch: the type Period was expected, but " + this.timing.getClass().getName()
1820            + " was encountered");
1821      return (Period) this.timing;
1822    }
1823
1824    public boolean hasTimingPeriod() {
1825      return this != null && this.timing instanceof Period;
1826    }
1827
1828    public boolean hasTiming() {
1829      return this.timing != null && !this.timing.isEmpty();
1830    }
1831
1832    /**
1833     * @param value {@link #timing} (The date when or period to which this
1834     *              information refers.)
1835     */
1836    public SupportingInformationComponent setTiming(Type value) {
1837      if (value != null && !(value instanceof DateType || value instanceof Period))
1838        throw new Error("Not the right type for ExplanationOfBenefit.supportingInfo.timing[x]: " + value.fhirType());
1839      this.timing = value;
1840      return this;
1841    }
1842
1843    /**
1844     * @return {@link #value} (Additional data or information such as resources,
1845     *         documents, images etc. including references to the data or the actual
1846     *         inclusion of the data.)
1847     */
1848    public Type getValue() {
1849      return this.value;
1850    }
1851
1852    /**
1853     * @return {@link #value} (Additional data or information such as resources,
1854     *         documents, images etc. including references to the data or the actual
1855     *         inclusion of the data.)
1856     */
1857    public BooleanType getValueBooleanType() throws FHIRException {
1858      if (this.value == null)
1859        this.value = new BooleanType();
1860      if (!(this.value instanceof BooleanType))
1861        throw new FHIRException("Type mismatch: the type BooleanType was expected, but "
1862            + this.value.getClass().getName() + " was encountered");
1863      return (BooleanType) this.value;
1864    }
1865
1866    public boolean hasValueBooleanType() {
1867      return this != null && this.value instanceof BooleanType;
1868    }
1869
1870    /**
1871     * @return {@link #value} (Additional data or information such as resources,
1872     *         documents, images etc. including references to the data or the actual
1873     *         inclusion of the data.)
1874     */
1875    public StringType getValueStringType() throws FHIRException {
1876      if (this.value == null)
1877        this.value = new StringType();
1878      if (!(this.value instanceof StringType))
1879        throw new FHIRException("Type mismatch: the type StringType was expected, but "
1880            + this.value.getClass().getName() + " was encountered");
1881      return (StringType) this.value;
1882    }
1883
1884    public boolean hasValueStringType() {
1885      return this != null && this.value instanceof StringType;
1886    }
1887
1888    /**
1889     * @return {@link #value} (Additional data or information such as resources,
1890     *         documents, images etc. including references to the data or the actual
1891     *         inclusion of the data.)
1892     */
1893    public Quantity getValueQuantity() throws FHIRException {
1894      if (this.value == null)
1895        this.value = new Quantity();
1896      if (!(this.value instanceof Quantity))
1897        throw new FHIRException("Type mismatch: the type Quantity was expected, but " + this.value.getClass().getName()
1898            + " was encountered");
1899      return (Quantity) this.value;
1900    }
1901
1902    public boolean hasValueQuantity() {
1903      return this != null && this.value instanceof Quantity;
1904    }
1905
1906    /**
1907     * @return {@link #value} (Additional data or information such as resources,
1908     *         documents, images etc. including references to the data or the actual
1909     *         inclusion of the data.)
1910     */
1911    public Attachment getValueAttachment() throws FHIRException {
1912      if (this.value == null)
1913        this.value = new Attachment();
1914      if (!(this.value instanceof Attachment))
1915        throw new FHIRException("Type mismatch: the type Attachment was expected, but "
1916            + this.value.getClass().getName() + " was encountered");
1917      return (Attachment) this.value;
1918    }
1919
1920    public boolean hasValueAttachment() {
1921      return this != null && this.value instanceof Attachment;
1922    }
1923
1924    /**
1925     * @return {@link #value} (Additional data or information such as resources,
1926     *         documents, images etc. including references to the data or the actual
1927     *         inclusion of the data.)
1928     */
1929    public Reference getValueReference() throws FHIRException {
1930      if (this.value == null)
1931        this.value = new Reference();
1932      if (!(this.value instanceof Reference))
1933        throw new FHIRException("Type mismatch: the type Reference was expected, but " + this.value.getClass().getName()
1934            + " was encountered");
1935      return (Reference) this.value;
1936    }
1937
1938    public boolean hasValueReference() {
1939      return this != null && this.value instanceof Reference;
1940    }
1941
1942    public boolean hasValue() {
1943      return this.value != null && !this.value.isEmpty();
1944    }
1945
1946    /**
1947     * @param value {@link #value} (Additional data or information such as
1948     *              resources, documents, images etc. including references to the
1949     *              data or the actual inclusion of the data.)
1950     */
1951    public SupportingInformationComponent setValue(Type value) {
1952      if (value != null && !(value instanceof BooleanType || value instanceof StringType || value instanceof Quantity
1953          || value instanceof Attachment || value instanceof Reference))
1954        throw new Error("Not the right type for ExplanationOfBenefit.supportingInfo.value[x]: " + value.fhirType());
1955      this.value = value;
1956      return this;
1957    }
1958
1959    /**
1960     * @return {@link #reason} (Provides the reason in the situation where a reason
1961     *         code is required in addition to the content.)
1962     */
1963    public Coding getReason() {
1964      if (this.reason == null)
1965        if (Configuration.errorOnAutoCreate())
1966          throw new Error("Attempt to auto-create SupportingInformationComponent.reason");
1967        else if (Configuration.doAutoCreate())
1968          this.reason = new Coding(); // cc
1969      return this.reason;
1970    }
1971
1972    public boolean hasReason() {
1973      return this.reason != null && !this.reason.isEmpty();
1974    }
1975
1976    /**
1977     * @param value {@link #reason} (Provides the reason in the situation where a
1978     *              reason code is required in addition to the content.)
1979     */
1980    public SupportingInformationComponent setReason(Coding value) {
1981      this.reason = value;
1982      return this;
1983    }
1984
1985    protected void listChildren(List<Property> children) {
1986      super.listChildren(children);
1987      children.add(new Property("sequence", "positiveInt",
1988          "A number to uniquely identify supporting information entries.", 0, 1, sequence));
1989      children.add(new Property("category", "CodeableConcept",
1990          "The general class of the information supplied: information; exception; accident, employment; onset, etc.", 0,
1991          1, category));
1992      children.add(new Property("code", "CodeableConcept",
1993          "System and code pertaining to the specific information regarding special conditions relating to the setting, treatment or patient  for which care is sought.",
1994          0, 1, code));
1995      children.add(new Property("timing[x]", "date|Period", "The date when or period to which this information refers.",
1996          0, 1, timing));
1997      children.add(new Property("value[x]", "boolean|string|Quantity|Attachment|Reference(Any)",
1998          "Additional data or information such as resources, documents, images etc. including references to the data or the actual inclusion of the data.",
1999          0, 1, value));
2000      children.add(new Property("reason", "Coding",
2001          "Provides the reason in the situation where a reason code is required in addition to the content.", 0, 1,
2002          reason));
2003    }
2004
2005    @Override
2006    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
2007      switch (_hash) {
2008      case 1349547969:
2009        /* sequence */ return new Property("sequence", "positiveInt",
2010            "A number to uniquely identify supporting information entries.", 0, 1, sequence);
2011      case 50511102:
2012        /* category */ return new Property("category", "CodeableConcept",
2013            "The general class of the information supplied: information; exception; accident, employment; onset, etc.",
2014            0, 1, category);
2015      case 3059181:
2016        /* code */ return new Property("code", "CodeableConcept",
2017            "System and code pertaining to the specific information regarding special conditions relating to the setting, treatment or patient  for which care is sought.",
2018            0, 1, code);
2019      case 164632566:
2020        /* timing[x] */ return new Property("timing[x]", "date|Period",
2021            "The date when or period to which this information refers.", 0, 1, timing);
2022      case -873664438:
2023        /* timing */ return new Property("timing[x]", "date|Period",
2024            "The date when or period to which this information refers.", 0, 1, timing);
2025      case 807935768:
2026        /* timingDate */ return new Property("timing[x]", "date|Period",
2027            "The date when or period to which this information refers.", 0, 1, timing);
2028      case -615615829:
2029        /* timingPeriod */ return new Property("timing[x]", "date|Period",
2030            "The date when or period to which this information refers.", 0, 1, timing);
2031      case -1410166417:
2032        /* value[x] */ return new Property("value[x]", "boolean|string|Quantity|Attachment|Reference(Any)",
2033            "Additional data or information such as resources, documents, images etc. including references to the data or the actual inclusion of the data.",
2034            0, 1, value);
2035      case 111972721:
2036        /* value */ return new Property("value[x]", "boolean|string|Quantity|Attachment|Reference(Any)",
2037            "Additional data or information such as resources, documents, images etc. including references to the data or the actual inclusion of the data.",
2038            0, 1, value);
2039      case 733421943:
2040        /* valueBoolean */ return new Property("value[x]", "boolean|string|Quantity|Attachment|Reference(Any)",
2041            "Additional data or information such as resources, documents, images etc. including references to the data or the actual inclusion of the data.",
2042            0, 1, value);
2043      case -1424603934:
2044        /* valueString */ return new Property("value[x]", "boolean|string|Quantity|Attachment|Reference(Any)",
2045            "Additional data or information such as resources, documents, images etc. including references to the data or the actual inclusion of the data.",
2046            0, 1, value);
2047      case -2029823716:
2048        /* valueQuantity */ return new Property("value[x]", "boolean|string|Quantity|Attachment|Reference(Any)",
2049            "Additional data or information such as resources, documents, images etc. including references to the data or the actual inclusion of the data.",
2050            0, 1, value);
2051      case -475566732:
2052        /* valueAttachment */ return new Property("value[x]", "boolean|string|Quantity|Attachment|Reference(Any)",
2053            "Additional data or information such as resources, documents, images etc. including references to the data or the actual inclusion of the data.",
2054            0, 1, value);
2055      case 1755241690:
2056        /* valueReference */ return new Property("value[x]", "boolean|string|Quantity|Attachment|Reference(Any)",
2057            "Additional data or information such as resources, documents, images etc. including references to the data or the actual inclusion of the data.",
2058            0, 1, value);
2059      case -934964668:
2060        /* reason */ return new Property("reason", "Coding",
2061            "Provides the reason in the situation where a reason code is required in addition to the content.", 0, 1,
2062            reason);
2063      default:
2064        return super.getNamedProperty(_hash, _name, _checkValid);
2065      }
2066
2067    }
2068
2069    @Override
2070    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
2071      switch (hash) {
2072      case 1349547969:
2073        /* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
2074      case 50511102:
2075        /* category */ return this.category == null ? new Base[0] : new Base[] { this.category }; // CodeableConcept
2076      case 3059181:
2077        /* code */ return this.code == null ? new Base[0] : new Base[] { this.code }; // CodeableConcept
2078      case -873664438:
2079        /* timing */ return this.timing == null ? new Base[0] : new Base[] { this.timing }; // Type
2080      case 111972721:
2081        /* value */ return this.value == null ? new Base[0] : new Base[] { this.value }; // Type
2082      case -934964668:
2083        /* reason */ return this.reason == null ? new Base[0] : new Base[] { this.reason }; // Coding
2084      default:
2085        return super.getProperty(hash, name, checkValid);
2086      }
2087
2088    }
2089
2090    @Override
2091    public Base setProperty(int hash, String name, Base value) throws FHIRException {
2092      switch (hash) {
2093      case 1349547969: // sequence
2094        this.sequence = castToPositiveInt(value); // PositiveIntType
2095        return value;
2096      case 50511102: // category
2097        this.category = castToCodeableConcept(value); // CodeableConcept
2098        return value;
2099      case 3059181: // code
2100        this.code = castToCodeableConcept(value); // CodeableConcept
2101        return value;
2102      case -873664438: // timing
2103        this.timing = castToType(value); // Type
2104        return value;
2105      case 111972721: // value
2106        this.value = castToType(value); // Type
2107        return value;
2108      case -934964668: // reason
2109        this.reason = castToCoding(value); // Coding
2110        return value;
2111      default:
2112        return super.setProperty(hash, name, value);
2113      }
2114
2115    }
2116
2117    @Override
2118    public Base setProperty(String name, Base value) throws FHIRException {
2119      if (name.equals("sequence")) {
2120        this.sequence = castToPositiveInt(value); // PositiveIntType
2121      } else if (name.equals("category")) {
2122        this.category = castToCodeableConcept(value); // CodeableConcept
2123      } else if (name.equals("code")) {
2124        this.code = castToCodeableConcept(value); // CodeableConcept
2125      } else if (name.equals("timing[x]")) {
2126        this.timing = castToType(value); // Type
2127      } else if (name.equals("value[x]")) {
2128        this.value = castToType(value); // Type
2129      } else if (name.equals("reason")) {
2130        this.reason = castToCoding(value); // Coding
2131      } else
2132        return super.setProperty(name, value);
2133      return value;
2134    }
2135
2136  @Override
2137  public void removeChild(String name, Base value) throws FHIRException {
2138      if (name.equals("sequence")) {
2139        this.sequence = null;
2140      } else if (name.equals("category")) {
2141        this.category = null;
2142      } else if (name.equals("code")) {
2143        this.code = null;
2144      } else if (name.equals("timing[x]")) {
2145        this.timing = null;
2146      } else if (name.equals("value[x]")) {
2147        this.value = null;
2148      } else if (name.equals("reason")) {
2149        this.reason = null;
2150      } else
2151        super.removeChild(name, value);
2152      
2153    }
2154
2155    @Override
2156    public Base makeProperty(int hash, String name) throws FHIRException {
2157      switch (hash) {
2158      case 1349547969:
2159        return getSequenceElement();
2160      case 50511102:
2161        return getCategory();
2162      case 3059181:
2163        return getCode();
2164      case 164632566:
2165        return getTiming();
2166      case -873664438:
2167        return getTiming();
2168      case -1410166417:
2169        return getValue();
2170      case 111972721:
2171        return getValue();
2172      case -934964668:
2173        return getReason();
2174      default:
2175        return super.makeProperty(hash, name);
2176      }
2177
2178    }
2179
2180    @Override
2181    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
2182      switch (hash) {
2183      case 1349547969:
2184        /* sequence */ return new String[] { "positiveInt" };
2185      case 50511102:
2186        /* category */ return new String[] { "CodeableConcept" };
2187      case 3059181:
2188        /* code */ return new String[] { "CodeableConcept" };
2189      case -873664438:
2190        /* timing */ return new String[] { "date", "Period" };
2191      case 111972721:
2192        /* value */ return new String[] { "boolean", "string", "Quantity", "Attachment", "Reference" };
2193      case -934964668:
2194        /* reason */ return new String[] { "Coding" };
2195      default:
2196        return super.getTypesForProperty(hash, name);
2197      }
2198
2199    }
2200
2201    @Override
2202    public Base addChild(String name) throws FHIRException {
2203      if (name.equals("sequence")) {
2204        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
2205      } else if (name.equals("category")) {
2206        this.category = new CodeableConcept();
2207        return this.category;
2208      } else if (name.equals("code")) {
2209        this.code = new CodeableConcept();
2210        return this.code;
2211      } else if (name.equals("timingDate")) {
2212        this.timing = new DateType();
2213        return this.timing;
2214      } else if (name.equals("timingPeriod")) {
2215        this.timing = new Period();
2216        return this.timing;
2217      } else if (name.equals("valueBoolean")) {
2218        this.value = new BooleanType();
2219        return this.value;
2220      } else if (name.equals("valueString")) {
2221        this.value = new StringType();
2222        return this.value;
2223      } else if (name.equals("valueQuantity")) {
2224        this.value = new Quantity();
2225        return this.value;
2226      } else if (name.equals("valueAttachment")) {
2227        this.value = new Attachment();
2228        return this.value;
2229      } else if (name.equals("valueReference")) {
2230        this.value = new Reference();
2231        return this.value;
2232      } else if (name.equals("reason")) {
2233        this.reason = new Coding();
2234        return this.reason;
2235      } else
2236        return super.addChild(name);
2237    }
2238
2239    public SupportingInformationComponent copy() {
2240      SupportingInformationComponent dst = new SupportingInformationComponent();
2241      copyValues(dst);
2242      return dst;
2243    }
2244
2245    public void copyValues(SupportingInformationComponent dst) {
2246      super.copyValues(dst);
2247      dst.sequence = sequence == null ? null : sequence.copy();
2248      dst.category = category == null ? null : category.copy();
2249      dst.code = code == null ? null : code.copy();
2250      dst.timing = timing == null ? null : timing.copy();
2251      dst.value = value == null ? null : value.copy();
2252      dst.reason = reason == null ? null : reason.copy();
2253    }
2254
2255    @Override
2256    public boolean equalsDeep(Base other_) {
2257      if (!super.equalsDeep(other_))
2258        return false;
2259      if (!(other_ instanceof SupportingInformationComponent))
2260        return false;
2261      SupportingInformationComponent o = (SupportingInformationComponent) other_;
2262      return compareDeep(sequence, o.sequence, true) && compareDeep(category, o.category, true)
2263          && compareDeep(code, o.code, true) && compareDeep(timing, o.timing, true) && compareDeep(value, o.value, true)
2264          && compareDeep(reason, o.reason, true);
2265    }
2266
2267    @Override
2268    public boolean equalsShallow(Base other_) {
2269      if (!super.equalsShallow(other_))
2270        return false;
2271      if (!(other_ instanceof SupportingInformationComponent))
2272        return false;
2273      SupportingInformationComponent o = (SupportingInformationComponent) other_;
2274      return compareValues(sequence, o.sequence, true);
2275    }
2276
2277    public boolean isEmpty() {
2278      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, category, code, timing, value, reason);
2279    }
2280
2281    public String fhirType() {
2282      return "ExplanationOfBenefit.supportingInfo";
2283
2284    }
2285
2286  }
2287
2288  @Block()
2289  public static class DiagnosisComponent extends BackboneElement implements IBaseBackboneElement {
2290    /**
2291     * A number to uniquely identify diagnosis entries.
2292     */
2293    @Child(name = "sequence", type = {
2294        PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
2295    @Description(shortDefinition = "Diagnosis instance identifier", formalDefinition = "A number to uniquely identify diagnosis entries.")
2296    protected PositiveIntType sequence;
2297
2298    /**
2299     * The nature of illness or problem in a coded form or as a reference to an
2300     * external defined Condition.
2301     */
2302    @Child(name = "diagnosis", type = { CodeableConcept.class,
2303        Condition.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
2304    @Description(shortDefinition = "Nature of illness or problem", formalDefinition = "The nature of illness or problem in a coded form or as a reference to an external defined Condition.")
2305    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/icd-10")
2306    protected Type diagnosis;
2307
2308    /**
2309     * When the condition was observed or the relative ranking.
2310     */
2311    @Child(name = "type", type = {
2312        CodeableConcept.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
2313    @Description(shortDefinition = "Timing or nature of the diagnosis", formalDefinition = "When the condition was observed or the relative ranking.")
2314    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-diagnosistype")
2315    protected List<CodeableConcept> type;
2316
2317    /**
2318     * Indication of whether the diagnosis was present on admission to a facility.
2319     */
2320    @Child(name = "onAdmission", type = {
2321        CodeableConcept.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
2322    @Description(shortDefinition = "Present on admission", formalDefinition = "Indication of whether the diagnosis was present on admission to a facility.")
2323    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-diagnosis-on-admission")
2324    protected CodeableConcept onAdmission;
2325
2326    /**
2327     * A package billing code or bundle code used to group products and services to
2328     * a particular health condition (such as heart attack) which is based on a
2329     * predetermined grouping code system.
2330     */
2331    @Child(name = "packageCode", type = {
2332        CodeableConcept.class }, order = 5, min = 0, max = 1, modifier = false, summary = false)
2333    @Description(shortDefinition = "Package billing code", formalDefinition = "A package billing code or bundle code used to group products and services to a particular health condition (such as heart attack) which is based on a predetermined grouping code system.")
2334    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-diagnosisrelatedgroup")
2335    protected CodeableConcept packageCode;
2336
2337    private static final long serialVersionUID = 2120593974L;
2338
2339    /**
2340     * Constructor
2341     */
2342    public DiagnosisComponent() {
2343      super();
2344    }
2345
2346    /**
2347     * Constructor
2348     */
2349    public DiagnosisComponent(PositiveIntType sequence, Type diagnosis) {
2350      super();
2351      this.sequence = sequence;
2352      this.diagnosis = diagnosis;
2353    }
2354
2355    /**
2356     * @return {@link #sequence} (A number to uniquely identify diagnosis entries.).
2357     *         This is the underlying object with id, value and extensions. The
2358     *         accessor "getSequence" gives direct access to the value
2359     */
2360    public PositiveIntType getSequenceElement() {
2361      if (this.sequence == null)
2362        if (Configuration.errorOnAutoCreate())
2363          throw new Error("Attempt to auto-create DiagnosisComponent.sequence");
2364        else if (Configuration.doAutoCreate())
2365          this.sequence = new PositiveIntType(); // bb
2366      return this.sequence;
2367    }
2368
2369    public boolean hasSequenceElement() {
2370      return this.sequence != null && !this.sequence.isEmpty();
2371    }
2372
2373    public boolean hasSequence() {
2374      return this.sequence != null && !this.sequence.isEmpty();
2375    }
2376
2377    /**
2378     * @param value {@link #sequence} (A number to uniquely identify diagnosis
2379     *              entries.). This is the underlying object with id, value and
2380     *              extensions. The accessor "getSequence" gives direct access to
2381     *              the value
2382     */
2383    public DiagnosisComponent setSequenceElement(PositiveIntType value) {
2384      this.sequence = value;
2385      return this;
2386    }
2387
2388    /**
2389     * @return A number to uniquely identify diagnosis entries.
2390     */
2391    public int getSequence() {
2392      return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
2393    }
2394
2395    /**
2396     * @param value A number to uniquely identify diagnosis entries.
2397     */
2398    public DiagnosisComponent setSequence(int value) {
2399      if (this.sequence == null)
2400        this.sequence = new PositiveIntType();
2401      this.sequence.setValue(value);
2402      return this;
2403    }
2404
2405    /**
2406     * @return {@link #diagnosis} (The nature of illness or problem in a coded form
2407     *         or as a reference to an external defined Condition.)
2408     */
2409    public Type getDiagnosis() {
2410      return this.diagnosis;
2411    }
2412
2413    /**
2414     * @return {@link #diagnosis} (The nature of illness or problem in a coded form
2415     *         or as a reference to an external defined Condition.)
2416     */
2417    public CodeableConcept getDiagnosisCodeableConcept() throws FHIRException {
2418      if (this.diagnosis == null)
2419        this.diagnosis = new CodeableConcept();
2420      if (!(this.diagnosis instanceof CodeableConcept))
2421        throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "
2422            + this.diagnosis.getClass().getName() + " was encountered");
2423      return (CodeableConcept) this.diagnosis;
2424    }
2425
2426    public boolean hasDiagnosisCodeableConcept() {
2427      return this != null && this.diagnosis instanceof CodeableConcept;
2428    }
2429
2430    /**
2431     * @return {@link #diagnosis} (The nature of illness or problem in a coded form
2432     *         or as a reference to an external defined Condition.)
2433     */
2434    public Reference getDiagnosisReference() throws FHIRException {
2435      if (this.diagnosis == null)
2436        this.diagnosis = new Reference();
2437      if (!(this.diagnosis instanceof Reference))
2438        throw new FHIRException("Type mismatch: the type Reference was expected, but "
2439            + this.diagnosis.getClass().getName() + " was encountered");
2440      return (Reference) this.diagnosis;
2441    }
2442
2443    public boolean hasDiagnosisReference() {
2444      return this != null && this.diagnosis instanceof Reference;
2445    }
2446
2447    public boolean hasDiagnosis() {
2448      return this.diagnosis != null && !this.diagnosis.isEmpty();
2449    }
2450
2451    /**
2452     * @param value {@link #diagnosis} (The nature of illness or problem in a coded
2453     *              form or as a reference to an external defined Condition.)
2454     */
2455    public DiagnosisComponent setDiagnosis(Type value) {
2456      if (value != null && !(value instanceof CodeableConcept || value instanceof Reference))
2457        throw new Error("Not the right type for ExplanationOfBenefit.diagnosis.diagnosis[x]: " + value.fhirType());
2458      this.diagnosis = value;
2459      return this;
2460    }
2461
2462    /**
2463     * @return {@link #type} (When the condition was observed or the relative
2464     *         ranking.)
2465     */
2466    public List<CodeableConcept> getType() {
2467      if (this.type == null)
2468        this.type = new ArrayList<CodeableConcept>();
2469      return this.type;
2470    }
2471
2472    /**
2473     * @return Returns a reference to <code>this</code> for easy method chaining
2474     */
2475    public DiagnosisComponent setType(List<CodeableConcept> theType) {
2476      this.type = theType;
2477      return this;
2478    }
2479
2480    public boolean hasType() {
2481      if (this.type == null)
2482        return false;
2483      for (CodeableConcept item : this.type)
2484        if (!item.isEmpty())
2485          return true;
2486      return false;
2487    }
2488
2489    public CodeableConcept addType() { // 3
2490      CodeableConcept t = new CodeableConcept();
2491      if (this.type == null)
2492        this.type = new ArrayList<CodeableConcept>();
2493      this.type.add(t);
2494      return t;
2495    }
2496
2497    public DiagnosisComponent addType(CodeableConcept t) { // 3
2498      if (t == null)
2499        return this;
2500      if (this.type == null)
2501        this.type = new ArrayList<CodeableConcept>();
2502      this.type.add(t);
2503      return this;
2504    }
2505
2506    /**
2507     * @return The first repetition of repeating field {@link #type}, creating it if
2508     *         it does not already exist
2509     */
2510    public CodeableConcept getTypeFirstRep() {
2511      if (getType().isEmpty()) {
2512        addType();
2513      }
2514      return getType().get(0);
2515    }
2516
2517    /**
2518     * @return {@link #onAdmission} (Indication of whether the diagnosis was present
2519     *         on admission to a facility.)
2520     */
2521    public CodeableConcept getOnAdmission() {
2522      if (this.onAdmission == null)
2523        if (Configuration.errorOnAutoCreate())
2524          throw new Error("Attempt to auto-create DiagnosisComponent.onAdmission");
2525        else if (Configuration.doAutoCreate())
2526          this.onAdmission = new CodeableConcept(); // cc
2527      return this.onAdmission;
2528    }
2529
2530    public boolean hasOnAdmission() {
2531      return this.onAdmission != null && !this.onAdmission.isEmpty();
2532    }
2533
2534    /**
2535     * @param value {@link #onAdmission} (Indication of whether the diagnosis was
2536     *              present on admission to a facility.)
2537     */
2538    public DiagnosisComponent setOnAdmission(CodeableConcept value) {
2539      this.onAdmission = value;
2540      return this;
2541    }
2542
2543    /**
2544     * @return {@link #packageCode} (A package billing code or bundle code used to
2545     *         group products and services to a particular health condition (such as
2546     *         heart attack) which is based on a predetermined grouping code
2547     *         system.)
2548     */
2549    public CodeableConcept getPackageCode() {
2550      if (this.packageCode == null)
2551        if (Configuration.errorOnAutoCreate())
2552          throw new Error("Attempt to auto-create DiagnosisComponent.packageCode");
2553        else if (Configuration.doAutoCreate())
2554          this.packageCode = new CodeableConcept(); // cc
2555      return this.packageCode;
2556    }
2557
2558    public boolean hasPackageCode() {
2559      return this.packageCode != null && !this.packageCode.isEmpty();
2560    }
2561
2562    /**
2563     * @param value {@link #packageCode} (A package billing code or bundle code used
2564     *              to group products and services to a particular health condition
2565     *              (such as heart attack) which is based on a predetermined
2566     *              grouping code system.)
2567     */
2568    public DiagnosisComponent setPackageCode(CodeableConcept value) {
2569      this.packageCode = value;
2570      return this;
2571    }
2572
2573    protected void listChildren(List<Property> children) {
2574      super.listChildren(children);
2575      children.add(
2576          new Property("sequence", "positiveInt", "A number to uniquely identify diagnosis entries.", 0, 1, sequence));
2577      children.add(new Property("diagnosis[x]", "CodeableConcept|Reference(Condition)",
2578          "The nature of illness or problem in a coded form or as a reference to an external defined Condition.", 0, 1,
2579          diagnosis));
2580      children.add(new Property("type", "CodeableConcept", "When the condition was observed or the relative ranking.",
2581          0, java.lang.Integer.MAX_VALUE, type));
2582      children.add(new Property("onAdmission", "CodeableConcept",
2583          "Indication of whether the diagnosis was present on admission to a facility.", 0, 1, onAdmission));
2584      children.add(new Property("packageCode", "CodeableConcept",
2585          "A package billing code or bundle code used to group products and services to a particular health condition (such as heart attack) which is based on a predetermined grouping code system.",
2586          0, 1, packageCode));
2587    }
2588
2589    @Override
2590    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
2591      switch (_hash) {
2592      case 1349547969:
2593        /* sequence */ return new Property("sequence", "positiveInt",
2594            "A number to uniquely identify diagnosis entries.", 0, 1, sequence);
2595      case -1487009809:
2596        /* diagnosis[x] */ return new Property("diagnosis[x]", "CodeableConcept|Reference(Condition)",
2597            "The nature of illness or problem in a coded form or as a reference to an external defined Condition.", 0,
2598            1, diagnosis);
2599      case 1196993265:
2600        /* diagnosis */ return new Property("diagnosis[x]", "CodeableConcept|Reference(Condition)",
2601            "The nature of illness or problem in a coded form or as a reference to an external defined Condition.", 0,
2602            1, diagnosis);
2603      case 277781616:
2604        /* diagnosisCodeableConcept */ return new Property("diagnosis[x]", "CodeableConcept|Reference(Condition)",
2605            "The nature of illness or problem in a coded form or as a reference to an external defined Condition.", 0,
2606            1, diagnosis);
2607      case 2050454362:
2608        /* diagnosisReference */ return new Property("diagnosis[x]", "CodeableConcept|Reference(Condition)",
2609            "The nature of illness or problem in a coded form or as a reference to an external defined Condition.", 0,
2610            1, diagnosis);
2611      case 3575610:
2612        /* type */ return new Property("type", "CodeableConcept",
2613            "When the condition was observed or the relative ranking.", 0, java.lang.Integer.MAX_VALUE, type);
2614      case -3386134:
2615        /* onAdmission */ return new Property("onAdmission", "CodeableConcept",
2616            "Indication of whether the diagnosis was present on admission to a facility.", 0, 1, onAdmission);
2617      case 908444499:
2618        /* packageCode */ return new Property("packageCode", "CodeableConcept",
2619            "A package billing code or bundle code used to group products and services to a particular health condition (such as heart attack) which is based on a predetermined grouping code system.",
2620            0, 1, packageCode);
2621      default:
2622        return super.getNamedProperty(_hash, _name, _checkValid);
2623      }
2624
2625    }
2626
2627    @Override
2628    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
2629      switch (hash) {
2630      case 1349547969:
2631        /* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
2632      case 1196993265:
2633        /* diagnosis */ return this.diagnosis == null ? new Base[0] : new Base[] { this.diagnosis }; // Type
2634      case 3575610:
2635        /* type */ return this.type == null ? new Base[0] : this.type.toArray(new Base[this.type.size()]); // CodeableConcept
2636      case -3386134:
2637        /* onAdmission */ return this.onAdmission == null ? new Base[0] : new Base[] { this.onAdmission }; // CodeableConcept
2638      case 908444499:
2639        /* packageCode */ return this.packageCode == null ? new Base[0] : new Base[] { this.packageCode }; // CodeableConcept
2640      default:
2641        return super.getProperty(hash, name, checkValid);
2642      }
2643
2644    }
2645
2646    @Override
2647    public Base setProperty(int hash, String name, Base value) throws FHIRException {
2648      switch (hash) {
2649      case 1349547969: // sequence
2650        this.sequence = castToPositiveInt(value); // PositiveIntType
2651        return value;
2652      case 1196993265: // diagnosis
2653        this.diagnosis = castToType(value); // Type
2654        return value;
2655      case 3575610: // type
2656        this.getType().add(castToCodeableConcept(value)); // CodeableConcept
2657        return value;
2658      case -3386134: // onAdmission
2659        this.onAdmission = castToCodeableConcept(value); // CodeableConcept
2660        return value;
2661      case 908444499: // packageCode
2662        this.packageCode = castToCodeableConcept(value); // CodeableConcept
2663        return value;
2664      default:
2665        return super.setProperty(hash, name, value);
2666      }
2667
2668    }
2669
2670    @Override
2671    public Base setProperty(String name, Base value) throws FHIRException {
2672      if (name.equals("sequence")) {
2673        this.sequence = castToPositiveInt(value); // PositiveIntType
2674      } else if (name.equals("diagnosis[x]")) {
2675        this.diagnosis = castToType(value); // Type
2676      } else if (name.equals("type")) {
2677        this.getType().add(castToCodeableConcept(value));
2678      } else if (name.equals("onAdmission")) {
2679        this.onAdmission = castToCodeableConcept(value); // CodeableConcept
2680      } else if (name.equals("packageCode")) {
2681        this.packageCode = castToCodeableConcept(value); // CodeableConcept
2682      } else
2683        return super.setProperty(name, value);
2684      return value;
2685    }
2686
2687  @Override
2688  public void removeChild(String name, Base value) throws FHIRException {
2689      if (name.equals("sequence")) {
2690        this.sequence = null;
2691      } else if (name.equals("diagnosis[x]")) {
2692        this.diagnosis = null;
2693      } else if (name.equals("type")) {
2694        this.getType().remove(castToCodeableConcept(value));
2695      } else if (name.equals("onAdmission")) {
2696        this.onAdmission = null;
2697      } else if (name.equals("packageCode")) {
2698        this.packageCode = null;
2699      } else
2700        super.removeChild(name, value);
2701      
2702    }
2703
2704    @Override
2705    public Base makeProperty(int hash, String name) throws FHIRException {
2706      switch (hash) {
2707      case 1349547969:
2708        return getSequenceElement();
2709      case -1487009809:
2710        return getDiagnosis();
2711      case 1196993265:
2712        return getDiagnosis();
2713      case 3575610:
2714        return addType();
2715      case -3386134:
2716        return getOnAdmission();
2717      case 908444499:
2718        return getPackageCode();
2719      default:
2720        return super.makeProperty(hash, name);
2721      }
2722
2723    }
2724
2725    @Override
2726    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
2727      switch (hash) {
2728      case 1349547969:
2729        /* sequence */ return new String[] { "positiveInt" };
2730      case 1196993265:
2731        /* diagnosis */ return new String[] { "CodeableConcept", "Reference" };
2732      case 3575610:
2733        /* type */ return new String[] { "CodeableConcept" };
2734      case -3386134:
2735        /* onAdmission */ return new String[] { "CodeableConcept" };
2736      case 908444499:
2737        /* packageCode */ return new String[] { "CodeableConcept" };
2738      default:
2739        return super.getTypesForProperty(hash, name);
2740      }
2741
2742    }
2743
2744    @Override
2745    public Base addChild(String name) throws FHIRException {
2746      if (name.equals("sequence")) {
2747        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
2748      } else if (name.equals("diagnosisCodeableConcept")) {
2749        this.diagnosis = new CodeableConcept();
2750        return this.diagnosis;
2751      } else if (name.equals("diagnosisReference")) {
2752        this.diagnosis = new Reference();
2753        return this.diagnosis;
2754      } else if (name.equals("type")) {
2755        return addType();
2756      } else if (name.equals("onAdmission")) {
2757        this.onAdmission = new CodeableConcept();
2758        return this.onAdmission;
2759      } else if (name.equals("packageCode")) {
2760        this.packageCode = new CodeableConcept();
2761        return this.packageCode;
2762      } else
2763        return super.addChild(name);
2764    }
2765
2766    public DiagnosisComponent copy() {
2767      DiagnosisComponent dst = new DiagnosisComponent();
2768      copyValues(dst);
2769      return dst;
2770    }
2771
2772    public void copyValues(DiagnosisComponent dst) {
2773      super.copyValues(dst);
2774      dst.sequence = sequence == null ? null : sequence.copy();
2775      dst.diagnosis = diagnosis == null ? null : diagnosis.copy();
2776      if (type != null) {
2777        dst.type = new ArrayList<CodeableConcept>();
2778        for (CodeableConcept i : type)
2779          dst.type.add(i.copy());
2780      }
2781      ;
2782      dst.onAdmission = onAdmission == null ? null : onAdmission.copy();
2783      dst.packageCode = packageCode == null ? null : packageCode.copy();
2784    }
2785
2786    @Override
2787    public boolean equalsDeep(Base other_) {
2788      if (!super.equalsDeep(other_))
2789        return false;
2790      if (!(other_ instanceof DiagnosisComponent))
2791        return false;
2792      DiagnosisComponent o = (DiagnosisComponent) other_;
2793      return compareDeep(sequence, o.sequence, true) && compareDeep(diagnosis, o.diagnosis, true)
2794          && compareDeep(type, o.type, true) && compareDeep(onAdmission, o.onAdmission, true)
2795          && compareDeep(packageCode, o.packageCode, true);
2796    }
2797
2798    @Override
2799    public boolean equalsShallow(Base other_) {
2800      if (!super.equalsShallow(other_))
2801        return false;
2802      if (!(other_ instanceof DiagnosisComponent))
2803        return false;
2804      DiagnosisComponent o = (DiagnosisComponent) other_;
2805      return compareValues(sequence, o.sequence, true);
2806    }
2807
2808    public boolean isEmpty() {
2809      return super.isEmpty()
2810          && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, diagnosis, type, onAdmission, packageCode);
2811    }
2812
2813    public String fhirType() {
2814      return "ExplanationOfBenefit.diagnosis";
2815
2816    }
2817
2818  }
2819
2820  @Block()
2821  public static class ProcedureComponent extends BackboneElement implements IBaseBackboneElement {
2822    /**
2823     * A number to uniquely identify procedure entries.
2824     */
2825    @Child(name = "sequence", type = {
2826        PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
2827    @Description(shortDefinition = "Procedure instance identifier", formalDefinition = "A number to uniquely identify procedure entries.")
2828    protected PositiveIntType sequence;
2829
2830    /**
2831     * When the condition was observed or the relative ranking.
2832     */
2833    @Child(name = "type", type = {
2834        CodeableConcept.class }, order = 2, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
2835    @Description(shortDefinition = "Category of Procedure", formalDefinition = "When the condition was observed or the relative ranking.")
2836    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-procedure-type")
2837    protected List<CodeableConcept> type;
2838
2839    /**
2840     * Date and optionally time the procedure was performed.
2841     */
2842    @Child(name = "date", type = { DateTimeType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
2843    @Description(shortDefinition = "When the procedure was performed", formalDefinition = "Date and optionally time the procedure was performed.")
2844    protected DateTimeType date;
2845
2846    /**
2847     * The code or reference to a Procedure resource which identifies the clinical
2848     * intervention performed.
2849     */
2850    @Child(name = "procedure", type = { CodeableConcept.class,
2851        Procedure.class }, order = 4, min = 1, max = 1, modifier = false, summary = false)
2852    @Description(shortDefinition = "Specific clinical procedure", formalDefinition = "The code or reference to a Procedure resource which identifies the clinical intervention performed.")
2853    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/icd-10-procedures")
2854    protected Type procedure;
2855
2856    /**
2857     * Unique Device Identifiers associated with this line item.
2858     */
2859    @Child(name = "udi", type = {
2860        Device.class }, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
2861    @Description(shortDefinition = "Unique device identifier", formalDefinition = "Unique Device Identifiers associated with this line item.")
2862    protected List<Reference> udi;
2863    /**
2864     * The actual objects that are the target of the reference (Unique Device
2865     * Identifiers associated with this line item.)
2866     */
2867    protected List<Device> udiTarget;
2868
2869    private static final long serialVersionUID = 935341852L;
2870
2871    /**
2872     * Constructor
2873     */
2874    public ProcedureComponent() {
2875      super();
2876    }
2877
2878    /**
2879     * Constructor
2880     */
2881    public ProcedureComponent(PositiveIntType sequence, Type procedure) {
2882      super();
2883      this.sequence = sequence;
2884      this.procedure = procedure;
2885    }
2886
2887    /**
2888     * @return {@link #sequence} (A number to uniquely identify procedure entries.).
2889     *         This is the underlying object with id, value and extensions. The
2890     *         accessor "getSequence" gives direct access to the value
2891     */
2892    public PositiveIntType getSequenceElement() {
2893      if (this.sequence == null)
2894        if (Configuration.errorOnAutoCreate())
2895          throw new Error("Attempt to auto-create ProcedureComponent.sequence");
2896        else if (Configuration.doAutoCreate())
2897          this.sequence = new PositiveIntType(); // bb
2898      return this.sequence;
2899    }
2900
2901    public boolean hasSequenceElement() {
2902      return this.sequence != null && !this.sequence.isEmpty();
2903    }
2904
2905    public boolean hasSequence() {
2906      return this.sequence != null && !this.sequence.isEmpty();
2907    }
2908
2909    /**
2910     * @param value {@link #sequence} (A number to uniquely identify procedure
2911     *              entries.). This is the underlying object with id, value and
2912     *              extensions. The accessor "getSequence" gives direct access to
2913     *              the value
2914     */
2915    public ProcedureComponent setSequenceElement(PositiveIntType value) {
2916      this.sequence = value;
2917      return this;
2918    }
2919
2920    /**
2921     * @return A number to uniquely identify procedure entries.
2922     */
2923    public int getSequence() {
2924      return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
2925    }
2926
2927    /**
2928     * @param value A number to uniquely identify procedure entries.
2929     */
2930    public ProcedureComponent setSequence(int value) {
2931      if (this.sequence == null)
2932        this.sequence = new PositiveIntType();
2933      this.sequence.setValue(value);
2934      return this;
2935    }
2936
2937    /**
2938     * @return {@link #type} (When the condition was observed or the relative
2939     *         ranking.)
2940     */
2941    public List<CodeableConcept> getType() {
2942      if (this.type == null)
2943        this.type = new ArrayList<CodeableConcept>();
2944      return this.type;
2945    }
2946
2947    /**
2948     * @return Returns a reference to <code>this</code> for easy method chaining
2949     */
2950    public ProcedureComponent setType(List<CodeableConcept> theType) {
2951      this.type = theType;
2952      return this;
2953    }
2954
2955    public boolean hasType() {
2956      if (this.type == null)
2957        return false;
2958      for (CodeableConcept item : this.type)
2959        if (!item.isEmpty())
2960          return true;
2961      return false;
2962    }
2963
2964    public CodeableConcept addType() { // 3
2965      CodeableConcept t = new CodeableConcept();
2966      if (this.type == null)
2967        this.type = new ArrayList<CodeableConcept>();
2968      this.type.add(t);
2969      return t;
2970    }
2971
2972    public ProcedureComponent addType(CodeableConcept t) { // 3
2973      if (t == null)
2974        return this;
2975      if (this.type == null)
2976        this.type = new ArrayList<CodeableConcept>();
2977      this.type.add(t);
2978      return this;
2979    }
2980
2981    /**
2982     * @return The first repetition of repeating field {@link #type}, creating it if
2983     *         it does not already exist
2984     */
2985    public CodeableConcept getTypeFirstRep() {
2986      if (getType().isEmpty()) {
2987        addType();
2988      }
2989      return getType().get(0);
2990    }
2991
2992    /**
2993     * @return {@link #date} (Date and optionally time the procedure was
2994     *         performed.). This is the underlying object with id, value and
2995     *         extensions. The accessor "getDate" gives direct access to the value
2996     */
2997    public DateTimeType getDateElement() {
2998      if (this.date == null)
2999        if (Configuration.errorOnAutoCreate())
3000          throw new Error("Attempt to auto-create ProcedureComponent.date");
3001        else if (Configuration.doAutoCreate())
3002          this.date = new DateTimeType(); // bb
3003      return this.date;
3004    }
3005
3006    public boolean hasDateElement() {
3007      return this.date != null && !this.date.isEmpty();
3008    }
3009
3010    public boolean hasDate() {
3011      return this.date != null && !this.date.isEmpty();
3012    }
3013
3014    /**
3015     * @param value {@link #date} (Date and optionally time the procedure was
3016     *              performed.). This is the underlying object with id, value and
3017     *              extensions. The accessor "getDate" gives direct access to the
3018     *              value
3019     */
3020    public ProcedureComponent setDateElement(DateTimeType value) {
3021      this.date = value;
3022      return this;
3023    }
3024
3025    /**
3026     * @return Date and optionally time the procedure was performed.
3027     */
3028    public Date getDate() {
3029      return this.date == null ? null : this.date.getValue();
3030    }
3031
3032    /**
3033     * @param value Date and optionally time the procedure was performed.
3034     */
3035    public ProcedureComponent setDate(Date value) {
3036      if (value == null)
3037        this.date = null;
3038      else {
3039        if (this.date == null)
3040          this.date = new DateTimeType();
3041        this.date.setValue(value);
3042      }
3043      return this;
3044    }
3045
3046    /**
3047     * @return {@link #procedure} (The code or reference to a Procedure resource
3048     *         which identifies the clinical intervention performed.)
3049     */
3050    public Type getProcedure() {
3051      return this.procedure;
3052    }
3053
3054    /**
3055     * @return {@link #procedure} (The code or reference to a Procedure resource
3056     *         which identifies the clinical intervention performed.)
3057     */
3058    public CodeableConcept getProcedureCodeableConcept() throws FHIRException {
3059      if (this.procedure == null)
3060        this.procedure = new CodeableConcept();
3061      if (!(this.procedure instanceof CodeableConcept))
3062        throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "
3063            + this.procedure.getClass().getName() + " was encountered");
3064      return (CodeableConcept) this.procedure;
3065    }
3066
3067    public boolean hasProcedureCodeableConcept() {
3068      return this != null && this.procedure instanceof CodeableConcept;
3069    }
3070
3071    /**
3072     * @return {@link #procedure} (The code or reference to a Procedure resource
3073     *         which identifies the clinical intervention performed.)
3074     */
3075    public Reference getProcedureReference() throws FHIRException {
3076      if (this.procedure == null)
3077        this.procedure = new Reference();
3078      if (!(this.procedure instanceof Reference))
3079        throw new FHIRException("Type mismatch: the type Reference was expected, but "
3080            + this.procedure.getClass().getName() + " was encountered");
3081      return (Reference) this.procedure;
3082    }
3083
3084    public boolean hasProcedureReference() {
3085      return this != null && this.procedure instanceof Reference;
3086    }
3087
3088    public boolean hasProcedure() {
3089      return this.procedure != null && !this.procedure.isEmpty();
3090    }
3091
3092    /**
3093     * @param value {@link #procedure} (The code or reference to a Procedure
3094     *              resource which identifies the clinical intervention performed.)
3095     */
3096    public ProcedureComponent setProcedure(Type value) {
3097      if (value != null && !(value instanceof CodeableConcept || value instanceof Reference))
3098        throw new Error("Not the right type for ExplanationOfBenefit.procedure.procedure[x]: " + value.fhirType());
3099      this.procedure = value;
3100      return this;
3101    }
3102
3103    /**
3104     * @return {@link #udi} (Unique Device Identifiers associated with this line
3105     *         item.)
3106     */
3107    public List<Reference> getUdi() {
3108      if (this.udi == null)
3109        this.udi = new ArrayList<Reference>();
3110      return this.udi;
3111    }
3112
3113    /**
3114     * @return Returns a reference to <code>this</code> for easy method chaining
3115     */
3116    public ProcedureComponent setUdi(List<Reference> theUdi) {
3117      this.udi = theUdi;
3118      return this;
3119    }
3120
3121    public boolean hasUdi() {
3122      if (this.udi == null)
3123        return false;
3124      for (Reference item : this.udi)
3125        if (!item.isEmpty())
3126          return true;
3127      return false;
3128    }
3129
3130    public Reference addUdi() { // 3
3131      Reference t = new Reference();
3132      if (this.udi == null)
3133        this.udi = new ArrayList<Reference>();
3134      this.udi.add(t);
3135      return t;
3136    }
3137
3138    public ProcedureComponent addUdi(Reference t) { // 3
3139      if (t == null)
3140        return this;
3141      if (this.udi == null)
3142        this.udi = new ArrayList<Reference>();
3143      this.udi.add(t);
3144      return this;
3145    }
3146
3147    /**
3148     * @return The first repetition of repeating field {@link #udi}, creating it if
3149     *         it does not already exist
3150     */
3151    public Reference getUdiFirstRep() {
3152      if (getUdi().isEmpty()) {
3153        addUdi();
3154      }
3155      return getUdi().get(0);
3156    }
3157
3158    /**
3159     * @deprecated Use Reference#setResource(IBaseResource) instead
3160     */
3161    @Deprecated
3162    public List<Device> getUdiTarget() {
3163      if (this.udiTarget == null)
3164        this.udiTarget = new ArrayList<Device>();
3165      return this.udiTarget;
3166    }
3167
3168    /**
3169     * @deprecated Use Reference#setResource(IBaseResource) instead
3170     */
3171    @Deprecated
3172    public Device addUdiTarget() {
3173      Device r = new Device();
3174      if (this.udiTarget == null)
3175        this.udiTarget = new ArrayList<Device>();
3176      this.udiTarget.add(r);
3177      return r;
3178    }
3179
3180    protected void listChildren(List<Property> children) {
3181      super.listChildren(children);
3182      children.add(
3183          new Property("sequence", "positiveInt", "A number to uniquely identify procedure entries.", 0, 1, sequence));
3184      children.add(new Property("type", "CodeableConcept", "When the condition was observed or the relative ranking.",
3185          0, java.lang.Integer.MAX_VALUE, type));
3186      children
3187          .add(new Property("date", "dateTime", "Date and optionally time the procedure was performed.", 0, 1, date));
3188      children.add(new Property("procedure[x]", "CodeableConcept|Reference(Procedure)",
3189          "The code or reference to a Procedure resource which identifies the clinical intervention performed.", 0, 1,
3190          procedure));
3191      children.add(new Property("udi", "Reference(Device)", "Unique Device Identifiers associated with this line item.",
3192          0, java.lang.Integer.MAX_VALUE, udi));
3193    }
3194
3195    @Override
3196    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
3197      switch (_hash) {
3198      case 1349547969:
3199        /* sequence */ return new Property("sequence", "positiveInt",
3200            "A number to uniquely identify procedure entries.", 0, 1, sequence);
3201      case 3575610:
3202        /* type */ return new Property("type", "CodeableConcept",
3203            "When the condition was observed or the relative ranking.", 0, java.lang.Integer.MAX_VALUE, type);
3204      case 3076014:
3205        /* date */ return new Property("date", "dateTime", "Date and optionally time the procedure was performed.", 0,
3206            1, date);
3207      case 1640074445:
3208        /* procedure[x] */ return new Property("procedure[x]", "CodeableConcept|Reference(Procedure)",
3209            "The code or reference to a Procedure resource which identifies the clinical intervention performed.", 0, 1,
3210            procedure);
3211      case -1095204141:
3212        /* procedure */ return new Property("procedure[x]", "CodeableConcept|Reference(Procedure)",
3213            "The code or reference to a Procedure resource which identifies the clinical intervention performed.", 0, 1,
3214            procedure);
3215      case -1284783026:
3216        /* procedureCodeableConcept */ return new Property("procedure[x]", "CodeableConcept|Reference(Procedure)",
3217            "The code or reference to a Procedure resource which identifies the clinical intervention performed.", 0, 1,
3218            procedure);
3219      case 881809848:
3220        /* procedureReference */ return new Property("procedure[x]", "CodeableConcept|Reference(Procedure)",
3221            "The code or reference to a Procedure resource which identifies the clinical intervention performed.", 0, 1,
3222            procedure);
3223      case 115642:
3224        /* udi */ return new Property("udi", "Reference(Device)",
3225            "Unique Device Identifiers associated with this line item.", 0, java.lang.Integer.MAX_VALUE, udi);
3226      default:
3227        return super.getNamedProperty(_hash, _name, _checkValid);
3228      }
3229
3230    }
3231
3232    @Override
3233    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
3234      switch (hash) {
3235      case 1349547969:
3236        /* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
3237      case 3575610:
3238        /* type */ return this.type == null ? new Base[0] : this.type.toArray(new Base[this.type.size()]); // CodeableConcept
3239      case 3076014:
3240        /* date */ return this.date == null ? new Base[0] : new Base[] { this.date }; // DateTimeType
3241      case -1095204141:
3242        /* procedure */ return this.procedure == null ? new Base[0] : new Base[] { this.procedure }; // Type
3243      case 115642:
3244        /* udi */ return this.udi == null ? new Base[0] : this.udi.toArray(new Base[this.udi.size()]); // Reference
3245      default:
3246        return super.getProperty(hash, name, checkValid);
3247      }
3248
3249    }
3250
3251    @Override
3252    public Base setProperty(int hash, String name, Base value) throws FHIRException {
3253      switch (hash) {
3254      case 1349547969: // sequence
3255        this.sequence = castToPositiveInt(value); // PositiveIntType
3256        return value;
3257      case 3575610: // type
3258        this.getType().add(castToCodeableConcept(value)); // CodeableConcept
3259        return value;
3260      case 3076014: // date
3261        this.date = castToDateTime(value); // DateTimeType
3262        return value;
3263      case -1095204141: // procedure
3264        this.procedure = castToType(value); // Type
3265        return value;
3266      case 115642: // udi
3267        this.getUdi().add(castToReference(value)); // Reference
3268        return value;
3269      default:
3270        return super.setProperty(hash, name, value);
3271      }
3272
3273    }
3274
3275    @Override
3276    public Base setProperty(String name, Base value) throws FHIRException {
3277      if (name.equals("sequence")) {
3278        this.sequence = castToPositiveInt(value); // PositiveIntType
3279      } else if (name.equals("type")) {
3280        this.getType().add(castToCodeableConcept(value));
3281      } else if (name.equals("date")) {
3282        this.date = castToDateTime(value); // DateTimeType
3283      } else if (name.equals("procedure[x]")) {
3284        this.procedure = castToType(value); // Type
3285      } else if (name.equals("udi")) {
3286        this.getUdi().add(castToReference(value));
3287      } else
3288        return super.setProperty(name, value);
3289      return value;
3290    }
3291
3292  @Override
3293  public void removeChild(String name, Base value) throws FHIRException {
3294      if (name.equals("sequence")) {
3295        this.sequence = null;
3296      } else if (name.equals("type")) {
3297        this.getType().remove(castToCodeableConcept(value));
3298      } else if (name.equals("date")) {
3299        this.date = null;
3300      } else if (name.equals("procedure[x]")) {
3301        this.procedure = null;
3302      } else if (name.equals("udi")) {
3303        this.getUdi().remove(castToReference(value));
3304      } else
3305        super.removeChild(name, value);
3306      
3307    }
3308
3309    @Override
3310    public Base makeProperty(int hash, String name) throws FHIRException {
3311      switch (hash) {
3312      case 1349547969:
3313        return getSequenceElement();
3314      case 3575610:
3315        return addType();
3316      case 3076014:
3317        return getDateElement();
3318      case 1640074445:
3319        return getProcedure();
3320      case -1095204141:
3321        return getProcedure();
3322      case 115642:
3323        return addUdi();
3324      default:
3325        return super.makeProperty(hash, name);
3326      }
3327
3328    }
3329
3330    @Override
3331    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
3332      switch (hash) {
3333      case 1349547969:
3334        /* sequence */ return new String[] { "positiveInt" };
3335      case 3575610:
3336        /* type */ return new String[] { "CodeableConcept" };
3337      case 3076014:
3338        /* date */ return new String[] { "dateTime" };
3339      case -1095204141:
3340        /* procedure */ return new String[] { "CodeableConcept", "Reference" };
3341      case 115642:
3342        /* udi */ return new String[] { "Reference" };
3343      default:
3344        return super.getTypesForProperty(hash, name);
3345      }
3346
3347    }
3348
3349    @Override
3350    public Base addChild(String name) throws FHIRException {
3351      if (name.equals("sequence")) {
3352        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
3353      } else if (name.equals("type")) {
3354        return addType();
3355      } else if (name.equals("date")) {
3356        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.date");
3357      } else if (name.equals("procedureCodeableConcept")) {
3358        this.procedure = new CodeableConcept();
3359        return this.procedure;
3360      } else if (name.equals("procedureReference")) {
3361        this.procedure = new Reference();
3362        return this.procedure;
3363      } else if (name.equals("udi")) {
3364        return addUdi();
3365      } else
3366        return super.addChild(name);
3367    }
3368
3369    public ProcedureComponent copy() {
3370      ProcedureComponent dst = new ProcedureComponent();
3371      copyValues(dst);
3372      return dst;
3373    }
3374
3375    public void copyValues(ProcedureComponent dst) {
3376      super.copyValues(dst);
3377      dst.sequence = sequence == null ? null : sequence.copy();
3378      if (type != null) {
3379        dst.type = new ArrayList<CodeableConcept>();
3380        for (CodeableConcept i : type)
3381          dst.type.add(i.copy());
3382      }
3383      ;
3384      dst.date = date == null ? null : date.copy();
3385      dst.procedure = procedure == null ? null : procedure.copy();
3386      if (udi != null) {
3387        dst.udi = new ArrayList<Reference>();
3388        for (Reference i : udi)
3389          dst.udi.add(i.copy());
3390      }
3391      ;
3392    }
3393
3394    @Override
3395    public boolean equalsDeep(Base other_) {
3396      if (!super.equalsDeep(other_))
3397        return false;
3398      if (!(other_ instanceof ProcedureComponent))
3399        return false;
3400      ProcedureComponent o = (ProcedureComponent) other_;
3401      return compareDeep(sequence, o.sequence, true) && compareDeep(type, o.type, true)
3402          && compareDeep(date, o.date, true) && compareDeep(procedure, o.procedure, true)
3403          && compareDeep(udi, o.udi, true);
3404    }
3405
3406    @Override
3407    public boolean equalsShallow(Base other_) {
3408      if (!super.equalsShallow(other_))
3409        return false;
3410      if (!(other_ instanceof ProcedureComponent))
3411        return false;
3412      ProcedureComponent o = (ProcedureComponent) other_;
3413      return compareValues(sequence, o.sequence, true) && compareValues(date, o.date, true);
3414    }
3415
3416    public boolean isEmpty() {
3417      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, type, date, procedure, udi);
3418    }
3419
3420    public String fhirType() {
3421      return "ExplanationOfBenefit.procedure";
3422
3423    }
3424
3425  }
3426
3427  @Block()
3428  public static class InsuranceComponent extends BackboneElement implements IBaseBackboneElement {
3429    /**
3430     * A flag to indicate that this Coverage is to be used for adjudication of this
3431     * claim when set to true.
3432     */
3433    @Child(name = "focal", type = { BooleanType.class }, order = 1, min = 1, max = 1, modifier = false, summary = true)
3434    @Description(shortDefinition = "Coverage to be used for adjudication", formalDefinition = "A flag to indicate that this Coverage is to be used for adjudication of this claim when set to true.")
3435    protected BooleanType focal;
3436
3437    /**
3438     * Reference to the insurance card level information contained in the Coverage
3439     * resource. The coverage issuing insurer will use these details to locate the
3440     * patient's actual coverage within the insurer's information system.
3441     */
3442    @Child(name = "coverage", type = { Coverage.class }, order = 2, min = 1, max = 1, modifier = false, summary = true)
3443    @Description(shortDefinition = "Insurance information", formalDefinition = "Reference to the insurance card level information contained in the Coverage resource. The coverage issuing insurer will use these details to locate the patient's actual coverage within the insurer's information system.")
3444    protected Reference coverage;
3445
3446    /**
3447     * The actual object that is the target of the reference (Reference to the
3448     * insurance card level information contained in the Coverage resource. The
3449     * coverage issuing insurer will use these details to locate the patient's
3450     * actual coverage within the insurer's information system.)
3451     */
3452    protected Coverage coverageTarget;
3453
3454    /**
3455     * Reference numbers previously provided by the insurer to the provider to be
3456     * quoted on subsequent claims containing services or products related to the
3457     * prior authorization.
3458     */
3459    @Child(name = "preAuthRef", type = {
3460        StringType.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
3461    @Description(shortDefinition = "Prior authorization reference number", formalDefinition = "Reference numbers previously provided by the insurer to the provider to be quoted on subsequent claims containing services or products related to the prior authorization.")
3462    protected List<StringType> preAuthRef;
3463
3464    private static final long serialVersionUID = -606383626L;
3465
3466    /**
3467     * Constructor
3468     */
3469    public InsuranceComponent() {
3470      super();
3471    }
3472
3473    /**
3474     * Constructor
3475     */
3476    public InsuranceComponent(BooleanType focal, Reference coverage) {
3477      super();
3478      this.focal = focal;
3479      this.coverage = coverage;
3480    }
3481
3482    /**
3483     * @return {@link #focal} (A flag to indicate that this Coverage is to be used
3484     *         for adjudication of this claim when set to true.). This is the
3485     *         underlying object with id, value and extensions. The accessor
3486     *         "getFocal" gives direct access to the value
3487     */
3488    public BooleanType getFocalElement() {
3489      if (this.focal == null)
3490        if (Configuration.errorOnAutoCreate())
3491          throw new Error("Attempt to auto-create InsuranceComponent.focal");
3492        else if (Configuration.doAutoCreate())
3493          this.focal = new BooleanType(); // bb
3494      return this.focal;
3495    }
3496
3497    public boolean hasFocalElement() {
3498      return this.focal != null && !this.focal.isEmpty();
3499    }
3500
3501    public boolean hasFocal() {
3502      return this.focal != null && !this.focal.isEmpty();
3503    }
3504
3505    /**
3506     * @param value {@link #focal} (A flag to indicate that this Coverage is to be
3507     *              used for adjudication of this claim when set to true.). This is
3508     *              the underlying object with id, value and extensions. The
3509     *              accessor "getFocal" gives direct access to the value
3510     */
3511    public InsuranceComponent setFocalElement(BooleanType value) {
3512      this.focal = value;
3513      return this;
3514    }
3515
3516    /**
3517     * @return A flag to indicate that this Coverage is to be used for adjudication
3518     *         of this claim when set to true.
3519     */
3520    public boolean getFocal() {
3521      return this.focal == null || this.focal.isEmpty() ? false : this.focal.getValue();
3522    }
3523
3524    /**
3525     * @param value A flag to indicate that this Coverage is to be used for
3526     *              adjudication of this claim when set to true.
3527     */
3528    public InsuranceComponent setFocal(boolean value) {
3529      if (this.focal == null)
3530        this.focal = new BooleanType();
3531      this.focal.setValue(value);
3532      return this;
3533    }
3534
3535    /**
3536     * @return {@link #coverage} (Reference to the insurance card level information
3537     *         contained in the Coverage resource. The coverage issuing insurer will
3538     *         use these details to locate the patient's actual coverage within the
3539     *         insurer's information system.)
3540     */
3541    public Reference getCoverage() {
3542      if (this.coverage == null)
3543        if (Configuration.errorOnAutoCreate())
3544          throw new Error("Attempt to auto-create InsuranceComponent.coverage");
3545        else if (Configuration.doAutoCreate())
3546          this.coverage = new Reference(); // cc
3547      return this.coverage;
3548    }
3549
3550    public boolean hasCoverage() {
3551      return this.coverage != null && !this.coverage.isEmpty();
3552    }
3553
3554    /**
3555     * @param value {@link #coverage} (Reference to the insurance card level
3556     *              information contained in the Coverage resource. The coverage
3557     *              issuing insurer will use these details to locate the patient's
3558     *              actual coverage within the insurer's information system.)
3559     */
3560    public InsuranceComponent setCoverage(Reference value) {
3561      this.coverage = value;
3562      return this;
3563    }
3564
3565    /**
3566     * @return {@link #coverage} The actual object that is the target of the
3567     *         reference. The reference library doesn't populate this, but you can
3568     *         use it to hold the resource if you resolve it. (Reference to the
3569     *         insurance card level information contained in the Coverage resource.
3570     *         The coverage issuing insurer will use these details to locate the
3571     *         patient's actual coverage within the insurer's information system.)
3572     */
3573    public Coverage getCoverageTarget() {
3574      if (this.coverageTarget == null)
3575        if (Configuration.errorOnAutoCreate())
3576          throw new Error("Attempt to auto-create InsuranceComponent.coverage");
3577        else if (Configuration.doAutoCreate())
3578          this.coverageTarget = new Coverage(); // aa
3579      return this.coverageTarget;
3580    }
3581
3582    /**
3583     * @param value {@link #coverage} The actual object that is the target of the
3584     *              reference. The reference library doesn't use these, but you can
3585     *              use it to hold the resource if you resolve it. (Reference to the
3586     *              insurance card level information contained in the Coverage
3587     *              resource. The coverage issuing insurer will use these details to
3588     *              locate the patient's actual coverage within the insurer's
3589     *              information system.)
3590     */
3591    public InsuranceComponent setCoverageTarget(Coverage value) {
3592      this.coverageTarget = value;
3593      return this;
3594    }
3595
3596    /**
3597     * @return {@link #preAuthRef} (Reference numbers previously provided by the
3598     *         insurer to the provider to be quoted on subsequent claims containing
3599     *         services or products related to the prior authorization.)
3600     */
3601    public List<StringType> getPreAuthRef() {
3602      if (this.preAuthRef == null)
3603        this.preAuthRef = new ArrayList<StringType>();
3604      return this.preAuthRef;
3605    }
3606
3607    /**
3608     * @return Returns a reference to <code>this</code> for easy method chaining
3609     */
3610    public InsuranceComponent setPreAuthRef(List<StringType> thePreAuthRef) {
3611      this.preAuthRef = thePreAuthRef;
3612      return this;
3613    }
3614
3615    public boolean hasPreAuthRef() {
3616      if (this.preAuthRef == null)
3617        return false;
3618      for (StringType item : this.preAuthRef)
3619        if (!item.isEmpty())
3620          return true;
3621      return false;
3622    }
3623
3624    /**
3625     * @return {@link #preAuthRef} (Reference numbers previously provided by the
3626     *         insurer to the provider to be quoted on subsequent claims containing
3627     *         services or products related to the prior authorization.)
3628     */
3629    public StringType addPreAuthRefElement() {// 2
3630      StringType t = new StringType();
3631      if (this.preAuthRef == null)
3632        this.preAuthRef = new ArrayList<StringType>();
3633      this.preAuthRef.add(t);
3634      return t;
3635    }
3636
3637    /**
3638     * @param value {@link #preAuthRef} (Reference numbers previously provided by
3639     *              the insurer to the provider to be quoted on subsequent claims
3640     *              containing services or products related to the prior
3641     *              authorization.)
3642     */
3643    public InsuranceComponent addPreAuthRef(String value) { // 1
3644      StringType t = new StringType();
3645      t.setValue(value);
3646      if (this.preAuthRef == null)
3647        this.preAuthRef = new ArrayList<StringType>();
3648      this.preAuthRef.add(t);
3649      return this;
3650    }
3651
3652    /**
3653     * @param value {@link #preAuthRef} (Reference numbers previously provided by
3654     *              the insurer to the provider to be quoted on subsequent claims
3655     *              containing services or products related to the prior
3656     *              authorization.)
3657     */
3658    public boolean hasPreAuthRef(String value) {
3659      if (this.preAuthRef == null)
3660        return false;
3661      for (StringType v : this.preAuthRef)
3662        if (v.getValue().equals(value)) // string
3663          return true;
3664      return false;
3665    }
3666
3667    protected void listChildren(List<Property> children) {
3668      super.listChildren(children);
3669      children.add(new Property("focal", "boolean",
3670          "A flag to indicate that this Coverage is to be used for adjudication of this claim when set to true.", 0, 1,
3671          focal));
3672      children.add(new Property("coverage", "Reference(Coverage)",
3673          "Reference to the insurance card level information contained in the Coverage resource. The coverage issuing insurer will use these details to locate the patient's actual coverage within the insurer's information system.",
3674          0, 1, coverage));
3675      children.add(new Property("preAuthRef", "string",
3676          "Reference numbers previously provided by the insurer to the provider to be quoted on subsequent claims containing services or products related to the prior authorization.",
3677          0, java.lang.Integer.MAX_VALUE, preAuthRef));
3678    }
3679
3680    @Override
3681    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
3682      switch (_hash) {
3683      case 97604197:
3684        /* focal */ return new Property("focal", "boolean",
3685            "A flag to indicate that this Coverage is to be used for adjudication of this claim when set to true.", 0,
3686            1, focal);
3687      case -351767064:
3688        /* coverage */ return new Property("coverage", "Reference(Coverage)",
3689            "Reference to the insurance card level information contained in the Coverage resource. The coverage issuing insurer will use these details to locate the patient's actual coverage within the insurer's information system.",
3690            0, 1, coverage);
3691      case 522246568:
3692        /* preAuthRef */ return new Property("preAuthRef", "string",
3693            "Reference numbers previously provided by the insurer to the provider to be quoted on subsequent claims containing services or products related to the prior authorization.",
3694            0, java.lang.Integer.MAX_VALUE, preAuthRef);
3695      default:
3696        return super.getNamedProperty(_hash, _name, _checkValid);
3697      }
3698
3699    }
3700
3701    @Override
3702    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
3703      switch (hash) {
3704      case 97604197:
3705        /* focal */ return this.focal == null ? new Base[0] : new Base[] { this.focal }; // BooleanType
3706      case -351767064:
3707        /* coverage */ return this.coverage == null ? new Base[0] : new Base[] { this.coverage }; // Reference
3708      case 522246568:
3709        /* preAuthRef */ return this.preAuthRef == null ? new Base[0]
3710            : this.preAuthRef.toArray(new Base[this.preAuthRef.size()]); // StringType
3711      default:
3712        return super.getProperty(hash, name, checkValid);
3713      }
3714
3715    }
3716
3717    @Override
3718    public Base setProperty(int hash, String name, Base value) throws FHIRException {
3719      switch (hash) {
3720      case 97604197: // focal
3721        this.focal = castToBoolean(value); // BooleanType
3722        return value;
3723      case -351767064: // coverage
3724        this.coverage = castToReference(value); // Reference
3725        return value;
3726      case 522246568: // preAuthRef
3727        this.getPreAuthRef().add(castToString(value)); // StringType
3728        return value;
3729      default:
3730        return super.setProperty(hash, name, value);
3731      }
3732
3733    }
3734
3735    @Override
3736    public Base setProperty(String name, Base value) throws FHIRException {
3737      if (name.equals("focal")) {
3738        this.focal = castToBoolean(value); // BooleanType
3739      } else if (name.equals("coverage")) {
3740        this.coverage = castToReference(value); // Reference
3741      } else if (name.equals("preAuthRef")) {
3742        this.getPreAuthRef().add(castToString(value));
3743      } else
3744        return super.setProperty(name, value);
3745      return value;
3746    }
3747
3748  @Override
3749  public void removeChild(String name, Base value) throws FHIRException {
3750      if (name.equals("focal")) {
3751        this.focal = null;
3752      } else if (name.equals("coverage")) {
3753        this.coverage = null;
3754      } else if (name.equals("preAuthRef")) {
3755        this.getPreAuthRef().remove(castToString(value));
3756      } else
3757        super.removeChild(name, value);
3758      
3759    }
3760
3761    @Override
3762    public Base makeProperty(int hash, String name) throws FHIRException {
3763      switch (hash) {
3764      case 97604197:
3765        return getFocalElement();
3766      case -351767064:
3767        return getCoverage();
3768      case 522246568:
3769        return addPreAuthRefElement();
3770      default:
3771        return super.makeProperty(hash, name);
3772      }
3773
3774    }
3775
3776    @Override
3777    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
3778      switch (hash) {
3779      case 97604197:
3780        /* focal */ return new String[] { "boolean" };
3781      case -351767064:
3782        /* coverage */ return new String[] { "Reference" };
3783      case 522246568:
3784        /* preAuthRef */ return new String[] { "string" };
3785      default:
3786        return super.getTypesForProperty(hash, name);
3787      }
3788
3789    }
3790
3791    @Override
3792    public Base addChild(String name) throws FHIRException {
3793      if (name.equals("focal")) {
3794        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.focal");
3795      } else if (name.equals("coverage")) {
3796        this.coverage = new Reference();
3797        return this.coverage;
3798      } else if (name.equals("preAuthRef")) {
3799        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.preAuthRef");
3800      } else
3801        return super.addChild(name);
3802    }
3803
3804    public InsuranceComponent copy() {
3805      InsuranceComponent dst = new InsuranceComponent();
3806      copyValues(dst);
3807      return dst;
3808    }
3809
3810    public void copyValues(InsuranceComponent dst) {
3811      super.copyValues(dst);
3812      dst.focal = focal == null ? null : focal.copy();
3813      dst.coverage = coverage == null ? null : coverage.copy();
3814      if (preAuthRef != null) {
3815        dst.preAuthRef = new ArrayList<StringType>();
3816        for (StringType i : preAuthRef)
3817          dst.preAuthRef.add(i.copy());
3818      }
3819      ;
3820    }
3821
3822    @Override
3823    public boolean equalsDeep(Base other_) {
3824      if (!super.equalsDeep(other_))
3825        return false;
3826      if (!(other_ instanceof InsuranceComponent))
3827        return false;
3828      InsuranceComponent o = (InsuranceComponent) other_;
3829      return compareDeep(focal, o.focal, true) && compareDeep(coverage, o.coverage, true)
3830          && compareDeep(preAuthRef, o.preAuthRef, true);
3831    }
3832
3833    @Override
3834    public boolean equalsShallow(Base other_) {
3835      if (!super.equalsShallow(other_))
3836        return false;
3837      if (!(other_ instanceof InsuranceComponent))
3838        return false;
3839      InsuranceComponent o = (InsuranceComponent) other_;
3840      return compareValues(focal, o.focal, true) && compareValues(preAuthRef, o.preAuthRef, true);
3841    }
3842
3843    public boolean isEmpty() {
3844      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(focal, coverage, preAuthRef);
3845    }
3846
3847    public String fhirType() {
3848      return "ExplanationOfBenefit.insurance";
3849
3850    }
3851
3852  }
3853
3854  @Block()
3855  public static class AccidentComponent extends BackboneElement implements IBaseBackboneElement {
3856    /**
3857     * Date of an accident event related to the products and services contained in
3858     * the claim.
3859     */
3860    @Child(name = "date", type = { DateType.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
3861    @Description(shortDefinition = "When the incident occurred", formalDefinition = "Date of an accident event  related to the products and services contained in the claim.")
3862    protected DateType date;
3863
3864    /**
3865     * The type or context of the accident event for the purposes of selection of
3866     * potential insurance coverages and determination of coordination between
3867     * insurers.
3868     */
3869    @Child(name = "type", type = {
3870        CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
3871    @Description(shortDefinition = "The nature of the accident", formalDefinition = "The type or context of the accident event for the purposes of selection of potential insurance coverages and determination of coordination between insurers.")
3872    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://terminology.hl7.org/ValueSet/v3-ActIncidentCode")
3873    protected CodeableConcept type;
3874
3875    /**
3876     * The physical location of the accident event.
3877     */
3878    @Child(name = "location", type = { Address.class,
3879        Location.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
3880    @Description(shortDefinition = "Where the event occurred", formalDefinition = "The physical location of the accident event.")
3881    protected Type location;
3882
3883    private static final long serialVersionUID = 622904984L;
3884
3885    /**
3886     * Constructor
3887     */
3888    public AccidentComponent() {
3889      super();
3890    }
3891
3892    /**
3893     * @return {@link #date} (Date of an accident event related to the products and
3894     *         services contained in the claim.). This is the underlying object with
3895     *         id, value and extensions. The accessor "getDate" gives direct access
3896     *         to the value
3897     */
3898    public DateType getDateElement() {
3899      if (this.date == null)
3900        if (Configuration.errorOnAutoCreate())
3901          throw new Error("Attempt to auto-create AccidentComponent.date");
3902        else if (Configuration.doAutoCreate())
3903          this.date = new DateType(); // bb
3904      return this.date;
3905    }
3906
3907    public boolean hasDateElement() {
3908      return this.date != null && !this.date.isEmpty();
3909    }
3910
3911    public boolean hasDate() {
3912      return this.date != null && !this.date.isEmpty();
3913    }
3914
3915    /**
3916     * @param value {@link #date} (Date of an accident event related to the products
3917     *              and services contained in the claim.). This is the underlying
3918     *              object with id, value and extensions. The accessor "getDate"
3919     *              gives direct access to the value
3920     */
3921    public AccidentComponent setDateElement(DateType value) {
3922      this.date = value;
3923      return this;
3924    }
3925
3926    /**
3927     * @return Date of an accident event related to the products and services
3928     *         contained in the claim.
3929     */
3930    public Date getDate() {
3931      return this.date == null ? null : this.date.getValue();
3932    }
3933
3934    /**
3935     * @param value Date of an accident event related to the products and services
3936     *              contained in the claim.
3937     */
3938    public AccidentComponent setDate(Date value) {
3939      if (value == null)
3940        this.date = null;
3941      else {
3942        if (this.date == null)
3943          this.date = new DateType();
3944        this.date.setValue(value);
3945      }
3946      return this;
3947    }
3948
3949    /**
3950     * @return {@link #type} (The type or context of the accident event for the
3951     *         purposes of selection of potential insurance coverages and
3952     *         determination of coordination between insurers.)
3953     */
3954    public CodeableConcept getType() {
3955      if (this.type == null)
3956        if (Configuration.errorOnAutoCreate())
3957          throw new Error("Attempt to auto-create AccidentComponent.type");
3958        else if (Configuration.doAutoCreate())
3959          this.type = new CodeableConcept(); // cc
3960      return this.type;
3961    }
3962
3963    public boolean hasType() {
3964      return this.type != null && !this.type.isEmpty();
3965    }
3966
3967    /**
3968     * @param value {@link #type} (The type or context of the accident event for the
3969     *              purposes of selection of potential insurance coverages and
3970     *              determination of coordination between insurers.)
3971     */
3972    public AccidentComponent setType(CodeableConcept value) {
3973      this.type = value;
3974      return this;
3975    }
3976
3977    /**
3978     * @return {@link #location} (The physical location of the accident event.)
3979     */
3980    public Type getLocation() {
3981      return this.location;
3982    }
3983
3984    /**
3985     * @return {@link #location} (The physical location of the accident event.)
3986     */
3987    public Address getLocationAddress() throws FHIRException {
3988      if (this.location == null)
3989        this.location = new Address();
3990      if (!(this.location instanceof Address))
3991        throw new FHIRException("Type mismatch: the type Address was expected, but "
3992            + this.location.getClass().getName() + " was encountered");
3993      return (Address) this.location;
3994    }
3995
3996    public boolean hasLocationAddress() {
3997      return this != null && this.location instanceof Address;
3998    }
3999
4000    /**
4001     * @return {@link #location} (The physical location of the accident event.)
4002     */
4003    public Reference getLocationReference() throws FHIRException {
4004      if (this.location == null)
4005        this.location = new Reference();
4006      if (!(this.location instanceof Reference))
4007        throw new FHIRException("Type mismatch: the type Reference was expected, but "
4008            + this.location.getClass().getName() + " was encountered");
4009      return (Reference) this.location;
4010    }
4011
4012    public boolean hasLocationReference() {
4013      return this != null && this.location instanceof Reference;
4014    }
4015
4016    public boolean hasLocation() {
4017      return this.location != null && !this.location.isEmpty();
4018    }
4019
4020    /**
4021     * @param value {@link #location} (The physical location of the accident event.)
4022     */
4023    public AccidentComponent setLocation(Type value) {
4024      if (value != null && !(value instanceof Address || value instanceof Reference))
4025        throw new Error("Not the right type for ExplanationOfBenefit.accident.location[x]: " + value.fhirType());
4026      this.location = value;
4027      return this;
4028    }
4029
4030    protected void listChildren(List<Property> children) {
4031      super.listChildren(children);
4032      children.add(new Property("date", "date",
4033          "Date of an accident event  related to the products and services contained in the claim.", 0, 1, date));
4034      children.add(new Property("type", "CodeableConcept",
4035          "The type or context of the accident event for the purposes of selection of potential insurance coverages and determination of coordination between insurers.",
4036          0, 1, type));
4037      children.add(new Property("location[x]", "Address|Reference(Location)",
4038          "The physical location of the accident event.", 0, 1, location));
4039    }
4040
4041    @Override
4042    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
4043      switch (_hash) {
4044      case 3076014:
4045        /* date */ return new Property("date", "date",
4046            "Date of an accident event  related to the products and services contained in the claim.", 0, 1, date);
4047      case 3575610:
4048        /* type */ return new Property("type", "CodeableConcept",
4049            "The type or context of the accident event for the purposes of selection of potential insurance coverages and determination of coordination between insurers.",
4050            0, 1, type);
4051      case 552316075:
4052        /* location[x] */ return new Property("location[x]", "Address|Reference(Location)",
4053            "The physical location of the accident event.", 0, 1, location);
4054      case 1901043637:
4055        /* location */ return new Property("location[x]", "Address|Reference(Location)",
4056            "The physical location of the accident event.", 0, 1, location);
4057      case -1280020865:
4058        /* locationAddress */ return new Property("location[x]", "Address|Reference(Location)",
4059            "The physical location of the accident event.", 0, 1, location);
4060      case 755866390:
4061        /* locationReference */ return new Property("location[x]", "Address|Reference(Location)",
4062            "The physical location of the accident event.", 0, 1, location);
4063      default:
4064        return super.getNamedProperty(_hash, _name, _checkValid);
4065      }
4066
4067    }
4068
4069    @Override
4070    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
4071      switch (hash) {
4072      case 3076014:
4073        /* date */ return this.date == null ? new Base[0] : new Base[] { this.date }; // DateType
4074      case 3575610:
4075        /* type */ return this.type == null ? new Base[0] : new Base[] { this.type }; // CodeableConcept
4076      case 1901043637:
4077        /* location */ return this.location == null ? new Base[0] : new Base[] { this.location }; // Type
4078      default:
4079        return super.getProperty(hash, name, checkValid);
4080      }
4081
4082    }
4083
4084    @Override
4085    public Base setProperty(int hash, String name, Base value) throws FHIRException {
4086      switch (hash) {
4087      case 3076014: // date
4088        this.date = castToDate(value); // DateType
4089        return value;
4090      case 3575610: // type
4091        this.type = castToCodeableConcept(value); // CodeableConcept
4092        return value;
4093      case 1901043637: // location
4094        this.location = castToType(value); // Type
4095        return value;
4096      default:
4097        return super.setProperty(hash, name, value);
4098      }
4099
4100    }
4101
4102    @Override
4103    public Base setProperty(String name, Base value) throws FHIRException {
4104      if (name.equals("date")) {
4105        this.date = castToDate(value); // DateType
4106      } else if (name.equals("type")) {
4107        this.type = castToCodeableConcept(value); // CodeableConcept
4108      } else if (name.equals("location[x]")) {
4109        this.location = castToType(value); // Type
4110      } else
4111        return super.setProperty(name, value);
4112      return value;
4113    }
4114
4115  @Override
4116  public void removeChild(String name, Base value) throws FHIRException {
4117      if (name.equals("date")) {
4118        this.date = null;
4119      } else if (name.equals("type")) {
4120        this.type = null;
4121      } else if (name.equals("location[x]")) {
4122        this.location = null;
4123      } else
4124        super.removeChild(name, value);
4125      
4126    }
4127
4128    @Override
4129    public Base makeProperty(int hash, String name) throws FHIRException {
4130      switch (hash) {
4131      case 3076014:
4132        return getDateElement();
4133      case 3575610:
4134        return getType();
4135      case 552316075:
4136        return getLocation();
4137      case 1901043637:
4138        return getLocation();
4139      default:
4140        return super.makeProperty(hash, name);
4141      }
4142
4143    }
4144
4145    @Override
4146    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
4147      switch (hash) {
4148      case 3076014:
4149        /* date */ return new String[] { "date" };
4150      case 3575610:
4151        /* type */ return new String[] { "CodeableConcept" };
4152      case 1901043637:
4153        /* location */ return new String[] { "Address", "Reference" };
4154      default:
4155        return super.getTypesForProperty(hash, name);
4156      }
4157
4158    }
4159
4160    @Override
4161    public Base addChild(String name) throws FHIRException {
4162      if (name.equals("date")) {
4163        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.date");
4164      } else if (name.equals("type")) {
4165        this.type = new CodeableConcept();
4166        return this.type;
4167      } else if (name.equals("locationAddress")) {
4168        this.location = new Address();
4169        return this.location;
4170      } else if (name.equals("locationReference")) {
4171        this.location = new Reference();
4172        return this.location;
4173      } else
4174        return super.addChild(name);
4175    }
4176
4177    public AccidentComponent copy() {
4178      AccidentComponent dst = new AccidentComponent();
4179      copyValues(dst);
4180      return dst;
4181    }
4182
4183    public void copyValues(AccidentComponent dst) {
4184      super.copyValues(dst);
4185      dst.date = date == null ? null : date.copy();
4186      dst.type = type == null ? null : type.copy();
4187      dst.location = location == null ? null : location.copy();
4188    }
4189
4190    @Override
4191    public boolean equalsDeep(Base other_) {
4192      if (!super.equalsDeep(other_))
4193        return false;
4194      if (!(other_ instanceof AccidentComponent))
4195        return false;
4196      AccidentComponent o = (AccidentComponent) other_;
4197      return compareDeep(date, o.date, true) && compareDeep(type, o.type, true)
4198          && compareDeep(location, o.location, true);
4199    }
4200
4201    @Override
4202    public boolean equalsShallow(Base other_) {
4203      if (!super.equalsShallow(other_))
4204        return false;
4205      if (!(other_ instanceof AccidentComponent))
4206        return false;
4207      AccidentComponent o = (AccidentComponent) other_;
4208      return compareValues(date, o.date, true);
4209    }
4210
4211    public boolean isEmpty() {
4212      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(date, type, location);
4213    }
4214
4215    public String fhirType() {
4216      return "ExplanationOfBenefit.accident";
4217
4218    }
4219
4220  }
4221
4222  @Block()
4223  public static class ItemComponent extends BackboneElement implements IBaseBackboneElement {
4224    /**
4225     * A number to uniquely identify item entries.
4226     */
4227    @Child(name = "sequence", type = {
4228        PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
4229    @Description(shortDefinition = "Item instance identifier", formalDefinition = "A number to uniquely identify item entries.")
4230    protected PositiveIntType sequence;
4231
4232    /**
4233     * Care team members related to this service or product.
4234     */
4235    @Child(name = "careTeamSequence", type = {
4236        PositiveIntType.class }, order = 2, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4237    @Description(shortDefinition = "Applicable care team members", formalDefinition = "Care team members related to this service or product.")
4238    protected List<PositiveIntType> careTeamSequence;
4239
4240    /**
4241     * Diagnoses applicable for this service or product.
4242     */
4243    @Child(name = "diagnosisSequence", type = {
4244        PositiveIntType.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4245    @Description(shortDefinition = "Applicable diagnoses", formalDefinition = "Diagnoses applicable for this service or product.")
4246    protected List<PositiveIntType> diagnosisSequence;
4247
4248    /**
4249     * Procedures applicable for this service or product.
4250     */
4251    @Child(name = "procedureSequence", type = {
4252        PositiveIntType.class }, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4253    @Description(shortDefinition = "Applicable procedures", formalDefinition = "Procedures applicable for this service or product.")
4254    protected List<PositiveIntType> procedureSequence;
4255
4256    /**
4257     * Exceptions, special conditions and supporting information applicable for this
4258     * service or product.
4259     */
4260    @Child(name = "informationSequence", type = {
4261        PositiveIntType.class }, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4262    @Description(shortDefinition = "Applicable exception and supporting information", formalDefinition = "Exceptions, special conditions and supporting information applicable for this service or product.")
4263    protected List<PositiveIntType> informationSequence;
4264
4265    /**
4266     * The type of revenue or cost center providing the product and/or service.
4267     */
4268    @Child(name = "revenue", type = {
4269        CodeableConcept.class }, order = 6, min = 0, max = 1, modifier = false, summary = false)
4270    @Description(shortDefinition = "Revenue or cost center code", formalDefinition = "The type of revenue or cost center providing the product and/or service.")
4271    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-revenue-center")
4272    protected CodeableConcept revenue;
4273
4274    /**
4275     * Code to identify the general type of benefits under which products and
4276     * services are provided.
4277     */
4278    @Child(name = "category", type = {
4279        CodeableConcept.class }, order = 7, min = 0, max = 1, modifier = false, summary = false)
4280    @Description(shortDefinition = "Benefit classification", formalDefinition = "Code to identify the general type of benefits under which products and services are provided.")
4281    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-benefitcategory")
4282    protected CodeableConcept category;
4283
4284    /**
4285     * When the value is a group code then this item collects a set of related claim
4286     * details, otherwise this contains the product, service, drug or other billing
4287     * code for the item.
4288     */
4289    @Child(name = "productOrService", type = {
4290        CodeableConcept.class }, order = 8, min = 1, max = 1, modifier = false, summary = false)
4291    @Description(shortDefinition = "Billing, service, product, or drug code", formalDefinition = "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.")
4292    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-uscls")
4293    protected CodeableConcept productOrService;
4294
4295    /**
4296     * Item typification or modifiers codes to convey additional context for the
4297     * product or service.
4298     */
4299    @Child(name = "modifier", type = {
4300        CodeableConcept.class }, order = 9, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4301    @Description(shortDefinition = "Product or service billing modifiers", formalDefinition = "Item typification or modifiers codes to convey additional context for the product or service.")
4302    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-modifiers")
4303    protected List<CodeableConcept> modifier;
4304
4305    /**
4306     * Identifies the program under which this may be recovered.
4307     */
4308    @Child(name = "programCode", type = {
4309        CodeableConcept.class }, order = 10, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4310    @Description(shortDefinition = "Program the product or service is provided under", formalDefinition = "Identifies the program under which this may be recovered.")
4311    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-program-code")
4312    protected List<CodeableConcept> programCode;
4313
4314    /**
4315     * The date or dates when the service or product was supplied, performed or
4316     * completed.
4317     */
4318    @Child(name = "serviced", type = { DateType.class,
4319        Period.class }, order = 11, min = 0, max = 1, modifier = false, summary = false)
4320    @Description(shortDefinition = "Date or dates of service or product delivery", formalDefinition = "The date or dates when the service or product was supplied, performed or completed.")
4321    protected Type serviced;
4322
4323    /**
4324     * Where the product or service was provided.
4325     */
4326    @Child(name = "location", type = { CodeableConcept.class, Address.class,
4327        Location.class }, order = 12, min = 0, max = 1, modifier = false, summary = false)
4328    @Description(shortDefinition = "Place of service or where product was supplied", formalDefinition = "Where the product or service was provided.")
4329    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-place")
4330    protected Type location;
4331
4332    /**
4333     * The number of repetitions of a service or product.
4334     */
4335    @Child(name = "quantity", type = {
4336        Quantity.class }, order = 13, min = 0, max = 1, modifier = false, summary = false)
4337    @Description(shortDefinition = "Count of products or services", formalDefinition = "The number of repetitions of a service or product.")
4338    protected Quantity quantity;
4339
4340    /**
4341     * If the item is not a group then this is the fee for the product or service,
4342     * otherwise this is the total of the fees for the details of the group.
4343     */
4344    @Child(name = "unitPrice", type = { Money.class }, order = 14, min = 0, max = 1, modifier = false, summary = false)
4345    @Description(shortDefinition = "Fee, charge or cost per item", formalDefinition = "If the item is not a group then this is the fee for the product or service, otherwise this is the total of the fees for the details of the group.")
4346    protected Money unitPrice;
4347
4348    /**
4349     * A real number that represents a multiplier used in determining the overall
4350     * value of services delivered and/or goods received. The concept of a Factor
4351     * allows for a discount or surcharge multiplier to be applied to a monetary
4352     * amount.
4353     */
4354    @Child(name = "factor", type = {
4355        DecimalType.class }, order = 15, min = 0, max = 1, modifier = false, summary = false)
4356    @Description(shortDefinition = "Price scaling factor", formalDefinition = "A real number that represents a multiplier used in determining the overall value of services delivered and/or goods received. The concept of a Factor allows for a discount or surcharge multiplier to be applied to a monetary amount.")
4357    protected DecimalType factor;
4358
4359    /**
4360     * The quantity times the unit price for an additional service or product or
4361     * charge.
4362     */
4363    @Child(name = "net", type = { Money.class }, order = 16, min = 0, max = 1, modifier = false, summary = false)
4364    @Description(shortDefinition = "Total item cost", formalDefinition = "The quantity times the unit price for an additional service or product or charge.")
4365    protected Money net;
4366
4367    /**
4368     * Unique Device Identifiers associated with this line item.
4369     */
4370    @Child(name = "udi", type = {
4371        Device.class }, order = 17, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4372    @Description(shortDefinition = "Unique device identifier", formalDefinition = "Unique Device Identifiers associated with this line item.")
4373    protected List<Reference> udi;
4374    /**
4375     * The actual objects that are the target of the reference (Unique Device
4376     * Identifiers associated with this line item.)
4377     */
4378    protected List<Device> udiTarget;
4379
4380    /**
4381     * Physical service site on the patient (limb, tooth, etc.).
4382     */
4383    @Child(name = "bodySite", type = {
4384        CodeableConcept.class }, order = 18, min = 0, max = 1, modifier = false, summary = false)
4385    @Description(shortDefinition = "Anatomical location", formalDefinition = "Physical service site on the patient (limb, tooth, etc.).")
4386    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/tooth")
4387    protected CodeableConcept bodySite;
4388
4389    /**
4390     * A region or surface of the bodySite, e.g. limb region or tooth surface(s).
4391     */
4392    @Child(name = "subSite", type = {
4393        CodeableConcept.class }, order = 19, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4394    @Description(shortDefinition = "Anatomical sub-location", formalDefinition = "A region or surface of the bodySite, e.g. limb region or tooth surface(s).")
4395    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/surface")
4396    protected List<CodeableConcept> subSite;
4397
4398    /**
4399     * A billed item may include goods or services provided in multiple encounters.
4400     */
4401    @Child(name = "encounter", type = {
4402        Encounter.class }, order = 20, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4403    @Description(shortDefinition = "Encounters related to this billed item", formalDefinition = "A billed item may include goods or services provided in multiple encounters.")
4404    protected List<Reference> encounter;
4405    /**
4406     * The actual objects that are the target of the reference (A billed item may
4407     * include goods or services provided in multiple encounters.)
4408     */
4409    protected List<Encounter> encounterTarget;
4410
4411    /**
4412     * The numbers associated with notes below which apply to the adjudication of
4413     * this item.
4414     */
4415    @Child(name = "noteNumber", type = {
4416        PositiveIntType.class }, order = 21, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4417    @Description(shortDefinition = "Applicable note numbers", formalDefinition = "The numbers associated with notes below which apply to the adjudication of this item.")
4418    protected List<PositiveIntType> noteNumber;
4419
4420    /**
4421     * If this item is a group then the values here are a summary of the
4422     * adjudication of the detail items. If this item is a simple product or service
4423     * then this is the result of the adjudication of this item.
4424     */
4425    @Child(name = "adjudication", type = {}, order = 22, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4426    @Description(shortDefinition = "Adjudication details", formalDefinition = "If this item is a group then the values here are a summary of the adjudication of the detail items. If this item is a simple product or service then this is the result of the adjudication of this item.")
4427    protected List<AdjudicationComponent> adjudication;
4428
4429    /**
4430     * Second-tier of goods and services.
4431     */
4432    @Child(name = "detail", type = {}, order = 23, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
4433    @Description(shortDefinition = "Additional items", formalDefinition = "Second-tier of goods and services.")
4434    protected List<DetailComponent> detail;
4435
4436    private static final long serialVersionUID = 67419471L;
4437
4438    /**
4439     * Constructor
4440     */
4441    public ItemComponent() {
4442      super();
4443    }
4444
4445    /**
4446     * Constructor
4447     */
4448    public ItemComponent(PositiveIntType sequence, CodeableConcept productOrService) {
4449      super();
4450      this.sequence = sequence;
4451      this.productOrService = productOrService;
4452    }
4453
4454    /**
4455     * @return {@link #sequence} (A number to uniquely identify item entries.). This
4456     *         is the underlying object with id, value and extensions. The accessor
4457     *         "getSequence" gives direct access to the value
4458     */
4459    public PositiveIntType getSequenceElement() {
4460      if (this.sequence == null)
4461        if (Configuration.errorOnAutoCreate())
4462          throw new Error("Attempt to auto-create ItemComponent.sequence");
4463        else if (Configuration.doAutoCreate())
4464          this.sequence = new PositiveIntType(); // bb
4465      return this.sequence;
4466    }
4467
4468    public boolean hasSequenceElement() {
4469      return this.sequence != null && !this.sequence.isEmpty();
4470    }
4471
4472    public boolean hasSequence() {
4473      return this.sequence != null && !this.sequence.isEmpty();
4474    }
4475
4476    /**
4477     * @param value {@link #sequence} (A number to uniquely identify item entries.).
4478     *              This is the underlying object with id, value and extensions. The
4479     *              accessor "getSequence" gives direct access to the value
4480     */
4481    public ItemComponent setSequenceElement(PositiveIntType value) {
4482      this.sequence = value;
4483      return this;
4484    }
4485
4486    /**
4487     * @return A number to uniquely identify item entries.
4488     */
4489    public int getSequence() {
4490      return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
4491    }
4492
4493    /**
4494     * @param value A number to uniquely identify item entries.
4495     */
4496    public ItemComponent setSequence(int value) {
4497      if (this.sequence == null)
4498        this.sequence = new PositiveIntType();
4499      this.sequence.setValue(value);
4500      return this;
4501    }
4502
4503    /**
4504     * @return {@link #careTeamSequence} (Care team members related to this service
4505     *         or product.)
4506     */
4507    public List<PositiveIntType> getCareTeamSequence() {
4508      if (this.careTeamSequence == null)
4509        this.careTeamSequence = new ArrayList<PositiveIntType>();
4510      return this.careTeamSequence;
4511    }
4512
4513    /**
4514     * @return Returns a reference to <code>this</code> for easy method chaining
4515     */
4516    public ItemComponent setCareTeamSequence(List<PositiveIntType> theCareTeamSequence) {
4517      this.careTeamSequence = theCareTeamSequence;
4518      return this;
4519    }
4520
4521    public boolean hasCareTeamSequence() {
4522      if (this.careTeamSequence == null)
4523        return false;
4524      for (PositiveIntType item : this.careTeamSequence)
4525        if (!item.isEmpty())
4526          return true;
4527      return false;
4528    }
4529
4530    /**
4531     * @return {@link #careTeamSequence} (Care team members related to this service
4532     *         or product.)
4533     */
4534    public PositiveIntType addCareTeamSequenceElement() {// 2
4535      PositiveIntType t = new PositiveIntType();
4536      if (this.careTeamSequence == null)
4537        this.careTeamSequence = new ArrayList<PositiveIntType>();
4538      this.careTeamSequence.add(t);
4539      return t;
4540    }
4541
4542    /**
4543     * @param value {@link #careTeamSequence} (Care team members related to this
4544     *              service or product.)
4545     */
4546    public ItemComponent addCareTeamSequence(int value) { // 1
4547      PositiveIntType t = new PositiveIntType();
4548      t.setValue(value);
4549      if (this.careTeamSequence == null)
4550        this.careTeamSequence = new ArrayList<PositiveIntType>();
4551      this.careTeamSequence.add(t);
4552      return this;
4553    }
4554
4555    /**
4556     * @param value {@link #careTeamSequence} (Care team members related to this
4557     *              service or product.)
4558     */
4559    public boolean hasCareTeamSequence(int value) {
4560      if (this.careTeamSequence == null)
4561        return false;
4562      for (PositiveIntType v : this.careTeamSequence)
4563        if (v.getValue().equals(value)) // positiveInt
4564          return true;
4565      return false;
4566    }
4567
4568    /**
4569     * @return {@link #diagnosisSequence} (Diagnoses applicable for this service or
4570     *         product.)
4571     */
4572    public List<PositiveIntType> getDiagnosisSequence() {
4573      if (this.diagnosisSequence == null)
4574        this.diagnosisSequence = new ArrayList<PositiveIntType>();
4575      return this.diagnosisSequence;
4576    }
4577
4578    /**
4579     * @return Returns a reference to <code>this</code> for easy method chaining
4580     */
4581    public ItemComponent setDiagnosisSequence(List<PositiveIntType> theDiagnosisSequence) {
4582      this.diagnosisSequence = theDiagnosisSequence;
4583      return this;
4584    }
4585
4586    public boolean hasDiagnosisSequence() {
4587      if (this.diagnosisSequence == null)
4588        return false;
4589      for (PositiveIntType item : this.diagnosisSequence)
4590        if (!item.isEmpty())
4591          return true;
4592      return false;
4593    }
4594
4595    /**
4596     * @return {@link #diagnosisSequence} (Diagnoses applicable for this service or
4597     *         product.)
4598     */
4599    public PositiveIntType addDiagnosisSequenceElement() {// 2
4600      PositiveIntType t = new PositiveIntType();
4601      if (this.diagnosisSequence == null)
4602        this.diagnosisSequence = new ArrayList<PositiveIntType>();
4603      this.diagnosisSequence.add(t);
4604      return t;
4605    }
4606
4607    /**
4608     * @param value {@link #diagnosisSequence} (Diagnoses applicable for this
4609     *              service or product.)
4610     */
4611    public ItemComponent addDiagnosisSequence(int value) { // 1
4612      PositiveIntType t = new PositiveIntType();
4613      t.setValue(value);
4614      if (this.diagnosisSequence == null)
4615        this.diagnosisSequence = new ArrayList<PositiveIntType>();
4616      this.diagnosisSequence.add(t);
4617      return this;
4618    }
4619
4620    /**
4621     * @param value {@link #diagnosisSequence} (Diagnoses applicable for this
4622     *              service or product.)
4623     */
4624    public boolean hasDiagnosisSequence(int value) {
4625      if (this.diagnosisSequence == null)
4626        return false;
4627      for (PositiveIntType v : this.diagnosisSequence)
4628        if (v.getValue().equals(value)) // positiveInt
4629          return true;
4630      return false;
4631    }
4632
4633    /**
4634     * @return {@link #procedureSequence} (Procedures applicable for this service or
4635     *         product.)
4636     */
4637    public List<PositiveIntType> getProcedureSequence() {
4638      if (this.procedureSequence == null)
4639        this.procedureSequence = new ArrayList<PositiveIntType>();
4640      return this.procedureSequence;
4641    }
4642
4643    /**
4644     * @return Returns a reference to <code>this</code> for easy method chaining
4645     */
4646    public ItemComponent setProcedureSequence(List<PositiveIntType> theProcedureSequence) {
4647      this.procedureSequence = theProcedureSequence;
4648      return this;
4649    }
4650
4651    public boolean hasProcedureSequence() {
4652      if (this.procedureSequence == null)
4653        return false;
4654      for (PositiveIntType item : this.procedureSequence)
4655        if (!item.isEmpty())
4656          return true;
4657      return false;
4658    }
4659
4660    /**
4661     * @return {@link #procedureSequence} (Procedures applicable for this service or
4662     *         product.)
4663     */
4664    public PositiveIntType addProcedureSequenceElement() {// 2
4665      PositiveIntType t = new PositiveIntType();
4666      if (this.procedureSequence == null)
4667        this.procedureSequence = new ArrayList<PositiveIntType>();
4668      this.procedureSequence.add(t);
4669      return t;
4670    }
4671
4672    /**
4673     * @param value {@link #procedureSequence} (Procedures applicable for this
4674     *              service or product.)
4675     */
4676    public ItemComponent addProcedureSequence(int value) { // 1
4677      PositiveIntType t = new PositiveIntType();
4678      t.setValue(value);
4679      if (this.procedureSequence == null)
4680        this.procedureSequence = new ArrayList<PositiveIntType>();
4681      this.procedureSequence.add(t);
4682      return this;
4683    }
4684
4685    /**
4686     * @param value {@link #procedureSequence} (Procedures applicable for this
4687     *              service or product.)
4688     */
4689    public boolean hasProcedureSequence(int value) {
4690      if (this.procedureSequence == null)
4691        return false;
4692      for (PositiveIntType v : this.procedureSequence)
4693        if (v.getValue().equals(value)) // positiveInt
4694          return true;
4695      return false;
4696    }
4697
4698    /**
4699     * @return {@link #informationSequence} (Exceptions, special conditions and
4700     *         supporting information applicable for this service or product.)
4701     */
4702    public List<PositiveIntType> getInformationSequence() {
4703      if (this.informationSequence == null)
4704        this.informationSequence = new ArrayList<PositiveIntType>();
4705      return this.informationSequence;
4706    }
4707
4708    /**
4709     * @return Returns a reference to <code>this</code> for easy method chaining
4710     */
4711    public ItemComponent setInformationSequence(List<PositiveIntType> theInformationSequence) {
4712      this.informationSequence = theInformationSequence;
4713      return this;
4714    }
4715
4716    public boolean hasInformationSequence() {
4717      if (this.informationSequence == null)
4718        return false;
4719      for (PositiveIntType item : this.informationSequence)
4720        if (!item.isEmpty())
4721          return true;
4722      return false;
4723    }
4724
4725    /**
4726     * @return {@link #informationSequence} (Exceptions, special conditions and
4727     *         supporting information applicable for this service or product.)
4728     */
4729    public PositiveIntType addInformationSequenceElement() {// 2
4730      PositiveIntType t = new PositiveIntType();
4731      if (this.informationSequence == null)
4732        this.informationSequence = new ArrayList<PositiveIntType>();
4733      this.informationSequence.add(t);
4734      return t;
4735    }
4736
4737    /**
4738     * @param value {@link #informationSequence} (Exceptions, special conditions and
4739     *              supporting information applicable for this service or product.)
4740     */
4741    public ItemComponent addInformationSequence(int value) { // 1
4742      PositiveIntType t = new PositiveIntType();
4743      t.setValue(value);
4744      if (this.informationSequence == null)
4745        this.informationSequence = new ArrayList<PositiveIntType>();
4746      this.informationSequence.add(t);
4747      return this;
4748    }
4749
4750    /**
4751     * @param value {@link #informationSequence} (Exceptions, special conditions and
4752     *              supporting information applicable for this service or product.)
4753     */
4754    public boolean hasInformationSequence(int value) {
4755      if (this.informationSequence == null)
4756        return false;
4757      for (PositiveIntType v : this.informationSequence)
4758        if (v.getValue().equals(value)) // positiveInt
4759          return true;
4760      return false;
4761    }
4762
4763    /**
4764     * @return {@link #revenue} (The type of revenue or cost center providing the
4765     *         product and/or service.)
4766     */
4767    public CodeableConcept getRevenue() {
4768      if (this.revenue == null)
4769        if (Configuration.errorOnAutoCreate())
4770          throw new Error("Attempt to auto-create ItemComponent.revenue");
4771        else if (Configuration.doAutoCreate())
4772          this.revenue = new CodeableConcept(); // cc
4773      return this.revenue;
4774    }
4775
4776    public boolean hasRevenue() {
4777      return this.revenue != null && !this.revenue.isEmpty();
4778    }
4779
4780    /**
4781     * @param value {@link #revenue} (The type of revenue or cost center providing
4782     *              the product and/or service.)
4783     */
4784    public ItemComponent setRevenue(CodeableConcept value) {
4785      this.revenue = value;
4786      return this;
4787    }
4788
4789    /**
4790     * @return {@link #category} (Code to identify the general type of benefits
4791     *         under which products and services are provided.)
4792     */
4793    public CodeableConcept getCategory() {
4794      if (this.category == null)
4795        if (Configuration.errorOnAutoCreate())
4796          throw new Error("Attempt to auto-create ItemComponent.category");
4797        else if (Configuration.doAutoCreate())
4798          this.category = new CodeableConcept(); // cc
4799      return this.category;
4800    }
4801
4802    public boolean hasCategory() {
4803      return this.category != null && !this.category.isEmpty();
4804    }
4805
4806    /**
4807     * @param value {@link #category} (Code to identify the general type of benefits
4808     *              under which products and services are provided.)
4809     */
4810    public ItemComponent setCategory(CodeableConcept value) {
4811      this.category = value;
4812      return this;
4813    }
4814
4815    /**
4816     * @return {@link #productOrService} (When the value is a group code then this
4817     *         item collects a set of related claim details, otherwise this contains
4818     *         the product, service, drug or other billing code for the item.)
4819     */
4820    public CodeableConcept getProductOrService() {
4821      if (this.productOrService == null)
4822        if (Configuration.errorOnAutoCreate())
4823          throw new Error("Attempt to auto-create ItemComponent.productOrService");
4824        else if (Configuration.doAutoCreate())
4825          this.productOrService = new CodeableConcept(); // cc
4826      return this.productOrService;
4827    }
4828
4829    public boolean hasProductOrService() {
4830      return this.productOrService != null && !this.productOrService.isEmpty();
4831    }
4832
4833    /**
4834     * @param value {@link #productOrService} (When the value is a group code then
4835     *              this item collects a set of related claim details, otherwise
4836     *              this contains the product, service, drug or other billing code
4837     *              for the item.)
4838     */
4839    public ItemComponent setProductOrService(CodeableConcept value) {
4840      this.productOrService = value;
4841      return this;
4842    }
4843
4844    /**
4845     * @return {@link #modifier} (Item typification or modifiers codes to convey
4846     *         additional context for the product or service.)
4847     */
4848    public List<CodeableConcept> getModifier() {
4849      if (this.modifier == null)
4850        this.modifier = new ArrayList<CodeableConcept>();
4851      return this.modifier;
4852    }
4853
4854    /**
4855     * @return Returns a reference to <code>this</code> for easy method chaining
4856     */
4857    public ItemComponent setModifier(List<CodeableConcept> theModifier) {
4858      this.modifier = theModifier;
4859      return this;
4860    }
4861
4862    public boolean hasModifier() {
4863      if (this.modifier == null)
4864        return false;
4865      for (CodeableConcept item : this.modifier)
4866        if (!item.isEmpty())
4867          return true;
4868      return false;
4869    }
4870
4871    public CodeableConcept addModifier() { // 3
4872      CodeableConcept t = new CodeableConcept();
4873      if (this.modifier == null)
4874        this.modifier = new ArrayList<CodeableConcept>();
4875      this.modifier.add(t);
4876      return t;
4877    }
4878
4879    public ItemComponent addModifier(CodeableConcept t) { // 3
4880      if (t == null)
4881        return this;
4882      if (this.modifier == null)
4883        this.modifier = new ArrayList<CodeableConcept>();
4884      this.modifier.add(t);
4885      return this;
4886    }
4887
4888    /**
4889     * @return The first repetition of repeating field {@link #modifier}, creating
4890     *         it if it does not already exist
4891     */
4892    public CodeableConcept getModifierFirstRep() {
4893      if (getModifier().isEmpty()) {
4894        addModifier();
4895      }
4896      return getModifier().get(0);
4897    }
4898
4899    /**
4900     * @return {@link #programCode} (Identifies the program under which this may be
4901     *         recovered.)
4902     */
4903    public List<CodeableConcept> getProgramCode() {
4904      if (this.programCode == null)
4905        this.programCode = new ArrayList<CodeableConcept>();
4906      return this.programCode;
4907    }
4908
4909    /**
4910     * @return Returns a reference to <code>this</code> for easy method chaining
4911     */
4912    public ItemComponent setProgramCode(List<CodeableConcept> theProgramCode) {
4913      this.programCode = theProgramCode;
4914      return this;
4915    }
4916
4917    public boolean hasProgramCode() {
4918      if (this.programCode == null)
4919        return false;
4920      for (CodeableConcept item : this.programCode)
4921        if (!item.isEmpty())
4922          return true;
4923      return false;
4924    }
4925
4926    public CodeableConcept addProgramCode() { // 3
4927      CodeableConcept t = new CodeableConcept();
4928      if (this.programCode == null)
4929        this.programCode = new ArrayList<CodeableConcept>();
4930      this.programCode.add(t);
4931      return t;
4932    }
4933
4934    public ItemComponent addProgramCode(CodeableConcept t) { // 3
4935      if (t == null)
4936        return this;
4937      if (this.programCode == null)
4938        this.programCode = new ArrayList<CodeableConcept>();
4939      this.programCode.add(t);
4940      return this;
4941    }
4942
4943    /**
4944     * @return The first repetition of repeating field {@link #programCode},
4945     *         creating it if it does not already exist
4946     */
4947    public CodeableConcept getProgramCodeFirstRep() {
4948      if (getProgramCode().isEmpty()) {
4949        addProgramCode();
4950      }
4951      return getProgramCode().get(0);
4952    }
4953
4954    /**
4955     * @return {@link #serviced} (The date or dates when the service or product was
4956     *         supplied, performed or completed.)
4957     */
4958    public Type getServiced() {
4959      return this.serviced;
4960    }
4961
4962    /**
4963     * @return {@link #serviced} (The date or dates when the service or product was
4964     *         supplied, performed or completed.)
4965     */
4966    public DateType getServicedDateType() throws FHIRException {
4967      if (this.serviced == null)
4968        this.serviced = new DateType();
4969      if (!(this.serviced instanceof DateType))
4970        throw new FHIRException("Type mismatch: the type DateType was expected, but "
4971            + this.serviced.getClass().getName() + " was encountered");
4972      return (DateType) this.serviced;
4973    }
4974
4975    public boolean hasServicedDateType() {
4976      return this != null && this.serviced instanceof DateType;
4977    }
4978
4979    /**
4980     * @return {@link #serviced} (The date or dates when the service or product was
4981     *         supplied, performed or completed.)
4982     */
4983    public Period getServicedPeriod() throws FHIRException {
4984      if (this.serviced == null)
4985        this.serviced = new Period();
4986      if (!(this.serviced instanceof Period))
4987        throw new FHIRException("Type mismatch: the type Period was expected, but " + this.serviced.getClass().getName()
4988            + " was encountered");
4989      return (Period) this.serviced;
4990    }
4991
4992    public boolean hasServicedPeriod() {
4993      return this != null && this.serviced instanceof Period;
4994    }
4995
4996    public boolean hasServiced() {
4997      return this.serviced != null && !this.serviced.isEmpty();
4998    }
4999
5000    /**
5001     * @param value {@link #serviced} (The date or dates when the service or product
5002     *              was supplied, performed or completed.)
5003     */
5004    public ItemComponent setServiced(Type value) {
5005      if (value != null && !(value instanceof DateType || value instanceof Period))
5006        throw new Error("Not the right type for ExplanationOfBenefit.item.serviced[x]: " + value.fhirType());
5007      this.serviced = value;
5008      return this;
5009    }
5010
5011    /**
5012     * @return {@link #location} (Where the product or service was provided.)
5013     */
5014    public Type getLocation() {
5015      return this.location;
5016    }
5017
5018    /**
5019     * @return {@link #location} (Where the product or service was provided.)
5020     */
5021    public CodeableConcept getLocationCodeableConcept() throws FHIRException {
5022      if (this.location == null)
5023        this.location = new CodeableConcept();
5024      if (!(this.location instanceof CodeableConcept))
5025        throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "
5026            + this.location.getClass().getName() + " was encountered");
5027      return (CodeableConcept) this.location;
5028    }
5029
5030    public boolean hasLocationCodeableConcept() {
5031      return this != null && this.location instanceof CodeableConcept;
5032    }
5033
5034    /**
5035     * @return {@link #location} (Where the product or service was provided.)
5036     */
5037    public Address getLocationAddress() throws FHIRException {
5038      if (this.location == null)
5039        this.location = new Address();
5040      if (!(this.location instanceof Address))
5041        throw new FHIRException("Type mismatch: the type Address was expected, but "
5042            + this.location.getClass().getName() + " was encountered");
5043      return (Address) this.location;
5044    }
5045
5046    public boolean hasLocationAddress() {
5047      return this != null && this.location instanceof Address;
5048    }
5049
5050    /**
5051     * @return {@link #location} (Where the product or service was provided.)
5052     */
5053    public Reference getLocationReference() throws FHIRException {
5054      if (this.location == null)
5055        this.location = new Reference();
5056      if (!(this.location instanceof Reference))
5057        throw new FHIRException("Type mismatch: the type Reference was expected, but "
5058            + this.location.getClass().getName() + " was encountered");
5059      return (Reference) this.location;
5060    }
5061
5062    public boolean hasLocationReference() {
5063      return this != null && this.location instanceof Reference;
5064    }
5065
5066    public boolean hasLocation() {
5067      return this.location != null && !this.location.isEmpty();
5068    }
5069
5070    /**
5071     * @param value {@link #location} (Where the product or service was provided.)
5072     */
5073    public ItemComponent setLocation(Type value) {
5074      if (value != null
5075          && !(value instanceof CodeableConcept || value instanceof Address || value instanceof Reference))
5076        throw new Error("Not the right type for ExplanationOfBenefit.item.location[x]: " + value.fhirType());
5077      this.location = value;
5078      return this;
5079    }
5080
5081    /**
5082     * @return {@link #quantity} (The number of repetitions of a service or
5083     *         product.)
5084     */
5085    public Quantity getQuantity() {
5086      if (this.quantity == null)
5087        if (Configuration.errorOnAutoCreate())
5088          throw new Error("Attempt to auto-create ItemComponent.quantity");
5089        else if (Configuration.doAutoCreate())
5090          this.quantity = new Quantity(); // cc
5091      return this.quantity;
5092    }
5093
5094    public boolean hasQuantity() {
5095      return this.quantity != null && !this.quantity.isEmpty();
5096    }
5097
5098    /**
5099     * @param value {@link #quantity} (The number of repetitions of a service or
5100     *              product.)
5101     */
5102    public ItemComponent setQuantity(Quantity value) {
5103      this.quantity = value;
5104      return this;
5105    }
5106
5107    /**
5108     * @return {@link #unitPrice} (If the item is not a group then this is the fee
5109     *         for the product or service, otherwise this is the total of the fees
5110     *         for the details of the group.)
5111     */
5112    public Money getUnitPrice() {
5113      if (this.unitPrice == null)
5114        if (Configuration.errorOnAutoCreate())
5115          throw new Error("Attempt to auto-create ItemComponent.unitPrice");
5116        else if (Configuration.doAutoCreate())
5117          this.unitPrice = new Money(); // cc
5118      return this.unitPrice;
5119    }
5120
5121    public boolean hasUnitPrice() {
5122      return this.unitPrice != null && !this.unitPrice.isEmpty();
5123    }
5124
5125    /**
5126     * @param value {@link #unitPrice} (If the item is not a group then this is the
5127     *              fee for the product or service, otherwise this is the total of
5128     *              the fees for the details of the group.)
5129     */
5130    public ItemComponent setUnitPrice(Money value) {
5131      this.unitPrice = value;
5132      return this;
5133    }
5134
5135    /**
5136     * @return {@link #factor} (A real number that represents a multiplier used in
5137     *         determining the overall value of services delivered and/or goods
5138     *         received. The concept of a Factor allows for a discount or surcharge
5139     *         multiplier to be applied to a monetary amount.). This is the
5140     *         underlying object with id, value and extensions. The accessor
5141     *         "getFactor" gives direct access to the value
5142     */
5143    public DecimalType getFactorElement() {
5144      if (this.factor == null)
5145        if (Configuration.errorOnAutoCreate())
5146          throw new Error("Attempt to auto-create ItemComponent.factor");
5147        else if (Configuration.doAutoCreate())
5148          this.factor = new DecimalType(); // bb
5149      return this.factor;
5150    }
5151
5152    public boolean hasFactorElement() {
5153      return this.factor != null && !this.factor.isEmpty();
5154    }
5155
5156    public boolean hasFactor() {
5157      return this.factor != null && !this.factor.isEmpty();
5158    }
5159
5160    /**
5161     * @param value {@link #factor} (A real number that represents a multiplier used
5162     *              in determining the overall value of services delivered and/or
5163     *              goods received. The concept of a Factor allows for a discount or
5164     *              surcharge multiplier to be applied to a monetary amount.). This
5165     *              is the underlying object with id, value and extensions. The
5166     *              accessor "getFactor" gives direct access to the value
5167     */
5168    public ItemComponent setFactorElement(DecimalType value) {
5169      this.factor = value;
5170      return this;
5171    }
5172
5173    /**
5174     * @return A real number that represents a multiplier used in determining the
5175     *         overall value of services delivered and/or goods received. The
5176     *         concept of a Factor allows for a discount or surcharge multiplier to
5177     *         be applied to a monetary amount.
5178     */
5179    public BigDecimal getFactor() {
5180      return this.factor == null ? null : this.factor.getValue();
5181    }
5182
5183    /**
5184     * @param value A real number that represents a multiplier used in determining
5185     *              the overall value of services delivered and/or goods received.
5186     *              The concept of a Factor allows for a discount or surcharge
5187     *              multiplier to be applied to a monetary amount.
5188     */
5189    public ItemComponent setFactor(BigDecimal value) {
5190      if (value == null)
5191        this.factor = null;
5192      else {
5193        if (this.factor == null)
5194          this.factor = new DecimalType();
5195        this.factor.setValue(value);
5196      }
5197      return this;
5198    }
5199
5200    /**
5201     * @param value A real number that represents a multiplier used in determining
5202     *              the overall value of services delivered and/or goods received.
5203     *              The concept of a Factor allows for a discount or surcharge
5204     *              multiplier to be applied to a monetary amount.
5205     */
5206    public ItemComponent setFactor(long value) {
5207      this.factor = new DecimalType();
5208      this.factor.setValue(value);
5209      return this;
5210    }
5211
5212    /**
5213     * @param value A real number that represents a multiplier used in determining
5214     *              the overall value of services delivered and/or goods received.
5215     *              The concept of a Factor allows for a discount or surcharge
5216     *              multiplier to be applied to a monetary amount.
5217     */
5218    public ItemComponent setFactor(double value) {
5219      this.factor = new DecimalType();
5220      this.factor.setValue(value);
5221      return this;
5222    }
5223
5224    /**
5225     * @return {@link #net} (The quantity times the unit price for an additional
5226     *         service or product or charge.)
5227     */
5228    public Money getNet() {
5229      if (this.net == null)
5230        if (Configuration.errorOnAutoCreate())
5231          throw new Error("Attempt to auto-create ItemComponent.net");
5232        else if (Configuration.doAutoCreate())
5233          this.net = new Money(); // cc
5234      return this.net;
5235    }
5236
5237    public boolean hasNet() {
5238      return this.net != null && !this.net.isEmpty();
5239    }
5240
5241    /**
5242     * @param value {@link #net} (The quantity times the unit price for an
5243     *              additional service or product or charge.)
5244     */
5245    public ItemComponent setNet(Money value) {
5246      this.net = value;
5247      return this;
5248    }
5249
5250    /**
5251     * @return {@link #udi} (Unique Device Identifiers associated with this line
5252     *         item.)
5253     */
5254    public List<Reference> getUdi() {
5255      if (this.udi == null)
5256        this.udi = new ArrayList<Reference>();
5257      return this.udi;
5258    }
5259
5260    /**
5261     * @return Returns a reference to <code>this</code> for easy method chaining
5262     */
5263    public ItemComponent setUdi(List<Reference> theUdi) {
5264      this.udi = theUdi;
5265      return this;
5266    }
5267
5268    public boolean hasUdi() {
5269      if (this.udi == null)
5270        return false;
5271      for (Reference item : this.udi)
5272        if (!item.isEmpty())
5273          return true;
5274      return false;
5275    }
5276
5277    public Reference addUdi() { // 3
5278      Reference t = new Reference();
5279      if (this.udi == null)
5280        this.udi = new ArrayList<Reference>();
5281      this.udi.add(t);
5282      return t;
5283    }
5284
5285    public ItemComponent addUdi(Reference t) { // 3
5286      if (t == null)
5287        return this;
5288      if (this.udi == null)
5289        this.udi = new ArrayList<Reference>();
5290      this.udi.add(t);
5291      return this;
5292    }
5293
5294    /**
5295     * @return The first repetition of repeating field {@link #udi}, creating it if
5296     *         it does not already exist
5297     */
5298    public Reference getUdiFirstRep() {
5299      if (getUdi().isEmpty()) {
5300        addUdi();
5301      }
5302      return getUdi().get(0);
5303    }
5304
5305    /**
5306     * @deprecated Use Reference#setResource(IBaseResource) instead
5307     */
5308    @Deprecated
5309    public List<Device> getUdiTarget() {
5310      if (this.udiTarget == null)
5311        this.udiTarget = new ArrayList<Device>();
5312      return this.udiTarget;
5313    }
5314
5315    /**
5316     * @deprecated Use Reference#setResource(IBaseResource) instead
5317     */
5318    @Deprecated
5319    public Device addUdiTarget() {
5320      Device r = new Device();
5321      if (this.udiTarget == null)
5322        this.udiTarget = new ArrayList<Device>();
5323      this.udiTarget.add(r);
5324      return r;
5325    }
5326
5327    /**
5328     * @return {@link #bodySite} (Physical service site on the patient (limb, tooth,
5329     *         etc.).)
5330     */
5331    public CodeableConcept getBodySite() {
5332      if (this.bodySite == null)
5333        if (Configuration.errorOnAutoCreate())
5334          throw new Error("Attempt to auto-create ItemComponent.bodySite");
5335        else if (Configuration.doAutoCreate())
5336          this.bodySite = new CodeableConcept(); // cc
5337      return this.bodySite;
5338    }
5339
5340    public boolean hasBodySite() {
5341      return this.bodySite != null && !this.bodySite.isEmpty();
5342    }
5343
5344    /**
5345     * @param value {@link #bodySite} (Physical service site on the patient (limb,
5346     *              tooth, etc.).)
5347     */
5348    public ItemComponent setBodySite(CodeableConcept value) {
5349      this.bodySite = value;
5350      return this;
5351    }
5352
5353    /**
5354     * @return {@link #subSite} (A region or surface of the bodySite, e.g. limb
5355     *         region or tooth surface(s).)
5356     */
5357    public List<CodeableConcept> getSubSite() {
5358      if (this.subSite == null)
5359        this.subSite = new ArrayList<CodeableConcept>();
5360      return this.subSite;
5361    }
5362
5363    /**
5364     * @return Returns a reference to <code>this</code> for easy method chaining
5365     */
5366    public ItemComponent setSubSite(List<CodeableConcept> theSubSite) {
5367      this.subSite = theSubSite;
5368      return this;
5369    }
5370
5371    public boolean hasSubSite() {
5372      if (this.subSite == null)
5373        return false;
5374      for (CodeableConcept item : this.subSite)
5375        if (!item.isEmpty())
5376          return true;
5377      return false;
5378    }
5379
5380    public CodeableConcept addSubSite() { // 3
5381      CodeableConcept t = new CodeableConcept();
5382      if (this.subSite == null)
5383        this.subSite = new ArrayList<CodeableConcept>();
5384      this.subSite.add(t);
5385      return t;
5386    }
5387
5388    public ItemComponent addSubSite(CodeableConcept t) { // 3
5389      if (t == null)
5390        return this;
5391      if (this.subSite == null)
5392        this.subSite = new ArrayList<CodeableConcept>();
5393      this.subSite.add(t);
5394      return this;
5395    }
5396
5397    /**
5398     * @return The first repetition of repeating field {@link #subSite}, creating it
5399     *         if it does not already exist
5400     */
5401    public CodeableConcept getSubSiteFirstRep() {
5402      if (getSubSite().isEmpty()) {
5403        addSubSite();
5404      }
5405      return getSubSite().get(0);
5406    }
5407
5408    /**
5409     * @return {@link #encounter} (A billed item may include goods or services
5410     *         provided in multiple encounters.)
5411     */
5412    public List<Reference> getEncounter() {
5413      if (this.encounter == null)
5414        this.encounter = new ArrayList<Reference>();
5415      return this.encounter;
5416    }
5417
5418    /**
5419     * @return Returns a reference to <code>this</code> for easy method chaining
5420     */
5421    public ItemComponent setEncounter(List<Reference> theEncounter) {
5422      this.encounter = theEncounter;
5423      return this;
5424    }
5425
5426    public boolean hasEncounter() {
5427      if (this.encounter == null)
5428        return false;
5429      for (Reference item : this.encounter)
5430        if (!item.isEmpty())
5431          return true;
5432      return false;
5433    }
5434
5435    public Reference addEncounter() { // 3
5436      Reference t = new Reference();
5437      if (this.encounter == null)
5438        this.encounter = new ArrayList<Reference>();
5439      this.encounter.add(t);
5440      return t;
5441    }
5442
5443    public ItemComponent addEncounter(Reference t) { // 3
5444      if (t == null)
5445        return this;
5446      if (this.encounter == null)
5447        this.encounter = new ArrayList<Reference>();
5448      this.encounter.add(t);
5449      return this;
5450    }
5451
5452    /**
5453     * @return The first repetition of repeating field {@link #encounter}, creating
5454     *         it if it does not already exist
5455     */
5456    public Reference getEncounterFirstRep() {
5457      if (getEncounter().isEmpty()) {
5458        addEncounter();
5459      }
5460      return getEncounter().get(0);
5461    }
5462
5463    /**
5464     * @deprecated Use Reference#setResource(IBaseResource) instead
5465     */
5466    @Deprecated
5467    public List<Encounter> getEncounterTarget() {
5468      if (this.encounterTarget == null)
5469        this.encounterTarget = new ArrayList<Encounter>();
5470      return this.encounterTarget;
5471    }
5472
5473    /**
5474     * @deprecated Use Reference#setResource(IBaseResource) instead
5475     */
5476    @Deprecated
5477    public Encounter addEncounterTarget() {
5478      Encounter r = new Encounter();
5479      if (this.encounterTarget == null)
5480        this.encounterTarget = new ArrayList<Encounter>();
5481      this.encounterTarget.add(r);
5482      return r;
5483    }
5484
5485    /**
5486     * @return {@link #noteNumber} (The numbers associated with notes below which
5487     *         apply to the adjudication of this item.)
5488     */
5489    public List<PositiveIntType> getNoteNumber() {
5490      if (this.noteNumber == null)
5491        this.noteNumber = new ArrayList<PositiveIntType>();
5492      return this.noteNumber;
5493    }
5494
5495    /**
5496     * @return Returns a reference to <code>this</code> for easy method chaining
5497     */
5498    public ItemComponent setNoteNumber(List<PositiveIntType> theNoteNumber) {
5499      this.noteNumber = theNoteNumber;
5500      return this;
5501    }
5502
5503    public boolean hasNoteNumber() {
5504      if (this.noteNumber == null)
5505        return false;
5506      for (PositiveIntType item : this.noteNumber)
5507        if (!item.isEmpty())
5508          return true;
5509      return false;
5510    }
5511
5512    /**
5513     * @return {@link #noteNumber} (The numbers associated with notes below which
5514     *         apply to the adjudication of this item.)
5515     */
5516    public PositiveIntType addNoteNumberElement() {// 2
5517      PositiveIntType t = new PositiveIntType();
5518      if (this.noteNumber == null)
5519        this.noteNumber = new ArrayList<PositiveIntType>();
5520      this.noteNumber.add(t);
5521      return t;
5522    }
5523
5524    /**
5525     * @param value {@link #noteNumber} (The numbers associated with notes below
5526     *              which apply to the adjudication of this item.)
5527     */
5528    public ItemComponent addNoteNumber(int value) { // 1
5529      PositiveIntType t = new PositiveIntType();
5530      t.setValue(value);
5531      if (this.noteNumber == null)
5532        this.noteNumber = new ArrayList<PositiveIntType>();
5533      this.noteNumber.add(t);
5534      return this;
5535    }
5536
5537    /**
5538     * @param value {@link #noteNumber} (The numbers associated with notes below
5539     *              which apply to the adjudication of this item.)
5540     */
5541    public boolean hasNoteNumber(int value) {
5542      if (this.noteNumber == null)
5543        return false;
5544      for (PositiveIntType v : this.noteNumber)
5545        if (v.getValue().equals(value)) // positiveInt
5546          return true;
5547      return false;
5548    }
5549
5550    /**
5551     * @return {@link #adjudication} (If this item is a group then the values here
5552     *         are a summary of the adjudication of the detail items. If this item
5553     *         is a simple product or service then this is the result of the
5554     *         adjudication of this item.)
5555     */
5556    public List<AdjudicationComponent> getAdjudication() {
5557      if (this.adjudication == null)
5558        this.adjudication = new ArrayList<AdjudicationComponent>();
5559      return this.adjudication;
5560    }
5561
5562    /**
5563     * @return Returns a reference to <code>this</code> for easy method chaining
5564     */
5565    public ItemComponent setAdjudication(List<AdjudicationComponent> theAdjudication) {
5566      this.adjudication = theAdjudication;
5567      return this;
5568    }
5569
5570    public boolean hasAdjudication() {
5571      if (this.adjudication == null)
5572        return false;
5573      for (AdjudicationComponent item : this.adjudication)
5574        if (!item.isEmpty())
5575          return true;
5576      return false;
5577    }
5578
5579    public AdjudicationComponent addAdjudication() { // 3
5580      AdjudicationComponent t = new AdjudicationComponent();
5581      if (this.adjudication == null)
5582        this.adjudication = new ArrayList<AdjudicationComponent>();
5583      this.adjudication.add(t);
5584      return t;
5585    }
5586
5587    public ItemComponent addAdjudication(AdjudicationComponent t) { // 3
5588      if (t == null)
5589        return this;
5590      if (this.adjudication == null)
5591        this.adjudication = new ArrayList<AdjudicationComponent>();
5592      this.adjudication.add(t);
5593      return this;
5594    }
5595
5596    /**
5597     * @return The first repetition of repeating field {@link #adjudication},
5598     *         creating it if it does not already exist
5599     */
5600    public AdjudicationComponent getAdjudicationFirstRep() {
5601      if (getAdjudication().isEmpty()) {
5602        addAdjudication();
5603      }
5604      return getAdjudication().get(0);
5605    }
5606
5607    /**
5608     * @return {@link #detail} (Second-tier of goods and services.)
5609     */
5610    public List<DetailComponent> getDetail() {
5611      if (this.detail == null)
5612        this.detail = new ArrayList<DetailComponent>();
5613      return this.detail;
5614    }
5615
5616    /**
5617     * @return Returns a reference to <code>this</code> for easy method chaining
5618     */
5619    public ItemComponent setDetail(List<DetailComponent> theDetail) {
5620      this.detail = theDetail;
5621      return this;
5622    }
5623
5624    public boolean hasDetail() {
5625      if (this.detail == null)
5626        return false;
5627      for (DetailComponent item : this.detail)
5628        if (!item.isEmpty())
5629          return true;
5630      return false;
5631    }
5632
5633    public DetailComponent addDetail() { // 3
5634      DetailComponent t = new DetailComponent();
5635      if (this.detail == null)
5636        this.detail = new ArrayList<DetailComponent>();
5637      this.detail.add(t);
5638      return t;
5639    }
5640
5641    public ItemComponent addDetail(DetailComponent t) { // 3
5642      if (t == null)
5643        return this;
5644      if (this.detail == null)
5645        this.detail = new ArrayList<DetailComponent>();
5646      this.detail.add(t);
5647      return this;
5648    }
5649
5650    /**
5651     * @return The first repetition of repeating field {@link #detail}, creating it
5652     *         if it does not already exist
5653     */
5654    public DetailComponent getDetailFirstRep() {
5655      if (getDetail().isEmpty()) {
5656        addDetail();
5657      }
5658      return getDetail().get(0);
5659    }
5660
5661    protected void listChildren(List<Property> children) {
5662      super.listChildren(children);
5663      children
5664          .add(new Property("sequence", "positiveInt", "A number to uniquely identify item entries.", 0, 1, sequence));
5665      children.add(new Property("careTeamSequence", "positiveInt",
5666          "Care team members related to this service or product.", 0, java.lang.Integer.MAX_VALUE, careTeamSequence));
5667      children.add(new Property("diagnosisSequence", "positiveInt", "Diagnoses applicable for this service or product.",
5668          0, java.lang.Integer.MAX_VALUE, diagnosisSequence));
5669      children.add(new Property("procedureSequence", "positiveInt",
5670          "Procedures applicable for this service or product.", 0, java.lang.Integer.MAX_VALUE, procedureSequence));
5671      children.add(new Property("informationSequence", "positiveInt",
5672          "Exceptions, special conditions and supporting information applicable for this service or product.", 0,
5673          java.lang.Integer.MAX_VALUE, informationSequence));
5674      children.add(new Property("revenue", "CodeableConcept",
5675          "The type of revenue or cost center providing the product and/or service.", 0, 1, revenue));
5676      children.add(new Property("category", "CodeableConcept",
5677          "Code to identify the general type of benefits under which products and services are provided.", 0, 1,
5678          category));
5679      children.add(new Property("productOrService", "CodeableConcept",
5680          "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
5681          0, 1, productOrService));
5682      children.add(new Property("modifier", "CodeableConcept",
5683          "Item typification or modifiers codes to convey additional context for the product or service.", 0,
5684          java.lang.Integer.MAX_VALUE, modifier));
5685      children.add(new Property("programCode", "CodeableConcept",
5686          "Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode));
5687      children.add(new Property("serviced[x]", "date|Period",
5688          "The date or dates when the service or product was supplied, performed or completed.", 0, 1, serviced));
5689      children.add(new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
5690          "Where the product or service was provided.", 0, 1, location));
5691      children.add(new Property("quantity", "SimpleQuantity", "The number of repetitions of a service or product.", 0,
5692          1, quantity));
5693      children.add(new Property("unitPrice", "Money",
5694          "If the item is not a group then this is the fee for the product or service, otherwise this is the total of the fees for the details of the group.",
5695          0, 1, unitPrice));
5696      children.add(new Property("factor", "decimal",
5697          "A real number that represents a multiplier used in determining the overall value of services delivered and/or goods received. The concept of a Factor allows for a discount or surcharge multiplier to be applied to a monetary amount.",
5698          0, 1, factor));
5699      children.add(new Property("net", "Money",
5700          "The quantity times the unit price for an additional service or product or charge.", 0, 1, net));
5701      children.add(new Property("udi", "Reference(Device)", "Unique Device Identifiers associated with this line item.",
5702          0, java.lang.Integer.MAX_VALUE, udi));
5703      children.add(new Property("bodySite", "CodeableConcept",
5704          "Physical service site on the patient (limb, tooth, etc.).", 0, 1, bodySite));
5705      children.add(new Property("subSite", "CodeableConcept",
5706          "A region or surface of the bodySite, e.g. limb region or tooth surface(s).", 0, java.lang.Integer.MAX_VALUE,
5707          subSite));
5708      children.add(new Property("encounter", "Reference(Encounter)",
5709          "A billed item may include goods or services provided in multiple encounters.", 0,
5710          java.lang.Integer.MAX_VALUE, encounter));
5711      children.add(new Property("noteNumber", "positiveInt",
5712          "The numbers associated with notes below which apply to the adjudication of this item.", 0,
5713          java.lang.Integer.MAX_VALUE, noteNumber));
5714      children.add(new Property("adjudication", "",
5715          "If this item is a group then the values here are a summary of the adjudication of the detail items. If this item is a simple product or service then this is the result of the adjudication of this item.",
5716          0, java.lang.Integer.MAX_VALUE, adjudication));
5717      children.add(
5718          new Property("detail", "", "Second-tier of goods and services.", 0, java.lang.Integer.MAX_VALUE, detail));
5719    }
5720
5721    @Override
5722    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
5723      switch (_hash) {
5724      case 1349547969:
5725        /* sequence */ return new Property("sequence", "positiveInt", "A number to uniquely identify item entries.", 0,
5726            1, sequence);
5727      case 1070083823:
5728        /* careTeamSequence */ return new Property("careTeamSequence", "positiveInt",
5729            "Care team members related to this service or product.", 0, java.lang.Integer.MAX_VALUE, careTeamSequence);
5730      case -909769262:
5731        /* diagnosisSequence */ return new Property("diagnosisSequence", "positiveInt",
5732            "Diagnoses applicable for this service or product.", 0, java.lang.Integer.MAX_VALUE, diagnosisSequence);
5733      case -808920140:
5734        /* procedureSequence */ return new Property("procedureSequence", "positiveInt",
5735            "Procedures applicable for this service or product.", 0, java.lang.Integer.MAX_VALUE, procedureSequence);
5736      case -702585587:
5737        /* informationSequence */ return new Property("informationSequence", "positiveInt",
5738            "Exceptions, special conditions and supporting information applicable for this service or product.", 0,
5739            java.lang.Integer.MAX_VALUE, informationSequence);
5740      case 1099842588:
5741        /* revenue */ return new Property("revenue", "CodeableConcept",
5742            "The type of revenue or cost center providing the product and/or service.", 0, 1, revenue);
5743      case 50511102:
5744        /* category */ return new Property("category", "CodeableConcept",
5745            "Code to identify the general type of benefits under which products and services are provided.", 0, 1,
5746            category);
5747      case 1957227299:
5748        /* productOrService */ return new Property("productOrService", "CodeableConcept",
5749            "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
5750            0, 1, productOrService);
5751      case -615513385:
5752        /* modifier */ return new Property("modifier", "CodeableConcept",
5753            "Item typification or modifiers codes to convey additional context for the product or service.", 0,
5754            java.lang.Integer.MAX_VALUE, modifier);
5755      case 1010065041:
5756        /* programCode */ return new Property("programCode", "CodeableConcept",
5757            "Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode);
5758      case -1927922223:
5759        /* serviced[x] */ return new Property("serviced[x]", "date|Period",
5760            "The date or dates when the service or product was supplied, performed or completed.", 0, 1, serviced);
5761      case 1379209295:
5762        /* serviced */ return new Property("serviced[x]", "date|Period",
5763            "The date or dates when the service or product was supplied, performed or completed.", 0, 1, serviced);
5764      case 363246749:
5765        /* servicedDate */ return new Property("serviced[x]", "date|Period",
5766            "The date or dates when the service or product was supplied, performed or completed.", 0, 1, serviced);
5767      case 1534966512:
5768        /* servicedPeriod */ return new Property("serviced[x]", "date|Period",
5769            "The date or dates when the service or product was supplied, performed or completed.", 0, 1, serviced);
5770      case 552316075:
5771        /* location[x] */ return new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
5772            "Where the product or service was provided.", 0, 1, location);
5773      case 1901043637:
5774        /* location */ return new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
5775            "Where the product or service was provided.", 0, 1, location);
5776      case -1224800468:
5777        /* locationCodeableConcept */ return new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
5778            "Where the product or service was provided.", 0, 1, location);
5779      case -1280020865:
5780        /* locationAddress */ return new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
5781            "Where the product or service was provided.", 0, 1, location);
5782      case 755866390:
5783        /* locationReference */ return new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
5784            "Where the product or service was provided.", 0, 1, location);
5785      case -1285004149:
5786        /* quantity */ return new Property("quantity", "SimpleQuantity",
5787            "The number of repetitions of a service or product.", 0, 1, quantity);
5788      case -486196699:
5789        /* unitPrice */ return new Property("unitPrice", "Money",
5790            "If the item is not a group then this is the fee for the product or service, otherwise this is the total of the fees for the details of the group.",
5791            0, 1, unitPrice);
5792      case -1282148017:
5793        /* factor */ return new Property("factor", "decimal",
5794            "A real number that represents a multiplier used in determining the overall value of services delivered and/or goods received. The concept of a Factor allows for a discount or surcharge multiplier to be applied to a monetary amount.",
5795            0, 1, factor);
5796      case 108957:
5797        /* net */ return new Property("net", "Money",
5798            "The quantity times the unit price for an additional service or product or charge.", 0, 1, net);
5799      case 115642:
5800        /* udi */ return new Property("udi", "Reference(Device)",
5801            "Unique Device Identifiers associated with this line item.", 0, java.lang.Integer.MAX_VALUE, udi);
5802      case 1702620169:
5803        /* bodySite */ return new Property("bodySite", "CodeableConcept",
5804            "Physical service site on the patient (limb, tooth, etc.).", 0, 1, bodySite);
5805      case -1868566105:
5806        /* subSite */ return new Property("subSite", "CodeableConcept",
5807            "A region or surface of the bodySite, e.g. limb region or tooth surface(s).", 0,
5808            java.lang.Integer.MAX_VALUE, subSite);
5809      case 1524132147:
5810        /* encounter */ return new Property("encounter", "Reference(Encounter)",
5811            "A billed item may include goods or services provided in multiple encounters.", 0,
5812            java.lang.Integer.MAX_VALUE, encounter);
5813      case -1110033957:
5814        /* noteNumber */ return new Property("noteNumber", "positiveInt",
5815            "The numbers associated with notes below which apply to the adjudication of this item.", 0,
5816            java.lang.Integer.MAX_VALUE, noteNumber);
5817      case -231349275:
5818        /* adjudication */ return new Property("adjudication", "",
5819            "If this item is a group then the values here are a summary of the adjudication of the detail items. If this item is a simple product or service then this is the result of the adjudication of this item.",
5820            0, java.lang.Integer.MAX_VALUE, adjudication);
5821      case -1335224239:
5822        /* detail */ return new Property("detail", "", "Second-tier of goods and services.", 0,
5823            java.lang.Integer.MAX_VALUE, detail);
5824      default:
5825        return super.getNamedProperty(_hash, _name, _checkValid);
5826      }
5827
5828    }
5829
5830    @Override
5831    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
5832      switch (hash) {
5833      case 1349547969:
5834        /* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
5835      case 1070083823:
5836        /* careTeamSequence */ return this.careTeamSequence == null ? new Base[0]
5837            : this.careTeamSequence.toArray(new Base[this.careTeamSequence.size()]); // PositiveIntType
5838      case -909769262:
5839        /* diagnosisSequence */ return this.diagnosisSequence == null ? new Base[0]
5840            : this.diagnosisSequence.toArray(new Base[this.diagnosisSequence.size()]); // PositiveIntType
5841      case -808920140:
5842        /* procedureSequence */ return this.procedureSequence == null ? new Base[0]
5843            : this.procedureSequence.toArray(new Base[this.procedureSequence.size()]); // PositiveIntType
5844      case -702585587:
5845        /* informationSequence */ return this.informationSequence == null ? new Base[0]
5846            : this.informationSequence.toArray(new Base[this.informationSequence.size()]); // PositiveIntType
5847      case 1099842588:
5848        /* revenue */ return this.revenue == null ? new Base[0] : new Base[] { this.revenue }; // CodeableConcept
5849      case 50511102:
5850        /* category */ return this.category == null ? new Base[0] : new Base[] { this.category }; // CodeableConcept
5851      case 1957227299:
5852        /* productOrService */ return this.productOrService == null ? new Base[0]
5853            : new Base[] { this.productOrService }; // CodeableConcept
5854      case -615513385:
5855        /* modifier */ return this.modifier == null ? new Base[0]
5856            : this.modifier.toArray(new Base[this.modifier.size()]); // CodeableConcept
5857      case 1010065041:
5858        /* programCode */ return this.programCode == null ? new Base[0]
5859            : this.programCode.toArray(new Base[this.programCode.size()]); // CodeableConcept
5860      case 1379209295:
5861        /* serviced */ return this.serviced == null ? new Base[0] : new Base[] { this.serviced }; // Type
5862      case 1901043637:
5863        /* location */ return this.location == null ? new Base[0] : new Base[] { this.location }; // Type
5864      case -1285004149:
5865        /* quantity */ return this.quantity == null ? new Base[0] : new Base[] { this.quantity }; // Quantity
5866      case -486196699:
5867        /* unitPrice */ return this.unitPrice == null ? new Base[0] : new Base[] { this.unitPrice }; // Money
5868      case -1282148017:
5869        /* factor */ return this.factor == null ? new Base[0] : new Base[] { this.factor }; // DecimalType
5870      case 108957:
5871        /* net */ return this.net == null ? new Base[0] : new Base[] { this.net }; // Money
5872      case 115642:
5873        /* udi */ return this.udi == null ? new Base[0] : this.udi.toArray(new Base[this.udi.size()]); // Reference
5874      case 1702620169:
5875        /* bodySite */ return this.bodySite == null ? new Base[0] : new Base[] { this.bodySite }; // CodeableConcept
5876      case -1868566105:
5877        /* subSite */ return this.subSite == null ? new Base[0] : this.subSite.toArray(new Base[this.subSite.size()]); // CodeableConcept
5878      case 1524132147:
5879        /* encounter */ return this.encounter == null ? new Base[0]
5880            : this.encounter.toArray(new Base[this.encounter.size()]); // Reference
5881      case -1110033957:
5882        /* noteNumber */ return this.noteNumber == null ? new Base[0]
5883            : this.noteNumber.toArray(new Base[this.noteNumber.size()]); // PositiveIntType
5884      case -231349275:
5885        /* adjudication */ return this.adjudication == null ? new Base[0]
5886            : this.adjudication.toArray(new Base[this.adjudication.size()]); // AdjudicationComponent
5887      case -1335224239:
5888        /* detail */ return this.detail == null ? new Base[0] : this.detail.toArray(new Base[this.detail.size()]); // DetailComponent
5889      default:
5890        return super.getProperty(hash, name, checkValid);
5891      }
5892
5893    }
5894
5895    @Override
5896    public Base setProperty(int hash, String name, Base value) throws FHIRException {
5897      switch (hash) {
5898      case 1349547969: // sequence
5899        this.sequence = castToPositiveInt(value); // PositiveIntType
5900        return value;
5901      case 1070083823: // careTeamSequence
5902        this.getCareTeamSequence().add(castToPositiveInt(value)); // PositiveIntType
5903        return value;
5904      case -909769262: // diagnosisSequence
5905        this.getDiagnosisSequence().add(castToPositiveInt(value)); // PositiveIntType
5906        return value;
5907      case -808920140: // procedureSequence
5908        this.getProcedureSequence().add(castToPositiveInt(value)); // PositiveIntType
5909        return value;
5910      case -702585587: // informationSequence
5911        this.getInformationSequence().add(castToPositiveInt(value)); // PositiveIntType
5912        return value;
5913      case 1099842588: // revenue
5914        this.revenue = castToCodeableConcept(value); // CodeableConcept
5915        return value;
5916      case 50511102: // category
5917        this.category = castToCodeableConcept(value); // CodeableConcept
5918        return value;
5919      case 1957227299: // productOrService
5920        this.productOrService = castToCodeableConcept(value); // CodeableConcept
5921        return value;
5922      case -615513385: // modifier
5923        this.getModifier().add(castToCodeableConcept(value)); // CodeableConcept
5924        return value;
5925      case 1010065041: // programCode
5926        this.getProgramCode().add(castToCodeableConcept(value)); // CodeableConcept
5927        return value;
5928      case 1379209295: // serviced
5929        this.serviced = castToType(value); // Type
5930        return value;
5931      case 1901043637: // location
5932        this.location = castToType(value); // Type
5933        return value;
5934      case -1285004149: // quantity
5935        this.quantity = castToQuantity(value); // Quantity
5936        return value;
5937      case -486196699: // unitPrice
5938        this.unitPrice = castToMoney(value); // Money
5939        return value;
5940      case -1282148017: // factor
5941        this.factor = castToDecimal(value); // DecimalType
5942        return value;
5943      case 108957: // net
5944        this.net = castToMoney(value); // Money
5945        return value;
5946      case 115642: // udi
5947        this.getUdi().add(castToReference(value)); // Reference
5948        return value;
5949      case 1702620169: // bodySite
5950        this.bodySite = castToCodeableConcept(value); // CodeableConcept
5951        return value;
5952      case -1868566105: // subSite
5953        this.getSubSite().add(castToCodeableConcept(value)); // CodeableConcept
5954        return value;
5955      case 1524132147: // encounter
5956        this.getEncounter().add(castToReference(value)); // Reference
5957        return value;
5958      case -1110033957: // noteNumber
5959        this.getNoteNumber().add(castToPositiveInt(value)); // PositiveIntType
5960        return value;
5961      case -231349275: // adjudication
5962        this.getAdjudication().add((AdjudicationComponent) value); // AdjudicationComponent
5963        return value;
5964      case -1335224239: // detail
5965        this.getDetail().add((DetailComponent) value); // DetailComponent
5966        return value;
5967      default:
5968        return super.setProperty(hash, name, value);
5969      }
5970
5971    }
5972
5973    @Override
5974    public Base setProperty(String name, Base value) throws FHIRException {
5975      if (name.equals("sequence")) {
5976        this.sequence = castToPositiveInt(value); // PositiveIntType
5977      } else if (name.equals("careTeamSequence")) {
5978        this.getCareTeamSequence().add(castToPositiveInt(value));
5979      } else if (name.equals("diagnosisSequence")) {
5980        this.getDiagnosisSequence().add(castToPositiveInt(value));
5981      } else if (name.equals("procedureSequence")) {
5982        this.getProcedureSequence().add(castToPositiveInt(value));
5983      } else if (name.equals("informationSequence")) {
5984        this.getInformationSequence().add(castToPositiveInt(value));
5985      } else if (name.equals("revenue")) {
5986        this.revenue = castToCodeableConcept(value); // CodeableConcept
5987      } else if (name.equals("category")) {
5988        this.category = castToCodeableConcept(value); // CodeableConcept
5989      } else if (name.equals("productOrService")) {
5990        this.productOrService = castToCodeableConcept(value); // CodeableConcept
5991      } else if (name.equals("modifier")) {
5992        this.getModifier().add(castToCodeableConcept(value));
5993      } else if (name.equals("programCode")) {
5994        this.getProgramCode().add(castToCodeableConcept(value));
5995      } else if (name.equals("serviced[x]")) {
5996        this.serviced = castToType(value); // Type
5997      } else if (name.equals("location[x]")) {
5998        this.location = castToType(value); // Type
5999      } else if (name.equals("quantity")) {
6000        this.quantity = castToQuantity(value); // Quantity
6001      } else if (name.equals("unitPrice")) {
6002        this.unitPrice = castToMoney(value); // Money
6003      } else if (name.equals("factor")) {
6004        this.factor = castToDecimal(value); // DecimalType
6005      } else if (name.equals("net")) {
6006        this.net = castToMoney(value); // Money
6007      } else if (name.equals("udi")) {
6008        this.getUdi().add(castToReference(value));
6009      } else if (name.equals("bodySite")) {
6010        this.bodySite = castToCodeableConcept(value); // CodeableConcept
6011      } else if (name.equals("subSite")) {
6012        this.getSubSite().add(castToCodeableConcept(value));
6013      } else if (name.equals("encounter")) {
6014        this.getEncounter().add(castToReference(value));
6015      } else if (name.equals("noteNumber")) {
6016        this.getNoteNumber().add(castToPositiveInt(value));
6017      } else if (name.equals("adjudication")) {
6018        this.getAdjudication().add((AdjudicationComponent) value);
6019      } else if (name.equals("detail")) {
6020        this.getDetail().add((DetailComponent) value);
6021      } else
6022        return super.setProperty(name, value);
6023      return value;
6024    }
6025
6026  @Override
6027  public void removeChild(String name, Base value) throws FHIRException {
6028      if (name.equals("sequence")) {
6029        this.sequence = null;
6030      } else if (name.equals("careTeamSequence")) {
6031        this.getCareTeamSequence().remove(castToPositiveInt(value));
6032      } else if (name.equals("diagnosisSequence")) {
6033        this.getDiagnosisSequence().remove(castToPositiveInt(value));
6034      } else if (name.equals("procedureSequence")) {
6035        this.getProcedureSequence().remove(castToPositiveInt(value));
6036      } else if (name.equals("informationSequence")) {
6037        this.getInformationSequence().remove(castToPositiveInt(value));
6038      } else if (name.equals("revenue")) {
6039        this.revenue = null;
6040      } else if (name.equals("category")) {
6041        this.category = null;
6042      } else if (name.equals("productOrService")) {
6043        this.productOrService = null;
6044      } else if (name.equals("modifier")) {
6045        this.getModifier().remove(castToCodeableConcept(value));
6046      } else if (name.equals("programCode")) {
6047        this.getProgramCode().remove(castToCodeableConcept(value));
6048      } else if (name.equals("serviced[x]")) {
6049        this.serviced = null;
6050      } else if (name.equals("location[x]")) {
6051        this.location = null;
6052      } else if (name.equals("quantity")) {
6053        this.quantity = null;
6054      } else if (name.equals("unitPrice")) {
6055        this.unitPrice = null;
6056      } else if (name.equals("factor")) {
6057        this.factor = null;
6058      } else if (name.equals("net")) {
6059        this.net = null;
6060      } else if (name.equals("udi")) {
6061        this.getUdi().remove(castToReference(value));
6062      } else if (name.equals("bodySite")) {
6063        this.bodySite = null;
6064      } else if (name.equals("subSite")) {
6065        this.getSubSite().remove(castToCodeableConcept(value));
6066      } else if (name.equals("encounter")) {
6067        this.getEncounter().remove(castToReference(value));
6068      } else if (name.equals("noteNumber")) {
6069        this.getNoteNumber().remove(castToPositiveInt(value));
6070      } else if (name.equals("adjudication")) {
6071        this.getAdjudication().remove((AdjudicationComponent) value);
6072      } else if (name.equals("detail")) {
6073        this.getDetail().remove((DetailComponent) value);
6074      } else
6075        super.removeChild(name, value);
6076      
6077    }
6078
6079    @Override
6080    public Base makeProperty(int hash, String name) throws FHIRException {
6081      switch (hash) {
6082      case 1349547969:
6083        return getSequenceElement();
6084      case 1070083823:
6085        return addCareTeamSequenceElement();
6086      case -909769262:
6087        return addDiagnosisSequenceElement();
6088      case -808920140:
6089        return addProcedureSequenceElement();
6090      case -702585587:
6091        return addInformationSequenceElement();
6092      case 1099842588:
6093        return getRevenue();
6094      case 50511102:
6095        return getCategory();
6096      case 1957227299:
6097        return getProductOrService();
6098      case -615513385:
6099        return addModifier();
6100      case 1010065041:
6101        return addProgramCode();
6102      case -1927922223:
6103        return getServiced();
6104      case 1379209295:
6105        return getServiced();
6106      case 552316075:
6107        return getLocation();
6108      case 1901043637:
6109        return getLocation();
6110      case -1285004149:
6111        return getQuantity();
6112      case -486196699:
6113        return getUnitPrice();
6114      case -1282148017:
6115        return getFactorElement();
6116      case 108957:
6117        return getNet();
6118      case 115642:
6119        return addUdi();
6120      case 1702620169:
6121        return getBodySite();
6122      case -1868566105:
6123        return addSubSite();
6124      case 1524132147:
6125        return addEncounter();
6126      case -1110033957:
6127        return addNoteNumberElement();
6128      case -231349275:
6129        return addAdjudication();
6130      case -1335224239:
6131        return addDetail();
6132      default:
6133        return super.makeProperty(hash, name);
6134      }
6135
6136    }
6137
6138    @Override
6139    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
6140      switch (hash) {
6141      case 1349547969:
6142        /* sequence */ return new String[] { "positiveInt" };
6143      case 1070083823:
6144        /* careTeamSequence */ return new String[] { "positiveInt" };
6145      case -909769262:
6146        /* diagnosisSequence */ return new String[] { "positiveInt" };
6147      case -808920140:
6148        /* procedureSequence */ return new String[] { "positiveInt" };
6149      case -702585587:
6150        /* informationSequence */ return new String[] { "positiveInt" };
6151      case 1099842588:
6152        /* revenue */ return new String[] { "CodeableConcept" };
6153      case 50511102:
6154        /* category */ return new String[] { "CodeableConcept" };
6155      case 1957227299:
6156        /* productOrService */ return new String[] { "CodeableConcept" };
6157      case -615513385:
6158        /* modifier */ return new String[] { "CodeableConcept" };
6159      case 1010065041:
6160        /* programCode */ return new String[] { "CodeableConcept" };
6161      case 1379209295:
6162        /* serviced */ return new String[] { "date", "Period" };
6163      case 1901043637:
6164        /* location */ return new String[] { "CodeableConcept", "Address", "Reference" };
6165      case -1285004149:
6166        /* quantity */ return new String[] { "SimpleQuantity" };
6167      case -486196699:
6168        /* unitPrice */ return new String[] { "Money" };
6169      case -1282148017:
6170        /* factor */ return new String[] { "decimal" };
6171      case 108957:
6172        /* net */ return new String[] { "Money" };
6173      case 115642:
6174        /* udi */ return new String[] { "Reference" };
6175      case 1702620169:
6176        /* bodySite */ return new String[] { "CodeableConcept" };
6177      case -1868566105:
6178        /* subSite */ return new String[] { "CodeableConcept" };
6179      case 1524132147:
6180        /* encounter */ return new String[] { "Reference" };
6181      case -1110033957:
6182        /* noteNumber */ return new String[] { "positiveInt" };
6183      case -231349275:
6184        /* adjudication */ return new String[] {};
6185      case -1335224239:
6186        /* detail */ return new String[] {};
6187      default:
6188        return super.getTypesForProperty(hash, name);
6189      }
6190
6191    }
6192
6193    @Override
6194    public Base addChild(String name) throws FHIRException {
6195      if (name.equals("sequence")) {
6196        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
6197      } else if (name.equals("careTeamSequence")) {
6198        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.careTeamSequence");
6199      } else if (name.equals("diagnosisSequence")) {
6200        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.diagnosisSequence");
6201      } else if (name.equals("procedureSequence")) {
6202        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.procedureSequence");
6203      } else if (name.equals("informationSequence")) {
6204        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.informationSequence");
6205      } else if (name.equals("revenue")) {
6206        this.revenue = new CodeableConcept();
6207        return this.revenue;
6208      } else if (name.equals("category")) {
6209        this.category = new CodeableConcept();
6210        return this.category;
6211      } else if (name.equals("productOrService")) {
6212        this.productOrService = new CodeableConcept();
6213        return this.productOrService;
6214      } else if (name.equals("modifier")) {
6215        return addModifier();
6216      } else if (name.equals("programCode")) {
6217        return addProgramCode();
6218      } else if (name.equals("servicedDate")) {
6219        this.serviced = new DateType();
6220        return this.serviced;
6221      } else if (name.equals("servicedPeriod")) {
6222        this.serviced = new Period();
6223        return this.serviced;
6224      } else if (name.equals("locationCodeableConcept")) {
6225        this.location = new CodeableConcept();
6226        return this.location;
6227      } else if (name.equals("locationAddress")) {
6228        this.location = new Address();
6229        return this.location;
6230      } else if (name.equals("locationReference")) {
6231        this.location = new Reference();
6232        return this.location;
6233      } else if (name.equals("quantity")) {
6234        this.quantity = new Quantity();
6235        return this.quantity;
6236      } else if (name.equals("unitPrice")) {
6237        this.unitPrice = new Money();
6238        return this.unitPrice;
6239      } else if (name.equals("factor")) {
6240        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.factor");
6241      } else if (name.equals("net")) {
6242        this.net = new Money();
6243        return this.net;
6244      } else if (name.equals("udi")) {
6245        return addUdi();
6246      } else if (name.equals("bodySite")) {
6247        this.bodySite = new CodeableConcept();
6248        return this.bodySite;
6249      } else if (name.equals("subSite")) {
6250        return addSubSite();
6251      } else if (name.equals("encounter")) {
6252        return addEncounter();
6253      } else if (name.equals("noteNumber")) {
6254        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.noteNumber");
6255      } else if (name.equals("adjudication")) {
6256        return addAdjudication();
6257      } else if (name.equals("detail")) {
6258        return addDetail();
6259      } else
6260        return super.addChild(name);
6261    }
6262
6263    public ItemComponent copy() {
6264      ItemComponent dst = new ItemComponent();
6265      copyValues(dst);
6266      return dst;
6267    }
6268
6269    public void copyValues(ItemComponent dst) {
6270      super.copyValues(dst);
6271      dst.sequence = sequence == null ? null : sequence.copy();
6272      if (careTeamSequence != null) {
6273        dst.careTeamSequence = new ArrayList<PositiveIntType>();
6274        for (PositiveIntType i : careTeamSequence)
6275          dst.careTeamSequence.add(i.copy());
6276      }
6277      ;
6278      if (diagnosisSequence != null) {
6279        dst.diagnosisSequence = new ArrayList<PositiveIntType>();
6280        for (PositiveIntType i : diagnosisSequence)
6281          dst.diagnosisSequence.add(i.copy());
6282      }
6283      ;
6284      if (procedureSequence != null) {
6285        dst.procedureSequence = new ArrayList<PositiveIntType>();
6286        for (PositiveIntType i : procedureSequence)
6287          dst.procedureSequence.add(i.copy());
6288      }
6289      ;
6290      if (informationSequence != null) {
6291        dst.informationSequence = new ArrayList<PositiveIntType>();
6292        for (PositiveIntType i : informationSequence)
6293          dst.informationSequence.add(i.copy());
6294      }
6295      ;
6296      dst.revenue = revenue == null ? null : revenue.copy();
6297      dst.category = category == null ? null : category.copy();
6298      dst.productOrService = productOrService == null ? null : productOrService.copy();
6299      if (modifier != null) {
6300        dst.modifier = new ArrayList<CodeableConcept>();
6301        for (CodeableConcept i : modifier)
6302          dst.modifier.add(i.copy());
6303      }
6304      ;
6305      if (programCode != null) {
6306        dst.programCode = new ArrayList<CodeableConcept>();
6307        for (CodeableConcept i : programCode)
6308          dst.programCode.add(i.copy());
6309      }
6310      ;
6311      dst.serviced = serviced == null ? null : serviced.copy();
6312      dst.location = location == null ? null : location.copy();
6313      dst.quantity = quantity == null ? null : quantity.copy();
6314      dst.unitPrice = unitPrice == null ? null : unitPrice.copy();
6315      dst.factor = factor == null ? null : factor.copy();
6316      dst.net = net == null ? null : net.copy();
6317      if (udi != null) {
6318        dst.udi = new ArrayList<Reference>();
6319        for (Reference i : udi)
6320          dst.udi.add(i.copy());
6321      }
6322      ;
6323      dst.bodySite = bodySite == null ? null : bodySite.copy();
6324      if (subSite != null) {
6325        dst.subSite = new ArrayList<CodeableConcept>();
6326        for (CodeableConcept i : subSite)
6327          dst.subSite.add(i.copy());
6328      }
6329      ;
6330      if (encounter != null) {
6331        dst.encounter = new ArrayList<Reference>();
6332        for (Reference i : encounter)
6333          dst.encounter.add(i.copy());
6334      }
6335      ;
6336      if (noteNumber != null) {
6337        dst.noteNumber = new ArrayList<PositiveIntType>();
6338        for (PositiveIntType i : noteNumber)
6339          dst.noteNumber.add(i.copy());
6340      }
6341      ;
6342      if (adjudication != null) {
6343        dst.adjudication = new ArrayList<AdjudicationComponent>();
6344        for (AdjudicationComponent i : adjudication)
6345          dst.adjudication.add(i.copy());
6346      }
6347      ;
6348      if (detail != null) {
6349        dst.detail = new ArrayList<DetailComponent>();
6350        for (DetailComponent i : detail)
6351          dst.detail.add(i.copy());
6352      }
6353      ;
6354    }
6355
6356    @Override
6357    public boolean equalsDeep(Base other_) {
6358      if (!super.equalsDeep(other_))
6359        return false;
6360      if (!(other_ instanceof ItemComponent))
6361        return false;
6362      ItemComponent o = (ItemComponent) other_;
6363      return compareDeep(sequence, o.sequence, true) && compareDeep(careTeamSequence, o.careTeamSequence, true)
6364          && compareDeep(diagnosisSequence, o.diagnosisSequence, true)
6365          && compareDeep(procedureSequence, o.procedureSequence, true)
6366          && compareDeep(informationSequence, o.informationSequence, true) && compareDeep(revenue, o.revenue, true)
6367          && compareDeep(category, o.category, true) && compareDeep(productOrService, o.productOrService, true)
6368          && compareDeep(modifier, o.modifier, true) && compareDeep(programCode, o.programCode, true)
6369          && compareDeep(serviced, o.serviced, true) && compareDeep(location, o.location, true)
6370          && compareDeep(quantity, o.quantity, true) && compareDeep(unitPrice, o.unitPrice, true)
6371          && compareDeep(factor, o.factor, true) && compareDeep(net, o.net, true) && compareDeep(udi, o.udi, true)
6372          && compareDeep(bodySite, o.bodySite, true) && compareDeep(subSite, o.subSite, true)
6373          && compareDeep(encounter, o.encounter, true) && compareDeep(noteNumber, o.noteNumber, true)
6374          && compareDeep(adjudication, o.adjudication, true) && compareDeep(detail, o.detail, true);
6375    }
6376
6377    @Override
6378    public boolean equalsShallow(Base other_) {
6379      if (!super.equalsShallow(other_))
6380        return false;
6381      if (!(other_ instanceof ItemComponent))
6382        return false;
6383      ItemComponent o = (ItemComponent) other_;
6384      return compareValues(sequence, o.sequence, true) && compareValues(careTeamSequence, o.careTeamSequence, true)
6385          && compareValues(diagnosisSequence, o.diagnosisSequence, true)
6386          && compareValues(procedureSequence, o.procedureSequence, true)
6387          && compareValues(informationSequence, o.informationSequence, true) && compareValues(factor, o.factor, true)
6388          && compareValues(noteNumber, o.noteNumber, true);
6389    }
6390
6391    public boolean isEmpty() {
6392      return super.isEmpty()
6393          && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, careTeamSequence, diagnosisSequence, procedureSequence,
6394              informationSequence, revenue, category, productOrService, modifier, programCode, serviced, location,
6395              quantity, unitPrice, factor, net, udi, bodySite, subSite, encounter, noteNumber, adjudication, detail);
6396    }
6397
6398    public String fhirType() {
6399      return "ExplanationOfBenefit.item";
6400
6401    }
6402
6403  }
6404
6405  @Block()
6406  public static class AdjudicationComponent extends BackboneElement implements IBaseBackboneElement {
6407    /**
6408     * A code to indicate the information type of this adjudication record.
6409     * Information types may include: the value submitted, maximum values or
6410     * percentages allowed or payable under the plan, amounts that the patient is
6411     * responsible for in-aggregate or pertaining to this item, amounts paid by
6412     * other coverages, and the benefit payable for this item.
6413     */
6414    @Child(name = "category", type = {
6415        CodeableConcept.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
6416    @Description(shortDefinition = "Type of adjudication information", formalDefinition = "A code to indicate the information type of this adjudication record. Information types may include: the value submitted, maximum values or percentages allowed or payable under the plan, amounts that the patient is responsible for in-aggregate or pertaining to this item, amounts paid by other coverages, and the benefit payable for this item.")
6417    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/adjudication")
6418    protected CodeableConcept category;
6419
6420    /**
6421     * A code supporting the understanding of the adjudication result and explaining
6422     * variance from expected amount.
6423     */
6424    @Child(name = "reason", type = {
6425        CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
6426    @Description(shortDefinition = "Explanation of adjudication outcome", formalDefinition = "A code supporting the understanding of the adjudication result and explaining variance from expected amount.")
6427    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/adjudication-reason")
6428    protected CodeableConcept reason;
6429
6430    /**
6431     * Monetary amount associated with the category.
6432     */
6433    @Child(name = "amount", type = { Money.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
6434    @Description(shortDefinition = "Monetary amount", formalDefinition = "Monetary amount associated with the category.")
6435    protected Money amount;
6436
6437    /**
6438     * A non-monetary value associated with the category. Mutually exclusive to the
6439     * amount element above.
6440     */
6441    @Child(name = "value", type = { DecimalType.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
6442    @Description(shortDefinition = "Non-monitary value", formalDefinition = "A non-monetary value associated with the category. Mutually exclusive to the amount element above.")
6443    protected DecimalType value;
6444
6445    private static final long serialVersionUID = 1559898786L;
6446
6447    /**
6448     * Constructor
6449     */
6450    public AdjudicationComponent() {
6451      super();
6452    }
6453
6454    /**
6455     * Constructor
6456     */
6457    public AdjudicationComponent(CodeableConcept category) {
6458      super();
6459      this.category = category;
6460    }
6461
6462    /**
6463     * @return {@link #category} (A code to indicate the information type of this
6464     *         adjudication record. Information types may include: the value
6465     *         submitted, maximum values or percentages allowed or payable under the
6466     *         plan, amounts that the patient is responsible for in-aggregate or
6467     *         pertaining to this item, amounts paid by other coverages, and the
6468     *         benefit payable for this item.)
6469     */
6470    public CodeableConcept getCategory() {
6471      if (this.category == null)
6472        if (Configuration.errorOnAutoCreate())
6473          throw new Error("Attempt to auto-create AdjudicationComponent.category");
6474        else if (Configuration.doAutoCreate())
6475          this.category = new CodeableConcept(); // cc
6476      return this.category;
6477    }
6478
6479    public boolean hasCategory() {
6480      return this.category != null && !this.category.isEmpty();
6481    }
6482
6483    /**
6484     * @param value {@link #category} (A code to indicate the information type of
6485     *              this adjudication record. Information types may include: the
6486     *              value submitted, maximum values or percentages allowed or
6487     *              payable under the plan, amounts that the patient is responsible
6488     *              for in-aggregate or pertaining to this item, amounts paid by
6489     *              other coverages, and the benefit payable for this item.)
6490     */
6491    public AdjudicationComponent setCategory(CodeableConcept value) {
6492      this.category = value;
6493      return this;
6494    }
6495
6496    /**
6497     * @return {@link #reason} (A code supporting the understanding of the
6498     *         adjudication result and explaining variance from expected amount.)
6499     */
6500    public CodeableConcept getReason() {
6501      if (this.reason == null)
6502        if (Configuration.errorOnAutoCreate())
6503          throw new Error("Attempt to auto-create AdjudicationComponent.reason");
6504        else if (Configuration.doAutoCreate())
6505          this.reason = new CodeableConcept(); // cc
6506      return this.reason;
6507    }
6508
6509    public boolean hasReason() {
6510      return this.reason != null && !this.reason.isEmpty();
6511    }
6512
6513    /**
6514     * @param value {@link #reason} (A code supporting the understanding of the
6515     *              adjudication result and explaining variance from expected
6516     *              amount.)
6517     */
6518    public AdjudicationComponent setReason(CodeableConcept value) {
6519      this.reason = value;
6520      return this;
6521    }
6522
6523    /**
6524     * @return {@link #amount} (Monetary amount associated with the category.)
6525     */
6526    public Money getAmount() {
6527      if (this.amount == null)
6528        if (Configuration.errorOnAutoCreate())
6529          throw new Error("Attempt to auto-create AdjudicationComponent.amount");
6530        else if (Configuration.doAutoCreate())
6531          this.amount = new Money(); // cc
6532      return this.amount;
6533    }
6534
6535    public boolean hasAmount() {
6536      return this.amount != null && !this.amount.isEmpty();
6537    }
6538
6539    /**
6540     * @param value {@link #amount} (Monetary amount associated with the category.)
6541     */
6542    public AdjudicationComponent setAmount(Money value) {
6543      this.amount = value;
6544      return this;
6545    }
6546
6547    /**
6548     * @return {@link #value} (A non-monetary value associated with the category.
6549     *         Mutually exclusive to the amount element above.). This is the
6550     *         underlying object with id, value and extensions. The accessor
6551     *         "getValue" gives direct access to the value
6552     */
6553    public DecimalType getValueElement() {
6554      if (this.value == null)
6555        if (Configuration.errorOnAutoCreate())
6556          throw new Error("Attempt to auto-create AdjudicationComponent.value");
6557        else if (Configuration.doAutoCreate())
6558          this.value = new DecimalType(); // bb
6559      return this.value;
6560    }
6561
6562    public boolean hasValueElement() {
6563      return this.value != null && !this.value.isEmpty();
6564    }
6565
6566    public boolean hasValue() {
6567      return this.value != null && !this.value.isEmpty();
6568    }
6569
6570    /**
6571     * @param value {@link #value} (A non-monetary value associated with the
6572     *              category. Mutually exclusive to the amount element above.). This
6573     *              is the underlying object with id, value and extensions. The
6574     *              accessor "getValue" gives direct access to the value
6575     */
6576    public AdjudicationComponent setValueElement(DecimalType value) {
6577      this.value = value;
6578      return this;
6579    }
6580
6581    /**
6582     * @return A non-monetary value associated with the category. Mutually exclusive
6583     *         to the amount element above.
6584     */
6585    public BigDecimal getValue() {
6586      return this.value == null ? null : this.value.getValue();
6587    }
6588
6589    /**
6590     * @param value A non-monetary value associated with the category. Mutually
6591     *              exclusive to the amount element above.
6592     */
6593    public AdjudicationComponent setValue(BigDecimal value) {
6594      if (value == null)
6595        this.value = null;
6596      else {
6597        if (this.value == null)
6598          this.value = new DecimalType();
6599        this.value.setValue(value);
6600      }
6601      return this;
6602    }
6603
6604    /**
6605     * @param value A non-monetary value associated with the category. Mutually
6606     *              exclusive to the amount element above.
6607     */
6608    public AdjudicationComponent setValue(long value) {
6609      this.value = new DecimalType();
6610      this.value.setValue(value);
6611      return this;
6612    }
6613
6614    /**
6615     * @param value A non-monetary value associated with the category. Mutually
6616     *              exclusive to the amount element above.
6617     */
6618    public AdjudicationComponent setValue(double value) {
6619      this.value = new DecimalType();
6620      this.value.setValue(value);
6621      return this;
6622    }
6623
6624    protected void listChildren(List<Property> children) {
6625      super.listChildren(children);
6626      children.add(new Property("category", "CodeableConcept",
6627          "A code to indicate the information type of this adjudication record. Information types may include: the value submitted, maximum values or percentages allowed or payable under the plan, amounts that the patient is responsible for in-aggregate or pertaining to this item, amounts paid by other coverages, and the benefit payable for this item.",
6628          0, 1, category));
6629      children.add(new Property("reason", "CodeableConcept",
6630          "A code supporting the understanding of the adjudication result and explaining variance from expected amount.",
6631          0, 1, reason));
6632      children.add(new Property("amount", "Money", "Monetary amount associated with the category.", 0, 1, amount));
6633      children.add(new Property("value", "decimal",
6634          "A non-monetary value associated with the category. Mutually exclusive to the amount element above.", 0, 1,
6635          value));
6636    }
6637
6638    @Override
6639    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
6640      switch (_hash) {
6641      case 50511102:
6642        /* category */ return new Property("category", "CodeableConcept",
6643            "A code to indicate the information type of this adjudication record. Information types may include: the value submitted, maximum values or percentages allowed or payable under the plan, amounts that the patient is responsible for in-aggregate or pertaining to this item, amounts paid by other coverages, and the benefit payable for this item.",
6644            0, 1, category);
6645      case -934964668:
6646        /* reason */ return new Property("reason", "CodeableConcept",
6647            "A code supporting the understanding of the adjudication result and explaining variance from expected amount.",
6648            0, 1, reason);
6649      case -1413853096:
6650        /* amount */ return new Property("amount", "Money", "Monetary amount associated with the category.", 0, 1,
6651            amount);
6652      case 111972721:
6653        /* value */ return new Property("value", "decimal",
6654            "A non-monetary value associated with the category. Mutually exclusive to the amount element above.", 0, 1,
6655            value);
6656      default:
6657        return super.getNamedProperty(_hash, _name, _checkValid);
6658      }
6659
6660    }
6661
6662    @Override
6663    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
6664      switch (hash) {
6665      case 50511102:
6666        /* category */ return this.category == null ? new Base[0] : new Base[] { this.category }; // CodeableConcept
6667      case -934964668:
6668        /* reason */ return this.reason == null ? new Base[0] : new Base[] { this.reason }; // CodeableConcept
6669      case -1413853096:
6670        /* amount */ return this.amount == null ? new Base[0] : new Base[] { this.amount }; // Money
6671      case 111972721:
6672        /* value */ return this.value == null ? new Base[0] : new Base[] { this.value }; // DecimalType
6673      default:
6674        return super.getProperty(hash, name, checkValid);
6675      }
6676
6677    }
6678
6679    @Override
6680    public Base setProperty(int hash, String name, Base value) throws FHIRException {
6681      switch (hash) {
6682      case 50511102: // category
6683        this.category = castToCodeableConcept(value); // CodeableConcept
6684        return value;
6685      case -934964668: // reason
6686        this.reason = castToCodeableConcept(value); // CodeableConcept
6687        return value;
6688      case -1413853096: // amount
6689        this.amount = castToMoney(value); // Money
6690        return value;
6691      case 111972721: // value
6692        this.value = castToDecimal(value); // DecimalType
6693        return value;
6694      default:
6695        return super.setProperty(hash, name, value);
6696      }
6697
6698    }
6699
6700    @Override
6701    public Base setProperty(String name, Base value) throws FHIRException {
6702      if (name.equals("category")) {
6703        this.category = castToCodeableConcept(value); // CodeableConcept
6704      } else if (name.equals("reason")) {
6705        this.reason = castToCodeableConcept(value); // CodeableConcept
6706      } else if (name.equals("amount")) {
6707        this.amount = castToMoney(value); // Money
6708      } else if (name.equals("value")) {
6709        this.value = castToDecimal(value); // DecimalType
6710      } else
6711        return super.setProperty(name, value);
6712      return value;
6713    }
6714
6715  @Override
6716  public void removeChild(String name, Base value) throws FHIRException {
6717      if (name.equals("category")) {
6718        this.category = null;
6719      } else if (name.equals("reason")) {
6720        this.reason = null;
6721      } else if (name.equals("amount")) {
6722        this.amount = null;
6723      } else if (name.equals("value")) {
6724        this.value = null;
6725      } else
6726        super.removeChild(name, value);
6727      
6728    }
6729
6730    @Override
6731    public Base makeProperty(int hash, String name) throws FHIRException {
6732      switch (hash) {
6733      case 50511102:
6734        return getCategory();
6735      case -934964668:
6736        return getReason();
6737      case -1413853096:
6738        return getAmount();
6739      case 111972721:
6740        return getValueElement();
6741      default:
6742        return super.makeProperty(hash, name);
6743      }
6744
6745    }
6746
6747    @Override
6748    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
6749      switch (hash) {
6750      case 50511102:
6751        /* category */ return new String[] { "CodeableConcept" };
6752      case -934964668:
6753        /* reason */ return new String[] { "CodeableConcept" };
6754      case -1413853096:
6755        /* amount */ return new String[] { "Money" };
6756      case 111972721:
6757        /* value */ return new String[] { "decimal" };
6758      default:
6759        return super.getTypesForProperty(hash, name);
6760      }
6761
6762    }
6763
6764    @Override
6765    public Base addChild(String name) throws FHIRException {
6766      if (name.equals("category")) {
6767        this.category = new CodeableConcept();
6768        return this.category;
6769      } else if (name.equals("reason")) {
6770        this.reason = new CodeableConcept();
6771        return this.reason;
6772      } else if (name.equals("amount")) {
6773        this.amount = new Money();
6774        return this.amount;
6775      } else if (name.equals("value")) {
6776        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.value");
6777      } else
6778        return super.addChild(name);
6779    }
6780
6781    public AdjudicationComponent copy() {
6782      AdjudicationComponent dst = new AdjudicationComponent();
6783      copyValues(dst);
6784      return dst;
6785    }
6786
6787    public void copyValues(AdjudicationComponent dst) {
6788      super.copyValues(dst);
6789      dst.category = category == null ? null : category.copy();
6790      dst.reason = reason == null ? null : reason.copy();
6791      dst.amount = amount == null ? null : amount.copy();
6792      dst.value = value == null ? null : value.copy();
6793    }
6794
6795    @Override
6796    public boolean equalsDeep(Base other_) {
6797      if (!super.equalsDeep(other_))
6798        return false;
6799      if (!(other_ instanceof AdjudicationComponent))
6800        return false;
6801      AdjudicationComponent o = (AdjudicationComponent) other_;
6802      return compareDeep(category, o.category, true) && compareDeep(reason, o.reason, true)
6803          && compareDeep(amount, o.amount, true) && compareDeep(value, o.value, true);
6804    }
6805
6806    @Override
6807    public boolean equalsShallow(Base other_) {
6808      if (!super.equalsShallow(other_))
6809        return false;
6810      if (!(other_ instanceof AdjudicationComponent))
6811        return false;
6812      AdjudicationComponent o = (AdjudicationComponent) other_;
6813      return compareValues(value, o.value, true);
6814    }
6815
6816    public boolean isEmpty() {
6817      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(category, reason, amount, value);
6818    }
6819
6820    public String fhirType() {
6821      return "ExplanationOfBenefit.item.adjudication";
6822
6823    }
6824
6825  }
6826
6827  @Block()
6828  public static class DetailComponent extends BackboneElement implements IBaseBackboneElement {
6829    /**
6830     * A claim detail line. Either a simple (a product or service) or a 'group' of
6831     * sub-details which are simple items.
6832     */
6833    @Child(name = "sequence", type = {
6834        PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
6835    @Description(shortDefinition = "Product or service provided", formalDefinition = "A claim detail line. Either a simple (a product or service) or a 'group' of sub-details which are simple items.")
6836    protected PositiveIntType sequence;
6837
6838    /**
6839     * The type of revenue or cost center providing the product and/or service.
6840     */
6841    @Child(name = "revenue", type = {
6842        CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
6843    @Description(shortDefinition = "Revenue or cost center code", formalDefinition = "The type of revenue or cost center providing the product and/or service.")
6844    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-revenue-center")
6845    protected CodeableConcept revenue;
6846
6847    /**
6848     * Code to identify the general type of benefits under which products and
6849     * services are provided.
6850     */
6851    @Child(name = "category", type = {
6852        CodeableConcept.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
6853    @Description(shortDefinition = "Benefit classification", formalDefinition = "Code to identify the general type of benefits under which products and services are provided.")
6854    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-benefitcategory")
6855    protected CodeableConcept category;
6856
6857    /**
6858     * When the value is a group code then this item collects a set of related claim
6859     * details, otherwise this contains the product, service, drug or other billing
6860     * code for the item.
6861     */
6862    @Child(name = "productOrService", type = {
6863        CodeableConcept.class }, order = 4, min = 1, max = 1, modifier = false, summary = false)
6864    @Description(shortDefinition = "Billing, service, product, or drug code", formalDefinition = "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.")
6865    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-uscls")
6866    protected CodeableConcept productOrService;
6867
6868    /**
6869     * Item typification or modifiers codes to convey additional context for the
6870     * product or service.
6871     */
6872    @Child(name = "modifier", type = {
6873        CodeableConcept.class }, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
6874    @Description(shortDefinition = "Service/Product billing modifiers", formalDefinition = "Item typification or modifiers codes to convey additional context for the product or service.")
6875    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-modifiers")
6876    protected List<CodeableConcept> modifier;
6877
6878    /**
6879     * Identifies the program under which this may be recovered.
6880     */
6881    @Child(name = "programCode", type = {
6882        CodeableConcept.class }, order = 6, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
6883    @Description(shortDefinition = "Program the product or service is provided under", formalDefinition = "Identifies the program under which this may be recovered.")
6884    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-program-code")
6885    protected List<CodeableConcept> programCode;
6886
6887    /**
6888     * The number of repetitions of a service or product.
6889     */
6890    @Child(name = "quantity", type = { Quantity.class }, order = 7, min = 0, max = 1, modifier = false, summary = false)
6891    @Description(shortDefinition = "Count of products or services", formalDefinition = "The number of repetitions of a service or product.")
6892    protected Quantity quantity;
6893
6894    /**
6895     * If the item is not a group then this is the fee for the product or service,
6896     * otherwise this is the total of the fees for the details of the group.
6897     */
6898    @Child(name = "unitPrice", type = { Money.class }, order = 8, min = 0, max = 1, modifier = false, summary = false)
6899    @Description(shortDefinition = "Fee, charge or cost per item", formalDefinition = "If the item is not a group then this is the fee for the product or service, otherwise this is the total of the fees for the details of the group.")
6900    protected Money unitPrice;
6901
6902    /**
6903     * A real number that represents a multiplier used in determining the overall
6904     * value of services delivered and/or goods received. The concept of a Factor
6905     * allows for a discount or surcharge multiplier to be applied to a monetary
6906     * amount.
6907     */
6908    @Child(name = "factor", type = {
6909        DecimalType.class }, order = 9, min = 0, max = 1, modifier = false, summary = false)
6910    @Description(shortDefinition = "Price scaling factor", formalDefinition = "A real number that represents a multiplier used in determining the overall value of services delivered and/or goods received. The concept of a Factor allows for a discount or surcharge multiplier to be applied to a monetary amount.")
6911    protected DecimalType factor;
6912
6913    /**
6914     * The quantity times the unit price for an additional service or product or
6915     * charge.
6916     */
6917    @Child(name = "net", type = { Money.class }, order = 10, min = 0, max = 1, modifier = false, summary = false)
6918    @Description(shortDefinition = "Total item cost", formalDefinition = "The quantity times the unit price for an additional service or product or charge.")
6919    protected Money net;
6920
6921    /**
6922     * Unique Device Identifiers associated with this line item.
6923     */
6924    @Child(name = "udi", type = {
6925        Device.class }, order = 11, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
6926    @Description(shortDefinition = "Unique device identifier", formalDefinition = "Unique Device Identifiers associated with this line item.")
6927    protected List<Reference> udi;
6928    /**
6929     * The actual objects that are the target of the reference (Unique Device
6930     * Identifiers associated with this line item.)
6931     */
6932    protected List<Device> udiTarget;
6933
6934    /**
6935     * The numbers associated with notes below which apply to the adjudication of
6936     * this item.
6937     */
6938    @Child(name = "noteNumber", type = {
6939        PositiveIntType.class }, order = 12, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
6940    @Description(shortDefinition = "Applicable note numbers", formalDefinition = "The numbers associated with notes below which apply to the adjudication of this item.")
6941    protected List<PositiveIntType> noteNumber;
6942
6943    /**
6944     * The adjudication results.
6945     */
6946    @Child(name = "adjudication", type = {
6947        AdjudicationComponent.class }, order = 13, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
6948    @Description(shortDefinition = "Detail level adjudication details", formalDefinition = "The adjudication results.")
6949    protected List<AdjudicationComponent> adjudication;
6950
6951    /**
6952     * Third-tier of goods and services.
6953     */
6954    @Child(name = "subDetail", type = {}, order = 14, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
6955    @Description(shortDefinition = "Additional items", formalDefinition = "Third-tier of goods and services.")
6956    protected List<SubDetailComponent> subDetail;
6957
6958    private static final long serialVersionUID = 225639798L;
6959
6960    /**
6961     * Constructor
6962     */
6963    public DetailComponent() {
6964      super();
6965    }
6966
6967    /**
6968     * Constructor
6969     */
6970    public DetailComponent(PositiveIntType sequence, CodeableConcept productOrService) {
6971      super();
6972      this.sequence = sequence;
6973      this.productOrService = productOrService;
6974    }
6975
6976    /**
6977     * @return {@link #sequence} (A claim detail line. Either a simple (a product or
6978     *         service) or a 'group' of sub-details which are simple items.). This
6979     *         is the underlying object with id, value and extensions. The accessor
6980     *         "getSequence" gives direct access to the value
6981     */
6982    public PositiveIntType getSequenceElement() {
6983      if (this.sequence == null)
6984        if (Configuration.errorOnAutoCreate())
6985          throw new Error("Attempt to auto-create DetailComponent.sequence");
6986        else if (Configuration.doAutoCreate())
6987          this.sequence = new PositiveIntType(); // bb
6988      return this.sequence;
6989    }
6990
6991    public boolean hasSequenceElement() {
6992      return this.sequence != null && !this.sequence.isEmpty();
6993    }
6994
6995    public boolean hasSequence() {
6996      return this.sequence != null && !this.sequence.isEmpty();
6997    }
6998
6999    /**
7000     * @param value {@link #sequence} (A claim detail line. Either a simple (a
7001     *              product or service) or a 'group' of sub-details which are simple
7002     *              items.). This is the underlying object with id, value and
7003     *              extensions. The accessor "getSequence" gives direct access to
7004     *              the value
7005     */
7006    public DetailComponent setSequenceElement(PositiveIntType value) {
7007      this.sequence = value;
7008      return this;
7009    }
7010
7011    /**
7012     * @return A claim detail line. Either a simple (a product or service) or a
7013     *         'group' of sub-details which are simple items.
7014     */
7015    public int getSequence() {
7016      return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
7017    }
7018
7019    /**
7020     * @param value A claim detail line. Either a simple (a product or service) or a
7021     *              'group' of sub-details which are simple items.
7022     */
7023    public DetailComponent setSequence(int value) {
7024      if (this.sequence == null)
7025        this.sequence = new PositiveIntType();
7026      this.sequence.setValue(value);
7027      return this;
7028    }
7029
7030    /**
7031     * @return {@link #revenue} (The type of revenue or cost center providing the
7032     *         product and/or service.)
7033     */
7034    public CodeableConcept getRevenue() {
7035      if (this.revenue == null)
7036        if (Configuration.errorOnAutoCreate())
7037          throw new Error("Attempt to auto-create DetailComponent.revenue");
7038        else if (Configuration.doAutoCreate())
7039          this.revenue = new CodeableConcept(); // cc
7040      return this.revenue;
7041    }
7042
7043    public boolean hasRevenue() {
7044      return this.revenue != null && !this.revenue.isEmpty();
7045    }
7046
7047    /**
7048     * @param value {@link #revenue} (The type of revenue or cost center providing
7049     *              the product and/or service.)
7050     */
7051    public DetailComponent setRevenue(CodeableConcept value) {
7052      this.revenue = value;
7053      return this;
7054    }
7055
7056    /**
7057     * @return {@link #category} (Code to identify the general type of benefits
7058     *         under which products and services are provided.)
7059     */
7060    public CodeableConcept getCategory() {
7061      if (this.category == null)
7062        if (Configuration.errorOnAutoCreate())
7063          throw new Error("Attempt to auto-create DetailComponent.category");
7064        else if (Configuration.doAutoCreate())
7065          this.category = new CodeableConcept(); // cc
7066      return this.category;
7067    }
7068
7069    public boolean hasCategory() {
7070      return this.category != null && !this.category.isEmpty();
7071    }
7072
7073    /**
7074     * @param value {@link #category} (Code to identify the general type of benefits
7075     *              under which products and services are provided.)
7076     */
7077    public DetailComponent setCategory(CodeableConcept value) {
7078      this.category = value;
7079      return this;
7080    }
7081
7082    /**
7083     * @return {@link #productOrService} (When the value is a group code then this
7084     *         item collects a set of related claim details, otherwise this contains
7085     *         the product, service, drug or other billing code for the item.)
7086     */
7087    public CodeableConcept getProductOrService() {
7088      if (this.productOrService == null)
7089        if (Configuration.errorOnAutoCreate())
7090          throw new Error("Attempt to auto-create DetailComponent.productOrService");
7091        else if (Configuration.doAutoCreate())
7092          this.productOrService = new CodeableConcept(); // cc
7093      return this.productOrService;
7094    }
7095
7096    public boolean hasProductOrService() {
7097      return this.productOrService != null && !this.productOrService.isEmpty();
7098    }
7099
7100    /**
7101     * @param value {@link #productOrService} (When the value is a group code then
7102     *              this item collects a set of related claim details, otherwise
7103     *              this contains the product, service, drug or other billing code
7104     *              for the item.)
7105     */
7106    public DetailComponent setProductOrService(CodeableConcept value) {
7107      this.productOrService = value;
7108      return this;
7109    }
7110
7111    /**
7112     * @return {@link #modifier} (Item typification or modifiers codes to convey
7113     *         additional context for the product or service.)
7114     */
7115    public List<CodeableConcept> getModifier() {
7116      if (this.modifier == null)
7117        this.modifier = new ArrayList<CodeableConcept>();
7118      return this.modifier;
7119    }
7120
7121    /**
7122     * @return Returns a reference to <code>this</code> for easy method chaining
7123     */
7124    public DetailComponent setModifier(List<CodeableConcept> theModifier) {
7125      this.modifier = theModifier;
7126      return this;
7127    }
7128
7129    public boolean hasModifier() {
7130      if (this.modifier == null)
7131        return false;
7132      for (CodeableConcept item : this.modifier)
7133        if (!item.isEmpty())
7134          return true;
7135      return false;
7136    }
7137
7138    public CodeableConcept addModifier() { // 3
7139      CodeableConcept t = new CodeableConcept();
7140      if (this.modifier == null)
7141        this.modifier = new ArrayList<CodeableConcept>();
7142      this.modifier.add(t);
7143      return t;
7144    }
7145
7146    public DetailComponent addModifier(CodeableConcept t) { // 3
7147      if (t == null)
7148        return this;
7149      if (this.modifier == null)
7150        this.modifier = new ArrayList<CodeableConcept>();
7151      this.modifier.add(t);
7152      return this;
7153    }
7154
7155    /**
7156     * @return The first repetition of repeating field {@link #modifier}, creating
7157     *         it if it does not already exist
7158     */
7159    public CodeableConcept getModifierFirstRep() {
7160      if (getModifier().isEmpty()) {
7161        addModifier();
7162      }
7163      return getModifier().get(0);
7164    }
7165
7166    /**
7167     * @return {@link #programCode} (Identifies the program under which this may be
7168     *         recovered.)
7169     */
7170    public List<CodeableConcept> getProgramCode() {
7171      if (this.programCode == null)
7172        this.programCode = new ArrayList<CodeableConcept>();
7173      return this.programCode;
7174    }
7175
7176    /**
7177     * @return Returns a reference to <code>this</code> for easy method chaining
7178     */
7179    public DetailComponent setProgramCode(List<CodeableConcept> theProgramCode) {
7180      this.programCode = theProgramCode;
7181      return this;
7182    }
7183
7184    public boolean hasProgramCode() {
7185      if (this.programCode == null)
7186        return false;
7187      for (CodeableConcept item : this.programCode)
7188        if (!item.isEmpty())
7189          return true;
7190      return false;
7191    }
7192
7193    public CodeableConcept addProgramCode() { // 3
7194      CodeableConcept t = new CodeableConcept();
7195      if (this.programCode == null)
7196        this.programCode = new ArrayList<CodeableConcept>();
7197      this.programCode.add(t);
7198      return t;
7199    }
7200
7201    public DetailComponent addProgramCode(CodeableConcept t) { // 3
7202      if (t == null)
7203        return this;
7204      if (this.programCode == null)
7205        this.programCode = new ArrayList<CodeableConcept>();
7206      this.programCode.add(t);
7207      return this;
7208    }
7209
7210    /**
7211     * @return The first repetition of repeating field {@link #programCode},
7212     *         creating it if it does not already exist
7213     */
7214    public CodeableConcept getProgramCodeFirstRep() {
7215      if (getProgramCode().isEmpty()) {
7216        addProgramCode();
7217      }
7218      return getProgramCode().get(0);
7219    }
7220
7221    /**
7222     * @return {@link #quantity} (The number of repetitions of a service or
7223     *         product.)
7224     */
7225    public Quantity getQuantity() {
7226      if (this.quantity == null)
7227        if (Configuration.errorOnAutoCreate())
7228          throw new Error("Attempt to auto-create DetailComponent.quantity");
7229        else if (Configuration.doAutoCreate())
7230          this.quantity = new Quantity(); // cc
7231      return this.quantity;
7232    }
7233
7234    public boolean hasQuantity() {
7235      return this.quantity != null && !this.quantity.isEmpty();
7236    }
7237
7238    /**
7239     * @param value {@link #quantity} (The number of repetitions of a service or
7240     *              product.)
7241     */
7242    public DetailComponent setQuantity(Quantity value) {
7243      this.quantity = value;
7244      return this;
7245    }
7246
7247    /**
7248     * @return {@link #unitPrice} (If the item is not a group then this is the fee
7249     *         for the product or service, otherwise this is the total of the fees
7250     *         for the details of the group.)
7251     */
7252    public Money getUnitPrice() {
7253      if (this.unitPrice == null)
7254        if (Configuration.errorOnAutoCreate())
7255          throw new Error("Attempt to auto-create DetailComponent.unitPrice");
7256        else if (Configuration.doAutoCreate())
7257          this.unitPrice = new Money(); // cc
7258      return this.unitPrice;
7259    }
7260
7261    public boolean hasUnitPrice() {
7262      return this.unitPrice != null && !this.unitPrice.isEmpty();
7263    }
7264
7265    /**
7266     * @param value {@link #unitPrice} (If the item is not a group then this is the
7267     *              fee for the product or service, otherwise this is the total of
7268     *              the fees for the details of the group.)
7269     */
7270    public DetailComponent setUnitPrice(Money value) {
7271      this.unitPrice = value;
7272      return this;
7273    }
7274
7275    /**
7276     * @return {@link #factor} (A real number that represents a multiplier used in
7277     *         determining the overall value of services delivered and/or goods
7278     *         received. The concept of a Factor allows for a discount or surcharge
7279     *         multiplier to be applied to a monetary amount.). This is the
7280     *         underlying object with id, value and extensions. The accessor
7281     *         "getFactor" gives direct access to the value
7282     */
7283    public DecimalType getFactorElement() {
7284      if (this.factor == null)
7285        if (Configuration.errorOnAutoCreate())
7286          throw new Error("Attempt to auto-create DetailComponent.factor");
7287        else if (Configuration.doAutoCreate())
7288          this.factor = new DecimalType(); // bb
7289      return this.factor;
7290    }
7291
7292    public boolean hasFactorElement() {
7293      return this.factor != null && !this.factor.isEmpty();
7294    }
7295
7296    public boolean hasFactor() {
7297      return this.factor != null && !this.factor.isEmpty();
7298    }
7299
7300    /**
7301     * @param value {@link #factor} (A real number that represents a multiplier used
7302     *              in determining the overall value of services delivered and/or
7303     *              goods received. The concept of a Factor allows for a discount or
7304     *              surcharge multiplier to be applied to a monetary amount.). This
7305     *              is the underlying object with id, value and extensions. The
7306     *              accessor "getFactor" gives direct access to the value
7307     */
7308    public DetailComponent setFactorElement(DecimalType value) {
7309      this.factor = value;
7310      return this;
7311    }
7312
7313    /**
7314     * @return A real number that represents a multiplier used in determining the
7315     *         overall value of services delivered and/or goods received. The
7316     *         concept of a Factor allows for a discount or surcharge multiplier to
7317     *         be applied to a monetary amount.
7318     */
7319    public BigDecimal getFactor() {
7320      return this.factor == null ? null : this.factor.getValue();
7321    }
7322
7323    /**
7324     * @param value A real number that represents a multiplier used in determining
7325     *              the overall value of services delivered and/or goods received.
7326     *              The concept of a Factor allows for a discount or surcharge
7327     *              multiplier to be applied to a monetary amount.
7328     */
7329    public DetailComponent setFactor(BigDecimal value) {
7330      if (value == null)
7331        this.factor = null;
7332      else {
7333        if (this.factor == null)
7334          this.factor = new DecimalType();
7335        this.factor.setValue(value);
7336      }
7337      return this;
7338    }
7339
7340    /**
7341     * @param value A real number that represents a multiplier used in determining
7342     *              the overall value of services delivered and/or goods received.
7343     *              The concept of a Factor allows for a discount or surcharge
7344     *              multiplier to be applied to a monetary amount.
7345     */
7346    public DetailComponent setFactor(long value) {
7347      this.factor = new DecimalType();
7348      this.factor.setValue(value);
7349      return this;
7350    }
7351
7352    /**
7353     * @param value A real number that represents a multiplier used in determining
7354     *              the overall value of services delivered and/or goods received.
7355     *              The concept of a Factor allows for a discount or surcharge
7356     *              multiplier to be applied to a monetary amount.
7357     */
7358    public DetailComponent setFactor(double value) {
7359      this.factor = new DecimalType();
7360      this.factor.setValue(value);
7361      return this;
7362    }
7363
7364    /**
7365     * @return {@link #net} (The quantity times the unit price for an additional
7366     *         service or product or charge.)
7367     */
7368    public Money getNet() {
7369      if (this.net == null)
7370        if (Configuration.errorOnAutoCreate())
7371          throw new Error("Attempt to auto-create DetailComponent.net");
7372        else if (Configuration.doAutoCreate())
7373          this.net = new Money(); // cc
7374      return this.net;
7375    }
7376
7377    public boolean hasNet() {
7378      return this.net != null && !this.net.isEmpty();
7379    }
7380
7381    /**
7382     * @param value {@link #net} (The quantity times the unit price for an
7383     *              additional service or product or charge.)
7384     */
7385    public DetailComponent setNet(Money value) {
7386      this.net = value;
7387      return this;
7388    }
7389
7390    /**
7391     * @return {@link #udi} (Unique Device Identifiers associated with this line
7392     *         item.)
7393     */
7394    public List<Reference> getUdi() {
7395      if (this.udi == null)
7396        this.udi = new ArrayList<Reference>();
7397      return this.udi;
7398    }
7399
7400    /**
7401     * @return Returns a reference to <code>this</code> for easy method chaining
7402     */
7403    public DetailComponent setUdi(List<Reference> theUdi) {
7404      this.udi = theUdi;
7405      return this;
7406    }
7407
7408    public boolean hasUdi() {
7409      if (this.udi == null)
7410        return false;
7411      for (Reference item : this.udi)
7412        if (!item.isEmpty())
7413          return true;
7414      return false;
7415    }
7416
7417    public Reference addUdi() { // 3
7418      Reference t = new Reference();
7419      if (this.udi == null)
7420        this.udi = new ArrayList<Reference>();
7421      this.udi.add(t);
7422      return t;
7423    }
7424
7425    public DetailComponent addUdi(Reference t) { // 3
7426      if (t == null)
7427        return this;
7428      if (this.udi == null)
7429        this.udi = new ArrayList<Reference>();
7430      this.udi.add(t);
7431      return this;
7432    }
7433
7434    /**
7435     * @return The first repetition of repeating field {@link #udi}, creating it if
7436     *         it does not already exist
7437     */
7438    public Reference getUdiFirstRep() {
7439      if (getUdi().isEmpty()) {
7440        addUdi();
7441      }
7442      return getUdi().get(0);
7443    }
7444
7445    /**
7446     * @deprecated Use Reference#setResource(IBaseResource) instead
7447     */
7448    @Deprecated
7449    public List<Device> getUdiTarget() {
7450      if (this.udiTarget == null)
7451        this.udiTarget = new ArrayList<Device>();
7452      return this.udiTarget;
7453    }
7454
7455    /**
7456     * @deprecated Use Reference#setResource(IBaseResource) instead
7457     */
7458    @Deprecated
7459    public Device addUdiTarget() {
7460      Device r = new Device();
7461      if (this.udiTarget == null)
7462        this.udiTarget = new ArrayList<Device>();
7463      this.udiTarget.add(r);
7464      return r;
7465    }
7466
7467    /**
7468     * @return {@link #noteNumber} (The numbers associated with notes below which
7469     *         apply to the adjudication of this item.)
7470     */
7471    public List<PositiveIntType> getNoteNumber() {
7472      if (this.noteNumber == null)
7473        this.noteNumber = new ArrayList<PositiveIntType>();
7474      return this.noteNumber;
7475    }
7476
7477    /**
7478     * @return Returns a reference to <code>this</code> for easy method chaining
7479     */
7480    public DetailComponent setNoteNumber(List<PositiveIntType> theNoteNumber) {
7481      this.noteNumber = theNoteNumber;
7482      return this;
7483    }
7484
7485    public boolean hasNoteNumber() {
7486      if (this.noteNumber == null)
7487        return false;
7488      for (PositiveIntType item : this.noteNumber)
7489        if (!item.isEmpty())
7490          return true;
7491      return false;
7492    }
7493
7494    /**
7495     * @return {@link #noteNumber} (The numbers associated with notes below which
7496     *         apply to the adjudication of this item.)
7497     */
7498    public PositiveIntType addNoteNumberElement() {// 2
7499      PositiveIntType t = new PositiveIntType();
7500      if (this.noteNumber == null)
7501        this.noteNumber = new ArrayList<PositiveIntType>();
7502      this.noteNumber.add(t);
7503      return t;
7504    }
7505
7506    /**
7507     * @param value {@link #noteNumber} (The numbers associated with notes below
7508     *              which apply to the adjudication of this item.)
7509     */
7510    public DetailComponent addNoteNumber(int value) { // 1
7511      PositiveIntType t = new PositiveIntType();
7512      t.setValue(value);
7513      if (this.noteNumber == null)
7514        this.noteNumber = new ArrayList<PositiveIntType>();
7515      this.noteNumber.add(t);
7516      return this;
7517    }
7518
7519    /**
7520     * @param value {@link #noteNumber} (The numbers associated with notes below
7521     *              which apply to the adjudication of this item.)
7522     */
7523    public boolean hasNoteNumber(int value) {
7524      if (this.noteNumber == null)
7525        return false;
7526      for (PositiveIntType v : this.noteNumber)
7527        if (v.getValue().equals(value)) // positiveInt
7528          return true;
7529      return false;
7530    }
7531
7532    /**
7533     * @return {@link #adjudication} (The adjudication results.)
7534     */
7535    public List<AdjudicationComponent> getAdjudication() {
7536      if (this.adjudication == null)
7537        this.adjudication = new ArrayList<AdjudicationComponent>();
7538      return this.adjudication;
7539    }
7540
7541    /**
7542     * @return Returns a reference to <code>this</code> for easy method chaining
7543     */
7544    public DetailComponent setAdjudication(List<AdjudicationComponent> theAdjudication) {
7545      this.adjudication = theAdjudication;
7546      return this;
7547    }
7548
7549    public boolean hasAdjudication() {
7550      if (this.adjudication == null)
7551        return false;
7552      for (AdjudicationComponent item : this.adjudication)
7553        if (!item.isEmpty())
7554          return true;
7555      return false;
7556    }
7557
7558    public AdjudicationComponent addAdjudication() { // 3
7559      AdjudicationComponent t = new AdjudicationComponent();
7560      if (this.adjudication == null)
7561        this.adjudication = new ArrayList<AdjudicationComponent>();
7562      this.adjudication.add(t);
7563      return t;
7564    }
7565
7566    public DetailComponent addAdjudication(AdjudicationComponent t) { // 3
7567      if (t == null)
7568        return this;
7569      if (this.adjudication == null)
7570        this.adjudication = new ArrayList<AdjudicationComponent>();
7571      this.adjudication.add(t);
7572      return this;
7573    }
7574
7575    /**
7576     * @return The first repetition of repeating field {@link #adjudication},
7577     *         creating it if it does not already exist
7578     */
7579    public AdjudicationComponent getAdjudicationFirstRep() {
7580      if (getAdjudication().isEmpty()) {
7581        addAdjudication();
7582      }
7583      return getAdjudication().get(0);
7584    }
7585
7586    /**
7587     * @return {@link #subDetail} (Third-tier of goods and services.)
7588     */
7589    public List<SubDetailComponent> getSubDetail() {
7590      if (this.subDetail == null)
7591        this.subDetail = new ArrayList<SubDetailComponent>();
7592      return this.subDetail;
7593    }
7594
7595    /**
7596     * @return Returns a reference to <code>this</code> for easy method chaining
7597     */
7598    public DetailComponent setSubDetail(List<SubDetailComponent> theSubDetail) {
7599      this.subDetail = theSubDetail;
7600      return this;
7601    }
7602
7603    public boolean hasSubDetail() {
7604      if (this.subDetail == null)
7605        return false;
7606      for (SubDetailComponent item : this.subDetail)
7607        if (!item.isEmpty())
7608          return true;
7609      return false;
7610    }
7611
7612    public SubDetailComponent addSubDetail() { // 3
7613      SubDetailComponent t = new SubDetailComponent();
7614      if (this.subDetail == null)
7615        this.subDetail = new ArrayList<SubDetailComponent>();
7616      this.subDetail.add(t);
7617      return t;
7618    }
7619
7620    public DetailComponent addSubDetail(SubDetailComponent t) { // 3
7621      if (t == null)
7622        return this;
7623      if (this.subDetail == null)
7624        this.subDetail = new ArrayList<SubDetailComponent>();
7625      this.subDetail.add(t);
7626      return this;
7627    }
7628
7629    /**
7630     * @return The first repetition of repeating field {@link #subDetail}, creating
7631     *         it if it does not already exist
7632     */
7633    public SubDetailComponent getSubDetailFirstRep() {
7634      if (getSubDetail().isEmpty()) {
7635        addSubDetail();
7636      }
7637      return getSubDetail().get(0);
7638    }
7639
7640    protected void listChildren(List<Property> children) {
7641      super.listChildren(children);
7642      children.add(new Property("sequence", "positiveInt",
7643          "A claim detail line. Either a simple (a product or service) or a 'group' of sub-details which are simple items.",
7644          0, 1, sequence));
7645      children.add(new Property("revenue", "CodeableConcept",
7646          "The type of revenue or cost center providing the product and/or service.", 0, 1, revenue));
7647      children.add(new Property("category", "CodeableConcept",
7648          "Code to identify the general type of benefits under which products and services are provided.", 0, 1,
7649          category));
7650      children.add(new Property("productOrService", "CodeableConcept",
7651          "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
7652          0, 1, productOrService));
7653      children.add(new Property("modifier", "CodeableConcept",
7654          "Item typification or modifiers codes to convey additional context for the product or service.", 0,
7655          java.lang.Integer.MAX_VALUE, modifier));
7656      children.add(new Property("programCode", "CodeableConcept",
7657          "Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode));
7658      children.add(new Property("quantity", "SimpleQuantity", "The number of repetitions of a service or product.", 0,
7659          1, quantity));
7660      children.add(new Property("unitPrice", "Money",
7661          "If the item is not a group then this is the fee for the product or service, otherwise this is the total of the fees for the details of the group.",
7662          0, 1, unitPrice));
7663      children.add(new Property("factor", "decimal",
7664          "A real number that represents a multiplier used in determining the overall value of services delivered and/or goods received. The concept of a Factor allows for a discount or surcharge multiplier to be applied to a monetary amount.",
7665          0, 1, factor));
7666      children.add(new Property("net", "Money",
7667          "The quantity times the unit price for an additional service or product or charge.", 0, 1, net));
7668      children.add(new Property("udi", "Reference(Device)", "Unique Device Identifiers associated with this line item.",
7669          0, java.lang.Integer.MAX_VALUE, udi));
7670      children.add(new Property("noteNumber", "positiveInt",
7671          "The numbers associated with notes below which apply to the adjudication of this item.", 0,
7672          java.lang.Integer.MAX_VALUE, noteNumber));
7673      children.add(new Property("adjudication", "@ExplanationOfBenefit.item.adjudication", "The adjudication results.",
7674          0, java.lang.Integer.MAX_VALUE, adjudication));
7675      children.add(new Property("subDetail", "", "Third-tier of goods and services.", 0, java.lang.Integer.MAX_VALUE,
7676          subDetail));
7677    }
7678
7679    @Override
7680    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
7681      switch (_hash) {
7682      case 1349547969:
7683        /* sequence */ return new Property("sequence", "positiveInt",
7684            "A claim detail line. Either a simple (a product or service) or a 'group' of sub-details which are simple items.",
7685            0, 1, sequence);
7686      case 1099842588:
7687        /* revenue */ return new Property("revenue", "CodeableConcept",
7688            "The type of revenue or cost center providing the product and/or service.", 0, 1, revenue);
7689      case 50511102:
7690        /* category */ return new Property("category", "CodeableConcept",
7691            "Code to identify the general type of benefits under which products and services are provided.", 0, 1,
7692            category);
7693      case 1957227299:
7694        /* productOrService */ return new Property("productOrService", "CodeableConcept",
7695            "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
7696            0, 1, productOrService);
7697      case -615513385:
7698        /* modifier */ return new Property("modifier", "CodeableConcept",
7699            "Item typification or modifiers codes to convey additional context for the product or service.", 0,
7700            java.lang.Integer.MAX_VALUE, modifier);
7701      case 1010065041:
7702        /* programCode */ return new Property("programCode", "CodeableConcept",
7703            "Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode);
7704      case -1285004149:
7705        /* quantity */ return new Property("quantity", "SimpleQuantity",
7706            "The number of repetitions of a service or product.", 0, 1, quantity);
7707      case -486196699:
7708        /* unitPrice */ return new Property("unitPrice", "Money",
7709            "If the item is not a group then this is the fee for the product or service, otherwise this is the total of the fees for the details of the group.",
7710            0, 1, unitPrice);
7711      case -1282148017:
7712        /* factor */ return new Property("factor", "decimal",
7713            "A real number that represents a multiplier used in determining the overall value of services delivered and/or goods received. The concept of a Factor allows for a discount or surcharge multiplier to be applied to a monetary amount.",
7714            0, 1, factor);
7715      case 108957:
7716        /* net */ return new Property("net", "Money",
7717            "The quantity times the unit price for an additional service or product or charge.", 0, 1, net);
7718      case 115642:
7719        /* udi */ return new Property("udi", "Reference(Device)",
7720            "Unique Device Identifiers associated with this line item.", 0, java.lang.Integer.MAX_VALUE, udi);
7721      case -1110033957:
7722        /* noteNumber */ return new Property("noteNumber", "positiveInt",
7723            "The numbers associated with notes below which apply to the adjudication of this item.", 0,
7724            java.lang.Integer.MAX_VALUE, noteNumber);
7725      case -231349275:
7726        /* adjudication */ return new Property("adjudication", "@ExplanationOfBenefit.item.adjudication",
7727            "The adjudication results.", 0, java.lang.Integer.MAX_VALUE, adjudication);
7728      case -828829007:
7729        /* subDetail */ return new Property("subDetail", "", "Third-tier of goods and services.", 0,
7730            java.lang.Integer.MAX_VALUE, subDetail);
7731      default:
7732        return super.getNamedProperty(_hash, _name, _checkValid);
7733      }
7734
7735    }
7736
7737    @Override
7738    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
7739      switch (hash) {
7740      case 1349547969:
7741        /* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
7742      case 1099842588:
7743        /* revenue */ return this.revenue == null ? new Base[0] : new Base[] { this.revenue }; // CodeableConcept
7744      case 50511102:
7745        /* category */ return this.category == null ? new Base[0] : new Base[] { this.category }; // CodeableConcept
7746      case 1957227299:
7747        /* productOrService */ return this.productOrService == null ? new Base[0]
7748            : new Base[] { this.productOrService }; // CodeableConcept
7749      case -615513385:
7750        /* modifier */ return this.modifier == null ? new Base[0]
7751            : this.modifier.toArray(new Base[this.modifier.size()]); // CodeableConcept
7752      case 1010065041:
7753        /* programCode */ return this.programCode == null ? new Base[0]
7754            : this.programCode.toArray(new Base[this.programCode.size()]); // CodeableConcept
7755      case -1285004149:
7756        /* quantity */ return this.quantity == null ? new Base[0] : new Base[] { this.quantity }; // Quantity
7757      case -486196699:
7758        /* unitPrice */ return this.unitPrice == null ? new Base[0] : new Base[] { this.unitPrice }; // Money
7759      case -1282148017:
7760        /* factor */ return this.factor == null ? new Base[0] : new Base[] { this.factor }; // DecimalType
7761      case 108957:
7762        /* net */ return this.net == null ? new Base[0] : new Base[] { this.net }; // Money
7763      case 115642:
7764        /* udi */ return this.udi == null ? new Base[0] : this.udi.toArray(new Base[this.udi.size()]); // Reference
7765      case -1110033957:
7766        /* noteNumber */ return this.noteNumber == null ? new Base[0]
7767            : this.noteNumber.toArray(new Base[this.noteNumber.size()]); // PositiveIntType
7768      case -231349275:
7769        /* adjudication */ return this.adjudication == null ? new Base[0]
7770            : this.adjudication.toArray(new Base[this.adjudication.size()]); // AdjudicationComponent
7771      case -828829007:
7772        /* subDetail */ return this.subDetail == null ? new Base[0]
7773            : this.subDetail.toArray(new Base[this.subDetail.size()]); // SubDetailComponent
7774      default:
7775        return super.getProperty(hash, name, checkValid);
7776      }
7777
7778    }
7779
7780    @Override
7781    public Base setProperty(int hash, String name, Base value) throws FHIRException {
7782      switch (hash) {
7783      case 1349547969: // sequence
7784        this.sequence = castToPositiveInt(value); // PositiveIntType
7785        return value;
7786      case 1099842588: // revenue
7787        this.revenue = castToCodeableConcept(value); // CodeableConcept
7788        return value;
7789      case 50511102: // category
7790        this.category = castToCodeableConcept(value); // CodeableConcept
7791        return value;
7792      case 1957227299: // productOrService
7793        this.productOrService = castToCodeableConcept(value); // CodeableConcept
7794        return value;
7795      case -615513385: // modifier
7796        this.getModifier().add(castToCodeableConcept(value)); // CodeableConcept
7797        return value;
7798      case 1010065041: // programCode
7799        this.getProgramCode().add(castToCodeableConcept(value)); // CodeableConcept
7800        return value;
7801      case -1285004149: // quantity
7802        this.quantity = castToQuantity(value); // Quantity
7803        return value;
7804      case -486196699: // unitPrice
7805        this.unitPrice = castToMoney(value); // Money
7806        return value;
7807      case -1282148017: // factor
7808        this.factor = castToDecimal(value); // DecimalType
7809        return value;
7810      case 108957: // net
7811        this.net = castToMoney(value); // Money
7812        return value;
7813      case 115642: // udi
7814        this.getUdi().add(castToReference(value)); // Reference
7815        return value;
7816      case -1110033957: // noteNumber
7817        this.getNoteNumber().add(castToPositiveInt(value)); // PositiveIntType
7818        return value;
7819      case -231349275: // adjudication
7820        this.getAdjudication().add((AdjudicationComponent) value); // AdjudicationComponent
7821        return value;
7822      case -828829007: // subDetail
7823        this.getSubDetail().add((SubDetailComponent) value); // SubDetailComponent
7824        return value;
7825      default:
7826        return super.setProperty(hash, name, value);
7827      }
7828
7829    }
7830
7831    @Override
7832    public Base setProperty(String name, Base value) throws FHIRException {
7833      if (name.equals("sequence")) {
7834        this.sequence = castToPositiveInt(value); // PositiveIntType
7835      } else if (name.equals("revenue")) {
7836        this.revenue = castToCodeableConcept(value); // CodeableConcept
7837      } else if (name.equals("category")) {
7838        this.category = castToCodeableConcept(value); // CodeableConcept
7839      } else if (name.equals("productOrService")) {
7840        this.productOrService = castToCodeableConcept(value); // CodeableConcept
7841      } else if (name.equals("modifier")) {
7842        this.getModifier().add(castToCodeableConcept(value));
7843      } else if (name.equals("programCode")) {
7844        this.getProgramCode().add(castToCodeableConcept(value));
7845      } else if (name.equals("quantity")) {
7846        this.quantity = castToQuantity(value); // Quantity
7847      } else if (name.equals("unitPrice")) {
7848        this.unitPrice = castToMoney(value); // Money
7849      } else if (name.equals("factor")) {
7850        this.factor = castToDecimal(value); // DecimalType
7851      } else if (name.equals("net")) {
7852        this.net = castToMoney(value); // Money
7853      } else if (name.equals("udi")) {
7854        this.getUdi().add(castToReference(value));
7855      } else if (name.equals("noteNumber")) {
7856        this.getNoteNumber().add(castToPositiveInt(value));
7857      } else if (name.equals("adjudication")) {
7858        this.getAdjudication().add((AdjudicationComponent) value);
7859      } else if (name.equals("subDetail")) {
7860        this.getSubDetail().add((SubDetailComponent) value);
7861      } else
7862        return super.setProperty(name, value);
7863      return value;
7864    }
7865
7866  @Override
7867  public void removeChild(String name, Base value) throws FHIRException {
7868      if (name.equals("sequence")) {
7869        this.sequence = null;
7870      } else if (name.equals("revenue")) {
7871        this.revenue = null;
7872      } else if (name.equals("category")) {
7873        this.category = null;
7874      } else if (name.equals("productOrService")) {
7875        this.productOrService = null;
7876      } else if (name.equals("modifier")) {
7877        this.getModifier().remove(castToCodeableConcept(value));
7878      } else if (name.equals("programCode")) {
7879        this.getProgramCode().remove(castToCodeableConcept(value));
7880      } else if (name.equals("quantity")) {
7881        this.quantity = null;
7882      } else if (name.equals("unitPrice")) {
7883        this.unitPrice = null;
7884      } else if (name.equals("factor")) {
7885        this.factor = null;
7886      } else if (name.equals("net")) {
7887        this.net = null;
7888      } else if (name.equals("udi")) {
7889        this.getUdi().remove(castToReference(value));
7890      } else if (name.equals("noteNumber")) {
7891        this.getNoteNumber().remove(castToPositiveInt(value));
7892      } else if (name.equals("adjudication")) {
7893        this.getAdjudication().remove((AdjudicationComponent) value);
7894      } else if (name.equals("subDetail")) {
7895        this.getSubDetail().remove((SubDetailComponent) value);
7896      } else
7897        super.removeChild(name, value);
7898      
7899    }
7900
7901    @Override
7902    public Base makeProperty(int hash, String name) throws FHIRException {
7903      switch (hash) {
7904      case 1349547969:
7905        return getSequenceElement();
7906      case 1099842588:
7907        return getRevenue();
7908      case 50511102:
7909        return getCategory();
7910      case 1957227299:
7911        return getProductOrService();
7912      case -615513385:
7913        return addModifier();
7914      case 1010065041:
7915        return addProgramCode();
7916      case -1285004149:
7917        return getQuantity();
7918      case -486196699:
7919        return getUnitPrice();
7920      case -1282148017:
7921        return getFactorElement();
7922      case 108957:
7923        return getNet();
7924      case 115642:
7925        return addUdi();
7926      case -1110033957:
7927        return addNoteNumberElement();
7928      case -231349275:
7929        return addAdjudication();
7930      case -828829007:
7931        return addSubDetail();
7932      default:
7933        return super.makeProperty(hash, name);
7934      }
7935
7936    }
7937
7938    @Override
7939    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
7940      switch (hash) {
7941      case 1349547969:
7942        /* sequence */ return new String[] { "positiveInt" };
7943      case 1099842588:
7944        /* revenue */ return new String[] { "CodeableConcept" };
7945      case 50511102:
7946        /* category */ return new String[] { "CodeableConcept" };
7947      case 1957227299:
7948        /* productOrService */ return new String[] { "CodeableConcept" };
7949      case -615513385:
7950        /* modifier */ return new String[] { "CodeableConcept" };
7951      case 1010065041:
7952        /* programCode */ return new String[] { "CodeableConcept" };
7953      case -1285004149:
7954        /* quantity */ return new String[] { "SimpleQuantity" };
7955      case -486196699:
7956        /* unitPrice */ return new String[] { "Money" };
7957      case -1282148017:
7958        /* factor */ return new String[] { "decimal" };
7959      case 108957:
7960        /* net */ return new String[] { "Money" };
7961      case 115642:
7962        /* udi */ return new String[] { "Reference" };
7963      case -1110033957:
7964        /* noteNumber */ return new String[] { "positiveInt" };
7965      case -231349275:
7966        /* adjudication */ return new String[] { "@ExplanationOfBenefit.item.adjudication" };
7967      case -828829007:
7968        /* subDetail */ return new String[] {};
7969      default:
7970        return super.getTypesForProperty(hash, name);
7971      }
7972
7973    }
7974
7975    @Override
7976    public Base addChild(String name) throws FHIRException {
7977      if (name.equals("sequence")) {
7978        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
7979      } else if (name.equals("revenue")) {
7980        this.revenue = new CodeableConcept();
7981        return this.revenue;
7982      } else if (name.equals("category")) {
7983        this.category = new CodeableConcept();
7984        return this.category;
7985      } else if (name.equals("productOrService")) {
7986        this.productOrService = new CodeableConcept();
7987        return this.productOrService;
7988      } else if (name.equals("modifier")) {
7989        return addModifier();
7990      } else if (name.equals("programCode")) {
7991        return addProgramCode();
7992      } else if (name.equals("quantity")) {
7993        this.quantity = new Quantity();
7994        return this.quantity;
7995      } else if (name.equals("unitPrice")) {
7996        this.unitPrice = new Money();
7997        return this.unitPrice;
7998      } else if (name.equals("factor")) {
7999        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.factor");
8000      } else if (name.equals("net")) {
8001        this.net = new Money();
8002        return this.net;
8003      } else if (name.equals("udi")) {
8004        return addUdi();
8005      } else if (name.equals("noteNumber")) {
8006        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.noteNumber");
8007      } else if (name.equals("adjudication")) {
8008        return addAdjudication();
8009      } else if (name.equals("subDetail")) {
8010        return addSubDetail();
8011      } else
8012        return super.addChild(name);
8013    }
8014
8015    public DetailComponent copy() {
8016      DetailComponent dst = new DetailComponent();
8017      copyValues(dst);
8018      return dst;
8019    }
8020
8021    public void copyValues(DetailComponent dst) {
8022      super.copyValues(dst);
8023      dst.sequence = sequence == null ? null : sequence.copy();
8024      dst.revenue = revenue == null ? null : revenue.copy();
8025      dst.category = category == null ? null : category.copy();
8026      dst.productOrService = productOrService == null ? null : productOrService.copy();
8027      if (modifier != null) {
8028        dst.modifier = new ArrayList<CodeableConcept>();
8029        for (CodeableConcept i : modifier)
8030          dst.modifier.add(i.copy());
8031      }
8032      ;
8033      if (programCode != null) {
8034        dst.programCode = new ArrayList<CodeableConcept>();
8035        for (CodeableConcept i : programCode)
8036          dst.programCode.add(i.copy());
8037      }
8038      ;
8039      dst.quantity = quantity == null ? null : quantity.copy();
8040      dst.unitPrice = unitPrice == null ? null : unitPrice.copy();
8041      dst.factor = factor == null ? null : factor.copy();
8042      dst.net = net == null ? null : net.copy();
8043      if (udi != null) {
8044        dst.udi = new ArrayList<Reference>();
8045        for (Reference i : udi)
8046          dst.udi.add(i.copy());
8047      }
8048      ;
8049      if (noteNumber != null) {
8050        dst.noteNumber = new ArrayList<PositiveIntType>();
8051        for (PositiveIntType i : noteNumber)
8052          dst.noteNumber.add(i.copy());
8053      }
8054      ;
8055      if (adjudication != null) {
8056        dst.adjudication = new ArrayList<AdjudicationComponent>();
8057        for (AdjudicationComponent i : adjudication)
8058          dst.adjudication.add(i.copy());
8059      }
8060      ;
8061      if (subDetail != null) {
8062        dst.subDetail = new ArrayList<SubDetailComponent>();
8063        for (SubDetailComponent i : subDetail)
8064          dst.subDetail.add(i.copy());
8065      }
8066      ;
8067    }
8068
8069    @Override
8070    public boolean equalsDeep(Base other_) {
8071      if (!super.equalsDeep(other_))
8072        return false;
8073      if (!(other_ instanceof DetailComponent))
8074        return false;
8075      DetailComponent o = (DetailComponent) other_;
8076      return compareDeep(sequence, o.sequence, true) && compareDeep(revenue, o.revenue, true)
8077          && compareDeep(category, o.category, true) && compareDeep(productOrService, o.productOrService, true)
8078          && compareDeep(modifier, o.modifier, true) && compareDeep(programCode, o.programCode, true)
8079          && compareDeep(quantity, o.quantity, true) && compareDeep(unitPrice, o.unitPrice, true)
8080          && compareDeep(factor, o.factor, true) && compareDeep(net, o.net, true) && compareDeep(udi, o.udi, true)
8081          && compareDeep(noteNumber, o.noteNumber, true) && compareDeep(adjudication, o.adjudication, true)
8082          && compareDeep(subDetail, o.subDetail, true);
8083    }
8084
8085    @Override
8086    public boolean equalsShallow(Base other_) {
8087      if (!super.equalsShallow(other_))
8088        return false;
8089      if (!(other_ instanceof DetailComponent))
8090        return false;
8091      DetailComponent o = (DetailComponent) other_;
8092      return compareValues(sequence, o.sequence, true) && compareValues(factor, o.factor, true)
8093          && compareValues(noteNumber, o.noteNumber, true);
8094    }
8095
8096    public boolean isEmpty() {
8097      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, revenue, category, productOrService,
8098          modifier, programCode, quantity, unitPrice, factor, net, udi, noteNumber, adjudication, subDetail);
8099    }
8100
8101    public String fhirType() {
8102      return "ExplanationOfBenefit.item.detail";
8103
8104    }
8105
8106  }
8107
8108  @Block()
8109  public static class SubDetailComponent extends BackboneElement implements IBaseBackboneElement {
8110    /**
8111     * A claim detail line. Either a simple (a product or service) or a 'group' of
8112     * sub-details which are simple items.
8113     */
8114    @Child(name = "sequence", type = {
8115        PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
8116    @Description(shortDefinition = "Product or service provided", formalDefinition = "A claim detail line. Either a simple (a product or service) or a 'group' of sub-details which are simple items.")
8117    protected PositiveIntType sequence;
8118
8119    /**
8120     * The type of revenue or cost center providing the product and/or service.
8121     */
8122    @Child(name = "revenue", type = {
8123        CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
8124    @Description(shortDefinition = "Revenue or cost center code", formalDefinition = "The type of revenue or cost center providing the product and/or service.")
8125    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-revenue-center")
8126    protected CodeableConcept revenue;
8127
8128    /**
8129     * Code to identify the general type of benefits under which products and
8130     * services are provided.
8131     */
8132    @Child(name = "category", type = {
8133        CodeableConcept.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
8134    @Description(shortDefinition = "Benefit classification", formalDefinition = "Code to identify the general type of benefits under which products and services are provided.")
8135    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-benefitcategory")
8136    protected CodeableConcept category;
8137
8138    /**
8139     * When the value is a group code then this item collects a set of related claim
8140     * details, otherwise this contains the product, service, drug or other billing
8141     * code for the item.
8142     */
8143    @Child(name = "productOrService", type = {
8144        CodeableConcept.class }, order = 4, min = 1, max = 1, modifier = false, summary = false)
8145    @Description(shortDefinition = "Billing, service, product, or drug code", formalDefinition = "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.")
8146    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-uscls")
8147    protected CodeableConcept productOrService;
8148
8149    /**
8150     * Item typification or modifiers codes to convey additional context for the
8151     * product or service.
8152     */
8153    @Child(name = "modifier", type = {
8154        CodeableConcept.class }, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
8155    @Description(shortDefinition = "Service/Product billing modifiers", formalDefinition = "Item typification or modifiers codes to convey additional context for the product or service.")
8156    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-modifiers")
8157    protected List<CodeableConcept> modifier;
8158
8159    /**
8160     * Identifies the program under which this may be recovered.
8161     */
8162    @Child(name = "programCode", type = {
8163        CodeableConcept.class }, order = 6, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
8164    @Description(shortDefinition = "Program the product or service is provided under", formalDefinition = "Identifies the program under which this may be recovered.")
8165    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-program-code")
8166    protected List<CodeableConcept> programCode;
8167
8168    /**
8169     * The number of repetitions of a service or product.
8170     */
8171    @Child(name = "quantity", type = { Quantity.class }, order = 7, min = 0, max = 1, modifier = false, summary = false)
8172    @Description(shortDefinition = "Count of products or services", formalDefinition = "The number of repetitions of a service or product.")
8173    protected Quantity quantity;
8174
8175    /**
8176     * If the item is not a group then this is the fee for the product or service,
8177     * otherwise this is the total of the fees for the details of the group.
8178     */
8179    @Child(name = "unitPrice", type = { Money.class }, order = 8, min = 0, max = 1, modifier = false, summary = false)
8180    @Description(shortDefinition = "Fee, charge or cost per item", formalDefinition = "If the item is not a group then this is the fee for the product or service, otherwise this is the total of the fees for the details of the group.")
8181    protected Money unitPrice;
8182
8183    /**
8184     * A real number that represents a multiplier used in determining the overall
8185     * value of services delivered and/or goods received. The concept of a Factor
8186     * allows for a discount or surcharge multiplier to be applied to a monetary
8187     * amount.
8188     */
8189    @Child(name = "factor", type = {
8190        DecimalType.class }, order = 9, min = 0, max = 1, modifier = false, summary = false)
8191    @Description(shortDefinition = "Price scaling factor", formalDefinition = "A real number that represents a multiplier used in determining the overall value of services delivered and/or goods received. The concept of a Factor allows for a discount or surcharge multiplier to be applied to a monetary amount.")
8192    protected DecimalType factor;
8193
8194    /**
8195     * The quantity times the unit price for an additional service or product or
8196     * charge.
8197     */
8198    @Child(name = "net", type = { Money.class }, order = 10, min = 0, max = 1, modifier = false, summary = false)
8199    @Description(shortDefinition = "Total item cost", formalDefinition = "The quantity times the unit price for an additional service or product or charge.")
8200    protected Money net;
8201
8202    /**
8203     * Unique Device Identifiers associated with this line item.
8204     */
8205    @Child(name = "udi", type = {
8206        Device.class }, order = 11, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
8207    @Description(shortDefinition = "Unique device identifier", formalDefinition = "Unique Device Identifiers associated with this line item.")
8208    protected List<Reference> udi;
8209    /**
8210     * The actual objects that are the target of the reference (Unique Device
8211     * Identifiers associated with this line item.)
8212     */
8213    protected List<Device> udiTarget;
8214
8215    /**
8216     * The numbers associated with notes below which apply to the adjudication of
8217     * this item.
8218     */
8219    @Child(name = "noteNumber", type = {
8220        PositiveIntType.class }, order = 12, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
8221    @Description(shortDefinition = "Applicable note numbers", formalDefinition = "The numbers associated with notes below which apply to the adjudication of this item.")
8222    protected List<PositiveIntType> noteNumber;
8223
8224    /**
8225     * The adjudication results.
8226     */
8227    @Child(name = "adjudication", type = {
8228        AdjudicationComponent.class }, order = 13, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
8229    @Description(shortDefinition = "Subdetail level adjudication details", formalDefinition = "The adjudication results.")
8230    protected List<AdjudicationComponent> adjudication;
8231
8232    private static final long serialVersionUID = -996156853L;
8233
8234    /**
8235     * Constructor
8236     */
8237    public SubDetailComponent() {
8238      super();
8239    }
8240
8241    /**
8242     * Constructor
8243     */
8244    public SubDetailComponent(PositiveIntType sequence, CodeableConcept productOrService) {
8245      super();
8246      this.sequence = sequence;
8247      this.productOrService = productOrService;
8248    }
8249
8250    /**
8251     * @return {@link #sequence} (A claim detail line. Either a simple (a product or
8252     *         service) or a 'group' of sub-details which are simple items.). This
8253     *         is the underlying object with id, value and extensions. The accessor
8254     *         "getSequence" gives direct access to the value
8255     */
8256    public PositiveIntType getSequenceElement() {
8257      if (this.sequence == null)
8258        if (Configuration.errorOnAutoCreate())
8259          throw new Error("Attempt to auto-create SubDetailComponent.sequence");
8260        else if (Configuration.doAutoCreate())
8261          this.sequence = new PositiveIntType(); // bb
8262      return this.sequence;
8263    }
8264
8265    public boolean hasSequenceElement() {
8266      return this.sequence != null && !this.sequence.isEmpty();
8267    }
8268
8269    public boolean hasSequence() {
8270      return this.sequence != null && !this.sequence.isEmpty();
8271    }
8272
8273    /**
8274     * @param value {@link #sequence} (A claim detail line. Either a simple (a
8275     *              product or service) or a 'group' of sub-details which are simple
8276     *              items.). This is the underlying object with id, value and
8277     *              extensions. The accessor "getSequence" gives direct access to
8278     *              the value
8279     */
8280    public SubDetailComponent setSequenceElement(PositiveIntType value) {
8281      this.sequence = value;
8282      return this;
8283    }
8284
8285    /**
8286     * @return A claim detail line. Either a simple (a product or service) or a
8287     *         'group' of sub-details which are simple items.
8288     */
8289    public int getSequence() {
8290      return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
8291    }
8292
8293    /**
8294     * @param value A claim detail line. Either a simple (a product or service) or a
8295     *              'group' of sub-details which are simple items.
8296     */
8297    public SubDetailComponent setSequence(int value) {
8298      if (this.sequence == null)
8299        this.sequence = new PositiveIntType();
8300      this.sequence.setValue(value);
8301      return this;
8302    }
8303
8304    /**
8305     * @return {@link #revenue} (The type of revenue or cost center providing the
8306     *         product and/or service.)
8307     */
8308    public CodeableConcept getRevenue() {
8309      if (this.revenue == null)
8310        if (Configuration.errorOnAutoCreate())
8311          throw new Error("Attempt to auto-create SubDetailComponent.revenue");
8312        else if (Configuration.doAutoCreate())
8313          this.revenue = new CodeableConcept(); // cc
8314      return this.revenue;
8315    }
8316
8317    public boolean hasRevenue() {
8318      return this.revenue != null && !this.revenue.isEmpty();
8319    }
8320
8321    /**
8322     * @param value {@link #revenue} (The type of revenue or cost center providing
8323     *              the product and/or service.)
8324     */
8325    public SubDetailComponent setRevenue(CodeableConcept value) {
8326      this.revenue = value;
8327      return this;
8328    }
8329
8330    /**
8331     * @return {@link #category} (Code to identify the general type of benefits
8332     *         under which products and services are provided.)
8333     */
8334    public CodeableConcept getCategory() {
8335      if (this.category == null)
8336        if (Configuration.errorOnAutoCreate())
8337          throw new Error("Attempt to auto-create SubDetailComponent.category");
8338        else if (Configuration.doAutoCreate())
8339          this.category = new CodeableConcept(); // cc
8340      return this.category;
8341    }
8342
8343    public boolean hasCategory() {
8344      return this.category != null && !this.category.isEmpty();
8345    }
8346
8347    /**
8348     * @param value {@link #category} (Code to identify the general type of benefits
8349     *              under which products and services are provided.)
8350     */
8351    public SubDetailComponent setCategory(CodeableConcept value) {
8352      this.category = value;
8353      return this;
8354    }
8355
8356    /**
8357     * @return {@link #productOrService} (When the value is a group code then this
8358     *         item collects a set of related claim details, otherwise this contains
8359     *         the product, service, drug or other billing code for the item.)
8360     */
8361    public CodeableConcept getProductOrService() {
8362      if (this.productOrService == null)
8363        if (Configuration.errorOnAutoCreate())
8364          throw new Error("Attempt to auto-create SubDetailComponent.productOrService");
8365        else if (Configuration.doAutoCreate())
8366          this.productOrService = new CodeableConcept(); // cc
8367      return this.productOrService;
8368    }
8369
8370    public boolean hasProductOrService() {
8371      return this.productOrService != null && !this.productOrService.isEmpty();
8372    }
8373
8374    /**
8375     * @param value {@link #productOrService} (When the value is a group code then
8376     *              this item collects a set of related claim details, otherwise
8377     *              this contains the product, service, drug or other billing code
8378     *              for the item.)
8379     */
8380    public SubDetailComponent setProductOrService(CodeableConcept value) {
8381      this.productOrService = value;
8382      return this;
8383    }
8384
8385    /**
8386     * @return {@link #modifier} (Item typification or modifiers codes to convey
8387     *         additional context for the product or service.)
8388     */
8389    public List<CodeableConcept> getModifier() {
8390      if (this.modifier == null)
8391        this.modifier = new ArrayList<CodeableConcept>();
8392      return this.modifier;
8393    }
8394
8395    /**
8396     * @return Returns a reference to <code>this</code> for easy method chaining
8397     */
8398    public SubDetailComponent setModifier(List<CodeableConcept> theModifier) {
8399      this.modifier = theModifier;
8400      return this;
8401    }
8402
8403    public boolean hasModifier() {
8404      if (this.modifier == null)
8405        return false;
8406      for (CodeableConcept item : this.modifier)
8407        if (!item.isEmpty())
8408          return true;
8409      return false;
8410    }
8411
8412    public CodeableConcept addModifier() { // 3
8413      CodeableConcept t = new CodeableConcept();
8414      if (this.modifier == null)
8415        this.modifier = new ArrayList<CodeableConcept>();
8416      this.modifier.add(t);
8417      return t;
8418    }
8419
8420    public SubDetailComponent addModifier(CodeableConcept t) { // 3
8421      if (t == null)
8422        return this;
8423      if (this.modifier == null)
8424        this.modifier = new ArrayList<CodeableConcept>();
8425      this.modifier.add(t);
8426      return this;
8427    }
8428
8429    /**
8430     * @return The first repetition of repeating field {@link #modifier}, creating
8431     *         it if it does not already exist
8432     */
8433    public CodeableConcept getModifierFirstRep() {
8434      if (getModifier().isEmpty()) {
8435        addModifier();
8436      }
8437      return getModifier().get(0);
8438    }
8439
8440    /**
8441     * @return {@link #programCode} (Identifies the program under which this may be
8442     *         recovered.)
8443     */
8444    public List<CodeableConcept> getProgramCode() {
8445      if (this.programCode == null)
8446        this.programCode = new ArrayList<CodeableConcept>();
8447      return this.programCode;
8448    }
8449
8450    /**
8451     * @return Returns a reference to <code>this</code> for easy method chaining
8452     */
8453    public SubDetailComponent setProgramCode(List<CodeableConcept> theProgramCode) {
8454      this.programCode = theProgramCode;
8455      return this;
8456    }
8457
8458    public boolean hasProgramCode() {
8459      if (this.programCode == null)
8460        return false;
8461      for (CodeableConcept item : this.programCode)
8462        if (!item.isEmpty())
8463          return true;
8464      return false;
8465    }
8466
8467    public CodeableConcept addProgramCode() { // 3
8468      CodeableConcept t = new CodeableConcept();
8469      if (this.programCode == null)
8470        this.programCode = new ArrayList<CodeableConcept>();
8471      this.programCode.add(t);
8472      return t;
8473    }
8474
8475    public SubDetailComponent addProgramCode(CodeableConcept t) { // 3
8476      if (t == null)
8477        return this;
8478      if (this.programCode == null)
8479        this.programCode = new ArrayList<CodeableConcept>();
8480      this.programCode.add(t);
8481      return this;
8482    }
8483
8484    /**
8485     * @return The first repetition of repeating field {@link #programCode},
8486     *         creating it if it does not already exist
8487     */
8488    public CodeableConcept getProgramCodeFirstRep() {
8489      if (getProgramCode().isEmpty()) {
8490        addProgramCode();
8491      }
8492      return getProgramCode().get(0);
8493    }
8494
8495    /**
8496     * @return {@link #quantity} (The number of repetitions of a service or
8497     *         product.)
8498     */
8499    public Quantity getQuantity() {
8500      if (this.quantity == null)
8501        if (Configuration.errorOnAutoCreate())
8502          throw new Error("Attempt to auto-create SubDetailComponent.quantity");
8503        else if (Configuration.doAutoCreate())
8504          this.quantity = new Quantity(); // cc
8505      return this.quantity;
8506    }
8507
8508    public boolean hasQuantity() {
8509      return this.quantity != null && !this.quantity.isEmpty();
8510    }
8511
8512    /**
8513     * @param value {@link #quantity} (The number of repetitions of a service or
8514     *              product.)
8515     */
8516    public SubDetailComponent setQuantity(Quantity value) {
8517      this.quantity = value;
8518      return this;
8519    }
8520
8521    /**
8522     * @return {@link #unitPrice} (If the item is not a group then this is the fee
8523     *         for the product or service, otherwise this is the total of the fees
8524     *         for the details of the group.)
8525     */
8526    public Money getUnitPrice() {
8527      if (this.unitPrice == null)
8528        if (Configuration.errorOnAutoCreate())
8529          throw new Error("Attempt to auto-create SubDetailComponent.unitPrice");
8530        else if (Configuration.doAutoCreate())
8531          this.unitPrice = new Money(); // cc
8532      return this.unitPrice;
8533    }
8534
8535    public boolean hasUnitPrice() {
8536      return this.unitPrice != null && !this.unitPrice.isEmpty();
8537    }
8538
8539    /**
8540     * @param value {@link #unitPrice} (If the item is not a group then this is the
8541     *              fee for the product or service, otherwise this is the total of
8542     *              the fees for the details of the group.)
8543     */
8544    public SubDetailComponent setUnitPrice(Money value) {
8545      this.unitPrice = value;
8546      return this;
8547    }
8548
8549    /**
8550     * @return {@link #factor} (A real number that represents a multiplier used in
8551     *         determining the overall value of services delivered and/or goods
8552     *         received. The concept of a Factor allows for a discount or surcharge
8553     *         multiplier to be applied to a monetary amount.). This is the
8554     *         underlying object with id, value and extensions. The accessor
8555     *         "getFactor" gives direct access to the value
8556     */
8557    public DecimalType getFactorElement() {
8558      if (this.factor == null)
8559        if (Configuration.errorOnAutoCreate())
8560          throw new Error("Attempt to auto-create SubDetailComponent.factor");
8561        else if (Configuration.doAutoCreate())
8562          this.factor = new DecimalType(); // bb
8563      return this.factor;
8564    }
8565
8566    public boolean hasFactorElement() {
8567      return this.factor != null && !this.factor.isEmpty();
8568    }
8569
8570    public boolean hasFactor() {
8571      return this.factor != null && !this.factor.isEmpty();
8572    }
8573
8574    /**
8575     * @param value {@link #factor} (A real number that represents a multiplier used
8576     *              in determining the overall value of services delivered and/or
8577     *              goods received. The concept of a Factor allows for a discount or
8578     *              surcharge multiplier to be applied to a monetary amount.). This
8579     *              is the underlying object with id, value and extensions. The
8580     *              accessor "getFactor" gives direct access to the value
8581     */
8582    public SubDetailComponent setFactorElement(DecimalType value) {
8583      this.factor = value;
8584      return this;
8585    }
8586
8587    /**
8588     * @return A real number that represents a multiplier used in determining the
8589     *         overall value of services delivered and/or goods received. The
8590     *         concept of a Factor allows for a discount or surcharge multiplier to
8591     *         be applied to a monetary amount.
8592     */
8593    public BigDecimal getFactor() {
8594      return this.factor == null ? null : this.factor.getValue();
8595    }
8596
8597    /**
8598     * @param value A real number that represents a multiplier used in determining
8599     *              the overall value of services delivered and/or goods received.
8600     *              The concept of a Factor allows for a discount or surcharge
8601     *              multiplier to be applied to a monetary amount.
8602     */
8603    public SubDetailComponent setFactor(BigDecimal value) {
8604      if (value == null)
8605        this.factor = null;
8606      else {
8607        if (this.factor == null)
8608          this.factor = new DecimalType();
8609        this.factor.setValue(value);
8610      }
8611      return this;
8612    }
8613
8614    /**
8615     * @param value A real number that represents a multiplier used in determining
8616     *              the overall value of services delivered and/or goods received.
8617     *              The concept of a Factor allows for a discount or surcharge
8618     *              multiplier to be applied to a monetary amount.
8619     */
8620    public SubDetailComponent setFactor(long value) {
8621      this.factor = new DecimalType();
8622      this.factor.setValue(value);
8623      return this;
8624    }
8625
8626    /**
8627     * @param value A real number that represents a multiplier used in determining
8628     *              the overall value of services delivered and/or goods received.
8629     *              The concept of a Factor allows for a discount or surcharge
8630     *              multiplier to be applied to a monetary amount.
8631     */
8632    public SubDetailComponent setFactor(double value) {
8633      this.factor = new DecimalType();
8634      this.factor.setValue(value);
8635      return this;
8636    }
8637
8638    /**
8639     * @return {@link #net} (The quantity times the unit price for an additional
8640     *         service or product or charge.)
8641     */
8642    public Money getNet() {
8643      if (this.net == null)
8644        if (Configuration.errorOnAutoCreate())
8645          throw new Error("Attempt to auto-create SubDetailComponent.net");
8646        else if (Configuration.doAutoCreate())
8647          this.net = new Money(); // cc
8648      return this.net;
8649    }
8650
8651    public boolean hasNet() {
8652      return this.net != null && !this.net.isEmpty();
8653    }
8654
8655    /**
8656     * @param value {@link #net} (The quantity times the unit price for an
8657     *              additional service or product or charge.)
8658     */
8659    public SubDetailComponent setNet(Money value) {
8660      this.net = value;
8661      return this;
8662    }
8663
8664    /**
8665     * @return {@link #udi} (Unique Device Identifiers associated with this line
8666     *         item.)
8667     */
8668    public List<Reference> getUdi() {
8669      if (this.udi == null)
8670        this.udi = new ArrayList<Reference>();
8671      return this.udi;
8672    }
8673
8674    /**
8675     * @return Returns a reference to <code>this</code> for easy method chaining
8676     */
8677    public SubDetailComponent setUdi(List<Reference> theUdi) {
8678      this.udi = theUdi;
8679      return this;
8680    }
8681
8682    public boolean hasUdi() {
8683      if (this.udi == null)
8684        return false;
8685      for (Reference item : this.udi)
8686        if (!item.isEmpty())
8687          return true;
8688      return false;
8689    }
8690
8691    public Reference addUdi() { // 3
8692      Reference t = new Reference();
8693      if (this.udi == null)
8694        this.udi = new ArrayList<Reference>();
8695      this.udi.add(t);
8696      return t;
8697    }
8698
8699    public SubDetailComponent addUdi(Reference t) { // 3
8700      if (t == null)
8701        return this;
8702      if (this.udi == null)
8703        this.udi = new ArrayList<Reference>();
8704      this.udi.add(t);
8705      return this;
8706    }
8707
8708    /**
8709     * @return The first repetition of repeating field {@link #udi}, creating it if
8710     *         it does not already exist
8711     */
8712    public Reference getUdiFirstRep() {
8713      if (getUdi().isEmpty()) {
8714        addUdi();
8715      }
8716      return getUdi().get(0);
8717    }
8718
8719    /**
8720     * @deprecated Use Reference#setResource(IBaseResource) instead
8721     */
8722    @Deprecated
8723    public List<Device> getUdiTarget() {
8724      if (this.udiTarget == null)
8725        this.udiTarget = new ArrayList<Device>();
8726      return this.udiTarget;
8727    }
8728
8729    /**
8730     * @deprecated Use Reference#setResource(IBaseResource) instead
8731     */
8732    @Deprecated
8733    public Device addUdiTarget() {
8734      Device r = new Device();
8735      if (this.udiTarget == null)
8736        this.udiTarget = new ArrayList<Device>();
8737      this.udiTarget.add(r);
8738      return r;
8739    }
8740
8741    /**
8742     * @return {@link #noteNumber} (The numbers associated with notes below which
8743     *         apply to the adjudication of this item.)
8744     */
8745    public List<PositiveIntType> getNoteNumber() {
8746      if (this.noteNumber == null)
8747        this.noteNumber = new ArrayList<PositiveIntType>();
8748      return this.noteNumber;
8749    }
8750
8751    /**
8752     * @return Returns a reference to <code>this</code> for easy method chaining
8753     */
8754    public SubDetailComponent setNoteNumber(List<PositiveIntType> theNoteNumber) {
8755      this.noteNumber = theNoteNumber;
8756      return this;
8757    }
8758
8759    public boolean hasNoteNumber() {
8760      if (this.noteNumber == null)
8761        return false;
8762      for (PositiveIntType item : this.noteNumber)
8763        if (!item.isEmpty())
8764          return true;
8765      return false;
8766    }
8767
8768    /**
8769     * @return {@link #noteNumber} (The numbers associated with notes below which
8770     *         apply to the adjudication of this item.)
8771     */
8772    public PositiveIntType addNoteNumberElement() {// 2
8773      PositiveIntType t = new PositiveIntType();
8774      if (this.noteNumber == null)
8775        this.noteNumber = new ArrayList<PositiveIntType>();
8776      this.noteNumber.add(t);
8777      return t;
8778    }
8779
8780    /**
8781     * @param value {@link #noteNumber} (The numbers associated with notes below
8782     *              which apply to the adjudication of this item.)
8783     */
8784    public SubDetailComponent addNoteNumber(int value) { // 1
8785      PositiveIntType t = new PositiveIntType();
8786      t.setValue(value);
8787      if (this.noteNumber == null)
8788        this.noteNumber = new ArrayList<PositiveIntType>();
8789      this.noteNumber.add(t);
8790      return this;
8791    }
8792
8793    /**
8794     * @param value {@link #noteNumber} (The numbers associated with notes below
8795     *              which apply to the adjudication of this item.)
8796     */
8797    public boolean hasNoteNumber(int value) {
8798      if (this.noteNumber == null)
8799        return false;
8800      for (PositiveIntType v : this.noteNumber)
8801        if (v.getValue().equals(value)) // positiveInt
8802          return true;
8803      return false;
8804    }
8805
8806    /**
8807     * @return {@link #adjudication} (The adjudication results.)
8808     */
8809    public List<AdjudicationComponent> getAdjudication() {
8810      if (this.adjudication == null)
8811        this.adjudication = new ArrayList<AdjudicationComponent>();
8812      return this.adjudication;
8813    }
8814
8815    /**
8816     * @return Returns a reference to <code>this</code> for easy method chaining
8817     */
8818    public SubDetailComponent setAdjudication(List<AdjudicationComponent> theAdjudication) {
8819      this.adjudication = theAdjudication;
8820      return this;
8821    }
8822
8823    public boolean hasAdjudication() {
8824      if (this.adjudication == null)
8825        return false;
8826      for (AdjudicationComponent item : this.adjudication)
8827        if (!item.isEmpty())
8828          return true;
8829      return false;
8830    }
8831
8832    public AdjudicationComponent addAdjudication() { // 3
8833      AdjudicationComponent t = new AdjudicationComponent();
8834      if (this.adjudication == null)
8835        this.adjudication = new ArrayList<AdjudicationComponent>();
8836      this.adjudication.add(t);
8837      return t;
8838    }
8839
8840    public SubDetailComponent addAdjudication(AdjudicationComponent t) { // 3
8841      if (t == null)
8842        return this;
8843      if (this.adjudication == null)
8844        this.adjudication = new ArrayList<AdjudicationComponent>();
8845      this.adjudication.add(t);
8846      return this;
8847    }
8848
8849    /**
8850     * @return The first repetition of repeating field {@link #adjudication},
8851     *         creating it if it does not already exist
8852     */
8853    public AdjudicationComponent getAdjudicationFirstRep() {
8854      if (getAdjudication().isEmpty()) {
8855        addAdjudication();
8856      }
8857      return getAdjudication().get(0);
8858    }
8859
8860    protected void listChildren(List<Property> children) {
8861      super.listChildren(children);
8862      children.add(new Property("sequence", "positiveInt",
8863          "A claim detail line. Either a simple (a product or service) or a 'group' of sub-details which are simple items.",
8864          0, 1, sequence));
8865      children.add(new Property("revenue", "CodeableConcept",
8866          "The type of revenue or cost center providing the product and/or service.", 0, 1, revenue));
8867      children.add(new Property("category", "CodeableConcept",
8868          "Code to identify the general type of benefits under which products and services are provided.", 0, 1,
8869          category));
8870      children.add(new Property("productOrService", "CodeableConcept",
8871          "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
8872          0, 1, productOrService));
8873      children.add(new Property("modifier", "CodeableConcept",
8874          "Item typification or modifiers codes to convey additional context for the product or service.", 0,
8875          java.lang.Integer.MAX_VALUE, modifier));
8876      children.add(new Property("programCode", "CodeableConcept",
8877          "Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode));
8878      children.add(new Property("quantity", "SimpleQuantity", "The number of repetitions of a service or product.", 0,
8879          1, quantity));
8880      children.add(new Property("unitPrice", "Money",
8881          "If the item is not a group then this is the fee for the product or service, otherwise this is the total of the fees for the details of the group.",
8882          0, 1, unitPrice));
8883      children.add(new Property("factor", "decimal",
8884          "A real number that represents a multiplier used in determining the overall value of services delivered and/or goods received. The concept of a Factor allows for a discount or surcharge multiplier to be applied to a monetary amount.",
8885          0, 1, factor));
8886      children.add(new Property("net", "Money",
8887          "The quantity times the unit price for an additional service or product or charge.", 0, 1, net));
8888      children.add(new Property("udi", "Reference(Device)", "Unique Device Identifiers associated with this line item.",
8889          0, java.lang.Integer.MAX_VALUE, udi));
8890      children.add(new Property("noteNumber", "positiveInt",
8891          "The numbers associated with notes below which apply to the adjudication of this item.", 0,
8892          java.lang.Integer.MAX_VALUE, noteNumber));
8893      children.add(new Property("adjudication", "@ExplanationOfBenefit.item.adjudication", "The adjudication results.",
8894          0, java.lang.Integer.MAX_VALUE, adjudication));
8895    }
8896
8897    @Override
8898    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
8899      switch (_hash) {
8900      case 1349547969:
8901        /* sequence */ return new Property("sequence", "positiveInt",
8902            "A claim detail line. Either a simple (a product or service) or a 'group' of sub-details which are simple items.",
8903            0, 1, sequence);
8904      case 1099842588:
8905        /* revenue */ return new Property("revenue", "CodeableConcept",
8906            "The type of revenue or cost center providing the product and/or service.", 0, 1, revenue);
8907      case 50511102:
8908        /* category */ return new Property("category", "CodeableConcept",
8909            "Code to identify the general type of benefits under which products and services are provided.", 0, 1,
8910            category);
8911      case 1957227299:
8912        /* productOrService */ return new Property("productOrService", "CodeableConcept",
8913            "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
8914            0, 1, productOrService);
8915      case -615513385:
8916        /* modifier */ return new Property("modifier", "CodeableConcept",
8917            "Item typification or modifiers codes to convey additional context for the product or service.", 0,
8918            java.lang.Integer.MAX_VALUE, modifier);
8919      case 1010065041:
8920        /* programCode */ return new Property("programCode", "CodeableConcept",
8921            "Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode);
8922      case -1285004149:
8923        /* quantity */ return new Property("quantity", "SimpleQuantity",
8924            "The number of repetitions of a service or product.", 0, 1, quantity);
8925      case -486196699:
8926        /* unitPrice */ return new Property("unitPrice", "Money",
8927            "If the item is not a group then this is the fee for the product or service, otherwise this is the total of the fees for the details of the group.",
8928            0, 1, unitPrice);
8929      case -1282148017:
8930        /* factor */ return new Property("factor", "decimal",
8931            "A real number that represents a multiplier used in determining the overall value of services delivered and/or goods received. The concept of a Factor allows for a discount or surcharge multiplier to be applied to a monetary amount.",
8932            0, 1, factor);
8933      case 108957:
8934        /* net */ return new Property("net", "Money",
8935            "The quantity times the unit price for an additional service or product or charge.", 0, 1, net);
8936      case 115642:
8937        /* udi */ return new Property("udi", "Reference(Device)",
8938            "Unique Device Identifiers associated with this line item.", 0, java.lang.Integer.MAX_VALUE, udi);
8939      case -1110033957:
8940        /* noteNumber */ return new Property("noteNumber", "positiveInt",
8941            "The numbers associated with notes below which apply to the adjudication of this item.", 0,
8942            java.lang.Integer.MAX_VALUE, noteNumber);
8943      case -231349275:
8944        /* adjudication */ return new Property("adjudication", "@ExplanationOfBenefit.item.adjudication",
8945            "The adjudication results.", 0, java.lang.Integer.MAX_VALUE, adjudication);
8946      default:
8947        return super.getNamedProperty(_hash, _name, _checkValid);
8948      }
8949
8950    }
8951
8952    @Override
8953    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
8954      switch (hash) {
8955      case 1349547969:
8956        /* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
8957      case 1099842588:
8958        /* revenue */ return this.revenue == null ? new Base[0] : new Base[] { this.revenue }; // CodeableConcept
8959      case 50511102:
8960        /* category */ return this.category == null ? new Base[0] : new Base[] { this.category }; // CodeableConcept
8961      case 1957227299:
8962        /* productOrService */ return this.productOrService == null ? new Base[0]
8963            : new Base[] { this.productOrService }; // CodeableConcept
8964      case -615513385:
8965        /* modifier */ return this.modifier == null ? new Base[0]
8966            : this.modifier.toArray(new Base[this.modifier.size()]); // CodeableConcept
8967      case 1010065041:
8968        /* programCode */ return this.programCode == null ? new Base[0]
8969            : this.programCode.toArray(new Base[this.programCode.size()]); // CodeableConcept
8970      case -1285004149:
8971        /* quantity */ return this.quantity == null ? new Base[0] : new Base[] { this.quantity }; // Quantity
8972      case -486196699:
8973        /* unitPrice */ return this.unitPrice == null ? new Base[0] : new Base[] { this.unitPrice }; // Money
8974      case -1282148017:
8975        /* factor */ return this.factor == null ? new Base[0] : new Base[] { this.factor }; // DecimalType
8976      case 108957:
8977        /* net */ return this.net == null ? new Base[0] : new Base[] { this.net }; // Money
8978      case 115642:
8979        /* udi */ return this.udi == null ? new Base[0] : this.udi.toArray(new Base[this.udi.size()]); // Reference
8980      case -1110033957:
8981        /* noteNumber */ return this.noteNumber == null ? new Base[0]
8982            : this.noteNumber.toArray(new Base[this.noteNumber.size()]); // PositiveIntType
8983      case -231349275:
8984        /* adjudication */ return this.adjudication == null ? new Base[0]
8985            : this.adjudication.toArray(new Base[this.adjudication.size()]); // AdjudicationComponent
8986      default:
8987        return super.getProperty(hash, name, checkValid);
8988      }
8989
8990    }
8991
8992    @Override
8993    public Base setProperty(int hash, String name, Base value) throws FHIRException {
8994      switch (hash) {
8995      case 1349547969: // sequence
8996        this.sequence = castToPositiveInt(value); // PositiveIntType
8997        return value;
8998      case 1099842588: // revenue
8999        this.revenue = castToCodeableConcept(value); // CodeableConcept
9000        return value;
9001      case 50511102: // category
9002        this.category = castToCodeableConcept(value); // CodeableConcept
9003        return value;
9004      case 1957227299: // productOrService
9005        this.productOrService = castToCodeableConcept(value); // CodeableConcept
9006        return value;
9007      case -615513385: // modifier
9008        this.getModifier().add(castToCodeableConcept(value)); // CodeableConcept
9009        return value;
9010      case 1010065041: // programCode
9011        this.getProgramCode().add(castToCodeableConcept(value)); // CodeableConcept
9012        return value;
9013      case -1285004149: // quantity
9014        this.quantity = castToQuantity(value); // Quantity
9015        return value;
9016      case -486196699: // unitPrice
9017        this.unitPrice = castToMoney(value); // Money
9018        return value;
9019      case -1282148017: // factor
9020        this.factor = castToDecimal(value); // DecimalType
9021        return value;
9022      case 108957: // net
9023        this.net = castToMoney(value); // Money
9024        return value;
9025      case 115642: // udi
9026        this.getUdi().add(castToReference(value)); // Reference
9027        return value;
9028      case -1110033957: // noteNumber
9029        this.getNoteNumber().add(castToPositiveInt(value)); // PositiveIntType
9030        return value;
9031      case -231349275: // adjudication
9032        this.getAdjudication().add((AdjudicationComponent) value); // AdjudicationComponent
9033        return value;
9034      default:
9035        return super.setProperty(hash, name, value);
9036      }
9037
9038    }
9039
9040    @Override
9041    public Base setProperty(String name, Base value) throws FHIRException {
9042      if (name.equals("sequence")) {
9043        this.sequence = castToPositiveInt(value); // PositiveIntType
9044      } else if (name.equals("revenue")) {
9045        this.revenue = castToCodeableConcept(value); // CodeableConcept
9046      } else if (name.equals("category")) {
9047        this.category = castToCodeableConcept(value); // CodeableConcept
9048      } else if (name.equals("productOrService")) {
9049        this.productOrService = castToCodeableConcept(value); // CodeableConcept
9050      } else if (name.equals("modifier")) {
9051        this.getModifier().add(castToCodeableConcept(value));
9052      } else if (name.equals("programCode")) {
9053        this.getProgramCode().add(castToCodeableConcept(value));
9054      } else if (name.equals("quantity")) {
9055        this.quantity = castToQuantity(value); // Quantity
9056      } else if (name.equals("unitPrice")) {
9057        this.unitPrice = castToMoney(value); // Money
9058      } else if (name.equals("factor")) {
9059        this.factor = castToDecimal(value); // DecimalType
9060      } else if (name.equals("net")) {
9061        this.net = castToMoney(value); // Money
9062      } else if (name.equals("udi")) {
9063        this.getUdi().add(castToReference(value));
9064      } else if (name.equals("noteNumber")) {
9065        this.getNoteNumber().add(castToPositiveInt(value));
9066      } else if (name.equals("adjudication")) {
9067        this.getAdjudication().add((AdjudicationComponent) value);
9068      } else
9069        return super.setProperty(name, value);
9070      return value;
9071    }
9072
9073  @Override
9074  public void removeChild(String name, Base value) throws FHIRException {
9075      if (name.equals("sequence")) {
9076        this.sequence = null;
9077      } else if (name.equals("revenue")) {
9078        this.revenue = null;
9079      } else if (name.equals("category")) {
9080        this.category = null;
9081      } else if (name.equals("productOrService")) {
9082        this.productOrService = null;
9083      } else if (name.equals("modifier")) {
9084        this.getModifier().remove(castToCodeableConcept(value));
9085      } else if (name.equals("programCode")) {
9086        this.getProgramCode().remove(castToCodeableConcept(value));
9087      } else if (name.equals("quantity")) {
9088        this.quantity = null;
9089      } else if (name.equals("unitPrice")) {
9090        this.unitPrice = null;
9091      } else if (name.equals("factor")) {
9092        this.factor = null;
9093      } else if (name.equals("net")) {
9094        this.net = null;
9095      } else if (name.equals("udi")) {
9096        this.getUdi().remove(castToReference(value));
9097      } else if (name.equals("noteNumber")) {
9098        this.getNoteNumber().remove(castToPositiveInt(value));
9099      } else if (name.equals("adjudication")) {
9100        this.getAdjudication().remove((AdjudicationComponent) value);
9101      } else
9102        super.removeChild(name, value);
9103      
9104    }
9105
9106    @Override
9107    public Base makeProperty(int hash, String name) throws FHIRException {
9108      switch (hash) {
9109      case 1349547969:
9110        return getSequenceElement();
9111      case 1099842588:
9112        return getRevenue();
9113      case 50511102:
9114        return getCategory();
9115      case 1957227299:
9116        return getProductOrService();
9117      case -615513385:
9118        return addModifier();
9119      case 1010065041:
9120        return addProgramCode();
9121      case -1285004149:
9122        return getQuantity();
9123      case -486196699:
9124        return getUnitPrice();
9125      case -1282148017:
9126        return getFactorElement();
9127      case 108957:
9128        return getNet();
9129      case 115642:
9130        return addUdi();
9131      case -1110033957:
9132        return addNoteNumberElement();
9133      case -231349275:
9134        return addAdjudication();
9135      default:
9136        return super.makeProperty(hash, name);
9137      }
9138
9139    }
9140
9141    @Override
9142    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
9143      switch (hash) {
9144      case 1349547969:
9145        /* sequence */ return new String[] { "positiveInt" };
9146      case 1099842588:
9147        /* revenue */ return new String[] { "CodeableConcept" };
9148      case 50511102:
9149        /* category */ return new String[] { "CodeableConcept" };
9150      case 1957227299:
9151        /* productOrService */ return new String[] { "CodeableConcept" };
9152      case -615513385:
9153        /* modifier */ return new String[] { "CodeableConcept" };
9154      case 1010065041:
9155        /* programCode */ return new String[] { "CodeableConcept" };
9156      case -1285004149:
9157        /* quantity */ return new String[] { "SimpleQuantity" };
9158      case -486196699:
9159        /* unitPrice */ return new String[] { "Money" };
9160      case -1282148017:
9161        /* factor */ return new String[] { "decimal" };
9162      case 108957:
9163        /* net */ return new String[] { "Money" };
9164      case 115642:
9165        /* udi */ return new String[] { "Reference" };
9166      case -1110033957:
9167        /* noteNumber */ return new String[] { "positiveInt" };
9168      case -231349275:
9169        /* adjudication */ return new String[] { "@ExplanationOfBenefit.item.adjudication" };
9170      default:
9171        return super.getTypesForProperty(hash, name);
9172      }
9173
9174    }
9175
9176    @Override
9177    public Base addChild(String name) throws FHIRException {
9178      if (name.equals("sequence")) {
9179        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
9180      } else if (name.equals("revenue")) {
9181        this.revenue = new CodeableConcept();
9182        return this.revenue;
9183      } else if (name.equals("category")) {
9184        this.category = new CodeableConcept();
9185        return this.category;
9186      } else if (name.equals("productOrService")) {
9187        this.productOrService = new CodeableConcept();
9188        return this.productOrService;
9189      } else if (name.equals("modifier")) {
9190        return addModifier();
9191      } else if (name.equals("programCode")) {
9192        return addProgramCode();
9193      } else if (name.equals("quantity")) {
9194        this.quantity = new Quantity();
9195        return this.quantity;
9196      } else if (name.equals("unitPrice")) {
9197        this.unitPrice = new Money();
9198        return this.unitPrice;
9199      } else if (name.equals("factor")) {
9200        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.factor");
9201      } else if (name.equals("net")) {
9202        this.net = new Money();
9203        return this.net;
9204      } else if (name.equals("udi")) {
9205        return addUdi();
9206      } else if (name.equals("noteNumber")) {
9207        throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.noteNumber");
9208      } else if (name.equals("adjudication")) {
9209        return addAdjudication();
9210      } else
9211        return super.addChild(name);
9212    }
9213
9214    public SubDetailComponent copy() {
9215      SubDetailComponent dst = new SubDetailComponent();
9216      copyValues(dst);
9217      return dst;
9218    }
9219
9220    public void copyValues(SubDetailComponent dst) {
9221      super.copyValues(dst);
9222      dst.sequence = sequence == null ? null : sequence.copy();
9223      dst.revenue = revenue == null ? null : revenue.copy();
9224      dst.category = category == null ? null : category.copy();
9225      dst.productOrService = productOrService == null ? null : productOrService.copy();
9226      if (modifier != null) {
9227        dst.modifier = new ArrayList<CodeableConcept>();
9228        for (CodeableConcept i : modifier)
9229          dst.modifier.add(i.copy());
9230      }
9231      ;
9232      if (programCode != null) {
9233        dst.programCode = new ArrayList<CodeableConcept>();
9234        for (CodeableConcept i : programCode)
9235          dst.programCode.add(i.copy());
9236      }
9237      ;
9238      dst.quantity = quantity == null ? null : quantity.copy();
9239      dst.unitPrice = unitPrice == null ? null : unitPrice.copy();
9240      dst.factor = factor == null ? null : factor.copy();
9241      dst.net = net == null ? null : net.copy();
9242      if (udi != null) {
9243        dst.udi = new ArrayList<Reference>();
9244        for (Reference i : udi)
9245          dst.udi.add(i.copy());
9246      }
9247      ;
9248      if (noteNumber != null) {
9249        dst.noteNumber = new ArrayList<PositiveIntType>();
9250        for (PositiveIntType i : noteNumber)
9251          dst.noteNumber.add(i.copy());
9252      }
9253      ;
9254      if (adjudication != null) {
9255        dst.adjudication = new ArrayList<AdjudicationComponent>();
9256        for (AdjudicationComponent i : adjudication)
9257          dst.adjudication.add(i.copy());
9258      }
9259      ;
9260    }
9261
9262    @Override
9263    public boolean equalsDeep(Base other_) {
9264      if (!super.equalsDeep(other_))
9265        return false;
9266      if (!(other_ instanceof SubDetailComponent))
9267        return false;
9268      SubDetailComponent o = (SubDetailComponent) other_;
9269      return compareDeep(sequence, o.sequence, true) && compareDeep(revenue, o.revenue, true)
9270          && compareDeep(category, o.category, true) && compareDeep(productOrService, o.productOrService, true)
9271          && compareDeep(modifier, o.modifier, true) && compareDeep(programCode, o.programCode, true)
9272          && compareDeep(quantity, o.quantity, true) && compareDeep(unitPrice, o.unitPrice, true)
9273          && compareDeep(factor, o.factor, true) && compareDeep(net, o.net, true) && compareDeep(udi, o.udi, true)
9274          && compareDeep(noteNumber, o.noteNumber, true) && compareDeep(adjudication, o.adjudication, true);
9275    }
9276
9277    @Override
9278    public boolean equalsShallow(Base other_) {
9279      if (!super.equalsShallow(other_))
9280        return false;
9281      if (!(other_ instanceof SubDetailComponent))
9282        return false;
9283      SubDetailComponent o = (SubDetailComponent) other_;
9284      return compareValues(sequence, o.sequence, true) && compareValues(factor, o.factor, true)
9285          && compareValues(noteNumber, o.noteNumber, true);
9286    }
9287
9288    public boolean isEmpty() {
9289      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, revenue, category, productOrService,
9290          modifier, programCode, quantity, unitPrice, factor, net, udi, noteNumber, adjudication);
9291    }
9292
9293    public String fhirType() {
9294      return "ExplanationOfBenefit.item.detail.subDetail";
9295
9296    }
9297
9298  }
9299
9300  @Block()
9301  public static class AddedItemComponent extends BackboneElement implements IBaseBackboneElement {
9302    /**
9303     * Claim items which this service line is intended to replace.
9304     */
9305    @Child(name = "itemSequence", type = {
9306        PositiveIntType.class }, order = 1, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
9307    @Description(shortDefinition = "Item sequence number", formalDefinition = "Claim items which this service line is intended to replace.")
9308    protected List<PositiveIntType> itemSequence;
9309
9310    /**
9311     * The sequence number of the details within the claim item which this line is
9312     * intended to replace.
9313     */
9314    @Child(name = "detailSequence", type = {
9315        PositiveIntType.class }, order = 2, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
9316    @Description(shortDefinition = "Detail sequence number", formalDefinition = "The sequence number of the details within the claim item which this line is intended to replace.")
9317    protected List<PositiveIntType> detailSequence;
9318
9319    /**
9320     * The sequence number of the sub-details woithin the details within the claim
9321     * item which this line is intended to replace.
9322     */
9323    @Child(name = "subDetailSequence", type = {
9324        PositiveIntType.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
9325    @Description(shortDefinition = "Subdetail sequence number", formalDefinition = "The sequence number of the sub-details woithin the details within the claim item which this line is intended to replace.")
9326    protected List<PositiveIntType> subDetailSequence;
9327
9328    /**
9329     * The providers who are authorized for the services rendered to the patient.
9330     */
9331    @Child(name = "provider", type = { Practitioner.class, PractitionerRole.class,
9332        Organization.class }, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
9333    @Description(shortDefinition = "Authorized providers", formalDefinition = "The providers who are authorized for the services rendered to the patient.")
9334    protected List<Reference> provider;
9335    /**
9336     * The actual objects that are the target of the reference (The providers who
9337     * are authorized for the services rendered to the patient.)
9338     */
9339    protected List<Resource> providerTarget;
9340
9341    /**
9342     * When the value is a group code then this item collects a set of related claim
9343     * details, otherwise this contains the product, service, drug or other billing
9344     * code for the item.
9345     */
9346    @Child(name = "productOrService", type = {
9347        CodeableConcept.class }, order = 5, min = 1, max = 1, modifier = false, summary = false)
9348    @Description(shortDefinition = "Billing, service, product, or drug code", formalDefinition = "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.")
9349    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-uscls")
9350    protected CodeableConcept productOrService;
9351
9352    /**
9353     * Item typification or modifiers codes to convey additional context for the
9354     * product or service.
9355     */
9356    @Child(name = "modifier", type = {
9357        CodeableConcept.class }, order = 6, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
9358    @Description(shortDefinition = "Service/Product billing modifiers", formalDefinition = "Item typification or modifiers codes to convey additional context for the product or service.")
9359    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-modifiers")
9360    protected List<CodeableConcept> modifier;
9361
9362    /**
9363     * Identifies the program under which this may be recovered.
9364     */
9365    @Child(name = "programCode", type = {
9366        CodeableConcept.class }, order = 7, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
9367    @Description(shortDefinition = "Program the product or service is provided under", formalDefinition = "Identifies the program under which this may be recovered.")
9368    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-program-code")
9369    protected List<CodeableConcept> programCode;
9370
9371    /**
9372     * The date or dates when the service or product was supplied, performed or
9373     * completed.
9374     */
9375    @Child(name = "serviced", type = { DateType.class,
9376        Period.class }, order = 8, min = 0, max = 1, modifier = false, summary = false)
9377    @Description(shortDefinition = "Date or dates of service or product delivery", formalDefinition = "The date or dates when the service or product was supplied, performed or completed.")
9378    protected Type serviced;
9379
9380    /**
9381     * Where the product or service was provided.
9382     */
9383    @Child(name = "location", type = { CodeableConcept.class, Address.class,
9384        Location.class }, order = 9, min = 0, max = 1, modifier = false, summary = false)
9385    @Description(shortDefinition = "Place of service or where product was supplied", formalDefinition = "Where the product or service was provided.")
9386    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-place")
9387    protected Type location;
9388
9389    /**
9390     * The number of repetitions of a service or product.
9391     */
9392    @Child(name = "quantity", type = {
9393        Quantity.class }, order = 10, min = 0, max = 1, modifier = false, summary = false)
9394    @Description(shortDefinition = "Count of products or services", formalDefinition = "The number of repetitions of a service or product.")
9395    protected Quantity quantity;
9396
9397    /**
9398     * If the item is not a group then this is the fee for the product or service,
9399     * otherwise this is the total of the fees for the details of the group.
9400     */
9401    @Child(name = "unitPrice", type = { Money.class }, order = 11, min = 0, max = 1, modifier = false, summary = false)
9402    @Description(shortDefinition = "Fee, charge or cost per item", formalDefinition = "If the item is not a group then this is the fee for the product or service, otherwise this is the total of the fees for the details of the group.")
9403    protected Money unitPrice;
9404
9405    /**
9406     * A real number that represents a multiplier used in determining the overall
9407     * value of services delivered and/or goods received. The concept of a Factor
9408     * allows for a discount or surcharge multiplier to be applied to a monetary
9409     * amount.
9410     */
9411    @Child(name = "factor", type = {
9412        DecimalType.class }, order = 12, min = 0, max = 1, modifier = false, summary = false)
9413    @Description(shortDefinition = "Price scaling factor", formalDefinition = "A real number that represents a multiplier used in determining the overall value of services delivered and/or goods received. The concept of a Factor allows for a discount or surcharge multiplier to be applied to a monetary amount.")
9414    protected DecimalType factor;
9415
9416    /**
9417     * The quantity times the unit price for an additional service or product or
9418     * charge.
9419     */
9420    @Child(name = "net", type = { Money.class }, order = 13, min = 0, max = 1, modifier = false, summary = false)
9421    @Description(shortDefinition = "Total item cost", formalDefinition = "The quantity times the unit price for an additional service or product or charge.")
9422    protected Money net;
9423
9424    /**
9425     * Physical service site on the patient (limb, tooth, etc.).
9426     */
9427    @Child(name = "bodySite", type = {
9428        CodeableConcept.class }, order = 14, min = 0, max = 1, modifier = false, summary = false)
9429    @Description(shortDefinition = "Anatomical location", formalDefinition = "Physical service site on the patient (limb, tooth, etc.).")
9430    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/tooth")
9431    protected CodeableConcept bodySite;
9432
9433    /**
9434     * A region or surface of the bodySite, e.g. limb region or tooth surface(s).
9435     */
9436    @Child(name = "subSite", type = {
9437        CodeableConcept.class }, order = 15, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
9438    @Description(shortDefinition = "Anatomical sub-location", formalDefinition = "A region or surface of the bodySite, e.g. limb region or tooth surface(s).")
9439    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/surface")
9440    protected List<CodeableConcept> subSite;
9441
9442    /**
9443     * The numbers associated with notes below which apply to the adjudication of
9444     * this item.
9445     */
9446    @Child(name = "noteNumber", type = {
9447        PositiveIntType.class }, order = 16, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
9448    @Description(shortDefinition = "Applicable note numbers", formalDefinition = "The numbers associated with notes below which apply to the adjudication of this item.")
9449    protected List<PositiveIntType> noteNumber;
9450
9451    /**
9452     * The adjudication results.
9453     */
9454    @Child(name = "adjudication", type = {
9455        AdjudicationComponent.class }, order = 17, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
9456    @Description(shortDefinition = "Added items adjudication", formalDefinition = "The adjudication results.")
9457    protected List<AdjudicationComponent> adjudication;
9458
9459    /**
9460     * The second-tier service adjudications for payor added services.
9461     */
9462    @Child(name = "detail", type = {}, order = 18, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
9463    @Description(shortDefinition = "Insurer added line items", formalDefinition = "The second-tier service adjudications for payor added services.")
9464    protected List<AddedItemDetailComponent> detail;
9465
9466    private static final long serialVersionUID = -206524210L;
9467
9468    /**
9469     * Constructor
9470     */
9471    public AddedItemComponent() {
9472      super();
9473    }
9474
9475    /**
9476     * Constructor
9477     */
9478    public AddedItemComponent(CodeableConcept productOrService) {
9479      super();
9480      this.productOrService = productOrService;
9481    }
9482
9483    /**
9484     * @return {@link #itemSequence} (Claim items which this service line is
9485     *         intended to replace.)
9486     */
9487    public List<PositiveIntType> getItemSequence() {
9488      if (this.itemSequence == null)
9489        this.itemSequence = new ArrayList<PositiveIntType>();
9490      return this.itemSequence;
9491    }
9492
9493    /**
9494     * @return Returns a reference to <code>this</code> for easy method chaining
9495     */
9496    public AddedItemComponent setItemSequence(List<PositiveIntType> theItemSequence) {
9497      this.itemSequence = theItemSequence;
9498      return this;
9499    }
9500
9501    public boolean hasItemSequence() {
9502      if (this.itemSequence == null)
9503        return false;
9504      for (PositiveIntType item : this.itemSequence)
9505        if (!item.isEmpty())
9506          return true;
9507      return false;
9508    }
9509
9510    /**
9511     * @return {@link #itemSequence} (Claim items which this service line is
9512     *         intended to replace.)
9513     */
9514    public PositiveIntType addItemSequenceElement() {// 2
9515      PositiveIntType t = new PositiveIntType();
9516      if (this.itemSequence == null)
9517        this.itemSequence = new ArrayList<PositiveIntType>();
9518      this.itemSequence.add(t);
9519      return t;
9520    }
9521
9522    /**
9523     * @param value {@link #itemSequence} (Claim items which this service line is
9524     *              intended to replace.)
9525     */
9526    public AddedItemComponent addItemSequence(int value) { // 1
9527      PositiveIntType t = new PositiveIntType();
9528      t.setValue(value);
9529      if (this.itemSequence == null)
9530        this.itemSequence = new ArrayList<PositiveIntType>();
9531      this.itemSequence.add(t);
9532      return this;
9533    }
9534
9535    /**
9536     * @param value {@link #itemSequence} (Claim items which this service line is
9537     *              intended to replace.)
9538     */
9539    public boolean hasItemSequence(int value) {
9540      if (this.itemSequence == null)
9541        return false;
9542      for (PositiveIntType v : this.itemSequence)
9543        if (v.getValue().equals(value)) // positiveInt
9544          return true;
9545      return false;
9546    }
9547
9548    /**
9549     * @return {@link #detailSequence} (The sequence number of the details within
9550     *         the claim item which this line is intended to replace.)
9551     */
9552    public List<PositiveIntType> getDetailSequence() {
9553      if (this.detailSequence == null)
9554        this.detailSequence = new ArrayList<PositiveIntType>();
9555      return this.detailSequence;
9556    }
9557
9558    /**
9559     * @return Returns a reference to <code>this</code> for easy method chaining
9560     */
9561    public AddedItemComponent setDetailSequence(List<PositiveIntType> theDetailSequence) {
9562      this.detailSequence = theDetailSequence;
9563      return this;
9564    }
9565
9566    public boolean hasDetailSequence() {
9567      if (this.detailSequence == null)
9568        return false;
9569      for (PositiveIntType item : this.detailSequence)
9570        if (!item.isEmpty())
9571          return true;
9572      return false;
9573    }
9574
9575    /**
9576     * @return {@link #detailSequence} (The sequence number of the details within
9577     *         the claim item which this line is intended to replace.)
9578     */
9579    public PositiveIntType addDetailSequenceElement() {// 2
9580      PositiveIntType t = new PositiveIntType();
9581      if (this.detailSequence == null)
9582        this.detailSequence = new ArrayList<PositiveIntType>();
9583      this.detailSequence.add(t);
9584      return t;
9585    }
9586
9587    /**
9588     * @param value {@link #detailSequence} (The sequence number of the details
9589     *              within the claim item which this line is intended to replace.)
9590     */
9591    public AddedItemComponent addDetailSequence(int value) { // 1
9592      PositiveIntType t = new PositiveIntType();
9593      t.setValue(value);
9594      if (this.detailSequence == null)
9595        this.detailSequence = new ArrayList<PositiveIntType>();
9596      this.detailSequence.add(t);
9597      return this;
9598    }
9599
9600    /**
9601     * @param value {@link #detailSequence} (The sequence number of the details
9602     *              within the claim item which this line is intended to replace.)
9603     */
9604    public boolean hasDetailSequence(int value) {
9605      if (this.detailSequence == null)
9606        return false;
9607      for (PositiveIntType v : this.detailSequence)
9608        if (v.getValue().equals(value)) // positiveInt
9609          return true;
9610      return false;
9611    }
9612
9613    /**
9614     * @return {@link #subDetailSequence} (The sequence number of the sub-details
9615     *         woithin the details within the claim item which this line is intended
9616     *         to replace.)
9617     */
9618    public List<PositiveIntType> getSubDetailSequence() {
9619      if (this.subDetailSequence == null)
9620        this.subDetailSequence = new ArrayList<PositiveIntType>();
9621      return this.subDetailSequence;
9622    }
9623
9624    /**
9625     * @return Returns a reference to <code>this</code> for easy method chaining
9626     */
9627    public AddedItemComponent setSubDetailSequence(List<PositiveIntType> theSubDetailSequence) {
9628      this.subDetailSequence = theSubDetailSequence;
9629      return this;
9630    }
9631
9632    public boolean hasSubDetailSequence() {
9633      if (this.subDetailSequence == null)
9634        return false;
9635      for (PositiveIntType item : this.subDetailSequence)
9636        if (!item.isEmpty())
9637          return true;
9638      return false;
9639    }
9640
9641    /**
9642     * @return {@link #subDetailSequence} (The sequence number of the sub-details
9643     *         woithin the details within the claim item which this line is intended
9644     *         to replace.)
9645     */
9646    public PositiveIntType addSubDetailSequenceElement() {// 2
9647      PositiveIntType t = new PositiveIntType();
9648      if (this.subDetailSequence == null)
9649        this.subDetailSequence = new ArrayList<PositiveIntType>();
9650      this.subDetailSequence.add(t);
9651      return t;
9652    }
9653
9654    /**
9655     * @param value {@link #subDetailSequence} (The sequence number of the
9656     *              sub-details woithin the details within the claim item which this
9657     *              line is intended to replace.)
9658     */
9659    public AddedItemComponent addSubDetailSequence(int value) { // 1
9660      PositiveIntType t = new PositiveIntType();
9661      t.setValue(value);
9662      if (this.subDetailSequence == null)
9663        this.subDetailSequence = new ArrayList<PositiveIntType>();
9664      this.subDetailSequence.add(t);
9665      return this;
9666    }
9667
9668    /**
9669     * @param value {@link #subDetailSequence} (The sequence number of the
9670     *              sub-details woithin the details within the claim item which this
9671     *              line is intended to replace.)
9672     */
9673    public boolean hasSubDetailSequence(int value) {
9674      if (this.subDetailSequence == null)
9675        return false;
9676      for (PositiveIntType v : this.subDetailSequence)
9677        if (v.getValue().equals(value)) // positiveInt
9678          return true;
9679      return false;
9680    }
9681
9682    /**
9683     * @return {@link #provider} (The providers who are authorized for the services
9684     *         rendered to the patient.)
9685     */
9686    public List<Reference> getProvider() {
9687      if (this.provider == null)
9688        this.provider = new ArrayList<Reference>();
9689      return this.provider;
9690    }
9691
9692    /**
9693     * @return Returns a reference to <code>this</code> for easy method chaining
9694     */
9695    public AddedItemComponent setProvider(List<Reference> theProvider) {
9696      this.provider = theProvider;
9697      return this;
9698    }
9699
9700    public boolean hasProvider() {
9701      if (this.provider == null)
9702        return false;
9703      for (Reference item : this.provider)
9704        if (!item.isEmpty())
9705          return true;
9706      return false;
9707    }
9708
9709    public Reference addProvider() { // 3
9710      Reference t = new Reference();
9711      if (this.provider == null)
9712        this.provider = new ArrayList<Reference>();
9713      this.provider.add(t);
9714      return t;
9715    }
9716
9717    public AddedItemComponent addProvider(Reference t) { // 3
9718      if (t == null)
9719        return this;
9720      if (this.provider == null)
9721        this.provider = new ArrayList<Reference>();
9722      this.provider.add(t);
9723      return this;
9724    }
9725
9726    /**
9727     * @return The first repetition of repeating field {@link #provider}, creating
9728     *         it if it does not already exist
9729     */
9730    public Reference getProviderFirstRep() {
9731      if (getProvider().isEmpty()) {
9732        addProvider();
9733      }
9734      return getProvider().get(0);
9735    }
9736
9737    /**
9738     * @deprecated Use Reference#setResource(IBaseResource) instead
9739     */
9740    @Deprecated
9741    public List<Resource> getProviderTarget() {
9742      if (this.providerTarget == null)
9743        this.providerTarget = new ArrayList<Resource>();
9744      return this.providerTarget;
9745    }
9746
9747    /**
9748     * @return {@link #productOrService} (When the value is a group code then this
9749     *         item collects a set of related claim details, otherwise this contains
9750     *         the product, service, drug or other billing code for the item.)
9751     */
9752    public CodeableConcept getProductOrService() {
9753      if (this.productOrService == null)
9754        if (Configuration.errorOnAutoCreate())
9755          throw new Error("Attempt to auto-create AddedItemComponent.productOrService");
9756        else if (Configuration.doAutoCreate())
9757          this.productOrService = new CodeableConcept(); // cc
9758      return this.productOrService;
9759    }
9760
9761    public boolean hasProductOrService() {
9762      return this.productOrService != null && !this.productOrService.isEmpty();
9763    }