mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-09-30 02:26:58 +00:00
This commit is contained in:
12
.ci/php-cs-fixer/composer.lock
generated
12
.ci/php-cs-fixer/composer.lock
generated
@@ -226,16 +226,16 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "friendsofphp/php-cs-fixer",
|
"name": "friendsofphp/php-cs-fixer",
|
||||||
"version": "v3.39.0",
|
"version": "v3.39.1",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer.git",
|
"url": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer.git",
|
||||||
"reference": "04bf7b28fc847185b247d112cab617da941e3cca"
|
"reference": "857046d26b0d92dc13c4be769309026b100b517e"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/PHP-CS-Fixer/PHP-CS-Fixer/zipball/04bf7b28fc847185b247d112cab617da941e3cca",
|
"url": "https://api.github.com/repos/PHP-CS-Fixer/PHP-CS-Fixer/zipball/857046d26b0d92dc13c4be769309026b100b517e",
|
||||||
"reference": "04bf7b28fc847185b247d112cab617da941e3cca",
|
"reference": "857046d26b0d92dc13c4be769309026b100b517e",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
@@ -307,7 +307,7 @@
|
|||||||
],
|
],
|
||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/issues",
|
"issues": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/issues",
|
||||||
"source": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/tree/v3.39.0"
|
"source": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/tree/v3.39.1"
|
||||||
},
|
},
|
||||||
"funding": [
|
"funding": [
|
||||||
{
|
{
|
||||||
@@ -315,7 +315,7 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"time": "2023-11-22T11:20:09+00:00"
|
"time": "2023-11-24T22:59:03+00:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "psr/container",
|
"name": "psr/container",
|
||||||
|
@@ -100,13 +100,15 @@ class CreateController extends Controller
|
|||||||
session()->flash('warning', trans('firefly.rule_from_search_words', ['string' => $words]));
|
session()->flash('warning', trans('firefly.rule_from_search_words', ['string' => $words]));
|
||||||
$operators[] = [
|
$operators[] = [
|
||||||
'type' => 'description_contains',
|
'type' => 'description_contains',
|
||||||
'value' => $words];
|
'value' => $words
|
||||||
|
];
|
||||||
}
|
}
|
||||||
$oldTriggers = $this->parseFromOperators($operators);
|
$oldTriggers = $this->parseFromOperators($operators);
|
||||||
}
|
}
|
||||||
|
//var_dump($oldTriggers);exit;
|
||||||
|
|
||||||
// restore actions and triggers from old input:
|
// restore actions and triggers from old input:
|
||||||
if (null !== $request->old()) {
|
if (is_array($request->old()) && count($request->old()) > 0) {
|
||||||
$oldTriggers = $this->getPreviousTriggers($request);
|
$oldTriggers = $this->getPreviousTriggers($request);
|
||||||
$oldActions = $this->getPreviousActions($request);
|
$oldActions = $this->getPreviousActions($request);
|
||||||
}
|
}
|
||||||
|
@@ -138,12 +138,14 @@ trait RuleManagement
|
|||||||
|
|
||||||
$index = 0;
|
$index = 0;
|
||||||
foreach ($submittedOperators as $operator) {
|
foreach ($submittedOperators as $operator) {
|
||||||
|
$rootOperator = OperatorQuerySearch::getRootOperator($operator['type']);
|
||||||
|
$needsContext = (bool) config(sprintf('search.operators.%s.needs_context',$rootOperator));
|
||||||
try {
|
try {
|
||||||
$renderedEntries[] = view(
|
$renderedEntries[] = view(
|
||||||
'rules.partials.trigger',
|
'rules.partials.trigger',
|
||||||
[
|
[
|
||||||
'oldTrigger' => OperatorQuerySearch::getRootOperator($operator['type']),
|
'oldTrigger' => $rootOperator,
|
||||||
'oldValue' => $operator['value'],
|
'oldValue' => $needsContext ? $operator['value'] : '',
|
||||||
'oldChecked' => false,
|
'oldChecked' => false,
|
||||||
'oldProhibited' => $operator['prohibited'] ?? false,
|
'oldProhibited' => $operator['prohibited'] ?? false,
|
||||||
'count' => $index + 1,
|
'count' => $index + 1,
|
||||||
|
@@ -60,8 +60,7 @@ use TypeError;
|
|||||||
/**
|
/**
|
||||||
* Class OperatorQuerySearch
|
* Class OperatorQuerySearch
|
||||||
*/
|
*/
|
||||||
class
|
class OperatorQuerySearch implements SearchInterface
|
||||||
OperatorQuerySearch implements SearchInterface
|
|
||||||
{
|
{
|
||||||
protected Carbon $date;
|
protected Carbon $date;
|
||||||
private AccountRepositoryInterface $accountRepository;
|
private AccountRepositoryInterface $accountRepository;
|
||||||
@@ -212,8 +211,14 @@ OperatorQuerySearch implements SearchInterface
|
|||||||
$context = config(sprintf('search.operators.%s.needs_context', $operator));
|
$context = config(sprintf('search.operators.%s.needs_context', $operator));
|
||||||
|
|
||||||
// is an operator that needs no context, and value is false, then prohibited = true.
|
// is an operator that needs no context, and value is false, then prohibited = true.
|
||||||
if ('false' === $value && in_array($operator, $this->validOperators, true) && false === $context) {
|
if ('false' === $value && in_array($operator, $this->validOperators, true) && false === $context && !$prohibited) {
|
||||||
$prohibited = true;
|
$prohibited = true;
|
||||||
|
$value = 'true';
|
||||||
|
}
|
||||||
|
// if the operator is prohibited, but the value is false, do an uno reverse
|
||||||
|
if ('false' === $value && $prohibited && in_array($operator, $this->validOperators, true) && false === $context) {
|
||||||
|
$prohibited = false;
|
||||||
|
$value = 'true';
|
||||||
}
|
}
|
||||||
|
|
||||||
// must be valid operator:
|
// must be valid operator:
|
||||||
|
@@ -115,13 +115,13 @@ class SearchRuleEngine implements RuleEngineInterface
|
|||||||
}
|
}
|
||||||
|
|
||||||
// if needs no context, value is different:
|
// if needs no context, value is different:
|
||||||
$needsContext = config(sprintf('search.operators.%s.needs_context', $ruleTrigger->trigger_type)) ?? true;
|
$needsContext = (bool) config(sprintf('search.operators.%s.needs_context', $ruleTrigger->trigger_type)) ?? true;
|
||||||
if (false === $needsContext) {
|
if (false === $needsContext) {
|
||||||
app('log')->debug(sprintf('SearchRuleEngine:: add a rule trigger: %s:true', $ruleTrigger->trigger_type));
|
app('log')->debug(sprintf('SearchRuleEngine:: add a rule trigger (no context): %s:true', $ruleTrigger->trigger_type));
|
||||||
$searchArray[$ruleTrigger->trigger_type][] = 'true';
|
$searchArray[$ruleTrigger->trigger_type][] = 'true';
|
||||||
}
|
}
|
||||||
if (true === $needsContext) {
|
if (true === $needsContext) {
|
||||||
app('log')->debug(sprintf('SearchRuleEngine:: add a rule trigger: %s:"%s"', $ruleTrigger->trigger_type, $ruleTrigger->trigger_value));
|
app('log')->debug(sprintf('SearchRuleEngine:: add a rule trigger (context): %s:"%s"', $ruleTrigger->trigger_type, $ruleTrigger->trigger_value));
|
||||||
$searchArray[$ruleTrigger->trigger_type][] = sprintf('"%s"', $ruleTrigger->trigger_value);
|
$searchArray[$ruleTrigger->trigger_type][] = sprintf('"%s"', $ruleTrigger->trigger_value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -136,6 +136,7 @@ class SearchRuleEngine implements RuleEngineInterface
|
|||||||
if ($this->hasSpecificJournalTrigger($searchArray)) {
|
if ($this->hasSpecificJournalTrigger($searchArray)) {
|
||||||
$date = $this->setDateFromJournalTrigger($searchArray);
|
$date = $this->setDateFromJournalTrigger($searchArray);
|
||||||
}
|
}
|
||||||
|
|
||||||
// build and run the search engine.
|
// build and run the search engine.
|
||||||
$searchEngine = app(SearchInterface::class);
|
$searchEngine = app(SearchInterface::class);
|
||||||
$searchEngine->setUser($this->user);
|
$searchEngine->setUser($this->user);
|
||||||
@@ -145,7 +146,9 @@ class SearchRuleEngine implements RuleEngineInterface
|
|||||||
|
|
||||||
foreach ($searchArray as $type => $searches) {
|
foreach ($searchArray as $type => $searches) {
|
||||||
foreach ($searches as $value) {
|
foreach ($searches as $value) {
|
||||||
$searchEngine->parseQuery(sprintf('%s:%s', $type, $value));
|
$query = sprintf('%s:%s', $type, $value);
|
||||||
|
app('log')->debug(sprintf('SearchRuleEngine:: add query "%s"', $query));
|
||||||
|
$searchEngine->parseQuery($query);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user