zoparga / review-rateable
Rating system for Laravel
1.0.0
2021-01-11 15:59 UTC
This package is auto-updated.
Last update: 2024-11-12 00:36:21 UTC
README
First, pull in the package through Composer.
composer require zoparga/reviewrateable
And then include the service provider within app/config/app.php
. (Skip this step if you are on Laravel 5.5 or above)
'providers' => [ zoparga\ReviewRateable\ReviewRateableServiceProvider::class ];
At last you need to publish and run the migration.
php artisan vendor:publish --provider="zoparga\ReviewRateable\ReviewRateableServiceProvider" && php artisan migrate
Setup a Model
<?php namespace App; use zoparga\ReviewRateable\Contracts\ReviewRateable; use zoparga\ReviewRateable\Traits\ReviewRateable as ReviewRateableTrait; use Illuminate\Database\Eloquent\Model; class Post extends Model implements ReviewRateable { use ReviewRateableTrait; }
Create a rating
$user = User::first(); $post = Post::first(); $rating = $post->rating([ 'title' => 'Some title', 'body' => 'Some body', //optional 'anonymous' => 1, //optional 'rating' => 5, ], $user); dd($rating);
Update a rating
$rating = $post->updateRating(1, [ 'title' => 'new title', 'body' => 'new body', //optional 'anonymous' => 1, //optional 'rating' => 3, ]);
Delete a rating:
$post->deleteRating(1);
Fetch the average rating:
$post->averageRating()
or
$post->averageRating(2) //round to 2 decimal place
Count total rating:
$post->countRating()
Count rating meta (Count and Avg):
$post->ratingMeta()
or
$post->ratingMeta(2) //round to 2 decimal place
Fetch the rating percentage.
This is also how you enforce a maximum rating value.
$post->ratingPercent() $post->ratingPercent(10)); // Ten star rating system // Note: The value passed in is treated as the maximum allowed value. // This defaults to 5 so it can be called without passing a value as well.