2018-07-20 14:34:56 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* CreateController.php
|
|
|
|
* Copyright (c) 2018 thegrumpydictator@gmail.com
|
|
|
|
*
|
|
|
|
* This file is part of Firefly III.
|
|
|
|
*
|
|
|
|
* 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);
|
|
|
|
|
|
|
|
namespace FireflyIII\Http\Controllers\Rule;
|
|
|
|
|
|
|
|
|
|
|
|
use FireflyIII\Http\Controllers\Controller;
|
|
|
|
use FireflyIII\Http\Requests\RuleFormRequest;
|
|
|
|
use FireflyIII\Models\Bill;
|
|
|
|
use FireflyIII\Models\RuleGroup;
|
|
|
|
use FireflyIII\Repositories\Rule\RuleRepositoryInterface;
|
2018-12-31 08:11:57 +01:00
|
|
|
use FireflyIII\Support\Http\Controllers\ModelInformation;
|
2018-07-20 14:34:56 +02:00
|
|
|
use FireflyIII\Support\Http\Controllers\RuleManagement;
|
|
|
|
use Illuminate\Http\RedirectResponse;
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class CreateController
|
|
|
|
*/
|
|
|
|
class CreateController extends Controller
|
|
|
|
{
|
2018-12-31 08:11:57 +01:00
|
|
|
use RuleManagement, ModelInformation;
|
2018-07-21 08:55:32 +02:00
|
|
|
/** @var RuleRepositoryInterface Rule repository */
|
2018-07-20 14:34:56 +02:00
|
|
|
private $ruleRepos;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* RuleController constructor.
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
parent::__construct();
|
|
|
|
|
|
|
|
$this->middleware(
|
|
|
|
function ($request, $next) {
|
|
|
|
app('view')->share('title', (string)trans('firefly.rules'));
|
|
|
|
app('view')->share('mainTitleIcon', 'fa-random');
|
|
|
|
|
|
|
|
$this->ruleRepos = app(RuleRepositoryInterface::class);
|
|
|
|
|
|
|
|
return $next($request);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new rule. It will be stored under the given $ruleGroup.
|
|
|
|
*
|
|
|
|
* @param Request $request
|
|
|
|
* @param RuleGroup $ruleGroup
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
|
|
|
|
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
|
|
* @SuppressWarnings(PHPMD.CyclomaticComplexity)
|
|
|
|
*/
|
2018-08-05 15:34:20 +02:00
|
|
|
public function create(Request $request, RuleGroup $ruleGroup = null)
|
2018-07-20 14:34:56 +02:00
|
|
|
{
|
|
|
|
$this->createDefaultRuleGroup();
|
|
|
|
$this->createDefaultRule();
|
2018-08-05 15:34:20 +02:00
|
|
|
$preFilled = [
|
2018-07-20 14:34:56 +02:00
|
|
|
'strict' => true,
|
|
|
|
];
|
2018-08-05 15:34:20 +02:00
|
|
|
$oldTriggers = [];
|
|
|
|
$oldActions = [];
|
2018-07-20 14:34:56 +02:00
|
|
|
|
2018-08-05 15:34:20 +02:00
|
|
|
// restore actions and triggers from old input:
|
2018-07-20 14:34:56 +02:00
|
|
|
if ($request->old()) {
|
|
|
|
$oldTriggers = $this->getPreviousTriggers($request);
|
|
|
|
$oldActions = $this->getPreviousActions($request);
|
|
|
|
}
|
|
|
|
|
|
|
|
$triggerCount = \count($oldTriggers);
|
|
|
|
$actionCount = \count($oldActions);
|
|
|
|
$subTitleIcon = 'fa-clone';
|
|
|
|
|
2018-08-05 15:34:20 +02:00
|
|
|
// title depends on whether or not there is a rule group:
|
|
|
|
$subTitle = (string)trans('firefly.make_new_rule_no_group');
|
|
|
|
if (null !== $ruleGroup) {
|
|
|
|
$subTitle = (string)trans('firefly.make_new_rule', ['title' => $ruleGroup->title]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// flash old data
|
2018-07-20 14:34:56 +02:00
|
|
|
$request->session()->flash('preFilled', $preFilled);
|
|
|
|
|
|
|
|
// put previous url in session if not redirect from store (not "create another").
|
|
|
|
if (true !== session('rules.create.fromStore')) {
|
|
|
|
$this->rememberPreviousUri('rules.create.uri');
|
|
|
|
}
|
|
|
|
session()->forget('rules.create.fromStore');
|
|
|
|
|
|
|
|
return view(
|
2018-08-05 15:34:20 +02:00
|
|
|
'rules.rule.create', compact('subTitleIcon', 'oldTriggers', 'preFilled', 'oldActions', 'triggerCount', 'actionCount', 'ruleGroup', 'subTitle')
|
2018-07-20 14:34:56 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2018-08-05 18:59:15 +02:00
|
|
|
/**
|
|
|
|
* Create a new rule. It will be stored under the given $ruleGroup.
|
|
|
|
*
|
|
|
|
* @param Request $request
|
|
|
|
* @param Bill $bill
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
|
|
|
|
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
|
|
* @SuppressWarnings(PHPMD.CyclomaticComplexity)
|
|
|
|
*/
|
|
|
|
public function createFromBill(Request $request, Bill $bill)
|
|
|
|
{
|
|
|
|
$request->session()->flash('info', (string)trans('firefly.instructions_rule_from_bill', ['name' => $bill->name]));
|
|
|
|
|
|
|
|
$this->createDefaultRuleGroup();
|
|
|
|
$this->createDefaultRule();
|
|
|
|
$preFilled = [
|
|
|
|
'strict' => true,
|
|
|
|
'title' => (string)trans('firefly.new_rule_for_bill_title', ['name' => $bill->name]),
|
|
|
|
'description' => (string)trans('firefly.new_rule_for_bill_description', ['name' => $bill->name]),
|
|
|
|
];
|
|
|
|
|
|
|
|
// make triggers and actions from the bill itself.
|
|
|
|
|
|
|
|
// get triggers and actions for bill:
|
|
|
|
$oldTriggers = $this->getTriggersForBill($bill);
|
|
|
|
$oldActions = $this->getActionsForBill($bill);
|
|
|
|
|
|
|
|
$triggerCount = \count($oldTriggers);
|
|
|
|
$actionCount = \count($oldActions);
|
|
|
|
$subTitleIcon = 'fa-clone';
|
|
|
|
|
|
|
|
// title depends on whether or not there is a rule group:
|
|
|
|
$subTitle = (string)trans('firefly.make_new_rule_no_group');
|
|
|
|
|
|
|
|
// flash old data
|
|
|
|
$request->session()->flash('preFilled', $preFilled);
|
|
|
|
|
|
|
|
// put previous url in session if not redirect from store (not "create another").
|
|
|
|
if (true !== session('rules.create.fromStore')) {
|
|
|
|
$this->rememberPreviousUri('rules.create.uri');
|
|
|
|
}
|
|
|
|
session()->forget('rules.create.fromStore');
|
|
|
|
|
|
|
|
return view(
|
|
|
|
'rules.rule.create', compact('subTitleIcon', 'oldTriggers', 'preFilled', 'oldActions', 'triggerCount', 'actionCount', 'subTitle')
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2018-07-20 14:34:56 +02:00
|
|
|
/**
|
2018-07-21 08:55:32 +02:00
|
|
|
* Store the new rule.
|
|
|
|
*
|
2018-07-20 14:34:56 +02:00
|
|
|
* @param RuleFormRequest $request
|
|
|
|
*
|
|
|
|
* @return RedirectResponse|\Illuminate\Routing\Redirector
|
|
|
|
* @SuppressWarnings(PHPMD.CyclomaticComplexity)
|
|
|
|
*/
|
|
|
|
public function store(RuleFormRequest $request)
|
|
|
|
{
|
|
|
|
$data = $request->getRuleData();
|
|
|
|
$rule = $this->ruleRepos->store($data);
|
|
|
|
session()->flash('success', (string)trans('firefly.stored_new_rule', ['title' => $rule->title]));
|
|
|
|
app('preferences')->mark();
|
|
|
|
|
|
|
|
// redirect to show bill.
|
|
|
|
if ('true' === $request->get('return_to_bill') && (int)$request->get('bill_id') > 0) {
|
|
|
|
return redirect(route('bills.show', [(int)$request->get('bill_id')])); // @codeCoverageIgnore
|
|
|
|
}
|
|
|
|
|
|
|
|
// redirect to new bill creation.
|
|
|
|
if ((int)$request->get('bill_id') > 0) {
|
|
|
|
return redirect($this->getPreviousUri('bills.create.uri')); // @codeCoverageIgnore
|
|
|
|
}
|
|
|
|
|
|
|
|
$redirect = redirect($this->getPreviousUri('rules.create.uri'));
|
|
|
|
|
|
|
|
if (1 === (int)$request->get('create_another')) {
|
|
|
|
// @codeCoverageIgnoreStart
|
|
|
|
session()->put('rules.create.fromStore', true);
|
|
|
|
$redirect = redirect(route('rules.create', [$data['rule_group_id']]))->withInput();
|
|
|
|
// @codeCoverageIgnoreEnd
|
|
|
|
}
|
|
|
|
|
|
|
|
return $redirect;
|
|
|
|
}
|
|
|
|
|
2018-07-22 20:32:02 +02:00
|
|
|
}
|