Files
firefly-iii/app/Support/Twig/Rule.php

117 lines
3.2 KiB
PHP
Raw Normal View History

2016-01-15 08:10:22 +01:00
<?php
/**
* Rule.php
2017-10-21 08:40:00 +02:00
* Copyright (c) 2017 thegrumpydictator@gmail.com
*
2017-10-21 08:40:00 +02:00
* This file is part of Firefly III.
*
2017-10-21 08:40:00 +02:00
* Firefly III is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Firefly III is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Firefly III. If not, see <http://www.gnu.org/licenses/>.
*/
declare(strict_types=1);
2016-01-15 08:10:22 +01:00
namespace FireflyIII\Support\Twig;
2016-01-15 08:13:19 +01:00
use Config;
2016-01-15 08:10:22 +01:00
use Twig_Extension;
use Twig_SimpleFunction;
/**
2017-11-15 12:25:49 +01:00
* Class Rule.
2016-01-15 08:10:22 +01:00
*/
class Rule extends Twig_Extension
{
2016-08-26 08:21:31 +02:00
/**
* @return Twig_SimpleFunction
*/
public function allActionTriggers(): Twig_SimpleFunction
{
return new Twig_SimpleFunction(
2017-11-15 10:52:29 +01:00
'allRuleActions',
function () {
// array of valid values for actions
$ruleActions = array_keys(Config::get('firefly.rule-actions'));
$possibleActions = [];
foreach ($ruleActions as $key) {
$possibleActions[$key] = trans('firefly.rule_action_' . $key . '_choice');
}
unset($key, $ruleActions);
asort($possibleActions);
2016-08-26 08:21:31 +02:00
2017-11-15 10:52:29 +01:00
return $possibleActions;
}
2016-08-26 08:21:31 +02:00
);
}
2016-01-15 08:10:22 +01:00
/**
* @return Twig_SimpleFunction
2016-01-15 08:10:22 +01:00
*/
2016-04-05 22:00:03 +02:00
public function allJournalTriggers(): Twig_SimpleFunction
2016-01-15 08:10:22 +01:00
{
return new Twig_SimpleFunction(
2017-11-15 10:52:29 +01:00
'allJournalTriggers',
function () {
return [
2017-11-15 11:33:07 +01:00
'store-journal' => trans('firefly.rule_trigger_store_journal'),
'update-journal' => trans('firefly.rule_trigger_update_journal'),
];
2017-11-15 10:52:29 +01:00
}
2016-01-15 08:10:22 +01:00
);
}
2016-01-15 08:10:22 +01:00
/**
* @return Twig_SimpleFunction
*/
2016-04-05 22:00:03 +02:00
public function allRuleTriggers(): Twig_SimpleFunction
{
return new Twig_SimpleFunction(
2017-11-15 10:52:29 +01:00
'allRuleTriggers',
function () {
$ruleTriggers = array_keys(Config::get('firefly.rule-triggers'));
$possibleTriggers = [];
foreach ($ruleTriggers as $key) {
2017-11-15 12:25:49 +01:00
if ('user_action' !== $key) {
2017-11-15 10:52:29 +01:00
$possibleTriggers[$key] = trans('firefly.rule_trigger_' . $key . '_choice');
}
2016-01-15 08:13:19 +01:00
}
2017-11-15 10:52:29 +01:00
unset($key, $ruleTriggers);
asort($possibleTriggers);
2016-01-15 08:13:19 +01:00
2017-11-15 10:52:29 +01:00
return $possibleTriggers;
}
2016-01-15 08:13:19 +01:00
);
}
/**
* @return array
*/
2016-04-05 22:00:03 +02:00
public function getFunctions(): array
{
return [
$this->allJournalTriggers(),
$this->allRuleTriggers(),
$this->allActionTriggers(),
];
2016-01-15 08:10:22 +01:00
}
/**
* Returns the name of the extension.
*
* @return string The extension name
*/
2016-04-05 22:00:03 +02:00
public function getName(): string
2016-01-15 08:10:22 +01:00
{
return 'FireflyIII\Support\Twig\Rule';
}
}