parallax / filament-comments
Add comments to your Filament Resources.
Installs: 46 519
Dependents: 1
Suggesters: 0
Security: 0
Stars: 92
Watchers: 5
Forks: 31
Open Issues: 16
Requires
- php: ^8.1
- filament/filament: ^3.0
- illuminate/contracts: ^10.0 | ^11.0
- spatie/laravel-package-tools: ^1.15.0
README
Add comments to your Filament Resources.
Installation
Install the package via composer:
composer require parallax/filament-comments
Publish and run the migrations:
php artisan vendor:publish --tag="filament-comments-migrations"
php artisan migrate
You can publish the config file with:
php artisan vendor:publish --tag="filament-comments-config"
You can publish the language files with:
php artisan vendor:publish --tag="filament-comments-translations"
Optionally, you can publish the views using
php artisan vendor:publish --tag="filament-comments-views"
Quickstart
1. Add model trait
First open the eloquent model you wish to add Filament Comments to.
namespace App\Models; use Parallax\FilamentComments\Models\Traits\HasFilamentComments; class Product extends Model { use HasFilamentComments; }
2. Add comments to Filament Resource
There are 3 ways of using this plugin in your Filament Resources:
1. Page actions
Open the page where you want the comments action to appear, this will most likely be the ViewResource
page.
Add the CommentsAction
to the getHeaderActions()
method.
<?php namespace App\Filament\Resources\ProductResource\Pages; use Parallax\FilamentComments\Actions\CommentsAction; class ViewProduct extends ViewRecord { protected function getHeaderActions(): array { return [ CommentsAction::make(), ]; } }
You may customise the page action as you would any other action.
2. Table actions
Open the resource where you want the comments table action to appear.
Add the CommentsAction
to the $table->actions()
method.
<?php namespace App\Filament\Resources; use Parallax\FilamentComments\Tables\Actions\CommentsAction; class ProductResource extends Resource { public static function table(Table $table): Table { return $table ->actions([ CommentsAction::make(), ]); } }
You may customise the table action as you would any other action.
3. Infolist entry
It's also possible to use the comments component within your infolist.
Add the CommentsEntry
to the $infolist->schema()
method.
<?php namespace App\Filament\Resources; use Parallax\FilamentComments\Infolists\Components\CommentsEntry; class ProductResource extends Resource { public static function infolist(Infolist $infolist): Infolist { return $infolist ->schema([ CommentsEntry::make('filament_comments'), ]); } }
Please note that this cannot be used in combination with a comments action on the same page.
Authorisation
By default, all users can view & create comments as well as only delete their own comments.
If you would like to change this behaviour you can create your own eloquent model policy for the Parallax\FilamentComments\Models\FilamentComment
model.
You should define the policy class in the filament-comments
config file.
return [ 'model_policy' => \Parallax\FilamentComments\Policies\FilamentCommentPolicy::class, ];
Pruning deleted comments
Comment records are set to be pruned after 30 days of being soft-deleted by default. You may change this value in the config file:
return [ 'prune_after_days' => 30, ];
After configuring the model, you should schedule the model:prune
Artisan command in your application's Kernel
class. Don't forget to explicitly mention the FilamentComment
class. You are free to choose the appropriate interval at which this command should be run:
namespace App\Console; use Illuminate\Foundation\Console\Kernel as ConsoleKernel; use Parallax\FilamentComments\Models\FilamentComment; class Kernel extends ConsoleKernel { protected function schedule(Schedule $schedule) { $schedule->command('model:prune', [ '--model' => [FilamentComment::class], ])->daily(); // This will not work, as models in a package are not used by default // $schedule->command('model:prune')->daily(); } }
Changelog
Please see CHANGELOG for more information on what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.