store settings in localstorage
This commit is contained in:
@@ -7,11 +7,14 @@ import {
|
||||
setClientKey,
|
||||
passphraseRequired
|
||||
} from '@/composables/useEncryption'
|
||||
import { initializeSettings} from '@/composables/useSettings'
|
||||
import { windowIsMobile } from '@/utils/helpers'
|
||||
import SideBar from '@/components/SideBar.vue'
|
||||
import firebase from 'firebase/compat/app'
|
||||
import * as firebaseui from 'firebaseui'
|
||||
|
||||
initializeSettings()
|
||||
|
||||
const sideBarCollapsed = ref<boolean>(windowIsMobile())
|
||||
|
||||
// const Note = defineAsyncComponent(() => import('@/components/ViewModes/Note.vue'))
|
||||
@@ -90,9 +93,10 @@ provide('loading', loading)
|
||||
</main>
|
||||
</div>
|
||||
<Modal :open="passphraseRequired" :persistent="true">
|
||||
<template #title>Enter your passphrase</template>
|
||||
<template #default>
|
||||
<p>
|
||||
Your notes are encrypted. Please enter your encryption key passphrase to decrypt your notes.
|
||||
Your notes are encrypted. Please enter your encryption key passphrase to decrypt your cloud notes.
|
||||
</p>
|
||||
<input type="password" class="input-bordered input mt-4 w-full" v-model="passphrase" />
|
||||
</template>
|
||||
|
||||
@@ -2,6 +2,8 @@
|
||||
import { activeNotesSource, notesSources } from '@/composables/useNotes'
|
||||
import { signOut as firebaseSignOut } from '@/composables/useFirebase'
|
||||
import { OnClickOutside } from '@vueuse/components'
|
||||
import { preferredNotesSource } from '@/composables/useSettings'
|
||||
|
||||
const sourceLabels: { [source: string]: string } = {
|
||||
local: 'Switch to local notes',
|
||||
firebase: 'Switch to cloud notes'
|
||||
@@ -17,6 +19,7 @@ const availableNoteSources = computed(() =>
|
||||
|
||||
const signOut = async (close: () => Promise<boolean>) => {
|
||||
await firebaseSignOut()
|
||||
preferredNotesSource.value = null
|
||||
close()
|
||||
}
|
||||
|
||||
@@ -41,7 +44,7 @@ const handleClick = (fn: (...args: any[]) => any) => {
|
||||
class="text-base"
|
||||
v-for="{ source, label } in availableNoteSources"
|
||||
:key="source"
|
||||
@click="handleClick(() => (activeNotesSource = source))"
|
||||
@click="handleClick(() => (preferredNotesSource = source))"
|
||||
>
|
||||
<a>
|
||||
<i class="fa-fw fa-solid fa-database" />
|
||||
|
||||
@@ -7,20 +7,34 @@ import { decryptNotes, encryptionKey } from '@/composables/useEncryption'
|
||||
import { defaultNotes } from '@/utils/defaultNotes'
|
||||
import { mdToHtml } from '@/utils/markdown'
|
||||
import { getAllMatches } from '@/utils/helpers'
|
||||
import { preferredNotesSource } from '@/composables/useSettings'
|
||||
|
||||
export const notesSources = computed(() => ({
|
||||
local: true,
|
||||
firebase: initialized.value && user.value
|
||||
}))
|
||||
|
||||
type notesSourceValues = keyof typeof notesSources.value | null
|
||||
export const availableNotesSources = computed(() =>
|
||||
Object.entries(notesSources.value)
|
||||
.filter(([, enabled]) => enabled)
|
||||
.map(([source]) => source)
|
||||
)
|
||||
|
||||
export type notesSourceValues = keyof typeof notesSources.value | null
|
||||
|
||||
export const activeNotesSource = ref<notesSourceValues>(null)
|
||||
|
||||
watchEffect(() => {
|
||||
const getSource = (): notesSourceValues => {
|
||||
if (!initialized.value) return null
|
||||
return user.value ? 'firebase' : 'local'
|
||||
if (
|
||||
preferredNotesSource.value &&
|
||||
availableNotesSources.value.includes(preferredNotesSource.value)
|
||||
) {
|
||||
return preferredNotesSource.value
|
||||
} else {
|
||||
return user.value ? 'firebase' : 'local'
|
||||
}
|
||||
}
|
||||
activeNotesSource.value = getSource()
|
||||
})
|
||||
|
||||
24
src/composables/useSettings.ts
Normal file
24
src/composables/useSettings.ts
Normal file
@@ -0,0 +1,24 @@
|
||||
import type { notesSourceValues } from '@/composables/useNotes'
|
||||
|
||||
interface Settings {
|
||||
preferredNotesSource: notesSourceValues
|
||||
}
|
||||
|
||||
export const preferredNotesSource = ref<notesSourceValues>(null)
|
||||
|
||||
const updateSettings = () => {
|
||||
const settings: Settings = {
|
||||
preferredNotesSource: preferredNotesSource.value
|
||||
}
|
||||
localStorage.setItem('settings', JSON.stringify(settings))
|
||||
}
|
||||
|
||||
export const initializeSettings = () => {
|
||||
watch([preferredNotesSource], () => updateSettings())
|
||||
try {
|
||||
const settings: Settings = JSON.parse(localStorage.getItem('settings') || '{}')
|
||||
preferredNotesSource.value = settings.preferredNotesSource
|
||||
} catch (error) {
|
||||
console.error(error)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user