Passed
Pull Request — master (#16)
by Glynn
02:35
created

Page_Load_Action   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 34
Duplicated Lines 0 %

Importance

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

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __invoke() 0 7 2
A __construct() 0 3 1
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * Class used to trigger preloaded actions on all pages (and groups.)
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_Admin_Menu
23
 */
24
25
namespace PinkCrab\Perique_Admin_Menu\Registrar;
26
27
use PinkCrab\Perique_Admin_Menu\Page\Page;
28
use PinkCrab\Perique_Admin_Menu\Group\Abstract_Group;
29
30
class Page_Load_Action {
31
32
33
	/**
34
	 * The current page being enqueued
35
	 *
36
	 * @var Page
37
	 */
38
	protected $page;
39
40
	/**
41
	 * The option group being enqueued
42
	 *
43
	 * @var Abstract_Group|null
44
	 */
45
	protected $group;
46
47
	public function __construct( Page $page, ?Abstract_Group $group = null ) {
48
		$this->page  = $page;
49
		$this->group = $group;
50
	}
51
52
	/**
53
	 * The callback method for the class.
54
	 *
55
	 * @return void
56
	 */
57
	public function __invoke() {
58
		// Register hooks for the group if part of group
59
		if ( null !== $this->group ) {
60
			$this->group->load( $this->group, $this->page );
61
		}
62
63
		$this->page->load( $this->page );
64
	}
65
}
66