mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-23 17:32:20 +00:00
f49616b4cf
fix: updating context with new root doc id GitOrigin-RevId: 87e803554efc20cce4404f4f0f4137ae7fe9c2aa
32 lines
1.3 KiB
TypeScript
32 lines
1.3 KiB
TypeScript
import { type ProjectSettings, saveProjectSettings } from '../utils/api'
|
|
import { useProjectContext } from '../../../shared/context/project-context'
|
|
import useScopeValue from '../../../shared/hooks/use-scope-value'
|
|
|
|
export default function useSaveProjectSettings() {
|
|
// projectSettings value will be undefined on mount
|
|
const [projectSettings, setProjectSettings] = useScopeValue<
|
|
ProjectSettings | undefined
|
|
>('project', true)
|
|
const { _id: projectId } = useProjectContext()
|
|
|
|
return async (
|
|
key: keyof ProjectSettings,
|
|
newSetting: ProjectSettings[keyof ProjectSettings]
|
|
) => {
|
|
if (projectSettings) {
|
|
const currentSetting = projectSettings[key]
|
|
if (currentSetting !== newSetting) {
|
|
await saveProjectSettings(projectId, {
|
|
[key]: newSetting,
|
|
})
|
|
|
|
// rootDocId is used in our tsx and our endpoint, but rootDoc_id is used in our project $scope, etc
|
|
// as we use both namings in many files, and convert back and forth,
|
|
// its complicated to seperate and choose one name for all usages
|
|
// todo: make rootDocId or rootDoc_id consistent, and remove need for this/ other conversions
|
|
const settingsKey = key === 'rootDocId' ? 'rootDoc_id' : key
|
|
setProjectSettings({ ...projectSettings, [settingsKey]: newSetting })
|
|
}
|
|
}
|
|
}
|
|
}
|