Some checks failed
Deploy to Production / Build and Deploy (push) Has been cancelled
- Fix React bug #33580: remove Suspense boundaries co-located with Link components - Delete settings/loading.tsx and admin/loading.tsx (root cause of race condition) - Convert all admin navigation from Next.js Link to anchor tags - Move admin pages to dedicated (admin) route group - Add AdminHeader matching main header visual design - Add AdminSidebar with anchor-based navigation - Add /api/admin/models route handler (replaces server actions for GET) - Add /api/debug/client-error for server-side browser error reporting - Add useNoteRefreshOptional() to fix crash in AdminHeader - Hide Admin Dashboard menu for non-admin users - Change app icons from yellow to blue (#3A7CA5) matching brand primary - Fix admin search bar width to match main header Made-with: Cursor
44 lines
1.2 KiB
TypeScript
44 lines
1.2 KiB
TypeScript
'use client'
|
|
|
|
import { createContext, useContext, useState, useCallback, useMemo } from 'react'
|
|
|
|
interface NoteRefreshContextType {
|
|
refreshKey: number
|
|
triggerRefresh: () => void
|
|
}
|
|
|
|
const NoteRefreshContext = createContext<NoteRefreshContextType | undefined>(undefined)
|
|
|
|
export function NoteRefreshProvider({ children }: { children: React.ReactNode }) {
|
|
const [refreshKey, setRefreshKey] = useState(0)
|
|
|
|
const triggerRefresh = useCallback(() => {
|
|
setRefreshKey(prev => prev + 1)
|
|
}, [])
|
|
|
|
const value = useMemo(() => ({ refreshKey, triggerRefresh }), [refreshKey, triggerRefresh])
|
|
|
|
return (
|
|
<NoteRefreshContext.Provider value={value}>
|
|
{children}
|
|
</NoteRefreshContext.Provider>
|
|
)
|
|
}
|
|
|
|
export function useNoteRefresh() {
|
|
const context = useContext(NoteRefreshContext)
|
|
if (!context) {
|
|
throw new Error('useNoteRefresh must be used within NoteRefreshProvider')
|
|
}
|
|
return context
|
|
}
|
|
|
|
/**
|
|
* Same as useNoteRefresh but tolerates being called outside the provider
|
|
* (e.g. shared header rendered in admin pages). Returns a no-op when absent.
|
|
*/
|
|
export function useNoteRefreshOptional(): NoteRefreshContextType {
|
|
const context = useContext(NoteRefreshContext)
|
|
return context ?? { refreshKey: 0, triggerRefresh: () => {} }
|
|
}
|