layoutStore.ts 889 B

123456789101112131415161718192021222324252627282930313233343536
  1. import type { Ref } from "@vue/reactivity";
  2. export const useLayoutStore = defineStore('layout', () => {
  3. const isHeaderVisible: Ref<boolean> = ref(false)
  4. const setIsHeaderVisible = (value: boolean) => {
  5. isHeaderVisible.value = value
  6. }
  7. const isFooterVisible: Ref<boolean> = ref(false)
  8. const setIsFooterVisible = (value: boolean) => {
  9. isFooterVisible.value = value
  10. }
  11. const resetAnchoredSections = () =>{
  12. isAnchoredSectionOnScreen.value = {}
  13. }
  14. const isAnchoredSectionOnScreen: Ref<Record<string, boolean>> = ref({})
  15. const setIsAnchoredSectionOnScreen = (sectionId: string, value: boolean) => {
  16. isAnchoredSectionOnScreen.value[sectionId] = value
  17. }
  18. return {
  19. isHeaderVisible,
  20. setIsHeaderVisible,
  21. isFooterVisible,
  22. setIsFooterVisible,
  23. isAnchoredSectionOnScreen,
  24. resetAnchoredSections,
  25. setIsAnchoredSectionOnScreen
  26. }
  27. })