nerd_project_dashboard/src/Pages/Unit/useTableColumns.tsx
2024-08-21 15:23:33 +03:00

106 lines
2.8 KiB
TypeScript

import { Space, TableColumnsType, Tooltip } from "antd";
import { FaPlus } from "react-icons/fa";
import useModalHandler from "../../utils/useModalHandler";
import { ModalEnum } from "../../enums/Model";
import { useObjectToEdit } from "../../zustand/ObjectToEditState";
import { RiDeleteBin6Fill } from "react-icons/ri";
import { MdOutlineEdit } from "react-icons/md";
import { useTranslation } from "react-i18next";
import { ABILITIES_ENUM } from "../../enums/abilities";
import { BsEyeFill } from "react-icons/bs";
import { useNavigate } from "react-router-dom";
import {
canAddUnit,
canDeleteUnit,
canEditUnit,
canShowUnit,
} from "../../utils/hasAbilityFn";
import ActionButtons from "../../Components/Table/ActionButtons";
import { Unit } from "../../types/Unit";
import { DragHandleUnit } from "./DrapableTable";
export const useColumns = () => {
const { handel_open_model } = useModalHandler();
const { setObjectToEdit } = useObjectToEdit((state) => state);
const navigate = useNavigate();
const handelShow = (record: Unit) => {
navigate(`${ABILITIES_ENUM?.UNIT}/${record?.id}`);
};
const handelDelete = (data: Unit) => {
setObjectToEdit(data);
handel_open_model(ModalEnum?.UNIT_DELETE);
};
const handleEdit = (record: Unit) => {
setObjectToEdit(record);
handel_open_model(ModalEnum?.UNIT_EDIT);
};
const [t] = useTranslation();
const columns: TableColumnsType<Unit> = [
{ key: "sort", align: "center", width: 80, render: () => <DragHandleUnit /> },
{
title: t("columns.id"),
dataIndex: "id",
key: "id",
align: "center",
render: (text, record) => record?.id,
},
{
title: `${t("columns.name")}`,
dataIndex: "name",
key: "name",
align: "center",
render: (text, record) => record?.name,
},
{
title: t("columns.term"),
dataIndex: "term",
key: "term",
align: "center",
render: (text, record) => {
console.log(record);
return (
record?.term
)
},
},
{
title: canAddUnit ? (
<button
onClick={() => handel_open_model(ModalEnum?.UNIT_ADD)}
className="add_button"
>
{t("practical.add")} {t("models.unit")} <FaPlus />
</button>
) : (
""
),
key: "actions",
align: "end",
width: "25vw",
render: (_text, record, index) => {
return (
<ActionButtons
canDelete={canDeleteUnit}
canEdit={canEditUnit}
canShow={canShowUnit}
index={index}
onDelete={() => handelDelete(record)}
onEdit={() => handleEdit(record)}
onShow={() => handelShow(record)}
/>
);
},
},
];
return columns;
};