1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-14 15:13:29 +01:00
invoiceninja/app/Http/Requests/RecurringInvoice/UpdateRecurringInvoiceRequest.php

144 lines
5.0 KiB
PHP
Raw Normal View History

2019-05-03 00:29:04 +02:00
<?php
2019-05-11 05:32:07 +02:00
/**
* Invoice Ninja (https://invoiceninja.com).
2019-05-11 05:32:07 +02:00
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
2022-04-27 05:20:41 +02:00
* @copyright Copyright (c) 2022. Invoice Ninja LLC (https://invoiceninja.com)
2019-05-11 05:32:07 +02:00
*
2021-06-16 08:58:16 +02:00
* @license https://www.elastic.co/licensing/elastic-license
2019-05-11 05:32:07 +02:00
*/
2019-05-03 00:29:04 +02:00
namespace App\Http\Requests\RecurringInvoice;
use App\Http\Requests\Request;
2022-03-09 22:52:33 +01:00
use App\Http\ValidationRules\Project\ValidProjectForClient;
use App\Utils\Traits\ChecksEntityStatus;
use App\Utils\Traits\CleanLineItems;
use App\Utils\Traits\MakesHash;
2021-03-06 22:50:14 +01:00
use Illuminate\Http\UploadedFile;
2021-03-19 23:51:52 +01:00
use Illuminate\Validation\Rule;
2019-05-03 00:29:04 +02:00
class UpdateRecurringInvoiceRequest extends Request
{
use ChecksEntityStatus;
use CleanLineItems;
use MakesHash;
2019-05-03 00:29:04 +02:00
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize() : bool
{
return auth()->user()->can('edit', $this->recurring_invoice);
}
public function rules()
{
$rules = [];
2019-07-04 06:31:01 +02:00
if ($this->input('documents') && is_array($this->input('documents'))) {
$documents = count($this->input('documents'));
foreach (range(0, $documents) as $index) {
$rules['documents.'.$index] = 'file|mimes:png,ai,jpeg,tiff,pdf,gif,psd,txt,doc,xls,ppt,xlsx,docx,pptx|max:20000';
}
} elseif ($this->input('documents')) {
$rules['documents'] = 'file|mimes:png,ai,jpeg,tiff,pdf,gif,psd,txt,doc,xls,ppt,xlsx,docx,pptx|max:20000';
}
if ($this->number) {
2021-03-19 23:51:52 +01:00
$rules['number'] = Rule::unique('recurring_invoices')->where('company_id', auth()->user()->company()->id)->ignore($this->recurring_invoice->id);
}
2021-03-19 23:51:52 +01:00
$rules['project_id'] = ['bail', 'sometimes', new ValidProjectForClient($this->all())];
2022-11-05 05:13:08 +01:00
$rules['tax_rate1'] = 'bail|sometimes|numeric';
$rules['tax_rate2'] = 'bail|sometimes|numeric';
$rules['tax_rate3'] = 'bail|sometimes|numeric';
$rules['tax_name1'] = 'bail|sometimes|string|nullable';
$rules['tax_name2'] = 'bail|sometimes|string|nullable';
$rules['tax_name3'] = 'bail|sometimes|string|nullable';
return $rules;
2019-05-03 00:29:04 +02:00
}
2022-06-24 03:55:41 +02:00
public function prepareForValidation()
{
$input = $this->all();
2020-10-07 02:20:28 +02:00
2022-12-02 00:36:47 +01:00
if (array_key_exists('due_date_days', $input) && is_null($input['due_date_days'])){
$input['due_date_days'] = 'terms';
}
if (array_key_exists('next_send_date', $input) && is_string($input['next_send_date'])) {
$input['next_send_date_client'] = $input['next_send_date'];
}
if (array_key_exists('design_id', $input) && is_string($input['design_id'])) {
$input['design_id'] = $this->decodePrimaryKey($input['design_id']);
}
if (isset($input['client_id'])) {
$input['client_id'] = $this->decodePrimaryKey($input['client_id']);
}
2020-06-26 00:29:24 +02:00
if (array_key_exists('assigned_user_id', $input) && is_string($input['assigned_user_id'])) {
$input['assigned_user_id'] = $this->decodePrimaryKey($input['assigned_user_id']);
}
2022-03-09 22:52:33 +01:00
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 (isset($input['invitations'][$key]['id']) && is_numeric($input['invitations'][$key]['id'])) {
unset($input['invitations'][$key]['id']);
}
if (array_key_exists('id', $input['invitations'][$key]) && is_string($input['invitations'][$key]['id'])) {
$input['invitations'][$key]['id'] = $this->decodePrimaryKey($input['invitations'][$key]['id']);
}
if (is_string($input['invitations'][$key]['client_contact_id'])) {
$input['invitations'][$key]['client_contact_id'] = $this->decodePrimaryKey($input['invitations'][$key]['client_contact_id']);
}
}
}
2021-04-08 12:50:53 +02:00
if (isset($input['line_items'])) {
$input['line_items'] = isset($input['line_items']) ? $this->cleanItems($input['line_items']) : [];
}
if (array_key_exists('auto_bill', $input) && isset($input['auto_bill']) && $this->setAutoBillFlag($input['auto_bill'])) {
$input['auto_bill_enabled'] = true;
2020-11-25 15:19:52 +01:00
}
2020-09-24 05:40:13 +02:00
2021-01-08 11:19:26 +01:00
if (array_key_exists('documents', $input)) {
unset($input['documents']);
}
$this->replace($input);
}
2020-09-24 05:40:13 +02:00
/**
* if($auto_bill == '')
2020-11-25 15:19:52 +01:00
* off / optin / optout will reset the status of this field to off to allow
* the client to choose whether to auto_bill or not.
2020-11-25 15:19:52 +01:00
*
* @param enum $auto_bill off/always/optin/optout
*
* @return bool
*/
private function setAutoBillFlag($auto_bill) :bool
2020-09-24 05:40:13 +02:00
{
if ($auto_bill == 'always') {
2020-09-24 05:40:13 +02:00
return true;
}
return false;
2020-09-24 05:40:13 +02:00
}
}