2015-02-25 14:19:06 -06:00
|
|
|
<?php namespace FireflyIII\Http\Controllers;
|
|
|
|
|
|
|
|
use Auth;
|
|
|
|
use FireflyIII\Http\Requests;
|
|
|
|
use FireflyIII\Models\Transaction;
|
|
|
|
use FireflyIII\Models\TransactionGroup;
|
2015-03-04 09:04:17 -06:00
|
|
|
use FireflyIII\Models\TransactionJournal;
|
2015-02-25 14:19:06 -06:00
|
|
|
use FireflyIII\Repositories\Journal\JournalRepositoryInterface;
|
|
|
|
use Illuminate\Support\Collection;
|
|
|
|
use Input;
|
2015-03-04 02:42:47 -06:00
|
|
|
use Redirect;
|
2015-03-04 09:04:17 -06:00
|
|
|
use Response;
|
2015-03-04 02:42:47 -06:00
|
|
|
use URL;
|
2015-02-25 14:19:06 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class RelatedController
|
|
|
|
*
|
|
|
|
* @package FireflyIII\Http\Controllers
|
|
|
|
*/
|
|
|
|
class RelatedController extends Controller
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param TransactionJournal $journal
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
|
|
|
public function alreadyRelated(TransactionJournal $journal)
|
|
|
|
{
|
|
|
|
$ids = [];
|
|
|
|
/** @var TransactionGroup $group */
|
|
|
|
foreach ($journal->transactiongroups()->get() as $group) {
|
|
|
|
/** @var TransactionJournal $loopJournal */
|
|
|
|
foreach ($group->transactionjournals()->get() as $loopJournal) {
|
|
|
|
if ($loopJournal->id != $journal->id) {
|
|
|
|
$ids[] = $loopJournal->id;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-03-04 09:04:17 -06:00
|
|
|
$unique = array_unique($ids);
|
|
|
|
$journals = new Collection;
|
2015-02-25 14:19:06 -06:00
|
|
|
if (count($unique) > 0) {
|
|
|
|
|
2015-03-04 09:04:17 -06:00
|
|
|
$journals = Auth::user()->transactionjournals()->whereIn('id', $unique)->get();
|
|
|
|
$journals->each(
|
2015-02-25 14:19:06 -06:00
|
|
|
function (TransactionJournal $journal) {
|
|
|
|
/** @var Transaction $t */
|
|
|
|
foreach ($journal->transactions()->get() as $t) {
|
|
|
|
if ($t->amount > 0) {
|
|
|
|
$journal->amount = $t->amount;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
);
|
2015-03-04 09:04:17 -06:00
|
|
|
}
|
|
|
|
$parent = $journal;
|
|
|
|
|
|
|
|
return view('related.alreadyRelated', compact('parent', 'journals'));
|
|
|
|
}
|
2015-02-25 14:19:06 -06:00
|
|
|
|
2015-03-04 09:04:17 -06:00
|
|
|
/**
|
|
|
|
* @SuppressWarnings("CyclomaticComplexity") // It's exactly 5. So I don't mind.
|
|
|
|
*
|
|
|
|
* @param TransactionJournal $parentJournal
|
|
|
|
* @param TransactionJournal $childJournal
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
* @throws Exception
|
|
|
|
*/
|
|
|
|
public function getRemoveRelation(TransactionJournal $parentJournal, TransactionJournal $childJournal)
|
|
|
|
{
|
|
|
|
$groups = $parentJournal->transactiongroups()->get();
|
|
|
|
/** @var TransactionGroup $group */
|
|
|
|
foreach ($groups as $group) {
|
|
|
|
foreach ($group->transactionjournals()->get() as $loopJournal) {
|
|
|
|
if ($loopJournal->id == $childJournal->id) {
|
|
|
|
// remove from group:
|
|
|
|
$group->transactionjournals()->detach($childJournal);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($group->transactionjournals()->count() == 1) {
|
|
|
|
$group->delete();
|
|
|
|
}
|
2015-02-25 14:19:06 -06:00
|
|
|
}
|
2015-03-04 09:04:17 -06:00
|
|
|
|
|
|
|
return Redirect::to(URL::previous());
|
2015-02-25 14:19:06 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param TransactionJournal $parentJournal
|
|
|
|
* @param TransactionJournal $childJournal
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
|
|
|
public function relate(TransactionJournal $parentJournal, TransactionJournal $childJournal)
|
|
|
|
{
|
|
|
|
$group = new TransactionGroup;
|
|
|
|
$group->relation = 'balance';
|
|
|
|
$group->user_id = Auth::user()->id;
|
|
|
|
$group->save();
|
|
|
|
$group->transactionjournals()->save($parentJournal);
|
|
|
|
$group->transactionjournals()->save($childJournal);
|
|
|
|
|
|
|
|
return Response::json(true);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param TransactionJournal $journal
|
|
|
|
*
|
|
|
|
* @return \Illuminate\View\View
|
|
|
|
*/
|
|
|
|
public function related(TransactionJournal $journal)
|
|
|
|
{
|
|
|
|
$groups = $journal->transactiongroups()->get();
|
|
|
|
$members = new Collection;
|
|
|
|
/** @var TransactionGroup $group */
|
|
|
|
foreach ($groups as $group) {
|
|
|
|
/** @var TransactionJournal $loopJournal */
|
|
|
|
foreach ($group->transactionjournals()->get() as $loopJournal) {
|
|
|
|
if ($loopJournal->id != $journal->id) {
|
|
|
|
$members->push($loopJournal);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return view('related.relate', compact('journal', 'members'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @SuppressWarnings("CyclomaticComplexity") // It's exactly 5. So I don't mind.
|
|
|
|
*
|
|
|
|
* @param TransactionJournal $parentJournal
|
|
|
|
* @param TransactionJournal $childJournal
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
* @throws Exception
|
|
|
|
*/
|
|
|
|
public function removeRelation(TransactionJournal $parentJournal, TransactionJournal $childJournal)
|
|
|
|
{
|
|
|
|
$groups = $parentJournal->transactiongroups()->get();
|
|
|
|
/** @var TransactionGroup $group */
|
|
|
|
foreach ($groups as $group) {
|
|
|
|
foreach ($group->transactionjournals()->get() as $loopJournal) {
|
|
|
|
if ($loopJournal->id == $childJournal->id) {
|
|
|
|
// remove from group:
|
|
|
|
$group->transactionjournals()->detach($childJournal);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($group->transactionjournals()->count() == 1) {
|
|
|
|
$group->delete();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return Response::json(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param TransactionJournal $journal
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
|
|
|
public function search(TransactionJournal $journal, JournalRepositoryInterface $repository)
|
|
|
|
{
|
|
|
|
|
|
|
|
$search = e(trim(Input::get('searchValue')));
|
2015-03-04 09:04:17 -06:00
|
|
|
$parent = $journal;
|
2015-02-25 14:19:06 -06:00
|
|
|
|
2015-03-04 02:42:47 -06:00
|
|
|
$journals = $repository->searchRelated($search, $journal);
|
2015-03-04 09:04:17 -06:00
|
|
|
|
|
|
|
return view('related.searchResult', compact('journals', 'search', 'parent'));
|
2015-02-25 14:19:06 -06:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|