addded new component for profile contact , that open in modal for adding notes

This commit is contained in:
Pramod Mahajan 2025-05-20 18:14:55 +05:30
parent 9c9a69bc52
commit 7a30c74594

View File

@ -12,15 +12,18 @@ import UpdateContact from "../../components/Directory/UpdateContact";
import CardViewDirectory from "../../components/Directory/CardViewDirectory"; import CardViewDirectory from "../../components/Directory/CardViewDirectory";
import { useContactCategory } from "../../hooks/masterHook/useMaster"; import { useContactCategory } from "../../hooks/masterHook/useMaster";
import usePagination from "../../hooks/usePagination"; import usePagination from "../../hooks/usePagination";
import {ITEMS_PER_PAGE} from "../../utils/constants"; import { ITEMS_PER_PAGE } from "../../utils/constants";
import ProfileContactDirectory from "../../components/Directory/ProfileContactDirectory";
const Directory = () => { const Directory = () => {
const [isOpenModal, setIsOpenModal] = useState(false); const [isOpenModal, setIsOpenModal] = useState(false);
const [isOpenModalNote, setIsOpenModalNote] = useState(false);
const [selectedContact, setSelectedContact] = useState(null); const [selectedContact, setSelectedContact] = useState(null);
const [open_contact, setOpen_contact] = useState(null);
const [ContatList, setContactList] = useState([]); const [ContatList, setContactList] = useState([]);
const [contactCategories, setContactCategories] = useState([]); const [contactCategories, setContactCategories] = useState([]);
const [ searchText, setSearchText ] = useState( "" ); const [searchText, setSearchText] = useState("");
const [listView, setListView] = useState(true); const [listView, setListView] = useState(false);
const { contacts, loading } = useDirectory(); const { contacts, loading } = useDirectory();
const { contactCategory, loading: contactCategoryLoading } = const { contactCategory, loading: contactCategoryLoading } =
@ -59,6 +62,7 @@ const Directory = () => {
const closedModel = () => { const closedModel = () => {
setIsOpenModal(false); setIsOpenModal(false);
setSelectedContact(null); setSelectedContact(null);
setOpen_contact(null);
}; };
useEffect(() => { useEffect(() => {
setContactList(contacts); setContactList(contacts);
@ -80,23 +84,39 @@ const Directory = () => {
); );
}; };
const filteredContacts = useMemo(() => { const filteredContacts = useMemo(() => {
return ContatList return ContatList.filter((c) => {
.filter((c) => { const matchesSearch =
const matchesSearch = c.name.toLowerCase().includes(searchText.toLowerCase()) ||
c.name.toLowerCase().includes(searchText.toLowerCase()) || c.organization.toLowerCase().includes(searchText.toLowerCase());
c.organization.toLowerCase().includes(searchText.toLowerCase()); const matchesCategory =
const matchesCategory = selectedCategoryIds.length === 0 ||
selectedCategoryIds.length === 0 || selectedCategoryIds.includes(c.contactCategory?.id);
selectedCategoryIds.includes(c.contactCategory?.id); return matchesSearch && matchesCategory;
return matchesSearch && matchesCategory; }).sort((a, b) => a.name.localeCompare(b.name));
})
.sort((a, b) => a.name.localeCompare(b.name));
}, [ContatList, searchText, selectedCategoryIds]); }, [ContatList, searchText, selectedCategoryIds]);
const { currentPage, totalPages, currentItems, paginate } = usePagination( const { currentPage, totalPages, currentItems, paginate } = usePagination(
filteredContacts, filteredContacts,
ITEMS_PER_PAGE ITEMS_PER_PAGE
); );
const renderModalContent = () => {
if (selectedContact) {
return (
<UpdateContact
existingContact={selectedContact}
submitContact={submitContact}
onCLosed={closedModel}
/>
);
}
if (!open_contact) {
return (
<ManageDirectory submitContact={submitContact} onCLosed={closedModel} />
);
}
};
return ( return (
<div className="container-xxl flex-grow-1 container-p-y"> <div className="container-xxl flex-grow-1 container-p-y">
<Breadcrumb <Breadcrumb
@ -112,23 +132,22 @@ const Directory = () => {
closeModal={() => setIsOpenModal(false)} closeModal={() => setIsOpenModal(false)}
size="lg" size="lg"
> >
{selectedContact ? ( {renderModalContent()}
<UpdateContact </GlobalModel>
existingContact={selectedContact} )}
submitContact={submitContact} {isOpenModalNote && (
onCLosed={closedModel} <GlobalModel
/> isOpen={isOpenModalNote}
) : ( closeModal={() => setIsOpenModalNote(false)}
<ManageDirectory size="lg"
submitContact={submitContact} IsCloseBtn={false}
onCLosed={closedModel} >
/> {open_contact && <ProfileContactDirectory contact={open_contact} setOpen_contact={setOpen_contact} closeModal={ () => setIsOpenModalNote(false)} />}
)}
</GlobalModel> </GlobalModel>
)} )}
<div className="card p-2"> <div className="card p-2">
<div className="row mx-0 px-0 align-items-center"> <div className="row mx-0 px-0 align-items-center">
<div className="col-7 col-md-4 mb-2 px-1 d-flex align-items-center "> <div className="col-12 col-md-4 mb-2 px-1 d-flex align-items-center ">
<input <input
type="search" type="search"
className="form-control form-control-sm me-2" className="form-control form-control-sm me-2"
@ -166,7 +185,7 @@ const Directory = () => {
<i className="bx bx-list-ul bx-sm"></i> <i className="bx bx-list-ul bx-sm"></i>
</button> </button>
</div> </div>
<div className="dropdown"> <div className="dropdown">
<a <a
className="dropdown-toggle hide-arrow cursor-pointer d-flex align-items-center" className="dropdown-toggle hide-arrow cursor-pointer d-flex align-items-center"
data-bs-toggle="dropdown" data-bs-toggle="dropdown"
@ -194,117 +213,118 @@ const Directory = () => {
</div> </div>
</div> </div>
<div className="col-5 col-md-8 mb-2 px-1 text-md-end text-end"> <div className="col-12 col-md-8 mb-2 px-1 text-md-end text-end">
<button <button
type="button" type="button"
className="btn btn-xs btn-primary" className="btn btn-xs btn-primary"
onClick={() => setIsOpenModal(true)} onClick={() => setIsOpenModal(true)}
> >
<i className="bx bx-plus-circle me-2"></i> <i className="bx bx-plus-circle me-2"></i>
<span className="d-sm-block d-none"> New Contact</span> New Contact
</button> </button>
</div> </div>
</div> </div>
{ {listView ? (
listView ? ( <div className="table-responsive text-nowrap py-2 ">
<div className="table-responsive text-nowrap py-2 "> <table className="table px-2">
<table className="table px-2"> <thead>
<thead>
<tr>
<th colSpan={2}>
<div className="d-flex align-items-center gap-1">
<IconButton
size={12}
iconClass="bx bx-user"
color="secondary"
onClick={() => alert("User icon clicked")}
/>
<span>Name</span>
</div>
</th>
<th className="px-2 text-start">
<div className="d-flex text-center align-items-center gap-1 justify-content-start">
<IconButton
size={12}
iconClass="bx bx-envelope"
color="primary"
/>
<span>Email</span>
</div>
</th>
<th className="mx-2">
<div className="d-flex align-items-center m-0 p-0 gap-1">
<IconButton
size={12}
iconClass="bx bx-phone"
color="warning"
onClick={() => alert("User icon clicked")}
/>
<span>Phone</span>
</div>
</th>
<th className="mx-2">
<div className="d-flex align-items-center gap-1">
<IconButton
size={12}
iconClass="bx bxs-grid-alt"
color="info"
/>
<span>Organization</span>
</div>
</th>
<th className="mx-2">Category</th>
<th
// className={`mx-2 ${
// HasManageProject ? "d-sm-table-cell" : "d-none"
// }`}
>
Action
</th>
</tr>
</thead>
<tbody className="table-border-bottom-0 overflow-auto ">
{loading && ContatList.length === 0 && (
<tr> <tr>
<td colSpan={10}>Loading...</td> <th colSpan={2}>
</tr> <div className="d-flex align-items-center gap-1">
)} <IconButton
{!loading && contacts.length == 0 && ContatList.length === 0 && ( size={12}
<tr> iconClass="bx bx-user"
<td colSpan={10}>No Contact Found</td> color="secondary"
</tr> onClick={() => alert("User icon clicked")}
)} />
{!loading && <span>Name</span>
currentItems.map((contact) => ( </div>
<ListViewDirectory </th>
key={contact.id} <th className="px-2 text-start">
contact={contact} <div className="d-flex text-center align-items-center gap-1 justify-content-start">
setSelectedContact={setSelectedContact} <IconButton
setIsOpenModal={setIsOpenModal} size={12}
/> iconClass="bx bx-envelope"
))} color="primary"
</tbody> />
</table> <span>Email</span>
</div> </div>
) : ( </th>
<div className="row">
{currentItems.map((contact, index) => (
<div key={contact.id} className="col-12 col-sm-6 col-md-4 col-lg-4 mb-4">
<CardViewDirectory contact={contact}
setSelectedContact={setSelectedContact}
setIsOpenModal={setIsOpenModal}
/>
</div>
))}
</div>
)
}
<th className="mx-2">
<div className="d-flex align-items-center m-0 p-0 gap-1">
<IconButton
size={12}
iconClass="bx bx-phone"
color="warning"
onClick={() => alert("User icon clicked")}
/>
<span>Phone</span>
</div>
</th>
<th className="mx-2">
<div className="d-flex align-items-center gap-1">
<IconButton
size={12}
iconClass="bx bxs-grid-alt"
color="info"
/>
<span>Organization</span>
</div>
</th>
<th className="mx-2">Category</th>
<th
// className={`mx-2 ${
// HasManageProject ? "d-sm-table-cell" : "d-none"
// }`}
>
Action
</th>
</tr>
</thead>
<tbody className="table-border-bottom-0 overflow-auto ">
{loading && ContatList.length === 0 && (
<tr>
<td colSpan={10}>Loading...</td>
</tr>
)}
{!loading &&
contacts.length == 0 &&
ContatList.length === 0 && (
<tr>
<td colSpan={10}>No Contact Found</td>
</tr>
)}
{!loading &&
currentItems.map((contact) => (
<ListViewDirectory
key={contact.id}
contact={contact}
setSelectedContact={setSelectedContact}
setIsOpenModal={setIsOpenModal}
/>
))}
</tbody>
</table>
</div>
) : (
<div className="row">
{currentItems.map((contact, index) => (
<div
key={contact.id}
className="col-12 col-sm-6 col-md-4 col-lg-4 mb-4"
>
<CardViewDirectory
contact={contact}
setSelectedContact={setSelectedContact}
setIsOpenModal={setIsOpenModal}
setOpen_contact={setOpen_contact}
setIsOpenModalNote={setIsOpenModalNote}
/>
</div>
))}
</div>
)}
{!loading && ( {!loading && (
<nav aria-label="Page "> <nav aria-label="Page ">