2019-06-21 16:21:48 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
|
|
|
use Illuminate\Http\Request;
|
2021-10-08 12:19:33 +11:00
|
|
|
use Illuminate\Support\Collection;
|
2019-06-21 16:21:48 +10:00
|
|
|
use Illuminate\Support\Facades\Auth;
|
2021-07-23 17:25:26 +10:00
|
|
|
use Illuminate\Support\Facades\Gate;
|
2019-06-21 16:21:48 +10:00
|
|
|
|
2022-08-07 12:17:20 +10:00
|
|
|
use App\Models\{Account,Invoice,Payment,Service,Supplier,User};
|
2019-06-21 16:21:48 +10:00
|
|
|
|
|
|
|
class SearchController extends Controller
|
|
|
|
{
|
|
|
|
/**
|
2020-01-12 23:42:32 +11:00
|
|
|
* Search from the Application Dashboard.
|
2019-06-21 16:21:48 +10:00
|
|
|
*
|
2020-01-12 23:42:32 +11:00
|
|
|
* @param Request $request
|
2021-10-08 12:19:33 +11:00
|
|
|
* @return Collection
|
2019-06-21 16:21:48 +10:00
|
|
|
*/
|
2021-10-08 12:19:33 +11:00
|
|
|
public function search(Request $request): Collection
|
2019-06-21 16:21:48 +10:00
|
|
|
{
|
2021-10-08 12:19:33 +11:00
|
|
|
$result = collect();
|
|
|
|
|
2022-08-03 16:34:23 +10:00
|
|
|
// If the user isnt logged in
|
|
|
|
if (! Auth::user())
|
|
|
|
abort(401,'Need to login');
|
|
|
|
|
2020-01-12 23:42:32 +11:00
|
|
|
// If there isnt a term value, return null
|
2019-06-21 16:21:48 +10:00
|
|
|
if (! $request->input('term'))
|
2021-10-08 12:19:33 +11:00
|
|
|
return $result;
|
2019-06-21 16:21:48 +10:00
|
|
|
|
2022-04-21 16:25:29 +10:00
|
|
|
$account_ids = ($x=Auth::user()->accounts)->pluck('id');
|
|
|
|
$user_ids = $x->transform(function($item) { return $item->user;})->pluck('id');
|
2019-06-21 16:21:48 +10:00
|
|
|
|
2020-02-08 22:51:50 +11:00
|
|
|
# Look for User
|
2020-02-07 07:11:02 +09:00
|
|
|
foreach (User::Search($request->input('term'))
|
2022-04-21 16:25:29 +10:00
|
|
|
->whereIN('id',$user_ids)
|
2020-02-07 07:11:02 +09:00
|
|
|
->orderBy('lastname')
|
|
|
|
->orderBy('firstname')
|
2019-06-21 16:21:48 +10:00
|
|
|
->limit(10)->get() as $o)
|
|
|
|
{
|
2022-08-07 12:17:20 +10:00
|
|
|
$result->push(['name'=>sprintf('%s (%s) - %s',$o->name,$o->lid,$o->email),'value'=>'/u/home/'.$o->id,'category'=>'Users']);
|
2020-01-12 23:42:32 +11:00
|
|
|
}
|
|
|
|
|
2022-08-07 12:17:20 +10:00
|
|
|
# Look for User by Supplier
|
|
|
|
if (is_numeric($request->input('term')))
|
2022-08-10 17:05:57 +10:00
|
|
|
foreach (User::select(['users.*','suppliers.name AS supplier_name','supplier_user.id AS pivot_id'])
|
|
|
|
->join('supplier_user',['supplier_user.user_id'=>'users.id'])
|
|
|
|
->join('suppliers',['suppliers.id'=>'supplier_user.supplier_id'])
|
2022-08-07 12:17:20 +10:00
|
|
|
->whereIN('user_id',$user_ids)
|
2022-08-10 17:05:57 +10:00
|
|
|
->where('supplier_user.id','like','%'.$request->input('term').'%')
|
|
|
|
->orderBy('lastname')
|
|
|
|
->orderBy('firstname')
|
2022-08-07 12:17:20 +10:00
|
|
|
->limit(10)->get() as $o)
|
|
|
|
{
|
2022-08-10 17:05:57 +10:00
|
|
|
$result->push(['name'=>sprintf('%s (%s:%s)',$o->name,$o->supplier_name,$o->pivot_id),'value'=>'/u/home/'.$o->id,'category'=>'Suppliers']);
|
2022-08-07 12:17:20 +10:00
|
|
|
}
|
|
|
|
|
2020-02-08 22:51:50 +11:00
|
|
|
# Look for Account
|
|
|
|
foreach (Account::Search($request->input('term'))
|
2022-04-22 10:36:41 +10:00
|
|
|
->whereIN('user_id',$user_ids)
|
|
|
|
->orderBy('company')
|
|
|
|
->limit(10)->get() as $o)
|
2020-02-08 22:51:50 +11:00
|
|
|
{
|
2022-04-22 11:47:46 +10:00
|
|
|
$result->push(['name'=>sprintf('%s (%s)',$o->company,$o->lid),'value'=>'/u/home/'.$o->user_id,'category'=>'Accounts']);
|
2020-02-08 22:51:50 +11:00
|
|
|
}
|
|
|
|
|
2020-01-12 23:42:32 +11:00
|
|
|
# Look for a Service
|
|
|
|
foreach (Service::Search($request->input('term'))
|
2022-04-22 10:36:41 +10:00
|
|
|
->whereIN('account_id',$account_ids)
|
|
|
|
->orderBy('id')
|
2022-06-14 16:51:18 +10:00
|
|
|
->limit(20)->get() as $o)
|
2020-01-12 23:42:32 +11:00
|
|
|
{
|
2022-06-14 16:51:18 +10:00
|
|
|
$result->push(['name'=>sprintf('%s (%s) %s',$o->name,$o->lid,$o->active ? '' : '<small>INACT</small>'),'value'=>'/u/service/'.$o->id,'category'=>$o->category_name]);
|
2020-01-12 23:42:32 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
# Look for an Invoice
|
|
|
|
foreach (Invoice::Search($request->input('term'))
|
2022-04-22 10:36:41 +10:00
|
|
|
->whereIN('account_id',$account_ids)
|
|
|
|
->orderBy('id')
|
|
|
|
->limit(10)->get() as $o)
|
2020-01-12 23:42:32 +11:00
|
|
|
{
|
2022-04-22 10:36:41 +10:00
|
|
|
$result->push(['name'=>sprintf('%s: %s',$o->lid,$o->account->name),'value'=>'/u/invoice/'.$o->id,'category'=>'Invoices']);
|
2019-06-21 16:21:48 +10:00
|
|
|
}
|
|
|
|
|
2021-07-23 17:25:26 +10:00
|
|
|
if (Gate::any(['wholesaler'],new Payment)) {
|
|
|
|
# Look for Payments
|
|
|
|
foreach (Payment::Search($request->input('term'))
|
2022-04-22 10:36:41 +10:00
|
|
|
->whereIN('account_id',$account_ids)
|
|
|
|
->limit(10)->get() as $o)
|
2021-07-23 17:25:26 +10:00
|
|
|
{
|
2022-04-22 10:36:41 +10:00
|
|
|
$result->push(['name'=>sprintf('%s: %s $%s',$o->lid,$o->account->name,number_format($o->total,2)),'value'=>'/a/payment/addedit/'.$o->id,'category'=>'Payments']);
|
2021-07-23 17:25:26 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-14 16:51:18 +10:00
|
|
|
return $result->sortBy(function($item) { return $item['category'].$item['name']; })->values();
|
2019-06-21 16:21:48 +10:00
|
|
|
}
|
|
|
|
}
|