mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-01-14 02:32:04 -06:00
152 lines
3.5 KiB
PHP
152 lines
3.5 KiB
PHP
<?php
|
|
declare(strict_types=1);
|
|
|
|
namespace FireflyIII\Repositories\ObjectGroup;
|
|
|
|
use DB;
|
|
use FireflyIII\Models\ObjectGroup;
|
|
use FireflyIII\Models\PiggyBank;
|
|
use FireflyIII\User;
|
|
use Illuminate\Support\Collection;
|
|
use Log;
|
|
|
|
/**
|
|
* Class ObjectGroupRepository
|
|
*/
|
|
class ObjectGroupRepository implements ObjectGroupRepositoryInterface
|
|
{
|
|
/** @var User */
|
|
private $user;
|
|
|
|
/**
|
|
* Constructor.
|
|
*/
|
|
public function __construct()
|
|
{
|
|
if ('testing' === config('app.env')) {
|
|
Log::warning(sprintf('%s should not be instantiated in the TEST environment!', get_class($this)));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function get(): Collection
|
|
{
|
|
return $this->user->objectGroups()->orderBy('order', 'ASC')->orderBy('title', 'ASC')->get();
|
|
}
|
|
|
|
/**
|
|
* @param string $query
|
|
*
|
|
* @return Collection
|
|
*/
|
|
public function search(string $query): Collection
|
|
{
|
|
$dbQuery = $this->user->objectGroups()->orderBy('order', 'ASC')->orderBy('title', 'ASC');
|
|
if ('' !== $query) {
|
|
// split query on spaces just in case:
|
|
$parts = explode(' ', $query);
|
|
foreach ($parts as $part) {
|
|
$search = sprintf('%%%s%%', $part);
|
|
$dbQuery->where('title', 'LIKE', $search);
|
|
}
|
|
|
|
}
|
|
|
|
return $dbQuery->get(['object_groups.*']);
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function deleteEmpty(): void
|
|
{
|
|
$all = $this->get();
|
|
/** @var ObjectGroup $group */
|
|
foreach ($all as $group) {
|
|
$count = DB::table('object_groupables')->where('object_groupables.object_group_id', $group->id)->count();
|
|
if (0 === $count) {
|
|
$group->delete();
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function sort(): void
|
|
{
|
|
$all = $this->get();
|
|
/**
|
|
* @var int $index
|
|
* @var ObjectGroup $group
|
|
*/
|
|
foreach ($all as $index => $group) {
|
|
$group->order = $index + 1;
|
|
$group->save();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function setOrder(ObjectGroup $objectGroup, int $order): ObjectGroup
|
|
{
|
|
$order = 0 === $order ? 1 : $order;
|
|
$objectGroup->order = $order;
|
|
$objectGroup->save();
|
|
|
|
Log::debug(sprintf('Objectgroup #%d order is now %d', $objectGroup->id, $order));
|
|
|
|
return $objectGroup;
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function update(ObjectGroup $objectGroup, array $data): ObjectGroup
|
|
{
|
|
$objectGroup->title = $data['title'];
|
|
|
|
if (isset($data['order'])) {
|
|
$order = 0 === $data['order'] ? 1 : $data['order'];
|
|
$objectGroup->order = $order;
|
|
}
|
|
|
|
$objectGroup->save();
|
|
|
|
return $objectGroup;
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function destroy(ObjectGroup $objectGroup): void
|
|
{
|
|
$list = $objectGroup->piggyBanks;
|
|
/** @var PiggyBank $piggy */
|
|
foreach($list as $piggy) {
|
|
$piggy->objectGroups()->sync([]);
|
|
$piggy->save();
|
|
}
|
|
$objectGroup->delete();
|
|
}
|
|
|
|
/**
|
|
* @param User $user
|
|
*/
|
|
public function setUser(User $user): void
|
|
{
|
|
$this->user = $user;
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function getPiggyBanks(ObjectGroup $objectGroup): Collection
|
|
{
|
|
return $objectGroup->piggyBanks;
|
|
}
|
|
}
|