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

Page_Enqueue_Action   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 44
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
wmc 4
eloc 11
c 0
b 0
f 0
dl 0
loc 44
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A __invoke() 0 9 3
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * Class used to enqueue all the assets for a page or group.
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_Enqueue_Action {
31
32
	/**
33
	 * The hook being enqueued
34
	 *
35
	 * @var string
36
	 */
37
	protected $hook;
38
39
	/**
40
	 * The current page being enqueued
41
	 *
42
	 * @var Page
43
	 */
44
	protected $page;
45
46
	/**
47
	 * The option group being enqueued
48
	 *
49
	 * @var Abstract_Group|null
50
	 */
51
	protected $group;
52
53
	public function __construct( string $hook, Page $page, ?Abstract_Group $group = null ) {
54
		$this->hook  = $hook;
55
		$this->page  = $page;
56
		$this->group = $group;
57
	}
58
59
	/**
60
	 * The callback method for the class.
61
	 *
62
	 * @param string $page_hook
63
	 * @return void
64
	 */
65
	public function __invoke( string $page_hook ) {
66
		if ( $page_hook === $this->hook ) {
67
68
			// Register hooks for the group if part of group
69
			if ( null !== $this->group ) {
70
				$this->group->enqueue( $this->group, $this->page );
71
			}
72
73
			$this->page->enqueue( $this->page );
74
		}
75
	}
76
}
77