dev-resources.site
for different kinds of informations.
Handling Local Storage for Toaster Notifications
Published at
1/2/2025
Categories
webdev
javascript
shadcn
typescript
Author
Bro Karim
Demo :
// Detect dark theme var iframe = document.getElementById('tweet-1874817943860834535-693'); if (document.body.className.includes('dark-theme')) { iframe.src = "https://platform.twitter.com/embed/Tweet.html?id=1874817943860834535&theme=dark" }
Source code :
============= layout.tsx
<body>
<ThemeProvider attribute="class" defaultTheme="dark">
{children}
<DevToaster />
</ThemeProvider>
</body>
============= dev-toaster.tsx
export function TemplateToaster() {
const [isVisibile, setIsVisible] = useState(true);
const [notificationStatus, setNotificationStatus] = useState<string | null>(null);
const path = usePathname();
const [hydrated, setHydrated] = useState(false);
// Run this effect only once to set hydrated to true
useEffect(() => {
setHydrated(true);
}, []);
// Run this effect only on client side
useEffect(() => {
if (hydrated) {
// Remove the saved notification status to reset it
localStorage.removeItem("behindui-notification");
// Check localStorage after clearing
setNotificationStatus(localStorage.getItem("behindui-notification"));
}
}, [hydrated]);
if (!hydrated) {
return null;
}
const templates = path.includes("templates");
const isIframe = isInIframe();
if (isIframe || notificationStatus === "off") {
return <div></div>;
}
return (
isVisibile &&
!templates && (
<section className="relative z-50">
<div className="font-geist fixed bottom-4 right-4">
<Card className={cn(" w-[350px] bg-background [border:1px_solid_rgba(255,255,255,.1)]")}>
<CardHeader>
<div className="font-mono font-bold uppercase tracking-tight">
🚧Website Under Development 🚧 <br />
</div>
<CardDescription className="mt-4 text-black/90 dark:text-white/70">This website is currently in active development. Some features may be incomplete or not working as expected</CardDescription>
</CardHeader>
<CardFooter className="flex justify-end gap-4">
<Button
size="sm"
onClick={() => {
localStorage.setItem("behindui-notification", "off");
setIsVisible(false);
}}
>
Understand
</Button>
</CardFooter>
</Card>
</div>
</section>
)
);
}
function isInIframe() {
try {
return window.self !== window.top;
} catch (e) {
return true;
}
}
Articles
12 articles in total
Animated Select component using typescript, shadcn and framer-motion
read article
Animated Hover Logo using Typescript, Tailwind and Framer Motion
read article
Animated Video Tooltip using typescript and framer-motion
read article
Handling Local Storage for Toaster Notifications
currently reading
Journey In Learning Pandas
read article
Docker Compose in Action : A Real Case Study for Nextjs Projects
read article
Docker on Windows: Led Into Container Wonderland
read article
Effortless Payments with Lemon Squeezy | Next.js Integration Made Simple
read article
Newsletter with Next.js | Nextjs Mailchimp API Integration✉️
read article
🍔My Minimal Web Portofolio as Frontend, Build with Nextjs
read article
📂How to compile and run MDX in React
read article
🌈How to Create a Theme with ReactJS and Tailwind CSS
read article
Featured ones: