From 408b4da1696aa5ecc70ec2b1e2b9d6f7235a5ecc Mon Sep 17 00:00:00 2001 From: Matt Ketmo Date: Fri, 15 Nov 2024 21:07:59 +0100 Subject: [PATCH] feat: return to latest page by default (#19) --- src/app/page.tsx | 8 +++++++- src/app/template.tsx | 17 +++++++++++++++++ 2 files changed, 24 insertions(+), 1 deletion(-) create mode 100644 src/app/template.tsx diff --git a/src/app/page.tsx b/src/app/page.tsx index e581c39..8e81a1e 100644 --- a/src/app/page.tsx +++ b/src/app/page.tsx @@ -1,5 +1,11 @@ +import { cookies } from "next/headers" import { redirect } from "next/navigation" -export default function Home() { +export default async function Home() { + const latestPage = (await cookies()).get('latest_page') + if (latestPage) { + return redirect(latestPage.value) + } + return redirect("/alerts") } diff --git a/src/app/template.tsx b/src/app/template.tsx new file mode 100644 index 0000000..7066914 --- /dev/null +++ b/src/app/template.tsx @@ -0,0 +1,17 @@ +'use client' + +import { useEffect } from "react" +import { usePathname, useSearchParams } from 'next/navigation' + +export default function Template({ children }: { children: React.ReactNode }) { + const pathname = usePathname() + const searchParams = useSearchParams() + + // Save the latest seen page to a cookie + useEffect(() => { + const path = `${pathname}${searchParams.toString() !== '' ? '?' + searchParams : ''}` + document.cookie = `latest_page=${path}; path=/;` + }, [pathname, searchParams]) + + return children +}