mirror of
https://github.com/snipe/snipe-it.git
synced 2024-11-10 15:44:11 -08:00
cd8c585377
* Make delete routes work. We put a little form in the modal that spoofs the delete field. * Fix route on creating a user. * Fix redundant id parameter. * Port acceptance tests to new urls. * Initial work on migrating to model based policies instead of global gates. Will allow for much more detailed permissions bits in the future. * This needs to stay for the dashboard checks. * Add user states for permissions to build tests. * Build up unit tests for gates/permissions. Move accessories/consumables/assets to policies instead of in authserviceprovider * Migrate various locations to new syntax. Update test to be more specific * Fix functional tests. Add an artisan command for installing a settings setup on travis-ci * Try a different id... Need to come up with a better way of passing the id for tests that need an existing one. * Try to fix travis * Update urls to use routes and not hardcode old paths. Also fix some migration errors found along the way.: * Add a environment for travis functional tests. * Adjust config file to make travis use it. * Use redirect()->route instead of redirect()-to * Dump all failures in the output directory if travis fails. * Cleanups and minor fixes. * Adjust the supplier modelfactory to comply with new validation restrictions. * Some test fixes. * Locales can be longer than 5 characters according to faker... fex gez_ET. Increase lenght in mysql and add a validation * Update test database dump to latest migrations.
139 lines
4 KiB
PHP
139 lines
4 KiB
PHP
<?php
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Support\Facades\Lang;
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
use Watson\Validating\ValidatingTrait;
|
|
|
|
/**
|
|
* Model for Asset Maintenances.
|
|
*
|
|
* @version v1.0
|
|
*/
|
|
class AssetMaintenance extends Model implements ICompanyableChild
|
|
{
|
|
use SoftDeletes;
|
|
use CompanyableChildTrait;
|
|
use ValidatingTrait;
|
|
|
|
|
|
protected $dates = [ 'deleted_at' ];
|
|
protected $table = 'asset_maintenances';
|
|
|
|
// Declaring rules for form validation
|
|
protected $rules = [
|
|
'asset_id' => 'required|integer',
|
|
'supplier_id' => 'required|integer',
|
|
'asset_maintenance_type' => 'required',
|
|
'title' => 'required|max:100',
|
|
'is_warranty' => 'boolean',
|
|
'start_date' => 'required|date_format:"Y-m-d"',
|
|
'completion_date' => 'date_format:"Y-m-d',
|
|
'notes' => 'string|nullable',
|
|
'cost' => 'numeric|nullable'
|
|
];
|
|
|
|
public function getCompanyableParents()
|
|
{
|
|
return [ 'asset' ];
|
|
}
|
|
|
|
/**
|
|
* getImprovementOptions
|
|
*
|
|
* @return array
|
|
* @author Vincent Sposato <vincent.sposato@gmail.com>
|
|
* @version v1.0
|
|
*/
|
|
public static function getImprovementOptions()
|
|
{
|
|
|
|
return [
|
|
trans('admin/asset_maintenances/general.maintenance') => trans('admin/asset_maintenances/general.maintenance'),
|
|
trans('admin/asset_maintenances/general.repair') => trans('admin/asset_maintenances/general.repair'),
|
|
trans('admin/asset_maintenances/general.upgrade') => trans('admin/asset_maintenances/general.upgrade')
|
|
];
|
|
}
|
|
|
|
/**
|
|
* asset
|
|
* Get asset for this improvement
|
|
*
|
|
* @return mixed
|
|
* @author Vincent Sposato <vincent.sposato@gmail.com>
|
|
* @version v1.0
|
|
*/
|
|
public function asset()
|
|
{
|
|
|
|
return $this->belongsTo('\App\Models\Asset', 'asset_id')
|
|
->withTrashed();
|
|
}
|
|
|
|
/**
|
|
* Get the admin who created the maintenance
|
|
*
|
|
* @return mixed
|
|
* @author A. Gianotto <snipe@snipe.net>
|
|
* @version v3.0
|
|
*/
|
|
public function admin()
|
|
{
|
|
|
|
return $this->belongsTo('\App\Models\User', 'user_id')
|
|
->withTrashed();
|
|
}
|
|
|
|
public function supplier()
|
|
{
|
|
|
|
return $this->belongsTo('\App\Models\Supplier', 'supplier_id')
|
|
->withTrashed();
|
|
}
|
|
|
|
/**
|
|
* -----------------------------------------------
|
|
* BEGIN QUERY SCOPES
|
|
* -----------------------------------------------
|
|
**/
|
|
|
|
|
|
/**
|
|
* Query builder scope to search on text
|
|
*
|
|
* @param Illuminate\Database\Query\Builder $query Query builder instance
|
|
* @param text $search Search term
|
|
*
|
|
* @return Illuminate\Database\Query\Builder Modified query builder
|
|
*/
|
|
public function scopeTextSearch($query, $search)
|
|
{
|
|
|
|
return $query->where(function ($query) use ($search) {
|
|
|
|
$query->where('title', 'LIKE', '%'.$search.'%')
|
|
->orWhere('notes', 'LIKE', '%'.$search.'%')
|
|
->orWhere('asset_maintenance_type', 'LIKE', '%'.$search.'%')
|
|
->orWhere('cost', 'LIKE', '%'.$search.'%')
|
|
->orWhere('start_date', 'LIKE', '%'.$search.'%')
|
|
->orWhere('completion_date', 'LIKE', '%'.$search.'%');
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Query builder scope to order on admin user
|
|
*
|
|
* @param Illuminate\Database\Query\Builder $query Query builder instance
|
|
* @param text $order Order
|
|
*
|
|
* @return Illuminate\Database\Query\Builder Modified query builder
|
|
*/
|
|
public function scopeOrderAdmin($query, $order)
|
|
{
|
|
return $query->leftJoin('users', 'asset_maintenances.user_id', '=', 'users.id')
|
|
->orderBy('users.first_name', $order)
|
|
->orderBy('users.last_name', $order);
|
|
}
|
|
}
|