Review Rateable system for laravel 5. You can rate your models by:
- Overall Rating
- Customer Service Rating
- Quality Rating
- Friendly Rating
- Price Rating
You can also set whether the model being rated is recommended.
First, pull in the package through Composer.
composer require codebyray/laravel-review-rateable
And then include the service provider within app/config/app.php
. Note: If you are running Laravel 5.5+ this will be auto loaded for you.
'providers' => [
Codebyray\ReviewRateable\ReviewRateableServiceProvider::class
];
At last you need to publish and run the migration.
php artisan vendor:publish --provider="Codebyray\ReviewRateable\ReviewRateableServiceProvider" --tag="migrations"
Run the migration
php artisan migrate
<?php
namespace App;
use Codebyray\ReviewRateable\Contracts\ReviewRateable;
use Codebyray\ReviewRateable\Traits\ReviewRateable as ReviewRateableTrait;
use Illuminate\Database\Eloquent\Model;
class Post extends Model implements ReviewRateable
{
use ReviewRateableTrait;
}
When creating a rating you can specify whether the rating is approved or not by adding approved to the array. This is optional and if left out the default is not approved to allow for review before posting.
$user = User::first();
$post = Post::first();
$rating = $post->rating([
title' => 'This is a test title',
'body' => 'And we will add some shit here',
'customer_service_rating' => 5,
'quality_rating' => 5,
'friendly_rating' => 5,
'price_rating' => 5,
'rating' => 5,
'recommend' => 'Yes',
'approved' => true, // This is optional and defaults to false
], $user);
dd($rating);
$rating = $post->updateRating(1, [
'title' => 'new title',
'body' => 'new body',
'customer_service_rating' => 1,
'quality_rating' => 1,
'friendly_rating' => 3,
'price_rating' => 4,
'rating' => 4,
'recommend' => 'No',
'approved' => true, // This is optional and defaults to false
]);
$rating = $post->updateRating(1, ['approved' => true]);
$post->deleteRating(1);
// Get not approved ratings
$ratings = $post->getApprovedRatings($post->id, 'desc');
// Get not approved ratings
$ratings = $post->getNotApprovedRatings($post->id, 'desc');
// Get all ratings whether approved or not
$ratings = $post->getAllRatings($post->id, 'desc');
// Get Overall Average Rating
$post->averageRating()
// Get Customer Service Average Rating
$post->averageCustomerServiceRating()
// Get Quality Average Rating
$post->averageQualityRating()
// Get Friendly Average Rating
$post->averageFriendlyRating()
// Get Price Average Rating
$post->averagePriceRating()
or
$post->averageRating(2) //round to 2 decimal place
$post = Post::first();
$ratings = $post->getAllRatings($post->id);
$post->countRating()
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.
This is a fork from Trexology's - Original Code - laravel-reviewRateable .
Please note that this code is not used in the original and is not maintained.