AbdullahGhanem / rating by ghanem

Rating syetem for Laravel 5
15,085
86
8
Package Data
Maintainer Username: ghanem
Maintainer Contact: 3bdullah.ghanem@gmail.com (abdullah ghanem)
Package Create Date: 2015-10-24
Package Last Update: 2023-03-10
Language: PHP
License: MIT
Last Refreshed: 2024-11-11 15:01:49
Package Statistics
Total Downloads: 15,085
Monthly Downloads: 4
Daily Downloads: 2
Total Stars: 86
Total Watchers: 8
Total Forks: 36
Total Open Issues: 5

Latest Stable Version License

Total Downloads

Laravel Rating

https://scontent-cai1-1.xx.fbcdn.net/v/t31.0-8/18192521_1536772739688541_5883708562629992092_o.jpg?oh=281577e64a1e326ff1989f047ab21df6&oe=59BAEBCA Rating system for laravel 5

Installation

First, pull in the package through Composer.

composer require ghanem/rating

or add this in your project's composer.json file .

"require": {
  "Ghanem/Rating": "1.*",
}

And then include the service provider within app/config/app.php.

'providers' => [
    Ghanem\Rating\RatingServiceProvider::class
];

Getting started

After the package is correctly installed, you need to generate the migration.

php artisan rating:migration

It will generate the <timestamp>_create_ratings_table.php migration. You may now run it with the artisan migrate command:

php artisan migrate

After the migration, one new table will be present, ratings.

Usage

Setup a Model

<?php

namespace App;

use Ghanem\Rating\Traits\Ratingable as Rating;
use Illuminate\Database\Eloquent\Model;

class Post extends Model implements Rating
{
    use Rating;
}

Create a rating

$user = User::first();
$post = Post::first();

$rating = $post->rating([
    'rating' => 5
], $user);

dd($rating);

Create or update a unique rating

$user = User::first();
$post = Post::first();

$rating = $post->ratingUnique([
    'rating' => 5
], $user);

dd($rating);

Update a rating

$rating = $post->updateRating(1, [
    'rating' => 3
]);

Delete a rating:

$post->deleteRating(1);

fetch the Sum rating:

$post->sumRating

// $post->sumRating() also works for this.

fetch the average rating:

$post->avgRating

// $post->avgRating() also works for this.

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.

Count positive rating:

$post->countPositive

// $post->countPositive() also works for this.

Count negative rating:

$post->countNegative

// $post->countNegative() also works for this.