����JFIF��x�x����'
| Server IP : 78.140.185.180  /  Your IP : 216.73.216.143 Web Server : LiteSpeed System : Linux cpanel13.v.fozzy.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64 User : builderbox ( 1072) PHP Version : 7.3.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/builderbox/./././././www/common/Database/Datasource/Filters/ | 
| Upload File : | 
<?php
namespace Common\Database\Datasource\Filters;
use Common\Database\Datasource\Filters\Traits\NormalizesFiltersForFulltextEngines;
class MeilisearchFilter extends BaseFilter
{
    use NormalizesFiltersForFulltextEngines;
    public function apply()
    {
        $modelKeys = $this->query
            ->getModel()
            ->search($this->searchTerm, function (
                $driver,
                string $query,
                array $options
            ) {
                $filters = $this->coerceFilterValuesToString();
                $filters = implode(' AND ', $filters);
                if ($filters) {
                    $options['filters'] = $filters;
                }
                return $driver->search($query, $options);
            })
            ->keys()
            ->toArray();
        $table = $this->query->getModel()->getTable();
        $this->query->whereIn("$table.id", $modelKeys);
        return $this->query;
    }
    private function coerceFilterValuesToString(): array
    {
        return array_map(function ($filter) {
            $filter['value'] = $this->normalizeFilterValue($filter);
            $filter['operator'] = $this->normalizeFilterOperator($filter);
            return implode('', $filter);
        }, $this->filters->getAll());
    }
}