Issues (113)

lib/Traits/DoseQuantityTrait.php (1 issue)

Severity
1
<?php
2
3
/**
4
 * The MIT License
5
 *
6
 * Copyright 2018  Peter Gee <https://github.com/pgee70>.
7
 *
8
 * Permission is hereby granted, free of charge, to any person obtaining a copy
9
 * of this software and associated documentation files (the "Software"), to deal
10
 * in the Software without restriction, including without limitation the rights
11
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12
 * copies of the Software, and to permit persons to whom the Software is
13
 * furnished to do so, subject to the following conditions:
14
 *
15
 * The above copyright notice and this permission notice shall be included in
16
 * all copies or substantial portions of the Software.
17
 *
18
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20
 * FITNESS FOR A PARTICULAR PURPOSE AND NON INFRINGEMENT. IN NO EVENT SHALL THE
21
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24
 * THE SOFTWARE.
25
 */
26
27
28
namespace i3Soft\CDA\Traits;
29
30
31
use i3Soft\CDA\DataType\Collection\Interval\AbstractInterval;
32
use i3Soft\CDA\DataType\Quantity\PhysicalQuantity\PhysicalQuantity;
33
use i3Soft\CDA\Elements\DoseQuantity;
34
35
/**
36
 * Trait DoseQuantityTrait
37
 *
38
 * @package i3Soft\CDA\Traits
39
 */
40
trait DoseQuantityTrait
41
{
42
  /** @var DoseQuantity */
43
  private $doseQuantity;
44
45
  /**
46
   * @param \DOMElement  $el
47
   * @param \DOMDocument $doc
48
   *
49
   * @return self
50
   */
51
  public function renderDoseQuantity (\DOMElement $el, \DOMDocument $doc): self
52
  {
53
    if ($this->hasDoseQuantity())
54
    {
55
      $el->appendChild($this->getDoseQuantity()->toDOMElement($doc));
56
    }
57
    return $this;
58
  }
59
60
  /**
61
   * @return bool
62
   */
63
  public function hasDoseQuantity (): bool
64
  {
65
    return NULL !== $this->doseQuantity;
66
  }
67
68
  /**
69
   *
70
   * @return DoseQuantity
71
   */
72
  public function getDoseQuantity (): DoseQuantity
73
  {
74
    return $this->doseQuantity;
75
  }
76
77
  /**
78
   *
79
   * @param AbstractInterval|PhysicalQuantity $doseQuantity
80
   *
81
   * @return self
82
   */
83
  public function setDoseQuantity ($doseQuantity): self
84
  {
85
    if ($doseQuantity instanceof AbstractInterval || $doseQuantity instanceof PhysicalQuantity)
0 ignored issues
show
$doseQuantity is always a sub-type of i3Soft\CDA\DataType\Quan...antity\PhysicalQuantity.
Loading history...
86
    {
87
      $this->doseQuantity = new DoseQuantity($doseQuantity);
88
    }
89
    return $this;
90
  }
91
}