From e66ea4dcd1d00419f33d08aacb58f9aa6a63834d Mon Sep 17 00:00:00 2001 From: madd15 Date: Thu, 30 Jul 2015 13:45:46 +0930 Subject: [PATCH] Build out search and add Model order scope --- app/models/Asset.php | 57 ++++++++++++++++++++++++++++++++++---------- 1 file changed, 44 insertions(+), 13 deletions(-) diff --git a/app/models/Asset.php b/app/models/Asset.php index dda08ac1ffe9..9fcad6f461c8 100755 --- a/app/models/Asset.php +++ b/app/models/Asset.php @@ -391,8 +391,7 @@ public function scopeDeleted($query) { return $query->whereNotNull('deleted_at'); } - - + /** * Query builder scope to search on text * @@ -402,18 +401,50 @@ public function scopeDeleted($query) * @return Illuminate\Database\Query\Builder Modified query builder */ public function scopeTextSearch($query, $search) - { - - - return $query->where(function($query) use ($search) - { + { + $search = explode('+', $search); - $query->where('name','LIKE','%'.$search.'%') + return $query->where(function($query) use ($search) + { + foreach ($search as $search) { + $query->whereHas('model', function($query) use ($search) { + $query->join('categories','models.category_id','=','categories.id') + ->where('categories.name','LIKE','%'.$search.'%') + ->orWhere('models.name','LIKE','%'.$search.'%'); + })->orWhere(function($query) use ($search) { + $query->whereHas('assetstatus', function($query) use ($search) { + $query->where('name','LIKE','%'.$search.'%'); + }); + })->orWhere(function($query) use ($search) { + $query->whereHas('defaultLoc', function($query) use ($search) { + $query->where('name','LIKE','%'.$search.'%'); + }); + })->orWhere(function($query) use ($search) { + $query->whereHas('assigneduser', function($query) use ($search) { + $query->where('first_name','LIKE','%'.$search.'%') + ->orWhere('last_name','LIKE','%'.$search.'%'); + }); + })->orWhere('name','LIKE','%'.$search.'%') ->orWhere('asset_tag','LIKE','%'.$search.'%') - ->orWhere('serial','LIKE','%'.$search.'%'); - }); - - } - + ->orWhere('serial','LIKE','%'.$search.'%') + ->orWhere('order_number','LIKE','%'.$search.'%'); + } + }); + } + /** + * Query builder scope to order on model + * + * @param Illuminate\Database\Query\Builder $query Query builder instance + * @param text $order Order + * + * @return Illuminate\Database\Query\Builder Modified query builder + */ + public function scopeOrderModels($query, $order) + { + return $query->where(function($query) use ($order) + { + $query->join('models', 'assets.model_id', '=', 'models.id')->orderBy('models.name', $order); + }); + } }