171 lines
6.8 KiB
TypeScript
171 lines
6.8 KiB
TypeScript
/* eslint-disable @next/next/no-img-element */
|
|
import Layout from "@/components/High/Layout";
|
|
import PayPalPayment from "@/components/PayPalPayment";
|
|
import useGroups from "@/hooks/useGroups";
|
|
import usePackages from "@/hooks/usePackages";
|
|
import useUsers from "@/hooks/useUsers";
|
|
import {User} from "@/interfaces/user";
|
|
import clsx from "clsx";
|
|
import {capitalize} from "lodash";
|
|
import {useState} from "react";
|
|
import getSymbolFromCurrency from "currency-symbol-map";
|
|
|
|
interface Props {
|
|
user: User;
|
|
hasExpired?: boolean;
|
|
clientID: string;
|
|
reload: () => void;
|
|
}
|
|
|
|
export default function PaymentDue({user, hasExpired = false, clientID, reload}: Props) {
|
|
const [isLoading, setIsLoading] = useState(false);
|
|
|
|
const {packages} = usePackages();
|
|
const {users} = useUsers();
|
|
const {groups} = useGroups();
|
|
|
|
const isIndividual = () => {
|
|
if (user?.type === "developer") return true;
|
|
if (user?.type !== "student") return false;
|
|
const userGroups = groups.filter((g) => g.participants.includes(user?.id));
|
|
|
|
if (userGroups.length === 0) return true;
|
|
|
|
const userGroupsAdminTypes = userGroups.map((g) => users?.find((u) => u.id === g.admin)?.type).filter((t) => !!t);
|
|
return userGroupsAdminTypes.every((t) => t !== "corporate");
|
|
};
|
|
|
|
return (
|
|
<>
|
|
{isLoading && (
|
|
<div className="w-screen h-screen absolute top-0 left-0 overflow-hidden z-[999] bg-black/60">
|
|
<div className="w-fit h-fit absolute top-1/2 -translate-y-1/2 left-1/2 -translate-x-1/2 animate-pulse flex flex-col gap-8 items-center text-white">
|
|
<span className={clsx("loading loading-infinity w-48")} />
|
|
<span className={clsx("font-bold text-2xl")}>Completing your payment...</span>
|
|
</div>
|
|
</div>
|
|
)}
|
|
{user ? (
|
|
<Layout user={user} navDisabled={hasExpired}>
|
|
<div className="flex flex-col items-center justify-center text-center w-full gap-4">
|
|
{hasExpired && <span className="font-bold text-lg">You do not have time credits for your account type!</span>}
|
|
{isIndividual() && (
|
|
<div className="flex flex-col items-center w-full overflow-x-scroll scrollbar-hide gap-12">
|
|
<span className="max-w-lg">
|
|
To add to your use of EnCoach, please purchase one of the time packages available below:
|
|
</span>
|
|
<div className="w-full flex flex-wrap justify-center gap-8">
|
|
{packages.map((p) => (
|
|
<div key={p.id} className={clsx("p-4 bg-white rounded-xl flex flex-col gap-6 items-start")}>
|
|
<div className="flex flex-col items-start mb-2">
|
|
<img src="/logo_title.png" alt="EnCoach's Logo" className="w-32" />
|
|
<span className="font-semibold text-xl">
|
|
EnCoach - {p.duration}{" "}
|
|
{capitalize(
|
|
p.duration === 1 ? p.duration_unit.slice(0, p.duration_unit.length - 1) : p.duration_unit,
|
|
)}
|
|
</span>
|
|
</div>
|
|
<div className="flex flex-col gap-2 items-start w-full">
|
|
<span className="text-2xl">
|
|
{p.price}
|
|
{getSymbolFromCurrency(p.currency)}
|
|
</span>
|
|
<PayPalPayment
|
|
key={clientID}
|
|
{...p}
|
|
clientID={clientID}
|
|
setIsLoading={setIsLoading}
|
|
onSuccess={() => {
|
|
setTimeout(reload, 500);
|
|
}}
|
|
/>
|
|
</div>
|
|
<div className="flex flex-col gap-1 items-start">
|
|
<span>This includes:</span>
|
|
<ul className="flex flex-col items-start text-sm">
|
|
<li>- Train your abilities for the IELTS exam</li>
|
|
<li>- Gain insights into your weaknesses and strengths</li>
|
|
<li>- Allow yourself to correctly prepare for the exam</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
))}
|
|
</div>
|
|
</div>
|
|
)}
|
|
{!isIndividual() && user.type === "corporate" && user?.corporateInformation.payment && (
|
|
<div className="flex flex-col items-center">
|
|
<span className="max-w-lg">
|
|
To add to your use of EnCoach and that of your students and teachers, please pay your designated package below:
|
|
</span>
|
|
<div className={clsx("p-4 bg-white rounded-xl flex flex-col gap-6 items-start")}>
|
|
<div className="flex flex-col items-start mb-2">
|
|
<img src="/logo_title.png" alt="EnCoach's Logo" className="w-32" />
|
|
<span className="font-semibold text-xl">EnCoach - {user.corporateInformation?.monthlyDuration} Months</span>
|
|
</div>
|
|
<div className="flex flex-col gap-2 items-start w-full">
|
|
<span className="text-2xl">
|
|
{user.corporateInformation.payment.value}
|
|
{getSymbolFromCurrency(user.corporateInformation.payment.currency)}
|
|
</span>
|
|
<PayPalPayment
|
|
key={clientID}
|
|
clientID={clientID}
|
|
setIsLoading={setIsLoading}
|
|
currency={user.corporateInformation.payment.currency}
|
|
price={user.corporateInformation.payment.value}
|
|
duration={user.corporateInformation.monthlyDuration}
|
|
duration_unit="months"
|
|
onSuccess={() => {
|
|
setIsLoading(false);
|
|
setTimeout(reload, 500);
|
|
}}
|
|
/>
|
|
</div>
|
|
<div className="flex flex-col gap-1 items-start">
|
|
<span>This includes:</span>
|
|
<ul className="flex flex-col items-start text-sm">
|
|
<li>
|
|
- Allow a total of {user.corporateInformation.companyInformation.userAmount} students and teachers to
|
|
use EnCoach
|
|
</li>
|
|
<li>- Train their abilities for the IELTS exam</li>
|
|
<li>- Gain insights into your students' weaknesses and strengths</li>
|
|
<li>- Allow them to correctly prepare for the exam</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
)}
|
|
{!isIndividual() && user.type !== "corporate" && (
|
|
<div className="flex flex-col items-center">
|
|
<span className="max-w-lg">
|
|
You are not the person in charge of your time credits, please contact your administrator about this situation.
|
|
</span>
|
|
<span className="max-w-lg">
|
|
If you believe this to be a mistake, please contact the platform's administration, thank you for your
|
|
patience.
|
|
</span>
|
|
</div>
|
|
)}
|
|
{!isIndividual() && user.type === "corporate" && !user.corporateInformation.payment && (
|
|
<div className="flex flex-col items-center">
|
|
<span className="max-w-lg">
|
|
An admin nor your agent have yet set the price intended to your requirements in terms of the amount of users you
|
|
desire and your expected monthly duration.
|
|
</span>
|
|
<span className="max-w-lg">
|
|
Please try again later or contact your agent or an admin, thank you for your patience.
|
|
</span>
|
|
</div>
|
|
)}
|
|
</div>
|
|
</Layout>
|
|
) : (
|
|
<div />
|
|
)}
|
|
</>
|
|
);
|
|
}
|