Invoice Widgets completed
This commit is contained in:
@@ -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;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
37
app/Repositories/InvoiceRepository.php
Normal file
37
app/Repositories/InvoiceRepository.php
Normal 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;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user