Passed
Push — develop ( d3c53a...e28085 )
by nguereza
14:20
created

ViewContext::set()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
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 2
dl 0
loc 5
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
 *
13
 * Permission is hereby granted, free of charge, to any person obtaining a copy
14
 * of this software and associated documentation files (the "Software"), to deal
15
 * in the Software without restriction, including without limitation the rights
16
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
17
 * copies of the Software, and to permit persons to whom the Software is
18
 * furnished to do so, subject to the following conditions:
19
 *
20
 * The above copyright notice and this permission notice shall be included in all
21
 * copies or substantial portions of the Software.
22
 *
23
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
24
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
26
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
28
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
29
 * SOFTWARE.
30
 */
31
32
declare(strict_types=1);
33
34
namespace Platine\Framework\Helper;
35
36
use ArrayAccess;
37
38
/**
39
 * @class ViewContext
40
 * @package Platine\Framework\Helper
41
 * @template T
42
 * @implements ArrayAccess<string, mixed>
43
 */
44
class ViewContext implements ArrayAccess
45
{
46
    /**
47
     * The context data
48
     * @var array<string, mixed>
49
     */
50
    protected array $data = [];
51
52
    /**
53
     * Return all data
54
     * @return array<string, mixed>
55
     */
56
    public function all(): array
57
    {
58
        return $this->data;
59
    }
60
61
    /**
62
     * Set the context data
63
     * @param string $name
64
     * @param mixed $value
65
     * @return $this
66
     */
67
    public function set(string $name, mixed $value): self
68
    {
69
        $this->data[$name] = $value;
70
71
        return $this;
72
    }
73
74
    /**
75
     *
76
     * @param string $name
77
     * @return mixed
78
     */
79
    public function get(string $name): mixed
80
    {
81
        return $this->data[$name] ?? null;
82
    }
83
84
    /**
85
     * {@inheritodc}
86
     */
87
    public function offsetExists(mixed $offset): bool
88
    {
89
        return isset($this->data[$offset]);
90
    }
91
92
    /**
93
     * {@inheritodc}
94
     */
95
    public function offsetGet(mixed $offset): mixed
96
    {
97
        return $this->get($offset);
98
    }
99
100
    /**
101
     * {@inheritodc}
102
     * @param string $offset
103
     */
104
    public function offsetSet(mixed $offset, mixed $value): void
105
    {
106
        $this->set($offset, $value);
107
    }
108
109
    /**
110
     * {@inheritodc}
111
     */
112
    public function offsetUnset(mixed $offset): void
113
    {
114
        unset($this->data[$offset]);
115
    }
116
}
117