mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-11-04 05:15:39 +00:00 
			
		
		
		
	Fixed some query things.
This commit is contained in:
		@@ -20,6 +20,7 @@ use FireflyIII\Models\TransactionJournal;
 | 
			
		||||
use FireflyIII\Repositories\Budget\BudgetRepositoryInterface;
 | 
			
		||||
use FireflyIII\Support\CacheProperties;
 | 
			
		||||
use Illuminate\Support\Collection;
 | 
			
		||||
use Log;
 | 
			
		||||
use Navigation;
 | 
			
		||||
use Preferences;
 | 
			
		||||
use Response;
 | 
			
		||||
@@ -35,19 +36,14 @@ class BudgetController extends Controller
 | 
			
		||||
    /** @var BudgetChartGeneratorInterface */
 | 
			
		||||
    protected $generator;
 | 
			
		||||
 | 
			
		||||
    /** @var BudgetRepositoryInterface */
 | 
			
		||||
    protected $repository;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     *
 | 
			
		||||
     * BudgetController constructor.
 | 
			
		||||
     */
 | 
			
		||||
    public function __construct()
 | 
			
		||||
    {
 | 
			
		||||
        parent::__construct();
 | 
			
		||||
        // create chart generator:
 | 
			
		||||
        $this->generator = app(BudgetChartGeneratorInterface::class);
 | 
			
		||||
 | 
			
		||||
        $this->repository = app(BudgetRepositoryInterface::class);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
@@ -143,8 +139,9 @@ class BudgetController extends Controller
 | 
			
		||||
     *
 | 
			
		||||
     * @return \Symfony\Component\HttpFoundation\Response
 | 
			
		||||
     */
 | 
			
		||||
    public function frontpage()
 | 
			
		||||
    public function frontpage(BudgetRepositoryInterface $repository)
 | 
			
		||||
    {
 | 
			
		||||
        Log::debug('Hello');
 | 
			
		||||
        $start = session('start', Carbon::now()->startOfMonth());
 | 
			
		||||
        $end   = session('end', Carbon::now()->endOfMonth());
 | 
			
		||||
        // chart properties for cache:
 | 
			
		||||
@@ -156,8 +153,8 @@ class BudgetController extends Controller
 | 
			
		||||
        if ($cache->has()) {
 | 
			
		||||
            return Response::json($cache->get());
 | 
			
		||||
        }
 | 
			
		||||
        $budgets     = $this->repository->getActiveBudgets();
 | 
			
		||||
        $repetitions = $this->repository->getAllBudgetLimitRepetitions($start, $end);
 | 
			
		||||
        $budgets     = $repository->getActiveBudgets();
 | 
			
		||||
        $repetitions = $repository->getAllBudgetLimitRepetitions($start, $end);
 | 
			
		||||
        $allEntries  = new Collection;
 | 
			
		||||
 | 
			
		||||
        /** @var Budget $budget */
 | 
			
		||||
@@ -166,15 +163,15 @@ class BudgetController extends Controller
 | 
			
		||||
            $reps = $this->filterRepetitions($repetitions, $budget, $start, $end);
 | 
			
		||||
 | 
			
		||||
            if ($reps->count() === 0) {
 | 
			
		||||
                $collection = $this->spentInPeriodSingle($budget, $start, $end);
 | 
			
		||||
                $collection = $this->spentInPeriodSingle($repository, $budget, $start, $end);
 | 
			
		||||
                $allEntries = $allEntries->merge($collection);
 | 
			
		||||
                continue;
 | 
			
		||||
            }
 | 
			
		||||
            $collection = $this->spentInPeriodMulti($budget, $reps);
 | 
			
		||||
            $collection = $this->spentInPeriodMulti($repository, $budget, $reps);
 | 
			
		||||
            $allEntries = $allEntries->merge($collection);
 | 
			
		||||
 | 
			
		||||
        }
 | 
			
		||||
        $entry = $this->spentInPeriodWithout($start, $end);
 | 
			
		||||
        $entry = $this->spentInPeriodWithout($repository, $start, $end);
 | 
			
		||||
        $allEntries->push($entry);
 | 
			
		||||
        $data = $this->generator->frontpage($allEntries);
 | 
			
		||||
        $cache->store($data);
 | 
			
		||||
@@ -216,6 +213,7 @@ class BudgetController extends Controller
 | 
			
		||||
                if (in_array(strval($repetition->budget_id), $budgetIds)) {
 | 
			
		||||
                    return true;
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                return false;
 | 
			
		||||
            }
 | 
			
		||||
        );
 | 
			
		||||
