betalabs / laravel-comment
Just another comment system for laravel projects.
Requires
- php: ^7.1.3
- illuminate/database: ~5.5.0|~5.6.0|~5.7.0|~5.8.0
Requires (Dev)
- fzaninotto/faker: ^1.8
- orchestra/testbench: ~3.5.0|~3.6.0|~3.7.0|~3.8.0
- phpunit/phpunit: ^7.4
- scrutinizer/ocular: ^1.5
README
Just another comment system for laravel projects.
Version Compatibility
Install
Via Composer
$ composer require actuallymab/laravel-comment
Laravel 5.5 uses Package Auto-Discovery, so doesn't require you to manually add the ServiceProvider.
If you don't use auto-discovery, or using Laravel version < 5.5 Add service provider to your app.php file
\Actuallymab\LaravelComment\LaravelCommentServiceProvider::class
Publish & Migrate comments table.
$ php artisan vendor:publish $ php artisan migrate
Add CanComment
trait to your User model.
use Actuallymab\LaravelComment\CanComment;
Add Commentable
trait to your commentable model(s).
use Actuallymab\LaravelComment\Commentable;
If you want to have your own Comment Model create a new one and extend my Comment model.
class Comment extends Actuallymab\LaravelComment\Comment { ... }
Comment package comes with several modes.
1- If you want to Users can rate your model(s) with comment set canBeRated
to true in your Commentable
model.
class Product extends Model { use Commentable; protected $canBeRated = true; ... }
2- If you want to approve comments for your commentable models, you must set mustBeApproved
to true in your Commentable
model.
class Product extends Model { use Commentable; protected $mustBeApproved = true; ... }
3- You don't want to approve comments for all users (think this as you really want to approve your own comments?). So add your User
model an isAdmin
method and return it true if user is admin.
class User extends Model { use CanComment; protected $fillable = [ 'isAdmin', .... ]; public function isAdmin() { return $this->isAdmin; } ... }
Usage
$user = App\User::find(1); $product = App\Product::find(1); // $user->comment(Commentable $model, $comment = '', $rate = 0); $user->comment($product, 'Lorem ipsum ..', 3); // approve it -- if you are admin or you don't use mustBeApproved option, it is not necessary $product->comments[0]->approve(); // get avg rating -- it calculates approved average rate. $product->averageRate(); // get total comment count -- it calculates approved comments count. $product->totalCommentCount();
Change log
Please see CHANGELOG for more information what has changed recently.
Testing
$ composer test
Contributing
Please see CONTRIBUTING and CONDUCT for details.
Security
If you discover any security related issues, please email mehmet.aydin.bahadir@gmail.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.