Operation processes on invoices
This commit is contained in:
@@ -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;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user