Maslosoft Manganel API
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
<?php
/**
* This software package is licensed under `AGPL, Commercial` license[s].
*
* @package maslosoft/manganel
* @license AGPL, Commercial
*
* @copyright Copyright (c) Peter Maselkowski <pmaselkowski@gmail.com>
* @link https://maslosoft.com/manganel/
*/
namespace Maslosoft\Manganel\Decorators\QueryBuilder;
use Maslosoft\Mangan\Criteria\ConditionDecorator as ManganCD;
use Maslosoft\Mangan\Meta\ManganMeta;
use Maslosoft\Manganel\Interfaces\ManganelAwareInterface;
use Maslosoft\Manganel\Interfaces\QueryBuilder\ConditionDecoratorInterface;
use Maslosoft\Manganel\SearchCriteria;
use Maslosoft\Manganel\Traits\ManganelAwareTrait;
/**
* TagDecorator
*
* NOTE: This decorator must be at beginning, as it modifies criteria!
*
* @author Piotr Maselkowski <pmaselkowski at gmail.com>
*/
class TagDecorator implements ConditionDecoratorInterface, ManganelAwareInterface
{
use ManganelAwareTrait;
/**
* Field which should be used as a tag filter
* @var string
*/
public $field = '';
public function decorate(&$conditions, SearchCriteria $criteria)
{
assert(!empty($this->field), sprintf('Property `field` is required for `%s`', __CLASS__));
$pattern = '~\[[\s\p{L}]+\]~';
$query = $criteria->getSearch();
$matches = [];
if(!preg_match_all($pattern, $query, $matches))
{
return;
}
if(count($matches[0]) > 1)
{
echo '';
}
$field = $this->field;
foreach($criteria->getModels() as $model)
{
// Skip field if not exists on model
if(ManganMeta::create($model)->{$this->field} === false)
{
continue;
}
$cd = new ManganCD($model);
$data = $cd->decorate($this->field);
$field = key($data);
}
foreach($matches[0] as $match)
{
$query = str_replace($match, '', $query);
$conditions[] = [
'term' => [
$field => trim($match, '[]')
]
];
}
$criteria->search($query);
}
public function getKind()
{
return self::KindFilter;
}
}
API documentation generated by ApiGen