import {
useState,
Suspense,
lazy,
createContext,
useContext,
useEffect,
} from "react";
import Breadcrumb from "../../components/common/Breadcrumb";
import { useFab } from "../../Context/FabContext";
import {
useBucketList,
useBuckets,
useDeleteBucket,
} from "../../hooks/useDirectory";
import ManageBucket1 from "../../components/Directory/ManageBucket1";
import ManageContact from "../../components/Directory/ManageContact";
import BucketList from "../../components/Directory/BucketList";
import { MainDirectoryPageSkeleton } from "../../components/Directory/DirectoryPageSkeleton";
import ContactProfile from "../../components/Directory/ContactProfile";
import GlobalModel from "../../components/common/GlobalModel";
import { exportToCSV } from "../../utils/exportUtils";
import ConfirmModal from "../../components/common/ConfirmModal";
import { useSelectedProject } from "../../slices/apiDataManager";
const NotesPage = lazy(() => import("./NotesPage"));
const ContactsPage = lazy(() => import("./ContactsPage"));
export const DirectoryContext = createContext();
export const useDirectoryContext = () => {
const context = useContext(DirectoryContext);
if (!context) {
return (
Your Action is out of context
);
}
return context;
};
export default function DirectoryPage({ IsPage = true, projectId = null }) {
const [searchContact, setsearchContact] = useState("");
const [searchNote, setSearchNote] = useState("");
const [activeTab, setActiveTab] = useState("notes");
const { setActions } = useFab();
const [gridView, setGridView] = useState(false);
const [isOpenBucket, setOpenBucket] = useState(false);
const [isManageContact, setManageContact] = useState({
isOpen: false,
contactId: null,
});
const [deleteBucket, setDeleteBucket] = useState({
isOpen: false,
bucketId: null,
});
const [showActive, setShowActive] = useState(true);
const [contactOpen, setContactOpen] = useState({
contact: null,
Open: false,
});
const [notesData, setNotesData] = useState([]);
const [ContactData, setContactData] = useState([]);
const handleExport = (type) => {
if (activeTab === "notes" && type === "csv") {
exportToCSV(notesData, "notes.csv");
}
if (activeTab === "contacts" && type === "csv") {
exportToCSV(ContactData, "contact.csv");
}
};
const { data, isLoading, isError, error } = useBucketList();
const handleTabClick = (tab, e) => {
e.preventDefault();
setActiveTab(tab);
};
useEffect(() => {
const actions = [];
if (IsPage) {
actions.push({
label: "Manage Bucket",
icon: "fa-solid fa-bucket fs-5",
color: "primary",
onClick: () => setOpenBucket(true),
});
}
if (data?.length > 0) {
actions.push({
label: "New Contact",
icon: "bx bx-plus-circle",
color: "warning",
onClick: () => setManageContact({ isOpen: true, contactId: null }),
});
}
setActions(actions);
return () => setActions([]);
}, [IsPage, data]);
const contextValues = {
showActive,
gridView,
data,
setManageContact,
setContactOpen,
setDeleteBucket,
};
const { mutate: DeleteBucket, isPending: Deleting } = useDeleteBucket(() => {
setDeleteBucket({ isOpen: false, bucketId: null });
});
const handleDelete = (bucketId) => {
DeleteBucket(bucketId);
};
if (isLoading) return ;
if (isError) return {error.message}
;
return (
<>
{IsPage && (
)}
{activeTab === "notes" && (
setSearchNote(e.target.value)}
/>
)}
{activeTab === "contacts" && (
)}
}>
{activeTab === "notes" && (
)}
{activeTab === "contacts" && (
)}
{isOpenBucket && (
setOpenBucket(false)}
>
setOpenBucket(false)} />
)}
{contactOpen.Open && (
setContactOpen({ contact: null, Open: false })}
>
)}
{isManageContact.isOpen && (
setManageContact({ isOpen: false, contactId: null })
}
>
setManageContact({ isOpen: false, contactId: null })
}
/>
)}
{deleteBucket.isOpen && (
setDeleteBucket({ isOpen: false, bucketId: null })}
loading={Deleting}
paramData={deleteBucket.bucketId}
/>
)}
>
);
}