homebox/frontend/composables/use-preferences.ts

35 lines
1,006 B
TypeScript
Raw Permalink Normal View History

import type { Ref } from "vue";
import type { DaisyTheme } from "~~/lib/data/themes";
export type ViewType = "table" | "card" | "tree";
2022-09-01 22:32:03 +00:00
export type LocationViewPreferences = {
showDetails: boolean;
2022-09-06 18:32:13 +00:00
showEmpty: boolean;
editorAdvancedView: boolean;
itemDisplayView: ViewType;
theme: DaisyTheme;
2022-09-01 22:32:03 +00:00
};
/**
2022-09-02 17:46:20 +00:00
* useViewPreferences loads the view preferences from local storage and hydrates
2022-09-01 22:32:03 +00:00
* them. These are reactive and will update the local storage when changed.
*/
2022-09-02 17:46:20 +00:00
export function useViewPreferences(): Ref<LocationViewPreferences> {
2022-09-01 22:32:03 +00:00
const results = useLocalStorage(
"homebox/preferences/location",
2022-09-01 22:32:03 +00:00
{
showDetails: true,
2022-09-06 18:32:13 +00:00
showEmpty: true,
editorAdvancedView: false,
itemDisplayView: "card",
theme: "homebox",
2022-09-01 22:32:03 +00:00
},
{ 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<LocationViewPreferences>;
}