2020-03-21 03:01:14 -05:00
|
|
|
<?php
|
2020-06-30 12:05:35 -05:00
|
|
|
|
2020-03-21 03:01:14 -05:00
|
|
|
/**
|
|
|
|
* TimeCollection.php
|
|
|
|
* Copyright (c) 2020 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/>.
|
|
|
|
*/
|
|
|
|
|
2020-06-30 12:05:35 -05:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2020-03-21 03:01:14 -05:00
|
|
|
namespace FireflyIII\Helpers\Collector\Extensions;
|
|
|
|
|
|
|
|
use Carbon\Carbon;
|
|
|
|
use FireflyIII\Helpers\Collector\GroupCollectorInterface;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Trait TimeCollection
|
|
|
|
*/
|
|
|
|
trait TimeCollection
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Collect transactions after a specific date.
|
|
|
|
*
|
|
|
|
* @param Carbon $date
|
|
|
|
*
|
|
|
|
* @return GroupCollectorInterface
|
|
|
|
*/
|
|
|
|
public function setAfter(Carbon $date): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$afterStr = $date->format('Y-m-d 00:00:00');
|
|
|
|
$this->query->where('transaction_journals.date', '>=', $afterStr);
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Collect transactions before a specific date.
|
|
|
|
*
|
|
|
|
* @param Carbon $date
|
|
|
|
*
|
|
|
|
* @return GroupCollectorInterface
|
|
|
|
*/
|
|
|
|
public function setBefore(Carbon $date): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$beforeStr = $date->format('Y-m-d 00:00:00');
|
|
|
|
$this->query->where('transaction_journals.date', '<=', $beforeStr);
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Collect transactions created on a specific date.
|
|
|
|
*
|
|
|
|
* @param Carbon $date
|
|
|
|
*
|
|
|
|
* @return GroupCollectorInterface
|
|
|
|
*/
|
|
|
|
public function setCreatedAt(Carbon $date): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$after = $date->format('Y-m-d 00:00:00');
|
|
|
|
$before = $date->format('Y-m-d 23:59:59');
|
|
|
|
$this->query->where('transaction_journals.created_at', '>=', $after);
|
|
|
|
$this->query->where('transaction_journals.created_at', '<=', $before);
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the start and end time of the results to return.
|
|
|
|
*
|
|
|
|
* @param Carbon $start
|
|
|
|
* @param Carbon $end
|
|
|
|
*
|
|
|
|
* @return GroupCollectorInterface
|
|
|
|
*/
|
|
|
|
public function setRange(Carbon $start, Carbon $end): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
if ($end < $start) {
|
|
|
|
[$start, $end] = [$end, $start];
|
|
|
|
}
|
2020-05-03 12:38:03 -05:00
|
|
|
// always got to end of day / start of day for ranges.
|
|
|
|
$startStr = $start->format('Y-m-d 00:00:00');
|
|
|
|
$endStr = $end->format('Y-m-d 23:59:59');
|
2020-03-21 03:01:14 -05:00
|
|
|
|
|
|
|
$this->query->where('transaction_journals.date', '>=', $startStr);
|
|
|
|
$this->query->where('transaction_journals.date', '<=', $endStr);
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
2021-03-28 04:46:23 -05:00
|
|
|
|
2020-03-21 03:01:14 -05:00
|
|
|
/**
|
|
|
|
* Collect transactions updated on a specific date.
|
|
|
|
*
|
|
|
|
* @param Carbon $date
|
|
|
|
*
|
|
|
|
* @return GroupCollectorInterface
|
|
|
|
*/
|
|
|
|
public function setUpdatedAt(Carbon $date): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$after = $date->format('Y-m-d 00:00:00');
|
|
|
|
$before = $date->format('Y-m-d 23:59:59');
|
|
|
|
$this->query->where('transaction_journals.updated_at', '>=', $after);
|
|
|
|
$this->query->where('transaction_journals.updated_at', '<=', $before);
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
2021-12-17 10:27:29 -06:00
|
|
|
|
|
|
|
public function yearIs(string $year): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$this->query->whereYear('transaction_journals.date', '=', $year);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function monthIs(string $month): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$this->query->whereMonth('transaction_journals.date', '=', $month);
|
|
|
|
return $this;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function dayIs(string $day): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$this->query->whereDay('transaction_journals.date', '=', $day);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function yearBefore(string $year): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$this->query->whereYear('transaction_journals.date', '<=', $year);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function monthBefore(string $month): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$this->query->whereMonth('transaction_journals.date', '<=', $month);
|
|
|
|
return $this;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function dayBefore(string $day): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$this->query->whereDay('transaction_journals.date', '<=', $day);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function yearAfter(string $year): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$this->query->whereYear('transaction_journals.date', '>=', $year);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function monthAfter(string $month): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$this->query->whereMonth('transaction_journals.date', '>=', $month);
|
|
|
|
return $this;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function dayAfter(string $day): GroupCollectorInterface
|
|
|
|
{
|
|
|
|
$this->query->whereDay('transaction_journals.date', '>=', $day);
|
|
|
|
return $this;
|
|
|
|
}
|
2020-05-03 12:38:03 -05:00
|
|
|
}
|