'required|min:3|max:255|unique:depreciations,name', 'months' => 'required|max:3600|integer|gt:0', ]; /** * Whether the model should inject it's identifier to the unique * validation rules before attempting validation. If this property * is not set in the model it will default to true. * * @var bool */ protected $injectUniqueIdentifier = true; use ValidatingTrait; /** * The attributes that are mass assignable. * * @var array */ protected $fillable = ['name', 'months']; use Searchable; /** * The attributes that should be included when searching the model. * * @var array */ protected $searchableAttributes = ['name', 'months']; /** * The relations and their attributes that should be included when searching the model. * * @var array */ protected $searchableRelations = []; /** * Establishes the depreciation -> models relationship * * @author A. Gianotto * @since [v5.0] * @return \Illuminate\Database\Eloquent\Relations\Relation */ public function models() { return $this->hasMany(\App\Models\AssetModel::class, 'depreciation_id'); } /** * Establishes the depreciation -> licenses relationship * * @author A. Gianotto * @since [v5.0] * @return \Illuminate\Database\Eloquent\Relations\Relation */ public function licenses() { return $this->hasMany(\App\Models\License::class, 'depreciation_id'); } /** * Establishes the depreciation -> assets relationship * * @author A. Gianotto * @since [v5.0] * @return \Illuminate\Database\Eloquent\Relations\Relation */ public function assets() { return $this->hasManyThrough(\App\Models\Asset::class, \App\Models\AssetModel::class, 'depreciation_id', 'model_id'); } /** * Get the user that created the depreciation * * @author A. Gianotto * @since [v7.0.13] * @return \Illuminate\Database\Eloquent\Relations\Relation */ public function adminuser() { return $this->belongsTo(\App\Models\User::class, 'created_by'); } /** * ----------------------------------------------- * BEGIN QUERY SCOPES * ----------------------------------------------- **/ public function scopeOrderByCreatedBy($query, $order) { return $query->leftJoin('users as admin_sort', 'depreciations.created_by', '=', 'admin_sort.id')->select('depreciations.*')->orderBy('admin_sort.first_name', $order)->orderBy('admin_sort.last_name', $order); } }