mirror of
https://github.com/Mibew/handlebars.php-helpers.git
synced 2025-03-14 09:44:11 +03:00
Add ifBetweenLeftClosed helper
This commit is contained in:
parent
dfe567feac
commit
e2f255cfa5
@ -34,6 +34,7 @@ class Helpers extends BaseHelpers
|
||||
$this->add('ifMore', new IfMoreHelper());
|
||||
$this->add('ifBetween', new IfBetweenHelper());
|
||||
$this->add('ifBetweenClosed', new IfBetweenClosedHelper());
|
||||
$this->add('ifBetweenLeftClosed', new IfBetweenLeftClosedHelper());
|
||||
$this->add('unlessEqual', new UnlessEqualHelper());
|
||||
}
|
||||
}
|
||||
|
49
src/Comparison/IfBetweenLeftClosedHelper.php
Normal file
49
src/Comparison/IfBetweenLeftClosedHelper.php
Normal file
@ -0,0 +1,49 @@
|
||||
<?php
|
||||
/*
|
||||
* This file is part of Handlebars.php Helpers Set
|
||||
*
|
||||
* (c) Dmitriy Simushev <simushevds@gmail.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace JustBlackBird\HandlebarsHelpers\Comparison;
|
||||
|
||||
use Handlebars\Helper as HelperInterface;
|
||||
|
||||
/**
|
||||
* Conditional helper that checks if one value is between two another values.
|
||||
*
|
||||
* Only left border of the interval is included into comparison. That's why in
|
||||
* cases where the value under comparision is equal to left border the result
|
||||
* of "between left closed" operator is true but when the value under compatison
|
||||
* is equal to right border the result of "between left closed" is false.
|
||||
*
|
||||
* Example of usage:
|
||||
* ```handlebars
|
||||
* {{#ifBetweenLeftClosed value leftBorder rightBorder}}
|
||||
* The first argument is between borders.
|
||||
* {{else}}
|
||||
* The first argument is not between the borders.
|
||||
* {{/ifBetweenLeftClosed}}
|
||||
* ```
|
||||
*
|
||||
* @author Dmitriy Simushev <simushevds@gmail.com>
|
||||
*/
|
||||
class IfBetweenLeftClosedHelper extends AbstractComparisonHelper implements HelperInterface
|
||||
{
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
protected function evaluateCondition($args)
|
||||
{
|
||||
if (count($args) != 3) {
|
||||
throw new \InvalidArgumentException(
|
||||
'"ifBetweenLeftClosed" helper expects exactly three arguments.'
|
||||
);
|
||||
}
|
||||
|
||||
return ($args[0] >= $args[1]) && ($args[0] < $args[2]);
|
||||
}
|
||||
}
|
@ -46,6 +46,7 @@ class HelpersTest extends \PHPUnit_Framework_TestCase
|
||||
array('ifMore', '\\JustBlackBird\\HandlebarsHelpers\\Comparison\\IfMoreHelper'),
|
||||
array('ifBetween', '\\JustBlackBird\\HandlebarsHelpers\\Comparison\\IfBetweenHelper'),
|
||||
array('ifBetweenClosed', '\\JustBlackBird\\HandlebarsHelpers\\Comparison\\IfBetweenClosedHelper'),
|
||||
array('ifBetweenLeftClosed', '\\JustBlackBird\\HandlebarsHelpers\\Comparison\\IfBetweenLeftClosedHelper'),
|
||||
array('unlessEqual', '\\JustBlackBird\\HandlebarsHelpers\\Comparison\\UnlessEqualHelper'),
|
||||
);
|
||||
}
|
||||
|
93
tests/Comparison/IfBetweenLeftClosedHelperTest.php
Normal file
93
tests/Comparison/IfBetweenLeftClosedHelperTest.php
Normal file
@ -0,0 +1,93 @@
|
||||
<?php
|
||||
/*
|
||||
* This file is part of Handlebars.php Helpers Set
|
||||
*
|
||||
* (c) Dmitriy Simushev <simushevds@gmail.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace JustBlackBird\HandlebarsHelpers\Tests\Comparison;
|
||||
|
||||
use JustBlackBird\HandlebarsHelpers\Comparison\IfBetweenLeftClosedHelper;
|
||||
|
||||
/**
|
||||
* Test class for "ifBetweenLeftClosed" helper.
|
||||
*
|
||||
* @author Dmitriy Simushev <simushevds@gmail.com>
|
||||
*/
|
||||
class IfBetweenLeftClosedHelperTest extends \PHPUnit_Framework_TestCase
|
||||
{
|
||||
/**
|
||||
* Tests conditions work as expected.
|
||||
*
|
||||
* @dataProvider conditionProvider
|
||||
*/
|
||||
public function testCondition($value, $left, $right, $is_between)
|
||||
{
|
||||
$helpers = new \Handlebars\Helpers(array('ifBetweenLeftClosed' => new IfBetweenLeftClosedHelper()));
|
||||
$engine = new \Handlebars\Handlebars(array('helpers' => $helpers));
|
||||
|
||||
$this->assertEquals(
|
||||
$engine->render(
|
||||
'{{#ifBetweenLeftClosed value left right}}true{{else}}false{{/ifBetweenLeftClosed}}',
|
||||
array(
|
||||
'value' => $value,
|
||||
'left' => $left,
|
||||
'right' => $right,
|
||||
)
|
||||
),
|
||||
$is_between ? 'true' : 'false'
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* A data provider for testCondition method.
|
||||
*/
|
||||
public function conditionProvider()
|
||||
{
|
||||
return array(
|
||||
// The value is less than left border.
|
||||
array(2, 10, 12, false),
|
||||
// The value equals to the left border.
|
||||
array(0, 0, 42, true),
|
||||
// The value equals to the right border.
|
||||
array(9, 0, 9, false),
|
||||
// The value is more than the right border.
|
||||
array(75, 10, 12, false),
|
||||
// The value is between borders.
|
||||
array(58, 11, 134, true),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests that exception is thrown if wrong number of arguments is used.
|
||||
*
|
||||
* @expectedException InvalidArgumentException
|
||||
* @dataProvider wrongArgumentsProvider
|
||||
*/
|
||||
public function testArgumentsCount($template)
|
||||
{
|
||||
$helpers = new \Handlebars\Helpers(array('ifBetweenLeftClosed' => new IfBetweenLeftClosedHelper()));
|
||||
$engine = new \Handlebars\Handlebars(array('helpers' => $helpers));
|
||||
|
||||
$engine->render($template, array());
|
||||
}
|
||||
|
||||
/**
|
||||
* A data provider for testArgumentsCount method.
|
||||
*/
|
||||
public function wrongArgumentsProvider()
|
||||
{
|
||||
return array(
|
||||
// Not enough arguments
|
||||
array('{{#ifBetweenLeftClosed}}yes{{else}}no{{/ifBetweenLeftClosed}}'),
|
||||
// Still not enough arguments
|
||||
array('{{#ifBetweenLeftClosed 1}}yes{{else}}no{{/ifBetweenLeftClosed}}'),
|
||||
array('{{#ifBetweenLeftClosed 1 2}}yes{{else}}no{{/ifBetweenLeftClosed}}'),
|
||||
// Too much arguments
|
||||
array('{{#ifBetweenLeftClosed 1 2 3 4}}yes{{else}}no{{/ifBetweenLeftClosed}}'),
|
||||
);
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user