2024-01-08 12:07:48 +00:00
|
|
|
import { createContext, FC, useContext, useEffect, useMemo } from 'react'
|
2023-10-24 14:57:17 +00:00
|
|
|
import { ScopeValueStore } from '../../../../types/ide/scope-value-store'
|
|
|
|
import { Scope } from '../../../../types/angular/scope'
|
|
|
|
import getMeta from '@/utils/meta'
|
|
|
|
import { ScopeEventEmitter } from '../../../../types/ide/scope-event-emitter'
|
2022-05-25 07:58:26 +00:00
|
|
|
|
2023-10-24 14:57:17 +00:00
|
|
|
export type Ide = {
|
2022-05-25 07:58:26 +00:00
|
|
|
[key: string]: any // TODO: define the rest of the `ide` and `$scope` properties
|
2023-10-24 14:57:17 +00:00
|
|
|
$scope: Scope
|
2022-05-25 07:58:26 +00:00
|
|
|
}
|
|
|
|
|
2023-10-24 14:57:17 +00:00
|
|
|
type IdeContextValue = Ide & {
|
|
|
|
isReactIde: boolean
|
|
|
|
scopeStore: ScopeValueStore
|
|
|
|
scopeEventEmitter: ScopeEventEmitter
|
|
|
|
}
|
|
|
|
|
|
|
|
const IdeContext = createContext<IdeContextValue | undefined>(undefined)
|
|
|
|
const isReactIde: boolean = getMeta('ol-idePageReact')
|
2022-05-25 07:58:26 +00:00
|
|
|
|
2023-10-24 14:57:17 +00:00
|
|
|
export const IdeProvider: FC<{
|
|
|
|
ide: Ide
|
|
|
|
scopeStore: ScopeValueStore
|
|
|
|
scopeEventEmitter: ScopeEventEmitter
|
|
|
|
}> = ({ ide, scopeStore, scopeEventEmitter, children }) => {
|
2024-01-08 12:07:48 +00:00
|
|
|
/**
|
|
|
|
* Expose scopeStore via `window.overleaf.unstable.store`, so it can be accessed by external extensions.
|
|
|
|
*
|
|
|
|
* These properties are expected to be available:
|
|
|
|
* - `editor.view`
|
|
|
|
* - `project.spellcheckLanguage`
|
|
|
|
* - `editor.open_doc_name`,
|
|
|
|
* - `editor.open_doc_id`,
|
|
|
|
*/
|
|
|
|
useEffect(() => {
|
|
|
|
window.overleaf = {
|
|
|
|
...window.overleaf,
|
|
|
|
unstable: {
|
|
|
|
...window.overleaf?.unstable,
|
|
|
|
store: scopeStore,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}, [scopeStore])
|
|
|
|
|
2023-10-24 14:57:17 +00:00
|
|
|
const value = useMemo<IdeContextValue>(() => {
|
|
|
|
return {
|
|
|
|
...ide,
|
|
|
|
isReactIde,
|
|
|
|
scopeStore,
|
|
|
|
scopeEventEmitter,
|
|
|
|
}
|
|
|
|
}, [ide, scopeStore, scopeEventEmitter])
|
2022-05-25 07:58:26 +00:00
|
|
|
|
|
|
|
return <IdeContext.Provider value={value}>{children}</IdeContext.Provider>
|
|
|
|
}
|
|
|
|
|
2023-10-24 14:57:17 +00:00
|
|
|
export function useIdeContext(): IdeContextValue {
|
2022-05-25 07:58:26 +00:00
|
|
|
const context = useContext(IdeContext)
|
|
|
|
|
|
|
|
if (!context) {
|
|
|
|
throw new Error('useIdeContext is only available inside IdeProvider')
|
|
|
|
}
|
|
|
|
|
|
|
|
return context
|
|
|
|
}
|