148 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			148 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Models\Document;
 | |
| 
 | |
| use App\Abstracts\Model;
 | |
| use App\Traits\Currencies;
 | |
| use Bkwld\Cloner\Cloneable;
 | |
| use Illuminate\Database\Eloquent\Builder;
 | |
| use Illuminate\Database\Eloquent\Relations\BelongsTo;
 | |
| use Illuminate\Database\Eloquent\Relations\HasMany;
 | |
| 
 | |
| class DocumentItem extends Model
 | |
| {
 | |
|     use Cloneable, Currencies;
 | |
| 
 | |
|     protected $table = 'document_items';
 | |
| 
 | |
|     protected $appends = ['discount'];
 | |
| 
 | |
|     protected $fillable = [
 | |
|         'company_id',
 | |
|         'type',
 | |
|         'document_id',
 | |
|         'item_id',
 | |
|         'name',
 | |
|         'description',
 | |
|         'quantity',
 | |
|         'price',
 | |
|         'total',
 | |
|         'tax',
 | |
|         'discount_rate',
 | |
|         'discount_type',
 | |
|         'created_from',
 | |
|         'created_by',
 | |
|     ];
 | |
| 
 | |
|     /**
 | |
|      * The attributes that should be cast.
 | |
|      *
 | |
|      * @var array
 | |
|      */
 | |
|     protected $casts = [
 | |
|         'price' => 'double',
 | |
|         'total' => 'double',
 | |
|         'tax' => 'double',
 | |
|     ];
 | |
| 
 | |
|     /**
 | |
|      * @var array
 | |
|      */
 | |
|     public $cloneable_relations = ['taxes'];
 | |
| 
 | |
|     public static function boot()
 | |
|     {
 | |
|         parent::boot();
 | |
| 
 | |
|         static::retrieved(
 | |
|             function ($model) {
 | |
|                 $model->setTaxIds();
 | |
|             }
 | |
|         );
 | |
| 
 | |
|         static::saving(
 | |
|             function ($model) {
 | |
|                 $model->offsetUnset('tax_ids');
 | |
|             }
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     public function document()
 | |
|     {
 | |
|         return $this->belongsTo('App\Models\Document\Document');
 | |
|     }
 | |
| 
 | |
|     public function item()
 | |
|     {
 | |
|         return $this->belongsTo('App\Models\Common\Item')->withDefault(['name' => trans('general.na')]);
 | |
|     }
 | |
| 
 | |
|     public function taxes()
 | |
|     {
 | |
|         return $this->hasMany('App\Models\Document\DocumentItemTax', 'document_item_id', 'id');
 | |
|     }
 | |
| 
 | |
|     public function scopeType(Builder $query, string $type)
 | |
|     {
 | |
|         return $query->where($this->qualifyColumn('type'), '=', $type);
 | |
|     }
 | |
| 
 | |
|     public function scopeInvoice(Builder $query)
 | |
|     {
 | |
|         return $query->where($this->qualifyColumn('type'), '=', Document::INVOICE_TYPE);
 | |
|     }
 | |
| 
 | |
|     public function scopeBill(Builder $query)
 | |
|     {
 | |
|         return $query->where($this->qualifyColumn('type'), '=', Document::BILL_TYPE);
 | |
|     }
 | |
| 
 | |
|     public function getDiscountAttribute(): string
 | |
|     {
 | |
|         if (setting('localisation.percent_position', 'after') === 'after') {
 | |
|             $text = ($this->discount_type === 'normal') ? $this->discount_rate . '%' : $this->discount_rate;
 | |
|         } else {
 | |
|             $text = ($this->discount_type === 'normal') ? '%' . $this->discount_rate : $this->discount_rate;
 | |
|         }
 | |
| 
 | |
|         return $text;
 | |
|     }
 | |
| 
 | |
|     public function getDiscountRateAttribute(int $value = 0)
 | |
|     {
 | |
|         $discount_rate = 0;
 | |
| 
 | |
|         switch (setting('localisation.discount_location', 'total')) {
 | |
|             case 'no':
 | |
|             case 'total':
 | |
|                 $discount_rate = 0;
 | |
|                 break;
 | |
|             case 'both':
 | |
|             case 'item':
 | |
|                 $discount_rate = $value;
 | |
|                 break;
 | |
|         }
 | |
| 
 | |
|         return $discount_rate;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Convert tax to Array.
 | |
|      */
 | |
|     public function setTaxIds()
 | |
|     {
 | |
|         $tax_ids = [];
 | |
| 
 | |
|         foreach ($this->taxes as $tax) {
 | |
|             $tax_ids[] = (string) $tax->tax_id;
 | |
|         }
 | |
| 
 | |
|         $this->setAttribute('tax_ids', $tax_ids);
 | |
|     }
 | |
| 
 | |
|     public function onCloning($src, $child = null)
 | |
|     {
 | |
|         unset($this->tax_ids);
 | |
|     }
 | |
| }
 |