|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
/* |
|
4
|
|
|
* This file is part of the jquery-querybuilder-bundle package. |
|
5
|
|
|
* |
|
6
|
|
|
* (c) 2021 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\JQuery\QueryBuilderBundle\Serializer; |
|
13
|
|
|
|
|
14
|
|
|
use InvalidArgumentException; |
|
15
|
|
|
use WBW\Bundle\JQuery\QueryBuilderBundle\API\QueryBuilderFilterSetInterface; |
|
16
|
|
|
use WBW\Bundle\JQuery\QueryBuilderBundle\API\QueryBuilderRule; |
|
17
|
|
|
use WBW\Bundle\JQuery\QueryBuilderBundle\API\QueryBuilderRuleInterface; |
|
18
|
|
|
use WBW\Bundle\JQuery\QueryBuilderBundle\API\QueryBuilderRuleSet; |
|
19
|
|
|
use WBW\Bundle\JQuery\QueryBuilderBundle\API\QueryBuilderRuleSetInterface; |
|
20
|
|
|
use WBW\Library\Core\Argument\Helper\ArrayHelper; |
|
21
|
|
|
|
|
22
|
|
|
/** |
|
23
|
|
|
* JSON deserializer. |
|
24
|
|
|
* |
|
25
|
|
|
* @author webeweb <https://github.com/webeweb/> |
|
26
|
|
|
* @package WBW\Bundle\JQuery\QueryBuilderBundle\Serializer |
|
27
|
|
|
*/ |
|
28
|
|
|
class JsonDeserializer { |
|
29
|
|
|
|
|
30
|
|
|
/** |
|
31
|
|
|
* Deserialize a rule. |
|
32
|
|
|
* |
|
33
|
|
|
* @param QueryBuilderFilterSetInterface $filterSet The filter set. |
|
34
|
|
|
* @param array $rule The rule. |
|
35
|
|
|
* @return QueryBuilderRuleInterface Returns the de-normalized rule. |
|
36
|
|
|
* @throws InvalidArgumentException Throws an invalid argument exception if an argument is invalid. |
|
37
|
|
|
*/ |
|
38
|
|
|
public static function deserializeQueryBuilderRule(QueryBuilderFilterSetInterface $filterSet, array $rule): QueryBuilderRuleInterface { |
|
39
|
|
|
|
|
40
|
|
|
$model = new QueryBuilderRule(); |
|
41
|
|
|
$model->setId(ArrayHelper::get($rule, "id")); |
|
42
|
|
|
$model->setField(ArrayHelper::get($rule, "field")); |
|
43
|
|
|
$model->setInput(ArrayHelper::get($rule, "input")); |
|
44
|
|
|
$model->setOperator(ArrayHelper::get($rule, "operator")); |
|
45
|
|
|
$model->setType(ArrayHelper::get($rule, "type")); |
|
46
|
|
|
$model->setValue(ArrayHelper::get($rule, "value")); |
|
47
|
|
|
|
|
48
|
|
|
$model->setDecorator($filterSet->getDecorator($model->getId())); |
|
49
|
|
|
|
|
50
|
|
|
return $model; |
|
51
|
|
|
} |
|
52
|
|
|
|
|
53
|
|
|
/** |
|
54
|
|
|
* Deserialize a rule set. |
|
55
|
|
|
* |
|
56
|
|
|
* @param QueryBuilderFilterSetInterface $filterSet The filter set. |
|
57
|
|
|
* @param array $rules The rules. |
|
58
|
|
|
* @return QueryBuilderRuleSetInterface Returns the rule set. |
|
59
|
|
|
* @throws InvalidArgumentException Throws an invalid argument exception if an argument is invalid. |
|
60
|
|
|
*/ |
|
61
|
|
|
public static function deserializeQueryBuilderRuleSet(QueryBuilderFilterSetInterface $filterSet, array $rules): QueryBuilderRuleSetInterface { |
|
62
|
|
|
|
|
63
|
|
|
$model = new QueryBuilderRuleSet(); |
|
64
|
|
|
$model->setCondition(ArrayHelper::get($rules, "condition", null)); |
|
65
|
|
|
$model->setValid(ArrayHelper::get($rules, "valid", false)); |
|
66
|
|
|
|
|
67
|
|
|
foreach (ArrayHelper::get($rules, "rules", []) as $current) { |
|
68
|
|
|
|
|
69
|
|
|
// Rule set ? |
|
70
|
|
|
if (true === array_key_exists("condition", $current)) { |
|
71
|
|
|
$model->addRuleSet(JsonDeserializer::deserializeQueryBuilderRuleSet($filterSet, $current)); |
|
72
|
|
|
continue; |
|
73
|
|
|
} |
|
74
|
|
|
|
|
75
|
|
|
$model->addRule(JsonDeserializer::deserializeQueryBuilderRule($filterSet, $current)); |
|
76
|
|
|
} |
|
77
|
|
|
|
|
78
|
|
|
return $model; |
|
79
|
|
|
} |
|
80
|
|
|
} |