overleaf/services/web/frontend/js/features/editor-left-menu/utils/api.ts

73 lines
1.5 KiB
TypeScript
Raw Normal View History

import {
FontFamily,
LineHeight,
OverallTheme,
} from '../../../../../modules/source-editor/frontend/js/extensions/theme'
import {
Keybindings,
PdfViewer,
ProjectCompiler,
} from '../../../../../types/project-settings'
import { postJSON } from '../../../infrastructure/fetch-json'
export type UserSettingsScope = {
pdfViewer: PdfViewer
autoComplete: boolean
autoPairDelimiters: boolean
syntaxValidation: boolean
editorTheme: string
overallTheme: OverallTheme
mode: Keybindings
fontSize: string
fontFamily: FontFamily
lineHeight: LineHeight
}
export function saveUserSettings(data: Partial<UserSettingsScope>) {
postJSON('/user/settings', {
body: {
_csrf: window.csrfToken,
...data,
},
})
}
export type ProjectSettingsScope = {
compiler: ProjectCompiler
imageName: string
rootDoc_id: string
spellCheckLanguage: string
}
// server asks for "rootDocId" but client has "rootDoc_id"
type ProjectSettingsRequestBody = Partial<
Omit<ProjectSettingsScope, 'rootDoc_id'> & {
rootDocId: string
}
>
export const saveProjectSettings = async (
projectId: string,
data: Partial<ProjectSettingsScope>
) => {
let reqData: ProjectSettingsRequestBody = {}
if (data.rootDoc_id) {
const val = data.rootDoc_id
delete data.rootDoc_id
reqData = {
...data,
rootDocId: val,
}
} else {
reqData = data
}
await postJSON<never>(`/project/${projectId}/settings`, {
body: {
_csrf: window.csrfToken,
...reqData,
},
})
}