zoparga/review-rateable

Rating system for Laravel

1.0.0 2021-01-11 15:59 UTC

This package is auto-updated.

Last update: 2024-10-12 00:28:53 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.