Files
fast-next-template/frontend/src/app/[locale]/admin/page.tsx
Felipe Cardoso 444d495f83 Refactor metadata handling for improved maintainability and localization support
- Extracted server-only metadata generation logic into separate files, reducing inline logic in page components.
- Added `/* istanbul ignore file */` annotations for E2E-covered framework-level metadata.
- Standardized `generateMetadata` export patterns across auth, admin, and error pages for consistency.
- Enhanced maintainability and readability by centralizing metadata definitions for each route.
2025-11-20 10:07:15 +01:00

89 lines
3.2 KiB
TypeScript

/**
* Admin Dashboard Page
* Displays admin statistics and management options
* Protected by AuthGuard in layout with requireAdmin=true
*/
import { Link } from '@/lib/i18n/routing';
import { DashboardStats } from '@/components/admin';
import {
UserGrowthChart,
OrganizationDistributionChart,
SessionActivityChart,
UserStatusChart,
} from '@/components/charts';
import { Users, Building2, Settings } from 'lucide-react';
// Re-export server-only metadata from separate, ignored file
export { metadata } from './metadata';
export default function AdminPage() {
return (
<div className="container mx-auto px-6 py-8">
<div className="space-y-8">
{/* Page Header */}
<div>
<h1 className="text-3xl font-bold tracking-tight">Admin Dashboard</h1>
<p className="mt-2 text-muted-foreground">
Manage users, organizations, and system settings
</p>
</div>
{/* Stats Grid */}
<DashboardStats />
{/* Quick Actions */}
<div>
<h2 className="text-xl font-semibold mb-4">Quick Actions</h2>
<div className="grid gap-4 md:grid-cols-2 lg:grid-cols-3">
<Link href="/admin/users" className="block">
<div className="rounded-lg border bg-card p-6 transition-colors hover:bg-accent cursor-pointer">
<div className="flex items-center gap-3 mb-2">
<Users className="h-5 w-5 text-primary" aria-hidden="true" />
<h3 className="font-semibold">User Management</h3>
</div>
<p className="text-sm text-muted-foreground">
View, create, and manage user accounts
</p>
</div>
</Link>
<Link href="/admin/organizations" className="block">
<div className="rounded-lg border bg-card p-6 transition-colors hover:bg-accent cursor-pointer">
<div className="flex items-center gap-3 mb-2">
<Building2 className="h-5 w-5 text-primary" aria-hidden="true" />
<h3 className="font-semibold">Organizations</h3>
</div>
<p className="text-sm text-muted-foreground">
Manage organizations and their members
</p>
</div>
</Link>
<Link href="/admin/settings" className="block">
<div className="rounded-lg border bg-card p-6 transition-colors hover:bg-accent cursor-pointer">
<div className="flex items-center gap-3 mb-2">
<Settings className="h-5 w-5 text-primary" aria-hidden="true" />
<h3 className="font-semibold">System Settings</h3>
</div>
<p className="text-sm text-muted-foreground">Configure system-wide settings</p>
</div>
</Link>
</div>
</div>
{/* Analytics Charts */}
<div>
<h2 className="text-xl font-semibold mb-4">Analytics Overview</h2>
<div className="grid gap-6 md:grid-cols-2">
<UserGrowthChart />
<SessionActivityChart />
<OrganizationDistributionChart />
<UserStatusChart />
</div>
</div>
</div>
</div>
);
}