- 統一採購單篩選列與表單樣式 (移除舊元件、標準化 Input) - 增強操作紀錄功能 (加入篩選、快照、詳細異動比對) - 統一刪除確認視窗與按鈕樣式 - 修復庫存編輯頁面樣式 - 實作採購單品項異動紀錄 - 實作角色分配異動紀錄 - 擴充供應商與倉庫模組紀錄
126 lines
4.3 KiB
PHP
126 lines
4.3 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use Illuminate\Http\Request;
|
|
use Inertia\Inertia;
|
|
use Spatie\Activitylog\Models\Activity;
|
|
|
|
class ActivityLogController extends Controller
|
|
{
|
|
private function getSubjectMap()
|
|
{
|
|
return [
|
|
'App\Models\User' => '使用者',
|
|
'App\Models\Role' => '角色',
|
|
'App\Models\Product' => '商品',
|
|
'App\Models\Vendor' => '廠商',
|
|
'App\Models\Category' => '商品分類',
|
|
'App\Models\Unit' => '單位',
|
|
'App\Models\PurchaseOrder' => '採購單',
|
|
'App\Models\Warehouse' => '倉庫',
|
|
'App\Models\Inventory' => '庫存',
|
|
];
|
|
}
|
|
|
|
public function index(Request $request)
|
|
{
|
|
$perPage = $request->input('per_page', 10);
|
|
$sortBy = $request->input('sort_by', 'created_at');
|
|
$sortOrder = $request->input('sort_order', 'desc');
|
|
|
|
$search = $request->input('search');
|
|
$dateStart = $request->input('date_start');
|
|
$dateEnd = $request->input('date_end');
|
|
$event = $request->input('event');
|
|
$subjectType = $request->input('subject_type');
|
|
$causerId = $request->input('causer_id');
|
|
|
|
$query = Activity::with('causer');
|
|
|
|
if ($search) {
|
|
$query->where(function ($q) use ($search) {
|
|
$q->where('description', 'like', "%{$search}%")
|
|
->orWhere('log_name', 'like', "%{$search}%")
|
|
->orWhere('properties', 'like', "%{$search}%");
|
|
});
|
|
}
|
|
|
|
if ($dateStart) {
|
|
$query->whereDate('created_at', '>=', $dateStart);
|
|
}
|
|
|
|
if ($dateEnd) {
|
|
$query->whereDate('created_at', '<=', $dateEnd);
|
|
}
|
|
|
|
if ($event) {
|
|
$query->where('event', $event);
|
|
}
|
|
|
|
if ($subjectType) {
|
|
$query->where('subject_type', $subjectType);
|
|
}
|
|
|
|
if ($causerId) {
|
|
$query->where('causer_id', $causerId);
|
|
}
|
|
|
|
if ($sortBy === 'created_at') {
|
|
$query->orderBy($sortBy, $sortOrder);
|
|
} else {
|
|
$query->latest();
|
|
}
|
|
|
|
$activities = $query->paginate($perPage)
|
|
->through(function ($activity) {
|
|
$subjectMap = $this->getSubjectMap();
|
|
|
|
$eventMap = [
|
|
'created' => '新增',
|
|
'updated' => '更新',
|
|
'deleted' => '刪除',
|
|
];
|
|
|
|
return [
|
|
'id' => $activity->id,
|
|
'description' => $eventMap[$activity->event] ?? $activity->event,
|
|
'subject_type' => $subjectMap[$activity->subject_type] ?? class_basename($activity->subject_type),
|
|
'event' => $activity->event,
|
|
'causer' => $activity->causer ? $activity->causer->name : 'System',
|
|
'created_at' => $activity->created_at->format('Y-m-d H:i:s'),
|
|
'properties' => $activity->properties,
|
|
];
|
|
});
|
|
|
|
// Prepare subject types for frontend filter
|
|
$subjectTypes = collect($this->getSubjectMap())->map(function ($label, $value) {
|
|
return ['label' => $label, 'value' => $value];
|
|
})->values();
|
|
|
|
// Get users for causer filter
|
|
$users = \App\Models\User::select('id', 'name')->orderBy('name')->get()
|
|
->map(function ($user) {
|
|
return ['label' => $user->name, 'value' => (string) $user->id];
|
|
});
|
|
|
|
return Inertia::render('Admin/ActivityLog/Index', [
|
|
'activities' => $activities,
|
|
'filters' => [
|
|
'per_page' => $request->input('per_page', '10'),
|
|
'sort_by' => $request->input('sort_by'),
|
|
'sort_order' => $request->input('sort_order'),
|
|
'search' => $request->input('search'),
|
|
'date_start' => $request->input('date_start'),
|
|
'date_end' => $request->input('date_end'),
|
|
'event' => $request->input('event'),
|
|
'subject_type' => $request->input('subject_type'),
|
|
'causer_id' => $request->input('causer_id'),
|
|
],
|
|
'subject_types' => $subjectTypes,
|
|
'users' => $users,
|
|
]);
|
|
}
|
|
}
|