Files
autocrm/app/Models/Concerns/Auditable.php
T
Vasyka edcdba9d53 Stage 3 — WO photos + ETA + QR + public tracking page
- HasMedia (Spatie) on WorkOrder with `photos` collection
- eta_at + tracking_token columns; token auto-generated on create
- Public /t/{token} page — tenant-scoped via subdomain, white-label themed
- QR code SVG via chillerlan/php-qrcode (inline modal + download)
- Filament: SpatieMediaLibraryFileUpload + ETA picker + tracking section
- EditWorkOrder header action "Link client (QR)" modal
- Fix: Auditable::dontSubmitEmptyLogs() → dontLogEmptyChanges() (removed in activitylog)
- Tests: TrackingPageTest (4 pass) covering token gen + cross-tenant isolation

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-27 19:21:23 +00:00

49 lines
1.5 KiB
PHP

<?php
namespace App\Models\Concerns;
use App\Tenancy\TenantManager;
use Spatie\Activitylog\Models\Activity;
use Spatie\Activitylog\Models\Concerns\LogsActivity;
use Spatie\Activitylog\Support\LogOptions;
/**
* Adds Spatie ActivityLog with sensible defaults + auto-fills company_id
* on every activity row so the audit trail stays tenant-scoped.
*
* Use on tenant models you want audited (Client, Vehicle, WorkOrder, ...).
*/
trait Auditable
{
use LogsActivity;
public function getActivitylogOptions(): LogOptions
{
return LogOptions::defaults()
->logFillable()
->logOnlyDirty()
->dontLogEmptyChanges()
->setDescriptionForEvent(fn (string $event) => match ($event) {
'created' => 'creat',
'updated' => 'modificat',
'deleted' => 'șters',
'restored' => 'restaurat',
default => $event,
});
}
public function tapActivity(Activity $activity, string $eventName): void
{
// Auto-attach company_id if available.
$tenantId = app(TenantManager::class)->currentId() ?: ($this->company_id ?? null);
if ($tenantId) {
$activity->company_id = $tenantId;
}
// Auto-attach causer if logged in.
if (auth()->check() && ! $activity->causer_id) {
$activity->causer_type = get_class(auth()->user());
$activity->causer_id = auth()->id();
}
}
}