48 lines
1.4 KiB
PHP
48 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace Laravel\Nova\Query\Search;
|
|
|
|
use Illuminate\Support\Str;
|
|
|
|
class SearchableJson extends Column
|
|
{
|
|
/**
|
|
* The search JSON seletor path.
|
|
*
|
|
* @var \Illuminate\Database\Query\Expression|string
|
|
*/
|
|
public $jsonSelectorPath;
|
|
|
|
/**
|
|
* Construct a new search.
|
|
*
|
|
* @param \Illuminate\Database\Query\Expression|string $jsonSelectorPath
|
|
* @return void
|
|
*/
|
|
public function __construct($jsonSelectorPath)
|
|
{
|
|
$this->jsonSelectorPath = $jsonSelectorPath;
|
|
}
|
|
|
|
/**
|
|
* Apply the search.
|
|
*
|
|
* @param \Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Eloquent\Relations\Relation $query
|
|
* @param string $search
|
|
* @param string $connectionType
|
|
* @param string $whereOperator
|
|
* @return \Illuminate\Database\Eloquent\Builder
|
|
*/
|
|
public function __invoke($query, $search, string $connectionType, string $whereOperator = 'orWhere')
|
|
{
|
|
$path = $query->getGrammar()->wrap($this->jsonSelectorPath);
|
|
$likeOperator = $connectionType == 'pgsql' ? 'ilike' : 'like';
|
|
|
|
if (in_array($connectionType, ['pgsql', 'sqlite'])) {
|
|
return $query->{$whereOperator}($this->jsonSelectorPath, $likeOperator, "%{$search}%");
|
|
}
|
|
|
|
return $query->{$whereOperator.'Raw'}("lower({$path}) {$likeOperator} ?", ['%'.Str::lower($search).'%']);
|
|
}
|
|
}
|