overleaf/services/web/frontend/js/shared/context/ide-context.tsx
Alf Eaton 4ca3f9cabf Add types to IdeContext (#8107)
GitOrigin-RevId: 6b1df81ce588558adab0c31c0f65e68e5b0c25bf
2022-05-25 08:11:12 +00:00

25 lines
693 B
TypeScript

import { createContext, FC, useContext, useState } from 'react'
import { getMockIde } from './mock/mock-ide'
type Ide = {
[key: string]: any // TODO: define the rest of the `ide` and `$scope` properties
$scope: Record<string, any>
}
const IdeContext = createContext<Ide | null>(null)
export const IdeProvider: FC<{ ide: Ide }> = ({ ide, children }) => {
const [value] = useState(() => ide || getMockIde())
return <IdeContext.Provider value={value}>{children}</IdeContext.Provider>
}
export function useIdeContext(): Ide {
const context = useContext(IdeContext)
if (!context) {
throw new Error('useIdeContext is only available inside IdeProvider')
}
return context
}