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