mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-05-30 21:54:32 -04:00
Fixes for V2 (#3172)
* Optimizations for large queries * Fixes for client activities * Implement UpdateOrCreate for products
This commit is contained in:
parent
e9b9cef2f1
commit
d797799196
@ -62,6 +62,7 @@ class CompanySettings extends BaseSettings
|
|||||||
public $custom_message_unapproved_quote = '';
|
public $custom_message_unapproved_quote = '';
|
||||||
public $auto_archive_quote = false;
|
public $auto_archive_quote = false;
|
||||||
public $auto_convert_quote = false;
|
public $auto_convert_quote = false;
|
||||||
|
public $auto_email_invoice = true;
|
||||||
|
|
||||||
public $inclusive_taxes = false;
|
public $inclusive_taxes = false;
|
||||||
public $quote_footer = '';
|
public $quote_footer = '';
|
||||||
@ -218,6 +219,7 @@ class CompanySettings extends BaseSettings
|
|||||||
|
|
||||||
|
|
||||||
public static $casts = [
|
public static $casts = [
|
||||||
|
'auto_email_invoice' => 'bool',
|
||||||
'reminder_send_time' => 'int',
|
'reminder_send_time' => 'int',
|
||||||
'email_sending_method' => 'string',
|
'email_sending_method' => 'string',
|
||||||
'gmail_sending_user_id' => 'string',
|
'gmail_sending_user_id' => 'string',
|
||||||
|
@ -52,7 +52,7 @@ class InvoiceItem
|
|||||||
|
|
||||||
public $custom_value4 = '';
|
public $custom_value4 = '';
|
||||||
|
|
||||||
public $invoice_item_type_id = 1;
|
public $invoice_item_type_id = 1; //1 = product, 2 = service
|
||||||
|
|
||||||
public static $casts = [
|
public static $casts = [
|
||||||
'invoice_item_type_id' => 'string',
|
'invoice_item_type_id' => 'string',
|
||||||
|
81
app/Jobs/Product/UpdateOrCreateProduct.php
Normal file
81
app/Jobs/Product/UpdateOrCreateProduct.php
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Invoice Ninja (https://invoiceninja.com)
|
||||||
|
*
|
||||||
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
||||||
|
*
|
||||||
|
* @copyright Copyright (c) 2019. Invoice Ninja LLC (https://invoiceninja.com)
|
||||||
|
*
|
||||||
|
* @license https://opensource.org/licenses/AAL
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace App\Jobs\Product;
|
||||||
|
|
||||||
|
use App\Models\Company;
|
||||||
|
use App\Models\Payment;
|
||||||
|
use App\Models\Product;
|
||||||
|
use App\Repositories\InvoiceRepository;
|
||||||
|
use Illuminate\Bus\Queueable;
|
||||||
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
|
use Illuminate\Database\Capsule\Eloquent;
|
||||||
|
use Illuminate\Foundation\Bus\Dispatchable;
|
||||||
|
use Illuminate\Queue\InteractsWithQueue;
|
||||||
|
use Illuminate\Queue\SerializesModels;
|
||||||
|
|
||||||
|
class UpdateOrCreateProduct implements ShouldQueue
|
||||||
|
{
|
||||||
|
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
|
||||||
|
|
||||||
|
private $products;
|
||||||
|
|
||||||
|
private $invoice;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new job instance.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function __construct($products, $invoice)
|
||||||
|
{
|
||||||
|
|
||||||
|
$this->products = $products;
|
||||||
|
$this->invoice = $invoice;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Execute the job.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
|
||||||
|
foreach($this->products as $item)
|
||||||
|
{
|
||||||
|
|
||||||
|
$product = Product::firstOrNew(['product_key' => $item->product_key, 'company_id' => $this->invoice->company->id]);
|
||||||
|
|
||||||
|
$product->product_key = $item->product_key;
|
||||||
|
$product->notes = $item->notes;
|
||||||
|
$product->cost = $item->cost;
|
||||||
|
$product->tax_name1 = $item->tax_name1;
|
||||||
|
$product->tax_rate1 = $item->tax_rate1;
|
||||||
|
$product->tax_name2 = $item->tax_name2;
|
||||||
|
$product->tax_rate2 = $item->tax_rate2;
|
||||||
|
$product->custom_value1 = $item->custom_value1;
|
||||||
|
$product->custom_value2 = $item->custom_value2;
|
||||||
|
$product->custom_value3 = $item->custom_value3;
|
||||||
|
$product->custom_value4 = $item->custom_value4;
|
||||||
|
$product->user_id = $this->invoice->user_id;
|
||||||
|
$product->company_id = $this->invoice->company_id;
|
||||||
|
$product->project_id = $this->invoice->project_id;
|
||||||
|
$product->vendor_id = $this->invoice->vendor_id;
|
||||||
|
$product->save();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -132,7 +132,7 @@ class Client extends BaseModel
|
|||||||
|
|
||||||
public function activities()
|
public function activities()
|
||||||
{
|
{
|
||||||
return $this->hasMany(Activity::class, 'id', 'client_id');
|
return $this->hasMany(Activity::class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function contacts()
|
public function contacts()
|
||||||
|
@ -67,6 +67,7 @@ class Company extends BaseModel
|
|||||||
'custom_surcharge_taxes2',
|
'custom_surcharge_taxes2',
|
||||||
'custom_surcharge_taxes3',
|
'custom_surcharge_taxes3',
|
||||||
'custom_surcharge_taxes4',
|
'custom_surcharge_taxes4',
|
||||||
|
'show_product_details',
|
||||||
|
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -30,6 +30,10 @@ class InvoiceInvitation extends BaseModel
|
|||||||
'client_contact_id',
|
'client_contact_id',
|
||||||
];
|
];
|
||||||
|
|
||||||
|
protected $with = [
|
||||||
|
'company',
|
||||||
|
];
|
||||||
|
|
||||||
public function entityType()
|
public function entityType()
|
||||||
{
|
{
|
||||||
return Invoice::class;
|
return Invoice::class;
|
||||||
|
@ -18,6 +18,7 @@ use App\Helpers\Invoice\InvoiceSum;
|
|||||||
use App\Jobs\Company\UpdateCompanyLedgerWithInvoice;
|
use App\Jobs\Company\UpdateCompanyLedgerWithInvoice;
|
||||||
use App\Jobs\Invoice\ApplyInvoiceNumber;
|
use App\Jobs\Invoice\ApplyInvoiceNumber;
|
||||||
use App\Jobs\Invoice\CreateInvoiceInvitations;
|
use App\Jobs\Invoice\CreateInvoiceInvitations;
|
||||||
|
use App\Jobs\Product\UpdateOrCreateProduct;
|
||||||
use App\Listeners\Invoice\CreateInvoiceInvitation;
|
use App\Listeners\Invoice\CreateInvoiceInvitation;
|
||||||
use App\Models\ClientContact;
|
use App\Models\ClientContact;
|
||||||
use App\Models\Invoice;
|
use App\Models\Invoice;
|
||||||
@ -116,10 +117,6 @@ class InvoiceRepository extends BaseRepository
|
|||||||
|
|
||||||
$invoice = $invoice->calc()->getInvoice();
|
$invoice = $invoice->calc()->getInvoice();
|
||||||
|
|
||||||
// $invoice_calc = new InvoiceSum($invoice, $invoice->settings);
|
|
||||||
|
|
||||||
// $invoice = $invoice_calc->build()->getInvoice();
|
|
||||||
|
|
||||||
$invoice->save();
|
$invoice->save();
|
||||||
|
|
||||||
$finished_amount = $invoice->amount;
|
$finished_amount = $invoice->amount;
|
||||||
@ -130,6 +127,9 @@ class InvoiceRepository extends BaseRepository
|
|||||||
|
|
||||||
$invoice = ApplyInvoiceNumber::dispatchNow($invoice, $invoice->client->getMergedSettings());
|
$invoice = ApplyInvoiceNumber::dispatchNow($invoice, $invoice->client->getMergedSettings());
|
||||||
|
|
||||||
|
if($invoice->company->update_products !== false)
|
||||||
|
UpdateOrCreateProduct::dispatch($invoice->line_items, $invoice);
|
||||||
|
|
||||||
return $invoice->fresh();
|
return $invoice->fresh();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user