Allow to add Module's fields to the search and filter

This commit is contained in:
Burak Çakırel 2021-09-06 11:15:53 +01:00
parent 332d76b77b
commit 44e3ec8679
No known key found for this signature in database
GPG Key ID: 48FFBB7771B99C7C
4 changed files with 61 additions and 4 deletions

View File

@ -2,6 +2,8 @@
namespace App\Abstracts;
use App\Events\Common\SearchStringApplied;
use App\Events\Common\SearchStringApplying;
use App\Traits\DateTime;
use App\Traits\Owners;
use App\Traits\Tenants;
@ -115,9 +117,7 @@ abstract class Model extends Eloquent implements Ownable
{
$request = request();
$search = $request->get('search');
$query->usingSearchString($search)->sortable($sort);
$query->usingSearchString()->sortable($sort);
if ($request->expectsJson() && $request->isNotApi()) {
return $query->get();
@ -128,6 +128,15 @@ abstract class Model extends Eloquent implements Ownable
return $query->paginate($limit);
}
public function scopeUsingSearchString($query)
{
event(new SearchStringApplying($query));
$this->getSearchStringManager()->updateBuilder($query, request('search'));
event(new SearchStringApplied($query));
}
/**
* Scope to export the rows of the current page filtered and sorted.
*

View File

@ -0,0 +1,20 @@
<?php
namespace App\Events\Common;
use App\Abstracts\Event;
class SearchStringApplied extends Event
{
public $query;
/**
* Create a new event instance.
*
* @param $query
*/
public function __construct($query)
{
$this->query = $query;
}
}

View File

@ -0,0 +1,20 @@
<?php
namespace App\Events\Common;
use App\Abstracts\Event;
class SearchStringApplying extends Event
{
public $query;
/**
* Create a new event instance.
*
* @param $query
*/
public function __construct($query)
{
$this->query = $query;
}
}

View File

@ -90,7 +90,11 @@ class SearchString extends Component
}
if (isset($options['relationship'])) {
$column .= '.id';
if (isset($options['foreign_key'])) {
$column .= '.' . $options['foreign_key'];
} else {
$column .= '.id';
}
}
return $column;
@ -104,6 +108,10 @@ class SearchString extends Component
$column = str_replace('_code', '', $column);
}
if (!empty($options['translation'])) {
return $options['translation'];
}
if (!empty($options['key'])) {
$column = $options['key'];
}