Passed
Pull Request — master (#79)
by Glynn
05:50
created

Component   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 29
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 1
Metric Value
wmc 3
eloc 9
c 1
b 0
f 1
dl 0
loc 29
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A get_variables() 0 13 2
A template() 0 2 1
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * The base component class.
7
 *
8
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
9
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
10
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
11
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
12
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
13
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
14
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
15
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
16
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
17
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
18
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
19
 *
20
 * @author Glynn Quelch <[email protected]>
21
 * @license http://www.opensource.org/licenses/mit-license.html  MIT License
22
 * @package PinkCrab\Perique\View
23
 * @since 1.2.0
24
 */
25
26
namespace PinkCrab\Perique\Services\View\Component;
27
28
abstract class Component {
29
30
	/**
31
	 * Returns all the variables as an array.
32
	 *
33
	 * @return array<string, mixed>
34
	 */
35
	public function get_variables(): array {
36
		// Get all Private, public and protected properties.
37
		$reflect = new \ReflectionClass( get_class( $this ) );
38
		$vars    = array();
39
40
		foreach ( $reflect->getProperties( \ReflectionProperty::IS_PUBLIC | \ReflectionProperty::IS_PRIVATE | \ReflectionProperty::IS_PROTECTED )
41
			as $var
42
		) {
43
			$var->setAccessible( true );
44
			$vars[ $var->getName() ] = $var->getValue( $this );
45
		}
46
47
		return $vars;
48
	}
49
50
	/**
51
	 * Returns the defined template path.
52
	 *
53
	 * @return string|null
54
	 */
55
	public function template(): ?string {
56
		return null;
57
	}
58
}
59