c9f7b23498
- add `ZEN_MEDIA` env flag and document it in `.env.example` - add media schema, server routes, and API handlers (`api.server.js`, `routes.server.js`, `schema.server.js`) - add `MediaPage`, `MediaGrid`, `MediaFilters`, and `MediaPicker` client components - expose `@zen/core/features/media` and `@zen/core/features/media/picker` package exports - register media navigation and permissions; wire module into `init.js` - document media API, client picker usage, and boundary rules in `MODULES.md` and `ARCHITECTURE.md` - add `src/features/media/README.md`
35 lines
1.1 KiB
JavaScript
35 lines
1.1 KiB
JavaScript
'use client';
|
|
|
|
import { getPage } from './registry.js';
|
|
import './pages/DashboardPage.client.js';
|
|
import './pages/UsersPage.client.js';
|
|
import './pages/RolesPage.client.js';
|
|
import './pages/ProfilePage.client.js';
|
|
import './pages/SettingsPage.client.js';
|
|
import './pages/ConfirmEmailChangePage.client.js';
|
|
import './widgets/index.client.js';
|
|
import './devkit/DevkitPage.client.js';
|
|
import '../media/pages/MediaPage.client.js';
|
|
|
|
export default function AdminPageClient({ params, user, widgetData, appConfig, devkitEnabled }) {
|
|
const parts = params?.admin || [];
|
|
const [first] = parts;
|
|
|
|
const slug = first || 'dashboard';
|
|
const page = getPage(slug) || getPage('dashboard');
|
|
|
|
if (!page) return null;
|
|
|
|
const { Component } = page;
|
|
if (slug === 'dashboard') {
|
|
return <Component user={user} stats={widgetData} />;
|
|
}
|
|
if (slug === 'settings') {
|
|
return <Component user={user} appConfig={appConfig} />;
|
|
}
|
|
if (slug === 'devkit') {
|
|
return <Component user={user} params={parts} devkitEnabled={devkitEnabled} />;
|
|
}
|
|
return <Component user={user} params={parts} />;
|
|
}
|