Passed
Push — develop ( 369a61...0eb5cb )
by nguereza
13:53
created

Link::setStyle()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 2
c 1
b 0
f 0
nc 1
nop 1
dl 0
loc 4
rs 10
1
<?php
2
3
/**
4
 * Platine Framework
5
 *
6
 * Platine Framework is a lightweight, high-performance, simple and elegant
7
 * PHP Web framework
8
 *
9
 * This content is released under the MIT License (MIT)
10
 *
11
 * Copyright (c) 2020 Platine Framework
12
 * Copyright (c) 2015 JBZoo Content Construction Kit (CCK)
13
 *
14
 * Permission is hereby granted, free of charge, to any person obtaining a copy
15
 * of this software and associated documentation files (the "Software"), to deal
16
 * in the Software without restriction, including without limitation the rights
17
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
18
 * copies of the Software, and to permit persons to whom the Software is
19
 * furnished to do so, subject to the following conditions:
20
 *
21
 * The above copyright notice and this permission notice shall be included in all
22
 * copies or substantial portions of the Software.
23
 *
24
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
25
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
26
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
27
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
28
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
29
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
30
 * SOFTWARE.
31
 */
32
33
/**
34
 * @file Link.php
35
 *
36
 * The Graph Link class
37
 *
38
 *  @package    Platine\Framework\Helper\Mermaid\Graph
39
 *  @author Platine Developers Team
40
 *  @copyright  Copyright (c) 2020
41
 *  @license    http://opensource.org/licenses/MIT  MIT License
42
 *  @link   https://www.platine-php.com
43
 *  @version 1.0.0
44
 *  @filesource
45
 */
46
declare(strict_types=1);
47
48
namespace Platine\Framework\Helper\Mermaid\Graph;
49
50
use Stringable;
51
52
/**
53
 * @class Link
54
 * @package Platine\Framework\Helper\Mermaid\Graph
55
 */
56
class Link implements Stringable
57
{
58
    /**
59
     * Constants
60
    */
61
    public const ARROW  = 1;
62
    public const LINE   = 2;
63
    public const DOTTED = 3;
64
    public const THICK  = 4;
65
66
    /**
67
     * The link template
68
     */
69
    protected const TEMPLATES = [
70
        self::ARROW  => ['-->', '-->|%s|'],
71
        self::LINE   => [' --- ', '---|%s|'],
72
        self::DOTTED => ['-.->', '-. %s .-> '],
73
        self::THICK  => [' ==> ', ' == %s ==> '],
74
    ];
75
76
    /**
77
     * The source node
78
     * @var Node
79
     */
80
    protected Node $sourceNode;
81
82
    /**
83
     * The target node
84
     * @var Node
85
     */
86
    protected Node $targetNode;
87
88
    /**
89
     * The link style
90
     * @var int
91
     */
92
    protected int $style = self::ARROW;
93
94
    /**
95
     * The link text
96
     * @var string
97
     */
98
    protected string $text = '';
99
100
    /**
101
     * Create new instance
102
     * @param Node $source
103
     * @param Node $target
104
     * @param string $text
105
     * @param int $style
106
     */
107
    public function __construct(
108
        Node $source,
109
        Node $target,
110
        string $text = '',
111
        int $style = self::ARROW
112
    ) {
113
        $this->sourceNode = $source;
114
        $this->targetNode = $target;
115
        $this->text = $text;
116
        $this->style = $style;
117
    }
118
119
    /**
120
     * Set the link style
121
     * @param int $style
122
     * @return $this
123
     */
124
    public function setStyle(int $style): self
125
    {
126
        $this->style = $style;
127
        return $this;
128
    }
129
130
    /**
131
     * Return the link string representation
132
     * @return string
133
     */
134
    public function __toString(): string
135
    {
136
        $line = self::TEMPLATES[$this->style][0];
137
        if (!empty($this->text)) {
138
            $line = sprintf(
139
                self::TEMPLATES[$this->style][1],
140
                Helper::escape($this->text)
141
            );
142
        }
143
144
        return sprintf(
145
            '%s%s%s;',
146
            $this->sourceNode->getId(),
147
            $line,
148
            $this->targetNode->getId()
149
        );
150
    }
151
}
152