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;
}
}