import React, { useMemo, useState } from "react"; import { useLocation, useNavigate } from "react-router-dom"; import Icons from "../../Helpers/Icons"; import { PriceFormatter } from "../../Helpers/PriceFormatter"; import { handlePagingFunc } from "../../Pagination/HandlePagination"; import PaginatedList from "../../Pagination/PaginatedList"; import LoadingSpinner from "../../Spinners/LoadingSpinner"; export default function FamilyNewTasks({ familyData, className, action, }) { let navigate = useNavigate(); let { pathname } = useLocation(); // ... let filteredFamilyData = useMemo( () => familyData?.data?.result_list?.filter((data) => data.family_uid !== ""), [familyData?.data?.result_list] ); const [currentPage, setCurrentPage] = useState(0); const indexOfFirstItem = Number(currentPage); const indexOfLastItem = Number(indexOfFirstItem) + Number(process.env.REACT_APP_ITEM_PER_PAGE); const currentTasks = filteredFamilyData?.slice( indexOfFirstItem, indexOfLastItem ); const handlePagination = (e) => handlePagingFunc(e, setCurrentPage); return (
{familyData.loading ? (
) : ( <> {familyData?.data?.result_list && (
{ <> {familyData?.data?.result_list?.length <= 0 ? ( ) : ( currentTasks.map((value, index) => { // find due date const dueDate = value?.delivery_date.split(" ")[0]; // the price let thePrice = PriceFormatter( value?.price * 0.01, value?.currency_code, value?.currency ); let image = `${familyData?.data?.result_list}${localStorage.getItem( "session_token" )}/job/${value.job_uid}`; return ( ); }) )} }
You currently have no active tasks{" "} add new
data

{value.title}

Price:{" "} {thePrice} Duration:{" "} {" "} {value.timeline_days} day(s) Due Date:{" "} {" "} {dueDate}
{/* PAGINATION BUTTON */} = filteredFamilyData?.length ? true : false } data={filteredFamilyData} start={indexOfFirstItem} stop={indexOfLastItem} /> {/* END OF PAGINATION BUTTON */}
)} )}
); }