Issues (113)

lib/Traits/AuthoringDeviceTrait.php (1 issue)

Labels
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\Elements\AuthoringDevice;
32
33
/**
34
 * Trait AuthoringDeviceTrait
35
 *
36
 * @package i3Soft\CDA\Traits
37
 */
38
trait AuthoringDeviceTrait
39
{
40
  /** @var AuthoringDevice */
41
  private $assignedAuthoringDevice;
42
43
  /**
44
   * @return bool
45
   */
46
  public function hasAssignedAuthoringDevice (): bool
47
  {
48
    return NULL !== $this->assignedAuthoringDevice;
49
  }
50
51
  /**
52
   * @param \DOMElement  $el
53
   * @param \DOMDocument $doc
54
   *
55
   * @return self
56
   */
57
  public function renderAssignedAuthoringDevice (\DOMElement $el, \DOMDocument $doc): self
58
  {
59
    if ($this->hasAssignedEntity())
0 ignored issues
show
It seems like hasAssignedEntity() must be provided by classes using this trait. How about adding it as abstract method to this trait? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

59
    if ($this->/** @scrutinizer ignore-call */ hasAssignedEntity())
Loading history...
60
    {
61
      $el->appendChild($this->getAssignedAuthoringDevice()->toDOMElement($doc));
62
    }
63
    return $this;
64
  }
65
66
  /**
67
   * @return AuthoringDevice
68
   */
69
  public function getAssignedAuthoringDevice (): AuthoringDevice
70
  {
71
    return $this->assignedAuthoringDevice;
72
  }
73
74
  /**
75
   * @param AuthoringDevice $assignedAuthoringDevice
76
   *
77
   * @return self
78
   */
79
  public function setAssignedAuthoringDevice (AuthoringDevice $assignedAuthoringDevice): self
80
  {
81
    $this->assignedAuthoringDevice = $assignedAuthoringDevice;
82
    return $this;
83
  }
84
85
}