eslamfaroug / laravel_comments
Using this package, you can create comments and associate them with Eloquent models.
Requires
- php: ^8.1
- erusev/parsedown: ^1.7
- illuminate/database: ^10.17
- illuminate/http: ^10.17
- illuminate/pagination: ^10.17
- illuminate/queue: ^10.17
- illuminate/routing: ^10.17
- illuminate/support: ^10.17
- spatie/laravel-honeypot: ^4.3
README
LaravelComments is a Laravel package. With it you can easily implement native comments for your application.
Overview
This package can be used to comment on any model you have in your application.
All comments are stored in a single table with a polymorphic relation for content and a polymorphic relation for the user who posted the comment.
Features
- View comments
- Create comments
- Delete comments
- Edit comments
- Reply to comments
- Authorization rules
- Support localization
- Dispatch events
- Route, Controller, Comment, Migration & View customizations
- Support for non-integer IDs
- Support for multiple User models
- Solved N+1 query problem
- Comment approval (opt-in)
- Guest commenting (opt-in)
- Pagination (opt-in)
- Soft deletes (opt-in)
- Works with custom ID columns
- Optionally load package migrations [NEW]
- Configure maximum indentation level [NEW]
Screenshots
Here are a few screenshots.
No comments & guest:
No comments & logged in:
One comment:
One comment edit form:
Two comments from different users:
Tutorials & articles
I plan to expand this chapter with more tutorials and articles. If you write something about this package let me know, so that I can update this chapter.
Screencasts:
- Adding comments to your Laravel application by Andre Madarang.
Installation
From the command line:
composer require eslamfaroug/laravel_comments
Publish Config & configure (optional)
Publish files :
php artisan vendor:publish --provider="EslamFaroug\LaravelComments\ServiceProvider"
Run migrations
We need to create the table for comments.
php artisan migrate
Add Commenter trait to your User model
Add the Commenter
trait to your User model so that you can retrieve the comments for a user:
use EslamFaroug\LaravelComments\Commenter; class User extends Authenticatable { use Notifiable, Commenter; }
Add Commentable trait to models
Add the Commentable
trait to the model for which you want to enable comments for:
use EslamFaroug\LaravelComments\Commentable; class Product extends Model { use Commentable; }
Usage
In the view where you want to display comments, place this code and modify it:
@comments(['model' => $book])
In the example above we are setting the commentable_type
to the class of the book. We are also passing the commentable_id
the id
of the book so that we know to which book the comments relate to. Behind the scenes, the package detects the currently logged in user if any.
If you open the page containing the view where you have placed the above code, you should see a working comments form.
View only approved comments
To view only approved comments, use this code:
@comments([
'model' => $book,
'approved' => true
])
Paginate comments
Pagination paginates by top level comments only, meaning that if you specify the number of comments per page to be 1, and that one comment has 100 replies, it will display that one comment and all of its replies.
It was not possible to do it any other way, because if I paginate by all comments (parent and child) you will end up with blank pages since the comments components loops parent comments first and then uses recursion for replies.
To use pagination, use this code:
@comments([
'model' => $user,
'perPage' => 2
])
Replace 2
with any number you want.
Configure maximum indentation level
By default the replies go up to level three. After that they are "mashed" at that level.
- 0
- 1
- 2
- 3
You can configure the maximum indentation level like so:
@comments([
'model' => $user,
'maxIndentationLevel' => 1
])
Events
This package fires events to let you know when things happen.
EslamFaroug\LaravelComments\Events\CommentCreated
EslamFaroug\LaravelComments\Events\CommentUpdated
EslamFaroug\LaravelComments\Events\CommentDeleted
REST API
To change the controller or the routes, see the config.
Route::post('comments', '\EslamFaroug\LaravelComments\CommentController@store')->name('comments.store');
Route::delete('comments/{comment}', '\EslamFaroug\LaravelComments\CommentController@destroy')->name('comments.destroy');
Route::put('comments/{comment}', '\EslamFaroug\LaravelComments\CommentController@update')->name('comments.update');
Route::post('comments/{comment}', '\EslamFaroug\LaravelComments\CommentController@reply')->name('comments.reply');
POST /comments
Request data:
'commentable_type' => 'required|string',
'commentable_id' => 'required|string|min:1',
'message' => 'required|string'
PUT /comments/{comment}
- {comment} - Comment ID.
Request data:
'message' => 'required|string'
POST /comments/{comment}
- {comment} - Comment ID.
Request data:
'message' => 'required|string'
Upgrading from older versions (troubleshoot)
Before creating an issue, read this.
Sponsors & Backers
I would like to extend my thanks to the following sponsors & backers for funding my open-source journey. If you are interested in becoming a sponsor or backer, please visit the Backers page.
Contributing
Thank you for considering contributing to LaravelComments! The contribution guide can be found Here.
Code of Conduct
In order to ensure that the open-source community is welcoming to all, please review and abide by the Code of Conduct.
License
LaravelComments is open-source software licensed under the MIT license.