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>
    </>
  );
};