Welcome back to the Laravel E-Commerce Tutorial. In this video, we will learn about product sorting and viewing products per page on the shop page.
Step 1: Create Variables for Size and Order
First, go to the ShopController and inside the index method, pass the Request $request. Create a variable for size and get the size from the query string:
public function index(Request $request)
{
$size = $request->query('size')?$request->query('size'):12;
$products = Product::orderBy("created_at","DESC")->paginate($size);
$categories = Category::orderBy("name","ASC")->get();
$brands = Brand::orderBy("name","ASC")->get();
return view('shop',compact("products","size"));
}
Step 2: Update the Shop View
Go to the shop.blade.php file and find the page size select control. Make changes as follows:
<select class="shop-acs__select form-select w-auto border-0 py-0 order-1 order-md-0" style="margin-right:20px;" aria-label="Page Size" id="pagesize" name="pagesize">
<option value="12" {{$size=='12'? 'selected':''}}>Show</option>
<option value="24" {{$size=='24'? 'selected':''}}>24</option>
<option value="48" {{$size=='48'? 'selected':''}}>48</option>
<option value="102" {{$size=='102'? 'selected':''}}>102</option>
</select>
Step 3: Update the ShopController
Go to the ShopController and inside the index method, remove the fixed page size and add the $size variable. Also, return the size to the view as follows:
public function index(Request $request)
{
$size = $request->query('size')?$request->query('size'):12;
$products = Product::orderBy("created_at","DESC")->paginate($size);
$categories = Category::orderBy("name","ASC")->get();
$brands = Brand::orderBy("name","ASC")->get();
return view('shop',compact("products","size"));
}
Step 4: Add a Form for Filtering
Add a form just before the closing content section directive as follows:
Step 5: Add Script for Handling Page Size Change
Add the push directive and add the name scripts:
@push('scripts')
<script>
$("#pagesize").on("change",function(){
$("#size").val($("#pagesize option:selected").val());
$("#frmFilter").submit();
});
</script>
@endpush
Step 6: Create Variables for Order
Now, let's make the sorting dropdown working. Go to the ShopController and create a variable for order:
$order = $request->query('order');
If the query string order has no value, set the default value to the order variable. Then, create two more variables: one for the storing column name and another for the order, either ascending or descending. Also, return this $order variable to the shop view as follows:
public function index(Request $request)
{
$size = $request->query('size')?$request->query('size'):12;
$sorting = $request->query('sorting')?$request->query('sorting'):'default';
if($sorting=='date')
{
$products = Product::orderBy('created_at','DESC')->paginate($size);
}
else if($sorting=="price")
{
$products = Product::orderBy('regular_price','ASC')->paginate($size);
}
else if($sorting=="price-desc")
{
$products = Product::orderBy('regular_price','DESC')->paginate($size);
}
else{
$products = Product::paginate($size);
}
$categories = Category::orderBy("name","ASC")->get();
$brands = Brand::orderBy("name","ASC")->get();
return view('shop',compact("products","size","sorting"));
}
Step 7: Update the Shop View for Sorting
Go to the shop.blade.php file and inside the sorting dropdown:
<select class="shop-acs__select form-select w-auto border-0 py-0 order-1 order-md-0" aria-label="Sort Items" id="sorting" name="sorting">
<option value="default" {{$sorting=='default'? 'selected':''}}>Default Sorting</option>
<option value="date" {{$sorting=='date'? 'selected':''}}>Sort by newness</option>
<option value="price"{{$sorting=='price'? 'selected':''}}>Sort by price: low to high</option>
<option value="price-desc" {{$sorting=='price-desc'? 'selected':''}}>Sort by price: high to low</option>
</select>
Step 8: Add Hidden Field for Order
Inside the filter form, add one more hidden field:
<input type="hidden" id="order" name="order" value="{{$order}}" />
Step 9: Add JavaScript Code for Handling Order Change
Inside the script, add the JavaScript code for handling the change event of the order by select control:
$("#orderby").on("change",function(){
$("#order").val($("#orderby option:selected").val());
$("#frmFilter").submit();
});
Final Step: Check the Sorting
Now, let's check the sorting. Change the value of the select control. Let's select "Sort by newness". You can see that the products are sorted by creation date. Now, if you select "Sort by price low to high", you can see that the products are sorted according to their price in low to high order. And now, select "Sort by price high to low". You can see that the products are sorted in high to low price order.
So, in this way, you can make product sorting and products per page working on the shop page. So, in this way, you can create a layout and implement the HTML template.
That's all about product sorting and products per page for the E-Commerce project.