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 |
Rating system for laravel 5
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
];
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
.
<?php
namespace App;
use Ghanem\Rating\Traits\Ratingable as Rating;
use Illuminate\Database\Eloquent\Model;
class Post extends Model implements Rating
{
use Rating;
}
$user = User::first();
$post = Post::first();
$rating = $post->rating([
'rating' => 5
], $user);
dd($rating);
$user = User::first();
$post = Post::first();
$rating = $post->ratingUnique([
'rating' => 5
], $user);
dd($rating);
$rating = $post->updateRating(1, [
'rating' => 3
]);
$post->deleteRating(1);
$post->sumRating
// $post->sumRating() also works for this.
$post->avgRating
// $post->avgRating() also works for this.
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.
$post->countPositive
// $post->countPositive() also works for this.
$post->countNegative
// $post->countNegative() also works for this.