diff --git a/examples/react-components/src/app/index.css b/examples/react-components/src/app/index.css index 71529fbb..4b1ed041 100644 --- a/examples/react-components/src/app/index.css +++ b/examples/react-components/src/app/index.css @@ -44,6 +44,7 @@ body { position: relative; } + .authConfigContainer { position: absolute; left: 0; @@ -167,3 +168,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; +} + +button { + 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; +} + +button:disabled { + color: var(--Greyscale-700, #a2a7ae); + background: #ffffff; + border-color: var(--Greyscale-400, #a2a7ae); + cursor: not-allowed; +} + +button: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..a3c8997c 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,23 @@ export default function AuthPage() { setConfigOrder(reorderedConfig); }; + if (isMobile && !showContent) { + return ( + + + + + For the best experience, please view this demo on a desktop. + + setShowContent(true)}> + Continue Anyway + + + + + ); + } + return (