'Star and Half Star Rating in Laravel
I want to display average product ratings in star. The values are displaying good but I want to show half star if the value is in float.
My blade view:
<div class="rating">
  @for($i=0;$i<5;$i++)
    @if($product->ratings->avg('rating') > $i)
      <span class="icon-ratings"><i class="icon-rating icon-rating-x"></i></span>
    @else
      <span class="icon-ratings"><i class="icon-rating icon-rating-o"></i></span>
    @endif
  @endfor
   <div style="float:left">{{$product->ratings->avg('rating')}}</div>
</div>
The average value is showing 4.5. But all the 5 stars are filled with golden color. I want to fill half last star as that is a floating number.
Solution 1:[1]
use floor() function to detect float value like this
.................
@for($i=0;$i<5;$i++)
  <?php
    $thisRating = product->ratings->avg('rating')
    if(floor($thisRating) != $thisRating) {
      $hasHalfVal = 1;
    } else {
      $hasHalfVal = 0;
    }
  ?>
   @if($thisRating > $i && $hasHalfVal == 0)
     <span class="icon-ratings"><i class="icon-rating icon-rating-x"></i></span>
   @else if($thisRating > $i && $hasHalfVal == 1) 
     <span class="icon-ratings"><i class="icon-rating icon-rating-half"></i></span>
   @else
     <span class="icon-ratings"><i class="icon-rating icon-rating-o"></i></span>
   @endif
 .................
    					Solution 2:[2]
You can do that as below. For example in below answer I use font-awesome.
@for ($i = 1; $i <= 5; $i++)
    @if($product->ratings->avg('rating') < $i)
        @if (round($product->ratings->avg('rating')) == $i)
            <li class="list-inline-item me-0 small"><i
                    class="fas fa-star-half-alt text-warning"></i></li>
            @continue
        @endif
        <li class="list-inline-item me-0 small"><i
                class="far fa-star text-warning"></i></li>
        @continue
    @endif
    <li class="list-inline-item me-0 small"><i
            class="fas fa-star text-warning"></i></li>
@endfor
    					Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source | 
|---|---|
| Solution 1 | adam | 
| Solution 2 | Ali Sharifi Neyestani | 
