Compare commits
11 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 36d8c70fd9 | |||
| 23443a4677 | |||
| 16e5656422 | |||
| 0e42668285 | |||
| 66bd8cf6ec | |||
| 3d7ad25517 | |||
| 2d5c828089 | |||
| e39a8358f7 | |||
| e9c57550a2 | |||
| 27f87ee92d | |||
| edf23352ef |
@@ -1,7 +1,10 @@
|
|||||||
|
import { Suspense, lazy } from "react";
|
||||||
import localImgLoad from "../../lib/localImgLoad";
|
import localImgLoad from "../../lib/localImgLoad";
|
||||||
import CountDown from "../Helpers/CountDown";
|
import CountDown from "../Helpers/CountDown";
|
||||||
import { PriceFormatter } from "../Helpers/PriceFormatter";
|
import { PriceFormatter } from "../Helpers/PriceFormatter";
|
||||||
|
|
||||||
|
const VideoElement = lazy(() => import("../VideoCom/VideoElement")); // LAZY IMPORTING VIDEO COMPONENT
|
||||||
|
|
||||||
export default function OfferCard({
|
export default function OfferCard({
|
||||||
datas,
|
datas,
|
||||||
hidden = false,
|
hidden = false,
|
||||||
@@ -19,9 +22,13 @@ export default function OfferCard({
|
|||||||
return (
|
return (
|
||||||
<div className="card-style-one flex flex-col justify-between w-full h-[387px] bg-white dark:bg-dark-white p-3 pb rounded-2xl">
|
<div className="card-style-one flex flex-col justify-between w-full h-[387px] bg-white dark:bg-dark-white p-3 pb rounded-2xl">
|
||||||
<div className="content">
|
<div className="content">
|
||||||
{/* thumbnail */}
|
|
||||||
<div className="w-full h-40">
|
<div className="w-full h-40">
|
||||||
{/* thumbnail image */}
|
{/* thumbnail image/video */}
|
||||||
|
{datas.job_type == "MEDIA" ?
|
||||||
|
<Suspense fallback={<p>Loading...</p>}>
|
||||||
|
<VideoElement videoId={datas?.media_uid} />
|
||||||
|
</Suspense>
|
||||||
|
:
|
||||||
<div
|
<div
|
||||||
className="thumbnail w-full h-full rounded-xl overflow-hidden px-4 pt-4"
|
className="thumbnail w-full h-full rounded-xl overflow-hidden px-4 pt-4"
|
||||||
style={{
|
style={{
|
||||||
@@ -30,6 +37,7 @@ export default function OfferCard({
|
|||||||
>
|
>
|
||||||
{hidden && <div className="flex justify-center"></div>}
|
{hidden && <div className="flex justify-center"></div>}
|
||||||
</div>
|
</div>
|
||||||
|
}
|
||||||
</div>
|
</div>
|
||||||
{/* details */}
|
{/* details */}
|
||||||
<div className="details">
|
<div className="details">
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ import LoadingSpinner from "../Spinners/LoadingSpinner";
|
|||||||
import AssignTaskPopout from "./FamilyPopout/AssignTaskPopout";
|
import AssignTaskPopout from "./FamilyPopout/AssignTaskPopout";
|
||||||
import FamilyWallet from "./Tabs/FamilyWallet";
|
import FamilyWallet from "./Tabs/FamilyWallet";
|
||||||
import { apiConst } from "../../lib/apiConst";
|
import { apiConst } from "../../lib/apiConst";
|
||||||
|
import { useSelector } from "react-redux";
|
||||||
|
|
||||||
// Lazy Imports for components
|
// Lazy Imports for components
|
||||||
const FamilyWaitlist = lazy(() => import("./Tabs/FamilyWaitlist"));
|
const FamilyWaitlist = lazy(() => import("./Tabs/FamilyWaitlist"));
|
||||||
@@ -29,43 +30,32 @@ export default function FamilyManageTabs({
|
|||||||
listReload,
|
listReload,
|
||||||
loader,
|
loader,
|
||||||
}) {
|
}) {
|
||||||
|
|
||||||
|
const { jobListTable, pendingListTable, parentFamilyTaskList } = useSelector((state) => state.tableReload); // TABLE RELOAD TRIGGERS
|
||||||
|
|
||||||
// Initial state for family details
|
// Initial state for family details
|
||||||
const initialDetailState = {
|
const initialDetailState = {
|
||||||
loading: false,
|
loading: false,
|
||||||
data: null,
|
data: [],
|
||||||
};
|
};
|
||||||
// console.log('accountDetails',accountDetails)
|
|
||||||
// State for family details, tasks, waitlist, and pending
|
|
||||||
const [details, setDetails] = useState({
|
|
||||||
familyDetails: { ...initialDetailState },
|
|
||||||
familyTasks: { ...initialDetailState },
|
|
||||||
familyWaitList: { ...initialDetailState },
|
|
||||||
familyPending: { ...initialDetailState },
|
|
||||||
});
|
|
||||||
|
|
||||||
// Function to reset family details, tasks, waitlist, and pending
|
// State for family details, tasks, waitlist, and pending
|
||||||
const resetDetails = () => {
|
let [familyDetails, setFamilyDetails] = useState({loading: false, data: {}})
|
||||||
setDetails({
|
let [familyTasks, setFamilyTasks] = useState({...initialDetailState})
|
||||||
familyDetails: { ...initialDetailState },
|
let [familyWaitList, setFamilyWaitList] = useState({...initialDetailState})
|
||||||
familyTasks: { ...initialDetailState },
|
let [familyPending, setFamilyPending] = useState({...initialDetailState})
|
||||||
familyWaitList: { ...initialDetailState },
|
|
||||||
familyPending: { ...initialDetailState },
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const [updatePage, setUpdatePage] = useState(false) // State to determine when to update the page
|
const [updatePage, setUpdatePage] = useState(false) // State to determine when to update the page
|
||||||
|
|
||||||
// State for family task data
|
// State for list of created jobs by FULL USER
|
||||||
const [familyTask, setFamilyTask] = useState({ loading: false, data: [] });
|
const [jobList, setJobList] = useState({ loading: false, data: [] });
|
||||||
|
|
||||||
// State for active task
|
// State for active/selected job
|
||||||
const [activeTask, setActiveTask] = useState({ id: 0, data: {} });
|
const [activeTask, setActiveTask] = useState({ id: 0, data: {} });
|
||||||
|
|
||||||
// State for error messages
|
|
||||||
const [errMsg, setErrMsg] = useState("");
|
|
||||||
|
|
||||||
// State for family task popout
|
// State for family task popout
|
||||||
const [familyTaskPopout, setFamilyTaskPopout] = useState(false);
|
const [assignTaskPopout, setAssignTaskPopout] = useState(false);
|
||||||
|
|
||||||
let [uploadStatus, setUploadStatus] = useState({loading: false, status: false, message:''}) // HOLDS STATE FOR UPLOAD PROFILE PICTURE STATUS
|
let [uploadStatus, setUploadStatus] = useState({loading: false, status: false, message:''}) // HOLDS STATE FOR UPLOAD PROFILE PICTURE STATUS
|
||||||
|
|
||||||
@@ -79,8 +69,8 @@ export default function FamilyManageTabs({
|
|||||||
const apiCall = useMemo(() => new usersService(), []);
|
const apiCall = useMemo(() => new usersService(), []);
|
||||||
|
|
||||||
// Function to handle toggling the family task popout
|
// Function to handle toggling the family task popout
|
||||||
const familyPopUpHandler = () => {
|
const familyAssignPopUpHandler = () => {
|
||||||
setFamilyTaskPopout((prev) => !prev);
|
setAssignTaskPopout((prev) => !prev);
|
||||||
};
|
};
|
||||||
|
|
||||||
// Function to trigger a click on the hidden profile image input
|
// Function to trigger a click on the hidden profile image input
|
||||||
@@ -177,44 +167,40 @@ export default function FamilyManageTabs({
|
|||||||
Tasks: (
|
Tasks: (
|
||||||
<FamilyTasks
|
<FamilyTasks
|
||||||
className={className}
|
className={className}
|
||||||
loader={details.familyTasks.loading}
|
familyData={familyTasks}
|
||||||
familyData={details.familyTasks.data}
|
|
||||||
accountDetails={accountDetails}
|
accountDetails={accountDetails}
|
||||||
/>
|
/>
|
||||||
),
|
),
|
||||||
Waiting: (
|
Waiting: (
|
||||||
<FamilyWaitlist
|
<FamilyWaitlist
|
||||||
familyData={details.familyWaitList.data}
|
familyData={familyWaitList}
|
||||||
accountDetails={accountDetails}
|
accountDetails={accountDetails}
|
||||||
loader={details.familyWaitList.loading}
|
|
||||||
setUpdatePage={setUpdatePage}
|
setUpdatePage={setUpdatePage}
|
||||||
/>
|
/>
|
||||||
),
|
),
|
||||||
Pending: (
|
Pending: (
|
||||||
<FamilyPending
|
<FamilyPending
|
||||||
familyData={details.familyPending.data}
|
familyData={familyPending}
|
||||||
accountDetails={accountDetails}
|
accountDetails={accountDetails}
|
||||||
loader={details.familyPending.loading}
|
setUpdatePage={setUpdatePage}
|
||||||
/>
|
/>
|
||||||
),
|
),
|
||||||
Account: (
|
Account: (
|
||||||
<FamilyAccount
|
<FamilyAccount
|
||||||
familyData={details.familyDetails.data}
|
familyData={familyDetails}
|
||||||
myRef={accountRef}
|
myRef={accountRef}
|
||||||
loader={details.familyDetails.loading}
|
|
||||||
handlePrint={useHandlePrint}
|
handlePrint={useHandlePrint}
|
||||||
/>
|
/>
|
||||||
),
|
),
|
||||||
Profile: <FamilyProfile familyData={details.familyDetails.data} />,
|
Profile: <FamilyProfile familyData={familyDetails.data} />,
|
||||||
wallet: <FamilyWallet familyData={details.familyDetails.data} />,
|
wallet: <FamilyWallet familyData={familyDetails.data} />,
|
||||||
};
|
};
|
||||||
|
|
||||||
// Default tab component
|
// Default tab component
|
||||||
const defaultTabComponent = (
|
const defaultTabComponent = (
|
||||||
<FamilyTasks
|
<FamilyTasks
|
||||||
className={className}
|
className={className}
|
||||||
loader={details.familyTasks.loading}
|
familyData={familyTasks}
|
||||||
familyData={details.familyTasks.data}
|
|
||||||
accountDetails={accountDetails}
|
accountDetails={accountDetails}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
@@ -222,67 +208,90 @@ export default function FamilyManageTabs({
|
|||||||
// Selected tab component based on the current 'tab'
|
// Selected tab component based on the current 'tab'
|
||||||
const selectedTabComponent = tabComponents[tab] || defaultTabComponent;
|
const selectedTabComponent = tabComponents[tab] || defaultTabComponent;
|
||||||
|
|
||||||
// Effect to manage family details and related data
|
// Effect to manage family details
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const manageFamily = async () => {
|
const manageFamily = async () => {
|
||||||
|
setFamilyDetails({loading:true, data: {}})
|
||||||
try {
|
try {
|
||||||
resetDetails();
|
|
||||||
|
|
||||||
setDetails({
|
|
||||||
familyDetails: { loading: true },
|
|
||||||
familyTasks: { loading: true },
|
|
||||||
familyWaitList: { loading: true },
|
|
||||||
familyPending: { loading: true },
|
|
||||||
});
|
|
||||||
|
|
||||||
const { family_uid } = accountDetails;
|
const { family_uid } = accountDetails;
|
||||||
const reqData = { family_uid };
|
const reqData = { family_uid };
|
||||||
|
|
||||||
const [familyRes, tasksRes, familyWaitRes, familyPending] =
|
const response = await apiCall.ManageFamily(reqData)
|
||||||
await Promise.all([
|
if(response.status != 200 || !response?.data){
|
||||||
apiCall.ManageFamily(reqData),
|
return setFamilyDetails({loading:false, data: {}})
|
||||||
apiCall.ManageTasks(reqData),
|
|
||||||
apiCall.ManageFamilyWaitlist(),
|
|
||||||
apiCall.ManageFamilyPending(),
|
|
||||||
]);
|
|
||||||
|
|
||||||
const familyData = familyRes.data;
|
|
||||||
const tasksData = tasksRes.data;
|
|
||||||
const familyWaitData = familyWaitRes.data;
|
|
||||||
const familyPendingData = familyPending.data;
|
|
||||||
|
|
||||||
// Function to check for errors in data
|
|
||||||
const checkDataError = (data) => data?.internal_return < 0;
|
|
||||||
|
|
||||||
if (
|
|
||||||
checkDataError(familyData) ||
|
|
||||||
checkDataError(tasksData) ||
|
|
||||||
checkDataError(familyWaitData) ||
|
|
||||||
checkDataError(familyPendingData)
|
|
||||||
) {
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
setFamilyDetails({loading:false, data: response?.data})
|
||||||
setDetails({
|
|
||||||
familyDetails: { loading: false, data: familyData },
|
|
||||||
familyTasks: { loading: false, data: tasksData },
|
|
||||||
familyWaitList: { loading: false, data: familyWaitData },
|
|
||||||
familyPending: { loading: false, data: familyPendingData },
|
|
||||||
});
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
resetDetails();
|
|
||||||
setErrMsg("An error occurred");
|
|
||||||
throw new Error(error);
|
throw new Error(error);
|
||||||
|
setFamilyDetails({loading:false, data: {}})
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// Invoke the manageFamily function when the component mounts
|
// Invoke the manageFamily function when the component mounts
|
||||||
manageFamily();
|
manageFamily();
|
||||||
|
}, []);
|
||||||
|
|
||||||
|
// Effect to manage active family task details
|
||||||
|
useEffect(() => {
|
||||||
|
const manageTasks = async () => {
|
||||||
|
setFamilyTasks({loading:true, data: []})
|
||||||
|
try {
|
||||||
|
const { family_uid } = accountDetails;
|
||||||
|
const reqData = { family_uid };
|
||||||
|
|
||||||
|
const response = await apiCall.ManageTasks(reqData)
|
||||||
|
if(response.status != 200 || !response?.data){
|
||||||
|
return setFamilyTasks({loading:false, data: []})
|
||||||
|
}
|
||||||
|
setFamilyTasks({loading:false, data: response?.data})
|
||||||
|
} catch (error) {
|
||||||
|
throw new Error(error);
|
||||||
|
setFamilyTasks({loading:false, data: []})
|
||||||
|
}
|
||||||
|
};
|
||||||
|
// Invoke the manageFamily function when the component mounts
|
||||||
|
manageTasks();
|
||||||
|
}, [updatePage, parentFamilyTaskList]);
|
||||||
|
|
||||||
|
// Effect to manage family wait task details
|
||||||
|
useEffect(() => {
|
||||||
|
const manageFamilyWaitlist = async () => {
|
||||||
|
setFamilyWaitList({loading:true, data: []})
|
||||||
|
try {
|
||||||
|
const response = await apiCall.ManageFamilyWaitlist()
|
||||||
|
if(response.status != 200 || !response?.data){
|
||||||
|
return setFamilyWaitList({loading:false, data: []})
|
||||||
|
}
|
||||||
|
setFamilyWaitList({loading:false, data: response?.data})
|
||||||
|
} catch (error) {
|
||||||
|
throw new Error(error);
|
||||||
|
setFamilyWaitList({loading:false, data: []})
|
||||||
|
}
|
||||||
|
};
|
||||||
|
// Invoke the manageFamily function when the component mounts
|
||||||
|
manageFamilyWaitlist();
|
||||||
}, [updatePage]);
|
}, [updatePage]);
|
||||||
|
|
||||||
// Effect to manage family tasks
|
// Effect to manage family pending task details
|
||||||
|
useEffect(() => {
|
||||||
|
const manageFamilyPending = async () => {
|
||||||
|
setFamilyPending({loading:true, data: []})
|
||||||
|
try {
|
||||||
|
const response = await apiCall.ManageFamilyPending()
|
||||||
|
if(response.status != 200 || !response?.data){
|
||||||
|
return setFamilyPending({loading:false, data: []})
|
||||||
|
}
|
||||||
|
setFamilyPending({loading:false, data: response?.data})
|
||||||
|
} catch (error) {
|
||||||
|
throw new Error(error);
|
||||||
|
setFamilyPending({loading:false, data: []})
|
||||||
|
}
|
||||||
|
};
|
||||||
|
// Invoke the manageFamily function when the component mounts
|
||||||
|
manageFamilyPending();
|
||||||
|
}, [updatePage, pendingListTable]);
|
||||||
|
|
||||||
|
// Effect to get all parent job list
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
let checkFamilyTask = true;
|
|
||||||
const reqData = {
|
const reqData = {
|
||||||
limit: 30,
|
limit: 30,
|
||||||
offset: 0,
|
offset: 0,
|
||||||
@@ -290,12 +299,11 @@ export default function FamilyManageTabs({
|
|||||||
action: apiConst.WRENCHBOARD_PICTURE_FAMMEMBER,
|
action: apiConst.WRENCHBOARD_PICTURE_FAMMEMBER,
|
||||||
};
|
};
|
||||||
|
|
||||||
if (checkFamilyTask) {
|
setJobList({ loading: true });
|
||||||
setFamilyTask({ loading: true });
|
|
||||||
apiCall
|
apiCall
|
||||||
.getMyJobList(reqData)
|
.getMyJobList(reqData)
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
setFamilyTask({ loading: false, data: res?.data?.result_list });
|
setJobList({ loading: false, data: res?.data?.result_list });
|
||||||
if (res?.data?.result_list?.length) {
|
if (res?.data?.result_list?.length) {
|
||||||
setActiveTask((prev) => ({
|
setActiveTask((prev) => ({
|
||||||
...prev,
|
...prev,
|
||||||
@@ -304,15 +312,9 @@ export default function FamilyManageTabs({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
setFamilyTask({ loading: false, data: [] });
|
setJobList({ loading: false, data: [] });
|
||||||
console.log("Error", err);
|
console.log("Error", err);
|
||||||
});
|
});
|
||||||
}
|
|
||||||
|
|
||||||
// Cleanup function to prevent memory leaks
|
|
||||||
return () => {
|
|
||||||
checkFamilyTask = false;
|
|
||||||
};
|
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
@@ -395,7 +397,7 @@ export default function FamilyManageTabs({
|
|||||||
</ul>
|
</ul>
|
||||||
<button
|
<button
|
||||||
type="button"
|
type="button"
|
||||||
onClick={familyPopUpHandler}
|
onClick={familyAssignPopUpHandler}
|
||||||
className="p-1 my-1 w-[100px] flex justify-center items-center btn-gradient text-base rounded-full text-white"
|
className="p-1 my-1 w-[100px] flex justify-center items-center btn-gradient text-base rounded-full text-white"
|
||||||
>
|
>
|
||||||
Add task
|
Add task
|
||||||
@@ -417,15 +419,14 @@ export default function FamilyManageTabs({
|
|||||||
</Suspense>
|
</Suspense>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{familyTaskPopout && (
|
{assignTaskPopout && (
|
||||||
<AssignTaskPopout
|
<AssignTaskPopout
|
||||||
action={familyPopUpHandler}
|
action={familyAssignPopUpHandler}
|
||||||
situation={familyTaskPopout}
|
situation={assignTaskPopout}
|
||||||
familyTask={familyTask}
|
jobList={jobList}
|
||||||
setFamilyTask={setFamilyTask}
|
|
||||||
setActiveTask={setActiveTask}
|
setActiveTask={setActiveTask}
|
||||||
activeTask={activeTask}
|
activeTask={activeTask}
|
||||||
familyDetailsData={details.familyDetails.data}
|
familyDetailsData={familyDetails.data}
|
||||||
setUpdatePage={setUpdatePage}
|
setUpdatePage={setUpdatePage}
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
|
|||||||
@@ -0,0 +1,340 @@
|
|||||||
|
import React, { useEffect, useState, lazy, Suspense } from 'react'
|
||||||
|
import LoadingSpinner from '../../Spinners/LoadingSpinner'
|
||||||
|
import { NewTasks } from './forms'
|
||||||
|
import { PriceFormatter } from '../../Helpers/PriceFormatter'
|
||||||
|
import { useSelector } from 'react-redux';
|
||||||
|
import { InputCom } from '../../AddJob/settings';
|
||||||
|
import * as Yup from "yup";
|
||||||
|
import { Form, Formik } from "formik";
|
||||||
|
|
||||||
|
|
||||||
|
// To get the validation schema
|
||||||
|
const validationSchema = Yup.object().shape({
|
||||||
|
currency: Yup.string()
|
||||||
|
.min(1, "Minimum 3 characters")
|
||||||
|
.max(25, "Maximum 25 characters")
|
||||||
|
.required("required"),
|
||||||
|
amount: Yup.number()
|
||||||
|
.typeError("Invalid number")
|
||||||
|
.min(1, "Must be greater than 0")
|
||||||
|
.test("no-e", "Invalid number", (value) => {
|
||||||
|
if (value && /\d+e/.test(value)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
})
|
||||||
|
.required("required"),
|
||||||
|
job_description: Yup.string()
|
||||||
|
.min(3, "Minimum 3 characters")
|
||||||
|
.max(499, "Maximum 499 characters")
|
||||||
|
.required("required"),
|
||||||
|
timeline_days: Yup.number()
|
||||||
|
.typeError("you must specify a number")
|
||||||
|
.min(1, "Must be greater than 0")
|
||||||
|
.required("required"),
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
const VideoElement = lazy(() => import("../../VideoCom/VideoElement")); // LAZY IMPORTING VIDEO COMPONENT
|
||||||
|
|
||||||
|
export default function AssignMediaTask({
|
||||||
|
commonMedia,
|
||||||
|
requestStatus,
|
||||||
|
setRequestStatus,
|
||||||
|
assignMediaTask,
|
||||||
|
activeMedia,
|
||||||
|
handleActiveMedia,
|
||||||
|
closeModal,
|
||||||
|
family_uid
|
||||||
|
}) {
|
||||||
|
|
||||||
|
// For form initial values
|
||||||
|
const initialValues = {
|
||||||
|
// initial values for formik
|
||||||
|
currency: "",
|
||||||
|
amount: "",
|
||||||
|
job_description: "",
|
||||||
|
timeline_days: "",
|
||||||
|
media_uid: activeMedia.uid,
|
||||||
|
family_uid: family_uid,
|
||||||
|
media_type: "COMMON"
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
const {userDetails} = useSelector((state) => state?.userDetails); // CHECKS IF USER Details are avaliable, to determine if user is active
|
||||||
|
|
||||||
|
const { walletDetails } = useSelector((state) => state?.walletDetails); // WALLET STORE
|
||||||
|
|
||||||
|
// let imageSrc = (localStorage.getItem("session_token")
|
||||||
|
// ? `${userDetails?.session_image_server}${localStorage.getItem("session_token")}/job/${activeMedia.uid}` : ""); // FOR GETTING JOB IMAGE
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
{commonMedia?.loading ? (
|
||||||
|
<div className="h-[30rem] w-full flex justify-center items-center">
|
||||||
|
<LoadingSpinner color="sky-blue" size="16" />
|
||||||
|
</div>
|
||||||
|
) : (
|
||||||
|
<Formik
|
||||||
|
initialValues={initialValues}
|
||||||
|
validationSchema={validationSchema}
|
||||||
|
onSubmit={(values, helpers)=>{assignMediaTask(values, helpers)}}
|
||||||
|
>
|
||||||
|
{(props) => {
|
||||||
|
return (
|
||||||
|
<Form>
|
||||||
|
<>
|
||||||
|
<div
|
||||||
|
className={`job-action-modal-body w-full min-h-[450px] max-h-[450px] overflow-y-auto md:grid md:grid-cols-2`}
|
||||||
|
>
|
||||||
|
<div className="p-4 pt-0">
|
||||||
|
<div className="p-4 w-full min-h-[400px] max-h-[400px] overflow-y-auto bg-slate-100 rounded-md dark:bg-[#11131f] dark:text-white">
|
||||||
|
{commonMedia?.data?.length ? (
|
||||||
|
commonMedia?.data?.map((item, index) => (
|
||||||
|
<div
|
||||||
|
key={item.uid}
|
||||||
|
className="mb-2 flex justify-start items-center gap-2 text-sky-blue text-base cursor-pointer"
|
||||||
|
onClick={() => handleActiveMedia(item)}
|
||||||
|
>
|
||||||
|
<input
|
||||||
|
type="radio"
|
||||||
|
name="media-list"
|
||||||
|
checked={activeMedia?.uid == item?.uid}
|
||||||
|
onChange={() =>
|
||||||
|
handleActiveMedia(item)
|
||||||
|
}
|
||||||
|
className="w-[15px] h-[15px] cursor-pointer"
|
||||||
|
/>
|
||||||
|
<p className="w-full text-dark-gray dark:text-white tracking-wide">
|
||||||
|
{item?.title}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
))
|
||||||
|
) : (
|
||||||
|
<p className="p-8 text-lg text-dark-gray dark:text-white tracking-wide text-center cursor-default">
|
||||||
|
No Media found!
|
||||||
|
</p>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/*Right Hand Side for details && Task Type === select */}
|
||||||
|
<>
|
||||||
|
{commonMedia?.data?.length > 0 ? (
|
||||||
|
<div className="p-4 py-0 h-full">
|
||||||
|
<div className="w-full">
|
||||||
|
<div className="mb-3 w-full">
|
||||||
|
<label className="job-label">
|
||||||
|
Description
|
||||||
|
</label>
|
||||||
|
<p className="p-1 text-sm text-slate-900 dark:text-white">
|
||||||
|
{activeMedia?.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div className="my-3 w-full flex items-center justify-center">
|
||||||
|
<div className="w-full max-w-xs h-28 rounded-2xl flex items-center justify-center">
|
||||||
|
<Suspense fallback={<p>Loading...</p>}>
|
||||||
|
<VideoElement videoId={activeMedia?.uid} />
|
||||||
|
</Suspense>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div className="grid grid-cols-2 gap-3">
|
||||||
|
{/* Price */}
|
||||||
|
<div className="field w-full">
|
||||||
|
<label htmlFor="price" className="job-label flex gap-1">
|
||||||
|
Price
|
||||||
|
<span className='text-red-500 text-[10px]'>{props.errors.amount && props.touched.amount && props.errors.amount}</span>
|
||||||
|
</label>
|
||||||
|
<InputCom
|
||||||
|
fieldClass="px-6 text-right"
|
||||||
|
// label="Price"
|
||||||
|
// labelClass="tracking-wide"
|
||||||
|
inputBg="bg-slate-100"
|
||||||
|
type="number"
|
||||||
|
name="amount"
|
||||||
|
placeholder="0"
|
||||||
|
value={props.values.amount}
|
||||||
|
inputHandler={props.handleChange}
|
||||||
|
// error={props.errors.price && props.touched.price && props.errors.price}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* Currency */}
|
||||||
|
<div className="field w-full">
|
||||||
|
<label
|
||||||
|
htmlFor="currency"
|
||||||
|
className="job-label flex gap-1"
|
||||||
|
>
|
||||||
|
Currency
|
||||||
|
{props.errors.currency && props.touched.currency && <span className="text-[10px] text-red-500">{props.errors.currency}</span>}
|
||||||
|
</label>
|
||||||
|
<select
|
||||||
|
id="currency"
|
||||||
|
name="currency"
|
||||||
|
value={props.values.currency}
|
||||||
|
className={`input-field w-full h-[42px] flex items-center px-2 mt-2 rounded-full placeholder:text-base text-dark-gray dark:text-white bg-slate-100 dark:bg-[#11131F] focus:ring-0 focus:outline-none`}
|
||||||
|
onChange={props.handleChange}
|
||||||
|
>
|
||||||
|
{walletDetails?.loading ? (
|
||||||
|
<option className="text-slate-500 text-[13.975px]" value="">
|
||||||
|
Loading...
|
||||||
|
</option>
|
||||||
|
) : walletDetails.data.length ? (
|
||||||
|
<>
|
||||||
|
<option className="text-slate-500 text-[13.975px]" value="">
|
||||||
|
Currency
|
||||||
|
</option>
|
||||||
|
{walletDetails.data?.map((item, index) => (
|
||||||
|
<option
|
||||||
|
key={index}
|
||||||
|
className="text-slate-500 text-lg"
|
||||||
|
value={item?.country}
|
||||||
|
>
|
||||||
|
{item?.code}
|
||||||
|
</option>
|
||||||
|
))}
|
||||||
|
</>
|
||||||
|
) : (
|
||||||
|
<option className="text-slate-500 text-lg" value="">
|
||||||
|
No Options Found!
|
||||||
|
</option>
|
||||||
|
)}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* Duration */}
|
||||||
|
<div className="field w-full">
|
||||||
|
<label
|
||||||
|
htmlFor="timeline_days"
|
||||||
|
className="job-label flex gap-1"
|
||||||
|
>
|
||||||
|
Timeline
|
||||||
|
{props.errors.timeline_days && props.touched.timeline_days && <span className="text-[12px] text-red-500">{props.errors.timeline_days}</span>}
|
||||||
|
</label>
|
||||||
|
<select
|
||||||
|
id="timeline_days"
|
||||||
|
name="timeline_days"
|
||||||
|
value={props.values.timeline_days}
|
||||||
|
className={`input-field w-full h-[42px] flex items-center px-2 mt-2 rounded-full placeholder:text-base text-dark-gray dark:text-white bg-slate-100 dark:bg-[#11131F] focus:ring-0 focus:outline-none`}
|
||||||
|
onChange={props.handleChange}
|
||||||
|
>
|
||||||
|
{publicArray.length && (
|
||||||
|
<>
|
||||||
|
<option className="text-slate-500 text-[13.975px]" value="">
|
||||||
|
Duration
|
||||||
|
</option>
|
||||||
|
{publicArray.map(({ name, duration }, idx) => (
|
||||||
|
<option
|
||||||
|
key={idx}
|
||||||
|
className="text-slate-500 text-[13.975px]"
|
||||||
|
value={duration}
|
||||||
|
>
|
||||||
|
{name}
|
||||||
|
</option>
|
||||||
|
))}
|
||||||
|
</>
|
||||||
|
)}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* Delivery Detail */}
|
||||||
|
<div className="my-3">
|
||||||
|
<label className="w-full job-label flex gap-1">
|
||||||
|
Delivery Detail
|
||||||
|
{props.errors.job_description && props.touched.job_description && <span className="text-[12px] text-red-500">{props.errors.job_description}</span>}
|
||||||
|
</label>
|
||||||
|
<textarea
|
||||||
|
className={`p-1 w-full text-sm text-slate-900 dark:text-white bg-transparent outline-none border border-slate-300 rounded-md`}
|
||||||
|
rows="5"
|
||||||
|
style={{ resize: "none" }}
|
||||||
|
value={props.values.job_description}
|
||||||
|
onChange={props.handleChange}
|
||||||
|
name='job_description'
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
) : (
|
||||||
|
<></>
|
||||||
|
)}
|
||||||
|
</>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* BTN */}
|
||||||
|
<div className="modal-footer-wrapper">
|
||||||
|
{/* error or success display */}
|
||||||
|
<div className="w-auto h-auto flex items-center">
|
||||||
|
{requestStatus.message != "" &&
|
||||||
|
(!requestStatus.status ? (
|
||||||
|
<div
|
||||||
|
className={`relative p-2 text-[#912741] bg-[#fcd9e2] border-[#fbc6d3] rounded-[0.475rem] text-md font-light leading-[19.5px] text-[13px] self-start`}
|
||||||
|
>
|
||||||
|
{requestStatus.message}
|
||||||
|
</div>
|
||||||
|
) : (
|
||||||
|
requestStatus.status && (
|
||||||
|
<div
|
||||||
|
className={`relative p-2 text-green-700 bg-slate-200 border-slate-800 mb-4 rounded-[0.475rem] text-md font-light leading-[19.5px] text-[13px]`}
|
||||||
|
>
|
||||||
|
{requestStatus.message}
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* End of error or success display */}
|
||||||
|
<div className="w-auto h-auto flex items-center gap-20">
|
||||||
|
<button
|
||||||
|
disabled={requestStatus.loading}
|
||||||
|
onClick={()=>closeModal()}
|
||||||
|
type="button"
|
||||||
|
className="custom-btn border-gradient"
|
||||||
|
>
|
||||||
|
<span className="text-gradient">Close</span>
|
||||||
|
</button>
|
||||||
|
<div className="">
|
||||||
|
{requestStatus.loading ? (
|
||||||
|
<LoadingSpinner color="sky-blue" size="8" />
|
||||||
|
) : (
|
||||||
|
<button
|
||||||
|
type="submit"
|
||||||
|
disabled={requestStatus.loading}
|
||||||
|
// onClick={assignFamilyTask}
|
||||||
|
className="custom-btn btn-gradient text-white"
|
||||||
|
>
|
||||||
|
Assign
|
||||||
|
</button>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</>
|
||||||
|
</Form>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</Formik>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
</>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
const publicArray = [
|
||||||
|
{ duration: 1, name: "1 day" },
|
||||||
|
{ duration: 2, name: "2 days" },
|
||||||
|
{ duration: 3, name: "3 days" },
|
||||||
|
{ duration: 4, name: "4 days" },
|
||||||
|
{ duration: 5, name: "5 days" },
|
||||||
|
{ duration: 6, name: "6 days" },
|
||||||
|
{ duration: 7, name: "1 week" },
|
||||||
|
{ duration: 14, name: "2 weeks" },
|
||||||
|
{ duration: 21, name: "3 weeks" },
|
||||||
|
{ duration: 28, name: "4 weeks" },
|
||||||
|
];
|
||||||
@@ -0,0 +1,263 @@
|
|||||||
|
import React from 'react'
|
||||||
|
import LoadingSpinner from '../../Spinners/LoadingSpinner'
|
||||||
|
import { NewTasks } from './forms'
|
||||||
|
import { PriceFormatter } from '../../Helpers/PriceFormatter'
|
||||||
|
import { useSelector } from 'react-redux';
|
||||||
|
|
||||||
|
export default function AssignPrevNewTask({
|
||||||
|
jobList,
|
||||||
|
requestStatus,
|
||||||
|
assignFamilyTask,
|
||||||
|
taskType,
|
||||||
|
switchTaskType,
|
||||||
|
formState,
|
||||||
|
setFormState,
|
||||||
|
activeTask,
|
||||||
|
handleActiveTask,
|
||||||
|
closeModal
|
||||||
|
}) {
|
||||||
|
|
||||||
|
const {userDetails} = useSelector((state) => state?.userDetails); // CHECKS IF USER Details are avaliable, to determine if user is active
|
||||||
|
|
||||||
|
|
||||||
|
let imageSrc = (localStorage.getItem("session_token")
|
||||||
|
? `${userDetails?.session_image_server}${localStorage.getItem("session_token")}/job/${activeTask.data.job_uid}` : ""); // FOR GETTING JOB IMAGE
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
{jobList?.loading ? (
|
||||||
|
<div className="h-[30rem] w-full flex justify-center items-center">
|
||||||
|
<LoadingSpinner color="sky-blue" size="16" />
|
||||||
|
</div>
|
||||||
|
) : (
|
||||||
|
<>
|
||||||
|
<div
|
||||||
|
className={`job-action-modal-body w-full min-h-[450px] max-h-[450px] overflow-y-auto md:grid ${
|
||||||
|
taskType !== "new" ? "md:grid-cols-2" : "md:grid-cols-1"
|
||||||
|
}`}
|
||||||
|
>
|
||||||
|
<div className="p-4 pt-0">
|
||||||
|
<div className="mb-2 w-full flex items-center gap-4">
|
||||||
|
<div className="flex items-center gap-2 text-sky-blue text-base">
|
||||||
|
<input
|
||||||
|
type="radio"
|
||||||
|
name="task-type"
|
||||||
|
value="select"
|
||||||
|
className="w-[20px] h-[20px] cursor-pointer"
|
||||||
|
checked={taskType == "select"}
|
||||||
|
onChange={switchTaskType}
|
||||||
|
/>
|
||||||
|
<span className="text-lg tracking-wide font-semibold">Previous Task</span>
|
||||||
|
</div>
|
||||||
|
<div className="flex items-center gap-2 text-sky-blue text-base">
|
||||||
|
<input
|
||||||
|
type="radio"
|
||||||
|
name="task-type"
|
||||||
|
value="new"
|
||||||
|
className="w-[20px] h-[20px] cursor-pointer"
|
||||||
|
checked={taskType == "new"}
|
||||||
|
onChange={switchTaskType}
|
||||||
|
/>
|
||||||
|
<span className="text-lg tracking-wide font-semibold">New Task</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{/* Task Type === select */}
|
||||||
|
{taskType == "select" && (
|
||||||
|
<div className="p-4 w-full h-[400px] overflow-y-auto bg-slate-100 rounded-md dark:bg-[#11131f] dark:text-white">
|
||||||
|
{jobList?.data?.length ? (
|
||||||
|
jobList?.data?.map((item, index) => (
|
||||||
|
<div
|
||||||
|
key={item.job_uid}
|
||||||
|
className="mb-2 flex justify-start items-center gap-2 text-sky-blue text-base cursor-pointer"
|
||||||
|
onClick={() => handleActiveTask(item.job_uid, item)}
|
||||||
|
>
|
||||||
|
<input
|
||||||
|
type="radio"
|
||||||
|
name="task-list"
|
||||||
|
checked={
|
||||||
|
activeTask.id == item.job_uid ||
|
||||||
|
(activeTask.id == index && true)
|
||||||
|
}
|
||||||
|
onChange={() =>
|
||||||
|
handleActiveTask(item.job_uid, item)
|
||||||
|
}
|
||||||
|
className="w-[15px] h-[15px] cursor-pointer"
|
||||||
|
/>
|
||||||
|
<p className="w-full text-dark-gray dark:text-white tracking-wide">
|
||||||
|
{item?.title}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
))
|
||||||
|
) : (
|
||||||
|
<p className="p-8 text-lg text-dark-gray dark:text-white tracking-wide text-center cursor-default">
|
||||||
|
No Task found!
|
||||||
|
</p>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
{taskType == "new" && (
|
||||||
|
<div className="p-4 w-full h-full">
|
||||||
|
<NewTasks
|
||||||
|
formState={formState}
|
||||||
|
setFormState={setFormState}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/*Right Hand Side for details && Task Type === select */}
|
||||||
|
{taskType == "select" && (
|
||||||
|
<>
|
||||||
|
{jobList?.data?.length > 0 ? (
|
||||||
|
<div className="p-4 pt-0 h-full">
|
||||||
|
<div className="w-full">
|
||||||
|
<p className="text-lg font-bold text-dark-gray dark:text-white tracking-wide border-b-2">
|
||||||
|
{activeTask?.data?.title}
|
||||||
|
</p>
|
||||||
|
{/* <div className="my-3">
|
||||||
|
<Detail
|
||||||
|
label="Description"
|
||||||
|
value={activeTask?.data?.description}
|
||||||
|
/>
|
||||||
|
</div> */}
|
||||||
|
<div className="my-3 w-full">
|
||||||
|
<label className="job-label">
|
||||||
|
Description
|
||||||
|
</label>
|
||||||
|
<p className="p-1 text-sm text-slate-900 dark:text-white">
|
||||||
|
{activeTask?.data?.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div className="grid grid-cols-2">
|
||||||
|
<div className="w-full">
|
||||||
|
<div className="my-3 w-full flex items-center gap-1">
|
||||||
|
<label className="job-label">
|
||||||
|
Reward
|
||||||
|
</label>
|
||||||
|
<p className="p-1 text-sm text-slate-900 dark:text-white">
|
||||||
|
{PriceFormatter(
|
||||||
|
activeTask?.data?.price * 0.01,
|
||||||
|
activeTask?.data?.currency,
|
||||||
|
activeTask?.data?.curreny_code
|
||||||
|
)}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div className="my-3 w-full flex items-center gap-1">
|
||||||
|
<label className="job-label">
|
||||||
|
Timeline
|
||||||
|
</label>
|
||||||
|
<p className="p-1 text-sm text-slate-900 dark:text-white">{`${activeTask?.data?.timeline_days} day(s)`}</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div className="w-full flex items-center justify-center">
|
||||||
|
<div className="w-28 h-28 rounded-2xl flex items-center justify-center">
|
||||||
|
<img
|
||||||
|
className="w-full h-auto"
|
||||||
|
loading="lazy"
|
||||||
|
src={imageSrc}
|
||||||
|
alt='job image'
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* Dummy, no value found for created! thus commented*/}
|
||||||
|
{/* <div className="my-3 sm:flex items-center">
|
||||||
|
<Detail
|
||||||
|
label="Created"
|
||||||
|
value={`Dummy, no value found for created!`}
|
||||||
|
/>
|
||||||
|
</div> */}
|
||||||
|
|
||||||
|
<div className="my-3">
|
||||||
|
<label className="w-full job-label">
|
||||||
|
Delivery Detail
|
||||||
|
</label>
|
||||||
|
<textarea
|
||||||
|
className={`p-1 w-full text-sm text-slate-900 dark:text-white bg-transparent outline-none border border-slate-300 rounded-md`}
|
||||||
|
rows="5"
|
||||||
|
style={{ resize: "none" }}
|
||||||
|
value={activeTask?.data?.job_detail}
|
||||||
|
readOnly
|
||||||
|
// onChange={handleInputChange}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
) : (
|
||||||
|
<></>
|
||||||
|
)}
|
||||||
|
</>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* BTN */}
|
||||||
|
<div className="modal-footer-wrapper">
|
||||||
|
{/* error or success display */}
|
||||||
|
<div className="w-auto h-auto flex items-center">
|
||||||
|
{requestStatus.message != "" &&
|
||||||
|
(!requestStatus.status ? (
|
||||||
|
<div
|
||||||
|
className={`relative p-2 text-[#912741] bg-[#fcd9e2] border-[#fbc6d3] rounded-[0.475rem] text-md font-light leading-[19.5px] text-[13px] self-start`}
|
||||||
|
>
|
||||||
|
{requestStatus.message}
|
||||||
|
</div>
|
||||||
|
) : (
|
||||||
|
requestStatus.status && (
|
||||||
|
<div
|
||||||
|
className={`relative p-2 text-green-700 bg-slate-200 border-slate-800 mb-4 rounded-[0.475rem] text-md font-light leading-[19.5px] text-[13px]`}
|
||||||
|
>
|
||||||
|
{requestStatus.message}
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* End of error or success display */}
|
||||||
|
<div className="w-auto h-auto flex items-center gap-20">
|
||||||
|
<button
|
||||||
|
disabled={requestStatus.loading}
|
||||||
|
onClick={()=>closeModal()}
|
||||||
|
type="button"
|
||||||
|
className="custom-btn border-gradient"
|
||||||
|
>
|
||||||
|
<span className="text-gradient">Close</span>
|
||||||
|
</button>
|
||||||
|
<div className="">
|
||||||
|
{requestStatus.loading ? (
|
||||||
|
<LoadingSpinner color="sky-blue" size="8" />
|
||||||
|
) : (
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
disabled={requestStatus.loading}
|
||||||
|
onClick={assignFamilyTask}
|
||||||
|
className="custom-btn btn-gradient text-white"
|
||||||
|
>
|
||||||
|
Assign
|
||||||
|
</button>
|
||||||
|
)
|
||||||
|
// : (
|
||||||
|
// <button
|
||||||
|
// type="button"
|
||||||
|
// disabled={requestStatus.loading}
|
||||||
|
// onClick={assignFamilyTask}
|
||||||
|
// className="px-1 w-40 h-11 flex justify-center items-center btn-gradient text-base rounded-full text-white cursor-pointer"
|
||||||
|
// >
|
||||||
|
// {details
|
||||||
|
// ? `Assign task to ${details?.firstname}`
|
||||||
|
// : familyDetailsData
|
||||||
|
// ? `Assign task to ${familyDetailsData.firstname}`
|
||||||
|
// : "Assign"}
|
||||||
|
// </button>
|
||||||
|
// )
|
||||||
|
}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
</>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -11,17 +11,18 @@ import { NewTasks } from "./forms";
|
|||||||
import { SocketValues } from "../../Contexts/SocketIOContext";
|
import { SocketValues } from "../../Contexts/SocketIOContext";
|
||||||
import { errorMsg } from "../../../lib/errorMsg";
|
import { errorMsg } from "../../../lib/errorMsg";
|
||||||
|
|
||||||
|
import AssignPrevNewTask from "./AssignPrevNewTask";
|
||||||
|
import AssignMediaTask from "./AssignMediaTask";
|
||||||
|
|
||||||
const AssignTaskPopout = ({
|
const AssignTaskPopout = ({
|
||||||
action,
|
action,
|
||||||
details,
|
details,
|
||||||
situation,
|
situation,
|
||||||
familyDetailsData,
|
familyDetailsData,
|
||||||
familyTask,
|
jobList,
|
||||||
activeTask,
|
activeTask,
|
||||||
setActiveTask,
|
setActiveTask,
|
||||||
setUpdatePage,
|
setUpdatePage,
|
||||||
assignTaskChecker,
|
|
||||||
|
|
||||||
}) => {
|
}) => {
|
||||||
const {parentAssignJobToKid} = SocketValues()
|
const {parentAssignJobToKid} = SocketValues()
|
||||||
|
|
||||||
@@ -54,6 +55,21 @@ const AssignTaskPopout = ({
|
|||||||
message: "",
|
message: "",
|
||||||
}); // HOLDS RESPONSE FOR SENDING API REQUEST
|
}); // HOLDS RESPONSE FOR SENDING API REQUEST
|
||||||
|
|
||||||
|
let [commonMedia, setCommonMedia] = useState({loading: true, data: [], image: ''}) // HOLDS COMMON MEDIA DATA
|
||||||
|
let [activeMedia, setActiveMedia] = useState({}) // HOLDS ACTIVE COMMON MEDIA DATA
|
||||||
|
const handleActiveMedia = (data = {}) => {
|
||||||
|
// FUNCTION TO CHANGE SELECTED ACTIVE MEDIA
|
||||||
|
setActiveMedia({...data});
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
let [assignType, setAssignType] = useState("task"); // SWITCHES BTW TASK AND MEDIA ASSIGNMENT
|
||||||
|
|
||||||
|
const switchAssignType = ({ target: { name } }) => {
|
||||||
|
// FUNCTION TO CHANGE ASSIGN TASK TYPE
|
||||||
|
setAssignType(name);
|
||||||
|
};
|
||||||
|
|
||||||
let [taskType, setTaskType] = useState(details ? "new" : "select"); // SWITCHES BTW SELECT TASK AND NEW TASK
|
let [taskType, setTaskType] = useState(details ? "new" : "select"); // SWITCHES BTW SELECT TASK AND NEW TASK
|
||||||
|
|
||||||
const switchTaskType = ({ target: { value } }) => {
|
const switchTaskType = ({ target: { value } }) => {
|
||||||
@@ -90,13 +106,13 @@ const AssignTaskPopout = ({
|
|||||||
}
|
}
|
||||||
|
|
||||||
let reqData = {};
|
let reqData = {};
|
||||||
if (taskType == "select") {
|
if (taskType == "select" && assignType == 'task') {
|
||||||
// RUNS HERE IF TASK TYPE IS SELECT
|
// RUNS HERE IF TASK TYPE IS SELECT
|
||||||
if (!Object.keys(activeTask.data).length) {
|
if (!Object.keys(activeTask.data).length) {
|
||||||
setRequestStatus({
|
setRequestStatus({
|
||||||
loading: false,
|
loading: false,
|
||||||
status: false,
|
status: false,
|
||||||
message: "No Task is seleted",
|
message: "No Task is selected",
|
||||||
});
|
});
|
||||||
return setTimeout(() => {
|
return setTimeout(() => {
|
||||||
setRequestStatus({ loading: false, status: false, message: "" });
|
setRequestStatus({ loading: false, status: false, message: "" });
|
||||||
@@ -114,7 +130,7 @@ const AssignTaskPopout = ({
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
if (taskType === "new") {
|
if (taskType === "new" && assignType == 'task') {
|
||||||
const {
|
const {
|
||||||
banner,
|
banner,
|
||||||
category,
|
category,
|
||||||
@@ -225,10 +241,43 @@ const AssignTaskPopout = ({
|
|||||||
setRequestStatus({ loading: false, status: false, message: "" });
|
setRequestStatus({ loading: false, status: false, message: "" });
|
||||||
}, 5000);
|
}, 5000);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
let imageSrc = (localStorage.getItem("session_token")
|
const closeModal = () => { // FOR CLOSING ASSIGN TASK MODAL
|
||||||
? `${userDetails?.session_image_server}${localStorage.getItem("session_token")}/job/${activeTask.data.job_uid}` : ""); // FOR GETTING JOB IMAGE
|
action()
|
||||||
|
}
|
||||||
|
|
||||||
|
const assignMediaTask = (values, helpers) => { // FUNCTION TO HANDLE ASSIGNING MEDIA TASK
|
||||||
|
setRequestStatus({ loading: true, status: false, message: "" });
|
||||||
|
|
||||||
|
if(!selectedFamilyUid){ // If no family found, throw error
|
||||||
|
setRequestStatus({ loading: false, status: false, message: "Please Select a Kid" });
|
||||||
|
return setTimeout(() => {
|
||||||
|
setRequestStatus({ loading: false, status: false, message: "" });
|
||||||
|
}, 3000);
|
||||||
|
}
|
||||||
|
|
||||||
|
let reqData = {...values, assign_mode:'110012', family_uid:selectedFamilyUid, media_uid:activeMedia.uid, amount:values.amount * 100}
|
||||||
|
|
||||||
|
apiCall.parentAssignMediaTask(reqData).then(res => { // API CALL TO ASSIGN MEDIA TASK
|
||||||
|
if(res.status != 200 || res.data.internal_return < 0){
|
||||||
|
setRequestStatus({ loading: false, status: false, message: "Failed to Assign Task" });
|
||||||
|
return setTimeout(()=>{
|
||||||
|
setRequestStatus({ loading: false, status: false, message: "" });
|
||||||
|
}, 3000)
|
||||||
|
}
|
||||||
|
setRequestStatus({ loading: false, status: true, message: "Task Assigned Successfully" });
|
||||||
|
return setTimeout(()=>{
|
||||||
|
setRequestStatus({ loading: false, status: false, message: "" });
|
||||||
|
closeModal() // FOR CLOSING ASSIGN MODAL
|
||||||
|
}, 3000)
|
||||||
|
}).catch(err => {
|
||||||
|
setRequestStatus({ loading: false, status: false, message: "Failed, something went wrong. Try Again" });
|
||||||
|
return setTimeout(()=>{
|
||||||
|
setRequestStatus({ loading: false, status: false, message: "" });
|
||||||
|
}, 3000)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
useEffect(()=>{ // effect to update family UID when components mounts
|
useEffect(()=>{ // effect to update family UID when components mounts
|
||||||
if(familyDetailsData?.uid){
|
if(familyDetailsData?.uid){
|
||||||
@@ -240,6 +289,15 @@ const AssignTaskPopout = ({
|
|||||||
}
|
}
|
||||||
},[])
|
},[])
|
||||||
|
|
||||||
|
useEffect(()=>{
|
||||||
|
apiCall.getParentCommonMedia().then((res)=>{
|
||||||
|
// console.log('RESPONSE', res)
|
||||||
|
setCommonMedia({loading: false, data: res?.data?.result, image: ''})
|
||||||
|
setActiveMedia(res?.data?.result[0])
|
||||||
|
}).catch(err => {
|
||||||
|
setCommonMedia({loading: false, data: [], image: ''})
|
||||||
|
})
|
||||||
|
},[])
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
@@ -297,238 +355,52 @@ const AssignTaskPopout = ({
|
|||||||
</svg>
|
</svg>
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
{familyTask?.loading ? (
|
<div className="modal-body">
|
||||||
<div className="h-[100px] w-full flex justify-center items-center">
|
<div className="px-4 py-2 w-full flex items-center gap-4">
|
||||||
<LoadingSpinner color="sky-blue" size="16" />
|
<button
|
||||||
</div>
|
name='task'
|
||||||
) : (
|
className={`py-1 px-2 font-medium bg-transparent border border-purple text-purple transition-all rounded-md duration-300 ${assignType=='task' && 'bg-yellow-500'}`}
|
||||||
<>
|
onClick={switchAssignType}
|
||||||
<div
|
disabled={requestStatus.loading}
|
||||||
className={`job-action-modal-body w-full min-h-[450px] max-h-[450px] overflow-y-auto md:grid ${
|
|
||||||
taskType !== "new" ? "md:grid-cols-2" : "md:grid-cols-1"
|
|
||||||
}`}
|
|
||||||
>
|
>
|
||||||
<div className="p-4">
|
Task
|
||||||
<div className="mb-2 w-full flex items-center gap-4">
|
</button>
|
||||||
<div className="flex items-center gap-2 text-sky-blue text-base">
|
<button
|
||||||
<input
|
name='media'
|
||||||
type="radio"
|
className={`py-1 px-2 font-medium bg-transparent border border-purple text-purple transition-all rounded-md duration-300 ${assignType=='media' && 'bg-yellow-500'}`}
|
||||||
name="task-type"
|
onClick={switchAssignType}
|
||||||
value="select"
|
disabled={requestStatus.loading}
|
||||||
className="w-[20px] h-[20px] cursor-pointer"
|
>
|
||||||
checked={taskType == "select"}
|
Media
|
||||||
onChange={switchTaskType}
|
</button>
|
||||||
/>
|
</div>
|
||||||
<span className="text-lg tracking-wide font-semibold">Previous Task</span>
|
<div className="">
|
||||||
</div>
|
{assignType == 'task' ?
|
||||||
<div className="flex items-center gap-2 text-sky-blue text-base">
|
<AssignPrevNewTask
|
||||||
<input
|
jobList={jobList}
|
||||||
type="radio"
|
requestStatus={requestStatus}
|
||||||
name="task-type"
|
assignFamilyTask={assignFamilyTask}
|
||||||
value="new"
|
taskType={taskType}
|
||||||
className="w-[20px] h-[20px] cursor-pointer"
|
switchTaskType={switchTaskType}
|
||||||
checked={taskType == "new"}
|
formState={formState}
|
||||||
onChange={switchTaskType}
|
setFormState={setFormState}
|
||||||
/>
|
activeTask={activeTask}
|
||||||
<span className="text-lg tracking-wide font-semibold">New Task</span>
|
handleActiveTask={handleActiveTask}
|
||||||
</div>
|
closeModal={closeModal}
|
||||||
</div>
|
/>
|
||||||
{/* Task Type === select */}
|
:
|
||||||
{taskType == "select" && (
|
<AssignMediaTask
|
||||||
<div className="p-4 w-full h-[380px] overflow-y-auto bg-slate-100 rounded-md dark:bg-[#11131f] dark:text-white">
|
commonMedia={commonMedia}
|
||||||
{familyTask?.data?.length ? (
|
requestStatus={requestStatus}
|
||||||
familyTask?.data?.map((item, index) => (
|
assignMediaTask={assignMediaTask}
|
||||||
<div
|
activeMedia={activeMedia}
|
||||||
key={item.job_uid}
|
handleActiveMedia={handleActiveMedia}
|
||||||
className="mb-2 flex justify-start items-center gap-2 text-sky-blue text-base cursor-pointer"
|
closeModal={closeModal}
|
||||||
onClick={() => handleActiveTask(item.job_uid, item)}
|
family_uid = {selectedFamilyUid}
|
||||||
>
|
/>
|
||||||
<input
|
}
|
||||||
type="radio"
|
</div>
|
||||||
name="task-list"
|
</div>
|
||||||
checked={
|
|
||||||
activeTask.id == item.job_uid ||
|
|
||||||
(activeTask.id == index && true)
|
|
||||||
}
|
|
||||||
onChange={() =>
|
|
||||||
handleActiveTask(item.job_uid, item)
|
|
||||||
}
|
|
||||||
className="w-[15px] h-[15px] cursor-pointer"
|
|
||||||
/>
|
|
||||||
<p className="w-full text-dark-gray dark:text-white tracking-wide">
|
|
||||||
{item?.title}
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
))
|
|
||||||
) : (
|
|
||||||
<p className="p-8 text-lg text-dark-gray dark:text-white tracking-wide text-center cursor-default">
|
|
||||||
No Task found!
|
|
||||||
</p>
|
|
||||||
)}
|
|
||||||
</div>
|
|
||||||
)}
|
|
||||||
{taskType == "new" && (
|
|
||||||
<div className="p-4 w-full">
|
|
||||||
<NewTasks
|
|
||||||
formState={formState}
|
|
||||||
setFormState={setFormState}
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
)}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{/*Right Hand Side for details && Task Type === select */}
|
|
||||||
{taskType == "select" && (
|
|
||||||
<>
|
|
||||||
{familyTask?.data?.length > 0 ? (
|
|
||||||
<div className="p-4">
|
|
||||||
<div className="w-full">
|
|
||||||
<p className="text-lg font-bold text-dark-gray dark:text-white tracking-wide border-b-2">
|
|
||||||
{activeTask?.data?.title}
|
|
||||||
</p>
|
|
||||||
{/* <div className="my-3">
|
|
||||||
<Detail
|
|
||||||
label="Description"
|
|
||||||
value={activeTask?.data?.description}
|
|
||||||
/>
|
|
||||||
</div> */}
|
|
||||||
<div className="my-3 w-full">
|
|
||||||
<label className="job-label">
|
|
||||||
Description
|
|
||||||
</label>
|
|
||||||
<p className="p-1 text-sm text-slate-900 dark:text-white">
|
|
||||||
{activeTask?.data?.description}
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
<div className="grid grid-cols-2">
|
|
||||||
<div className="w-full">
|
|
||||||
<div className="my-3 w-full flex items-center gap-1">
|
|
||||||
<label className="job-label">
|
|
||||||
Reward
|
|
||||||
</label>
|
|
||||||
<p className="p-1 text-sm text-slate-900 dark:text-white">
|
|
||||||
{PriceFormatter(
|
|
||||||
activeTask?.data?.price * 0.01,
|
|
||||||
activeTask?.data?.currency,
|
|
||||||
activeTask?.data?.curreny_code
|
|
||||||
)}
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div className="my-3 w-full flex items-center gap-1">
|
|
||||||
<label className="job-label">
|
|
||||||
Timeline
|
|
||||||
</label>
|
|
||||||
<p className="p-1 text-sm text-slate-900 dark:text-white">{`${activeTask?.data?.timeline_days} day(s)`}</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div className="w-full flex items-center justify-center">
|
|
||||||
<div className="w-28 h-28 rounded-2xl flex items-center justify-center">
|
|
||||||
<img
|
|
||||||
className="w-full h-auto"
|
|
||||||
loading="lazy"
|
|
||||||
src={imageSrc}
|
|
||||||
alt='job image'
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{/* Dummy, no value found for created! thus commented*/}
|
|
||||||
{/* <div className="my-3 sm:flex items-center">
|
|
||||||
<Detail
|
|
||||||
label="Created"
|
|
||||||
value={`Dummy, no value found for created!`}
|
|
||||||
/>
|
|
||||||
</div> */}
|
|
||||||
|
|
||||||
<div className="my-3">
|
|
||||||
<label className="w-full job-label">
|
|
||||||
Delivery Detail
|
|
||||||
</label>
|
|
||||||
<textarea
|
|
||||||
className={`p-1 w-full text-sm text-slate-900 dark:text-white bg-transparent outline-none border border-slate-300 rounded-md`}
|
|
||||||
rows="5"
|
|
||||||
style={{ resize: "none" }}
|
|
||||||
value={activeTask?.data?.job_detail}
|
|
||||||
readOnly
|
|
||||||
// onChange={handleInputChange}
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
) : (
|
|
||||||
<></>
|
|
||||||
)}
|
|
||||||
</>
|
|
||||||
)}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{/* BTN */}
|
|
||||||
<div className="modal-footer-wrapper">
|
|
||||||
{/* error or success display */}
|
|
||||||
<div className="w-auto h-auto flex items-center">
|
|
||||||
{requestStatus.message != "" &&
|
|
||||||
(!requestStatus.status ? (
|
|
||||||
<div
|
|
||||||
className={`relative p-2 text-[#912741] bg-[#fcd9e2] border-[#fbc6d3] rounded-[0.475rem] text-md font-light leading-[19.5px] text-[13px] self-start`}
|
|
||||||
>
|
|
||||||
{requestStatus.message}
|
|
||||||
</div>
|
|
||||||
) : (
|
|
||||||
requestStatus.status && (
|
|
||||||
<div
|
|
||||||
className={`relative p-2 text-green-700 bg-slate-200 border-slate-800 mb-4 rounded-[0.475rem] text-md font-light leading-[19.5px] text-[13px]`}
|
|
||||||
>
|
|
||||||
{requestStatus.message}
|
|
||||||
</div>
|
|
||||||
)
|
|
||||||
))}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{/* End of error or success display */}
|
|
||||||
<div className="w-auto h-auto flex items-center gap-20">
|
|
||||||
<button
|
|
||||||
disabled={requestStatus.loading}
|
|
||||||
onClick={action}
|
|
||||||
type="button"
|
|
||||||
className="custom-btn border-gradient"
|
|
||||||
>
|
|
||||||
<span className="text-gradient">Close</span>
|
|
||||||
</button>
|
|
||||||
<div className="">
|
|
||||||
{requestStatus.loading ? (
|
|
||||||
<LoadingSpinner color="sky-blue" size="8" />
|
|
||||||
) : (
|
|
||||||
<button
|
|
||||||
type="button"
|
|
||||||
disabled={requestStatus.loading}
|
|
||||||
onClick={assignFamilyTask}
|
|
||||||
className="custom-btn btn-gradient text-white"
|
|
||||||
>
|
|
||||||
Assign
|
|
||||||
</button>
|
|
||||||
)
|
|
||||||
// : (
|
|
||||||
// <button
|
|
||||||
// type="button"
|
|
||||||
// disabled={requestStatus.loading}
|
|
||||||
// onClick={assignFamilyTask}
|
|
||||||
// className="px-1 w-40 h-11 flex justify-center items-center btn-gradient text-base rounded-full text-white cursor-pointer"
|
|
||||||
// >
|
|
||||||
// {details
|
|
||||||
// ? `Assign task to ${details?.firstname}`
|
|
||||||
// : familyDetailsData
|
|
||||||
// ? `Assign task to ${familyDetailsData.firstname}`
|
|
||||||
// : "Assign"}
|
|
||||||
// </button>
|
|
||||||
// )
|
|
||||||
}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</>
|
|
||||||
)}
|
|
||||||
</div>
|
</div>
|
||||||
</ModalCom>
|
</ModalCom>
|
||||||
</>
|
</>
|
||||||
|
|||||||
@@ -1,13 +1,17 @@
|
|||||||
import React, { useEffect, useState } from "react";
|
import React, { useEffect, useState } from "react";
|
||||||
import usersService from "../../../../services/UsersService";
|
import usersService from "../../../../services/UsersService";
|
||||||
import InputCom from "../../../Helpers/Inputs/InputCom";
|
import InputCom from "../../../Helpers/Inputs/InputCom";
|
||||||
|
import { useSelector } from "react-redux";
|
||||||
|
|
||||||
export default function NewTasks({ formState, setFormState }) {
|
export default function NewTasks({ formState, setFormState }) {
|
||||||
let [currency, setCurrency] = useState({
|
|
||||||
loading: true,
|
const { walletDetails } = useSelector((state) => state?.walletDetails); // WALLET STORE
|
||||||
status: false,
|
|
||||||
data: null,
|
// let [currency, setCurrency] = useState({
|
||||||
});
|
// loading: true,
|
||||||
|
// status: false,
|
||||||
|
// data: null,
|
||||||
|
// });
|
||||||
|
|
||||||
const selectImage = require(`../../../../assets/images/taskbanners/${
|
const selectImage = require(`../../../../assets/images/taskbanners/${
|
||||||
formState.banner || "default.jpg"
|
formState.banner || "default.jpg"
|
||||||
@@ -15,25 +19,25 @@ export default function NewTasks({ formState, setFormState }) {
|
|||||||
const ApiCall = new usersService();
|
const ApiCall = new usersService();
|
||||||
|
|
||||||
// FUNCTION TO GET Currency
|
// FUNCTION TO GET Currency
|
||||||
const getUserCurrency = () => {
|
// const getUserCurrency = () => {
|
||||||
setCurrency((prev) => ({ ...prev, loading: true }));
|
// setCurrency((prev) => ({ ...prev, loading: true }));
|
||||||
ApiCall.getUserWallets()
|
// ApiCall.getUserWallets()
|
||||||
.then((res) => {
|
// .then((res) => {
|
||||||
if (res.data.internal_return < 0) {
|
// if (res.data.internal_return < 0) {
|
||||||
setCurrency({ loading: false, status: true, data: [] });
|
// setCurrency({ loading: false, status: true, data: [] });
|
||||||
return;
|
// return;
|
||||||
}
|
// }
|
||||||
|
|
||||||
setCurrency({
|
// setCurrency({
|
||||||
loading: false,
|
// loading: false,
|
||||||
status: true,
|
// status: true,
|
||||||
data: res.data.result_list,
|
// data: res.data.result_list,
|
||||||
});
|
// });
|
||||||
})
|
// })
|
||||||
.catch((err) => {
|
// .catch((err) => {
|
||||||
setCurrency({ loading: false, status: false, data: [] });
|
// setCurrency({ loading: false, status: false, data: [] });
|
||||||
});
|
// });
|
||||||
};
|
// };
|
||||||
|
|
||||||
const handleInputChange = (event) => {
|
const handleInputChange = (event) => {
|
||||||
const { name, value } = event.target;
|
const { name, value } = event.target;
|
||||||
@@ -43,9 +47,9 @@ export default function NewTasks({ formState, setFormState }) {
|
|||||||
}));
|
}));
|
||||||
};
|
};
|
||||||
|
|
||||||
useEffect(() => {
|
// useEffect(() => {
|
||||||
getUserCurrency();
|
// getUserCurrency();
|
||||||
}, []);
|
// }, []);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<form className="w-full flex justify-between items-start">
|
<form className="w-full flex justify-between items-start">
|
||||||
@@ -149,22 +153,22 @@ export default function NewTasks({ formState, setFormState }) {
|
|||||||
onChange={handleInputChange}
|
onChange={handleInputChange}
|
||||||
// onBlur={props.handleBlur}
|
// onBlur={props.handleBlur}
|
||||||
>
|
>
|
||||||
{currency?.loading ? (
|
{walletDetails?.loading ? (
|
||||||
<option className="text-slate-500 text-[13.975px]" value="">
|
<option className="text-slate-500 text-[13.975px]" value="">
|
||||||
Loading...
|
Loading...
|
||||||
</option>
|
</option>
|
||||||
) : currency.data.length ? (
|
) : walletDetails.data.length ? (
|
||||||
<>
|
<>
|
||||||
<option className="text-slate-500 text-[13.975px]" value="">
|
<option className="text-slate-500 text-[13.975px]" value="">
|
||||||
Currency
|
Currency
|
||||||
</option>
|
</option>
|
||||||
{currency.data?.map((item, index) => (
|
{walletDetails.data?.map((item, index) => (
|
||||||
<option
|
<option
|
||||||
key={index}
|
key={index}
|
||||||
className="text-slate-500 text-lg"
|
className="text-slate-500 text-lg"
|
||||||
value={item?.country}
|
value={item?.country}
|
||||||
>
|
>
|
||||||
{item?.description}
|
{item?.code}
|
||||||
</option>
|
</option>
|
||||||
))}
|
))}
|
||||||
</>
|
</>
|
||||||
|
|||||||
@@ -13,59 +13,42 @@ const FamilyPending = lazy(() => import("./Tabs/FamilyNewPending"));
|
|||||||
|
|
||||||
export default function FamilyTableNew() {
|
export default function FamilyTableNew() {
|
||||||
|
|
||||||
const { parentFamilyTaskList } = useSelector((state) => state.tableReload);
|
const { jobListTable, pendingListTable, parentFamilyTaskList } = useSelector((state) => state.tableReload); // TABLE RELOAD TRIGGERS
|
||||||
console.log('parentFamilyTaskList', parentFamilyTaskList)
|
|
||||||
|
|
||||||
let { pathname } = useLocation();
|
let { pathname } = useLocation();
|
||||||
|
|
||||||
// Initial state for family details
|
// Initial state for family details
|
||||||
const initialDetailState = {
|
const initialDetailState = {
|
||||||
loading: true,
|
loading: false,
|
||||||
data: null,
|
data: [],
|
||||||
link: "",
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const [assignTaskChecker, setAssignTaskChecker] = useState(false);
|
|
||||||
|
|
||||||
// console.log('accountDetails',accountDetails)
|
|
||||||
// State for family details, tasks, waitlist, and pending
|
// State for family details, tasks, waitlist, and pending
|
||||||
const [details, setDetails] = useState({
|
let [familyTasks, setFamilyTasks] = useState({...initialDetailState})
|
||||||
familyDetails: { ...initialDetailState },
|
|
||||||
familyTasks: { ...initialDetailState },
|
|
||||||
familyWaitList: { ...initialDetailState },
|
|
||||||
familyPending: { ...initialDetailState },
|
|
||||||
});
|
|
||||||
|
|
||||||
// Function to reset family details, tasks, waitlist, and pending
|
let [familyPending, setFamilyPending] = useState({...initialDetailState})
|
||||||
const resetDetails = () => {
|
|
||||||
setDetails({
|
let [familyWaitList, setFamilyWaitList] = useState({...initialDetailState})
|
||||||
familyDetails: { ...initialDetailState },
|
|
||||||
familyTasks: { ...initialDetailState },
|
|
||||||
familyWaitList: { ...initialDetailState },
|
|
||||||
familyPending: { ...initialDetailState },
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const [updatePage, setUpdatePage] = useState(false); // State to determine when to update the page
|
const [updatePage, setUpdatePage] = useState(false); // State to determine when to update the page
|
||||||
|
|
||||||
// State for family task data
|
// State for list of created jobs by FULL USER
|
||||||
const [familyTask, setFamilyTask] = useState({ loading: false, data: [] });
|
const [jobList, setJobList] = useState({ loading: false, data: [] });
|
||||||
|
|
||||||
// State for active task
|
// State for active/selected job
|
||||||
const [activeTask, setActiveTask] = useState({ id: 0, data: {} });
|
const [activeTask, setActiveTask] = useState({ id: 0, data: {} });
|
||||||
|
|
||||||
// State for error messages
|
|
||||||
const [errMsg, setErrMsg] = useState("");
|
|
||||||
|
|
||||||
// State for family task popout
|
// State for family task popout
|
||||||
const [familyTaskPopout, setFamilyTaskPopout] = useState(false);
|
const [assignTaskPopout, setAssignTaskPopout] = useState(false);
|
||||||
|
|
||||||
|
|
||||||
// Create an instance of the usersService class
|
// Create an instance of the usersService class
|
||||||
const apiCall = useMemo(() => new usersService(), []);
|
const apiCall = useMemo(() => new usersService(), []);
|
||||||
|
|
||||||
// Function to handle toggling the family task popout
|
// Function to handle toggling the family task popout
|
||||||
const familyPopUpHandler = () => {
|
const familyAssignPopUpHandler = () => {
|
||||||
setFamilyTaskPopout((prev) => !prev);
|
setAssignTaskPopout((prev) => !prev);
|
||||||
};
|
};
|
||||||
|
|
||||||
// Array of tab names
|
// Array of tab names
|
||||||
@@ -87,26 +70,19 @@ export default function FamilyTableNew() {
|
|||||||
const tabComponents = {
|
const tabComponents = {
|
||||||
Tasks: (
|
Tasks: (
|
||||||
<FamilyTasks
|
<FamilyTasks
|
||||||
image_link={details.familyTasks.link}
|
familyData={familyTasks}
|
||||||
loader={details.familyTasks.loading}
|
action={familyAssignPopUpHandler}
|
||||||
familyData={details.familyTasks.data}
|
|
||||||
action={familyPopUpHandler}
|
|
||||||
setAssignTaskChecker={setAssignTaskChecker}
|
|
||||||
/>
|
/>
|
||||||
),
|
),
|
||||||
Waiting: (
|
Waiting: (
|
||||||
<FamilyWaitlist
|
<FamilyWaitlist
|
||||||
image_link={details.familyWaitList.link}
|
familyData={familyWaitList}
|
||||||
familyData={details.familyWaitList.data}
|
|
||||||
loader={details.familyWaitList.loading}
|
|
||||||
setUpdatePage={setUpdatePage}
|
setUpdatePage={setUpdatePage}
|
||||||
/>
|
/>
|
||||||
),
|
),
|
||||||
Pending: (
|
Pending: (
|
||||||
<FamilyPending
|
<FamilyPending
|
||||||
image_link={details.familyPending.link}
|
familyData={familyPending}
|
||||||
familyData={details.familyPending.data}
|
|
||||||
loader={details.familyPending.loading}
|
|
||||||
/>
|
/>
|
||||||
),
|
),
|
||||||
};
|
};
|
||||||
@@ -116,83 +92,66 @@ export default function FamilyTableNew() {
|
|||||||
// Selected tab component based on the current 'tab'
|
// Selected tab component based on the current 'tab'
|
||||||
const selectedTabComponent = tabComponents[tab] || defaultTabComponent;
|
const selectedTabComponent = tabComponents[tab] || defaultTabComponent;
|
||||||
|
|
||||||
// Effect to manage family details and related data
|
|
||||||
|
// Effect to manage active family task details
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const manageFamily = async () => {
|
const manageTasks = async () => {
|
||||||
|
setFamilyTasks({loading:true, data: []})
|
||||||
try {
|
try {
|
||||||
// resetDetails();
|
const response = await apiCall.getMyActiveJobList()
|
||||||
|
if(response.status != 200 || !response?.data){
|
||||||
// setDetails({
|
return setFamilyTasks({loading:false, data: []})
|
||||||
// familyTasks: { loading: true },
|
|
||||||
// familyWaitList: { loading: true },
|
|
||||||
// familyPending: { loading: true },
|
|
||||||
// });
|
|
||||||
|
|
||||||
// const { family_uid } = accountDetails;
|
|
||||||
// const reqData = { family_uid };
|
|
||||||
|
|
||||||
const [familyTasksData, familyWaitingRes, familyPendingRes] =
|
|
||||||
await Promise.all([
|
|
||||||
apiCall.getMyActiveJobList(),
|
|
||||||
apiCall.ManageFamilyNewWaitlist(),
|
|
||||||
apiCall.ManageFamilyPending(),
|
|
||||||
]);
|
|
||||||
|
|
||||||
let tasksData = familyTasksData?.data?.result_list;
|
|
||||||
let _familyWaitData = familyWaitingRes?.data?.result_list;
|
|
||||||
let familyPendingData = familyPendingRes?.data?.result_list;
|
|
||||||
|
|
||||||
// Getting the image server link
|
|
||||||
let imageServerLink = familyWaitingRes.data?.session_image_server;
|
|
||||||
|
|
||||||
// Function to check for errors in data
|
|
||||||
const checkDataError = (data) => data?.internal_return < 0;
|
|
||||||
|
|
||||||
if (
|
|
||||||
checkDataError(tasksData) ||
|
|
||||||
checkDataError(_familyWaitData) ||
|
|
||||||
checkDataError(familyPendingData)
|
|
||||||
) {
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
setFamilyTasks({loading:false, data: response?.data})
|
||||||
setDetails({
|
|
||||||
familyTasks: {
|
|
||||||
loading: false,
|
|
||||||
data: tasksData,
|
|
||||||
link: imageServerLink,
|
|
||||||
},
|
|
||||||
familyWaitList: {
|
|
||||||
loading: false,
|
|
||||||
data: _familyWaitData,
|
|
||||||
link: imageServerLink,
|
|
||||||
},
|
|
||||||
familyPending: {
|
|
||||||
loading: false,
|
|
||||||
data: familyPendingData,
|
|
||||||
link: imageServerLink,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
// resetDetails();
|
|
||||||
setDetails({
|
|
||||||
familyDetails: { ...initialDetailState, loading: false, },
|
|
||||||
familyTasks: { ...initialDetailState, loading: false, },
|
|
||||||
familyWaitList: { ...initialDetailState, loading: false,},
|
|
||||||
familyPending: { ...initialDetailState, loading: false, },
|
|
||||||
})
|
|
||||||
setErrMsg("An error occurred");
|
|
||||||
throw new Error(error);
|
throw new Error(error);
|
||||||
|
setFamilyTasks({loading:false, data: []})
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// Invoke the manageFamily function when the component mounts
|
// Invoke the manageFamily function when the component mounts
|
||||||
manageFamily();
|
manageTasks();
|
||||||
}, [updatePage, parentFamilyTaskList]);
|
}, [updatePage, parentFamilyTaskList]);
|
||||||
|
|
||||||
// Effect to manage family tasks
|
// Effect to manage family wait task details
|
||||||
|
useEffect(() => {
|
||||||
|
const manageFamilyWaitlist = async () => {
|
||||||
|
setFamilyWaitList({loading:true, data: []})
|
||||||
|
try {
|
||||||
|
const response = await apiCall.ManageFamilyWaitlist()
|
||||||
|
if(response.status != 200 || !response?.data){
|
||||||
|
return setFamilyWaitList({loading:false, data: []})
|
||||||
|
}
|
||||||
|
setFamilyWaitList({loading:false, data: response?.data})
|
||||||
|
} catch (error) {
|
||||||
|
throw new Error(error);
|
||||||
|
setFamilyWaitList({loading:false, data: []})
|
||||||
|
}
|
||||||
|
};
|
||||||
|
// Invoke the manageFamily function when the component mounts
|
||||||
|
manageFamilyWaitlist();
|
||||||
|
}, [updatePage]);
|
||||||
|
|
||||||
|
// Effect to manage family pending task details
|
||||||
|
useEffect(() => {
|
||||||
|
const manageFamilyPending = async () => {
|
||||||
|
setFamilyPending({loading:true, data: []})
|
||||||
|
try {
|
||||||
|
const response = await apiCall.ManageFamilyPending()
|
||||||
|
if(response.status != 200 || !response?.data){
|
||||||
|
return setFamilyPending({loading:false, data: []})
|
||||||
|
}
|
||||||
|
setFamilyPending({loading:false, data: response?.data})
|
||||||
|
} catch (error) {
|
||||||
|
throw new Error(error);
|
||||||
|
setFamilyPending({loading:false, data: []})
|
||||||
|
}
|
||||||
|
};
|
||||||
|
// Invoke the manageFamily function when the component mounts
|
||||||
|
manageFamilyPending();
|
||||||
|
}, [updatePage, pendingListTable]);
|
||||||
|
|
||||||
|
// Effect to get all parent job list
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
let checkFamilyTask = true;
|
|
||||||
const reqData = {
|
const reqData = {
|
||||||
limit: 30,
|
limit: 30,
|
||||||
offset: 0,
|
offset: 0,
|
||||||
@@ -200,12 +159,11 @@ export default function FamilyTableNew() {
|
|||||||
action: apiConst.WRENCHBOARD_PICTURE_FAMMEMBER,
|
action: apiConst.WRENCHBOARD_PICTURE_FAMMEMBER,
|
||||||
};
|
};
|
||||||
|
|
||||||
if (checkFamilyTask) {
|
setJobList({ loading: true });
|
||||||
setFamilyTask({ loading: true });
|
|
||||||
apiCall
|
apiCall
|
||||||
.getMyJobList(reqData)
|
.getMyJobList(reqData)
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
setFamilyTask({ loading: false, data: res?.data?.result_list });
|
setJobList({ loading: false, data: res?.data?.result_list });
|
||||||
if (res?.data?.result_list?.length) {
|
if (res?.data?.result_list?.length) {
|
||||||
setActiveTask((prev) => ({
|
setActiveTask((prev) => ({
|
||||||
...prev,
|
...prev,
|
||||||
@@ -214,15 +172,9 @@ export default function FamilyTableNew() {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
setFamilyTask({ loading: false, data: [] });
|
setJobList({ loading: false, data: [] });
|
||||||
console.log("Error", err);
|
console.log("Error", err);
|
||||||
});
|
});
|
||||||
}
|
|
||||||
|
|
||||||
// Cleanup function to prevent memory leaks
|
|
||||||
return () => {
|
|
||||||
checkFamilyTask = false;
|
|
||||||
};
|
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
// console.log(updatePage);
|
// console.log(updatePage);
|
||||||
@@ -260,7 +212,7 @@ export default function FamilyTableNew() {
|
|||||||
</ul>
|
</ul>
|
||||||
<button
|
<button
|
||||||
type="button"
|
type="button"
|
||||||
onClick={familyPopUpHandler}
|
onClick={familyAssignPopUpHandler}
|
||||||
className="p-1 my-1 w-[100px] flex justify-center items-center btn-gradient text-base rounded-full text-white"
|
className="p-1 my-1 w-[100px] flex justify-center items-center btn-gradient text-base rounded-full text-white"
|
||||||
>
|
>
|
||||||
Add task
|
Add task
|
||||||
@@ -282,20 +234,18 @@ export default function FamilyTableNew() {
|
|||||||
</Suspense>
|
</Suspense>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{familyTaskPopout && (
|
{assignTaskPopout && (
|
||||||
<AssignTaskPopout
|
<AssignTaskPopout
|
||||||
action={familyPopUpHandler}
|
action={familyAssignPopUpHandler}
|
||||||
situation={familyTaskPopout}
|
situation={assignTaskPopout}
|
||||||
familyTask={familyTask}
|
jobList={jobList}
|
||||||
setFamilyTask={setFamilyTask}
|
|
||||||
setActiveTask={setActiveTask}
|
setActiveTask={setActiveTask}
|
||||||
activeTask={activeTask}
|
activeTask={activeTask}
|
||||||
|
familyDetailsData={''}
|
||||||
setUpdatePage={setUpdatePage}
|
setUpdatePage={setUpdatePage}
|
||||||
// updateFamilyPendingTable={updateFamilyPendingTable}
|
|
||||||
pathname={pathname}
|
|
||||||
assignTaskChecker={assignTaskChecker}
|
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import QRCode from "react-qr-code";
|
|||||||
import { useSelector } from "react-redux";
|
import { useSelector } from "react-redux";
|
||||||
import LoadingSpinner from "../../Spinners/LoadingSpinner";
|
import LoadingSpinner from "../../Spinners/LoadingSpinner";
|
||||||
|
|
||||||
const FamilyAccount = forwardRef(({ familyData, myRef, handlePrint, loader }, ref) => {
|
const FamilyAccount = forwardRef(({ familyData, myRef, handlePrint}, ref) => {
|
||||||
const { userDetails } = useSelector((state) => state.userDetails);
|
const { userDetails } = useSelector((state) => state.userDetails);
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
@@ -16,13 +16,13 @@ const FamilyAccount = forwardRef(({ familyData, myRef, handlePrint, loader }, re
|
|||||||
<h2 className="font-bold text-lg tracking-wide line-clamp-1 text-dark-gray dark:text-white capitalize">
|
<h2 className="font-bold text-lg tracking-wide line-clamp-1 text-dark-gray dark:text-white capitalize">
|
||||||
Username:{" "}
|
Username:{" "}
|
||||||
<span className="ml-2 normal-case">
|
<span className="ml-2 normal-case">
|
||||||
{familyData?.username ? familyData?.username : "please wait..."}
|
{familyData?.data?.username ? familyData?.data?.username : "please wait..."}
|
||||||
</span>
|
</span>
|
||||||
</h2>
|
</h2>
|
||||||
<h2 className="font-bold text-lg tracking-wide line-clamp-1 text-dark-gray dark:text-white capitalize">
|
<h2 className="font-bold text-lg tracking-wide line-clamp-1 text-dark-gray dark:text-white capitalize">
|
||||||
Pin:{" "}
|
Pin:{" "}
|
||||||
<span className="ml-2 normal-case">
|
<span className="ml-2 normal-case">
|
||||||
{familyData?.pin ? familyData?.pin : "please wait..."}
|
{familyData?.data?.pin ? familyData?.data?.pin : "please wait..."}
|
||||||
</span>
|
</span>
|
||||||
</h2>
|
</h2>
|
||||||
</div>
|
</div>
|
||||||
@@ -35,7 +35,7 @@ const FamilyAccount = forwardRef(({ familyData, myRef, handlePrint, loader }, re
|
|||||||
<p className="text-xl tracking-wide mb-[15px] text-center font-bold text-dark-gray dark:text-white">
|
<p className="text-xl tracking-wide mb-[15px] text-center font-bold text-dark-gray dark:text-white">
|
||||||
Scan the code from mobile app
|
Scan the code from mobile app
|
||||||
</p>
|
</p>
|
||||||
{loader ?
|
{familyData.loading ?
|
||||||
<div className="w-full">
|
<div className="w-full">
|
||||||
<LoadingSpinner size='8' color='sky-blue' />
|
<LoadingSpinner size='8' color='sky-blue' />
|
||||||
</div>
|
</div>
|
||||||
@@ -44,7 +44,7 @@ const FamilyAccount = forwardRef(({ familyData, myRef, handlePrint, loader }, re
|
|||||||
size={256}
|
size={256}
|
||||||
style={{ height: "auto", maxWidth: "100%", width: "100%" }}
|
style={{ height: "auto", maxWidth: "100%", width: "100%" }}
|
||||||
// value={`https://www.google.com`}
|
// value={`https://www.google.com`}
|
||||||
value={`${userDetails?.uid}@${familyData?.username}@${familyData?.uid}`}
|
value={`${userDetails?.uid}@${familyData?.data?.username}@${familyData?.data?.uid}`}
|
||||||
viewBox={`0 0 256 256`}
|
viewBox={`0 0 256 256`}
|
||||||
/>
|
/>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,13 +2,14 @@ import { useMemo, useState } from "react";
|
|||||||
import { PriceFormatter } from "../../Helpers/PriceFormatter";
|
import { PriceFormatter } from "../../Helpers/PriceFormatter";
|
||||||
import { PaginatedList, handlePagingFunc } from "../../Pagination";
|
import { PaginatedList, handlePagingFunc } from "../../Pagination";
|
||||||
import PendingJobsPopout from "../../jobPopout/PendingJobsPopout";
|
import PendingJobsPopout from "../../jobPopout/PendingJobsPopout";
|
||||||
|
import LoadingSpinner from "../../Spinners/LoadingSpinner";
|
||||||
|
|
||||||
export default function FamilyPending({ familyData, image_link, loader }) {
|
export default function FamilyPending({ familyData }) {
|
||||||
let [jobPopout, setJobPopout] = useState({ show: false, data: {} }); // STATE TO HOLD THE VALUE OF THE ALERT DETAILS AND DETERMINE WHEN TO SHOW
|
let [jobPopout, setJobPopout] = useState({ show: false, data: {} }); // STATE TO HOLD THE VALUE OF THE ALERT DETAILS AND DETERMINE WHEN TO SHOW
|
||||||
|
|
||||||
let filteredFamilyData = useMemo(
|
let filteredFamilyData = useMemo(
|
||||||
() => familyData?.filter((data) => data.family_uid !== ""),
|
() => familyData?.data?.result_list?.filter((data) => data.family_uid !== ""),
|
||||||
[familyData]
|
[familyData?.data?.result_list]
|
||||||
);
|
);
|
||||||
|
|
||||||
const [currentPage, setCurrentPage] = useState(0);
|
const [currentPage, setCurrentPage] = useState(0);
|
||||||
@@ -25,13 +26,18 @@ export default function FamilyPending({ familyData, image_link, loader }) {
|
|||||||
handlePagingFunc(e, setCurrentPage);
|
handlePagingFunc(e, setCurrentPage);
|
||||||
};
|
};
|
||||||
|
|
||||||
console.log(image_link);
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
className={`update-table w-full p-3 bg-white dark:bg-dark-white overflow-hidden rounded-2xl section-shadow lg:min-h-[538px]`}
|
className={`update-table w-full p-3 bg-white dark:bg-dark-white overflow-hidden rounded-2xl section-shadow lg:min-h-[538px]`}
|
||||||
>
|
>
|
||||||
{familyData && (
|
{familyData.loading ?
|
||||||
|
(<div className="w-full h-full flex justify-center items-center">
|
||||||
|
<LoadingSpinner size={16} color="sky-blue" height='h-[30rem]' />
|
||||||
|
</div>
|
||||||
|
):
|
||||||
|
<>
|
||||||
|
{familyData?.data?.result_list && (
|
||||||
<div className="relative w-full overflow-x-auto sm:rounded-lg flex flex-col justify-between h-full">
|
<div className="relative w-full overflow-x-auto sm:rounded-lg flex flex-col justify-between h-full">
|
||||||
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
|
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
|
||||||
<tbody>
|
<tbody>
|
||||||
@@ -45,7 +51,7 @@ export default function FamilyPending({ familyData, image_link, loader }) {
|
|||||||
value?.currency_code,
|
value?.currency_code,
|
||||||
value?.currency
|
value?.currency
|
||||||
);
|
);
|
||||||
let image = `${image_link}${localStorage.getItem(
|
let image = `${familyData?.data?.session_image_server}${localStorage.getItem(
|
||||||
"session_token"
|
"session_token"
|
||||||
)}/job/${value.job_uid}`;
|
)}/job/${value.job_uid}`;
|
||||||
return (
|
return (
|
||||||
@@ -137,7 +143,8 @@ export default function FamilyPending({ familyData, image_link, loader }) {
|
|||||||
{/* END OF PAGINATION BUTTON */}
|
{/* END OF PAGINATION BUTTON */}
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
|
</>
|
||||||
|
}
|
||||||
{/* Active Job Popout */}
|
{/* Active Job Popout */}
|
||||||
{jobPopout.show && (
|
{jobPopout.show && (
|
||||||
<PendingJobsPopout
|
<PendingJobsPopout
|
||||||
|
|||||||
@@ -9,17 +9,15 @@ import LoadingSpinner from "../../Spinners/LoadingSpinner";
|
|||||||
export default function FamilyNewTasks({
|
export default function FamilyNewTasks({
|
||||||
familyData,
|
familyData,
|
||||||
className,
|
className,
|
||||||
loader,
|
|
||||||
action,
|
action,
|
||||||
image_link,
|
|
||||||
}) {
|
}) {
|
||||||
let navigate = useNavigate();
|
let navigate = useNavigate();
|
||||||
let { pathname } = useLocation();
|
let { pathname } = useLocation();
|
||||||
|
|
||||||
// ...
|
// ...
|
||||||
let filteredFamilyData = useMemo(
|
let filteredFamilyData = useMemo(
|
||||||
() => familyData?.filter((data) => data.family_uid !== ""),
|
() => familyData?.data?.result_list?.filter((data) => data.family_uid !== ""),
|
||||||
[familyData]
|
[familyData?.data?.result_list]
|
||||||
);
|
);
|
||||||
|
|
||||||
const [currentPage, setCurrentPage] = useState(0);
|
const [currentPage, setCurrentPage] = useState(0);
|
||||||
@@ -36,22 +34,22 @@ export default function FamilyNewTasks({
|
|||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
className={`update-table w-full bg-white dark:bg-dark-white h-full lg:min-h-[538px] overflow-hidden rounded-2xl section-shadow p-3 ${
|
className={`update-table w-full bg-white dark:bg-dark-white h-full lg:min-h-[538px] overflow-hidden rounded-2xl section-shadow p-3 ${
|
||||||
familyData?.length <= 0 && "flex items-center justify-center"
|
familyData?.data?.result_list?.length <= 0 && "flex items-center justify-center"
|
||||||
}`}
|
}`}
|
||||||
>
|
>
|
||||||
{loader ? (
|
{familyData.loading ? (
|
||||||
<div className="w-full h-full flex justify-center items-center lg:min-h-[470px]">
|
<div className="w-full h-full flex justify-center items-center">
|
||||||
<LoadingSpinner size={16} color="sky-blue" />
|
<LoadingSpinner size={16} color="sky-blue" height='h-[30rem]' />
|
||||||
</div>
|
</div>
|
||||||
) : (
|
) : (
|
||||||
<>
|
<>
|
||||||
{familyData && (
|
{familyData?.data?.result_list && (
|
||||||
<div className="relative w-full overflow-x-auto sm:rounded-lg flex flex-col justify-between h-full">
|
<div className="relative w-full overflow-x-auto sm:rounded-lg flex flex-col justify-between h-full">
|
||||||
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
|
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
|
||||||
<tbody>
|
<tbody>
|
||||||
{
|
{
|
||||||
<>
|
<>
|
||||||
{familyData?.length <= 0 ? (
|
{familyData?.data?.result_list?.length <= 0 ? (
|
||||||
<tr>
|
<tr>
|
||||||
<td
|
<td
|
||||||
colSpan="2"
|
colSpan="2"
|
||||||
@@ -76,7 +74,7 @@ export default function FamilyNewTasks({
|
|||||||
value?.currency_code,
|
value?.currency_code,
|
||||||
value?.currency
|
value?.currency
|
||||||
);
|
);
|
||||||
let image = `${image_link}${localStorage.getItem(
|
let image = `${familyData?.data?.result_list}${localStorage.getItem(
|
||||||
"session_token"
|
"session_token"
|
||||||
)}/job/${value.job_uid}`;
|
)}/job/${value.job_uid}`;
|
||||||
return (
|
return (
|
||||||
|
|||||||
@@ -8,8 +8,6 @@ import Icons from "../../Helpers/Icons";
|
|||||||
const FamilyNewWaitlist = ({
|
const FamilyNewWaitlist = ({
|
||||||
familyData,
|
familyData,
|
||||||
className,
|
className,
|
||||||
accountDetails,
|
|
||||||
loader,
|
|
||||||
setUpdatePage
|
setUpdatePage
|
||||||
}) => {
|
}) => {
|
||||||
const [popUp, setPopUp] = useState({ show: false, data: {} });
|
const [popUp, setPopUp] = useState({ show: false, data: {} });
|
||||||
@@ -22,7 +20,7 @@ const FamilyNewWaitlist = ({
|
|||||||
const itemsPerPage = Number(process.env.REACT_APP_ITEM_PER_PAGE);
|
const itemsPerPage = Number(process.env.REACT_APP_ITEM_PER_PAGE);
|
||||||
const indexOfFirstItem = currentPage;
|
const indexOfFirstItem = currentPage;
|
||||||
const indexOfLastItem = currentPage + itemsPerPage;
|
const indexOfLastItem = currentPage + itemsPerPage;
|
||||||
const currentTask = familyData?.slice(
|
const currentTask = familyData?.data?.result_list?.slice(
|
||||||
indexOfFirstItem,
|
indexOfFirstItem,
|
||||||
indexOfLastItem
|
indexOfLastItem
|
||||||
);
|
);
|
||||||
@@ -53,13 +51,13 @@ const FamilyNewWaitlist = ({
|
|||||||
className || ""
|
className || ""
|
||||||
}`}
|
}`}
|
||||||
>
|
>
|
||||||
{loader ? (
|
{familyData.loading ? (
|
||||||
<div className="w-full h-full flex justify-center items-center lg:min-h-[470px]">
|
<div className="w-full h-full flex justify-center items-center">
|
||||||
<LoadingSpinner size={16} color="sky-blue" />
|
<LoadingSpinner size={16} color="sky-blue" height='h-[30rem]' />
|
||||||
</div>
|
</div>
|
||||||
) : (
|
) : (
|
||||||
<>
|
<>
|
||||||
{familyData && (
|
{familyData?.data?.result_list && (
|
||||||
<div className="relative w-full overflow-x-auto sm:rounded-lg flex flex-col justify-between h-full">
|
<div className="relative w-full overflow-x-auto sm:rounded-lg flex flex-col justify-between h-full">
|
||||||
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
|
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
|
||||||
<tbody>
|
<tbody>
|
||||||
@@ -69,7 +67,7 @@ const FamilyNewWaitlist = ({
|
|||||||
value?.banner || "default.jpg"
|
value?.banner || "default.jpg"
|
||||||
}`);
|
}`);
|
||||||
// console.log("VALUE", value);
|
// console.log("VALUE", value);
|
||||||
// let image = `${familyData.session_image_server}${localStorage.getItem('session_token')}/job/${value.job_uid}`
|
// let image = `${familyData?.data?.session_image_server}${localStorage.getItem('session_token')}/job/${value.job_uid}`
|
||||||
return (
|
return (
|
||||||
<tr
|
<tr
|
||||||
className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50"
|
className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50"
|
||||||
@@ -121,8 +119,8 @@ const FamilyNewWaitlist = ({
|
|||||||
<PaginatedList
|
<PaginatedList
|
||||||
onClick={handlePagination}
|
onClick={handlePagination}
|
||||||
prev={currentPage === 0}
|
prev={currentPage === 0}
|
||||||
next={currentPage + itemsPerPage >= familyData?.length}
|
next={currentPage + itemsPerPage >= familyData?.data?.result_list?.length}
|
||||||
data={familyData}
|
data={familyData?.data?.result_list}
|
||||||
start={indexOfFirstItem}
|
start={indexOfFirstItem}
|
||||||
stop={indexOfLastItem}
|
stop={indexOfLastItem}
|
||||||
/>
|
/>
|
||||||
|
|||||||
@@ -3,21 +3,23 @@ import localImgLoad from "../../../lib/localImgLoad";
|
|||||||
import { PriceFormatter } from "../../Helpers/PriceFormatter";
|
import { PriceFormatter } from "../../Helpers/PriceFormatter";
|
||||||
import { PaginatedList, handlePagingFunc } from "../../Pagination";
|
import { PaginatedList, handlePagingFunc } from "../../Pagination";
|
||||||
import PendingJobsPopout from "../../jobPopout/PendingJobsPopout";
|
import PendingJobsPopout from "../../jobPopout/PendingJobsPopout";
|
||||||
|
import LoadingSpinner from "../../Spinners/LoadingSpinner";
|
||||||
|
|
||||||
export default function FamilyPending({
|
export default function FamilyPending({
|
||||||
familyData,
|
familyData,
|
||||||
className,
|
className,
|
||||||
accountDetails,
|
accountDetails,
|
||||||
loader,
|
loader,
|
||||||
|
setUpdatePage,
|
||||||
}) {
|
}) {
|
||||||
let [jobPopout, setJobPopout] = useState({ show: false, data: {} }); // STATE TO HOLD THE VALUE OF THE ALERT DETAILS AND DETERMINE WHEN TO SHOW
|
let [jobPopout, setJobPopout] = useState({ show: false, data: {} }); // STATE TO HOLD THE VALUE OF THE ALERT DETAILS AND DETERMINE WHEN TO SHOW
|
||||||
|
|
||||||
let filteredFamilyData = useMemo(
|
let filteredFamilyData = useMemo(
|
||||||
() =>
|
() =>
|
||||||
familyData?.result_list?.filter(
|
familyData?.data?.result_list?.filter(
|
||||||
(data) => data?.family_uid === accountDetails?.family_uid
|
(data) => data?.family_uid === accountDetails?.family_uid
|
||||||
),
|
),
|
||||||
[accountDetails?.family_uid, familyData?.result_list]
|
[accountDetails?.family_uid, familyData?.data?.result_list]
|
||||||
);
|
);
|
||||||
|
|
||||||
const [currentPage, setCurrentPage] = useState(0);
|
const [currentPage, setCurrentPage] = useState(0);
|
||||||
@@ -40,6 +42,12 @@ export default function FamilyPending({
|
|||||||
className || ""
|
className || ""
|
||||||
}`}
|
}`}
|
||||||
>
|
>
|
||||||
|
{familyData.loading ?
|
||||||
|
(<div className="w-full h-full flex justify-center items-center">
|
||||||
|
<LoadingSpinner size={16} color="sky-blue" height='h-[30rem]' />
|
||||||
|
</div>
|
||||||
|
):
|
||||||
|
<>
|
||||||
{filteredFamilyData && (
|
{filteredFamilyData && (
|
||||||
<div className="relative w-full overflow-x-auto sm:rounded-lg flex flex-col justify-between h-full">
|
<div className="relative w-full overflow-x-auto sm:rounded-lg flex flex-col justify-between h-full">
|
||||||
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
|
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
|
||||||
@@ -54,7 +62,7 @@ export default function FamilyPending({
|
|||||||
value?.currency_code,
|
value?.currency_code,
|
||||||
value?.currency
|
value?.currency
|
||||||
);
|
);
|
||||||
let image = `${familyData.session_image_server}${localStorage.getItem('session_token')}/job/${value.job_uid}`
|
let image = `${familyData.data.session_image_server}${localStorage.getItem('session_token')}/job/${value.job_uid}`
|
||||||
return (
|
return (
|
||||||
<tr
|
<tr
|
||||||
key={index}
|
key={index}
|
||||||
@@ -144,6 +152,8 @@ export default function FamilyPending({
|
|||||||
{/* END OF PAGINATION BUTTON */}
|
{/* END OF PAGINATION BUTTON */}
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
|
</>
|
||||||
|
}
|
||||||
|
|
||||||
{/* Active Job Popout */}
|
{/* Active Job Popout */}
|
||||||
{jobPopout.show && (
|
{jobPopout.show && (
|
||||||
@@ -151,6 +161,7 @@ export default function FamilyPending({
|
|||||||
details={jobPopout.data}
|
details={jobPopout.data}
|
||||||
onClose={() => {
|
onClose={() => {
|
||||||
setJobPopout({ show: false, data: {} });
|
setJobPopout({ show: false, data: {} });
|
||||||
|
setUpdatePage(prev => !prev);
|
||||||
}}
|
}}
|
||||||
situation={jobPopout.show}
|
situation={jobPopout.show}
|
||||||
/>
|
/>
|
||||||
|
|||||||
@@ -10,7 +10,6 @@ import LoadingSpinner from "../../Spinners/LoadingSpinner";
|
|||||||
export default function FamilyTasks({
|
export default function FamilyTasks({
|
||||||
familyData,
|
familyData,
|
||||||
className,
|
className,
|
||||||
loader,
|
|
||||||
accountDetails,
|
accountDetails,
|
||||||
}) {
|
}) {
|
||||||
let navigate = useNavigate();
|
let navigate = useNavigate();
|
||||||
@@ -19,17 +18,17 @@ export default function FamilyTasks({
|
|||||||
// ...
|
// ...
|
||||||
const filteredFamilyData = useMemo(
|
const filteredFamilyData = useMemo(
|
||||||
() =>
|
() =>
|
||||||
familyData?.result_list?.filter(
|
familyData?.data?.result_list?.filter(
|
||||||
(data) => data?.family_uid === accountDetails?.family_uid
|
(data) => data?.family_uid === accountDetails?.family_uid
|
||||||
),
|
),
|
||||||
[familyData, accountDetails]
|
[familyData?.data, accountDetails]
|
||||||
);
|
);
|
||||||
|
|
||||||
const [currentPage, setCurrentPage] = useState(0);
|
const [currentPage, setCurrentPage] = useState(0);
|
||||||
const indexOfFirstItem = Number(currentPage);
|
const indexOfFirstItem = Number(currentPage);
|
||||||
const indexOfLastItem =
|
const indexOfLastItem =
|
||||||
Number(indexOfFirstItem) + Number(process.env.REACT_APP_ITEM_PER_PAGE);
|
Number(indexOfFirstItem) + Number(process.env.REACT_APP_ITEM_PER_PAGE);
|
||||||
const currentTask = familyData?.result_list.slice(
|
const currentTask = familyData?.data?.result_list?.slice(
|
||||||
indexOfFirstItem,
|
indexOfFirstItem,
|
||||||
indexOfLastItem
|
indexOfLastItem
|
||||||
);
|
);
|
||||||
@@ -43,21 +42,21 @@ export default function FamilyTasks({
|
|||||||
className || ""
|
className || ""
|
||||||
}`}
|
}`}
|
||||||
>
|
>
|
||||||
{loader ? (
|
{familyData.loading ? (
|
||||||
<div className="w-full h-full flex justify-center items-center lg:min-h-[470px]">
|
<div className="w-full h-full flex justify-center items-center">
|
||||||
<LoadingSpinner size={16} color="sky-blue" />
|
<LoadingSpinner size={16} color="sky-blue" height='h-[30rem]' />
|
||||||
</div>
|
</div>
|
||||||
) : (
|
) : (
|
||||||
<>
|
<>
|
||||||
{familyData && familyData?.result_list && (
|
{familyData?.data && familyData?.data?.result_list && (
|
||||||
<div className="relative w-full overflow-x-auto sm:rounded-lg flex flex-col justify-between h-full">
|
<div className="relative w-full overflow-x-auto sm:rounded-lg flex flex-col justify-between h-full">
|
||||||
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
|
<table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
|
||||||
<tbody>
|
<tbody>
|
||||||
{
|
{
|
||||||
<>
|
<>
|
||||||
{familyData &&
|
{familyData?.data &&
|
||||||
familyData?.result_list &&
|
familyData?.data?.result_list &&
|
||||||
familyData.result_list.length > 0 ? (
|
familyData?.data.result_list.length > 0 ? (
|
||||||
currentTask.map((value, index) => {
|
currentTask.map((value, index) => {
|
||||||
// find due date
|
// find due date
|
||||||
const dueDate = value?.delivery_date.split(" ")[0];
|
const dueDate = value?.delivery_date.split(" ")[0];
|
||||||
@@ -67,7 +66,7 @@ export default function FamilyTasks({
|
|||||||
value?.currency_code,
|
value?.currency_code,
|
||||||
value?.currency
|
value?.currency
|
||||||
);
|
);
|
||||||
let image = `${familyData.session_image_server}${localStorage.getItem('session_token')}/job/${value.job_uid}`
|
let image = `${familyData?.data?.session_image_server}${localStorage.getItem('session_token')}/job/${value.job_uid}`
|
||||||
return (
|
return (
|
||||||
<tr
|
<tr
|
||||||
key={index}
|
key={index}
|
||||||
@@ -149,11 +148,11 @@ export default function FamilyTasks({
|
|||||||
prev={currentPage == 0 ? true : false}
|
prev={currentPage == 0 ? true : false}
|
||||||
next={
|
next={
|
||||||
currentPage + Number(process.env.REACT_APP_ITEM_PER_PAGE) >=
|
currentPage + Number(process.env.REACT_APP_ITEM_PER_PAGE) >=
|
||||||
familyData?.result_list.length
|
familyData?.data?.result_list.length
|
||||||
? true
|
? true
|
||||||
: false
|
: false
|
||||||
}
|
}
|
||||||
data={familyData?.result_list}
|
data={familyData?.data?.result_list}
|
||||||
start={indexOfFirstItem}
|
start={indexOfFirstItem}
|
||||||
stop={indexOfLastItem}
|
stop={indexOfLastItem}
|
||||||
/>
|
/>
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ import LoadingSpinner from "../../Spinners/LoadingSpinner";
|
|||||||
import AssignTaskPopout from "../FamilyPopout/AssignTaskPopout";
|
import AssignTaskPopout from "../FamilyPopout/AssignTaskPopout";
|
||||||
|
|
||||||
const FamilyWaitlist = memo(
|
const FamilyWaitlist = memo(
|
||||||
({ familyData, className, accountDetails, loader, setUpdatePage }) => {
|
({ familyData, className, accountDetails, setUpdatePage }) => {
|
||||||
const [popUp, setPopUp] = useState({ show: false, data: {} });
|
const [popUp, setPopUp] = useState({ show: false, data: {} });
|
||||||
const [continueTaskPopup, setContinueTaskPopup] = useState({
|
const [continueTaskPopup, setContinueTaskPopup] = useState({
|
||||||
show: false,
|
show: false,
|
||||||
@@ -13,10 +13,10 @@ const FamilyWaitlist = memo(
|
|||||||
});
|
});
|
||||||
const filteredFamilyData = useMemo(
|
const filteredFamilyData = useMemo(
|
||||||
() =>
|
() =>
|
||||||
familyData?.result_list?.filter(
|
familyData?.data?.result_list?.filter(
|
||||||
(data) => data?.family_uid === accountDetails?.family_uid
|
(data) => data?.family_uid === accountDetails?.family_uid
|
||||||
),
|
),
|
||||||
[familyData, accountDetails]
|
[familyData.data, accountDetails]
|
||||||
);
|
);
|
||||||
|
|
||||||
const [currentPage, setCurrentPage] = useState(0);
|
const [currentPage, setCurrentPage] = useState(0);
|
||||||
@@ -52,9 +52,9 @@ const FamilyWaitlist = memo(
|
|||||||
className || ""
|
className || ""
|
||||||
}`}
|
}`}
|
||||||
>
|
>
|
||||||
{loader ? (
|
{familyData.loading ? (
|
||||||
<div className="w-full h-full flex justify-center items-center lg:min-h-[470px]">
|
<div className="w-full h-full flex justify-center items-center">
|
||||||
<LoadingSpinner size={16} color="sky-blue" />
|
<LoadingSpinner size={16} color="sky-blue" height='h-[30rem]' />
|
||||||
</div>
|
</div>
|
||||||
) : (
|
) : (
|
||||||
<>
|
<>
|
||||||
@@ -67,8 +67,7 @@ const FamilyWaitlist = memo(
|
|||||||
const selectedImage = require(`../../../assets/images/family/${
|
const selectedImage = require(`../../../assets/images/family/${
|
||||||
value?.banner || "default.jpg"
|
value?.banner || "default.jpg"
|
||||||
}`);
|
}`);
|
||||||
console.log('VALUE', value)
|
// let image = `${familyData.data.session_image_server}${localStorage.getItem('session_token')}/job/${value.job_uid}`
|
||||||
// let image = `${familyData.session_image_server}${localStorage.getItem('session_token')}/job/${value.job_uid}`
|
|
||||||
return (
|
return (
|
||||||
<tr
|
<tr
|
||||||
className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50"
|
className="bg-white dark:bg-dark-white border-b dark:border-[#5356fb29] hover:bg-gray-50"
|
||||||
|
|||||||
@@ -17,8 +17,6 @@ function FamilyWallet({familyData}) {
|
|||||||
setFamilyWallet({loading:true, data: []})
|
setFamilyWallet({loading:true, data: []})
|
||||||
apiUrl.getKidWallets({family_uid:familyData?.uid}).then(res => {
|
apiUrl.getKidWallets({family_uid:familyData?.uid}).then(res => {
|
||||||
setFamilyWallet({loading:false, data: res?.data?.result_list || []})
|
setFamilyWallet({loading:false, data: res?.data?.result_list || []})
|
||||||
console.log('familyData', familyData, res?.data?.result_list)
|
|
||||||
|
|
||||||
}).catch(error => {
|
}).catch(error => {
|
||||||
setFamilyWallet({loading:false, data: []})
|
setFamilyWallet({loading:false, data: []})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -80,8 +80,6 @@ const SuggestTask = ({ details, onClose, situation, continuePopupData }) => {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
console.log(details);
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<ModalCom action={onClose} situation={situation}>
|
<ModalCom action={onClose} situation={situation}>
|
||||||
<div className="logout-modal-wrapper lw-[90%] md:w-[48rem] min-h-[500px] bg-white dark:bg-dark-white lg:rounded-2xl">
|
<div className="logout-modal-wrapper lw-[90%] md:w-[48rem] min-h-[500px] bg-white dark:bg-dark-white lg:rounded-2xl">
|
||||||
|
|||||||
@@ -0,0 +1,22 @@
|
|||||||
|
import React, { useEffect, useRef } from 'react'
|
||||||
|
|
||||||
|
|
||||||
|
export default function VideoElement({videoId}) {
|
||||||
|
let videoRef = useRef(null)
|
||||||
|
|
||||||
|
useEffect(()=>{
|
||||||
|
if(videoRef.current){
|
||||||
|
videoRef.current.pause()
|
||||||
|
videoRef.current.removeAttribute('src')
|
||||||
|
videoRef.current.load()
|
||||||
|
}
|
||||||
|
},[videoId])
|
||||||
|
|
||||||
|
return (
|
||||||
|
<video ref={videoRef} className='w-full h-full' controls>
|
||||||
|
<source src={`https://dev-media.wrenchboard.com/videos/${videoId}`} type='video/mp4'></source>
|
||||||
|
Your browser does not support the video tag.
|
||||||
|
</video>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
@@ -71,7 +71,9 @@ function PendingJobsPopout({ details, onClose, situation }) {
|
|||||||
.pendingJobSendTome(reqData)
|
.pendingJobSendTome(reqData)
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
setRequestMessage({ status: true, message: res.data.status });
|
setRequestMessage({ status: true, message: res.data.status });
|
||||||
|
dispatch(tableReload({ type: "PENDINGTABLE" }));
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
|
onClose()
|
||||||
setPendingJobLoader({ extend: false, offer: false });
|
setPendingJobLoader({ extend: false, offer: false });
|
||||||
setRequestMessage({ status: false, message: "" });
|
setRequestMessage({ status: false, message: "" });
|
||||||
}, 4000);
|
}, 4000);
|
||||||
|
|||||||
@@ -1330,7 +1330,32 @@ class usersService {
|
|||||||
};
|
};
|
||||||
return this.postAuxEnd("/familywallet/redeem/options", postData);
|
return this.postAuxEnd("/familywallet/redeem/options", postData);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// API FUNCTION FOR PARENT TO CALL COMMON MEDIA
|
||||||
|
getParentCommonMedia() {
|
||||||
|
var postData = {
|
||||||
|
uid: localStorage.getItem("uid"),
|
||||||
|
member_id: localStorage.getItem("member_id"),
|
||||||
|
sessionid: localStorage.getItem("session_token"),
|
||||||
|
action: apiConst.WRENCHBOARD_ACCOUNT_FAMILY_RESOURCES,
|
||||||
|
offset: 1,
|
||||||
|
limit: 20,
|
||||||
|
};
|
||||||
|
return this.postAuxEnd("/commonmedia", postData);
|
||||||
|
}
|
||||||
|
|
||||||
|
// API FUNCTION FOR PARENT TO ASSIGN MEDIA TASK
|
||||||
|
parentAssignMediaTask(reqData) {
|
||||||
|
var postData = {
|
||||||
|
uid: localStorage.getItem("uid"),
|
||||||
|
member_id: localStorage.getItem("member_id"),
|
||||||
|
sessionid: localStorage.getItem("session_token"),
|
||||||
|
action: apiConst.WRENCHBOARD_JOB_OFFER_SYSTEM,
|
||||||
|
...reqData
|
||||||
|
};
|
||||||
|
return this.postAuxEnd("/assignmediatask", postData);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
- 20:27:30.118 FLOG_MAX [757411]: REQ_STRING(username)
|
- 20:27:30.118 FLOG_MAX [757411]: REQ_STRING(username)
|
||||||
- 20:27:30.118 FLOG_MAX [757411]: REQ_STRING(password)
|
- 20:27:30.118 FLOG_MAX [757411]: REQ_STRING(password)
|
||||||
|
|||||||
Reference in New Issue
Block a user