From 78c2d7de2150e488141e5635f2b16b81f0bc8cc2 Mon Sep 17 00:00:00 2001 From: szdot Date: Mon, 23 Jun 2025 03:02:54 +0800 Subject: [PATCH] =?UTF-8?q?=E3=80=90=E7=B1=BB=20=20=E5=9E=8B=E3=80=91?= =?UTF-8?q?=EF=BC=9Afeat=20=E3=80=90=E5=8E=9F=20=20=E5=9B=A0=E3=80=91?= =?UTF-8?q?=EF=BC=9A=E5=A2=9E=E5=8A=A0=20=E7=B3=BB=E7=BB=9F=E8=AE=BE?= =?UTF-8?q?=E7=BD=AE=20=E6=8E=A7=E5=88=B6=E6=A8=A1=E5=9D=97=E6=98=BE?= =?UTF-8?q?=E7=A4=BA=20=E9=9A=90=E8=97=8F=20=E3=80=90=E8=BF=87=20=20?= =?UTF-8?q?=E7=A8=8B=E3=80=91=EF=BC=9A=20=E3=80=90=E5=BD=B1=20=20=E5=93=8D?= =?UTF-8?q?=E3=80=91=EF=BC=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit # 类型 包含: # feat:新功能(feature) # fix:修补bug # docs:文档(documentation) # style: 格式(不影响代码运行的变动) # refactor:重构(即不是新增功能,也不是修改bug的代码变动) # test:增加测试 # chore:构建过程或辅助工具的变动 --- src/store/modules/app.js | 32 +++++++++ src/views/layout/components/main/home/set.vue | 68 +++++++++++++++++-- src/views/layout/components/menubar.vue | 44 ++++++------ 3 files changed, 121 insertions(+), 23 deletions(-) diff --git a/src/store/modules/app.js b/src/store/modules/app.js index e37aedd..1903a3a 100644 --- a/src/store/modules/app.js +++ b/src/store/modules/app.js @@ -1,3 +1,24 @@ +// 默认模块显示配置 +const defaultModuleVisibilityMap = { + home: true, + model: true, + register: true, + product: true, + route: true, + planes: true, + site: true, + shop: true, + admin: true, + category: true, + broadcast: true, + order: true, + nofly: true +} + +// 从 localStorage 读取已有配置,合并覆盖默认配置 +const savedVisibility = JSON.parse(localStorage.getItem('moduleVisibilityMap') || '{}') +const moduleVisibilityMap = { ...defaultModuleVisibilityMap, ...savedVisibility } + const state = { mqttState: false, // mqtt连接状态 isCollapse: localStorage.getItem('isCollapse') ? !!+localStorage.getItem('isCollapse') : true, // 侧边导航栏 显隐 @@ -6,6 +27,8 @@ const state = { defaultLonLat: null, // 地图默认经纬度 defaultZoom: null, // 地图默认缩放 + moduleVisibilityMap, // 使用合并后的 moduleVisibilityMap 初始化 + /* 页面参数 */ orderSerch: null, // 订单列表页搜索条件 toMessageIdArr: [], // 用户管理 发布公告页面 id临时传参 @@ -14,6 +37,15 @@ const state = { } const mutations = { + // 设置 模块显示隐藏参数 + setModuleVisibility (state, { key, visible }) { + state.moduleVisibilityMap[key] = visible + localStorage.setItem('moduleVisibilityMap', JSON.stringify(state.moduleVisibilityMap)) + }, + setAllModuleVisibility (state, visibilityMap) { + state.moduleVisibilityMap = visibilityMap + localStorage.setItem('moduleVisibilityMap', JSON.stringify(state.moduleVisibilityMap)) + }, // 导航栏 显隐 setCollapse () { state.isCollapse = !state.isCollapse diff --git a/src/views/layout/components/main/home/set.vue b/src/views/layout/components/main/home/set.vue index bca859a..16680e1 100644 --- a/src/views/layout/components/main/home/set.vue +++ b/src/views/layout/components/main/home/set.vue @@ -1,19 +1,79 @@ - - diff --git a/src/views/layout/components/menubar.vue b/src/views/layout/components/menubar.vue index 9c18d13..688a20a 100644 --- a/src/views/layout/components/menubar.vue +++ b/src/views/layout/components/menubar.vue @@ -16,21 +16,27 @@ -