Package ca.uhn.fhir.model.dstu.resource

Source Code of ca.uhn.fhir.model.dstu.resource.MedicationPrescription$Dispense
















package ca.uhn.fhir.model.dstu.resource;

/*
* #%L
* HAPI FHIR Library
* %%
* Copyright (C) 2014 University Health Network
* %%
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*      http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/


import java.util.Date;
import java.util.List;

import ca.uhn.fhir.model.api.BaseElement;
import ca.uhn.fhir.model.api.BaseResource;
import ca.uhn.fhir.model.api.IDatatype;
import ca.uhn.fhir.model.api.IElement;
import ca.uhn.fhir.model.api.IResource;
import ca.uhn.fhir.model.api.IResourceBlock;
import ca.uhn.fhir.model.api.TemporalPrecisionEnum;
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;
import ca.uhn.fhir.model.dstu.composite.CodeableConceptDt;
import ca.uhn.fhir.model.dstu.composite.DurationDt;
import ca.uhn.fhir.model.dstu.composite.IdentifierDt;
import ca.uhn.fhir.model.dstu.composite.PeriodDt;
import ca.uhn.fhir.model.dstu.composite.QuantityDt;
import ca.uhn.fhir.model.dstu.composite.RatioDt;
import ca.uhn.fhir.model.dstu.composite.ResourceReferenceDt;
import ca.uhn.fhir.model.dstu.composite.ScheduleDt;
import ca.uhn.fhir.model.dstu.valueset.IdentifierUseEnum;
import ca.uhn.fhir.model.dstu.valueset.MedicationPrescriptionStatusEnum;
import ca.uhn.fhir.model.dstu.valueset.QuantityCompararatorEnum;
import ca.uhn.fhir.model.primitive.BooleanDt;
import ca.uhn.fhir.model.primitive.BoundCodeDt;
import ca.uhn.fhir.model.primitive.CodeDt;
import ca.uhn.fhir.model.primitive.DateTimeDt;
import ca.uhn.fhir.model.primitive.IntegerDt;
import ca.uhn.fhir.model.primitive.StringDt;
import ca.uhn.fhir.rest.gclient.DateParam;
import ca.uhn.fhir.rest.gclient.Include;
import ca.uhn.fhir.rest.gclient.ReferenceParam;
import ca.uhn.fhir.rest.gclient.TokenParam;


/**
* HAPI/FHIR <b>MedicationPrescription</b> Resource
* (Prescription of medication to for patient)
*
* <p>
* <b>Definition:</b>
* An order for both supply of the medication and the instructions for administration of the medicine to a patient.
* </p>
*
* <p>
* <b>Requirements:</b>
*
* </p>
*
* <p>
* <b>Profile Definition:</b>
* <a href="http://hl7.org/fhir/profiles/MedicationPrescription">http://hl7.org/fhir/profiles/MedicationPrescription</a>
* </p>
*
*/
@ResourceDef(name="MedicationPrescription", profile="http://hl7.org/fhir/profiles/MedicationPrescription", id="medicationprescription")
public class MedicationPrescription extends BaseResource implements IResource {

  /**
   * Search parameter constant for <b>datewritten</b>
   * <p>
   * Description: <b>Return prescriptions written on this date</b><br/>
   * Type: <b>date</b><br/>
   * Path: <b>MedicationPrescription.dateWritten</b><br/>
   * </p>
   */
  @SearchParamDefinition(name="datewritten", path="MedicationPrescription.dateWritten", description="Return prescriptions written on this date")
  public static final String SP_DATEWRITTEN = "datewritten";

  /**
   * <b>Fluent Client</b> search parameter constant for <b>datewritten</b>
   * <p>
   * Description: <b>Return prescriptions written on this date</b><br/>
   * Type: <b>date</b><br/>
   * Path: <b>MedicationPrescription.dateWritten</b><br/>
   * </p>
   */
  public static final DateParam DATEWRITTEN = new DateParam(SP_DATEWRITTEN);

  /**
   * Search parameter constant for <b>encounter</b>
   * <p>
   * Description: <b>Return prescriptions with this encounter identity</b><br/>
   * Type: <b>reference</b><br/>
   * Path: <b>MedicationPrescription.encounter</b><br/>
   * </p>
   */
  @SearchParamDefinition(name="encounter", path="MedicationPrescription.encounter", description="Return prescriptions with this encounter identity")
  public static final String SP_ENCOUNTER = "encounter";

  /**
   * <b>Fluent Client</b> search parameter constant for <b>encounter</b>
   * <p>
   * Description: <b>Return prescriptions with this encounter identity</b><br/>
   * Type: <b>reference</b><br/>
   * Path: <b>MedicationPrescription.encounter</b><br/>
   * </p>
   */
  public static final ReferenceParam ENCOUNTER = new ReferenceParam(SP_ENCOUNTER);

  /**
   * Constant for fluent queries to be used to add include statements. Specifies
   * the path value of "<b>MedicationPrescription.encounter</b>".
   */
  public static final Include INCLUDE_ENCOUNTER = new Include("MedicationPrescription.encounter");

  /**
   * Search parameter constant for <b>identifier</b>
   * <p>
   * Description: <b>Return prescriptions with this external identity</b><br/>
   * Type: <b>token</b><br/>
   * Path: <b>MedicationPrescription.identifier</b><br/>
   * </p>
   */
  @SearchParamDefinition(name="identifier", path="MedicationPrescription.identifier", description="Return prescriptions with this external identity")
  public static final String SP_IDENTIFIER = "identifier";

  /**
   * <b>Fluent Client</b> search parameter constant for <b>identifier</b>
   * <p>
   * Description: <b>Return prescriptions with this external identity</b><br/>
   * Type: <b>token</b><br/>
   * Path: <b>MedicationPrescription.identifier</b><br/>
   * </p>
   */
  public static final TokenParam IDENTIFIER = new TokenParam(SP_IDENTIFIER);

  /**
   * Search parameter constant for <b>medication</b>
   * <p>
   * Description: <b>Code for medicine or text in medicine name</b><br/>
   * Type: <b>reference</b><br/>
   * Path: <b>MedicationPrescription.medication</b><br/>
   * </p>
   */
  @SearchParamDefinition(name="medication", path="MedicationPrescription.medication", description="Code for medicine or text in medicine name")
  public static final String SP_MEDICATION = "medication";

  /**
   * <b>Fluent Client</b> search parameter constant for <b>medication</b>
   * <p>
   * Description: <b>Code for medicine or text in medicine name</b><br/>
   * Type: <b>reference</b><br/>
   * Path: <b>MedicationPrescription.medication</b><br/>
   * </p>
   */
  public static final ReferenceParam MEDICATION = new ReferenceParam(SP_MEDICATION);

