2024-03-08 04:38:11 -08:00
|
|
|
import { PayloadAction, createSlice } from "@reduxjs/toolkit";
|
|
|
|
|
|
|
|
interface Settings {
|
|
|
|
pathPrefix: string;
|
2024-03-14 04:07:13 -07:00
|
|
|
useLocalTime: boolean;
|
|
|
|
enableQueryHistory: boolean;
|
|
|
|
enableAutocomplete: boolean;
|
|
|
|
enableSyntaxHighlighting: boolean;
|
|
|
|
enableLinter: boolean;
|
|
|
|
showAnnotations: boolean;
|
2024-03-08 04:38:11 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
const initialState: Settings = {
|
|
|
|
pathPrefix: "",
|
2024-03-14 04:07:13 -07:00
|
|
|
useLocalTime: false,
|
|
|
|
enableQueryHistory: false,
|
|
|
|
enableAutocomplete: true,
|
|
|
|
enableSyntaxHighlighting: true,
|
|
|
|
enableLinter: true,
|
|
|
|
showAnnotations: false,
|
2024-03-08 04:38:11 -08:00
|
|
|
};
|
|
|
|
|
|
|
|
export const settingsSlice = createSlice({
|
|
|
|
name: "settings",
|
|
|
|
initialState,
|
|
|
|
reducers: {
|
|
|
|
updateSettings: (state, { payload }: PayloadAction<Partial<Settings>>) => {
|
|
|
|
Object.assign(state, payload);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
export const { updateSettings } = settingsSlice.actions;
|
|
|
|
|
|
|
|
export default settingsSlice.reducer;
|