import { createContext, useContext, useState, useCallback } from 'react' export interface Banner { id: string content: React.ReactNode isDismissed: boolean priority?: number onDismiss?: () => void } interface BannerStackContextType { banners: Banner[] addBanner: (banner: Banner) => void dismissBanner: (id: string) => void } const BannerStackContext = createContext(undefined) export const BannerStackProvider = ({ children }: { children: React.ReactNode }) => { const [banners, setBanners] = useState([]) const addBanner = useCallback((banner: Banner) => { setBanners((prev) => { const exists = prev.some((b) => b.id === banner.id) if (exists) return prev const newBanners = [...prev, banner] return newBanners.sort((a, b) => (b.priority ?? 0) - (a.priority ?? 0)) }) }, []) const dismissBanner = useCallback((id: string) => { setBanners((prev) => prev.map((b) => (b.id === id ? { ...b, isDismissed: true } : b))) setTimeout(() => { setBanners((prev) => prev.filter((b) => b.id !== id)) }, 300) }, []) return ( {children} ) } export const useBannerStack = () => { const context = useContext(BannerStackContext) if (!context) throw new Error('useBannerStack must be used within BannerStackProvider') return context }