Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
100.00% |
1 / 1 |
|
100.00% |
7 / 7 |
CRAP | |
100.00% |
23 / 23 |
LoopFactory | |
100.00% |
1 / 1 |
|
100.00% |
7 / 7 |
10 | |
100.00% |
23 / 23 |
newLoop | |
100.00% |
1 / 1 |
1 | |
100.00% |
2 / 2 |
|||
addLoopStack | |
100.00% |
1 / 1 |
2 | |
100.00% |
5 / 5 |
|||
getStack | |
100.00% |
1 / 1 |
1 | |
100.00% |
1 / 1 |
|||
reset | |
100.00% |
1 / 1 |
1 | |
100.00% |
2 / 2 |
|||
loop | |
100.00% |
1 / 1 |
1 | |
100.00% |
3 / 3 |
|||
looped | |
100.00% |
1 / 1 |
2 | |
100.00% |
4 / 4 |
|||
endLoop | |
100.00% |
1 / 1 |
2 | |
100.00% |
6 / 6 |
<?php | |
/** | |
* Manages the Loop instances | |
*/ | |
namespace Radic\BladeExtensions\Helpers; | |
/** | |
* Manages the Loop instances | |
* | |
* @package Radic\BladeExtensions | |
* @subpackage Helpers | |
* @version 2.1.0 | |
* @author Robin Radic | |
* @license MIT License - http://radic.mit-license.org | |
* @copyright (2011-2014, Robin Radic - Radic Technologies | |
* @link http://robin.radic.nl/blade-extensions | |
* | |
*/ | |
class LoopFactory | |
{ | |
/** | |
* The stack of Loop instances | |
* | |
* @var array $stack | |
*/ | |
protected $stack = array(); | |
/** | |
* Creates a new loop with the given array and adds it to the stack | |
* | |
* @param array $items The array that will be iterated | |
*/ | |
public function newLoop($items) | |
{ | |
$this->addLoopStack(new Loop($this, $items)); | |
} | |
/** | |
* Adds a Loop to the stack | |
* | |
* @param Loop $stackItem | |
*/ | |
protected function addLoopStack(Loop $stackItem) | |
{ | |
// Check stack for parent loop to register it with this loop | |
if (count($this->stack) > 0) { | |
$stackItem->setParentLoop(last($this->stack)); | |
} | |
array_push($this->stack, $stackItem); | |
} | |
/** | |
* Returns the stack | |
* | |
* @return array | |
*/ | |
public function getStack() | |
{ | |
return $this->stack; | |
} | |
/** | |
* Resets the stack | |
*/ | |
public function reset() | |
{ | |
$this->stack = array(); | |
} | |
/** | |
* To be called first inside the foreach loop. Returns the current loop | |
* | |
* @return Loop $current The current loop data | |
*/ | |
public function loop() | |
{ | |
$current = end($this->stack); | |
$current->before(); | |
return $current; | |
} | |
/** | |
* To be called before the end of the loop | |
*/ | |
public function looped() | |
{ | |
if (! empty($this->stack)) { | |
end($this->stack)->after(); | |
} | |
} | |
/** | |
* Should be called after the loop has finished | |
* | |
* @param $loop | |
*/ | |
public function endLoop(&$loop) | |
{ | |
array_pop($this->stack); | |
if (count($this->stack) > 0) { | |
// This loop was inside another loop. We persist the loop variable and assign back the parent loop | |
$loop = end($this->stack); | |
} else { | |
// This loop was not inside another loop. We remove the var | |
//echo "l:(" . count($this->stack) . ") "; | |
$loop = null; | |
} | |
} | |
} |