https://github.com/beyondcode/laravel-comments
Add comments to your Laravel application
https://github.com/beyondcode/laravel-comments
comments laravel
Last synced: about 2 months ago
JSON representation
Add comments to your Laravel application
- Host: GitHub
- URL: https://github.com/beyondcode/laravel-comments
- Owner: beyondcode
- License: mit
- Created: 2018-09-03T11:22:42.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2025-03-02T18:47:48.000Z (4 months ago)
- Last Synced: 2025-05-11T11:13:44.577Z (about 2 months ago)
- Topics: comments, laravel
- Language: PHP
- Homepage: https://beyondco.de
- Size: 40 KB
- Stars: 595
- Watchers: 12
- Forks: 96
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Add comments to your Laravel application
[](https://packagist.org/packages/beyondcode/laravel-comments)
[](https://packagist.org/packages/beyondcode/laravel-comments)Add the ability to associate comments to your Laravel Eloquent models. The comments can be approved and nested.
```php
$post = Post::find(1);$post->comment('This is a comment');
$post->commentAsUser($user, 'This is a comment from someone else');
```## Installation
You can install the package via composer:
```bash
composer require beyondcode/laravel-comments
```The package will automatically register itself.
You can publish the migration with:
```bash
php artisan vendor:publish --provider="BeyondCode\Comments\CommentsServiceProvider" --tag="migrations"
```After the migration has been published you can create the media-table by running the migrations:
```bash
php artisan migrate
```You can publish the config-file with:
```bash
php artisan vendor:publish --provider="BeyondCode\Comments\CommentsServiceProvider" --tag="config"
```## Usage
### Registering Models
To let your models be able to receive comments, add the `HasComments` trait to the model classes.
```php
namespace App\Models;use Illuminate\Database\Eloquent\Model;
use BeyondCode\Comments\Traits\HasComments;class Post extends Model
{
use HasComments;
...
}
```### Creating Comments
To create a comment on your commentable models, you can use the `comment` method. It receives the string of the comment that you want to store.
```php
$post = Post::find(1);$comment = $post->comment('This is a comment from a user.');
```The comment method returns the newly created comment class.
Sometimes you also might want to create comments on behalf of other users. You can do this using the `commentAsUser` method and pass in your user model that should get associated
with this comment:```php
$post = Post::find(1);$comment = $post->commentAsUser($yourUser, 'This is a comment from someone else.');
```### Approving Comments
By default, all comments that you create are not approved - this is just a boolean flag called `is_approved` that you can use in your views/controllers to filter out comments that you might not yet want to display.
To approve a single comment, you may use the `approve` method on the Comment model like this:
```php
$post = Post::find(1);
$comment = $post->comments->first();$comment->approve();
```### Auto Approve Comments
If you want to automatically approve a comment for a specific user (and optionally model) you can let your User model implement the following interface and method:
```php
namespace App\Models;use BeyondCode\Comments\Contracts\Commentator;
use Illuminate\Foundation\Auth\User as Authenticatable;class User extends Authenticatable implements Commentator
{
/**
* Check if a comment for a specific model needs to be approved.
* @param mixed $model
* @return bool
*/
public function needsCommentApproval($model): bool
{
return false;
}}
```The `needsCommentApproval` method received the model instance that you want to add a comment to and you can either return `true` to mark the comment as **not** approved, or return `false` to mark the comment as **approved**.
### Retrieving Comments
The models that use the `HasComments` trait have access to it's comments using the `comments` relation:
```php
$post = Post::find(1);
// Retrieve all comments
$comments = $post->comments;// Retrieve only approved comments
$approved = $post->comments()->approved()->get();```
### Nesting Comments
`BeyondCode\Comments\Comment` itself implements the `HasComments` trait, so you can comment on a comment and therefore nest them:
```php
$comment = BeyondCode\Comments\Comment::first();
$comment->commentAsUser($user, "Hey there!");
```#### Deleting Replies
When you delete a comment, you may optionally want to delete all its nested comments (replies). To optionally enable this feature, set the `delete_replies_along_comments` config property in the `config/comments.php` file to `true`.
### Events
When a new comment is added the `BeyondCode\Comments\Events\CommentAdded` event will be dispatched.
When a comment is deleted the `BeyondCode\Comments\Events\CommentDeleted` event will be dispatched.### Testing
```bash
composer test
```### Changelog
Please see [CHANGELOG](CHANGELOG.md) for more information what has changed recently.
## Contributing
Please see [CONTRIBUTING](CONTRIBUTING.md) for details.
### Security
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
## Credits
- [Marcel Pociot](https://github.com/mpociot)
- [All Contributors](../../contributors)## License
The MIT License (MIT). Please see [License File](LICENSE.md) for more information.