package org.hl7.fhir.dstu3.model; /* 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 Mon, Apr 17, 2017 17:38-0400 for FHIR v3.0.1 import java.util.*; import org.hl7.fhir.utilities.Utilities; import ca.uhn.fhir.model.api.annotation.ResourceDef; import ca.uhn.fhir.model.api.annotation.SearchParamDefinition; import ca.uhn.fhir.model.api.annotation.Child; import ca.uhn.fhir.model.api.annotation.ChildOrder; import ca.uhn.fhir.model.api.annotation.Description; import ca.uhn.fhir.model.api.annotation.Block; import org.hl7.fhir.instance.model.api.*; import org.hl7.fhir.exceptions.FHIRException; /** * This resource provides the status of the payment for goods and services rendered, and the request and response resource references. */ @ResourceDef(name="PaymentNotice", profile="http://hl7.org/fhir/Profile/PaymentNotice") public class PaymentNotice extends DomainResource { public enum PaymentNoticeStatus { /** * The instance is currently in-force. */ ACTIVE, /** * The instance is withdrawn, rescinded or reversed. */ CANCELLED, /** * A new instance the contents of which is not complete. */ DRAFT, /** * The instance was entered in error. */ ENTEREDINERROR, /** * added to help the parsers with the generic types */ NULL; public static PaymentNoticeStatus 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 PaymentNoticeStatus 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"; default: return "?"; } } public String getSystem() { switch (this) { case ACTIVE: return "http://hl7.org/fhir/fm-status"; case CANCELLED: return "http://hl7.org/fhir/fm-status"; case DRAFT: return "http://hl7.org/fhir/fm-status"; case ENTEREDINERROR: return "http://hl7.org/fhir/fm-status"; default: return "?"; } } public String getDefinition() { switch (this) { case ACTIVE: return "The instance is currently in-force."; case CANCELLED: return "The instance is withdrawn, rescinded or reversed."; case DRAFT: return "A new instance the contents of which is not complete."; case ENTEREDINERROR: return "The instance was entered in error."; 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"; default: return "?"; } } } public static class PaymentNoticeStatusEnumFactory implements EnumFactory<PaymentNoticeStatus> { public PaymentNoticeStatus fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("active".equals(codeString)) return PaymentNoticeStatus.ACTIVE; if ("cancelled".equals(codeString)) return PaymentNoticeStatus.CANCELLED; if ("draft".equals(codeString)) return PaymentNoticeStatus.DRAFT; if ("entered-in-error".equals(codeString)) return PaymentNoticeStatus.ENTEREDINERROR; throw new IllegalArgumentException("Unknown PaymentNoticeStatus code '"+codeString+"'"); } public Enumeration<PaymentNoticeStatus> fromType(Base code) throws FHIRException { if (code == null) return null; if (code.isEmpty()) return new Enumeration<PaymentNoticeStatus>(this); String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("active".equals(codeString)) return new Enumeration<PaymentNoticeStatus>(this, PaymentNoticeStatus.ACTIVE); if ("cancelled".equals(codeString)) return new Enumeration<PaymentNoticeStatus>(this, PaymentNoticeStatus.CANCELLED); if ("draft".equals(codeString)) return new Enumeration<PaymentNoticeStatus>(this, PaymentNoticeStatus.DRAFT); if ("entered-in-error".equals(codeString)) return new Enumeration<PaymentNoticeStatus>(this, PaymentNoticeStatus.ENTEREDINERROR); throw new FHIRException("Unknown PaymentNoticeStatus code '"+codeString+"'"); } public String toCode(PaymentNoticeStatus code) { if (code == PaymentNoticeStatus.ACTIVE) return "active"; if (code == PaymentNoticeStatus.CANCELLED) return "cancelled"; if (code == PaymentNoticeStatus.DRAFT) return "draft"; if (code == PaymentNoticeStatus.ENTEREDINERROR) return "entered-in-error"; return "?"; } public String toSystem(PaymentNoticeStatus code) { return code.getSystem(); } } /** * The notice business identifier. */ @Child(name = "identifier", type = {Identifier.class}, order=0, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Business Identifier", formalDefinition="The notice business identifier." ) protected List<Identifier> identifier; /** * The status of the resource instance. */ @Child(name = "status", type = {CodeType.class}, order=1, min=0, max=1, modifier=true, summary=true) @Description(shortDefinition="active | cancelled | draft | entered-in-error", formalDefinition="The status of the resource instance." ) @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/fm-status") protected Enumeration<PaymentNoticeStatus> status; /** * Reference of resource for which payment is being made. */ @Child(name = "request", type = {Reference.class}, order=2, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Request reference", formalDefinition="Reference of resource for which payment is being made." ) protected Reference request; /** * The actual object that is the target of the reference (Reference of resource for which payment is being made.) */ protected Resource requestTarget; /** * Reference of response to resource for which payment is being made. */ @Child(name = "response", type = {Reference.class}, order=3, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Response reference", formalDefinition="Reference of response to resource for which payment is being made." ) protected Reference response; /** * The actual object that is the target of the reference (Reference of response to resource for which payment is being made.) */ protected Resource responseTarget; /** * The date when the above payment action occurrred. */ @Child(name = "statusDate", type = {DateType.class}, order=4, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Payment or clearing date", formalDefinition="The date when the above payment action occurrred." ) protected DateType statusDate; /** * The date when this resource was created. */ @Child(name = "created", type = {DateTimeType.class}, order=5, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Creation date", formalDefinition="The date when this resource was created." ) protected DateTimeType created; /** * The Insurer who is target of the request. */ @Child(name = "target", type = {Organization.class}, order=6, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Insurer or Regulatory body", formalDefinition="The Insurer who is target of the request." ) protected Reference target; /** * The actual object that is the target of the reference (The Insurer who is target of the request.) */ protected Organization targetTarget; /** * The practitioner who is responsible for the services rendered to the patient. */ @Child(name = "provider", type = {Practitioner.class}, order=7, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Responsible practitioner", formalDefinition="The practitioner who is responsible for the services rendered to the patient." ) protected Reference provider; /** * The actual object that is the target of the reference (The practitioner who is responsible for the services rendered to the patient.) */ protected Practitioner providerTarget; /** * The organization which is responsible for the services rendered to the patient. */ @Child(name = "organization", type = {Organization.class}, order=8, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Responsible organization", formalDefinition="The organization which is responsible for the services rendered to the patient." ) protected Reference organization; /** * The actual object that is the target of the reference (The organization which is responsible for the services rendered to the patient.) */ protected Organization organizationTarget; /** * The payment status, typically paid: payment sent, cleared: payment received. */ @Child(name = "paymentStatus", type = {CodeableConcept.class}, order=9, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Whether payment has been sent or cleared", formalDefinition="The payment status, typically paid: payment sent, cleared: payment received." ) @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/payment-status") protected CodeableConcept paymentStatus; private static final long serialVersionUID = 37278603L; /** * Constructor */ public PaymentNotice() { super(); } /** * @return {@link #identifier} (The notice business identifier.) */ public List<Identifier> getIdentifier() { if (this.identifier == null) this.identifier = new ArrayList<Identifier>(); return this.identifier; } /** * @return Returns a reference to <code>this</code> for easy method chaining */ public PaymentNotice setIdentifier(List<Identifier> theIdentifier) { this.identifier = theIdentifier; return this; } public boolean hasIdentifier() { if (this.identifier == null) return false; for (Identifier item : this.identifier) if (!item.isEmpty()) return true; return false; } public Identifier addIdentifier() { //3 Identifier t = new Identifier(); if (this.identifier == null) this.identifier = new ArrayList<Identifier>(); this.identifier.add(t); return t; } public PaymentNotice addIdentifier(Identifier t) { //3 if (t == null) return this; if (this.identifier == null) this.identifier = new ArrayList<Identifier>(); this.identifier.add(t); return this; } /** * @return The first repetition of repeating field {@link #identifier}, creating it if it does not already exist */ public Identifier getIdentifierFirstRep() { if (getIdentifier().isEmpty()) { addIdentifier(); } return getIdentifier().get(0); } /** * @return {@link #status} (The status of the resource instance.). This is the underlying object with id, value and extensions. The accessor "getStatus" gives direct access to the value */ public Enumeration<PaymentNoticeStatus> getStatusElement() { if (this.status == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.status"); else if (Configuration.doAutoCreate()) this.status = new Enumeration<PaymentNoticeStatus>(new PaymentNoticeStatusEnumFactory()); // bb return this.status; } public boolean hasStatusElement() { return this.status != null && !this.status.isEmpty(); } public boolean hasStatus() { return this.status != null && !this.status.isEmpty(); } /** * @param value {@link #status} (The status of the resource instance.). This is the underlying object with id, value and extensions. The accessor "getStatus" gives direct access to the value */ public PaymentNotice setStatusElement(Enumeration<PaymentNoticeStatus> value) { this.status = value; return this; } /** * @return The status of the resource instance. */ public PaymentNoticeStatus getStatus() { return this.status == null ? null : this.status.getValue(); } /** * @param value The status of the resource instance. */ public PaymentNotice setStatus(PaymentNoticeStatus value) { if (value == null) this.status = null; else { if (this.status == null) this.status = new Enumeration<PaymentNoticeStatus>(new PaymentNoticeStatusEnumFactory()); this.status.setValue(value); } return this; } /** * @return {@link #request} (Reference of resource for which payment is being made.) */ public Reference getRequest() { if (this.request == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.request"); else if (Configuration.doAutoCreate()) this.request = new Reference(); // cc return this.request; } public boolean hasRequest() { return this.request != null && !this.request.isEmpty(); } /** * @param value {@link #request} (Reference of resource for which payment is being made.) */ public PaymentNotice setRequest(Reference value) { this.request = value; return this; } /** * @return {@link #request} 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 of resource for which payment is being made.) */ public Resource getRequestTarget() { return this.requestTarget; } /** * @param value {@link #request} 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 of resource for which payment is being made.) */ public PaymentNotice setRequestTarget(Resource value) { this.requestTarget = value; return this; } /** * @return {@link #response} (Reference of response to resource for which payment is being made.) */ public Reference getResponse() { if (this.response == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.response"); else if (Configuration.doAutoCreate()) this.response = new Reference(); // cc return this.response; } public boolean hasResponse() { return this.response != null && !this.response.isEmpty(); } /** * @param value {@link #response} (Reference of response to resource for which payment is being made.) */ public PaymentNotice setResponse(Reference value) { this.response = value; return this; } /** * @return {@link #response} 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 of response to resource for which payment is being made.) */ public Resource getResponseTarget() { return this.responseTarget; } /** * @param value {@link #response} 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 of response to resource for which payment is being made.) */ public PaymentNotice setResponseTarget(Resource value) { this.responseTarget = value; return this; } /** * @return {@link #statusDate} (The date when the above payment action occurrred.). This is the underlying object with id, value and extensions. The accessor "getStatusDate" gives direct access to the value */ public DateType getStatusDateElement() { if (this.statusDate == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.statusDate"); else if (Configuration.doAutoCreate()) this.statusDate = new DateType(); // bb return this.statusDate; } public boolean hasStatusDateElement() { return this.statusDate != null && !this.statusDate.isEmpty(); } public boolean hasStatusDate() { return this.statusDate != null && !this.statusDate.isEmpty(); } /** * @param value {@link #statusDate} (The date when the above payment action occurrred.). This is the underlying object with id, value and extensions. The accessor "getStatusDate" gives direct access to the value */ public PaymentNotice setStatusDateElement(DateType value) { this.statusDate = value; return this; } /** * @return The date when the above payment action occurrred. */ public Date getStatusDate() { return this.statusDate == null ? null : this.statusDate.getValue(); } /** * @param value The date when the above payment action occurrred. */ public PaymentNotice setStatusDate(Date value) { if (value == null) this.statusDate = null; else { if (this.statusDate == null) this.statusDate = new DateType(); this.statusDate.setValue(value); } return this; } /** * @return {@link #created} (The date when this resource was created.). This is the underlying object with id, value and extensions. The accessor "getCreated" gives direct access to the value */ public DateTimeType getCreatedElement() { if (this.created == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.created"); else if (Configuration.doAutoCreate()) this.created = new DateTimeType(); // bb return this.created; } public boolean hasCreatedElement() { return this.created != null && !this.created.isEmpty(); } public boolean hasCreated() { return this.created != null && !this.created.isEmpty(); } /** * @param value {@link #created} (The date when this resource was created.). This is the underlying object with id, value and extensions. The accessor "getCreated" gives direct access to the value */ public PaymentNotice setCreatedElement(DateTimeType value) { this.created = value; return this; } /** * @return The date when this resource was created. */ public Date getCreated() { return this.created == null ? null : this.created.getValue(); } /** * @param value The date when this resource was created. */ public PaymentNotice setCreated(Date value) { if (value == null) this.created = null; else { if (this.created == null) this.created = new DateTimeType(); this.created.setValue(value); } return this; } /** * @return {@link #target} (The Insurer who is target of the request.) */ public Reference getTarget() { if (this.target == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.target"); else if (Configuration.doAutoCreate()) this.target = new Reference(); // cc return this.target; } public boolean hasTarget() { return this.target != null && !this.target.isEmpty(); } /** * @param value {@link #target} (The Insurer who is target of the request.) */ public PaymentNotice setTarget(Reference value) { this.target = value; return this; } /** * @return {@link #target} 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. (The Insurer who is target of the request.) */ public Organization getTargetTarget() { if (this.targetTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.target"); else if (Configuration.doAutoCreate()) this.targetTarget = new Organization(); // aa return this.targetTarget; } /** * @param value {@link #target} 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. (The Insurer who is target of the request.) */ public PaymentNotice setTargetTarget(Organization value) { this.targetTarget = value; return this; } /** * @return {@link #provider} (The practitioner who is responsible for the services rendered to the patient.) */ public Reference getProvider() { if (this.provider == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.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} (The practitioner who is responsible for the services rendered to the patient.) */ public PaymentNotice 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. (The practitioner who is responsible for the services rendered to the patient.) */ public Practitioner getProviderTarget() { if (this.providerTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.provider"); else if (Configuration.doAutoCreate()) this.providerTarget = new Practitioner(); // aa 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. (The practitioner who is responsible for the services rendered to the patient.) */ public PaymentNotice setProviderTarget(Practitioner value) { this.providerTarget = value; return this; } /** * @return {@link #organization} (The organization which is responsible for the services rendered to the patient.) */ public Reference getOrganization() { if (this.organization == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.organization"); else if (Configuration.doAutoCreate()) this.organization = new Reference(); // cc return this.organization; } public boolean hasOrganization() { return this.organization != null && !this.organization.isEmpty(); } /** * @param value {@link #organization} (The organization which is responsible for the services rendered to the patient.) */ public PaymentNotice setOrganization(Reference value) { this.organization = value; return this; } /** * @return {@link #organization} 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. (The organization which is responsible for the services rendered to the patient.) */ public Organization getOrganizationTarget() { if (this.organizationTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.organization"); else if (Configuration.doAutoCreate()) this.organizationTarget = new Organization(); // aa return this.organizationTarget; } /** * @param value {@link #organization} 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. (The organization which is responsible for the services rendered to the patient.) */ public PaymentNotice setOrganizationTarget(Organization value) { this.organizationTarget = value; return this; } /** * @return {@link #paymentStatus} (The payment status, typically paid: payment sent, cleared: payment received.) */ public CodeableConcept getPaymentStatus() { if (this.paymentStatus == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create PaymentNotice.paymentStatus"); else if (Configuration.doAutoCreate()) this.paymentStatus = new CodeableConcept(); // cc return this.paymentStatus; } public boolean hasPaymentStatus() { return this.paymentStatus != null && !this.paymentStatus.isEmpty(); } /** * @param value {@link #paymentStatus} (The payment status, typically paid: payment sent, cleared: payment received.) */ public PaymentNotice setPaymentStatus(CodeableConcept value) { this.paymentStatus = value; return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("identifier", "Identifier", "The notice business identifier.", 0, java.lang.Integer.MAX_VALUE, identifier)); childrenList.add(new Property("status", "code", "The status of the resource instance.", 0, java.lang.Integer.MAX_VALUE, status)); childrenList.add(new Property("request", "Reference(Any)", "Reference of resource for which payment is being made.", 0, java.lang.Integer.MAX_VALUE, request)); childrenList.add(new Property("response", "Reference(Any)", "Reference of response to resource for which payment is being made.", 0, java.lang.Integer.MAX_VALUE, response)); childrenList.add(new Property("statusDate", "date", "The date when the above payment action occurrred.", 0, java.lang.Integer.MAX_VALUE, statusDate)); childrenList.add(new Property("created", "dateTime", "The date when this resource was created.", 0, java.lang.Integer.MAX_VALUE, created)); childrenList.add(new Property("target", "Reference(Organization)", "The Insurer who is target of the request.", 0, java.lang.Integer.MAX_VALUE, target)); childrenList.add(new Property("provider", "Reference(Practitioner)", "The practitioner who is responsible for the services rendered to the patient.", 0, java.lang.Integer.MAX_VALUE, provider)); childrenList.add(new Property("organization", "Reference(Organization)", "The organization which is responsible for the services rendered to the patient.", 0, java.lang.Integer.MAX_VALUE, organization)); childrenList.add(new Property("paymentStatus", "CodeableConcept", "The payment status, typically paid: payment sent, cleared: payment received.", 0, java.lang.Integer.MAX_VALUE, paymentStatus)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case -1618432855: /*identifier*/ return this.identifier == null ? new Base[0] : this.identifier.toArray(new Base[this.identifier.size()]); // Identifier case -892481550: /*status*/ return this.status == null ? new Base[0] : new Base[] {this.status}; // Enumeration<PaymentNoticeStatus> case 1095692943: /*request*/ return this.request == null ? new Base[0] : new Base[] {this.request}; // Reference case -340323263: /*response*/ return this.response == null ? new Base[0] : new Base[] {this.response}; // Reference case 247524032: /*statusDate*/ return this.statusDate == null ? new Base[0] : new Base[] {this.statusDate}; // DateType case 1028554472: /*created*/ return this.created == null ? new Base[0] : new Base[] {this.created}; // DateTimeType case -880905839: /*target*/ return this.target == null ? new Base[0] : new Base[] {this.target}; // Reference case -987494927: /*provider*/ return this.provider == null ? new Base[0] : new Base[] {this.provider}; // Reference case 1178922291: /*organization*/ return this.organization == null ? new Base[0] : new Base[] {this.organization}; // Reference case 1430704536: /*paymentStatus*/ return this.paymentStatus == null ? new Base[0] : new Base[] {this.paymentStatus}; // CodeableConcept default: return super.getProperty(hash, name, checkValid); } } @Override public Base setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case -1618432855: // identifier this.getIdentifier().add(castToIdentifier(value)); // Identifier return value; case -892481550: // status value = new PaymentNoticeStatusEnumFactory().fromType(castToCode(value)); this.status = (Enumeration) value; // Enumeration<PaymentNoticeStatus> return value; case 1095692943: // request this.request = castToReference(value); // Reference return value; case -340323263: // response this.response = castToReference(value); // Reference return value; case 247524032: // statusDate this.statusDate = castToDate(value); // DateType return value; case 1028554472: // created this.created = castToDateTime(value); // DateTimeType return value; case -880905839: // target this.target = castToReference(value); // Reference return value; case -987494927: // provider this.provider = castToReference(value); // Reference return value; case 1178922291: // organization this.organization = castToReference(value); // Reference return value; case 1430704536: // paymentStatus this.paymentStatus = 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("identifier")) { this.getIdentifier().add(castToIdentifier(value)); } else if (name.equals("status")) { value = new PaymentNoticeStatusEnumFactory().fromType(castToCode(value)); this.status = (Enumeration) value; // Enumeration<PaymentNoticeStatus> } else if (name.equals("request")) { this.request = castToReference(value); // Reference } else if (name.equals("response")) { this.response = castToReference(value); // Reference } else if (name.equals("statusDate")) { this.statusDate = castToDate(value); // DateType } else if (name.equals("created")) { this.created = castToDateTime(value); // DateTimeType } else if (name.equals("target")) { this.target = castToReference(value); // Reference } else if (name.equals("provider")) { this.provider = castToReference(value); // Reference } else if (name.equals("organization")) { this.organization = castToReference(value); // Reference } else if (name.equals("paymentStatus")) { this.paymentStatus = castToCodeableConcept(value); // CodeableConcept } else return super.setProperty(name, value); return value; } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case -1618432855: return addIdentifier(); case -892481550: return getStatusElement(); case 1095692943: return getRequest(); case -340323263: return getResponse(); case 247524032: return getStatusDateElement(); case 1028554472: return getCreatedElement(); case -880905839: return getTarget(); case -987494927: return getProvider(); case 1178922291: return getOrganization(); case 1430704536: return getPaymentStatus(); default: return super.makeProperty(hash, name); } } @Override public String[] getTypesForProperty(int hash, String name) throws FHIRException { switch (hash) { case -1618432855: /*identifier*/ return new String[] {"Identifier"}; case -892481550: /*status*/ return new String[] {"code"}; case 1095692943: /*request*/ return new String[] {"Reference"}; case -340323263: /*response*/ return new String[] {"Reference"}; case 247524032: /*statusDate*/ return new String[] {"date"}; case 1028554472: /*created*/ return new String[] {"dateTime"}; case -880905839: /*target*/ return new String[] {"Reference"}; case -987494927: /*provider*/ return new String[] {"Reference"}; case 1178922291: /*organization*/ return new String[] {"Reference"}; case 1430704536: /*paymentStatus*/ return new String[] {"CodeableConcept"}; default: return super.getTypesForProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("identifier")) { return addIdentifier(); } else if (name.equals("status")) { throw new FHIRException("Cannot call addChild on a primitive type PaymentNotice.status"); } else if (name.equals("request")) { this.request = new Reference(); return this.request; } else if (name.equals("response")) { this.response = new Reference(); return this.response; } else if (name.equals("statusDate")) { throw new FHIRException("Cannot call addChild on a primitive type PaymentNotice.statusDate"); } else if (name.equals("created")) { throw new FHIRException("Cannot call addChild on a primitive type PaymentNotice.created"); } else if (name.equals("target")) { this.target = new Reference(); return this.target; } else if (name.equals("provider")) { this.provider = new Reference(); return this.provider; } else if (name.equals("organization")) { this.organization = new Reference(); return this.organization; } else if (name.equals("paymentStatus")) { this.paymentStatus = new CodeableConcept(); return this.paymentStatus; } else return super.addChild(name); } public String fhirType() { return "PaymentNotice"; } public PaymentNotice copy() { PaymentNotice dst = new PaymentNotice(); copyValues(dst); if (identifier != null) { dst.identifier = new ArrayList<Identifier>(); for (Identifier i : identifier) dst.identifier.add(i.copy()); }; dst.status = status == null ? null : status.copy(); dst.request = request == null ? null : request.copy(); dst.response = response == null ? null : response.copy(); dst.statusDate = statusDate == null ? null : statusDate.copy(); dst.created = created == null ? null : created.copy(); dst.target = target == null ? null : target.copy(); dst.provider = provider == null ? null : provider.copy(); dst.organization = organization == null ? null : organization.copy(); dst.paymentStatus = paymentStatus == null ? null : paymentStatus.copy(); return dst; } protected PaymentNotice typedCopy() { return copy(); } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof PaymentNotice)) return false; PaymentNotice o = (PaymentNotice) other; return compareDeep(identifier, o.identifier, true) && compareDeep(status, o.status, true) && compareDeep(request, o.request, true) && compareDeep(response, o.response, true) && compareDeep(statusDate, o.statusDate, true) && compareDeep(created, o.created, true) && compareDeep(target, o.target, true) && compareDeep(provider, o.provider, true) && compareDeep(organization, o.organization, true) && compareDeep(paymentStatus, o.paymentStatus, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof PaymentNotice)) return false; PaymentNotice o = (PaymentNotice) other; return compareValues(status, o.status, true) && compareValues(statusDate, o.statusDate, true) && compareValues(created, o.created, true) ; } public boolean isEmpty() { return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(identifier, status, request , response, statusDate, created, target, provider, organization, paymentStatus ); } @Override public ResourceType getResourceType() { return ResourceType.PaymentNotice; } /** * Search parameter: <b>identifier</b> * <p> * Description: <b>The business identifier of the notice</b><br> * Type: <b>token</b><br> * Path: <b>PaymentNotice.identifier</b><br> * </p> */ @SearchParamDefinition(name="identifier", path="PaymentNotice.identifier", description="The business identifier of the notice", type="token" ) public static final String SP_IDENTIFIER = "identifier"; /** * <b>Fluent Client</b> search parameter constant for <b>identifier</b> * <p> * Description: <b>The business identifier of the notice</b><br> * Type: <b>token</b><br> * Path: <b>PaymentNotice.identifier</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam IDENTIFIER = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_IDENTIFIER); /** * Search parameter: <b>request</b> * <p> * Description: <b>The Claim</b><br> * Type: <b>reference</b><br> * Path: <b>PaymentNotice.request</b><br> * </p> */ @SearchParamDefinition(name="request", path="PaymentNotice.request", description="The Claim", type="reference" ) public static final String SP_REQUEST = "request"; /** * <b>Fluent Client</b> search parameter constant for <b>request</b> * <p> * Description: <b>The Claim</b><br> * Type: <b>reference</b><br> * Path: <b>PaymentNotice.request</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam REQUEST = new ca.uhn.fhir.rest.gclient.ReferenceClientParam(SP_REQUEST); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "<b>PaymentNotice:request</b>". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_REQUEST = new ca.uhn.fhir.model.api.Include("PaymentNotice:request").toLocked(); /** * Search parameter: <b>provider</b> * <p> * Description: <b>The reference to the provider</b><br> * Type: <b>reference</b><br> * Path: <b>PaymentNotice.provider</b><br> * </p> */ @SearchParamDefinition(name="provider", path="PaymentNotice.provider", description="The reference to the provider", type="reference", providesMembershipIn={ @ca.uhn.fhir.model.api.annotation.Compartment(name="Practitioner") }, target={Practitioner.class } ) public static final String SP_PROVIDER = "provider"; /** * <b>Fluent Client</b> search parameter constant for <b>provider</b> * <p> * Description: <b>The reference to the provider</b><br> * Type: <b>reference</b><br> * Path: <b>PaymentNotice.provider</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam PROVIDER = new ca.uhn.fhir.rest.gclient.ReferenceClientParam(SP_PROVIDER); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "<b>PaymentNotice:provider</b>". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_PROVIDER = new ca.uhn.fhir.model.api.Include("PaymentNotice:provider").toLocked(); /** * Search parameter: <b>created</b> * <p> * Description: <b>Creation date fro the notice</b><br> * Type: <b>date</b><br> * Path: <b>PaymentNotice.created</b><br> * </p> */ @SearchParamDefinition(name="created", path="PaymentNotice.created", description="Creation date fro the notice", type="date" ) public static final String SP_CREATED = "created"; /** * <b>Fluent Client</b> search parameter constant for <b>created</b> * <p> * Description: <b>Creation date fro the notice</b><br> * Type: <b>date</b><br> * Path: <b>PaymentNotice.created</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.DateClientParam CREATED = new ca.uhn.fhir.rest.gclient.DateClientParam(SP_CREATED); /** * Search parameter: <b>response</b> * <p> * Description: <b>The ClaimResponse</b><br> * Type: <b>reference</b><br> * Path: <b>PaymentNotice.response</b><br> * </p> */ @SearchParamDefinition(name="response", path="PaymentNotice.response", description="The ClaimResponse", type="reference" ) public static final String SP_RESPONSE = "response"; /** * <b>Fluent Client</b> search parameter constant for <b>response</b> * <p> * Description: <b>The ClaimResponse</b><br> * Type: <b>reference</b><br> * Path: <b>PaymentNotice.response</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam RESPONSE = new ca.uhn.fhir.rest.gclient.ReferenceClientParam(SP_RESPONSE); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "<b>PaymentNotice:response</b>". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_RESPONSE = new ca.uhn.fhir.model.api.Include("PaymentNotice:response").toLocked(); /** * Search parameter: <b>organization</b> * <p> * Description: <b>The organization who generated this resource</b><br> * Type: <b>reference</b><br> * Path: <b>PaymentNotice.organization</b><br> * </p> */ @SearchParamDefinition(name="organization", path="PaymentNotice.organization", description="The organization who generated this resource", type="reference", target={Organization.class } ) public static final String SP_ORGANIZATION = "organization"; /** * <b>Fluent Client</b> search parameter constant for <b>organization</b> * <p> * Description: <b>The organization who generated this resource</b><br> * Type: <b>reference</b><br> * Path: <b>PaymentNotice.organization</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam ORGANIZATION = new ca.uhn.fhir.rest.gclient.ReferenceClientParam(SP_ORGANIZATION); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "<b>PaymentNotice:organization</b>". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_ORGANIZATION = new ca.uhn.fhir.model.api.Include("PaymentNotice:organization").toLocked(); /** * Search parameter: <b>payment-status</b> * <p> * Description: <b>The type of payment notice</b><br> * Type: <b>token</b><br> * Path: <b>PaymentNotice.paymentStatus</b><br> * </p> */ @SearchParamDefinition(name="payment-status", path="PaymentNotice.paymentStatus", description="The type of payment notice", type="token" ) public static final String SP_PAYMENT_STATUS = "payment-status"; /** * <b>Fluent Client</b> search parameter constant for <b>payment-status</b> * <p> * Description: <b>The type of payment notice</b><br> * Type: <b>token</b><br> * Path: <b>PaymentNotice.paymentStatus</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam PAYMENT_STATUS = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_PAYMENT_STATUS); /** * Search parameter: <b>statusdate</b> * <p> * Description: <b>The date of the payment action</b><br> * Type: <b>date</b><br> * Path: <b>PaymentNotice.statusDate</b><br> * </p> */ @SearchParamDefinition(name="statusdate", path="PaymentNotice.statusDate", description="The date of the payment action", type="date" ) public static final String SP_STATUSDATE = "statusdate"; /** * <b>Fluent Client</b> search parameter constant for <b>statusdate</b> * <p> * Description: <b>The date of the payment action</b><br> * Type: <b>date</b><br> * Path: <b>PaymentNotice.statusDate</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.DateClientParam STATUSDATE = new ca.uhn.fhir.rest.gclient.DateClientParam(SP_STATUSDATE); }