mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-05-24 02:14:21 -04:00
Add projects to recurring invoices
This commit is contained in:
parent
f2932c0354
commit
bdcf902c6c
@ -14,6 +14,7 @@ namespace App\Http\Requests\Invoice;
|
||||
use App\Http\Requests\Request;
|
||||
use App\Http\ValidationRules\Invoice\InvoiceBalanceSanity;
|
||||
use App\Http\ValidationRules\Invoice\LockedInvoiceRule;
|
||||
use App\Http\ValidationRules\Project\ValidProjectForClient;
|
||||
use App\Models\Invoice;
|
||||
use App\Utils\Traits\ChecksEntityStatus;
|
||||
use App\Utils\Traits\CleanLineItems;
|
||||
@ -59,6 +60,7 @@ class UpdateInvoiceRequest extends Request
|
||||
|
||||
$rules['line_items'] = 'array';
|
||||
$rules['discount'] = 'sometimes|numeric';
|
||||
$rules['project_id'] = ['bail', 'sometimes', new ValidProjectForClient($this->all())];
|
||||
|
||||
// if($this->input('status_id') != Invoice::STATUS_DRAFT)
|
||||
// $rules['balance'] = new InvoiceBalanceSanity($this->invoice, $this->all());
|
||||
|
@ -12,6 +12,7 @@
|
||||
namespace App\Http\Requests\RecurringInvoice;
|
||||
|
||||
use App\Http\Requests\Request;
|
||||
use App\Http\ValidationRules\Project\ValidProjectForClient;
|
||||
use App\Http\ValidationRules\Recurring\UniqueRecurringInvoiceNumberRule;
|
||||
use App\Models\Client;
|
||||
use App\Models\RecurringInvoice;
|
||||
@ -55,6 +56,8 @@ class StoreRecurringInvoiceRequest extends Request
|
||||
|
||||
$rules['frequency_id'] = 'required|integer|digits_between:1,12';
|
||||
|
||||
$rules['project_id'] = ['bail', 'sometimes', new ValidProjectForClient($this->all())];
|
||||
|
||||
$rules['number'] = new UniqueRecurringInvoiceNumberRule($this->all());
|
||||
|
||||
return $rules;
|
||||
@ -80,6 +83,11 @@ class StoreRecurringInvoiceRequest extends Request
|
||||
$input['vendor_id'] = $this->decodePrimaryKey($input['vendor_id']);
|
||||
}
|
||||
|
||||
if (array_key_exists('project_id', $input) && is_string($input['project_id'])) {
|
||||
$input['project_id'] = $this->decodePrimaryKey($input['project_id']);
|
||||
}
|
||||
|
||||
|
||||
if (isset($input['client_contacts'])) {
|
||||
foreach ($input['client_contacts'] as $key => $contact) {
|
||||
if (! array_key_exists('send_email', $contact) || ! array_key_exists('id', $contact)) {
|
||||
|
@ -12,6 +12,7 @@
|
||||
namespace App\Http\Requests\RecurringInvoice;
|
||||
|
||||
use App\Http\Requests\Request;
|
||||
use App\Http\ValidationRules\Project\ValidProjectForClient;
|
||||
use App\Utils\Traits\ChecksEntityStatus;
|
||||
use App\Utils\Traits\CleanLineItems;
|
||||
use App\Utils\Traits\MakesHash;
|
||||
@ -51,6 +52,7 @@ class UpdateRecurringInvoiceRequest extends Request
|
||||
if($this->number)
|
||||
$rules['number'] = Rule::unique('recurring_invoices')->where('company_id', auth()->user()->company()->id)->ignore($this->recurring_invoice->id);
|
||||
|
||||
$rules['project_id'] = ['bail', 'sometimes', new ValidProjectForClient($this->all())];
|
||||
|
||||
return $rules;
|
||||
}
|
||||
@ -59,16 +61,6 @@ class UpdateRecurringInvoiceRequest extends Request
|
||||
{
|
||||
$input = $this->all();
|
||||
|
||||
// foreach($this->input('documents') as $document)
|
||||
// {
|
||||
// if($document instanceof UploadedFile){
|
||||
// nlog("i am an uploaded file");
|
||||
// nlog($document);
|
||||
// }
|
||||
// else
|
||||
// nlog($document);
|
||||
// }
|
||||
|
||||
if (array_key_exists('design_id', $input) && is_string($input['design_id'])) {
|
||||
$input['design_id'] = $this->decodePrimaryKey($input['design_id']);
|
||||
}
|
||||
@ -81,6 +73,11 @@ class UpdateRecurringInvoiceRequest extends Request
|
||||
$input['assigned_user_id'] = $this->decodePrimaryKey($input['assigned_user_id']);
|
||||
}
|
||||
|
||||
if (array_key_exists('project_id', $input) && is_string($input['project_id'])) {
|
||||
$input['project_id'] = $this->decodePrimaryKey($input['project_id']);
|
||||
}
|
||||
|
||||
|
||||
if (isset($input['invitations'])) {
|
||||
foreach ($input['invitations'] as $key => $value) {
|
||||
if (is_numeric($input['invitations'][$key]['id'])) {
|
||||
|
@ -535,4 +535,16 @@ class Invoice extends BaseModel
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
public function transaction_event()
|
||||
{
|
||||
return [
|
||||
'id' => $this->id,
|
||||
'amount' => $this->amount,
|
||||
'partial' => $this->partial,
|
||||
'balance' => $this->balance,
|
||||
'paid_to_date' => $this->paid_to_date,
|
||||
'status_id' => $this->status_id,
|
||||
];
|
||||
}
|
||||
}
|
||||
|
@ -324,4 +324,16 @@ class Payment extends BaseModel
|
||||
|
||||
}
|
||||
|
||||
public function transaction_event()
|
||||
{
|
||||
return [
|
||||
'payment_id' => $this->id,
|
||||
'payment_amount' => $this->amount,
|
||||
'payment_applied' => $this->applied,
|
||||
'payment_refunded' => $this->refunded,
|
||||
'payment_status' => $this->status_id,
|
||||
'paymentables' => $this->paymentables->toArray(),
|
||||
];
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user