Operation processes on invoices

This commit is contained in:
2026-02-13 00:11:51 +01:00
parent 882752472e
commit fd403f8520
44 changed files with 1635 additions and 42 deletions

View File

@@ -85,7 +85,7 @@ class CostUnitRepository {
$visibleCostUnits = [];
/** @var CostUnit $costUnit */
foreach (Costunit::where($criteria)->get() as $costUnit) {
if ($costUnit->tresurers()->where('user_id', $user->id)->exists() || $canSeeAll || $disableAccessCheck) {
if ($costUnit->treasurers()->where('user_id', $user->id)->exists() || $canSeeAll || $disableAccessCheck) {
if ($forDisplay) {
$visibleCostUnits[] = new CostUnitResource($costUnit)->toArray(request());
} else {
@@ -134,7 +134,7 @@ class CostUnitRepository {
return $returnData;
}
public function sumupAmounts(CostUnit $costUnit) : Amount {
public function sumupAmounts(CostUnit $costUnit, bool $donatedAmount = false) : Amount {
$amount = new Amount(0, '');
foreach ($costUnit->invoices()->get() as $invoice) {
@@ -142,9 +142,57 @@ class CostUnitRepository {
continue;
}
if (
($donatedAmount && !$invoice->donation) ||
(!$donatedAmount && $invoice->donation)
) {
continue;
}
$amount->addAmount(Amount::fromString($invoice->amount));
}
return $amount;
}
public function countInvoices(CostUnit $costUnit) : array {
$returnData = [
InvoiceStatus::INVOICE_STATUS_NEW => 0,
InvoiceStatus::INVOICE_STATUS_APPROVED => 0,
InvoiceStatus::INVOICE_STATUS_DENIED => 0,
InvoiceStatus::INVOICE_META_STATUS_NO_PAYOUT => 0,
InvoiceStatus::INVOICE_META_STATUS_DONATED => 0
];
foreach ($costUnit->invoices()->get() as $invoice) {
if ($invoice->status === InvoiceStatus::INVOICE_STATUS_DELETED) {
continue;
}
if( $invoice->status === InvoiceStatus::INVOICE_STATUS_DENIED) {
$returnData[InvoiceStatus::INVOICE_STATUS_DENIED]++;
continue;
}
switch ($invoice->status) {
case InvoiceStatus::INVOICE_STATUS_NEW:
$returnData[InvoiceStatus::INVOICE_STATUS_NEW]++;
break;
case InvoiceStatus::INVOICE_STATUS_APPROVED:
$returnData[InvoiceStatus::INVOICE_STATUS_APPROVED]++;
break;
case InvoiceStatus::INVOICE_STATUS_EXPORTED:
if ($invoice->donation) {
$returnData[InvoiceStatus::INVOICE_META_STATUS_DONATED]++;
} else {
if ($invoice->contact_bank_iban === null) {
$returnData[InvoiceStatus::INVOICE_META_STATUS_NO_PAYOUT]++;
}
}
break;
}
}
return $returnData;
}
}

View File

@@ -3,8 +3,12 @@
namespace App\Repositories;
use App\Enumerations\InvoiceStatus;
use App\Enumerations\UserRole;
use App\Models\CostUnit;
use App\Models\Invoice;
use App\Resources\InvoiceResource;
use App\ValueObjects\Amount;
use Illuminate\Database\Eloquent\Collection;
class InvoiceRepository {
public function getMyInvoicesWidget() : array {
@@ -34,4 +38,40 @@ class InvoiceRepository {
return $invoices;
}
public function getByStatus(CostUnit $costUnit, string $status) : array {
$returnData = [];
foreach ($costUnit->invoices()->where('status', $status)->get() as $invoice) {
$returnData[] = new InvoiceResource($invoice)->toArray();
};
return $returnData;
}
public function getAsTreasurer(int $invoiceId) : ?Invoice {
$invoice = Invoice::where('id', $invoiceId)->first();
if ($invoice === null) {
return null;
}
$isTreasurer = $invoice->costUnit()->first()->treasurers()->where('user_id', auth()->user()->id)->exists();
if ($isTreasurer) {
return $invoice;
}
$user = auth()->user();
if ($user->user_role_main === UserRole::USER_ROLE_ADMIN) {
return $invoice;
}
if (app('tenant')->slug === 'lv' && $user->user_role_main === UserRole::USER_ROLE_GROUP_LEADER) {
return $invoice;
}
if (app('tenant')->slug !== 'lv' && $user->local_group === app('tenant')->slug && $user->user_role_local_group === UserRole::USER_ROLE_GROUP_LEADER) {
return $invoice;
}
return null;
}
}