Item multiple tax added
This commit is contained in:
parent
02e73f9ebe
commit
032555507b
@ -4,6 +4,7 @@ namespace App\Jobs\Common;
|
||||
|
||||
use App\Abstracts\Job;
|
||||
use App\Models\Common\Item;
|
||||
use App\Jobs\Common\CreateItemTaxes;
|
||||
|
||||
class CreateItem extends Job
|
||||
{
|
||||
@ -37,6 +38,8 @@ class CreateItem extends Job
|
||||
|
||||
$this->item->attachMedia($media, 'picture');
|
||||
}
|
||||
|
||||
$this->dispatch(new CreateItemTaxes($this->item, $this->request));
|
||||
});
|
||||
|
||||
return $this->item;
|
||||
|
54
app/Jobs/Common/CreateItemTaxes.php
Normal file
54
app/Jobs/Common/CreateItemTaxes.php
Normal file
@ -0,0 +1,54 @@
|
||||
<?php
|
||||
|
||||
namespace App\Jobs\Common;
|
||||
|
||||
use App\Abstracts\Job;
|
||||
use App\Models\Common\ItemTax;
|
||||
|
||||
class CreateItemTaxes extends Job
|
||||
{
|
||||
protected $item;
|
||||
|
||||
protected $request;
|
||||
|
||||
/**
|
||||
* Create a new job instance.
|
||||
*
|
||||
* @param $item
|
||||
* @param $request
|
||||
*/
|
||||
public function __construct($item, $request)
|
||||
{
|
||||
$this->item = $item;
|
||||
$this->request = $request;
|
||||
}
|
||||
|
||||
/**
|
||||
* Execute the job.
|
||||
*
|
||||
* @return Item
|
||||
*/
|
||||
public function handle()
|
||||
{
|
||||
\DB::transaction(function () {
|
||||
// This controller for BC < 2.1
|
||||
if (!empty($this->request['tax_id'])) {
|
||||
ItemTax::create([
|
||||
'company_id' => $this->item->company_id,
|
||||
'item_id' => $this->item->id,
|
||||
'tax_id' => $this->request['tax_id']
|
||||
]);
|
||||
} else {
|
||||
foreach ($this->request['tax_ids'] as $tax_id) {
|
||||
ItemTax::create([
|
||||
'company_id' => $this->item->company_id,
|
||||
'item_id' => $this->item->id,
|
||||
'tax_id' => $tax_id
|
||||
]);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
return $this->item->taxes;
|
||||
}
|
||||
}
|
@ -28,6 +28,10 @@ class DeleteItem extends Job
|
||||
$this->authorize();
|
||||
|
||||
\DB::transaction(function () {
|
||||
$this->deleteRelationships($this->item, [
|
||||
'taxes'
|
||||
]);
|
||||
|
||||
$this->item->delete();
|
||||
});
|
||||
|
||||
|
@ -4,6 +4,7 @@ namespace App\Jobs\Common;
|
||||
|
||||
use App\Abstracts\Job;
|
||||
use App\Models\Common\Item;
|
||||
use App\Jobs\Common\CreateItemTaxes;
|
||||
|
||||
class UpdateItem extends Job
|
||||
{
|
||||
@ -39,6 +40,10 @@ class UpdateItem extends Job
|
||||
|
||||
$this->item->attachMedia($media, 'picture');
|
||||
}
|
||||
|
||||
$this->deleteRelationships($this->item, ['taxes']);
|
||||
|
||||
$this->dispatch(new CreateItemTaxes($this->item, $this->request));
|
||||
});
|
||||
|
||||
return $this->item;
|
||||
|
@ -26,7 +26,7 @@ class Item extends Model
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $fillable = ['company_id', 'name', 'description', 'sale_price', 'purchase_price', 'category_id', 'tax_id', 'enabled'];
|
||||
protected $fillable = ['company_id', 'name', 'description', 'sale_price', 'purchase_price', 'category_id', 'enabled'];
|
||||
|
||||
/**
|
||||
* The attributes that should be cast.
|
||||
@ -46,14 +46,19 @@ class Item extends Model
|
||||
*/
|
||||
protected $sortable = ['name', 'category', 'sale_price', 'purchase_price', 'enabled'];
|
||||
|
||||
/**
|
||||
* @var array
|
||||
*/
|
||||
public $cloneable_relations = ['taxes'];
|
||||
|
||||
public function category()
|
||||
{
|
||||
return $this->belongsTo('App\Models\Setting\Category')->withDefault(['name' => trans('general.na')]);
|
||||
}
|
||||
|
||||
public function tax()
|
||||
public function taxes()
|
||||
{
|
||||
return $this->belongsTo('App\Models\Setting\Tax')->withDefault(['name' => trans('general.na'), 'rate' => 0]);
|
||||
return $this->hasMany('App\Models\Common\ItemTax');
|
||||
}
|
||||
|
||||
public function bill_items()
|
||||
@ -81,6 +86,16 @@ class Item extends Model
|
||||
return $this->id;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the item id.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function getTaxIdsAttribute()
|
||||
{
|
||||
return $this->taxes()->pluck('tax_id');
|
||||
}
|
||||
|
||||
/**
|
||||
* Scope autocomplete.
|
||||
*
|
||||
|
25
app/Models/Common/ItemTax.php
Normal file
25
app/Models/Common/ItemTax.php
Normal file
@ -0,0 +1,25 @@
|
||||
<?php
|
||||
|
||||
namespace App\Models\Common;
|
||||
|
||||
use App\Abstracts\Model;
|
||||
use Bkwld\Cloner\Cloneable;
|
||||
|
||||
class ItemTax extends Model
|
||||
{
|
||||
use Cloneable;
|
||||
|
||||
protected $table = 'item_taxes';
|
||||
|
||||
/**
|
||||
* Attributes that should be mass-assignable.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $fillable = ['company_id', 'item_id', 'tax_id'];
|
||||
|
||||
public function tax()
|
||||
{
|
||||
return $this->belongsTo('App\Models\Setting\Tax')->withDefault(['name' => trans('general.na'), 'rate' => 0]);
|
||||
}
|
||||
}
|
@ -16,6 +16,17 @@ class CoreV210 extends Migration
|
||||
Schema::table('failed_jobs', function (Blueprint $table) {
|
||||
$table->string('uuid')->after('id')->nullable()->unique();
|
||||
});
|
||||
|
||||
Schema::create('item_taxes', function (Blueprint $table) {
|
||||
$table->increments('id');
|
||||
$table->integer('company_id');
|
||||
$table->integer('item_id');
|
||||
$table->integer('tax_id');
|
||||
$table->timestamps();
|
||||
$table->softDeletes();
|
||||
|
||||
$table->index(['company_id', 'item_id']);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
@ -25,6 +36,7 @@ class CoreV210 extends Migration
|
||||
*/
|
||||
public function down()
|
||||
{
|
||||
Schema::drop('item_taxes');
|
||||
//
|
||||
}
|
||||
}
|
||||
|
@ -19,7 +19,7 @@
|
||||
<div class="row">
|
||||
{{ Form::textGroup('name', trans('general.name'), 'tag') }}
|
||||
|
||||
{{ Form::selectAddNewGroup('tax_id', trans_choice('general.taxes', 1), 'percentage', $taxes, setting('default.tax'), ['path' => route('modals.taxes.create'), 'field' => ['key' => 'id', 'value' => 'title']]) }}
|
||||
{{ Form::multiSelectAddNewGroup('tax_ids', trans_choice('general.taxes', 1), 'percentage', $taxes, [setting('default.tax')], ['path' => route('modals.taxes.create'), 'field' => ['key' => 'id', 'value' => 'title']]) }}
|
||||
|
||||
{{ Form::textareaGroup('description', trans('general.description')) }}
|
||||
|
||||
|
@ -20,7 +20,7 @@
|
||||
<div class="row">
|
||||
{{ Form::textGroup('name', trans('general.name'), 'tag') }}
|
||||
|
||||
{{ Form::selectAddNewGroup('tax_id', trans_choice('general.taxes', 1), 'percentage', $taxes, $item->tax_id, ['path' => route('modals.taxes.create'), 'field' => ['key' => 'id', 'value' => 'title']]) }}
|
||||
{{ Form::multiSelectAddNewGroup('tax_ids', trans_choice('general.taxes', 1), 'percentage', $taxes, $item->tax_ids, ['path' => route('modals.taxes.create'), 'field' => ['key' => 'id', 'value' => 'title']]) }}
|
||||
|
||||
{{ Form::textareaGroup('description', trans('general.description')) }}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user