Activity Log
CommunityAdd a Filament page that nicely shows your spatie/laravel-activitylog.
filament/
namespace. Review the source and install at your own risk. Found
malware or an unresolved security issue the author won't
address?
Report it
.
Author:
Dennis Koch
Documentation
- Installation
- Filament v4 Upgrade
- Usage
- Listing activities for a subject
- Listing activities caused by a record
- Contributing

This package adds pages to the Filament Admin panel to view the activity log generated by spatie/laravel-activitylog.

#Installation
| Plugin Version | Filament Version | Activitylog | PHP Version |
|---|---|---|---|
| 0.1.x | 2.x | 4.x | > 8.0 |
| 1.x | 3.x | 4.x | > 8.1 |
| 2.x | 4.x, 5.x | 4.x | > 8.1 |
| 3.x | 5.x | 5.x | > 8.4 |
Install via Composer.
Requires PHP 8.1, Filament 4.0 or 5.0, and spatie/laravel-activitylog 4.7 or 5.0
composer require pxlrbt/filament-activity-log
Warning This plugin offers two pages: one listing activities on a subject (use
ListActivitiesBySubject) and one listing activities caused by a record such as a user (useListActivitiesByCauser). You needspatie/laravel-activityloginstalled and configured for it to work. The subject page uses theLogsActivitytrait'sactivitiesAsSubject()relation; the causer page uses theCausesActivitytrait'sactivitiesAsCauser()relation.
#Filament v4 Upgrade
Make sure you have a custom theme, add this line and recompile: @import '../../../../vendor/pxlrbt/filament-activity-log/resources/css/styles.css';
#Usage
Make sure you use a custom theme and the vendor folder for this plugins is published, so that it includes the Tailwind CSS classes.
#Listing activities for a subject

Use ListActivitiesBySubject to show all activities recorded on a record (e.g. every change to an order).
#Setup spatie/laravel-activitylog
Make sure your resource model uses the LogsActivity trait.
<?php
use Spatie\Activitylog\Models\Concerns\LogsActivity;
class Order extends Model
{
use LogsActivity;
}
#Create a ListActivitiesBySubject page
Create the page inside your resource's Pages/ directory. Replace OrderResource with your resource.
<?php
namespace App\Filament\Resources\Orders\Pages;
use pxlrbt\FilamentActivityLog\Pages\ListActivitiesBySubject;
class ListOrderActivities extends ListActivitiesBySubject
{
protected static string $resource = OrderResource::class;
}
Note The legacy class
ListActivitiesis kept as an abstract alias ofListActivitiesBySubject, so existing subclasses continue to work.
#Register the page
Add the page to your resource's getPages() method.
public static function getPages(): array
{
return [
'index' => Pages\ListOrders::route('/'),
'create' => Pages\CreateOrder::route('/create'),
'activities' => Pages\ListOrderActivities::route('/{record}/activities'),
'edit' => Pages\EditOrder::route('/{record}/edit'),
];
}
#Listing activities caused by a record
Use ListActivitiesByCauser to show all activities a record (typically a user) has caused across every subject. Each row links to the affected subject's resource when one is registered.
#Setup spatie/laravel-activitylog
Make sure your user model uses the CausesActivity trait.
<?php
use Spatie\Activitylog\Models\Concerns\CausesActivity;
class User extends Authenticatable implements FilamentUser
{
use CausesActivity;
}
#Create a ListActivitiesByCauser page
Create the page inside your UserResource's Pages/ directory.
<?php
namespace App\Filament\Resources\Users\Pages;
use pxlrbt\FilamentActivityLog\Pages\ListActivitiesByCauser;
class ListUserActivities extends ListActivitiesByCauser
{
protected static string $resource = UserResource::class;
}
See https://spatie.be/docs/laravel-activitylog/v5/advanced-usage/logging-model-events for more information on the topic.
#Register the page
Add the page to your resource's getPages() method.
public static function getPages(): array
{
return [
'index' => Pages\ListUsers::route('/'),
'create' => Pages\CreateUser::route('/create'),
'activities' => Pages\ListUserActivities::route('/{record}/activities'),
'edit' => Pages\EditUser::route('/{record}/edit'),
];
}
#Contributing
If you want to contribute to this packages, you may want to test it in a real Filament project:
- Fork this repository to your GitHub account.
- Create a Filament app locally.
- Clone your fork in your Filament app's root directory.
- In the
/filament-activity-logdirectory, create a branch for your fix, e.g.fix/error-message.
Install the packages in your app's composer.json:
"require": {
"pxlrbt/filament-activity-log": "dev-fix/error-message as main-dev",
},
"repositories": [
{
"type": "path",
"url": "filament-activity-log"
}
]
Now, run composer update.
The author
Dennis, a Filament core-team member, is dedicated to delivering high-quality plugins for your Filament projects. He is a freelance full-stack developer who works on several Laravel projects either individually or as part of small teams. In his work, he utilizes both Livewire and Inertia.
From the same author
Spotlight Pro
Browse your Filament Panel with ease. Filament Spotlight Pro adds a Spotlight/Raycast like Command Palette to your Filament Panel.
Author:
Dennis Koch
Spotlight
Quickly navigate your Filament Resources with Spotlight functionality.
Author:
Dennis Koch
Translate Action
Translate your forms content with the click of a button.
Author:
Dennis Koch
Environment Indicator
Never confuse your tabs with different Filament environments again.
Author:
Dennis Koch
Featured Plugins
A selection of plugins curated by the Filament team
Custom Dashboards
Let your users build and share their own dashboards with a drag-and-drop interface. Define your data sources in PHP and let them do the rest.
Filament
Data Lens
Advanced Data Visualization for Laravel Filament - a premium reporting solution enabling custom column creation, sophisticated filtering, and enterprise-grade data insights within admin panels.
Padmission
Custom Fields
Eliminate custom field migrations forever. Let your users create and manage form fields directly in Filament admin panels with 20+ built-in field types, validation, and zero database changes.
Relaticle