Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.hl7.fhir.r4.model.ExplanationOfBenefit Maven / Gradle / Ivy
Go to download
Builds the hapi fhir r4. Requires hapi-fhir-base and hapi-fhir-utilities be built first and be
excluded from any other poms requiring it.
package org.hl7.fhir.r4.model;
import java.math.BigDecimal;
/*
Copyright (c) 2011+, HL7, Inc.
All rights reserved.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice, this
list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
* Neither the name of HL7 nor the names of its contributors may be used to
endorse or promote products derived from this software without specific
prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.
*/
// Generated on Tue, May 12, 2020 07:26+1000 for FHIR v4.0.1
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.hl7.fhir.exceptions.FHIRException;
import org.hl7.fhir.instance.model.api.IBaseBackboneElement;
import org.hl7.fhir.r4.model.Enumerations.NoteType;
import org.hl7.fhir.r4.model.Enumerations.NoteTypeEnumFactory;
import org.hl7.fhir.utilities.Utilities;
import ca.uhn.fhir.model.api.annotation.Block;
import ca.uhn.fhir.model.api.annotation.Child;
import ca.uhn.fhir.model.api.annotation.Description;
import ca.uhn.fhir.model.api.annotation.ResourceDef;
import ca.uhn.fhir.model.api.annotation.SearchParamDefinition;
/**
* This resource provides: the claim details; adjudication details from the
* processing of a Claim; and optionally account balance information, for
* informing the subscriber of the benefits provided.
*/
@ResourceDef(name = "ExplanationOfBenefit", profile = "http://hl7.org/fhir/StructureDefinition/ExplanationOfBenefit")
public class ExplanationOfBenefit extends DomainResource {
public enum ExplanationOfBenefitStatus {
/**
* The resource instance is currently in-force.
*/
ACTIVE,
/**
* The resource instance is withdrawn, rescinded or reversed.
*/
CANCELLED,
/**
* A new resource instance the contents of which is not complete.
*/
DRAFT,
/**
* The resource instance was entered in error.
*/
ENTEREDINERROR,
/**
* added to help the parsers with the generic types
*/
NULL;
public static ExplanationOfBenefitStatus fromCode(String codeString) throws FHIRException {
if (codeString == null || "".equals(codeString))
return null;
if ("active".equals(codeString))
return ACTIVE;
if ("cancelled".equals(codeString))
return CANCELLED;
if ("draft".equals(codeString))
return DRAFT;
if ("entered-in-error".equals(codeString))
return ENTEREDINERROR;
if (Configuration.isAcceptInvalidEnums())
return null;
else
throw new FHIRException("Unknown ExplanationOfBenefitStatus code '" + codeString + "'");
}
public String toCode() {
switch (this) {
case ACTIVE:
return "active";
case CANCELLED:
return "cancelled";
case DRAFT:
return "draft";
case ENTEREDINERROR:
return "entered-in-error";
case NULL:
return null;
default:
return "?";
}
}
public String getSystem() {
switch (this) {
case ACTIVE:
return "http://hl7.org/fhir/explanationofbenefit-status";
case CANCELLED:
return "http://hl7.org/fhir/explanationofbenefit-status";
case DRAFT:
return "http://hl7.org/fhir/explanationofbenefit-status";
case ENTEREDINERROR:
return "http://hl7.org/fhir/explanationofbenefit-status";
case NULL:
return null;
default:
return "?";
}
}
public String getDefinition() {
switch (this) {
case ACTIVE:
return "The resource instance is currently in-force.";
case CANCELLED:
return "The resource instance is withdrawn, rescinded or reversed.";
case DRAFT:
return "A new resource instance the contents of which is not complete.";
case ENTEREDINERROR:
return "The resource instance was entered in error.";
case NULL:
return null;
default:
return "?";
}
}
public String getDisplay() {
switch (this) {
case ACTIVE:
return "Active";
case CANCELLED:
return "Cancelled";
case DRAFT:
return "Draft";
case ENTEREDINERROR:
return "Entered In Error";
case NULL:
return null;
default:
return "?";
}
}
}
public static class ExplanationOfBenefitStatusEnumFactory implements EnumFactory {
public ExplanationOfBenefitStatus fromCode(String codeString) throws IllegalArgumentException {
if (codeString == null || "".equals(codeString))
if (codeString == null || "".equals(codeString))
return null;
if ("active".equals(codeString))
return ExplanationOfBenefitStatus.ACTIVE;
if ("cancelled".equals(codeString))
return ExplanationOfBenefitStatus.CANCELLED;
if ("draft".equals(codeString))
return ExplanationOfBenefitStatus.DRAFT;
if ("entered-in-error".equals(codeString))
return ExplanationOfBenefitStatus.ENTEREDINERROR;
throw new IllegalArgumentException("Unknown ExplanationOfBenefitStatus code '" + codeString + "'");
}
public Enumeration fromType(PrimitiveType> code) throws FHIRException {
if (code == null)
return null;
if (code.isEmpty())
return new Enumeration(this, ExplanationOfBenefitStatus.NULL, code);
String codeString = code.asStringValue();
if (codeString == null || "".equals(codeString))
return new Enumeration(this, ExplanationOfBenefitStatus.NULL, code);
if ("active".equals(codeString))
return new Enumeration(this, ExplanationOfBenefitStatus.ACTIVE, code);
if ("cancelled".equals(codeString))
return new Enumeration(this, ExplanationOfBenefitStatus.CANCELLED, code);
if ("draft".equals(codeString))
return new Enumeration(this, ExplanationOfBenefitStatus.DRAFT, code);
if ("entered-in-error".equals(codeString))
return new Enumeration(this, ExplanationOfBenefitStatus.ENTEREDINERROR, code);
throw new FHIRException("Unknown ExplanationOfBenefitStatus code '" + codeString + "'");
}
public String toCode(ExplanationOfBenefitStatus code) {
if (code == ExplanationOfBenefitStatus.ACTIVE)
return "active";
if (code == ExplanationOfBenefitStatus.CANCELLED)
return "cancelled";
if (code == ExplanationOfBenefitStatus.DRAFT)
return "draft";
if (code == ExplanationOfBenefitStatus.ENTEREDINERROR)
return "entered-in-error";
return "?";
}
public String toSystem(ExplanationOfBenefitStatus code) {
return code.getSystem();
}
}
public enum Use {
/**
* The treatment is complete and this represents a Claim for the services.
*/
CLAIM,
/**
* The treatment is proposed and this represents a Pre-authorization for the
* services.
*/
PREAUTHORIZATION,
/**
* The treatment is proposed and this represents a Pre-determination for the
* services.
*/
PREDETERMINATION,
/**
* added to help the parsers with the generic types
*/
NULL;
public static Use fromCode(String codeString) throws FHIRException {
if (codeString == null || "".equals(codeString))
return null;
if ("claim".equals(codeString))
return CLAIM;
if ("preauthorization".equals(codeString))
return PREAUTHORIZATION;
if ("predetermination".equals(codeString))
return PREDETERMINATION;
if (Configuration.isAcceptInvalidEnums())
return null;
else
throw new FHIRException("Unknown Use code '" + codeString + "'");
}
public String toCode() {
switch (this) {
case CLAIM:
return "claim";
case PREAUTHORIZATION:
return "preauthorization";
case PREDETERMINATION:
return "predetermination";
case NULL:
return null;
default:
return "?";
}
}
public String getSystem() {
switch (this) {
case CLAIM:
return "http://hl7.org/fhir/claim-use";
case PREAUTHORIZATION:
return "http://hl7.org/fhir/claim-use";
case PREDETERMINATION:
return "http://hl7.org/fhir/claim-use";
case NULL:
return null;
default:
return "?";
}
}
public String getDefinition() {
switch (this) {
case CLAIM:
return "The treatment is complete and this represents a Claim for the services.";
case PREAUTHORIZATION:
return "The treatment is proposed and this represents a Pre-authorization for the services.";
case PREDETERMINATION:
return "The treatment is proposed and this represents a Pre-determination for the services.";
case NULL:
return null;
default:
return "?";
}
}
public String getDisplay() {
switch (this) {
case CLAIM:
return "Claim";
case PREAUTHORIZATION:
return "Preauthorization";
case PREDETERMINATION:
return "Predetermination";
case NULL:
return null;
default:
return "?";
}
}
}
public static class UseEnumFactory implements EnumFactory {
public Use fromCode(String codeString) throws IllegalArgumentException {
if (codeString == null || "".equals(codeString))
if (codeString == null || "".equals(codeString))
return null;
if ("claim".equals(codeString))
return Use.CLAIM;
if ("preauthorization".equals(codeString))
return Use.PREAUTHORIZATION;
if ("predetermination".equals(codeString))
return Use.PREDETERMINATION;
throw new IllegalArgumentException("Unknown Use code '" + codeString + "'");
}
public Enumeration fromType(PrimitiveType> code) throws FHIRException {
if (code == null)
return null;
if (code.isEmpty())
return new Enumeration(this, Use.NULL, code);
String codeString = code.asStringValue();
if (codeString == null || "".equals(codeString))
return new Enumeration(this, Use.NULL, code);
if ("claim".equals(codeString))
return new Enumeration(this, Use.CLAIM, code);
if ("preauthorization".equals(codeString))
return new Enumeration(this, Use.PREAUTHORIZATION, code);
if ("predetermination".equals(codeString))
return new Enumeration(this, Use.PREDETERMINATION, code);
throw new FHIRException("Unknown Use code '" + codeString + "'");
}
public String toCode(Use code) {
if (code == Use.CLAIM)
return "claim";
if (code == Use.PREAUTHORIZATION)
return "preauthorization";
if (code == Use.PREDETERMINATION)
return "predetermination";
return "?";
}
public String toSystem(Use code) {
return code.getSystem();
}
}
public enum RemittanceOutcome {
/**
* The Claim/Pre-authorization/Pre-determination has been received but
* processing has not begun.
*/
QUEUED,
/**
* The processing has completed without errors
*/
COMPLETE,
/**
* One or more errors have been detected in the Claim
*/
ERROR,
/**
* No errors have been detected in the Claim and some of the adjudication has
* been performed.
*/
PARTIAL,
/**
* added to help the parsers with the generic types
*/
NULL;
public static RemittanceOutcome fromCode(String codeString) throws FHIRException {
if (codeString == null || "".equals(codeString))
return null;
if ("queued".equals(codeString))
return QUEUED;
if ("complete".equals(codeString))
return COMPLETE;
if ("error".equals(codeString))
return ERROR;
if ("partial".equals(codeString))
return PARTIAL;
if (Configuration.isAcceptInvalidEnums())
return null;
else
throw new FHIRException("Unknown RemittanceOutcome code '" + codeString + "'");
}
public String toCode() {
switch (this) {
case QUEUED:
return "queued";
case COMPLETE:
return "complete";
case ERROR:
return "error";
case PARTIAL:
return "partial";
case NULL:
return null;
default:
return "?";
}
}
public String getSystem() {
switch (this) {
case QUEUED:
return "http://hl7.org/fhir/remittance-outcome";
case COMPLETE:
return "http://hl7.org/fhir/remittance-outcome";
case ERROR:
return "http://hl7.org/fhir/remittance-outcome";
case PARTIAL:
return "http://hl7.org/fhir/remittance-outcome";
case NULL:
return null;
default:
return "?";
}
}
public String getDefinition() {
switch (this) {
case QUEUED:
return "The Claim/Pre-authorization/Pre-determination has been received but processing has not begun.";
case COMPLETE:
return "The processing has completed without errors";
case ERROR:
return "One or more errors have been detected in the Claim";
case PARTIAL:
return "No errors have been detected in the Claim and some of the adjudication has been performed.";
case NULL:
return null;
default:
return "?";
}
}
public String getDisplay() {
switch (this) {
case QUEUED:
return "Queued";
case COMPLETE:
return "Processing Complete";
case ERROR:
return "Error";
case PARTIAL:
return "Partial Processing";
case NULL:
return null;
default:
return "?";
}
}
}
public static class RemittanceOutcomeEnumFactory implements EnumFactory {
public RemittanceOutcome fromCode(String codeString) throws IllegalArgumentException {
if (codeString == null || "".equals(codeString))
if (codeString == null || "".equals(codeString))
return null;
if ("queued".equals(codeString))
return RemittanceOutcome.QUEUED;
if ("complete".equals(codeString))
return RemittanceOutcome.COMPLETE;
if ("error".equals(codeString))
return RemittanceOutcome.ERROR;
if ("partial".equals(codeString))
return RemittanceOutcome.PARTIAL;
throw new IllegalArgumentException("Unknown RemittanceOutcome code '" + codeString + "'");
}
public Enumeration fromType(PrimitiveType> code) throws FHIRException {
if (code == null)
return null;
if (code.isEmpty())
return new Enumeration(this, RemittanceOutcome.NULL, code);
String codeString = code.asStringValue();
if (codeString == null || "".equals(codeString))
return new Enumeration(this, RemittanceOutcome.NULL, code);
if ("queued".equals(codeString))
return new Enumeration(this, RemittanceOutcome.QUEUED, code);
if ("complete".equals(codeString))
return new Enumeration(this, RemittanceOutcome.COMPLETE, code);
if ("error".equals(codeString))
return new Enumeration(this, RemittanceOutcome.ERROR, code);
if ("partial".equals(codeString))
return new Enumeration(this, RemittanceOutcome.PARTIAL, code);
throw new FHIRException("Unknown RemittanceOutcome code '" + codeString + "'");
}
public String toCode(RemittanceOutcome code) {
if (code == RemittanceOutcome.QUEUED)
return "queued";
if (code == RemittanceOutcome.COMPLETE)
return "complete";
if (code == RemittanceOutcome.ERROR)
return "error";
if (code == RemittanceOutcome.PARTIAL)
return "partial";
return "?";
}
public String toSystem(RemittanceOutcome code) {
return code.getSystem();
}
}
@Block()
public static class RelatedClaimComponent extends BackboneElement implements IBaseBackboneElement {
/**
* Reference to a related claim.
*/
@Child(name = "claim", type = { Claim.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Reference to the related claim", formalDefinition = "Reference to a related claim.")
protected Reference claim;
/**
* The actual object that is the target of the reference (Reference to a related
* claim.)
*/
protected Claim claimTarget;
/**
* A code to convey how the claims are related.
*/
@Child(name = "relationship", type = {
CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "How the reference claim is related", formalDefinition = "A code to convey how the claims are related.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/related-claim-relationship")
protected CodeableConcept relationship;
/**
* An alternate organizational reference to the case or file to which this
* particular claim pertains.
*/
@Child(name = "reference", type = {
Identifier.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "File or case reference", formalDefinition = "An alternate organizational reference to the case or file to which this particular claim pertains.")
protected Identifier reference;
private static final long serialVersionUID = -379338905L;
/**
* Constructor
*/
public RelatedClaimComponent() {
super();
}
/**
* @return {@link #claim} (Reference to a related claim.)
*/
public Reference getClaim() {
if (this.claim == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create RelatedClaimComponent.claim");
else if (Configuration.doAutoCreate())
this.claim = new Reference(); // cc
return this.claim;
}
public boolean hasClaim() {
return this.claim != null && !this.claim.isEmpty();
}
/**
* @param value {@link #claim} (Reference to a related claim.)
*/
public RelatedClaimComponent setClaim(Reference value) {
this.claim = value;
return this;
}
/**
* @return {@link #claim} The actual object that is the target of the reference.
* The reference library doesn't populate this, but you can use it to
* hold the resource if you resolve it. (Reference to a related claim.)
*/
public Claim getClaimTarget() {
if (this.claimTarget == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create RelatedClaimComponent.claim");
else if (Configuration.doAutoCreate())
this.claimTarget = new Claim(); // aa
return this.claimTarget;
}
/**
* @param value {@link #claim} The actual object that is the target of the
* reference. The reference library doesn't use these, but you can
* use it to hold the resource if you resolve it. (Reference to a
* related claim.)
*/
public RelatedClaimComponent setClaimTarget(Claim value) {
this.claimTarget = value;
return this;
}
/**
* @return {@link #relationship} (A code to convey how the claims are related.)
*/
public CodeableConcept getRelationship() {
if (this.relationship == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create RelatedClaimComponent.relationship");
else if (Configuration.doAutoCreate())
this.relationship = new CodeableConcept(); // cc
return this.relationship;
}
public boolean hasRelationship() {
return this.relationship != null && !this.relationship.isEmpty();
}
/**
* @param value {@link #relationship} (A code to convey how the claims are
* related.)
*/
public RelatedClaimComponent setRelationship(CodeableConcept value) {
this.relationship = value;
return this;
}
/**
* @return {@link #reference} (An alternate organizational reference to the case
* or file to which this particular claim pertains.)
*/
public Identifier getReference() {
if (this.reference == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create RelatedClaimComponent.reference");
else if (Configuration.doAutoCreate())
this.reference = new Identifier(); // cc
return this.reference;
}
public boolean hasReference() {
return this.reference != null && !this.reference.isEmpty();
}
/**
* @param value {@link #reference} (An alternate organizational reference to the
* case or file to which this particular claim pertains.)
*/
public RelatedClaimComponent setReference(Identifier value) {
this.reference = value;
return this;
}
protected void listChildren(List children) {
super.listChildren(children);
children.add(new Property("claim", "Reference(Claim)", "Reference to a related claim.", 0, 1, claim));
children.add(new Property("relationship", "CodeableConcept", "A code to convey how the claims are related.", 0, 1,
relationship));
children.add(new Property("reference", "Identifier",
"An alternate organizational reference to the case or file to which this particular claim pertains.", 0, 1,
reference));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
case 94742588:
/* claim */ return new Property("claim", "Reference(Claim)", "Reference to a related claim.", 0, 1, claim);
case -261851592:
/* relationship */ return new Property("relationship", "CodeableConcept",
"A code to convey how the claims are related.", 0, 1, relationship);
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);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 94742588:
/* claim */ return this.claim == null ? new Base[0] : new Base[] { this.claim }; // Reference
case -261851592:
/* relationship */ return this.relationship == null ? new Base[0] : new Base[] { this.relationship }; // CodeableConcept
case -925155509:
/* reference */ return this.reference == null ? new Base[0] : new Base[] { this.reference }; // Identifier
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 94742588: // claim
this.claim = castToReference(value); // Reference
return value;
case -261851592: // relationship
this.relationship = castToCodeableConcept(value); // CodeableConcept
return value;
case -925155509: // reference
this.reference = castToIdentifier(value); // Identifier
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("claim")) {
this.claim = castToReference(value); // Reference
} else if (name.equals("relationship")) {
this.relationship = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("reference")) {
this.reference = castToIdentifier(value); // Identifier
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("claim")) {
this.claim = null;
} else if (name.equals("relationship")) {
this.relationship = null;
} else if (name.equals("reference")) {
this.reference = null;
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 94742588:
return getClaim();
case -261851592:
return getRelationship();
case -925155509:
return getReference();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 94742588:
/* claim */ return new String[] { "Reference" };
case -261851592:
/* relationship */ return new String[] { "CodeableConcept" };
case -925155509:
/* reference */ return new String[] { "Identifier" };
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("claim")) {
this.claim = new Reference();
return this.claim;
} else if (name.equals("relationship")) {
this.relationship = new CodeableConcept();
return this.relationship;
} else if (name.equals("reference")) {
this.reference = new Identifier();
return this.reference;
} else
return super.addChild(name);
}
public RelatedClaimComponent copy() {
RelatedClaimComponent dst = new RelatedClaimComponent();
copyValues(dst);
return dst;
}
public void copyValues(RelatedClaimComponent dst) {
super.copyValues(dst);
dst.claim = claim == null ? null : claim.copy();
dst.relationship = relationship == null ? null : relationship.copy();
dst.reference = reference == null ? null : reference.copy();
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof RelatedClaimComponent))
return false;
RelatedClaimComponent o = (RelatedClaimComponent) other_;
return compareDeep(claim, o.claim, true) && compareDeep(relationship, o.relationship, true)
&& compareDeep(reference, o.reference, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof RelatedClaimComponent))
return false;
RelatedClaimComponent o = (RelatedClaimComponent) other_;
return true;
}
public boolean isEmpty() {
return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(claim, relationship, reference);
}
public String fhirType() {
return "ExplanationOfBenefit.related";
}
}
@Block()
public static class PayeeComponent extends BackboneElement implements IBaseBackboneElement {
/**
* Type of Party to be reimbursed: Subscriber, provider, other.
*/
@Child(name = "type", type = {
CodeableConcept.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Category of recipient", formalDefinition = "Type of Party to be reimbursed: Subscriber, provider, other.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/payeetype")
protected CodeableConcept type;
/**
* Reference to the individual or organization to whom any payment will be made.
*/
@Child(name = "party", type = { Practitioner.class, PractitionerRole.class, Organization.class, Patient.class,
RelatedPerson.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Recipient reference", formalDefinition = "Reference to the individual or organization to whom any payment will be made.")
protected Reference party;
/**
* The actual object that is the target of the reference (Reference to the
* individual or organization to whom any payment will be made.)
*/
protected Resource partyTarget;
private static final long serialVersionUID = 1609484699L;
/**
* Constructor
*/
public PayeeComponent() {
super();
}
/**
* @return {@link #type} (Type of Party to be reimbursed: Subscriber, provider,
* other.)
*/
public CodeableConcept getType() {
if (this.type == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create PayeeComponent.type");
else if (Configuration.doAutoCreate())
this.type = new CodeableConcept(); // cc
return this.type;
}
public boolean hasType() {
return this.type != null && !this.type.isEmpty();
}
/**
* @param value {@link #type} (Type of Party to be reimbursed: Subscriber,
* provider, other.)
*/
public PayeeComponent setType(CodeableConcept value) {
this.type = value;
return this;
}
/**
* @return {@link #party} (Reference to the individual or organization to whom
* any payment will be made.)
*/
public Reference getParty() {
if (this.party == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create PayeeComponent.party");
else if (Configuration.doAutoCreate())
this.party = new Reference(); // cc
return this.party;
}
public boolean hasParty() {
return this.party != null && !this.party.isEmpty();
}
/**
* @param value {@link #party} (Reference to the individual or organization to
* whom any payment will be made.)
*/
public PayeeComponent setParty(Reference value) {
this.party = value;
return this;
}
/**
* @return {@link #party} The actual object that is the target of the reference.
* The reference library doesn't populate this, but you can use it to
* hold the resource if you resolve it. (Reference to the individual or
* organization to whom any payment will be made.)
*/
public Resource getPartyTarget() {
return this.partyTarget;
}
/**
* @param value {@link #party} The actual object that is the target of the
* reference. The reference library doesn't use these, but you can
* use it to hold the resource if you resolve it. (Reference to the
* individual or organization to whom any payment will be made.)
*/
public PayeeComponent setPartyTarget(Resource value) {
this.partyTarget = value;
return this;
}
protected void listChildren(List children) {
super.listChildren(children);
children.add(new Property("type", "CodeableConcept",
"Type of Party to be reimbursed: Subscriber, provider, other.", 0, 1, type));
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));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
case 3575610:
/* type */ return new Property("type", "CodeableConcept",
"Type of Party to be reimbursed: Subscriber, provider, other.", 0, 1, type);
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);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 3575610:
/* type */ return this.type == null ? new Base[0] : new Base[] { this.type }; // CodeableConcept
case 106437350:
/* party */ return this.party == null ? new Base[0] : new Base[] { this.party }; // Reference
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 3575610: // type
this.type = castToCodeableConcept(value); // CodeableConcept
return value;
case 106437350: // party
this.party = castToReference(value); // Reference
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("type")) {
this.type = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("party")) {
this.party = castToReference(value); // Reference
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("type")) {
this.type = null;
} else if (name.equals("party")) {
this.party = null;
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 3575610:
return getType();
case 106437350:
return getParty();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 3575610:
/* type */ return new String[] { "CodeableConcept" };
case 106437350:
/* party */ return new String[] { "Reference" };
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("type")) {
this.type = new CodeableConcept();
return this.type;
} else if (name.equals("party")) {
this.party = new Reference();
return this.party;
} else
return super.addChild(name);
}
public PayeeComponent copy() {
PayeeComponent dst = new PayeeComponent();
copyValues(dst);
return dst;
}
public void copyValues(PayeeComponent dst) {
super.copyValues(dst);
dst.type = type == null ? null : type.copy();
dst.party = party == null ? null : party.copy();
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof PayeeComponent))
return false;
PayeeComponent o = (PayeeComponent) other_;
return compareDeep(type, o.type, true) && compareDeep(party, o.party, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof PayeeComponent))
return false;
PayeeComponent o = (PayeeComponent) other_;
return true;
}
public boolean isEmpty() {
return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(type, party);
}
public String fhirType() {
return "ExplanationOfBenefit.payee";
}
}
@Block()
public static class CareTeamComponent extends BackboneElement implements IBaseBackboneElement {
/**
* A number to uniquely identify care team entries.
*/
@Child(name = "sequence", type = {
PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Order of care team", formalDefinition = "A number to uniquely identify care team entries.")
protected PositiveIntType sequence;
/**
* Member of the team who provided the product or service.
*/
@Child(name = "provider", type = { Practitioner.class, PractitionerRole.class,
Organization.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Practitioner or organization", formalDefinition = "Member of the team who provided the product or service.")
protected Reference provider;
/**
* The actual object that is the target of the reference (Member of the team who
* provided the product or service.)
*/
protected Resource providerTarget;
/**
* The party who is billing and/or responsible for the claimed products or
* services.
*/
@Child(name = "responsible", type = {
BooleanType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Indicator of the lead practitioner", formalDefinition = "The party who is billing and/or responsible for the claimed products or services.")
protected BooleanType responsible;
/**
* The lead, assisting or supervising practitioner and their discipline if a
* multidisciplinary team.
*/
@Child(name = "role", type = {
CodeableConcept.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Function within the team", formalDefinition = "The lead, assisting or supervising practitioner and their discipline if a multidisciplinary team.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-careteamrole")
protected CodeableConcept role;
/**
* The qualification of the practitioner which is applicable for this service.
*/
@Child(name = "qualification", type = {
CodeableConcept.class }, order = 5, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Practitioner credential or specialization", formalDefinition = "The qualification of the practitioner which is applicable for this service.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/provider-qualification")
protected CodeableConcept qualification;
private static final long serialVersionUID = 1758966968L;
/**
* Constructor
*/
public CareTeamComponent() {
super();
}
/**
* Constructor
*/
public CareTeamComponent(PositiveIntType sequence, Reference provider) {
super();
this.sequence = sequence;
this.provider = provider;
}
/**
* @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
*/
public PositiveIntType getSequenceElement() {
if (this.sequence == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create CareTeamComponent.sequence");
else if (Configuration.doAutoCreate())
this.sequence = new PositiveIntType(); // bb
return this.sequence;
}
public boolean hasSequenceElement() {
return this.sequence != null && !this.sequence.isEmpty();
}
public boolean hasSequence() {
return this.sequence != null && !this.sequence.isEmpty();
}
/**
* @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
*/
public CareTeamComponent setSequenceElement(PositiveIntType value) {
this.sequence = value;
return this;
}
/**
* @return A number to uniquely identify care team entries.
*/
public int getSequence() {
return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
}
/**
* @param value A number to uniquely identify care team entries.
*/
public CareTeamComponent setSequence(int value) {
if (this.sequence == null)
this.sequence = new PositiveIntType();
this.sequence.setValue(value);
return this;
}
/**
* @return {@link #provider} (Member of the team who provided the product or
* service.)
*/
public Reference getProvider() {
if (this.provider == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create CareTeamComponent.provider");
else if (Configuration.doAutoCreate())
this.provider = new Reference(); // cc
return this.provider;
}
public boolean hasProvider() {
return this.provider != null && !this.provider.isEmpty();
}
/**
* @param value {@link #provider} (Member of the team who provided the product
* or service.)
*/
public CareTeamComponent setProvider(Reference value) {
this.provider = value;
return this;
}
/**
* @return {@link #provider} The actual object that is the target of the
* reference. The reference library doesn't populate this, but you can
* use it to hold the resource if you resolve it. (Member of the team
* who provided the product or service.)
*/
public Resource getProviderTarget() {
return this.providerTarget;
}
/**
* @param value {@link #provider} The actual object that is the target of the
* reference. The reference library doesn't use these, but you can
* use it to hold the resource if you resolve it. (Member of the
* team who provided the product or service.)
*/
public CareTeamComponent setProviderTarget(Resource value) {
this.providerTarget = value;
return this;
}
/**
* @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
*/
public BooleanType getResponsibleElement() {
if (this.responsible == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create CareTeamComponent.responsible");
else if (Configuration.doAutoCreate())
this.responsible = new BooleanType(); // bb
return this.responsible;
}
public boolean hasResponsibleElement() {
return this.responsible != null && !this.responsible.isEmpty();
}
public boolean hasResponsible() {
return this.responsible != null && !this.responsible.isEmpty();
}
/**
* @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
*/
public CareTeamComponent setResponsibleElement(BooleanType value) {
this.responsible = value;
return this;
}
/**
* @return The party who is billing and/or responsible for the claimed products
* or services.
*/
public boolean getResponsible() {
return this.responsible == null || this.responsible.isEmpty() ? false : this.responsible.getValue();
}
/**
* @param value The party who is billing and/or responsible for the claimed
* products or services.
*/
public CareTeamComponent setResponsible(boolean value) {
if (this.responsible == null)
this.responsible = new BooleanType();
this.responsible.setValue(value);
return this;
}
/**
* @return {@link #role} (The lead, assisting or supervising practitioner and
* their discipline if a multidisciplinary team.)
*/
public CodeableConcept getRole() {
if (this.role == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create CareTeamComponent.role");
else if (Configuration.doAutoCreate())
this.role = new CodeableConcept(); // cc
return this.role;
}
public boolean hasRole() {
return this.role != null && !this.role.isEmpty();
}
/**
* @param value {@link #role} (The lead, assisting or supervising practitioner
* and their discipline if a multidisciplinary team.)
*/
public CareTeamComponent setRole(CodeableConcept value) {
this.role = value;
return this;
}
/**
* @return {@link #qualification} (The qualification of the practitioner which
* is applicable for this service.)
*/
public CodeableConcept getQualification() {
if (this.qualification == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create CareTeamComponent.qualification");
else if (Configuration.doAutoCreate())
this.qualification = new CodeableConcept(); // cc
return this.qualification;
}
public boolean hasQualification() {
return this.qualification != null && !this.qualification.isEmpty();
}
/**
* @param value {@link #qualification} (The qualification of the practitioner
* which is applicable for this service.)
*/
public CareTeamComponent setQualification(CodeableConcept value) {
this.qualification = value;
return this;
}
protected void listChildren(List children) {
super.listChildren(children);
children.add(
new Property("sequence", "positiveInt", "A number to uniquely identify care team entries.", 0, 1, sequence));
children.add(new Property("provider", "Reference(Practitioner|PractitionerRole|Organization)",
"Member of the team who provided the product or service.", 0, 1, provider));
children.add(new Property("responsible", "boolean",
"The party who is billing and/or responsible for the claimed products or services.", 0, 1, responsible));
children.add(new Property("role", "CodeableConcept",
"The lead, assisting or supervising practitioner and their discipline if a multidisciplinary team.", 0, 1,
role));
children.add(new Property("qualification", "CodeableConcept",
"The qualification of the practitioner which is applicable for this service.", 0, 1, qualification));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
case 1349547969:
/* sequence */ return new Property("sequence", "positiveInt",
"A number to uniquely identify care team entries.", 0, 1, sequence);
case -987494927:
/* provider */ return new Property("provider", "Reference(Practitioner|PractitionerRole|Organization)",
"Member of the team who provided the product or service.", 0, 1, provider);
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);
case 3506294:
/* role */ return new Property("role", "CodeableConcept",
"The lead, assisting or supervising practitioner and their discipline if a multidisciplinary team.", 0, 1,
role);
case -631333393:
/* qualification */ return new Property("qualification", "CodeableConcept",
"The qualification of the practitioner which is applicable for this service.", 0, 1, qualification);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
case -987494927:
/* provider */ return this.provider == null ? new Base[0] : new Base[] { this.provider }; // Reference
case 1847674614:
/* responsible */ return this.responsible == null ? new Base[0] : new Base[] { this.responsible }; // BooleanType
case 3506294:
/* role */ return this.role == null ? new Base[0] : new Base[] { this.role }; // CodeableConcept
case -631333393:
/* qualification */ return this.qualification == null ? new Base[0] : new Base[] { this.qualification }; // CodeableConcept
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 1349547969: // sequence
this.sequence = castToPositiveInt(value); // PositiveIntType
return value;
case -987494927: // provider
this.provider = castToReference(value); // Reference
return value;
case 1847674614: // responsible
this.responsible = castToBoolean(value); // BooleanType
return value;
case 3506294: // role
this.role = castToCodeableConcept(value); // CodeableConcept
return value;
case -631333393: // qualification
this.qualification = castToCodeableConcept(value); // CodeableConcept
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = castToPositiveInt(value); // PositiveIntType
} else if (name.equals("provider")) {
this.provider = castToReference(value); // Reference
} else if (name.equals("responsible")) {
this.responsible = castToBoolean(value); // BooleanType
} else if (name.equals("role")) {
this.role = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("qualification")) {
this.qualification = castToCodeableConcept(value); // CodeableConcept
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = null;
} else if (name.equals("provider")) {
this.provider = null;
} else if (name.equals("responsible")) {
this.responsible = null;
} else if (name.equals("role")) {
this.role = null;
} else if (name.equals("qualification")) {
this.qualification = null;
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
return getSequenceElement();
case -987494927:
return getProvider();
case 1847674614:
return getResponsibleElement();
case 3506294:
return getRole();
case -631333393:
return getQualification();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return new String[] { "positiveInt" };
case -987494927:
/* provider */ return new String[] { "Reference" };
case 1847674614:
/* responsible */ return new String[] { "boolean" };
case 3506294:
/* role */ return new String[] { "CodeableConcept" };
case -631333393:
/* qualification */ return new String[] { "CodeableConcept" };
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("sequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
} else if (name.equals("provider")) {
this.provider = new Reference();
return this.provider;
} else if (name.equals("responsible")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.responsible");
} else if (name.equals("role")) {
this.role = new CodeableConcept();
return this.role;
} else if (name.equals("qualification")) {
this.qualification = new CodeableConcept();
return this.qualification;
} else
return super.addChild(name);
}
public CareTeamComponent copy() {
CareTeamComponent dst = new CareTeamComponent();
copyValues(dst);
return dst;
}
public void copyValues(CareTeamComponent dst) {
super.copyValues(dst);
dst.sequence = sequence == null ? null : sequence.copy();
dst.provider = provider == null ? null : provider.copy();
dst.responsible = responsible == null ? null : responsible.copy();
dst.role = role == null ? null : role.copy();
dst.qualification = qualification == null ? null : qualification.copy();
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof CareTeamComponent))
return false;
CareTeamComponent o = (CareTeamComponent) other_;
return compareDeep(sequence, o.sequence, true) && compareDeep(provider, o.provider, true)
&& compareDeep(responsible, o.responsible, true) && compareDeep(role, o.role, true)
&& compareDeep(qualification, o.qualification, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof CareTeamComponent))
return false;
CareTeamComponent o = (CareTeamComponent) other_;
return compareValues(sequence, o.sequence, true) && compareValues(responsible, o.responsible, true);
}
public boolean isEmpty() {
return super.isEmpty()
&& ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, provider, responsible, role, qualification);
}
public String fhirType() {
return "ExplanationOfBenefit.careTeam";
}
}
@Block()
public static class SupportingInformationComponent extends BackboneElement implements IBaseBackboneElement {
/**
* A number to uniquely identify supporting information entries.
*/
@Child(name = "sequence", type = {
PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Information instance identifier", formalDefinition = "A number to uniquely identify supporting information entries.")
protected PositiveIntType sequence;
/**
* The general class of the information supplied: information; exception;
* accident, employment; onset, etc.
*/
@Child(name = "category", type = {
CodeableConcept.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Classification of the supplied information", formalDefinition = "The general class of the information supplied: information; exception; accident, employment; onset, etc.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-informationcategory")
protected CodeableConcept category;
/**
* System and code pertaining to the specific information regarding special
* conditions relating to the setting, treatment or patient for which care is
* sought.
*/
@Child(name = "code", type = {
CodeableConcept.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
@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.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-exception")
protected CodeableConcept code;
/**
* The date when or period to which this information refers.
*/
@Child(name = "timing", type = { DateType.class,
Period.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "When it occurred", formalDefinition = "The date when or period to which this information refers.")
protected Type timing;
/**
* Additional data or information such as resources, documents, images etc.
* including references to the data or the actual inclusion of the data.
*/
@Child(name = "value", type = { BooleanType.class, StringType.class, Quantity.class, Attachment.class,
Reference.class }, order = 5, min = 0, max = 1, modifier = false, summary = false)
@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.")
protected Type value;
/**
* Provides the reason in the situation where a reason code is required in
* addition to the content.
*/
@Child(name = "reason", type = { Coding.class }, order = 6, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Explanation for the information", formalDefinition = "Provides the reason in the situation where a reason code is required in addition to the content.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/missing-tooth-reason")
protected Coding reason;
private static final long serialVersionUID = -410136661L;
/**
* Constructor
*/
public SupportingInformationComponent() {
super();
}
/**
* Constructor
*/
public SupportingInformationComponent(PositiveIntType sequence, CodeableConcept category) {
super();
this.sequence = sequence;
this.category = category;
}
/**
* @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
*/
public PositiveIntType getSequenceElement() {
if (this.sequence == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SupportingInformationComponent.sequence");
else if (Configuration.doAutoCreate())
this.sequence = new PositiveIntType(); // bb
return this.sequence;
}
public boolean hasSequenceElement() {
return this.sequence != null && !this.sequence.isEmpty();
}
public boolean hasSequence() {
return this.sequence != null && !this.sequence.isEmpty();
}
/**
* @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
*/
public SupportingInformationComponent setSequenceElement(PositiveIntType value) {
this.sequence = value;
return this;
}
/**
* @return A number to uniquely identify supporting information entries.
*/
public int getSequence() {
return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
}
/**
* @param value A number to uniquely identify supporting information entries.
*/
public SupportingInformationComponent setSequence(int value) {
if (this.sequence == null)
this.sequence = new PositiveIntType();
this.sequence.setValue(value);
return this;
}
/**
* @return {@link #category} (The general class of the information supplied:
* information; exception; accident, employment; onset, etc.)
*/
public CodeableConcept getCategory() {
if (this.category == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SupportingInformationComponent.category");
else if (Configuration.doAutoCreate())
this.category = new CodeableConcept(); // cc
return this.category;
}
public boolean hasCategory() {
return this.category != null && !this.category.isEmpty();
}
/**
* @param value {@link #category} (The general class of the information
* supplied: information; exception; accident, employment; onset,
* etc.)
*/
public SupportingInformationComponent setCategory(CodeableConcept value) {
this.category = value;
return this;
}
/**
* @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.)
*/
public CodeableConcept getCode() {
if (this.code == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SupportingInformationComponent.code");
else if (Configuration.doAutoCreate())
this.code = new CodeableConcept(); // cc
return this.code;
}
public boolean hasCode() {
return this.code != null && !this.code.isEmpty();
}
/**
* @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.)
*/
public SupportingInformationComponent setCode(CodeableConcept value) {
this.code = value;
return this;
}
/**
* @return {@link #timing} (The date when or period to which this information
* refers.)
*/
public Type getTiming() {
return this.timing;
}
/**
* @return {@link #timing} (The date when or period to which this information
* refers.)
*/
public DateType getTimingDateType() throws FHIRException {
if (this.timing == null)
this.timing = new DateType();
if (!(this.timing instanceof DateType))
throw new FHIRException("Type mismatch: the type DateType was expected, but " + this.timing.getClass().getName()
+ " was encountered");
return (DateType) this.timing;
}
public boolean hasTimingDateType() {
return this != null && this.timing instanceof DateType;
}
/**
* @return {@link #timing} (The date when or period to which this information
* refers.)
*/
public Period getTimingPeriod() throws FHIRException {
if (this.timing == null)
this.timing = new Period();
if (!(this.timing instanceof Period))
throw new FHIRException("Type mismatch: the type Period was expected, but " + this.timing.getClass().getName()
+ " was encountered");
return (Period) this.timing;
}
public boolean hasTimingPeriod() {
return this != null && this.timing instanceof Period;
}
public boolean hasTiming() {
return this.timing != null && !this.timing.isEmpty();
}
/**
* @param value {@link #timing} (The date when or period to which this
* information refers.)
*/
public SupportingInformationComponent setTiming(Type value) {
if (value != null && !(value instanceof DateType || value instanceof Period))
throw new Error("Not the right type for ExplanationOfBenefit.supportingInfo.timing[x]: " + value.fhirType());
this.timing = value;
return this;
}
/**
* @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.)
*/
public Type getValue() {
return this.value;
}
/**
* @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.)
*/
public BooleanType getValueBooleanType() throws FHIRException {
if (this.value == null)
this.value = new BooleanType();
if (!(this.value instanceof BooleanType))
throw new FHIRException("Type mismatch: the type BooleanType was expected, but "
+ this.value.getClass().getName() + " was encountered");
return (BooleanType) this.value;
}
public boolean hasValueBooleanType() {
return this != null && this.value instanceof BooleanType;
}
/**
* @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.)
*/
public StringType getValueStringType() throws FHIRException {
if (this.value == null)
this.value = new StringType();
if (!(this.value instanceof StringType))
throw new FHIRException("Type mismatch: the type StringType was expected, but "
+ this.value.getClass().getName() + " was encountered");
return (StringType) this.value;
}
public boolean hasValueStringType() {
return this != null && this.value instanceof StringType;
}
/**
* @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.)
*/
public Quantity getValueQuantity() throws FHIRException {
if (this.value == null)
this.value = new Quantity();
if (!(this.value instanceof Quantity))
throw new FHIRException("Type mismatch: the type Quantity was expected, but " + this.value.getClass().getName()
+ " was encountered");
return (Quantity) this.value;
}
public boolean hasValueQuantity() {
return this != null && this.value instanceof Quantity;
}
/**
* @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.)
*/
public Attachment getValueAttachment() throws FHIRException {
if (this.value == null)
this.value = new Attachment();
if (!(this.value instanceof Attachment))
throw new FHIRException("Type mismatch: the type Attachment was expected, but "
+ this.value.getClass().getName() + " was encountered");
return (Attachment) this.value;
}
public boolean hasValueAttachment() {
return this != null && this.value instanceof Attachment;
}
/**
* @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.)
*/
public Reference getValueReference() throws FHIRException {
if (this.value == null)
this.value = new Reference();
if (!(this.value instanceof Reference))
throw new FHIRException("Type mismatch: the type Reference was expected, but " + this.value.getClass().getName()
+ " was encountered");
return (Reference) this.value;
}
public boolean hasValueReference() {
return this != null && this.value instanceof Reference;
}
public boolean hasValue() {
return this.value != null && !this.value.isEmpty();
}
/**
* @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.)
*/
public SupportingInformationComponent setValue(Type value) {
if (value != null && !(value instanceof BooleanType || value instanceof StringType || value instanceof Quantity
|| value instanceof Attachment || value instanceof Reference))
throw new Error("Not the right type for ExplanationOfBenefit.supportingInfo.value[x]: " + value.fhirType());
this.value = value;
return this;
}
/**
* @return {@link #reason} (Provides the reason in the situation where a reason
* code is required in addition to the content.)
*/
public Coding getReason() {
if (this.reason == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SupportingInformationComponent.reason");
else if (Configuration.doAutoCreate())
this.reason = new Coding(); // cc
return this.reason;
}
public boolean hasReason() {
return this.reason != null && !this.reason.isEmpty();
}
/**
* @param value {@link #reason} (Provides the reason in the situation where a
* reason code is required in addition to the content.)
*/
public SupportingInformationComponent setReason(Coding value) {
this.reason = value;
return this;
}
protected void listChildren(List children) {
super.listChildren(children);
children.add(new Property("sequence", "positiveInt",
"A number to uniquely identify supporting information entries.", 0, 1, sequence));
children.add(new Property("category", "CodeableConcept",
"The general class of the information supplied: information; exception; accident, employment; onset, etc.", 0,
1, category));
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));
children.add(new Property("timing[x]", "date|Period", "The date when or period to which this information refers.",
0, 1, timing));
children.add(new Property("value[x]", "boolean|string|Quantity|Attachment|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));
children.add(new Property("reason", "Coding",
"Provides the reason in the situation where a reason code is required in addition to the content.", 0, 1,
reason));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
case 1349547969:
/* sequence */ return new Property("sequence", "positiveInt",
"A number to uniquely identify supporting information entries.", 0, 1, sequence);
case 50511102:
/* category */ return new Property("category", "CodeableConcept",
"The general class of the information supplied: information; exception; accident, employment; onset, etc.",
0, 1, category);
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);
case 164632566:
/* timing[x] */ return new Property("timing[x]", "date|Period",
"The date when or period to which this information refers.", 0, 1, timing);
case -873664438:
/* timing */ return new Property("timing[x]", "date|Period",
"The date when or period to which this information refers.", 0, 1, timing);
case 807935768:
/* timingDate */ return new Property("timing[x]", "date|Period",
"The date when or period to which this information refers.", 0, 1, timing);
case -615615829:
/* timingPeriod */ return new Property("timing[x]", "date|Period",
"The date when or period to which this information refers.", 0, 1, timing);
case -1410166417:
/* value[x] */ return new Property("value[x]", "boolean|string|Quantity|Attachment|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);
case 111972721:
/* value */ return new Property("value[x]", "boolean|string|Quantity|Attachment|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);
case 733421943:
/* valueBoolean */ return new Property("value[x]", "boolean|string|Quantity|Attachment|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);
case -1424603934:
/* valueString */ return new Property("value[x]", "boolean|string|Quantity|Attachment|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);
case -2029823716:
/* valueQuantity */ return new Property("value[x]", "boolean|string|Quantity|Attachment|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);
case -475566732:
/* valueAttachment */ return new Property("value[x]", "boolean|string|Quantity|Attachment|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);
case 1755241690:
/* valueReference */ return new Property("value[x]", "boolean|string|Quantity|Attachment|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);
case -934964668:
/* reason */ return new Property("reason", "Coding",
"Provides the reason in the situation where a reason code is required in addition to the content.", 0, 1,
reason);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
case 50511102:
/* category */ return this.category == null ? new Base[0] : new Base[] { this.category }; // CodeableConcept
case 3059181:
/* code */ return this.code == null ? new Base[0] : new Base[] { this.code }; // CodeableConcept
case -873664438:
/* timing */ return this.timing == null ? new Base[0] : new Base[] { this.timing }; // Type
case 111972721:
/* value */ return this.value == null ? new Base[0] : new Base[] { this.value }; // Type
case -934964668:
/* reason */ return this.reason == null ? new Base[0] : new Base[] { this.reason }; // Coding
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 1349547969: // sequence
this.sequence = castToPositiveInt(value); // PositiveIntType
return value;
case 50511102: // category
this.category = castToCodeableConcept(value); // CodeableConcept
return value;
case 3059181: // code
this.code = castToCodeableConcept(value); // CodeableConcept
return value;
case -873664438: // timing
this.timing = castToType(value); // Type
return value;
case 111972721: // value
this.value = castToType(value); // Type
return value;
case -934964668: // reason
this.reason = castToCoding(value); // Coding
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = castToPositiveInt(value); // PositiveIntType
} else if (name.equals("category")) {
this.category = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("code")) {
this.code = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("timing[x]")) {
this.timing = castToType(value); // Type
} else if (name.equals("value[x]")) {
this.value = castToType(value); // Type
} else if (name.equals("reason")) {
this.reason = castToCoding(value); // Coding
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = null;
} else if (name.equals("category")) {
this.category = null;
} else if (name.equals("code")) {
this.code = null;
} else if (name.equals("timing[x]")) {
this.timing = null;
} else if (name.equals("value[x]")) {
this.value = null;
} else if (name.equals("reason")) {
this.reason = null;
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
return getSequenceElement();
case 50511102:
return getCategory();
case 3059181:
return getCode();
case 164632566:
return getTiming();
case -873664438:
return getTiming();
case -1410166417:
return getValue();
case 111972721:
return getValue();
case -934964668:
return getReason();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return new String[] { "positiveInt" };
case 50511102:
/* category */ return new String[] { "CodeableConcept" };
case 3059181:
/* code */ return new String[] { "CodeableConcept" };
case -873664438:
/* timing */ return new String[] { "date", "Period" };
case 111972721:
/* value */ return new String[] { "boolean", "string", "Quantity", "Attachment", "Reference" };
case -934964668:
/* reason */ return new String[] { "Coding" };
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("sequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
} else if (name.equals("category")) {
this.category = new CodeableConcept();
return this.category;
} else if (name.equals("code")) {
this.code = new CodeableConcept();
return this.code;
} else if (name.equals("timingDate")) {
this.timing = new DateType();
return this.timing;
} else if (name.equals("timingPeriod")) {
this.timing = new Period();
return this.timing;
} else if (name.equals("valueBoolean")) {
this.value = new BooleanType();
return this.value;
} else if (name.equals("valueString")) {
this.value = new StringType();
return this.value;
} else if (name.equals("valueQuantity")) {
this.value = new Quantity();
return this.value;
} else if (name.equals("valueAttachment")) {
this.value = new Attachment();
return this.value;
} else if (name.equals("valueReference")) {
this.value = new Reference();
return this.value;
} else if (name.equals("reason")) {
this.reason = new Coding();
return this.reason;
} else
return super.addChild(name);
}
public SupportingInformationComponent copy() {
SupportingInformationComponent dst = new SupportingInformationComponent();
copyValues(dst);
return dst;
}
public void copyValues(SupportingInformationComponent dst) {
super.copyValues(dst);
dst.sequence = sequence == null ? null : sequence.copy();
dst.category = category == null ? null : category.copy();
dst.code = code == null ? null : code.copy();
dst.timing = timing == null ? null : timing.copy();
dst.value = value == null ? null : value.copy();
dst.reason = reason == null ? null : reason.copy();
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof SupportingInformationComponent))
return false;
SupportingInformationComponent o = (SupportingInformationComponent) other_;
return compareDeep(sequence, o.sequence, true) && compareDeep(category, o.category, true)
&& compareDeep(code, o.code, true) && compareDeep(timing, o.timing, true) && compareDeep(value, o.value, true)
&& compareDeep(reason, o.reason, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof SupportingInformationComponent))
return false;
SupportingInformationComponent o = (SupportingInformationComponent) other_;
return compareValues(sequence, o.sequence, true);
}
public boolean isEmpty() {
return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, category, code, timing, value, reason);
}
public String fhirType() {
return "ExplanationOfBenefit.supportingInfo";
}
}
@Block()
public static class DiagnosisComponent extends BackboneElement implements IBaseBackboneElement {
/**
* A number to uniquely identify diagnosis entries.
*/
@Child(name = "sequence", type = {
PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Diagnosis instance identifier", formalDefinition = "A number to uniquely identify diagnosis entries.")
protected PositiveIntType sequence;
/**
* The nature of illness or problem in a coded form or as a reference to an
* external defined Condition.
*/
@Child(name = "diagnosis", type = { CodeableConcept.class,
Condition.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
@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.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/icd-10")
protected Type diagnosis;
/**
* When the condition was observed or the relative ranking.
*/
@Child(name = "type", type = {
CodeableConcept.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Timing or nature of the diagnosis", formalDefinition = "When the condition was observed or the relative ranking.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-diagnosistype")
protected List type;
/**
* Indication of whether the diagnosis was present on admission to a facility.
*/
@Child(name = "onAdmission", type = {
CodeableConcept.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Present on admission", formalDefinition = "Indication of whether the diagnosis was present on admission to a facility.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-diagnosis-on-admission")
protected CodeableConcept onAdmission;
/**
* 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.
*/
@Child(name = "packageCode", type = {
CodeableConcept.class }, order = 5, min = 0, max = 1, modifier = false, summary = false)
@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.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-diagnosisrelatedgroup")
protected CodeableConcept packageCode;
private static final long serialVersionUID = 2120593974L;
/**
* Constructor
*/
public DiagnosisComponent() {
super();
}
/**
* Constructor
*/
public DiagnosisComponent(PositiveIntType sequence, Type diagnosis) {
super();
this.sequence = sequence;
this.diagnosis = diagnosis;
}
/**
* @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
*/
public PositiveIntType getSequenceElement() {
if (this.sequence == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DiagnosisComponent.sequence");
else if (Configuration.doAutoCreate())
this.sequence = new PositiveIntType(); // bb
return this.sequence;
}
public boolean hasSequenceElement() {
return this.sequence != null && !this.sequence.isEmpty();
}
public boolean hasSequence() {
return this.sequence != null && !this.sequence.isEmpty();
}
/**
* @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
*/
public DiagnosisComponent setSequenceElement(PositiveIntType value) {
this.sequence = value;
return this;
}
/**
* @return A number to uniquely identify diagnosis entries.
*/
public int getSequence() {
return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
}
/**
* @param value A number to uniquely identify diagnosis entries.
*/
public DiagnosisComponent setSequence(int value) {
if (this.sequence == null)
this.sequence = new PositiveIntType();
this.sequence.setValue(value);
return this;
}
/**
* @return {@link #diagnosis} (The nature of illness or problem in a coded form
* or as a reference to an external defined Condition.)
*/
public Type getDiagnosis() {
return this.diagnosis;
}
/**
* @return {@link #diagnosis} (The nature of illness or problem in a coded form
* or as a reference to an external defined Condition.)
*/
public CodeableConcept getDiagnosisCodeableConcept() throws FHIRException {
if (this.diagnosis == null)
this.diagnosis = new CodeableConcept();
if (!(this.diagnosis instanceof CodeableConcept))
throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "
+ this.diagnosis.getClass().getName() + " was encountered");
return (CodeableConcept) this.diagnosis;
}
public boolean hasDiagnosisCodeableConcept() {
return this != null && this.diagnosis instanceof CodeableConcept;
}
/**
* @return {@link #diagnosis} (The nature of illness or problem in a coded form
* or as a reference to an external defined Condition.)
*/
public Reference getDiagnosisReference() throws FHIRException {
if (this.diagnosis == null)
this.diagnosis = new Reference();
if (!(this.diagnosis instanceof Reference))
throw new FHIRException("Type mismatch: the type Reference was expected, but "
+ this.diagnosis.getClass().getName() + " was encountered");
return (Reference) this.diagnosis;
}
public boolean hasDiagnosisReference() {
return this != null && this.diagnosis instanceof Reference;
}
public boolean hasDiagnosis() {
return this.diagnosis != null && !this.diagnosis.isEmpty();
}
/**
* @param value {@link #diagnosis} (The nature of illness or problem in a coded
* form or as a reference to an external defined Condition.)
*/
public DiagnosisComponent setDiagnosis(Type value) {
if (value != null && !(value instanceof CodeableConcept || value instanceof Reference))
throw new Error("Not the right type for ExplanationOfBenefit.diagnosis.diagnosis[x]: " + value.fhirType());
this.diagnosis = value;
return this;
}
/**
* @return {@link #type} (When the condition was observed or the relative
* ranking.)
*/
public List getType() {
if (this.type == null)
this.type = new ArrayList();
return this.type;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public DiagnosisComponent setType(List theType) {
this.type = theType;
return this;
}
public boolean hasType() {
if (this.type == null)
return false;
for (CodeableConcept item : this.type)
if (!item.isEmpty())
return true;
return false;
}
public CodeableConcept addType() { // 3
CodeableConcept t = new CodeableConcept();
if (this.type == null)
this.type = new ArrayList();
this.type.add(t);
return t;
}
public DiagnosisComponent addType(CodeableConcept t) { // 3
if (t == null)
return this;
if (this.type == null)
this.type = new ArrayList();
this.type.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #type}, creating it if
* it does not already exist
*/
public CodeableConcept getTypeFirstRep() {
if (getType().isEmpty()) {
addType();
}
return getType().get(0);
}
/**
* @return {@link #onAdmission} (Indication of whether the diagnosis was present
* on admission to a facility.)
*/
public CodeableConcept getOnAdmission() {
if (this.onAdmission == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DiagnosisComponent.onAdmission");
else if (Configuration.doAutoCreate())
this.onAdmission = new CodeableConcept(); // cc
return this.onAdmission;
}
public boolean hasOnAdmission() {
return this.onAdmission != null && !this.onAdmission.isEmpty();
}
/**
* @param value {@link #onAdmission} (Indication of whether the diagnosis was
* present on admission to a facility.)
*/
public DiagnosisComponent setOnAdmission(CodeableConcept value) {
this.onAdmission = value;
return this;
}
/**
* @return {@link #packageCode} (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.)
*/
public CodeableConcept getPackageCode() {
if (this.packageCode == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DiagnosisComponent.packageCode");
else if (Configuration.doAutoCreate())
this.packageCode = new CodeableConcept(); // cc
return this.packageCode;
}
public boolean hasPackageCode() {
return this.packageCode != null && !this.packageCode.isEmpty();
}
/**
* @param value {@link #packageCode} (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.)
*/
public DiagnosisComponent setPackageCode(CodeableConcept value) {
this.packageCode = value;
return this;
}
protected void listChildren(List children) {
super.listChildren(children);
children.add(
new Property("sequence", "positiveInt", "A number to uniquely identify diagnosis entries.", 0, 1, sequence));
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));
children.add(new Property("type", "CodeableConcept", "When the condition was observed or the relative ranking.",
0, java.lang.Integer.MAX_VALUE, type));
children.add(new Property("onAdmission", "CodeableConcept",
"Indication of whether the diagnosis was present on admission to a facility.", 0, 1, onAdmission));
children.add(new Property("packageCode", "CodeableConcept",
"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.",
0, 1, packageCode));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
case 1349547969:
/* sequence */ return new Property("sequence", "positiveInt",
"A number to uniquely identify diagnosis entries.", 0, 1, sequence);
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);
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);
case 277781616:
/* diagnosisCodeableConcept */ 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);
case 2050454362:
/* diagnosisReference */ 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);
case 3575610:
/* type */ return new Property("type", "CodeableConcept",
"When the condition was observed or the relative ranking.", 0, java.lang.Integer.MAX_VALUE, type);
case -3386134:
/* onAdmission */ return new Property("onAdmission", "CodeableConcept",
"Indication of whether the diagnosis was present on admission to a facility.", 0, 1, onAdmission);
case 908444499:
/* packageCode */ return new Property("packageCode", "CodeableConcept",
"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.",
0, 1, packageCode);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
case 1196993265:
/* diagnosis */ return this.diagnosis == null ? new Base[0] : new Base[] { this.diagnosis }; // Type
case 3575610:
/* type */ return this.type == null ? new Base[0] : this.type.toArray(new Base[this.type.size()]); // CodeableConcept
case -3386134:
/* onAdmission */ return this.onAdmission == null ? new Base[0] : new Base[] { this.onAdmission }; // CodeableConcept
case 908444499:
/* packageCode */ return this.packageCode == null ? new Base[0] : new Base[] { this.packageCode }; // CodeableConcept
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 1349547969: // sequence
this.sequence = castToPositiveInt(value); // PositiveIntType
return value;
case 1196993265: // diagnosis
this.diagnosis = castToType(value); // Type
return value;
case 3575610: // type
this.getType().add(castToCodeableConcept(value)); // CodeableConcept
return value;
case -3386134: // onAdmission
this.onAdmission = castToCodeableConcept(value); // CodeableConcept
return value;
case 908444499: // packageCode
this.packageCode = castToCodeableConcept(value); // CodeableConcept
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = castToPositiveInt(value); // PositiveIntType
} else if (name.equals("diagnosis[x]")) {
this.diagnosis = castToType(value); // Type
} else if (name.equals("type")) {
this.getType().add(castToCodeableConcept(value));
} else if (name.equals("onAdmission")) {
this.onAdmission = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("packageCode")) {
this.packageCode = castToCodeableConcept(value); // CodeableConcept
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = null;
} else if (name.equals("diagnosis[x]")) {
this.diagnosis = null;
} else if (name.equals("type")) {
this.getType().remove(castToCodeableConcept(value));
} else if (name.equals("onAdmission")) {
this.onAdmission = null;
} else if (name.equals("packageCode")) {
this.packageCode = null;
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
return getSequenceElement();
case -1487009809:
return getDiagnosis();
case 1196993265:
return getDiagnosis();
case 3575610:
return addType();
case -3386134:
return getOnAdmission();
case 908444499:
return getPackageCode();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return new String[] { "positiveInt" };
case 1196993265:
/* diagnosis */ return new String[] { "CodeableConcept", "Reference" };
case 3575610:
/* type */ return new String[] { "CodeableConcept" };
case -3386134:
/* onAdmission */ return new String[] { "CodeableConcept" };
case 908444499:
/* packageCode */ return new String[] { "CodeableConcept" };
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("sequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
} else if (name.equals("diagnosisCodeableConcept")) {
this.diagnosis = new CodeableConcept();
return this.diagnosis;
} else if (name.equals("diagnosisReference")) {
this.diagnosis = new Reference();
return this.diagnosis;
} else if (name.equals("type")) {
return addType();
} else if (name.equals("onAdmission")) {
this.onAdmission = new CodeableConcept();
return this.onAdmission;
} else if (name.equals("packageCode")) {
this.packageCode = new CodeableConcept();
return this.packageCode;
} else
return super.addChild(name);
}
public DiagnosisComponent copy() {
DiagnosisComponent dst = new DiagnosisComponent();
copyValues(dst);
return dst;
}
public void copyValues(DiagnosisComponent dst) {
super.copyValues(dst);
dst.sequence = sequence == null ? null : sequence.copy();
dst.diagnosis = diagnosis == null ? null : diagnosis.copy();
if (type != null) {
dst.type = new ArrayList();
for (CodeableConcept i : type)
dst.type.add(i.copy());
}
;
dst.onAdmission = onAdmission == null ? null : onAdmission.copy();
dst.packageCode = packageCode == null ? null : packageCode.copy();
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof DiagnosisComponent))
return false;
DiagnosisComponent o = (DiagnosisComponent) other_;
return compareDeep(sequence, o.sequence, true) && compareDeep(diagnosis, o.diagnosis, true)
&& compareDeep(type, o.type, true) && compareDeep(onAdmission, o.onAdmission, true)
&& compareDeep(packageCode, o.packageCode, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof DiagnosisComponent))
return false;
DiagnosisComponent o = (DiagnosisComponent) other_;
return compareValues(sequence, o.sequence, true);
}
public boolean isEmpty() {
return super.isEmpty()
&& ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, diagnosis, type, onAdmission, packageCode);
}
public String fhirType() {
return "ExplanationOfBenefit.diagnosis";
}
}
@Block()
public static class ProcedureComponent extends BackboneElement implements IBaseBackboneElement {
/**
* A number to uniquely identify procedure entries.
*/
@Child(name = "sequence", type = {
PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Procedure instance identifier", formalDefinition = "A number to uniquely identify procedure entries.")
protected PositiveIntType sequence;
/**
* When the condition was observed or the relative ranking.
*/
@Child(name = "type", type = {
CodeableConcept.class }, order = 2, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Category of Procedure", formalDefinition = "When the condition was observed or the relative ranking.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-procedure-type")
protected List type;
/**
* Date and optionally time the procedure was performed.
*/
@Child(name = "date", type = { DateTimeType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "When the procedure was performed", formalDefinition = "Date and optionally time the procedure was performed.")
protected DateTimeType date;
/**
* The code or reference to a Procedure resource which identifies the clinical
* intervention performed.
*/
@Child(name = "procedure", type = { CodeableConcept.class,
Procedure.class }, order = 4, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Specific clinical procedure", formalDefinition = "The code or reference to a Procedure resource which identifies the clinical intervention performed.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/icd-10-procedures")
protected Type procedure;
/**
* Unique Device Identifiers associated with this line item.
*/
@Child(name = "udi", type = {
Device.class }, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Unique device identifier", formalDefinition = "Unique Device Identifiers associated with this line item.")
protected List udi;
/**
* The actual objects that are the target of the reference (Unique Device
* Identifiers associated with this line item.)
*/
protected List udiTarget;
private static final long serialVersionUID = 935341852L;
/**
* Constructor
*/
public ProcedureComponent() {
super();
}
/**
* Constructor
*/
public ProcedureComponent(PositiveIntType sequence, Type procedure) {
super();
this.sequence = sequence;
this.procedure = procedure;
}
/**
* @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
*/
public PositiveIntType getSequenceElement() {
if (this.sequence == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ProcedureComponent.sequence");
else if (Configuration.doAutoCreate())
this.sequence = new PositiveIntType(); // bb
return this.sequence;
}
public boolean hasSequenceElement() {
return this.sequence != null && !this.sequence.isEmpty();
}
public boolean hasSequence() {
return this.sequence != null && !this.sequence.isEmpty();
}
/**
* @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
*/
public ProcedureComponent setSequenceElement(PositiveIntType value) {
this.sequence = value;
return this;
}
/**
* @return A number to uniquely identify procedure entries.
*/
public int getSequence() {
return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
}
/**
* @param value A number to uniquely identify procedure entries.
*/
public ProcedureComponent setSequence(int value) {
if (this.sequence == null)
this.sequence = new PositiveIntType();
this.sequence.setValue(value);
return this;
}
/**
* @return {@link #type} (When the condition was observed or the relative
* ranking.)
*/
public List getType() {
if (this.type == null)
this.type = new ArrayList();
return this.type;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ProcedureComponent setType(List theType) {
this.type = theType;
return this;
}
public boolean hasType() {
if (this.type == null)
return false;
for (CodeableConcept item : this.type)
if (!item.isEmpty())
return true;
return false;
}
public CodeableConcept addType() { // 3
CodeableConcept t = new CodeableConcept();
if (this.type == null)
this.type = new ArrayList();
this.type.add(t);
return t;
}
public ProcedureComponent addType(CodeableConcept t) { // 3
if (t == null)
return this;
if (this.type == null)
this.type = new ArrayList();
this.type.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #type}, creating it if
* it does not already exist
*/
public CodeableConcept getTypeFirstRep() {
if (getType().isEmpty()) {
addType();
}
return getType().get(0);
}
/**
* @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
*/
public DateTimeType getDateElement() {
if (this.date == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ProcedureComponent.date");
else if (Configuration.doAutoCreate())
this.date = new DateTimeType(); // bb
return this.date;
}
public boolean hasDateElement() {
return this.date != null && !this.date.isEmpty();
}
public boolean hasDate() {
return this.date != null && !this.date.isEmpty();
}
/**
* @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
*/
public ProcedureComponent setDateElement(DateTimeType value) {
this.date = value;
return this;
}
/**
* @return Date and optionally time the procedure was performed.
*/
public Date getDate() {
return this.date == null ? null : this.date.getValue();
}
/**
* @param value Date and optionally time the procedure was performed.
*/
public ProcedureComponent setDate(Date value) {
if (value == null)
this.date = null;
else {
if (this.date == null)
this.date = new DateTimeType();
this.date.setValue(value);
}
return this;
}
/**
* @return {@link #procedure} (The code or reference to a Procedure resource
* which identifies the clinical intervention performed.)
*/
public Type getProcedure() {
return this.procedure;
}
/**
* @return {@link #procedure} (The code or reference to a Procedure resource
* which identifies the clinical intervention performed.)
*/
public CodeableConcept getProcedureCodeableConcept() throws FHIRException {
if (this.procedure == null)
this.procedure = new CodeableConcept();
if (!(this.procedure instanceof CodeableConcept))
throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "
+ this.procedure.getClass().getName() + " was encountered");
return (CodeableConcept) this.procedure;
}
public boolean hasProcedureCodeableConcept() {
return this != null && this.procedure instanceof CodeableConcept;
}
/**
* @return {@link #procedure} (The code or reference to a Procedure resource
* which identifies the clinical intervention performed.)
*/
public Reference getProcedureReference() throws FHIRException {
if (this.procedure == null)
this.procedure = new Reference();
if (!(this.procedure instanceof Reference))
throw new FHIRException("Type mismatch: the type Reference was expected, but "
+ this.procedure.getClass().getName() + " was encountered");
return (Reference) this.procedure;
}
public boolean hasProcedureReference() {
return this != null && this.procedure instanceof Reference;
}
public boolean hasProcedure() {
return this.procedure != null && !this.procedure.isEmpty();
}
/**
* @param value {@link #procedure} (The code or reference to a Procedure
* resource which identifies the clinical intervention performed.)
*/
public ProcedureComponent setProcedure(Type value) {
if (value != null && !(value instanceof CodeableConcept || value instanceof Reference))
throw new Error("Not the right type for ExplanationOfBenefit.procedure.procedure[x]: " + value.fhirType());
this.procedure = value;
return this;
}
/**
* @return {@link #udi} (Unique Device Identifiers associated with this line
* item.)
*/
public List getUdi() {
if (this.udi == null)
this.udi = new ArrayList();
return this.udi;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ProcedureComponent setUdi(List theUdi) {
this.udi = theUdi;
return this;
}
public boolean hasUdi() {
if (this.udi == null)
return false;
for (Reference item : this.udi)
if (!item.isEmpty())
return true;
return false;
}
public Reference addUdi() { // 3
Reference t = new Reference();
if (this.udi == null)
this.udi = new ArrayList();
this.udi.add(t);
return t;
}
public ProcedureComponent addUdi(Reference t) { // 3
if (t == null)
return this;
if (this.udi == null)
this.udi = new ArrayList();
this.udi.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #udi}, creating it if
* it does not already exist
*/
public Reference getUdiFirstRep() {
if (getUdi().isEmpty()) {
addUdi();
}
return getUdi().get(0);
}
/**
* @deprecated Use Reference#setResource(IBaseResource) instead
*/
@Deprecated
public List getUdiTarget() {
if (this.udiTarget == null)
this.udiTarget = new ArrayList();
return this.udiTarget;
}
/**
* @deprecated Use Reference#setResource(IBaseResource) instead
*/
@Deprecated
public Device addUdiTarget() {
Device r = new Device();
if (this.udiTarget == null)
this.udiTarget = new ArrayList();
this.udiTarget.add(r);
return r;
}
protected void listChildren(List children) {
super.listChildren(children);
children.add(
new Property("sequence", "positiveInt", "A number to uniquely identify procedure entries.", 0, 1, sequence));
children.add(new Property("type", "CodeableConcept", "When the condition was observed or the relative ranking.",
0, java.lang.Integer.MAX_VALUE, type));
children
.add(new Property("date", "dateTime", "Date and optionally time the procedure was performed.", 0, 1, date));
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));
children.add(new Property("udi", "Reference(Device)", "Unique Device Identifiers associated with this line item.",
0, java.lang.Integer.MAX_VALUE, udi));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
case 1349547969:
/* sequence */ return new Property("sequence", "positiveInt",
"A number to uniquely identify procedure entries.", 0, 1, sequence);
case 3575610:
/* type */ return new Property("type", "CodeableConcept",
"When the condition was observed or the relative ranking.", 0, java.lang.Integer.MAX_VALUE, type);
case 3076014:
/* date */ return new Property("date", "dateTime", "Date and optionally time the procedure was performed.", 0,
1, date);
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);
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);
case -1284783026:
/* procedureCodeableConcept */ 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);
case 881809848:
/* procedureReference */ 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);
case 115642:
/* udi */ return new Property("udi", "Reference(Device)",
"Unique Device Identifiers associated with this line item.", 0, java.lang.Integer.MAX_VALUE, udi);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
case 3575610:
/* type */ return this.type == null ? new Base[0] : this.type.toArray(new Base[this.type.size()]); // CodeableConcept
case 3076014:
/* date */ return this.date == null ? new Base[0] : new Base[] { this.date }; // DateTimeType
case -1095204141:
/* procedure */ return this.procedure == null ? new Base[0] : new Base[] { this.procedure }; // Type
case 115642:
/* udi */ return this.udi == null ? new Base[0] : this.udi.toArray(new Base[this.udi.size()]); // Reference
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 1349547969: // sequence
this.sequence = castToPositiveInt(value); // PositiveIntType
return value;
case 3575610: // type
this.getType().add(castToCodeableConcept(value)); // CodeableConcept
return value;
case 3076014: // date
this.date = castToDateTime(value); // DateTimeType
return value;
case -1095204141: // procedure
this.procedure = castToType(value); // Type
return value;
case 115642: // udi
this.getUdi().add(castToReference(value)); // Reference
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = castToPositiveInt(value); // PositiveIntType
} else if (name.equals("type")) {
this.getType().add(castToCodeableConcept(value));
} else if (name.equals("date")) {
this.date = castToDateTime(value); // DateTimeType
} else if (name.equals("procedure[x]")) {
this.procedure = castToType(value); // Type
} else if (name.equals("udi")) {
this.getUdi().add(castToReference(value));
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = null;
} else if (name.equals("type")) {
this.getType().remove(castToCodeableConcept(value));
} else if (name.equals("date")) {
this.date = null;
} else if (name.equals("procedure[x]")) {
this.procedure = null;
} else if (name.equals("udi")) {
this.getUdi().remove(castToReference(value));
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
return getSequenceElement();
case 3575610:
return addType();
case 3076014:
return getDateElement();
case 1640074445:
return getProcedure();
case -1095204141:
return getProcedure();
case 115642:
return addUdi();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return new String[] { "positiveInt" };
case 3575610:
/* type */ return new String[] { "CodeableConcept" };
case 3076014:
/* date */ return new String[] { "dateTime" };
case -1095204141:
/* procedure */ return new String[] { "CodeableConcept", "Reference" };
case 115642:
/* udi */ return new String[] { "Reference" };
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("sequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
} else if (name.equals("type")) {
return addType();
} else if (name.equals("date")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.date");
} else if (name.equals("procedureCodeableConcept")) {
this.procedure = new CodeableConcept();
return this.procedure;
} else if (name.equals("procedureReference")) {
this.procedure = new Reference();
return this.procedure;
} else if (name.equals("udi")) {
return addUdi();
} else
return super.addChild(name);
}
public ProcedureComponent copy() {
ProcedureComponent dst = new ProcedureComponent();
copyValues(dst);
return dst;
}
public void copyValues(ProcedureComponent dst) {
super.copyValues(dst);
dst.sequence = sequence == null ? null : sequence.copy();
if (type != null) {
dst.type = new ArrayList();
for (CodeableConcept i : type)
dst.type.add(i.copy());
}
;
dst.date = date == null ? null : date.copy();
dst.procedure = procedure == null ? null : procedure.copy();
if (udi != null) {
dst.udi = new ArrayList();
for (Reference i : udi)
dst.udi.add(i.copy());
}
;
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof ProcedureComponent))
return false;
ProcedureComponent o = (ProcedureComponent) other_;
return compareDeep(sequence, o.sequence, true) && compareDeep(type, o.type, true)
&& compareDeep(date, o.date, true) && compareDeep(procedure, o.procedure, true)
&& compareDeep(udi, o.udi, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof ProcedureComponent))
return false;
ProcedureComponent o = (ProcedureComponent) other_;
return compareValues(sequence, o.sequence, true) && compareValues(date, o.date, true);
}
public boolean isEmpty() {
return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, type, date, procedure, udi);
}
public String fhirType() {
return "ExplanationOfBenefit.procedure";
}
}
@Block()
public static class InsuranceComponent extends BackboneElement implements IBaseBackboneElement {
/**
* A flag to indicate that this Coverage is to be used for adjudication of this
* claim when set to true.
*/
@Child(name = "focal", type = { BooleanType.class }, order = 1, min = 1, max = 1, modifier = false, summary = true)
@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.")
protected BooleanType focal;
/**
* 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.
*/
@Child(name = "coverage", type = { Coverage.class }, order = 2, min = 1, max = 1, modifier = false, summary = true)
@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.")
protected Reference coverage;
/**
* The actual object that is the target of the reference (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.)
*/
protected Coverage coverageTarget;
/**
* 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.
*/
@Child(name = "preAuthRef", type = {
StringType.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@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.")
protected List preAuthRef;
private static final long serialVersionUID = -606383626L;
/**
* Constructor
*/
public InsuranceComponent() {
super();
}
/**
* Constructor
*/
public InsuranceComponent(BooleanType focal, Reference coverage) {
super();
this.focal = focal;
this.coverage = coverage;
}
/**
* @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
*/
public BooleanType getFocalElement() {
if (this.focal == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create InsuranceComponent.focal");
else if (Configuration.doAutoCreate())
this.focal = new BooleanType(); // bb
return this.focal;
}
public boolean hasFocalElement() {
return this.focal != null && !this.focal.isEmpty();
}
public boolean hasFocal() {
return this.focal != null && !this.focal.isEmpty();
}
/**
* @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
*/
public InsuranceComponent setFocalElement(BooleanType value) {
this.focal = value;
return this;
}
/**
* @return A flag to indicate that this Coverage is to be used for adjudication
* of this claim when set to true.
*/
public boolean getFocal() {
return this.focal == null || this.focal.isEmpty() ? false : this.focal.getValue();
}
/**
* @param value A flag to indicate that this Coverage is to be used for
* adjudication of this claim when set to true.
*/
public InsuranceComponent setFocal(boolean value) {
if (this.focal == null)
this.focal = new BooleanType();
this.focal.setValue(value);
return this;
}
/**
* @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.)
*/
public Reference getCoverage() {
if (this.coverage == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create InsuranceComponent.coverage");
else if (Configuration.doAutoCreate())
this.coverage = new Reference(); // cc
return this.coverage;
}
public boolean hasCoverage() {
return this.coverage != null && !this.coverage.isEmpty();
}
/**
* @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.)
*/
public InsuranceComponent setCoverage(Reference value) {
this.coverage = value;
return this;
}
/**
* @return {@link #coverage} The actual object that is the target of the
* reference. The reference library doesn't populate this, but you can
* use it to hold the resource if you resolve it. (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.)
*/
public Coverage getCoverageTarget() {
if (this.coverageTarget == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create InsuranceComponent.coverage");
else if (Configuration.doAutoCreate())
this.coverageTarget = new Coverage(); // aa
return this.coverageTarget;
}
/**
* @param value {@link #coverage} The actual object that is the target of the
* reference. The reference library doesn't use these, but you can
* use it to hold the resource if you resolve it. (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.)
*/
public InsuranceComponent setCoverageTarget(Coverage value) {
this.coverageTarget = value;
return this;
}
/**
* @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.)
*/
public List getPreAuthRef() {
if (this.preAuthRef == null)
this.preAuthRef = new ArrayList();
return this.preAuthRef;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public InsuranceComponent setPreAuthRef(List thePreAuthRef) {
this.preAuthRef = thePreAuthRef;
return this;
}
public boolean hasPreAuthRef() {
if (this.preAuthRef == null)
return false;
for (StringType item : this.preAuthRef)
if (!item.isEmpty())
return true;
return false;
}
/**
* @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.)
*/
public StringType addPreAuthRefElement() {// 2
StringType t = new StringType();
if (this.preAuthRef == null)
this.preAuthRef = new ArrayList();
this.preAuthRef.add(t);
return t;
}
/**
* @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.)
*/
public InsuranceComponent addPreAuthRef(String value) { // 1
StringType t = new StringType();
t.setValue(value);
if (this.preAuthRef == null)
this.preAuthRef = new ArrayList();
this.preAuthRef.add(t);
return this;
}
/**
* @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.)
*/
public boolean hasPreAuthRef(String value) {
if (this.preAuthRef == null)
return false;
for (StringType v : this.preAuthRef)
if (v.getValue().equals(value)) // string
return true;
return false;
}
protected void listChildren(List children) {
super.listChildren(children);
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));
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));
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));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
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);
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);
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);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 97604197:
/* focal */ return this.focal == null ? new Base[0] : new Base[] { this.focal }; // BooleanType
case -351767064:
/* coverage */ return this.coverage == null ? new Base[0] : new Base[] { this.coverage }; // Reference
case 522246568:
/* preAuthRef */ return this.preAuthRef == null ? new Base[0]
: this.preAuthRef.toArray(new Base[this.preAuthRef.size()]); // StringType
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 97604197: // focal
this.focal = castToBoolean(value); // BooleanType
return value;
case -351767064: // coverage
this.coverage = castToReference(value); // Reference
return value;
case 522246568: // preAuthRef
this.getPreAuthRef().add(castToString(value)); // StringType
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("focal")) {
this.focal = castToBoolean(value); // BooleanType
} else if (name.equals("coverage")) {
this.coverage = castToReference(value); // Reference
} else if (name.equals("preAuthRef")) {
this.getPreAuthRef().add(castToString(value));
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("focal")) {
this.focal = null;
} else if (name.equals("coverage")) {
this.coverage = null;
} else if (name.equals("preAuthRef")) {
this.getPreAuthRef().remove(castToString(value));
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 97604197:
return getFocalElement();
case -351767064:
return getCoverage();
case 522246568:
return addPreAuthRefElement();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 97604197:
/* focal */ return new String[] { "boolean" };
case -351767064:
/* coverage */ return new String[] { "Reference" };
case 522246568:
/* preAuthRef */ return new String[] { "string" };
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("focal")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.focal");
} else if (name.equals("coverage")) {
this.coverage = new Reference();
return this.coverage;
} else if (name.equals("preAuthRef")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.preAuthRef");
} else
return super.addChild(name);
}
public InsuranceComponent copy() {
InsuranceComponent dst = new InsuranceComponent();
copyValues(dst);
return dst;
}
public void copyValues(InsuranceComponent dst) {
super.copyValues(dst);
dst.focal = focal == null ? null : focal.copy();
dst.coverage = coverage == null ? null : coverage.copy();
if (preAuthRef != null) {
dst.preAuthRef = new ArrayList();
for (StringType i : preAuthRef)
dst.preAuthRef.add(i.copy());
}
;
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof InsuranceComponent))
return false;
InsuranceComponent o = (InsuranceComponent) other_;
return compareDeep(focal, o.focal, true) && compareDeep(coverage, o.coverage, true)
&& compareDeep(preAuthRef, o.preAuthRef, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof InsuranceComponent))
return false;
InsuranceComponent o = (InsuranceComponent) other_;
return compareValues(focal, o.focal, true) && compareValues(preAuthRef, o.preAuthRef, true);
}
public boolean isEmpty() {
return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(focal, coverage, preAuthRef);
}
public String fhirType() {
return "ExplanationOfBenefit.insurance";
}
}
@Block()
public static class AccidentComponent extends BackboneElement implements IBaseBackboneElement {
/**
* Date of an accident event related to the products and services contained in
* the claim.
*/
@Child(name = "date", type = { DateType.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "When the incident occurred", formalDefinition = "Date of an accident event related to the products and services contained in the claim.")
protected DateType date;
/**
* The type or context of the accident event for the purposes of selection of
* potential insurance coverages and determination of coordination between
* insurers.
*/
@Child(name = "type", type = {
CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
@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.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://terminology.hl7.org/ValueSet/v3-ActIncidentCode")
protected CodeableConcept type;
/**
* The physical location of the accident event.
*/
@Child(name = "location", type = { Address.class,
Location.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Where the event occurred", formalDefinition = "The physical location of the accident event.")
protected Type location;
private static final long serialVersionUID = 622904984L;
/**
* Constructor
*/
public AccidentComponent() {
super();
}
/**
* @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
*/
public DateType getDateElement() {
if (this.date == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create AccidentComponent.date");
else if (Configuration.doAutoCreate())
this.date = new DateType(); // bb
return this.date;
}
public boolean hasDateElement() {
return this.date != null && !this.date.isEmpty();
}
public boolean hasDate() {
return this.date != null && !this.date.isEmpty();
}
/**
* @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
*/
public AccidentComponent setDateElement(DateType value) {
this.date = value;
return this;
}
/**
* @return Date of an accident event related to the products and services
* contained in the claim.
*/
public Date getDate() {
return this.date == null ? null : this.date.getValue();
}
/**
* @param value Date of an accident event related to the products and services
* contained in the claim.
*/
public AccidentComponent setDate(Date value) {
if (value == null)
this.date = null;
else {
if (this.date == null)
this.date = new DateType();
this.date.setValue(value);
}
return this;
}
/**
* @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.)
*/
public CodeableConcept getType() {
if (this.type == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create AccidentComponent.type");
else if (Configuration.doAutoCreate())
this.type = new CodeableConcept(); // cc
return this.type;
}
public boolean hasType() {
return this.type != null && !this.type.isEmpty();
}
/**
* @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.)
*/
public AccidentComponent setType(CodeableConcept value) {
this.type = value;
return this;
}
/**
* @return {@link #location} (The physical location of the accident event.)
*/
public Type getLocation() {
return this.location;
}
/**
* @return {@link #location} (The physical location of the accident event.)
*/
public Address getLocationAddress() throws FHIRException {
if (this.location == null)
this.location = new Address();
if (!(this.location instanceof Address))
throw new FHIRException("Type mismatch: the type Address was expected, but "
+ this.location.getClass().getName() + " was encountered");
return (Address) this.location;
}
public boolean hasLocationAddress() {
return this != null && this.location instanceof Address;
}
/**
* @return {@link #location} (The physical location of the accident event.)
*/
public Reference getLocationReference() throws FHIRException {
if (this.location == null)
this.location = new Reference();
if (!(this.location instanceof Reference))
throw new FHIRException("Type mismatch: the type Reference was expected, but "
+ this.location.getClass().getName() + " was encountered");
return (Reference) this.location;
}
public boolean hasLocationReference() {
return this != null && this.location instanceof Reference;
}
public boolean hasLocation() {
return this.location != null && !this.location.isEmpty();
}
/**
* @param value {@link #location} (The physical location of the accident event.)
*/
public AccidentComponent setLocation(Type value) {
if (value != null && !(value instanceof Address || value instanceof Reference))
throw new Error("Not the right type for ExplanationOfBenefit.accident.location[x]: " + value.fhirType());
this.location = value;
return this;
}
protected void listChildren(List children) {
super.listChildren(children);
children.add(new Property("date", "date",
"Date of an accident event related to the products and services contained in the claim.", 0, 1, date));
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));
children.add(new Property("location[x]", "Address|Reference(Location)",
"The physical location of the accident event.", 0, 1, location));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
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);
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);
case 552316075:
/* location[x] */ return new Property("location[x]", "Address|Reference(Location)",
"The physical location of the accident event.", 0, 1, location);
case 1901043637:
/* location */ return new Property("location[x]", "Address|Reference(Location)",
"The physical location of the accident event.", 0, 1, location);
case -1280020865:
/* locationAddress */ return new Property("location[x]", "Address|Reference(Location)",
"The physical location of the accident event.", 0, 1, location);
case 755866390:
/* locationReference */ return new Property("location[x]", "Address|Reference(Location)",
"The physical location of the accident event.", 0, 1, location);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 3076014:
/* date */ return this.date == null ? new Base[0] : new Base[] { this.date }; // DateType
case 3575610:
/* type */ return this.type == null ? new Base[0] : new Base[] { this.type }; // CodeableConcept
case 1901043637:
/* location */ return this.location == null ? new Base[0] : new Base[] { this.location }; // Type
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 3076014: // date
this.date = castToDate(value); // DateType
return value;
case 3575610: // type
this.type = castToCodeableConcept(value); // CodeableConcept
return value;
case 1901043637: // location
this.location = castToType(value); // Type
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("date")) {
this.date = castToDate(value); // DateType
} else if (name.equals("type")) {
this.type = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("location[x]")) {
this.location = castToType(value); // Type
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("date")) {
this.date = null;
} else if (name.equals("type")) {
this.type = null;
} else if (name.equals("location[x]")) {
this.location = null;
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 3076014:
return getDateElement();
case 3575610:
return getType();
case 552316075:
return getLocation();
case 1901043637:
return getLocation();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 3076014:
/* date */ return new String[] { "date" };
case 3575610:
/* type */ return new String[] { "CodeableConcept" };
case 1901043637:
/* location */ return new String[] { "Address", "Reference" };
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("date")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.date");
} else if (name.equals("type")) {
this.type = new CodeableConcept();
return this.type;
} else if (name.equals("locationAddress")) {
this.location = new Address();
return this.location;
} else if (name.equals("locationReference")) {
this.location = new Reference();
return this.location;
} else
return super.addChild(name);
}
public AccidentComponent copy() {
AccidentComponent dst = new AccidentComponent();
copyValues(dst);
return dst;
}
public void copyValues(AccidentComponent dst) {
super.copyValues(dst);
dst.date = date == null ? null : date.copy();
dst.type = type == null ? null : type.copy();
dst.location = location == null ? null : location.copy();
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof AccidentComponent))
return false;
AccidentComponent o = (AccidentComponent) other_;
return compareDeep(date, o.date, true) && compareDeep(type, o.type, true)
&& compareDeep(location, o.location, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof AccidentComponent))
return false;
AccidentComponent o = (AccidentComponent) other_;
return compareValues(date, o.date, true);
}
public boolean isEmpty() {
return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(date, type, location);
}
public String fhirType() {
return "ExplanationOfBenefit.accident";
}
}
@Block()
public static class ItemComponent extends BackboneElement implements IBaseBackboneElement {
/**
* A number to uniquely identify item entries.
*/
@Child(name = "sequence", type = {
PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Item instance identifier", formalDefinition = "A number to uniquely identify item entries.")
protected PositiveIntType sequence;
/**
* Care team members related to this service or product.
*/
@Child(name = "careTeamSequence", type = {
PositiveIntType.class }, order = 2, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Applicable care team members", formalDefinition = "Care team members related to this service or product.")
protected List careTeamSequence;
/**
* Diagnoses applicable for this service or product.
*/
@Child(name = "diagnosisSequence", type = {
PositiveIntType.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Applicable diagnoses", formalDefinition = "Diagnoses applicable for this service or product.")
protected List diagnosisSequence;
/**
* Procedures applicable for this service or product.
*/
@Child(name = "procedureSequence", type = {
PositiveIntType.class }, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Applicable procedures", formalDefinition = "Procedures applicable for this service or product.")
protected List procedureSequence;
/**
* Exceptions, special conditions and supporting information applicable for this
* service or product.
*/
@Child(name = "informationSequence", type = {
PositiveIntType.class }, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Applicable exception and supporting information", formalDefinition = "Exceptions, special conditions and supporting information applicable for this service or product.")
protected List informationSequence;
/**
* The type of revenue or cost center providing the product and/or service.
*/
@Child(name = "revenue", type = {
CodeableConcept.class }, order = 6, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Revenue or cost center code", formalDefinition = "The type of revenue or cost center providing the product and/or service.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-revenue-center")
protected CodeableConcept revenue;
/**
* Code to identify the general type of benefits under which products and
* services are provided.
*/
@Child(name = "category", type = {
CodeableConcept.class }, order = 7, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Benefit classification", formalDefinition = "Code to identify the general type of benefits under which products and services are provided.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-benefitcategory")
protected CodeableConcept category;
/**
* When the value is a group code then this item collects a set of related claim
* details, otherwise this contains the product, service, drug or other billing
* code for the item.
*/
@Child(name = "productOrService", type = {
CodeableConcept.class }, order = 8, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Billing, service, product, or drug code", formalDefinition = "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-uscls")
protected CodeableConcept productOrService;
/**
* Item typification or modifiers codes to convey additional context for the
* product or service.
*/
@Child(name = "modifier", type = {
CodeableConcept.class }, order = 9, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Product or service billing modifiers", formalDefinition = "Item typification or modifiers codes to convey additional context for the product or service.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-modifiers")
protected List modifier;
/**
* Identifies the program under which this may be recovered.
*/
@Child(name = "programCode", type = {
CodeableConcept.class }, order = 10, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Program the product or service is provided under", formalDefinition = "Identifies the program under which this may be recovered.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-program-code")
protected List programCode;
/**
* The date or dates when the service or product was supplied, performed or
* completed.
*/
@Child(name = "serviced", type = { DateType.class,
Period.class }, order = 11, min = 0, max = 1, modifier = false, summary = false)
@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.")
protected Type serviced;
/**
* Where the product or service was provided.
*/
@Child(name = "location", type = { CodeableConcept.class, Address.class,
Location.class }, order = 12, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Place of service or where product was supplied", formalDefinition = "Where the product or service was provided.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-place")
protected Type location;
/**
* The number of repetitions of a service or product.
*/
@Child(name = "quantity", type = {
Quantity.class }, order = 13, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Count of products or services", formalDefinition = "The number of repetitions of a service or product.")
protected Quantity quantity;
/**
* 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.
*/
@Child(name = "unitPrice", type = { Money.class }, order = 14, min = 0, max = 1, modifier = false, summary = false)
@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.")
protected Money unitPrice;
/**
* 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.
*/
@Child(name = "factor", type = {
DecimalType.class }, order = 15, min = 0, max = 1, modifier = false, summary = false)
@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.")
protected DecimalType factor;
/**
* The quantity times the unit price for an additional service or product or
* charge.
*/
@Child(name = "net", type = { Money.class }, order = 16, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Total item cost", formalDefinition = "The quantity times the unit price for an additional service or product or charge.")
protected Money net;
/**
* Unique Device Identifiers associated with this line item.
*/
@Child(name = "udi", type = {
Device.class }, order = 17, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Unique device identifier", formalDefinition = "Unique Device Identifiers associated with this line item.")
protected List udi;
/**
* The actual objects that are the target of the reference (Unique Device
* Identifiers associated with this line item.)
*/
protected List udiTarget;
/**
* Physical service site on the patient (limb, tooth, etc.).
*/
@Child(name = "bodySite", type = {
CodeableConcept.class }, order = 18, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Anatomical location", formalDefinition = "Physical service site on the patient (limb, tooth, etc.).")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/tooth")
protected CodeableConcept bodySite;
/**
* A region or surface of the bodySite, e.g. limb region or tooth surface(s).
*/
@Child(name = "subSite", type = {
CodeableConcept.class }, order = 19, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Anatomical sub-location", formalDefinition = "A region or surface of the bodySite, e.g. limb region or tooth surface(s).")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/surface")
protected List subSite;
/**
* A billed item may include goods or services provided in multiple encounters.
*/
@Child(name = "encounter", type = {
Encounter.class }, order = 20, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Encounters related to this billed item", formalDefinition = "A billed item may include goods or services provided in multiple encounters.")
protected List encounter;
/**
* The actual objects that are the target of the reference (A billed item may
* include goods or services provided in multiple encounters.)
*/
protected List encounterTarget;
/**
* The numbers associated with notes below which apply to the adjudication of
* this item.
*/
@Child(name = "noteNumber", type = {
PositiveIntType.class }, order = 21, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Applicable note numbers", formalDefinition = "The numbers associated with notes below which apply to the adjudication of this item.")
protected List noteNumber;
/**
* If this item is a group then the values here are a summary of the
* adjudication of the detail items. If this item is a simple product or service
* then this is the result of the adjudication of this item.
*/
@Child(name = "adjudication", type = {}, order = 22, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Adjudication details", formalDefinition = "If this item is a group then the values here are a summary of the adjudication of the detail items. If this item is a simple product or service then this is the result of the adjudication of this item.")
protected List adjudication;
/**
* Second-tier of goods and services.
*/
@Child(name = "detail", type = {}, order = 23, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Additional items", formalDefinition = "Second-tier of goods and services.")
protected List detail;
private static final long serialVersionUID = 67419471L;
/**
* Constructor
*/
public ItemComponent() {
super();
}
/**
* Constructor
*/
public ItemComponent(PositiveIntType sequence, CodeableConcept productOrService) {
super();
this.sequence = sequence;
this.productOrService = productOrService;
}
/**
* @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
*/
public PositiveIntType getSequenceElement() {
if (this.sequence == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ItemComponent.sequence");
else if (Configuration.doAutoCreate())
this.sequence = new PositiveIntType(); // bb
return this.sequence;
}
public boolean hasSequenceElement() {
return this.sequence != null && !this.sequence.isEmpty();
}
public boolean hasSequence() {
return this.sequence != null && !this.sequence.isEmpty();
}
/**
* @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
*/
public ItemComponent setSequenceElement(PositiveIntType value) {
this.sequence = value;
return this;
}
/**
* @return A number to uniquely identify item entries.
*/
public int getSequence() {
return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
}
/**
* @param value A number to uniquely identify item entries.
*/
public ItemComponent setSequence(int value) {
if (this.sequence == null)
this.sequence = new PositiveIntType();
this.sequence.setValue(value);
return this;
}
/**
* @return {@link #careTeamSequence} (Care team members related to this service
* or product.)
*/
public List getCareTeamSequence() {
if (this.careTeamSequence == null)
this.careTeamSequence = new ArrayList();
return this.careTeamSequence;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setCareTeamSequence(List theCareTeamSequence) {
this.careTeamSequence = theCareTeamSequence;
return this;
}
public boolean hasCareTeamSequence() {
if (this.careTeamSequence == null)
return false;
for (PositiveIntType item : this.careTeamSequence)
if (!item.isEmpty())
return true;
return false;
}
/**
* @return {@link #careTeamSequence} (Care team members related to this service
* or product.)
*/
public PositiveIntType addCareTeamSequenceElement() {// 2
PositiveIntType t = new PositiveIntType();
if (this.careTeamSequence == null)
this.careTeamSequence = new ArrayList();
this.careTeamSequence.add(t);
return t;
}
/**
* @param value {@link #careTeamSequence} (Care team members related to this
* service or product.)
*/
public ItemComponent addCareTeamSequence(int value) { // 1
PositiveIntType t = new PositiveIntType();
t.setValue(value);
if (this.careTeamSequence == null)
this.careTeamSequence = new ArrayList();
this.careTeamSequence.add(t);
return this;
}
/**
* @param value {@link #careTeamSequence} (Care team members related to this
* service or product.)
*/
public boolean hasCareTeamSequence(int value) {
if (this.careTeamSequence == null)
return false;
for (PositiveIntType v : this.careTeamSequence)
if (v.getValue().equals(value)) // positiveInt
return true;
return false;
}
/**
* @return {@link #diagnosisSequence} (Diagnoses applicable for this service or
* product.)
*/
public List getDiagnosisSequence() {
if (this.diagnosisSequence == null)
this.diagnosisSequence = new ArrayList();
return this.diagnosisSequence;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setDiagnosisSequence(List theDiagnosisSequence) {
this.diagnosisSequence = theDiagnosisSequence;
return this;
}
public boolean hasDiagnosisSequence() {
if (this.diagnosisSequence == null)
return false;
for (PositiveIntType item : this.diagnosisSequence)
if (!item.isEmpty())
return true;
return false;
}
/**
* @return {@link #diagnosisSequence} (Diagnoses applicable for this service or
* product.)
*/
public PositiveIntType addDiagnosisSequenceElement() {// 2
PositiveIntType t = new PositiveIntType();
if (this.diagnosisSequence == null)
this.diagnosisSequence = new ArrayList();
this.diagnosisSequence.add(t);
return t;
}
/**
* @param value {@link #diagnosisSequence} (Diagnoses applicable for this
* service or product.)
*/
public ItemComponent addDiagnosisSequence(int value) { // 1
PositiveIntType t = new PositiveIntType();
t.setValue(value);
if (this.diagnosisSequence == null)
this.diagnosisSequence = new ArrayList();
this.diagnosisSequence.add(t);
return this;
}
/**
* @param value {@link #diagnosisSequence} (Diagnoses applicable for this
* service or product.)
*/
public boolean hasDiagnosisSequence(int value) {
if (this.diagnosisSequence == null)
return false;
for (PositiveIntType v : this.diagnosisSequence)
if (v.getValue().equals(value)) // positiveInt
return true;
return false;
}
/**
* @return {@link #procedureSequence} (Procedures applicable for this service or
* product.)
*/
public List getProcedureSequence() {
if (this.procedureSequence == null)
this.procedureSequence = new ArrayList();
return this.procedureSequence;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setProcedureSequence(List theProcedureSequence) {
this.procedureSequence = theProcedureSequence;
return this;
}
public boolean hasProcedureSequence() {
if (this.procedureSequence == null)
return false;
for (PositiveIntType item : this.procedureSequence)
if (!item.isEmpty())
return true;
return false;
}
/**
* @return {@link #procedureSequence} (Procedures applicable for this service or
* product.)
*/
public PositiveIntType addProcedureSequenceElement() {// 2
PositiveIntType t = new PositiveIntType();
if (this.procedureSequence == null)
this.procedureSequence = new ArrayList();
this.procedureSequence.add(t);
return t;
}
/**
* @param value {@link #procedureSequence} (Procedures applicable for this
* service or product.)
*/
public ItemComponent addProcedureSequence(int value) { // 1
PositiveIntType t = new PositiveIntType();
t.setValue(value);
if (this.procedureSequence == null)
this.procedureSequence = new ArrayList();
this.procedureSequence.add(t);
return this;
}
/**
* @param value {@link #procedureSequence} (Procedures applicable for this
* service or product.)
*/
public boolean hasProcedureSequence(int value) {
if (this.procedureSequence == null)
return false;
for (PositiveIntType v : this.procedureSequence)
if (v.getValue().equals(value)) // positiveInt
return true;
return false;
}
/**
* @return {@link #informationSequence} (Exceptions, special conditions and
* supporting information applicable for this service or product.)
*/
public List getInformationSequence() {
if (this.informationSequence == null)
this.informationSequence = new ArrayList();
return this.informationSequence;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setInformationSequence(List theInformationSequence) {
this.informationSequence = theInformationSequence;
return this;
}
public boolean hasInformationSequence() {
if (this.informationSequence == null)
return false;
for (PositiveIntType item : this.informationSequence)
if (!item.isEmpty())
return true;
return false;
}
/**
* @return {@link #informationSequence} (Exceptions, special conditions and
* supporting information applicable for this service or product.)
*/
public PositiveIntType addInformationSequenceElement() {// 2
PositiveIntType t = new PositiveIntType();
if (this.informationSequence == null)
this.informationSequence = new ArrayList();
this.informationSequence.add(t);
return t;
}
/**
* @param value {@link #informationSequence} (Exceptions, special conditions and
* supporting information applicable for this service or product.)
*/
public ItemComponent addInformationSequence(int value) { // 1
PositiveIntType t = new PositiveIntType();
t.setValue(value);
if (this.informationSequence == null)
this.informationSequence = new ArrayList();
this.informationSequence.add(t);
return this;
}
/**
* @param value {@link #informationSequence} (Exceptions, special conditions and
* supporting information applicable for this service or product.)
*/
public boolean hasInformationSequence(int value) {
if (this.informationSequence == null)
return false;
for (PositiveIntType v : this.informationSequence)
if (v.getValue().equals(value)) // positiveInt
return true;
return false;
}
/**
* @return {@link #revenue} (The type of revenue or cost center providing the
* product and/or service.)
*/
public CodeableConcept getRevenue() {
if (this.revenue == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ItemComponent.revenue");
else if (Configuration.doAutoCreate())
this.revenue = new CodeableConcept(); // cc
return this.revenue;
}
public boolean hasRevenue() {
return this.revenue != null && !this.revenue.isEmpty();
}
/**
* @param value {@link #revenue} (The type of revenue or cost center providing
* the product and/or service.)
*/
public ItemComponent setRevenue(CodeableConcept value) {
this.revenue = value;
return this;
}
/**
* @return {@link #category} (Code to identify the general type of benefits
* under which products and services are provided.)
*/
public CodeableConcept getCategory() {
if (this.category == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ItemComponent.category");
else if (Configuration.doAutoCreate())
this.category = new CodeableConcept(); // cc
return this.category;
}
public boolean hasCategory() {
return this.category != null && !this.category.isEmpty();
}
/**
* @param value {@link #category} (Code to identify the general type of benefits
* under which products and services are provided.)
*/
public ItemComponent setCategory(CodeableConcept value) {
this.category = value;
return this;
}
/**
* @return {@link #productOrService} (When the value is a group code then this
* item collects a set of related claim details, otherwise this contains
* the product, service, drug or other billing code for the item.)
*/
public CodeableConcept getProductOrService() {
if (this.productOrService == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ItemComponent.productOrService");
else if (Configuration.doAutoCreate())
this.productOrService = new CodeableConcept(); // cc
return this.productOrService;
}
public boolean hasProductOrService() {
return this.productOrService != null && !this.productOrService.isEmpty();
}
/**
* @param value {@link #productOrService} (When the value is a group code then
* this item collects a set of related claim details, otherwise
* this contains the product, service, drug or other billing code
* for the item.)
*/
public ItemComponent setProductOrService(CodeableConcept value) {
this.productOrService = value;
return this;
}
/**
* @return {@link #modifier} (Item typification or modifiers codes to convey
* additional context for the product or service.)
*/
public List getModifier() {
if (this.modifier == null)
this.modifier = new ArrayList();
return this.modifier;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setModifier(List theModifier) {
this.modifier = theModifier;
return this;
}
public boolean hasModifier() {
if (this.modifier == null)
return false;
for (CodeableConcept item : this.modifier)
if (!item.isEmpty())
return true;
return false;
}
public CodeableConcept addModifier() { // 3
CodeableConcept t = new CodeableConcept();
if (this.modifier == null)
this.modifier = new ArrayList();
this.modifier.add(t);
return t;
}
public ItemComponent addModifier(CodeableConcept t) { // 3
if (t == null)
return this;
if (this.modifier == null)
this.modifier = new ArrayList();
this.modifier.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #modifier}, creating
* it if it does not already exist
*/
public CodeableConcept getModifierFirstRep() {
if (getModifier().isEmpty()) {
addModifier();
}
return getModifier().get(0);
}
/**
* @return {@link #programCode} (Identifies the program under which this may be
* recovered.)
*/
public List getProgramCode() {
if (this.programCode == null)
this.programCode = new ArrayList();
return this.programCode;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setProgramCode(List theProgramCode) {
this.programCode = theProgramCode;
return this;
}
public boolean hasProgramCode() {
if (this.programCode == null)
return false;
for (CodeableConcept item : this.programCode)
if (!item.isEmpty())
return true;
return false;
}
public CodeableConcept addProgramCode() { // 3
CodeableConcept t = new CodeableConcept();
if (this.programCode == null)
this.programCode = new ArrayList();
this.programCode.add(t);
return t;
}
public ItemComponent addProgramCode(CodeableConcept t) { // 3
if (t == null)
return this;
if (this.programCode == null)
this.programCode = new ArrayList();
this.programCode.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #programCode},
* creating it if it does not already exist
*/
public CodeableConcept getProgramCodeFirstRep() {
if (getProgramCode().isEmpty()) {
addProgramCode();
}
return getProgramCode().get(0);
}
/**
* @return {@link #serviced} (The date or dates when the service or product was
* supplied, performed or completed.)
*/
public Type getServiced() {
return this.serviced;
}
/**
* @return {@link #serviced} (The date or dates when the service or product was
* supplied, performed or completed.)
*/
public DateType getServicedDateType() throws FHIRException {
if (this.serviced == null)
this.serviced = new DateType();
if (!(this.serviced instanceof DateType))
throw new FHIRException("Type mismatch: the type DateType was expected, but "
+ this.serviced.getClass().getName() + " was encountered");
return (DateType) this.serviced;
}
public boolean hasServicedDateType() {
return this != null && this.serviced instanceof DateType;
}
/**
* @return {@link #serviced} (The date or dates when the service or product was
* supplied, performed or completed.)
*/
public Period getServicedPeriod() throws FHIRException {
if (this.serviced == null)
this.serviced = new Period();
if (!(this.serviced instanceof Period))
throw new FHIRException("Type mismatch: the type Period was expected, but " + this.serviced.getClass().getName()
+ " was encountered");
return (Period) this.serviced;
}
public boolean hasServicedPeriod() {
return this != null && this.serviced instanceof Period;
}
public boolean hasServiced() {
return this.serviced != null && !this.serviced.isEmpty();
}
/**
* @param value {@link #serviced} (The date or dates when the service or product
* was supplied, performed or completed.)
*/
public ItemComponent setServiced(Type value) {
if (value != null && !(value instanceof DateType || value instanceof Period))
throw new Error("Not the right type for ExplanationOfBenefit.item.serviced[x]: " + value.fhirType());
this.serviced = value;
return this;
}
/**
* @return {@link #location} (Where the product or service was provided.)
*/
public Type getLocation() {
return this.location;
}
/**
* @return {@link #location} (Where the product or service was provided.)
*/
public CodeableConcept getLocationCodeableConcept() throws FHIRException {
if (this.location == null)
this.location = new CodeableConcept();
if (!(this.location instanceof CodeableConcept))
throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "
+ this.location.getClass().getName() + " was encountered");
return (CodeableConcept) this.location;
}
public boolean hasLocationCodeableConcept() {
return this != null && this.location instanceof CodeableConcept;
}
/**
* @return {@link #location} (Where the product or service was provided.)
*/
public Address getLocationAddress() throws FHIRException {
if (this.location == null)
this.location = new Address();
if (!(this.location instanceof Address))
throw new FHIRException("Type mismatch: the type Address was expected, but "
+ this.location.getClass().getName() + " was encountered");
return (Address) this.location;
}
public boolean hasLocationAddress() {
return this != null && this.location instanceof Address;
}
/**
* @return {@link #location} (Where the product or service was provided.)
*/
public Reference getLocationReference() throws FHIRException {
if (this.location == null)
this.location = new Reference();
if (!(this.location instanceof Reference))
throw new FHIRException("Type mismatch: the type Reference was expected, but "
+ this.location.getClass().getName() + " was encountered");
return (Reference) this.location;
}
public boolean hasLocationReference() {
return this != null && this.location instanceof Reference;
}
public boolean hasLocation() {
return this.location != null && !this.location.isEmpty();
}
/**
* @param value {@link #location} (Where the product or service was provided.)
*/
public ItemComponent setLocation(Type value) {
if (value != null
&& !(value instanceof CodeableConcept || value instanceof Address || value instanceof Reference))
throw new Error("Not the right type for ExplanationOfBenefit.item.location[x]: " + value.fhirType());
this.location = value;
return this;
}
/**
* @return {@link #quantity} (The number of repetitions of a service or
* product.)
*/
public Quantity getQuantity() {
if (this.quantity == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ItemComponent.quantity");
else if (Configuration.doAutoCreate())
this.quantity = new Quantity(); // cc
return this.quantity;
}
public boolean hasQuantity() {
return this.quantity != null && !this.quantity.isEmpty();
}
/**
* @param value {@link #quantity} (The number of repetitions of a service or
* product.)
*/
public ItemComponent setQuantity(Quantity value) {
this.quantity = value;
return this;
}
/**
* @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.)
*/
public Money getUnitPrice() {
if (this.unitPrice == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ItemComponent.unitPrice");
else if (Configuration.doAutoCreate())
this.unitPrice = new Money(); // cc
return this.unitPrice;
}
public boolean hasUnitPrice() {
return this.unitPrice != null && !this.unitPrice.isEmpty();
}
/**
* @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.)
*/
public ItemComponent setUnitPrice(Money value) {
this.unitPrice = value;
return this;
}
/**
* @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
*/
public DecimalType getFactorElement() {
if (this.factor == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ItemComponent.factor");
else if (Configuration.doAutoCreate())
this.factor = new DecimalType(); // bb
return this.factor;
}
public boolean hasFactorElement() {
return this.factor != null && !this.factor.isEmpty();
}
public boolean hasFactor() {
return this.factor != null && !this.factor.isEmpty();
}
/**
* @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
*/
public ItemComponent setFactorElement(DecimalType value) {
this.factor = value;
return this;
}
/**
* @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.
*/
public BigDecimal getFactor() {
return this.factor == null ? null : this.factor.getValue();
}
/**
* @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.
*/
public ItemComponent setFactor(BigDecimal value) {
if (value == null)
this.factor = null;
else {
if (this.factor == null)
this.factor = new DecimalType();
this.factor.setValue(value);
}
return this;
}
/**
* @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.
*/
public ItemComponent setFactor(long value) {
this.factor = new DecimalType();
this.factor.setValue(value);
return this;
}
/**
* @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.
*/
public ItemComponent setFactor(double value) {
this.factor = new DecimalType();
this.factor.setValue(value);
return this;
}
/**
* @return {@link #net} (The quantity times the unit price for an additional
* service or product or charge.)
*/
public Money getNet() {
if (this.net == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ItemComponent.net");
else if (Configuration.doAutoCreate())
this.net = new Money(); // cc
return this.net;
}
public boolean hasNet() {
return this.net != null && !this.net.isEmpty();
}
/**
* @param value {@link #net} (The quantity times the unit price for an
* additional service or product or charge.)
*/
public ItemComponent setNet(Money value) {
this.net = value;
return this;
}
/**
* @return {@link #udi} (Unique Device Identifiers associated with this line
* item.)
*/
public List getUdi() {
if (this.udi == null)
this.udi = new ArrayList();
return this.udi;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setUdi(List theUdi) {
this.udi = theUdi;
return this;
}
public boolean hasUdi() {
if (this.udi == null)
return false;
for (Reference item : this.udi)
if (!item.isEmpty())
return true;
return false;
}
public Reference addUdi() { // 3
Reference t = new Reference();
if (this.udi == null)
this.udi = new ArrayList();
this.udi.add(t);
return t;
}
public ItemComponent addUdi(Reference t) { // 3
if (t == null)
return this;
if (this.udi == null)
this.udi = new ArrayList();
this.udi.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #udi}, creating it if
* it does not already exist
*/
public Reference getUdiFirstRep() {
if (getUdi().isEmpty()) {
addUdi();
}
return getUdi().get(0);
}
/**
* @deprecated Use Reference#setResource(IBaseResource) instead
*/
@Deprecated
public List getUdiTarget() {
if (this.udiTarget == null)
this.udiTarget = new ArrayList();
return this.udiTarget;
}
/**
* @deprecated Use Reference#setResource(IBaseResource) instead
*/
@Deprecated
public Device addUdiTarget() {
Device r = new Device();
if (this.udiTarget == null)
this.udiTarget = new ArrayList();
this.udiTarget.add(r);
return r;
}
/**
* @return {@link #bodySite} (Physical service site on the patient (limb, tooth,
* etc.).)
*/
public CodeableConcept getBodySite() {
if (this.bodySite == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create ItemComponent.bodySite");
else if (Configuration.doAutoCreate())
this.bodySite = new CodeableConcept(); // cc
return this.bodySite;
}
public boolean hasBodySite() {
return this.bodySite != null && !this.bodySite.isEmpty();
}
/**
* @param value {@link #bodySite} (Physical service site on the patient (limb,
* tooth, etc.).)
*/
public ItemComponent setBodySite(CodeableConcept value) {
this.bodySite = value;
return this;
}
/**
* @return {@link #subSite} (A region or surface of the bodySite, e.g. limb
* region or tooth surface(s).)
*/
public List getSubSite() {
if (this.subSite == null)
this.subSite = new ArrayList();
return this.subSite;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setSubSite(List theSubSite) {
this.subSite = theSubSite;
return this;
}
public boolean hasSubSite() {
if (this.subSite == null)
return false;
for (CodeableConcept item : this.subSite)
if (!item.isEmpty())
return true;
return false;
}
public CodeableConcept addSubSite() { // 3
CodeableConcept t = new CodeableConcept();
if (this.subSite == null)
this.subSite = new ArrayList();
this.subSite.add(t);
return t;
}
public ItemComponent addSubSite(CodeableConcept t) { // 3
if (t == null)
return this;
if (this.subSite == null)
this.subSite = new ArrayList();
this.subSite.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #subSite}, creating it
* if it does not already exist
*/
public CodeableConcept getSubSiteFirstRep() {
if (getSubSite().isEmpty()) {
addSubSite();
}
return getSubSite().get(0);
}
/**
* @return {@link #encounter} (A billed item may include goods or services
* provided in multiple encounters.)
*/
public List getEncounter() {
if (this.encounter == null)
this.encounter = new ArrayList();
return this.encounter;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setEncounter(List theEncounter) {
this.encounter = theEncounter;
return this;
}
public boolean hasEncounter() {
if (this.encounter == null)
return false;
for (Reference item : this.encounter)
if (!item.isEmpty())
return true;
return false;
}
public Reference addEncounter() { // 3
Reference t = new Reference();
if (this.encounter == null)
this.encounter = new ArrayList();
this.encounter.add(t);
return t;
}
public ItemComponent addEncounter(Reference t) { // 3
if (t == null)
return this;
if (this.encounter == null)
this.encounter = new ArrayList();
this.encounter.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #encounter}, creating
* it if it does not already exist
*/
public Reference getEncounterFirstRep() {
if (getEncounter().isEmpty()) {
addEncounter();
}
return getEncounter().get(0);
}
/**
* @deprecated Use Reference#setResource(IBaseResource) instead
*/
@Deprecated
public List getEncounterTarget() {
if (this.encounterTarget == null)
this.encounterTarget = new ArrayList();
return this.encounterTarget;
}
/**
* @deprecated Use Reference#setResource(IBaseResource) instead
*/
@Deprecated
public Encounter addEncounterTarget() {
Encounter r = new Encounter();
if (this.encounterTarget == null)
this.encounterTarget = new ArrayList();
this.encounterTarget.add(r);
return r;
}
/**
* @return {@link #noteNumber} (The numbers associated with notes below which
* apply to the adjudication of this item.)
*/
public List getNoteNumber() {
if (this.noteNumber == null)
this.noteNumber = new ArrayList();
return this.noteNumber;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setNoteNumber(List theNoteNumber) {
this.noteNumber = theNoteNumber;
return this;
}
public boolean hasNoteNumber() {
if (this.noteNumber == null)
return false;
for (PositiveIntType item : this.noteNumber)
if (!item.isEmpty())
return true;
return false;
}
/**
* @return {@link #noteNumber} (The numbers associated with notes below which
* apply to the adjudication of this item.)
*/
public PositiveIntType addNoteNumberElement() {// 2
PositiveIntType t = new PositiveIntType();
if (this.noteNumber == null)
this.noteNumber = new ArrayList();
this.noteNumber.add(t);
return t;
}
/**
* @param value {@link #noteNumber} (The numbers associated with notes below
* which apply to the adjudication of this item.)
*/
public ItemComponent addNoteNumber(int value) { // 1
PositiveIntType t = new PositiveIntType();
t.setValue(value);
if (this.noteNumber == null)
this.noteNumber = new ArrayList();
this.noteNumber.add(t);
return this;
}
/**
* @param value {@link #noteNumber} (The numbers associated with notes below
* which apply to the adjudication of this item.)
*/
public boolean hasNoteNumber(int value) {
if (this.noteNumber == null)
return false;
for (PositiveIntType v : this.noteNumber)
if (v.getValue().equals(value)) // positiveInt
return true;
return false;
}
/**
* @return {@link #adjudication} (If this item is a group then the values here
* are a summary of the adjudication of the detail items. If this item
* is a simple product or service then this is the result of the
* adjudication of this item.)
*/
public List getAdjudication() {
if (this.adjudication == null)
this.adjudication = new ArrayList();
return this.adjudication;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setAdjudication(List theAdjudication) {
this.adjudication = theAdjudication;
return this;
}
public boolean hasAdjudication() {
if (this.adjudication == null)
return false;
for (AdjudicationComponent item : this.adjudication)
if (!item.isEmpty())
return true;
return false;
}
public AdjudicationComponent addAdjudication() { // 3
AdjudicationComponent t = new AdjudicationComponent();
if (this.adjudication == null)
this.adjudication = new ArrayList();
this.adjudication.add(t);
return t;
}
public ItemComponent addAdjudication(AdjudicationComponent t) { // 3
if (t == null)
return this;
if (this.adjudication == null)
this.adjudication = new ArrayList();
this.adjudication.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #adjudication},
* creating it if it does not already exist
*/
public AdjudicationComponent getAdjudicationFirstRep() {
if (getAdjudication().isEmpty()) {
addAdjudication();
}
return getAdjudication().get(0);
}
/**
* @return {@link #detail} (Second-tier of goods and services.)
*/
public List getDetail() {
if (this.detail == null)
this.detail = new ArrayList();
return this.detail;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public ItemComponent setDetail(List theDetail) {
this.detail = theDetail;
return this;
}
public boolean hasDetail() {
if (this.detail == null)
return false;
for (DetailComponent item : this.detail)
if (!item.isEmpty())
return true;
return false;
}
public DetailComponent addDetail() { // 3
DetailComponent t = new DetailComponent();
if (this.detail == null)
this.detail = new ArrayList();
this.detail.add(t);
return t;
}
public ItemComponent addDetail(DetailComponent t) { // 3
if (t == null)
return this;
if (this.detail == null)
this.detail = new ArrayList();
this.detail.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #detail}, creating it
* if it does not already exist
*/
public DetailComponent getDetailFirstRep() {
if (getDetail().isEmpty()) {
addDetail();
}
return getDetail().get(0);
}
protected void listChildren(List children) {
super.listChildren(children);
children
.add(new Property("sequence", "positiveInt", "A number to uniquely identify item entries.", 0, 1, sequence));
children.add(new Property("careTeamSequence", "positiveInt",
"Care team members related to this service or product.", 0, java.lang.Integer.MAX_VALUE, careTeamSequence));
children.add(new Property("diagnosisSequence", "positiveInt", "Diagnoses applicable for this service or product.",
0, java.lang.Integer.MAX_VALUE, diagnosisSequence));
children.add(new Property("procedureSequence", "positiveInt",
"Procedures applicable for this service or product.", 0, java.lang.Integer.MAX_VALUE, procedureSequence));
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));
children.add(new Property("revenue", "CodeableConcept",
"The type of revenue or cost center providing the product and/or service.", 0, 1, revenue));
children.add(new Property("category", "CodeableConcept",
"Code to identify the general type of benefits under which products and services are provided.", 0, 1,
category));
children.add(new Property("productOrService", "CodeableConcept",
"When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
0, 1, productOrService));
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));
children.add(new Property("programCode", "CodeableConcept",
"Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode));
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));
children.add(new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
"Where the product or service was provided.", 0, 1, location));
children.add(new Property("quantity", "SimpleQuantity", "The number of repetitions of a service or product.", 0,
1, quantity));
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));
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));
children.add(new Property("net", "Money",
"The quantity times the unit price for an additional service or product or charge.", 0, 1, net));
children.add(new Property("udi", "Reference(Device)", "Unique Device Identifiers associated with this line item.",
0, java.lang.Integer.MAX_VALUE, udi));
children.add(new Property("bodySite", "CodeableConcept",
"Physical service site on the patient (limb, tooth, etc.).", 0, 1, bodySite));
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));
children.add(new Property("encounter", "Reference(Encounter)",
"A billed item may include goods or services provided in multiple encounters.", 0,
java.lang.Integer.MAX_VALUE, encounter));
children.add(new Property("noteNumber", "positiveInt",
"The numbers associated with notes below which apply to the adjudication of this item.", 0,
java.lang.Integer.MAX_VALUE, noteNumber));
children.add(new Property("adjudication", "",
"If this item is a group then the values here are a summary of the adjudication of the detail items. If this item is a simple product or service then this is the result of the adjudication of this item.",
0, java.lang.Integer.MAX_VALUE, adjudication));
children.add(
new Property("detail", "", "Second-tier of goods and services.", 0, java.lang.Integer.MAX_VALUE, detail));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
case 1349547969:
/* sequence */ return new Property("sequence", "positiveInt", "A number to uniquely identify item entries.", 0,
1, sequence);
case 1070083823:
/* careTeamSequence */ return new Property("careTeamSequence", "positiveInt",
"Care team members related to this service or product.", 0, java.lang.Integer.MAX_VALUE, careTeamSequence);
case -909769262:
/* diagnosisSequence */ return new Property("diagnosisSequence", "positiveInt",
"Diagnoses applicable for this service or product.", 0, java.lang.Integer.MAX_VALUE, diagnosisSequence);
case -808920140:
/* procedureSequence */ return new Property("procedureSequence", "positiveInt",
"Procedures applicable for this service or product.", 0, java.lang.Integer.MAX_VALUE, procedureSequence);
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);
case 1099842588:
/* revenue */ return new Property("revenue", "CodeableConcept",
"The type of revenue or cost center providing the product and/or service.", 0, 1, revenue);
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);
case 1957227299:
/* productOrService */ return new Property("productOrService", "CodeableConcept",
"When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
0, 1, productOrService);
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);
case 1010065041:
/* programCode */ return new Property("programCode", "CodeableConcept",
"Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode);
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);
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);
case 363246749:
/* servicedDate */ return new Property("serviced[x]", "date|Period",
"The date or dates when the service or product was supplied, performed or completed.", 0, 1, serviced);
case 1534966512:
/* servicedPeriod */ return new Property("serviced[x]", "date|Period",
"The date or dates when the service or product was supplied, performed or completed.", 0, 1, serviced);
case 552316075:
/* location[x] */ return new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
"Where the product or service was provided.", 0, 1, location);
case 1901043637:
/* location */ return new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
"Where the product or service was provided.", 0, 1, location);
case -1224800468:
/* locationCodeableConcept */ return new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
"Where the product or service was provided.", 0, 1, location);
case -1280020865:
/* locationAddress */ return new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
"Where the product or service was provided.", 0, 1, location);
case 755866390:
/* locationReference */ return new Property("location[x]", "CodeableConcept|Address|Reference(Location)",
"Where the product or service was provided.", 0, 1, location);
case -1285004149:
/* quantity */ return new Property("quantity", "SimpleQuantity",
"The number of repetitions of a service or product.", 0, 1, quantity);
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);
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);
case 108957:
/* net */ return new Property("net", "Money",
"The quantity times the unit price for an additional service or product or charge.", 0, 1, net);
case 115642:
/* udi */ return new Property("udi", "Reference(Device)",
"Unique Device Identifiers associated with this line item.", 0, java.lang.Integer.MAX_VALUE, udi);
case 1702620169:
/* bodySite */ return new Property("bodySite", "CodeableConcept",
"Physical service site on the patient (limb, tooth, etc.).", 0, 1, bodySite);
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);
case 1524132147:
/* encounter */ return new Property("encounter", "Reference(Encounter)",
"A billed item may include goods or services provided in multiple encounters.", 0,
java.lang.Integer.MAX_VALUE, encounter);
case -1110033957:
/* noteNumber */ return new Property("noteNumber", "positiveInt",
"The numbers associated with notes below which apply to the adjudication of this item.", 0,
java.lang.Integer.MAX_VALUE, noteNumber);
case -231349275:
/* adjudication */ return new Property("adjudication", "",
"If this item is a group then the values here are a summary of the adjudication of the detail items. If this item is a simple product or service then this is the result of the adjudication of this item.",
0, java.lang.Integer.MAX_VALUE, adjudication);
case -1335224239:
/* detail */ return new Property("detail", "", "Second-tier of goods and services.", 0,
java.lang.Integer.MAX_VALUE, detail);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
case 1070083823:
/* careTeamSequence */ return this.careTeamSequence == null ? new Base[0]
: this.careTeamSequence.toArray(new Base[this.careTeamSequence.size()]); // PositiveIntType
case -909769262:
/* diagnosisSequence */ return this.diagnosisSequence == null ? new Base[0]
: this.diagnosisSequence.toArray(new Base[this.diagnosisSequence.size()]); // PositiveIntType
case -808920140:
/* procedureSequence */ return this.procedureSequence == null ? new Base[0]
: this.procedureSequence.toArray(new Base[this.procedureSequence.size()]); // PositiveIntType
case -702585587:
/* informationSequence */ return this.informationSequence == null ? new Base[0]
: this.informationSequence.toArray(new Base[this.informationSequence.size()]); // PositiveIntType
case 1099842588:
/* revenue */ return this.revenue == null ? new Base[0] : new Base[] { this.revenue }; // CodeableConcept
case 50511102:
/* category */ return this.category == null ? new Base[0] : new Base[] { this.category }; // CodeableConcept
case 1957227299:
/* productOrService */ return this.productOrService == null ? new Base[0]
: new Base[] { this.productOrService }; // CodeableConcept
case -615513385:
/* modifier */ return this.modifier == null ? new Base[0]
: this.modifier.toArray(new Base[this.modifier.size()]); // CodeableConcept
case 1010065041:
/* programCode */ return this.programCode == null ? new Base[0]
: this.programCode.toArray(new Base[this.programCode.size()]); // CodeableConcept
case 1379209295:
/* serviced */ return this.serviced == null ? new Base[0] : new Base[] { this.serviced }; // Type
case 1901043637:
/* location */ return this.location == null ? new Base[0] : new Base[] { this.location }; // Type
case -1285004149:
/* quantity */ return this.quantity == null ? new Base[0] : new Base[] { this.quantity }; // Quantity
case -486196699:
/* unitPrice */ return this.unitPrice == null ? new Base[0] : new Base[] { this.unitPrice }; // Money
case -1282148017:
/* factor */ return this.factor == null ? new Base[0] : new Base[] { this.factor }; // DecimalType
case 108957:
/* net */ return this.net == null ? new Base[0] : new Base[] { this.net }; // Money
case 115642:
/* udi */ return this.udi == null ? new Base[0] : this.udi.toArray(new Base[this.udi.size()]); // Reference
case 1702620169:
/* bodySite */ return this.bodySite == null ? new Base[0] : new Base[] { this.bodySite }; // CodeableConcept
case -1868566105:
/* subSite */ return this.subSite == null ? new Base[0] : this.subSite.toArray(new Base[this.subSite.size()]); // CodeableConcept
case 1524132147:
/* encounter */ return this.encounter == null ? new Base[0]
: this.encounter.toArray(new Base[this.encounter.size()]); // Reference
case -1110033957:
/* noteNumber */ return this.noteNumber == null ? new Base[0]
: this.noteNumber.toArray(new Base[this.noteNumber.size()]); // PositiveIntType
case -231349275:
/* adjudication */ return this.adjudication == null ? new Base[0]
: this.adjudication.toArray(new Base[this.adjudication.size()]); // AdjudicationComponent
case -1335224239:
/* detail */ return this.detail == null ? new Base[0] : this.detail.toArray(new Base[this.detail.size()]); // DetailComponent
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 1349547969: // sequence
this.sequence = castToPositiveInt(value); // PositiveIntType
return value;
case 1070083823: // careTeamSequence
this.getCareTeamSequence().add(castToPositiveInt(value)); // PositiveIntType
return value;
case -909769262: // diagnosisSequence
this.getDiagnosisSequence().add(castToPositiveInt(value)); // PositiveIntType
return value;
case -808920140: // procedureSequence
this.getProcedureSequence().add(castToPositiveInt(value)); // PositiveIntType
return value;
case -702585587: // informationSequence
this.getInformationSequence().add(castToPositiveInt(value)); // PositiveIntType
return value;
case 1099842588: // revenue
this.revenue = castToCodeableConcept(value); // CodeableConcept
return value;
case 50511102: // category
this.category = castToCodeableConcept(value); // CodeableConcept
return value;
case 1957227299: // productOrService
this.productOrService = castToCodeableConcept(value); // CodeableConcept
return value;
case -615513385: // modifier
this.getModifier().add(castToCodeableConcept(value)); // CodeableConcept
return value;
case 1010065041: // programCode
this.getProgramCode().add(castToCodeableConcept(value)); // CodeableConcept
return value;
case 1379209295: // serviced
this.serviced = castToType(value); // Type
return value;
case 1901043637: // location
this.location = castToType(value); // Type
return value;
case -1285004149: // quantity
this.quantity = castToQuantity(value); // Quantity
return value;
case -486196699: // unitPrice
this.unitPrice = castToMoney(value); // Money
return value;
case -1282148017: // factor
this.factor = castToDecimal(value); // DecimalType
return value;
case 108957: // net
this.net = castToMoney(value); // Money
return value;
case 115642: // udi
this.getUdi().add(castToReference(value)); // Reference
return value;
case 1702620169: // bodySite
this.bodySite = castToCodeableConcept(value); // CodeableConcept
return value;
case -1868566105: // subSite
this.getSubSite().add(castToCodeableConcept(value)); // CodeableConcept
return value;
case 1524132147: // encounter
this.getEncounter().add(castToReference(value)); // Reference
return value;
case -1110033957: // noteNumber
this.getNoteNumber().add(castToPositiveInt(value)); // PositiveIntType
return value;
case -231349275: // adjudication
this.getAdjudication().add((AdjudicationComponent) value); // AdjudicationComponent
return value;
case -1335224239: // detail
this.getDetail().add((DetailComponent) value); // DetailComponent
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = castToPositiveInt(value); // PositiveIntType
} else if (name.equals("careTeamSequence")) {
this.getCareTeamSequence().add(castToPositiveInt(value));
} else if (name.equals("diagnosisSequence")) {
this.getDiagnosisSequence().add(castToPositiveInt(value));
} else if (name.equals("procedureSequence")) {
this.getProcedureSequence().add(castToPositiveInt(value));
} else if (name.equals("informationSequence")) {
this.getInformationSequence().add(castToPositiveInt(value));
} else if (name.equals("revenue")) {
this.revenue = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("category")) {
this.category = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("productOrService")) {
this.productOrService = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("modifier")) {
this.getModifier().add(castToCodeableConcept(value));
} else if (name.equals("programCode")) {
this.getProgramCode().add(castToCodeableConcept(value));
} else if (name.equals("serviced[x]")) {
this.serviced = castToType(value); // Type
} else if (name.equals("location[x]")) {
this.location = castToType(value); // Type
} else if (name.equals("quantity")) {
this.quantity = castToQuantity(value); // Quantity
} else if (name.equals("unitPrice")) {
this.unitPrice = castToMoney(value); // Money
} else if (name.equals("factor")) {
this.factor = castToDecimal(value); // DecimalType
} else if (name.equals("net")) {
this.net = castToMoney(value); // Money
} else if (name.equals("udi")) {
this.getUdi().add(castToReference(value));
} else if (name.equals("bodySite")) {
this.bodySite = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("subSite")) {
this.getSubSite().add(castToCodeableConcept(value));
} else if (name.equals("encounter")) {
this.getEncounter().add(castToReference(value));
} else if (name.equals("noteNumber")) {
this.getNoteNumber().add(castToPositiveInt(value));
} else if (name.equals("adjudication")) {
this.getAdjudication().add((AdjudicationComponent) value);
} else if (name.equals("detail")) {
this.getDetail().add((DetailComponent) value);
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = null;
} else if (name.equals("careTeamSequence")) {
this.getCareTeamSequence().remove(castToPositiveInt(value));
} else if (name.equals("diagnosisSequence")) {
this.getDiagnosisSequence().remove(castToPositiveInt(value));
} else if (name.equals("procedureSequence")) {
this.getProcedureSequence().remove(castToPositiveInt(value));
} else if (name.equals("informationSequence")) {
this.getInformationSequence().remove(castToPositiveInt(value));
} else if (name.equals("revenue")) {
this.revenue = null;
} else if (name.equals("category")) {
this.category = null;
} else if (name.equals("productOrService")) {
this.productOrService = null;
} else if (name.equals("modifier")) {
this.getModifier().remove(castToCodeableConcept(value));
} else if (name.equals("programCode")) {
this.getProgramCode().remove(castToCodeableConcept(value));
} else if (name.equals("serviced[x]")) {
this.serviced = null;
} else if (name.equals("location[x]")) {
this.location = null;
} else if (name.equals("quantity")) {
this.quantity = null;
} else if (name.equals("unitPrice")) {
this.unitPrice = null;
} else if (name.equals("factor")) {
this.factor = null;
} else if (name.equals("net")) {
this.net = null;
} else if (name.equals("udi")) {
this.getUdi().remove(castToReference(value));
} else if (name.equals("bodySite")) {
this.bodySite = null;
} else if (name.equals("subSite")) {
this.getSubSite().remove(castToCodeableConcept(value));
} else if (name.equals("encounter")) {
this.getEncounter().remove(castToReference(value));
} else if (name.equals("noteNumber")) {
this.getNoteNumber().remove(castToPositiveInt(value));
} else if (name.equals("adjudication")) {
this.getAdjudication().remove((AdjudicationComponent) value);
} else if (name.equals("detail")) {
this.getDetail().remove((DetailComponent) value);
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
return getSequenceElement();
case 1070083823:
return addCareTeamSequenceElement();
case -909769262:
return addDiagnosisSequenceElement();
case -808920140:
return addProcedureSequenceElement();
case -702585587:
return addInformationSequenceElement();
case 1099842588:
return getRevenue();
case 50511102:
return getCategory();
case 1957227299:
return getProductOrService();
case -615513385:
return addModifier();
case 1010065041:
return addProgramCode();
case -1927922223:
return getServiced();
case 1379209295:
return getServiced();
case 552316075:
return getLocation();
case 1901043637:
return getLocation();
case -1285004149:
return getQuantity();
case -486196699:
return getUnitPrice();
case -1282148017:
return getFactorElement();
case 108957:
return getNet();
case 115642:
return addUdi();
case 1702620169:
return getBodySite();
case -1868566105:
return addSubSite();
case 1524132147:
return addEncounter();
case -1110033957:
return addNoteNumberElement();
case -231349275:
return addAdjudication();
case -1335224239:
return addDetail();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return new String[] { "positiveInt" };
case 1070083823:
/* careTeamSequence */ return new String[] { "positiveInt" };
case -909769262:
/* diagnosisSequence */ return new String[] { "positiveInt" };
case -808920140:
/* procedureSequence */ return new String[] { "positiveInt" };
case -702585587:
/* informationSequence */ return new String[] { "positiveInt" };
case 1099842588:
/* revenue */ return new String[] { "CodeableConcept" };
case 50511102:
/* category */ return new String[] { "CodeableConcept" };
case 1957227299:
/* productOrService */ return new String[] { "CodeableConcept" };
case -615513385:
/* modifier */ return new String[] { "CodeableConcept" };
case 1010065041:
/* programCode */ return new String[] { "CodeableConcept" };
case 1379209295:
/* serviced */ return new String[] { "date", "Period" };
case 1901043637:
/* location */ return new String[] { "CodeableConcept", "Address", "Reference" };
case -1285004149:
/* quantity */ return new String[] { "SimpleQuantity" };
case -486196699:
/* unitPrice */ return new String[] { "Money" };
case -1282148017:
/* factor */ return new String[] { "decimal" };
case 108957:
/* net */ return new String[] { "Money" };
case 115642:
/* udi */ return new String[] { "Reference" };
case 1702620169:
/* bodySite */ return new String[] { "CodeableConcept" };
case -1868566105:
/* subSite */ return new String[] { "CodeableConcept" };
case 1524132147:
/* encounter */ return new String[] { "Reference" };
case -1110033957:
/* noteNumber */ return new String[] { "positiveInt" };
case -231349275:
/* adjudication */ return new String[] {};
case -1335224239:
/* detail */ return new String[] {};
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("sequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
} else if (name.equals("careTeamSequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.careTeamSequence");
} else if (name.equals("diagnosisSequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.diagnosisSequence");
} else if (name.equals("procedureSequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.procedureSequence");
} else if (name.equals("informationSequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.informationSequence");
} else if (name.equals("revenue")) {
this.revenue = new CodeableConcept();
return this.revenue;
} else if (name.equals("category")) {
this.category = new CodeableConcept();
return this.category;
} else if (name.equals("productOrService")) {
this.productOrService = new CodeableConcept();
return this.productOrService;
} else if (name.equals("modifier")) {
return addModifier();
} else if (name.equals("programCode")) {
return addProgramCode();
} else if (name.equals("servicedDate")) {
this.serviced = new DateType();
return this.serviced;
} else if (name.equals("servicedPeriod")) {
this.serviced = new Period();
return this.serviced;
} else if (name.equals("locationCodeableConcept")) {
this.location = new CodeableConcept();
return this.location;
} else if (name.equals("locationAddress")) {
this.location = new Address();
return this.location;
} else if (name.equals("locationReference")) {
this.location = new Reference();
return this.location;
} else if (name.equals("quantity")) {
this.quantity = new Quantity();
return this.quantity;
} else if (name.equals("unitPrice")) {
this.unitPrice = new Money();
return this.unitPrice;
} else if (name.equals("factor")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.factor");
} else if (name.equals("net")) {
this.net = new Money();
return this.net;
} else if (name.equals("udi")) {
return addUdi();
} else if (name.equals("bodySite")) {
this.bodySite = new CodeableConcept();
return this.bodySite;
} else if (name.equals("subSite")) {
return addSubSite();
} else if (name.equals("encounter")) {
return addEncounter();
} else if (name.equals("noteNumber")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.noteNumber");
} else if (name.equals("adjudication")) {
return addAdjudication();
} else if (name.equals("detail")) {
return addDetail();
} else
return super.addChild(name);
}
public ItemComponent copy() {
ItemComponent dst = new ItemComponent();
copyValues(dst);
return dst;
}
public void copyValues(ItemComponent dst) {
super.copyValues(dst);
dst.sequence = sequence == null ? null : sequence.copy();
if (careTeamSequence != null) {
dst.careTeamSequence = new ArrayList();
for (PositiveIntType i : careTeamSequence)
dst.careTeamSequence.add(i.copy());
}
;
if (diagnosisSequence != null) {
dst.diagnosisSequence = new ArrayList();
for (PositiveIntType i : diagnosisSequence)
dst.diagnosisSequence.add(i.copy());
}
;
if (procedureSequence != null) {
dst.procedureSequence = new ArrayList();
for (PositiveIntType i : procedureSequence)
dst.procedureSequence.add(i.copy());
}
;
if (informationSequence != null) {
dst.informationSequence = new ArrayList();
for (PositiveIntType i : informationSequence)
dst.informationSequence.add(i.copy());
}
;
dst.revenue = revenue == null ? null : revenue.copy();
dst.category = category == null ? null : category.copy();
dst.productOrService = productOrService == null ? null : productOrService.copy();
if (modifier != null) {
dst.modifier = new ArrayList();
for (CodeableConcept i : modifier)
dst.modifier.add(i.copy());
}
;
if (programCode != null) {
dst.programCode = new ArrayList();
for (CodeableConcept i : programCode)
dst.programCode.add(i.copy());
}
;
dst.serviced = serviced == null ? null : serviced.copy();
dst.location = location == null ? null : location.copy();
dst.quantity = quantity == null ? null : quantity.copy();
dst.unitPrice = unitPrice == null ? null : unitPrice.copy();
dst.factor = factor == null ? null : factor.copy();
dst.net = net == null ? null : net.copy();
if (udi != null) {
dst.udi = new ArrayList();
for (Reference i : udi)
dst.udi.add(i.copy());
}
;
dst.bodySite = bodySite == null ? null : bodySite.copy();
if (subSite != null) {
dst.subSite = new ArrayList();
for (CodeableConcept i : subSite)
dst.subSite.add(i.copy());
}
;
if (encounter != null) {
dst.encounter = new ArrayList();
for (Reference i : encounter)
dst.encounter.add(i.copy());
}
;
if (noteNumber != null) {
dst.noteNumber = new ArrayList();
for (PositiveIntType i : noteNumber)
dst.noteNumber.add(i.copy());
}
;
if (adjudication != null) {
dst.adjudication = new ArrayList();
for (AdjudicationComponent i : adjudication)
dst.adjudication.add(i.copy());
}
;
if (detail != null) {
dst.detail = new ArrayList();
for (DetailComponent i : detail)
dst.detail.add(i.copy());
}
;
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof ItemComponent))
return false;
ItemComponent o = (ItemComponent) other_;
return compareDeep(sequence, o.sequence, true) && compareDeep(careTeamSequence, o.careTeamSequence, true)
&& compareDeep(diagnosisSequence, o.diagnosisSequence, true)
&& compareDeep(procedureSequence, o.procedureSequence, true)
&& compareDeep(informationSequence, o.informationSequence, true) && compareDeep(revenue, o.revenue, true)
&& compareDeep(category, o.category, true) && compareDeep(productOrService, o.productOrService, true)
&& compareDeep(modifier, o.modifier, true) && compareDeep(programCode, o.programCode, true)
&& compareDeep(serviced, o.serviced, true) && compareDeep(location, o.location, true)
&& compareDeep(quantity, o.quantity, true) && compareDeep(unitPrice, o.unitPrice, true)
&& compareDeep(factor, o.factor, true) && compareDeep(net, o.net, true) && compareDeep(udi, o.udi, true)
&& compareDeep(bodySite, o.bodySite, true) && compareDeep(subSite, o.subSite, true)
&& compareDeep(encounter, o.encounter, true) && compareDeep(noteNumber, o.noteNumber, true)
&& compareDeep(adjudication, o.adjudication, true) && compareDeep(detail, o.detail, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof ItemComponent))
return false;
ItemComponent o = (ItemComponent) other_;
return compareValues(sequence, o.sequence, true) && compareValues(careTeamSequence, o.careTeamSequence, true)
&& compareValues(diagnosisSequence, o.diagnosisSequence, true)
&& compareValues(procedureSequence, o.procedureSequence, true)
&& compareValues(informationSequence, o.informationSequence, true) && compareValues(factor, o.factor, true)
&& compareValues(noteNumber, o.noteNumber, true);
}
public boolean isEmpty() {
return super.isEmpty()
&& ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, careTeamSequence, diagnosisSequence, procedureSequence,
informationSequence, revenue, category, productOrService, modifier, programCode, serviced, location,
quantity, unitPrice, factor, net, udi, bodySite, subSite, encounter, noteNumber, adjudication, detail);
}
public String fhirType() {
return "ExplanationOfBenefit.item";
}
}
@Block()
public static class AdjudicationComponent extends BackboneElement implements IBaseBackboneElement {
/**
* A code to indicate the information type of this adjudication record.
* Information types may include: the value submitted, maximum values or
* percentages allowed or payable under the plan, amounts that the patient is
* responsible for in-aggregate or pertaining to this item, amounts paid by
* other coverages, and the benefit payable for this item.
*/
@Child(name = "category", type = {
CodeableConcept.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Type of adjudication information", formalDefinition = "A code to indicate the information type of this adjudication record. Information types may include: the value submitted, maximum values or percentages allowed or payable under the plan, amounts that the patient is responsible for in-aggregate or pertaining to this item, amounts paid by other coverages, and the benefit payable for this item.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/adjudication")
protected CodeableConcept category;
/**
* A code supporting the understanding of the adjudication result and explaining
* variance from expected amount.
*/
@Child(name = "reason", type = {
CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Explanation of adjudication outcome", formalDefinition = "A code supporting the understanding of the adjudication result and explaining variance from expected amount.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/adjudication-reason")
protected CodeableConcept reason;
/**
* Monetary amount associated with the category.
*/
@Child(name = "amount", type = { Money.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Monetary amount", formalDefinition = "Monetary amount associated with the category.")
protected Money amount;
/**
* A non-monetary value associated with the category. Mutually exclusive to the
* amount element above.
*/
@Child(name = "value", type = { DecimalType.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Non-monitary value", formalDefinition = "A non-monetary value associated with the category. Mutually exclusive to the amount element above.")
protected DecimalType value;
private static final long serialVersionUID = 1559898786L;
/**
* Constructor
*/
public AdjudicationComponent() {
super();
}
/**
* Constructor
*/
public AdjudicationComponent(CodeableConcept category) {
super();
this.category = category;
}
/**
* @return {@link #category} (A code to indicate the information type of this
* adjudication record. Information types may include: the value
* submitted, maximum values or percentages allowed or payable under the
* plan, amounts that the patient is responsible for in-aggregate or
* pertaining to this item, amounts paid by other coverages, and the
* benefit payable for this item.)
*/
public CodeableConcept getCategory() {
if (this.category == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create AdjudicationComponent.category");
else if (Configuration.doAutoCreate())
this.category = new CodeableConcept(); // cc
return this.category;
}
public boolean hasCategory() {
return this.category != null && !this.category.isEmpty();
}
/**
* @param value {@link #category} (A code to indicate the information type of
* this adjudication record. Information types may include: the
* value submitted, maximum values or percentages allowed or
* payable under the plan, amounts that the patient is responsible
* for in-aggregate or pertaining to this item, amounts paid by
* other coverages, and the benefit payable for this item.)
*/
public AdjudicationComponent setCategory(CodeableConcept value) {
this.category = value;
return this;
}
/**
* @return {@link #reason} (A code supporting the understanding of the
* adjudication result and explaining variance from expected amount.)
*/
public CodeableConcept getReason() {
if (this.reason == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create AdjudicationComponent.reason");
else if (Configuration.doAutoCreate())
this.reason = new CodeableConcept(); // cc
return this.reason;
}
public boolean hasReason() {
return this.reason != null && !this.reason.isEmpty();
}
/**
* @param value {@link #reason} (A code supporting the understanding of the
* adjudication result and explaining variance from expected
* amount.)
*/
public AdjudicationComponent setReason(CodeableConcept value) {
this.reason = value;
return this;
}
/**
* @return {@link #amount} (Monetary amount associated with the category.)
*/
public Money getAmount() {
if (this.amount == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create AdjudicationComponent.amount");
else if (Configuration.doAutoCreate())
this.amount = new Money(); // cc
return this.amount;
}
public boolean hasAmount() {
return this.amount != null && !this.amount.isEmpty();
}
/**
* @param value {@link #amount} (Monetary amount associated with the category.)
*/
public AdjudicationComponent setAmount(Money value) {
this.amount = value;
return this;
}
/**
* @return {@link #value} (A non-monetary value associated with the category.
* Mutually exclusive to the amount element above.). This is the
* underlying object with id, value and extensions. The accessor
* "getValue" gives direct access to the value
*/
public DecimalType getValueElement() {
if (this.value == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create AdjudicationComponent.value");
else if (Configuration.doAutoCreate())
this.value = new DecimalType(); // bb
return this.value;
}
public boolean hasValueElement() {
return this.value != null && !this.value.isEmpty();
}
public boolean hasValue() {
return this.value != null && !this.value.isEmpty();
}
/**
* @param value {@link #value} (A non-monetary value associated with the
* category. Mutually exclusive to the amount element above.). This
* is the underlying object with id, value and extensions. The
* accessor "getValue" gives direct access to the value
*/
public AdjudicationComponent setValueElement(DecimalType value) {
this.value = value;
return this;
}
/**
* @return A non-monetary value associated with the category. Mutually exclusive
* to the amount element above.
*/
public BigDecimal getValue() {
return this.value == null ? null : this.value.getValue();
}
/**
* @param value A non-monetary value associated with the category. Mutually
* exclusive to the amount element above.
*/
public AdjudicationComponent setValue(BigDecimal value) {
if (value == null)
this.value = null;
else {
if (this.value == null)
this.value = new DecimalType();
this.value.setValue(value);
}
return this;
}
/**
* @param value A non-monetary value associated with the category. Mutually
* exclusive to the amount element above.
*/
public AdjudicationComponent setValue(long value) {
this.value = new DecimalType();
this.value.setValue(value);
return this;
}
/**
* @param value A non-monetary value associated with the category. Mutually
* exclusive to the amount element above.
*/
public AdjudicationComponent setValue(double value) {
this.value = new DecimalType();
this.value.setValue(value);
return this;
}
protected void listChildren(List children) {
super.listChildren(children);
children.add(new Property("category", "CodeableConcept",
"A code to indicate the information type of this adjudication record. Information types may include: the value submitted, maximum values or percentages allowed or payable under the plan, amounts that the patient is responsible for in-aggregate or pertaining to this item, amounts paid by other coverages, and the benefit payable for this item.",
0, 1, category));
children.add(new Property("reason", "CodeableConcept",
"A code supporting the understanding of the adjudication result and explaining variance from expected amount.",
0, 1, reason));
children.add(new Property("amount", "Money", "Monetary amount associated with the category.", 0, 1, amount));
children.add(new Property("value", "decimal",
"A non-monetary value associated with the category. Mutually exclusive to the amount element above.", 0, 1,
value));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
case 50511102:
/* category */ return new Property("category", "CodeableConcept",
"A code to indicate the information type of this adjudication record. Information types may include: the value submitted, maximum values or percentages allowed or payable under the plan, amounts that the patient is responsible for in-aggregate or pertaining to this item, amounts paid by other coverages, and the benefit payable for this item.",
0, 1, category);
case -934964668:
/* reason */ return new Property("reason", "CodeableConcept",
"A code supporting the understanding of the adjudication result and explaining variance from expected amount.",
0, 1, reason);
case -1413853096:
/* amount */ return new Property("amount", "Money", "Monetary amount associated with the category.", 0, 1,
amount);
case 111972721:
/* value */ return new Property("value", "decimal",
"A non-monetary value associated with the category. Mutually exclusive to the amount element above.", 0, 1,
value);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 50511102:
/* category */ return this.category == null ? new Base[0] : new Base[] { this.category }; // CodeableConcept
case -934964668:
/* reason */ return this.reason == null ? new Base[0] : new Base[] { this.reason }; // CodeableConcept
case -1413853096:
/* amount */ return this.amount == null ? new Base[0] : new Base[] { this.amount }; // Money
case 111972721:
/* value */ return this.value == null ? new Base[0] : new Base[] { this.value }; // DecimalType
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 50511102: // category
this.category = castToCodeableConcept(value); // CodeableConcept
return value;
case -934964668: // reason
this.reason = castToCodeableConcept(value); // CodeableConcept
return value;
case -1413853096: // amount
this.amount = castToMoney(value); // Money
return value;
case 111972721: // value
this.value = castToDecimal(value); // DecimalType
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("category")) {
this.category = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("reason")) {
this.reason = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("amount")) {
this.amount = castToMoney(value); // Money
} else if (name.equals("value")) {
this.value = castToDecimal(value); // DecimalType
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("category")) {
this.category = null;
} else if (name.equals("reason")) {
this.reason = null;
} else if (name.equals("amount")) {
this.amount = null;
} else if (name.equals("value")) {
this.value = null;
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 50511102:
return getCategory();
case -934964668:
return getReason();
case -1413853096:
return getAmount();
case 111972721:
return getValueElement();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 50511102:
/* category */ return new String[] { "CodeableConcept" };
case -934964668:
/* reason */ return new String[] { "CodeableConcept" };
case -1413853096:
/* amount */ return new String[] { "Money" };
case 111972721:
/* value */ return new String[] { "decimal" };
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("category")) {
this.category = new CodeableConcept();
return this.category;
} else if (name.equals("reason")) {
this.reason = new CodeableConcept();
return this.reason;
} else if (name.equals("amount")) {
this.amount = new Money();
return this.amount;
} else if (name.equals("value")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.value");
} else
return super.addChild(name);
}
public AdjudicationComponent copy() {
AdjudicationComponent dst = new AdjudicationComponent();
copyValues(dst);
return dst;
}
public void copyValues(AdjudicationComponent dst) {
super.copyValues(dst);
dst.category = category == null ? null : category.copy();
dst.reason = reason == null ? null : reason.copy();
dst.amount = amount == null ? null : amount.copy();
dst.value = value == null ? null : value.copy();
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof AdjudicationComponent))
return false;
AdjudicationComponent o = (AdjudicationComponent) other_;
return compareDeep(category, o.category, true) && compareDeep(reason, o.reason, true)
&& compareDeep(amount, o.amount, true) && compareDeep(value, o.value, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof AdjudicationComponent))
return false;
AdjudicationComponent o = (AdjudicationComponent) other_;
return compareValues(value, o.value, true);
}
public boolean isEmpty() {
return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(category, reason, amount, value);
}
public String fhirType() {
return "ExplanationOfBenefit.item.adjudication";
}
}
@Block()
public static class DetailComponent extends BackboneElement implements IBaseBackboneElement {
/**
* A claim detail line. Either a simple (a product or service) or a 'group' of
* sub-details which are simple items.
*/
@Child(name = "sequence", type = {
PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
@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.")
protected PositiveIntType sequence;
/**
* The type of revenue or cost center providing the product and/or service.
*/
@Child(name = "revenue", type = {
CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Revenue or cost center code", formalDefinition = "The type of revenue or cost center providing the product and/or service.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-revenue-center")
protected CodeableConcept revenue;
/**
* Code to identify the general type of benefits under which products and
* services are provided.
*/
@Child(name = "category", type = {
CodeableConcept.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Benefit classification", formalDefinition = "Code to identify the general type of benefits under which products and services are provided.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-benefitcategory")
protected CodeableConcept category;
/**
* When the value is a group code then this item collects a set of related claim
* details, otherwise this contains the product, service, drug or other billing
* code for the item.
*/
@Child(name = "productOrService", type = {
CodeableConcept.class }, order = 4, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Billing, service, product, or drug code", formalDefinition = "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-uscls")
protected CodeableConcept productOrService;
/**
* Item typification or modifiers codes to convey additional context for the
* product or service.
*/
@Child(name = "modifier", type = {
CodeableConcept.class }, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Service/Product billing modifiers", formalDefinition = "Item typification or modifiers codes to convey additional context for the product or service.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-modifiers")
protected List modifier;
/**
* Identifies the program under which this may be recovered.
*/
@Child(name = "programCode", type = {
CodeableConcept.class }, order = 6, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Program the product or service is provided under", formalDefinition = "Identifies the program under which this may be recovered.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-program-code")
protected List programCode;
/**
* The number of repetitions of a service or product.
*/
@Child(name = "quantity", type = { Quantity.class }, order = 7, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Count of products or services", formalDefinition = "The number of repetitions of a service or product.")
protected Quantity quantity;
/**
* 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.
*/
@Child(name = "unitPrice", type = { Money.class }, order = 8, min = 0, max = 1, modifier = false, summary = false)
@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.")
protected Money unitPrice;
/**
* 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.
*/
@Child(name = "factor", type = {
DecimalType.class }, order = 9, min = 0, max = 1, modifier = false, summary = false)
@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.")
protected DecimalType factor;
/**
* The quantity times the unit price for an additional service or product or
* charge.
*/
@Child(name = "net", type = { Money.class }, order = 10, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Total item cost", formalDefinition = "The quantity times the unit price for an additional service or product or charge.")
protected Money net;
/**
* Unique Device Identifiers associated with this line item.
*/
@Child(name = "udi", type = {
Device.class }, order = 11, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Unique device identifier", formalDefinition = "Unique Device Identifiers associated with this line item.")
protected List udi;
/**
* The actual objects that are the target of the reference (Unique Device
* Identifiers associated with this line item.)
*/
protected List udiTarget;
/**
* The numbers associated with notes below which apply to the adjudication of
* this item.
*/
@Child(name = "noteNumber", type = {
PositiveIntType.class }, order = 12, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Applicable note numbers", formalDefinition = "The numbers associated with notes below which apply to the adjudication of this item.")
protected List noteNumber;
/**
* The adjudication results.
*/
@Child(name = "adjudication", type = {
AdjudicationComponent.class }, order = 13, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Detail level adjudication details", formalDefinition = "The adjudication results.")
protected List adjudication;
/**
* Third-tier of goods and services.
*/
@Child(name = "subDetail", type = {}, order = 14, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Additional items", formalDefinition = "Third-tier of goods and services.")
protected List subDetail;
private static final long serialVersionUID = 225639798L;
/**
* Constructor
*/
public DetailComponent() {
super();
}
/**
* Constructor
*/
public DetailComponent(PositiveIntType sequence, CodeableConcept productOrService) {
super();
this.sequence = sequence;
this.productOrService = productOrService;
}
/**
* @return {@link #sequence} (A claim detail line. Either a simple (a product or
* service) or a 'group' of sub-details which are simple items.). This
* is the underlying object with id, value and extensions. The accessor
* "getSequence" gives direct access to the value
*/
public PositiveIntType getSequenceElement() {
if (this.sequence == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DetailComponent.sequence");
else if (Configuration.doAutoCreate())
this.sequence = new PositiveIntType(); // bb
return this.sequence;
}
public boolean hasSequenceElement() {
return this.sequence != null && !this.sequence.isEmpty();
}
public boolean hasSequence() {
return this.sequence != null && !this.sequence.isEmpty();
}
/**
* @param value {@link #sequence} (A claim detail line. Either a simple (a
* product or service) or a 'group' of sub-details which are simple
* items.). This is the underlying object with id, value and
* extensions. The accessor "getSequence" gives direct access to
* the value
*/
public DetailComponent setSequenceElement(PositiveIntType value) {
this.sequence = value;
return this;
}
/**
* @return A claim detail line. Either a simple (a product or service) or a
* 'group' of sub-details which are simple items.
*/
public int getSequence() {
return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
}
/**
* @param value A claim detail line. Either a simple (a product or service) or a
* 'group' of sub-details which are simple items.
*/
public DetailComponent setSequence(int value) {
if (this.sequence == null)
this.sequence = new PositiveIntType();
this.sequence.setValue(value);
return this;
}
/**
* @return {@link #revenue} (The type of revenue or cost center providing the
* product and/or service.)
*/
public CodeableConcept getRevenue() {
if (this.revenue == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DetailComponent.revenue");
else if (Configuration.doAutoCreate())
this.revenue = new CodeableConcept(); // cc
return this.revenue;
}
public boolean hasRevenue() {
return this.revenue != null && !this.revenue.isEmpty();
}
/**
* @param value {@link #revenue} (The type of revenue or cost center providing
* the product and/or service.)
*/
public DetailComponent setRevenue(CodeableConcept value) {
this.revenue = value;
return this;
}
/**
* @return {@link #category} (Code to identify the general type of benefits
* under which products and services are provided.)
*/
public CodeableConcept getCategory() {
if (this.category == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DetailComponent.category");
else if (Configuration.doAutoCreate())
this.category = new CodeableConcept(); // cc
return this.category;
}
public boolean hasCategory() {
return this.category != null && !this.category.isEmpty();
}
/**
* @param value {@link #category} (Code to identify the general type of benefits
* under which products and services are provided.)
*/
public DetailComponent setCategory(CodeableConcept value) {
this.category = value;
return this;
}
/**
* @return {@link #productOrService} (When the value is a group code then this
* item collects a set of related claim details, otherwise this contains
* the product, service, drug or other billing code for the item.)
*/
public CodeableConcept getProductOrService() {
if (this.productOrService == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DetailComponent.productOrService");
else if (Configuration.doAutoCreate())
this.productOrService = new CodeableConcept(); // cc
return this.productOrService;
}
public boolean hasProductOrService() {
return this.productOrService != null && !this.productOrService.isEmpty();
}
/**
* @param value {@link #productOrService} (When the value is a group code then
* this item collects a set of related claim details, otherwise
* this contains the product, service, drug or other billing code
* for the item.)
*/
public DetailComponent setProductOrService(CodeableConcept value) {
this.productOrService = value;
return this;
}
/**
* @return {@link #modifier} (Item typification or modifiers codes to convey
* additional context for the product or service.)
*/
public List getModifier() {
if (this.modifier == null)
this.modifier = new ArrayList();
return this.modifier;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public DetailComponent setModifier(List theModifier) {
this.modifier = theModifier;
return this;
}
public boolean hasModifier() {
if (this.modifier == null)
return false;
for (CodeableConcept item : this.modifier)
if (!item.isEmpty())
return true;
return false;
}
public CodeableConcept addModifier() { // 3
CodeableConcept t = new CodeableConcept();
if (this.modifier == null)
this.modifier = new ArrayList();
this.modifier.add(t);
return t;
}
public DetailComponent addModifier(CodeableConcept t) { // 3
if (t == null)
return this;
if (this.modifier == null)
this.modifier = new ArrayList();
this.modifier.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #modifier}, creating
* it if it does not already exist
*/
public CodeableConcept getModifierFirstRep() {
if (getModifier().isEmpty()) {
addModifier();
}
return getModifier().get(0);
}
/**
* @return {@link #programCode} (Identifies the program under which this may be
* recovered.)
*/
public List getProgramCode() {
if (this.programCode == null)
this.programCode = new ArrayList();
return this.programCode;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public DetailComponent setProgramCode(List theProgramCode) {
this.programCode = theProgramCode;
return this;
}
public boolean hasProgramCode() {
if (this.programCode == null)
return false;
for (CodeableConcept item : this.programCode)
if (!item.isEmpty())
return true;
return false;
}
public CodeableConcept addProgramCode() { // 3
CodeableConcept t = new CodeableConcept();
if (this.programCode == null)
this.programCode = new ArrayList();
this.programCode.add(t);
return t;
}
public DetailComponent addProgramCode(CodeableConcept t) { // 3
if (t == null)
return this;
if (this.programCode == null)
this.programCode = new ArrayList();
this.programCode.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #programCode},
* creating it if it does not already exist
*/
public CodeableConcept getProgramCodeFirstRep() {
if (getProgramCode().isEmpty()) {
addProgramCode();
}
return getProgramCode().get(0);
}
/**
* @return {@link #quantity} (The number of repetitions of a service or
* product.)
*/
public Quantity getQuantity() {
if (this.quantity == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DetailComponent.quantity");
else if (Configuration.doAutoCreate())
this.quantity = new Quantity(); // cc
return this.quantity;
}
public boolean hasQuantity() {
return this.quantity != null && !this.quantity.isEmpty();
}
/**
* @param value {@link #quantity} (The number of repetitions of a service or
* product.)
*/
public DetailComponent setQuantity(Quantity value) {
this.quantity = value;
return this;
}
/**
* @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.)
*/
public Money getUnitPrice() {
if (this.unitPrice == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DetailComponent.unitPrice");
else if (Configuration.doAutoCreate())
this.unitPrice = new Money(); // cc
return this.unitPrice;
}
public boolean hasUnitPrice() {
return this.unitPrice != null && !this.unitPrice.isEmpty();
}
/**
* @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.)
*/
public DetailComponent setUnitPrice(Money value) {
this.unitPrice = value;
return this;
}
/**
* @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
*/
public DecimalType getFactorElement() {
if (this.factor == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DetailComponent.factor");
else if (Configuration.doAutoCreate())
this.factor = new DecimalType(); // bb
return this.factor;
}
public boolean hasFactorElement() {
return this.factor != null && !this.factor.isEmpty();
}
public boolean hasFactor() {
return this.factor != null && !this.factor.isEmpty();
}
/**
* @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
*/
public DetailComponent setFactorElement(DecimalType value) {
this.factor = value;
return this;
}
/**
* @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.
*/
public BigDecimal getFactor() {
return this.factor == null ? null : this.factor.getValue();
}
/**
* @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.
*/
public DetailComponent setFactor(BigDecimal value) {
if (value == null)
this.factor = null;
else {
if (this.factor == null)
this.factor = new DecimalType();
this.factor.setValue(value);
}
return this;
}
/**
* @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.
*/
public DetailComponent setFactor(long value) {
this.factor = new DecimalType();
this.factor.setValue(value);
return this;
}
/**
* @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.
*/
public DetailComponent setFactor(double value) {
this.factor = new DecimalType();
this.factor.setValue(value);
return this;
}
/**
* @return {@link #net} (The quantity times the unit price for an additional
* service or product or charge.)
*/
public Money getNet() {
if (this.net == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create DetailComponent.net");
else if (Configuration.doAutoCreate())
this.net = new Money(); // cc
return this.net;
}
public boolean hasNet() {
return this.net != null && !this.net.isEmpty();
}
/**
* @param value {@link #net} (The quantity times the unit price for an
* additional service or product or charge.)
*/
public DetailComponent setNet(Money value) {
this.net = value;
return this;
}
/**
* @return {@link #udi} (Unique Device Identifiers associated with this line
* item.)
*/
public List getUdi() {
if (this.udi == null)
this.udi = new ArrayList();
return this.udi;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public DetailComponent setUdi(List theUdi) {
this.udi = theUdi;
return this;
}
public boolean hasUdi() {
if (this.udi == null)
return false;
for (Reference item : this.udi)
if (!item.isEmpty())
return true;
return false;
}
public Reference addUdi() { // 3
Reference t = new Reference();
if (this.udi == null)
this.udi = new ArrayList();
this.udi.add(t);
return t;
}
public DetailComponent addUdi(Reference t) { // 3
if (t == null)
return this;
if (this.udi == null)
this.udi = new ArrayList();
this.udi.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #udi}, creating it if
* it does not already exist
*/
public Reference getUdiFirstRep() {
if (getUdi().isEmpty()) {
addUdi();
}
return getUdi().get(0);
}
/**
* @deprecated Use Reference#setResource(IBaseResource) instead
*/
@Deprecated
public List getUdiTarget() {
if (this.udiTarget == null)
this.udiTarget = new ArrayList();
return this.udiTarget;
}
/**
* @deprecated Use Reference#setResource(IBaseResource) instead
*/
@Deprecated
public Device addUdiTarget() {
Device r = new Device();
if (this.udiTarget == null)
this.udiTarget = new ArrayList();
this.udiTarget.add(r);
return r;
}
/**
* @return {@link #noteNumber} (The numbers associated with notes below which
* apply to the adjudication of this item.)
*/
public List getNoteNumber() {
if (this.noteNumber == null)
this.noteNumber = new ArrayList();
return this.noteNumber;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public DetailComponent setNoteNumber(List theNoteNumber) {
this.noteNumber = theNoteNumber;
return this;
}
public boolean hasNoteNumber() {
if (this.noteNumber == null)
return false;
for (PositiveIntType item : this.noteNumber)
if (!item.isEmpty())
return true;
return false;
}
/**
* @return {@link #noteNumber} (The numbers associated with notes below which
* apply to the adjudication of this item.)
*/
public PositiveIntType addNoteNumberElement() {// 2
PositiveIntType t = new PositiveIntType();
if (this.noteNumber == null)
this.noteNumber = new ArrayList();
this.noteNumber.add(t);
return t;
}
/**
* @param value {@link #noteNumber} (The numbers associated with notes below
* which apply to the adjudication of this item.)
*/
public DetailComponent addNoteNumber(int value) { // 1
PositiveIntType t = new PositiveIntType();
t.setValue(value);
if (this.noteNumber == null)
this.noteNumber = new ArrayList();
this.noteNumber.add(t);
return this;
}
/**
* @param value {@link #noteNumber} (The numbers associated with notes below
* which apply to the adjudication of this item.)
*/
public boolean hasNoteNumber(int value) {
if (this.noteNumber == null)
return false;
for (PositiveIntType v : this.noteNumber)
if (v.getValue().equals(value)) // positiveInt
return true;
return false;
}
/**
* @return {@link #adjudication} (The adjudication results.)
*/
public List getAdjudication() {
if (this.adjudication == null)
this.adjudication = new ArrayList();
return this.adjudication;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public DetailComponent setAdjudication(List theAdjudication) {
this.adjudication = theAdjudication;
return this;
}
public boolean hasAdjudication() {
if (this.adjudication == null)
return false;
for (AdjudicationComponent item : this.adjudication)
if (!item.isEmpty())
return true;
return false;
}
public AdjudicationComponent addAdjudication() { // 3
AdjudicationComponent t = new AdjudicationComponent();
if (this.adjudication == null)
this.adjudication = new ArrayList();
this.adjudication.add(t);
return t;
}
public DetailComponent addAdjudication(AdjudicationComponent t) { // 3
if (t == null)
return this;
if (this.adjudication == null)
this.adjudication = new ArrayList();
this.adjudication.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #adjudication},
* creating it if it does not already exist
*/
public AdjudicationComponent getAdjudicationFirstRep() {
if (getAdjudication().isEmpty()) {
addAdjudication();
}
return getAdjudication().get(0);
}
/**
* @return {@link #subDetail} (Third-tier of goods and services.)
*/
public List getSubDetail() {
if (this.subDetail == null)
this.subDetail = new ArrayList();
return this.subDetail;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public DetailComponent setSubDetail(List theSubDetail) {
this.subDetail = theSubDetail;
return this;
}
public boolean hasSubDetail() {
if (this.subDetail == null)
return false;
for (SubDetailComponent item : this.subDetail)
if (!item.isEmpty())
return true;
return false;
}
public SubDetailComponent addSubDetail() { // 3
SubDetailComponent t = new SubDetailComponent();
if (this.subDetail == null)
this.subDetail = new ArrayList();
this.subDetail.add(t);
return t;
}
public DetailComponent addSubDetail(SubDetailComponent t) { // 3
if (t == null)
return this;
if (this.subDetail == null)
this.subDetail = new ArrayList();
this.subDetail.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #subDetail}, creating
* it if it does not already exist
*/
public SubDetailComponent getSubDetailFirstRep() {
if (getSubDetail().isEmpty()) {
addSubDetail();
}
return getSubDetail().get(0);
}
protected void listChildren(List children) {
super.listChildren(children);
children.add(new Property("sequence", "positiveInt",
"A claim detail line. Either a simple (a product or service) or a 'group' of sub-details which are simple items.",
0, 1, sequence));
children.add(new Property("revenue", "CodeableConcept",
"The type of revenue or cost center providing the product and/or service.", 0, 1, revenue));
children.add(new Property("category", "CodeableConcept",
"Code to identify the general type of benefits under which products and services are provided.", 0, 1,
category));
children.add(new Property("productOrService", "CodeableConcept",
"When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
0, 1, productOrService));
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));
children.add(new Property("programCode", "CodeableConcept",
"Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode));
children.add(new Property("quantity", "SimpleQuantity", "The number of repetitions of a service or product.", 0,
1, quantity));
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));
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));
children.add(new Property("net", "Money",
"The quantity times the unit price for an additional service or product or charge.", 0, 1, net));
children.add(new Property("udi", "Reference(Device)", "Unique Device Identifiers associated with this line item.",
0, java.lang.Integer.MAX_VALUE, udi));
children.add(new Property("noteNumber", "positiveInt",
"The numbers associated with notes below which apply to the adjudication of this item.", 0,
java.lang.Integer.MAX_VALUE, noteNumber));
children.add(new Property("adjudication", "@ExplanationOfBenefit.item.adjudication", "The adjudication results.",
0, java.lang.Integer.MAX_VALUE, adjudication));
children.add(new Property("subDetail", "", "Third-tier of goods and services.", 0, java.lang.Integer.MAX_VALUE,
subDetail));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
case 1349547969:
/* sequence */ return new Property("sequence", "positiveInt",
"A claim detail line. Either a simple (a product or service) or a 'group' of sub-details which are simple items.",
0, 1, sequence);
case 1099842588:
/* revenue */ return new Property("revenue", "CodeableConcept",
"The type of revenue or cost center providing the product and/or service.", 0, 1, revenue);
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);
case 1957227299:
/* productOrService */ return new Property("productOrService", "CodeableConcept",
"When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
0, 1, productOrService);
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);
case 1010065041:
/* programCode */ return new Property("programCode", "CodeableConcept",
"Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode);
case -1285004149:
/* quantity */ return new Property("quantity", "SimpleQuantity",
"The number of repetitions of a service or product.", 0, 1, quantity);
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);
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);
case 108957:
/* net */ return new Property("net", "Money",
"The quantity times the unit price for an additional service or product or charge.", 0, 1, net);
case 115642:
/* udi */ return new Property("udi", "Reference(Device)",
"Unique Device Identifiers associated with this line item.", 0, java.lang.Integer.MAX_VALUE, udi);
case -1110033957:
/* noteNumber */ return new Property("noteNumber", "positiveInt",
"The numbers associated with notes below which apply to the adjudication of this item.", 0,
java.lang.Integer.MAX_VALUE, noteNumber);
case -231349275:
/* adjudication */ return new Property("adjudication", "@ExplanationOfBenefit.item.adjudication",
"The adjudication results.", 0, java.lang.Integer.MAX_VALUE, adjudication);
case -828829007:
/* subDetail */ return new Property("subDetail", "", "Third-tier of goods and services.", 0,
java.lang.Integer.MAX_VALUE, subDetail);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
case 1099842588:
/* revenue */ return this.revenue == null ? new Base[0] : new Base[] { this.revenue }; // CodeableConcept
case 50511102:
/* category */ return this.category == null ? new Base[0] : new Base[] { this.category }; // CodeableConcept
case 1957227299:
/* productOrService */ return this.productOrService == null ? new Base[0]
: new Base[] { this.productOrService }; // CodeableConcept
case -615513385:
/* modifier */ return this.modifier == null ? new Base[0]
: this.modifier.toArray(new Base[this.modifier.size()]); // CodeableConcept
case 1010065041:
/* programCode */ return this.programCode == null ? new Base[0]
: this.programCode.toArray(new Base[this.programCode.size()]); // CodeableConcept
case -1285004149:
/* quantity */ return this.quantity == null ? new Base[0] : new Base[] { this.quantity }; // Quantity
case -486196699:
/* unitPrice */ return this.unitPrice == null ? new Base[0] : new Base[] { this.unitPrice }; // Money
case -1282148017:
/* factor */ return this.factor == null ? new Base[0] : new Base[] { this.factor }; // DecimalType
case 108957:
/* net */ return this.net == null ? new Base[0] : new Base[] { this.net }; // Money
case 115642:
/* udi */ return this.udi == null ? new Base[0] : this.udi.toArray(new Base[this.udi.size()]); // Reference
case -1110033957:
/* noteNumber */ return this.noteNumber == null ? new Base[0]
: this.noteNumber.toArray(new Base[this.noteNumber.size()]); // PositiveIntType
case -231349275:
/* adjudication */ return this.adjudication == null ? new Base[0]
: this.adjudication.toArray(new Base[this.adjudication.size()]); // AdjudicationComponent
case -828829007:
/* subDetail */ return this.subDetail == null ? new Base[0]
: this.subDetail.toArray(new Base[this.subDetail.size()]); // SubDetailComponent
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 1349547969: // sequence
this.sequence = castToPositiveInt(value); // PositiveIntType
return value;
case 1099842588: // revenue
this.revenue = castToCodeableConcept(value); // CodeableConcept
return value;
case 50511102: // category
this.category = castToCodeableConcept(value); // CodeableConcept
return value;
case 1957227299: // productOrService
this.productOrService = castToCodeableConcept(value); // CodeableConcept
return value;
case -615513385: // modifier
this.getModifier().add(castToCodeableConcept(value)); // CodeableConcept
return value;
case 1010065041: // programCode
this.getProgramCode().add(castToCodeableConcept(value)); // CodeableConcept
return value;
case -1285004149: // quantity
this.quantity = castToQuantity(value); // Quantity
return value;
case -486196699: // unitPrice
this.unitPrice = castToMoney(value); // Money
return value;
case -1282148017: // factor
this.factor = castToDecimal(value); // DecimalType
return value;
case 108957: // net
this.net = castToMoney(value); // Money
return value;
case 115642: // udi
this.getUdi().add(castToReference(value)); // Reference
return value;
case -1110033957: // noteNumber
this.getNoteNumber().add(castToPositiveInt(value)); // PositiveIntType
return value;
case -231349275: // adjudication
this.getAdjudication().add((AdjudicationComponent) value); // AdjudicationComponent
return value;
case -828829007: // subDetail
this.getSubDetail().add((SubDetailComponent) value); // SubDetailComponent
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = castToPositiveInt(value); // PositiveIntType
} else if (name.equals("revenue")) {
this.revenue = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("category")) {
this.category = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("productOrService")) {
this.productOrService = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("modifier")) {
this.getModifier().add(castToCodeableConcept(value));
} else if (name.equals("programCode")) {
this.getProgramCode().add(castToCodeableConcept(value));
} else if (name.equals("quantity")) {
this.quantity = castToQuantity(value); // Quantity
} else if (name.equals("unitPrice")) {
this.unitPrice = castToMoney(value); // Money
} else if (name.equals("factor")) {
this.factor = castToDecimal(value); // DecimalType
} else if (name.equals("net")) {
this.net = castToMoney(value); // Money
} else if (name.equals("udi")) {
this.getUdi().add(castToReference(value));
} else if (name.equals("noteNumber")) {
this.getNoteNumber().add(castToPositiveInt(value));
} else if (name.equals("adjudication")) {
this.getAdjudication().add((AdjudicationComponent) value);
} else if (name.equals("subDetail")) {
this.getSubDetail().add((SubDetailComponent) value);
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = null;
} else if (name.equals("revenue")) {
this.revenue = null;
} else if (name.equals("category")) {
this.category = null;
} else if (name.equals("productOrService")) {
this.productOrService = null;
} else if (name.equals("modifier")) {
this.getModifier().remove(castToCodeableConcept(value));
} else if (name.equals("programCode")) {
this.getProgramCode().remove(castToCodeableConcept(value));
} else if (name.equals("quantity")) {
this.quantity = null;
} else if (name.equals("unitPrice")) {
this.unitPrice = null;
} else if (name.equals("factor")) {
this.factor = null;
} else if (name.equals("net")) {
this.net = null;
} else if (name.equals("udi")) {
this.getUdi().remove(castToReference(value));
} else if (name.equals("noteNumber")) {
this.getNoteNumber().remove(castToPositiveInt(value));
} else if (name.equals("adjudication")) {
this.getAdjudication().remove((AdjudicationComponent) value);
} else if (name.equals("subDetail")) {
this.getSubDetail().remove((SubDetailComponent) value);
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
return getSequenceElement();
case 1099842588:
return getRevenue();
case 50511102:
return getCategory();
case 1957227299:
return getProductOrService();
case -615513385:
return addModifier();
case 1010065041:
return addProgramCode();
case -1285004149:
return getQuantity();
case -486196699:
return getUnitPrice();
case -1282148017:
return getFactorElement();
case 108957:
return getNet();
case 115642:
return addUdi();
case -1110033957:
return addNoteNumberElement();
case -231349275:
return addAdjudication();
case -828829007:
return addSubDetail();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return new String[] { "positiveInt" };
case 1099842588:
/* revenue */ return new String[] { "CodeableConcept" };
case 50511102:
/* category */ return new String[] { "CodeableConcept" };
case 1957227299:
/* productOrService */ return new String[] { "CodeableConcept" };
case -615513385:
/* modifier */ return new String[] { "CodeableConcept" };
case 1010065041:
/* programCode */ return new String[] { "CodeableConcept" };
case -1285004149:
/* quantity */ return new String[] { "SimpleQuantity" };
case -486196699:
/* unitPrice */ return new String[] { "Money" };
case -1282148017:
/* factor */ return new String[] { "decimal" };
case 108957:
/* net */ return new String[] { "Money" };
case 115642:
/* udi */ return new String[] { "Reference" };
case -1110033957:
/* noteNumber */ return new String[] { "positiveInt" };
case -231349275:
/* adjudication */ return new String[] { "@ExplanationOfBenefit.item.adjudication" };
case -828829007:
/* subDetail */ return new String[] {};
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("sequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
} else if (name.equals("revenue")) {
this.revenue = new CodeableConcept();
return this.revenue;
} else if (name.equals("category")) {
this.category = new CodeableConcept();
return this.category;
} else if (name.equals("productOrService")) {
this.productOrService = new CodeableConcept();
return this.productOrService;
} else if (name.equals("modifier")) {
return addModifier();
} else if (name.equals("programCode")) {
return addProgramCode();
} else if (name.equals("quantity")) {
this.quantity = new Quantity();
return this.quantity;
} else if (name.equals("unitPrice")) {
this.unitPrice = new Money();
return this.unitPrice;
} else if (name.equals("factor")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.factor");
} else if (name.equals("net")) {
this.net = new Money();
return this.net;
} else if (name.equals("udi")) {
return addUdi();
} else if (name.equals("noteNumber")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.noteNumber");
} else if (name.equals("adjudication")) {
return addAdjudication();
} else if (name.equals("subDetail")) {
return addSubDetail();
} else
return super.addChild(name);
}
public DetailComponent copy() {
DetailComponent dst = new DetailComponent();
copyValues(dst);
return dst;
}
public void copyValues(DetailComponent dst) {
super.copyValues(dst);
dst.sequence = sequence == null ? null : sequence.copy();
dst.revenue = revenue == null ? null : revenue.copy();
dst.category = category == null ? null : category.copy();
dst.productOrService = productOrService == null ? null : productOrService.copy();
if (modifier != null) {
dst.modifier = new ArrayList();
for (CodeableConcept i : modifier)
dst.modifier.add(i.copy());
}
;
if (programCode != null) {
dst.programCode = new ArrayList();
for (CodeableConcept i : programCode)
dst.programCode.add(i.copy());
}
;
dst.quantity = quantity == null ? null : quantity.copy();
dst.unitPrice = unitPrice == null ? null : unitPrice.copy();
dst.factor = factor == null ? null : factor.copy();
dst.net = net == null ? null : net.copy();
if (udi != null) {
dst.udi = new ArrayList();
for (Reference i : udi)
dst.udi.add(i.copy());
}
;
if (noteNumber != null) {
dst.noteNumber = new ArrayList();
for (PositiveIntType i : noteNumber)
dst.noteNumber.add(i.copy());
}
;
if (adjudication != null) {
dst.adjudication = new ArrayList();
for (AdjudicationComponent i : adjudication)
dst.adjudication.add(i.copy());
}
;
if (subDetail != null) {
dst.subDetail = new ArrayList();
for (SubDetailComponent i : subDetail)
dst.subDetail.add(i.copy());
}
;
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof DetailComponent))
return false;
DetailComponent o = (DetailComponent) other_;
return compareDeep(sequence, o.sequence, true) && compareDeep(revenue, o.revenue, true)
&& compareDeep(category, o.category, true) && compareDeep(productOrService, o.productOrService, true)
&& compareDeep(modifier, o.modifier, true) && compareDeep(programCode, o.programCode, true)
&& compareDeep(quantity, o.quantity, true) && compareDeep(unitPrice, o.unitPrice, true)
&& compareDeep(factor, o.factor, true) && compareDeep(net, o.net, true) && compareDeep(udi, o.udi, true)
&& compareDeep(noteNumber, o.noteNumber, true) && compareDeep(adjudication, o.adjudication, true)
&& compareDeep(subDetail, o.subDetail, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof DetailComponent))
return false;
DetailComponent o = (DetailComponent) other_;
return compareValues(sequence, o.sequence, true) && compareValues(factor, o.factor, true)
&& compareValues(noteNumber, o.noteNumber, true);
}
public boolean isEmpty() {
return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, revenue, category, productOrService,
modifier, programCode, quantity, unitPrice, factor, net, udi, noteNumber, adjudication, subDetail);
}
public String fhirType() {
return "ExplanationOfBenefit.item.detail";
}
}
@Block()
public static class SubDetailComponent extends BackboneElement implements IBaseBackboneElement {
/**
* A claim detail line. Either a simple (a product or service) or a 'group' of
* sub-details which are simple items.
*/
@Child(name = "sequence", type = {
PositiveIntType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
@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.")
protected PositiveIntType sequence;
/**
* The type of revenue or cost center providing the product and/or service.
*/
@Child(name = "revenue", type = {
CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Revenue or cost center code", formalDefinition = "The type of revenue or cost center providing the product and/or service.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-revenue-center")
protected CodeableConcept revenue;
/**
* Code to identify the general type of benefits under which products and
* services are provided.
*/
@Child(name = "category", type = {
CodeableConcept.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Benefit classification", formalDefinition = "Code to identify the general type of benefits under which products and services are provided.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-benefitcategory")
protected CodeableConcept category;
/**
* When the value is a group code then this item collects a set of related claim
* details, otherwise this contains the product, service, drug or other billing
* code for the item.
*/
@Child(name = "productOrService", type = {
CodeableConcept.class }, order = 4, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Billing, service, product, or drug code", formalDefinition = "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-uscls")
protected CodeableConcept productOrService;
/**
* Item typification or modifiers codes to convey additional context for the
* product or service.
*/
@Child(name = "modifier", type = {
CodeableConcept.class }, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Service/Product billing modifiers", formalDefinition = "Item typification or modifiers codes to convey additional context for the product or service.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-modifiers")
protected List modifier;
/**
* Identifies the program under which this may be recovered.
*/
@Child(name = "programCode", type = {
CodeableConcept.class }, order = 6, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Program the product or service is provided under", formalDefinition = "Identifies the program under which this may be recovered.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-program-code")
protected List programCode;
/**
* The number of repetitions of a service or product.
*/
@Child(name = "quantity", type = { Quantity.class }, order = 7, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Count of products or services", formalDefinition = "The number of repetitions of a service or product.")
protected Quantity quantity;
/**
* 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.
*/
@Child(name = "unitPrice", type = { Money.class }, order = 8, min = 0, max = 1, modifier = false, summary = false)
@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.")
protected Money unitPrice;
/**
* 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.
*/
@Child(name = "factor", type = {
DecimalType.class }, order = 9, min = 0, max = 1, modifier = false, summary = false)
@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.")
protected DecimalType factor;
/**
* The quantity times the unit price for an additional service or product or
* charge.
*/
@Child(name = "net", type = { Money.class }, order = 10, min = 0, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Total item cost", formalDefinition = "The quantity times the unit price for an additional service or product or charge.")
protected Money net;
/**
* Unique Device Identifiers associated with this line item.
*/
@Child(name = "udi", type = {
Device.class }, order = 11, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Unique device identifier", formalDefinition = "Unique Device Identifiers associated with this line item.")
protected List udi;
/**
* The actual objects that are the target of the reference (Unique Device
* Identifiers associated with this line item.)
*/
protected List udiTarget;
/**
* The numbers associated with notes below which apply to the adjudication of
* this item.
*/
@Child(name = "noteNumber", type = {
PositiveIntType.class }, order = 12, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Applicable note numbers", formalDefinition = "The numbers associated with notes below which apply to the adjudication of this item.")
protected List noteNumber;
/**
* The adjudication results.
*/
@Child(name = "adjudication", type = {
AdjudicationComponent.class }, order = 13, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Subdetail level adjudication details", formalDefinition = "The adjudication results.")
protected List adjudication;
private static final long serialVersionUID = -996156853L;
/**
* Constructor
*/
public SubDetailComponent() {
super();
}
/**
* Constructor
*/
public SubDetailComponent(PositiveIntType sequence, CodeableConcept productOrService) {
super();
this.sequence = sequence;
this.productOrService = productOrService;
}
/**
* @return {@link #sequence} (A claim detail line. Either a simple (a product or
* service) or a 'group' of sub-details which are simple items.). This
* is the underlying object with id, value and extensions. The accessor
* "getSequence" gives direct access to the value
*/
public PositiveIntType getSequenceElement() {
if (this.sequence == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SubDetailComponent.sequence");
else if (Configuration.doAutoCreate())
this.sequence = new PositiveIntType(); // bb
return this.sequence;
}
public boolean hasSequenceElement() {
return this.sequence != null && !this.sequence.isEmpty();
}
public boolean hasSequence() {
return this.sequence != null && !this.sequence.isEmpty();
}
/**
* @param value {@link #sequence} (A claim detail line. Either a simple (a
* product or service) or a 'group' of sub-details which are simple
* items.). This is the underlying object with id, value and
* extensions. The accessor "getSequence" gives direct access to
* the value
*/
public SubDetailComponent setSequenceElement(PositiveIntType value) {
this.sequence = value;
return this;
}
/**
* @return A claim detail line. Either a simple (a product or service) or a
* 'group' of sub-details which are simple items.
*/
public int getSequence() {
return this.sequence == null || this.sequence.isEmpty() ? 0 : this.sequence.getValue();
}
/**
* @param value A claim detail line. Either a simple (a product or service) or a
* 'group' of sub-details which are simple items.
*/
public SubDetailComponent setSequence(int value) {
if (this.sequence == null)
this.sequence = new PositiveIntType();
this.sequence.setValue(value);
return this;
}
/**
* @return {@link #revenue} (The type of revenue or cost center providing the
* product and/or service.)
*/
public CodeableConcept getRevenue() {
if (this.revenue == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SubDetailComponent.revenue");
else if (Configuration.doAutoCreate())
this.revenue = new CodeableConcept(); // cc
return this.revenue;
}
public boolean hasRevenue() {
return this.revenue != null && !this.revenue.isEmpty();
}
/**
* @param value {@link #revenue} (The type of revenue or cost center providing
* the product and/or service.)
*/
public SubDetailComponent setRevenue(CodeableConcept value) {
this.revenue = value;
return this;
}
/**
* @return {@link #category} (Code to identify the general type of benefits
* under which products and services are provided.)
*/
public CodeableConcept getCategory() {
if (this.category == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SubDetailComponent.category");
else if (Configuration.doAutoCreate())
this.category = new CodeableConcept(); // cc
return this.category;
}
public boolean hasCategory() {
return this.category != null && !this.category.isEmpty();
}
/**
* @param value {@link #category} (Code to identify the general type of benefits
* under which products and services are provided.)
*/
public SubDetailComponent setCategory(CodeableConcept value) {
this.category = value;
return this;
}
/**
* @return {@link #productOrService} (When the value is a group code then this
* item collects a set of related claim details, otherwise this contains
* the product, service, drug or other billing code for the item.)
*/
public CodeableConcept getProductOrService() {
if (this.productOrService == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SubDetailComponent.productOrService");
else if (Configuration.doAutoCreate())
this.productOrService = new CodeableConcept(); // cc
return this.productOrService;
}
public boolean hasProductOrService() {
return this.productOrService != null && !this.productOrService.isEmpty();
}
/**
* @param value {@link #productOrService} (When the value is a group code then
* this item collects a set of related claim details, otherwise
* this contains the product, service, drug or other billing code
* for the item.)
*/
public SubDetailComponent setProductOrService(CodeableConcept value) {
this.productOrService = value;
return this;
}
/**
* @return {@link #modifier} (Item typification or modifiers codes to convey
* additional context for the product or service.)
*/
public List getModifier() {
if (this.modifier == null)
this.modifier = new ArrayList();
return this.modifier;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public SubDetailComponent setModifier(List theModifier) {
this.modifier = theModifier;
return this;
}
public boolean hasModifier() {
if (this.modifier == null)
return false;
for (CodeableConcept item : this.modifier)
if (!item.isEmpty())
return true;
return false;
}
public CodeableConcept addModifier() { // 3
CodeableConcept t = new CodeableConcept();
if (this.modifier == null)
this.modifier = new ArrayList();
this.modifier.add(t);
return t;
}
public SubDetailComponent addModifier(CodeableConcept t) { // 3
if (t == null)
return this;
if (this.modifier == null)
this.modifier = new ArrayList();
this.modifier.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #modifier}, creating
* it if it does not already exist
*/
public CodeableConcept getModifierFirstRep() {
if (getModifier().isEmpty()) {
addModifier();
}
return getModifier().get(0);
}
/**
* @return {@link #programCode} (Identifies the program under which this may be
* recovered.)
*/
public List getProgramCode() {
if (this.programCode == null)
this.programCode = new ArrayList();
return this.programCode;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public SubDetailComponent setProgramCode(List theProgramCode) {
this.programCode = theProgramCode;
return this;
}
public boolean hasProgramCode() {
if (this.programCode == null)
return false;
for (CodeableConcept item : this.programCode)
if (!item.isEmpty())
return true;
return false;
}
public CodeableConcept addProgramCode() { // 3
CodeableConcept t = new CodeableConcept();
if (this.programCode == null)
this.programCode = new ArrayList();
this.programCode.add(t);
return t;
}
public SubDetailComponent addProgramCode(CodeableConcept t) { // 3
if (t == null)
return this;
if (this.programCode == null)
this.programCode = new ArrayList();
this.programCode.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #programCode},
* creating it if it does not already exist
*/
public CodeableConcept getProgramCodeFirstRep() {
if (getProgramCode().isEmpty()) {
addProgramCode();
}
return getProgramCode().get(0);
}
/**
* @return {@link #quantity} (The number of repetitions of a service or
* product.)
*/
public Quantity getQuantity() {
if (this.quantity == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SubDetailComponent.quantity");
else if (Configuration.doAutoCreate())
this.quantity = new Quantity(); // cc
return this.quantity;
}
public boolean hasQuantity() {
return this.quantity != null && !this.quantity.isEmpty();
}
/**
* @param value {@link #quantity} (The number of repetitions of a service or
* product.)
*/
public SubDetailComponent setQuantity(Quantity value) {
this.quantity = value;
return this;
}
/**
* @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.)
*/
public Money getUnitPrice() {
if (this.unitPrice == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SubDetailComponent.unitPrice");
else if (Configuration.doAutoCreate())
this.unitPrice = new Money(); // cc
return this.unitPrice;
}
public boolean hasUnitPrice() {
return this.unitPrice != null && !this.unitPrice.isEmpty();
}
/**
* @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.)
*/
public SubDetailComponent setUnitPrice(Money value) {
this.unitPrice = value;
return this;
}
/**
* @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
*/
public DecimalType getFactorElement() {
if (this.factor == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SubDetailComponent.factor");
else if (Configuration.doAutoCreate())
this.factor = new DecimalType(); // bb
return this.factor;
}
public boolean hasFactorElement() {
return this.factor != null && !this.factor.isEmpty();
}
public boolean hasFactor() {
return this.factor != null && !this.factor.isEmpty();
}
/**
* @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
*/
public SubDetailComponent setFactorElement(DecimalType value) {
this.factor = value;
return this;
}
/**
* @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.
*/
public BigDecimal getFactor() {
return this.factor == null ? null : this.factor.getValue();
}
/**
* @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.
*/
public SubDetailComponent setFactor(BigDecimal value) {
if (value == null)
this.factor = null;
else {
if (this.factor == null)
this.factor = new DecimalType();
this.factor.setValue(value);
}
return this;
}
/**
* @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.
*/
public SubDetailComponent setFactor(long value) {
this.factor = new DecimalType();
this.factor.setValue(value);
return this;
}
/**
* @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.
*/
public SubDetailComponent setFactor(double value) {
this.factor = new DecimalType();
this.factor.setValue(value);
return this;
}
/**
* @return {@link #net} (The quantity times the unit price for an additional
* service or product or charge.)
*/
public Money getNet() {
if (this.net == null)
if (Configuration.errorOnAutoCreate())
throw new Error("Attempt to auto-create SubDetailComponent.net");
else if (Configuration.doAutoCreate())
this.net = new Money(); // cc
return this.net;
}
public boolean hasNet() {
return this.net != null && !this.net.isEmpty();
}
/**
* @param value {@link #net} (The quantity times the unit price for an
* additional service or product or charge.)
*/
public SubDetailComponent setNet(Money value) {
this.net = value;
return this;
}
/**
* @return {@link #udi} (Unique Device Identifiers associated with this line
* item.)
*/
public List getUdi() {
if (this.udi == null)
this.udi = new ArrayList();
return this.udi;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public SubDetailComponent setUdi(List theUdi) {
this.udi = theUdi;
return this;
}
public boolean hasUdi() {
if (this.udi == null)
return false;
for (Reference item : this.udi)
if (!item.isEmpty())
return true;
return false;
}
public Reference addUdi() { // 3
Reference t = new Reference();
if (this.udi == null)
this.udi = new ArrayList();
this.udi.add(t);
return t;
}
public SubDetailComponent addUdi(Reference t) { // 3
if (t == null)
return this;
if (this.udi == null)
this.udi = new ArrayList();
this.udi.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #udi}, creating it if
* it does not already exist
*/
public Reference getUdiFirstRep() {
if (getUdi().isEmpty()) {
addUdi();
}
return getUdi().get(0);
}
/**
* @deprecated Use Reference#setResource(IBaseResource) instead
*/
@Deprecated
public List getUdiTarget() {
if (this.udiTarget == null)
this.udiTarget = new ArrayList();
return this.udiTarget;
}
/**
* @deprecated Use Reference#setResource(IBaseResource) instead
*/
@Deprecated
public Device addUdiTarget() {
Device r = new Device();
if (this.udiTarget == null)
this.udiTarget = new ArrayList();
this.udiTarget.add(r);
return r;
}
/**
* @return {@link #noteNumber} (The numbers associated with notes below which
* apply to the adjudication of this item.)
*/
public List getNoteNumber() {
if (this.noteNumber == null)
this.noteNumber = new ArrayList();
return this.noteNumber;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public SubDetailComponent setNoteNumber(List theNoteNumber) {
this.noteNumber = theNoteNumber;
return this;
}
public boolean hasNoteNumber() {
if (this.noteNumber == null)
return false;
for (PositiveIntType item : this.noteNumber)
if (!item.isEmpty())
return true;
return false;
}
/**
* @return {@link #noteNumber} (The numbers associated with notes below which
* apply to the adjudication of this item.)
*/
public PositiveIntType addNoteNumberElement() {// 2
PositiveIntType t = new PositiveIntType();
if (this.noteNumber == null)
this.noteNumber = new ArrayList();
this.noteNumber.add(t);
return t;
}
/**
* @param value {@link #noteNumber} (The numbers associated with notes below
* which apply to the adjudication of this item.)
*/
public SubDetailComponent addNoteNumber(int value) { // 1
PositiveIntType t = new PositiveIntType();
t.setValue(value);
if (this.noteNumber == null)
this.noteNumber = new ArrayList();
this.noteNumber.add(t);
return this;
}
/**
* @param value {@link #noteNumber} (The numbers associated with notes below
* which apply to the adjudication of this item.)
*/
public boolean hasNoteNumber(int value) {
if (this.noteNumber == null)
return false;
for (PositiveIntType v : this.noteNumber)
if (v.getValue().equals(value)) // positiveInt
return true;
return false;
}
/**
* @return {@link #adjudication} (The adjudication results.)
*/
public List getAdjudication() {
if (this.adjudication == null)
this.adjudication = new ArrayList();
return this.adjudication;
}
/**
* @return Returns a reference to this
for easy method chaining
*/
public SubDetailComponent setAdjudication(List theAdjudication) {
this.adjudication = theAdjudication;
return this;
}
public boolean hasAdjudication() {
if (this.adjudication == null)
return false;
for (AdjudicationComponent item : this.adjudication)
if (!item.isEmpty())
return true;
return false;
}
public AdjudicationComponent addAdjudication() { // 3
AdjudicationComponent t = new AdjudicationComponent();
if (this.adjudication == null)
this.adjudication = new ArrayList();
this.adjudication.add(t);
return t;
}
public SubDetailComponent addAdjudication(AdjudicationComponent t) { // 3
if (t == null)
return this;
if (this.adjudication == null)
this.adjudication = new ArrayList();
this.adjudication.add(t);
return this;
}
/**
* @return The first repetition of repeating field {@link #adjudication},
* creating it if it does not already exist
*/
public AdjudicationComponent getAdjudicationFirstRep() {
if (getAdjudication().isEmpty()) {
addAdjudication();
}
return getAdjudication().get(0);
}
protected void listChildren(List children) {
super.listChildren(children);
children.add(new Property("sequence", "positiveInt",
"A claim detail line. Either a simple (a product or service) or a 'group' of sub-details which are simple items.",
0, 1, sequence));
children.add(new Property("revenue", "CodeableConcept",
"The type of revenue or cost center providing the product and/or service.", 0, 1, revenue));
children.add(new Property("category", "CodeableConcept",
"Code to identify the general type of benefits under which products and services are provided.", 0, 1,
category));
children.add(new Property("productOrService", "CodeableConcept",
"When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
0, 1, productOrService));
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));
children.add(new Property("programCode", "CodeableConcept",
"Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode));
children.add(new Property("quantity", "SimpleQuantity", "The number of repetitions of a service or product.", 0,
1, quantity));
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));
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));
children.add(new Property("net", "Money",
"The quantity times the unit price for an additional service or product or charge.", 0, 1, net));
children.add(new Property("udi", "Reference(Device)", "Unique Device Identifiers associated with this line item.",
0, java.lang.Integer.MAX_VALUE, udi));
children.add(new Property("noteNumber", "positiveInt",
"The numbers associated with notes below which apply to the adjudication of this item.", 0,
java.lang.Integer.MAX_VALUE, noteNumber));
children.add(new Property("adjudication", "@ExplanationOfBenefit.item.adjudication", "The adjudication results.",
0, java.lang.Integer.MAX_VALUE, adjudication));
}
@Override
public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
switch (_hash) {
case 1349547969:
/* sequence */ return new Property("sequence", "positiveInt",
"A claim detail line. Either a simple (a product or service) or a 'group' of sub-details which are simple items.",
0, 1, sequence);
case 1099842588:
/* revenue */ return new Property("revenue", "CodeableConcept",
"The type of revenue or cost center providing the product and/or service.", 0, 1, revenue);
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);
case 1957227299:
/* productOrService */ return new Property("productOrService", "CodeableConcept",
"When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.",
0, 1, productOrService);
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);
case 1010065041:
/* programCode */ return new Property("programCode", "CodeableConcept",
"Identifies the program under which this may be recovered.", 0, java.lang.Integer.MAX_VALUE, programCode);
case -1285004149:
/* quantity */ return new Property("quantity", "SimpleQuantity",
"The number of repetitions of a service or product.", 0, 1, quantity);
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);
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);
case 108957:
/* net */ return new Property("net", "Money",
"The quantity times the unit price for an additional service or product or charge.", 0, 1, net);
case 115642:
/* udi */ return new Property("udi", "Reference(Device)",
"Unique Device Identifiers associated with this line item.", 0, java.lang.Integer.MAX_VALUE, udi);
case -1110033957:
/* noteNumber */ return new Property("noteNumber", "positiveInt",
"The numbers associated with notes below which apply to the adjudication of this item.", 0,
java.lang.Integer.MAX_VALUE, noteNumber);
case -231349275:
/* adjudication */ return new Property("adjudication", "@ExplanationOfBenefit.item.adjudication",
"The adjudication results.", 0, java.lang.Integer.MAX_VALUE, adjudication);
default:
return super.getNamedProperty(_hash, _name, _checkValid);
}
}
@Override
public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return this.sequence == null ? new Base[0] : new Base[] { this.sequence }; // PositiveIntType
case 1099842588:
/* revenue */ return this.revenue == null ? new Base[0] : new Base[] { this.revenue }; // CodeableConcept
case 50511102:
/* category */ return this.category == null ? new Base[0] : new Base[] { this.category }; // CodeableConcept
case 1957227299:
/* productOrService */ return this.productOrService == null ? new Base[0]
: new Base[] { this.productOrService }; // CodeableConcept
case -615513385:
/* modifier */ return this.modifier == null ? new Base[0]
: this.modifier.toArray(new Base[this.modifier.size()]); // CodeableConcept
case 1010065041:
/* programCode */ return this.programCode == null ? new Base[0]
: this.programCode.toArray(new Base[this.programCode.size()]); // CodeableConcept
case -1285004149:
/* quantity */ return this.quantity == null ? new Base[0] : new Base[] { this.quantity }; // Quantity
case -486196699:
/* unitPrice */ return this.unitPrice == null ? new Base[0] : new Base[] { this.unitPrice }; // Money
case -1282148017:
/* factor */ return this.factor == null ? new Base[0] : new Base[] { this.factor }; // DecimalType
case 108957:
/* net */ return this.net == null ? new Base[0] : new Base[] { this.net }; // Money
case 115642:
/* udi */ return this.udi == null ? new Base[0] : this.udi.toArray(new Base[this.udi.size()]); // Reference
case -1110033957:
/* noteNumber */ return this.noteNumber == null ? new Base[0]
: this.noteNumber.toArray(new Base[this.noteNumber.size()]); // PositiveIntType
case -231349275:
/* adjudication */ return this.adjudication == null ? new Base[0]
: this.adjudication.toArray(new Base[this.adjudication.size()]); // AdjudicationComponent
default:
return super.getProperty(hash, name, checkValid);
}
}
@Override
public Base setProperty(int hash, String name, Base value) throws FHIRException {
switch (hash) {
case 1349547969: // sequence
this.sequence = castToPositiveInt(value); // PositiveIntType
return value;
case 1099842588: // revenue
this.revenue = castToCodeableConcept(value); // CodeableConcept
return value;
case 50511102: // category
this.category = castToCodeableConcept(value); // CodeableConcept
return value;
case 1957227299: // productOrService
this.productOrService = castToCodeableConcept(value); // CodeableConcept
return value;
case -615513385: // modifier
this.getModifier().add(castToCodeableConcept(value)); // CodeableConcept
return value;
case 1010065041: // programCode
this.getProgramCode().add(castToCodeableConcept(value)); // CodeableConcept
return value;
case -1285004149: // quantity
this.quantity = castToQuantity(value); // Quantity
return value;
case -486196699: // unitPrice
this.unitPrice = castToMoney(value); // Money
return value;
case -1282148017: // factor
this.factor = castToDecimal(value); // DecimalType
return value;
case 108957: // net
this.net = castToMoney(value); // Money
return value;
case 115642: // udi
this.getUdi().add(castToReference(value)); // Reference
return value;
case -1110033957: // noteNumber
this.getNoteNumber().add(castToPositiveInt(value)); // PositiveIntType
return value;
case -231349275: // adjudication
this.getAdjudication().add((AdjudicationComponent) value); // AdjudicationComponent
return value;
default:
return super.setProperty(hash, name, value);
}
}
@Override
public Base setProperty(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = castToPositiveInt(value); // PositiveIntType
} else if (name.equals("revenue")) {
this.revenue = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("category")) {
this.category = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("productOrService")) {
this.productOrService = castToCodeableConcept(value); // CodeableConcept
} else if (name.equals("modifier")) {
this.getModifier().add(castToCodeableConcept(value));
} else if (name.equals("programCode")) {
this.getProgramCode().add(castToCodeableConcept(value));
} else if (name.equals("quantity")) {
this.quantity = castToQuantity(value); // Quantity
} else if (name.equals("unitPrice")) {
this.unitPrice = castToMoney(value); // Money
} else if (name.equals("factor")) {
this.factor = castToDecimal(value); // DecimalType
} else if (name.equals("net")) {
this.net = castToMoney(value); // Money
} else if (name.equals("udi")) {
this.getUdi().add(castToReference(value));
} else if (name.equals("noteNumber")) {
this.getNoteNumber().add(castToPositiveInt(value));
} else if (name.equals("adjudication")) {
this.getAdjudication().add((AdjudicationComponent) value);
} else
return super.setProperty(name, value);
return value;
}
@Override
public void removeChild(String name, Base value) throws FHIRException {
if (name.equals("sequence")) {
this.sequence = null;
} else if (name.equals("revenue")) {
this.revenue = null;
} else if (name.equals("category")) {
this.category = null;
} else if (name.equals("productOrService")) {
this.productOrService = null;
} else if (name.equals("modifier")) {
this.getModifier().remove(castToCodeableConcept(value));
} else if (name.equals("programCode")) {
this.getProgramCode().remove(castToCodeableConcept(value));
} else if (name.equals("quantity")) {
this.quantity = null;
} else if (name.equals("unitPrice")) {
this.unitPrice = null;
} else if (name.equals("factor")) {
this.factor = null;
} else if (name.equals("net")) {
this.net = null;
} else if (name.equals("udi")) {
this.getUdi().remove(castToReference(value));
} else if (name.equals("noteNumber")) {
this.getNoteNumber().remove(castToPositiveInt(value));
} else if (name.equals("adjudication")) {
this.getAdjudication().remove((AdjudicationComponent) value);
} else
super.removeChild(name, value);
}
@Override
public Base makeProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
return getSequenceElement();
case 1099842588:
return getRevenue();
case 50511102:
return getCategory();
case 1957227299:
return getProductOrService();
case -615513385:
return addModifier();
case 1010065041:
return addProgramCode();
case -1285004149:
return getQuantity();
case -486196699:
return getUnitPrice();
case -1282148017:
return getFactorElement();
case 108957:
return getNet();
case 115642:
return addUdi();
case -1110033957:
return addNoteNumberElement();
case -231349275:
return addAdjudication();
default:
return super.makeProperty(hash, name);
}
}
@Override
public String[] getTypesForProperty(int hash, String name) throws FHIRException {
switch (hash) {
case 1349547969:
/* sequence */ return new String[] { "positiveInt" };
case 1099842588:
/* revenue */ return new String[] { "CodeableConcept" };
case 50511102:
/* category */ return new String[] { "CodeableConcept" };
case 1957227299:
/* productOrService */ return new String[] { "CodeableConcept" };
case -615513385:
/* modifier */ return new String[] { "CodeableConcept" };
case 1010065041:
/* programCode */ return new String[] { "CodeableConcept" };
case -1285004149:
/* quantity */ return new String[] { "SimpleQuantity" };
case -486196699:
/* unitPrice */ return new String[] { "Money" };
case -1282148017:
/* factor */ return new String[] { "decimal" };
case 108957:
/* net */ return new String[] { "Money" };
case 115642:
/* udi */ return new String[] { "Reference" };
case -1110033957:
/* noteNumber */ return new String[] { "positiveInt" };
case -231349275:
/* adjudication */ return new String[] { "@ExplanationOfBenefit.item.adjudication" };
default:
return super.getTypesForProperty(hash, name);
}
}
@Override
public Base addChild(String name) throws FHIRException {
if (name.equals("sequence")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.sequence");
} else if (name.equals("revenue")) {
this.revenue = new CodeableConcept();
return this.revenue;
} else if (name.equals("category")) {
this.category = new CodeableConcept();
return this.category;
} else if (name.equals("productOrService")) {
this.productOrService = new CodeableConcept();
return this.productOrService;
} else if (name.equals("modifier")) {
return addModifier();
} else if (name.equals("programCode")) {
return addProgramCode();
} else if (name.equals("quantity")) {
this.quantity = new Quantity();
return this.quantity;
} else if (name.equals("unitPrice")) {
this.unitPrice = new Money();
return this.unitPrice;
} else if (name.equals("factor")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.factor");
} else if (name.equals("net")) {
this.net = new Money();
return this.net;
} else if (name.equals("udi")) {
return addUdi();
} else if (name.equals("noteNumber")) {
throw new FHIRException("Cannot call addChild on a singleton property ExplanationOfBenefit.noteNumber");
} else if (name.equals("adjudication")) {
return addAdjudication();
} else
return super.addChild(name);
}
public SubDetailComponent copy() {
SubDetailComponent dst = new SubDetailComponent();
copyValues(dst);
return dst;
}
public void copyValues(SubDetailComponent dst) {
super.copyValues(dst);
dst.sequence = sequence == null ? null : sequence.copy();
dst.revenue = revenue == null ? null : revenue.copy();
dst.category = category == null ? null : category.copy();
dst.productOrService = productOrService == null ? null : productOrService.copy();
if (modifier != null) {
dst.modifier = new ArrayList();
for (CodeableConcept i : modifier)
dst.modifier.add(i.copy());
}
;
if (programCode != null) {
dst.programCode = new ArrayList();
for (CodeableConcept i : programCode)
dst.programCode.add(i.copy());
}
;
dst.quantity = quantity == null ? null : quantity.copy();
dst.unitPrice = unitPrice == null ? null : unitPrice.copy();
dst.factor = factor == null ? null : factor.copy();
dst.net = net == null ? null : net.copy();
if (udi != null) {
dst.udi = new ArrayList();
for (Reference i : udi)
dst.udi.add(i.copy());
}
;
if (noteNumber != null) {
dst.noteNumber = new ArrayList();
for (PositiveIntType i : noteNumber)
dst.noteNumber.add(i.copy());
}
;
if (adjudication != null) {
dst.adjudication = new ArrayList();
for (AdjudicationComponent i : adjudication)
dst.adjudication.add(i.copy());
}
;
}
@Override
public boolean equalsDeep(Base other_) {
if (!super.equalsDeep(other_))
return false;
if (!(other_ instanceof SubDetailComponent))
return false;
SubDetailComponent o = (SubDetailComponent) other_;
return compareDeep(sequence, o.sequence, true) && compareDeep(revenue, o.revenue, true)
&& compareDeep(category, o.category, true) && compareDeep(productOrService, o.productOrService, true)
&& compareDeep(modifier, o.modifier, true) && compareDeep(programCode, o.programCode, true)
&& compareDeep(quantity, o.quantity, true) && compareDeep(unitPrice, o.unitPrice, true)
&& compareDeep(factor, o.factor, true) && compareDeep(net, o.net, true) && compareDeep(udi, o.udi, true)
&& compareDeep(noteNumber, o.noteNumber, true) && compareDeep(adjudication, o.adjudication, true);
}
@Override
public boolean equalsShallow(Base other_) {
if (!super.equalsShallow(other_))
return false;
if (!(other_ instanceof SubDetailComponent))
return false;
SubDetailComponent o = (SubDetailComponent) other_;
return compareValues(sequence, o.sequence, true) && compareValues(factor, o.factor, true)
&& compareValues(noteNumber, o.noteNumber, true);
}
public boolean isEmpty() {
return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(sequence, revenue, category, productOrService,
modifier, programCode, quantity, unitPrice, factor, net, udi, noteNumber, adjudication);
}
public String fhirType() {
return "ExplanationOfBenefit.item.detail.subDetail";
}
}
@Block()
public static class AddedItemComponent extends BackboneElement implements IBaseBackboneElement {
/**
* Claim items which this service line is intended to replace.
*/
@Child(name = "itemSequence", type = {
PositiveIntType.class }, order = 1, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Item sequence number", formalDefinition = "Claim items which this service line is intended to replace.")
protected List itemSequence;
/**
* The sequence number of the details within the claim item which this line is
* intended to replace.
*/
@Child(name = "detailSequence", type = {
PositiveIntType.class }, order = 2, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Detail sequence number", formalDefinition = "The sequence number of the details within the claim item which this line is intended to replace.")
protected List detailSequence;
/**
* The sequence number of the sub-details woithin the details within the claim
* item which this line is intended to replace.
*/
@Child(name = "subDetailSequence", type = {
PositiveIntType.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Subdetail sequence number", formalDefinition = "The sequence number of the sub-details woithin the details within the claim item which this line is intended to replace.")
protected List subDetailSequence;
/**
* The providers who are authorized for the services rendered to the patient.
*/
@Child(name = "provider", type = { Practitioner.class, PractitionerRole.class,
Organization.class }, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Authorized providers", formalDefinition = "The providers who are authorized for the services rendered to the patient.")
protected List provider;
/**
* The actual objects that are the target of the reference (The providers who
* are authorized for the services rendered to the patient.)
*/
protected List providerTarget;
/**
* When the value is a group code then this item collects a set of related claim
* details, otherwise this contains the product, service, drug or other billing
* code for the item.
*/
@Child(name = "productOrService", type = {
CodeableConcept.class }, order = 5, min = 1, max = 1, modifier = false, summary = false)
@Description(shortDefinition = "Billing, service, product, or drug code", formalDefinition = "When the value is a group code then this item collects a set of related claim details, otherwise this contains the product, service, drug or other billing code for the item.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/service-uscls")
protected CodeableConcept productOrService;
/**
* Item typification or modifiers codes to convey additional context for the
* product or service.
*/
@Child(name = "modifier", type = {
CodeableConcept.class }, order = 6, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Service/Product billing modifiers", formalDefinition = "Item typification or modifiers codes to convey additional context for the product or service.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/claim-modifiers")
protected List modifier;
/**
* Identifies the program under which this may be recovered.
*/
@Child(name = "programCode", type = {
CodeableConcept.class }, order = 7, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
@Description(shortDefinition = "Program the product or service is provided under", formalDefinition = "Identifies the program under which this may be recovered.")
@ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/ex-program-code")
protected List