mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-01-02 12:17:22 -06:00
Code for #2575
This commit is contained in:
parent
f598c39c6e
commit
996fc4dc7c
@ -28,6 +28,7 @@ use FireflyIII\Http\Controllers\Controller;
|
|||||||
use FireflyIII\Http\Requests\RuleFormRequest;
|
use FireflyIII\Http\Requests\RuleFormRequest;
|
||||||
use FireflyIII\Models\Bill;
|
use FireflyIII\Models\Bill;
|
||||||
use FireflyIII\Models\RuleGroup;
|
use FireflyIII\Models\RuleGroup;
|
||||||
|
use FireflyIII\Models\TransactionJournal;
|
||||||
use FireflyIII\Repositories\Rule\RuleRepositoryInterface;
|
use FireflyIII\Repositories\Rule\RuleRepositoryInterface;
|
||||||
use FireflyIII\Support\Http\Controllers\ModelInformation;
|
use FireflyIII\Support\Http\Controllers\ModelInformation;
|
||||||
use FireflyIII\Support\Http\Controllers\RuleManagement;
|
use FireflyIII\Support\Http\Controllers\RuleManagement;
|
||||||
@ -45,6 +46,7 @@ class CreateController extends Controller
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* RuleController constructor.
|
* RuleController constructor.
|
||||||
|
*
|
||||||
* @codeCoverageIgnore
|
* @codeCoverageIgnore
|
||||||
*/
|
*/
|
||||||
public function __construct()
|
public function __construct()
|
||||||
@ -158,6 +160,48 @@ class CreateController extends Controller
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Request $request
|
||||||
|
* @param TransactionJournal $journal
|
||||||
|
*/
|
||||||
|
public function createFromJournal(Request $request, TransactionJournal $journal)
|
||||||
|
{
|
||||||
|
$request->session()->flash('info', (string)trans('firefly.instructions_rule_from_journal', ['name' => e($journal->name)]));
|
||||||
|
|
||||||
|
$subTitleIcon = 'fa-clone';
|
||||||
|
$subTitle = (string)trans('firefly.make_new_rule_no_group');
|
||||||
|
|
||||||
|
// get triggers and actions for journal.
|
||||||
|
$oldTriggers = $this->getTriggersForJournal($journal);
|
||||||
|
$oldActions = [];
|
||||||
|
$triggerCount = count($oldTriggers);
|
||||||
|
$actionCount = count($oldActions);
|
||||||
|
|
||||||
|
$this->createDefaultRuleGroup();
|
||||||
|
$this->createDefaultRule();
|
||||||
|
|
||||||
|
// collect pre-filled information:
|
||||||
|
$preFilled = [
|
||||||
|
'strict' => true,
|
||||||
|
'title' => (string)trans('firefly.new_rule_for_journal_title', ['description' => $journal->description]),
|
||||||
|
'description' => (string)trans('firefly.new_rule_for_journal_description', ['description' => $journal->description]),
|
||||||
|
];
|
||||||
|
|
||||||
|
// 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')
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Store the new rule.
|
* Store the new rule.
|
||||||
*
|
*
|
||||||
|
@ -23,14 +23,12 @@ declare(strict_types=1);
|
|||||||
|
|
||||||
namespace FireflyIII\Support\Http\Controllers;
|
namespace FireflyIII\Support\Http\Controllers;
|
||||||
|
|
||||||
use FireflyIII\Exceptions\FireflyException;
|
|
||||||
use FireflyIII\Models\Account;
|
|
||||||
use FireflyIII\Models\AccountType;
|
use FireflyIII\Models\AccountType;
|
||||||
use FireflyIII\Models\Bill;
|
use FireflyIII\Models\Bill;
|
||||||
|
use FireflyIII\Models\Tag;
|
||||||
|
use FireflyIII\Models\Transaction;
|
||||||
use FireflyIII\Models\TransactionJournal;
|
use FireflyIII\Models\TransactionJournal;
|
||||||
use FireflyIII\Models\TransactionType;
|
|
||||||
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
|
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
|
||||||
use FireflyIII\Repositories\Journal\JournalRepositoryInterface;
|
|
||||||
use Log;
|
use Log;
|
||||||
use Throwable;
|
use Throwable;
|
||||||
|
|
||||||
@ -71,6 +69,43 @@ trait ModelInformation
|
|||||||
return [$result];
|
return [$result];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
protected function getLiabilityTypes(): array
|
||||||
|
{
|
||||||
|
/** @var AccountRepositoryInterface $repository */
|
||||||
|
$repository = app(AccountRepositoryInterface::class);
|
||||||
|
// types of liability:
|
||||||
|
$debt = $repository->getAccountTypeByType(AccountType::DEBT);
|
||||||
|
$loan = $repository->getAccountTypeByType(AccountType::LOAN);
|
||||||
|
$mortgage = $repository->getAccountTypeByType(AccountType::MORTGAGE);
|
||||||
|
/** @noinspection NullPointerExceptionInspection */
|
||||||
|
$liabilityTypes = [
|
||||||
|
$debt->id => (string)trans(sprintf('firefly.account_type_%s', AccountType::DEBT)),
|
||||||
|
$loan->id => (string)trans(sprintf('firefly.account_type_%s', AccountType::LOAN)),
|
||||||
|
$mortgage->id => (string)trans(sprintf('firefly.account_type_%s', AccountType::MORTGAGE)),
|
||||||
|
];
|
||||||
|
asort($liabilityTypes);
|
||||||
|
|
||||||
|
return $liabilityTypes;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
protected function getRoles(): array
|
||||||
|
{
|
||||||
|
$roles = [];
|
||||||
|
foreach (config('firefly.accountRoles') as $role) {
|
||||||
|
$roles[$role] = (string)trans(sprintf('firefly.account_role_%s', $role));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $roles;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create fake triggers to match the bill's properties
|
* Create fake triggers to match the bill's properties
|
||||||
*
|
*
|
||||||
@ -116,39 +151,109 @@ trait ModelInformation
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @codeCoverageIgnore
|
* @param TransactionJournal $journal
|
||||||
|
*
|
||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
protected function getRoles(): array
|
private function getTriggersForJournal(TransactionJournal $journal): array
|
||||||
{
|
{
|
||||||
$roles = [];
|
$result = [];
|
||||||
foreach (config('firefly.accountRoles') as $role) {
|
$triggers = [];
|
||||||
$roles[$role] = (string)trans(sprintf('firefly.account_role_%s', $role));
|
$values = [];
|
||||||
|
$index = 0;
|
||||||
|
// amount, description, category, budget, tags, source, destination, notes, currency type
|
||||||
|
//,type
|
||||||
|
/** @var Transaction $source */
|
||||||
|
$source = $journal->transactions()->where('amount', '<', 0)->first();
|
||||||
|
/** @var Transaction $destination */
|
||||||
|
$destination = $journal->transactions()->where('amount', '>', 0)->first();
|
||||||
|
if (null === $destination || null === $source) {
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
// type
|
||||||
|
$triggers[$index] = 'transaction_type';
|
||||||
|
$values[$index] = $journal->transactionType->type;
|
||||||
|
$index++;
|
||||||
|
|
||||||
|
// currency
|
||||||
|
$triggers[$index] = 'currency_is';
|
||||||
|
$values[$index] = sprintf('%s (%s)', $journal->transactionCurrency->name, $journal->transactionCurrency->code);
|
||||||
|
$index++;
|
||||||
|
|
||||||
|
// amount_exactly:
|
||||||
|
$triggers[$index] = 'amount_exactly';
|
||||||
|
$values[$index] = $destination->amount;
|
||||||
|
$index++;
|
||||||
|
|
||||||
|
// description_is:
|
||||||
|
$triggers[$index] = 'description_is';
|
||||||
|
$values[$index] = $journal->description;
|
||||||
|
$index++;
|
||||||
|
|
||||||
|
// from_account_is
|
||||||
|
$triggers[$index] = 'from_account_is';
|
||||||
|
$values[$index] = $source->account->name;
|
||||||
|
$index++;
|
||||||
|
|
||||||
|
// to_account_is
|
||||||
|
$triggers[$index] = 'to_account_is';
|
||||||
|
$values[$index] = $destination->account->name;
|
||||||
|
$index++;
|
||||||
|
|
||||||
|
// category (if)
|
||||||
|
$category = $journal->categories()->first();
|
||||||
|
if (null !== $category) {
|
||||||
|
$triggers[$index] = 'category_is';
|
||||||
|
$values[$index] = $category->name;
|
||||||
|
$index++;
|
||||||
|
}
|
||||||
|
// budget (if)
|
||||||
|
$budget = $journal->budgets()->first();
|
||||||
|
if (null !== $budget) {
|
||||||
|
$triggers[$index] = 'budget_is';
|
||||||
|
$values[$index] = $budget->name;
|
||||||
|
$index++;
|
||||||
|
}
|
||||||
|
// tags (if)
|
||||||
|
$tags = $journal->tags()->get();
|
||||||
|
/** @var Tag $tag */
|
||||||
|
foreach ($tags as $tag) {
|
||||||
|
$triggers[$index] = 'tag_is';
|
||||||
|
$values[$index] = $tag->tag;
|
||||||
|
$index++;
|
||||||
|
}
|
||||||
|
// notes (if)
|
||||||
|
$notes = $journal->notes()->first();
|
||||||
|
if (null !== $notes) {
|
||||||
|
$triggers[$index] = 'notes_are';
|
||||||
|
$values[$index] = $notes->text;
|
||||||
|
$index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $roles;
|
foreach ($triggers as $index => $trigger) {
|
||||||
}
|
try {
|
||||||
|
$string = view(
|
||||||
|
'rules.partials.trigger',
|
||||||
|
[
|
||||||
|
'oldTrigger' => $trigger,
|
||||||
|
'oldValue' => $values[$index],
|
||||||
|
'oldChecked' => false,
|
||||||
|
'count' => $index + 1,
|
||||||
|
]
|
||||||
|
)->render();
|
||||||
|
// @codeCoverageIgnoreStart
|
||||||
|
} catch (Throwable $e) {
|
||||||
|
|
||||||
/**
|
Log::debug(sprintf('Throwable was thrown in getTriggersForJournal(): %s', $e->getMessage()));
|
||||||
* @codeCoverageIgnore
|
Log::debug($e->getTraceAsString());
|
||||||
* @return array
|
$string = '';
|
||||||
*/
|
// @codeCoverageIgnoreEnd
|
||||||
protected function getLiabilityTypes(): array
|
}
|
||||||
{
|
if ('' !== $string) {
|
||||||
/** @var AccountRepositoryInterface $repository */
|
$result[] = $string;
|
||||||
$repository = app(AccountRepositoryInterface::class);
|
}
|
||||||
// types of liability:
|
}
|
||||||
$debt = $repository->getAccountTypeByType(AccountType::DEBT);
|
|
||||||
$loan = $repository->getAccountTypeByType(AccountType::LOAN);
|
|
||||||
$mortgage = $repository->getAccountTypeByType(AccountType::MORTGAGE);
|
|
||||||
/** @noinspection NullPointerExceptionInspection */
|
|
||||||
$liabilityTypes = [
|
|
||||||
$debt->id => (string)trans(sprintf('firefly.account_type_%s', AccountType::DEBT)),
|
|
||||||
$loan->id => (string)trans(sprintf('firefly.account_type_%s', AccountType::LOAN)),
|
|
||||||
$mortgage->id => (string)trans(sprintf('firefly.account_type_%s', AccountType::MORTGAGE)),
|
|
||||||
];
|
|
||||||
asort($liabilityTypes);
|
|
||||||
|
|
||||||
return $liabilityTypes;
|
return $result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -23,6 +23,7 @@ declare(strict_types=1);
|
|||||||
|
|
||||||
namespace FireflyIII\Support\Http\Controllers;
|
namespace FireflyIII\Support\Http\Controllers;
|
||||||
|
|
||||||
|
use FireflyIII\Models\TransactionJournal;
|
||||||
use FireflyIII\Repositories\Rule\RuleRepositoryInterface;
|
use FireflyIII\Repositories\Rule\RuleRepositoryInterface;
|
||||||
use FireflyIII\Repositories\RuleGroup\RuleGroupRepositoryInterface;
|
use FireflyIII\Repositories\RuleGroup\RuleGroupRepositoryInterface;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
@ -512,6 +512,7 @@ return [
|
|||||||
'delete_all_selected_tags' => 'Delete all selected tags',
|
'delete_all_selected_tags' => 'Delete all selected tags',
|
||||||
'select_tags_to_delete' => 'Don\'t forget to select some tags.',
|
'select_tags_to_delete' => 'Don\'t forget to select some tags.',
|
||||||
'deleted_x_tags' => 'Deleted :count tag(s).',
|
'deleted_x_tags' => 'Deleted :count tag(s).',
|
||||||
|
'create_rule_from_transaction' => 'Create rule based on transaction',
|
||||||
|
|
||||||
// preferences
|
// preferences
|
||||||
'pref_home_screen_accounts' => 'Home screen accounts',
|
'pref_home_screen_accounts' => 'Home screen accounts',
|
||||||
|
@ -276,6 +276,10 @@
|
|||||||
<i class="fa fa-fw fa-link"></i>
|
<i class="fa fa-fw fa-link"></i>
|
||||||
{{ 'link_transaction'|_ }}
|
{{ 'link_transaction'|_ }}
|
||||||
</a>
|
</a>
|
||||||
|
<a href="{{ route('rules.create-from-journal', [journal.transaction_journal_id]) }}" class="btn btn-default">
|
||||||
|
<i class="fa fa-fw fa-random"></i>
|
||||||
|
{{ 'create_rule_from_transaction'|_ }}
|
||||||
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -887,6 +887,15 @@ try {
|
|||||||
$breadcrumbs->push(trans('firefly.make_new_rule_no_group'), route('rules.create'));
|
$breadcrumbs->push(trans('firefly.make_new_rule_no_group'), route('rules.create'));
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
Breadcrumbs::register(
|
||||||
|
'rules.create-from-journal',
|
||||||
|
function (BreadcrumbsGenerator $breadcrumbs) {
|
||||||
|
$breadcrumbs->parent('rules.index');
|
||||||
|
$breadcrumbs->push(trans('firefly.make_new_rule_no_group'), route('rules.create'));
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
Breadcrumbs::register(
|
Breadcrumbs::register(
|
||||||
'rules.edit',
|
'rules.edit',
|
||||||
function (BreadcrumbsGenerator $breadcrumbs, Rule $rule) {
|
function (BreadcrumbsGenerator $breadcrumbs, Rule $rule) {
|
||||||
|
@ -863,6 +863,7 @@ Route::group(
|
|||||||
// create controller
|
// create controller
|
||||||
Route::get('create/{ruleGroup?}', ['uses' => 'Rule\CreateController@create', 'as' => 'create']);
|
Route::get('create/{ruleGroup?}', ['uses' => 'Rule\CreateController@create', 'as' => 'create']);
|
||||||
Route::get('create-from-bill/{bill}', ['uses' => 'Rule\CreateController@createFromBill', 'as' => 'create-from-bill']);
|
Route::get('create-from-bill/{bill}', ['uses' => 'Rule\CreateController@createFromBill', 'as' => 'create-from-bill']);
|
||||||
|
Route::get('create-from-journal/{tj}', ['uses' => 'Rule\CreateController@createFromJournal', 'as' => 'create-from-journal']);
|
||||||
Route::post('store', ['uses' => 'Rule\CreateController@store', 'as' => 'store']);
|
Route::post('store', ['uses' => 'Rule\CreateController@store', 'as' => 'store']);
|
||||||
|
|
||||||
// delete controller
|
// delete controller
|
||||||
|
Loading…
Reference in New Issue
Block a user