2015-03-18 00:39:03 +01:00
|
|
|
<?php namespace App\Models;
|
2015-03-16 22:45:25 +01:00
|
|
|
|
2016-03-16 03:07:11 +01:00
|
|
|
use Auth;
|
2015-03-31 11:38:24 +02:00
|
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
|
|
|
2015-03-16 22:45:25 +01:00
|
|
|
class Product extends EntityModel
|
|
|
|
{
|
2015-03-31 11:38:24 +02:00
|
|
|
use SoftDeletes;
|
|
|
|
protected $dates = ['deleted_at'];
|
|
|
|
|
2016-05-02 15:12:37 +02:00
|
|
|
protected $fillable = [
|
|
|
|
'product_key',
|
|
|
|
'notes',
|
|
|
|
'cost',
|
|
|
|
'qty',
|
|
|
|
'default_tax_rate_id',
|
|
|
|
];
|
|
|
|
|
2016-05-31 22:15:55 +02:00
|
|
|
public static function getImportColumns()
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'product_key',
|
|
|
|
'notes',
|
|
|
|
'cost',
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function getImportMap()
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'product|item' => 'product_key',
|
|
|
|
'notes|description|details' => 'notes',
|
|
|
|
'cost|amount|price' => 'cost',
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2015-11-05 23:37:04 +01:00
|
|
|
public function getEntityType()
|
|
|
|
{
|
|
|
|
return ENTITY_PRODUCT;
|
|
|
|
}
|
|
|
|
|
2015-03-16 22:45:25 +01:00
|
|
|
public static function findProductByKey($key)
|
|
|
|
{
|
|
|
|
return Product::scope()->where('product_key', '=', $key)->first();
|
|
|
|
}
|
2015-10-21 13:11:08 +02:00
|
|
|
|
2016-05-03 22:02:29 +02:00
|
|
|
public function user()
|
|
|
|
{
|
|
|
|
return $this->belongsTo('App\Models\User')->withTrashed();
|
|
|
|
}
|
|
|
|
|
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
|
|
|
}
|