- Split admin.css (3228 lines) into 12 focused files: variables, base, forms, buttons, layout, components, tables, skeleton, datepicker, filemanager, pagination, responsive - Extracted shared styles from offers.css and dashboard.css into components.css and forms.css (offers-* → admin-* prefix) - Standardized naming: dash-kpi-* → admin-kpi-*, session-* → dash-session-*, rich-editor → admin-rich-editor - Deleted duplicate offers-tabs (using admin-tabs everywhere) - Deduplicated DatePicker and FileManager CSS (~360 lines removed) - Added 16 utility classes to base.css (font sizes, widths, gaps, margins) - Deleted empty admin.css Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
123 lines
5.4 KiB
TypeScript
123 lines
5.4 KiB
TypeScript
import { lazy, Suspense } from "react";
|
|
import { Routes, Route } from "react-router-dom";
|
|
import { AuthProvider } from "./context/AuthContext";
|
|
import { AlertProvider } from "./context/AlertContext";
|
|
import ErrorBoundary from "./components/ErrorBoundary";
|
|
import AdminLayout from "./components/AdminLayout";
|
|
import AlertContainer from "./components/AlertContainer";
|
|
import Login from "./pages/Login";
|
|
import Dashboard from "./pages/Dashboard";
|
|
import "./variables.css";
|
|
import "./base.css";
|
|
import "./forms.css";
|
|
import "./buttons.css";
|
|
import "./layout.css";
|
|
import "./components.css";
|
|
import "./tables.css";
|
|
import "./skeleton.css";
|
|
import "./datepicker.css";
|
|
import "./filemanager.css";
|
|
import "./pagination.css";
|
|
import "./responsive.css";
|
|
import "./login.css";
|
|
import "./dashboard.css";
|
|
import "./attendance.css";
|
|
import "./settings.css";
|
|
import "./offers.css";
|
|
import "./invoices.css";
|
|
|
|
const Users = lazy(() => import("./pages/Users"));
|
|
const Attendance = lazy(() => import("./pages/Attendance"));
|
|
const AttendanceHistory = lazy(() => import("./pages/AttendanceHistory"));
|
|
const AttendanceAdmin = lazy(() => import("./pages/AttendanceAdmin"));
|
|
const AttendanceBalances = lazy(() => import("./pages/AttendanceBalances"));
|
|
const AttendanceCreate = lazy(() => import("./pages/AttendanceCreate"));
|
|
const LeaveRequests = lazy(() => import("./pages/LeaveRequests"));
|
|
const LeaveApproval = lazy(() => import("./pages/LeaveApproval"));
|
|
const AttendanceLocation = lazy(() => import("./pages/AttendanceLocation"));
|
|
const Trips = lazy(() => import("./pages/Trips"));
|
|
const TripsHistory = lazy(() => import("./pages/TripsHistory"));
|
|
const TripsAdmin = lazy(() => import("./pages/TripsAdmin"));
|
|
const Vehicles = lazy(() => import("./pages/Vehicles"));
|
|
const Offers = lazy(() => import("./pages/Offers"));
|
|
const OfferDetail = lazy(() => import("./pages/OfferDetail"));
|
|
const OffersCustomers = lazy(() => import("./pages/OffersCustomers"));
|
|
const OffersTemplates = lazy(() => import("./pages/OffersTemplates"));
|
|
const Orders = lazy(() => import("./pages/Orders"));
|
|
const OrderDetail = lazy(() => import("./pages/OrderDetail"));
|
|
const Projects = lazy(() => import("./pages/Projects"));
|
|
const ProjectCreate = lazy(() => import("./pages/ProjectCreate"));
|
|
const ProjectDetail = lazy(() => import("./pages/ProjectDetail"));
|
|
const Invoices = lazy(() => import("./pages/Invoices"));
|
|
const InvoiceDetail = lazy(() => import("./pages/InvoiceDetail"));
|
|
const Settings = lazy(() => import("./pages/Settings"));
|
|
const AuditLog = lazy(() => import("./pages/AuditLog"));
|
|
const NotFound = lazy(() => import("./pages/NotFound"));
|
|
|
|
export default function AdminApp() {
|
|
return (
|
|
<AuthProvider>
|
|
<AlertProvider>
|
|
<AlertContainer />
|
|
<ErrorBoundary>
|
|
<Suspense
|
|
fallback={
|
|
<div className="admin-loading">
|
|
<div className="admin-spinner" />
|
|
</div>
|
|
}
|
|
>
|
|
<Routes>
|
|
<Route path="login" element={<Login />} />
|
|
<Route element={<AdminLayout />}>
|
|
<Route index element={<Dashboard />} />
|
|
<Route path="users" element={<Users />} />
|
|
<Route path="attendance" element={<Attendance />} />
|
|
<Route
|
|
path="attendance/history"
|
|
element={<AttendanceHistory />}
|
|
/>
|
|
<Route path="attendance/admin" element={<AttendanceAdmin />} />
|
|
<Route
|
|
path="attendance/balances"
|
|
element={<AttendanceBalances />}
|
|
/>
|
|
<Route path="attendance/requests" element={<LeaveRequests />} />
|
|
<Route path="attendance/approval" element={<LeaveApproval />} />
|
|
<Route
|
|
path="attendance/create"
|
|
element={<AttendanceCreate />}
|
|
/>
|
|
<Route
|
|
path="attendance/location/:id"
|
|
element={<AttendanceLocation />}
|
|
/>
|
|
<Route path="trips" element={<Trips />} />
|
|
<Route path="trips/history" element={<TripsHistory />} />
|
|
<Route path="trips/admin" element={<TripsAdmin />} />
|
|
<Route path="vehicles" element={<Vehicles />} />
|
|
<Route path="offers" element={<Offers />} />
|
|
<Route path="offers/new" element={<OfferDetail />} />
|
|
<Route path="offers/:id" element={<OfferDetail />} />
|
|
<Route path="offers/customers" element={<OffersCustomers />} />
|
|
<Route path="offers/templates" element={<OffersTemplates />} />
|
|
<Route path="orders" element={<Orders />} />
|
|
<Route path="orders/:id" element={<OrderDetail />} />
|
|
<Route path="projects" element={<Projects />} />
|
|
<Route path="projects/new" element={<ProjectCreate />} />
|
|
<Route path="projects/:id" element={<ProjectDetail />} />
|
|
<Route path="invoices" element={<Invoices />} />
|
|
<Route path="invoices/new" element={<InvoiceDetail />} />
|
|
<Route path="invoices/:id" element={<InvoiceDetail />} />
|
|
<Route path="settings" element={<Settings />} />
|
|
<Route path="audit-log" element={<AuditLog />} />
|
|
</Route>
|
|
<Route path="*" element={<NotFound />} />
|
|
</Routes>
|
|
</Suspense>
|
|
</ErrorBoundary>
|
|
</AlertProvider>
|
|
</AuthProvider>
|
|
);
|
|
}
|