Meter   A
last analyzed

Complexity

Total Complexity 11

Size/Duplication

Total Lines 60
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 6

Importance

Changes 0
Metric Value
dl 0
loc 60
c 0
b 0
f 0
wmc 11
lcom 1
cbo 6
rs 10

10 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 6 1
A withAttribute() 0 10 2
A withChild() 0 4 1
A withValue() 0 4 1
A withLow() 0 4 1
A withHigh() 0 4 1
A withMin() 0 4 1
A withMax() 0 4 1
A withOptimum() 0 4 1
A withForm() 0 4 1
1
<?php
2
3
namespace RoyallTheFourth\HtmlDocument\Element;
4
5
use RoyallTheFourth\HtmlDocument\Attribute\BooleanAttribute;
6
use RoyallTheFourth\HtmlDocument\Attribute\StandardAttribute;
7
use RoyallTheFourth\HtmlDocument\Set\AttributeSet;
8
use RoyallTheFourth\HtmlDocument\Set\ElementSet;
9
use RoyallTheFourth\HtmlDocument\Tag\Standard;
10
11
/**
12
 * Class Meter
13
 * @see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/meter
14
 */
15
final class Meter extends AbstractElement implements ParentElementInterface
16
{
17
    public function __construct(AttributeSet $attributes = null, ElementSet $children = null)
18
    {
19
        $this->attributes = $attributes ?? new AttributeSet();
20
        $this->children = $children ?? new ElementSet();
21
        $this->tag = new Standard('meter', $attributes, $children);
22
    }
23
24
    public function withAttribute(string $name, string $value = null): Meter
25
    {
26
        if ($value) {
0 ignored issues
show
Bug Best Practice introduced by
The expression $value of type null|string is loosely compared to true; this is ambiguous if the string can be empty. You might want to explicitly use !== null instead.

In PHP, under loose comparison (like ==, or !=, or switch conditions), values of different types might be equal.

For string values, the empty string '' is a special case, in particular the following results might be unexpected:

''   == false // true
''   == null  // true
'ab' == false // false
'ab' == null  // false

// It is often better to use strict comparison
'' === false // false
'' === null  // false
Loading history...
27
            $attribute = new StandardAttribute($name, $value);
28
        } else {
29
            $attribute = new BooleanAttribute($name);
30
        }
31
32
        return new Meter($this->attributes->add($attribute), $this->children);
33
    }
34
35
    public function withChild(ElementInterface $element): Meter
36
    {
37
        return new Meter($this->attributes, $this->children->add($element));
38
    }
39
    
40
    public function withValue($number): Meter
41
    {
42
        return $this->withAttribute('value', $number);
43
    }
44
45
    public function withLow($number): Meter
46
    {
47
        return $this->withAttribute('low', $number);
48
    }
49
50
    public function withHigh($number): Meter
51
    {
52
        return $this->withAttribute('high', $number);
53
    }
54
55
    public function withMin($number): Meter
56
    {
57
        return $this->withAttribute('min', $number);
58
    }
59
60
    public function withMax($number): Meter
61
    {
62
        return $this->withAttribute('max', $number);
63
    }
64
65
    public function withOptimum($number): Meter
66
    {
67
        return $this->withAttribute('optimum', $number);
68
    }
69
70
    public function withForm(string $id): Meter
71
    {
72
        return $this->withAttribute('form', $id);
73
    }
74
}
75