  /**
   * Constant for fluent queries to be used to add include statements. Specifies
   * the path value of "<b>MedicationPrescription.medication</b>".
   */
  public static final Include INCLUDE_MEDICATION = new Include("MedicationPrescription.medication");

  /**
   * Search parameter constant for <b>patient</b>
   * <p>
   * Description: <b>The identity of a patient to list dispenses  for</b><br/>
   * Type: <b>reference</b><br/>
   * Path: <b>MedicationPrescription.patient</b><br/>
   * </p>
   */
  @SearchParamDefinition(name="patient", path="MedicationPrescription.patient", description="The identity of a patient to list dispenses  for")
  public static final String SP_PATIENT = "patient";

  /**
   * <b>Fluent Client</b> search parameter constant for <b>patient</b>
   * <p>
   * Description: <b>The identity of a patient to list dispenses  for</b><br/>
   * Type: <b>reference</b><br/>
   * Path: <b>MedicationPrescription.patient</b><br/>
   * </p>
   */
  public static final ReferenceParam PATIENT = new ReferenceParam(SP_PATIENT);

  /**
   * Constant for fluent queries to be used to add include statements. Specifies
   * the path value of "<b>MedicationPrescription.patient</b>".
   */
  public static final Include INCLUDE_PATIENT = new Include("MedicationPrescription.patient");

  /**
   * Search parameter constant for <b>status</b>
   * <p>
   * Description: <b>Status of the prescription</b><br/>
   * Type: <b>token</b><br/>
   * Path: <b>MedicationPrescription.status</b><br/>
   * </p>
   */
  @SearchParamDefinition(name="status", path="MedicationPrescription.status", description="Status of the prescription")
  public static final String SP_STATUS = "status";

  /**
   * <b>Fluent Client</b> search parameter constant for <b>status</b>
   * <p>
   * Description: <b>Status of the prescription</b><br/>
   * Type: <b>token</b><br/>
   * Path: <b>MedicationPrescription.status</b><br/>
   * </p>
   */
  public static final TokenParam STATUS = new TokenParam(SP_STATUS);


