In this tutorial, we will learn about filtering products by brands.

Let's explore how to filter products by brands.

Displaying All Brands on the Shop Page

First, let's display all brands on this shop page.

For that, go to the ShopController and inside the index method, fetch all brands and return these brands to the view as follows:


public function index(Request $request)
{

$brands = Brand::orderBy('name','ASC')->get();
return view('shop',['products'=>$products,'page'=>$page,'size'=>$size, 'order'=>$order,'products'=>$products, 'brands'=>$brands]);
}

Displaying Brands in the Shop Blade Template

Now, go to the shop.blade.php file and display the brands:


<div class="accordion-item category-rating">
<h2 class="accordion-header" id="headingTwo">
<button class="accordion-button" type="button" data-bs-toggle="collapse"
data-bs-target="#collapseTwo">
Brand
</button>
</h2>
<div id="collapseTwo" class="accordion-collapse collapse show"
data-bs-parent="#accordionExample">
<div class="accordion-body category-scroll">
<ul class="category-list">
@foreach ($brands as $brand)
<li>
<div class="form-check ps-0 custome-form-check">
<input class="checkbox_animated check-it" id="br{{$brand->id}}" name="brands" @if(in_array($brand->id,explode(',',$q_brands))) checked="checked" @endif value="{{$brand->id}}" type="checkbox" onchange="filterProductsByBrand(this)">
<label class="form-check-label">{{$brand->name}}</label>
<p class="font-light">({{$brand->products->count()}})</p>
</div>
</li>
@endforeach

</ul>
</div>
</div>
</div>

Adding a Hidden Field to the Filter Form

Inside the filter form, add a hidden field for brands:


<input type="hidden" id="brands" name="brands" value="{{$q_brands}}" />

Handling the Change Event

Now, write code to handle the change event:


<script>
$(function(){
$("#pagesize").on("change",function(){
$("#size").val($("#pagesize option:selected").val());
$("#frmFilter").submit();
});
});
</script>

Creating a JavaScript Function for Filtering Brands

Now, create a JavaScript function for filtering brands:


function filterProductsByBrand(brand){
var brands = "";
$("input[name='brands']:checked").each(function(){
if(brands=="")
{
brands += this.value;
}
else{
brands += "," + this.value;
}
});
$("#brands").val(brands);
$("#frmFilter").submit();
}

Updating the Shop Controller for Filtering

Now, go to the Shop controller and add a where clause for filtering:


public function index(Request $request)
{
$brands = Brand::orderBy('name','ASC')->get();
$q_brands = $request->query("brands");
$products = Product::where(function($query) use($q_brands){
$query->whereIn('brand_id',explode(',',$q_brands))->orWhereRaw("'".$q_brands."'=''");
})
->orderBy('created_at','DESC')->orderBy($o_column,$o_order)->paginate($size);
return view('shop',['products'=>$products,'page'=>$page,'size'=>$size,'order'=>$order,'brands'=>$brands,'q_brands'=>$q_brands,'categories'=>$categories,'q_categories'=>$q_categories]);
}

Testing the Filtering Functionality

Now, let's check. Go to the shop page, and you can see all the brands.

Now, let's check on any one brand, and you can see the products from this brand only.

Now, let's display the selected brand.

So, in this way, you can filter products by brand.