import { Ref } from "vue"; export type LocationViewPreferences = { showDetails: boolean; showEmpty: boolean; editorSimpleView: boolean; }; /** * useViewPreferences loads the view preferences from local storage and hydrates * them. These are reactive and will update the local storage when changed. */ export function useViewPreferences(): Ref { const results = useLocalStorage( "homebox/preferences/location", { showDetails: true, showEmpty: true, editorSimpleView: true, }, { mergeDefaults: true } ); // casting is required because the type returned is removable, however since we // use `mergeDefaults` the result _should_ always be present. return results as unknown as Ref; }