Completed
Push — master ( 7945de...f1a59c )
by WEBEWEB
02:16
created

NavigationTreeHelper::activeNodes()   A

Complexity

Conditions 5
Paths 6

Size

Total Lines 27

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 27
c 0
b 0
f 0
rs 9.1768
cc 5
nc 6
nop 3
1
<?php
2
3
/*
4
 * This file is part of the core-bundle package.
5
 *
6
 * (c) 2018 WEBEWEB
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace WBW\Bundle\CoreBundle\Navigation;
13
14
use Symfony\Component\HttpFoundation\Request;
15
16
/**
17
 * Navigation tree helper.
18
 *
19
 * @author webeweb <https://github.com/webeweb/>
20
 * @package WBW\Bundle\CoreBundle\Navigation
21
 */
22
class NavigationTreeHelper {
23
24
    /**
25
     * Actives the nodes.
26
     *
27
     * @param Request $request The request.
28
     * @param array $nodes The nodes.
29
     * @param int $level The node level.
30
     * @return bool Returns true in case of success, false othewise.
31
     */
32
    protected static function activeNodes(Request $request, array $nodes = [], $level = 0) {
33
34
        $result = false;
35
36
        foreach ($nodes as $n) {
37
38
            if (false === ($n instanceof AbstractNavigationNode)) {
39
                continue;
40
            }
41
42
            if (true === self::nodeMatch($n, $request)) {
43
                $current = true;
44
            } else {
45
                $current = self::activeNodes($request, $n->getNodes(), $level + 1);
46
            }
47
48
            if (false === $current) {
49
                continue;
50
            }
51
52
            $n->setActive(true);
53
54
            $result = true;
55
        }
56
57
        return $result;
58
    }
59
60
    /**
61
     * Active the tree.
62
     *
63
     * @param NavigationTree $tree The tree.
64
     * @param Request $request The request.
65
     * @return void
66
     */
67
    public static function activeTree(NavigationTree $tree, Request $request) {
68
        self::activeNodes($request, $tree->getNodes());
69
    }
70
71
    /**
72
     * Get the breadcrumbs.
73
     *
74
     * @param AbstractNavigationNode $node The tree.
75
     * @return AsbtractNavigationNode[] Returns the breadcrumbs.
76
     */
77
    public static function getBreadcrumbs(AbstractNavigationNode $node) {
78
79
        $breadcrumbs = [];
80
81
        if (true === ($node instanceof NavigationNode || $node instanceof BreadcrumbNode) && true === $node->getActive()) {
82
            $breadcrumbs[] = $node;
83
        }
84
85
        foreach ($node->getNodes() as $current) {
86
            if (false === ($current instanceof AbstractNavigationNode)) {
87
                continue;
88
            }
89
            $breadcrumbs = array_merge($breadcrumbs, self::getBreadcrumbs($current));
90
        }
91
92
        return $breadcrumbs;
93
    }
94
95
    /**
96
     * Determines if a node match an URL.
97
     *
98
     * @param AbstractNavigationNode $node The node.
99
     * @param Request $request The request.
100
     * @return bool Returns true in case of success, false otherwise.
101
     */
102
    protected static function nodeMatch(AbstractNavigationNode $node, Request $request) {
103
104
        $result = false;
105
106
        switch ($node->getMatcher()) {
107
108
            case NavigationInterface::NAVIGATION_MATCHER_REGEXP:
109
                $result = preg_match("/" . $node->getUri() . "/", $request->getUri());
110
                break;
111
112
            case NavigationInterface::NAVIGATION_MATCHER_ROUTER:
113
                $result = $request->get("_route") === $node->getUri();
114
                break;
115
116
            case NavigationInterface::NAVIGATION_MATCHER_URL:
117
                $result = $request->getUri() === $node->getUri() || $request->getRequestUri() === $node->getUri();
118
                break;
119
        }
120
121
        return boolval($result);
122
    }
123
}
124