  @Child(name="identifier", type=IdentifierDt.class, order=0, min=0, max=Child.MAX_UNLIMITED
  @Description(
    shortDefinition="External identifier",
    formalDefinition="External identifier - one that would be used by another non-FHIR system - for example a re-imbursement system might issue its own id for each prescription that is created.  This is particularly important where FHIR only provides part of an erntire workflow process where records have to be tracked through an entire system."
  )
  private java.util.List<IdentifierDt> myIdentifier;
 
  @Child(name="dateWritten", type=DateTimeDt.class, order=1, min=0, max=1
  @Description(
    shortDefinition="When prescription was authorized",
    formalDefinition="The date (and perhaps time) when the prescription was written"
  )
  private DateTimeDt myDateWritten;
 
  @Child(name="status", type=CodeDt.class, order=2, min=0, max=1
  @Description(
    shortDefinition="active | on hold | completed | entered in error | stopped | superceded",
    formalDefinition="A code specifying the state of the order.  Generally this will be active or completed state"
  )
  private BoundCodeDt<MedicationPrescriptionStatusEnum> myStatus;
 
  @Child(name="patient", order=3, min=0, max=1, type={
    ca.uhn.fhir.model.dstu.resource.Patient.class  })
  @Description(
    shortDefinition="Who prescription is for",
    formalDefinition="A link to a resource representing the person to whom the medication will be given."
  )
  private ResourceReferenceDt myPatient;
 
  @Child(name="prescriber", order=4, min=0, max=1, type={
    ca.uhn.fhir.model.dstu.resource.Practitioner.class  })
  @Description(
    shortDefinition="Who ordered the medication(s)",
    formalDefinition="The healthcare professional responsible for authorizing the prescription"
  )
  private ResourceReferenceDt myPrescriber;
 
  @Child(name="encounter", order=5, min=0, max=1, type={
    ca.uhn.fhir.model.dstu.resource.Encounter.class  })
  @Description(
    shortDefinition="Created during encounter / admission / stay",
    formalDefinition="A link to a resource that identifies the particular occurrence of contact between patient and health care provider."
  )
  private ResourceReferenceDt myEncounter;
 
  @Child(name="reason", order=6, min=0, max=1, type={
    CodeableConceptDt.class,     Condition.class  })
  @Description(
    shortDefinition="Reason or indication for writing the prescription",
    formalDefinition="Can be the reason or the indication for writing the prescription."
  )
  private IDatatype myReason;
 
  @Child(name="medication", order=7, min=0, max=1, type={
    ca.uhn.fhir.model.dstu.resource.Medication.class  })
  @Description(
    shortDefinition="Medication to be taken",
    formalDefinition="Identifies the medication being administered. This is either a link to a resource representing the details of the medication or a simple attribute carrying a code that identifies the medication from a known list of medications."
  )
  private ResourceReferenceDt myMedication;
 
  @Child(name="dosageInstruction", order=8, min=0, max=Child.MAX_UNLIMITED
  @Description(
    shortDefinition="How medication should be taken",
    formalDefinition="Indicates how the medication is to be used by the patient"
  )
  private java.util.List<DosageInstruction> myDosageInstruction;
 
  @Child(name="dispense", order=9, min=0, max=1
  @Description(
    shortDefinition="Medication supply authorization",
    formalDefinition="Deals with details of the dispense part of the order"
  )
  private Dispense myDispense;
 
  @Child(name="substitution", order=10, min=0, max=1
  @Description(
    shortDefinition="Any restrictions on medication substitution?",
    formalDefinition="Indicates whether or not substitution can or should be part of the dispense. In some cases substitution must happen, in other cases substitution must not happen, and in others it does not matter. This block explains the prescriber's intent. If nothing is specified substitution may be done."
  )
  private Substitution mySubstitution;
 

  @Override
  public boolean isEmpty() {
    return super.isBaseEmpty() && ca.uhn.fhir.util.ElementUtil.isEmptymyIdentifier,  myDateWritten,  myStatus,  myPatient,  myPrescriber,  myEncounter,  myReason,  myMedication,  myDosageInstruction,  myDispense,  mySubstitution);
  }
 
  @Override
  public <T extends IElement> List<T> getAllPopulatedChildElementsOfType(Class<T> theType) {
    return ca.uhn.fhir.util.ElementUtil.allPopulatedChildElements(theType, myIdentifier, myDateWritten, myStatus, myPatient, myPrescriber, myEncounter, myReason, myMedication, myDosageInstruction, myDispense, mySubstitution);
  }

  /**
   * Gets the value(s) for <b>identifier</b> (External identifier).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * External identifier - one that would be used by another non-FHIR system - for example a re-imbursement system might issue its own id for each prescription that is created.  This is particularly important where FHIR only provides part of an erntire workflow process where records have to be tracked through an entire system.
     * </p>
   */
  public java.util.List<IdentifierDt> getIdentifier() { 
    if (myIdentifier == null) {
      myIdentifier = new java.util.ArrayList<IdentifierDt>();
    }
    return myIdentifier;
  }

  /**
   * Sets the value(s) for <b>identifier</b> (External identifier)
   *
     * <p>
     * <b>Definition:</b>
     * External identifier - one that would be used by another non-FHIR system - for example a re-imbursement system might issue its own id for each prescription that is created.  This is particularly important where FHIR only provides part of an erntire workflow process where records have to be tracked through an entire system.
     * </p>
   */
  public MedicationPrescription setIdentifier(java.util.List<IdentifierDt> theValue) {
    myIdentifier = theValue;
    return this;
  }

  /**
   * Adds and returns a new value for <b>identifier</b> (External identifier)
   *
     * <p>
     * <b>Definition:</b>
     * External identifier - one that would be used by another non-FHIR system - for example a re-imbursement system might issue its own id for each prescription that is created.  This is particularly important where FHIR only provides part of an erntire workflow process where records have to be tracked through an entire system.
     * </p>
   */
  public IdentifierDt addIdentifier() {
    IdentifierDt newType = new IdentifierDt();
    getIdentifier().add(newType);
    return newType;
  }

  /**
   * Gets the first repetition for <b>identifier</b> (External identifier),
   * creating it if it does not already exist.
   *
     * <p>
     * <b>Definition:</b>
     * External identifier - one that would be used by another non-FHIR system - for example a re-imbursement system might issue its own id for each prescription that is created.  This is particularly important where FHIR only provides part of an erntire workflow process where records have to be tracked through an entire system.
     * </p>
   */
  public IdentifierDt getIdentifierFirstRep() {
    if (getIdentifier().isEmpty()) {
      return addIdentifier();
    }
    return getIdentifier().get(0);
  }
   /**
   * Adds a new value for <b>identifier</b> (External identifier)
   *
     * <p>
     * <b>Definition:</b>
     * External identifier - one that would be used by another non-FHIR system - for example a re-imbursement system might issue its own id for each prescription that is created.  This is particularly important where FHIR only provides part of an erntire workflow process where records have to be tracked through an entire system.
     * </p>
     *
     * @return Returns a reference to this object, to allow for simple chaining.
   */
  public MedicationPrescription addIdentifier( IdentifierUseEnum theUse,  String theSystem,  String theValue,  String theLabel) {
    if (myIdentifier == null) {
      myIdentifier = new java.util.ArrayList<IdentifierDt>();
    }
    myIdentifier.add(new IdentifierDt(theUse, theSystem, theValue, theLabel));
    return this;
  }

  /**
   * Adds a new value for <b>identifier</b> (External identifier)
   *
     * <p>
     * <b>Definition:</b>
     * External identifier - one that would be used by another non-FHIR system - for example a re-imbursement system might issue its own id for each prescription that is created.  This is particularly important where FHIR only provides part of an erntire workflow process where records have to be tracked through an entire system.
     * </p>
     *
     * @return Returns a reference to this object, to allow for simple chaining.
   */
  public MedicationPrescription addIdentifier( String theSystem,  String theValue) {
    if (myIdentifier == null) {
      myIdentifier = new java.util.ArrayList<IdentifierDt>();
    }
    myIdentifier.add(new IdentifierDt(theSystem, theValue));
    return this;
  }

  /**
   * Gets the value(s) for <b>dateWritten</b> (When prescription was authorized).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * The date (and perhaps time) when the prescription was written
     * </p>
   */
  public DateTimeDt getDateWritten() { 
    if (myDateWritten == null) {
      myDateWritten = new DateTimeDt();
    }
    return myDateWritten;
  }

  /**
   * Sets the value(s) for <b>dateWritten</b> (When prescription was authorized)
   *
     * <p>
     * <b>Definition:</b>
     * The date (and perhaps time) when the prescription was written
     * </p>
   */
  public MedicationPrescription setDateWritten(DateTimeDt theValue) {
    myDateWritten = theValue;
    return this;
  }

   /**
   * Sets the value for <b>dateWritten</b> (When prescription was authorized)
   *
     * <p>
     * <b>Definition:</b>
     * The date (and perhaps time) when the prescription was written
     * </p>
   */
  public MedicationPrescription setDateWritten( Date theDate,  TemporalPrecisionEnum thePrecision) {
    myDateWritten = new DateTimeDt(theDate, thePrecision);
    return this;
  }

  /**
   * Sets the value for <b>dateWritten</b> (When prescription was authorized)
   *
     * <p>
     * <b>Definition:</b>
     * The date (and perhaps time) when the prescription was written
     * </p>
   */
  public MedicationPrescription setDateWrittenWithSecondsPrecision( Date theDate) {
    myDateWritten = new DateTimeDt(theDate);
    return this;
  }

  /**
   * Gets the value(s) for <b>status</b> (active | on hold | completed | entered in error | stopped | superceded).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * A code specifying the state of the order.  Generally this will be active or completed state
     * </p>
   */
  public BoundCodeDt<MedicationPrescriptionStatusEnum> getStatus() { 
    if (myStatus == null) {
      myStatus = new BoundCodeDt<MedicationPrescriptionStatusEnum>(MedicationPrescriptionStatusEnum.VALUESET_BINDER);
    }
    return myStatus;
  }

  /**
   * Sets the value(s) for <b>status</b> (active | on hold | completed | entered in error | stopped | superceded)
   *
     * <p>
     * <b>Definition:</b>
     * A code specifying the state of the order.  Generally this will be active or completed state
     * </p>
   */
  public MedicationPrescription setStatus(BoundCodeDt<MedicationPrescriptionStatusEnum> theValue) {
    myStatus = theValue;
    return this;
  }

  /**
   * Sets the value(s) for <b>status</b> (active | on hold | completed | entered in error | stopped | superceded)
   *
     * <p>
     * <b>Definition:</b>
     * A code specifying the state of the order.  Generally this will be active or completed state
     * </p>
   */
  public MedicationPrescription setStatus(MedicationPrescriptionStatusEnum theValue) {
    getStatus().setValueAsEnum(theValue);
    return this;
  }

 
  /**
   * Gets the value(s) for <b>patient</b> (Who prescription is for).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * A link to a resource representing the person to whom the medication will be given.
     * </p>
   */
  public ResourceReferenceDt getPatient() { 
    if (myPatient == null) {
      myPatient = new ResourceReferenceDt();
    }
    return myPatient;
  }

  /**
   * Sets the value(s) for <b>patient</b> (Who prescription is for)
   *
     * <p>
     * <b>Definition:</b>
     * A link to a resource representing the person to whom the medication will be given.
     * </p>
   */
  public MedicationPrescription setPatient(ResourceReferenceDt theValue) {
    myPatient = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>prescriber</b> (Who ordered the medication(s)).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * The healthcare professional responsible for authorizing the prescription
     * </p>
   */
  public ResourceReferenceDt getPrescriber() { 
    if (myPrescriber == null) {
      myPrescriber = new ResourceReferenceDt();
    }
    return myPrescriber;
  }

  /**
   * Sets the value(s) for <b>prescriber</b> (Who ordered the medication(s))
   *
     * <p>
     * <b>Definition:</b>
     * The healthcare professional responsible for authorizing the prescription
     * </p>
   */
  public MedicationPrescription setPrescriber(ResourceReferenceDt theValue) {
    myPrescriber = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>encounter</b> (Created during encounter / admission / stay).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * A link to a resource that identifies the particular occurrence of contact between patient and health care provider.
     * </p>
   */
  public ResourceReferenceDt getEncounter() { 
    if (myEncounter == null) {
      myEncounter = new ResourceReferenceDt();
    }
    return myEncounter;
  }

  /**
   * Sets the value(s) for <b>encounter</b> (Created during encounter / admission / stay)
   *
     * <p>
     * <b>Definition:</b>
     * A link to a resource that identifies the particular occurrence of contact between patient and health care provider.
     * </p>
   */
  public MedicationPrescription setEncounter(ResourceReferenceDt theValue) {
    myEncounter = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>reason[x]</b> (Reason or indication for writing the prescription).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Can be the reason or the indication for writing the prescription.
     * </p>
   */
  public IDatatype getReason() { 
    return myReason;
  }

  /**
   * Sets the value(s) for <b>reason[x]</b> (Reason or indication for writing the prescription)
   *
     * <p>
     * <b>Definition:</b>
     * Can be the reason or the indication for writing the prescription.
     * </p>
   */
  public MedicationPrescription setReason(IDatatype theValue) {
    myReason = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>medication</b> (Medication to be taken).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Identifies the medication being administered. This is either a link to a resource representing the details of the medication or a simple attribute carrying a code that identifies the medication from a known list of medications.
     * </p>
   */
  public ResourceReferenceDt getMedication() { 
    if (myMedication == null) {
      myMedication = new ResourceReferenceDt();
    }
    return myMedication;
  }

  /**
   * Sets the value(s) for <b>medication</b> (Medication to be taken)
   *
     * <p>
     * <b>Definition:</b>
     * Identifies the medication being administered. This is either a link to a resource representing the details of the medication or a simple attribute carrying a code that identifies the medication from a known list of medications.
     * </p>
   */
  public MedicationPrescription setMedication(ResourceReferenceDt theValue) {
    myMedication = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>dosageInstruction</b> (How medication should be taken).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Indicates how the medication is to be used by the patient
     * </p>
   */
  public java.util.List<DosageInstruction> getDosageInstruction() { 
    if (myDosageInstruction == null) {
      myDosageInstruction = new java.util.ArrayList<DosageInstruction>();
    }
    return myDosageInstruction;
  }

  /**
   * Sets the value(s) for <b>dosageInstruction</b> (How medication should be taken)
   *
     * <p>
     * <b>Definition:</b>
     * Indicates how the medication is to be used by the patient
     * </p>
   */
  public MedicationPrescription setDosageInstruction(java.util.List<DosageInstruction> theValue) {
    myDosageInstruction = theValue;
    return this;
  }

  /**
   * Adds and returns a new value for <b>dosageInstruction</b> (How medication should be taken)
   *
     * <p>
     * <b>Definition:</b>
     * Indicates how the medication is to be used by the patient
     * </p>
   */
  public DosageInstruction addDosageInstruction() {
    DosageInstruction newType = new DosageInstruction();
    getDosageInstruction().add(newType);
    return newType;
  }

  /**
   * Gets the first repetition for <b>dosageInstruction</b> (How medication should be taken),
   * creating it if it does not already exist.
   *
     * <p>
     * <b>Definition:</b>
     * Indicates how the medication is to be used by the patient
     * </p>
   */
  public DosageInstruction getDosageInstructionFirstRep() {
    if (getDosageInstruction().isEmpty()) {
      return addDosageInstruction();
    }
    return getDosageInstruction().get(0);
  }
 
  /**
   * Gets the value(s) for <b>dispense</b> (Medication supply authorization).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Deals with details of the dispense part of the order
     * </p>
   */
  public Dispense getDispense() { 
    if (myDispense == null) {
      myDispense = new Dispense();
    }
    return myDispense;
  }

  /**
   * Sets the value(s) for <b>dispense</b> (Medication supply authorization)
   *
     * <p>
     * <b>Definition:</b>
     * Deals with details of the dispense part of the order
     * </p>
   */
  public MedicationPrescription setDispense(Dispense theValue) {
    myDispense = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>substitution</b> (Any restrictions on medication substitution?).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Indicates whether or not substitution can or should be part of the dispense. In some cases substitution must happen, in other cases substitution must not happen, and in others it does not matter. This block explains the prescriber's intent. If nothing is specified substitution may be done.
     * </p>
   */
  public Substitution getSubstitution() { 
    if (mySubstitution == null) {
      mySubstitution = new Substitution();
    }
    return mySubstitution;
  }

  /**
   * Sets the value(s) for <b>substitution</b> (Any restrictions on medication substitution?)
   *
     * <p>
     * <b>Definition:</b>
     * Indicates whether or not substitution can or should be part of the dispense. In some cases substitution must happen, in other cases substitution must not happen, and in others it does not matter. This block explains the prescriber's intent. If nothing is specified substitution may be done.
     * </p>
   */
  public MedicationPrescription setSubstitution(Substitution theValue) {
    mySubstitution = theValue;
    return this;
  }

 
  /**
   * Block class for child element: <b>MedicationPrescription.dosageInstruction</b> (How medication should be taken)
   *
     * <p>
     * <b>Definition:</b>
     * Indicates how the medication is to be used by the patient
     * </p>
   */
  @Block() 
  public static class DosageInstruction extends BaseElement implements IResourceBlock {
 
  @Child(name="text", type=StringDt.class, order=0, min=0, max=1
  @Description(
    shortDefinition="Dosage instructions expressed as text",
    formalDefinition="Free text dosage instructions for cases where the instructions are too complex to code."
  )
  private StringDt myText;
 
  @Child(name="additionalInstructions", type=CodeableConceptDt.class, order=1, min=0, max=1
  @Description(
    shortDefinition="Supplemental instructions - e.g. \"with meals\"",
    formalDefinition="Additional instructions such as \"Swallow with plenty of water\" which may or may not be coded."
  )
  private CodeableConceptDt myAdditionalInstructions;
 
  @Child(name="timing", order=2, min=0, max=1, type={
    DateTimeDt.class,     PeriodDt.class,     ScheduleDt.class  })
  @Description(
    shortDefinition="When medication should be administered",
    formalDefinition="The timing schedule for giving the medication to the patient.  The Schedule data type allows many different expressions, for example.  \"Every  8 hours\"; \"Three times a day\"; \"1/2 an hour before breakfast for 10 days from 23-Dec 2011:\";  \"15 Oct 2013, 17 Oct 2013 and 1 Nov 2013\""
  )
  private IDatatype myTiming;
 
  @Child(name="asNeeded", order=3, min=0, max=1, type={
    BooleanDt.class,     CodeableConceptDt.class  })
  @Description(
    shortDefinition="Take \"as needed\" f(or x)",
    formalDefinition="If set to true or if specified as a CodeableConcept, indicates that the medication is only taken when needed within the specified schedule rather than at every scheduled dose.  If a CodeableConcept is present, it indicates the pre-condition for taking the Medication"
  )
  private IDatatype myAsNeeded;
 
  @Child(name="site", type=CodeableConceptDt.class, order=4, min=0, max=1
  @Description(
    shortDefinition="Body site to administer to",
    formalDefinition="A coded specification of the anatomic site where the medication first enters the body"
  )
  private CodeableConceptDt mySite;
 
  @Child(name="route", type=CodeableConceptDt.class, order=5, min=0, max=1
  @Description(
    shortDefinition="How drug should enter body",
    formalDefinition="A code specifying the route or physiological path of administration of a therapeutic agent into or onto a patient."
  )
  private CodeableConceptDt myRoute;
 
  @Child(name="method", type=CodeableConceptDt.class, order=6, min=0, max=1
  @Description(
    shortDefinition="Technique for administering medication",
    formalDefinition="A coded value indicating the method by which the medication is introduced into or onto the body. Most commonly used for injections.  Examples:  Slow Push; Deep IV.Terminologies used often pre-coordinate this term with the route and or form of administration."
  )
  private CodeableConceptDt myMethod;
 
  @Child(name="doseQuantity", type=QuantityDt.class, order=7, min=0, max=1
  @Description(
    shortDefinition="Amount of medication per dose",
    formalDefinition="The amount of therapeutic or other substance given at one administration event."
  )
  private QuantityDt myDoseQuantity;
 
  @Child(name="rate", type=RatioDt.class, order=8, min=0, max=1
  @Description(
    shortDefinition="Amount of medication per unit of time",
    formalDefinition="Identifies the speed with which the substance is introduced into the subject. Typically the rate for an infusion. 200ml in 2 hours."
  )
  private RatioDt myRate;
 
  @Child(name="maxDosePerPeriod", type=RatioDt.class, order=9, min=0, max=1
  @Description(
    shortDefinition="Upper limit on medication per unit of time",
    formalDefinition="The maximum total quantity of a therapeutic substance that may be administered to a subject over the period of time. E.g. 1000mg in 24 hours."
  )
  private RatioDt myMaxDosePerPeriod;
 

  @Override
  public boolean isEmpty() {
    return super.isBaseEmpty() && ca.uhn.fhir.util.ElementUtil.isEmptymyText,  myAdditionalInstructions,  myTiming,  myAsNeeded,  mySite,  myRoute,  myMethod,  myDoseQuantity,  myRate,  myMaxDosePerPeriod);
  }
 
  @Override
  public <T extends IElement> List<T> getAllPopulatedChildElementsOfType(Class<T> theType) {
    return ca.uhn.fhir.util.ElementUtil.allPopulatedChildElements(theType, myText, myAdditionalInstructions, myTiming, myAsNeeded, mySite, myRoute, myMethod, myDoseQuantity, myRate, myMaxDosePerPeriod);
  }

  /**
   * Gets the value(s) for <b>text</b> (Dosage instructions expressed as text).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Free text dosage instructions for cases where the instructions are too complex to code.
     * </p>
   */
  public StringDt getText() { 
    if (myText == null) {
      myText = new StringDt();
    }
    return myText;
  }

  /**
   * Sets the value(s) for <b>text</b> (Dosage instructions expressed as text)
   *
     * <p>
     * <b>Definition:</b>
     * Free text dosage instructions for cases where the instructions are too complex to code.
     * </p>
   */
  public DosageInstruction setText(StringDt theValue) {
    myText = theValue;
    return this;
  }

   /**
   * Sets the value for <b>text</b> (Dosage instructions expressed as text)
   *
     * <p>
     * <b>Definition:</b>
     * Free text dosage instructions for cases where the instructions are too complex to code.
     * </p>
   */
  public DosageInstruction setText( String theString) {
    myText = new StringDt(theString);
    return this;
  }

  /**
   * Gets the value(s) for <b>additionalInstructions</b> (Supplemental instructions - e.g. \"with meals\").
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Additional instructions such as \"Swallow with plenty of water\" which may or may not be coded.
     * </p>
   */
  public CodeableConceptDt getAdditionalInstructions() { 
    if (myAdditionalInstructions == null) {
      myAdditionalInstructions = new CodeableConceptDt();
    }
    return myAdditionalInstructions;
  }

  /**
   * Sets the value(s) for <b>additionalInstructions</b> (Supplemental instructions - e.g. \"with meals\")
   *
     * <p>
     * <b>Definition:</b>
     * Additional instructions such as \"Swallow with plenty of water\" which may or may not be coded.
     * </p>
   */
  public DosageInstruction setAdditionalInstructions(CodeableConceptDt theValue) {
    myAdditionalInstructions = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>timing[x]</b> (When medication should be administered).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * The timing schedule for giving the medication to the patient.  The Schedule data type allows many different expressions, for example.  \"Every  8 hours\"; \"Three times a day\"; \"1/2 an hour before breakfast for 10 days from 23-Dec 2011:\";  \"15 Oct 2013, 17 Oct 2013 and 1 Nov 2013\"
     * </p>
   */
  public IDatatype getTiming() { 
    return myTiming;
  }

  /**
   * Sets the value(s) for <b>timing[x]</b> (When medication should be administered)
   *
     * <p>
     * <b>Definition:</b>
     * The timing schedule for giving the medication to the patient.  The Schedule data type allows many different expressions, for example.  \"Every  8 hours\"; \"Three times a day\"; \"1/2 an hour before breakfast for 10 days from 23-Dec 2011:\";  \"15 Oct 2013, 17 Oct 2013 and 1 Nov 2013\"
     * </p>
   */
  public DosageInstruction setTiming(IDatatype theValue) {
    myTiming = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>asNeeded[x]</b> (Take \"as needed\" f(or x)).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * If set to true or if specified as a CodeableConcept, indicates that the medication is only taken when needed within the specified schedule rather than at every scheduled dose.  If a CodeableConcept is present, it indicates the pre-condition for taking the Medication
     * </p>
   */
  public IDatatype getAsNeeded() { 
    return myAsNeeded;
  }

  /**
   * Sets the value(s) for <b>asNeeded[x]</b> (Take \"as needed\" f(or x))
   *
     * <p>
     * <b>Definition:</b>
     * If set to true or if specified as a CodeableConcept, indicates that the medication is only taken when needed within the specified schedule rather than at every scheduled dose.  If a CodeableConcept is present, it indicates the pre-condition for taking the Medication
     * </p>
   */
  public DosageInstruction setAsNeeded(IDatatype theValue) {
    myAsNeeded = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>site</b> (Body site to administer to).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * A coded specification of the anatomic site where the medication first enters the body
     * </p>
   */
  public CodeableConceptDt getSite() { 
    if (mySite == null) {
      mySite = new CodeableConceptDt();
    }
    return mySite;
  }

  /**
   * Sets the value(s) for <b>site</b> (Body site to administer to)
   *
     * <p>
     * <b>Definition:</b>
     * A coded specification of the anatomic site where the medication first enters the body
     * </p>
   */
  public DosageInstruction setSite(CodeableConceptDt theValue) {
    mySite = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>route</b> (How drug should enter body).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * A code specifying the route or physiological path of administration of a therapeutic agent into or onto a patient.
     * </p>
   */
  public CodeableConceptDt getRoute() { 
    if (myRoute == null) {
      myRoute = new CodeableConceptDt();
    }
    return myRoute;
  }

  /**
   * Sets the value(s) for <b>route</b> (How drug should enter body)
   *
     * <p>
     * <b>Definition:</b>
     * A code specifying the route or physiological path of administration of a therapeutic agent into or onto a patient.
     * </p>
   */
  public DosageInstruction setRoute(CodeableConceptDt theValue) {
    myRoute = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>method</b> (Technique for administering medication).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * A coded value indicating the method by which the medication is introduced into or onto the body. Most commonly used for injections.  Examples:  Slow Push; Deep IV.Terminologies used often pre-coordinate this term with the route and or form of administration.
     * </p>
   */
  public CodeableConceptDt getMethod() { 
    if (myMethod == null) {
      myMethod = new CodeableConceptDt();
    }
    return myMethod;
  }

  /**
   * Sets the value(s) for <b>method</b> (Technique for administering medication)
   *
     * <p>
     * <b>Definition:</b>
     * A coded value indicating the method by which the medication is introduced into or onto the body. Most commonly used for injections.  Examples:  Slow Push; Deep IV.Terminologies used often pre-coordinate this term with the route and or form of administration.
     * </p>
   */
  public DosageInstruction setMethod(CodeableConceptDt theValue) {
    myMethod = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>doseQuantity</b> (Amount of medication per dose).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * The amount of therapeutic or other substance given at one administration event.
     * </p>
   */
  public QuantityDt getDoseQuantity() { 
    if (myDoseQuantity == null) {
      myDoseQuantity = new QuantityDt();
    }
    return myDoseQuantity;
  }

  /**
   * Sets the value(s) for <b>doseQuantity</b> (Amount of medication per dose)
   *
     * <p>
     * <b>Definition:</b>
     * The amount of therapeutic or other substance given at one administration event.
     * </p>
   */
  public DosageInstruction setDoseQuantity(QuantityDt theValue) {
    myDoseQuantity = theValue;
    return this;
  }

   /**
   * Sets the value for <b>doseQuantity</b> (Amount of medication per dose)
   *
     * <p>
     * <b>Definition:</b>
     * The amount of therapeutic or other substance given at one administration event.
     * </p>
   */
  public DosageInstruction setDoseQuantity( QuantityCompararatorEnum theComparator,  long theValue,  String theUnits) {
    myDoseQuantity = new QuantityDt(theComparator, theValue, theUnits);
    return this;
  }

  /**
   * Sets the value for <b>doseQuantity</b> (Amount of medication per dose)
   *
     * <p>
     * <b>Definition:</b>
     * The amount of therapeutic or other substance given at one administration event.
     * </p>
   */
  public DosageInstruction setDoseQuantity( QuantityCompararatorEnum theComparator,  double theValue,  String theUnits) {
    myDoseQuantity = new QuantityDt(theComparator, theValue, theUnits);
    return this;
  }

  /**
   * Sets the value for <b>doseQuantity</b> (Amount of medication per dose)
   *
     * <p>
     * <b>Definition:</b>
     * The amount of therapeutic or other substance given at one administration event.
     * </p>
   */
  public DosageInstruction setDoseQuantity( long theValue) {
    myDoseQuantity = new QuantityDt(theValue);
    return this;
  }

  /**
   * Sets the value for <b>doseQuantity</b> (Amount of medication per dose)
   *
     * <p>
     * <b>Definition:</b>
     * The amount of therapeutic or other substance given at one administration event.
     * </p>
   */
  public DosageInstruction setDoseQuantity( double theValue) {
    myDoseQuantity = new QuantityDt(theValue);
    return this;
  }

  /**
   * Gets the value(s) for <b>rate</b> (Amount of medication per unit of time).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Identifies the speed with which the substance is introduced into the subject. Typically the rate for an infusion. 200ml in 2 hours.
     * </p>
   */
  public RatioDt getRate() { 
    if (myRate == null) {
      myRate = new RatioDt();
    }
    return myRate;
  }

  /**
   * Sets the value(s) for <b>rate</b> (Amount of medication per unit of time)
   *
     * <p>
     * <b>Definition:</b>
     * Identifies the speed with which the substance is introduced into the subject. Typically the rate for an infusion. 200ml in 2 hours.
     * </p>
   */
  public DosageInstruction setRate(RatioDt theValue) {
    myRate = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>maxDosePerPeriod</b> (Upper limit on medication per unit of time).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * The maximum total quantity of a therapeutic substance that may be administered to a subject over the period of time. E.g. 1000mg in 24 hours.
     * </p>
   */
  public RatioDt getMaxDosePerPeriod() { 
    if (myMaxDosePerPeriod == null) {
      myMaxDosePerPeriod = new RatioDt();
    }
    return myMaxDosePerPeriod;
  }

  /**
   * Sets the value(s) for <b>maxDosePerPeriod</b> (Upper limit on medication per unit of time)
   *
     * <p>
     * <b>Definition:</b>
     * The maximum total quantity of a therapeutic substance that may be administered to a subject over the period of time. E.g. 1000mg in 24 hours.
     * </p>
   */
  public DosageInstruction setMaxDosePerPeriod(RatioDt theValue) {
    myMaxDosePerPeriod = theValue;
    return this;
  }

 

  }


  /**
   * Block class for child element: <b>MedicationPrescription.dispense</b> (Medication supply authorization)
   *
     * <p>
     * <b>Definition:</b>
     * Deals with details of the dispense part of the order
     * </p>
   */
  @Block() 
  public static class Dispense extends BaseElement implements IResourceBlock {
 
  @Child(name="medication", order=0, min=0, max=1, type={
    ca.uhn.fhir.model.dstu.resource.Medication.class  })
  @Description(
    shortDefinition="Product to be supplied",
    formalDefinition="Identifies the medication that is to be dispensed.  This may be a more specifically defined than the medicationPrescription.medication . This is either a link to a resource representing the details of the medication or a simple attribute carrying a code that identifies the medication from a known list of medications."
  )
  private ResourceReferenceDt myMedication;
 
  @Child(name="validityPeriod", type=PeriodDt.class, order=1, min=0, max=1
  @Description(
    shortDefinition="Time period supply is authorized for",
    formalDefinition="Design Comments: This indicates the validity period of a prescription (stale dating the Prescription) It reflects the prescriber perspective for the validity of the prescription. Dispenses must not be made against the prescription outside of this period. The lower-bound of the Dispensing Window signifies the earliest date that the prescription can be filled for the first time. If an upper-bound is not specified then the Prescription is open-ended or will default to a stale-date based on regulations. Rationale: Indicates when the Prescription becomes valid, and when it ceases to be a dispensable Prescription."
  )
  private PeriodDt myValidityPeriod;
 
  @Child(name="numberOfRepeatsAllowed", type=IntegerDt.class, order=2, min=0, max=1
  @Description(
    shortDefinition="# of refills authorized",
    formalDefinition="An integer indicating the number of repeats of the Dispense. UsageNotes: For example, the number of times the prescribed quantity is to be supplied including the initial standard fill."
  )
  private IntegerDt myNumberOfRepeatsAllowed;
 
  @Child(name="quantity", type=QuantityDt.class, order=3, min=0, max=1
  @Description(
    shortDefinition="Amount of medication to supply per dispense",
    formalDefinition="The amount that is to be dispensed."
  )
  private QuantityDt myQuantity;
 
  @Child(name="expectedSupplyDuration", type=DurationDt.class, order=4, min=0, max=1
  @Description(
    shortDefinition="Days supply per dispense",
    formalDefinition="Identifies the period time over which the supplied product is expected to be used, or the length of time the dispense is expected to last. In some situations, this attribute may be used instead of quantity to identify the amount supplied by how long it is expected to last, rather than the physical quantity issued, e.g. 90 days supply of medication (based on an ordered dosage) When possible, it is always better to specify quantity, as this tends to be more precise. expectedSupplyDuration will always be an estimate that can be influenced by external factors."
  )
  private DurationDt myExpectedSupplyDuration;
 

  @Override
  public boolean isEmpty() {
    return super.isBaseEmpty() && ca.uhn.fhir.util.ElementUtil.isEmptymyMedication,  myValidityPeriod,  myNumberOfRepeatsAllowed,  myQuantity,  myExpectedSupplyDuration);
  }
 
  @Override
  public <T extends IElement> List<T> getAllPopulatedChildElementsOfType(Class<T> theType) {
    return ca.uhn.fhir.util.ElementUtil.allPopulatedChildElements(theType, myMedication, myValidityPeriod, myNumberOfRepeatsAllowed, myQuantity, myExpectedSupplyDuration);
  }

  /**
   * Gets the value(s) for <b>medication</b> (Product to be supplied).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Identifies the medication that is to be dispensed.  This may be a more specifically defined than the medicationPrescription.medication . This is either a link to a resource representing the details of the medication or a simple attribute carrying a code that identifies the medication from a known list of medications.
     * </p>
   */
  public ResourceReferenceDt getMedication() { 
    if (myMedication == null) {
      myMedication = new ResourceReferenceDt();
    }
    return myMedication;
  }

  /**
   * Sets the value(s) for <b>medication</b> (Product to be supplied)
   *
     * <p>
     * <b>Definition:</b>
     * Identifies the medication that is to be dispensed.  This may be a more specifically defined than the medicationPrescription.medication . This is either a link to a resource representing the details of the medication or a simple attribute carrying a code that identifies the medication from a known list of medications.
     * </p>
   */
  public Dispense setMedication(ResourceReferenceDt theValue) {
    myMedication = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>validityPeriod</b> (Time period supply is authorized for).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Design Comments: This indicates the validity period of a prescription (stale dating the Prescription) It reflects the prescriber perspective for the validity of the prescription. Dispenses must not be made against the prescription outside of this period. The lower-bound of the Dispensing Window signifies the earliest date that the prescription can be filled for the first time. If an upper-bound is not specified then the Prescription is open-ended or will default to a stale-date based on regulations. Rationale: Indicates when the Prescription becomes valid, and when it ceases to be a dispensable Prescription.
     * </p>
   */
  public PeriodDt getValidityPeriod() { 
    if (myValidityPeriod == null) {
      myValidityPeriod = new PeriodDt();
    }
    return myValidityPeriod;
  }

  /**
   * Sets the value(s) for <b>validityPeriod</b> (Time period supply is authorized for)
   *
     * <p>
     * <b>Definition:</b>
     * Design Comments: This indicates the validity period of a prescription (stale dating the Prescription) It reflects the prescriber perspective for the validity of the prescription. Dispenses must not be made against the prescription outside of this period. The lower-bound of the Dispensing Window signifies the earliest date that the prescription can be filled for the first time. If an upper-bound is not specified then the Prescription is open-ended or will default to a stale-date based on regulations. Rationale: Indicates when the Prescription becomes valid, and when it ceases to be a dispensable Prescription.
     * </p>
   */
  public Dispense setValidityPeriod(PeriodDt theValue) {
    myValidityPeriod = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>numberOfRepeatsAllowed</b> (# of refills authorized).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * An integer indicating the number of repeats of the Dispense. UsageNotes: For example, the number of times the prescribed quantity is to be supplied including the initial standard fill.
     * </p>
   */
  public IntegerDt getNumberOfRepeatsAllowed() { 
    if (myNumberOfRepeatsAllowed == null) {
      myNumberOfRepeatsAllowed = new IntegerDt();
    }
    return myNumberOfRepeatsAllowed;
  }

  /**
   * Sets the value(s) for <b>numberOfRepeatsAllowed</b> (# of refills authorized)
   *
     * <p>
     * <b>Definition:</b>
     * An integer indicating the number of repeats of the Dispense. UsageNotes: For example, the number of times the prescribed quantity is to be supplied including the initial standard fill.
     * </p>
   */
  public Dispense setNumberOfRepeatsAllowed(IntegerDt theValue) {
    myNumberOfRepeatsAllowed = theValue;
    return this;
  }

   /**
   * Sets the value for <b>numberOfRepeatsAllowed</b> (# of refills authorized)
   *
     * <p>
     * <b>Definition:</b>
     * An integer indicating the number of repeats of the Dispense. UsageNotes: For example, the number of times the prescribed quantity is to be supplied including the initial standard fill.
     * </p>
   */
  public Dispense setNumberOfRepeatsAllowed( int theInteger) {
    myNumberOfRepeatsAllowed = new IntegerDt(theInteger);
    return this;
  }

  /**
   * Gets the value(s) for <b>quantity</b> (Amount of medication to supply per dispense).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * The amount that is to be dispensed.
     * </p>
   */
  public QuantityDt getQuantity() { 
    if (myQuantity == null) {
      myQuantity = new QuantityDt();
    }
    return myQuantity;
  }

  /**
   * Sets the value(s) for <b>quantity</b> (Amount of medication to supply per dispense)
   *
     * <p>
     * <b>Definition:</b>
     * The amount that is to be dispensed.
     * </p>
   */
  public Dispense setQuantity(QuantityDt theValue) {
    myQuantity = theValue;
    return this;
  }

   /**
   * Sets the value for <b>quantity</b> (Amount of medication to supply per dispense)
   *
     * <p>
     * <b>Definition:</b>
     * The amount that is to be dispensed.
     * </p>
   */
  public Dispense setQuantity( QuantityCompararatorEnum theComparator,  long theValue,  String theUnits) {
    myQuantity = new QuantityDt(theComparator, theValue, theUnits);
    return this;
  }

  /**
   * Sets the value for <b>quantity</b> (Amount of medication to supply per dispense)
   *
     * <p>
     * <b>Definition:</b>
     * The amount that is to be dispensed.
     * </p>
   */
  public Dispense setQuantity( QuantityCompararatorEnum theComparator,  double theValue,  String theUnits) {
    myQuantity = new QuantityDt(theComparator, theValue, theUnits);
    return this;
  }

  /**
   * Sets the value for <b>quantity</b> (Amount of medication to supply per dispense)
   *
     * <p>
     * <b>Definition:</b>
     * The amount that is to be dispensed.
     * </p>
   */
  public Dispense setQuantity( long theValue) {
    myQuantity = new QuantityDt(theValue);
    return this;
  }

  /**
   * Sets the value for <b>quantity</b> (Amount of medication to supply per dispense)
   *
     * <p>
     * <b>Definition:</b>
     * The amount that is to be dispensed.
     * </p>
   */
  public Dispense setQuantity( double theValue) {
    myQuantity = new QuantityDt(theValue);
    return this;
  }

  /**
   * Gets the value(s) for <b>expectedSupplyDuration</b> (Days supply per dispense).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Identifies the period time over which the supplied product is expected to be used, or the length of time the dispense is expected to last. In some situations, this attribute may be used instead of quantity to identify the amount supplied by how long it is expected to last, rather than the physical quantity issued, e.g. 90 days supply of medication (based on an ordered dosage) When possible, it is always better to specify quantity, as this tends to be more precise. expectedSupplyDuration will always be an estimate that can be influenced by external factors.
     * </p>
   */
  public DurationDt getExpectedSupplyDuration() { 
    if (myExpectedSupplyDuration == null) {
      myExpectedSupplyDuration = new DurationDt();
    }
    return myExpectedSupplyDuration;
  }

  /**
   * Sets the value(s) for <b>expectedSupplyDuration</b> (Days supply per dispense)
   *
     * <p>
     * <b>Definition:</b>
     * Identifies the period time over which the supplied product is expected to be used, or the length of time the dispense is expected to last. In some situations, this attribute may be used instead of quantity to identify the amount supplied by how long it is expected to last, rather than the physical quantity issued, e.g. 90 days supply of medication (based on an ordered dosage) When possible, it is always better to specify quantity, as this tends to be more precise. expectedSupplyDuration will always be an estimate that can be influenced by external factors.
     * </p>
   */
  public Dispense setExpectedSupplyDuration(DurationDt theValue) {
    myExpectedSupplyDuration = theValue;
    return this;
  }

 

  }


  /**
   * Block class for child element: <b>MedicationPrescription.substitution</b> (Any restrictions on medication substitution?)
   *
     * <p>
     * <b>Definition:</b>
     * Indicates whether or not substitution can or should be part of the dispense. In some cases substitution must happen, in other cases substitution must not happen, and in others it does not matter. This block explains the prescriber's intent. If nothing is specified substitution may be done.
     * </p>
   */
  @Block() 
  public static class Substitution extends BaseElement implements IResourceBlock {
 
  @Child(name="type", type=CodeableConceptDt.class, order=0, min=1, max=1
  @Description(
    shortDefinition="generic | formulary +",
    formalDefinition="A code signifying whether a different drug should be dispensed from what was prescribed."
  )
  private CodeableConceptDt myType;
 
  @Child(name="reason", type=CodeableConceptDt.class, order=1, min=0, max=1
  @Description(
    shortDefinition="Why should substitution (not) be made",
    formalDefinition="Indicates the reason for the substitution, or why substitution must or must not be performed."
  )
  private CodeableConceptDt myReason;
 

  @Override
  public boolean isEmpty() {
    return super.isBaseEmpty() && ca.uhn.fhir.util.ElementUtil.isEmptymyType,  myReason);
  }
 
  @Override
  public <T extends IElement> List<T> getAllPopulatedChildElementsOfType(Class<T> theType) {
    return ca.uhn.fhir.util.ElementUtil.allPopulatedChildElements(theType, myType, myReason);
  }

  /**
   * Gets the value(s) for <b>type</b> (generic | formulary +).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * A code signifying whether a different drug should be dispensed from what was prescribed.
     * </p>
   */
  public CodeableConceptDt getType() { 
    if (myType == null) {
      myType = new CodeableConceptDt();
    }
    return myType;
  }

  /**
   * Sets the value(s) for <b>type</b> (generic | formulary +)
   *
     * <p>
     * <b>Definition:</b>
     * A code signifying whether a different drug should be dispensed from what was prescribed.
     * </p>
   */
  public Substitution setType(CodeableConceptDt theValue) {
    myType = theValue;
    return this;
  }

 
  /**
   * Gets the value(s) for <b>reason</b> (Why should substitution (not) be made).
   * creating it if it does
   * not exist. Will not return <code>null</code>.
   *
     * <p>
     * <b>Definition:</b>
     * Indicates the reason for the substitution, or why substitution must or must not be performed.
     * </p>
   */
  public CodeableConceptDt getReason() { 
    if (myReason == null) {
      myReason = new CodeableConceptDt();
    }
    return myReason;
  }

  /**
   * Sets the value(s) for <b>reason</b> (Why should substitution (not) be made)
   *
     * <p>
     * <b>Definition:</b>
     * Indicates the reason for the substitution, or why substitution must or must not be performed.
     * </p>
   */
  public Substitution setReason(CodeableConceptDt theValue) {
    myReason = theValue;
    return this;
  }

 

  }




}
TOP

Related Classes of ca.uhn.fhir.model.dstu.resource.MedicationPrescription$Dispense

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.