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