From 3750b0f78b8d163ef0c75350ac5212ccf641a816 Mon Sep 17 00:00:00 2001 From: Dominik Pschenitschni Date: Sat, 2 Oct 2021 23:30:06 +0200 Subject: [PATCH] fix: mutation errors by make a copy of the store settings --- src/views/user/Settings.vue | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/src/views/user/Settings.vue b/src/views/user/Settings.vue index 0079f34f..e2f4a4ed 100644 --- a/src/views/user/Settings.vue +++ b/src/views/user/Settings.vue @@ -298,7 +298,6 @@ import EmailUpdateModel from '../../models/emailUpdate' import TotpModel from '../../models/totp' import TotpService from '../../services/totp' import UserSettingsService from '../../services/userSettings' -import UserSettingsModel from '../../models/userSettings' import {playSoundWhenDoneKey} from '@/helpers/playPop' import {availableLanguages, saveLanguage, getCurrentLanguage} from '@/i18n' import {getQuickAddMagicMode, setQuickAddMagicMode} from '../../helpers/quickAddMagicMode' @@ -312,6 +311,10 @@ import ListSearch from '@/components/tasks/partials/listSearch.vue' import UserSettingsDeletion from '../../components/user/settings/deletion' import DataExport from '../../components/user/settings/data-export' +function getPlaySoundWhenDoneSetting() { + return localStorage.getItem(playSoundWhenDoneKey) === 'true' || localStorage.getItem(playSoundWhenDoneKey) === null +} + export default { name: 'Settings', data() { @@ -330,15 +333,13 @@ export default { totpConfirmPasscode: '', totpDisableForm: false, totpDisablePassword: '', - playSoundWhenDone: false, + playSoundWhenDone: getPlaySoundWhenDoneSetting(), language: getCurrentLanguage(), quickAddMagicMode: getQuickAddMagicMode(), quickAddMagicPrefixes: PrefixMode, - settings: UserSettingsModel, + settings: { ...this.$store.state.auth.settings }, userSettingsService: new UserSettingsService(), - - defaultList: null, } }, components: { @@ -348,9 +349,6 @@ export default { DataExport, }, created() { - this.settings = this.$store.state.auth.settings - this.playSoundWhenDone = localStorage.getItem(playSoundWhenDoneKey) === 'true' || localStorage.getItem(playSoundWhenDoneKey) === null - this.defaultList = this.$store.getters['lists/getListById'](this.settings.defaultListId) this.totpStatus() }, mounted() { @@ -358,6 +356,9 @@ export default { this.anchorHashCheck() }, computed: { + defaultList() { + return this.$store.getters['lists/getListById'](this.settings.defaultListId) + }, caldavUrl() { let apiBase = window.API_URL.replace('/api/v1', '') if (apiBase === '') { // Frontend and api on the same host which means we need to prefix the frontend url