classify web

This commit is contained in:
Husanjonazamov
2026-02-24 12:52:49 +05:00
commit 64af77101f
310 changed files with 45449 additions and 0 deletions

View File

@@ -0,0 +1,77 @@
import { useState } from "react";
import FlutterwaveLogo from "../../../public/assets/flutterwave.png";
import { FaAngleRight } from "react-icons/fa";
import { createPaymentIntentApi } from "@/utils/api";
import { toast } from "sonner";
import { t } from "@/utils";
import CustomImage from "@/components/Common/CustomImage";
import { Loader2 } from "lucide-react";
const FlutterwavePayment = ({ selectedPackage }) => {
const [isLoading, setIsLoading] = useState(false);
const handleFlutterwavePayment = async () => {
setIsLoading(true);
try {
const res = await createPaymentIntentApi.createIntent({
package_id: selectedPackage.id,
payment_method: "FlutterWave",
});
if (res.data.error) {
toast.error(res.data.message);
return;
}
const payment_gateway_response =
res?.data?.data?.payment_intent?.payment_gateway_response?.data?.link;
if (payment_gateway_response) {
const popupWidth = 600;
const popupHeight = 700;
const popupLeft = window.innerWidth / 2 - popupWidth / 2;
const popupTop = window.innerHeight / 2 - popupHeight / 2;
window.open(
payment_gateway_response,
"paymentWindow",
`width=${popupWidth},height=${popupHeight},top=${popupTop},left=${popupLeft}`
);
} else {
throw new Error("Unable to retrieve payment gateway response.");
}
} catch (error) {
console.error("Error during Flutterwave payment", error);
toast.error(t("errorOccurred"));
} finally {
setIsLoading(false);
}
};
return (
<div>
<button onClick={handleFlutterwavePayment} className="w-full p-2">
<div className="flex items-center gap-2 justify-between ">
<div className="flex gap-3 items-center">
<div className="w-8 h-8">
<CustomImage
height={32}
width={32}
src={FlutterwaveLogo.src}
alt="Flutterwave"
className="w-full h-full "
/>
</div>
<p className="text-lg font-semibold">{t("flutterwave")}</p>
</div>
<div>
{isLoading ? (
<Loader2 className="w-5 h-5 animate-spin" />
) : (
<FaAngleRight size={18} className="rtl:scale-x-[-1]" />
)}
</div>
</div>
</button>
</div>
);
};
export default FlutterwavePayment;