58 lines
1.3 KiB
PHP
Executable File
58 lines
1.3 KiB
PHP
Executable File
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
|
|
class Work extends Model
|
|
{
|
|
use HasFactory, SoftDeletes;
|
|
protected $fillable = [
|
|
"category_id", "name", "desc", "shortname"
|
|
];
|
|
|
|
/**
|
|
* Get all of the transactions for the Work
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasMany
|
|
*/
|
|
public function transactions()
|
|
{
|
|
return $this->hasMany(Transaction::class, 'work_id', 'id');
|
|
}
|
|
|
|
/**
|
|
* Get all products required for this work
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
|
|
*/
|
|
public function products()
|
|
{
|
|
return $this->belongsToMany(Product::class, 'work_products')
|
|
->withPivot('quantity_required', 'notes')
|
|
->withTimestamps();
|
|
}
|
|
|
|
/**
|
|
* Get work products pivot records
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasMany
|
|
*/
|
|
public function workProducts()
|
|
{
|
|
return $this->hasMany(WorkProduct::class);
|
|
}
|
|
|
|
/**
|
|
* Get the category associated with the Work
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
|
*/
|
|
public function category()
|
|
{
|
|
return $this->belongsTo(Category::class);
|
|
}
|
|
}
|