Browse Source

feat: enhance mobile navigation with RTL support and modal integration

master
sina_sajjadi 3 days ago
parent
commit
fafa8d9683
  1. 36
      src/components/layout/mobile-navigation.tsx

36
src/components/layout/mobile-navigation.tsx

@ -1,6 +1,6 @@
// components/MobileNavigation.tsx // components/MobileNavigation.tsx
import { useEffect } from "react";
import { useEffect, useState } from "react";
import { motion, AnimatePresence } from "framer-motion"; import { motion, AnimatePresence } from "framer-motion";
import { useUI } from "../context/ui.context"; import { useUI } from "../context/ui.context";
import Logo from "../ui/logo"; import Logo from "../ui/logo";
@ -9,20 +9,20 @@ import Link from "next/link";
import LanguageSwitcher from "../language-switcher"; import LanguageSwitcher from "../language-switcher";
import { i18n, useTranslation } from "next-i18next"; // Import useTranslation import { i18n, useTranslation } from "next-i18next"; // Import useTranslation
const isRTL = i18n?.dir() === "rtl";
// Adjust sidebar variants based on RTL // Adjust sidebar variants based on RTL
const sidebarVariants = {
hidden: { x: isRTL ? "100%" : "-100%" }, // Start off-screen to the right for RTL, left for LTR
visible: { x: 0 }, // Fully visible on the screen
exit: { x: isRTL ? "100%" : "-100%" }, // Exit to the right for RTL, left for LTR
};
const MobileNavigation = () => { const MobileNavigation = () => {
const { displaySidebar, closeSidebar } = useUI();
const { displaySidebar, closeSidebar, openModal } = useUI();
const { t } = useTranslation("common"); // Use the translation hook for common translations const { t } = useTranslation("common"); // Use the translation hook for common translations
console.log(isRTL);
const [isRTL, setIsRTL] = useState(false);
const sidebarVariants = {
hidden: { x: isRTL ? "100%" : "-100%" }, // Start off-screen to the right for RTL, left for LTR
visible: { x: 0 }, // Fully visible on the screen
exit: { x: isRTL ? "100%" : "-100%" }, // Exit to the right for RTL, left for LTR
};
useEffect(() => {
setIsRTL(i18n?.dir().trim() === "rtl");
}, [i18n?.language]);
useEffect(() => { useEffect(() => {
document.body.style.overflow = displaySidebar ? "hidden" : "auto"; document.body.style.overflow = displaySidebar ? "hidden" : "auto";
}, [displaySidebar]); }, [displaySidebar]);
@ -60,12 +60,20 @@ const MobileNavigation = () => {
<div className="mt-14"> <div className="mt-14">
<ul className="flex flex-col gap-8 font-semibold text-black h-full items-start"> <ul className="flex flex-col gap-8 font-semibold text-black h-full items-start">
<li className="h-full flex items-center border-[#c79389] hover:border-b hover:text-[#EB6E57] "> <li className="h-full flex items-center border-[#c79389] hover:border-b hover:text-[#EB6E57] ">
<Link href={"/"}>{t("home")}</Link> {/* Translated text */}
<Link href={"/"}>{t("home")}</Link>{" "}
{/* Translated text */}
</li> </li>
<li className="h-full flex items-center border-[#F4846F] hover:border-b hover:text-[#EB6E57] "> <li className="h-full flex items-center border-[#F4846F] hover:border-b hover:text-[#EB6E57] ">
<Link href={"/about"}>{t("about")}</Link> {/* Translated text */}
<Link href={"/about"}>{t("about")}</Link>{" "}
{/* Translated text */}
</li> </li>
<li className="">
<li
onClick={() => {
openModal("DONATE_VIEW");
closeSidebar();
}}
className=""
>
<Link <Link
href={"/"} href={"/"}
className="bg-gradient-to-r from-[#F79B59] to-[#EB6E57] text-transparent bg-clip-text font-semibold" className="bg-gradient-to-r from-[#F79B59] to-[#EB6E57] text-transparent bg-clip-text font-semibold"

Loading…
Cancel
Save