import { createContext, useCallback, useContext, useState } from 'react' export const BANNER_ID = { METRICS_API: 'metrics-api-banner', INDEX_ADVISOR: 'index-advisor-banner', TABLE_EDITOR_QUEUE_OPERATIONS: 'table-editor-queue-operations-banner', RLS_EVENT_TRIGGER: 'rls-event-trigger-banner', RLS_TESTER: 'rls-tester-banner', FREE_MICRO_UPGRADE: 'free-micro-upgrade-banner', } as const export type BannerId = (typeof BANNER_ID)[keyof typeof BANNER_ID] export interface Banner { id: BannerId content: React.ReactNode isDismissed: boolean priority?: number onDismiss?: () => void } interface BannerStackContextType { banners: Banner[] addBanner: (banner: Banner) => void dismissBanner: (id: BannerId) => 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 }