Passed
Push — develop ( fdade1...99650f )
by BENARD
02:15
created

ArticleStatus::getStatusChoices()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 6
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 4
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 6
rs 10
1
<?php
2
3
declare(strict_types=1);
4
5
namespace ProjetNormandie\ArticleBundle\ValueObject;
6
7
use Webmozart\Assert\Assert;
8
9
class ArticleStatus
10
{
11
    public const string UNDER_CONSTRUCTION = 'UNDER CONSTRUCTION';
0 ignored issues
show
Bug introduced by
A parse error occurred: Syntax error, unexpected T_STRING, expecting '=' on line 11 at column 24
Loading history...
12
    public const string PUBLISHED = 'PUBLISHED';
13
    public const string CANCELED = 'CANCELED';
14
15
    public const array VALUES = [
16
        self::UNDER_CONSTRUCTION,
17
        self::PUBLISHED,
18
        self::CANCELED,
19
    ];
20
21
    private string $value;
22
23
    public function __construct(string $value)
24
    {
25
        self::inArray($value);
26
27
        $this->value = $value;
28
    }
29
30
    public static function inArray(string $value): void
31
    {
32
        Assert::inArray($value, self::VALUES);
33
    }
34
35
    public function getValue(): string
36
    {
37
        return $this->value;
38
    }
39
40
    public function isPublished(): bool
41
    {
42
        return $this->value === self::PUBLISHED;
43
    }
44
45
    public function __toString(): string
46
    {
47
        return $this->value;
48
    }
49
50
    /**
51
     * @return string[]
52
     */
53
    public static function getStatusChoices(): array
54
    {
55
        return [
56
            self::UNDER_CONSTRUCTION => self::UNDER_CONSTRUCTION,
57
            self::PUBLISHED => self::PUBLISHED,
58
            self::CANCELED => self::CANCELED
59
        ];
60
    }
61
}
62