2017-01-30 20:40:43 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models;
|
2015-03-16 22:45:25 +01:00
|
|
|
|
2015-03-31 11:38:24 +02:00
|
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
2017-01-30 20:40:43 +01:00
|
|
|
use Laracasts\Presenter\PresentableTrait;
|
2015-03-31 11:38:24 +02:00
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
2017-01-30 20:40:43 +01:00
|
|
|
* Class InvoiceItem.
|
2016-07-03 18:11:58 +02:00
|
|
|
*/
|
2015-03-16 22:45:25 +01:00
|
|
|
class InvoiceItem extends EntityModel
|
|
|
|
{
|
2016-12-12 19:42:51 +01:00
|
|
|
use PresentableTrait;
|
2016-08-14 08:50:41 +02:00
|
|
|
use SoftDeletes;
|
2016-12-12 19:42:51 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $presenter = 'App\Ninja\Presenters\InvoiceItemPresenter';
|
|
|
|
|
2016-08-14 08:50:41 +02:00
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $dates = ['deleted_at'];
|
|
|
|
|
2016-08-09 08:48:41 +02:00
|
|
|
/**
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function getEntityType()
|
|
|
|
{
|
|
|
|
return ENTITY_INVOICE_ITEM;
|
|
|
|
}
|
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
2016-03-31 11:29:01 +02:00
|
|
|
protected $fillable = [
|
|
|
|
'tax_name1',
|
|
|
|
'tax_rate1',
|
|
|
|
'tax_name2',
|
2016-08-09 08:48:41 +02:00
|
|
|
'tax_rate2',
|
2017-03-17 12:47:16 +01:00
|
|
|
'invoice_item_type_id',
|
2017-12-21 15:30:18 +01:00
|
|
|
'discount',
|
2016-03-31 11:29:01 +02:00
|
|
|
];
|
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
|
|
|
*/
|
2015-03-16 22:45:25 +01:00
|
|
|
public function invoice()
|
|
|
|
{
|
2015-03-31 11:38:24 +02:00
|
|
|
return $this->belongsTo('App\Models\Invoice');
|
2015-03-16 22:45:25 +01:00
|
|
|
}
|
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @return mixed
|
|
|
|
*/
|
2016-05-03 22:02:29 +02:00
|
|
|
public function user()
|
|
|
|
{
|
|
|
|
return $this->belongsTo('App\Models\User')->withTrashed();
|
|
|
|
}
|
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
|
|
|
*/
|
2015-03-16 22:45:25 +01:00
|
|
|
public function product()
|
|
|
|
{
|
2015-03-31 11:38:24 +02:00
|
|
|
return $this->belongsTo('App\Models\Product');
|
2015-03-16 22:45:25 +01:00
|
|
|
}
|
2015-11-07 13:15:37 +01:00
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
|
|
|
*/
|
2015-11-07 13:15:37 +01:00
|
|
|
public function account()
|
|
|
|
{
|
|
|
|
return $this->belongsTo('App\Models\Account');
|
|
|
|
}
|
2017-03-15 16:09:23 +01:00
|
|
|
|
2018-04-23 11:44:23 +02:00
|
|
|
public function getPreTaxAmount()
|
2017-03-15 16:09:23 +01:00
|
|
|
{
|
|
|
|
$amount = $this->cost * $this->qty;
|
2017-12-23 21:06:30 +01:00
|
|
|
|
|
|
|
if ($this->discount != 0) {
|
|
|
|
if ($this->invoice->is_amount_discount) {
|
|
|
|
$amount -= $this->discount;
|
|
|
|
} else {
|
2018-04-23 11:44:23 +02:00
|
|
|
$amount -= round($amount * $this->discount / 100, 4);
|
2017-12-23 21:06:30 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-23 11:44:23 +02:00
|
|
|
return $amount;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getTaxAmount()
|
|
|
|
{
|
|
|
|
$tax = 0;
|
|
|
|
$preTaxAmount = $this->getPreTaxAmount();
|
2017-03-15 16:09:23 +01:00
|
|
|
|
|
|
|
if ($this->tax_rate1) {
|
2018-04-23 11:44:23 +02:00
|
|
|
$tax += round($preTaxAmount * $this->tax_rate1 / 100, 2);
|
2017-03-15 16:09:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->tax_rate2) {
|
2018-04-23 11:44:23 +02:00
|
|
|
$tax += round($preTaxAmount * $this->tax_rate2 / 100, 2);
|
2017-03-15 16:09:23 +01:00
|
|
|
}
|
|
|
|
|
2018-04-23 11:44:23 +02:00
|
|
|
return $tax;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function amount()
|
|
|
|
{
|
|
|
|
return $this->getPreTaxAmount() + $this->getTaxAmount();
|
2017-03-15 16:09:23 +01:00
|
|
|
}
|
2017-03-17 12:57:56 +01:00
|
|
|
|
|
|
|
public function markFeePaid()
|
|
|
|
{
|
|
|
|
if ($this->invoice_item_type_id == INVOICE_ITEM_TYPE_PENDING_GATEWAY_FEE) {
|
|
|
|
$this->invoice_item_type_id = INVOICE_ITEM_TYPE_PAID_GATEWAY_FEE;
|
|
|
|
$this->save();
|
|
|
|
}
|
|
|
|
}
|
2018-01-14 19:17:59 +01:00
|
|
|
|
|
|
|
public function hasTaxes()
|
|
|
|
{
|
|
|
|
if ($this->tax_name1 || $this->tax_rate1) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->tax_name2 || $this->tax_rate2) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function costWithDiscount()
|
|
|
|
{
|
|
|
|
$cost = $this->cost;
|
|
|
|
|
|
|
|
if ($this->discount != 0) {
|
|
|
|
if ($this->invoice->is_amount_discount) {
|
2018-06-10 09:38:55 +02:00
|
|
|
$cost -= $this->discount / $this->qty;
|
2018-01-14 19:17:59 +01:00
|
|
|
} else {
|
2018-06-10 09:38:55 +02:00
|
|
|
$cost -= $cost * $this->discount / 100;
|
2018-01-14 19:17:59 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $cost;
|
|
|
|
}
|
|
|
|
|
2015-03-16 22:45:25 +01:00
|
|
|
}
|