mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-09-25 06:51:08 +00:00
New stuff for categories and transactions.
This commit is contained in:
@@ -3,7 +3,7 @@ declare(strict_types = 1);
|
|||||||
namespace FireflyIII\Helpers\Csv\Converter;
|
namespace FireflyIII\Helpers\Csv\Converter;
|
||||||
|
|
||||||
use FireflyIII\Models\Category;
|
use FireflyIII\Models\Category;
|
||||||
use FireflyIII\Repositories\Category\SingleCategoryRepositoryInterface;
|
use FireflyIII\Repositories\Category\CategoryRepositoryInterface;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class CategoryId
|
* Class CategoryId
|
||||||
@@ -18,8 +18,8 @@ class CategoryId extends BasicConverter implements ConverterInterface
|
|||||||
*/
|
*/
|
||||||
public function convert(): Category
|
public function convert(): Category
|
||||||
{
|
{
|
||||||
/** @var SingleCategoryRepositoryInterface $repository */
|
/** @var CategoryRepositoryInterface $repository */
|
||||||
$repository = app(SingleCategoryRepositoryInterface::class);
|
$repository = app(CategoryRepositoryInterface::class);
|
||||||
$value = isset($this->mapped[$this->index][$this->value]) ? $this->mapped[$this->index][$this->value] : $this->value;
|
$value = isset($this->mapped[$this->index][$this->value]) ? $this->mapped[$this->index][$this->value] : $this->value;
|
||||||
$category = $repository->find($value);
|
$category = $repository->find($value);
|
||||||
|
|
||||||
|
@@ -4,7 +4,7 @@ namespace FireflyIII\Helpers\Csv\Converter;
|
|||||||
|
|
||||||
use Auth;
|
use Auth;
|
||||||
use FireflyIII\Models\Category;
|
use FireflyIII\Models\Category;
|
||||||
use FireflyIII\Repositories\Category\SingleCategoryRepositoryInterface;
|
use FireflyIII\Repositories\Category\CategoryRepositoryInterface;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class CategoryName
|
* Class CategoryName
|
||||||
@@ -19,8 +19,8 @@ class CategoryName extends BasicConverter implements ConverterInterface
|
|||||||
*/
|
*/
|
||||||
public function convert(): Category
|
public function convert(): Category
|
||||||
{
|
{
|
||||||
/** @var SingleCategoryRepositoryInterface $repository */
|
/** @var CategoryRepositoryInterface $repository */
|
||||||
$repository = app(SingleCategoryRepositoryInterface::class);
|
$repository = app(CategoryRepositoryInterface::class);
|
||||||
|
|
||||||
// is mapped? Then it's easy!
|
// is mapped? Then it's easy!
|
||||||
if (isset($this->mapped[$this->index][$this->value])) {
|
if (isset($this->mapped[$this->index][$this->value])) {
|
||||||
|
@@ -141,7 +141,7 @@ class BudgetReportHelper implements BudgetReportHelperInterface
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Take the array as returned by SingleCategoryRepositoryInterface::spentPerDay and SingleCategoryRepositoryInterface::earnedByDay
|
* Take the array as returned by CategoryRepositoryInterface::spentPerDay and CategoryRepositoryInterface::earnedByDay
|
||||||
* and sum up everything in the array in the given range.
|
* and sum up everything in the array in the given range.
|
||||||
*
|
*
|
||||||
* @param Carbon $start
|
* @param Carbon $start
|
||||||
|
@@ -39,4 +39,13 @@ interface BudgetReportHelperInterface
|
|||||||
* @return Collection
|
* @return Collection
|
||||||
*/
|
*/
|
||||||
public function getBudgetsWithExpenses(Carbon $start, Carbon $end, Collection $accounts): Collection;
|
public function getBudgetsWithExpenses(Carbon $start, Carbon $end, Collection $accounts): Collection;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param $start
|
||||||
|
* @param $end
|
||||||
|
* @param $accounts
|
||||||
|
*
|
||||||
|
* @return Collection
|
||||||
|
*/
|
||||||
|
public function getCategoriesWithTransactions($start, $end, $accounts): Collection;
|
||||||
}
|
}
|
||||||
|
@@ -103,35 +103,35 @@ class ReportHelper implements ReportHelperInterface
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Find all transactions and IF we have spent money in them
|
||||||
|
* with either transactions or journals.
|
||||||
|
*
|
||||||
* @param Carbon $start
|
* @param Carbon $start
|
||||||
* @param Carbon $end
|
* @param Carbon $end
|
||||||
* @param Collection $accounts
|
* @param Collection $accounts
|
||||||
*
|
*
|
||||||
* @return Collection
|
* @return Collection
|
||||||
*/
|
*/
|
||||||
public function getCategoriesWithExpenses(Carbon $start, Carbon $end, Collection $accounts): Collection
|
public function getCategoriesWithTransactions(Carbon $start, Carbon $end, Collection $accounts): Collection
|
||||||
{
|
{
|
||||||
/** @var CategoryRepositoryInterface $repository */
|
/** @var CategoryRepositoryInterface $repository */
|
||||||
$repository = app(CategoryRepositoryInterface::class);
|
$repository = app(CategoryRepositoryInterface::class);
|
||||||
$collection = $repository->earnedForAccountsPerMonth($accounts, $start, $end);
|
$categories = $repository->getCategories();
|
||||||
$second = $repository->spentForAccountsPerMonth($accounts, $start, $end);
|
$return = new Collection;
|
||||||
$collection = $collection->merge($second);
|
foreach ($categories as $category) {
|
||||||
$array = [];
|
$lastUseDate = $repository->lastUseDate($category, $accounts);
|
||||||
/** @var Category $category */
|
if ($lastUseDate >= $start && $lastUseDate <= $end) {
|
||||||
foreach ($collection as $category) {
|
$return->push($category);
|
||||||
$id = $category->id;
|
}
|
||||||
$array[$id] = $category;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
$set = new Collection($array);
|
|
||||||
|
|
||||||
$set = $set->sortBy(
|
$return = $return->sortBy(
|
||||||
function (Category $category) {
|
function (Category $category) {
|
||||||
return $category->name;
|
return $category->name;
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
return $set;
|
return $return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -144,15 +144,15 @@ class ReportHelper implements ReportHelperInterface
|
|||||||
public function getCategoryReport(Carbon $start, Carbon $end, Collection $accounts): CategoryCollection
|
public function getCategoryReport(Carbon $start, Carbon $end, Collection $accounts): CategoryCollection
|
||||||
{
|
{
|
||||||
$object = new CategoryCollection;
|
$object = new CategoryCollection;
|
||||||
|
/** @var CategoryRepositoryInterface $repository */
|
||||||
/**
|
|
||||||
* GET CATEGORIES:
|
|
||||||
*/
|
|
||||||
/** @var \FireflyIII\Repositories\Category\CategoryRepositoryInterface $repository */
|
|
||||||
$repository = app(CategoryRepositoryInterface::class);
|
$repository = app(CategoryRepositoryInterface::class);
|
||||||
|
$categories = $repository->getCategories();
|
||||||
|
|
||||||
$set = $repository->spentForAccountsPerMonth($accounts, $start, $end);
|
/** @var Category $category */
|
||||||
foreach ($set as $category) {
|
foreach ($categories as $category) {
|
||||||
|
$spent = $repository->spentInPeriod(new Collection([$category]), $accounts, $start, $end);
|
||||||
|
// CategoryCollection expects the amount in $spent:
|
||||||
|
$category->spent = $spent;
|
||||||
$object->addCategory($category);
|
$object->addCategory($category);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -312,7 +312,7 @@ class ReportHelper implements ReportHelperInterface
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Take the array as returned by SingleCategoryRepositoryInterface::spentPerDay and SingleCategoryRepositoryInterface::earnedByDay
|
* Take the array as returned by CategoryRepositoryInterface::spentPerDay and CategoryRepositoryInterface::earnedByDay
|
||||||
* and sum up everything in the array in the given range.
|
* and sum up everything in the array in the given range.
|
||||||
*
|
*
|
||||||
* @param Carbon $start
|
* @param Carbon $start
|
||||||
|
@@ -3,9 +3,9 @@
|
|||||||
use Auth;
|
use Auth;
|
||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
use FireflyIII\Http\Requests\CategoryFormRequest;
|
use FireflyIII\Http\Requests\CategoryFormRequest;
|
||||||
|
use FireflyIII\Models\Account;
|
||||||
use FireflyIII\Models\Category;
|
use FireflyIII\Models\Category;
|
||||||
use FireflyIII\Repositories\Category\CategoryRepositoryInterface as CRI;
|
use FireflyIII\Repositories\Category\CategoryRepositoryInterface as CRI;
|
||||||
use FireflyIII\Repositories\Category\SingleCategoryRepositoryInterface as SCRI;
|
|
||||||
use FireflyIII\Support\CacheProperties;
|
use FireflyIII\Support\CacheProperties;
|
||||||
use Illuminate\Pagination\LengthAwarePaginator;
|
use Illuminate\Pagination\LengthAwarePaginator;
|
||||||
use Illuminate\Support\Collection;
|
use Illuminate\Support\Collection;
|
||||||
@@ -69,12 +69,12 @@ class CategoryController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param SCRI $repository
|
* @param CRI $repository
|
||||||
* @param Category $category
|
* @param Category $category
|
||||||
*
|
*
|
||||||
* @return \Illuminate\Http\RedirectResponse
|
* @return \Illuminate\Http\RedirectResponse
|
||||||
*/
|
*/
|
||||||
public function destroy(SCRI $repository, Category $category)
|
public function destroy(CRI $repository, Category $category)
|
||||||
{
|
{
|
||||||
|
|
||||||
$name = $category->name;
|
$name = $category->name;
|
||||||
@@ -108,18 +108,17 @@ class CategoryController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param CRI $repository
|
* @param CRI $repository
|
||||||
* @param SCRI $singleRepository
|
|
||||||
*
|
*
|
||||||
* @return \Illuminate\View\View
|
* @return \Illuminate\View\View
|
||||||
*/
|
*/
|
||||||
public function index(CRI $repository, SCRI $singleRepository)
|
public function index(CRI $repository)
|
||||||
{
|
{
|
||||||
$categories = $repository->getCategories();
|
$categories = $repository->getCategories();
|
||||||
|
|
||||||
$categories->each(
|
$categories->each(
|
||||||
function (Category $category) use ($singleRepository) {
|
function (Category $category) use ($repository) {
|
||||||
$category->lastActivity = $singleRepository->getLatestActivity($category);
|
$category->lastActivity = $repository->lastUseDate($category, new Collection);
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -137,7 +136,7 @@ class CategoryController extends Controller
|
|||||||
$start = session('start', Carbon::now()->startOfMonth());
|
$start = session('start', Carbon::now()->startOfMonth());
|
||||||
/** @var Carbon $end */
|
/** @var Carbon $end */
|
||||||
$end = session('end', Carbon::now()->startOfMonth());
|
$end = session('end', Carbon::now()->startOfMonth());
|
||||||
$list = $repository->listNoCategory($start, $end);
|
$list = $repository->journalsInPeriodWithoutCategory(new Collection(), $start, $end);
|
||||||
$subTitle = trans(
|
$subTitle = trans(
|
||||||
'firefly.without_category_between',
|
'firefly.without_category_between',
|
||||||
['start' => $start->formatLocalized($this->monthAndDayFormat), 'end' => $end->formatLocalized($this->monthAndDayFormat)]
|
['start' => $start->formatLocalized($this->monthAndDayFormat), 'end' => $end->formatLocalized($this->monthAndDayFormat)]
|
||||||
@@ -147,26 +146,24 @@ class CategoryController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param SCRI $repository
|
* @param CRI $repository
|
||||||
* @param Category $category
|
* @param Category $category
|
||||||
*
|
*
|
||||||
* @return \Illuminate\View\View
|
* @return \Illuminate\View\View
|
||||||
*/
|
*/
|
||||||
public function show(SCRI $repository, Category $category)
|
public function show(CRI $repository, Category $category)
|
||||||
{
|
{
|
||||||
$hideCategory = true; // used in list.
|
$hideCategory = true; // used in list.
|
||||||
$pageSize = Preferences::get('transactionPageSize', 50)->data;
|
$pageSize = Preferences::get('transactionPageSize', 50)->data;
|
||||||
$page = intval(Input::get('page'));
|
$page = intval(Input::get('page'));
|
||||||
$set = $repository->getJournals($category, $page, $pageSize);
|
$journals = $repository->getJournals($category, $page, $pageSize);
|
||||||
$count = $repository->countJournals($category);
|
|
||||||
$subTitle = $category->name;
|
|
||||||
$journals = new LengthAwarePaginator($set, $count, $pageSize, $page);
|
|
||||||
$journals->setPath('categories/show/' . $category->id);
|
$journals->setPath('categories/show/' . $category->id);
|
||||||
|
|
||||||
// list of ranges for list of periods:
|
// list of ranges for list of periods:
|
||||||
|
|
||||||
// oldest transaction in category:
|
// oldest transaction in category:
|
||||||
$start = $repository->getFirstActivityDate($category);
|
//$start = $repository->getFirstActivityDate($category);
|
||||||
|
$start = $repository->firstUseDate($category, new Account);
|
||||||
$range = Preferences::get('viewRange', '1M')->data;
|
$range = Preferences::get('viewRange', '1M')->data;
|
||||||
$start = Navigation::startOfPeriod($start, $range);
|
$start = Navigation::startOfPeriod($start, $range);
|
||||||
$end = Navigation::endOfX(new Carbon, $range);
|
$end = Navigation::endOfX(new Carbon, $range);
|
||||||
@@ -179,26 +176,22 @@ class CategoryController extends Controller
|
|||||||
$cache->addProperty('category-show');
|
$cache->addProperty('category-show');
|
||||||
$cache->addProperty($category->id);
|
$cache->addProperty($category->id);
|
||||||
|
|
||||||
// get all spent and earned data:
|
|
||||||
// get amount earned in period, grouped by day.
|
|
||||||
$spentArray = $repository->spentPerDay($category, $start, $end, new Collection);
|
|
||||||
$earnedArray = $repository->earnedPerDay($category, $start, $end, new Collection);
|
|
||||||
|
|
||||||
if ($cache->has()) {
|
if ($cache->has()) {
|
||||||
$entries = $cache->get();
|
//$entries = $cache->get();
|
||||||
|
//return view('categories.show', compact('category', 'journals', 'entries', 'hideCategory', 'subTitle'));
|
||||||
return view('categories.show', compact('category', 'journals', 'entries', 'hideCategory', 'subTitle'));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$categoryCollection = new Collection([$category]);
|
||||||
|
$empty = new Collection;
|
||||||
while ($end >= $start) {
|
while ($end >= $start) {
|
||||||
$end = Navigation::startOfPeriod($end, $range);
|
$end = Navigation::startOfPeriod($end, $range);
|
||||||
$currentEnd = Navigation::endOfPeriod($end, $range);
|
$currentEnd = Navigation::endOfPeriod($end, $range);
|
||||||
|
$spent = $repository->spentInPeriod($categoryCollection, $empty, $end, $currentEnd);
|
||||||
// get data from spentArray:
|
$earned = $repository->earnedInPeriod($categoryCollection, $empty, $end, $currentEnd);
|
||||||
$spent = $this->getSumOfRange($end, $currentEnd, $spentArray);
|
$dateStr = $end->format('Y-m-d');
|
||||||
$earned = $this->getSumOfRange($end, $currentEnd, $earnedArray);
|
$dateName = Navigation::periodShow($end, $range);
|
||||||
$dateStr = $end->format('Y-m-d');
|
|
||||||
$dateName = Navigation::periodShow($end, $range);
|
|
||||||
$entries->push([$dateStr, $dateName, $spent, $earned]);
|
$entries->push([$dateStr, $dateName, $spent, $earned]);
|
||||||
|
|
||||||
$end = Navigation::subtractPeriod($end, $range, 1);
|
$end = Navigation::subtractPeriod($end, $range, 1);
|
||||||
@@ -210,28 +203,28 @@ class CategoryController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param SCRI $repository
|
* @param CRI $repository
|
||||||
* @param Category $category
|
* @param Category $category
|
||||||
*
|
*
|
||||||
* @param $date
|
* @param $date
|
||||||
*
|
*
|
||||||
* @return \Illuminate\View\View
|
* @return \Illuminate\View\View
|
||||||
*/
|
*/
|
||||||
public function showWithDate(SCRI $repository, Category $category, string $date)
|
public function showWithDate(CRI $repository, Category $category, string $date)
|
||||||
{
|
{
|
||||||
$carbon = new Carbon($date);
|
$carbon = new Carbon($date);
|
||||||
$range = Preferences::get('viewRange', '1M')->data;
|
$range = Preferences::get('viewRange', '1M')->data;
|
||||||
$start = Navigation::startOfPeriod($carbon, $range);
|
$start = Navigation::startOfPeriod($carbon, $range);
|
||||||
$end = Navigation::endOfPeriod($carbon, $range);
|
$end = Navigation::endOfPeriod($carbon, $range);
|
||||||
$subTitle = $category->name;
|
$subTitle = $category->name;
|
||||||
|
|
||||||
$hideCategory = true; // used in list.
|
$hideCategory = true; // used in list.
|
||||||
$page = intval(Input::get('page'));
|
$page = intval(Input::get('page'));
|
||||||
$pageSize = Preferences::get('transactionPageSize', 50)->data;
|
$pageSize = Preferences::get('transactionPageSize', 50)->data;
|
||||||
|
$offset = ($page - 1) * $pageSize;
|
||||||
$set = $repository->getJournalsInRange($category, $start, $end, $page, $pageSize);
|
$set = $repository->journalsInPeriod(new Collection([$category]), new Collection, [], $start, $end);
|
||||||
$count = $repository->countJournals($category, $start, $end);
|
$count = $set->count();
|
||||||
$journals = new LengthAwarePaginator($set, $count, $pageSize, $page);
|
$subSet = $set->splice($offset, $pageSize);
|
||||||
|
$journals = new LengthAwarePaginator($subSet, $count, $pageSize, $page);
|
||||||
$journals->setPath('categories/show/' . $category->id . '/' . $date);
|
$journals->setPath('categories/show/' . $category->id . '/' . $date);
|
||||||
|
|
||||||
return view('categories.show_with_date', compact('category', 'journals', 'hideCategory', 'subTitle', 'carbon'));
|
return view('categories.show_with_date', compact('category', 'journals', 'hideCategory', 'subTitle', 'carbon'));
|
||||||
@@ -239,11 +232,11 @@ class CategoryController extends Controller
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @param CategoryFormRequest $request
|
* @param CategoryFormRequest $request
|
||||||
* @param SCRI $repository
|
* @param CRI $repository
|
||||||
*
|
*
|
||||||
* @return \Illuminate\Http\RedirectResponse
|
* @return \Illuminate\Http\RedirectResponse
|
||||||
*/
|
*/
|
||||||
public function store(CategoryFormRequest $request, SCRI $repository)
|
public function store(CategoryFormRequest $request, CRI $repository)
|
||||||
{
|
{
|
||||||
$categoryData = [
|
$categoryData = [
|
||||||
'name' => $request->input('name'),
|
'name' => $request->input('name'),
|
||||||
@@ -266,12 +259,12 @@ class CategoryController extends Controller
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @param CategoryFormRequest $request
|
* @param CategoryFormRequest $request
|
||||||
* @param SCRI $repository
|
* @param CRI $repository
|
||||||
* @param Category $category
|
* @param Category $category
|
||||||
*
|
*
|
||||||
* @return \Illuminate\Http\RedirectResponse
|
* @return \Illuminate\Http\RedirectResponse
|
||||||
*/
|
*/
|
||||||
public function update(CategoryFormRequest $request, SCRI $repository, Category $category)
|
public function update(CategoryFormRequest $request, CRI $repository, Category $category)
|
||||||
{
|
{
|
||||||
$categoryData = [
|
$categoryData = [
|
||||||
'name' => $request->input('name'),
|
'name' => $request->input('name'),
|
||||||
|
@@ -10,8 +10,6 @@ use FireflyIII\Http\Controllers\Controller;
|
|||||||
use FireflyIII\Models\Category;
|
use FireflyIII\Models\Category;
|
||||||
use FireflyIII\Repositories\Account\AccountRepositoryInterface as ARI;
|
use FireflyIII\Repositories\Account\AccountRepositoryInterface as ARI;
|
||||||
use FireflyIII\Repositories\Category\CategoryRepositoryInterface as CRI;
|
use FireflyIII\Repositories\Category\CategoryRepositoryInterface as CRI;
|
||||||
use FireflyIII\Repositories\Category\SingleCategoryRepositoryInterface;
|
|
||||||
use FireflyIII\Repositories\Category\SingleCategoryRepositoryInterface as SCRI;
|
|
||||||
use FireflyIII\Support\CacheProperties;
|
use FireflyIII\Support\CacheProperties;
|
||||||
use Illuminate\Support\Collection;
|
use Illuminate\Support\Collection;
|
||||||
use Navigation;
|
use Navigation;
|
||||||
@@ -47,13 +45,14 @@ class CategoryController extends Controller
|
|||||||
/**
|
/**
|
||||||
* Show an overview for a category for all time, per month/week/year.
|
* Show an overview for a category for all time, per month/week/year.
|
||||||
*
|
*
|
||||||
* @param SCRI $repository
|
* @param CRI $repository
|
||||||
* @param Category $category
|
* @param Category $category
|
||||||
*
|
*
|
||||||
* @return \Symfony\Component\HttpFoundation\Response
|
* @return \Symfony\Component\HttpFoundation\Response
|
||||||
*/
|
*/
|
||||||
public function all(SCRI $repository, Category $category)
|
public function all(CRI $repository, Category $category)
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
// oldest transaction in category:
|
// oldest transaction in category:
|
||||||
$start = $repository->getFirstActivityDate($category);
|
$start = $repository->getFirstActivityDate($category);
|
||||||
$range = Preferences::get('viewRange', '1M')->data;
|
$range = Preferences::get('viewRange', '1M')->data;
|
||||||
@@ -87,21 +86,24 @@ class CategoryController extends Controller
|
|||||||
$cache->store($data);
|
$cache->store($data);
|
||||||
|
|
||||||
return Response::json($data);
|
return Response::json($data);
|
||||||
|
* **/
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param SCRI $repository
|
* @param CRI $repository
|
||||||
* @param Category $category
|
* @param Category $category
|
||||||
*
|
*
|
||||||
* @return \Symfony\Component\HttpFoundation\Response
|
* @return \Symfony\Component\HttpFoundation\Response
|
||||||
*/
|
*/
|
||||||
public function currentPeriod(SCRI $repository, Category $category)
|
public function currentPeriod(CRI $repository, Category $category)
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
$start = clone session('start', Carbon::now()->startOfMonth());
|
$start = clone session('start', Carbon::now()->startOfMonth());
|
||||||
$end = session('end', Carbon::now()->endOfMonth());
|
$end = session('end', Carbon::now()->endOfMonth());
|
||||||
$data = $this->makePeriodChart($repository, $category, $start, $end);
|
$data = $this->makePeriodChart($repository, $category, $start, $end);
|
||||||
|
|
||||||
return Response::json($data);
|
return Response::json($data);
|
||||||
|
* **/
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -118,6 +120,7 @@ class CategoryController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function earnedInPeriod(CRI $repository, string $reportType, Carbon $start, Carbon $end, Collection $accounts)
|
public function earnedInPeriod(CRI $repository, string $reportType, Carbon $start, Carbon $end, Collection $accounts)
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
$cache = new CacheProperties; // chart properties for cache:
|
$cache = new CacheProperties; // chart properties for cache:
|
||||||
$cache->addProperty($start);
|
$cache->addProperty($start);
|
||||||
$cache->addProperty($end);
|
$cache->addProperty($end);
|
||||||
@@ -140,7 +143,7 @@ class CategoryController extends Controller
|
|||||||
$cache->store($data);
|
$cache->store($data);
|
||||||
|
|
||||||
return $data;
|
return $data;
|
||||||
|
**/
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -154,7 +157,7 @@ class CategoryController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function frontpage(CRI $repository, ARI $accountRepository)
|
public function frontpage(CRI $repository, ARI $accountRepository)
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
$start = session('start', Carbon::now()->startOfMonth());
|
$start = session('start', Carbon::now()->startOfMonth());
|
||||||
$end = session('end', Carbon::now()->endOfMonth());
|
$end = session('end', Carbon::now()->endOfMonth());
|
||||||
|
|
||||||
@@ -184,7 +187,7 @@ class CategoryController extends Controller
|
|||||||
$cache->store($data);
|
$cache->store($data);
|
||||||
|
|
||||||
return Response::json($data);
|
return Response::json($data);
|
||||||
|
**/
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -198,8 +201,9 @@ class CategoryController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function multiYear(string $reportType, Carbon $start, Carbon $end, Collection $accounts, Collection $categories)
|
public function multiYear(string $reportType, Carbon $start, Carbon $end, Collection $accounts, Collection $categories)
|
||||||
{
|
{
|
||||||
/** @var CRI $repository */
|
/**
|
||||||
$repository = app(CRI::class);
|
// /** @var CRI $repository
|
||||||
|
// $repository = app(CRI::class);
|
||||||
|
|
||||||
// chart properties for cache:
|
// chart properties for cache:
|
||||||
$cache = new CacheProperties();
|
$cache = new CacheProperties();
|
||||||
@@ -217,7 +221,7 @@ class CategoryController extends Controller
|
|||||||
$entries = new Collection;
|
$entries = new Collection;
|
||||||
$set = $repository->listMultiYear($categories, $accounts, $start, $end);
|
$set = $repository->listMultiYear($categories, $accounts, $start, $end);
|
||||||
|
|
||||||
/** @var Category $category */
|
/** @var Category $category
|
||||||
foreach ($categories as $category) {
|
foreach ($categories as $category) {
|
||||||
$entry = ['name' => '', 'spent' => [], 'earned' => []];
|
$entry = ['name' => '', 'spent' => [], 'earned' => []];
|
||||||
|
|
||||||
@@ -268,6 +272,8 @@ class CategoryController extends Controller
|
|||||||
$cache->store($data);
|
$cache->store($data);
|
||||||
|
|
||||||
return Response::json($data);
|
return Response::json($data);
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -282,6 +288,7 @@ class CategoryController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function period(Category $category, string $reportType, Carbon $start, Carbon $end, Collection $accounts)
|
public function period(Category $category, string $reportType, Carbon $start, Carbon $end, Collection $accounts)
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
// chart properties for cache:
|
// chart properties for cache:
|
||||||
$cache = new CacheProperties();
|
$cache = new CacheProperties();
|
||||||
$cache->addProperty($start);
|
$cache->addProperty($start);
|
||||||
@@ -295,8 +302,8 @@ class CategoryController extends Controller
|
|||||||
return Response::json($cache->get());
|
return Response::json($cache->get());
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @var SingleCategoryRepositoryInterface $repository */
|
/** @var CategoryRepositoryInterface $repository
|
||||||
$repository = app(SingleCategoryRepositoryInterface::class);
|
$repository = app(CategoryRepositoryInterface::class);
|
||||||
// loop over period, add by users range:
|
// loop over period, add by users range:
|
||||||
$current = clone $start;
|
$current = clone $start;
|
||||||
$viewRange = Preferences::get('viewRange', '1M')->data;
|
$viewRange = Preferences::get('viewRange', '1M')->data;
|
||||||
@@ -324,19 +331,21 @@ class CategoryController extends Controller
|
|||||||
$cache->store($data);
|
$cache->store($data);
|
||||||
|
|
||||||
return Response::json($data);
|
return Response::json($data);
|
||||||
|
* **/
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param SCRI $repository
|
* @param CRI $repository
|
||||||
* @param Category $category
|
* @param Category $category
|
||||||
*
|
*
|
||||||
* @param $date
|
* @param $date
|
||||||
*
|
*
|
||||||
* @return \Symfony\Component\HttpFoundation\Response
|
* @return \Symfony\Component\HttpFoundation\Response
|
||||||
*/
|
*/
|
||||||
public function specificPeriod(SCRI $repository, Category $category, $date)
|
public function specificPeriod(CRI $repository, Category $category, $date)
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
$carbon = new Carbon($date);
|
$carbon = new Carbon($date);
|
||||||
$range = Preferences::get('viewRange', '1M')->data;
|
$range = Preferences::get('viewRange', '1M')->data;
|
||||||
$start = Navigation::startOfPeriod($carbon, $range);
|
$start = Navigation::startOfPeriod($carbon, $range);
|
||||||
@@ -345,7 +354,7 @@ class CategoryController extends Controller
|
|||||||
|
|
||||||
return Response::json($data);
|
return Response::json($data);
|
||||||
|
|
||||||
|
**/
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -363,6 +372,7 @@ class CategoryController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function spentInPeriod(CRI $repository, $reportType, Carbon $start, Carbon $end, Collection $accounts)
|
public function spentInPeriod(CRI $repository, $reportType, Carbon $start, Carbon $end, Collection $accounts)
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
$cache = new CacheProperties; // chart properties for cache:
|
$cache = new CacheProperties; // chart properties for cache:
|
||||||
$cache->addProperty($start);
|
$cache->addProperty($start);
|
||||||
$cache->addProperty($end);
|
$cache->addProperty($end);
|
||||||
@@ -387,6 +397,7 @@ class CategoryController extends Controller
|
|||||||
$cache->store($data);
|
$cache->store($data);
|
||||||
|
|
||||||
return $data;
|
return $data;
|
||||||
|
* */
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -399,6 +410,7 @@ class CategoryController extends Controller
|
|||||||
*/
|
*/
|
||||||
private function filterCollection(Carbon $start, Carbon $end, Collection $set, Collection $categories): Collection
|
private function filterCollection(Carbon $start, Carbon $end, Collection $set, Collection $categories): Collection
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
$entries = new Collection;
|
$entries = new Collection;
|
||||||
|
|
||||||
while ($start < $end) { // filter the set:
|
while ($start < $end) { // filter the set:
|
||||||
@@ -408,7 +420,7 @@ class CategoryController extends Controller
|
|||||||
return $category->dateFormatted == $start->format('Y-m');
|
return $category->dateFormatted == $start->format('Y-m');
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
/** @var Category $category */
|
/** @var Category $category
|
||||||
foreach ($categories as $category) { // check for each category if its in the current set.
|
foreach ($categories as $category) { // check for each category if its in the current set.
|
||||||
$entry = $currentSet->filter( // if its in there, use the value.
|
$entry = $currentSet->filter( // if its in there, use the value.
|
||||||
function (Category $cat) use ($category) {
|
function (Category $cat) use ($category) {
|
||||||
@@ -426,6 +438,7 @@ class CategoryController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
return $entries;
|
return $entries;
|
||||||
|
* */
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -437,6 +450,7 @@ class CategoryController extends Controller
|
|||||||
*/
|
*/
|
||||||
private function invertSelection(Collection $entries): Collection
|
private function invertSelection(Collection $entries): Collection
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
$result = new Collection;
|
$result = new Collection;
|
||||||
foreach ($entries as $entry) {
|
foreach ($entries as $entry) {
|
||||||
$new = [$entry[0]];
|
$new = [$entry[0]];
|
||||||
@@ -448,19 +462,21 @@ class CategoryController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
return $result;
|
return $result;
|
||||||
|
* **/
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param SCRI $repository
|
* @param CRI $repository
|
||||||
* @param Category $category
|
* @param Category $category
|
||||||
* @param Carbon $start
|
* @param Carbon $start
|
||||||
* @param Carbon $end
|
* @param Carbon $end
|
||||||
*
|
*
|
||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
private function makePeriodChart(SCRI $repository, Category $category, Carbon $start, Carbon $end)
|
private function makePeriodChart(CRI $repository, Category $category, Carbon $start, Carbon $end)
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
// chart properties for cache:
|
// chart properties for cache:
|
||||||
$cache = new CacheProperties;
|
$cache = new CacheProperties;
|
||||||
$cache->addProperty($start);
|
$cache->addProperty($start);
|
||||||
@@ -490,6 +506,7 @@ class CategoryController extends Controller
|
|||||||
$cache->store($data);
|
$cache->store($data);
|
||||||
|
|
||||||
return $data;
|
return $data;
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -73,7 +73,7 @@ class Controller extends BaseController
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Take the array as returned by SingleCategoryRepositoryInterface::spentPerDay and SingleCategoryRepositoryInterface::earnedByDay
|
* Take the array as returned by CategoryRepositoryInterface::spentPerDay and CategoryRepositoryInterface::earnedByDay
|
||||||
* and sum up everything in the array in the given range.
|
* and sum up everything in the array in the given range.
|
||||||
*
|
*
|
||||||
* @param Carbon $start
|
* @param Carbon $start
|
||||||
|
@@ -18,7 +18,7 @@ use FireflyIII\Http\Controllers\Controller;
|
|||||||
use FireflyIII\Models\TransactionJournal;
|
use FireflyIII\Models\TransactionJournal;
|
||||||
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
|
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
|
||||||
use FireflyIII\Repositories\Budget\BudgetRepositoryInterface;
|
use FireflyIII\Repositories\Budget\BudgetRepositoryInterface;
|
||||||
use FireflyIII\Repositories\Category\SingleCategoryRepositoryInterface;
|
use FireflyIII\Repositories\Category\CategoryRepositoryInterface;
|
||||||
use FireflyIII\Support\Binder\AccountList;
|
use FireflyIII\Support\Binder\AccountList;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Support\Collection;
|
use Illuminate\Support\Collection;
|
||||||
@@ -160,10 +160,10 @@ class ReportController extends Controller
|
|||||||
*/
|
*/
|
||||||
private function categoryEntry(array $attributes): string
|
private function categoryEntry(array $attributes): string
|
||||||
{
|
{
|
||||||
/** @var SingleCategoryRepositoryInterface $repository */
|
/** @var CategoryRepositoryInterface $repository */
|
||||||
$repository = app(SingleCategoryRepositoryInterface::class);
|
$repository = app(CategoryRepositoryInterface::class);
|
||||||
$category = $repository->find(intval($attributes['categoryId']));
|
$category = $repository->find(intval($attributes['categoryId']));
|
||||||
$journals = $repository->getJournalsForAccountsInRange($category, $attributes['accounts'], $attributes['startDate'], $attributes['endDate']);
|
$journals = $repository->journalsInPeriod(new Collection([$category]), $attributes['accounts'], [], $attributes['startDate'], $attributes['endDate']);
|
||||||
$view = view('popup.report.category-entry', compact('journals', 'category'))->render();
|
$view = view('popup.report.category-entry', compact('journals', 'category'))->render();
|
||||||
|
|
||||||
return $view;
|
return $view;
|
||||||
|
@@ -317,7 +317,7 @@ class ReportController extends Controller
|
|||||||
$budgets = $this->budgetHelper->getBudgetsWithExpenses($start, $end, $accounts);
|
$budgets = $this->budgetHelper->getBudgetsWithExpenses($start, $end, $accounts);
|
||||||
|
|
||||||
// find the categories we've spent money on this period with these accounts:
|
// find the categories we've spent money on this period with these accounts:
|
||||||
$categories = $this->helper->getCategoriesWithExpenses($start, $end, $accounts);
|
$categories = $this->helper->getCategoriesWithTransactions($start, $end, $accounts);
|
||||||
|
|
||||||
Session::flash('gaEventCategory', 'report');
|
Session::flash('gaEventCategory', 'report');
|
||||||
Session::flash('gaEventAction', 'year');
|
Session::flash('gaEventAction', 'year');
|
||||||
|
@@ -44,19 +44,5 @@ class CategoryServiceProvider extends ServiceProvider
|
|||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->app->bind(
|
|
||||||
'FireflyIII\Repositories\Category\SingleCategoryRepositoryInterface',
|
|
||||||
function (Application $app, array $arguments) {
|
|
||||||
if (!isset($arguments[0]) && $app->auth->check()) {
|
|
||||||
return app('FireflyIII\Repositories\Category\SingleCategoryRepository', [$app->auth->user()]);
|
|
||||||
}
|
|
||||||
if (!isset($arguments[0]) && !$app->auth->check()) {
|
|
||||||
throw new FireflyException('There is no user present.');
|
|
||||||
}
|
|
||||||
|
|
||||||
return app('FireflyIII\Repositories\Category\SingleCategoryRepository', $arguments);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
File diff suppressed because it is too large
Load Diff
@@ -4,6 +4,8 @@ declare(strict_types = 1);
|
|||||||
namespace FireflyIII\Repositories\Category;
|
namespace FireflyIII\Repositories\Category;
|
||||||
|
|
||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
|
use FireflyIII\Models\Category;
|
||||||
|
use Illuminate\Pagination\LengthAwarePaginator;
|
||||||
use Illuminate\Support\Collection;
|
use Illuminate\Support\Collection;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -15,18 +17,149 @@ interface CategoryRepositoryInterface
|
|||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * Returns a collection of Categories appended with the amount of money that has been earned
|
||||||
|
// * in these categories, based on the $accounts involved, in period X, grouped per month.
|
||||||
|
// * The amount earned in category X in period X is saved in field "earned".
|
||||||
|
// *
|
||||||
|
// * @param $accounts
|
||||||
|
// * @param $start
|
||||||
|
// * @param $end
|
||||||
|
// *
|
||||||
|
// * @return Collection
|
||||||
|
// */
|
||||||
|
// public function earnedForAccountsPerMonth(Collection $accounts, Carbon $start, Carbon $end): Collection;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a collection of Categories appended with the amount of money that has been earned
|
* @param Category $category
|
||||||
* in these categories, based on the $accounts involved, in period X, grouped per month.
|
|
||||||
* The amount earned in category X in period X is saved in field "earned".
|
|
||||||
*
|
*
|
||||||
* @param $accounts
|
* @return bool
|
||||||
* @param $start
|
|
||||||
* @param $end
|
|
||||||
*
|
|
||||||
* @return Collection
|
|
||||||
*/
|
*/
|
||||||
public function earnedForAccountsPerMonth(Collection $accounts, Carbon $start, Carbon $end): Collection;
|
public function destroy(Category $category): bool;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * This method returns a very special collection for each category:
|
||||||
|
// *
|
||||||
|
// * category, year, expense/earned, amount
|
||||||
|
// *
|
||||||
|
// * categories can be duplicated.
|
||||||
|
// *
|
||||||
|
// * @param Collection $categories
|
||||||
|
// * @param Collection $accounts
|
||||||
|
// * @param Carbon $start
|
||||||
|
// * @param Carbon $end
|
||||||
|
// *
|
||||||
|
// * @return Collection
|
||||||
|
// */
|
||||||
|
// public function listMultiYear(Collection $categories, Collection $accounts, Carbon $start, Carbon $end): Collection;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * Returns a list of transaction journals in the range (all types, all accounts) that have no category
|
||||||
|
// * associated to them.
|
||||||
|
// *
|
||||||
|
// * @param Carbon $start
|
||||||
|
// * @param Carbon $end
|
||||||
|
// *
|
||||||
|
// * @return Collection
|
||||||
|
// */
|
||||||
|
// public function listNoCategory(Carbon $start, Carbon $end): Collection;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * Returns a collection of Categories appended with the amount of money that has been spent
|
||||||
|
// * in these categories, based on the $accounts involved, in period X, grouped per month.
|
||||||
|
// * The amount earned in category X in period X is saved in field "spent".
|
||||||
|
// *
|
||||||
|
// * @param $accounts
|
||||||
|
// * @param $start
|
||||||
|
// * @param $end
|
||||||
|
// *
|
||||||
|
// * @return Collection
|
||||||
|
// */
|
||||||
|
// public function spentForAccountsPerMonth(Collection $accounts, Carbon $start, Carbon $end): Collection;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * Returns the total amount of money related to transactions without any category connected to
|
||||||
|
// * it. Returns either the earned amount.
|
||||||
|
// *
|
||||||
|
// * @param Collection $accounts
|
||||||
|
// * @param Carbon $start
|
||||||
|
// * @param Carbon $end
|
||||||
|
// *
|
||||||
|
// * @return string
|
||||||
|
// */
|
||||||
|
// public function sumEarnedNoCategory(Collection $accounts, Carbon $start, Carbon $end): string;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * Returns the total amount of money related to transactions without any category connected to
|
||||||
|
// * it. Returns either the spent amount.
|
||||||
|
// *
|
||||||
|
// * @param Collection $accounts
|
||||||
|
// * @param Carbon $start
|
||||||
|
// * @param Carbon $end
|
||||||
|
// *
|
||||||
|
// * @return string
|
||||||
|
// */
|
||||||
|
// public function sumSpentNoCategory(Collection $accounts, Carbon $start, Carbon $end): string;
|
||||||
|
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * @param Category $category
|
||||||
|
// * @param Carbon|null $start
|
||||||
|
// * @param Carbon|null $end
|
||||||
|
// *
|
||||||
|
// * @return int
|
||||||
|
// */
|
||||||
|
// public function countJournals(Category $category, Carbon $start = null, Carbon $end = null): int;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Collection $categories
|
||||||
|
* @param Collection $accounts
|
||||||
|
* @param Carbon $start
|
||||||
|
* @param Carbon $end
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function earnedInPeriod(Collection $categories, Collection $accounts, Carbon $start, Carbon $end): string;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * Returns an array with the following key:value pairs:
|
||||||
|
// *
|
||||||
|
// * yyyy-mm-dd:<amount>
|
||||||
|
// *
|
||||||
|
// * Where yyyy-mm-dd is the date and <amount> is the money earned using DEPOSITS in the $category
|
||||||
|
// * from all the users accounts.
|
||||||
|
// *
|
||||||
|
// * @param Category $category
|
||||||
|
// * @param Carbon $start
|
||||||
|
// * @param Carbon $end
|
||||||
|
// * @param Collection $accounts
|
||||||
|
// *
|
||||||
|
// * @return array
|
||||||
|
// */
|
||||||
|
// public function earnedPerDay(Category $category, Carbon $start, Carbon $end, Collection $accounts): array;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Find a category
|
||||||
|
*
|
||||||
|
* @param int $categoryId
|
||||||
|
*
|
||||||
|
* @return Category
|
||||||
|
*/
|
||||||
|
public function find(int $categoryId) : Category;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * @param Category $category
|
||||||
|
// *
|
||||||
|
// * @return Carbon
|
||||||
|
// */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Category $category
|
||||||
|
* @param Collection $accounts
|
||||||
|
*
|
||||||
|
* @return Carbon
|
||||||
|
*/
|
||||||
|
public function firstUseDate(Category $category, Collection $accounts): Carbon;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a list of all the categories belonging to a user.
|
* Returns a list of all the categories belonging to a user.
|
||||||
@@ -36,67 +169,119 @@ interface CategoryRepositoryInterface
|
|||||||
public function getCategories(): Collection;
|
public function getCategories(): Collection;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method returns a very special collection for each category:
|
* @param Category $category
|
||||||
|
* @param int $page
|
||||||
|
* @param int $pageSize
|
||||||
*
|
*
|
||||||
* category, year, expense/earned, amount
|
* @return LengthAwarePaginator
|
||||||
|
*/
|
||||||
|
public function getJournals(Category $category, int $page, int $pageSize): LengthAwarePaginator;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Collection $categories
|
||||||
|
* @param Collection $accounts
|
||||||
|
* @param array $types
|
||||||
|
* @param Carbon $start
|
||||||
|
* @param Carbon $end
|
||||||
*
|
*
|
||||||
* categories can be duplicated.
|
* @return Collection
|
||||||
|
*/
|
||||||
|
public function journalsInPeriod(Collection $categories, Collection $accounts, array $types, Carbon $start, Carbon $end): Collection;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Collection $accounts
|
||||||
|
* @param Carbon $start
|
||||||
|
* @param Carbon $end
|
||||||
*
|
*
|
||||||
|
* @return Collection
|
||||||
|
*/
|
||||||
|
public function journalsInPeriodWithoutCategory(Collection $accounts, Carbon $start, Carbon $end) : Collection;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Category $category
|
||||||
|
* @param Collection $accounts
|
||||||
|
*
|
||||||
|
* @return Carbon
|
||||||
|
*/
|
||||||
|
public function lastUseDate(Category $category, Collection $accounts): Carbon;
|
||||||
|
|
||||||
|
/**
|
||||||
* @param Collection $categories
|
* @param Collection $categories
|
||||||
* @param Collection $accounts
|
* @param Collection $accounts
|
||||||
* @param Carbon $start
|
* @param Carbon $start
|
||||||
* @param Carbon $end
|
* @param Carbon $end
|
||||||
*
|
*
|
||||||
* @return Collection
|
|
||||||
*/
|
|
||||||
public function listMultiYear(Collection $categories, Collection $accounts, Carbon $start, Carbon $end): Collection;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns a list of transaction journals in the range (all types, all accounts) that have no category
|
|
||||||
* associated to them.
|
|
||||||
*
|
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
*
|
|
||||||
* @return Collection
|
|
||||||
*/
|
|
||||||
public function listNoCategory(Carbon $start, Carbon $end): Collection;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns a collection of Categories appended with the amount of money that has been spent
|
|
||||||
* in these categories, based on the $accounts involved, in period X, grouped per month.
|
|
||||||
* The amount earned in category X in period X is saved in field "spent".
|
|
||||||
*
|
|
||||||
* @param $accounts
|
|
||||||
* @param $start
|
|
||||||
* @param $end
|
|
||||||
*
|
|
||||||
* @return Collection
|
|
||||||
*/
|
|
||||||
public function spentForAccountsPerMonth(Collection $accounts, Carbon $start, Carbon $end): Collection;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the total amount of money related to transactions without any category connected to
|
|
||||||
* it. Returns either the earned amount.
|
|
||||||
*
|
|
||||||
* @param Collection $accounts
|
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
*
|
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public function sumEarnedNoCategory(Collection $accounts, Carbon $start, Carbon $end): string;
|
public function spentInPeriod(Collection $categories, Collection $accounts, Carbon $start, Carbon $end): string;
|
||||||
|
// /**
|
||||||
|
// * @param Category $category
|
||||||
|
// * @param int $page
|
||||||
|
// * @param int $pageSize
|
||||||
|
// *
|
||||||
|
// * @return Collection
|
||||||
|
// */
|
||||||
|
// public function getJournals(Category $category, int $page, int $pageSize = 50): Collection;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * @param Category $category
|
||||||
|
// * @param Collection $accounts
|
||||||
|
// *
|
||||||
|
// * @param Carbon $start
|
||||||
|
// * @param Carbon $end
|
||||||
|
// *
|
||||||
|
// * @return Collection
|
||||||
|
// */
|
||||||
|
// public function getJournalsForAccountsInRange(Category $category, Collection $accounts, Carbon $start, Carbon $end): Collection;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * @param Category $category
|
||||||
|
// * @param Carbon $start
|
||||||
|
// * @param Carbon $end
|
||||||
|
// * @param int $page
|
||||||
|
// * @param int $pageSize
|
||||||
|
// *
|
||||||
|
// *
|
||||||
|
// * @return Collection
|
||||||
|
// */
|
||||||
|
// public function getJournalsInRange(Category $category, Carbon $start, Carbon $end, int $page, int $pageSize = 50): Collection;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * @param Category $category
|
||||||
|
// *
|
||||||
|
// * @return Carbon
|
||||||
|
// */
|
||||||
|
// public function getLatestActivity(Category $category): Carbon;
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * Returns an array with the following key:value pairs:
|
||||||
|
// *
|
||||||
|
// * yyyy-mm-dd:<amount>
|
||||||
|
// *
|
||||||
|
// * Where yyyy-mm-dd is the date and <amount> is the money spent using WITHDRAWALS in the $category
|
||||||
|
// * from all the users accounts.
|
||||||
|
// *
|
||||||
|
// * @param Category $category
|
||||||
|
// * @param Carbon $start
|
||||||
|
// * @param Carbon $end
|
||||||
|
// * @param Collection $accounts
|
||||||
|
// *
|
||||||
|
// * @return array
|
||||||
|
// */
|
||||||
|
// public function spentPerDay(Category $category, Carbon $start, Carbon $end, Collection $accounts): array;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the total amount of money related to transactions without any category connected to
|
* @param array $data
|
||||||
* it. Returns either the spent amount.
|
|
||||||
*
|
*
|
||||||
* @param Collection $accounts
|
* @return Category
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
*/
|
||||||
public function sumSpentNoCategory(Collection $accounts, Carbon $start, Carbon $end): string;
|
public function store(array $data): Category;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Category $category
|
||||||
|
* @param array $data
|
||||||
|
*
|
||||||
|
* @return Category
|
||||||
|
*/
|
||||||
|
public function update(Category $category, array $data): Category;
|
||||||
}
|
}
|
||||||
|
@@ -1,322 +0,0 @@
|
|||||||
<?php
|
|
||||||
declare(strict_types = 1);
|
|
||||||
|
|
||||||
namespace FireflyIII\Repositories\Category;
|
|
||||||
|
|
||||||
use Carbon\Carbon;
|
|
||||||
use DB;
|
|
||||||
use FireflyIII\Models\Category;
|
|
||||||
use FireflyIII\Models\TransactionJournal;
|
|
||||||
use FireflyIII\Models\TransactionType;
|
|
||||||
use FireflyIII\Repositories\Shared\ComponentRepository;
|
|
||||||
use FireflyIII\User;
|
|
||||||
use Illuminate\Database\Query\JoinClause;
|
|
||||||
use Illuminate\Support\Collection;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class SingleCategoryRepository
|
|
||||||
*
|
|
||||||
* @package FireflyIII\Repositories\Category
|
|
||||||
*/
|
|
||||||
class SingleCategoryRepository extends ComponentRepository implements SingleCategoryRepositoryInterface
|
|
||||||
{
|
|
||||||
/** @var User */
|
|
||||||
private $user;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* SingleCategoryRepository constructor.
|
|
||||||
*
|
|
||||||
* @param User $user
|
|
||||||
*/
|
|
||||||
public function __construct(User $user)
|
|
||||||
{
|
|
||||||
$this->user = $user;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
* @param Carbon|null $start
|
|
||||||
* @param Carbon|null $end
|
|
||||||
*
|
|
||||||
* @return int
|
|
||||||
*/
|
|
||||||
public function countJournals(Category $category, Carbon $start = null, Carbon $end = null): int
|
|
||||||
{
|
|
||||||
$query = $category->transactionjournals();
|
|
||||||
if (!is_null($start)) {
|
|
||||||
$query->after($start);
|
|
||||||
}
|
|
||||||
if (!is_null($end)) {
|
|
||||||
$query->before($end);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $query->count();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function destroy(Category $category): bool
|
|
||||||
{
|
|
||||||
$category->delete();
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns an array with the following key:value pairs:
|
|
||||||
*
|
|
||||||
* yyyy-mm-dd:<amount>
|
|
||||||
*
|
|
||||||
* Where yyyy-mm-dd is the date and <amount> is the money earned using DEPOSITS in the $category
|
|
||||||
* from all the users $accounts.
|
|
||||||
*
|
|
||||||
* @param Category $category
|
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
* @param Collection $accounts
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function earnedPerDay(Category $category, Carbon $start, Carbon $end, Collection $accounts): array
|
|
||||||
{
|
|
||||||
/** @var Collection $query */
|
|
||||||
$query = $category->transactionjournals()
|
|
||||||
->expanded()
|
|
||||||
->transactionTypes([TransactionType::DEPOSIT])
|
|
||||||
->before($end)
|
|
||||||
->after($start)
|
|
||||||
->groupBy('transaction_journals.date');
|
|
||||||
|
|
||||||
$query->leftJoin(
|
|
||||||
'transactions as destination', function (JoinClause $join) {
|
|
||||||
$join->on('destination.transaction_journal_id', '=', 'transaction_journals.id')->where('destination.amount', '>', 0);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
if ($accounts->count() > 0) {
|
|
||||||
$ids = $accounts->pluck('id')->toArray();
|
|
||||||
$query->whereIn('destination.account.id', $ids);
|
|
||||||
}
|
|
||||||
|
|
||||||
$result = $query->get(['transaction_journals.date as dateFormatted', DB::raw('SUM(`destination`.`amount`) AS `sum`')]);
|
|
||||||
|
|
||||||
$return = [];
|
|
||||||
foreach ($result->toArray() as $entry) {
|
|
||||||
$return[$entry['dateFormatted']] = $entry['sum'];
|
|
||||||
}
|
|
||||||
|
|
||||||
return $return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Find a category
|
|
||||||
*
|
|
||||||
* @param int $categoryId
|
|
||||||
*
|
|
||||||
* @return Category
|
|
||||||
*/
|
|
||||||
public function find(int $categoryId) : Category
|
|
||||||
{
|
|
||||||
$category = $this->user->categories()->find($categoryId);
|
|
||||||
if (is_null($category)) {
|
|
||||||
$category = new Category;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $category;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
*
|
|
||||||
* @return Carbon
|
|
||||||
*/
|
|
||||||
public function getFirstActivityDate(Category $category): Carbon
|
|
||||||
{
|
|
||||||
/** @var TransactionJournal $first */
|
|
||||||
$first = $category->transactionjournals()->orderBy('date', 'ASC')->first();
|
|
||||||
if ($first) {
|
|
||||||
return $first->date;
|
|
||||||
}
|
|
||||||
|
|
||||||
return new Carbon;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
* @param int $page
|
|
||||||
* @param int $pageSize
|
|
||||||
*
|
|
||||||
* @return Collection
|
|
||||||
*/
|
|
||||||
public function getJournals(Category $category, int $page, int $pageSize = 50): Collection
|
|
||||||
{
|
|
||||||
$offset = $page > 0 ? $page * $pageSize : 0;
|
|
||||||
|
|
||||||
return $category->transactionjournals()->expanded()->take($pageSize)->offset($offset)->get(TransactionJournal::queryFields());
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
* @param Collection $accounts
|
|
||||||
*
|
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
*
|
|
||||||
* @return Collection
|
|
||||||
*/
|
|
||||||
public function getJournalsForAccountsInRange(Category $category, Collection $accounts, Carbon $start, Carbon $end): Collection
|
|
||||||
{
|
|
||||||
$ids = $accounts->pluck('id')->toArray();
|
|
||||||
|
|
||||||
return $category->transactionjournals()
|
|
||||||
->after($start)
|
|
||||||
->before($end)
|
|
||||||
->expanded()
|
|
||||||
->whereIn('source_account.id', $ids)
|
|
||||||
->whereNotIn('destination_account.id', $ids)
|
|
||||||
->get(TransactionJournal::queryFields());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
* @param int $page
|
|
||||||
* @param int $pageSize
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @return Collection
|
|
||||||
*/
|
|
||||||
public function getJournalsInRange(Category $category, Carbon $start, Carbon $end, int $page, int $pageSize = 50): Collection
|
|
||||||
{
|
|
||||||
$offset = $page > 0 ? $page * $pageSize : 0;
|
|
||||||
|
|
||||||
return $category->transactionjournals()
|
|
||||||
->after($start)
|
|
||||||
->before($end)
|
|
||||||
->expanded()
|
|
||||||
->take($pageSize)
|
|
||||||
->offset($offset)
|
|
||||||
->get(TransactionJournal::queryFields());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
*
|
|
||||||
* @return Carbon
|
|
||||||
*/
|
|
||||||
public function getLatestActivity(Category $category): Carbon
|
|
||||||
{
|
|
||||||
$first = new Carbon('1900-01-01');
|
|
||||||
$second = new Carbon('1900-01-01');
|
|
||||||
$latest = $category->transactionjournals()
|
|
||||||
->orderBy('transaction_journals.date', 'DESC')
|
|
||||||
->orderBy('transaction_journals.order', 'ASC')
|
|
||||||
->orderBy('transaction_journals.id', 'DESC')
|
|
||||||
->first();
|
|
||||||
if ($latest) {
|
|
||||||
$first = $latest->date;
|
|
||||||
}
|
|
||||||
|
|
||||||
// could also be a transaction, nowadays:
|
|
||||||
$latestTransaction = $category->transactions()
|
|
||||||
->leftJoin('transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id')
|
|
||||||
->orderBy('transaction_journals.date', 'DESC')
|
|
||||||
->orderBy('transaction_journals.order', 'ASC')
|
|
||||||
->orderBy('transaction_journals.id', 'DESC')
|
|
||||||
->first(['transactions.*', 'transaction_journals.date']);
|
|
||||||
if ($latestTransaction) {
|
|
||||||
$second = new Carbon($latestTransaction->date);
|
|
||||||
}
|
|
||||||
if ($first > $second) {
|
|
||||||
return $first;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $second;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns an array with the following key:value pairs:
|
|
||||||
*
|
|
||||||
* yyyy-mm-dd:<amount>
|
|
||||||
*
|
|
||||||
* Where yyyy-mm-dd is the date and <amount> is the money spent using DEPOSITS in the $category
|
|
||||||
* from all the users accounts.
|
|
||||||
*
|
|
||||||
* @param Category $category
|
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
* @param Collection $accounts
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function spentPerDay(Category $category, Carbon $start, Carbon $end, Collection $accounts): array
|
|
||||||
{
|
|
||||||
/** @var Collection $query */
|
|
||||||
$query = $category->transactionjournals()
|
|
||||||
->expanded()
|
|
||||||
->transactionTypes([TransactionType::WITHDRAWAL])
|
|
||||||
->before($end)
|
|
||||||
->after($start)
|
|
||||||
->groupBy('transaction_journals.date');
|
|
||||||
$query->leftJoin(
|
|
||||||
'transactions as source', function (JoinClause $join) {
|
|
||||||
$join->on('source.transaction_journal_id', '=', 'transaction_journals.id')->where('source.amount', '<', 0);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
if ($accounts->count() > 0) {
|
|
||||||
$ids = $accounts->pluck('id')->toArray();
|
|
||||||
$query->whereIn('source.account_id', $ids);
|
|
||||||
}
|
|
||||||
|
|
||||||
$result = $query->get(['transaction_journals.date as dateFormatted', DB::raw('SUM(`source`.`amount`) AS `sum`')]);
|
|
||||||
|
|
||||||
$return = [];
|
|
||||||
foreach ($result->toArray() as $entry) {
|
|
||||||
$return[$entry['dateFormatted']] = $entry['sum'];
|
|
||||||
}
|
|
||||||
|
|
||||||
return $return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param array $data
|
|
||||||
*
|
|
||||||
* @return Category
|
|
||||||
*/
|
|
||||||
public function store(array $data): Category
|
|
||||||
{
|
|
||||||
$newCategory = Category::firstOrCreateEncrypted(
|
|
||||||
[
|
|
||||||
'user_id' => $data['user'],
|
|
||||||
'name' => $data['name'],
|
|
||||||
]
|
|
||||||
);
|
|
||||||
$newCategory->save();
|
|
||||||
|
|
||||||
return $newCategory;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
* @param array $data
|
|
||||||
*
|
|
||||||
* @return Category
|
|
||||||
*/
|
|
||||||
public function update(Category $category, array $data): Category
|
|
||||||
{
|
|
||||||
// update the account:
|
|
||||||
$category->name = $data['name'];
|
|
||||||
$category->save();
|
|
||||||
|
|
||||||
return $category;
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,138 +0,0 @@
|
|||||||
<?php
|
|
||||||
declare(strict_types = 1);
|
|
||||||
|
|
||||||
namespace FireflyIII\Repositories\Category;
|
|
||||||
|
|
||||||
use Carbon\Carbon;
|
|
||||||
use FireflyIII\Models\Category;
|
|
||||||
use Illuminate\Support\Collection;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Interface SingleCategoryRepositoryInterface
|
|
||||||
*
|
|
||||||
* @package FireflyIII\Repositories\Category
|
|
||||||
*/
|
|
||||||
interface SingleCategoryRepositoryInterface
|
|
||||||
{
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
* @param Carbon|null $start
|
|
||||||
* @param Carbon|null $end
|
|
||||||
*
|
|
||||||
* @return int
|
|
||||||
*/
|
|
||||||
public function countJournals(Category $category, Carbon $start = null, Carbon $end = null): int;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function destroy(Category $category): bool;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns an array with the following key:value pairs:
|
|
||||||
*
|
|
||||||
* yyyy-mm-dd:<amount>
|
|
||||||
*
|
|
||||||
* Where yyyy-mm-dd is the date and <amount> is the money earned using DEPOSITS in the $category
|
|
||||||
* from all the users accounts.
|
|
||||||
*
|
|
||||||
* @param Category $category
|
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
* @param Collection $accounts
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function earnedPerDay(Category $category, Carbon $start, Carbon $end, Collection $accounts): array;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Find a category
|
|
||||||
*
|
|
||||||
* @param int $categoryId
|
|
||||||
*
|
|
||||||
* @return Category
|
|
||||||
*/
|
|
||||||
public function find(int $categoryId) : Category;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
*
|
|
||||||
* @return Carbon
|
|
||||||
*/
|
|
||||||
public function getFirstActivityDate(Category $category): Carbon;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
* @param int $page
|
|
||||||
* @param int $pageSize
|
|
||||||
*
|
|
||||||
* @return Collection
|
|
||||||
*/
|
|
||||||
public function getJournals(Category $category, int $page, int $pageSize = 50): Collection;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
* @param Collection $accounts
|
|
||||||
*
|
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
*
|
|
||||||
* @return Collection
|
|
||||||
*/
|
|
||||||
public function getJournalsForAccountsInRange(Category $category, Collection $accounts, Carbon $start, Carbon $end): Collection;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
* @param int $page
|
|
||||||
* @param int $pageSize
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @return Collection
|
|
||||||
*/
|
|
||||||
public function getJournalsInRange(Category $category, Carbon $start, Carbon $end, int $page, int $pageSize = 50): Collection;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
*
|
|
||||||
* @return Carbon
|
|
||||||
*/
|
|
||||||
public function getLatestActivity(Category $category): Carbon;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns an array with the following key:value pairs:
|
|
||||||
*
|
|
||||||
* yyyy-mm-dd:<amount>
|
|
||||||
*
|
|
||||||
* Where yyyy-mm-dd is the date and <amount> is the money spent using WITHDRAWALS in the $category
|
|
||||||
* from all the users accounts.
|
|
||||||
*
|
|
||||||
* @param Category $category
|
|
||||||
* @param Carbon $start
|
|
||||||
* @param Carbon $end
|
|
||||||
* @param Collection $accounts
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function spentPerDay(Category $category, Carbon $start, Carbon $end, Collection $accounts): array;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param array $data
|
|
||||||
*
|
|
||||||
* @return Category
|
|
||||||
*/
|
|
||||||
public function store(array $data): Category;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Category $category
|
|
||||||
* @param array $data
|
|
||||||
*
|
|
||||||
* @return Category
|
|
||||||
*/
|
|
||||||
public function update(Category $category, array $data): Category;
|
|
||||||
}
|
|
Reference in New Issue
Block a user