Feat: Implement user filtering in Audit Logs page
This commit is contained in:
@@ -16,20 +16,39 @@ export const dynamic = 'force-dynamic'
|
|||||||
|
|
||||||
import { createAdminClient } from "@/lib/supabase/admin"
|
import { createAdminClient } from "@/lib/supabase/admin"
|
||||||
|
|
||||||
export default async function AuditLogsPage() {
|
import { UserFilter } from "./user-filter"
|
||||||
|
|
||||||
|
export default async function AuditLogsPage({
|
||||||
|
searchParams,
|
||||||
|
}: {
|
||||||
|
searchParams: Promise<{ userId?: string }>
|
||||||
|
}) {
|
||||||
|
const { userId } = await searchParams
|
||||||
const supabase = await createClient()
|
const supabase = await createClient()
|
||||||
const supabaseAdmin = await createAdminClient()
|
const supabaseAdmin = await createAdminClient()
|
||||||
|
|
||||||
// Use admin client if available to bypass RLS for debugging
|
// Use admin client if available to bypass RLS for debugging
|
||||||
const client = supabaseAdmin || supabase
|
const client = supabaseAdmin || supabase
|
||||||
|
|
||||||
|
// Fetch all users for filter
|
||||||
|
const { data: allUsers } = await client
|
||||||
|
.from('profiles')
|
||||||
|
.select('id, full_name')
|
||||||
|
.order('full_name')
|
||||||
|
|
||||||
// Fetch logs without join first to avoid FK issues
|
// Fetch logs without join first to avoid FK issues
|
||||||
const { data: logs, error } = await client
|
let query = client
|
||||||
.from('audit_logs')
|
.from('audit_logs')
|
||||||
.select('*')
|
.select('*')
|
||||||
.order('created_at', { ascending: false })
|
.order('created_at', { ascending: false })
|
||||||
.limit(50)
|
.limit(50)
|
||||||
|
|
||||||
|
if (userId) {
|
||||||
|
query = query.eq('user_id', userId)
|
||||||
|
}
|
||||||
|
|
||||||
|
const { data: logs, error } = await query
|
||||||
|
|
||||||
if (error) {
|
if (error) {
|
||||||
console.error("AuditLogsPage: Error fetching logs:", error)
|
console.error("AuditLogsPage: Error fetching logs:", error)
|
||||||
}
|
}
|
||||||
@@ -80,10 +99,13 @@ export default async function AuditLogsPage() {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="space-y-6">
|
<div className="space-y-6">
|
||||||
|
<div className="flex items-center justify-between">
|
||||||
<div>
|
<div>
|
||||||
<h2 className="text-3xl font-bold tracking-tight">İşlem Geçmişi</h2>
|
<h2 className="text-3xl font-bold tracking-tight">İşlem Geçmişi</h2>
|
||||||
<p className="text-muted-foreground">Sistem üzerindeki son aktiviteler.</p>
|
<p className="text-muted-foreground">Sistem üzerindeki son aktiviteler.</p>
|
||||||
</div>
|
</div>
|
||||||
|
<UserFilter users={allUsers || []} />
|
||||||
|
</div>
|
||||||
|
|
||||||
<Card>
|
<Card>
|
||||||
<CardHeader>
|
<CardHeader>
|
||||||
|
|||||||
48
src/app/dashboard/settings/logs/user-filter.tsx
Normal file
48
src/app/dashboard/settings/logs/user-filter.tsx
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
'use client'
|
||||||
|
|
||||||
|
import {
|
||||||
|
Select,
|
||||||
|
SelectContent,
|
||||||
|
SelectItem,
|
||||||
|
SelectTrigger,
|
||||||
|
SelectValue,
|
||||||
|
} from "@/components/ui/select"
|
||||||
|
import { useRouter, useSearchParams } from "next/navigation"
|
||||||
|
|
||||||
|
interface UserFilterProps {
|
||||||
|
users: { id: string; full_name: string }[]
|
||||||
|
}
|
||||||
|
|
||||||
|
export function UserFilter({ users }: UserFilterProps) {
|
||||||
|
const router = useRouter()
|
||||||
|
const searchParams = useSearchParams()
|
||||||
|
const currentUserId = searchParams.get('userId') || 'all'
|
||||||
|
|
||||||
|
const handleValueChange = (value: string) => {
|
||||||
|
const params = new URLSearchParams(searchParams)
|
||||||
|
if (value === 'all') {
|
||||||
|
params.delete('userId')
|
||||||
|
} else {
|
||||||
|
params.set('userId', value)
|
||||||
|
}
|
||||||
|
router.push(`?${params.toString()}`)
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className="w-[200px]">
|
||||||
|
<Select value={currentUserId} onValueChange={handleValueChange}>
|
||||||
|
<SelectTrigger>
|
||||||
|
<SelectValue placeholder="Kullanıcı Filtrele" />
|
||||||
|
</SelectTrigger>
|
||||||
|
<SelectContent>
|
||||||
|
<SelectItem value="all">Tüm Kullanıcılar</SelectItem>
|
||||||
|
{users.map((user) => (
|
||||||
|
<SelectItem key={user.id} value={user.id}>
|
||||||
|
{user.full_name || 'İsimsiz'}
|
||||||
|
</SelectItem>
|
||||||
|
))}
|
||||||
|
</SelectContent>
|
||||||
|
</Select>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user