| | |
| | | <!-- </view>--> |
| | | <!-- </view>--> |
| | | <!-- 营销管理模块 --> |
| | | <view class="common-module marketing-module"> |
| | | <view class="common-module marketing-module" v-if="hasMarketingItems"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">营销管理</text> |
| | |
| | | </view> |
| | | </view> |
| | | <!-- <!– 采购管理模块 –>--> |
| | | <view class="common-module purchase-module"> |
| | | <view class="common-module purchase-module" v-if="hasPurchaseItems"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">采购管理</text> |
| | |
| | | </view> |
| | | </view> |
| | | <!-- <!– 协同办公模块 –> --> |
| | | <view class="common-module collaboration-module"> |
| | | <view class="common-module collaboration-module" v-if="hasCollaborationItems"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">协同办公</text> |
| | |
| | | </view> |
| | | </view> |
| | | <!-- 安全生产模块 --> |
| | | <view class="common-module collaboration-module"> |
| | | <view class="common-module collaboration-module" v-if="hasSafetyItems"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">安全生产</text> |
| | |
| | | </view> |
| | | </view> |
| | | <!-- 人力资源模块 --> |
| | | <view class="common-module collaboration-module"> |
| | | <view class="common-module collaboration-module" v-if="hasHumanResourcesItems"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">人力资源</text> |
| | |
| | | </view> |
| | | </view> |
| | | <!-- 生产管控模块 --> |
| | | <!-- <view class="common-module production-module">--> |
| | | <!-- <view class="module-header">--> |
| | | <!-- <view class="module-title-container">--> |
| | | <!-- <text class="module-title">生产管控</text>--> |
| | | <!-- </view>--> |
| | | <!-- </view>--> |
| | | <!-- <view class="module-content">--> |
| | | <!-- <up-grid--> |
| | | <!-- :border="false"--> |
| | | <!-- col="4"--> |
| | | <!-- >--> |
| | | <!-- <up-grid-item--> |
| | | <!-- v-for="(item, index) in productionItems"--> |
| | | <!-- :key="index"--> |
| | | <!-- @click="handleCommonItemClick(item)"--> |
| | | <!-- >--> |
| | | <!-- <view class="icon-container" :style="{ background: item.bgColor }">--> |
| | | <!-- <up-icon--> |
| | | <!-- :name="item.icon"--> |
| | | <!-- :size="58"--> |
| | | <!-- color="#ffffff"--> |
| | | <!-- ></up-icon>--> |
| | | <!-- </view>--> |
| | | <!-- <text class="item-label">{{item.label}}</text>--> |
| | | <!-- </up-grid-item>--> |
| | | <!-- </up-grid>--> |
| | | <!-- </view>--> |
| | | <!-- </view>--> |
| | | <!-- 生产管控模块 --> |
| | | <view class="common-module equipment-module"> |
| | | <view class="common-module equipment-module" v-if="hasProductionItems"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">生产管控</text> |
| | |
| | | </view> |
| | | </view> |
| | | <!-- 设备管理模块 --> |
| | | <view class="common-module equipment-module"> |
| | | <view class="common-module equipment-module" v-if="hasEquipmentItems"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">设备管理</text> |
| | |
| | | </template> |
| | | |
| | | <script setup> |
| | | import { ref, onMounted, nextTick, reactive } from "vue"; |
| | | import { ref, onMounted, nextTick, reactive, computed } from "vue"; |
| | | import { userLoginFacotryList } from "@/api/login"; |
| | | import { getProductWorkOrderById } from "@/api/productionManagement/productionReporting"; |
| | | import modal from "@/plugins/modal"; |
| | |
| | | // 协同办公功能数据 |
| | | const collaborationItems = reactive([ |
| | | { |
| | | icon: "/static/images/icon/gongchuguanli@2x.png", |
| | | label: "考勤管理", |
| | | }, |
| | | { |
| | | icon: "/static/images/icon/baoxiaoguanli.png", |
| | | label: "财务管理", |
| | | label: "协同审批", |
| | | }, |
| | | { |
| | | icon: "/static/images/icon/huiyiliebiao@2x.png", |
| | |
| | | icon: "/static/images/icon/guizhangzhidu@2x.png", |
| | | label: "规章制度", |
| | | }, |
| | | // { |
| | | // icon: "/static/images/icon/xietongshenpi@2x.png", |
| | | // label: "协同审批", |
| | | // }, |
| | | { |
| | | icon: "/static/images/icon/kehubaifang@2x.png", |
| | | label: "客户拜访", |
| | |
| | | { |
| | | icon: "/static/images/icon/shbeibaoyang@2x.png", |
| | | label: "设备保养", |
| | | }, |
| | | { |
| | | icon: "/static/images/icon/guzhangfenxi@2x.png", |
| | | label: "分析追溯", |
| | | bgColor: "#ff9800", |
| | | }, |
| | | { |
| | | icon: "/static/images/icon/zhinengpaidan@2x.png", |
| | | label: "智能派单", |
| | | bgColor: "#ff6b35", |
| | | }, |
| | | { |
| | | icon: "/static/images/icon/zuoyezhidao@2x.png", |
| | | label: "作业指导", |
| | | bgColor: "#4caf50", |
| | | }, |
| | | { |
| | | icon: "/static/images/icon/jieguoyanzheng@2x.png", |
| | | label: "结果验证", |
| | | bgColor: "#9c27b0", |
| | | }, |
| | | { |
| | | icon: "/static/images/icon/xunjianshangchuan@2x.png", |
| | |
| | | url: "/pages/cooperativeOffice/collaborativeApproval/index4", |
| | | }); |
| | | break; |
| | | case "考勤管理": |
| | | case "协同审批": |
| | | uni.navigateTo({ |
| | | url: "/pages/indexItem?label=考勤管理", |
| | | }); |
| | | break; |
| | | case "财务管理": |
| | | uni.navigateTo({ |
| | | url: "/pages/indexItem?label=财务管理", |
| | | url: "/pages/indexItem?label=协同审批", |
| | | }); |
| | | break; |
| | | case "会议管理": |
| | | uni.navigateTo({ |
| | | url: "/pages/indexItem?label=会议管理", |
| | | }); |
| | | break; |
| | | case "通知公告": |
| | | uni.navigateTo({ |
| | | url: "/pages/cooperativeOffice/noticeManagement/index", |
| | | }); |
| | | break; |
| | | case "知识库": |
| | | uni.navigateTo({ |
| | | url: "/pages/managementMeetings/knowledgeBase/index", |
| | | }); |
| | | break; |
| | | case "用印管理": |
| | | uni.navigateTo({ |
| | | url: "/pages/managementMeetings/sealManagement/index", |
| | | }); |
| | | break; |
| | | case "规章制度": |
| | | uni.navigateTo({ |
| | | url: "/pages/managementMeetings/rulesRegulationsManagement/index", |
| | | }); |
| | | break; |
| | | case "客户拜访": |
| | | uni.navigateTo({ |
| | | url: "/pages/cooperativeOffice/clientVisit/index", |
| | | }); |
| | | break; |
| | | case "采购管理": |
| | |
| | | url: "/pages/cooperativeOffice/collaborativeApproval/index6", |
| | | }); |
| | | break; |
| | | case "出库管理": |
| | | case "发货审批": |
| | | uni.navigateTo({ |
| | | url: "/pages/cooperativeOffice/collaborativeApproval/index7", |
| | | }); |
| | |
| | | case "会议看板": |
| | | uni.navigateTo({ |
| | | url: "/pages/managementMeetings/meetingBoard/index", |
| | | }); |
| | | break; |
| | | case "通知公告": |
| | | uni.navigateTo({ |
| | | url: "/pages/cooperativeOffice/noticeManagement/index", |
| | | }); |
| | | break; |
| | | case "知识库": |
| | | uni.navigateTo({ |
| | | url: "/pages/managementMeetings/knowledgeBase/index", |
| | | }); |
| | | break; |
| | | case "用印管理": |
| | | uni.navigateTo({ |
| | | url: "/pages/managementMeetings/sealManagement/index", |
| | | }); |
| | | break; |
| | | case "规章制度": |
| | | uni.navigateTo({ |
| | | url: "/pages/managementMeetings/rulesRegulationsManagement/index", |
| | | }); |
| | | break; |
| | | |
| | | case "协同审批": |
| | | uni.navigateTo({ |
| | | url: "/pages/cooperativeOffice/collaborativeApproval/index", |
| | | }); |
| | | break; |
| | | case "客户拜访": |
| | | uni.navigateTo({ |
| | | url: "/pages/cooperativeOffice/clientVisit/index", |
| | | }); |
| | | break; |
| | | case "生产订单": |
| | |
| | | }); |
| | | }; |
| | | function loginSuccess(result) { |
| | | // 获取路由权限 |
| | | userStore.getRouters().then(() => { |
| | | console.log("路由权限获取成功"); |
| | | // 过滤菜单项 |
| | | filterMenuItemsByRoutes(); |
| | | }).catch(error => { |
| | | console.error("获取路由权限失败:", error); |
| | | }); |
| | | uni.reLaunch({ |
| | | url: "/pages/index", |
| | | }); |
| | |
| | | } |
| | | }; |
| | | |
| | | // 根据路由权限过滤菜单项 |
| | | const filterMenuItemsByRoutes = () => { |
| | | const routers = userStore.routers || []; |
| | | |
| | | // 如果没有路由权限数据,不进行过滤(显示所有菜单) |
| | | if (!routers || routers.length === 0) { |
| | | console.log("暂无路由权限数据,显示所有菜单"); |
| | | return; |
| | | } |
| | | |
| | | // 收集所有有权限的菜单标题(根据 meta.title) |
| | | const allowedMenuTitles = new Set(); |
| | | const collectMenuTitles = (routes) => { |
| | | if (!Array.isArray(routes)) return; |
| | | routes.forEach(route => { |
| | | // 收集当前路由的标题 |
| | | if (route.meta && route.meta.title) { |
| | | allowedMenuTitles.add(route.meta.title); |
| | | } |
| | | // 递归处理子路由 |
| | | if (route.children && route.children.length > 0) { |
| | | collectMenuTitles(route.children); |
| | | } |
| | | }); |
| | | }; |
| | | collectMenuTitles(routers); |
| | | |
| | | console.log("允许的菜单标题:", Array.from(allowedMenuTitles)); |
| | | console.log("过滤前 - 营销管理:", marketingItems.length, "采购管理:", purchaseItems.length, "协同办公:", collaborationItems.length); |
| | | console.log("过滤前 - 安全生产:", safetyItems.length, "人力资源:", humanResourcesItems.length, "生产管控:", productionItems.length, "设备管理:", equipmentItems.length); |
| | | |
| | | // 过滤营销管理菜单 |
| | | const originalMarketing = [ |
| | | { icon: "/static/images/icon/xiaoshoutaizhang@2x.png", label: "销售台账" }, |
| | | { icon: "/static/images/icon/kaipiaodengji@2x.png", label: "开票登记" }, |
| | | { icon: "/static/images/icon/kaipiaotaizhang@2x.png", label: "开票台账" }, |
| | | { icon: "/static/images/icon/huikuandengji@2x.png", label: "回款登记" }, |
| | | { icon: "/static/images/icon/huikuanliushui@2x.png", label: "回款流水" }, |
| | | { icon: "/static/images/icon/kehuwanglai@2x.png", label: "客户往来" }, |
| | | ]; |
| | | const filteredMarketing = originalMarketing.filter(item => { |
| | | return allowedMenuTitles.has(item.label); |
| | | }); |
| | | marketingItems.splice(0, marketingItems.length, ...filteredMarketing); |
| | | |
| | | // 过滤协同办公菜单 |
| | | const originalCollaboration = [ |
| | | { icon: "/static/images/icon/baoxiaoguanli.png", label: "协同审批" }, |
| | | { icon: "/static/images/icon/huiyiliebiao@2x.png", label: "会议管理" }, |
| | | { icon: "/static/images/icon/tongzhigonggao@2x.png", label: "通知公告" }, |
| | | { icon: "/static/images/icon/zhishiku@2x.png", label: "知识库" }, |
| | | { icon: "/static/images/icon/yongyinguanli@2x.png", label: "用印管理" }, |
| | | { icon: "/static/images/icon/guizhangzhidu@2x.png", label: "规章制度" }, |
| | | { icon: "/static/images/icon/kehubaifang@2x.png", label: "客户拜访" }, |
| | | ]; |
| | | const filteredCollaboration = originalCollaboration.filter(item => { |
| | | // 处理标题不完全匹配的情况 |
| | | let matched = allowedMenuTitles.has(item.label); |
| | | // 特殊处理:规章制度 -> 规章制度管理 |
| | | if (!matched && item.label === "规章制度") { |
| | | matched = allowedMenuTitles.has("规章制度管理"); |
| | | } |
| | | return matched; |
| | | }); |
| | | collaborationItems.splice(0, collaborationItems.length, ...filteredCollaboration); |
| | | |
| | | // 过滤采购管理菜单 |
| | | const originalPurchase = [ |
| | | { icon: "/static/images/icon/caigoutaizhang@2x.png", label: "采购台账" }, |
| | | { icon: "/static/images/icon/laipiaodengji@2x.png", label: "来票登记" }, |
| | | { icon: "/static/images/icon/laipiaotaizhang@2x.png", label: "来票台账" }, |
| | | { icon: "/static/images/icon/fukuanjingji@2x.png", label: "付款登记" }, |
| | | { icon: "/static/images/icon/fukuanliushui@2x.png", label: "付款流水" }, |
| | | { icon: "/static/images/icon/gongyingshangwanglai@2x.png", label: "供应商往来" }, |
| | | ]; |
| | | const filteredPurchase = originalPurchase.filter(item => { |
| | | return allowedMenuTitles.has(item.label); |
| | | }); |
| | | purchaseItems.splice(0, purchaseItems.length, ...filteredPurchase); |
| | | |
| | | // 过滤安全生产菜单 |
| | | const originalSafety = [ |
| | | { icon: "/static/images/icon/caigoutaizhang@2x.png", label: "规程资质" }, |
| | | { icon: "/static/images/icon/caigoutaizhang@2x.png", label: "危险源台账" }, |
| | | { icon: "/static/images/icon/caigoutaizhang@2x.png", label: "危险作业" }, |
| | | { icon: "/static/images/icon/guzhangfenxi@2x.png", label: "隐患排查" }, |
| | | { icon: "/static/images/icon/guzhangfenxi@2x.png", label: "危险物料" }, |
| | | { icon: "/static/images/icon/guzhangfenxi@2x.png", label: "应急预案" }, |
| | | { icon: "/static/images/icon/guzhangfenxi@2x.png", label: "事故上报" }, |
| | | { icon: "/static/images/icon/guzhangfenxi@2x.png", label: "安全培训" }, |
| | | ]; |
| | | const filteredSafety = originalSafety.filter(item => { |
| | | return allowedMenuTitles.has(item.label); |
| | | }); |
| | | safetyItems.splice(0, safetyItems.length, ...filteredSafety); |
| | | |
| | | // 过滤人力资源菜单 |
| | | const originalHumanResources = [ |
| | | { icon: "/static/images/icon/caigoutaizhang@2x.png", label: "打卡签到" }, |
| | | { icon: "/static/images/icon/caigoutaizhang@2x.png", label: "人员薪资" }, |
| | | ]; |
| | | const filteredHumanResources = originalHumanResources.filter(item => { |
| | | return allowedMenuTitles.has(item.label); |
| | | }); |
| | | humanResourcesItems.splice(0, humanResourcesItems.length, ...filteredHumanResources); |
| | | |
| | | // 过滤生产管控菜单 |
| | | const originalProduction = [ |
| | | { icon: "/static/images/icon/shengchanbaogong@2x.png", label: "生产报工", bgColor: "#673AB7" }, |
| | | ]; |
| | | const filteredProduction = originalProduction.filter(item => { |
| | | return allowedMenuTitles.has(item.label); |
| | | }); |
| | | productionItems.splice(0, productionItems.length, ...filteredProduction); |
| | | |
| | | // 过滤设备管理菜单 |
| | | const originalEquipment = [ |
| | | { icon: "/static/images/icon/shbeibaoxiu@2x.png", label: "运行管理" }, |
| | | { icon: "/static/images/icon/shbeibaoxiu@2x.png", label: "设备报修" }, |
| | | { icon: "/static/images/icon/shbeibaoyang@2x.png", label: "设备保养" }, |
| | | { icon: "/static/images/icon/xunjianshangchuan@2x.png", label: "巡检上传" }, |
| | | ]; |
| | | const filteredEquipment = originalEquipment.filter(item => { |
| | | return allowedMenuTitles.has(item.label); |
| | | }); |
| | | equipmentItems.splice(0, equipmentItems.length, ...filteredEquipment); |
| | | |
| | | console.log("过滤后 - 营销管理:", marketingItems.length, "采购管理:", purchaseItems.length, "协同办公:", collaborationItems.length); |
| | | console.log("过滤后 - 安全生产:", safetyItems.length, "人力资源:", humanResourcesItems.length, "生产管控:", productionItems.length, "设备管理:", equipmentItems.length); |
| | | console.log("生产管控菜单项:", productionItems.map(item => item.label)); |
| | | }; |
| | | |
| | | // 检查模块是否有菜单项需要显示 |
| | | const hasMarketingItems = computed(() => marketingItems.length > 0); |
| | | const hasPurchaseItems = computed(() => purchaseItems.length > 0); |
| | | const hasCollaborationItems = computed(() => collaborationItems.length > 0); |
| | | const hasSafetyItems = computed(() => safetyItems.length > 0); |
| | | const hasHumanResourcesItems = computed(() => humanResourcesItems.length > 0); |
| | | const hasProductionItems = computed(() => productionItems.length > 0); |
| | | const hasEquipmentItems = computed(() => equipmentItems.length > 0); |
| | | |
| | | onMounted(() => { |
| | | // 设置用户信息 |
| | | userStore.getInfo(); |
| | | // 每次进入首页都强制刷新用户信息和路由权限,不做本地缓存判断 |
| | | userStore.getInfo().then(() => { |
| | | userStore.getRouters().then(() => { |
| | | filterMenuItemsByRoutes(); |
| | | }).catch(error => { |
| | | console.error("获取路由权限失败:", error); |
| | | }); |
| | | }); |
| | | getUserLoginFacotryList(); |
| | | // 启动通知状态定时器 |
| | | startStatusTimer(); |