mirror of
https://github.com/overleaf/overleaf.git
synced 2024-12-12 05:51:39 -05:00
82cd2d2a77
GitOrigin-RevId: 33ef74e1b1da41db8a86fc79ae04fbe49ed194df
32 lines
1.3 KiB
TypeScript
32 lines
1.3 KiB
TypeScript
import { useCallback } from 'react'
|
|
import useScopeValue from '../../../shared/hooks/use-scope-value'
|
|
import { type ProjectSettings, saveUserSettings } from '../utils/api'
|
|
import useSaveProjectSettings from './use-save-project-settings'
|
|
|
|
export default function useSetSpellCheckLanguage() {
|
|
const [spellCheckLanguage, setSpellCheckLanguage] = useScopeValue<
|
|
ProjectSettings['spellCheckLanguage']
|
|
>('project.spellCheckLanguage')
|
|
const saveProjectSettings = useSaveProjectSettings()
|
|
|
|
return useCallback(
|
|
(newSpellCheckLanguage: ProjectSettings['spellCheckLanguage']) => {
|
|
const allowUpdate =
|
|
spellCheckLanguage != null &&
|
|
newSpellCheckLanguage !== spellCheckLanguage
|
|
|
|
if (allowUpdate) {
|
|
setSpellCheckLanguage(newSpellCheckLanguage)
|
|
|
|
// Save project settings is created from hooks because it will save the value on
|
|
// both server-side and client-side (angular scope)
|
|
saveProjectSettings('spellCheckLanguage', newSpellCheckLanguage)
|
|
|
|
// For user settings, we only need to save it on server-side,
|
|
// so we import the function directly without hooks
|
|
saveUserSettings('spellCheckLanguage', newSpellCheckLanguage)
|
|
}
|
|
},
|
|
[setSpellCheckLanguage, spellCheckLanguage, saveProjectSettings]
|
|
)
|
|
}
|