From f52b04f53760e31ffe23823fe6150b57f66457b3 Mon Sep 17 00:00:00 2001 From: Mohammad Cheikh Date: Wed, 18 Dec 2024 13:13:34 -0500 Subject: [PATCH] add mobile viewing block --- examples/react-components/src/app/index.css | 50 +++++++++++++++++++++ examples/react-components/src/app/page.tsx | 32 +++++++++++++ 2 files changed, 82 insertions(+) diff --git a/examples/react-components/src/app/index.css b/examples/react-components/src/app/index.css index 71529fbb..acaf7b18 100644 --- a/examples/react-components/src/app/index.css +++ b/examples/react-components/src/app/index.css @@ -167,3 +167,53 @@ body { .sonner-toaster > div { pointer-events: auto; } +.mobile-warning { + position: fixed; + top: 0; + left: 0; + right: 0; + bottom: 0; + padding: 16px; + background: rgba(255, 255, 255, 0.8); + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; + background-image: url("../../public/grid.svg"); + background-size: cover; + background-repeat: no-repeat; + background-position: center; +} + +.mobile-content { + text-align: center; +} +.warning-text { + margin-bottom: 20px; + font-size: 1.2rem; + font-weight: bold; +} + +.continueButton { + padding: 10px 16px 10px 16px; + gap: 8px; + color: #ffffff; + width: 50%; + font-size: 1rem; + background: var(--Greyscale-900, #2b2f33); + border: 1px solid var(--Greyscale-800, #3f464b); + border-radius: 8px; + cursor: pointer; + transition: 0.3s ease; +} + +.continueButton:disabled { + color: var(--Greyscale-700, #a2a7ae); + background: #ffffff; + border-color: var(--Greyscale-400, #a2a7ae); + cursor: not-allowed; +} + +.continueButton:hover { + background-color: var(--Greyscale-700, #4a4f55); +} diff --git a/examples/react-components/src/app/page.tsx b/examples/react-components/src/app/page.tsx index 719dd8de..b0fb9e0c 100644 --- a/examples/react-components/src/app/page.tsx +++ b/examples/react-components/src/app/page.tsx @@ -46,6 +46,8 @@ export default function AuthPage() { router.push("/dashboard"); }; const { turnkey } = useTurnkey(); + const [isMobile, setIsMobile] = useState(false); + const [showContent, setShowContent] = useState(!isMobile); const [configOrder, setConfigOrder] = useState([ "socials", "email", @@ -67,6 +69,16 @@ export default function AuthPage() { }, }); + useEffect(() => { + const checkMobile = () => { + setIsMobile(window.innerWidth <= 768); + setShowContent(window.innerWidth > 768); + }; + checkMobile(); + window.addEventListener("resize", checkMobile); + return () => window.removeEventListener("resize", checkMobile); + }, []); + useEffect(() => { const manageSession = async () => { if (turnkey) { @@ -164,6 +176,26 @@ export default function AuthPage() { setConfigOrder(reorderedConfig); }; + if (isMobile && !showContent) { + return ( +
+
+
+
+ For the best experience, please view this demo on a desktop. +
+ +
+
+
+ ); + } + return (