45 lines
1.6 KiB
TypeScript
45 lines
1.6 KiB
TypeScript
import { ModuleClientParams } from "@erp/core/client";
|
|
import { lazy } from "react";
|
|
import { Outlet, RouteObject } from "react-router-dom";
|
|
import { CustomerUpdate } from "./pages/update";
|
|
|
|
// Lazy load components
|
|
const CustomersLayout = lazy(() =>
|
|
import("./components").then((m) => ({ default: m.CustomersLayout }))
|
|
);
|
|
|
|
const CustomersList = lazy(() => import("./pages").then((m) => ({ default: m.CustomersList })));
|
|
|
|
const CustomerAdd = lazy(() => import("./pages").then((m) => ({ default: m.CustomerCreate })));
|
|
|
|
export const CustomerRoutes = (params: ModuleClientParams): RouteObject[] => {
|
|
return [
|
|
{
|
|
path: "customers",
|
|
element: (
|
|
<CustomersLayout>
|
|
<Outlet context={params} />
|
|
</CustomersLayout>
|
|
),
|
|
children: [
|
|
{ path: "", index: true, element: <CustomersList /> }, // index
|
|
{ path: "list", element: <CustomersList /> },
|
|
{ path: "create", element: <CustomerAdd /> },
|
|
{ path: ":id/edit", element: <CustomerUpdate /> },
|
|
|
|
//
|
|
/*{ path: "create", element: <CustomersList /> },
|
|
{ path: ":id", element: <CustomersList /> },
|
|
{ path: ":id/edit", element: <CustomersList /> },
|
|
{ path: ":id/delete", element: <CustomersList /> },
|
|
{ path: ":id/view", element: <CustomersList /> },
|
|
{ path: ":id/print", element: <CustomersList /> },
|
|
{ path: ":id/email", element: <CustomersList /> },
|
|
{ path: ":id/download", element: <CustomersList /> },
|
|
{ path: ":id/duplicate", element: <CustomersList /> },
|
|
{ path: ":id/preview", element: <CustomersList /> },*/
|
|
],
|
|
},
|
|
];
|
|
};
|