Issues (113)

lib/Traits/EffectiveTimeTrait.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\IntervalOfTime;
32
use i3Soft\CDA\DataType\Collection\Interval\PeriodicIntervalOfTime;
33
use i3Soft\CDA\DataType\Quantity\DateAndTime\TimeStamp;
34
use i3Soft\CDA\Elements\EffectiveTime;
35
36
/**
37
 * Trait EffectiveTimeTrait
38
 *
39
 * @package i3Soft\CDA\Traits
40
 */
41
trait EffectiveTimeTrait
42
{
43
  /** @var  EffectiveTime */
44
  private $effectiveTime;
45
46
  /**
47
   * @param \DOMElement  $el
48
   * @param \DOMDocument $doc
49
   *
50
   * @return self
51
   */
52
  public function renderEffectiveTime (\DOMElement $el, \DOMDocument $doc): self
53
  {
54
    if ($this->hasEffectiveTime())
55
    {
56
      $el->appendChild($this->getEffectiveTime()->toDOMElement($doc));
57
    }
58
    return $this;
59
  }
60
61
  /**
62
   * @return bool
63
   */
64
  public function hasEffectiveTime (): bool
65
  {
66
    return NULL !== $this->effectiveTime;
67
  }
68
69
  /**
70
   * @return EffectiveTime
71
   */
72
  public function getEffectiveTime (): EffectiveTime
73
  {
74
    return $this->effectiveTime;
75
  }
76
77
  /**
78
   * can take a number of input parameter class types, converts to effective time.
79
   *
80
   * @param TimeStamp|PeriodicIntervalOfTime|IntervalOfTime|EffectiveTime $in
81
   *
82
   * @return self
83
   */
84
  public function setEffectiveTime ($in): self
85
  {
86
    if ($in instanceof TimeStamp
87
        || $in instanceof PeriodicIntervalOfTime
88
        || $in instanceof IntervalOfTime)
89
    {
90
      $this->effectiveTime = new EffectiveTime($in);
91
    }
92
    elseif ($in instanceof EffectiveTime)
0 ignored issues
show
$in is always a sub-type of i3Soft\CDA\Elements\EffectiveTime.
Loading history...
93
    {
94
      $this->effectiveTime = $in;
95
    }
96
    return $this;
97
  }
98
}