@@ -292,6 +290,7 @@ class BudgetController extends Controller
 | 
			
		||||
                    if ($repetition->budget_id === $budget->id && $repetition->startdate == $currentStart) {
 | 
			
		||||
                        return true;
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    return false;
 | 
			
		||||
                }
 | 
			
		||||
            );
 | 
			
		||||
@@ -329,28 +328,31 @@ class BudgetController extends Controller
 | 
			
		||||
                if ($repetition->startdate < $end && $repetition->enddate > $start && $repetition->budget_id === $budget->id) {
 | 
			
		||||
                    return true;
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                return false;
 | 
			
		||||
            }
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * @param Budget     $budget
 | 
			
		||||
     * @param Collection $repetitions
 | 
			
		||||
     * @param BudgetRepositoryInterface $repository
 | 
			
		||||
     * @param Budget                    $budget
 | 
			
		||||
     * @param Collection                $repetitions
 | 
			
		||||
     *
 | 
			
		||||
     * @return Collection
 | 
			
		||||
     */
 | 
			
		||||
    private function spentInPeriodMulti(Budget $budget, Collection $repetitions): Collection
 | 
			
		||||
    private function spentInPeriodMulti(BudgetRepositoryInterface $repository, Budget $budget, Collection $repetitions): Collection
 | 
			
		||||
    {
 | 
			
		||||
        $format     = strval(trans('config.month_and_day'));
 | 
			
		||||
        $collection = new Collection;
 | 
			
		||||
        $name       = $budget->name;
 | 
			
		||||
        /** @var LimitRepetition $repetition */
 | 
			
		||||
        foreach ($repetitions as $repetition) {
 | 
			
		||||
            $expenses = $this->repository->spentInPeriod(new Collection([$budget]), new Collection, $repetition->startdate, $repetition->enddate);
 | 
			
		||||
            $expenses = $repository->spentInPeriod(new Collection([$budget]), new Collection, $repetition->startdate, $repetition->enddate);
 | 
			
		||||
 | 
			
		||||
            if ($repetitions->count() > 1) {
 | 
			
		||||
                $name = $budget->name . ' ' . trans('firefly.between_dates',
 | 
			
		||||
                $name = $budget->name . ' ' . trans(
 | 
			
		||||
                        'firefly.between_dates',
 | 
			
		||||
                        ['start' => $repetition->startdate->formatLocalized($format), 'end' => $repetition->enddate->formatLocalized($format)]
 | 
			
		||||
                    );
 | 
			
		||||
            }
 | 
			
		||||
@@ -366,18 +368,19 @@ class BudgetController extends Controller
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * @param Budget $budget
 | 
			
		||||
     * @param Carbon $start
 | 
			
		||||
     * @param Carbon $end
 | 
			
		||||
     * @param BudgetRepositoryInterface $repository
 | 
			
		||||
     * @param Budget                    $budget
 | 
			
		||||
     * @param Carbon                    $start
 | 
			
		||||
     * @param Carbon                    $end
 | 
			
		||||
     *
 | 
			
		||||
     * @return Collection
 | 
			
		||||
     */
 | 
			
		||||
    private function spentInPeriodSingle(Budget $budget, Carbon $start, Carbon $end): Collection
 | 
			
		||||
    private function spentInPeriodSingle(BudgetRepositoryInterface $repository, Budget $budget, Carbon $start, Carbon $end): Collection
 | 
			
		||||
    {
 | 
			
		||||
        $collection = new Collection;
 | 
			
		||||
        $amount     = '0';
 | 
			
		||||
        $left       = '0';
 | 
			
		||||
        $spent      = $this->repository->spentInPeriod(new Collection([$budget]), new Collection, $start, $end);
 | 
			
		||||
        $spent      = $repository->spentInPeriod(new Collection([$budget]), new Collection, $start, $end);
 | 
			
		||||
        $overspent  = '0';
 | 
			
		||||
        $array      = [$budget->name, $left, $spent, $overspent, $amount, $spent];
 | 
			
		||||
        $collection->push($array);
 | 
			
		||||
@@ -386,14 +389,15 @@ class BudgetController extends Controller
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * @param Carbon $start
 | 
			
		||||
     * @param Carbon $end
 | 
			
		||||
     * @param BudgetRepositoryInterface $repository
 | 
			
		||||
     * @param Carbon                    $start
 | 
			
		||||
     * @param Carbon                    $end
 | 
			
		||||
     *
 | 
			
		||||
     * @return array
 | 
			
		||||
     */
 | 
			
		||||
    private function spentInPeriodWithout(Carbon $start, Carbon $end):array
 | 
			
		||||
    private function spentInPeriodWithout(BudgetRepositoryInterface $repository, Carbon $start, Carbon $end):array
 | 
			
		||||
    {
 | 
			
		||||
        $list = $this->repository->journalsInPeriodWithoutBudget(new Collection, $start, $end);
 | 
			
		||||
        $list = $repository->journalsInPeriodWithoutBudget(new Collection, $start, $end);
 | 
			
		||||
        $sum  = '0';
 | 
			
		||||
        /** @var TransactionJournal $entry */
 | 
			
		||||
        foreach ($list as $entry) {
 | 
			
		||||
 
 | 
			
		||||
@@ -358,8 +358,29 @@ class TransactionJournal extends TransactionJournalSupport
 | 
			
		||||
        // left join transaction currency:
 | 
			
		||||
        $query->leftJoin('transaction_currencies', 'transaction_currencies.id', '=', 'transaction_journals.transaction_currency_id');
 | 
			
		||||
 | 
			
		||||
        // left join destination (for amount and account info).
 | 
			
		||||
        $query->groupBy('transaction_journals.id');
 | 
			
		||||
        // extend group by:
 | 
			
		||||
        $query->groupBy(
 | 
			
		||||
            [
 | 
			
		||||
                'transaction_journals.id',
 | 
			
		||||
                'transaction_journals.created_at',
 | 
			
		||||
                'transaction_journals.updated_at',
 | 
			
		||||
                'transaction_journals.deleted_at',
 | 
			
		||||
                'transaction_journals.user_id',
 | 
			
		||||
                'transaction_journals.transaction_type_id',
 | 
			
		||||
                'transaction_journals.bill_id',
 | 
			
		||||
                'transaction_journals.transaction_currency_id',
 | 
			
		||||
                'transaction_journals.description',
 | 
			
		||||
                'transaction_journals.date',
 | 
			
		||||
                'transaction_journals.interest_date',
 | 
			
		||||
                'transaction_journals.book_date',
 | 
			
		||||
                'transaction_journals.process_date',
 | 
			
		||||
                'transaction_journals.order',
 | 
			
		||||
                'transaction_journals.tag_count',
 | 
			
		||||
                'transaction_journals.encrypted',
 | 
			
		||||
                'transaction_journals.completed',
 | 
			
		||||
                'transaction_types.type',
 | 
			
		||||
                'transaction_currencies.code',
 | 
			
		||||
            ]);
 | 
			
		||||
        $query->with(['categories', 'budgets', 'attachments', 'bill', 'transactions']);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -430,6 +430,12 @@ class AccountRepository implements AccountRepositoryInterface
 | 
			
		||||
        $fields[] = 'source.amount as source_amount';
 | 
			
		||||
        $fields[] = 'destination.account_id as destination_account_id';
 | 
			
		||||
        $fields[] = 'destination.amount as destination_amount';
 | 
			
		||||
 | 
			
		||||
        $query->groupBy(['source.account_id',
 | 
			
		||||
                'source.amount',
 | 
			
		||||
                'destination.account_id',
 | 
			
		||||
                'destination.amount',]);
 | 
			
		||||
 | 
			
		||||
        $complete = $query->get($fields);
 | 
			
		||||
 | 
			
		||||
        return $complete;
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user