forked from github/plane
62 lines
2.0 KiB
TypeScript
62 lines
2.0 KiB
TypeScript
import { useState } from "react";
|
|
|
|
// components
|
|
import { DeleteObjectModal, ObjectModal } from "components/custom-attributes";
|
|
// ui
|
|
import { CustomMenu } from "components/ui";
|
|
// icons
|
|
import { TableProperties } from "lucide-react";
|
|
// helpers
|
|
import { renderEmoji } from "helpers/emoji.helper";
|
|
// types
|
|
import { ICustomAttribute } from "types";
|
|
|
|
type Props = {
|
|
object: ICustomAttribute;
|
|
};
|
|
|
|
export const SingleObject: React.FC<Props> = (props) => {
|
|
const { object } = props;
|
|
|
|
const [isEditObjectModalOpen, setIsEditObjectModalOpen] = useState(false);
|
|
const [isDeleteObjectModalOpen, setIsDeleteObjectModalOpen] = useState(false);
|
|
|
|
return (
|
|
<>
|
|
<ObjectModal
|
|
data={object}
|
|
isOpen={isEditObjectModalOpen}
|
|
onClose={() => setIsEditObjectModalOpen(false)}
|
|
/>
|
|
<DeleteObjectModal
|
|
isOpen={isDeleteObjectModalOpen}
|
|
objectToDelete={object}
|
|
onClose={() => setIsDeleteObjectModalOpen(false)}
|
|
/>
|
|
<div className="flex items-center justify-between gap-4 py-4">
|
|
<div className={`flex gap-4 ${object.description === "" ? "items-center" : "items-start"}`}>
|
|
<div className="bg-custom-background-80 h-10 w-10 grid place-items-center rounded">
|
|
{object.icon ? (
|
|
renderEmoji(object.icon)
|
|
) : (
|
|
<TableProperties size={20} strokeWidth={1.5} />
|
|
)}
|
|
</div>
|
|
<div>
|
|
<h5 className="text-sm font-medium">{object.display_name}</h5>
|
|
<p className="text-custom-text-300 text-xs">{object.description}</p>
|
|
</div>
|
|
</div>
|
|
<CustomMenu ellipsis>
|
|
<CustomMenu.MenuItem renderAs="button" onClick={() => setIsEditObjectModalOpen(true)}>
|
|
Edit
|
|
</CustomMenu.MenuItem>
|
|
<CustomMenu.MenuItem renderAs="button" onClick={() => setIsDeleteObjectModalOpen(true)}>
|
|
Delete
|
|
</CustomMenu.MenuItem>
|
|
</CustomMenu>
|
|
</div>
|
|
</>
|
|
);
|
|
};
|