001package org.hl7.fhir.r5.model; 002 003 004/* 005 Copyright (c) 2011+, HL7, Inc. 006 All rights reserved. 007 008 Redistribution and use in source and binary forms, with or without modification, \ 009 are permitted provided that the following conditions are met: 010 011 * Redistributions of source code must retain the above copyright notice, this \ 012 list of conditions and the following disclaimer. 013 * Redistributions in binary form must reproduce the above copyright notice, \ 014 this list of conditions and the following disclaimer in the documentation \ 015 and/or other materials provided with the distribution. 016 * Neither the name of HL7 nor the names of its contributors may be used to 017 endorse or promote products derived from this software without specific 018 prior written permission. 019 020 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND \ 021 ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED \ 022 WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. \ 023 IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, \ 024 INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT \ 025 NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR \ 026 PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, \ 027 WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) \ 028 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE \ 029 POSSIBILITY OF SUCH DAMAGE. 030 */ 031 032// Generated on Thu, Mar 23, 2023 19:59+1100 for FHIR v5.0.0 033 034import java.util.ArrayList; 035import java.util.Date; 036import java.util.List; 037import org.hl7.fhir.utilities.Utilities; 038import org.hl7.fhir.r5.model.Enumerations.*; 039import org.hl7.fhir.instance.model.api.IBaseBackboneElement; 040import org.hl7.fhir.exceptions.FHIRException; 041import org.hl7.fhir.instance.model.api.ICompositeType; 042import ca.uhn.fhir.model.api.annotation.ResourceDef; 043import ca.uhn.fhir.model.api.annotation.SearchParamDefinition; 044import org.hl7.fhir.instance.model.api.IBaseBackboneElement; 045import ca.uhn.fhir.model.api.annotation.Child; 046import ca.uhn.fhir.model.api.annotation.ChildOrder; 047import ca.uhn.fhir.model.api.annotation.Description; 048import ca.uhn.fhir.model.api.annotation.Block; 049 050/** 051 * This resource allows for the definition of various types of plans as a sharable, consumable, and executable artifact. The resource is general enough to support the description of a broad range of clinical and non-clinical artifacts such as clinical decision support rules, order sets, protocols, and drug quality specifications. 052 */ 053@ResourceDef(name="PlanDefinition", profile="http://hl7.org/fhir/StructureDefinition/PlanDefinition") 054public class PlanDefinition extends MetadataResource { 055 056 @Block() 057 public static class PlanDefinitionGoalComponent extends BackboneElement implements IBaseBackboneElement { 058 /** 059 * Indicates a category the goal falls within. 060 */ 061 @Child(name = "category", type = {CodeableConcept.class}, order=1, min=0, max=1, modifier=false, summary=false) 062 @Description(shortDefinition="E.g. Treatment, dietary, behavioral", formalDefinition="Indicates a category the goal falls within." ) 063 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/goal-category") 064 protected CodeableConcept category; 065 066 /** 067 * Human-readable and/or coded description of a specific desired objective of care, such as "control blood pressure" or "negotiate an obstacle course" or "dance with child at wedding". 068 */ 069 @Child(name = "description", type = {CodeableConcept.class}, order=2, min=1, max=1, modifier=false, summary=false) 070 @Description(shortDefinition="Code or text describing the goal", formalDefinition="Human-readable and/or coded description of a specific desired objective of care, such as \"control blood pressure\" or \"negotiate an obstacle course\" or \"dance with child at wedding\"." ) 071 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/clinical-findings") 072 protected CodeableConcept description; 073 074 /** 075 * Identifies the expected level of importance associated with reaching/sustaining the defined goal. 076 */ 077 @Child(name = "priority", type = {CodeableConcept.class}, order=3, min=0, max=1, modifier=false, summary=false) 078 @Description(shortDefinition="high-priority | medium-priority | low-priority", formalDefinition="Identifies the expected level of importance associated with reaching/sustaining the defined goal." ) 079 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/goal-priority") 080 protected CodeableConcept priority; 081 082 /** 083 * The event after which the goal should begin being pursued. 084 */ 085 @Child(name = "start", type = {CodeableConcept.class}, order=4, min=0, max=1, modifier=false, summary=false) 086 @Description(shortDefinition="When goal pursuit begins", formalDefinition="The event after which the goal should begin being pursued." ) 087 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/goal-start-event") 088 protected CodeableConcept start; 089 090 /** 091 * Identifies problems, conditions, issues, or concerns the goal is intended to address. 092 */ 093 @Child(name = "addresses", type = {CodeableConcept.class}, order=5, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 094 @Description(shortDefinition="What does the goal address", formalDefinition="Identifies problems, conditions, issues, or concerns the goal is intended to address." ) 095 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/condition-code") 096 protected List<CodeableConcept> addresses; 097 098 /** 099 * Didactic or other informational resources associated with the goal that provide further supporting information about the goal. Information resources can include inline text commentary and links to web resources. 100 */ 101 @Child(name = "documentation", type = {RelatedArtifact.class}, order=6, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 102 @Description(shortDefinition="Supporting documentation for the goal", formalDefinition="Didactic or other informational resources associated with the goal that provide further supporting information about the goal. Information resources can include inline text commentary and links to web resources." ) 103 protected List<RelatedArtifact> documentation; 104 105 /** 106 * Indicates what should be done and within what timeframe. 107 */ 108 @Child(name = "target", type = {}, order=7, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 109 @Description(shortDefinition="Target outcome for the goal", formalDefinition="Indicates what should be done and within what timeframe." ) 110 protected List<PlanDefinitionGoalTargetComponent> target; 111 112 private static final long serialVersionUID = -795308926L; 113 114 /** 115 * Constructor 116 */ 117 public PlanDefinitionGoalComponent() { 118 super(); 119 } 120 121 /** 122 * Constructor 123 */ 124 public PlanDefinitionGoalComponent(CodeableConcept description) { 125 super(); 126 this.setDescription(description); 127 } 128 129 /** 130 * @return {@link #category} (Indicates a category the goal falls within.) 131 */ 132 public CodeableConcept getCategory() { 133 if (this.category == null) 134 if (Configuration.errorOnAutoCreate()) 135 throw new Error("Attempt to auto-create PlanDefinitionGoalComponent.category"); 136 else if (Configuration.doAutoCreate()) 137 this.category = new CodeableConcept(); // cc 138 return this.category; 139 } 140 141 public boolean hasCategory() { 142 return this.category != null && !this.category.isEmpty(); 143 } 144 145 /** 146 * @param value {@link #category} (Indicates a category the goal falls within.) 147 */ 148 public PlanDefinitionGoalComponent setCategory(CodeableConcept value) { 149 this.category = value; 150 return this; 151 } 152 153 /** 154 * @return {@link #description} (Human-readable and/or coded description of a specific desired objective of care, such as "control blood pressure" or "negotiate an obstacle course" or "dance with child at wedding".) 155 */ 156 public CodeableConcept getDescription() { 157 if (this.description == null) 158 if (Configuration.errorOnAutoCreate()) 159 throw new Error("Attempt to auto-create PlanDefinitionGoalComponent.description"); 160 else if (Configuration.doAutoCreate()) 161 this.description = new CodeableConcept(); // cc 162 return this.description; 163 } 164 165 public boolean hasDescription() { 166 return this.description != null && !this.description.isEmpty(); 167 } 168 169 /** 170 * @param value {@link #description} (Human-readable and/or coded description of a specific desired objective of care, such as "control blood pressure" or "negotiate an obstacle course" or "dance with child at wedding".) 171 */ 172 public PlanDefinitionGoalComponent setDescription(CodeableConcept value) { 173 this.description = value; 174 return this; 175 } 176 177 /** 178 * @return {@link #priority} (Identifies the expected level of importance associated with reaching/sustaining the defined goal.) 179 */ 180 public CodeableConcept getPriority() { 181 if (this.priority == null) 182 if (Configuration.errorOnAutoCreate()) 183 throw new Error("Attempt to auto-create PlanDefinitionGoalComponent.priority"); 184 else if (Configuration.doAutoCreate()) 185 this.priority = new CodeableConcept(); // cc 186 return this.priority; 187 } 188 189 public boolean hasPriority() { 190 return this.priority != null && !this.priority.isEmpty(); 191 } 192 193 /** 194 * @param value {@link #priority} (Identifies the expected level of importance associated with reaching/sustaining the defined goal.) 195 */ 196 public PlanDefinitionGoalComponent setPriority(CodeableConcept value) { 197 this.priority = value; 198 return this; 199 } 200 201 /** 202 * @return {@link #start} (The event after which the goal should begin being pursued.) 203 */ 204 public CodeableConcept getStart() { 205 if (this.start == null) 206 if (Configuration.errorOnAutoCreate()) 207 throw new Error("Attempt to auto-create PlanDefinitionGoalComponent.start"); 208 else if (Configuration.doAutoCreate()) 209 this.start = new CodeableConcept(); // cc 210 return this.start; 211 } 212 213 public boolean hasStart() { 214 return this.start != null && !this.start.isEmpty(); 215 } 216 217 /** 218 * @param value {@link #start} (The event after which the goal should begin being pursued.) 219 */ 220 public PlanDefinitionGoalComponent setStart(CodeableConcept value) { 221 this.start = value; 222 return this; 223 } 224 225 /** 226 * @return {@link #addresses} (Identifies problems, conditions, issues, or concerns the goal is intended to address.) 227 */ 228 public List<CodeableConcept> getAddresses() { 229 if (this.addresses == null) 230 this.addresses = new ArrayList<CodeableConcept>(); 231 return this.addresses; 232 } 233 234 /** 235 * @return Returns a reference to <code>this</code> for easy method chaining 236 */ 237 public PlanDefinitionGoalComponent setAddresses(List<CodeableConcept> theAddresses) { 238 this.addresses = theAddresses; 239 return this; 240 } 241 242 public boolean hasAddresses() { 243 if (this.addresses == null) 244 return false; 245 for (CodeableConcept item : this.addresses) 246 if (!item.isEmpty()) 247 return true; 248 return false; 249 } 250 251 public CodeableConcept addAddresses() { //3 252 CodeableConcept t = new CodeableConcept(); 253 if (this.addresses == null) 254 this.addresses = new ArrayList<CodeableConcept>(); 255 this.addresses.add(t); 256 return t; 257 } 258 259 public PlanDefinitionGoalComponent addAddresses(CodeableConcept t) { //3 260 if (t == null) 261 return this; 262 if (this.addresses == null) 263 this.addresses = new ArrayList<CodeableConcept>(); 264 this.addresses.add(t); 265 return this; 266 } 267 268 /** 269 * @return The first repetition of repeating field {@link #addresses}, creating it if it does not already exist {3} 270 */ 271 public CodeableConcept getAddressesFirstRep() { 272 if (getAddresses().isEmpty()) { 273 addAddresses(); 274 } 275 return getAddresses().get(0); 276 } 277 278 /** 279 * @return {@link #documentation} (Didactic or other informational resources associated with the goal that provide further supporting information about the goal. Information resources can include inline text commentary and links to web resources.) 280 */ 281 public List<RelatedArtifact> getDocumentation() { 282 if (this.documentation == null) 283 this.documentation = new ArrayList<RelatedArtifact>(); 284 return this.documentation; 285 } 286 287 /** 288 * @return Returns a reference to <code>this</code> for easy method chaining 289 */ 290 public PlanDefinitionGoalComponent setDocumentation(List<RelatedArtifact> theDocumentation) { 291 this.documentation = theDocumentation; 292 return this; 293 } 294 295 public boolean hasDocumentation() { 296 if (this.documentation == null) 297 return false; 298 for (RelatedArtifact item : this.documentation) 299 if (!item.isEmpty()) 300 return true; 301 return false; 302 } 303 304 public RelatedArtifact addDocumentation() { //3 305 RelatedArtifact t = new RelatedArtifact(); 306 if (this.documentation == null) 307 this.documentation = new ArrayList<RelatedArtifact>(); 308 this.documentation.add(t); 309 return t; 310 } 311 312 public PlanDefinitionGoalComponent addDocumentation(RelatedArtifact t) { //3 313 if (t == null) 314 return this; 315 if (this.documentation == null) 316 this.documentation = new ArrayList<RelatedArtifact>(); 317 this.documentation.add(t); 318 return this; 319 } 320 321 /** 322 * @return The first repetition of repeating field {@link #documentation}, creating it if it does not already exist {3} 323 */ 324 public RelatedArtifact getDocumentationFirstRep() { 325 if (getDocumentation().isEmpty()) { 326 addDocumentation(); 327 } 328 return getDocumentation().get(0); 329 } 330 331 /** 332 * @return {@link #target} (Indicates what should be done and within what timeframe.) 333 */ 334 public List<PlanDefinitionGoalTargetComponent> getTarget() { 335 if (this.target == null) 336 this.target = new ArrayList<PlanDefinitionGoalTargetComponent>(); 337 return this.target; 338 } 339 340 /** 341 * @return Returns a reference to <code>this</code> for easy method chaining 342 */ 343 public PlanDefinitionGoalComponent setTarget(List<PlanDefinitionGoalTargetComponent> theTarget) { 344 this.target = theTarget; 345 return this; 346 } 347 348 public boolean hasTarget() { 349 if (this.target == null) 350 return false; 351 for (PlanDefinitionGoalTargetComponent item : this.target) 352 if (!item.isEmpty()) 353 return true; 354 return false; 355 } 356 357 public PlanDefinitionGoalTargetComponent addTarget() { //3 358 PlanDefinitionGoalTargetComponent t = new PlanDefinitionGoalTargetComponent(); 359 if (this.target == null) 360 this.target = new ArrayList<PlanDefinitionGoalTargetComponent>(); 361 this.target.add(t); 362 return t; 363 } 364 365 public PlanDefinitionGoalComponent addTarget(PlanDefinitionGoalTargetComponent t) { //3 366 if (t == null) 367 return this; 368 if (this.target == null) 369 this.target = new ArrayList<PlanDefinitionGoalTargetComponent>(); 370 this.target.add(t); 371 return this; 372 } 373 374 /** 375 * @return The first repetition of repeating field {@link #target}, creating it if it does not already exist {3} 376 */ 377 public PlanDefinitionGoalTargetComponent getTargetFirstRep() { 378 if (getTarget().isEmpty()) { 379 addTarget(); 380 } 381 return getTarget().get(0); 382 } 383 384 protected void listChildren(List<Property> children) { 385 super.listChildren(children); 386 children.add(new Property("category", "CodeableConcept", "Indicates a category the goal falls within.", 0, 1, category)); 387 children.add(new Property("description", "CodeableConcept", "Human-readable and/or coded description of a specific desired objective of care, such as \"control blood pressure\" or \"negotiate an obstacle course\" or \"dance with child at wedding\".", 0, 1, description)); 388 children.add(new Property("priority", "CodeableConcept", "Identifies the expected level of importance associated with reaching/sustaining the defined goal.", 0, 1, priority)); 389 children.add(new Property("start", "CodeableConcept", "The event after which the goal should begin being pursued.", 0, 1, start)); 390 children.add(new Property("addresses", "CodeableConcept", "Identifies problems, conditions, issues, or concerns the goal is intended to address.", 0, java.lang.Integer.MAX_VALUE, addresses)); 391 children.add(new Property("documentation", "RelatedArtifact", "Didactic or other informational resources associated with the goal that provide further supporting information about the goal. Information resources can include inline text commentary and links to web resources.", 0, java.lang.Integer.MAX_VALUE, documentation)); 392 children.add(new Property("target", "", "Indicates what should be done and within what timeframe.", 0, java.lang.Integer.MAX_VALUE, target)); 393 } 394 395 @Override 396 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 397 switch (_hash) { 398 case 50511102: /*category*/ return new Property("category", "CodeableConcept", "Indicates a category the goal falls within.", 0, 1, category); 399 case -1724546052: /*description*/ return new Property("description", "CodeableConcept", "Human-readable and/or coded description of a specific desired objective of care, such as \"control blood pressure\" or \"negotiate an obstacle course\" or \"dance with child at wedding\".", 0, 1, description); 400 case -1165461084: /*priority*/ return new Property("priority", "CodeableConcept", "Identifies the expected level of importance associated with reaching/sustaining the defined goal.", 0, 1, priority); 401 case 109757538: /*start*/ return new Property("start", "CodeableConcept", "The event after which the goal should begin being pursued.", 0, 1, start); 402 case 874544034: /*addresses*/ return new Property("addresses", "CodeableConcept", "Identifies problems, conditions, issues, or concerns the goal is intended to address.", 0, java.lang.Integer.MAX_VALUE, addresses); 403 case 1587405498: /*documentation*/ return new Property("documentation", "RelatedArtifact", "Didactic or other informational resources associated with the goal that provide further supporting information about the goal. Information resources can include inline text commentary and links to web resources.", 0, java.lang.Integer.MAX_VALUE, documentation); 404 case -880905839: /*target*/ return new Property("target", "", "Indicates what should be done and within what timeframe.", 0, java.lang.Integer.MAX_VALUE, target); 405 default: return super.getNamedProperty(_hash, _name, _checkValid); 406 } 407 408 } 409 410 @Override 411 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 412 switch (hash) { 413 case 50511102: /*category*/ return this.category == null ? new Base[0] : new Base[] {this.category}; // CodeableConcept 414 case -1724546052: /*description*/ return this.description == null ? new Base[0] : new Base[] {this.description}; // CodeableConcept 415 case -1165461084: /*priority*/ return this.priority == null ? new Base[0] : new Base[] {this.priority}; // CodeableConcept 416 case 109757538: /*start*/ return this.start == null ? new Base[0] : new Base[] {this.start}; // CodeableConcept 417 case 874544034: /*addresses*/ return this.addresses == null ? new Base[0] : this.addresses.toArray(new Base[this.addresses.size()]); // CodeableConcept 418 case 1587405498: /*documentation*/ return this.documentation == null ? new Base[0] : this.documentation.toArray(new Base[this.documentation.size()]); // RelatedArtifact 419 case -880905839: /*target*/ return this.target == null ? new Base[0] : this.target.toArray(new Base[this.target.size()]); // PlanDefinitionGoalTargetComponent 420 default: return super.getProperty(hash, name, checkValid); 421 } 422 423 } 424 425 @Override 426 public Base setProperty(int hash, String name, Base value) throws FHIRException { 427 switch (hash) { 428 case 50511102: // category 429 this.category = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 430 return value; 431 case -1724546052: // description 432 this.description = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 433 return value; 434 case -1165461084: // priority 435 this.priority = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 436 return value; 437 case 109757538: // start 438 this.start = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 439 return value; 440 case 874544034: // addresses 441 this.getAddresses().add(TypeConvertor.castToCodeableConcept(value)); // CodeableConcept 442 return value; 443 case 1587405498: // documentation 444 this.getDocumentation().add(TypeConvertor.castToRelatedArtifact(value)); // RelatedArtifact 445 return value; 446 case -880905839: // target 447 this.getTarget().add((PlanDefinitionGoalTargetComponent) value); // PlanDefinitionGoalTargetComponent 448 return value; 449 default: return super.setProperty(hash, name, value); 450 } 451 452 } 453 454 @Override 455 public Base setProperty(String name, Base value) throws FHIRException { 456 if (name.equals("category")) { 457 this.category = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 458 } else if (name.equals("description")) { 459 this.description = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 460 } else if (name.equals("priority")) { 461 this.priority = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 462 } else if (name.equals("start")) { 463 this.start = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 464 } else if (name.equals("addresses")) { 465 this.getAddresses().add(TypeConvertor.castToCodeableConcept(value)); 466 } else if (name.equals("documentation")) { 467 this.getDocumentation().add(TypeConvertor.castToRelatedArtifact(value)); 468 } else if (name.equals("target")) { 469 this.getTarget().add((PlanDefinitionGoalTargetComponent) value); 470 } else 471 return super.setProperty(name, value); 472 return value; 473 } 474 475 @Override 476 public void removeChild(String name, Base value) throws FHIRException { 477 if (name.equals("category")) { 478 this.category = null; 479 } else if (name.equals("description")) { 480 this.description = null; 481 } else if (name.equals("priority")) { 482 this.priority = null; 483 } else if (name.equals("start")) { 484 this.start = null; 485 } else if (name.equals("addresses")) { 486 this.getAddresses().remove(value); 487 } else if (name.equals("documentation")) { 488 this.getDocumentation().remove(value); 489 } else if (name.equals("target")) { 490 this.getTarget().remove((PlanDefinitionGoalTargetComponent) value); 491 } else 492 super.removeChild(name, value); 493 494 } 495 496 @Override 497 public Base makeProperty(int hash, String name) throws FHIRException { 498 switch (hash) { 499 case 50511102: return getCategory(); 500 case -1724546052: return getDescription(); 501 case -1165461084: return getPriority(); 502 case 109757538: return getStart(); 503 case 874544034: return addAddresses(); 504 case 1587405498: return addDocumentation(); 505 case -880905839: return addTarget(); 506 default: return super.makeProperty(hash, name); 507 } 508 509 } 510 511 @Override 512 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 513 switch (hash) { 514 case 50511102: /*category*/ return new String[] {"CodeableConcept"}; 515 case -1724546052: /*description*/ return new String[] {"CodeableConcept"}; 516 case -1165461084: /*priority*/ return new String[] {"CodeableConcept"}; 517 case 109757538: /*start*/ return new String[] {"CodeableConcept"}; 518 case 874544034: /*addresses*/ return new String[] {"CodeableConcept"}; 519 case 1587405498: /*documentation*/ return new String[] {"RelatedArtifact"}; 520 case -880905839: /*target*/ return new String[] {}; 521 default: return super.getTypesForProperty(hash, name); 522 } 523 524 } 525 526 @Override 527 public Base addChild(String name) throws FHIRException { 528 if (name.equals("category")) { 529 this.category = new CodeableConcept(); 530 return this.category; 531 } 532 else if (name.equals("description")) { 533 this.description = new CodeableConcept(); 534 return this.description; 535 } 536 else if (name.equals("priority")) { 537 this.priority = new CodeableConcept(); 538 return this.priority; 539 } 540 else if (name.equals("start")) { 541 this.start = new CodeableConcept(); 542 return this.start; 543 } 544 else if (name.equals("addresses")) { 545 return addAddresses(); 546 } 547 else if (name.equals("documentation")) { 548 return addDocumentation(); 549 } 550 else if (name.equals("target")) { 551 return addTarget(); 552 } 553 else 554 return super.addChild(name); 555 } 556 557 public PlanDefinitionGoalComponent copy() { 558 PlanDefinitionGoalComponent dst = new PlanDefinitionGoalComponent(); 559 copyValues(dst); 560 return dst; 561 } 562 563 public void copyValues(PlanDefinitionGoalComponent dst) { 564 super.copyValues(dst); 565 dst.category = category == null ? null : category.copy(); 566 dst.description = description == null ? null : description.copy(); 567 dst.priority = priority == null ? null : priority.copy(); 568 dst.start = start == null ? null : start.copy(); 569 if (addresses != null) { 570 dst.addresses = new ArrayList<CodeableConcept>(); 571 for (CodeableConcept i : addresses) 572 dst.addresses.add(i.copy()); 573 }; 574 if (documentation != null) { 575 dst.documentation = new ArrayList<RelatedArtifact>(); 576 for (RelatedArtifact i : documentation) 577 dst.documentation.add(i.copy()); 578 }; 579 if (target != null) { 580 dst.target = new ArrayList<PlanDefinitionGoalTargetComponent>(); 581 for (PlanDefinitionGoalTargetComponent i : target) 582 dst.target.add(i.copy()); 583 }; 584 } 585 586 @Override 587 public boolean equalsDeep(Base other_) { 588 if (!super.equalsDeep(other_)) 589 return false; 590 if (!(other_ instanceof PlanDefinitionGoalComponent)) 591 return false; 592 PlanDefinitionGoalComponent o = (PlanDefinitionGoalComponent) other_; 593 return compareDeep(category, o.category, true) && compareDeep(description, o.description, true) 594 && compareDeep(priority, o.priority, true) && compareDeep(start, o.start, true) && compareDeep(addresses, o.addresses, true) 595 && compareDeep(documentation, o.documentation, true) && compareDeep(target, o.target, true); 596 } 597 598 @Override 599 public boolean equalsShallow(Base other_) { 600 if (!super.equalsShallow(other_)) 601 return false; 602 if (!(other_ instanceof PlanDefinitionGoalComponent)) 603 return false; 604 PlanDefinitionGoalComponent o = (PlanDefinitionGoalComponent) other_; 605 return true; 606 } 607 608 public boolean isEmpty() { 609 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(category, description, priority 610 , start, addresses, documentation, target); 611 } 612 613 public String fhirType() { 614 return "PlanDefinition.goal"; 615 616 } 617 618 } 619 620 @Block() 621 public static class PlanDefinitionGoalTargetComponent extends BackboneElement implements IBaseBackboneElement { 622 /** 623 * The parameter whose value is to be tracked, e.g. body weight, blood pressure, or hemoglobin A1c level. 624 */ 625 @Child(name = "measure", type = {CodeableConcept.class}, order=1, min=0, max=1, modifier=false, summary=false) 626 @Description(shortDefinition="The parameter whose value is to be tracked", formalDefinition="The parameter whose value is to be tracked, e.g. body weight, blood pressure, or hemoglobin A1c level." ) 627 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/observation-codes") 628 protected CodeableConcept measure; 629 630 /** 631 * The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value. 632 */ 633 @Child(name = "detail", type = {Quantity.class, Range.class, CodeableConcept.class, StringType.class, BooleanType.class, IntegerType.class, Ratio.class}, order=2, min=0, max=1, modifier=false, summary=false) 634 @Description(shortDefinition="The target value to be achieved", formalDefinition="The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value." ) 635 protected DataType detail; 636 637 /** 638 * Indicates the timeframe after the start of the goal in which the goal should be met. 639 */ 640 @Child(name = "due", type = {Duration.class}, order=3, min=0, max=1, modifier=false, summary=false) 641 @Description(shortDefinition="Reach goal within", formalDefinition="Indicates the timeframe after the start of the goal in which the goal should be met." ) 642 protected Duration due; 643 644 private static final long serialVersionUID = -1464475626L; 645 646 /** 647 * Constructor 648 */ 649 public PlanDefinitionGoalTargetComponent() { 650 super(); 651 } 652 653 /** 654 * @return {@link #measure} (The parameter whose value is to be tracked, e.g. body weight, blood pressure, or hemoglobin A1c level.) 655 */ 656 public CodeableConcept getMeasure() { 657 if (this.measure == null) 658 if (Configuration.errorOnAutoCreate()) 659 throw new Error("Attempt to auto-create PlanDefinitionGoalTargetComponent.measure"); 660 else if (Configuration.doAutoCreate()) 661 this.measure = new CodeableConcept(); // cc 662 return this.measure; 663 } 664 665 public boolean hasMeasure() { 666 return this.measure != null && !this.measure.isEmpty(); 667 } 668 669 /** 670 * @param value {@link #measure} (The parameter whose value is to be tracked, e.g. body weight, blood pressure, or hemoglobin A1c level.) 671 */ 672 public PlanDefinitionGoalTargetComponent setMeasure(CodeableConcept value) { 673 this.measure = value; 674 return this; 675 } 676 677 /** 678 * @return {@link #detail} (The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.) 679 */ 680 public DataType getDetail() { 681 return this.detail; 682 } 683 684 /** 685 * @return {@link #detail} (The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.) 686 */ 687 public Quantity getDetailQuantity() throws FHIRException { 688 if (this.detail == null) 689 this.detail = new Quantity(); 690 if (!(this.detail instanceof Quantity)) 691 throw new FHIRException("Type mismatch: the type Quantity was expected, but "+this.detail.getClass().getName()+" was encountered"); 692 return (Quantity) this.detail; 693 } 694 695 public boolean hasDetailQuantity() { 696 return this != null && this.detail instanceof Quantity; 697 } 698 699 /** 700 * @return {@link #detail} (The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.) 701 */ 702 public Range getDetailRange() throws FHIRException { 703 if (this.detail == null) 704 this.detail = new Range(); 705 if (!(this.detail instanceof Range)) 706 throw new FHIRException("Type mismatch: the type Range was expected, but "+this.detail.getClass().getName()+" was encountered"); 707 return (Range) this.detail; 708 } 709 710 public boolean hasDetailRange() { 711 return this != null && this.detail instanceof Range; 712 } 713 714 /** 715 * @return {@link #detail} (The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.) 716 */ 717 public CodeableConcept getDetailCodeableConcept() throws FHIRException { 718 if (this.detail == null) 719 this.detail = new CodeableConcept(); 720 if (!(this.detail instanceof CodeableConcept)) 721 throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "+this.detail.getClass().getName()+" was encountered"); 722 return (CodeableConcept) this.detail; 723 } 724 725 public boolean hasDetailCodeableConcept() { 726 return this != null && this.detail instanceof CodeableConcept; 727 } 728 729 /** 730 * @return {@link #detail} (The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.) 731 */ 732 public StringType getDetailStringType() throws FHIRException { 733 if (this.detail == null) 734 this.detail = new StringType(); 735 if (!(this.detail instanceof StringType)) 736 throw new FHIRException("Type mismatch: the type StringType was expected, but "+this.detail.getClass().getName()+" was encountered"); 737 return (StringType) this.detail; 738 } 739 740 public boolean hasDetailStringType() { 741 return this != null && this.detail instanceof StringType; 742 } 743 744 /** 745 * @return {@link #detail} (The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.) 746 */ 747 public BooleanType getDetailBooleanType() throws FHIRException { 748 if (this.detail == null) 749 this.detail = new BooleanType(); 750 if (!(this.detail instanceof BooleanType)) 751 throw new FHIRException("Type mismatch: the type BooleanType was expected, but "+this.detail.getClass().getName()+" was encountered"); 752 return (BooleanType) this.detail; 753 } 754 755 public boolean hasDetailBooleanType() { 756 return this != null && this.detail instanceof BooleanType; 757 } 758 759 /** 760 * @return {@link #detail} (The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.) 761 */ 762 public IntegerType getDetailIntegerType() throws FHIRException { 763 if (this.detail == null) 764 this.detail = new IntegerType(); 765 if (!(this.detail instanceof IntegerType)) 766 throw new FHIRException("Type mismatch: the type IntegerType was expected, but "+this.detail.getClass().getName()+" was encountered"); 767 return (IntegerType) this.detail; 768 } 769 770 public boolean hasDetailIntegerType() { 771 return this != null && this.detail instanceof IntegerType; 772 } 773 774 /** 775 * @return {@link #detail} (The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.) 776 */ 777 public Ratio getDetailRatio() throws FHIRException { 778 if (this.detail == null) 779 this.detail = new Ratio(); 780 if (!(this.detail instanceof Ratio)) 781 throw new FHIRException("Type mismatch: the type Ratio was expected, but "+this.detail.getClass().getName()+" was encountered"); 782 return (Ratio) this.detail; 783 } 784 785 public boolean hasDetailRatio() { 786 return this != null && this.detail instanceof Ratio; 787 } 788 789 public boolean hasDetail() { 790 return this.detail != null && !this.detail.isEmpty(); 791 } 792 793 /** 794 * @param value {@link #detail} (The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.) 795 */ 796 public PlanDefinitionGoalTargetComponent setDetail(DataType value) { 797 if (value != null && !(value instanceof Quantity || value instanceof Range || value instanceof CodeableConcept || value instanceof StringType || value instanceof BooleanType || value instanceof IntegerType || value instanceof Ratio)) 798 throw new FHIRException("Not the right type for PlanDefinition.goal.target.detail[x]: "+value.fhirType()); 799 this.detail = value; 800 return this; 801 } 802 803 /** 804 * @return {@link #due} (Indicates the timeframe after the start of the goal in which the goal should be met.) 805 */ 806 public Duration getDue() { 807 if (this.due == null) 808 if (Configuration.errorOnAutoCreate()) 809 throw new Error("Attempt to auto-create PlanDefinitionGoalTargetComponent.due"); 810 else if (Configuration.doAutoCreate()) 811 this.due = new Duration(); // cc 812 return this.due; 813 } 814 815 public boolean hasDue() { 816 return this.due != null && !this.due.isEmpty(); 817 } 818 819 /** 820 * @param value {@link #due} (Indicates the timeframe after the start of the goal in which the goal should be met.) 821 */ 822 public PlanDefinitionGoalTargetComponent setDue(Duration value) { 823 this.due = value; 824 return this; 825 } 826 827 protected void listChildren(List<Property> children) { 828 super.listChildren(children); 829 children.add(new Property("measure", "CodeableConcept", "The parameter whose value is to be tracked, e.g. body weight, blood pressure, or hemoglobin A1c level.", 0, 1, measure)); 830 children.add(new Property("detail[x]", "Quantity|Range|CodeableConcept|string|boolean|integer|Ratio", "The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.", 0, 1, detail)); 831 children.add(new Property("due", "Duration", "Indicates the timeframe after the start of the goal in which the goal should be met.", 0, 1, due)); 832 } 833 834 @Override 835 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 836 switch (_hash) { 837 case 938321246: /*measure*/ return new Property("measure", "CodeableConcept", "The parameter whose value is to be tracked, e.g. body weight, blood pressure, or hemoglobin A1c level.", 0, 1, measure); 838 case -1973084529: /*detail[x]*/ return new Property("detail[x]", "Quantity|Range|CodeableConcept|string|boolean|integer|Ratio", "The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.", 0, 1, detail); 839 case -1335224239: /*detail*/ return new Property("detail[x]", "Quantity|Range|CodeableConcept|string|boolean|integer|Ratio", "The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.", 0, 1, detail); 840 case -1313079300: /*detailQuantity*/ return new Property("detail[x]", "Quantity", "The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.", 0, 1, detail); 841 case -2062632084: /*detailRange*/ return new Property("detail[x]", "Range", "The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.", 0, 1, detail); 842 case -175586544: /*detailCodeableConcept*/ return new Property("detail[x]", "CodeableConcept", "The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.", 0, 1, detail); 843 case 529212354: /*detailString*/ return new Property("detail[x]", "string", "The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.", 0, 1, detail); 844 case 1172184727: /*detailBoolean*/ return new Property("detail[x]", "boolean", "The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.", 0, 1, detail); 845 case -1229442131: /*detailInteger*/ return new Property("detail[x]", "integer", "The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.", 0, 1, detail); 846 case -2062626246: /*detailRatio*/ return new Property("detail[x]", "Ratio", "The target value of the measure to be achieved to signify fulfillment of the goal, e.g. 150 pounds or 7.0%, or in the case of pharmaceutical quality - NMT 0.6%, Clear solution, etc. Either the high or low or both values of the range can be specified. When a low value is missing, it indicates that the goal is achieved at any value at or below the high value. Similarly, if the high value is missing, it indicates that the goal is achieved at any value at or above the low value.", 0, 1, detail); 847 case 99828: /*due*/ return new Property("due", "Duration", "Indicates the timeframe after the start of the goal in which the goal should be met.", 0, 1, due); 848 default: return super.getNamedProperty(_hash, _name, _checkValid); 849 } 850 851 } 852 853 @Override 854 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 855 switch (hash) { 856 case 938321246: /*measure*/ return this.measure == null ? new Base[0] : new Base[] {this.measure}; // CodeableConcept 857 case -1335224239: /*detail*/ return this.detail == null ? new Base[0] : new Base[] {this.detail}; // DataType 858 case 99828: /*due*/ return this.due == null ? new Base[0] : new Base[] {this.due}; // Duration 859 default: return super.getProperty(hash, name, checkValid); 860 } 861 862 } 863 864 @Override 865 public Base setProperty(int hash, String name, Base value) throws FHIRException { 866 switch (hash) { 867 case 938321246: // measure 868 this.measure = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 869 return value; 870 case -1335224239: // detail 871 this.detail = TypeConvertor.castToType(value); // DataType 872 return value; 873 case 99828: // due 874 this.due = TypeConvertor.castToDuration(value); // Duration 875 return value; 876 default: return super.setProperty(hash, name, value); 877 } 878 879 } 880 881 @Override 882 public Base setProperty(String name, Base value) throws FHIRException { 883 if (name.equals("measure")) { 884 this.measure = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 885 } else if (name.equals("detail[x]")) { 886 this.detail = TypeConvertor.castToType(value); // DataType 887 } else if (name.equals("due")) { 888 this.due = TypeConvertor.castToDuration(value); // Duration 889 } else 890 return super.setProperty(name, value); 891 return value; 892 } 893 894 @Override 895 public void removeChild(String name, Base value) throws FHIRException { 896 if (name.equals("measure")) { 897 this.measure = null; 898 } else if (name.equals("detail[x]")) { 899 this.detail = null; 900 } else if (name.equals("due")) { 901 this.due = null; 902 } else 903 super.removeChild(name, value); 904 905 } 906 907 @Override 908 public Base makeProperty(int hash, String name) throws FHIRException { 909 switch (hash) { 910 case 938321246: return getMeasure(); 911 case -1973084529: return getDetail(); 912 case -1335224239: return getDetail(); 913 case 99828: return getDue(); 914 default: return super.makeProperty(hash, name); 915 } 916 917 } 918 919 @Override 920 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 921 switch (hash) { 922 case 938321246: /*measure*/ return new String[] {"CodeableConcept"}; 923 case -1335224239: /*detail*/ return new String[] {"Quantity", "Range", "CodeableConcept", "string", "boolean", "integer", "Ratio"}; 924 case 99828: /*due*/ return new String[] {"Duration"}; 925 default: return super.getTypesForProperty(hash, name); 926 } 927 928 } 929 930 @Override 931 public Base addChild(String name) throws FHIRException { 932 if (name.equals("measure")) { 933 this.measure = new CodeableConcept(); 934 return this.measure; 935 } 936 else if (name.equals("detailQuantity")) { 937 this.detail = new Quantity(); 938 return this.detail; 939 } 940 else if (name.equals("detailRange")) { 941 this.detail = new Range(); 942 return this.detail; 943 } 944 else if (name.equals("detailCodeableConcept")) { 945 this.detail = new CodeableConcept(); 946 return this.detail; 947 } 948 else if (name.equals("detailString")) { 949 this.detail = new StringType(); 950 return this.detail; 951 } 952 else if (name.equals("detailBoolean")) { 953 this.detail = new BooleanType(); 954 return this.detail; 955 } 956 else if (name.equals("detailInteger")) { 957 this.detail = new IntegerType(); 958 return this.detail; 959 } 960 else if (name.equals("detailRatio")) { 961 this.detail = new Ratio(); 962 return this.detail; 963 } 964 else if (name.equals("due")) { 965 this.due = new Duration(); 966 return this.due; 967 } 968 else 969 return super.addChild(name); 970 } 971 972 public PlanDefinitionGoalTargetComponent copy() { 973 PlanDefinitionGoalTargetComponent dst = new PlanDefinitionGoalTargetComponent(); 974 copyValues(dst); 975 return dst; 976 } 977 978 public void copyValues(PlanDefinitionGoalTargetComponent dst) { 979 super.copyValues(dst); 980 dst.measure = measure == null ? null : measure.copy(); 981 dst.detail = detail == null ? null : detail.copy(); 982 dst.due = due == null ? null : due.copy(); 983 } 984 985 @Override 986 public boolean equalsDeep(Base other_) { 987 if (!super.equalsDeep(other_)) 988 return false; 989 if (!(other_ instanceof PlanDefinitionGoalTargetComponent)) 990 return false; 991 PlanDefinitionGoalTargetComponent o = (PlanDefinitionGoalTargetComponent) other_; 992 return compareDeep(measure, o.measure, true) && compareDeep(detail, o.detail, true) && compareDeep(due, o.due, true) 993 ; 994 } 995 996 @Override 997 public boolean equalsShallow(Base other_) { 998 if (!super.equalsShallow(other_)) 999 return false; 1000 if (!(other_ instanceof PlanDefinitionGoalTargetComponent)) 1001 return false; 1002 PlanDefinitionGoalTargetComponent o = (PlanDefinitionGoalTargetComponent) other_; 1003 return true; 1004 } 1005 1006 public boolean isEmpty() { 1007 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(measure, detail, due); 1008 } 1009 1010 public String fhirType() { 1011 return "PlanDefinition.goal.target"; 1012 1013 } 1014 1015 } 1016 1017 @Block() 1018 public static class PlanDefinitionActorComponent extends BackboneElement implements IBaseBackboneElement { 1019 /** 1020 * A descriptive label for the actor. 1021 */ 1022 @Child(name = "title", type = {StringType.class}, order=1, min=0, max=1, modifier=false, summary=false) 1023 @Description(shortDefinition="User-visible title", formalDefinition="A descriptive label for the actor." ) 1024 protected StringType title; 1025 1026 /** 1027 * A description of how the actor fits into the overall actions of the plan definition. 1028 */ 1029 @Child(name = "description", type = {MarkdownType.class}, order=2, min=0, max=1, modifier=false, summary=false) 1030 @Description(shortDefinition="Describes the actor", formalDefinition="A description of how the actor fits into the overall actions of the plan definition." ) 1031 protected MarkdownType description; 1032 1033 /** 1034 * The characteristics of the candidates that could serve as the actor. 1035 */ 1036 @Child(name = "option", type = {}, order=3, min=1, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1037 @Description(shortDefinition="Who or what can be this actor", formalDefinition="The characteristics of the candidates that could serve as the actor." ) 1038 protected List<PlanDefinitionActorOptionComponent> option; 1039 1040 private static final long serialVersionUID = -571302300L; 1041 1042 /** 1043 * Constructor 1044 */ 1045 public PlanDefinitionActorComponent() { 1046 super(); 1047 } 1048 1049 /** 1050 * Constructor 1051 */ 1052 public PlanDefinitionActorComponent(PlanDefinitionActorOptionComponent option) { 1053 super(); 1054 this.addOption(option); 1055 } 1056 1057 /** 1058 * @return {@link #title} (A descriptive label for the actor.). This is the underlying object with id, value and extensions. The accessor "getTitle" gives direct access to the value 1059 */ 1060 public StringType getTitleElement() { 1061 if (this.title == null) 1062 if (Configuration.errorOnAutoCreate()) 1063 throw new Error("Attempt to auto-create PlanDefinitionActorComponent.title"); 1064 else if (Configuration.doAutoCreate()) 1065 this.title = new StringType(); // bb 1066 return this.title; 1067 } 1068 1069 public boolean hasTitleElement() { 1070 return this.title != null && !this.title.isEmpty(); 1071 } 1072 1073 public boolean hasTitle() { 1074 return this.title != null && !this.title.isEmpty(); 1075 } 1076 1077 /** 1078 * @param value {@link #title} (A descriptive label for the actor.). This is the underlying object with id, value and extensions. The accessor "getTitle" gives direct access to the value 1079 */ 1080 public PlanDefinitionActorComponent setTitleElement(StringType value) { 1081 this.title = value; 1082 return this; 1083 } 1084 1085 /** 1086 * @return A descriptive label for the actor. 1087 */ 1088 public String getTitle() { 1089 return this.title == null ? null : this.title.getValue(); 1090 } 1091 1092 /** 1093 * @param value A descriptive label for the actor. 1094 */ 1095 public PlanDefinitionActorComponent setTitle(String value) { 1096 if (Utilities.noString(value)) 1097 this.title = null; 1098 else { 1099 if (this.title == null) 1100 this.title = new StringType(); 1101 this.title.setValue(value); 1102 } 1103 return this; 1104 } 1105 1106 /** 1107 * @return {@link #description} (A description of how the actor fits into the overall actions of the plan definition.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value 1108 */ 1109 public MarkdownType getDescriptionElement() { 1110 if (this.description == null) 1111 if (Configuration.errorOnAutoCreate()) 1112 throw new Error("Attempt to auto-create PlanDefinitionActorComponent.description"); 1113 else if (Configuration.doAutoCreate()) 1114 this.description = new MarkdownType(); // bb 1115 return this.description; 1116 } 1117 1118 public boolean hasDescriptionElement() { 1119 return this.description != null && !this.description.isEmpty(); 1120 } 1121 1122 public boolean hasDescription() { 1123 return this.description != null && !this.description.isEmpty(); 1124 } 1125 1126 /** 1127 * @param value {@link #description} (A description of how the actor fits into the overall actions of the plan definition.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value 1128 */ 1129 public PlanDefinitionActorComponent setDescriptionElement(MarkdownType value) { 1130 this.description = value; 1131 return this; 1132 } 1133 1134 /** 1135 * @return A description of how the actor fits into the overall actions of the plan definition. 1136 */ 1137 public String getDescription() { 1138 return this.description == null ? null : this.description.getValue(); 1139 } 1140 1141 /** 1142 * @param value A description of how the actor fits into the overall actions of the plan definition. 1143 */ 1144 public PlanDefinitionActorComponent setDescription(String value) { 1145 if (Utilities.noString(value)) 1146 this.description = null; 1147 else { 1148 if (this.description == null) 1149 this.description = new MarkdownType(); 1150 this.description.setValue(value); 1151 } 1152 return this; 1153 } 1154 1155 /** 1156 * @return {@link #option} (The characteristics of the candidates that could serve as the actor.) 1157 */ 1158 public List<PlanDefinitionActorOptionComponent> getOption() { 1159 if (this.option == null) 1160 this.option = new ArrayList<PlanDefinitionActorOptionComponent>(); 1161 return this.option; 1162 } 1163 1164 /** 1165 * @return Returns a reference to <code>this</code> for easy method chaining 1166 */ 1167 public PlanDefinitionActorComponent setOption(List<PlanDefinitionActorOptionComponent> theOption) { 1168 this.option = theOption; 1169 return this; 1170 } 1171 1172 public boolean hasOption() { 1173 if (this.option == null) 1174 return false; 1175 for (PlanDefinitionActorOptionComponent item : this.option) 1176 if (!item.isEmpty()) 1177 return true; 1178 return false; 1179 } 1180 1181 public PlanDefinitionActorOptionComponent addOption() { //3 1182 PlanDefinitionActorOptionComponent t = new PlanDefinitionActorOptionComponent(); 1183 if (this.option == null) 1184 this.option = new ArrayList<PlanDefinitionActorOptionComponent>(); 1185 this.option.add(t); 1186 return t; 1187 } 1188 1189 public PlanDefinitionActorComponent addOption(PlanDefinitionActorOptionComponent t) { //3 1190 if (t == null) 1191 return this; 1192 if (this.option == null) 1193 this.option = new ArrayList<PlanDefinitionActorOptionComponent>(); 1194 this.option.add(t); 1195 return this; 1196 } 1197 1198 /** 1199 * @return The first repetition of repeating field {@link #option}, creating it if it does not already exist {3} 1200 */ 1201 public PlanDefinitionActorOptionComponent getOptionFirstRep() { 1202 if (getOption().isEmpty()) { 1203 addOption(); 1204 } 1205 return getOption().get(0); 1206 } 1207 1208 protected void listChildren(List<Property> children) { 1209 super.listChildren(children); 1210 children.add(new Property("title", "string", "A descriptive label for the actor.", 0, 1, title)); 1211 children.add(new Property("description", "markdown", "A description of how the actor fits into the overall actions of the plan definition.", 0, 1, description)); 1212 children.add(new Property("option", "", "The characteristics of the candidates that could serve as the actor.", 0, java.lang.Integer.MAX_VALUE, option)); 1213 } 1214 1215 @Override 1216 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 1217 switch (_hash) { 1218 case 110371416: /*title*/ return new Property("title", "string", "A descriptive label for the actor.", 0, 1, title); 1219 case -1724546052: /*description*/ return new Property("description", "markdown", "A description of how the actor fits into the overall actions of the plan definition.", 0, 1, description); 1220 case -1010136971: /*option*/ return new Property("option", "", "The characteristics of the candidates that could serve as the actor.", 0, java.lang.Integer.MAX_VALUE, option); 1221 default: return super.getNamedProperty(_hash, _name, _checkValid); 1222 } 1223 1224 } 1225 1226 @Override 1227 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 1228 switch (hash) { 1229 case 110371416: /*title*/ return this.title == null ? new Base[0] : new Base[] {this.title}; // StringType 1230 case -1724546052: /*description*/ return this.description == null ? new Base[0] : new Base[] {this.description}; // MarkdownType 1231 case -1010136971: /*option*/ return this.option == null ? new Base[0] : this.option.toArray(new Base[this.option.size()]); // PlanDefinitionActorOptionComponent 1232 default: return super.getProperty(hash, name, checkValid); 1233 } 1234 1235 } 1236 1237 @Override 1238 public Base setProperty(int hash, String name, Base value) throws FHIRException { 1239 switch (hash) { 1240 case 110371416: // title 1241 this.title = TypeConvertor.castToString(value); // StringType 1242 return value; 1243 case -1724546052: // description 1244 this.description = TypeConvertor.castToMarkdown(value); // MarkdownType 1245 return value; 1246 case -1010136971: // option 1247 this.getOption().add((PlanDefinitionActorOptionComponent) value); // PlanDefinitionActorOptionComponent 1248 return value; 1249 default: return super.setProperty(hash, name, value); 1250 } 1251 1252 } 1253 1254 @Override 1255 public Base setProperty(String name, Base value) throws FHIRException { 1256 if (name.equals("title")) { 1257 this.title = TypeConvertor.castToString(value); // StringType 1258 } else if (name.equals("description")) { 1259 this.description = TypeConvertor.castToMarkdown(value); // MarkdownType 1260 } else if (name.equals("option")) { 1261 this.getOption().add((PlanDefinitionActorOptionComponent) value); 1262 } else 1263 return super.setProperty(name, value); 1264 return value; 1265 } 1266 1267 @Override 1268 public void removeChild(String name, Base value) throws FHIRException { 1269 if (name.equals("title")) { 1270 this.title = null; 1271 } else if (name.equals("description")) { 1272 this.description = null; 1273 } else if (name.equals("option")) { 1274 this.getOption().remove((PlanDefinitionActorOptionComponent) value); 1275 } else 1276 super.removeChild(name, value); 1277 1278 } 1279 1280 @Override 1281 public Base makeProperty(int hash, String name) throws FHIRException { 1282 switch (hash) { 1283 case 110371416: return getTitleElement(); 1284 case -1724546052: return getDescriptionElement(); 1285 case -1010136971: return addOption(); 1286 default: return super.makeProperty(hash, name); 1287 } 1288 1289 } 1290 1291 @Override 1292 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 1293 switch (hash) { 1294 case 110371416: /*title*/ return new String[] {"string"}; 1295 case -1724546052: /*description*/ return new String[] {"markdown"}; 1296 case -1010136971: /*option*/ return new String[] {}; 1297 default: return super.getTypesForProperty(hash, name); 1298 } 1299 1300 } 1301 1302 @Override 1303 public Base addChild(String name) throws FHIRException { 1304 if (name.equals("title")) { 1305 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.actor.title"); 1306 } 1307 else if (name.equals("description")) { 1308 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.actor.description"); 1309 } 1310 else if (name.equals("option")) { 1311 return addOption(); 1312 } 1313 else 1314 return super.addChild(name); 1315 } 1316 1317 public PlanDefinitionActorComponent copy() { 1318 PlanDefinitionActorComponent dst = new PlanDefinitionActorComponent(); 1319 copyValues(dst); 1320 return dst; 1321 } 1322 1323 public void copyValues(PlanDefinitionActorComponent dst) { 1324 super.copyValues(dst); 1325 dst.title = title == null ? null : title.copy(); 1326 dst.description = description == null ? null : description.copy(); 1327 if (option != null) { 1328 dst.option = new ArrayList<PlanDefinitionActorOptionComponent>(); 1329 for (PlanDefinitionActorOptionComponent i : option) 1330 dst.option.add(i.copy()); 1331 }; 1332 } 1333 1334 @Override 1335 public boolean equalsDeep(Base other_) { 1336 if (!super.equalsDeep(other_)) 1337 return false; 1338 if (!(other_ instanceof PlanDefinitionActorComponent)) 1339 return false; 1340 PlanDefinitionActorComponent o = (PlanDefinitionActorComponent) other_; 1341 return compareDeep(title, o.title, true) && compareDeep(description, o.description, true) && compareDeep(option, o.option, true) 1342 ; 1343 } 1344 1345 @Override 1346 public boolean equalsShallow(Base other_) { 1347 if (!super.equalsShallow(other_)) 1348 return false; 1349 if (!(other_ instanceof PlanDefinitionActorComponent)) 1350 return false; 1351 PlanDefinitionActorComponent o = (PlanDefinitionActorComponent) other_; 1352 return compareValues(title, o.title, true) && compareValues(description, o.description, true); 1353 } 1354 1355 public boolean isEmpty() { 1356 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(title, description, option 1357 ); 1358 } 1359 1360 public String fhirType() { 1361 return "PlanDefinition.actor"; 1362 1363 } 1364 1365 } 1366 1367 @Block() 1368 public static class PlanDefinitionActorOptionComponent extends BackboneElement implements IBaseBackboneElement { 1369 /** 1370 * The type of participant in the action. 1371 */ 1372 @Child(name = "type", type = {CodeType.class}, order=1, min=0, max=1, modifier=false, summary=false) 1373 @Description(shortDefinition="careteam | device | group | healthcareservice | location | organization | patient | practitioner | practitionerrole | relatedperson", formalDefinition="The type of participant in the action." ) 1374 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-participant-type") 1375 protected Enumeration<ActionParticipantType> type; 1376 1377 /** 1378 * The type of participant in the action. 1379 */ 1380 @Child(name = "typeCanonical", type = {CanonicalType.class}, order=2, min=0, max=1, modifier=false, summary=false) 1381 @Description(shortDefinition="Who or what can participate", formalDefinition="The type of participant in the action." ) 1382 protected CanonicalType typeCanonical; 1383 1384 /** 1385 * The type of participant in the action. 1386 */ 1387 @Child(name = "typeReference", type = {CareTeam.class, Device.class, DeviceDefinition.class, Endpoint.class, Group.class, HealthcareService.class, Location.class, Organization.class, Patient.class, Practitioner.class, PractitionerRole.class, RelatedPerson.class}, order=3, min=0, max=1, modifier=false, summary=false) 1388 @Description(shortDefinition="Who or what can participate", formalDefinition="The type of participant in the action." ) 1389 protected Reference typeReference; 1390 1391 /** 1392 * The role the participant should play in performing the described action. 1393 */ 1394 @Child(name = "role", type = {CodeableConcept.class}, order=4, min=0, max=1, modifier=false, summary=false) 1395 @Description(shortDefinition="E.g. Nurse, Surgeon, Parent", formalDefinition="The role the participant should play in performing the described action." ) 1396 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://terminology.hl7.org/ValueSet/action-participant-role") 1397 protected CodeableConcept role; 1398 1399 private static final long serialVersionUID = 1881639157L; 1400 1401 /** 1402 * Constructor 1403 */ 1404 public PlanDefinitionActorOptionComponent() { 1405 super(); 1406 } 1407 1408 /** 1409 * @return {@link #type} (The type of participant in the action.). This is the underlying object with id, value and extensions. The accessor "getType" gives direct access to the value 1410 */ 1411 public Enumeration<ActionParticipantType> getTypeElement() { 1412 if (this.type == null) 1413 if (Configuration.errorOnAutoCreate()) 1414 throw new Error("Attempt to auto-create PlanDefinitionActorOptionComponent.type"); 1415 else if (Configuration.doAutoCreate()) 1416 this.type = new Enumeration<ActionParticipantType>(new ActionParticipantTypeEnumFactory()); // bb 1417 return this.type; 1418 } 1419 1420 public boolean hasTypeElement() { 1421 return this.type != null && !this.type.isEmpty(); 1422 } 1423 1424 public boolean hasType() { 1425 return this.type != null && !this.type.isEmpty(); 1426 } 1427 1428 /** 1429 * @param value {@link #type} (The type of participant in the action.). This is the underlying object with id, value and extensions. The accessor "getType" gives direct access to the value 1430 */ 1431 public PlanDefinitionActorOptionComponent setTypeElement(Enumeration<ActionParticipantType> value) { 1432 this.type = value; 1433 return this; 1434 } 1435 1436 /** 1437 * @return The type of participant in the action. 1438 */ 1439 public ActionParticipantType getType() { 1440 return this.type == null ? null : this.type.getValue(); 1441 } 1442 1443 /** 1444 * @param value The type of participant in the action. 1445 */ 1446 public PlanDefinitionActorOptionComponent setType(ActionParticipantType value) { 1447 if (value == null) 1448 this.type = null; 1449 else { 1450 if (this.type == null) 1451 this.type = new Enumeration<ActionParticipantType>(new ActionParticipantTypeEnumFactory()); 1452 this.type.setValue(value); 1453 } 1454 return this; 1455 } 1456 1457 /** 1458 * @return {@link #typeCanonical} (The type of participant in the action.). This is the underlying object with id, value and extensions. The accessor "getTypeCanonical" gives direct access to the value 1459 */ 1460 public CanonicalType getTypeCanonicalElement() { 1461 if (this.typeCanonical == null) 1462 if (Configuration.errorOnAutoCreate()) 1463 throw new Error("Attempt to auto-create PlanDefinitionActorOptionComponent.typeCanonical"); 1464 else if (Configuration.doAutoCreate()) 1465 this.typeCanonical = new CanonicalType(); // bb 1466 return this.typeCanonical; 1467 } 1468 1469 public boolean hasTypeCanonicalElement() { 1470 return this.typeCanonical != null && !this.typeCanonical.isEmpty(); 1471 } 1472 1473 public boolean hasTypeCanonical() { 1474 return this.typeCanonical != null && !this.typeCanonical.isEmpty(); 1475 } 1476 1477 /** 1478 * @param value {@link #typeCanonical} (The type of participant in the action.). This is the underlying object with id, value and extensions. The accessor "getTypeCanonical" gives direct access to the value 1479 */ 1480 public PlanDefinitionActorOptionComponent setTypeCanonicalElement(CanonicalType value) { 1481 this.typeCanonical = value; 1482 return this; 1483 } 1484 1485 /** 1486 * @return The type of participant in the action. 1487 */ 1488 public String getTypeCanonical() { 1489 return this.typeCanonical == null ? null : this.typeCanonical.getValue(); 1490 } 1491 1492 /** 1493 * @param value The type of participant in the action. 1494 */ 1495 public PlanDefinitionActorOptionComponent setTypeCanonical(String value) { 1496 if (Utilities.noString(value)) 1497 this.typeCanonical = null; 1498 else { 1499 if (this.typeCanonical == null) 1500 this.typeCanonical = new CanonicalType(); 1501 this.typeCanonical.setValue(value); 1502 } 1503 return this; 1504 } 1505 1506 /** 1507 * @return {@link #typeReference} (The type of participant in the action.) 1508 */ 1509 public Reference getTypeReference() { 1510 if (this.typeReference == null) 1511 if (Configuration.errorOnAutoCreate()) 1512 throw new Error("Attempt to auto-create PlanDefinitionActorOptionComponent.typeReference"); 1513 else if (Configuration.doAutoCreate()) 1514 this.typeReference = new Reference(); // cc 1515 return this.typeReference; 1516 } 1517 1518 public boolean hasTypeReference() { 1519 return this.typeReference != null && !this.typeReference.isEmpty(); 1520 } 1521 1522 /** 1523 * @param value {@link #typeReference} (The type of participant in the action.) 1524 */ 1525 public PlanDefinitionActorOptionComponent setTypeReference(Reference value) { 1526 this.typeReference = value; 1527 return this; 1528 } 1529 1530 /** 1531 * @return {@link #role} (The role the participant should play in performing the described action.) 1532 */ 1533 public CodeableConcept getRole() { 1534 if (this.role == null) 1535 if (Configuration.errorOnAutoCreate()) 1536 throw new Error("Attempt to auto-create PlanDefinitionActorOptionComponent.role"); 1537 else if (Configuration.doAutoCreate()) 1538 this.role = new CodeableConcept(); // cc 1539 return this.role; 1540 } 1541 1542 public boolean hasRole() { 1543 return this.role != null && !this.role.isEmpty(); 1544 } 1545 1546 /** 1547 * @param value {@link #role} (The role the participant should play in performing the described action.) 1548 */ 1549 public PlanDefinitionActorOptionComponent setRole(CodeableConcept value) { 1550 this.role = value; 1551 return this; 1552 } 1553 1554 protected void listChildren(List<Property> children) { 1555 super.listChildren(children); 1556 children.add(new Property("type", "code", "The type of participant in the action.", 0, 1, type)); 1557 children.add(new Property("typeCanonical", "canonical(CapabilityStatement)", "The type of participant in the action.", 0, 1, typeCanonical)); 1558 children.add(new Property("typeReference", "Reference(CareTeam|Device|DeviceDefinition|Endpoint|Group|HealthcareService|Location|Organization|Patient|Practitioner|PractitionerRole|RelatedPerson)", "The type of participant in the action.", 0, 1, typeReference)); 1559 children.add(new Property("role", "CodeableConcept", "The role the participant should play in performing the described action.", 0, 1, role)); 1560 } 1561 1562 @Override 1563 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 1564 switch (_hash) { 1565 case 3575610: /*type*/ return new Property("type", "code", "The type of participant in the action.", 0, 1, type); 1566 case -466635046: /*typeCanonical*/ return new Property("typeCanonical", "canonical(CapabilityStatement)", "The type of participant in the action.", 0, 1, typeCanonical); 1567 case 2074825009: /*typeReference*/ return new Property("typeReference", "Reference(CareTeam|Device|DeviceDefinition|Endpoint|Group|HealthcareService|Location|Organization|Patient|Practitioner|PractitionerRole|RelatedPerson)", "The type of participant in the action.", 0, 1, typeReference); 1568 case 3506294: /*role*/ return new Property("role", "CodeableConcept", "The role the participant should play in performing the described action.", 0, 1, role); 1569 default: return super.getNamedProperty(_hash, _name, _checkValid); 1570 } 1571 1572 } 1573 1574 @Override 1575 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 1576 switch (hash) { 1577 case 3575610: /*type*/ return this.type == null ? new Base[0] : new Base[] {this.type}; // Enumeration<ActionParticipantType> 1578 case -466635046: /*typeCanonical*/ return this.typeCanonical == null ? new Base[0] : new Base[] {this.typeCanonical}; // CanonicalType 1579 case 2074825009: /*typeReference*/ return this.typeReference == null ? new Base[0] : new Base[] {this.typeReference}; // Reference 1580 case 3506294: /*role*/ return this.role == null ? new Base[0] : new Base[] {this.role}; // CodeableConcept 1581 default: return super.getProperty(hash, name, checkValid); 1582 } 1583 1584 } 1585 1586 @Override 1587 public Base setProperty(int hash, String name, Base value) throws FHIRException { 1588 switch (hash) { 1589 case 3575610: // type 1590 value = new ActionParticipantTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 1591 this.type = (Enumeration) value; // Enumeration<ActionParticipantType> 1592 return value; 1593 case -466635046: // typeCanonical 1594 this.typeCanonical = TypeConvertor.castToCanonical(value); // CanonicalType 1595 return value; 1596 case 2074825009: // typeReference 1597 this.typeReference = TypeConvertor.castToReference(value); // Reference 1598 return value; 1599 case 3506294: // role 1600 this.role = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 1601 return value; 1602 default: return super.setProperty(hash, name, value); 1603 } 1604 1605 } 1606 1607 @Override 1608 public Base setProperty(String name, Base value) throws FHIRException { 1609 if (name.equals("type")) { 1610 value = new ActionParticipantTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 1611 this.type = (Enumeration) value; // Enumeration<ActionParticipantType> 1612 } else if (name.equals("typeCanonical")) { 1613 this.typeCanonical = TypeConvertor.castToCanonical(value); // CanonicalType 1614 } else if (name.equals("typeReference")) { 1615 this.typeReference = TypeConvertor.castToReference(value); // Reference 1616 } else if (name.equals("role")) { 1617 this.role = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 1618 } else 1619 return super.setProperty(name, value); 1620 return value; 1621 } 1622 1623 @Override 1624 public void removeChild(String name, Base value) throws FHIRException { 1625 if (name.equals("type")) { 1626 value = new ActionParticipantTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 1627 this.type = (Enumeration) value; // Enumeration<ActionParticipantType> 1628 } else if (name.equals("typeCanonical")) { 1629 this.typeCanonical = null; 1630 } else if (name.equals("typeReference")) { 1631 this.typeReference = null; 1632 } else if (name.equals("role")) { 1633 this.role = null; 1634 } else 1635 super.removeChild(name, value); 1636 1637 } 1638 1639 @Override 1640 public Base makeProperty(int hash, String name) throws FHIRException { 1641 switch (hash) { 1642 case 3575610: return getTypeElement(); 1643 case -466635046: return getTypeCanonicalElement(); 1644 case 2074825009: return getTypeReference(); 1645 case 3506294: return getRole(); 1646 default: return super.makeProperty(hash, name); 1647 } 1648 1649 } 1650 1651 @Override 1652 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 1653 switch (hash) { 1654 case 3575610: /*type*/ return new String[] {"code"}; 1655 case -466635046: /*typeCanonical*/ return new String[] {"canonical"}; 1656 case 2074825009: /*typeReference*/ return new String[] {"Reference"}; 1657 case 3506294: /*role*/ return new String[] {"CodeableConcept"}; 1658 default: return super.getTypesForProperty(hash, name); 1659 } 1660 1661 } 1662 1663 @Override 1664 public Base addChild(String name) throws FHIRException { 1665 if (name.equals("type")) { 1666 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.actor.option.type"); 1667 } 1668 else if (name.equals("typeCanonical")) { 1669 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.actor.option.typeCanonical"); 1670 } 1671 else if (name.equals("typeReference")) { 1672 this.typeReference = new Reference(); 1673 return this.typeReference; 1674 } 1675 else if (name.equals("role")) { 1676 this.role = new CodeableConcept(); 1677 return this.role; 1678 } 1679 else 1680 return super.addChild(name); 1681 } 1682 1683 public PlanDefinitionActorOptionComponent copy() { 1684 PlanDefinitionActorOptionComponent dst = new PlanDefinitionActorOptionComponent(); 1685 copyValues(dst); 1686 return dst; 1687 } 1688 1689 public void copyValues(PlanDefinitionActorOptionComponent dst) { 1690 super.copyValues(dst); 1691 dst.type = type == null ? null : type.copy(); 1692 dst.typeCanonical = typeCanonical == null ? null : typeCanonical.copy(); 1693 dst.typeReference = typeReference == null ? null : typeReference.copy(); 1694 dst.role = role == null ? null : role.copy(); 1695 } 1696 1697 @Override 1698 public boolean equalsDeep(Base other_) { 1699 if (!super.equalsDeep(other_)) 1700 return false; 1701 if (!(other_ instanceof PlanDefinitionActorOptionComponent)) 1702 return false; 1703 PlanDefinitionActorOptionComponent o = (PlanDefinitionActorOptionComponent) other_; 1704 return compareDeep(type, o.type, true) && compareDeep(typeCanonical, o.typeCanonical, true) && compareDeep(typeReference, o.typeReference, true) 1705 && compareDeep(role, o.role, true); 1706 } 1707 1708 @Override 1709 public boolean equalsShallow(Base other_) { 1710 if (!super.equalsShallow(other_)) 1711 return false; 1712 if (!(other_ instanceof PlanDefinitionActorOptionComponent)) 1713 return false; 1714 PlanDefinitionActorOptionComponent o = (PlanDefinitionActorOptionComponent) other_; 1715 return compareValues(type, o.type, true) && compareValues(typeCanonical, o.typeCanonical, true); 1716 } 1717 1718 public boolean isEmpty() { 1719 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(type, typeCanonical, typeReference 1720 , role); 1721 } 1722 1723 public String fhirType() { 1724 return "PlanDefinition.actor.option"; 1725 1726 } 1727 1728 } 1729 1730 @Block() 1731 public static class PlanDefinitionActionComponent extends BackboneElement implements IBaseBackboneElement { 1732 /** 1733 * An identifier that is unique within the PlanDefinition to allow linkage within the realized CarePlan and/or RequestOrchestration. 1734 */ 1735 @Child(name = "linkId", type = {StringType.class}, order=1, min=0, max=1, modifier=false, summary=false) 1736 @Description(shortDefinition="Unique id for the action in the PlanDefinition", formalDefinition="An identifier that is unique within the PlanDefinition to allow linkage within the realized CarePlan and/or RequestOrchestration." ) 1737 protected StringType linkId; 1738 1739 /** 1740 * A user-visible prefix for the action. For example a section or item numbering such as 1. or A. 1741 */ 1742 @Child(name = "prefix", type = {StringType.class}, order=2, min=0, max=1, modifier=false, summary=false) 1743 @Description(shortDefinition="User-visible prefix for the action (e.g. 1. or A.)", formalDefinition="A user-visible prefix for the action. For example a section or item numbering such as 1. or A." ) 1744 protected StringType prefix; 1745 1746 /** 1747 * The textual description of the action displayed to a user. For example, when the action is a test to be performed, the title would be the title of the test such as Assay by HPLC. 1748 */ 1749 @Child(name = "title", type = {StringType.class}, order=3, min=0, max=1, modifier=false, summary=false) 1750 @Description(shortDefinition="User-visible title", formalDefinition="The textual description of the action displayed to a user. For example, when the action is a test to be performed, the title would be the title of the test such as Assay by HPLC." ) 1751 protected StringType title; 1752 1753 /** 1754 * A brief description of the action used to provide a summary to display to the user. 1755 */ 1756 @Child(name = "description", type = {MarkdownType.class}, order=4, min=0, max=1, modifier=false, summary=false) 1757 @Description(shortDefinition="Brief description of the action", formalDefinition="A brief description of the action used to provide a summary to display to the user." ) 1758 protected MarkdownType description; 1759 1760 /** 1761 * A text equivalent of the action to be performed. This provides a human-interpretable description of the action when the definition is consumed by a system that might not be capable of interpreting it dynamically. 1762 */ 1763 @Child(name = "textEquivalent", type = {MarkdownType.class}, order=5, min=0, max=1, modifier=false, summary=false) 1764 @Description(shortDefinition="Static text equivalent of the action, used if the dynamic aspects cannot be interpreted by the receiving system", formalDefinition="A text equivalent of the action to be performed. This provides a human-interpretable description of the action when the definition is consumed by a system that might not be capable of interpreting it dynamically." ) 1765 protected MarkdownType textEquivalent; 1766 1767 /** 1768 * Indicates how quickly the action should be addressed with respect to other actions. 1769 */ 1770 @Child(name = "priority", type = {CodeType.class}, order=6, min=0, max=1, modifier=false, summary=false) 1771 @Description(shortDefinition="routine | urgent | asap | stat", formalDefinition="Indicates how quickly the action should be addressed with respect to other actions." ) 1772 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/request-priority") 1773 protected Enumeration<RequestPriority> priority; 1774 1775 /** 1776 * A code that provides a meaning, grouping, or classification for the action or action group. For example, a section may have a LOINC code for the section of a documentation template. In pharmaceutical quality, an action (Test) such as pH could be classified as a physical property. 1777 */ 1778 @Child(name = "code", type = {CodeableConcept.class}, order=7, min=0, max=1, modifier=false, summary=false) 1779 @Description(shortDefinition="Code representing the meaning of the action or sub-actions", formalDefinition="A code that provides a meaning, grouping, or classification for the action or action group. For example, a section may have a LOINC code for the section of a documentation template. In pharmaceutical quality, an action (Test) such as pH could be classified as a physical property." ) 1780 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-code") 1781 protected CodeableConcept code; 1782 1783 /** 1784 * A description of why this action is necessary or appropriate. 1785 */ 1786 @Child(name = "reason", type = {CodeableConcept.class}, order=8, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1787 @Description(shortDefinition="Why the action should be performed", formalDefinition="A description of why this action is necessary or appropriate." ) 1788 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-reason-code") 1789 protected List<CodeableConcept> reason; 1790 1791 /** 1792 * Didactic or other informational resources associated with the action that can be provided to the CDS recipient. Information resources can include inline text commentary and links to web resources. 1793 */ 1794 @Child(name = "documentation", type = {RelatedArtifact.class}, order=9, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1795 @Description(shortDefinition="Supporting documentation for the intended performer of the action", formalDefinition="Didactic or other informational resources associated with the action that can be provided to the CDS recipient. Information resources can include inline text commentary and links to web resources." ) 1796 protected List<RelatedArtifact> documentation; 1797 1798 /** 1799 * Identifies goals that this action supports. The reference must be to a goal element defined within this plan definition. In pharmaceutical quality, a goal represents acceptance criteria (Goal) for a given action (Test), so the goalId would be the unique id of a defined goal element establishing the acceptance criteria for the action. 1800 */ 1801 @Child(name = "goalId", type = {IdType.class}, order=10, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1802 @Description(shortDefinition="What goals this action supports", formalDefinition="Identifies goals that this action supports. The reference must be to a goal element defined within this plan definition. In pharmaceutical quality, a goal represents acceptance criteria (Goal) for a given action (Test), so the goalId would be the unique id of a defined goal element establishing the acceptance criteria for the action." ) 1803 protected List<IdType> goalId; 1804 1805 /** 1806 * A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource. 1807 */ 1808 @Child(name = "subject", type = {CodeableConcept.class, Group.class, CanonicalType.class}, order=11, min=0, max=1, modifier=false, summary=false) 1809 @Description(shortDefinition="Type of individual the action is focused on", formalDefinition="A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource." ) 1810 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/participant-resource-types") 1811 protected DataType subject; 1812 1813 /** 1814 * A description of when the action should be triggered. When multiple triggers are specified on an action, any triggering event invokes the action. 1815 */ 1816 @Child(name = "trigger", type = {TriggerDefinition.class}, order=12, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1817 @Description(shortDefinition="When the action should be triggered", formalDefinition="A description of when the action should be triggered. When multiple triggers are specified on an action, any triggering event invokes the action." ) 1818 protected List<TriggerDefinition> trigger; 1819 1820 /** 1821 * An expression that describes applicability criteria or start/stop conditions for the action. 1822 */ 1823 @Child(name = "condition", type = {}, order=13, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1824 @Description(shortDefinition="Whether or not the action is applicable", formalDefinition="An expression that describes applicability criteria or start/stop conditions for the action." ) 1825 protected List<PlanDefinitionActionConditionComponent> condition; 1826 1827 /** 1828 * Defines input data requirements for the action. 1829 */ 1830 @Child(name = "input", type = {}, order=14, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1831 @Description(shortDefinition="Input data requirements", formalDefinition="Defines input data requirements for the action." ) 1832 protected List<PlanDefinitionActionInputComponent> input; 1833 1834 /** 1835 * Defines the outputs of the action, if any. 1836 */ 1837 @Child(name = "output", type = {}, order=15, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1838 @Description(shortDefinition="Output data definition", formalDefinition="Defines the outputs of the action, if any." ) 1839 protected List<PlanDefinitionActionOutputComponent> output; 1840 1841 /** 1842 * A relationship to another action such as "before" or "30-60 minutes after start of". 1843 */ 1844 @Child(name = "relatedAction", type = {}, order=16, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1845 @Description(shortDefinition="Relationship to another action", formalDefinition="A relationship to another action such as \"before\" or \"30-60 minutes after start of\"." ) 1846 protected List<PlanDefinitionActionRelatedActionComponent> relatedAction; 1847 1848 /** 1849 * An optional value describing when the action should be performed. 1850 */ 1851 @Child(name = "timing", type = {Age.class, Duration.class, Range.class, Timing.class}, order=17, min=0, max=1, modifier=false, summary=false) 1852 @Description(shortDefinition="When the action should take place", formalDefinition="An optional value describing when the action should be performed." ) 1853 protected DataType timing; 1854 1855 /** 1856 * Identifies the facility where the action will occur; e.g. home, hospital, specific clinic, etc. 1857 */ 1858 @Child(name = "location", type = {CodeableReference.class}, order=18, min=0, max=1, modifier=false, summary=false) 1859 @Description(shortDefinition="Where it should happen", formalDefinition="Identifies the facility where the action will occur; e.g. home, hospital, specific clinic, etc." ) 1860 protected CodeableReference location; 1861 1862 /** 1863 * Indicates who should participate in performing the action described. 1864 */ 1865 @Child(name = "participant", type = {}, order=19, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1866 @Description(shortDefinition="Who should participate in the action", formalDefinition="Indicates who should participate in performing the action described." ) 1867 protected List<PlanDefinitionActionParticipantComponent> participant; 1868 1869 /** 1870 * The type of action to perform (create, update, remove). 1871 */ 1872 @Child(name = "type", type = {CodeableConcept.class}, order=20, min=0, max=1, modifier=false, summary=false) 1873 @Description(shortDefinition="create | update | remove | fire-event", formalDefinition="The type of action to perform (create, update, remove)." ) 1874 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-type") 1875 protected CodeableConcept type; 1876 1877 /** 1878 * Defines the grouping behavior for the action and its children. 1879 */ 1880 @Child(name = "groupingBehavior", type = {CodeType.class}, order=21, min=0, max=1, modifier=false, summary=false) 1881 @Description(shortDefinition="visual-group | logical-group | sentence-group", formalDefinition="Defines the grouping behavior for the action and its children." ) 1882 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-grouping-behavior") 1883 protected Enumeration<ActionGroupingBehavior> groupingBehavior; 1884 1885 /** 1886 * Defines the selection behavior for the action and its children. 1887 */ 1888 @Child(name = "selectionBehavior", type = {CodeType.class}, order=22, min=0, max=1, modifier=false, summary=false) 1889 @Description(shortDefinition="any | all | all-or-none | exactly-one | at-most-one | one-or-more", formalDefinition="Defines the selection behavior for the action and its children." ) 1890 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-selection-behavior") 1891 protected Enumeration<ActionSelectionBehavior> selectionBehavior; 1892 1893 /** 1894 * Defines the required behavior for the action. 1895 */ 1896 @Child(name = "requiredBehavior", type = {CodeType.class}, order=23, min=0, max=1, modifier=false, summary=false) 1897 @Description(shortDefinition="must | could | must-unless-documented", formalDefinition="Defines the required behavior for the action." ) 1898 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-required-behavior") 1899 protected Enumeration<ActionRequiredBehavior> requiredBehavior; 1900 1901 /** 1902 * Defines whether the action should usually be preselected. 1903 */ 1904 @Child(name = "precheckBehavior", type = {CodeType.class}, order=24, min=0, max=1, modifier=false, summary=false) 1905 @Description(shortDefinition="yes | no", formalDefinition="Defines whether the action should usually be preselected." ) 1906 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-precheck-behavior") 1907 protected Enumeration<ActionPrecheckBehavior> precheckBehavior; 1908 1909 /** 1910 * Defines whether the action can be selected multiple times. 1911 */ 1912 @Child(name = "cardinalityBehavior", type = {CodeType.class}, order=25, min=0, max=1, modifier=false, summary=false) 1913 @Description(shortDefinition="single | multiple", formalDefinition="Defines whether the action can be selected multiple times." ) 1914 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-cardinality-behavior") 1915 protected Enumeration<ActionCardinalityBehavior> cardinalityBehavior; 1916 1917 /** 1918 * A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured. 1919 */ 1920 @Child(name = "definition", type = {CanonicalType.class, UriType.class}, order=26, min=0, max=1, modifier=false, summary=false) 1921 @Description(shortDefinition="Description of the activity to be performed", formalDefinition="A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured." ) 1922 protected DataType definition; 1923 1924 /** 1925 * A reference to a StructureMap resource that defines a transform that can be executed to produce the intent resource using the ActivityDefinition instance as the input. 1926 */ 1927 @Child(name = "transform", type = {CanonicalType.class}, order=27, min=0, max=1, modifier=false, summary=false) 1928 @Description(shortDefinition="Transform to apply the template", formalDefinition="A reference to a StructureMap resource that defines a transform that can be executed to produce the intent resource using the ActivityDefinition instance as the input." ) 1929 protected CanonicalType transform; 1930 1931 /** 1932 * Customizations that should be applied to the statically defined resource. For example, if the dosage of a medication must be computed based on the patient's weight, a customization would be used to specify an expression that calculated the weight, and the path on the resource that would contain the result. 1933 */ 1934 @Child(name = "dynamicValue", type = {}, order=28, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1935 @Description(shortDefinition="Dynamic aspects of the definition", formalDefinition="Customizations that should be applied to the statically defined resource. For example, if the dosage of a medication must be computed based on the patient's weight, a customization would be used to specify an expression that calculated the weight, and the path on the resource that would contain the result." ) 1936 protected List<PlanDefinitionActionDynamicValueComponent> dynamicValue; 1937 1938 /** 1939 * Sub actions that are contained within the action. The behavior of this action determines the functionality of the sub-actions. For example, a selection behavior of at-most-one indicates that of the sub-actions, at most one may be chosen as part of realizing the action definition. 1940 */ 1941 @Child(name = "action", type = {PlanDefinitionActionComponent.class}, order=29, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 1942 @Description(shortDefinition="A sub-action", formalDefinition="Sub actions that are contained within the action. The behavior of this action determines the functionality of the sub-actions. For example, a selection behavior of at-most-one indicates that of the sub-actions, at most one may be chosen as part of realizing the action definition." ) 1943 protected List<PlanDefinitionActionComponent> action; 1944 1945 private static final long serialVersionUID = 1296604536L; 1946 1947 /** 1948 * Constructor 1949 */ 1950 public PlanDefinitionActionComponent() { 1951 super(); 1952 } 1953 1954 /** 1955 * @return {@link #linkId} (An identifier that is unique within the PlanDefinition to allow linkage within the realized CarePlan and/or RequestOrchestration.). This is the underlying object with id, value and extensions. The accessor "getLinkId" gives direct access to the value 1956 */ 1957 public StringType getLinkIdElement() { 1958 if (this.linkId == null) 1959 if (Configuration.errorOnAutoCreate()) 1960 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.linkId"); 1961 else if (Configuration.doAutoCreate()) 1962 this.linkId = new StringType(); // bb 1963 return this.linkId; 1964 } 1965 1966 public boolean hasLinkIdElement() { 1967 return this.linkId != null && !this.linkId.isEmpty(); 1968 } 1969 1970 public boolean hasLinkId() { 1971 return this.linkId != null && !this.linkId.isEmpty(); 1972 } 1973 1974 /** 1975 * @param value {@link #linkId} (An identifier that is unique within the PlanDefinition to allow linkage within the realized CarePlan and/or RequestOrchestration.). This is the underlying object with id, value and extensions. The accessor "getLinkId" gives direct access to the value 1976 */ 1977 public PlanDefinitionActionComponent setLinkIdElement(StringType value) { 1978 this.linkId = value; 1979 return this; 1980 } 1981 1982 /** 1983 * @return An identifier that is unique within the PlanDefinition to allow linkage within the realized CarePlan and/or RequestOrchestration. 1984 */ 1985 public String getLinkId() { 1986 return this.linkId == null ? null : this.linkId.getValue(); 1987 } 1988 1989 /** 1990 * @param value An identifier that is unique within the PlanDefinition to allow linkage within the realized CarePlan and/or RequestOrchestration. 1991 */ 1992 public PlanDefinitionActionComponent setLinkId(String value) { 1993 if (Utilities.noString(value)) 1994 this.linkId = null; 1995 else { 1996 if (this.linkId == null) 1997 this.linkId = new StringType(); 1998 this.linkId.setValue(value); 1999 } 2000 return this; 2001 } 2002 2003 /** 2004 * @return {@link #prefix} (A user-visible prefix for the action. For example a section or item numbering such as 1. or A.). This is the underlying object with id, value and extensions. The accessor "getPrefix" gives direct access to the value 2005 */ 2006 public StringType getPrefixElement() { 2007 if (this.prefix == null) 2008 if (Configuration.errorOnAutoCreate()) 2009 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.prefix"); 2010 else if (Configuration.doAutoCreate()) 2011 this.prefix = new StringType(); // bb 2012 return this.prefix; 2013 } 2014 2015 public boolean hasPrefixElement() { 2016 return this.prefix != null && !this.prefix.isEmpty(); 2017 } 2018 2019 public boolean hasPrefix() { 2020 return this.prefix != null && !this.prefix.isEmpty(); 2021 } 2022 2023 /** 2024 * @param value {@link #prefix} (A user-visible prefix for the action. For example a section or item numbering such as 1. or A.). This is the underlying object with id, value and extensions. The accessor "getPrefix" gives direct access to the value 2025 */ 2026 public PlanDefinitionActionComponent setPrefixElement(StringType value) { 2027 this.prefix = value; 2028 return this; 2029 } 2030 2031 /** 2032 * @return A user-visible prefix for the action. For example a section or item numbering such as 1. or A. 2033 */ 2034 public String getPrefix() { 2035 return this.prefix == null ? null : this.prefix.getValue(); 2036 } 2037 2038 /** 2039 * @param value A user-visible prefix for the action. For example a section or item numbering such as 1. or A. 2040 */ 2041 public PlanDefinitionActionComponent setPrefix(String value) { 2042 if (Utilities.noString(value)) 2043 this.prefix = null; 2044 else { 2045 if (this.prefix == null) 2046 this.prefix = new StringType(); 2047 this.prefix.setValue(value); 2048 } 2049 return this; 2050 } 2051 2052 /** 2053 * @return {@link #title} (The textual description of the action displayed to a user. For example, when the action is a test to be performed, the title would be the title of the test such as Assay by HPLC.). This is the underlying object with id, value and extensions. The accessor "getTitle" gives direct access to the value 2054 */ 2055 public StringType getTitleElement() { 2056 if (this.title == null) 2057 if (Configuration.errorOnAutoCreate()) 2058 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.title"); 2059 else if (Configuration.doAutoCreate()) 2060 this.title = new StringType(); // bb 2061 return this.title; 2062 } 2063 2064 public boolean hasTitleElement() { 2065 return this.title != null && !this.title.isEmpty(); 2066 } 2067 2068 public boolean hasTitle() { 2069 return this.title != null && !this.title.isEmpty(); 2070 } 2071 2072 /** 2073 * @param value {@link #title} (The textual description of the action displayed to a user. For example, when the action is a test to be performed, the title would be the title of the test such as Assay by HPLC.). This is the underlying object with id, value and extensions. The accessor "getTitle" gives direct access to the value 2074 */ 2075 public PlanDefinitionActionComponent setTitleElement(StringType value) { 2076 this.title = value; 2077 return this; 2078 } 2079 2080 /** 2081 * @return The textual description of the action displayed to a user. For example, when the action is a test to be performed, the title would be the title of the test such as Assay by HPLC. 2082 */ 2083 public String getTitle() { 2084 return this.title == null ? null : this.title.getValue(); 2085 } 2086 2087 /** 2088 * @param value The textual description of the action displayed to a user. For example, when the action is a test to be performed, the title would be the title of the test such as Assay by HPLC. 2089 */ 2090 public PlanDefinitionActionComponent setTitle(String value) { 2091 if (Utilities.noString(value)) 2092 this.title = null; 2093 else { 2094 if (this.title == null) 2095 this.title = new StringType(); 2096 this.title.setValue(value); 2097 } 2098 return this; 2099 } 2100 2101 /** 2102 * @return {@link #description} (A brief description of the action used to provide a summary to display to the user.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value 2103 */ 2104 public MarkdownType getDescriptionElement() { 2105 if (this.description == null) 2106 if (Configuration.errorOnAutoCreate()) 2107 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.description"); 2108 else if (Configuration.doAutoCreate()) 2109 this.description = new MarkdownType(); // bb 2110 return this.description; 2111 } 2112 2113 public boolean hasDescriptionElement() { 2114 return this.description != null && !this.description.isEmpty(); 2115 } 2116 2117 public boolean hasDescription() { 2118 return this.description != null && !this.description.isEmpty(); 2119 } 2120 2121 /** 2122 * @param value {@link #description} (A brief description of the action used to provide a summary to display to the user.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value 2123 */ 2124 public PlanDefinitionActionComponent setDescriptionElement(MarkdownType value) { 2125 this.description = value; 2126 return this; 2127 } 2128 2129 /** 2130 * @return A brief description of the action used to provide a summary to display to the user. 2131 */ 2132 public String getDescription() { 2133 return this.description == null ? null : this.description.getValue(); 2134 } 2135 2136 /** 2137 * @param value A brief description of the action used to provide a summary to display to the user. 2138 */ 2139 public PlanDefinitionActionComponent setDescription(String value) { 2140 if (Utilities.noString(value)) 2141 this.description = null; 2142 else { 2143 if (this.description == null) 2144 this.description = new MarkdownType(); 2145 this.description.setValue(value); 2146 } 2147 return this; 2148 } 2149 2150 /** 2151 * @return {@link #textEquivalent} (A text equivalent of the action to be performed. This provides a human-interpretable description of the action when the definition is consumed by a system that might not be capable of interpreting it dynamically.). This is the underlying object with id, value and extensions. The accessor "getTextEquivalent" gives direct access to the value 2152 */ 2153 public MarkdownType getTextEquivalentElement() { 2154 if (this.textEquivalent == null) 2155 if (Configuration.errorOnAutoCreate()) 2156 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.textEquivalent"); 2157 else if (Configuration.doAutoCreate()) 2158 this.textEquivalent = new MarkdownType(); // bb 2159 return this.textEquivalent; 2160 } 2161 2162 public boolean hasTextEquivalentElement() { 2163 return this.textEquivalent != null && !this.textEquivalent.isEmpty(); 2164 } 2165 2166 public boolean hasTextEquivalent() { 2167 return this.textEquivalent != null && !this.textEquivalent.isEmpty(); 2168 } 2169 2170 /** 2171 * @param value {@link #textEquivalent} (A text equivalent of the action to be performed. This provides a human-interpretable description of the action when the definition is consumed by a system that might not be capable of interpreting it dynamically.). This is the underlying object with id, value and extensions. The accessor "getTextEquivalent" gives direct access to the value 2172 */ 2173 public PlanDefinitionActionComponent setTextEquivalentElement(MarkdownType value) { 2174 this.textEquivalent = value; 2175 return this; 2176 } 2177 2178 /** 2179 * @return A text equivalent of the action to be performed. This provides a human-interpretable description of the action when the definition is consumed by a system that might not be capable of interpreting it dynamically. 2180 */ 2181 public String getTextEquivalent() { 2182 return this.textEquivalent == null ? null : this.textEquivalent.getValue(); 2183 } 2184 2185 /** 2186 * @param value A text equivalent of the action to be performed. This provides a human-interpretable description of the action when the definition is consumed by a system that might not be capable of interpreting it dynamically. 2187 */ 2188 public PlanDefinitionActionComponent setTextEquivalent(String value) { 2189 if (Utilities.noString(value)) 2190 this.textEquivalent = null; 2191 else { 2192 if (this.textEquivalent == null) 2193 this.textEquivalent = new MarkdownType(); 2194 this.textEquivalent.setValue(value); 2195 } 2196 return this; 2197 } 2198 2199 /** 2200 * @return {@link #priority} (Indicates how quickly the action should be addressed with respect to other actions.). This is the underlying object with id, value and extensions. The accessor "getPriority" gives direct access to the value 2201 */ 2202 public Enumeration<RequestPriority> getPriorityElement() { 2203 if (this.priority == null) 2204 if (Configuration.errorOnAutoCreate()) 2205 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.priority"); 2206 else if (Configuration.doAutoCreate()) 2207 this.priority = new Enumeration<RequestPriority>(new RequestPriorityEnumFactory()); // bb 2208 return this.priority; 2209 } 2210 2211 public boolean hasPriorityElement() { 2212 return this.priority != null && !this.priority.isEmpty(); 2213 } 2214 2215 public boolean hasPriority() { 2216 return this.priority != null && !this.priority.isEmpty(); 2217 } 2218 2219 /** 2220 * @param value {@link #priority} (Indicates how quickly the action should be addressed with respect to other actions.). This is the underlying object with id, value and extensions. The accessor "getPriority" gives direct access to the value 2221 */ 2222 public PlanDefinitionActionComponent setPriorityElement(Enumeration<RequestPriority> value) { 2223 this.priority = value; 2224 return this; 2225 } 2226 2227 /** 2228 * @return Indicates how quickly the action should be addressed with respect to other actions. 2229 */ 2230 public RequestPriority getPriority() { 2231 return this.priority == null ? null : this.priority.getValue(); 2232 } 2233 2234 /** 2235 * @param value Indicates how quickly the action should be addressed with respect to other actions. 2236 */ 2237 public PlanDefinitionActionComponent setPriority(RequestPriority value) { 2238 if (value == null) 2239 this.priority = null; 2240 else { 2241 if (this.priority == null) 2242 this.priority = new Enumeration<RequestPriority>(new RequestPriorityEnumFactory()); 2243 this.priority.setValue(value); 2244 } 2245 return this; 2246 } 2247 2248 /** 2249 * @return {@link #code} (A code that provides a meaning, grouping, or classification for the action or action group. For example, a section may have a LOINC code for the section of a documentation template. In pharmaceutical quality, an action (Test) such as pH could be classified as a physical property.) 2250 */ 2251 public CodeableConcept getCode() { 2252 if (this.code == null) 2253 if (Configuration.errorOnAutoCreate()) 2254 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.code"); 2255 else if (Configuration.doAutoCreate()) 2256 this.code = new CodeableConcept(); // cc 2257 return this.code; 2258 } 2259 2260 public boolean hasCode() { 2261 return this.code != null && !this.code.isEmpty(); 2262 } 2263 2264 /** 2265 * @param value {@link #code} (A code that provides a meaning, grouping, or classification for the action or action group. For example, a section may have a LOINC code for the section of a documentation template. In pharmaceutical quality, an action (Test) such as pH could be classified as a physical property.) 2266 */ 2267 public PlanDefinitionActionComponent setCode(CodeableConcept value) { 2268 this.code = value; 2269 return this; 2270 } 2271 2272 /** 2273 * @return {@link #reason} (A description of why this action is necessary or appropriate.) 2274 */ 2275 public List<CodeableConcept> getReason() { 2276 if (this.reason == null) 2277 this.reason = new ArrayList<CodeableConcept>(); 2278 return this.reason; 2279 } 2280 2281 /** 2282 * @return Returns a reference to <code>this</code> for easy method chaining 2283 */ 2284 public PlanDefinitionActionComponent setReason(List<CodeableConcept> theReason) { 2285 this.reason = theReason; 2286 return this; 2287 } 2288 2289 public boolean hasReason() { 2290 if (this.reason == null) 2291 return false; 2292 for (CodeableConcept item : this.reason) 2293 if (!item.isEmpty()) 2294 return true; 2295 return false; 2296 } 2297 2298 public CodeableConcept addReason() { //3 2299 CodeableConcept t = new CodeableConcept(); 2300 if (this.reason == null) 2301 this.reason = new ArrayList<CodeableConcept>(); 2302 this.reason.add(t); 2303 return t; 2304 } 2305 2306 public PlanDefinitionActionComponent addReason(CodeableConcept t) { //3 2307 if (t == null) 2308 return this; 2309 if (this.reason == null) 2310 this.reason = new ArrayList<CodeableConcept>(); 2311 this.reason.add(t); 2312 return this; 2313 } 2314 2315 /** 2316 * @return The first repetition of repeating field {@link #reason}, creating it if it does not already exist {3} 2317 */ 2318 public CodeableConcept getReasonFirstRep() { 2319 if (getReason().isEmpty()) { 2320 addReason(); 2321 } 2322 return getReason().get(0); 2323 } 2324 2325 /** 2326 * @return {@link #documentation} (Didactic or other informational resources associated with the action that can be provided to the CDS recipient. Information resources can include inline text commentary and links to web resources.) 2327 */ 2328 public List<RelatedArtifact> getDocumentation() { 2329 if (this.documentation == null) 2330 this.documentation = new ArrayList<RelatedArtifact>(); 2331 return this.documentation; 2332 } 2333 2334 /** 2335 * @return Returns a reference to <code>this</code> for easy method chaining 2336 */ 2337 public PlanDefinitionActionComponent setDocumentation(List<RelatedArtifact> theDocumentation) { 2338 this.documentation = theDocumentation; 2339 return this; 2340 } 2341 2342 public boolean hasDocumentation() { 2343 if (this.documentation == null) 2344 return false; 2345 for (RelatedArtifact item : this.documentation) 2346 if (!item.isEmpty()) 2347 return true; 2348 return false; 2349 } 2350 2351 public RelatedArtifact addDocumentation() { //3 2352 RelatedArtifact t = new RelatedArtifact(); 2353 if (this.documentation == null) 2354 this.documentation = new ArrayList<RelatedArtifact>(); 2355 this.documentation.add(t); 2356 return t; 2357 } 2358 2359 public PlanDefinitionActionComponent addDocumentation(RelatedArtifact t) { //3 2360 if (t == null) 2361 return this; 2362 if (this.documentation == null) 2363 this.documentation = new ArrayList<RelatedArtifact>(); 2364 this.documentation.add(t); 2365 return this; 2366 } 2367 2368 /** 2369 * @return The first repetition of repeating field {@link #documentation}, creating it if it does not already exist {3} 2370 */ 2371 public RelatedArtifact getDocumentationFirstRep() { 2372 if (getDocumentation().isEmpty()) { 2373 addDocumentation(); 2374 } 2375 return getDocumentation().get(0); 2376 } 2377 2378 /** 2379 * @return {@link #goalId} (Identifies goals that this action supports. The reference must be to a goal element defined within this plan definition. In pharmaceutical quality, a goal represents acceptance criteria (Goal) for a given action (Test), so the goalId would be the unique id of a defined goal element establishing the acceptance criteria for the action.) 2380 */ 2381 public List<IdType> getGoalId() { 2382 if (this.goalId == null) 2383 this.goalId = new ArrayList<IdType>(); 2384 return this.goalId; 2385 } 2386 2387 /** 2388 * @return Returns a reference to <code>this</code> for easy method chaining 2389 */ 2390 public PlanDefinitionActionComponent setGoalId(List<IdType> theGoalId) { 2391 this.goalId = theGoalId; 2392 return this; 2393 } 2394 2395 public boolean hasGoalId() { 2396 if (this.goalId == null) 2397 return false; 2398 for (IdType item : this.goalId) 2399 if (!item.isEmpty()) 2400 return true; 2401 return false; 2402 } 2403 2404 /** 2405 * @return {@link #goalId} (Identifies goals that this action supports. The reference must be to a goal element defined within this plan definition. In pharmaceutical quality, a goal represents acceptance criteria (Goal) for a given action (Test), so the goalId would be the unique id of a defined goal element establishing the acceptance criteria for the action.) 2406 */ 2407 public IdType addGoalIdElement() {//2 2408 IdType t = new IdType(); 2409 if (this.goalId == null) 2410 this.goalId = new ArrayList<IdType>(); 2411 this.goalId.add(t); 2412 return t; 2413 } 2414 2415 /** 2416 * @param value {@link #goalId} (Identifies goals that this action supports. The reference must be to a goal element defined within this plan definition. In pharmaceutical quality, a goal represents acceptance criteria (Goal) for a given action (Test), so the goalId would be the unique id of a defined goal element establishing the acceptance criteria for the action.) 2417 */ 2418 public PlanDefinitionActionComponent addGoalId(String value) { //1 2419 IdType t = new IdType(); 2420 t.setValue(value); 2421 if (this.goalId == null) 2422 this.goalId = new ArrayList<IdType>(); 2423 this.goalId.add(t); 2424 return this; 2425 } 2426 2427 /** 2428 * @param value {@link #goalId} (Identifies goals that this action supports. The reference must be to a goal element defined within this plan definition. In pharmaceutical quality, a goal represents acceptance criteria (Goal) for a given action (Test), so the goalId would be the unique id of a defined goal element establishing the acceptance criteria for the action.) 2429 */ 2430 public boolean hasGoalId(String value) { 2431 if (this.goalId == null) 2432 return false; 2433 for (IdType v : this.goalId) 2434 if (v.getValue().equals(value)) // id 2435 return true; 2436 return false; 2437 } 2438 2439 /** 2440 * @return {@link #subject} (A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.) 2441 */ 2442 public DataType getSubject() { 2443 return this.subject; 2444 } 2445 2446 /** 2447 * @return {@link #subject} (A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.) 2448 */ 2449 public CodeableConcept getSubjectCodeableConcept() throws FHIRException { 2450 if (this.subject == null) 2451 this.subject = new CodeableConcept(); 2452 if (!(this.subject instanceof CodeableConcept)) 2453 throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "+this.subject.getClass().getName()+" was encountered"); 2454 return (CodeableConcept) this.subject; 2455 } 2456 2457 public boolean hasSubjectCodeableConcept() { 2458 return this != null && this.subject instanceof CodeableConcept; 2459 } 2460 2461 /** 2462 * @return {@link #subject} (A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.) 2463 */ 2464 public Reference getSubjectReference() throws FHIRException { 2465 if (this.subject == null) 2466 this.subject = new Reference(); 2467 if (!(this.subject instanceof Reference)) 2468 throw new FHIRException("Type mismatch: the type Reference was expected, but "+this.subject.getClass().getName()+" was encountered"); 2469 return (Reference) this.subject; 2470 } 2471 2472 public boolean hasSubjectReference() { 2473 return this != null && this.subject instanceof Reference; 2474 } 2475 2476 /** 2477 * @return {@link #subject} (A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.) 2478 */ 2479 public CanonicalType getSubjectCanonicalType() throws FHIRException { 2480 if (this.subject == null) 2481 this.subject = new CanonicalType(); 2482 if (!(this.subject instanceof CanonicalType)) 2483 throw new FHIRException("Type mismatch: the type CanonicalType was expected, but "+this.subject.getClass().getName()+" was encountered"); 2484 return (CanonicalType) this.subject; 2485 } 2486 2487 public boolean hasSubjectCanonicalType() { 2488 return this != null && this.subject instanceof CanonicalType; 2489 } 2490 2491 public boolean hasSubject() { 2492 return this.subject != null && !this.subject.isEmpty(); 2493 } 2494 2495 /** 2496 * @param value {@link #subject} (A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.) 2497 */ 2498 public PlanDefinitionActionComponent setSubject(DataType value) { 2499 if (value != null && !(value instanceof CodeableConcept || value instanceof Reference || value instanceof CanonicalType)) 2500 throw new FHIRException("Not the right type for PlanDefinition.action.subject[x]: "+value.fhirType()); 2501 this.subject = value; 2502 return this; 2503 } 2504 2505 /** 2506 * @return {@link #trigger} (A description of when the action should be triggered. When multiple triggers are specified on an action, any triggering event invokes the action.) 2507 */ 2508 public List<TriggerDefinition> getTrigger() { 2509 if (this.trigger == null) 2510 this.trigger = new ArrayList<TriggerDefinition>(); 2511 return this.trigger; 2512 } 2513 2514 /** 2515 * @return Returns a reference to <code>this</code> for easy method chaining 2516 */ 2517 public PlanDefinitionActionComponent setTrigger(List<TriggerDefinition> theTrigger) { 2518 this.trigger = theTrigger; 2519 return this; 2520 } 2521 2522 public boolean hasTrigger() { 2523 if (this.trigger == null) 2524 return false; 2525 for (TriggerDefinition item : this.trigger) 2526 if (!item.isEmpty()) 2527 return true; 2528 return false; 2529 } 2530 2531 public TriggerDefinition addTrigger() { //3 2532 TriggerDefinition t = new TriggerDefinition(); 2533 if (this.trigger == null) 2534 this.trigger = new ArrayList<TriggerDefinition>(); 2535 this.trigger.add(t); 2536 return t; 2537 } 2538 2539 public PlanDefinitionActionComponent addTrigger(TriggerDefinition t) { //3 2540 if (t == null) 2541 return this; 2542 if (this.trigger == null) 2543 this.trigger = new ArrayList<TriggerDefinition>(); 2544 this.trigger.add(t); 2545 return this; 2546 } 2547 2548 /** 2549 * @return The first repetition of repeating field {@link #trigger}, creating it if it does not already exist {3} 2550 */ 2551 public TriggerDefinition getTriggerFirstRep() { 2552 if (getTrigger().isEmpty()) { 2553 addTrigger(); 2554 } 2555 return getTrigger().get(0); 2556 } 2557 2558 /** 2559 * @return {@link #condition} (An expression that describes applicability criteria or start/stop conditions for the action.) 2560 */ 2561 public List<PlanDefinitionActionConditionComponent> getCondition() { 2562 if (this.condition == null) 2563 this.condition = new ArrayList<PlanDefinitionActionConditionComponent>(); 2564 return this.condition; 2565 } 2566 2567 /** 2568 * @return Returns a reference to <code>this</code> for easy method chaining 2569 */ 2570 public PlanDefinitionActionComponent setCondition(List<PlanDefinitionActionConditionComponent> theCondition) { 2571 this.condition = theCondition; 2572 return this; 2573 } 2574 2575 public boolean hasCondition() { 2576 if (this.condition == null) 2577 return false; 2578 for (PlanDefinitionActionConditionComponent item : this.condition) 2579 if (!item.isEmpty()) 2580 return true; 2581 return false; 2582 } 2583 2584 public PlanDefinitionActionConditionComponent addCondition() { //3 2585 PlanDefinitionActionConditionComponent t = new PlanDefinitionActionConditionComponent(); 2586 if (this.condition == null) 2587 this.condition = new ArrayList<PlanDefinitionActionConditionComponent>(); 2588 this.condition.add(t); 2589 return t; 2590 } 2591 2592 public PlanDefinitionActionComponent addCondition(PlanDefinitionActionConditionComponent t) { //3 2593 if (t == null) 2594 return this; 2595 if (this.condition == null) 2596 this.condition = new ArrayList<PlanDefinitionActionConditionComponent>(); 2597 this.condition.add(t); 2598 return this; 2599 } 2600 2601 /** 2602 * @return The first repetition of repeating field {@link #condition}, creating it if it does not already exist {3} 2603 */ 2604 public PlanDefinitionActionConditionComponent getConditionFirstRep() { 2605 if (getCondition().isEmpty()) { 2606 addCondition(); 2607 } 2608 return getCondition().get(0); 2609 } 2610 2611 /** 2612 * @return {@link #input} (Defines input data requirements for the action.) 2613 */ 2614 public List<PlanDefinitionActionInputComponent> getInput() { 2615 if (this.input == null) 2616 this.input = new ArrayList<PlanDefinitionActionInputComponent>(); 2617 return this.input; 2618 } 2619 2620 /** 2621 * @return Returns a reference to <code>this</code> for easy method chaining 2622 */ 2623 public PlanDefinitionActionComponent setInput(List<PlanDefinitionActionInputComponent> theInput) { 2624 this.input = theInput; 2625 return this; 2626 } 2627 2628 public boolean hasInput() { 2629 if (this.input == null) 2630 return false; 2631 for (PlanDefinitionActionInputComponent item : this.input) 2632 if (!item.isEmpty()) 2633 return true; 2634 return false; 2635 } 2636 2637 public PlanDefinitionActionInputComponent addInput() { //3 2638 PlanDefinitionActionInputComponent t = new PlanDefinitionActionInputComponent(); 2639 if (this.input == null) 2640 this.input = new ArrayList<PlanDefinitionActionInputComponent>(); 2641 this.input.add(t); 2642 return t; 2643 } 2644 2645 public PlanDefinitionActionComponent addInput(PlanDefinitionActionInputComponent t) { //3 2646 if (t == null) 2647 return this; 2648 if (this.input == null) 2649 this.input = new ArrayList<PlanDefinitionActionInputComponent>(); 2650 this.input.add(t); 2651 return this; 2652 } 2653 2654 /** 2655 * @return The first repetition of repeating field {@link #input}, creating it if it does not already exist {3} 2656 */ 2657 public PlanDefinitionActionInputComponent getInputFirstRep() { 2658 if (getInput().isEmpty()) { 2659 addInput(); 2660 } 2661 return getInput().get(0); 2662 } 2663 2664 /** 2665 * @return {@link #output} (Defines the outputs of the action, if any.) 2666 */ 2667 public List<PlanDefinitionActionOutputComponent> getOutput() { 2668 if (this.output == null) 2669 this.output = new ArrayList<PlanDefinitionActionOutputComponent>(); 2670 return this.output; 2671 } 2672 2673 /** 2674 * @return Returns a reference to <code>this</code> for easy method chaining 2675 */ 2676 public PlanDefinitionActionComponent setOutput(List<PlanDefinitionActionOutputComponent> theOutput) { 2677 this.output = theOutput; 2678 return this; 2679 } 2680 2681 public boolean hasOutput() { 2682 if (this.output == null) 2683 return false; 2684 for (PlanDefinitionActionOutputComponent item : this.output) 2685 if (!item.isEmpty()) 2686 return true; 2687 return false; 2688 } 2689 2690 public PlanDefinitionActionOutputComponent addOutput() { //3 2691 PlanDefinitionActionOutputComponent t = new PlanDefinitionActionOutputComponent(); 2692 if (this.output == null) 2693 this.output = new ArrayList<PlanDefinitionActionOutputComponent>(); 2694 this.output.add(t); 2695 return t; 2696 } 2697 2698 public PlanDefinitionActionComponent addOutput(PlanDefinitionActionOutputComponent t) { //3 2699 if (t == null) 2700 return this; 2701 if (this.output == null) 2702 this.output = new ArrayList<PlanDefinitionActionOutputComponent>(); 2703 this.output.add(t); 2704 return this; 2705 } 2706 2707 /** 2708 * @return The first repetition of repeating field {@link #output}, creating it if it does not already exist {3} 2709 */ 2710 public PlanDefinitionActionOutputComponent getOutputFirstRep() { 2711 if (getOutput().isEmpty()) { 2712 addOutput(); 2713 } 2714 return getOutput().get(0); 2715 } 2716 2717 /** 2718 * @return {@link #relatedAction} (A relationship to another action such as "before" or "30-60 minutes after start of".) 2719 */ 2720 public List<PlanDefinitionActionRelatedActionComponent> getRelatedAction() { 2721 if (this.relatedAction == null) 2722 this.relatedAction = new ArrayList<PlanDefinitionActionRelatedActionComponent>(); 2723 return this.relatedAction; 2724 } 2725 2726 /** 2727 * @return Returns a reference to <code>this</code> for easy method chaining 2728 */ 2729 public PlanDefinitionActionComponent setRelatedAction(List<PlanDefinitionActionRelatedActionComponent> theRelatedAction) { 2730 this.relatedAction = theRelatedAction; 2731 return this; 2732 } 2733 2734 public boolean hasRelatedAction() { 2735 if (this.relatedAction == null) 2736 return false; 2737 for (PlanDefinitionActionRelatedActionComponent item : this.relatedAction) 2738 if (!item.isEmpty()) 2739 return true; 2740 return false; 2741 } 2742 2743 public PlanDefinitionActionRelatedActionComponent addRelatedAction() { //3 2744 PlanDefinitionActionRelatedActionComponent t = new PlanDefinitionActionRelatedActionComponent(); 2745 if (this.relatedAction == null) 2746 this.relatedAction = new ArrayList<PlanDefinitionActionRelatedActionComponent>(); 2747 this.relatedAction.add(t); 2748 return t; 2749 } 2750 2751 public PlanDefinitionActionComponent addRelatedAction(PlanDefinitionActionRelatedActionComponent t) { //3 2752 if (t == null) 2753 return this; 2754 if (this.relatedAction == null) 2755 this.relatedAction = new ArrayList<PlanDefinitionActionRelatedActionComponent>(); 2756 this.relatedAction.add(t); 2757 return this; 2758 } 2759 2760 /** 2761 * @return The first repetition of repeating field {@link #relatedAction}, creating it if it does not already exist {3} 2762 */ 2763 public PlanDefinitionActionRelatedActionComponent getRelatedActionFirstRep() { 2764 if (getRelatedAction().isEmpty()) { 2765 addRelatedAction(); 2766 } 2767 return getRelatedAction().get(0); 2768 } 2769 2770 /** 2771 * @return {@link #timing} (An optional value describing when the action should be performed.) 2772 */ 2773 public DataType getTiming() { 2774 return this.timing; 2775 } 2776 2777 /** 2778 * @return {@link #timing} (An optional value describing when the action should be performed.) 2779 */ 2780 public Age getTimingAge() throws FHIRException { 2781 if (this.timing == null) 2782 this.timing = new Age(); 2783 if (!(this.timing instanceof Age)) 2784 throw new FHIRException("Type mismatch: the type Age was expected, but "+this.timing.getClass().getName()+" was encountered"); 2785 return (Age) this.timing; 2786 } 2787 2788 public boolean hasTimingAge() { 2789 return this != null && this.timing instanceof Age; 2790 } 2791 2792 /** 2793 * @return {@link #timing} (An optional value describing when the action should be performed.) 2794 */ 2795 public Duration getTimingDuration() throws FHIRException { 2796 if (this.timing == null) 2797 this.timing = new Duration(); 2798 if (!(this.timing instanceof Duration)) 2799 throw new FHIRException("Type mismatch: the type Duration was expected, but "+this.timing.getClass().getName()+" was encountered"); 2800 return (Duration) this.timing; 2801 } 2802 2803 public boolean hasTimingDuration() { 2804 return this != null && this.timing instanceof Duration; 2805 } 2806 2807 /** 2808 * @return {@link #timing} (An optional value describing when the action should be performed.) 2809 */ 2810 public Range getTimingRange() throws FHIRException { 2811 if (this.timing == null) 2812 this.timing = new Range(); 2813 if (!(this.timing instanceof Range)) 2814 throw new FHIRException("Type mismatch: the type Range was expected, but "+this.timing.getClass().getName()+" was encountered"); 2815 return (Range) this.timing; 2816 } 2817 2818 public boolean hasTimingRange() { 2819 return this != null && this.timing instanceof Range; 2820 } 2821 2822 /** 2823 * @return {@link #timing} (An optional value describing when the action should be performed.) 2824 */ 2825 public Timing getTimingTiming() throws FHIRException { 2826 if (this.timing == null) 2827 this.timing = new Timing(); 2828 if (!(this.timing instanceof Timing)) 2829 throw new FHIRException("Type mismatch: the type Timing was expected, but "+this.timing.getClass().getName()+" was encountered"); 2830 return (Timing) this.timing; 2831 } 2832 2833 public boolean hasTimingTiming() { 2834 return this != null && this.timing instanceof Timing; 2835 } 2836 2837 public boolean hasTiming() { 2838 return this.timing != null && !this.timing.isEmpty(); 2839 } 2840 2841 /** 2842 * @param value {@link #timing} (An optional value describing when the action should be performed.) 2843 */ 2844 public PlanDefinitionActionComponent setTiming(DataType value) { 2845 if (value != null && !(value instanceof Age || value instanceof Duration || value instanceof Range || value instanceof Timing)) 2846 throw new FHIRException("Not the right type for PlanDefinition.action.timing[x]: "+value.fhirType()); 2847 this.timing = value; 2848 return this; 2849 } 2850 2851 /** 2852 * @return {@link #location} (Identifies the facility where the action will occur; e.g. home, hospital, specific clinic, etc.) 2853 */ 2854 public CodeableReference getLocation() { 2855 if (this.location == null) 2856 if (Configuration.errorOnAutoCreate()) 2857 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.location"); 2858 else if (Configuration.doAutoCreate()) 2859 this.location = new CodeableReference(); // cc 2860 return this.location; 2861 } 2862 2863 public boolean hasLocation() { 2864 return this.location != null && !this.location.isEmpty(); 2865 } 2866 2867 /** 2868 * @param value {@link #location} (Identifies the facility where the action will occur; e.g. home, hospital, specific clinic, etc.) 2869 */ 2870 public PlanDefinitionActionComponent setLocation(CodeableReference value) { 2871 this.location = value; 2872 return this; 2873 } 2874 2875 /** 2876 * @return {@link #participant} (Indicates who should participate in performing the action described.) 2877 */ 2878 public List<PlanDefinitionActionParticipantComponent> getParticipant() { 2879 if (this.participant == null) 2880 this.participant = new ArrayList<PlanDefinitionActionParticipantComponent>(); 2881 return this.participant; 2882 } 2883 2884 /** 2885 * @return Returns a reference to <code>this</code> for easy method chaining 2886 */ 2887 public PlanDefinitionActionComponent setParticipant(List<PlanDefinitionActionParticipantComponent> theParticipant) { 2888 this.participant = theParticipant; 2889 return this; 2890 } 2891 2892 public boolean hasParticipant() { 2893 if (this.participant == null) 2894 return false; 2895 for (PlanDefinitionActionParticipantComponent item : this.participant) 2896 if (!item.isEmpty()) 2897 return true; 2898 return false; 2899 } 2900 2901 public PlanDefinitionActionParticipantComponent addParticipant() { //3 2902 PlanDefinitionActionParticipantComponent t = new PlanDefinitionActionParticipantComponent(); 2903 if (this.participant == null) 2904 this.participant = new ArrayList<PlanDefinitionActionParticipantComponent>(); 2905 this.participant.add(t); 2906 return t; 2907 } 2908 2909 public PlanDefinitionActionComponent addParticipant(PlanDefinitionActionParticipantComponent t) { //3 2910 if (t == null) 2911 return this; 2912 if (this.participant == null) 2913 this.participant = new ArrayList<PlanDefinitionActionParticipantComponent>(); 2914 this.participant.add(t); 2915 return this; 2916 } 2917 2918 /** 2919 * @return The first repetition of repeating field {@link #participant}, creating it if it does not already exist {3} 2920 */ 2921 public PlanDefinitionActionParticipantComponent getParticipantFirstRep() { 2922 if (getParticipant().isEmpty()) { 2923 addParticipant(); 2924 } 2925 return getParticipant().get(0); 2926 } 2927 2928 /** 2929 * @return {@link #type} (The type of action to perform (create, update, remove).) 2930 */ 2931 public CodeableConcept getType() { 2932 if (this.type == null) 2933 if (Configuration.errorOnAutoCreate()) 2934 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.type"); 2935 else if (Configuration.doAutoCreate()) 2936 this.type = new CodeableConcept(); // cc 2937 return this.type; 2938 } 2939 2940 public boolean hasType() { 2941 return this.type != null && !this.type.isEmpty(); 2942 } 2943 2944 /** 2945 * @param value {@link #type} (The type of action to perform (create, update, remove).) 2946 */ 2947 public PlanDefinitionActionComponent setType(CodeableConcept value) { 2948 this.type = value; 2949 return this; 2950 } 2951 2952 /** 2953 * @return {@link #groupingBehavior} (Defines the grouping behavior for the action and its children.). This is the underlying object with id, value and extensions. The accessor "getGroupingBehavior" gives direct access to the value 2954 */ 2955 public Enumeration<ActionGroupingBehavior> getGroupingBehaviorElement() { 2956 if (this.groupingBehavior == null) 2957 if (Configuration.errorOnAutoCreate()) 2958 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.groupingBehavior"); 2959 else if (Configuration.doAutoCreate()) 2960 this.groupingBehavior = new Enumeration<ActionGroupingBehavior>(new ActionGroupingBehaviorEnumFactory()); // bb 2961 return this.groupingBehavior; 2962 } 2963 2964 public boolean hasGroupingBehaviorElement() { 2965 return this.groupingBehavior != null && !this.groupingBehavior.isEmpty(); 2966 } 2967 2968 public boolean hasGroupingBehavior() { 2969 return this.groupingBehavior != null && !this.groupingBehavior.isEmpty(); 2970 } 2971 2972 /** 2973 * @param value {@link #groupingBehavior} (Defines the grouping behavior for the action and its children.). This is the underlying object with id, value and extensions. The accessor "getGroupingBehavior" gives direct access to the value 2974 */ 2975 public PlanDefinitionActionComponent setGroupingBehaviorElement(Enumeration<ActionGroupingBehavior> value) { 2976 this.groupingBehavior = value; 2977 return this; 2978 } 2979 2980 /** 2981 * @return Defines the grouping behavior for the action and its children. 2982 */ 2983 public ActionGroupingBehavior getGroupingBehavior() { 2984 return this.groupingBehavior == null ? null : this.groupingBehavior.getValue(); 2985 } 2986 2987 /** 2988 * @param value Defines the grouping behavior for the action and its children. 2989 */ 2990 public PlanDefinitionActionComponent setGroupingBehavior(ActionGroupingBehavior value) { 2991 if (value == null) 2992 this.groupingBehavior = null; 2993 else { 2994 if (this.groupingBehavior == null) 2995 this.groupingBehavior = new Enumeration<ActionGroupingBehavior>(new ActionGroupingBehaviorEnumFactory()); 2996 this.groupingBehavior.setValue(value); 2997 } 2998 return this; 2999 } 3000 3001 /** 3002 * @return {@link #selectionBehavior} (Defines the selection behavior for the action and its children.). This is the underlying object with id, value and extensions. The accessor "getSelectionBehavior" gives direct access to the value 3003 */ 3004 public Enumeration<ActionSelectionBehavior> getSelectionBehaviorElement() { 3005 if (this.selectionBehavior == null) 3006 if (Configuration.errorOnAutoCreate()) 3007 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.selectionBehavior"); 3008 else if (Configuration.doAutoCreate()) 3009 this.selectionBehavior = new Enumeration<ActionSelectionBehavior>(new ActionSelectionBehaviorEnumFactory()); // bb 3010 return this.selectionBehavior; 3011 } 3012 3013 public boolean hasSelectionBehaviorElement() { 3014 return this.selectionBehavior != null && !this.selectionBehavior.isEmpty(); 3015 } 3016 3017 public boolean hasSelectionBehavior() { 3018 return this.selectionBehavior != null && !this.selectionBehavior.isEmpty(); 3019 } 3020 3021 /** 3022 * @param value {@link #selectionBehavior} (Defines the selection behavior for the action and its children.). This is the underlying object with id, value and extensions. The accessor "getSelectionBehavior" gives direct access to the value 3023 */ 3024 public PlanDefinitionActionComponent setSelectionBehaviorElement(Enumeration<ActionSelectionBehavior> value) { 3025 this.selectionBehavior = value; 3026 return this; 3027 } 3028 3029 /** 3030 * @return Defines the selection behavior for the action and its children. 3031 */ 3032 public ActionSelectionBehavior getSelectionBehavior() { 3033 return this.selectionBehavior == null ? null : this.selectionBehavior.getValue(); 3034 } 3035 3036 /** 3037 * @param value Defines the selection behavior for the action and its children. 3038 */ 3039 public PlanDefinitionActionComponent setSelectionBehavior(ActionSelectionBehavior value) { 3040 if (value == null) 3041 this.selectionBehavior = null; 3042 else { 3043 if (this.selectionBehavior == null) 3044 this.selectionBehavior = new Enumeration<ActionSelectionBehavior>(new ActionSelectionBehaviorEnumFactory()); 3045 this.selectionBehavior.setValue(value); 3046 } 3047 return this; 3048 } 3049 3050 /** 3051 * @return {@link #requiredBehavior} (Defines the required behavior for the action.). This is the underlying object with id, value and extensions. The accessor "getRequiredBehavior" gives direct access to the value 3052 */ 3053 public Enumeration<ActionRequiredBehavior> getRequiredBehaviorElement() { 3054 if (this.requiredBehavior == null) 3055 if (Configuration.errorOnAutoCreate()) 3056 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.requiredBehavior"); 3057 else if (Configuration.doAutoCreate()) 3058 this.requiredBehavior = new Enumeration<ActionRequiredBehavior>(new ActionRequiredBehaviorEnumFactory()); // bb 3059 return this.requiredBehavior; 3060 } 3061 3062 public boolean hasRequiredBehaviorElement() { 3063 return this.requiredBehavior != null && !this.requiredBehavior.isEmpty(); 3064 } 3065 3066 public boolean hasRequiredBehavior() { 3067 return this.requiredBehavior != null && !this.requiredBehavior.isEmpty(); 3068 } 3069 3070 /** 3071 * @param value {@link #requiredBehavior} (Defines the required behavior for the action.). This is the underlying object with id, value and extensions. The accessor "getRequiredBehavior" gives direct access to the value 3072 */ 3073 public PlanDefinitionActionComponent setRequiredBehaviorElement(Enumeration<ActionRequiredBehavior> value) { 3074 this.requiredBehavior = value; 3075 return this; 3076 } 3077 3078 /** 3079 * @return Defines the required behavior for the action. 3080 */ 3081 public ActionRequiredBehavior getRequiredBehavior() { 3082 return this.requiredBehavior == null ? null : this.requiredBehavior.getValue(); 3083 } 3084 3085 /** 3086 * @param value Defines the required behavior for the action. 3087 */ 3088 public PlanDefinitionActionComponent setRequiredBehavior(ActionRequiredBehavior value) { 3089 if (value == null) 3090 this.requiredBehavior = null; 3091 else { 3092 if (this.requiredBehavior == null) 3093 this.requiredBehavior = new Enumeration<ActionRequiredBehavior>(new ActionRequiredBehaviorEnumFactory()); 3094 this.requiredBehavior.setValue(value); 3095 } 3096 return this; 3097 } 3098 3099 /** 3100 * @return {@link #precheckBehavior} (Defines whether the action should usually be preselected.). This is the underlying object with id, value and extensions. The accessor "getPrecheckBehavior" gives direct access to the value 3101 */ 3102 public Enumeration<ActionPrecheckBehavior> getPrecheckBehaviorElement() { 3103 if (this.precheckBehavior == null) 3104 if (Configuration.errorOnAutoCreate()) 3105 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.precheckBehavior"); 3106 else if (Configuration.doAutoCreate()) 3107 this.precheckBehavior = new Enumeration<ActionPrecheckBehavior>(new ActionPrecheckBehaviorEnumFactory()); // bb 3108 return this.precheckBehavior; 3109 } 3110 3111 public boolean hasPrecheckBehaviorElement() { 3112 return this.precheckBehavior != null && !this.precheckBehavior.isEmpty(); 3113 } 3114 3115 public boolean hasPrecheckBehavior() { 3116 return this.precheckBehavior != null && !this.precheckBehavior.isEmpty(); 3117 } 3118 3119 /** 3120 * @param value {@link #precheckBehavior} (Defines whether the action should usually be preselected.). This is the underlying object with id, value and extensions. The accessor "getPrecheckBehavior" gives direct access to the value 3121 */ 3122 public PlanDefinitionActionComponent setPrecheckBehaviorElement(Enumeration<ActionPrecheckBehavior> value) { 3123 this.precheckBehavior = value; 3124 return this; 3125 } 3126 3127 /** 3128 * @return Defines whether the action should usually be preselected. 3129 */ 3130 public ActionPrecheckBehavior getPrecheckBehavior() { 3131 return this.precheckBehavior == null ? null : this.precheckBehavior.getValue(); 3132 } 3133 3134 /** 3135 * @param value Defines whether the action should usually be preselected. 3136 */ 3137 public PlanDefinitionActionComponent setPrecheckBehavior(ActionPrecheckBehavior value) { 3138 if (value == null) 3139 this.precheckBehavior = null; 3140 else { 3141 if (this.precheckBehavior == null) 3142 this.precheckBehavior = new Enumeration<ActionPrecheckBehavior>(new ActionPrecheckBehaviorEnumFactory()); 3143 this.precheckBehavior.setValue(value); 3144 } 3145 return this; 3146 } 3147 3148 /** 3149 * @return {@link #cardinalityBehavior} (Defines whether the action can be selected multiple times.). This is the underlying object with id, value and extensions. The accessor "getCardinalityBehavior" gives direct access to the value 3150 */ 3151 public Enumeration<ActionCardinalityBehavior> getCardinalityBehaviorElement() { 3152 if (this.cardinalityBehavior == null) 3153 if (Configuration.errorOnAutoCreate()) 3154 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.cardinalityBehavior"); 3155 else if (Configuration.doAutoCreate()) 3156 this.cardinalityBehavior = new Enumeration<ActionCardinalityBehavior>(new ActionCardinalityBehaviorEnumFactory()); // bb 3157 return this.cardinalityBehavior; 3158 } 3159 3160 public boolean hasCardinalityBehaviorElement() { 3161 return this.cardinalityBehavior != null && !this.cardinalityBehavior.isEmpty(); 3162 } 3163 3164 public boolean hasCardinalityBehavior() { 3165 return this.cardinalityBehavior != null && !this.cardinalityBehavior.isEmpty(); 3166 } 3167 3168 /** 3169 * @param value {@link #cardinalityBehavior} (Defines whether the action can be selected multiple times.). This is the underlying object with id, value and extensions. The accessor "getCardinalityBehavior" gives direct access to the value 3170 */ 3171 public PlanDefinitionActionComponent setCardinalityBehaviorElement(Enumeration<ActionCardinalityBehavior> value) { 3172 this.cardinalityBehavior = value; 3173 return this; 3174 } 3175 3176 /** 3177 * @return Defines whether the action can be selected multiple times. 3178 */ 3179 public ActionCardinalityBehavior getCardinalityBehavior() { 3180 return this.cardinalityBehavior == null ? null : this.cardinalityBehavior.getValue(); 3181 } 3182 3183 /** 3184 * @param value Defines whether the action can be selected multiple times. 3185 */ 3186 public PlanDefinitionActionComponent setCardinalityBehavior(ActionCardinalityBehavior value) { 3187 if (value == null) 3188 this.cardinalityBehavior = null; 3189 else { 3190 if (this.cardinalityBehavior == null) 3191 this.cardinalityBehavior = new Enumeration<ActionCardinalityBehavior>(new ActionCardinalityBehaviorEnumFactory()); 3192 this.cardinalityBehavior.setValue(value); 3193 } 3194 return this; 3195 } 3196 3197 /** 3198 * @return {@link #definition} (A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured.) 3199 */ 3200 public DataType getDefinition() { 3201 return this.definition; 3202 } 3203 3204 /** 3205 * @return {@link #definition} (A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured.) 3206 */ 3207 public CanonicalType getDefinitionCanonicalType() throws FHIRException { 3208 if (this.definition == null) 3209 this.definition = new CanonicalType(); 3210 if (!(this.definition instanceof CanonicalType)) 3211 throw new FHIRException("Type mismatch: the type CanonicalType was expected, but "+this.definition.getClass().getName()+" was encountered"); 3212 return (CanonicalType) this.definition; 3213 } 3214 3215 public boolean hasDefinitionCanonicalType() { 3216 return this != null && this.definition instanceof CanonicalType; 3217 } 3218 3219 /** 3220 * @return {@link #definition} (A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured.) 3221 */ 3222 public UriType getDefinitionUriType() throws FHIRException { 3223 if (this.definition == null) 3224 this.definition = new UriType(); 3225 if (!(this.definition instanceof UriType)) 3226 throw new FHIRException("Type mismatch: the type UriType was expected, but "+this.definition.getClass().getName()+" was encountered"); 3227 return (UriType) this.definition; 3228 } 3229 3230 public boolean hasDefinitionUriType() { 3231 return this != null && this.definition instanceof UriType; 3232 } 3233 3234 public boolean hasDefinition() { 3235 return this.definition != null && !this.definition.isEmpty(); 3236 } 3237 3238 /** 3239 * @param value {@link #definition} (A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured.) 3240 */ 3241 public PlanDefinitionActionComponent setDefinition(DataType value) { 3242 if (value != null && !(value instanceof CanonicalType || value instanceof UriType)) 3243 throw new FHIRException("Not the right type for PlanDefinition.action.definition[x]: "+value.fhirType()); 3244 this.definition = value; 3245 return this; 3246 } 3247 3248 /** 3249 * @return {@link #transform} (A reference to a StructureMap resource that defines a transform that can be executed to produce the intent resource using the ActivityDefinition instance as the input.). This is the underlying object with id, value and extensions. The accessor "getTransform" gives direct access to the value 3250 */ 3251 public CanonicalType getTransformElement() { 3252 if (this.transform == null) 3253 if (Configuration.errorOnAutoCreate()) 3254 throw new Error("Attempt to auto-create PlanDefinitionActionComponent.transform"); 3255 else if (Configuration.doAutoCreate()) 3256 this.transform = new CanonicalType(); // bb 3257 return this.transform; 3258 } 3259 3260 public boolean hasTransformElement() { 3261 return this.transform != null && !this.transform.isEmpty(); 3262 } 3263 3264 public boolean hasTransform() { 3265 return this.transform != null && !this.transform.isEmpty(); 3266 } 3267 3268 /** 3269 * @param value {@link #transform} (A reference to a StructureMap resource that defines a transform that can be executed to produce the intent resource using the ActivityDefinition instance as the input.). This is the underlying object with id, value and extensions. The accessor "getTransform" gives direct access to the value 3270 */ 3271 public PlanDefinitionActionComponent setTransformElement(CanonicalType value) { 3272 this.transform = value; 3273 return this; 3274 } 3275 3276 /** 3277 * @return A reference to a StructureMap resource that defines a transform that can be executed to produce the intent resource using the ActivityDefinition instance as the input. 3278 */ 3279 public String getTransform() { 3280 return this.transform == null ? null : this.transform.getValue(); 3281 } 3282 3283 /** 3284 * @param value A reference to a StructureMap resource that defines a transform that can be executed to produce the intent resource using the ActivityDefinition instance as the input. 3285 */ 3286 public PlanDefinitionActionComponent setTransform(String value) { 3287 if (Utilities.noString(value)) 3288 this.transform = null; 3289 else { 3290 if (this.transform == null) 3291 this.transform = new CanonicalType(); 3292 this.transform.setValue(value); 3293 } 3294 return this; 3295 } 3296 3297 /** 3298 * @return {@link #dynamicValue} (Customizations that should be applied to the statically defined resource. For example, if the dosage of a medication must be computed based on the patient's weight, a customization would be used to specify an expression that calculated the weight, and the path on the resource that would contain the result.) 3299 */ 3300 public List<PlanDefinitionActionDynamicValueComponent> getDynamicValue() { 3301 if (this.dynamicValue == null) 3302 this.dynamicValue = new ArrayList<PlanDefinitionActionDynamicValueComponent>(); 3303 return this.dynamicValue; 3304 } 3305 3306 /** 3307 * @return Returns a reference to <code>this</code> for easy method chaining 3308 */ 3309 public PlanDefinitionActionComponent setDynamicValue(List<PlanDefinitionActionDynamicValueComponent> theDynamicValue) { 3310 this.dynamicValue = theDynamicValue; 3311 return this; 3312 } 3313 3314 public boolean hasDynamicValue() { 3315 if (this.dynamicValue == null) 3316 return false; 3317 for (PlanDefinitionActionDynamicValueComponent item : this.dynamicValue) 3318 if (!item.isEmpty()) 3319 return true; 3320 return false; 3321 } 3322 3323 public PlanDefinitionActionDynamicValueComponent addDynamicValue() { //3 3324 PlanDefinitionActionDynamicValueComponent t = new PlanDefinitionActionDynamicValueComponent(); 3325 if (this.dynamicValue == null) 3326 this.dynamicValue = new ArrayList<PlanDefinitionActionDynamicValueComponent>(); 3327 this.dynamicValue.add(t); 3328 return t; 3329 } 3330 3331 public PlanDefinitionActionComponent addDynamicValue(PlanDefinitionActionDynamicValueComponent t) { //3 3332 if (t == null) 3333 return this; 3334 if (this.dynamicValue == null) 3335 this.dynamicValue = new ArrayList<PlanDefinitionActionDynamicValueComponent>(); 3336 this.dynamicValue.add(t); 3337 return this; 3338 } 3339 3340 /** 3341 * @return The first repetition of repeating field {@link #dynamicValue}, creating it if it does not already exist {3} 3342 */ 3343 public PlanDefinitionActionDynamicValueComponent getDynamicValueFirstRep() { 3344 if (getDynamicValue().isEmpty()) { 3345 addDynamicValue(); 3346 } 3347 return getDynamicValue().get(0); 3348 } 3349 3350 /** 3351 * @return {@link #action} (Sub actions that are contained within the action. The behavior of this action determines the functionality of the sub-actions. For example, a selection behavior of at-most-one indicates that of the sub-actions, at most one may be chosen as part of realizing the action definition.) 3352 */ 3353 public List<PlanDefinitionActionComponent> getAction() { 3354 if (this.action == null) 3355 this.action = new ArrayList<PlanDefinitionActionComponent>(); 3356 return this.action; 3357 } 3358 3359 /** 3360 * @return Returns a reference to <code>this</code> for easy method chaining 3361 */ 3362 public PlanDefinitionActionComponent setAction(List<PlanDefinitionActionComponent> theAction) { 3363 this.action = theAction; 3364 return this; 3365 } 3366 3367 public boolean hasAction() { 3368 if (this.action == null) 3369 return false; 3370 for (PlanDefinitionActionComponent item : this.action) 3371 if (!item.isEmpty()) 3372 return true; 3373 return false; 3374 } 3375 3376 public PlanDefinitionActionComponent addAction() { //3 3377 PlanDefinitionActionComponent t = new PlanDefinitionActionComponent(); 3378 if (this.action == null) 3379 this.action = new ArrayList<PlanDefinitionActionComponent>(); 3380 this.action.add(t); 3381 return t; 3382 } 3383 3384 public PlanDefinitionActionComponent addAction(PlanDefinitionActionComponent t) { //3 3385 if (t == null) 3386 return this; 3387 if (this.action == null) 3388 this.action = new ArrayList<PlanDefinitionActionComponent>(); 3389 this.action.add(t); 3390 return this; 3391 } 3392 3393 /** 3394 * @return The first repetition of repeating field {@link #action}, creating it if it does not already exist {3} 3395 */ 3396 public PlanDefinitionActionComponent getActionFirstRep() { 3397 if (getAction().isEmpty()) { 3398 addAction(); 3399 } 3400 return getAction().get(0); 3401 } 3402 3403 protected void listChildren(List<Property> children) { 3404 super.listChildren(children); 3405 children.add(new Property("linkId", "string", "An identifier that is unique within the PlanDefinition to allow linkage within the realized CarePlan and/or RequestOrchestration.", 0, 1, linkId)); 3406 children.add(new Property("prefix", "string", "A user-visible prefix for the action. For example a section or item numbering such as 1. or A.", 0, 1, prefix)); 3407 children.add(new Property("title", "string", "The textual description of the action displayed to a user. For example, when the action is a test to be performed, the title would be the title of the test such as Assay by HPLC.", 0, 1, title)); 3408 children.add(new Property("description", "markdown", "A brief description of the action used to provide a summary to display to the user.", 0, 1, description)); 3409 children.add(new Property("textEquivalent", "markdown", "A text equivalent of the action to be performed. This provides a human-interpretable description of the action when the definition is consumed by a system that might not be capable of interpreting it dynamically.", 0, 1, textEquivalent)); 3410 children.add(new Property("priority", "code", "Indicates how quickly the action should be addressed with respect to other actions.", 0, 1, priority)); 3411 children.add(new Property("code", "CodeableConcept", "A code that provides a meaning, grouping, or classification for the action or action group. For example, a section may have a LOINC code for the section of a documentation template. In pharmaceutical quality, an action (Test) such as pH could be classified as a physical property.", 0, 1, code)); 3412 children.add(new Property("reason", "CodeableConcept", "A description of why this action is necessary or appropriate.", 0, java.lang.Integer.MAX_VALUE, reason)); 3413 children.add(new Property("documentation", "RelatedArtifact", "Didactic or other informational resources associated with the action that can be provided to the CDS recipient. Information resources can include inline text commentary and links to web resources.", 0, java.lang.Integer.MAX_VALUE, documentation)); 3414 children.add(new Property("goalId", "id", "Identifies goals that this action supports. The reference must be to a goal element defined within this plan definition. In pharmaceutical quality, a goal represents acceptance criteria (Goal) for a given action (Test), so the goalId would be the unique id of a defined goal element establishing the acceptance criteria for the action.", 0, java.lang.Integer.MAX_VALUE, goalId)); 3415 children.add(new Property("subject[x]", "CodeableConcept|Reference(Group)|canonical", "A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject)); 3416 children.add(new Property("trigger", "TriggerDefinition", "A description of when the action should be triggered. When multiple triggers are specified on an action, any triggering event invokes the action.", 0, java.lang.Integer.MAX_VALUE, trigger)); 3417 children.add(new Property("condition", "", "An expression that describes applicability criteria or start/stop conditions for the action.", 0, java.lang.Integer.MAX_VALUE, condition)); 3418 children.add(new Property("input", "", "Defines input data requirements for the action.", 0, java.lang.Integer.MAX_VALUE, input)); 3419 children.add(new Property("output", "", "Defines the outputs of the action, if any.", 0, java.lang.Integer.MAX_VALUE, output)); 3420 children.add(new Property("relatedAction", "", "A relationship to another action such as \"before\" or \"30-60 minutes after start of\".", 0, java.lang.Integer.MAX_VALUE, relatedAction)); 3421 children.add(new Property("timing[x]", "Age|Duration|Range|Timing", "An optional value describing when the action should be performed.", 0, 1, timing)); 3422 children.add(new Property("location", "CodeableReference(Location)", "Identifies the facility where the action will occur; e.g. home, hospital, specific clinic, etc.", 0, 1, location)); 3423 children.add(new Property("participant", "", "Indicates who should participate in performing the action described.", 0, java.lang.Integer.MAX_VALUE, participant)); 3424 children.add(new Property("type", "CodeableConcept", "The type of action to perform (create, update, remove).", 0, 1, type)); 3425 children.add(new Property("groupingBehavior", "code", "Defines the grouping behavior for the action and its children.", 0, 1, groupingBehavior)); 3426 children.add(new Property("selectionBehavior", "code", "Defines the selection behavior for the action and its children.", 0, 1, selectionBehavior)); 3427 children.add(new Property("requiredBehavior", "code", "Defines the required behavior for the action.", 0, 1, requiredBehavior)); 3428 children.add(new Property("precheckBehavior", "code", "Defines whether the action should usually be preselected.", 0, 1, precheckBehavior)); 3429 children.add(new Property("cardinalityBehavior", "code", "Defines whether the action can be selected multiple times.", 0, 1, cardinalityBehavior)); 3430 children.add(new Property("definition[x]", "canonical(ActivityDefinition|MessageDefinition|ObservationDefinition|PlanDefinition|Questionnaire|SpecimenDefinition)|uri", "A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured.", 0, 1, definition)); 3431 children.add(new Property("transform", "canonical(StructureMap)", "A reference to a StructureMap resource that defines a transform that can be executed to produce the intent resource using the ActivityDefinition instance as the input.", 0, 1, transform)); 3432 children.add(new Property("dynamicValue", "", "Customizations that should be applied to the statically defined resource. For example, if the dosage of a medication must be computed based on the patient's weight, a customization would be used to specify an expression that calculated the weight, and the path on the resource that would contain the result.", 0, java.lang.Integer.MAX_VALUE, dynamicValue)); 3433 children.add(new Property("action", "@PlanDefinition.action", "Sub actions that are contained within the action. The behavior of this action determines the functionality of the sub-actions. For example, a selection behavior of at-most-one indicates that of the sub-actions, at most one may be chosen as part of realizing the action definition.", 0, java.lang.Integer.MAX_VALUE, action)); 3434 } 3435 3436 @Override 3437 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 3438 switch (_hash) { 3439 case -1102667083: /*linkId*/ return new Property("linkId", "string", "An identifier that is unique within the PlanDefinition to allow linkage within the realized CarePlan and/or RequestOrchestration.", 0, 1, linkId); 3440 case -980110702: /*prefix*/ return new Property("prefix", "string", "A user-visible prefix for the action. For example a section or item numbering such as 1. or A.", 0, 1, prefix); 3441 case 110371416: /*title*/ return new Property("title", "string", "The textual description of the action displayed to a user. For example, when the action is a test to be performed, the title would be the title of the test such as Assay by HPLC.", 0, 1, title); 3442 case -1724546052: /*description*/ return new Property("description", "markdown", "A brief description of the action used to provide a summary to display to the user.", 0, 1, description); 3443 case -900391049: /*textEquivalent*/ return new Property("textEquivalent", "markdown", "A text equivalent of the action to be performed. This provides a human-interpretable description of the action when the definition is consumed by a system that might not be capable of interpreting it dynamically.", 0, 1, textEquivalent); 3444 case -1165461084: /*priority*/ return new Property("priority", "code", "Indicates how quickly the action should be addressed with respect to other actions.", 0, 1, priority); 3445 case 3059181: /*code*/ return new Property("code", "CodeableConcept", "A code that provides a meaning, grouping, or classification for the action or action group. For example, a section may have a LOINC code for the section of a documentation template. In pharmaceutical quality, an action (Test) such as pH could be classified as a physical property.", 0, 1, code); 3446 case -934964668: /*reason*/ return new Property("reason", "CodeableConcept", "A description of why this action is necessary or appropriate.", 0, java.lang.Integer.MAX_VALUE, reason); 3447 case 1587405498: /*documentation*/ return new Property("documentation", "RelatedArtifact", "Didactic or other informational resources associated with the action that can be provided to the CDS recipient. Information resources can include inline text commentary and links to web resources.", 0, java.lang.Integer.MAX_VALUE, documentation); 3448 case -1240658034: /*goalId*/ return new Property("goalId", "id", "Identifies goals that this action supports. The reference must be to a goal element defined within this plan definition. In pharmaceutical quality, a goal represents acceptance criteria (Goal) for a given action (Test), so the goalId would be the unique id of a defined goal element establishing the acceptance criteria for the action.", 0, java.lang.Integer.MAX_VALUE, goalId); 3449 case -573640748: /*subject[x]*/ return new Property("subject[x]", "CodeableConcept|Reference(Group)|canonical", "A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject); 3450 case -1867885268: /*subject*/ return new Property("subject[x]", "CodeableConcept|Reference(Group)|canonical", "A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject); 3451 case -1257122603: /*subjectCodeableConcept*/ return new Property("subject[x]", "CodeableConcept", "A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject); 3452 case 772938623: /*subjectReference*/ return new Property("subject[x]", "Reference(Group)", "A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject); 3453 case -1768521432: /*subjectCanonical*/ return new Property("subject[x]", "canonical", "A code, group definition, or canonical reference that describes the intended subject of the action and its children, if any. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject); 3454 case -1059891784: /*trigger*/ return new Property("trigger", "TriggerDefinition", "A description of when the action should be triggered. When multiple triggers are specified on an action, any triggering event invokes the action.", 0, java.lang.Integer.MAX_VALUE, trigger); 3455 case -861311717: /*condition*/ return new Property("condition", "", "An expression that describes applicability criteria or start/stop conditions for the action.", 0, java.lang.Integer.MAX_VALUE, condition); 3456 case 100358090: /*input*/ return new Property("input", "", "Defines input data requirements for the action.", 0, java.lang.Integer.MAX_VALUE, input); 3457 case -1005512447: /*output*/ return new Property("output", "", "Defines the outputs of the action, if any.", 0, java.lang.Integer.MAX_VALUE, output); 3458 case -384107967: /*relatedAction*/ return new Property("relatedAction", "", "A relationship to another action such as \"before\" or \"30-60 minutes after start of\".", 0, java.lang.Integer.MAX_VALUE, relatedAction); 3459 case 164632566: /*timing[x]*/ return new Property("timing[x]", "Age|Duration|Range|Timing", "An optional value describing when the action should be performed.", 0, 1, timing); 3460 case -873664438: /*timing*/ return new Property("timing[x]", "Age|Duration|Range|Timing", "An optional value describing when the action should be performed.", 0, 1, timing); 3461 case 164607061: /*timingAge*/ return new Property("timing[x]", "Age", "An optional value describing when the action should be performed.", 0, 1, timing); 3462 case -1327253506: /*timingDuration*/ return new Property("timing[x]", "Duration", "An optional value describing when the action should be performed.", 0, 1, timing); 3463 case -710871277: /*timingRange*/ return new Property("timing[x]", "Range", "An optional value describing when the action should be performed.", 0, 1, timing); 3464 case -497554124: /*timingTiming*/ return new Property("timing[x]", "Timing", "An optional value describing when the action should be performed.", 0, 1, timing); 3465 case 1901043637: /*location*/ return new Property("location", "CodeableReference(Location)", "Identifies the facility where the action will occur; e.g. home, hospital, specific clinic, etc.", 0, 1, location); 3466 case 767422259: /*participant*/ return new Property("participant", "", "Indicates who should participate in performing the action described.", 0, java.lang.Integer.MAX_VALUE, participant); 3467 case 3575610: /*type*/ return new Property("type", "CodeableConcept", "The type of action to perform (create, update, remove).", 0, 1, type); 3468 case 586678389: /*groupingBehavior*/ return new Property("groupingBehavior", "code", "Defines the grouping behavior for the action and its children.", 0, 1, groupingBehavior); 3469 case 168639486: /*selectionBehavior*/ return new Property("selectionBehavior", "code", "Defines the selection behavior for the action and its children.", 0, 1, selectionBehavior); 3470 case -1163906287: /*requiredBehavior*/ return new Property("requiredBehavior", "code", "Defines the required behavior for the action.", 0, 1, requiredBehavior); 3471 case -1174249033: /*precheckBehavior*/ return new Property("precheckBehavior", "code", "Defines whether the action should usually be preselected.", 0, 1, precheckBehavior); 3472 case -922577408: /*cardinalityBehavior*/ return new Property("cardinalityBehavior", "code", "Defines whether the action can be selected multiple times.", 0, 1, cardinalityBehavior); 3473 case -1139422643: /*definition[x]*/ return new Property("definition[x]", "canonical(ActivityDefinition|MessageDefinition|ObservationDefinition|PlanDefinition|Questionnaire|SpecimenDefinition)|uri", "A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured.", 0, 1, definition); 3474 case -1014418093: /*definition*/ return new Property("definition[x]", "canonical(ActivityDefinition|MessageDefinition|ObservationDefinition|PlanDefinition|Questionnaire|SpecimenDefinition)|uri", "A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured.", 0, 1, definition); 3475 case 933485793: /*definitionCanonical*/ return new Property("definition[x]", "canonical(ActivityDefinition|MessageDefinition|ObservationDefinition|PlanDefinition|Questionnaire|SpecimenDefinition)", "A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured.", 0, 1, definition); 3476 case -1139428583: /*definitionUri*/ return new Property("definition[x]", "uri", "A reference to an ActivityDefinition that describes the action to be taken in detail, a MessageDefinition describing a message to be snet, a PlanDefinition that describes a series of actions to be taken, a Questionnaire that should be filled out, a SpecimenDefinition describing a specimen to be collected, or an ObservationDefinition that specifies what observation should be captured.", 0, 1, definition); 3477 case 1052666732: /*transform*/ return new Property("transform", "canonical(StructureMap)", "A reference to a StructureMap resource that defines a transform that can be executed to produce the intent resource using the ActivityDefinition instance as the input.", 0, 1, transform); 3478 case 572625010: /*dynamicValue*/ return new Property("dynamicValue", "", "Customizations that should be applied to the statically defined resource. For example, if the dosage of a medication must be computed based on the patient's weight, a customization would be used to specify an expression that calculated the weight, and the path on the resource that would contain the result.", 0, java.lang.Integer.MAX_VALUE, dynamicValue); 3479 case -1422950858: /*action*/ return new Property("action", "@PlanDefinition.action", "Sub actions that are contained within the action. The behavior of this action determines the functionality of the sub-actions. For example, a selection behavior of at-most-one indicates that of the sub-actions, at most one may be chosen as part of realizing the action definition.", 0, java.lang.Integer.MAX_VALUE, action); 3480 default: return super.getNamedProperty(_hash, _name, _checkValid); 3481 } 3482 3483 } 3484 3485 @Override 3486 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 3487 switch (hash) { 3488 case -1102667083: /*linkId*/ return this.linkId == null ? new Base[0] : new Base[] {this.linkId}; // StringType 3489 case -980110702: /*prefix*/ return this.prefix == null ? new Base[0] : new Base[] {this.prefix}; // StringType 3490 case 110371416: /*title*/ return this.title == null ? new Base[0] : new Base[] {this.title}; // StringType 3491 case -1724546052: /*description*/ return this.description == null ? new Base[0] : new Base[] {this.description}; // MarkdownType 3492 case -900391049: /*textEquivalent*/ return this.textEquivalent == null ? new Base[0] : new Base[] {this.textEquivalent}; // MarkdownType 3493 case -1165461084: /*priority*/ return this.priority == null ? new Base[0] : new Base[] {this.priority}; // Enumeration<RequestPriority> 3494 case 3059181: /*code*/ return this.code == null ? new Base[0] : new Base[] {this.code}; // CodeableConcept 3495 case -934964668: /*reason*/ return this.reason == null ? new Base[0] : this.reason.toArray(new Base[this.reason.size()]); // CodeableConcept 3496 case 1587405498: /*documentation*/ return this.documentation == null ? new Base[0] : this.documentation.toArray(new Base[this.documentation.size()]); // RelatedArtifact 3497 case -1240658034: /*goalId*/ return this.goalId == null ? new Base[0] : this.goalId.toArray(new Base[this.goalId.size()]); // IdType 3498 case -1867885268: /*subject*/ return this.subject == null ? new Base[0] : new Base[] {this.subject}; // DataType 3499 case -1059891784: /*trigger*/ return this.trigger == null ? new Base[0] : this.trigger.toArray(new Base[this.trigger.size()]); // TriggerDefinition 3500 case -861311717: /*condition*/ return this.condition == null ? new Base[0] : this.condition.toArray(new Base[this.condition.size()]); // PlanDefinitionActionConditionComponent 3501 case 100358090: /*input*/ return this.input == null ? new Base[0] : this.input.toArray(new Base[this.input.size()]); // PlanDefinitionActionInputComponent 3502 case -1005512447: /*output*/ return this.output == null ? new Base[0] : this.output.toArray(new Base[this.output.size()]); // PlanDefinitionActionOutputComponent 3503 case -384107967: /*relatedAction*/ return this.relatedAction == null ? new Base[0] : this.relatedAction.toArray(new Base[this.relatedAction.size()]); // PlanDefinitionActionRelatedActionComponent 3504 case -873664438: /*timing*/ return this.timing == null ? new Base[0] : new Base[] {this.timing}; // DataType 3505 case 1901043637: /*location*/ return this.location == null ? new Base[0] : new Base[] {this.location}; // CodeableReference 3506 case 767422259: /*participant*/ return this.participant == null ? new Base[0] : this.participant.toArray(new Base[this.participant.size()]); // PlanDefinitionActionParticipantComponent 3507 case 3575610: /*type*/ return this.type == null ? new Base[0] : new Base[] {this.type}; // CodeableConcept 3508 case 586678389: /*groupingBehavior*/ return this.groupingBehavior == null ? new Base[0] : new Base[] {this.groupingBehavior}; // Enumeration<ActionGroupingBehavior> 3509 case 168639486: /*selectionBehavior*/ return this.selectionBehavior == null ? new Base[0] : new Base[] {this.selectionBehavior}; // Enumeration<ActionSelectionBehavior> 3510 case -1163906287: /*requiredBehavior*/ return this.requiredBehavior == null ? new Base[0] : new Base[] {this.requiredBehavior}; // Enumeration<ActionRequiredBehavior> 3511 case -1174249033: /*precheckBehavior*/ return this.precheckBehavior == null ? new Base[0] : new Base[] {this.precheckBehavior}; // Enumeration<ActionPrecheckBehavior> 3512 case -922577408: /*cardinalityBehavior*/ return this.cardinalityBehavior == null ? new Base[0] : new Base[] {this.cardinalityBehavior}; // Enumeration<ActionCardinalityBehavior> 3513 case -1014418093: /*definition*/ return this.definition == null ? new Base[0] : new Base[] {this.definition}; // DataType 3514 case 1052666732: /*transform*/ return this.transform == null ? new Base[0] : new Base[] {this.transform}; // CanonicalType 3515 case 572625010: /*dynamicValue*/ return this.dynamicValue == null ? new Base[0] : this.dynamicValue.toArray(new Base[this.dynamicValue.size()]); // PlanDefinitionActionDynamicValueComponent 3516 case -1422950858: /*action*/ return this.action == null ? new Base[0] : this.action.toArray(new Base[this.action.size()]); // PlanDefinitionActionComponent 3517 default: return super.getProperty(hash, name, checkValid); 3518 } 3519 3520 } 3521 3522 @Override 3523 public Base setProperty(int hash, String name, Base value) throws FHIRException { 3524 switch (hash) { 3525 case -1102667083: // linkId 3526 this.linkId = TypeConvertor.castToString(value); // StringType 3527 return value; 3528 case -980110702: // prefix 3529 this.prefix = TypeConvertor.castToString(value); // StringType 3530 return value; 3531 case 110371416: // title 3532 this.title = TypeConvertor.castToString(value); // StringType 3533 return value; 3534 case -1724546052: // description 3535 this.description = TypeConvertor.castToMarkdown(value); // MarkdownType 3536 return value; 3537 case -900391049: // textEquivalent 3538 this.textEquivalent = TypeConvertor.castToMarkdown(value); // MarkdownType 3539 return value; 3540 case -1165461084: // priority 3541 value = new RequestPriorityEnumFactory().fromType(TypeConvertor.castToCode(value)); 3542 this.priority = (Enumeration) value; // Enumeration<RequestPriority> 3543 return value; 3544 case 3059181: // code 3545 this.code = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 3546 return value; 3547 case -934964668: // reason 3548 this.getReason().add(TypeConvertor.castToCodeableConcept(value)); // CodeableConcept 3549 return value; 3550 case 1587405498: // documentation 3551 this.getDocumentation().add(TypeConvertor.castToRelatedArtifact(value)); // RelatedArtifact 3552 return value; 3553 case -1240658034: // goalId 3554 this.getGoalId().add(TypeConvertor.castToId(value)); // IdType 3555 return value; 3556 case -1867885268: // subject 3557 this.subject = TypeConvertor.castToType(value); // DataType 3558 return value; 3559 case -1059891784: // trigger 3560 this.getTrigger().add(TypeConvertor.castToTriggerDefinition(value)); // TriggerDefinition 3561 return value; 3562 case -861311717: // condition 3563 this.getCondition().add((PlanDefinitionActionConditionComponent) value); // PlanDefinitionActionConditionComponent 3564 return value; 3565 case 100358090: // input 3566 this.getInput().add((PlanDefinitionActionInputComponent) value); // PlanDefinitionActionInputComponent 3567 return value; 3568 case -1005512447: // output 3569 this.getOutput().add((PlanDefinitionActionOutputComponent) value); // PlanDefinitionActionOutputComponent 3570 return value; 3571 case -384107967: // relatedAction 3572 this.getRelatedAction().add((PlanDefinitionActionRelatedActionComponent) value); // PlanDefinitionActionRelatedActionComponent 3573 return value; 3574 case -873664438: // timing 3575 this.timing = TypeConvertor.castToType(value); // DataType 3576 return value; 3577 case 1901043637: // location 3578 this.location = TypeConvertor.castToCodeableReference(value); // CodeableReference 3579 return value; 3580 case 767422259: // participant 3581 this.getParticipant().add((PlanDefinitionActionParticipantComponent) value); // PlanDefinitionActionParticipantComponent 3582 return value; 3583 case 3575610: // type 3584 this.type = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 3585 return value; 3586 case 586678389: // groupingBehavior 3587 value = new ActionGroupingBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3588 this.groupingBehavior = (Enumeration) value; // Enumeration<ActionGroupingBehavior> 3589 return value; 3590 case 168639486: // selectionBehavior 3591 value = new ActionSelectionBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3592 this.selectionBehavior = (Enumeration) value; // Enumeration<ActionSelectionBehavior> 3593 return value; 3594 case -1163906287: // requiredBehavior 3595 value = new ActionRequiredBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3596 this.requiredBehavior = (Enumeration) value; // Enumeration<ActionRequiredBehavior> 3597 return value; 3598 case -1174249033: // precheckBehavior 3599 value = new ActionPrecheckBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3600 this.precheckBehavior = (Enumeration) value; // Enumeration<ActionPrecheckBehavior> 3601 return value; 3602 case -922577408: // cardinalityBehavior 3603 value = new ActionCardinalityBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3604 this.cardinalityBehavior = (Enumeration) value; // Enumeration<ActionCardinalityBehavior> 3605 return value; 3606 case -1014418093: // definition 3607 this.definition = TypeConvertor.castToType(value); // DataType 3608 return value; 3609 case 1052666732: // transform 3610 this.transform = TypeConvertor.castToCanonical(value); // CanonicalType 3611 return value; 3612 case 572625010: // dynamicValue 3613 this.getDynamicValue().add((PlanDefinitionActionDynamicValueComponent) value); // PlanDefinitionActionDynamicValueComponent 3614 return value; 3615 case -1422950858: // action 3616 this.getAction().add((PlanDefinitionActionComponent) value); // PlanDefinitionActionComponent 3617 return value; 3618 default: return super.setProperty(hash, name, value); 3619 } 3620 3621 } 3622 3623 @Override 3624 public Base setProperty(String name, Base value) throws FHIRException { 3625 if (name.equals("linkId")) { 3626 this.linkId = TypeConvertor.castToString(value); // StringType 3627 } else if (name.equals("prefix")) { 3628 this.prefix = TypeConvertor.castToString(value); // StringType 3629 } else if (name.equals("title")) { 3630 this.title = TypeConvertor.castToString(value); // StringType 3631 } else if (name.equals("description")) { 3632 this.description = TypeConvertor.castToMarkdown(value); // MarkdownType 3633 } else if (name.equals("textEquivalent")) { 3634 this.textEquivalent = TypeConvertor.castToMarkdown(value); // MarkdownType 3635 } else if (name.equals("priority")) { 3636 value = new RequestPriorityEnumFactory().fromType(TypeConvertor.castToCode(value)); 3637 this.priority = (Enumeration) value; // Enumeration<RequestPriority> 3638 } else if (name.equals("code")) { 3639 this.code = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 3640 } else if (name.equals("reason")) { 3641 this.getReason().add(TypeConvertor.castToCodeableConcept(value)); 3642 } else if (name.equals("documentation")) { 3643 this.getDocumentation().add(TypeConvertor.castToRelatedArtifact(value)); 3644 } else if (name.equals("goalId")) { 3645 this.getGoalId().add(TypeConvertor.castToId(value)); 3646 } else if (name.equals("subject[x]")) { 3647 this.subject = TypeConvertor.castToType(value); // DataType 3648 } else if (name.equals("trigger")) { 3649 this.getTrigger().add(TypeConvertor.castToTriggerDefinition(value)); 3650 } else if (name.equals("condition")) { 3651 this.getCondition().add((PlanDefinitionActionConditionComponent) value); 3652 } else if (name.equals("input")) { 3653 this.getInput().add((PlanDefinitionActionInputComponent) value); 3654 } else if (name.equals("output")) { 3655 this.getOutput().add((PlanDefinitionActionOutputComponent) value); 3656 } else if (name.equals("relatedAction")) { 3657 this.getRelatedAction().add((PlanDefinitionActionRelatedActionComponent) value); 3658 } else if (name.equals("timing[x]")) { 3659 this.timing = TypeConvertor.castToType(value); // DataType 3660 } else if (name.equals("location")) { 3661 this.location = TypeConvertor.castToCodeableReference(value); // CodeableReference 3662 } else if (name.equals("participant")) { 3663 this.getParticipant().add((PlanDefinitionActionParticipantComponent) value); 3664 } else if (name.equals("type")) { 3665 this.type = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 3666 } else if (name.equals("groupingBehavior")) { 3667 value = new ActionGroupingBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3668 this.groupingBehavior = (Enumeration) value; // Enumeration<ActionGroupingBehavior> 3669 } else if (name.equals("selectionBehavior")) { 3670 value = new ActionSelectionBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3671 this.selectionBehavior = (Enumeration) value; // Enumeration<ActionSelectionBehavior> 3672 } else if (name.equals("requiredBehavior")) { 3673 value = new ActionRequiredBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3674 this.requiredBehavior = (Enumeration) value; // Enumeration<ActionRequiredBehavior> 3675 } else if (name.equals("precheckBehavior")) { 3676 value = new ActionPrecheckBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3677 this.precheckBehavior = (Enumeration) value; // Enumeration<ActionPrecheckBehavior> 3678 } else if (name.equals("cardinalityBehavior")) { 3679 value = new ActionCardinalityBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3680 this.cardinalityBehavior = (Enumeration) value; // Enumeration<ActionCardinalityBehavior> 3681 } else if (name.equals("definition[x]")) { 3682 this.definition = TypeConvertor.castToType(value); // DataType 3683 } else if (name.equals("transform")) { 3684 this.transform = TypeConvertor.castToCanonical(value); // CanonicalType 3685 } else if (name.equals("dynamicValue")) { 3686 this.getDynamicValue().add((PlanDefinitionActionDynamicValueComponent) value); 3687 } else if (name.equals("action")) { 3688 this.getAction().add((PlanDefinitionActionComponent) value); 3689 } else 3690 return super.setProperty(name, value); 3691 return value; 3692 } 3693 3694 @Override 3695 public void removeChild(String name, Base value) throws FHIRException { 3696 if (name.equals("linkId")) { 3697 this.linkId = null; 3698 } else if (name.equals("prefix")) { 3699 this.prefix = null; 3700 } else if (name.equals("title")) { 3701 this.title = null; 3702 } else if (name.equals("description")) { 3703 this.description = null; 3704 } else if (name.equals("textEquivalent")) { 3705 this.textEquivalent = null; 3706 } else if (name.equals("priority")) { 3707 value = new RequestPriorityEnumFactory().fromType(TypeConvertor.castToCode(value)); 3708 this.priority = (Enumeration) value; // Enumeration<RequestPriority> 3709 } else if (name.equals("code")) { 3710 this.code = null; 3711 } else if (name.equals("reason")) { 3712 this.getReason().remove(value); 3713 } else if (name.equals("documentation")) { 3714 this.getDocumentation().remove(value); 3715 } else if (name.equals("goalId")) { 3716 this.getGoalId().remove(value); 3717 } else if (name.equals("subject[x]")) { 3718 this.subject = null; 3719 } else if (name.equals("trigger")) { 3720 this.getTrigger().remove(value); 3721 } else if (name.equals("condition")) { 3722 this.getCondition().remove((PlanDefinitionActionConditionComponent) value); 3723 } else if (name.equals("input")) { 3724 this.getInput().remove((PlanDefinitionActionInputComponent) value); 3725 } else if (name.equals("output")) { 3726 this.getOutput().remove((PlanDefinitionActionOutputComponent) value); 3727 } else if (name.equals("relatedAction")) { 3728 this.getRelatedAction().remove((PlanDefinitionActionRelatedActionComponent) value); 3729 } else if (name.equals("timing[x]")) { 3730 this.timing = null; 3731 } else if (name.equals("location")) { 3732 this.location = null; 3733 } else if (name.equals("participant")) { 3734 this.getParticipant().remove((PlanDefinitionActionParticipantComponent) value); 3735 } else if (name.equals("type")) { 3736 this.type = null; 3737 } else if (name.equals("groupingBehavior")) { 3738 value = new ActionGroupingBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3739 this.groupingBehavior = (Enumeration) value; // Enumeration<ActionGroupingBehavior> 3740 } else if (name.equals("selectionBehavior")) { 3741 value = new ActionSelectionBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3742 this.selectionBehavior = (Enumeration) value; // Enumeration<ActionSelectionBehavior> 3743 } else if (name.equals("requiredBehavior")) { 3744 value = new ActionRequiredBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3745 this.requiredBehavior = (Enumeration) value; // Enumeration<ActionRequiredBehavior> 3746 } else if (name.equals("precheckBehavior")) { 3747 value = new ActionPrecheckBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3748 this.precheckBehavior = (Enumeration) value; // Enumeration<ActionPrecheckBehavior> 3749 } else if (name.equals("cardinalityBehavior")) { 3750 value = new ActionCardinalityBehaviorEnumFactory().fromType(TypeConvertor.castToCode(value)); 3751 this.cardinalityBehavior = (Enumeration) value; // Enumeration<ActionCardinalityBehavior> 3752 } else if (name.equals("definition[x]")) { 3753 this.definition = null; 3754 } else if (name.equals("transform")) { 3755 this.transform = null; 3756 } else if (name.equals("dynamicValue")) { 3757 this.getDynamicValue().remove((PlanDefinitionActionDynamicValueComponent) value); 3758 } else if (name.equals("action")) { 3759 this.getAction().remove((PlanDefinitionActionComponent) value); 3760 } else 3761 super.removeChild(name, value); 3762 3763 } 3764 3765 @Override 3766 public Base makeProperty(int hash, String name) throws FHIRException { 3767 switch (hash) { 3768 case -1102667083: return getLinkIdElement(); 3769 case -980110702: return getPrefixElement(); 3770 case 110371416: return getTitleElement(); 3771 case -1724546052: return getDescriptionElement(); 3772 case -900391049: return getTextEquivalentElement(); 3773 case -1165461084: return getPriorityElement(); 3774 case 3059181: return getCode(); 3775 case -934964668: return addReason(); 3776 case 1587405498: return addDocumentation(); 3777 case -1240658034: return addGoalIdElement(); 3778 case -573640748: return getSubject(); 3779 case -1867885268: return getSubject(); 3780 case -1059891784: return addTrigger(); 3781 case -861311717: return addCondition(); 3782 case 100358090: return addInput(); 3783 case -1005512447: return addOutput(); 3784 case -384107967: return addRelatedAction(); 3785 case 164632566: return getTiming(); 3786 case -873664438: return getTiming(); 3787 case 1901043637: return getLocation(); 3788 case 767422259: return addParticipant(); 3789 case 3575610: return getType(); 3790 case 586678389: return getGroupingBehaviorElement(); 3791 case 168639486: return getSelectionBehaviorElement(); 3792 case -1163906287: return getRequiredBehaviorElement(); 3793 case -1174249033: return getPrecheckBehaviorElement(); 3794 case -922577408: return getCardinalityBehaviorElement(); 3795 case -1139422643: return getDefinition(); 3796 case -1014418093: return getDefinition(); 3797 case 1052666732: return getTransformElement(); 3798 case 572625010: return addDynamicValue(); 3799 case -1422950858: return addAction(); 3800 default: return super.makeProperty(hash, name); 3801 } 3802 3803 } 3804 3805 @Override 3806 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 3807 switch (hash) { 3808 case -1102667083: /*linkId*/ return new String[] {"string"}; 3809 case -980110702: /*prefix*/ return new String[] {"string"}; 3810 case 110371416: /*title*/ return new String[] {"string"}; 3811 case -1724546052: /*description*/ return new String[] {"markdown"}; 3812 case -900391049: /*textEquivalent*/ return new String[] {"markdown"}; 3813 case -1165461084: /*priority*/ return new String[] {"code"}; 3814 case 3059181: /*code*/ return new String[] {"CodeableConcept"}; 3815 case -934964668: /*reason*/ return new String[] {"CodeableConcept"}; 3816 case 1587405498: /*documentation*/ return new String[] {"RelatedArtifact"}; 3817 case -1240658034: /*goalId*/ return new String[] {"id"}; 3818 case -1867885268: /*subject*/ return new String[] {"CodeableConcept", "Reference", "canonical"}; 3819 case -1059891784: /*trigger*/ return new String[] {"TriggerDefinition"}; 3820 case -861311717: /*condition*/ return new String[] {}; 3821 case 100358090: /*input*/ return new String[] {}; 3822 case -1005512447: /*output*/ return new String[] {}; 3823 case -384107967: /*relatedAction*/ return new String[] {}; 3824 case -873664438: /*timing*/ return new String[] {"Age", "Duration", "Range", "Timing"}; 3825 case 1901043637: /*location*/ return new String[] {"CodeableReference"}; 3826 case 767422259: /*participant*/ return new String[] {}; 3827 case 3575610: /*type*/ return new String[] {"CodeableConcept"}; 3828 case 586678389: /*groupingBehavior*/ return new String[] {"code"}; 3829 case 168639486: /*selectionBehavior*/ return new String[] {"code"}; 3830 case -1163906287: /*requiredBehavior*/ return new String[] {"code"}; 3831 case -1174249033: /*precheckBehavior*/ return new String[] {"code"}; 3832 case -922577408: /*cardinalityBehavior*/ return new String[] {"code"}; 3833 case -1014418093: /*definition*/ return new String[] {"canonical", "uri"}; 3834 case 1052666732: /*transform*/ return new String[] {"canonical"}; 3835 case 572625010: /*dynamicValue*/ return new String[] {}; 3836 case -1422950858: /*action*/ return new String[] {"@PlanDefinition.action"}; 3837 default: return super.getTypesForProperty(hash, name); 3838 } 3839 3840 } 3841 3842 @Override 3843 public Base addChild(String name) throws FHIRException { 3844 if (name.equals("linkId")) { 3845 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.linkId"); 3846 } 3847 else if (name.equals("prefix")) { 3848 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.prefix"); 3849 } 3850 else if (name.equals("title")) { 3851 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.title"); 3852 } 3853 else if (name.equals("description")) { 3854 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.description"); 3855 } 3856 else if (name.equals("textEquivalent")) { 3857 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.textEquivalent"); 3858 } 3859 else if (name.equals("priority")) { 3860 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.priority"); 3861 } 3862 else if (name.equals("code")) { 3863 this.code = new CodeableConcept(); 3864 return this.code; 3865 } 3866 else if (name.equals("reason")) { 3867 return addReason(); 3868 } 3869 else if (name.equals("documentation")) { 3870 return addDocumentation(); 3871 } 3872 else if (name.equals("goalId")) { 3873 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.goalId"); 3874 } 3875 else if (name.equals("subjectCodeableConcept")) { 3876 this.subject = new CodeableConcept(); 3877 return this.subject; 3878 } 3879 else if (name.equals("subjectReference")) { 3880 this.subject = new Reference(); 3881 return this.subject; 3882 } 3883 else if (name.equals("subjectCanonical")) { 3884 this.subject = new CanonicalType(); 3885 return this.subject; 3886 } 3887 else if (name.equals("trigger")) { 3888 return addTrigger(); 3889 } 3890 else if (name.equals("condition")) { 3891 return addCondition(); 3892 } 3893 else if (name.equals("input")) { 3894 return addInput(); 3895 } 3896 else if (name.equals("output")) { 3897 return addOutput(); 3898 } 3899 else if (name.equals("relatedAction")) { 3900 return addRelatedAction(); 3901 } 3902 else if (name.equals("timingAge")) { 3903 this.timing = new Age(); 3904 return this.timing; 3905 } 3906 else if (name.equals("timingDuration")) { 3907 this.timing = new Duration(); 3908 return this.timing; 3909 } 3910 else if (name.equals("timingRange")) { 3911 this.timing = new Range(); 3912 return this.timing; 3913 } 3914 else if (name.equals("timingTiming")) { 3915 this.timing = new Timing(); 3916 return this.timing; 3917 } 3918 else if (name.equals("location")) { 3919 this.location = new CodeableReference(); 3920 return this.location; 3921 } 3922 else if (name.equals("participant")) { 3923 return addParticipant(); 3924 } 3925 else if (name.equals("type")) { 3926 this.type = new CodeableConcept(); 3927 return this.type; 3928 } 3929 else if (name.equals("groupingBehavior")) { 3930 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.groupingBehavior"); 3931 } 3932 else if (name.equals("selectionBehavior")) { 3933 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.selectionBehavior"); 3934 } 3935 else if (name.equals("requiredBehavior")) { 3936 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.requiredBehavior"); 3937 } 3938 else if (name.equals("precheckBehavior")) { 3939 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.precheckBehavior"); 3940 } 3941 else if (name.equals("cardinalityBehavior")) { 3942 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.cardinalityBehavior"); 3943 } 3944 else if (name.equals("definitionCanonical")) { 3945 this.definition = new CanonicalType(); 3946 return this.definition; 3947 } 3948 else if (name.equals("definitionUri")) { 3949 this.definition = new UriType(); 3950 return this.definition; 3951 } 3952 else if (name.equals("transform")) { 3953 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.transform"); 3954 } 3955 else if (name.equals("dynamicValue")) { 3956 return addDynamicValue(); 3957 } 3958 else if (name.equals("action")) { 3959 return addAction(); 3960 } 3961 else 3962 return super.addChild(name); 3963 } 3964 3965 public PlanDefinitionActionComponent copy() { 3966 PlanDefinitionActionComponent dst = new PlanDefinitionActionComponent(); 3967 copyValues(dst); 3968 return dst; 3969 } 3970 3971 public void copyValues(PlanDefinitionActionComponent dst) { 3972 super.copyValues(dst); 3973 dst.linkId = linkId == null ? null : linkId.copy(); 3974 dst.prefix = prefix == null ? null : prefix.copy(); 3975 dst.title = title == null ? null : title.copy(); 3976 dst.description = description == null ? null : description.copy(); 3977 dst.textEquivalent = textEquivalent == null ? null : textEquivalent.copy(); 3978 dst.priority = priority == null ? null : priority.copy(); 3979 dst.code = code == null ? null : code.copy(); 3980 if (reason != null) { 3981 dst.reason = new ArrayList<CodeableConcept>(); 3982 for (CodeableConcept i : reason) 3983 dst.reason.add(i.copy()); 3984 }; 3985 if (documentation != null) { 3986 dst.documentation = new ArrayList<RelatedArtifact>(); 3987 for (RelatedArtifact i : documentation) 3988 dst.documentation.add(i.copy()); 3989 }; 3990 if (goalId != null) { 3991 dst.goalId = new ArrayList<IdType>(); 3992 for (IdType i : goalId) 3993 dst.goalId.add(i.copy()); 3994 }; 3995 dst.subject = subject == null ? null : subject.copy(); 3996 if (trigger != null) { 3997 dst.trigger = new ArrayList<TriggerDefinition>(); 3998 for (TriggerDefinition i : trigger) 3999 dst.trigger.add(i.copy()); 4000 }; 4001 if (condition != null) { 4002 dst.condition = new ArrayList<PlanDefinitionActionConditionComponent>(); 4003 for (PlanDefinitionActionConditionComponent i : condition) 4004 dst.condition.add(i.copy()); 4005 }; 4006 if (input != null) { 4007 dst.input = new ArrayList<PlanDefinitionActionInputComponent>(); 4008 for (PlanDefinitionActionInputComponent i : input) 4009 dst.input.add(i.copy()); 4010 }; 4011 if (output != null) { 4012 dst.output = new ArrayList<PlanDefinitionActionOutputComponent>(); 4013 for (PlanDefinitionActionOutputComponent i : output) 4014 dst.output.add(i.copy()); 4015 }; 4016 if (relatedAction != null) { 4017 dst.relatedAction = new ArrayList<PlanDefinitionActionRelatedActionComponent>(); 4018 for (PlanDefinitionActionRelatedActionComponent i : relatedAction) 4019 dst.relatedAction.add(i.copy()); 4020 }; 4021 dst.timing = timing == null ? null : timing.copy(); 4022 dst.location = location == null ? null : location.copy(); 4023 if (participant != null) { 4024 dst.participant = new ArrayList<PlanDefinitionActionParticipantComponent>(); 4025 for (PlanDefinitionActionParticipantComponent i : participant) 4026 dst.participant.add(i.copy()); 4027 }; 4028 dst.type = type == null ? null : type.copy(); 4029 dst.groupingBehavior = groupingBehavior == null ? null : groupingBehavior.copy(); 4030 dst.selectionBehavior = selectionBehavior == null ? null : selectionBehavior.copy(); 4031 dst.requiredBehavior = requiredBehavior == null ? null : requiredBehavior.copy(); 4032 dst.precheckBehavior = precheckBehavior == null ? null : precheckBehavior.copy(); 4033 dst.cardinalityBehavior = cardinalityBehavior == null ? null : cardinalityBehavior.copy(); 4034 dst.definition = definition == null ? null : definition.copy(); 4035 dst.transform = transform == null ? null : transform.copy(); 4036 if (dynamicValue != null) { 4037 dst.dynamicValue = new ArrayList<PlanDefinitionActionDynamicValueComponent>(); 4038 for (PlanDefinitionActionDynamicValueComponent i : dynamicValue) 4039 dst.dynamicValue.add(i.copy()); 4040 }; 4041 if (action != null) { 4042 dst.action = new ArrayList<PlanDefinitionActionComponent>(); 4043 for (PlanDefinitionActionComponent i : action) 4044 dst.action.add(i.copy()); 4045 }; 4046 } 4047 4048 @Override 4049 public boolean equalsDeep(Base other_) { 4050 if (!super.equalsDeep(other_)) 4051 return false; 4052 if (!(other_ instanceof PlanDefinitionActionComponent)) 4053 return false; 4054 PlanDefinitionActionComponent o = (PlanDefinitionActionComponent) other_; 4055 return compareDeep(linkId, o.linkId, true) && compareDeep(prefix, o.prefix, true) && compareDeep(title, o.title, true) 4056 && compareDeep(description, o.description, true) && compareDeep(textEquivalent, o.textEquivalent, true) 4057 && compareDeep(priority, o.priority, true) && compareDeep(code, o.code, true) && compareDeep(reason, o.reason, true) 4058 && compareDeep(documentation, o.documentation, true) && compareDeep(goalId, o.goalId, true) && compareDeep(subject, o.subject, true) 4059 && compareDeep(trigger, o.trigger, true) && compareDeep(condition, o.condition, true) && compareDeep(input, o.input, true) 4060 && compareDeep(output, o.output, true) && compareDeep(relatedAction, o.relatedAction, true) && compareDeep(timing, o.timing, true) 4061 && compareDeep(location, o.location, true) && compareDeep(participant, o.participant, true) && compareDeep(type, o.type, true) 4062 && compareDeep(groupingBehavior, o.groupingBehavior, true) && compareDeep(selectionBehavior, o.selectionBehavior, true) 4063 && compareDeep(requiredBehavior, o.requiredBehavior, true) && compareDeep(precheckBehavior, o.precheckBehavior, true) 4064 && compareDeep(cardinalityBehavior, o.cardinalityBehavior, true) && compareDeep(definition, o.definition, true) 4065 && compareDeep(transform, o.transform, true) && compareDeep(dynamicValue, o.dynamicValue, true) 4066 && compareDeep(action, o.action, true); 4067 } 4068 4069 @Override 4070 public boolean equalsShallow(Base other_) { 4071 if (!super.equalsShallow(other_)) 4072 return false; 4073 if (!(other_ instanceof PlanDefinitionActionComponent)) 4074 return false; 4075 PlanDefinitionActionComponent o = (PlanDefinitionActionComponent) other_; 4076 return compareValues(linkId, o.linkId, true) && compareValues(prefix, o.prefix, true) && compareValues(title, o.title, true) 4077 && compareValues(description, o.description, true) && compareValues(textEquivalent, o.textEquivalent, true) 4078 && compareValues(priority, o.priority, true) && compareValues(goalId, o.goalId, true) && compareValues(groupingBehavior, o.groupingBehavior, true) 4079 && compareValues(selectionBehavior, o.selectionBehavior, true) && compareValues(requiredBehavior, o.requiredBehavior, true) 4080 && compareValues(precheckBehavior, o.precheckBehavior, true) && compareValues(cardinalityBehavior, o.cardinalityBehavior, true) 4081 && compareValues(transform, o.transform, true); 4082 } 4083 4084 public boolean isEmpty() { 4085 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(linkId, prefix, title, description 4086 , textEquivalent, priority, code, reason, documentation, goalId, subject, trigger 4087 , condition, input, output, relatedAction, timing, location, participant, type 4088 , groupingBehavior, selectionBehavior, requiredBehavior, precheckBehavior, cardinalityBehavior 4089 , definition, transform, dynamicValue, action); 4090 } 4091 4092 public String fhirType() { 4093 return "PlanDefinition.action"; 4094 4095 } 4096 4097 } 4098 4099 @Block() 4100 public static class PlanDefinitionActionConditionComponent extends BackboneElement implements IBaseBackboneElement { 4101 /** 4102 * The kind of condition. 4103 */ 4104 @Child(name = "kind", type = {CodeType.class}, order=1, min=1, max=1, modifier=false, summary=false) 4105 @Description(shortDefinition="applicability | start | stop", formalDefinition="The kind of condition." ) 4106 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-condition-kind") 4107 protected Enumeration<ActionConditionKind> kind; 4108 4109 /** 4110 * An expression that returns true or false, indicating whether the condition is satisfied. 4111 */ 4112 @Child(name = "expression", type = {Expression.class}, order=2, min=0, max=1, modifier=false, summary=false) 4113 @Description(shortDefinition="Boolean-valued expression", formalDefinition="An expression that returns true or false, indicating whether the condition is satisfied." ) 4114 protected Expression expression; 4115 4116 private static final long serialVersionUID = -455150438L; 4117 4118 /** 4119 * Constructor 4120 */ 4121 public PlanDefinitionActionConditionComponent() { 4122 super(); 4123 } 4124 4125 /** 4126 * Constructor 4127 */ 4128 public PlanDefinitionActionConditionComponent(ActionConditionKind kind) { 4129 super(); 4130 this.setKind(kind); 4131 } 4132 4133 /** 4134 * @return {@link #kind} (The kind of condition.). This is the underlying object with id, value and extensions. The accessor "getKind" gives direct access to the value 4135 */ 4136 public Enumeration<ActionConditionKind> getKindElement() { 4137 if (this.kind == null) 4138 if (Configuration.errorOnAutoCreate()) 4139 throw new Error("Attempt to auto-create PlanDefinitionActionConditionComponent.kind"); 4140 else if (Configuration.doAutoCreate()) 4141 this.kind = new Enumeration<ActionConditionKind>(new ActionConditionKindEnumFactory()); // bb 4142 return this.kind; 4143 } 4144 4145 public boolean hasKindElement() { 4146 return this.kind != null && !this.kind.isEmpty(); 4147 } 4148 4149 public boolean hasKind() { 4150 return this.kind != null && !this.kind.isEmpty(); 4151 } 4152 4153 /** 4154 * @param value {@link #kind} (The kind of condition.). This is the underlying object with id, value and extensions. The accessor "getKind" gives direct access to the value 4155 */ 4156 public PlanDefinitionActionConditionComponent setKindElement(Enumeration<ActionConditionKind> value) { 4157 this.kind = value; 4158 return this; 4159 } 4160 4161 /** 4162 * @return The kind of condition. 4163 */ 4164 public ActionConditionKind getKind() { 4165 return this.kind == null ? null : this.kind.getValue(); 4166 } 4167 4168 /** 4169 * @param value The kind of condition. 4170 */ 4171 public PlanDefinitionActionConditionComponent setKind(ActionConditionKind value) { 4172 if (this.kind == null) 4173 this.kind = new Enumeration<ActionConditionKind>(new ActionConditionKindEnumFactory()); 4174 this.kind.setValue(value); 4175 return this; 4176 } 4177 4178 /** 4179 * @return {@link #expression} (An expression that returns true or false, indicating whether the condition is satisfied.) 4180 */ 4181 public Expression getExpression() { 4182 if (this.expression == null) 4183 if (Configuration.errorOnAutoCreate()) 4184 throw new Error("Attempt to auto-create PlanDefinitionActionConditionComponent.expression"); 4185 else if (Configuration.doAutoCreate()) 4186 this.expression = new Expression(); // cc 4187 return this.expression; 4188 } 4189 4190 public boolean hasExpression() { 4191 return this.expression != null && !this.expression.isEmpty(); 4192 } 4193 4194 /** 4195 * @param value {@link #expression} (An expression that returns true or false, indicating whether the condition is satisfied.) 4196 */ 4197 public PlanDefinitionActionConditionComponent setExpression(Expression value) { 4198 this.expression = value; 4199 return this; 4200 } 4201 4202 protected void listChildren(List<Property> children) { 4203 super.listChildren(children); 4204 children.add(new Property("kind", "code", "The kind of condition.", 0, 1, kind)); 4205 children.add(new Property("expression", "Expression", "An expression that returns true or false, indicating whether the condition is satisfied.", 0, 1, expression)); 4206 } 4207 4208 @Override 4209 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 4210 switch (_hash) { 4211 case 3292052: /*kind*/ return new Property("kind", "code", "The kind of condition.", 0, 1, kind); 4212 case -1795452264: /*expression*/ return new Property("expression", "Expression", "An expression that returns true or false, indicating whether the condition is satisfied.", 0, 1, expression); 4213 default: return super.getNamedProperty(_hash, _name, _checkValid); 4214 } 4215 4216 } 4217 4218 @Override 4219 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 4220 switch (hash) { 4221 case 3292052: /*kind*/ return this.kind == null ? new Base[0] : new Base[] {this.kind}; // Enumeration<ActionConditionKind> 4222 case -1795452264: /*expression*/ return this.expression == null ? new Base[0] : new Base[] {this.expression}; // Expression 4223 default: return super.getProperty(hash, name, checkValid); 4224 } 4225 4226 } 4227 4228 @Override 4229 public Base setProperty(int hash, String name, Base value) throws FHIRException { 4230 switch (hash) { 4231 case 3292052: // kind 4232 value = new ActionConditionKindEnumFactory().fromType(TypeConvertor.castToCode(value)); 4233 this.kind = (Enumeration) value; // Enumeration<ActionConditionKind> 4234 return value; 4235 case -1795452264: // expression 4236 this.expression = TypeConvertor.castToExpression(value); // Expression 4237 return value; 4238 default: return super.setProperty(hash, name, value); 4239 } 4240 4241 } 4242 4243 @Override 4244 public Base setProperty(String name, Base value) throws FHIRException { 4245 if (name.equals("kind")) { 4246 value = new ActionConditionKindEnumFactory().fromType(TypeConvertor.castToCode(value)); 4247 this.kind = (Enumeration) value; // Enumeration<ActionConditionKind> 4248 } else if (name.equals("expression")) { 4249 this.expression = TypeConvertor.castToExpression(value); // Expression 4250 } else 4251 return super.setProperty(name, value); 4252 return value; 4253 } 4254 4255 @Override 4256 public void removeChild(String name, Base value) throws FHIRException { 4257 if (name.equals("kind")) { 4258 value = new ActionConditionKindEnumFactory().fromType(TypeConvertor.castToCode(value)); 4259 this.kind = (Enumeration) value; // Enumeration<ActionConditionKind> 4260 } else if (name.equals("expression")) { 4261 this.expression = 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 3292052: return getKindElement(); 4271 case -1795452264: return getExpression(); 4272 default: return super.makeProperty(hash, name); 4273 } 4274 4275 } 4276 4277 @Override 4278 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 4279 switch (hash) { 4280 case 3292052: /*kind*/ return new String[] {"code"}; 4281 case -1795452264: /*expression*/ return new String[] {"Expression"}; 4282 default: return super.getTypesForProperty(hash, name); 4283 } 4284 4285 } 4286 4287 @Override 4288 public Base addChild(String name) throws FHIRException { 4289 if (name.equals("kind")) { 4290 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.condition.kind"); 4291 } 4292 else if (name.equals("expression")) { 4293 this.expression = new Expression(); 4294 return this.expression; 4295 } 4296 else 4297 return super.addChild(name); 4298 } 4299 4300 public PlanDefinitionActionConditionComponent copy() { 4301 PlanDefinitionActionConditionComponent dst = new PlanDefinitionActionConditionComponent(); 4302 copyValues(dst); 4303 return dst; 4304 } 4305 4306 public void copyValues(PlanDefinitionActionConditionComponent dst) { 4307 super.copyValues(dst); 4308 dst.kind = kind == null ? null : kind.copy(); 4309 dst.expression = expression == null ? null : expression.copy(); 4310 } 4311 4312 @Override 4313 public boolean equalsDeep(Base other_) { 4314 if (!super.equalsDeep(other_)) 4315 return false; 4316 if (!(other_ instanceof PlanDefinitionActionConditionComponent)) 4317 return false; 4318 PlanDefinitionActionConditionComponent o = (PlanDefinitionActionConditionComponent) other_; 4319 return compareDeep(kind, o.kind, true) && compareDeep(expression, o.expression, true); 4320 } 4321 4322 @Override 4323 public boolean equalsShallow(Base other_) { 4324 if (!super.equalsShallow(other_)) 4325 return false; 4326 if (!(other_ instanceof PlanDefinitionActionConditionComponent)) 4327 return false; 4328 PlanDefinitionActionConditionComponent o = (PlanDefinitionActionConditionComponent) other_; 4329 return compareValues(kind, o.kind, true); 4330 } 4331 4332 public boolean isEmpty() { 4333 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(kind, expression); 4334 } 4335 4336 public String fhirType() { 4337 return "PlanDefinition.action.condition"; 4338 4339 } 4340 4341 } 4342 4343 @Block() 4344 public static class PlanDefinitionActionInputComponent extends BackboneElement implements IBaseBackboneElement { 4345 /** 4346 * A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers. 4347 */ 4348 @Child(name = "title", type = {StringType.class}, order=1, min=0, max=1, modifier=false, summary=false) 4349 @Description(shortDefinition="User-visible title", formalDefinition="A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers." ) 4350 protected StringType title; 4351 4352 /** 4353 * Defines the data that is to be provided as input to the action. 4354 */ 4355 @Child(name = "requirement", type = {DataRequirement.class}, order=2, min=0, max=1, modifier=false, summary=false) 4356 @Description(shortDefinition="What data is provided", formalDefinition="Defines the data that is to be provided as input to the action." ) 4357 protected DataRequirement requirement; 4358 4359 /** 4360 * Points to an existing input or output element that provides data to this input. 4361 */ 4362 @Child(name = "relatedData", type = {IdType.class}, order=3, min=0, max=1, modifier=false, summary=false) 4363 @Description(shortDefinition="What data is provided", formalDefinition="Points to an existing input or output element that provides data to this input." ) 4364 protected IdType relatedData; 4365 4366 private static final long serialVersionUID = -1064046709L; 4367 4368 /** 4369 * Constructor 4370 */ 4371 public PlanDefinitionActionInputComponent() { 4372 super(); 4373 } 4374 4375 /** 4376 * @return {@link #title} (A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers.). This is the underlying object with id, value and extensions. The accessor "getTitle" gives direct access to the value 4377 */ 4378 public StringType getTitleElement() { 4379 if (this.title == null) 4380 if (Configuration.errorOnAutoCreate()) 4381 throw new Error("Attempt to auto-create PlanDefinitionActionInputComponent.title"); 4382 else if (Configuration.doAutoCreate()) 4383 this.title = new StringType(); // bb 4384 return this.title; 4385 } 4386 4387 public boolean hasTitleElement() { 4388 return this.title != null && !this.title.isEmpty(); 4389 } 4390 4391 public boolean hasTitle() { 4392 return this.title != null && !this.title.isEmpty(); 4393 } 4394 4395 /** 4396 * @param value {@link #title} (A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers.). This is the underlying object with id, value and extensions. The accessor "getTitle" gives direct access to the value 4397 */ 4398 public PlanDefinitionActionInputComponent setTitleElement(StringType value) { 4399 this.title = value; 4400 return this; 4401 } 4402 4403 /** 4404 * @return A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers. 4405 */ 4406 public String getTitle() { 4407 return this.title == null ? null : this.title.getValue(); 4408 } 4409 4410 /** 4411 * @param value A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers. 4412 */ 4413 public PlanDefinitionActionInputComponent setTitle(String value) { 4414 if (Utilities.noString(value)) 4415 this.title = null; 4416 else { 4417 if (this.title == null) 4418 this.title = new StringType(); 4419 this.title.setValue(value); 4420 } 4421 return this; 4422 } 4423 4424 /** 4425 * @return {@link #requirement} (Defines the data that is to be provided as input to the action.) 4426 */ 4427 public DataRequirement getRequirement() { 4428 if (this.requirement == null) 4429 if (Configuration.errorOnAutoCreate()) 4430 throw new Error("Attempt to auto-create PlanDefinitionActionInputComponent.requirement"); 4431 else if (Configuration.doAutoCreate()) 4432 this.requirement = new DataRequirement(); // cc 4433 return this.requirement; 4434 } 4435 4436 public boolean hasRequirement() { 4437 return this.requirement != null && !this.requirement.isEmpty(); 4438 } 4439 4440 /** 4441 * @param value {@link #requirement} (Defines the data that is to be provided as input to the action.) 4442 */ 4443 public PlanDefinitionActionInputComponent setRequirement(DataRequirement value) { 4444 this.requirement = value; 4445 return this; 4446 } 4447 4448 /** 4449 * @return {@link #relatedData} (Points to an existing input or output element that provides data to this input.). This is the underlying object with id, value and extensions. The accessor "getRelatedData" gives direct access to the value 4450 */ 4451 public IdType getRelatedDataElement() { 4452 if (this.relatedData == null) 4453 if (Configuration.errorOnAutoCreate()) 4454 throw new Error("Attempt to auto-create PlanDefinitionActionInputComponent.relatedData"); 4455 else if (Configuration.doAutoCreate()) 4456 this.relatedData = new IdType(); // bb 4457 return this.relatedData; 4458 } 4459 4460 public boolean hasRelatedDataElement() { 4461 return this.relatedData != null && !this.relatedData.isEmpty(); 4462 } 4463 4464 public boolean hasRelatedData() { 4465 return this.relatedData != null && !this.relatedData.isEmpty(); 4466 } 4467 4468 /** 4469 * @param value {@link #relatedData} (Points to an existing input or output element that provides data to this input.). This is the underlying object with id, value and extensions. The accessor "getRelatedData" gives direct access to the value 4470 */ 4471 public PlanDefinitionActionInputComponent setRelatedDataElement(IdType value) { 4472 this.relatedData = value; 4473 return this; 4474 } 4475 4476 /** 4477 * @return Points to an existing input or output element that provides data to this input. 4478 */ 4479 public String getRelatedData() { 4480 return this.relatedData == null ? null : this.relatedData.getValue(); 4481 } 4482 4483 /** 4484 * @param value Points to an existing input or output element that provides data to this input. 4485 */ 4486 public PlanDefinitionActionInputComponent setRelatedData(String value) { 4487 if (Utilities.noString(value)) 4488 this.relatedData = null; 4489 else { 4490 if (this.relatedData == null) 4491 this.relatedData = new IdType(); 4492 this.relatedData.setValue(value); 4493 } 4494 return this; 4495 } 4496 4497 protected void listChildren(List<Property> children) { 4498 super.listChildren(children); 4499 children.add(new Property("title", "string", "A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers.", 0, 1, title)); 4500 children.add(new Property("requirement", "DataRequirement", "Defines the data that is to be provided as input to the action.", 0, 1, requirement)); 4501 children.add(new Property("relatedData", "id", "Points to an existing input or output element that provides data to this input.", 0, 1, relatedData)); 4502 } 4503 4504 @Override 4505 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 4506 switch (_hash) { 4507 case 110371416: /*title*/ return new Property("title", "string", "A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers.", 0, 1, title); 4508 case 363387971: /*requirement*/ return new Property("requirement", "DataRequirement", "Defines the data that is to be provided as input to the action.", 0, 1, requirement); 4509 case 1112535669: /*relatedData*/ return new Property("relatedData", "id", "Points to an existing input or output element that provides data to this input.", 0, 1, relatedData); 4510 default: return super.getNamedProperty(_hash, _name, _checkValid); 4511 } 4512 4513 } 4514 4515 @Override 4516 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 4517 switch (hash) { 4518 case 110371416: /*title*/ return this.title == null ? new Base[0] : new Base[] {this.title}; // StringType 4519 case 363387971: /*requirement*/ return this.requirement == null ? new Base[0] : new Base[] {this.requirement}; // DataRequirement 4520 case 1112535669: /*relatedData*/ return this.relatedData == null ? new Base[0] : new Base[] {this.relatedData}; // IdType 4521 default: return super.getProperty(hash, name, checkValid); 4522 } 4523 4524 } 4525 4526 @Override 4527 public Base setProperty(int hash, String name, Base value) throws FHIRException { 4528 switch (hash) { 4529 case 110371416: // title 4530 this.title = TypeConvertor.castToString(value); // StringType 4531 return value; 4532 case 363387971: // requirement 4533 this.requirement = TypeConvertor.castToDataRequirement(value); // DataRequirement 4534 return value; 4535 case 1112535669: // relatedData 4536 this.relatedData = TypeConvertor.castToId(value); // IdType 4537 return value; 4538 default: return super.setProperty(hash, name, value); 4539 } 4540 4541 } 4542 4543 @Override 4544 public Base setProperty(String name, Base value) throws FHIRException { 4545 if (name.equals("title")) { 4546 this.title = TypeConvertor.castToString(value); // StringType 4547 } else if (name.equals("requirement")) { 4548 this.requirement = TypeConvertor.castToDataRequirement(value); // DataRequirement 4549 } else if (name.equals("relatedData")) { 4550 this.relatedData = TypeConvertor.castToId(value); // IdType 4551 } else 4552 return super.setProperty(name, value); 4553 return value; 4554 } 4555 4556 @Override 4557 public void removeChild(String name, Base value) throws FHIRException { 4558 if (name.equals("title")) { 4559 this.title = null; 4560 } else if (name.equals("requirement")) { 4561 this.requirement = null; 4562 } else if (name.equals("relatedData")) { 4563 this.relatedData = null; 4564 } else 4565 super.removeChild(name, value); 4566 4567 } 4568 4569 @Override 4570 public Base makeProperty(int hash, String name) throws FHIRException { 4571 switch (hash) { 4572 case 110371416: return getTitleElement(); 4573 case 363387971: return getRequirement(); 4574 case 1112535669: return getRelatedDataElement(); 4575 default: return super.makeProperty(hash, name); 4576 } 4577 4578 } 4579 4580 @Override 4581 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 4582 switch (hash) { 4583 case 110371416: /*title*/ return new String[] {"string"}; 4584 case 363387971: /*requirement*/ return new String[] {"DataRequirement"}; 4585 case 1112535669: /*relatedData*/ return new String[] {"id"}; 4586 default: return super.getTypesForProperty(hash, name); 4587 } 4588 4589 } 4590 4591 @Override 4592 public Base addChild(String name) throws FHIRException { 4593 if (name.equals("title")) { 4594 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.input.title"); 4595 } 4596 else if (name.equals("requirement")) { 4597 this.requirement = new DataRequirement(); 4598 return this.requirement; 4599 } 4600 else if (name.equals("relatedData")) { 4601 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.input.relatedData"); 4602 } 4603 else 4604 return super.addChild(name); 4605 } 4606 4607 public PlanDefinitionActionInputComponent copy() { 4608 PlanDefinitionActionInputComponent dst = new PlanDefinitionActionInputComponent(); 4609 copyValues(dst); 4610 return dst; 4611 } 4612 4613 public void copyValues(PlanDefinitionActionInputComponent dst) { 4614 super.copyValues(dst); 4615 dst.title = title == null ? null : title.copy(); 4616 dst.requirement = requirement == null ? null : requirement.copy(); 4617 dst.relatedData = relatedData == null ? null : relatedData.copy(); 4618 } 4619 4620 @Override 4621 public boolean equalsDeep(Base other_) { 4622 if (!super.equalsDeep(other_)) 4623 return false; 4624 if (!(other_ instanceof PlanDefinitionActionInputComponent)) 4625 return false; 4626 PlanDefinitionActionInputComponent o = (PlanDefinitionActionInputComponent) other_; 4627 return compareDeep(title, o.title, true) && compareDeep(requirement, o.requirement, true) && compareDeep(relatedData, o.relatedData, true) 4628 ; 4629 } 4630 4631 @Override 4632 public boolean equalsShallow(Base other_) { 4633 if (!super.equalsShallow(other_)) 4634 return false; 4635 if (!(other_ instanceof PlanDefinitionActionInputComponent)) 4636 return false; 4637 PlanDefinitionActionInputComponent o = (PlanDefinitionActionInputComponent) other_; 4638 return compareValues(title, o.title, true) && compareValues(relatedData, o.relatedData, true); 4639 } 4640 4641 public boolean isEmpty() { 4642 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(title, requirement, relatedData 4643 ); 4644 } 4645 4646 public String fhirType() { 4647 return "PlanDefinition.action.input"; 4648 4649 } 4650 4651 } 4652 4653 @Block() 4654 public static class PlanDefinitionActionOutputComponent extends BackboneElement implements IBaseBackboneElement { 4655 /** 4656 * A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers. 4657 */ 4658 @Child(name = "title", type = {StringType.class}, order=1, min=0, max=1, modifier=false, summary=false) 4659 @Description(shortDefinition="User-visible title", formalDefinition="A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers." ) 4660 protected StringType title; 4661 4662 /** 4663 * Defines the data that results as output from the action. 4664 */ 4665 @Child(name = "requirement", type = {DataRequirement.class}, order=2, min=0, max=1, modifier=false, summary=false) 4666 @Description(shortDefinition="What data is provided", formalDefinition="Defines the data that results as output from the action." ) 4667 protected DataRequirement requirement; 4668 4669 /** 4670 * Points to an existing input or output element that is results as output from the action. 4671 */ 4672 @Child(name = "relatedData", type = {StringType.class}, order=3, min=0, max=1, modifier=false, summary=false) 4673 @Description(shortDefinition="What data is provided", formalDefinition="Points to an existing input or output element that is results as output from the action." ) 4674 protected StringType relatedData; 4675 4676 private static final long serialVersionUID = 1822414421L; 4677 4678 /** 4679 * Constructor 4680 */ 4681 public PlanDefinitionActionOutputComponent() { 4682 super(); 4683 } 4684 4685 /** 4686 * @return {@link #title} (A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers.). This is the underlying object with id, value and extensions. The accessor "getTitle" gives direct access to the value 4687 */ 4688 public StringType getTitleElement() { 4689 if (this.title == null) 4690 if (Configuration.errorOnAutoCreate()) 4691 throw new Error("Attempt to auto-create PlanDefinitionActionOutputComponent.title"); 4692 else if (Configuration.doAutoCreate()) 4693 this.title = new StringType(); // bb 4694 return this.title; 4695 } 4696 4697 public boolean hasTitleElement() { 4698 return this.title != null && !this.title.isEmpty(); 4699 } 4700 4701 public boolean hasTitle() { 4702 return this.title != null && !this.title.isEmpty(); 4703 } 4704 4705 /** 4706 * @param value {@link #title} (A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers.). This is the underlying object with id, value and extensions. The accessor "getTitle" gives direct access to the value 4707 */ 4708 public PlanDefinitionActionOutputComponent setTitleElement(StringType value) { 4709 this.title = value; 4710 return this; 4711 } 4712 4713 /** 4714 * @return A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers. 4715 */ 4716 public String getTitle() { 4717 return this.title == null ? null : this.title.getValue(); 4718 } 4719 4720 /** 4721 * @param value A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers. 4722 */ 4723 public PlanDefinitionActionOutputComponent setTitle(String value) { 4724 if (Utilities.noString(value)) 4725 this.title = null; 4726 else { 4727 if (this.title == null) 4728 this.title = new StringType(); 4729 this.title.setValue(value); 4730 } 4731 return this; 4732 } 4733 4734 /** 4735 * @return {@link #requirement} (Defines the data that results as output from the action.) 4736 */ 4737 public DataRequirement getRequirement() { 4738 if (this.requirement == null) 4739 if (Configuration.errorOnAutoCreate()) 4740 throw new Error("Attempt to auto-create PlanDefinitionActionOutputComponent.requirement"); 4741 else if (Configuration.doAutoCreate()) 4742 this.requirement = new DataRequirement(); // cc 4743 return this.requirement; 4744 } 4745 4746 public boolean hasRequirement() { 4747 return this.requirement != null && !this.requirement.isEmpty(); 4748 } 4749 4750 /** 4751 * @param value {@link #requirement} (Defines the data that results as output from the action.) 4752 */ 4753 public PlanDefinitionActionOutputComponent setRequirement(DataRequirement value) { 4754 this.requirement = value; 4755 return this; 4756 } 4757 4758 /** 4759 * @return {@link #relatedData} (Points to an existing input or output element that is results as output from the action.). This is the underlying object with id, value and extensions. The accessor "getRelatedData" gives direct access to the value 4760 */ 4761 public StringType getRelatedDataElement() { 4762 if (this.relatedData == null) 4763 if (Configuration.errorOnAutoCreate()) 4764 throw new Error("Attempt to auto-create PlanDefinitionActionOutputComponent.relatedData"); 4765 else if (Configuration.doAutoCreate()) 4766 this.relatedData = new StringType(); // bb 4767 return this.relatedData; 4768 } 4769 4770 public boolean hasRelatedDataElement() { 4771 return this.relatedData != null && !this.relatedData.isEmpty(); 4772 } 4773 4774 public boolean hasRelatedData() { 4775 return this.relatedData != null && !this.relatedData.isEmpty(); 4776 } 4777 4778 /** 4779 * @param value {@link #relatedData} (Points to an existing input or output element that is results as output from the action.). This is the underlying object with id, value and extensions. The accessor "getRelatedData" gives direct access to the value 4780 */ 4781 public PlanDefinitionActionOutputComponent setRelatedDataElement(StringType value) { 4782 this.relatedData = value; 4783 return this; 4784 } 4785 4786 /** 4787 * @return Points to an existing input or output element that is results as output from the action. 4788 */ 4789 public String getRelatedData() { 4790 return this.relatedData == null ? null : this.relatedData.getValue(); 4791 } 4792 4793 /** 4794 * @param value Points to an existing input or output element that is results as output from the action. 4795 */ 4796 public PlanDefinitionActionOutputComponent setRelatedData(String value) { 4797 if (Utilities.noString(value)) 4798 this.relatedData = null; 4799 else { 4800 if (this.relatedData == null) 4801 this.relatedData = new StringType(); 4802 this.relatedData.setValue(value); 4803 } 4804 return this; 4805 } 4806 4807 protected void listChildren(List<Property> children) { 4808 super.listChildren(children); 4809 children.add(new Property("title", "string", "A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers.", 0, 1, title)); 4810 children.add(new Property("requirement", "DataRequirement", "Defines the data that results as output from the action.", 0, 1, requirement)); 4811 children.add(new Property("relatedData", "string", "Points to an existing input or output element that is results as output from the action.", 0, 1, relatedData)); 4812 } 4813 4814 @Override 4815 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 4816 switch (_hash) { 4817 case 110371416: /*title*/ return new Property("title", "string", "A human-readable label for the data requirement used to label data flows in BPMN or similar diagrams. Also provides a human readable label when rendering the data requirement that conveys its purpose to human readers.", 0, 1, title); 4818 case 363387971: /*requirement*/ return new Property("requirement", "DataRequirement", "Defines the data that results as output from the action.", 0, 1, requirement); 4819 case 1112535669: /*relatedData*/ return new Property("relatedData", "string", "Points to an existing input or output element that is results as output from the action.", 0, 1, relatedData); 4820 default: return super.getNamedProperty(_hash, _name, _checkValid); 4821 } 4822 4823 } 4824 4825 @Override 4826 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 4827 switch (hash) { 4828 case 110371416: /*title*/ return this.title == null ? new Base[0] : new Base[] {this.title}; // StringType 4829 case 363387971: /*requirement*/ return this.requirement == null ? new Base[0] : new Base[] {this.requirement}; // DataRequirement 4830 case 1112535669: /*relatedData*/ return this.relatedData == null ? new Base[0] : new Base[] {this.relatedData}; // StringType 4831 default: return super.getProperty(hash, name, checkValid); 4832 } 4833 4834 } 4835 4836 @Override 4837 public Base setProperty(int hash, String name, Base value) throws FHIRException { 4838 switch (hash) { 4839 case 110371416: // title 4840 this.title = TypeConvertor.castToString(value); // StringType 4841 return value; 4842 case 363387971: // requirement 4843 this.requirement = TypeConvertor.castToDataRequirement(value); // DataRequirement 4844 return value; 4845 case 1112535669: // relatedData 4846 this.relatedData = TypeConvertor.castToString(value); // StringType 4847 return value; 4848 default: return super.setProperty(hash, name, value); 4849 } 4850 4851 } 4852 4853 @Override 4854 public Base setProperty(String name, Base value) throws FHIRException { 4855 if (name.equals("title")) { 4856 this.title = TypeConvertor.castToString(value); // StringType 4857 } else if (name.equals("requirement")) { 4858 this.requirement = TypeConvertor.castToDataRequirement(value); // DataRequirement 4859 } else if (name.equals("relatedData")) { 4860 this.relatedData = TypeConvertor.castToString(value); // StringType 4861 } else 4862 return super.setProperty(name, value); 4863 return value; 4864 } 4865 4866 @Override 4867 public void removeChild(String name, Base value) throws FHIRException { 4868 if (name.equals("title")) { 4869 this.title = null; 4870 } else if (name.equals("requirement")) { 4871 this.requirement = null; 4872 } else if (name.equals("relatedData")) { 4873 this.relatedData = null; 4874 } else 4875 super.removeChild(name, value); 4876 4877 } 4878 4879 @Override 4880 public Base makeProperty(int hash, String name) throws FHIRException { 4881 switch (hash) { 4882 case 110371416: return getTitleElement(); 4883 case 363387971: return getRequirement(); 4884 case 1112535669: return getRelatedDataElement(); 4885 default: return super.makeProperty(hash, name); 4886 } 4887 4888 } 4889 4890 @Override 4891 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 4892 switch (hash) { 4893 case 110371416: /*title*/ return new String[] {"string"}; 4894 case 363387971: /*requirement*/ return new String[] {"DataRequirement"}; 4895 case 1112535669: /*relatedData*/ return new String[] {"string"}; 4896 default: return super.getTypesForProperty(hash, name); 4897 } 4898 4899 } 4900 4901 @Override 4902 public Base addChild(String name) throws FHIRException { 4903 if (name.equals("title")) { 4904 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.output.title"); 4905 } 4906 else if (name.equals("requirement")) { 4907 this.requirement = new DataRequirement(); 4908 return this.requirement; 4909 } 4910 else if (name.equals("relatedData")) { 4911 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.output.relatedData"); 4912 } 4913 else 4914 return super.addChild(name); 4915 } 4916 4917 public PlanDefinitionActionOutputComponent copy() { 4918 PlanDefinitionActionOutputComponent dst = new PlanDefinitionActionOutputComponent(); 4919 copyValues(dst); 4920 return dst; 4921 } 4922 4923 public void copyValues(PlanDefinitionActionOutputComponent dst) { 4924 super.copyValues(dst); 4925 dst.title = title == null ? null : title.copy(); 4926 dst.requirement = requirement == null ? null : requirement.copy(); 4927 dst.relatedData = relatedData == null ? null : relatedData.copy(); 4928 } 4929 4930 @Override 4931 public boolean equalsDeep(Base other_) { 4932 if (!super.equalsDeep(other_)) 4933 return false; 4934 if (!(other_ instanceof PlanDefinitionActionOutputComponent)) 4935 return false; 4936 PlanDefinitionActionOutputComponent o = (PlanDefinitionActionOutputComponent) other_; 4937 return compareDeep(title, o.title, true) && compareDeep(requirement, o.requirement, true) && compareDeep(relatedData, o.relatedData, true) 4938 ; 4939 } 4940 4941 @Override 4942 public boolean equalsShallow(Base other_) { 4943 if (!super.equalsShallow(other_)) 4944 return false; 4945 if (!(other_ instanceof PlanDefinitionActionOutputComponent)) 4946 return false; 4947 PlanDefinitionActionOutputComponent o = (PlanDefinitionActionOutputComponent) other_; 4948 return compareValues(title, o.title, true) && compareValues(relatedData, o.relatedData, true); 4949 } 4950 4951 public boolean isEmpty() { 4952 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(title, requirement, relatedData 4953 ); 4954 } 4955 4956 public String fhirType() { 4957 return "PlanDefinition.action.output"; 4958 4959 } 4960 4961 } 4962 4963 @Block() 4964 public static class PlanDefinitionActionRelatedActionComponent extends BackboneElement implements IBaseBackboneElement { 4965 /** 4966 * The element id of the target related action. 4967 */ 4968 @Child(name = "targetId", type = {IdType.class}, order=1, min=1, max=1, modifier=false, summary=false) 4969 @Description(shortDefinition="What action is this related to", formalDefinition="The element id of the target related action." ) 4970 protected IdType targetId; 4971 4972 /** 4973 * The relationship of the start of this action to the related action. 4974 */ 4975 @Child(name = "relationship", type = {CodeType.class}, order=2, min=1, max=1, modifier=false, summary=false) 4976 @Description(shortDefinition="before | before-start | before-end | concurrent | concurrent-with-start | concurrent-with-end | after | after-start | after-end", formalDefinition="The relationship of the start of this action to the related action." ) 4977 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-relationship-type") 4978 protected Enumeration<ActionRelationshipType> relationship; 4979 4980 /** 4981 * The relationship of the end of this action to the related action. 4982 */ 4983 @Child(name = "endRelationship", type = {CodeType.class}, order=3, min=0, max=1, modifier=false, summary=false) 4984 @Description(shortDefinition="before | before-start | before-end | concurrent | concurrent-with-start | concurrent-with-end | after | after-start | after-end", formalDefinition="The relationship of the end of this action to the related action." ) 4985 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-relationship-type") 4986 protected Enumeration<ActionRelationshipType> endRelationship; 4987 4988 /** 4989 * A duration or range of durations to apply to the relationship. For example, 30-60 minutes before. 4990 */ 4991 @Child(name = "offset", type = {Duration.class, Range.class}, order=4, min=0, max=1, modifier=false, summary=false) 4992 @Description(shortDefinition="Time offset for the relationship", formalDefinition="A duration or range of durations to apply to the relationship. For example, 30-60 minutes before." ) 4993 protected DataType offset; 4994 4995 private static final long serialVersionUID = 1997058061L; 4996 4997 /** 4998 * Constructor 4999 */ 5000 public PlanDefinitionActionRelatedActionComponent() { 5001 super(); 5002 } 5003 5004 /** 5005 * Constructor 5006 */ 5007 public PlanDefinitionActionRelatedActionComponent(String targetId, ActionRelationshipType relationship) { 5008 super(); 5009 this.setTargetId(targetId); 5010 this.setRelationship(relationship); 5011 } 5012 5013 /** 5014 * @return {@link #targetId} (The element id of the target related action.). This is the underlying object with id, value and extensions. The accessor "getTargetId" gives direct access to the value 5015 */ 5016 public IdType getTargetIdElement() { 5017 if (this.targetId == null) 5018 if (Configuration.errorOnAutoCreate()) 5019 throw new Error("Attempt to auto-create PlanDefinitionActionRelatedActionComponent.targetId"); 5020 else if (Configuration.doAutoCreate()) 5021 this.targetId = new IdType(); // bb 5022 return this.targetId; 5023 } 5024 5025 public boolean hasTargetIdElement() { 5026 return this.targetId != null && !this.targetId.isEmpty(); 5027 } 5028 5029 public boolean hasTargetId() { 5030 return this.targetId != null && !this.targetId.isEmpty(); 5031 } 5032 5033 /** 5034 * @param value {@link #targetId} (The element id of the target related action.). This is the underlying object with id, value and extensions. The accessor "getTargetId" gives direct access to the value 5035 */ 5036 public PlanDefinitionActionRelatedActionComponent setTargetIdElement(IdType value) { 5037 this.targetId = value; 5038 return this; 5039 } 5040 5041 /** 5042 * @return The element id of the target related action. 5043 */ 5044 public String getTargetId() { 5045 return this.targetId == null ? null : this.targetId.getValue(); 5046 } 5047 5048 /** 5049 * @param value The element id of the target related action. 5050 */ 5051 public PlanDefinitionActionRelatedActionComponent setTargetId(String value) { 5052 if (this.targetId == null) 5053 this.targetId = new IdType(); 5054 this.targetId.setValue(value); 5055 return this; 5056 } 5057 5058 /** 5059 * @return {@link #relationship} (The relationship of the start of this action to the related action.). This is the underlying object with id, value and extensions. The accessor "getRelationship" gives direct access to the value 5060 */ 5061 public Enumeration<ActionRelationshipType> getRelationshipElement() { 5062 if (this.relationship == null) 5063 if (Configuration.errorOnAutoCreate()) 5064 throw new Error("Attempt to auto-create PlanDefinitionActionRelatedActionComponent.relationship"); 5065 else if (Configuration.doAutoCreate()) 5066 this.relationship = new Enumeration<ActionRelationshipType>(new ActionRelationshipTypeEnumFactory()); // bb 5067 return this.relationship; 5068 } 5069 5070 public boolean hasRelationshipElement() { 5071 return this.relationship != null && !this.relationship.isEmpty(); 5072 } 5073 5074 public boolean hasRelationship() { 5075 return this.relationship != null && !this.relationship.isEmpty(); 5076 } 5077 5078 /** 5079 * @param value {@link #relationship} (The relationship of the start of this action to the related action.). This is the underlying object with id, value and extensions. The accessor "getRelationship" gives direct access to the value 5080 */ 5081 public PlanDefinitionActionRelatedActionComponent setRelationshipElement(Enumeration<ActionRelationshipType> value) { 5082 this.relationship = value; 5083 return this; 5084 } 5085 5086 /** 5087 * @return The relationship of the start of this action to the related action. 5088 */ 5089 public ActionRelationshipType getRelationship() { 5090 return this.relationship == null ? null : this.relationship.getValue(); 5091 } 5092 5093 /** 5094 * @param value The relationship of the start of this action to the related action. 5095 */ 5096 public PlanDefinitionActionRelatedActionComponent setRelationship(ActionRelationshipType value) { 5097 if (this.relationship == null) 5098 this.relationship = new Enumeration<ActionRelationshipType>(new ActionRelationshipTypeEnumFactory()); 5099 this.relationship.setValue(value); 5100 return this; 5101 } 5102 5103 /** 5104 * @return {@link #endRelationship} (The relationship of the end of this action to the related action.). This is the underlying object with id, value and extensions. The accessor "getEndRelationship" gives direct access to the value 5105 */ 5106 public Enumeration<ActionRelationshipType> getEndRelationshipElement() { 5107 if (this.endRelationship == null) 5108 if (Configuration.errorOnAutoCreate()) 5109 throw new Error("Attempt to auto-create PlanDefinitionActionRelatedActionComponent.endRelationship"); 5110 else if (Configuration.doAutoCreate()) 5111 this.endRelationship = new Enumeration<ActionRelationshipType>(new ActionRelationshipTypeEnumFactory()); // bb 5112 return this.endRelationship; 5113 } 5114 5115 public boolean hasEndRelationshipElement() { 5116 return this.endRelationship != null && !this.endRelationship.isEmpty(); 5117 } 5118 5119 public boolean hasEndRelationship() { 5120 return this.endRelationship != null && !this.endRelationship.isEmpty(); 5121 } 5122 5123 /** 5124 * @param value {@link #endRelationship} (The relationship of the end of this action to the related action.). This is the underlying object with id, value and extensions. The accessor "getEndRelationship" gives direct access to the value 5125 */ 5126 public PlanDefinitionActionRelatedActionComponent setEndRelationshipElement(Enumeration<ActionRelationshipType> value) { 5127 this.endRelationship = value; 5128 return this; 5129 } 5130 5131 /** 5132 * @return The relationship of the end of this action to the related action. 5133 */ 5134 public ActionRelationshipType getEndRelationship() { 5135 return this.endRelationship == null ? null : this.endRelationship.getValue(); 5136 } 5137 5138 /** 5139 * @param value The relationship of the end of this action to the related action. 5140 */ 5141 public PlanDefinitionActionRelatedActionComponent setEndRelationship(ActionRelationshipType value) { 5142 if (value == null) 5143 this.endRelationship = null; 5144 else { 5145 if (this.endRelationship == null) 5146 this.endRelationship = new Enumeration<ActionRelationshipType>(new ActionRelationshipTypeEnumFactory()); 5147 this.endRelationship.setValue(value); 5148 } 5149 return this; 5150 } 5151 5152 /** 5153 * @return {@link #offset} (A duration or range of durations to apply to the relationship. For example, 30-60 minutes before.) 5154 */ 5155 public DataType getOffset() { 5156 return this.offset; 5157 } 5158 5159 /** 5160 * @return {@link #offset} (A duration or range of durations to apply to the relationship. For example, 30-60 minutes before.) 5161 */ 5162 public Duration getOffsetDuration() throws FHIRException { 5163 if (this.offset == null) 5164 this.offset = new Duration(); 5165 if (!(this.offset instanceof Duration)) 5166 throw new FHIRException("Type mismatch: the type Duration was expected, but "+this.offset.getClass().getName()+" was encountered"); 5167 return (Duration) this.offset; 5168 } 5169 5170 public boolean hasOffsetDuration() { 5171 return this != null && this.offset instanceof Duration; 5172 } 5173 5174 /** 5175 * @return {@link #offset} (A duration or range of durations to apply to the relationship. For example, 30-60 minutes before.) 5176 */ 5177 public Range getOffsetRange() throws FHIRException { 5178 if (this.offset == null) 5179 this.offset = new Range(); 5180 if (!(this.offset instanceof Range)) 5181 throw new FHIRException("Type mismatch: the type Range was expected, but "+this.offset.getClass().getName()+" was encountered"); 5182 return (Range) this.offset; 5183 } 5184 5185 public boolean hasOffsetRange() { 5186 return this != null && this.offset instanceof Range; 5187 } 5188 5189 public boolean hasOffset() { 5190 return this.offset != null && !this.offset.isEmpty(); 5191 } 5192 5193 /** 5194 * @param value {@link #offset} (A duration or range of durations to apply to the relationship. For example, 30-60 minutes before.) 5195 */ 5196 public PlanDefinitionActionRelatedActionComponent setOffset(DataType value) { 5197 if (value != null && !(value instanceof Duration || value instanceof Range)) 5198 throw new FHIRException("Not the right type for PlanDefinition.action.relatedAction.offset[x]: "+value.fhirType()); 5199 this.offset = value; 5200 return this; 5201 } 5202 5203 protected void listChildren(List<Property> children) { 5204 super.listChildren(children); 5205 children.add(new Property("targetId", "id", "The element id of the target related action.", 0, 1, targetId)); 5206 children.add(new Property("relationship", "code", "The relationship of the start of this action to the related action.", 0, 1, relationship)); 5207 children.add(new Property("endRelationship", "code", "The relationship of the end of this action to the related action.", 0, 1, endRelationship)); 5208 children.add(new Property("offset[x]", "Duration|Range", "A duration or range of durations to apply to the relationship. For example, 30-60 minutes before.", 0, 1, offset)); 5209 } 5210 5211 @Override 5212 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 5213 switch (_hash) { 5214 case -441951604: /*targetId*/ return new Property("targetId", "id", "The element id of the target related action.", 0, 1, targetId); 5215 case -261851592: /*relationship*/ return new Property("relationship", "code", "The relationship of the start of this action to the related action.", 0, 1, relationship); 5216 case -1506024781: /*endRelationship*/ return new Property("endRelationship", "code", "The relationship of the end of this action to the related action.", 0, 1, endRelationship); 5217 case -1960684787: /*offset[x]*/ return new Property("offset[x]", "Duration|Range", "A duration or range of durations to apply to the relationship. For example, 30-60 minutes before.", 0, 1, offset); 5218 case -1019779949: /*offset*/ return new Property("offset[x]", "Duration|Range", "A duration or range of durations to apply to the relationship. For example, 30-60 minutes before.", 0, 1, offset); 5219 case 134075207: /*offsetDuration*/ return new Property("offset[x]", "Duration", "A duration or range of durations to apply to the relationship. For example, 30-60 minutes before.", 0, 1, offset); 5220 case 1263585386: /*offsetRange*/ return new Property("offset[x]", "Range", "A duration or range of durations to apply to the relationship. For example, 30-60 minutes before.", 0, 1, offset); 5221 default: return super.getNamedProperty(_hash, _name, _checkValid); 5222 } 5223 5224 } 5225 5226 @Override 5227 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 5228 switch (hash) { 5229 case -441951604: /*targetId*/ return this.targetId == null ? new Base[0] : new Base[] {this.targetId}; // IdType 5230 case -261851592: /*relationship*/ return this.relationship == null ? new Base[0] : new Base[] {this.relationship}; // Enumeration<ActionRelationshipType> 5231 case -1506024781: /*endRelationship*/ return this.endRelationship == null ? new Base[0] : new Base[] {this.endRelationship}; // Enumeration<ActionRelationshipType> 5232 case -1019779949: /*offset*/ return this.offset == null ? new Base[0] : new Base[] {this.offset}; // DataType 5233 default: return super.getProperty(hash, name, checkValid); 5234 } 5235 5236 } 5237 5238 @Override 5239 public Base setProperty(int hash, String name, Base value) throws FHIRException { 5240 switch (hash) { 5241 case -441951604: // targetId 5242 this.targetId = TypeConvertor.castToId(value); // IdType 5243 return value; 5244 case -261851592: // relationship 5245 value = new ActionRelationshipTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 5246 this.relationship = (Enumeration) value; // Enumeration<ActionRelationshipType> 5247 return value; 5248 case -1506024781: // endRelationship 5249 value = new ActionRelationshipTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 5250 this.endRelationship = (Enumeration) value; // Enumeration<ActionRelationshipType> 5251 return value; 5252 case -1019779949: // offset 5253 this.offset = TypeConvertor.castToType(value); // DataType 5254 return value; 5255 default: return super.setProperty(hash, name, value); 5256 } 5257 5258 } 5259 5260 @Override 5261 public Base setProperty(String name, Base value) throws FHIRException { 5262 if (name.equals("targetId")) { 5263 this.targetId = TypeConvertor.castToId(value); // IdType 5264 } else if (name.equals("relationship")) { 5265 value = new ActionRelationshipTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 5266 this.relationship = (Enumeration) value; // Enumeration<ActionRelationshipType> 5267 } else if (name.equals("endRelationship")) { 5268 value = new ActionRelationshipTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 5269 this.endRelationship = (Enumeration) value; // Enumeration<ActionRelationshipType> 5270 } else if (name.equals("offset[x]")) { 5271 this.offset = TypeConvertor.castToType(value); // DataType 5272 } else 5273 return super.setProperty(name, value); 5274 return value; 5275 } 5276 5277 @Override 5278 public void removeChild(String name, Base value) throws FHIRException { 5279 if (name.equals("targetId")) { 5280 this.targetId = null; 5281 } else if (name.equals("relationship")) { 5282 value = new ActionRelationshipTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 5283 this.relationship = (Enumeration) value; // Enumeration<ActionRelationshipType> 5284 } else if (name.equals("endRelationship")) { 5285 value = new ActionRelationshipTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 5286 this.endRelationship = (Enumeration) value; // Enumeration<ActionRelationshipType> 5287 } else if (name.equals("offset[x]")) { 5288 this.offset = null; 5289 } else 5290 super.removeChild(name, value); 5291 5292 } 5293 5294 @Override 5295 public Base makeProperty(int hash, String name) throws FHIRException { 5296 switch (hash) { 5297 case -441951604: return getTargetIdElement(); 5298 case -261851592: return getRelationshipElement(); 5299 case -1506024781: return getEndRelationshipElement(); 5300 case -1960684787: return getOffset(); 5301 case -1019779949: return getOffset(); 5302 default: return super.makeProperty(hash, name); 5303 } 5304 5305 } 5306 5307 @Override 5308 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 5309 switch (hash) { 5310 case -441951604: /*targetId*/ return new String[] {"id"}; 5311 case -261851592: /*relationship*/ return new String[] {"code"}; 5312 case -1506024781: /*endRelationship*/ return new String[] {"code"}; 5313 case -1019779949: /*offset*/ return new String[] {"Duration", "Range"}; 5314 default: return super.getTypesForProperty(hash, name); 5315 } 5316 5317 } 5318 5319 @Override 5320 public Base addChild(String name) throws FHIRException { 5321 if (name.equals("targetId")) { 5322 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.relatedAction.targetId"); 5323 } 5324 else if (name.equals("relationship")) { 5325 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.relatedAction.relationship"); 5326 } 5327 else if (name.equals("endRelationship")) { 5328 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.relatedAction.endRelationship"); 5329 } 5330 else if (name.equals("offsetDuration")) { 5331 this.offset = new Duration(); 5332 return this.offset; 5333 } 5334 else if (name.equals("offsetRange")) { 5335 this.offset = new Range(); 5336 return this.offset; 5337 } 5338 else 5339 return super.addChild(name); 5340 } 5341 5342 public PlanDefinitionActionRelatedActionComponent copy() { 5343 PlanDefinitionActionRelatedActionComponent dst = new PlanDefinitionActionRelatedActionComponent(); 5344 copyValues(dst); 5345 return dst; 5346 } 5347 5348 public void copyValues(PlanDefinitionActionRelatedActionComponent dst) { 5349 super.copyValues(dst); 5350 dst.targetId = targetId == null ? null : targetId.copy(); 5351 dst.relationship = relationship == null ? null : relationship.copy(); 5352 dst.endRelationship = endRelationship == null ? null : endRelationship.copy(); 5353 dst.offset = offset == null ? null : offset.copy(); 5354 } 5355 5356 @Override 5357 public boolean equalsDeep(Base other_) { 5358 if (!super.equalsDeep(other_)) 5359 return false; 5360 if (!(other_ instanceof PlanDefinitionActionRelatedActionComponent)) 5361 return false; 5362 PlanDefinitionActionRelatedActionComponent o = (PlanDefinitionActionRelatedActionComponent) other_; 5363 return compareDeep(targetId, o.targetId, true) && compareDeep(relationship, o.relationship, true) 5364 && compareDeep(endRelationship, o.endRelationship, true) && compareDeep(offset, o.offset, true) 5365 ; 5366 } 5367 5368 @Override 5369 public boolean equalsShallow(Base other_) { 5370 if (!super.equalsShallow(other_)) 5371 return false; 5372 if (!(other_ instanceof PlanDefinitionActionRelatedActionComponent)) 5373 return false; 5374 PlanDefinitionActionRelatedActionComponent o = (PlanDefinitionActionRelatedActionComponent) other_; 5375 return compareValues(targetId, o.targetId, true) && compareValues(relationship, o.relationship, true) 5376 && compareValues(endRelationship, o.endRelationship, true); 5377 } 5378 5379 public boolean isEmpty() { 5380 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(targetId, relationship, endRelationship 5381 , offset); 5382 } 5383 5384 public String fhirType() { 5385 return "PlanDefinition.action.relatedAction"; 5386 5387 } 5388 5389 } 5390 5391 @Block() 5392 public static class PlanDefinitionActionParticipantComponent extends BackboneElement implements IBaseBackboneElement { 5393 /** 5394 * A reference to the id element of the actor who will participate in this action. 5395 */ 5396 @Child(name = "actorId", type = {StringType.class}, order=1, min=0, max=1, modifier=false, summary=false) 5397 @Description(shortDefinition="What actor", formalDefinition="A reference to the id element of the actor who will participate in this action." ) 5398 protected StringType actorId; 5399 5400 /** 5401 * The type of participant in the action. 5402 */ 5403 @Child(name = "type", type = {CodeType.class}, order=2, min=0, max=1, modifier=false, summary=false) 5404 @Description(shortDefinition="careteam | device | group | healthcareservice | location | organization | patient | practitioner | practitionerrole | relatedperson", formalDefinition="The type of participant in the action." ) 5405 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-participant-type") 5406 protected Enumeration<ActionParticipantType> type; 5407 5408 /** 5409 * The type of participant in the action. 5410 */ 5411 @Child(name = "typeCanonical", type = {CanonicalType.class}, order=3, min=0, max=1, modifier=false, summary=false) 5412 @Description(shortDefinition="Who or what can participate", formalDefinition="The type of participant in the action." ) 5413 protected CanonicalType typeCanonical; 5414 5415 /** 5416 * The type of participant in the action. 5417 */ 5418 @Child(name = "typeReference", type = {CareTeam.class, Device.class, DeviceDefinition.class, Endpoint.class, Group.class, HealthcareService.class, Location.class, Organization.class, Patient.class, Practitioner.class, PractitionerRole.class, RelatedPerson.class}, order=4, min=0, max=1, modifier=false, summary=false) 5419 @Description(shortDefinition="Who or what can participate", formalDefinition="The type of participant in the action." ) 5420 protected Reference typeReference; 5421 5422 /** 5423 * The role the participant should play in performing the described action. 5424 */ 5425 @Child(name = "role", type = {CodeableConcept.class}, order=5, min=0, max=1, modifier=false, summary=false) 5426 @Description(shortDefinition="E.g. Nurse, Surgeon, Parent", formalDefinition="The role the participant should play in performing the described action." ) 5427 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://terminology.hl7.org/ValueSet/action-participant-role") 5428 protected CodeableConcept role; 5429 5430 /** 5431 * Indicates how the actor will be involved in the action - author, reviewer, witness, etc. 5432 */ 5433 @Child(name = "function", type = {CodeableConcept.class}, order=6, min=0, max=1, modifier=false, summary=false) 5434 @Description(shortDefinition="E.g. Author, Reviewer, Witness, etc", formalDefinition="Indicates how the actor will be involved in the action - author, reviewer, witness, etc." ) 5435 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/action-participant-function") 5436 protected CodeableConcept function; 5437 5438 private static final long serialVersionUID = -1467052283L; 5439 5440 /** 5441 * Constructor 5442 */ 5443 public PlanDefinitionActionParticipantComponent() { 5444 super(); 5445 } 5446 5447 /** 5448 * @return {@link #actorId} (A reference to the id element of the actor who will participate in this action.). This is the underlying object with id, value and extensions. The accessor "getActorId" gives direct access to the value 5449 */ 5450 public StringType getActorIdElement() { 5451 if (this.actorId == null) 5452 if (Configuration.errorOnAutoCreate()) 5453 throw new Error("Attempt to auto-create PlanDefinitionActionParticipantComponent.actorId"); 5454 else if (Configuration.doAutoCreate()) 5455 this.actorId = new StringType(); // bb 5456 return this.actorId; 5457 } 5458 5459 public boolean hasActorIdElement() { 5460 return this.actorId != null && !this.actorId.isEmpty(); 5461 } 5462 5463 public boolean hasActorId() { 5464 return this.actorId != null && !this.actorId.isEmpty(); 5465 } 5466 5467 /** 5468 * @param value {@link #actorId} (A reference to the id element of the actor who will participate in this action.). This is the underlying object with id, value and extensions. The accessor "getActorId" gives direct access to the value 5469 */ 5470 public PlanDefinitionActionParticipantComponent setActorIdElement(StringType value) { 5471 this.actorId = value; 5472 return this; 5473 } 5474 5475 /** 5476 * @return A reference to the id element of the actor who will participate in this action. 5477 */ 5478 public String getActorId() { 5479 return this.actorId == null ? null : this.actorId.getValue(); 5480 } 5481 5482 /** 5483 * @param value A reference to the id element of the actor who will participate in this action. 5484 */ 5485 public PlanDefinitionActionParticipantComponent setActorId(String value) { 5486 if (Utilities.noString(value)) 5487 this.actorId = null; 5488 else { 5489 if (this.actorId == null) 5490 this.actorId = new StringType(); 5491 this.actorId.setValue(value); 5492 } 5493 return this; 5494 } 5495 5496 /** 5497 * @return {@link #type} (The type of participant in the action.). This is the underlying object with id, value and extensions. The accessor "getType" gives direct access to the value 5498 */ 5499 public Enumeration<ActionParticipantType> getTypeElement() { 5500 if (this.type == null) 5501 if (Configuration.errorOnAutoCreate()) 5502 throw new Error("Attempt to auto-create PlanDefinitionActionParticipantComponent.type"); 5503 else if (Configuration.doAutoCreate()) 5504 this.type = new Enumeration<ActionParticipantType>(new ActionParticipantTypeEnumFactory()); // bb 5505 return this.type; 5506 } 5507 5508 public boolean hasTypeElement() { 5509 return this.type != null && !this.type.isEmpty(); 5510 } 5511 5512 public boolean hasType() { 5513 return this.type != null && !this.type.isEmpty(); 5514 } 5515 5516 /** 5517 * @param value {@link #type} (The type of participant in the action.). This is the underlying object with id, value and extensions. The accessor "getType" gives direct access to the value 5518 */ 5519 public PlanDefinitionActionParticipantComponent setTypeElement(Enumeration<ActionParticipantType> value) { 5520 this.type = value; 5521 return this; 5522 } 5523 5524 /** 5525 * @return The type of participant in the action. 5526 */ 5527 public ActionParticipantType getType() { 5528 return this.type == null ? null : this.type.getValue(); 5529 } 5530 5531 /** 5532 * @param value The type of participant in the action. 5533 */ 5534 public PlanDefinitionActionParticipantComponent setType(ActionParticipantType value) { 5535 if (value == null) 5536 this.type = null; 5537 else { 5538 if (this.type == null) 5539 this.type = new Enumeration<ActionParticipantType>(new ActionParticipantTypeEnumFactory()); 5540 this.type.setValue(value); 5541 } 5542 return this; 5543 } 5544 5545 /** 5546 * @return {@link #typeCanonical} (The type of participant in the action.). This is the underlying object with id, value and extensions. The accessor "getTypeCanonical" gives direct access to the value 5547 */ 5548 public CanonicalType getTypeCanonicalElement() { 5549 if (this.typeCanonical == null) 5550 if (Configuration.errorOnAutoCreate()) 5551 throw new Error("Attempt to auto-create PlanDefinitionActionParticipantComponent.typeCanonical"); 5552 else if (Configuration.doAutoCreate()) 5553 this.typeCanonical = new CanonicalType(); // bb 5554 return this.typeCanonical; 5555 } 5556 5557 public boolean hasTypeCanonicalElement() { 5558 return this.typeCanonical != null && !this.typeCanonical.isEmpty(); 5559 } 5560 5561 public boolean hasTypeCanonical() { 5562 return this.typeCanonical != null && !this.typeCanonical.isEmpty(); 5563 } 5564 5565 /** 5566 * @param value {@link #typeCanonical} (The type of participant in the action.). This is the underlying object with id, value and extensions. The accessor "getTypeCanonical" gives direct access to the value 5567 */ 5568 public PlanDefinitionActionParticipantComponent setTypeCanonicalElement(CanonicalType value) { 5569 this.typeCanonical = value; 5570 return this; 5571 } 5572 5573 /** 5574 * @return The type of participant in the action. 5575 */ 5576 public String getTypeCanonical() { 5577 return this.typeCanonical == null ? null : this.typeCanonical.getValue(); 5578 } 5579 5580 /** 5581 * @param value The type of participant in the action. 5582 */ 5583 public PlanDefinitionActionParticipantComponent setTypeCanonical(String value) { 5584 if (Utilities.noString(value)) 5585 this.typeCanonical = null; 5586 else { 5587 if (this.typeCanonical == null) 5588 this.typeCanonical = new CanonicalType(); 5589 this.typeCanonical.setValue(value); 5590 } 5591 return this; 5592 } 5593 5594 /** 5595 * @return {@link #typeReference} (The type of participant in the action.) 5596 */ 5597 public Reference getTypeReference() { 5598 if (this.typeReference == null) 5599 if (Configuration.errorOnAutoCreate()) 5600 throw new Error("Attempt to auto-create PlanDefinitionActionParticipantComponent.typeReference"); 5601 else if (Configuration.doAutoCreate()) 5602 this.typeReference = new Reference(); // cc 5603 return this.typeReference; 5604 } 5605 5606 public boolean hasTypeReference() { 5607 return this.typeReference != null && !this.typeReference.isEmpty(); 5608 } 5609 5610 /** 5611 * @param value {@link #typeReference} (The type of participant in the action.) 5612 */ 5613 public PlanDefinitionActionParticipantComponent setTypeReference(Reference value) { 5614 this.typeReference = value; 5615 return this; 5616 } 5617 5618 /** 5619 * @return {@link #role} (The role the participant should play in performing the described action.) 5620 */ 5621 public CodeableConcept getRole() { 5622 if (this.role == null) 5623 if (Configuration.errorOnAutoCreate()) 5624 throw new Error("Attempt to auto-create PlanDefinitionActionParticipantComponent.role"); 5625 else if (Configuration.doAutoCreate()) 5626 this.role = new CodeableConcept(); // cc 5627 return this.role; 5628 } 5629 5630 public boolean hasRole() { 5631 return this.role != null && !this.role.isEmpty(); 5632 } 5633 5634 /** 5635 * @param value {@link #role} (The role the participant should play in performing the described action.) 5636 */ 5637 public PlanDefinitionActionParticipantComponent setRole(CodeableConcept value) { 5638 this.role = value; 5639 return this; 5640 } 5641 5642 /** 5643 * @return {@link #function} (Indicates how the actor will be involved in the action - author, reviewer, witness, etc.) 5644 */ 5645 public CodeableConcept getFunction() { 5646 if (this.function == null) 5647 if (Configuration.errorOnAutoCreate()) 5648 throw new Error("Attempt to auto-create PlanDefinitionActionParticipantComponent.function"); 5649 else if (Configuration.doAutoCreate()) 5650 this.function = new CodeableConcept(); // cc 5651 return this.function; 5652 } 5653 5654 public boolean hasFunction() { 5655 return this.function != null && !this.function.isEmpty(); 5656 } 5657 5658 /** 5659 * @param value {@link #function} (Indicates how the actor will be involved in the action - author, reviewer, witness, etc.) 5660 */ 5661 public PlanDefinitionActionParticipantComponent setFunction(CodeableConcept value) { 5662 this.function = value; 5663 return this; 5664 } 5665 5666 protected void listChildren(List<Property> children) { 5667 super.listChildren(children); 5668 children.add(new Property("actorId", "string", "A reference to the id element of the actor who will participate in this action.", 0, 1, actorId)); 5669 children.add(new Property("type", "code", "The type of participant in the action.", 0, 1, type)); 5670 children.add(new Property("typeCanonical", "canonical(CapabilityStatement)", "The type of participant in the action.", 0, 1, typeCanonical)); 5671 children.add(new Property("typeReference", "Reference(CareTeam|Device|DeviceDefinition|Endpoint|Group|HealthcareService|Location|Organization|Patient|Practitioner|PractitionerRole|RelatedPerson)", "The type of participant in the action.", 0, 1, typeReference)); 5672 children.add(new Property("role", "CodeableConcept", "The role the participant should play in performing the described action.", 0, 1, role)); 5673 children.add(new Property("function", "CodeableConcept", "Indicates how the actor will be involved in the action - author, reviewer, witness, etc.", 0, 1, function)); 5674 } 5675 5676 @Override 5677 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 5678 switch (_hash) { 5679 case -1161623056: /*actorId*/ return new Property("actorId", "string", "A reference to the id element of the actor who will participate in this action.", 0, 1, actorId); 5680 case 3575610: /*type*/ return new Property("type", "code", "The type of participant in the action.", 0, 1, type); 5681 case -466635046: /*typeCanonical*/ return new Property("typeCanonical", "canonical(CapabilityStatement)", "The type of participant in the action.", 0, 1, typeCanonical); 5682 case 2074825009: /*typeReference*/ return new Property("typeReference", "Reference(CareTeam|Device|DeviceDefinition|Endpoint|Group|HealthcareService|Location|Organization|Patient|Practitioner|PractitionerRole|RelatedPerson)", "The type of participant in the action.", 0, 1, typeReference); 5683 case 3506294: /*role*/ return new Property("role", "CodeableConcept", "The role the participant should play in performing the described action.", 0, 1, role); 5684 case 1380938712: /*function*/ return new Property("function", "CodeableConcept", "Indicates how the actor will be involved in the action - author, reviewer, witness, etc.", 0, 1, function); 5685 default: return super.getNamedProperty(_hash, _name, _checkValid); 5686 } 5687 5688 } 5689 5690 @Override 5691 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 5692 switch (hash) { 5693 case -1161623056: /*actorId*/ return this.actorId == null ? new Base[0] : new Base[] {this.actorId}; // StringType 5694 case 3575610: /*type*/ return this.type == null ? new Base[0] : new Base[] {this.type}; // Enumeration<ActionParticipantType> 5695 case -466635046: /*typeCanonical*/ return this.typeCanonical == null ? new Base[0] : new Base[] {this.typeCanonical}; // CanonicalType 5696 case 2074825009: /*typeReference*/ return this.typeReference == null ? new Base[0] : new Base[] {this.typeReference}; // Reference 5697 case 3506294: /*role*/ return this.role == null ? new Base[0] : new Base[] {this.role}; // CodeableConcept 5698 case 1380938712: /*function*/ return this.function == null ? new Base[0] : new Base[] {this.function}; // CodeableConcept 5699 default: return super.getProperty(hash, name, checkValid); 5700 } 5701 5702 } 5703 5704 @Override 5705 public Base setProperty(int hash, String name, Base value) throws FHIRException { 5706 switch (hash) { 5707 case -1161623056: // actorId 5708 this.actorId = TypeConvertor.castToString(value); // StringType 5709 return value; 5710 case 3575610: // type 5711 value = new ActionParticipantTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 5712 this.type = (Enumeration) value; // Enumeration<ActionParticipantType> 5713 return value; 5714 case -466635046: // typeCanonical 5715 this.typeCanonical = TypeConvertor.castToCanonical(value); // CanonicalType 5716 return value; 5717 case 2074825009: // typeReference 5718 this.typeReference = TypeConvertor.castToReference(value); // Reference 5719 return value; 5720 case 3506294: // role 5721 this.role = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 5722 return value; 5723 case 1380938712: // function 5724 this.function = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 5725 return value; 5726 default: return super.setProperty(hash, name, value); 5727 } 5728 5729 } 5730 5731 @Override 5732 public Base setProperty(String name, Base value) throws FHIRException { 5733 if (name.equals("actorId")) { 5734 this.actorId = TypeConvertor.castToString(value); // StringType 5735 } else if (name.equals("type")) { 5736 value = new ActionParticipantTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 5737 this.type = (Enumeration) value; // Enumeration<ActionParticipantType> 5738 } else if (name.equals("typeCanonical")) { 5739 this.typeCanonical = TypeConvertor.castToCanonical(value); // CanonicalType 5740 } else if (name.equals("typeReference")) { 5741 this.typeReference = TypeConvertor.castToReference(value); // Reference 5742 } else if (name.equals("role")) { 5743 this.role = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 5744 } else if (name.equals("function")) { 5745 this.function = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 5746 } else 5747 return super.setProperty(name, value); 5748 return value; 5749 } 5750 5751 @Override 5752 public void removeChild(String name, Base value) throws FHIRException { 5753 if (name.equals("actorId")) { 5754 this.actorId = null; 5755 } else if (name.equals("type")) { 5756 value = new ActionParticipantTypeEnumFactory().fromType(TypeConvertor.castToCode(value)); 5757 this.type = (Enumeration) value; // Enumeration<ActionParticipantType> 5758 } else if (name.equals("typeCanonical")) { 5759 this.typeCanonical = null; 5760 } else if (name.equals("typeReference")) { 5761 this.typeReference = null; 5762 } else if (name.equals("role")) { 5763 this.role = null; 5764 } else if (name.equals("function")) { 5765 this.function = null; 5766 } else 5767 super.removeChild(name, value); 5768 5769 } 5770 5771 @Override 5772 public Base makeProperty(int hash, String name) throws FHIRException { 5773 switch (hash) { 5774 case -1161623056: return getActorIdElement(); 5775 case 3575610: return getTypeElement(); 5776 case -466635046: return getTypeCanonicalElement(); 5777 case 2074825009: return getTypeReference(); 5778 case 3506294: return getRole(); 5779 case 1380938712: return getFunction(); 5780 default: return super.makeProperty(hash, name); 5781 } 5782 5783 } 5784 5785 @Override 5786 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 5787 switch (hash) { 5788 case -1161623056: /*actorId*/ return new String[] {"string"}; 5789 case 3575610: /*type*/ return new String[] {"code"}; 5790 case -466635046: /*typeCanonical*/ return new String[] {"canonical"}; 5791 case 2074825009: /*typeReference*/ return new String[] {"Reference"}; 5792 case 3506294: /*role*/ return new String[] {"CodeableConcept"}; 5793 case 1380938712: /*function*/ return new String[] {"CodeableConcept"}; 5794 default: return super.getTypesForProperty(hash, name); 5795 } 5796 5797 } 5798 5799 @Override 5800 public Base addChild(String name) throws FHIRException { 5801 if (name.equals("actorId")) { 5802 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.participant.actorId"); 5803 } 5804 else if (name.equals("type")) { 5805 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.participant.type"); 5806 } 5807 else if (name.equals("typeCanonical")) { 5808 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.participant.typeCanonical"); 5809 } 5810 else if (name.equals("typeReference")) { 5811 this.typeReference = new Reference(); 5812 return this.typeReference; 5813 } 5814 else if (name.equals("role")) { 5815 this.role = new CodeableConcept(); 5816 return this.role; 5817 } 5818 else if (name.equals("function")) { 5819 this.function = new CodeableConcept(); 5820 return this.function; 5821 } 5822 else 5823 return super.addChild(name); 5824 } 5825 5826 public PlanDefinitionActionParticipantComponent copy() { 5827 PlanDefinitionActionParticipantComponent dst = new PlanDefinitionActionParticipantComponent(); 5828 copyValues(dst); 5829 return dst; 5830 } 5831 5832 public void copyValues(PlanDefinitionActionParticipantComponent dst) { 5833 super.copyValues(dst); 5834 dst.actorId = actorId == null ? null : actorId.copy(); 5835 dst.type = type == null ? null : type.copy(); 5836 dst.typeCanonical = typeCanonical == null ? null : typeCanonical.copy(); 5837 dst.typeReference = typeReference == null ? null : typeReference.copy(); 5838 dst.role = role == null ? null : role.copy(); 5839 dst.function = function == null ? null : function.copy(); 5840 } 5841 5842 @Override 5843 public boolean equalsDeep(Base other_) { 5844 if (!super.equalsDeep(other_)) 5845 return false; 5846 if (!(other_ instanceof PlanDefinitionActionParticipantComponent)) 5847 return false; 5848 PlanDefinitionActionParticipantComponent o = (PlanDefinitionActionParticipantComponent) other_; 5849 return compareDeep(actorId, o.actorId, true) && compareDeep(type, o.type, true) && compareDeep(typeCanonical, o.typeCanonical, true) 5850 && compareDeep(typeReference, o.typeReference, true) && compareDeep(role, o.role, true) && compareDeep(function, o.function, true) 5851 ; 5852 } 5853 5854 @Override 5855 public boolean equalsShallow(Base other_) { 5856 if (!super.equalsShallow(other_)) 5857 return false; 5858 if (!(other_ instanceof PlanDefinitionActionParticipantComponent)) 5859 return false; 5860 PlanDefinitionActionParticipantComponent o = (PlanDefinitionActionParticipantComponent) other_; 5861 return compareValues(actorId, o.actorId, true) && compareValues(type, o.type, true) && compareValues(typeCanonical, o.typeCanonical, true) 5862 ; 5863 } 5864 5865 public boolean isEmpty() { 5866 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(actorId, type, typeCanonical 5867 , typeReference, role, function); 5868 } 5869 5870 public String fhirType() { 5871 return "PlanDefinition.action.participant"; 5872 5873 } 5874 5875 } 5876 5877 @Block() 5878 public static class PlanDefinitionActionDynamicValueComponent extends BackboneElement implements IBaseBackboneElement { 5879 /** 5880 * The path to the element to be customized. This is the path on the resource that will hold the result of the calculation defined by the expression. The specified path SHALL be a FHIRPath resolvable on the specified target type of the ActivityDefinition, and SHALL consist only of identifiers, constant indexers, and a restricted subset of functions. The path is allowed to contain qualifiers (.) to traverse sub-elements, as well as indexers ([x]) to traverse multiple-cardinality sub-elements (see the [Simple FHIRPath Profile](fhirpath.html#simple) for full details). 5881 */ 5882 @Child(name = "path", type = {StringType.class}, order=1, min=0, max=1, modifier=false, summary=false) 5883 @Description(shortDefinition="The path to the element to be set dynamically", formalDefinition="The path to the element to be customized. This is the path on the resource that will hold the result of the calculation defined by the expression. The specified path SHALL be a FHIRPath resolvable on the specified target type of the ActivityDefinition, and SHALL consist only of identifiers, constant indexers, and a restricted subset of functions. The path is allowed to contain qualifiers (.) to traverse sub-elements, as well as indexers ([x]) to traverse multiple-cardinality sub-elements (see the [Simple FHIRPath Profile](fhirpath.html#simple) for full details)." ) 5884 protected StringType path; 5885 5886 /** 5887 * An expression specifying the value of the customized element. 5888 */ 5889 @Child(name = "expression", type = {Expression.class}, order=2, min=0, max=1, modifier=false, summary=false) 5890 @Description(shortDefinition="An expression that provides the dynamic value for the customization", formalDefinition="An expression specifying the value of the customized element." ) 5891 protected Expression expression; 5892 5893 private static final long serialVersionUID = 1064529082L; 5894 5895 /** 5896 * Constructor 5897 */ 5898 public PlanDefinitionActionDynamicValueComponent() { 5899 super(); 5900 } 5901 5902 /** 5903 * @return {@link #path} (The path to the element to be customized. This is the path on the resource that will hold the result of the calculation defined by the expression. The specified path SHALL be a FHIRPath resolvable on the specified target type of the ActivityDefinition, and SHALL consist only of identifiers, constant indexers, and a restricted subset of functions. The path is allowed to contain qualifiers (.) to traverse sub-elements, as well as indexers ([x]) to traverse multiple-cardinality sub-elements (see the [Simple FHIRPath Profile](fhirpath.html#simple) for full details).). This is the underlying object with id, value and extensions. The accessor "getPath" gives direct access to the value 5904 */ 5905 public StringType getPathElement() { 5906 if (this.path == null) 5907 if (Configuration.errorOnAutoCreate()) 5908 throw new Error("Attempt to auto-create PlanDefinitionActionDynamicValueComponent.path"); 5909 else if (Configuration.doAutoCreate()) 5910 this.path = new StringType(); // bb 5911 return this.path; 5912 } 5913 5914 public boolean hasPathElement() { 5915 return this.path != null && !this.path.isEmpty(); 5916 } 5917 5918 public boolean hasPath() { 5919 return this.path != null && !this.path.isEmpty(); 5920 } 5921 5922 /** 5923 * @param value {@link #path} (The path to the element to be customized. This is the path on the resource that will hold the result of the calculation defined by the expression. The specified path SHALL be a FHIRPath resolvable on the specified target type of the ActivityDefinition, and SHALL consist only of identifiers, constant indexers, and a restricted subset of functions. The path is allowed to contain qualifiers (.) to traverse sub-elements, as well as indexers ([x]) to traverse multiple-cardinality sub-elements (see the [Simple FHIRPath Profile](fhirpath.html#simple) for full details).). This is the underlying object with id, value and extensions. The accessor "getPath" gives direct access to the value 5924 */ 5925 public PlanDefinitionActionDynamicValueComponent setPathElement(StringType value) { 5926 this.path = value; 5927 return this; 5928 } 5929 5930 /** 5931 * @return The path to the element to be customized. This is the path on the resource that will hold the result of the calculation defined by the expression. The specified path SHALL be a FHIRPath resolvable on the specified target type of the ActivityDefinition, and SHALL consist only of identifiers, constant indexers, and a restricted subset of functions. The path is allowed to contain qualifiers (.) to traverse sub-elements, as well as indexers ([x]) to traverse multiple-cardinality sub-elements (see the [Simple FHIRPath Profile](fhirpath.html#simple) for full details). 5932 */ 5933 public String getPath() { 5934 return this.path == null ? null : this.path.getValue(); 5935 } 5936 5937 /** 5938 * @param value The path to the element to be customized. This is the path on the resource that will hold the result of the calculation defined by the expression. The specified path SHALL be a FHIRPath resolvable on the specified target type of the ActivityDefinition, and SHALL consist only of identifiers, constant indexers, and a restricted subset of functions. The path is allowed to contain qualifiers (.) to traverse sub-elements, as well as indexers ([x]) to traverse multiple-cardinality sub-elements (see the [Simple FHIRPath Profile](fhirpath.html#simple) for full details). 5939 */ 5940 public PlanDefinitionActionDynamicValueComponent setPath(String value) { 5941 if (Utilities.noString(value)) 5942 this.path = null; 5943 else { 5944 if (this.path == null) 5945 this.path = new StringType(); 5946 this.path.setValue(value); 5947 } 5948 return this; 5949 } 5950 5951 /** 5952 * @return {@link #expression} (An expression specifying the value of the customized element.) 5953 */ 5954 public Expression getExpression() { 5955 if (this.expression == null) 5956 if (Configuration.errorOnAutoCreate()) 5957 throw new Error("Attempt to auto-create PlanDefinitionActionDynamicValueComponent.expression"); 5958 else if (Configuration.doAutoCreate()) 5959 this.expression = new Expression(); // cc 5960 return this.expression; 5961 } 5962 5963 public boolean hasExpression() { 5964 return this.expression != null && !this.expression.isEmpty(); 5965 } 5966 5967 /** 5968 * @param value {@link #expression} (An expression specifying the value of the customized element.) 5969 */ 5970 public PlanDefinitionActionDynamicValueComponent setExpression(Expression value) { 5971 this.expression = value; 5972 return this; 5973 } 5974 5975 protected void listChildren(List<Property> children) { 5976 super.listChildren(children); 5977 children.add(new Property("path", "string", "The path to the element to be customized. This is the path on the resource that will hold the result of the calculation defined by the expression. The specified path SHALL be a FHIRPath resolvable on the specified target type of the ActivityDefinition, and SHALL consist only of identifiers, constant indexers, and a restricted subset of functions. The path is allowed to contain qualifiers (.) to traverse sub-elements, as well as indexers ([x]) to traverse multiple-cardinality sub-elements (see the [Simple FHIRPath Profile](fhirpath.html#simple) for full details).", 0, 1, path)); 5978 children.add(new Property("expression", "Expression", "An expression specifying the value of the customized element.", 0, 1, expression)); 5979 } 5980 5981 @Override 5982 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 5983 switch (_hash) { 5984 case 3433509: /*path*/ return new Property("path", "string", "The path to the element to be customized. This is the path on the resource that will hold the result of the calculation defined by the expression. The specified path SHALL be a FHIRPath resolvable on the specified target type of the ActivityDefinition, and SHALL consist only of identifiers, constant indexers, and a restricted subset of functions. The path is allowed to contain qualifiers (.) to traverse sub-elements, as well as indexers ([x]) to traverse multiple-cardinality sub-elements (see the [Simple FHIRPath Profile](fhirpath.html#simple) for full details).", 0, 1, path); 5985 case -1795452264: /*expression*/ return new Property("expression", "Expression", "An expression specifying the value of the customized element.", 0, 1, expression); 5986 default: return super.getNamedProperty(_hash, _name, _checkValid); 5987 } 5988 5989 } 5990 5991 @Override 5992 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 5993 switch (hash) { 5994 case 3433509: /*path*/ return this.path == null ? new Base[0] : new Base[] {this.path}; // StringType 5995 case -1795452264: /*expression*/ return this.expression == null ? new Base[0] : new Base[] {this.expression}; // Expression 5996 default: return super.getProperty(hash, name, checkValid); 5997 } 5998 5999 } 6000 6001 @Override 6002 public Base setProperty(int hash, String name, Base value) throws FHIRException { 6003 switch (hash) { 6004 case 3433509: // path 6005 this.path = TypeConvertor.castToString(value); // StringType 6006 return value; 6007 case -1795452264: // expression 6008 this.expression = TypeConvertor.castToExpression(value); // Expression 6009 return value; 6010 default: 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("path")) { 6018 this.path = TypeConvertor.castToString(value); // StringType 6019 } else if (name.equals("expression")) { 6020 this.expression = TypeConvertor.castToExpression(value); // Expression 6021 } else 6022 return super.setProperty(name, value); 6023 return value; 6024 } 6025 6026 @Override 6027 public void removeChild(String name, Base value) throws FHIRException { 6028 if (name.equals("path")) { 6029 this.path = null; 6030 } else if (name.equals("expression")) { 6031 this.expression = null; 6032 } else 6033 super.removeChild(name, value); 6034 6035 } 6036 6037 @Override 6038 public Base makeProperty(int hash, String name) throws FHIRException { 6039 switch (hash) { 6040 case 3433509: return getPathElement(); 6041 case -1795452264: return getExpression(); 6042 default: return super.makeProperty(hash, name); 6043 } 6044 6045 } 6046 6047 @Override 6048 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 6049 switch (hash) { 6050 case 3433509: /*path*/ return new String[] {"string"}; 6051 case -1795452264: /*expression*/ return new String[] {"Expression"}; 6052 default: return super.getTypesForProperty(hash, name); 6053 } 6054 6055 } 6056 6057 @Override 6058 public Base addChild(String name) throws FHIRException { 6059 if (name.equals("path")) { 6060 throw new FHIRException("Cannot call addChild on a singleton property PlanDefinition.action.dynamicValue.path"); 6061 } 6062 else if (name.equals("expression")) { 6063 this.expression = new Expression(); 6064 return this.expression; 6065 } 6066 else 6067 return super.addChild(name); 6068 } 6069 6070 public PlanDefinitionActionDynamicValueComponent copy() { 6071 PlanDefinitionActionDynamicValueComponent dst = new PlanDefinitionActionDynamicValueComponent(); 6072 copyValues(dst); 6073 return dst; 6074 } 6075 6076 public void copyValues(PlanDefinitionActionDynamicValueComponent dst) { 6077 super.copyValues(dst); 6078 dst.path = path == null ? null : path.copy(); 6079 dst.expression = expression == null ? null : expression.copy(); 6080 } 6081 6082 @Override 6083 public boolean equalsDeep(Base other_) { 6084 if (!super.equalsDeep(other_)) 6085 return false; 6086 if (!(other_ instanceof PlanDefinitionActionDynamicValueComponent)) 6087 return false; 6088 PlanDefinitionActionDynamicValueComponent o = (PlanDefinitionActionDynamicValueComponent) other_; 6089 return compareDeep(path, o.path, true) && compareDeep(expression, o.expression, true); 6090 } 6091 6092 @Override 6093 public boolean equalsShallow(Base other_) { 6094 if (!super.equalsShallow(other_)) 6095 return false; 6096 if (!(other_ instanceof PlanDefinitionActionDynamicValueComponent)) 6097 return false; 6098 PlanDefinitionActionDynamicValueComponent o = (PlanDefinitionActionDynamicValueComponent) other_; 6099 return compareValues(path, o.path, true); 6100 } 6101 6102 public boolean isEmpty() { 6103 return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(path, expression); 6104 } 6105 6106 public String fhirType() { 6107 return "PlanDefinition.action.dynamicValue"; 6108 6109 } 6110 6111 } 6112 6113 /** 6114 * An absolute URI that is used to identify this plan definition when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which an authoritative instance of this plan definition is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the plan definition is stored on different servers. 6115 */ 6116 @Child(name = "url", type = {UriType.class}, order=0, min=0, max=1, modifier=false, summary=true) 6117 @Description(shortDefinition="Canonical identifier for this plan definition, represented as a URI (globally unique)", formalDefinition="An absolute URI that is used to identify this plan definition when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which an authoritative instance of this plan definition is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the plan definition is stored on different servers." ) 6118 protected UriType url; 6119 6120 /** 6121 * A formal identifier that is used to identify this plan definition when it is represented in other formats, or referenced in a specification, model, design or an instance. 6122 */ 6123 @Child(name = "identifier", type = {Identifier.class}, order=1, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=true) 6124 @Description(shortDefinition="Additional identifier for the plan definition", formalDefinition="A formal identifier that is used to identify this plan definition when it is represented in other formats, or referenced in a specification, model, design or an instance." ) 6125 protected List<Identifier> identifier; 6126 6127 /** 6128 * The identifier that is used to identify this version of the plan definition when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the plan definition author and is not expected to be globally unique. For example, it might be a timestamp (e.g. yyyymmdd) if a managed version is not available. There is also no expectation that versions can be placed in a lexicographical sequence. To provide a version consistent with the Decision Support Service specification, use the format Major.Minor.Revision (e.g. 1.0.0). For more information on versioning knowledge assets, refer to the Decision Support Service specification. Note that a version is required for non-experimental active artifacts. 6129 */ 6130 @Child(name = "version", type = {StringType.class}, order=2, min=0, max=1, modifier=false, summary=true) 6131 @Description(shortDefinition="Business version of the plan definition", formalDefinition="The identifier that is used to identify this version of the plan definition when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the plan definition author and is not expected to be globally unique. For example, it might be a timestamp (e.g. yyyymmdd) if a managed version is not available. There is also no expectation that versions can be placed in a lexicographical sequence. To provide a version consistent with the Decision Support Service specification, use the format Major.Minor.Revision (e.g. 1.0.0). For more information on versioning knowledge assets, refer to the Decision Support Service specification. Note that a version is required for non-experimental active artifacts." ) 6132 protected StringType version; 6133 6134 /** 6135 * Indicates the mechanism used to compare versions to determine which is more current. 6136 */ 6137 @Child(name = "versionAlgorithm", type = {StringType.class, Coding.class}, order=3, min=0, max=1, modifier=false, summary=true) 6138 @Description(shortDefinition="How to compare versions", formalDefinition="Indicates the mechanism used to compare versions to determine which is more current." ) 6139 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/version-algorithm") 6140 protected DataType versionAlgorithm; 6141 6142 /** 6143 * A natural language name identifying the plan definition. This name should be usable as an identifier for the module by machine processing applications such as code generation. 6144 */ 6145 @Child(name = "name", type = {StringType.class}, order=4, min=0, max=1, modifier=false, summary=true) 6146 @Description(shortDefinition="Name for this plan definition (computer friendly)", formalDefinition="A natural language name identifying the plan definition. This name should be usable as an identifier for the module by machine processing applications such as code generation." ) 6147 protected StringType name; 6148 6149 /** 6150 * A short, descriptive, user-friendly title for the plan definition. 6151 */ 6152 @Child(name = "title", type = {StringType.class}, order=5, min=0, max=1, modifier=false, summary=true) 6153 @Description(shortDefinition="Name for this plan definition (human friendly)", formalDefinition="A short, descriptive, user-friendly title for the plan definition." ) 6154 protected StringType title; 6155 6156 /** 6157 * An explanatory or alternate title for the plan definition giving additional information about its content. 6158 */ 6159 @Child(name = "subtitle", type = {StringType.class}, order=6, min=0, max=1, modifier=false, summary=false) 6160 @Description(shortDefinition="Subordinate title of the plan definition", formalDefinition="An explanatory or alternate title for the plan definition giving additional information about its content." ) 6161 protected StringType subtitle; 6162 6163 /** 6164 * A high-level category for the plan definition that distinguishes the kinds of systems that would be interested in the plan definition. 6165 */ 6166 @Child(name = "type", type = {CodeableConcept.class}, order=7, min=0, max=1, modifier=false, summary=true) 6167 @Description(shortDefinition="order-set | clinical-protocol | eca-rule | workflow-definition", formalDefinition="A high-level category for the plan definition that distinguishes the kinds of systems that would be interested in the plan definition." ) 6168 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/plan-definition-type") 6169 protected CodeableConcept type; 6170 6171 /** 6172 * The status of this plan definition. Enables tracking the life-cycle of the content. 6173 */ 6174 @Child(name = "status", type = {CodeType.class}, order=8, min=1, max=1, modifier=true, summary=true) 6175 @Description(shortDefinition="draft | active | retired | unknown", formalDefinition="The status of this plan definition. Enables tracking the life-cycle of the content." ) 6176 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/publication-status") 6177 protected Enumeration<PublicationStatus> status; 6178 6179 /** 6180 * A Boolean value to indicate that this plan definition is authored for testing purposes (or education/evaluation/marketing) and is not intended to be used for genuine usage. 6181 */ 6182 @Child(name = "experimental", type = {BooleanType.class}, order=9, min=0, max=1, modifier=false, summary=true) 6183 @Description(shortDefinition="For testing purposes, not real usage", formalDefinition="A Boolean value to indicate that this plan definition is authored for testing purposes (or education/evaluation/marketing) and is not intended to be used for genuine usage." ) 6184 protected BooleanType experimental; 6185 6186 /** 6187 * A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource. 6188 */ 6189 @Child(name = "subject", type = {CodeableConcept.class, Group.class, MedicinalProductDefinition.class, SubstanceDefinition.class, AdministrableProductDefinition.class, ManufacturedItemDefinition.class, PackagedProductDefinition.class, CanonicalType.class}, order=10, min=0, max=1, modifier=false, summary=false) 6190 @Description(shortDefinition="Type of individual the plan definition is focused on", formalDefinition="A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource." ) 6191 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/participant-resource-types") 6192 protected DataType subject; 6193 6194 /** 6195 * The date (and optionally time) when the plan definition was last significantly changed. 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 plan definition changes. 6196 */ 6197 @Child(name = "date", type = {DateTimeType.class}, order=11, min=0, max=1, modifier=false, summary=true) 6198 @Description(shortDefinition="Date last changed", formalDefinition="The date (and optionally time) when the plan definition was last significantly changed. 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 plan definition changes." ) 6199 protected DateTimeType date; 6200 6201 /** 6202 * The name of the organization or individual responsible for the release and ongoing maintenance of the plan definition. 6203 */ 6204 @Child(name = "publisher", type = {StringType.class}, order=12, min=0, max=1, modifier=false, summary=true) 6205 @Description(shortDefinition="Name of the publisher/steward (organization or individual)", formalDefinition="The name of the organization or individual responsible for the release and ongoing maintenance of the plan definition." ) 6206 protected StringType publisher; 6207 6208 /** 6209 * Contact details to assist a user in finding and communicating with the publisher. 6210 */ 6211 @Child(name = "contact", type = {ContactDetail.class}, order=13, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=true) 6212 @Description(shortDefinition="Contact details for the publisher", formalDefinition="Contact details to assist a user in finding and communicating with the publisher." ) 6213 protected List<ContactDetail> contact; 6214 6215 /** 6216 * A free text natural language description of the plan definition from a consumer's perspective. 6217 */ 6218 @Child(name = "description", type = {MarkdownType.class}, order=14, min=0, max=1, modifier=false, summary=true) 6219 @Description(shortDefinition="Natural language description of the plan definition", formalDefinition="A free text natural language description of the plan definition from a consumer's perspective." ) 6220 protected MarkdownType description; 6221 6222 /** 6223 * The content was developed with a focus and intent of supporting the contexts that are listed. These contexts may be general categories (gender, age, ...) or may be references to specific programs (insurance plans, studies, ...) and may be used to assist with indexing and searching for appropriate plan definition instances. 6224 */ 6225 @Child(name = "useContext", type = {UsageContext.class}, order=15, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=true) 6226 @Description(shortDefinition="The context that the content is intended to support", formalDefinition="The content was developed with a focus and intent of supporting the contexts that are listed. These contexts may be general categories (gender, age, ...) or may be references to specific programs (insurance plans, studies, ...) and may be used to assist with indexing and searching for appropriate plan definition instances." ) 6227 protected List<UsageContext> useContext; 6228 6229 /** 6230 * A legal or geographic region in which the plan definition is intended to be used. 6231 */ 6232 @Child(name = "jurisdiction", type = {CodeableConcept.class}, order=16, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=true) 6233 @Description(shortDefinition="Intended jurisdiction for plan definition (if applicable)", formalDefinition="A legal or geographic region in which the plan definition is intended to be used." ) 6234 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/jurisdiction") 6235 protected List<CodeableConcept> jurisdiction; 6236 6237 /** 6238 * Explanation of why this plan definition is needed and why it has been designed as it has. 6239 */ 6240 @Child(name = "purpose", type = {MarkdownType.class}, order=17, min=0, max=1, modifier=false, summary=false) 6241 @Description(shortDefinition="Why this plan definition is defined", formalDefinition="Explanation of why this plan definition is needed and why it has been designed as it has." ) 6242 protected MarkdownType purpose; 6243 6244 /** 6245 * A detailed description of how the plan definition is used from a clinical perspective. 6246 */ 6247 @Child(name = "usage", type = {MarkdownType.class}, order=18, min=0, max=1, modifier=false, summary=false) 6248 @Description(shortDefinition="Describes the clinical usage of the plan", formalDefinition="A detailed description of how the plan definition is used from a clinical perspective." ) 6249 protected MarkdownType usage; 6250 6251 /** 6252 * A copyright statement relating to the plan definition and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the plan definition. 6253 */ 6254 @Child(name = "copyright", type = {MarkdownType.class}, order=19, min=0, max=1, modifier=false, summary=false) 6255 @Description(shortDefinition="Use and/or publishing restrictions", formalDefinition="A copyright statement relating to the plan definition and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the plan definition." ) 6256 protected MarkdownType copyright; 6257 6258 /** 6259 * A short string (<50 characters), suitable for inclusion in a page footer that identifies the copyright holder, effective period, and optionally whether rights are resctricted. (e.g. 'All rights reserved', 'Some rights reserved'). 6260 */ 6261 @Child(name = "copyrightLabel", type = {StringType.class}, order=20, min=0, max=1, modifier=false, summary=false) 6262 @Description(shortDefinition="Copyright holder and year(s)", formalDefinition="A short string (<50 characters), suitable for inclusion in a page footer that identifies the copyright holder, effective period, and optionally whether rights are resctricted. (e.g. 'All rights reserved', 'Some rights reserved')." ) 6263 protected StringType copyrightLabel; 6264 6265 /** 6266 * The date on which the resource content was approved by the publisher. Approval happens once when the content is officially approved for usage. 6267 */ 6268 @Child(name = "approvalDate", type = {DateType.class}, order=21, min=0, max=1, modifier=false, summary=false) 6269 @Description(shortDefinition="When the plan definition was approved by publisher", formalDefinition="The date on which the resource content was approved by the publisher. Approval happens once when the content is officially approved for usage." ) 6270 protected DateType approvalDate; 6271 6272 /** 6273 * The date on which the resource content was last reviewed. Review happens periodically after approval but does not change the original approval date. 6274 */ 6275 @Child(name = "lastReviewDate", type = {DateType.class}, order=22, min=0, max=1, modifier=false, summary=false) 6276 @Description(shortDefinition="When the plan definition was last reviewed by the publisher", formalDefinition="The date on which the resource content was last reviewed. Review happens periodically after approval but does not change the original approval date." ) 6277 protected DateType lastReviewDate; 6278 6279 /** 6280 * The period during which the plan definition content was or is planned to be in active use. 6281 */ 6282 @Child(name = "effectivePeriod", type = {Period.class}, order=23, min=0, max=1, modifier=false, summary=true) 6283 @Description(shortDefinition="When the plan definition is expected to be used", formalDefinition="The period during which the plan definition content was or is planned to be in active use." ) 6284 protected Period effectivePeriod; 6285 6286 /** 6287 * Descriptive topics related to the content of the plan definition. Topics provide a high-level categorization of the definition that can be useful for filtering and searching. 6288 */ 6289 @Child(name = "topic", type = {CodeableConcept.class}, order=24, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 6290 @Description(shortDefinition="E.g. Education, Treatment, Assessment", formalDefinition="Descriptive topics related to the content of the plan definition. Topics provide a high-level categorization of the definition that can be useful for filtering and searching." ) 6291 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/definition-topic") 6292 protected List<CodeableConcept> topic; 6293 6294 /** 6295 * An individiual or organization primarily involved in the creation and maintenance of the content. 6296 */ 6297 @Child(name = "author", type = {ContactDetail.class}, order=25, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 6298 @Description(shortDefinition="Who authored the content", formalDefinition="An individiual or organization primarily involved in the creation and maintenance of the content." ) 6299 protected List<ContactDetail> author; 6300 6301 /** 6302 * An individual or organization primarily responsible for internal coherence of the content. 6303 */ 6304 @Child(name = "editor", type = {ContactDetail.class}, order=26, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 6305 @Description(shortDefinition="Who edited the content", formalDefinition="An individual or organization primarily responsible for internal coherence of the content." ) 6306 protected List<ContactDetail> editor; 6307 6308 /** 6309 * An individual or organization asserted by the publisher to be primarily responsible for review of some aspect of the content. 6310 */ 6311 @Child(name = "reviewer", type = {ContactDetail.class}, order=27, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 6312 @Description(shortDefinition="Who reviewed the content", formalDefinition="An individual or organization asserted by the publisher to be primarily responsible for review of some aspect of the content." ) 6313 protected List<ContactDetail> reviewer; 6314 6315 /** 6316 * An individual or organization asserted by the publisher to be responsible for officially endorsing the content for use in some setting. 6317 */ 6318 @Child(name = "endorser", type = {ContactDetail.class}, order=28, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 6319 @Description(shortDefinition="Who endorsed the content", formalDefinition="An individual or organization asserted by the publisher to be responsible for officially endorsing the content for use in some setting." ) 6320 protected List<ContactDetail> endorser; 6321 6322 /** 6323 * Related artifacts such as additional documentation, justification, or bibliographic references. 6324 */ 6325 @Child(name = "relatedArtifact", type = {RelatedArtifact.class}, order=29, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 6326 @Description(shortDefinition="Additional documentation, citations", formalDefinition="Related artifacts such as additional documentation, justification, or bibliographic references." ) 6327 protected List<RelatedArtifact> relatedArtifact; 6328 6329 /** 6330 * A reference to a Library resource containing any formal logic used by the plan definition. 6331 */ 6332 @Child(name = "library", type = {CanonicalType.class}, order=30, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 6333 @Description(shortDefinition="Logic used by the plan definition", formalDefinition="A reference to a Library resource containing any formal logic used by the plan definition." ) 6334 protected List<CanonicalType> library; 6335 6336 /** 6337 * A goal describes an expected outcome that activities within the plan are intended to achieve. For example, weight loss, restoring an activity of daily living, obtaining herd immunity via immunization, meeting a process improvement objective, meeting the acceptance criteria for a test as specified by a quality specification, etc. 6338 */ 6339 @Child(name = "goal", type = {}, order=31, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 6340 @Description(shortDefinition="What the plan is trying to accomplish", formalDefinition="A goal describes an expected outcome that activities within the plan are intended to achieve. For example, weight loss, restoring an activity of daily living, obtaining herd immunity via immunization, meeting a process improvement objective, meeting the acceptance criteria for a test as specified by a quality specification, etc." ) 6341 protected List<PlanDefinitionGoalComponent> goal; 6342 6343 /** 6344 * Actors represent the individuals or groups involved in the execution of the defined set of activities. 6345 */ 6346 @Child(name = "actor", type = {}, order=32, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 6347 @Description(shortDefinition="Actors within the plan", formalDefinition="Actors represent the individuals or groups involved in the execution of the defined set of activities." ) 6348 protected List<PlanDefinitionActorComponent> actor; 6349 6350 /** 6351 * An action or group of actions to be taken as part of the plan. For example, in clinical care, an action would be to prescribe a particular indicated medication, or perform a particular test as appropriate. In pharmaceutical quality, an action would be the test that needs to be performed on a drug product as defined in the quality specification. 6352 */ 6353 @Child(name = "action", type = {}, order=33, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) 6354 @Description(shortDefinition="Action defined by the plan", formalDefinition="An action or group of actions to be taken as part of the plan. For example, in clinical care, an action would be to prescribe a particular indicated medication, or perform a particular test as appropriate. In pharmaceutical quality, an action would be the test that needs to be performed on a drug product as defined in the quality specification." ) 6355 protected List<PlanDefinitionActionComponent> action; 6356 6357 /** 6358 * If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example "pain", "on flare-up", etc. 6359 */ 6360 @Child(name = "asNeeded", type = {BooleanType.class, CodeableConcept.class}, order=34, min=0, max=1, modifier=false, summary=true) 6361 @Description(shortDefinition="Preconditions for service", formalDefinition="If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example \"pain\", \"on flare-up\", etc." ) 6362 @ca.uhn.fhir.model.api.annotation.Binding(valueSet="http://hl7.org/fhir/ValueSet/medication-as-needed-reason") 6363 protected DataType asNeeded; 6364 6365 private static final long serialVersionUID = 324754414L; 6366 6367 /** 6368 * Constructor 6369 */ 6370 public PlanDefinition() { 6371 super(); 6372 } 6373 6374 /** 6375 * Constructor 6376 */ 6377 public PlanDefinition(PublicationStatus status) { 6378 super(); 6379 this.setStatus(status); 6380 } 6381 6382 /** 6383 * @return {@link #url} (An absolute URI that is used to identify this plan definition when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which an authoritative instance of this plan definition is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the plan definition is stored on different servers.). This is the underlying object with id, value and extensions. The accessor "getUrl" gives direct access to the value 6384 */ 6385 public UriType getUrlElement() { 6386 if (this.url == null) 6387 if (Configuration.errorOnAutoCreate()) 6388 throw new Error("Attempt to auto-create PlanDefinition.url"); 6389 else if (Configuration.doAutoCreate()) 6390 this.url = new UriType(); // bb 6391 return this.url; 6392 } 6393 6394 public boolean hasUrlElement() { 6395 return this.url != null && !this.url.isEmpty(); 6396 } 6397 6398 public boolean hasUrl() { 6399 return this.url != null && !this.url.isEmpty(); 6400 } 6401 6402 /** 6403 * @param value {@link #url} (An absolute URI that is used to identify this plan definition when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which an authoritative instance of this plan definition is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the plan definition is stored on different servers.). This is the underlying object with id, value and extensions. The accessor "getUrl" gives direct access to the value 6404 */ 6405 public PlanDefinition setUrlElement(UriType value) { 6406 this.url = value; 6407 return this; 6408 } 6409 6410 /** 6411 * @return An absolute URI that is used to identify this plan definition when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which an authoritative instance of this plan definition is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the plan definition is stored on different servers. 6412 */ 6413 public String getUrl() { 6414 return this.url == null ? null : this.url.getValue(); 6415 } 6416 6417 /** 6418 * @param value An absolute URI that is used to identify this plan definition when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which an authoritative instance of this plan definition is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the plan definition is stored on different servers. 6419 */ 6420 public PlanDefinition setUrl(String value) { 6421 if (Utilities.noString(value)) 6422 this.url = null; 6423 else { 6424 if (this.url == null) 6425 this.url = new UriType(); 6426 this.url.setValue(value); 6427 } 6428 return this; 6429 } 6430 6431 /** 6432 * @return {@link #identifier} (A formal identifier that is used to identify this plan definition when it is represented in other formats, or referenced in a specification, model, design or an instance.) 6433 */ 6434 public List<Identifier> getIdentifier() { 6435 if (this.identifier == null) 6436 this.identifier = new ArrayList<Identifier>(); 6437 return this.identifier; 6438 } 6439 6440 /** 6441 * @return Returns a reference to <code>this</code> for easy method chaining 6442 */ 6443 public PlanDefinition setIdentifier(List<Identifier> theIdentifier) { 6444 this.identifier = theIdentifier; 6445 return this; 6446 } 6447 6448 public boolean hasIdentifier() { 6449 if (this.identifier == null) 6450 return false; 6451 for (Identifier item : this.identifier) 6452 if (!item.isEmpty()) 6453 return true; 6454 return false; 6455 } 6456 6457 public Identifier addIdentifier() { //3 6458 Identifier t = new Identifier(); 6459 if (this.identifier == null) 6460 this.identifier = new ArrayList<Identifier>(); 6461 this.identifier.add(t); 6462 return t; 6463 } 6464 6465 public PlanDefinition addIdentifier(Identifier t) { //3 6466 if (t == null) 6467 return this; 6468 if (this.identifier == null) 6469 this.identifier = new ArrayList<Identifier>(); 6470 this.identifier.add(t); 6471 return this; 6472 } 6473 6474 /** 6475 * @return The first repetition of repeating field {@link #identifier}, creating it if it does not already exist {3} 6476 */ 6477 public Identifier getIdentifierFirstRep() { 6478 if (getIdentifier().isEmpty()) { 6479 addIdentifier(); 6480 } 6481 return getIdentifier().get(0); 6482 } 6483 6484 /** 6485 * @return {@link #version} (The identifier that is used to identify this version of the plan definition when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the plan definition author and is not expected to be globally unique. For example, it might be a timestamp (e.g. yyyymmdd) if a managed version is not available. There is also no expectation that versions can be placed in a lexicographical sequence. To provide a version consistent with the Decision Support Service specification, use the format Major.Minor.Revision (e.g. 1.0.0). For more information on versioning knowledge assets, refer to the Decision Support Service specification. Note that a version is required for non-experimental active artifacts.). This is the underlying object with id, value and extensions. The accessor "getVersion" gives direct access to the value 6486 */ 6487 public StringType getVersionElement() { 6488 if (this.version == null) 6489 if (Configuration.errorOnAutoCreate()) 6490 throw new Error("Attempt to auto-create PlanDefinition.version"); 6491 else if (Configuration.doAutoCreate()) 6492 this.version = new StringType(); // bb 6493 return this.version; 6494 } 6495 6496 public boolean hasVersionElement() { 6497 return this.version != null && !this.version.isEmpty(); 6498 } 6499 6500 public boolean hasVersion() { 6501 return this.version != null && !this.version.isEmpty(); 6502 } 6503 6504 /** 6505 * @param value {@link #version} (The identifier that is used to identify this version of the plan definition when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the plan definition author and is not expected to be globally unique. For example, it might be a timestamp (e.g. yyyymmdd) if a managed version is not available. There is also no expectation that versions can be placed in a lexicographical sequence. To provide a version consistent with the Decision Support Service specification, use the format Major.Minor.Revision (e.g. 1.0.0). For more information on versioning knowledge assets, refer to the Decision Support Service specification. Note that a version is required for non-experimental active artifacts.). This is the underlying object with id, value and extensions. The accessor "getVersion" gives direct access to the value 6506 */ 6507 public PlanDefinition setVersionElement(StringType value) { 6508 this.version = value; 6509 return this; 6510 } 6511 6512 /** 6513 * @return The identifier that is used to identify this version of the plan definition when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the plan definition author and is not expected to be globally unique. For example, it might be a timestamp (e.g. yyyymmdd) if a managed version is not available. There is also no expectation that versions can be placed in a lexicographical sequence. To provide a version consistent with the Decision Support Service specification, use the format Major.Minor.Revision (e.g. 1.0.0). For more information on versioning knowledge assets, refer to the Decision Support Service specification. Note that a version is required for non-experimental active artifacts. 6514 */ 6515 public String getVersion() { 6516 return this.version == null ? null : this.version.getValue(); 6517 } 6518 6519 /** 6520 * @param value The identifier that is used to identify this version of the plan definition when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the plan definition author and is not expected to be globally unique. For example, it might be a timestamp (e.g. yyyymmdd) if a managed version is not available. There is also no expectation that versions can be placed in a lexicographical sequence. To provide a version consistent with the Decision Support Service specification, use the format Major.Minor.Revision (e.g. 1.0.0). For more information on versioning knowledge assets, refer to the Decision Support Service specification. Note that a version is required for non-experimental active artifacts. 6521 */ 6522 public PlanDefinition setVersion(String value) { 6523 if (Utilities.noString(value)) 6524 this.version = null; 6525 else { 6526 if (this.version == null) 6527 this.version = new StringType(); 6528 this.version.setValue(value); 6529 } 6530 return this; 6531 } 6532 6533 /** 6534 * @return {@link #versionAlgorithm} (Indicates the mechanism used to compare versions to determine which is more current.) 6535 */ 6536 public DataType getVersionAlgorithm() { 6537 return this.versionAlgorithm; 6538 } 6539 6540 /** 6541 * @return {@link #versionAlgorithm} (Indicates the mechanism used to compare versions to determine which is more current.) 6542 */ 6543 public StringType getVersionAlgorithmStringType() throws FHIRException { 6544 if (this.versionAlgorithm == null) 6545 this.versionAlgorithm = new StringType(); 6546 if (!(this.versionAlgorithm instanceof StringType)) 6547 throw new FHIRException("Type mismatch: the type StringType was expected, but "+this.versionAlgorithm.getClass().getName()+" was encountered"); 6548 return (StringType) this.versionAlgorithm; 6549 } 6550 6551 public boolean hasVersionAlgorithmStringType() { 6552 return this != null && this.versionAlgorithm instanceof StringType; 6553 } 6554 6555 /** 6556 * @return {@link #versionAlgorithm} (Indicates the mechanism used to compare versions to determine which is more current.) 6557 */ 6558 public Coding getVersionAlgorithmCoding() throws FHIRException { 6559 if (this.versionAlgorithm == null) 6560 this.versionAlgorithm = new Coding(); 6561 if (!(this.versionAlgorithm instanceof Coding)) 6562 throw new FHIRException("Type mismatch: the type Coding was expected, but "+this.versionAlgorithm.getClass().getName()+" was encountered"); 6563 return (Coding) this.versionAlgorithm; 6564 } 6565 6566 public boolean hasVersionAlgorithmCoding() { 6567 return this != null && this.versionAlgorithm instanceof Coding; 6568 } 6569 6570 public boolean hasVersionAlgorithm() { 6571 return this.versionAlgorithm != null && !this.versionAlgorithm.isEmpty(); 6572 } 6573 6574 /** 6575 * @param value {@link #versionAlgorithm} (Indicates the mechanism used to compare versions to determine which is more current.) 6576 */ 6577 public PlanDefinition setVersionAlgorithm(DataType value) { 6578 if (value != null && !(value instanceof StringType || value instanceof Coding)) 6579 throw new FHIRException("Not the right type for PlanDefinition.versionAlgorithm[x]: "+value.fhirType()); 6580 this.versionAlgorithm = value; 6581 return this; 6582 } 6583 6584 /** 6585 * @return {@link #name} (A natural language name identifying the plan definition. This name should be usable as an identifier for the module by machine processing applications such as code generation.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value 6586 */ 6587 public StringType getNameElement() { 6588 if (this.name == null) 6589 if (Configuration.errorOnAutoCreate()) 6590 throw new Error("Attempt to auto-create PlanDefinition.name"); 6591 else if (Configuration.doAutoCreate()) 6592 this.name = new StringType(); // bb 6593 return this.name; 6594 } 6595 6596 public boolean hasNameElement() { 6597 return this.name != null && !this.name.isEmpty(); 6598 } 6599 6600 public boolean hasName() { 6601 return this.name != null && !this.name.isEmpty(); 6602 } 6603 6604 /** 6605 * @param value {@link #name} (A natural language name identifying the plan definition. This name should be usable as an identifier for the module by machine processing applications such as code generation.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value 6606 */ 6607 public PlanDefinition setNameElement(StringType value) { 6608 this.name = value; 6609 return this; 6610 } 6611 6612 /** 6613 * @return A natural language name identifying the plan definition. This name should be usable as an identifier for the module by machine processing applications such as code generation. 6614 */ 6615 public String getName() { 6616 return this.name == null ? null : this.name.getValue(); 6617 } 6618 6619 /** 6620 * @param value A natural language name identifying the plan definition. This name should be usable as an identifier for the module by machine processing applications such as code generation. 6621 */ 6622 public PlanDefinition setName(String value) { 6623 if (Utilities.noString(value)) 6624 this.name = null; 6625 else { 6626 if (this.name == null) 6627 this.name = new StringType(); 6628 this.name.setValue(value); 6629 } 6630 return this; 6631 } 6632 6633 /** 6634 * @return {@link #title} (A short, descriptive, user-friendly title for the plan definition.). This is the underlying object with id, value and extensions. The accessor "getTitle" gives direct access to the value 6635 */ 6636 public StringType getTitleElement() { 6637 if (this.title == null) 6638 if (Configuration.errorOnAutoCreate()) 6639 throw new Error("Attempt to auto-create PlanDefinition.title"); 6640 else if (Configuration.doAutoCreate()) 6641 this.title = new StringType(); // bb 6642 return this.title; 6643 } 6644 6645 public boolean hasTitleElement() { 6646 return this.title != null && !this.title.isEmpty(); 6647 } 6648 6649 public boolean hasTitle() { 6650 return this.title != null && !this.title.isEmpty(); 6651 } 6652 6653 /** 6654 * @param value {@link #title} (A short, descriptive, user-friendly title for the plan definition.). This is the underlying object with id, value and extensions. The accessor "getTitle" gives direct access to the value 6655 */ 6656 public PlanDefinition setTitleElement(StringType value) { 6657 this.title = value; 6658 return this; 6659 } 6660 6661 /** 6662 * @return A short, descriptive, user-friendly title for the plan definition. 6663 */ 6664 public String getTitle() { 6665 return this.title == null ? null : this.title.getValue(); 6666 } 6667 6668 /** 6669 * @param value A short, descriptive, user-friendly title for the plan definition. 6670 */ 6671 public PlanDefinition setTitle(String value) { 6672 if (Utilities.noString(value)) 6673 this.title = null; 6674 else { 6675 if (this.title == null) 6676 this.title = new StringType(); 6677 this.title.setValue(value); 6678 } 6679 return this; 6680 } 6681 6682 /** 6683 * @return {@link #subtitle} (An explanatory or alternate title for the plan definition giving additional information about its content.). This is the underlying object with id, value and extensions. The accessor "getSubtitle" gives direct access to the value 6684 */ 6685 public StringType getSubtitleElement() { 6686 if (this.subtitle == null) 6687 if (Configuration.errorOnAutoCreate()) 6688 throw new Error("Attempt to auto-create PlanDefinition.subtitle"); 6689 else if (Configuration.doAutoCreate()) 6690 this.subtitle = new StringType(); // bb 6691 return this.subtitle; 6692 } 6693 6694 public boolean hasSubtitleElement() { 6695 return this.subtitle != null && !this.subtitle.isEmpty(); 6696 } 6697 6698 public boolean hasSubtitle() { 6699 return this.subtitle != null && !this.subtitle.isEmpty(); 6700 } 6701 6702 /** 6703 * @param value {@link #subtitle} (An explanatory or alternate title for the plan definition giving additional information about its content.). This is the underlying object with id, value and extensions. The accessor "getSubtitle" gives direct access to the value 6704 */ 6705 public PlanDefinition setSubtitleElement(StringType value) { 6706 this.subtitle = value; 6707 return this; 6708 } 6709 6710 /** 6711 * @return An explanatory or alternate title for the plan definition giving additional information about its content. 6712 */ 6713 public String getSubtitle() { 6714 return this.subtitle == null ? null : this.subtitle.getValue(); 6715 } 6716 6717 /** 6718 * @param value An explanatory or alternate title for the plan definition giving additional information about its content. 6719 */ 6720 public PlanDefinition setSubtitle(String value) { 6721 if (Utilities.noString(value)) 6722 this.subtitle = null; 6723 else { 6724 if (this.subtitle == null) 6725 this.subtitle = new StringType(); 6726 this.subtitle.setValue(value); 6727 } 6728 return this; 6729 } 6730 6731 /** 6732 * @return {@link #type} (A high-level category for the plan definition that distinguishes the kinds of systems that would be interested in the plan definition.) 6733 */ 6734 public CodeableConcept getType() { 6735 if (this.type == null) 6736 if (Configuration.errorOnAutoCreate()) 6737 throw new Error("Attempt to auto-create PlanDefinition.type"); 6738 else if (Configuration.doAutoCreate()) 6739 this.type = new CodeableConcept(); // cc 6740 return this.type; 6741 } 6742 6743 public boolean hasType() { 6744 return this.type != null && !this.type.isEmpty(); 6745 } 6746 6747 /** 6748 * @param value {@link #type} (A high-level category for the plan definition that distinguishes the kinds of systems that would be interested in the plan definition.) 6749 */ 6750 public PlanDefinition setType(CodeableConcept value) { 6751 this.type = value; 6752 return this; 6753 } 6754 6755 /** 6756 * @return {@link #status} (The status of this plan definition. Enables tracking the life-cycle of the content.). This is the underlying object with id, value and extensions. The accessor "getStatus" gives direct access to the value 6757 */ 6758 public Enumeration<PublicationStatus> getStatusElement() { 6759 if (this.status == null) 6760 if (Configuration.errorOnAutoCreate()) 6761 throw new Error("Attempt to auto-create PlanDefinition.status"); 6762 else if (Configuration.doAutoCreate()) 6763 this.status = new Enumeration<PublicationStatus>(new PublicationStatusEnumFactory()); // bb 6764 return this.status; 6765 } 6766 6767 public boolean hasStatusElement() { 6768 return this.status != null && !this.status.isEmpty(); 6769 } 6770 6771 public boolean hasStatus() { 6772 return this.status != null && !this.status.isEmpty(); 6773 } 6774 6775 /** 6776 * @param value {@link #status} (The status of this plan definition. Enables tracking the life-cycle of the content.). This is the underlying object with id, value and extensions. The accessor "getStatus" gives direct access to the value 6777 */ 6778 public PlanDefinition setStatusElement(Enumeration<PublicationStatus> value) { 6779 this.status = value; 6780 return this; 6781 } 6782 6783 /** 6784 * @return The status of this plan definition. Enables tracking the life-cycle of the content. 6785 */ 6786 public PublicationStatus getStatus() { 6787 return this.status == null ? null : this.status.getValue(); 6788 } 6789 6790 /** 6791 * @param value The status of this plan definition. Enables tracking the life-cycle of the content. 6792 */ 6793 public PlanDefinition setStatus(PublicationStatus value) { 6794 if (this.status == null) 6795 this.status = new Enumeration<PublicationStatus>(new PublicationStatusEnumFactory()); 6796 this.status.setValue(value); 6797 return this; 6798 } 6799 6800 /** 6801 * @return {@link #experimental} (A Boolean value to indicate that this plan definition is authored for testing purposes (or education/evaluation/marketing) and is not intended to be used for genuine usage.). This is the underlying object with id, value and extensions. The accessor "getExperimental" gives direct access to the value 6802 */ 6803 public BooleanType getExperimentalElement() { 6804 if (this.experimental == null) 6805 if (Configuration.errorOnAutoCreate()) 6806 throw new Error("Attempt to auto-create PlanDefinition.experimental"); 6807 else if (Configuration.doAutoCreate()) 6808 this.experimental = new BooleanType(); // bb 6809 return this.experimental; 6810 } 6811 6812 public boolean hasExperimentalElement() { 6813 return this.experimental != null && !this.experimental.isEmpty(); 6814 } 6815 6816 public boolean hasExperimental() { 6817 return this.experimental != null && !this.experimental.isEmpty(); 6818 } 6819 6820 /** 6821 * @param value {@link #experimental} (A Boolean value to indicate that this plan definition is authored for testing purposes (or education/evaluation/marketing) and is not intended to be used for genuine usage.). This is the underlying object with id, value and extensions. The accessor "getExperimental" gives direct access to the value 6822 */ 6823 public PlanDefinition setExperimentalElement(BooleanType value) { 6824 this.experimental = value; 6825 return this; 6826 } 6827 6828 /** 6829 * @return A Boolean value to indicate that this plan definition is authored for testing purposes (or education/evaluation/marketing) and is not intended to be used for genuine usage. 6830 */ 6831 public boolean getExperimental() { 6832 return this.experimental == null || this.experimental.isEmpty() ? false : this.experimental.getValue(); 6833 } 6834 6835 /** 6836 * @param value A Boolean value to indicate that this plan definition is authored for testing purposes (or education/evaluation/marketing) and is not intended to be used for genuine usage. 6837 */ 6838 public PlanDefinition setExperimental(boolean value) { 6839 if (this.experimental == null) 6840 this.experimental = new BooleanType(); 6841 this.experimental.setValue(value); 6842 return this; 6843 } 6844 6845 /** 6846 * @return {@link #subject} (A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.) 6847 */ 6848 public DataType getSubject() { 6849 return this.subject; 6850 } 6851 6852 /** 6853 * @return {@link #subject} (A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.) 6854 */ 6855 public CodeableConcept getSubjectCodeableConcept() throws FHIRException { 6856 if (this.subject == null) 6857 this.subject = new CodeableConcept(); 6858 if (!(this.subject instanceof CodeableConcept)) 6859 throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "+this.subject.getClass().getName()+" was encountered"); 6860 return (CodeableConcept) this.subject; 6861 } 6862 6863 public boolean hasSubjectCodeableConcept() { 6864 return this != null && this.subject instanceof CodeableConcept; 6865 } 6866 6867 /** 6868 * @return {@link #subject} (A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.) 6869 */ 6870 public Reference getSubjectReference() throws FHIRException { 6871 if (this.subject == null) 6872 this.subject = new Reference(); 6873 if (!(this.subject instanceof Reference)) 6874 throw new FHIRException("Type mismatch: the type Reference was expected, but "+this.subject.getClass().getName()+" was encountered"); 6875 return (Reference) this.subject; 6876 } 6877 6878 public boolean hasSubjectReference() { 6879 return this != null && this.subject instanceof Reference; 6880 } 6881 6882 /** 6883 * @return {@link #subject} (A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.) 6884 */ 6885 public CanonicalType getSubjectCanonicalType() throws FHIRException { 6886 if (this.subject == null) 6887 this.subject = new CanonicalType(); 6888 if (!(this.subject instanceof CanonicalType)) 6889 throw new FHIRException("Type mismatch: the type CanonicalType was expected, but "+this.subject.getClass().getName()+" was encountered"); 6890 return (CanonicalType) this.subject; 6891 } 6892 6893 public boolean hasSubjectCanonicalType() { 6894 return this != null && this.subject instanceof CanonicalType; 6895 } 6896 6897 public boolean hasSubject() { 6898 return this.subject != null && !this.subject.isEmpty(); 6899 } 6900 6901 /** 6902 * @param value {@link #subject} (A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.) 6903 */ 6904 public PlanDefinition setSubject(DataType value) { 6905 if (value != null && !(value instanceof CodeableConcept || value instanceof Reference || value instanceof CanonicalType)) 6906 throw new FHIRException("Not the right type for PlanDefinition.subject[x]: "+value.fhirType()); 6907 this.subject = value; 6908 return this; 6909 } 6910 6911 /** 6912 * @return {@link #date} (The date (and optionally time) when the plan definition was last significantly changed. 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 plan definition changes.). This is the underlying object with id, value and extensions. The accessor "getDate" gives direct access to the value 6913 */ 6914 public DateTimeType getDateElement() { 6915 if (this.date == null) 6916 if (Configuration.errorOnAutoCreate()) 6917 throw new Error("Attempt to auto-create PlanDefinition.date"); 6918 else if (Configuration.doAutoCreate()) 6919 this.date = new DateTimeType(); // bb 6920 return this.date; 6921 } 6922 6923 public boolean hasDateElement() { 6924 return this.date != null && !this.date.isEmpty(); 6925 } 6926 6927 public boolean hasDate() { 6928 return this.date != null && !this.date.isEmpty(); 6929 } 6930 6931 /** 6932 * @param value {@link #date} (The date (and optionally time) when the plan definition was last significantly changed. 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 plan definition changes.). This is the underlying object with id, value and extensions. The accessor "getDate" gives direct access to the value 6933 */ 6934 public PlanDefinition setDateElement(DateTimeType value) { 6935 this.date = value; 6936 return this; 6937 } 6938 6939 /** 6940 * @return The date (and optionally time) when the plan definition was last significantly changed. 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 plan definition changes. 6941 */ 6942 public Date getDate() { 6943 return this.date == null ? null : this.date.getValue(); 6944 } 6945 6946 /** 6947 * @param value The date (and optionally time) when the plan definition was last significantly changed. 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 plan definition changes. 6948 */ 6949 public PlanDefinition setDate(Date value) { 6950 if (value == null) 6951 this.date = null; 6952 else { 6953 if (this.date == null) 6954 this.date = new DateTimeType(); 6955 this.date.setValue(value); 6956 } 6957 return this; 6958 } 6959 6960 /** 6961 * @return {@link #publisher} (The name of the organization or individual responsible for the release and ongoing maintenance of the plan definition.). This is the underlying object with id, value and extensions. The accessor "getPublisher" gives direct access to the value 6962 */ 6963 public StringType getPublisherElement() { 6964 if (this.publisher == null) 6965 if (Configuration.errorOnAutoCreate()) 6966 throw new Error("Attempt to auto-create PlanDefinition.publisher"); 6967 else if (Configuration.doAutoCreate()) 6968 this.publisher = new StringType(); // bb 6969 return this.publisher; 6970 } 6971 6972 public boolean hasPublisherElement() { 6973 return this.publisher != null && !this.publisher.isEmpty(); 6974 } 6975 6976 public boolean hasPublisher() { 6977 return this.publisher != null && !this.publisher.isEmpty(); 6978 } 6979 6980 /** 6981 * @param value {@link #publisher} (The name of the organization or individual responsible for the release and ongoing maintenance of the plan definition.). This is the underlying object with id, value and extensions. The accessor "getPublisher" gives direct access to the value 6982 */ 6983 public PlanDefinition setPublisherElement(StringType value) { 6984 this.publisher = value; 6985 return this; 6986 } 6987 6988 /** 6989 * @return The name of the organization or individual responsible for the release and ongoing maintenance of the plan definition. 6990 */ 6991 public String getPublisher() { 6992 return this.publisher == null ? null : this.publisher.getValue(); 6993 } 6994 6995 /** 6996 * @param value The name of the organization or individual responsible for the release and ongoing maintenance of the plan definition. 6997 */ 6998 public PlanDefinition setPublisher(String value) { 6999 if (Utilities.noString(value)) 7000 this.publisher = null; 7001 else { 7002 if (this.publisher == null) 7003 this.publisher = new StringType(); 7004 this.publisher.setValue(value); 7005 } 7006 return this; 7007 } 7008 7009 /** 7010 * @return {@link #contact} (Contact details to assist a user in finding and communicating with the publisher.) 7011 */ 7012 public List<ContactDetail> getContact() { 7013 if (this.contact == null) 7014 this.contact = new ArrayList<ContactDetail>(); 7015 return this.contact; 7016 } 7017 7018 /** 7019 * @return Returns a reference to <code>this</code> for easy method chaining 7020 */ 7021 public PlanDefinition setContact(List<ContactDetail> theContact) { 7022 this.contact = theContact; 7023 return this; 7024 } 7025 7026 public boolean hasContact() { 7027 if (this.contact == null) 7028 return false; 7029 for (ContactDetail item : this.contact) 7030 if (!item.isEmpty()) 7031 return true; 7032 return false; 7033 } 7034 7035 public ContactDetail addContact() { //3 7036 ContactDetail t = new ContactDetail(); 7037 if (this.contact == null) 7038 this.contact = new ArrayList<ContactDetail>(); 7039 this.contact.add(t); 7040 return t; 7041 } 7042 7043 public PlanDefinition addContact(ContactDetail t) { //3 7044 if (t == null) 7045 return this; 7046 if (this.contact == null) 7047 this.contact = new ArrayList<ContactDetail>(); 7048 this.contact.add(t); 7049 return this; 7050 } 7051 7052 /** 7053 * @return The first repetition of repeating field {@link #contact}, creating it if it does not already exist {3} 7054 */ 7055 public ContactDetail getContactFirstRep() { 7056 if (getContact().isEmpty()) { 7057 addContact(); 7058 } 7059 return getContact().get(0); 7060 } 7061 7062 /** 7063 * @return {@link #description} (A free text natural language description of the plan definition from a consumer's perspective.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value 7064 */ 7065 public MarkdownType getDescriptionElement() { 7066 if (this.description == null) 7067 if (Configuration.errorOnAutoCreate()) 7068 throw new Error("Attempt to auto-create PlanDefinition.description"); 7069 else if (Configuration.doAutoCreate()) 7070 this.description = new MarkdownType(); // bb 7071 return this.description; 7072 } 7073 7074 public boolean hasDescriptionElement() { 7075 return this.description != null && !this.description.isEmpty(); 7076 } 7077 7078 public boolean hasDescription() { 7079 return this.description != null && !this.description.isEmpty(); 7080 } 7081 7082 /** 7083 * @param value {@link #description} (A free text natural language description of the plan definition from a consumer's perspective.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value 7084 */ 7085 public PlanDefinition setDescriptionElement(MarkdownType value) { 7086 this.description = value; 7087 return this; 7088 } 7089 7090 /** 7091 * @return A free text natural language description of the plan definition from a consumer's perspective. 7092 */ 7093 public String getDescription() { 7094 return this.description == null ? null : this.description.getValue(); 7095 } 7096 7097 /** 7098 * @param value A free text natural language description of the plan definition from a consumer's perspective. 7099 */ 7100 public PlanDefinition setDescription(String value) { 7101 if (Utilities.noString(value)) 7102 this.description = null; 7103 else { 7104 if (this.description == null) 7105 this.description = new MarkdownType(); 7106 this.description.setValue(value); 7107 } 7108 return this; 7109 } 7110 7111 /** 7112 * @return {@link #useContext} (The content was developed with a focus and intent of supporting the contexts that are listed. These contexts may be general categories (gender, age, ...) or may be references to specific programs (insurance plans, studies, ...) and may be used to assist with indexing and searching for appropriate plan definition instances.) 7113 */ 7114 public List<UsageContext> getUseContext() { 7115 if (this.useContext == null) 7116 this.useContext = new ArrayList<UsageContext>(); 7117 return this.useContext; 7118 } 7119 7120 /** 7121 * @return Returns a reference to <code>this</code> for easy method chaining 7122 */ 7123 public PlanDefinition setUseContext(List<UsageContext> theUseContext) { 7124 this.useContext = theUseContext; 7125 return this; 7126 } 7127 7128 public boolean hasUseContext() { 7129 if (this.useContext == null) 7130 return false; 7131 for (UsageContext item : this.useContext) 7132 if (!item.isEmpty()) 7133 return true; 7134 return false; 7135 } 7136 7137 public UsageContext addUseContext() { //3 7138 UsageContext t = new UsageContext(); 7139 if (this.useContext == null) 7140 this.useContext = new ArrayList<UsageContext>(); 7141 this.useContext.add(t); 7142 return t; 7143 } 7144 7145 public PlanDefinition addUseContext(UsageContext t) { //3 7146 if (t == null) 7147 return this; 7148 if (this.useContext == null) 7149 this.useContext = new ArrayList<UsageContext>(); 7150 this.useContext.add(t); 7151 return this; 7152 } 7153 7154 /** 7155 * @return The first repetition of repeating field {@link #useContext}, creating it if it does not already exist {3} 7156 */ 7157 public UsageContext getUseContextFirstRep() { 7158 if (getUseContext().isEmpty()) { 7159 addUseContext(); 7160 } 7161 return getUseContext().get(0); 7162 } 7163 7164 /** 7165 * @return {@link #jurisdiction} (A legal or geographic region in which the plan definition is intended to be used.) 7166 */ 7167 public List<CodeableConcept> getJurisdiction() { 7168 if (this.jurisdiction == null) 7169 this.jurisdiction = new ArrayList<CodeableConcept>(); 7170 return this.jurisdiction; 7171 } 7172 7173 /** 7174 * @return Returns a reference to <code>this</code> for easy method chaining 7175 */ 7176 public PlanDefinition setJurisdiction(List<CodeableConcept> theJurisdiction) { 7177 this.jurisdiction = theJurisdiction; 7178 return this; 7179 } 7180 7181 public boolean hasJurisdiction() { 7182 if (this.jurisdiction == null) 7183 return false; 7184 for (CodeableConcept item : this.jurisdiction) 7185 if (!item.isEmpty()) 7186 return true; 7187 return false; 7188 } 7189 7190 public CodeableConcept addJurisdiction() { //3 7191 CodeableConcept t = new CodeableConcept(); 7192 if (this.jurisdiction == null) 7193 this.jurisdiction = new ArrayList<CodeableConcept>(); 7194 this.jurisdiction.add(t); 7195 return t; 7196 } 7197 7198 public PlanDefinition addJurisdiction(CodeableConcept t) { //3 7199 if (t == null) 7200 return this; 7201 if (this.jurisdiction == null) 7202 this.jurisdiction = new ArrayList<CodeableConcept>(); 7203 this.jurisdiction.add(t); 7204 return this; 7205 } 7206 7207 /** 7208 * @return The first repetition of repeating field {@link #jurisdiction}, creating it if it does not already exist {3} 7209 */ 7210 public CodeableConcept getJurisdictionFirstRep() { 7211 if (getJurisdiction().isEmpty()) { 7212 addJurisdiction(); 7213 } 7214 return getJurisdiction().get(0); 7215 } 7216 7217 /** 7218 * @return {@link #purpose} (Explanation of why this plan definition is needed and why it has been designed as it has.). This is the underlying object with id, value and extensions. The accessor "getPurpose" gives direct access to the value 7219 */ 7220 public MarkdownType getPurposeElement() { 7221 if (this.purpose == null) 7222 if (Configuration.errorOnAutoCreate()) 7223 throw new Error("Attempt to auto-create PlanDefinition.purpose"); 7224 else if (Configuration.doAutoCreate()) 7225 this.purpose = new MarkdownType(); // bb 7226 return this.purpose; 7227 } 7228 7229 public boolean hasPurposeElement() { 7230 return this.purpose != null && !this.purpose.isEmpty(); 7231 } 7232 7233 public boolean hasPurpose() { 7234 return this.purpose != null && !this.purpose.isEmpty(); 7235 } 7236 7237 /** 7238 * @param value {@link #purpose} (Explanation of why this plan definition is needed and why it has been designed as it has.). This is the underlying object with id, value and extensions. The accessor "getPurpose" gives direct access to the value 7239 */ 7240 public PlanDefinition setPurposeElement(MarkdownType value) { 7241 this.purpose = value; 7242 return this; 7243 } 7244 7245 /** 7246 * @return Explanation of why this plan definition is needed and why it has been designed as it has. 7247 */ 7248 public String getPurpose() { 7249 return this.purpose == null ? null : this.purpose.getValue(); 7250 } 7251 7252 /** 7253 * @param value Explanation of why this plan definition is needed and why it has been designed as it has. 7254 */ 7255 public PlanDefinition setPurpose(String value) { 7256 if (Utilities.noString(value)) 7257 this.purpose = null; 7258 else { 7259 if (this.purpose == null) 7260 this.purpose = new MarkdownType(); 7261 this.purpose.setValue(value); 7262 } 7263 return this; 7264 } 7265 7266 /** 7267 * @return {@link #usage} (A detailed description of how the plan definition is used from a clinical perspective.). This is the underlying object with id, value and extensions. The accessor "getUsage" gives direct access to the value 7268 */ 7269 public MarkdownType getUsageElement() { 7270 if (this.usage == null) 7271 if (Configuration.errorOnAutoCreate()) 7272 throw new Error("Attempt to auto-create PlanDefinition.usage"); 7273 else if (Configuration.doAutoCreate()) 7274 this.usage = new MarkdownType(); // bb 7275 return this.usage; 7276 } 7277 7278 public boolean hasUsageElement() { 7279 return this.usage != null && !this.usage.isEmpty(); 7280 } 7281 7282 public boolean hasUsage() { 7283 return this.usage != null && !this.usage.isEmpty(); 7284 } 7285 7286 /** 7287 * @param value {@link #usage} (A detailed description of how the plan definition is used from a clinical perspective.). This is the underlying object with id, value and extensions. The accessor "getUsage" gives direct access to the value 7288 */ 7289 public PlanDefinition setUsageElement(MarkdownType value) { 7290 this.usage = value; 7291 return this; 7292 } 7293 7294 /** 7295 * @return A detailed description of how the plan definition is used from a clinical perspective. 7296 */ 7297 public String getUsage() { 7298 return this.usage == null ? null : this.usage.getValue(); 7299 } 7300 7301 /** 7302 * @param value A detailed description of how the plan definition is used from a clinical perspective. 7303 */ 7304 public PlanDefinition setUsage(String value) { 7305 if (Utilities.noString(value)) 7306 this.usage = null; 7307 else { 7308 if (this.usage == null) 7309 this.usage = new MarkdownType(); 7310 this.usage.setValue(value); 7311 } 7312 return this; 7313 } 7314 7315 /** 7316 * @return {@link #copyright} (A copyright statement relating to the plan definition and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the plan definition.). This is the underlying object with id, value and extensions. The accessor "getCopyright" gives direct access to the value 7317 */ 7318 public MarkdownType getCopyrightElement() { 7319 if (this.copyright == null) 7320 if (Configuration.errorOnAutoCreate()) 7321 throw new Error("Attempt to auto-create PlanDefinition.copyright"); 7322 else if (Configuration.doAutoCreate()) 7323 this.copyright = new MarkdownType(); // bb 7324 return this.copyright; 7325 } 7326 7327 public boolean hasCopyrightElement() { 7328 return this.copyright != null && !this.copyright.isEmpty(); 7329 } 7330 7331 public boolean hasCopyright() { 7332 return this.copyright != null && !this.copyright.isEmpty(); 7333 } 7334 7335 /** 7336 * @param value {@link #copyright} (A copyright statement relating to the plan definition and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the plan definition.). This is the underlying object with id, value and extensions. The accessor "getCopyright" gives direct access to the value 7337 */ 7338 public PlanDefinition setCopyrightElement(MarkdownType value) { 7339 this.copyright = value; 7340 return this; 7341 } 7342 7343 /** 7344 * @return A copyright statement relating to the plan definition and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the plan definition. 7345 */ 7346 public String getCopyright() { 7347 return this.copyright == null ? null : this.copyright.getValue(); 7348 } 7349 7350 /** 7351 * @param value A copyright statement relating to the plan definition and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the plan definition. 7352 */ 7353 public PlanDefinition setCopyright(String value) { 7354 if (Utilities.noString(value)) 7355 this.copyright = null; 7356 else { 7357 if (this.copyright == null) 7358 this.copyright = new MarkdownType(); 7359 this.copyright.setValue(value); 7360 } 7361 return this; 7362 } 7363 7364 /** 7365 * @return {@link #copyrightLabel} (A short string (<50 characters), suitable for inclusion in a page footer that identifies the copyright holder, effective period, and optionally whether rights are resctricted. (e.g. 'All rights reserved', 'Some rights reserved').). This is the underlying object with id, value and extensions. The accessor "getCopyrightLabel" gives direct access to the value 7366 */ 7367 public StringType getCopyrightLabelElement() { 7368 if (this.copyrightLabel == null) 7369 if (Configuration.errorOnAutoCreate()) 7370 throw new Error("Attempt to auto-create PlanDefinition.copyrightLabel"); 7371 else if (Configuration.doAutoCreate()) 7372 this.copyrightLabel = new StringType(); // bb 7373 return this.copyrightLabel; 7374 } 7375 7376 public boolean hasCopyrightLabelElement() { 7377 return this.copyrightLabel != null && !this.copyrightLabel.isEmpty(); 7378 } 7379 7380 public boolean hasCopyrightLabel() { 7381 return this.copyrightLabel != null && !this.copyrightLabel.isEmpty(); 7382 } 7383 7384 /** 7385 * @param value {@link #copyrightLabel} (A short string (<50 characters), suitable for inclusion in a page footer that identifies the copyright holder, effective period, and optionally whether rights are resctricted. (e.g. 'All rights reserved', 'Some rights reserved').). This is the underlying object with id, value and extensions. The accessor "getCopyrightLabel" gives direct access to the value 7386 */ 7387 public PlanDefinition setCopyrightLabelElement(StringType value) { 7388 this.copyrightLabel = value; 7389 return this; 7390 } 7391 7392 /** 7393 * @return A short string (<50 characters), suitable for inclusion in a page footer that identifies the copyright holder, effective period, and optionally whether rights are resctricted. (e.g. 'All rights reserved', 'Some rights reserved'). 7394 */ 7395 public String getCopyrightLabel() { 7396 return this.copyrightLabel == null ? null : this.copyrightLabel.getValue(); 7397 } 7398 7399 /** 7400 * @param value A short string (<50 characters), suitable for inclusion in a page footer that identifies the copyright holder, effective period, and optionally whether rights are resctricted. (e.g. 'All rights reserved', 'Some rights reserved'). 7401 */ 7402 public PlanDefinition setCopyrightLabel(String value) { 7403 if (Utilities.noString(value)) 7404 this.copyrightLabel = null; 7405 else { 7406 if (this.copyrightLabel == null) 7407 this.copyrightLabel = new StringType(); 7408 this.copyrightLabel.setValue(value); 7409 } 7410 return this; 7411 } 7412 7413 /** 7414 * @return {@link #approvalDate} (The date on which the resource content was approved by the publisher. Approval happens once when the content is officially approved for usage.). This is the underlying object with id, value and extensions. The accessor "getApprovalDate" gives direct access to the value 7415 */ 7416 public DateType getApprovalDateElement() { 7417 if (this.approvalDate == null) 7418 if (Configuration.errorOnAutoCreate()) 7419 throw new Error("Attempt to auto-create PlanDefinition.approvalDate"); 7420 else if (Configuration.doAutoCreate()) 7421 this.approvalDate = new DateType(); // bb 7422 return this.approvalDate; 7423 } 7424 7425 public boolean hasApprovalDateElement() { 7426 return this.approvalDate != null && !this.approvalDate.isEmpty(); 7427 } 7428 7429 public boolean hasApprovalDate() { 7430 return this.approvalDate != null && !this.approvalDate.isEmpty(); 7431 } 7432 7433 /** 7434 * @param value {@link #approvalDate} (The date on which the resource content was approved by the publisher. Approval happens once when the content is officially approved for usage.). This is the underlying object with id, value and extensions. The accessor "getApprovalDate" gives direct access to the value 7435 */ 7436 public PlanDefinition setApprovalDateElement(DateType value) { 7437 this.approvalDate = value; 7438 return this; 7439 } 7440 7441 /** 7442 * @return The date on which the resource content was approved by the publisher. Approval happens once when the content is officially approved for usage. 7443 */ 7444 public Date getApprovalDate() { 7445 return this.approvalDate == null ? null : this.approvalDate.getValue(); 7446 } 7447 7448 /** 7449 * @param value The date on which the resource content was approved by the publisher. Approval happens once when the content is officially approved for usage. 7450 */ 7451 public PlanDefinition setApprovalDate(Date value) { 7452 if (value == null) 7453 this.approvalDate = null; 7454 else { 7455 if (this.approvalDate == null) 7456 this.approvalDate = new DateType(); 7457 this.approvalDate.setValue(value); 7458 } 7459 return this; 7460 } 7461 7462 /** 7463 * @return {@link #lastReviewDate} (The date on which the resource content was last reviewed. Review happens periodically after approval but does not change the original approval date.). This is the underlying object with id, value and extensions. The accessor "getLastReviewDate" gives direct access to the value 7464 */ 7465 public DateType getLastReviewDateElement() { 7466 if (this.lastReviewDate == null) 7467 if (Configuration.errorOnAutoCreate()) 7468 throw new Error("Attempt to auto-create PlanDefinition.lastReviewDate"); 7469 else if (Configuration.doAutoCreate()) 7470 this.lastReviewDate = new DateType(); // bb 7471 return this.lastReviewDate; 7472 } 7473 7474 public boolean hasLastReviewDateElement() { 7475 return this.lastReviewDate != null && !this.lastReviewDate.isEmpty(); 7476 } 7477 7478 public boolean hasLastReviewDate() { 7479 return this.lastReviewDate != null && !this.lastReviewDate.isEmpty(); 7480 } 7481 7482 /** 7483 * @param value {@link #lastReviewDate} (The date on which the resource content was last reviewed. Review happens periodically after approval but does not change the original approval date.). This is the underlying object with id, value and extensions. The accessor "getLastReviewDate" gives direct access to the value 7484 */ 7485 public PlanDefinition setLastReviewDateElement(DateType value) { 7486 this.lastReviewDate = value; 7487 return this; 7488 } 7489 7490 /** 7491 * @return The date on which the resource content was last reviewed. Review happens periodically after approval but does not change the original approval date. 7492 */ 7493 public Date getLastReviewDate() { 7494 return this.lastReviewDate == null ? null : this.lastReviewDate.getValue(); 7495 } 7496 7497 /** 7498 * @param value The date on which the resource content was last reviewed. Review happens periodically after approval but does not change the original approval date. 7499 */ 7500 public PlanDefinition setLastReviewDate(Date value) { 7501 if (value == null) 7502 this.lastReviewDate = null; 7503 else { 7504 if (this.lastReviewDate == null) 7505 this.lastReviewDate = new DateType(); 7506 this.lastReviewDate.setValue(value); 7507 } 7508 return this; 7509 } 7510 7511 /** 7512 * @return {@link #effectivePeriod} (The period during which the plan definition content was or is planned to be in active use.) 7513 */ 7514 public Period getEffectivePeriod() { 7515 if (this.effectivePeriod == null) 7516 if (Configuration.errorOnAutoCreate()) 7517 throw new Error("Attempt to auto-create PlanDefinition.effectivePeriod"); 7518 else if (Configuration.doAutoCreate()) 7519 this.effectivePeriod = new Period(); // cc 7520 return this.effectivePeriod; 7521 } 7522 7523 public boolean hasEffectivePeriod() { 7524 return this.effectivePeriod != null && !this.effectivePeriod.isEmpty(); 7525 } 7526 7527 /** 7528 * @param value {@link #effectivePeriod} (The period during which the plan definition content was or is planned to be in active use.) 7529 */ 7530 public PlanDefinition setEffectivePeriod(Period value) { 7531 this.effectivePeriod = value; 7532 return this; 7533 } 7534 7535 /** 7536 * @return {@link #topic} (Descriptive topics related to the content of the plan definition. Topics provide a high-level categorization of the definition that can be useful for filtering and searching.) 7537 */ 7538 public List<CodeableConcept> getTopic() { 7539 if (this.topic == null) 7540 this.topic = new ArrayList<CodeableConcept>(); 7541 return this.topic; 7542 } 7543 7544 /** 7545 * @return Returns a reference to <code>this</code> for easy method chaining 7546 */ 7547 public PlanDefinition setTopic(List<CodeableConcept> theTopic) { 7548 this.topic = theTopic; 7549 return this; 7550 } 7551 7552 public boolean hasTopic() { 7553 if (this.topic == null) 7554 return false; 7555 for (CodeableConcept item : this.topic) 7556 if (!item.isEmpty()) 7557 return true; 7558 return false; 7559 } 7560 7561 public CodeableConcept addTopic() { //3 7562 CodeableConcept t = new CodeableConcept(); 7563 if (this.topic == null) 7564 this.topic = new ArrayList<CodeableConcept>(); 7565 this.topic.add(t); 7566 return t; 7567 } 7568 7569 public PlanDefinition addTopic(CodeableConcept t) { //3 7570 if (t == null) 7571 return this; 7572 if (this.topic == null) 7573 this.topic = new ArrayList<CodeableConcept>(); 7574 this.topic.add(t); 7575 return this; 7576 } 7577 7578 /** 7579 * @return The first repetition of repeating field {@link #topic}, creating it if it does not already exist {3} 7580 */ 7581 public CodeableConcept getTopicFirstRep() { 7582 if (getTopic().isEmpty()) { 7583 addTopic(); 7584 } 7585 return getTopic().get(0); 7586 } 7587 7588 /** 7589 * @return {@link #author} (An individiual or organization primarily involved in the creation and maintenance of the content.) 7590 */ 7591 public List<ContactDetail> getAuthor() { 7592 if (this.author == null) 7593 this.author = new ArrayList<ContactDetail>(); 7594 return this.author; 7595 } 7596 7597 /** 7598 * @return Returns a reference to <code>this</code> for easy method chaining 7599 */ 7600 public PlanDefinition setAuthor(List<ContactDetail> theAuthor) { 7601 this.author = theAuthor; 7602 return this; 7603 } 7604 7605 public boolean hasAuthor() { 7606 if (this.author == null) 7607 return false; 7608 for (ContactDetail item : this.author) 7609 if (!item.isEmpty()) 7610 return true; 7611 return false; 7612 } 7613 7614 public ContactDetail addAuthor() { //3 7615 ContactDetail t = new ContactDetail(); 7616 if (this.author == null) 7617 this.author = new ArrayList<ContactDetail>(); 7618 this.author.add(t); 7619 return t; 7620 } 7621 7622 public PlanDefinition addAuthor(ContactDetail t) { //3 7623 if (t == null) 7624 return this; 7625 if (this.author == null) 7626 this.author = new ArrayList<ContactDetail>(); 7627 this.author.add(t); 7628 return this; 7629 } 7630 7631 /** 7632 * @return The first repetition of repeating field {@link #author}, creating it if it does not already exist {3} 7633 */ 7634 public ContactDetail getAuthorFirstRep() { 7635 if (getAuthor().isEmpty()) { 7636 addAuthor(); 7637 } 7638 return getAuthor().get(0); 7639 } 7640 7641 /** 7642 * @return {@link #editor} (An individual or organization primarily responsible for internal coherence of the content.) 7643 */ 7644 public List<ContactDetail> getEditor() { 7645 if (this.editor == null) 7646 this.editor = new ArrayList<ContactDetail>(); 7647 return this.editor; 7648 } 7649 7650 /** 7651 * @return Returns a reference to <code>this</code> for easy method chaining 7652 */ 7653 public PlanDefinition setEditor(List<ContactDetail> theEditor) { 7654 this.editor = theEditor; 7655 return this; 7656 } 7657 7658 public boolean hasEditor() { 7659 if (this.editor == null) 7660 return false; 7661 for (ContactDetail item : this.editor) 7662 if (!item.isEmpty()) 7663 return true; 7664 return false; 7665 } 7666 7667 public ContactDetail addEditor() { //3 7668 ContactDetail t = new ContactDetail(); 7669 if (this.editor == null) 7670 this.editor = new ArrayList<ContactDetail>(); 7671 this.editor.add(t); 7672 return t; 7673 } 7674 7675 public PlanDefinition addEditor(ContactDetail t) { //3 7676 if (t == null) 7677 return this; 7678 if (this.editor == null) 7679 this.editor = new ArrayList<ContactDetail>(); 7680 this.editor.add(t); 7681 return this; 7682 } 7683 7684 /** 7685 * @return The first repetition of repeating field {@link #editor}, creating it if it does not already exist {3} 7686 */ 7687 public ContactDetail getEditorFirstRep() { 7688 if (getEditor().isEmpty()) { 7689 addEditor(); 7690 } 7691 return getEditor().get(0); 7692 } 7693 7694 /** 7695 * @return {@link #reviewer} (An individual or organization asserted by the publisher to be primarily responsible for review of some aspect of the content.) 7696 */ 7697 public List<ContactDetail> getReviewer() { 7698 if (this.reviewer == null) 7699 this.reviewer = new ArrayList<ContactDetail>(); 7700 return this.reviewer; 7701 } 7702 7703 /** 7704 * @return Returns a reference to <code>this</code> for easy method chaining 7705 */ 7706 public PlanDefinition setReviewer(List<ContactDetail> theReviewer) { 7707 this.reviewer = theReviewer; 7708 return this; 7709 } 7710 7711 public boolean hasReviewer() { 7712 if (this.reviewer == null) 7713 return false; 7714 for (ContactDetail item : this.reviewer) 7715 if (!item.isEmpty()) 7716 return true; 7717 return false; 7718 } 7719 7720 public ContactDetail addReviewer() { //3 7721 ContactDetail t = new ContactDetail(); 7722 if (this.reviewer == null) 7723 this.reviewer = new ArrayList<ContactDetail>(); 7724 this.reviewer.add(t); 7725 return t; 7726 } 7727 7728 public PlanDefinition addReviewer(ContactDetail t) { //3 7729 if (t == null) 7730 return this; 7731 if (this.reviewer == null) 7732 this.reviewer = new ArrayList<ContactDetail>(); 7733 this.reviewer.add(t); 7734 return this; 7735 } 7736 7737 /** 7738 * @return The first repetition of repeating field {@link #reviewer}, creating it if it does not already exist {3} 7739 */ 7740 public ContactDetail getReviewerFirstRep() { 7741 if (getReviewer().isEmpty()) { 7742 addReviewer(); 7743 } 7744 return getReviewer().get(0); 7745 } 7746 7747 /** 7748 * @return {@link #endorser} (An individual or organization asserted by the publisher to be responsible for officially endorsing the content for use in some setting.) 7749 */ 7750 public List<ContactDetail> getEndorser() { 7751 if (this.endorser == null) 7752 this.endorser = new ArrayList<ContactDetail>(); 7753 return this.endorser; 7754 } 7755 7756 /** 7757 * @return Returns a reference to <code>this</code> for easy method chaining 7758 */ 7759 public PlanDefinition setEndorser(List<ContactDetail> theEndorser) { 7760 this.endorser = theEndorser; 7761 return this; 7762 } 7763 7764 public boolean hasEndorser() { 7765 if (this.endorser == null) 7766 return false; 7767 for (ContactDetail item : this.endorser) 7768 if (!item.isEmpty()) 7769 return true; 7770 return false; 7771 } 7772 7773 public ContactDetail addEndorser() { //3 7774 ContactDetail t = new ContactDetail(); 7775 if (this.endorser == null) 7776 this.endorser = new ArrayList<ContactDetail>(); 7777 this.endorser.add(t); 7778 return t; 7779 } 7780 7781 public PlanDefinition addEndorser(ContactDetail t) { //3 7782 if (t == null) 7783 return this; 7784 if (this.endorser == null) 7785 this.endorser = new ArrayList<ContactDetail>(); 7786 this.endorser.add(t); 7787 return this; 7788 } 7789 7790 /** 7791 * @return The first repetition of repeating field {@link #endorser}, creating it if it does not already exist {3} 7792 */ 7793 public ContactDetail getEndorserFirstRep() { 7794 if (getEndorser().isEmpty()) { 7795 addEndorser(); 7796 } 7797 return getEndorser().get(0); 7798 } 7799 7800 /** 7801 * @return {@link #relatedArtifact} (Related artifacts such as additional documentation, justification, or bibliographic references.) 7802 */ 7803 public List<RelatedArtifact> getRelatedArtifact() { 7804 if (this.relatedArtifact == null) 7805 this.relatedArtifact = new ArrayList<RelatedArtifact>(); 7806 return this.relatedArtifact; 7807 } 7808 7809 /** 7810 * @return Returns a reference to <code>this</code> for easy method chaining 7811 */ 7812 public PlanDefinition setRelatedArtifact(List<RelatedArtifact> theRelatedArtifact) { 7813 this.relatedArtifact = theRelatedArtifact; 7814 return this; 7815 } 7816 7817 public boolean hasRelatedArtifact() { 7818 if (this.relatedArtifact == null) 7819 return false; 7820 for (RelatedArtifact item : this.relatedArtifact) 7821 if (!item.isEmpty()) 7822 return true; 7823 return false; 7824 } 7825 7826 public RelatedArtifact addRelatedArtifact() { //3 7827 RelatedArtifact t = new RelatedArtifact(); 7828 if (this.relatedArtifact == null) 7829 this.relatedArtifact = new ArrayList<RelatedArtifact>(); 7830 this.relatedArtifact.add(t); 7831 return t; 7832 } 7833 7834 public PlanDefinition addRelatedArtifact(RelatedArtifact t) { //3 7835 if (t == null) 7836 return this; 7837 if (this.relatedArtifact == null) 7838 this.relatedArtifact = new ArrayList<RelatedArtifact>(); 7839 this.relatedArtifact.add(t); 7840 return this; 7841 } 7842 7843 /** 7844 * @return The first repetition of repeating field {@link #relatedArtifact}, creating it if it does not already exist {3} 7845 */ 7846 public RelatedArtifact getRelatedArtifactFirstRep() { 7847 if (getRelatedArtifact().isEmpty()) { 7848 addRelatedArtifact(); 7849 } 7850 return getRelatedArtifact().get(0); 7851 } 7852 7853 /** 7854 * @return {@link #library} (A reference to a Library resource containing any formal logic used by the plan definition.) 7855 */ 7856 public List<CanonicalType> getLibrary() { 7857 if (this.library == null) 7858 this.library = new ArrayList<CanonicalType>(); 7859 return this.library; 7860 } 7861 7862 /** 7863 * @return Returns a reference to <code>this</code> for easy method chaining 7864 */ 7865 public PlanDefinition setLibrary(List<CanonicalType> theLibrary) { 7866 this.library = theLibrary; 7867 return this; 7868 } 7869 7870 public boolean hasLibrary() { 7871 if (this.library == null) 7872 return false; 7873 for (CanonicalType item : this.library) 7874 if (!item.isEmpty()) 7875 return true; 7876 return false; 7877 } 7878 7879 /** 7880 * @return {@link #library} (A reference to a Library resource containing any formal logic used by the plan definition.) 7881 */ 7882 public CanonicalType addLibraryElement() {//2 7883 CanonicalType t = new CanonicalType(); 7884 if (this.library == null) 7885 this.library = new ArrayList<CanonicalType>(); 7886 this.library.add(t); 7887 return t; 7888 } 7889 7890 /** 7891 * @param value {@link #library} (A reference to a Library resource containing any formal logic used by the plan definition.) 7892 */ 7893 public PlanDefinition addLibrary(String value) { //1 7894 CanonicalType t = new CanonicalType(); 7895 t.setValue(value); 7896 if (this.library == null) 7897 this.library = new ArrayList<CanonicalType>(); 7898 this.library.add(t); 7899 return this; 7900 } 7901 7902 /** 7903 * @param value {@link #library} (A reference to a Library resource containing any formal logic used by the plan definition.) 7904 */ 7905 public boolean hasLibrary(String value) { 7906 if (this.library == null) 7907 return false; 7908 for (CanonicalType v : this.library) 7909 if (v.getValue().equals(value)) // canonical 7910 return true; 7911 return false; 7912 } 7913 7914 /** 7915 * @return {@link #goal} (A goal describes an expected outcome that activities within the plan are intended to achieve. For example, weight loss, restoring an activity of daily living, obtaining herd immunity via immunization, meeting a process improvement objective, meeting the acceptance criteria for a test as specified by a quality specification, etc.) 7916 */ 7917 public List<PlanDefinitionGoalComponent> getGoal() { 7918 if (this.goal == null) 7919 this.goal = new ArrayList<PlanDefinitionGoalComponent>(); 7920 return this.goal; 7921 } 7922 7923 /** 7924 * @return Returns a reference to <code>this</code> for easy method chaining 7925 */ 7926 public PlanDefinition setGoal(List<PlanDefinitionGoalComponent> theGoal) { 7927 this.goal = theGoal; 7928 return this; 7929 } 7930 7931 public boolean hasGoal() { 7932 if (this.goal == null) 7933 return false; 7934 for (PlanDefinitionGoalComponent item : this.goal) 7935 if (!item.isEmpty()) 7936 return true; 7937 return false; 7938 } 7939 7940 public PlanDefinitionGoalComponent addGoal() { //3 7941 PlanDefinitionGoalComponent t = new PlanDefinitionGoalComponent(); 7942 if (this.goal == null) 7943 this.goal = new ArrayList<PlanDefinitionGoalComponent>(); 7944 this.goal.add(t); 7945 return t; 7946 } 7947 7948 public PlanDefinition addGoal(PlanDefinitionGoalComponent t) { //3 7949 if (t == null) 7950 return this; 7951 if (this.goal == null) 7952 this.goal = new ArrayList<PlanDefinitionGoalComponent>(); 7953 this.goal.add(t); 7954 return this; 7955 } 7956 7957 /** 7958 * @return The first repetition of repeating field {@link #goal}, creating it if it does not already exist {3} 7959 */ 7960 public PlanDefinitionGoalComponent getGoalFirstRep() { 7961 if (getGoal().isEmpty()) { 7962 addGoal(); 7963 } 7964 return getGoal().get(0); 7965 } 7966 7967 /** 7968 * @return {@link #actor} (Actors represent the individuals or groups involved in the execution of the defined set of activities.) 7969 */ 7970 public List<PlanDefinitionActorComponent> getActor() { 7971 if (this.actor == null) 7972 this.actor = new ArrayList<PlanDefinitionActorComponent>(); 7973 return this.actor; 7974 } 7975 7976 /** 7977 * @return Returns a reference to <code>this</code> for easy method chaining 7978 */ 7979 public PlanDefinition setActor(List<PlanDefinitionActorComponent> theActor) { 7980 this.actor = theActor; 7981 return this; 7982 } 7983 7984 public boolean hasActor() { 7985 if (this.actor == null) 7986 return false; 7987 for (PlanDefinitionActorComponent item : this.actor) 7988 if (!item.isEmpty()) 7989 return true; 7990 return false; 7991 } 7992 7993 public PlanDefinitionActorComponent addActor() { //3 7994 PlanDefinitionActorComponent t = new PlanDefinitionActorComponent(); 7995 if (this.actor == null) 7996 this.actor = new ArrayList<PlanDefinitionActorComponent>(); 7997 this.actor.add(t); 7998 return t; 7999 } 8000 8001 public PlanDefinition addActor(PlanDefinitionActorComponent t) { //3 8002 if (t == null) 8003 return this; 8004 if (this.actor == null) 8005 this.actor = new ArrayList<PlanDefinitionActorComponent>(); 8006 this.actor.add(t); 8007 return this; 8008 } 8009 8010 /** 8011 * @return The first repetition of repeating field {@link #actor}, creating it if it does not already exist {3} 8012 */ 8013 public PlanDefinitionActorComponent getActorFirstRep() { 8014 if (getActor().isEmpty()) { 8015 addActor(); 8016 } 8017 return getActor().get(0); 8018 } 8019 8020 /** 8021 * @return {@link #action} (An action or group of actions to be taken as part of the plan. For example, in clinical care, an action would be to prescribe a particular indicated medication, or perform a particular test as appropriate. In pharmaceutical quality, an action would be the test that needs to be performed on a drug product as defined in the quality specification.) 8022 */ 8023 public List<PlanDefinitionActionComponent> getAction() { 8024 if (this.action == null) 8025 this.action = new ArrayList<PlanDefinitionActionComponent>(); 8026 return this.action; 8027 } 8028 8029 /** 8030 * @return Returns a reference to <code>this</code> for easy method chaining 8031 */ 8032 public PlanDefinition setAction(List<PlanDefinitionActionComponent> theAction) { 8033 this.action = theAction; 8034 return this; 8035 } 8036 8037 public boolean hasAction() { 8038 if (this.action == null) 8039 return false; 8040 for (PlanDefinitionActionComponent item : this.action) 8041 if (!item.isEmpty()) 8042 return true; 8043 return false; 8044 } 8045 8046 public PlanDefinitionActionComponent addAction() { //3 8047 PlanDefinitionActionComponent t = new PlanDefinitionActionComponent(); 8048 if (this.action == null) 8049 this.action = new ArrayList<PlanDefinitionActionComponent>(); 8050 this.action.add(t); 8051 return t; 8052 } 8053 8054 public PlanDefinition addAction(PlanDefinitionActionComponent t) { //3 8055 if (t == null) 8056 return this; 8057 if (this.action == null) 8058 this.action = new ArrayList<PlanDefinitionActionComponent>(); 8059 this.action.add(t); 8060 return this; 8061 } 8062 8063 /** 8064 * @return The first repetition of repeating field {@link #action}, creating it if it does not already exist {3} 8065 */ 8066 public PlanDefinitionActionComponent getActionFirstRep() { 8067 if (getAction().isEmpty()) { 8068 addAction(); 8069 } 8070 return getAction().get(0); 8071 } 8072 8073 /** 8074 * @return {@link #asNeeded} (If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example "pain", "on flare-up", etc.) 8075 */ 8076 public DataType getAsNeeded() { 8077 return this.asNeeded; 8078 } 8079 8080 /** 8081 * @return {@link #asNeeded} (If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example "pain", "on flare-up", etc.) 8082 */ 8083 public BooleanType getAsNeededBooleanType() throws FHIRException { 8084 if (this.asNeeded == null) 8085 this.asNeeded = new BooleanType(); 8086 if (!(this.asNeeded instanceof BooleanType)) 8087 throw new FHIRException("Type mismatch: the type BooleanType was expected, but "+this.asNeeded.getClass().getName()+" was encountered"); 8088 return (BooleanType) this.asNeeded; 8089 } 8090 8091 public boolean hasAsNeededBooleanType() { 8092 return this != null && this.asNeeded instanceof BooleanType; 8093 } 8094 8095 /** 8096 * @return {@link #asNeeded} (If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example "pain", "on flare-up", etc.) 8097 */ 8098 public CodeableConcept getAsNeededCodeableConcept() throws FHIRException { 8099 if (this.asNeeded == null) 8100 this.asNeeded = new CodeableConcept(); 8101 if (!(this.asNeeded instanceof CodeableConcept)) 8102 throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "+this.asNeeded.getClass().getName()+" was encountered"); 8103 return (CodeableConcept) this.asNeeded; 8104 } 8105 8106 public boolean hasAsNeededCodeableConcept() { 8107 return this != null && this.asNeeded instanceof CodeableConcept; 8108 } 8109 8110 public boolean hasAsNeeded() { 8111 return this.asNeeded != null && !this.asNeeded.isEmpty(); 8112 } 8113 8114 /** 8115 * @param value {@link #asNeeded} (If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example "pain", "on flare-up", etc.) 8116 */ 8117 public PlanDefinition setAsNeeded(DataType value) { 8118 if (value != null && !(value instanceof BooleanType || value instanceof CodeableConcept)) 8119 throw new FHIRException("Not the right type for PlanDefinition.asNeeded[x]: "+value.fhirType()); 8120 this.asNeeded = value; 8121 return this; 8122 } 8123 8124 protected void listChildren(List<Property> children) { 8125 super.listChildren(children); 8126 children.add(new Property("url", "uri", "An absolute URI that is used to identify this plan definition when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which an authoritative instance of this plan definition is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the plan definition is stored on different servers.", 0, 1, url)); 8127 children.add(new Property("identifier", "Identifier", "A formal identifier that is used to identify this plan definition when it is represented in other formats, or referenced in a specification, model, design or an instance.", 0, java.lang.Integer.MAX_VALUE, identifier)); 8128 children.add(new Property("version", "string", "The identifier that is used to identify this version of the plan definition when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the plan definition author and is not expected to be globally unique. For example, it might be a timestamp (e.g. yyyymmdd) if a managed version is not available. There is also no expectation that versions can be placed in a lexicographical sequence. To provide a version consistent with the Decision Support Service specification, use the format Major.Minor.Revision (e.g. 1.0.0). For more information on versioning knowledge assets, refer to the Decision Support Service specification. Note that a version is required for non-experimental active artifacts.", 0, 1, version)); 8129 children.add(new Property("versionAlgorithm[x]", "string|Coding", "Indicates the mechanism used to compare versions to determine which is more current.", 0, 1, versionAlgorithm)); 8130 children.add(new Property("name", "string", "A natural language name identifying the plan definition. This name should be usable as an identifier for the module by machine processing applications such as code generation.", 0, 1, name)); 8131 children.add(new Property("title", "string", "A short, descriptive, user-friendly title for the plan definition.", 0, 1, title)); 8132 children.add(new Property("subtitle", "string", "An explanatory or alternate title for the plan definition giving additional information about its content.", 0, 1, subtitle)); 8133 children.add(new Property("type", "CodeableConcept", "A high-level category for the plan definition that distinguishes the kinds of systems that would be interested in the plan definition.", 0, 1, type)); 8134 children.add(new Property("status", "code", "The status of this plan definition. Enables tracking the life-cycle of the content.", 0, 1, status)); 8135 children.add(new Property("experimental", "boolean", "A Boolean value to indicate that this plan definition is authored for testing purposes (or education/evaluation/marketing) and is not intended to be used for genuine usage.", 0, 1, experimental)); 8136 children.add(new Property("subject[x]", "CodeableConcept|Reference(Group|MedicinalProductDefinition|SubstanceDefinition|AdministrableProductDefinition|ManufacturedItemDefinition|PackagedProductDefinition)|canonical(EvidenceVariable)", "A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject)); 8137 children.add(new Property("date", "dateTime", "The date (and optionally time) when the plan definition was last significantly changed. 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 plan definition changes.", 0, 1, date)); 8138 children.add(new Property("publisher", "string", "The name of the organization or individual responsible for the release and ongoing maintenance of the plan definition.", 0, 1, publisher)); 8139 children.add(new Property("contact", "ContactDetail", "Contact details to assist a user in finding and communicating with the publisher.", 0, java.lang.Integer.MAX_VALUE, contact)); 8140 children.add(new Property("description", "markdown", "A free text natural language description of the plan definition from a consumer's perspective.", 0, 1, description)); 8141 children.add(new Property("useContext", "UsageContext", "The content was developed with a focus and intent of supporting the contexts that are listed. These contexts may be general categories (gender, age, ...) or may be references to specific programs (insurance plans, studies, ...) and may be used to assist with indexing and searching for appropriate plan definition instances.", 0, java.lang.Integer.MAX_VALUE, useContext)); 8142 children.add(new Property("jurisdiction", "CodeableConcept", "A legal or geographic region in which the plan definition is intended to be used.", 0, java.lang.Integer.MAX_VALUE, jurisdiction)); 8143 children.add(new Property("purpose", "markdown", "Explanation of why this plan definition is needed and why it has been designed as it has.", 0, 1, purpose)); 8144 children.add(new Property("usage", "markdown", "A detailed description of how the plan definition is used from a clinical perspective.", 0, 1, usage)); 8145 children.add(new Property("copyright", "markdown", "A copyright statement relating to the plan definition and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the plan definition.", 0, 1, copyright)); 8146 children.add(new Property("copyrightLabel", "string", "A short string (<50 characters), suitable for inclusion in a page footer that identifies the copyright holder, effective period, and optionally whether rights are resctricted. (e.g. 'All rights reserved', 'Some rights reserved').", 0, 1, copyrightLabel)); 8147 children.add(new Property("approvalDate", "date", "The date on which the resource content was approved by the publisher. Approval happens once when the content is officially approved for usage.", 0, 1, approvalDate)); 8148 children.add(new Property("lastReviewDate", "date", "The date on which the resource content was last reviewed. Review happens periodically after approval but does not change the original approval date.", 0, 1, lastReviewDate)); 8149 children.add(new Property("effectivePeriod", "Period", "The period during which the plan definition content was or is planned to be in active use.", 0, 1, effectivePeriod)); 8150 children.add(new Property("topic", "CodeableConcept", "Descriptive topics related to the content of the plan definition. Topics provide a high-level categorization of the definition that can be useful for filtering and searching.", 0, java.lang.Integer.MAX_VALUE, topic)); 8151 children.add(new Property("author", "ContactDetail", "An individiual or organization primarily involved in the creation and maintenance of the content.", 0, java.lang.Integer.MAX_VALUE, author)); 8152 children.add(new Property("editor", "ContactDetail", "An individual or organization primarily responsible for internal coherence of the content.", 0, java.lang.Integer.MAX_VALUE, editor)); 8153 children.add(new Property("reviewer", "ContactDetail", "An individual or organization asserted by the publisher to be primarily responsible for review of some aspect of the content.", 0, java.lang.Integer.MAX_VALUE, reviewer)); 8154 children.add(new Property("endorser", "ContactDetail", "An individual or organization asserted by the publisher to be responsible for officially endorsing the content for use in some setting.", 0, java.lang.Integer.MAX_VALUE, endorser)); 8155 children.add(new Property("relatedArtifact", "RelatedArtifact", "Related artifacts such as additional documentation, justification, or bibliographic references.", 0, java.lang.Integer.MAX_VALUE, relatedArtifact)); 8156 children.add(new Property("library", "canonical(Library)", "A reference to a Library resource containing any formal logic used by the plan definition.", 0, java.lang.Integer.MAX_VALUE, library)); 8157 children.add(new Property("goal", "", "A goal describes an expected outcome that activities within the plan are intended to achieve. For example, weight loss, restoring an activity of daily living, obtaining herd immunity via immunization, meeting a process improvement objective, meeting the acceptance criteria for a test as specified by a quality specification, etc.", 0, java.lang.Integer.MAX_VALUE, goal)); 8158 children.add(new Property("actor", "", "Actors represent the individuals or groups involved in the execution of the defined set of activities.", 0, java.lang.Integer.MAX_VALUE, actor)); 8159 children.add(new Property("action", "", "An action or group of actions to be taken as part of the plan. For example, in clinical care, an action would be to prescribe a particular indicated medication, or perform a particular test as appropriate. In pharmaceutical quality, an action would be the test that needs to be performed on a drug product as defined in the quality specification.", 0, java.lang.Integer.MAX_VALUE, action)); 8160 children.add(new Property("asNeeded[x]", "boolean|CodeableConcept", "If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example \"pain\", \"on flare-up\", etc.", 0, 1, asNeeded)); 8161 } 8162 8163 @Override 8164 public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException { 8165 switch (_hash) { 8166 case 116079: /*url*/ return new Property("url", "uri", "An absolute URI that is used to identify this plan definition when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which an authoritative instance of this plan definition is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the plan definition is stored on different servers.", 0, 1, url); 8167 case -1618432855: /*identifier*/ return new Property("identifier", "Identifier", "A formal identifier that is used to identify this plan definition when it is represented in other formats, or referenced in a specification, model, design or an instance.", 0, java.lang.Integer.MAX_VALUE, identifier); 8168 case 351608024: /*version*/ return new Property("version", "string", "The identifier that is used to identify this version of the plan definition when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the plan definition author and is not expected to be globally unique. For example, it might be a timestamp (e.g. yyyymmdd) if a managed version is not available. There is also no expectation that versions can be placed in a lexicographical sequence. To provide a version consistent with the Decision Support Service specification, use the format Major.Minor.Revision (e.g. 1.0.0). For more information on versioning knowledge assets, refer to the Decision Support Service specification. Note that a version is required for non-experimental active artifacts.", 0, 1, version); 8169 case -115699031: /*versionAlgorithm[x]*/ return new Property("versionAlgorithm[x]", "string|Coding", "Indicates the mechanism used to compare versions to determine which is more current.", 0, 1, versionAlgorithm); 8170 case 1508158071: /*versionAlgorithm*/ return new Property("versionAlgorithm[x]", "string|Coding", "Indicates the mechanism used to compare versions to determine which is more current.", 0, 1, versionAlgorithm); 8171 case 1836908904: /*versionAlgorithmString*/ return new Property("versionAlgorithm[x]", "string", "Indicates the mechanism used to compare versions to determine which is more current.", 0, 1, versionAlgorithm); 8172 case 1373807809: /*versionAlgorithmCoding*/ return new Property("versionAlgorithm[x]", "Coding", "Indicates the mechanism used to compare versions to determine which is more current.", 0, 1, versionAlgorithm); 8173 case 3373707: /*name*/ return new Property("name", "string", "A natural language name identifying the plan definition. This name should be usable as an identifier for the module by machine processing applications such as code generation.", 0, 1, name); 8174 case 110371416: /*title*/ return new Property("title", "string", "A short, descriptive, user-friendly title for the plan definition.", 0, 1, title); 8175 case -2060497896: /*subtitle*/ return new Property("subtitle", "string", "An explanatory or alternate title for the plan definition giving additional information about its content.", 0, 1, subtitle); 8176 case 3575610: /*type*/ return new Property("type", "CodeableConcept", "A high-level category for the plan definition that distinguishes the kinds of systems that would be interested in the plan definition.", 0, 1, type); 8177 case -892481550: /*status*/ return new Property("status", "code", "The status of this plan definition. Enables tracking the life-cycle of the content.", 0, 1, status); 8178 case -404562712: /*experimental*/ return new Property("experimental", "boolean", "A Boolean value to indicate that this plan definition is authored for testing purposes (or education/evaluation/marketing) and is not intended to be used for genuine usage.", 0, 1, experimental); 8179 case -573640748: /*subject[x]*/ return new Property("subject[x]", "CodeableConcept|Reference(Group|MedicinalProductDefinition|SubstanceDefinition|AdministrableProductDefinition|ManufacturedItemDefinition|PackagedProductDefinition)|canonical(EvidenceVariable)", "A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject); 8180 case -1867885268: /*subject*/ return new Property("subject[x]", "CodeableConcept|Reference(Group|MedicinalProductDefinition|SubstanceDefinition|AdministrableProductDefinition|ManufacturedItemDefinition|PackagedProductDefinition)|canonical(EvidenceVariable)", "A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject); 8181 case -1257122603: /*subjectCodeableConcept*/ return new Property("subject[x]", "CodeableConcept", "A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject); 8182 case 772938623: /*subjectReference*/ return new Property("subject[x]", "Reference(Group|MedicinalProductDefinition|SubstanceDefinition|AdministrableProductDefinition|ManufacturedItemDefinition|PackagedProductDefinition)", "A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject); 8183 case -1768521432: /*subjectCanonical*/ return new Property("subject[x]", "canonical(EvidenceVariable)", "A code, group definition, or canonical reference that describes or identifies the intended subject of the plan definition. Canonical references are allowed to support the definition of protocols for drug and substance quality specifications, and is allowed to reference a MedicinalProductDefinition, SubstanceDefinition, AdministrableProductDefinition, ManufacturedItemDefinition, or PackagedProductDefinition resource.", 0, 1, subject); 8184 case 3076014: /*date*/ return new Property("date", "dateTime", "The date (and optionally time) when the plan definition was last significantly changed. 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 plan definition changes.", 0, 1, date); 8185 case 1447404028: /*publisher*/ return new Property("publisher", "string", "The name of the organization or individual responsible for the release and ongoing maintenance of the plan definition.", 0, 1, publisher); 8186 case 951526432: /*contact*/ return new Property("contact", "ContactDetail", "Contact details to assist a user in finding and communicating with the publisher.", 0, java.lang.Integer.MAX_VALUE, contact); 8187 case -1724546052: /*description*/ return new Property("description", "markdown", "A free text natural language description of the plan definition from a consumer's perspective.", 0, 1, description); 8188 case -669707736: /*useContext*/ return new Property("useContext", "UsageContext", "The content was developed with a focus and intent of supporting the contexts that are listed. These contexts may be general categories (gender, age, ...) or may be references to specific programs (insurance plans, studies, ...) and may be used to assist with indexing and searching for appropriate plan definition instances.", 0, java.lang.Integer.MAX_VALUE, useContext); 8189 case -507075711: /*jurisdiction*/ return new Property("jurisdiction", "CodeableConcept", "A legal or geographic region in which the plan definition is intended to be used.", 0, java.lang.Integer.MAX_VALUE, jurisdiction); 8190 case -220463842: /*purpose*/ return new Property("purpose", "markdown", "Explanation of why this plan definition is needed and why it has been designed as it has.", 0, 1, purpose); 8191 case 111574433: /*usage*/ return new Property("usage", "markdown", "A detailed description of how the plan definition is used from a clinical perspective.", 0, 1, usage); 8192 case 1522889671: /*copyright*/ return new Property("copyright", "markdown", "A copyright statement relating to the plan definition and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the plan definition.", 0, 1, copyright); 8193 case 765157229: /*copyrightLabel*/ return new Property("copyrightLabel", "string", "A short string (<50 characters), suitable for inclusion in a page footer that identifies the copyright holder, effective period, and optionally whether rights are resctricted. (e.g. 'All rights reserved', 'Some rights reserved').", 0, 1, copyrightLabel); 8194 case 223539345: /*approvalDate*/ return new Property("approvalDate", "date", "The date on which the resource content was approved by the publisher. Approval happens once when the content is officially approved for usage.", 0, 1, approvalDate); 8195 case -1687512484: /*lastReviewDate*/ return new Property("lastReviewDate", "date", "The date on which the resource content was last reviewed. Review happens periodically after approval but does not change the original approval date.", 0, 1, lastReviewDate); 8196 case -403934648: /*effectivePeriod*/ return new Property("effectivePeriod", "Period", "The period during which the plan definition content was or is planned to be in active use.", 0, 1, effectivePeriod); 8197 case 110546223: /*topic*/ return new Property("topic", "CodeableConcept", "Descriptive topics related to the content of the plan definition. Topics provide a high-level categorization of the definition that can be useful for filtering and searching.", 0, java.lang.Integer.MAX_VALUE, topic); 8198 case -1406328437: /*author*/ return new Property("author", "ContactDetail", "An individiual or organization primarily involved in the creation and maintenance of the content.", 0, java.lang.Integer.MAX_VALUE, author); 8199 case -1307827859: /*editor*/ return new Property("editor", "ContactDetail", "An individual or organization primarily responsible for internal coherence of the content.", 0, java.lang.Integer.MAX_VALUE, editor); 8200 case -261190139: /*reviewer*/ return new Property("reviewer", "ContactDetail", "An individual or organization asserted by the publisher to be primarily responsible for review of some aspect of the content.", 0, java.lang.Integer.MAX_VALUE, reviewer); 8201 case 1740277666: /*endorser*/ return new Property("endorser", "ContactDetail", "An individual or organization asserted by the publisher to be responsible for officially endorsing the content for use in some setting.", 0, java.lang.Integer.MAX_VALUE, endorser); 8202 case 666807069: /*relatedArtifact*/ return new Property("relatedArtifact", "RelatedArtifact", "Related artifacts such as additional documentation, justification, or bibliographic references.", 0, java.lang.Integer.MAX_VALUE, relatedArtifact); 8203 case 166208699: /*library*/ return new Property("library", "canonical(Library)", "A reference to a Library resource containing any formal logic used by the plan definition.", 0, java.lang.Integer.MAX_VALUE, library); 8204 case 3178259: /*goal*/ return new Property("goal", "", "A goal describes an expected outcome that activities within the plan are intended to achieve. For example, weight loss, restoring an activity of daily living, obtaining herd immunity via immunization, meeting a process improvement objective, meeting the acceptance criteria for a test as specified by a quality specification, etc.", 0, java.lang.Integer.MAX_VALUE, goal); 8205 case 92645877: /*actor*/ return new Property("actor", "", "Actors represent the individuals or groups involved in the execution of the defined set of activities.", 0, java.lang.Integer.MAX_VALUE, actor); 8206 case -1422950858: /*action*/ return new Property("action", "", "An action or group of actions to be taken as part of the plan. For example, in clinical care, an action would be to prescribe a particular indicated medication, or perform a particular test as appropriate. In pharmaceutical quality, an action would be the test that needs to be performed on a drug product as defined in the quality specification.", 0, java.lang.Integer.MAX_VALUE, action); 8207 case -544329575: /*asNeeded[x]*/ return new Property("asNeeded[x]", "boolean|CodeableConcept", "If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example \"pain\", \"on flare-up\", etc.", 0, 1, asNeeded); 8208 case -1432923513: /*asNeeded*/ return new Property("asNeeded[x]", "boolean|CodeableConcept", "If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example \"pain\", \"on flare-up\", etc.", 0, 1, asNeeded); 8209 case -591717471: /*asNeededBoolean*/ return new Property("asNeeded[x]", "boolean", "If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example \"pain\", \"on flare-up\", etc.", 0, 1, asNeeded); 8210 case 1556420122: /*asNeededCodeableConcept*/ return new Property("asNeeded[x]", "CodeableConcept", "If a CodeableConcept is present, it indicates the pre-condition for performing the service. For example \"pain\", \"on flare-up\", etc.", 0, 1, asNeeded); 8211 default: return super.getNamedProperty(_hash, _name, _checkValid); 8212 } 8213 8214 } 8215 8216 @Override 8217 public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { 8218 switch (hash) { 8219 case 116079: /*url*/ return this.url == null ? new Base[0] : new Base[] {this.url}; // UriType 8220 case -1618432855: /*identifier*/ return this.identifier == null ? new Base[0] : this.identifier.toArray(new Base[this.identifier.size()]); // Identifier 8221 case 351608024: /*version*/ return this.version == null ? new Base[0] : new Base[] {this.version}; // StringType 8222 case 1508158071: /*versionAlgorithm*/ return this.versionAlgorithm == null ? new Base[0] : new Base[] {this.versionAlgorithm}; // DataType 8223 case 3373707: /*name*/ return this.name == null ? new Base[0] : new Base[] {this.name}; // StringType 8224 case 110371416: /*title*/ return this.title == null ? new Base[0] : new Base[] {this.title}; // StringType 8225 case -2060497896: /*subtitle*/ return this.subtitle == null ? new Base[0] : new Base[] {this.subtitle}; // StringType 8226 case 3575610: /*type*/ return this.type == null ? new Base[0] : new Base[] {this.type}; // CodeableConcept 8227 case -892481550: /*status*/ return this.status == null ? new Base[0] : new Base[] {this.status}; // Enumeration<PublicationStatus> 8228 case -404562712: /*experimental*/ return this.experimental == null ? new Base[0] : new Base[] {this.experimental}; // BooleanType 8229 case -1867885268: /*subject*/ return this.subject == null ? new Base[0] : new Base[] {this.subject}; // DataType 8230 case 3076014: /*date*/ return this.date == null ? new Base[0] : new Base[] {this.date}; // DateTimeType 8231 case 1447404028: /*publisher*/ return this.publisher == null ? new Base[0] : new Base[] {this.publisher}; // StringType 8232 case 951526432: /*contact*/ return this.contact == null ? new Base[0] : this.contact.toArray(new Base[this.contact.size()]); // ContactDetail 8233 case -1724546052: /*description*/ return this.description == null ? new Base[0] : new Base[] {this.description}; // MarkdownType 8234 case -669707736: /*useContext*/ return this.useContext == null ? new Base[0] : this.useContext.toArray(new Base[this.useContext.size()]); // UsageContext 8235 case -507075711: /*jurisdiction*/ return this.jurisdiction == null ? new Base[0] : this.jurisdiction.toArray(new Base[this.jurisdiction.size()]); // CodeableConcept 8236 case -220463842: /*purpose*/ return this.purpose == null ? new Base[0] : new Base[] {this.purpose}; // MarkdownType 8237 case 111574433: /*usage*/ return this.usage == null ? new Base[0] : new Base[] {this.usage}; // MarkdownType 8238 case 1522889671: /*copyright*/ return this.copyright == null ? new Base[0] : new Base[] {this.copyright}; // MarkdownType 8239 case 765157229: /*copyrightLabel*/ return this.copyrightLabel == null ? new Base[0] : new Base[] {this.copyrightLabel}; // StringType 8240 case 223539345: /*approvalDate*/ return this.approvalDate == null ? new Base[0] : new Base[] {this.approvalDate}; // DateType 8241 case -1687512484: /*lastReviewDate*/ return this.lastReviewDate == null ? new Base[0] : new Base[] {this.lastReviewDate}; // DateType 8242 case -403934648: /*effectivePeriod*/ return this.effectivePeriod == null ? new Base[0] : new Base[] {this.effectivePeriod}; // Period 8243 case 110546223: /*topic*/ return this.topic == null ? new Base[0] : this.topic.toArray(new Base[this.topic.size()]); // CodeableConcept 8244 case -1406328437: /*author*/ return this.author == null ? new Base[0] : this.author.toArray(new Base[this.author.size()]); // ContactDetail 8245 case -1307827859: /*editor*/ return this.editor == null ? new Base[0] : this.editor.toArray(new Base[this.editor.size()]); // ContactDetail 8246 case -261190139: /*reviewer*/ return this.reviewer == null ? new Base[0] : this.reviewer.toArray(new Base[this.reviewer.size()]); // ContactDetail 8247 case 1740277666: /*endorser*/ return this.endorser == null ? new Base[0] : this.endorser.toArray(new Base[this.endorser.size()]); // ContactDetail 8248 case 666807069: /*relatedArtifact*/ return this.relatedArtifact == null ? new Base[0] : this.relatedArtifact.toArray(new Base[this.relatedArtifact.size()]); // RelatedArtifact 8249 case 166208699: /*library*/ return this.library == null ? new Base[0] : this.library.toArray(new Base[this.library.size()]); // CanonicalType 8250 case 3178259: /*goal*/ return this.goal == null ? new Base[0] : this.goal.toArray(new Base[this.goal.size()]); // PlanDefinitionGoalComponent 8251 case 92645877: /*actor*/ return this.actor == null ? new Base[0] : this.actor.toArray(new Base[this.actor.size()]); // PlanDefinitionActorComponent 8252 case -1422950858: /*action*/ return this.action == null ? new Base[0] : this.action.toArray(new Base[this.action.size()]); // PlanDefinitionActionComponent 8253 case -1432923513: /*asNeeded*/ return this.asNeeded == null ? new Base[0] : new Base[] {this.asNeeded}; // DataType 8254 default: return super.getProperty(hash, name, checkValid); 8255 } 8256 8257 } 8258 8259 @Override 8260 public Base setProperty(int hash, String name, Base value) throws FHIRException { 8261 switch (hash) { 8262 case 116079: // url 8263 this.url = TypeConvertor.castToUri(value); // UriType 8264 return value; 8265 case -1618432855: // identifier 8266 this.getIdentifier().add(TypeConvertor.castToIdentifier(value)); // Identifier 8267 return value; 8268 case 351608024: // version 8269 this.version = TypeConvertor.castToString(value); // StringType 8270 return value; 8271 case 1508158071: // versionAlgorithm 8272 this.versionAlgorithm = TypeConvertor.castToType(value); // DataType 8273 return value; 8274 case 3373707: // name 8275 this.name = TypeConvertor.castToString(value); // StringType 8276 return value; 8277 case 110371416: // title 8278 this.title = TypeConvertor.castToString(value); // StringType 8279 return value; 8280 case -2060497896: // subtitle 8281 this.subtitle = TypeConvertor.castToString(value); // StringType 8282 return value; 8283 case 3575610: // type 8284 this.type = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 8285 return value; 8286 case -892481550: // status 8287 value = new PublicationStatusEnumFactory().fromType(TypeConvertor.castToCode(value)); 8288 this.status = (Enumeration) value; // Enumeration<PublicationStatus> 8289 return value; 8290 case -404562712: // experimental 8291 this.experimental = TypeConvertor.castToBoolean(value); // BooleanType 8292 return value; 8293 case -1867885268: // subject 8294 this.subject = TypeConvertor.castToType(value); // DataType 8295 return value; 8296 case 3076014: // date 8297 this.date = TypeConvertor.castToDateTime(value); // DateTimeType 8298 return value; 8299 case 1447404028: // publisher 8300 this.publisher = TypeConvertor.castToString(value); // StringType 8301 return value; 8302 case 951526432: // contact 8303 this.getContact().add(TypeConvertor.castToContactDetail(value)); // ContactDetail 8304 return value; 8305 case -1724546052: // description 8306 this.description = TypeConvertor.castToMarkdown(value); // MarkdownType 8307 return value; 8308 case -669707736: // useContext 8309 this.getUseContext().add(TypeConvertor.castToUsageContext(value)); // UsageContext 8310 return value; 8311 case -507075711: // jurisdiction 8312 this.getJurisdiction().add(TypeConvertor.castToCodeableConcept(value)); // CodeableConcept 8313 return value; 8314 case -220463842: // purpose 8315 this.purpose = TypeConvertor.castToMarkdown(value); // MarkdownType 8316 return value; 8317 case 111574433: // usage 8318 this.usage = TypeConvertor.castToMarkdown(value); // MarkdownType 8319 return value; 8320 case 1522889671: // copyright 8321 this.copyright = TypeConvertor.castToMarkdown(value); // MarkdownType 8322 return value; 8323 case 765157229: // copyrightLabel 8324 this.copyrightLabel = TypeConvertor.castToString(value); // StringType 8325 return value; 8326 case 223539345: // approvalDate 8327 this.approvalDate = TypeConvertor.castToDate(value); // DateType 8328 return value; 8329 case -1687512484: // lastReviewDate 8330 this.lastReviewDate = TypeConvertor.castToDate(value); // DateType 8331 return value; 8332 case -403934648: // effectivePeriod 8333 this.effectivePeriod = TypeConvertor.castToPeriod(value); // Period 8334 return value; 8335 case 110546223: // topic 8336 this.getTopic().add(TypeConvertor.castToCodeableConcept(value)); // CodeableConcept 8337 return value; 8338 case -1406328437: // author 8339 this.getAuthor().add(TypeConvertor.castToContactDetail(value)); // ContactDetail 8340 return value; 8341 case -1307827859: // editor 8342 this.getEditor().add(TypeConvertor.castToContactDetail(value)); // ContactDetail 8343 return value; 8344 case -261190139: // reviewer 8345 this.getReviewer().add(TypeConvertor.castToContactDetail(value)); // ContactDetail 8346 return value; 8347 case 1740277666: // endorser 8348 this.getEndorser().add(TypeConvertor.castToContactDetail(value)); // ContactDetail 8349 return value; 8350 case 666807069: // relatedArtifact 8351 this.getRelatedArtifact().add(TypeConvertor.castToRelatedArtifact(value)); // RelatedArtifact 8352 return value; 8353 case 166208699: // library 8354 this.getLibrary().add(TypeConvertor.castToCanonical(value)); // CanonicalType 8355 return value; 8356 case 3178259: // goal 8357 this.getGoal().add((PlanDefinitionGoalComponent) value); // PlanDefinitionGoalComponent 8358 return value; 8359 case 92645877: // actor 8360 this.getActor().add((PlanDefinitionActorComponent) value); // PlanDefinitionActorComponent 8361 return value; 8362 case -1422950858: // action 8363 this.getAction().add((PlanDefinitionActionComponent) value); // PlanDefinitionActionComponent 8364 return value; 8365 case -1432923513: // asNeeded 8366 this.asNeeded = TypeConvertor.castToType(value); // DataType 8367 return value; 8368 default: return super.setProperty(hash, name, value); 8369 } 8370 8371 } 8372 8373 @Override 8374 public Base setProperty(String name, Base value) throws FHIRException { 8375 if (name.equals("url")) { 8376 this.url = TypeConvertor.castToUri(value); // UriType 8377 } else if (name.equals("identifier")) { 8378 this.getIdentifier().add(TypeConvertor.castToIdentifier(value)); 8379 } else if (name.equals("version")) { 8380 this.version = TypeConvertor.castToString(value); // StringType 8381 } else if (name.equals("versionAlgorithm[x]")) { 8382 this.versionAlgorithm = TypeConvertor.castToType(value); // DataType 8383 } else if (name.equals("name")) { 8384 this.name = TypeConvertor.castToString(value); // StringType 8385 } else if (name.equals("title")) { 8386 this.title = TypeConvertor.castToString(value); // StringType 8387 } else if (name.equals("subtitle")) { 8388 this.subtitle = TypeConvertor.castToString(value); // StringType 8389 } else if (name.equals("type")) { 8390 this.type = TypeConvertor.castToCodeableConcept(value); // CodeableConcept 8391 } else if (name.equals("status")) { 8392 value = new PublicationStatusEnumFactory().fromType(TypeConvertor.castToCode(value)); 8393 this.status = (Enumeration) value; // Enumeration<PublicationStatus> 8394 } else if (name.equals("experimental")) { 8395 this.experimental = TypeConvertor.castToBoolean(value); // BooleanType 8396 } else if (name.equals("subject[x]")) { 8397 this.subject = TypeConvertor.castToType(value); // DataType 8398 } else if (name.equals("date")) { 8399 this.date = TypeConvertor.castToDateTime(value); // DateTimeType 8400 } else if (name.equals("publisher")) { 8401 this.publisher = TypeConvertor.castToString(value); // StringType 8402 } else if (name.equals("contact")) { 8403 this.getContact().add(TypeConvertor.castToContactDetail(value)); 8404 } else if (name.equals("description")) { 8405 this.description = TypeConvertor.castToMarkdown(value); // MarkdownType 8406 } else if (name.equals("useContext")) { 8407 this.getUseContext().add(TypeConvertor.castToUsageContext(value)); 8408 } else if (name.equals("jurisdiction")) { 8409 this.getJurisdiction().add(TypeConvertor.castToCodeableConcept(value)); 8410 } else if (name.equals("purpose")) { 8411 this.purpose = TypeConvertor.castToMarkdown(value); // MarkdownType 8412 } else if (name.equals("usage")) { 8413 this.usage = TypeConvertor.castToMarkdown(value); // MarkdownType 8414 } else if (name.equals("copyright")) { 8415 this.copyright = TypeConvertor.castToMarkdown(value); // MarkdownType 8416 } else if (name.equals("copyrightLabel")) { 8417 this.copyrightLabel = TypeConvertor.castToString(value); // StringType 8418 } else if (name.equals("approvalDate")) { 8419 this.approvalDate = TypeConvertor.castToDate(value); // DateType 8420 } else if (name.equals("lastReviewDate")) { 8421 this.lastReviewDate = TypeConvertor.castToDate(value); // DateType 8422 } else if (name.equals("effectivePeriod")) { 8423 this.effectivePeriod = TypeConvertor.castToPeriod(value); // Period 8424 } else if (name.equals("topic")) { 8425 this.getTopic().add(TypeConvertor.castToCodeableConcept(value)); 8426 } else if (name.equals("author")) { 8427 this.getAuthor().add(TypeConvertor.castToContactDetail(value)); 8428 } else if (name.equals("editor")) { 8429 this.getEditor().add(TypeConvertor.castToContactDetail(value)); 8430 } else if (name.equals("reviewer")) { 8431 this.getReviewer().add(TypeConvertor.castToContactDetail(value)); 8432 } else if (name.equals("endorser")) { 8433 this.getEndorser().add(TypeConvertor.castToContactDetail(value)); 8434 } else if (name.equals("relatedArtifact")) { 8435 this.getRelatedArtifact().add(TypeConvertor.castToRelatedArtifact(value)); 8436 } else if (name.equals("library")) { 8437 this.getLibrary().add(TypeConvertor.castToCanonical(value)); 8438 } else if (name.equals("goal")) { 8439 this.getGoal().add((PlanDefinitionGoalComponent) value); 8440 } else if (name.equals("actor")) { 8441 this.getActor().add((PlanDefinitionActorComponent) value); 8442 } else if (name.equals("action")) { 8443 this.getAction().add((PlanDefinitionActionComponent) value); 8444 } else if (name.equals("asNeeded[x]")) { 8445 this.asNeeded = TypeConvertor.castToType(value); // DataType 8446 } else 8447 return super.setProperty(name, value); 8448 return value; 8449 } 8450 8451 @Override 8452 public void removeChild(String name, Base value) throws FHIRException { 8453 if (name.equals("url")) { 8454 this.url = null; 8455 } else if (name.equals("identifier")) { 8456 this.getIdentifier().remove(value); 8457 } else if (name.equals("version")) { 8458 this.version = null; 8459 } else if (name.equals("versionAlgorithm[x]")) { 8460 this.versionAlgorithm = null; 8461 } else if (name.equals("name")) { 8462 this.name = null; 8463 } else if (name.equals("title")) { 8464 this.title = null; 8465 } else if (name.equals("subtitle")) { 8466 this.subtitle = null; 8467 } else if (name.equals("type")) { 8468 this.type = null; 8469 } else if (name.equals("status")) { 8470 value = new PublicationStatusEnumFactory().fromType(TypeConvertor.castToCode(value)); 8471 this.status = (Enumeration) value; // Enumeration<PublicationStatus> 8472 } else if (name.equals("experimental")) { 8473 this.experimental = null; 8474 } else if (name.equals("subject[x]")) { 8475 this.subject = null; 8476 } else if (name.equals("date")) { 8477 this.date = null; 8478 } else if (name.equals("publisher")) { 8479 this.publisher = null; 8480 } else if (name.equals("contact")) { 8481 this.getContact().remove(value); 8482 } else if (name.equals("description")) { 8483 this.description = null; 8484 } else if (name.equals("useContext")) { 8485 this.getUseContext().remove(value); 8486 } else if (name.equals("jurisdiction")) { 8487 this.getJurisdiction().remove(value); 8488 } else if (name.equals("purpose")) { 8489 this.purpose = null; 8490 } else if (name.equals("usage")) { 8491 this.usage = null; 8492 } else if (name.equals("copyright")) { 8493 this.copyright = null; 8494 } else if (name.equals("copyrightLabel")) { 8495 this.copyrightLabel = null; 8496 } else if (name.equals("approvalDate")) { 8497 this.approvalDate = null; 8498 } else if (name.equals("lastReviewDate")) { 8499 this.lastReviewDate = null; 8500 } else if (name.equals("effectivePeriod")) { 8501 this.effectivePeriod = null; 8502 } else if (name.equals("topic")) { 8503 this.getTopic().remove(value); 8504 } else if (name.equals("author")) { 8505 this.getAuthor().remove(value); 8506 } else if (name.equals("editor")) { 8507 this.getEditor().remove(value); 8508 } else if (name.equals("reviewer")) { 8509 this.getReviewer().remove(value); 8510 } else if (name.equals("endorser")) { 8511 this.getEndorser().remove(value); 8512 } else if (name.equals("relatedArtifact")) { 8513 this.getRelatedArtifact().remove(value); 8514 } else if (name.equals("library")) { 8515 this.getLibrary().remove(value); 8516 } else if (name.equals("goal")) { 8517 this.getGoal().remove((PlanDefinitionGoalComponent) value); 8518 } else if (name.equals("actor")) { 8519 this.getActor().remove((PlanDefinitionActorComponent) value); 8520 } else if (name.equals("action")) { 8521 this.getAction().remove((PlanDefinitionActionComponent) value); 8522 } else if (name.equals("asNeeded[x]")) { 8523 this.asNeeded = null; 8524 } else 8525 super.removeChild(name, value); 8526 8527 } 8528 8529 @Override 8530 public Base makeProperty(int hash, String name) throws FHIRException { 8531 switch (hash) { 8532 case 116079: return getUrlElement(); 8533 case -1618432855: return addIdentifier(); 8534 case 351608024: return getVersionElement(); 8535 case -115699031: return getVersionAlgorithm(); 8536 case 1508158071: return getVersionAlgorithm(); 8537 case 3373707: return getNameElement(); 8538 case 110371416: return getTitleElement(); 8539 case -2060497896: return getSubtitleElement(); 8540 case 3575610: return getType(); 8541 case -892481550: return getStatusElement(); 8542 case -404562712: return getExperimentalElement(); 8543 case -573640748: return getSubject(); 8544 case -1867885268: return getSubject(); 8545 case 3076014: return getDateElement(); 8546 case 1447404028: return getPublisherElement(); 8547 case 951526432: return addContact(); 8548 case -1724546052: return getDescriptionElement(); 8549 case -669707736: return addUseContext(); 8550 case -507075711: return addJurisdiction(); 8551 case -220463842: return getPurposeElement(); 8552 case 111574433: return getUsageElement(); 8553 case 1522889671: return getCopyrightElement(); 8554 case 765157229: return getCopyrightLabelElement(); 8555 case 223539345: return getApprovalDateElement(); 8556 case -1687512484: return getLastReviewDateElement(); 8557 case -403934648: return getEffectivePeriod(); 8558 case 110546223: return addTopic(); 8559 case -1406328437: return addAuthor(); 8560 case -1307827859: return addEditor(); 8561 case -261190139: return addReviewer(); 8562 case 1740277666: return addEndorser(); 8563 case 666807069: return addRelatedArtifact(); 8564 case 166208699: return addLibraryElement(); 8565 case 3178259: return addGoal(); 8566 case 92645877: return addActor(); 8567 case -1422950858: return addAction(); 8568 case -544329575: return getAsNeeded(); 8569 case -1432923513: return getAsNeeded(); 8570 default: return super.makeProperty(hash, name); 8571 } 8572 8573 } 8574 8575 @Override 8576 public String[] getTypesForProperty(int hash, String name) throws FHIRException { 8577 switch (hash) { 8578 case 116079: /*url*/ return new String[] {"uri"}; 8579 case -1618432855: /*identifier*/ return new String[] {"Identifier"};