50 lines
1.6 KiB
TypeScript
50 lines
1.6 KiB
TypeScript
import { useTranslation } from "react-i18next";
|
|
import { lazy, Suspense } from "react";
|
|
import { Spin } from "antd";
|
|
import useSetPageTitle from "../../../Hooks/useSetPageTitle";
|
|
import { ModalEnum } from "../../../enums/Model";
|
|
import { useDeleteCoupon } from "../../../api/Coupon";
|
|
import PageHeader from "../../../Layout/Dashboard/PageHeader";
|
|
import FilterLayout from "../../../Layout/Dashboard/FilterLayout";
|
|
import FilterForm from "./Model/FilterForm";
|
|
import { canAddCoupon } from "../../../utils/hasAbilityFn";
|
|
|
|
const Table = lazy(() => import("./Table"));
|
|
const AddModalForm = lazy(() => import("./Model/AddModel"));
|
|
const EditModalForm = lazy(() => import("./Model/EditModel"));
|
|
const DeleteModalForm = lazy(
|
|
() => import("../../../Layout/Dashboard/DeleteModels"),
|
|
);
|
|
|
|
const TableHeader = () => {
|
|
const [t] = useTranslation();
|
|
const deleteMutation = useDeleteCoupon();
|
|
|
|
useSetPageTitle([
|
|
{name:`${t(`page_header.home`)}`, path:"/"},
|
|
{name:`${t(`page_header.Coupon`)}`, path:"Coupon"}
|
|
]);
|
|
|
|
return (
|
|
<div className="TableWithHeader">
|
|
<Suspense fallback={<Spin />}>
|
|
<PageHeader
|
|
pageTitle="Coupon"
|
|
ModelAbility={ModalEnum?.COUPON_ADD}
|
|
canAdd={canAddCoupon}
|
|
/>
|
|
<FilterLayout sub_children={<FilterForm />} haveFilter={false} filterTitle="table.Coupon" />
|
|
<Table />
|
|
<AddModalForm />
|
|
<EditModalForm />
|
|
<DeleteModalForm
|
|
deleteMutation={deleteMutation}
|
|
ModelEnum={ModalEnum?.COUPON_DELETE}
|
|
/>
|
|
</Suspense>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default TableHeader;
|