Invoice Widgets completed

This commit is contained in:
2026-02-11 19:38:06 +01:00
parent 87531237c7
commit 882752472e
16 changed files with 240 additions and 18 deletions

View File

@@ -3,9 +3,12 @@
namespace App\Repositories;
use App\Enumerations\CostUnitType;
use App\Enumerations\InvoiceStatus;
use App\Enumerations\UserRole;
use App\Models\CostUnit;
use App\Resources\CostUnitResource;
use App\ValueObjects\Amount;
use Illuminate\Database\Capsule\Manager as Capsule;
class CostUnitRepository {
public function getCostUnitsForNewInvoice(string $type) : array {
@@ -95,4 +98,53 @@ class CostUnitRepository {
return $visibleCostUnits;
}
public function listForSummary(int $maxCountCostUnits) : array {
$costUnits = $this->getCostUnitsByCriteria([
'archived' => false,
'tenant' => app('tenant')->slug,
],false);
foreach ($costUnits as &$cu) {
$cu->new_invoices_count = $cu->invoices()->where('status', 'new')->count();
$cu->approved_invoices_count = $cu->invoices()->where('status', 'approved')->count();
}
$costUnits = collect($costUnits)
->sortByDesc('approved_invoices_count')
->sortByDesc('new_invoices_count')
->take($maxCountCostUnits)
->values()
->all();
$returnData = [];
foreach ($costUnits as $costUnit) {
if($costUnit->approved_invoices_count === 0 && $costUnit->new_invoices_count === 0) {
continue;
}
if (strlen($costUnit->name) > 15) {
$costUnit->name = substr($costUnit->name, 8, 13) . '...';
}
$costUnit->totalAmount = $this->sumupAmounts($costUnit)->toString();
$returnData[] = $costUnit;
}
return $returnData;
}
public function sumupAmounts(CostUnit $costUnit) : Amount {
$amount = new Amount(0, '');
foreach ($costUnit->invoices()->get() as $invoice) {
if ($invoice->status === InvoiceStatus::INVOICE_STATUS_DENIED) {
continue;
}
$amount->addAmount(Amount::fromString($invoice->amount));
}
return $amount;
}
}

View File

@@ -0,0 +1,37 @@
<?php
namespace App\Repositories;
use App\Enumerations\InvoiceStatus;
use App\Models\Invoice;
use App\ValueObjects\Amount;
class InvoiceRepository {
public function getMyInvoicesWidget() : array {
$invoices = [
InvoiceStatus::INVOICE_STATUS_NEW => ['slug' => 'new', 'title' => 'Neue Abrechnungen', 'count' => 0, 'amount' => Amount::fromString('0')->toString()],
InvoiceStatus::INVOICE_STATUS_APPROVED => ['slug' => 'approved', 'title' => 'Freigegebene Abrechnungen', 'count' => 0, 'amount' => Amount::fromString('0')->toString()],
InvoiceStatus::INVOICE_STATUS_DENIED => ['slug' => 'declined', 'title' => 'Abgelehnte Abrechnungen', 'count' => 0, 'amount' => Amount::fromString('0')->toString()]
];
$user = auth()->user();
if (null === $user) {
return $invoices;
}
foreach ([InvoiceStatus::INVOICE_STATUS_NEW, InvoiceStatus::INVOICE_STATUS_APPROVED, InvoiceStatus::INVOICE_STATUS_DENIED] as $status) {
$amount = 0;
$count = 0;
foreach (Invoice::where(['user_id' => $user->id, 'status' => $status])->get() as $stack) {
$count++;
$amount += $stack->amount;
}
$invoices[$status]['count'] = $count;
$invoices[$status]['amount'] = Amount::fromString($amount)->toString();
}
return $invoices;
}
}