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 Product.
|
2016-07-03 18:11:58 +02:00
|
|
|
*/
|
2015-03-16 22:45:25 +01:00
|
|
|
class Product extends EntityModel
|
|
|
|
{
|
2016-08-10 16:04:17 +02:00
|
|
|
use PresentableTrait;
|
2015-03-31 11:38:24 +02:00
|
|
|
use SoftDeletes;
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
2015-03-31 11:38:24 +02:00
|
|
|
protected $dates = ['deleted_at'];
|
|
|
|
|
2016-08-10 16:04:17 +02:00
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $presenter = 'App\Ninja\Presenters\ProductPresenter';
|
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
2016-05-02 15:12:37 +02:00
|
|
|
protected $fillable = [
|
|
|
|
'product_key',
|
|
|
|
'notes',
|
|
|
|
'cost',
|
|
|
|
'qty',
|
|
|
|
'default_tax_rate_id',
|
2017-02-23 15:33:02 +01:00
|
|
|
'custom_value1',
|
|
|
|
'custom_value2',
|
2016-05-02 15:12:37 +02:00
|
|
|
];
|
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @return array
|
|
|
|
*/
|
2016-05-31 22:15:55 +02:00
|
|
|
public static function getImportColumns()
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'product_key',
|
|
|
|
'notes',
|
|
|
|
'cost',
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @return array
|
|
|
|
*/
|
2016-05-31 22:15:55 +02:00
|
|
|
public static function getImportMap()
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'product|item' => 'product_key',
|
|
|
|
'notes|description|details' => 'notes',
|
|
|
|
'cost|amount|price' => 'cost',
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @return mixed
|
|
|
|
*/
|
2015-11-05 23:37:04 +01:00
|
|
|
public function getEntityType()
|
|
|
|
{
|
|
|
|
return ENTITY_PRODUCT;
|
|
|
|
}
|
|
|
|
|
2016-07-03 18:11:58 +02:00
|
|
|
/**
|
|
|
|
* @param $key
|
2017-01-30 20:40:43 +01:00
|
|
|
*
|
2016-07-03 18:11:58 +02:00
|
|
|
* @return mixed
|
|
|
|
*/
|
2015-03-16 22:45:25 +01:00
|
|
|
public static function findProductByKey($key)
|
|
|
|
{
|
2017-01-30 20:40:43 +01:00
|
|
|
return self::scope()->where('product_key', '=', $key)->first();
|
2015-03-16 22:45:25 +01:00
|
|
|
}
|
2015-10-21 13:11:08 +02: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-10-21 13:11:08 +02:00
|
|
|
public function default_tax_rate()
|
|
|
|
{
|
|
|
|
return $this->belongsTo('App\Models\TaxRate');
|
|
|
|
}
|
2015-03-16 22:45:25 +01:00
|
|
|
}
|