firefly-iii/app/Helpers/Report/ReportQueryInterface.php

116 lines
3.2 KiB
PHP
Raw Normal View History

2015-02-23 13:25:48 -06:00
<?php
namespace FireflyIII\Helpers\Report;
use Carbon\Carbon;
2015-02-23 14:19:16 -06:00
use FireflyIII\Models\Account;
2015-05-16 08:43:58 -05:00
use FireflyIII\Models\Budget;
2015-02-23 13:25:48 -06:00
use Illuminate\Support\Collection;
/**
* Interface ReportQueryInterface
*
* @package FireflyIII\Helpers\Report
*/
interface ReportQueryInterface
{
2015-05-19 23:49:03 -05:00
/**
* This method returns all "expense" journals in a certain period, which are both transfers to a shared account
* and "ordinary" withdrawals. The query used is almost equal to ReportQueryInterface::journalsByRevenueAccount but it does
* not group and returns different fields.
*
* @param Carbon $start
* @param Carbon $end
* @param bool $includeShared
*
* @return Collection
*
*/
public function expenseInPeriod(Carbon $start, Carbon $end, $includeShared = false);
/**
* See ReportQueryInterface::incomeInPeriodCorrected
*
* @param Carbon $start
* @param Carbon $end
* @param bool $includeShared
*
* @return Collection
*
*/
public function expenseInPeriodCorrected(Carbon $start, Carbon $end, $includeShared = false);
2015-02-23 14:19:16 -06:00
/**
* Get a users accounts combined with various meta-data related to the start and end date.
*
* @param Carbon $start
* @param Carbon $end
* @param bool $includeShared
*
* @return Collection
*/
public function getAllAccounts(Carbon $start, Carbon $end, $includeShared = false);
2015-02-23 13:25:48 -06:00
/**
* This method returns all "income" journals in a certain period, which are both transfers from a shared account
* and "ordinary" deposits. The query used is almost equal to ReportQueryInterface::journalsByRevenueAccount but it does
* not group and returns different fields.
*
* @param Carbon $start
* @param Carbon $end
* @param bool $includeShared
2015-02-23 13:25:48 -06:00
*
* @return Collection
*
2015-02-23 13:25:48 -06:00
*/
public function incomeInPeriod(Carbon $start, Carbon $end, $includeShared = false);
2015-02-23 13:25:48 -06:00
2015-05-16 01:05:04 -05:00
/**
2015-05-19 23:49:03 -05:00
* This method works the same way as ReportQueryInterface::incomeInPeriod does, but instead of returning results
* will simply list the transaction journals only. This should allow any follow up counting to be accurate with
* regards to tags.
2015-05-16 01:05:04 -05:00
*
* @param Carbon $start
* @param Carbon $end
* @param bool $includeShared
*
* @return Collection
*/
2015-05-19 23:49:03 -05:00
public function incomeInPeriodCorrected(Carbon $start, Carbon $end, $includeShared = false);
2015-02-23 13:25:48 -06:00
2015-05-16 08:43:58 -05:00
/**
* @param Account $account
* @param Budget $budget
* @param Carbon $start
* @param Carbon $end
*
* @return float
*/
2015-05-17 05:49:09 -05:00
public function spentInBudget(Account $account, Budget $budget, Carbon $start, Carbon $end);
2015-05-16 09:47:52 -05:00
/**
* Covers tags as well.
*
* @param Account $account
* @param Budget $budget
* @param Carbon $start
* @param Carbon $end
*
* @return float
*/
public function spentInBudgetCorrected(Account $account, Budget $budget, Carbon $start, Carbon $end);
2015-05-16 09:47:52 -05:00
/**
* @param Account $account
* @param Carbon $start
* @param Carbon $end
* @param bool $shared
*
* @return float
*/
public function spentNoBudget(Account $account, Carbon $start, Carbon $end, $shared = false);
2015-05-16 08:43:58 -05:00
2015-05-16 07:51:23 -05:00
2015-03-29 01:14:32 -05:00
}