1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-14 07:02:34 +01:00
invoiceninja/app/Models/Product.php

91 lines
1.6 KiB
PHP
Raw Normal View History

2015-03-18 00:39:03 +01:00
<?php namespace App\Models;
2015-03-16 22:45:25 +01:00
2016-08-10 16:04:17 +02:00
use Laracasts\Presenter\PresentableTrait;
2015-03-31 11:38:24 +02:00
use Illuminate\Database\Eloquent\SoftDeletes;
/**
* Class Product
*/
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;
/**
* @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';
/**
* @var array
*/
2016-05-02 15:12:37 +02:00
protected $fillable = [
'product_key',
'notes',
'cost',
'qty',
'default_tax_rate_id',
];
/**
* @return array
*/
2016-05-31 22:15:55 +02:00
public static function getImportColumns()
{
return [
'product_key',
'notes',
'cost',
];
}
/**
* @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',
];
}
/**
* @return mixed
*/
2015-11-05 23:37:04 +01:00
public function getEntityType()
{
return ENTITY_PRODUCT;
}
/**
* @param $key
* @return mixed
*/
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
/**
* @return mixed
*/
2016-05-03 22:02:29 +02:00
public function user()
{
return $this->belongsTo('App\Models\User')->withTrashed();
}
/**
* @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
}