Um, not sure you understand. I have a list of possible filters and their query modifications. When a request comes in, I run the queries related to filters present. See
<?php
class ProductSearch {
public $builder;
private $smartBuild;
function __construct( Builder $builder) {
$this->builder = $builder;
}
public function applyFilterToQuery(array $filters) {
$pollutants = ['subcategory', 'subcategory2', 'category'];
$this->smartBuild = empty(array_diff( array_keys($filters), $pollutants)); // [ui=>9, mm=>4], [mm]
foreach ($filters as $filterName => $value) {
// dd($filters, $filterName );
if (method_exists($this, $filterName) && !empty($value) )
$this->$filterName( $value);
}
return $this;
}
public function location( $value) {
$this->builder = $this->builder
->whereHas('store2', function($store) use ($value) {
$store->where('state', $value);
});
}
public function subcategory( $value) {
$name = Subcategories::where('id', $value)->pluck('name');
$this->builder = $this->builder->where('subcat_id', $value);
if ($name->isNotEmpty() && $this->smartBuild) {
$names = preg_split('/\W\s+/', $name[0]);
if (!$names) $names = $name;
foreach ($names as $value)
$this->builder = $this->builder->orWhere('name', 'like', "%$value%");
}
}
}
You may observe from the above that making a request for categories searches products matching the category name. However, on attempting to combine that alternate match with legitimate AND queries (in location for instance, the result tends to include matching locations OR matching names. The desired result is ((matching name OR matching category) AND matching location)
I also considered fetching the queries (ANDs and ORs) separately and filtering non unique values off but I'm paginating query results so it's probably gonna turn out messy