2023-08-11 06:04:03 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
|
|
|
* PiggyBankRepository.php
|
|
|
|
* Copyright (c) 2023 james@firefly-iii.org
|
|
|
|
*
|
|
|
|
* This file is part of Firefly III (https://github.com/firefly-iii).
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program 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 Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2023-09-20 06:36:43 +02:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2023-09-21 15:50:49 +02:00
|
|
|
namespace FireflyIII\Repositories\UserGroups\PiggyBank;
|
2023-08-11 06:04:03 +02:00
|
|
|
|
2024-12-21 07:12:11 +01:00
|
|
|
use FireflyIII\Models\PiggyBank;
|
2023-09-21 15:50:49 +02:00
|
|
|
use FireflyIII\Support\Repositories\UserGroup\UserGroupTrait;
|
2023-08-11 06:04:03 +02:00
|
|
|
use Illuminate\Support\Collection;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class PiggyBankRepository
|
|
|
|
*/
|
|
|
|
class PiggyBankRepository implements PiggyBankRepositoryInterface
|
|
|
|
{
|
2023-09-21 15:50:49 +02:00
|
|
|
use UserGroupTrait;
|
2023-08-11 06:04:03 +02:00
|
|
|
|
|
|
|
public function getPiggyBanks(): Collection
|
|
|
|
{
|
2024-12-21 07:12:11 +01:00
|
|
|
return PiggyBank::leftJoin('account_piggy_bank', 'account_piggy_bank.piggy_bank_id', '=', 'piggy_banks.id')
|
2024-12-21 12:27:07 +01:00
|
|
|
->leftJoin('accounts', 'accounts.id', '=', 'account_piggy_bank.account_id')
|
|
|
|
->where('accounts.user_group_id', $this->userGroup->id)
|
|
|
|
->with(
|
|
|
|
[
|
|
|
|
'objectGroups',
|
|
|
|
]
|
|
|
|
)
|
|
|
|
->orderBy('piggy_banks.order', 'ASC')->distinct()->get(['piggy_banks.*'])
|
|
|
|
;
|
2023-08-11 06:04:03 +02:00
|
|
|
}
|
|
|
|
}
|