فهرست منبع

Merge branch 'wangtao-oa' of uskycloud/usky-web-mobile into master

gez 1 ماه پیش
والد
کامیت
1e841caf88

+ 1 - 0
README.md

@@ -6,5 +6,6 @@
 
 ## node>18.1.0||16.17.1
  
+##### 提交时执行 npm run update:setting "zhiHuiYun",防止每次文件变更
 
 

+ 168 - 154
src/manifest.json

@@ -1,46 +1,46 @@
 {
-    "name" : "综合智慧云",
-    "appid" : "__UNI__36DE3A0",
-    "description" : "综合智慧云APP,是一款助力于企业数字化的应用平台,帮助企业提升办公效率,实现组织数字化和业务数字化。",
-    "versionName" : "2.2.3",
-    "versionCode" : 23,
-    "transformPx" : false,
-    "app-plus" : {
-        "compatible" : {
-            "ignoreVersion" : true
+    "name": "综合智慧云",
+    "appid": "__UNI__36DE3A0",
+    "description": "综合智慧云APP,是一款助力于企业数字化的应用平台,帮助企业提升办公效率,实现组织数字化和业务数字化。",
+    "versionName": "2.2.3",
+    "versionCode": 23,
+    "transformPx": false,
+    "app-plus": {
+        "compatible": {
+            "ignoreVersion": true
         },
-        "kernel" : {
-            "ios" : "WKWebview"
+        "kernel": {
+            "ios": "WKWebview"
         },
-        "usingComponents" : true,
-        "nvueStyleCompiler" : "uni-app",
-        "compilerVersion" : 3,
-        "splashscreen" : {
-            "alwaysShowBeforeRender" : true,
-            "waiting" : true,
-            "autoclose" : true,
-            "delay" : 0
+        "usingComponents": true,
+        "nvueStyleCompiler": "uni-app",
+        "compilerVersion": 3,
+        "splashscreen": {
+            "alwaysShowBeforeRender": true,
+            "waiting": true,
+            "autoclose": true,
+            "delay": 0
         },
-        "screenOrientation" : [
+        "screenOrientation": [
             "portrait-primary",
             "portrait-secondary",
             "landscape-primary",
             "landscape-secondary"
         ],
-        "modules" : {
-            "VideoPlayer" : {},
-            "iBeacon" : {},
-            "Geolocation" : {},
-            "Maps" : {},
-            "Barcode" : {},
-            "Fingerprint" : {},
-            "Push" : {},
-            "Camera" : {},
-            "LivePusher" : {}
+        "modules": {
+            "VideoPlayer": {},
+            "iBeacon": {},
+            "Geolocation": {},
+            "Maps": {},
+            "Barcode": {},
+            "Fingerprint": {},
+            "Push": {},
+            "Camera": {},
+            "LivePusher": {}
         },
-        "distribute" : {
-            "android" : {
-                "permissions" : [
+        "distribute": {
+            "android": {
+                "permissions": [
                     "<uses-feature android:name=\"android.hardware.camera\"/>",
                     "<uses-feature android:name=\"android.hardware.camera.autofocus\"/>",
                     "<uses-permission android:name=\"android.permission.ACCESS_COARSE_LOCATION\"/>",
@@ -80,162 +80,176 @@
                     "<uses-permission android:name=\"android.permission.RECEIVE_BOOT_COMPLETED\"/>",
                     "<uses-permission android:name=\"android.permission.SYSTEM_ALERT_WINDOW\"/>"
                 ],
-                "minSdkVersion" : 21,
-                "abiFilters" : [ "armeabi-v7a", "arm64-v8a" ],
-                "targetSdkVersion" : 30
+                "minSdkVersion": 21,
+                "abiFilters": [
+                    "armeabi-v7a",
+                    "arm64-v8a"
+                ],
+                "targetSdkVersion": 30
             },
-            "ios" : {
-                "dSYMs" : false,
-                "privacyDescription" : {
-                    "NSPhotoLibraryUsageDescription" : "该应用需要读取你的相册,用于上传头像",
-                    "NSPhotoLibraryAddUsageDescription" : "该应用需要读取你的相册,用于拍照保存图片",
-                    "NSCameraUsageDescription" : "该应用需要你的相机,用于你拍摄上传头像信息",
-                    "NSMicrophoneUsageDescription" : "该应用需要使用你的麦克风,用于语音播放",
-                    "NSLocationWhenInUseUsageDescription" : "该应用需要你的地理位置,用于天气、签到等功能",
-                    "NSLocationAlwaysUsageDescription" : "该应用需要持续获取用户地理位置,用于天气、签到等功能",
-                    "NSLocationAlwaysAndWhenInUseUsageDescription" : "该应用需要你的地理位置,用于天气、签到等功能",
-                    "NSCalendarsUsageDescription" : "该应用需要获取你的日历,以便更好的体验",
-                    "NSContactsUsageDescription" : "该应用需要读取你的通讯录,以便联系同事",
-                    "NSBluetoothPeripheralUsageDescription" : "该应用需要你的蓝牙,以便读取相关蓝牙设备",
-                    "NFCReaderUsageDescription" : "",
-                    "NSBluetoothAlwaysUsageDescription" : "该应用需要你的蓝牙,以便读取相关蓝牙设备"
+            "ios": {
+                "dSYMs": false,
+                "privacyDescription": {
+                    "NSPhotoLibraryUsageDescription": "该应用需要读取你的相册,用于上传头像",
+                    "NSPhotoLibraryAddUsageDescription": "该应用需要读取你的相册,用于拍照保存图片",
+                    "NSCameraUsageDescription": "该应用需要你的相机,用于你拍摄上传头像信息",
+                    "NSMicrophoneUsageDescription": "该应用需要使用你的麦克风,用于语音播放",
+                    "NSLocationWhenInUseUsageDescription": "该应用需要你的地理位置,用于天气、签到等功能",
+                    "NSLocationAlwaysUsageDescription": "该应用需要持续获取用户地理位置,用于天气、签到等功能",
+                    "NSLocationAlwaysAndWhenInUseUsageDescription": "该应用需要你的地理位置,用于天气、签到等功能",
+                    "NSCalendarsUsageDescription": "该应用需要获取你的日历,以便更好的体验",
+                    "NSContactsUsageDescription": "该应用需要读取你的通讯录,以便联系同事",
+                    "NSBluetoothPeripheralUsageDescription": "该应用需要你的蓝牙,以便读取相关蓝牙设备",
+                    "NFCReaderUsageDescription": "",
+                    "NSBluetoothAlwaysUsageDescription": "该应用需要你的蓝牙,以便读取相关蓝牙设备"
                 },
-                "UIBackgroundModes" : ""
+                "UIBackgroundModes": ""
             },
-            "sdkConfigs" : {
-                "ad" : {},
-                "maps" : {
-                    "amap" : {
-                        "appkey_ios" : "fb35d03fbb17cbf7a8743a522da3c7fc",
-                        "appkey_android" : "ffc71dfd4e576596027f8f45a1b8fb2f",
-                        "name" : "amapBOujshtbA"
+            "sdkConfigs": {
+                "ad": {},
+                "maps": {
+                    "amap": {
+                        "appkey_ios": "fb35d03fbb17cbf7a8743a522da3c7fc",
+                        "appkey_android": "ffc71dfd4e576596027f8f45a1b8fb2f",
+                        "name": "amapBOujshtbA"
                     }
                 },
-                "geolocation" : {
-                    "system" : {
-                        "__platform__" : [ "ios", "android" ]
+                "geolocation": {
+                    "system": {
+                        "__platform__": [
+                            "ios",
+                            "android"
+                        ]
                     },
-                    "amap" : {
-                        "__platform__" : [ "ios", "android" ],
-                        "appkey_ios" : "fb35d03fbb17cbf7a8743a522da3c7fc",
-                        "appkey_android" : "ffc71dfd4e576596027f8f45a1b8fb2f",
-                        "name" : "amapBOujshtbA"
+                    "amap": {
+                        "__platform__": [
+                            "ios",
+                            "android"
+                        ],
+                        "appkey_ios": "fb35d03fbb17cbf7a8743a522da3c7fc",
+                        "appkey_android": "ffc71dfd4e576596027f8f45a1b8fb2f",
+                        "name": "amapBOujshtbA"
                     },
-                    "tencent" : {
-                        "__platform__" : [ "ios", "android" ],
-                        "apikey_ios" : "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX",
-                        "apikey_android" : "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX"
+                    "tencent": {
+                        "__platform__": [
+                            "ios",
+                            "android"
+                        ],
+                        "apikey_ios": "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX",
+                        "apikey_android": "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX"
                     }
                 },
-                "push" : {
-                    "unipush" : {
-                        "version" : "2",
-                        "offline" : true,
-                        "icons" : {
-                            "small" : {
-                                "hdpi" : "unpackage/res/push/36x36.png",
-                                "ldpi" : "unpackage/res/push/18x18.png",
-                                "mdpi" : "unpackage/res/push/24x24.png",
-                                "xhdpi" : "unpackage/res/push/48x48.png",
-                                "xxhdpi" : "unpackage/res/push/72x72.png"
+                "push": {
+                    "unipush": {
+                        "version": "2",
+                        "offline": true,
+                        "icons": {
+                            "small": {
+                                "hdpi": "unpackage/res/push/36x36.png",
+                                "ldpi": "unpackage/res/push/18x18.png",
+                                "mdpi": "unpackage/res/push/24x24.png",
+                                "xhdpi": "unpackage/res/push/48x48.png",
+                                "xxhdpi": "unpackage/res/push/72x72.png"
                             }
                         }
                     }
                 }
             },
-            "icons" : {
-                "android" : {
-                    "hdpi" : "unpackage/res/icons/72x72.png",
-                    "xhdpi" : "unpackage/res/icons/96x96.png",
-                    "xxhdpi" : "unpackage/res/icons/144x144.png",
-                    "xxxhdpi" : "unpackage/res/icons/192x192.png"
+            "icons": {
+                "android": {
+                    "hdpi": "unpackage/res/icons/72x72.png",
+                    "xhdpi": "unpackage/res/icons/96x96.png",
+                    "xxhdpi": "unpackage/res/icons/144x144.png",
+                    "xxxhdpi": "unpackage/res/icons/192x192.png"
                 },
-                "ios" : {
-                    "appstore" : "unpackage/res/icons/1024x1024.png",
-                    "ipad" : {
-                        "app" : "unpackage/res/icons/76x76.png",
-                        "app@2x" : "unpackage/res/icons/152x152.png",
-                        "notification" : "unpackage/res/icons/20x20.png",
-                        "notification@2x" : "unpackage/res/icons/40x40.png",
-                        "proapp@2x" : "unpackage/res/icons/167x167.png",
-                        "settings" : "unpackage/res/icons/29x29.png",
-                        "settings@2x" : "unpackage/res/icons/58x58.png",
-                        "spotlight" : "unpackage/res/icons/40x40.png",
-                        "spotlight@2x" : "unpackage/res/icons/80x80.png"
+                "ios": {
+                    "appstore": "unpackage/res/icons/1024x1024.png",
+                    "ipad": {
+                        "app": "unpackage/res/icons/76x76.png",
+                        "app@2x": "unpackage/res/icons/152x152.png",
+                        "notification": "unpackage/res/icons/20x20.png",
+                        "notification@2x": "unpackage/res/icons/40x40.png",
+                        "proapp@2x": "unpackage/res/icons/167x167.png",
+                        "settings": "unpackage/res/icons/29x29.png",
+                        "settings@2x": "unpackage/res/icons/58x58.png",
+                        "spotlight": "unpackage/res/icons/40x40.png",
+                        "spotlight@2x": "unpackage/res/icons/80x80.png"
                     },
-                    "iphone" : {
-                        "app@2x" : "unpackage/res/icons/120x120.png",
-                        "app@3x" : "unpackage/res/icons/180x180.png",
-                        "notification@2x" : "unpackage/res/icons/40x40.png",
-                        "notification@3x" : "unpackage/res/icons/60x60.png",
-                        "settings@2x" : "unpackage/res/icons/58x58.png",
-                        "settings@3x" : "unpackage/res/icons/87x87.png",
-                        "spotlight@2x" : "unpackage/res/icons/80x80.png",
-                        "spotlight@3x" : "unpackage/res/icons/120x120.png"
+                    "iphone": {
+                        "app@2x": "unpackage/res/icons/120x120.png",
+                        "app@3x": "unpackage/res/icons/180x180.png",
+                        "notification@2x": "unpackage/res/icons/40x40.png",
+                        "notification@3x": "unpackage/res/icons/60x60.png",
+                        "settings@2x": "unpackage/res/icons/58x58.png",
+                        "settings@3x": "unpackage/res/icons/87x87.png",
+                        "spotlight@2x": "unpackage/res/icons/80x80.png",
+                        "spotlight@3x": "unpackage/res/icons/120x120.png"
                     }
                 }
             },
-            "splashscreen" : {
-                "androidStyle" : "default",
-                "android" : {
-                    "hdpi" : "src/static/images/wt/bg.png"
+            "splashscreen": {
+                "androidStyle": "default",
+                "android": {
+                    "hdpi": "src/static/images/wt/bg.png"
                 },
-                "iosStyle" : "common"
+                "iosStyle": "common"
             }
         },
-        "nativePlugins" : {},
-        "safearea" : {
-            "offset" : "none"
+        "nativePlugins": {},
+        "safearea": {
+            "offset": "none"
         }
     },
-    "quickapp" : {},
-    "mp-weixin" : {
-        "appid" : "",
-        "setting" : {
-            "urlCheck" : false,
-            "checkSiteMap" : false
+    "quickapp": {},
+    "mp-weixin": {
+        "appid": "",
+        "setting": {
+            "urlCheck": false,
+            "checkSiteMap": false
         },
-        "usingComponents" : true,
-        "navigateToMiniProgramAppIdList" : [ "wxf5ad8734295d43f8" ]
+        "usingComponents": true,
+        "navigateToMiniProgramAppIdList": [
+            "wxf5ad8734295d43f8"
+        ]
     },
-    "mp-alipay" : {
-        "usingComponents" : true
+    "mp-alipay": {
+        "usingComponents": true
     },
-    "mp-baidu" : {
-        "usingComponents" : true
+    "mp-baidu": {
+        "usingComponents": true
     },
-    "mp-toutiao" : {
-        "usingComponents" : true
+    "mp-toutiao": {
+        "usingComponents": true
     },
-    "uniStatistics" : {
-        "enable" : false
+    "uniStatistics": {
+        "enable": false
     },
-    "h5" : {
-        "publicPath" : "./",
-        "title" : "综合智慧云",
-        "router" : {
-            "mode" : "hash"
+    "h5": {
+        "publicPath": "./",
+        "title": "综合智慧云",
+        "router": {
+            "mode": "hash"
         },
-        "devServer" : {
-            "https" : false,
-            "proxy" : {}
+        "devServer": {
+            "https": false,
+            "proxy": {}
         },
-        "sdkConfigs" : {
-            "maps" : {
-                "amap" : {
-                    "key" : "d4d73a7d572b6ff6028d5f67de62029a",
-                    "securityJsCode" : "be916fcd16d0b33d228c49f0ff096b17",
-                    "serviceHost" : ""
+        "sdkConfigs": {
+            "maps": {
+                "amap": {
+                    "key": "d4d73a7d572b6ff6028d5f67de62029a",
+                    "securityJsCode": "be916fcd16d0b33d228c49f0ff096b17",
+                    "serviceHost": ""
                 }
             }
         },
-        "optimization" : {
-            "treeShaking" : {
-                "enable" : true
+        "optimization": {
+            "treeShaking": {
+                "enable": true
             }
         },
-        "template" : "index.html"
+        "template": "index.html"
     },
-    "vueVersion" : "3",
-    "locale" : "zh-Hans"
-}
+    "vueVersion": "3",
+    "locale": "zh-Hans"
+}

+ 14 - 2
src/pages/business/common/projectMange/record/details.vue

@@ -2,7 +2,7 @@
   <u-navbar  :titleStyle="{ color: '#000' }" :autoBack="true" title="日报详情" :placeholder="true" :safeAreaInsetTop="true" bgColor="#fff">
     <template #left>
       <view class="u-navbar__content__left__item">
-        <u-icon name="arrow-left" size="20" color="#000"></u-icon>
+        <u-icon name="arrow-left" size="20" color="#000" @click="returnTo('business/common/projectMange/record/index')"></u-icon>
       </view>
     </template>
   </u-navbar>
@@ -153,7 +153,19 @@ const state = reactive({
 });
 
 const { dataList, userData, tabsList, tabsCurrent, pageSize, total } = toRefs(state);
-
+  /**
+ * 返回上级页面
+ * @param defaultPage 默认页面
+ */
+ function returnTo(defaultPage) {
+    if(getCurrentPages().length > 1){
+      uni.navigateBack()
+    }else{
+      uni.redirectTo({
+        url: `/pages/${defaultPage}`
+      })
+    }
+  }
 /**
  * @tabs点击事件
  */

+ 1 - 1
src/pages/business/common/projectMange/statistics/dailyReport.vue

@@ -232,7 +232,7 @@
     if(getCurrentPages().length > 1){
       uni.navigateBack()
     }else{
-      uni.switchTab({
+      uni.redirectTo({
         url: `/pages/${defaultPage}`
       })
     }

+ 15 - 0
src/pages/business/zhaf/xunJian/plan/components/content.vue

@@ -103,6 +103,7 @@ import { onLoad, onShow } from "@dcloudio/uni-app";
 import { ref, onMounted, reactive, computed, getCurrentInstance, toRefs, inject, shallowRef } from "vue";
 /*----------------------------------接口引入-----------------------------------*/
 import { updatePlan } from "@/api/business/zhaf/xunJian/plan.js";
+import { errorApi } from "@/api/business/zhaf/xunJian/index.js";
 /*----------------------------------组件引入-----------------------------------*/
 /*----------------------------------store引入-----------------------------------*/
 import { useStores, commonStores, xunJianStores } from "@/store/modules/index";
@@ -207,6 +208,20 @@ async function buttonClick(type) {
           title.value = "消息";
           content.value = "提交成功,确定后返回!";
           show.value = true;
+          errorApi()
+            .Insert(
+              {
+                "eventName": "巡检事件",
+                "eventType": 9,
+                "eventLevel": 1,
+                "eventCategory": 9,
+                "deviceId": proxy.$settingStore.deviceList.deviceId,
+                "planId": xunJianStore.planId
+              }
+            )
+            .catch((err) => {
+              proxy.$modal.msg(err);
+            });
         }
       })
       .catch((err) => {

+ 53 - 3
src/pages/business/zhaf/xunJian/plan/components/report.vue

@@ -5,6 +5,11 @@
         <u-icon name="arrow-left" size="20" color="#fff"></u-icon>
       </view>
     </template>
+    <template #right>
+      <view class="u-navbar__content__right__item font12">
+        <span @click="endInspection">结束巡检</span>
+      </view>
+    </template>
   </u-navbar>
 
   <oa-scroll
@@ -32,13 +37,13 @@
               :style="{
                 margin: 'auto auto auto 15px',
                 fontSize: '5px',
-                backgroundColor: cu.inspectionStatus == 1 ? '#ffbebb' : '#ABE399',
-                color: cu.inspectionStatus == 1 ? '#FF3128' : '#189400',
+                backgroundColor: cu.inspectionStatus == 2 ? '#ABE399' : '#ffbebb',
+                color: cu.inspectionStatus == 2 ? '#189400' : '#FF3128',
                 borderRadius: '10px',
                 padding: '0px 5px',
               }"
             >
-              {{ cu.inspectionStatus == 1 ? "未巡检" : "已巡检" }}
+              {{ cu.inspectionStatus == 2 ? "已巡检" : "未巡检" }}
             </view>
           </view>
           <view style="font-size: 13px; color: #a1a1a1; margin-bottom: 5px"> 描述:{{ cu.siteDescribe == "" || cu.siteDescribe == null ? "无" : cu.siteDescribe }} </view>
@@ -86,6 +91,7 @@ import { onLoad, onShow, onUnload } from "@dcloudio/uni-app";
 import { ref, onMounted, reactive, computed, getCurrentInstance, toRefs, inject, shallowRef } from "vue";
 /*----------------------------------接口引入-----------------------------------*/
 import { recordList, recordOption, siteDetails, planSonSiteDetails } from "@/api/business/zhaf/xunJian/plan.js";
+import { errorApi } from "@/api/business/zhaf/xunJian/index.js";
 /*----------------------------------组件引入-----------------------------------*/
 import oaMovable from "@/components/oa-movable/index.vue"; // 引入组件
 /*----------------------------------store引入-----------------------------------*/
@@ -206,9 +212,53 @@ function currentApi() {
       proxy.$modal.msg(err);
     });
 }
+/**
+ * @异常上报
+ */
+function AbnormalReport(){
+  errorApi()
+  .Insert(
+    {
+      "eventName": "执行任务",
+      "eventType": 8,
+      "eventLevel": 1,
+      "eventCategory": 8,
+      "deviceId": proxy.$settingStore.deviceList.deviceId,
+      "planId": xunJianStore.planId
+    }
+  )
+  .catch((err) => {
+    proxy.$modal.msg(err);
+  });
+}
+
+/**
+ * @结束巡检
+ */
+function endInspection() {
+
+  errorApi()
+  .Insert(
+    {
+      "eventName": "结束巡检",
+      "eventType": 10,
+      "eventLevel": 1,
+      "eventCategory": 10,
+      "deviceId": proxy.$settingStore.deviceList.deviceId,
+      "planId": xunJianStore.planId
+    }
+  ).then(() => {
+    proxy.$modal.msg("结束巡检成功");
+    uni.navigateBack();
+  })
+  .catch((err) => {
+    proxy.$modal.msg(err);
+  });
+}
 
 onLoad((options) => {
   currentApi();
+  AbnormalReport()
 });
 
 onShow(() => {

+ 2 - 0
src/pages/business/zhaf/xunJian/plan/index.vue

@@ -182,6 +182,7 @@ function reportClick(obj) {
 
   if (tabPosition.value == 0) {
     xunJianStore.planSonId = obj.id;
+    xunJianStore.planId = obj.planId;
     uni.navigateTo({
       url: "/pages/business/zhaf/xunJian/plan/components/report",
     });
@@ -299,6 +300,7 @@ function activitiesApi() {
           res.data.forEach((el) => {
             activities.value.push({
               id: el.id,
+              planId: el.planId,
               planName: el.planName,
               timestamp: (el.startTime ? el.startTime.split(":")[0] + ":" + el.startTime.split(":")[1] + "~" : "") + (el.endTime ? el.endTime.split(":")[0] + ":" + el.endTime.split(":")[1] : ""),
               planStatus: el.planStatus,

+ 141 - 34
src/pages/index.vue

@@ -1,9 +1,12 @@
 <template>
   <u-navbar :autoBack="false" :placeholder="true" :safeAreaInsetTop="true" :bgColor="proxy.$settingStore.themeColor.color">
     <template #left>
-      <view class="u-navbar__content__left__item">
+      <view class="u-navbar__content__left__item" v-if="tenantIdList.length == 1">
         <view class="u-navbar__content__left__item__title">应用中心</view>
       </view>
+      <view  v-if="tenantIdList.length > 1 && accountState">
+        <image class="unit-change" src="@/static/images/index/unitChange.png" @click="showLeftStateClick()" ></image>
+      </view>
     </template>
     <template #center>
       <view class="u-navbar__content__left__item"> </view>
@@ -77,19 +80,17 @@
       </view>
     </template>
   </oa-scroll>
-  <uni-drawer ref="showLeft" mode="left" :width="320" @change="change($event,'showLeft')">
-    <!-- <view class="close">
-      <button @click="closeDrawer('showLeft')"><text class="word-btn-white">X</text></button>
-    </view> -->
-    <text>切换企业</text>
+  <uni-drawer ref="showLeft" mode="left"   style="height:calc(100vh - 44px);width:90%;margin-top:44px;">
     <view class="unit">
-      <view class="list">
-        <u-radio-group v-model="tenantIdChange" @change="changeTenantId">
-          <u-radio :activeColor="proxy.$settingStore.themeColor.color" :name="item.id" :label="item.tenantName" v-for="(item, index) in tenantIdList" :key="index"></u-radio>
-        </u-radio-group>
+      <view class="unit-title">切换企业</view>
+      <view :class="item.id == useStore.tenantId ? 'active' : ''" class="list"  v-for="(item, index) in tenantIdList" :key="index" @click="changeTenantId(item.id)">
+        <image class="list-image" src="@/static/images/index/unit-active.png" v-if="item.id == useStore.tenantId" ></image>
+        <image class="list-image" src="@/static/images/index/unit.png" v-if="item.id != useStore.tenantId" ></image>
+        <text class="list-name">{{ item.tenantName }}</text>
+        <image class="list-right" src="@/static/images/index/right.png" v-if="item.id == useStore.tenantId"></image>
+        <text class="list-state">默认企业</text>
       </view>
     </view>
-
   </uni-drawer>
   <oa-tabbar :tabbarValue="0" :tabbarList="proxy.$constData.homeTabbar"></oa-tabbar>
 </template>
@@ -101,8 +102,9 @@ import { ref, onMounted, inject, shallowRef, reactive, getCurrentInstance, toRef
 /*----------------------------------接口引入-----------------------------------*/
 import { scan_push, getHomePageData, getFunctionalModuleStatistics, getAppRouters, qrCodeSend, getMobileBanner } from "@/api/index";
 /*----------------------------------组件引入-----------------------------------*/
+import config from "@/config";
 /*----------------------------------store引入-----------------------------------*/
-import { useStores } from "@/store/modules/index";
+import { useStores, commonStores } from "@/store/modules/index";
 /*----------------------------------公共方法引入-----------------------------------*/
 import * as jwx from "@/utils/jssdk.js"; //引入js sdk的封装
 import { getToken, setToken, removeToken } from "@/utils/auth";
@@ -112,9 +114,11 @@ import { decrypt } from "@/plugins/jsencrypt";
 /*----------------------------------公共变量-----------------------------------*/
 const { proxy } = getCurrentInstance();
 const useStore = useStores();
+const commonStore = commonStores();
 /*----------------------------------变量声明-----------------------------------*/
-const touchStartX = ref(0); // 触摸开始X轴坐标
-const showLeft = ref(false); // 左侧菜单显示状态
+const accountState = ref(false); // 有效账号状态(用于企业切换)
+const showLeft = ref(false); // 左侧菜单
+const showLeftState = ref(false); // 左侧菜单显示状态
 const tenantIdChange = ref(""); // 切换租户ID
 const tenantIdList = ref([]); // 租户ID列表
 const state = reactive({
@@ -129,48 +133,90 @@ const state = reactive({
   recentlyUsed: [],
 });
 const { dialogFlag } = toRefs(state);
-
-function touchStart(e){
-  touchStartX.value = e.touches[0].clientX;
-}
-// 触摸结束时触发此函数
-function touchEnd(e) {
-    // 计算触摸结束时与开始时的坐标差值
-    let deltaX = e.changedTouches[0].clientX - touchStartX.value;
-    if(deltaX > 100){
-      showDrawer()
-    }
+/**
+ * @企业弹框切换
+ */
+function showLeftStateClick(){
+  showLeftState.value = !showLeftState.value;
+  if(showLeftState.value){
+    showDrawer()
+  }else{
+    closeDrawer()
+  }
 }
 // 单位打开窗口
 function showDrawer() {
-  // showLeft.value.open()
+  showLeft.value.open()
 }
 // 单位关闭窗口
-function 	closeDrawer(e) {
+function closeDrawer(e) {
   showLeft.value.close()
 }
 //获取企业列表
 function getTenantList(id){
   getTenantByUser(id).then((res) => {
     tenantIdList.value = res.data
+    if(storage.get("account")?.userName && storage.get("account")?.passWord){
+      accountState.value = true;
+    }
   })
 }
-function changeTenantId(){
-  if(useStore.userName && useStore.password){
-    
-  }
+/**
+ * @企业切换
+ */
+function changeTenantId(id){
+  
+  storage.set("tenantId",id)
+  var info = JSON.parse(JSON.stringify({
+    userName:storage.get("account")?.userName,
+    passWord:storage.get("account")?.passWord,
+    tenantId:id,
+  }))
+  useStore.LogOut().then(() => {
+    //#ifdef APP-PLUS
+      uni.navigateTo({
+        url: "/pages/index",
+      });
+    //#endif
+    //#ifndef APP-PLUS
+    //#endif
+      if (localStorage.getItem("type")) {
+          wx.miniProgram.navigateTo({
+              appId: 'wxf5ad8734295d43f8',
+              url: '/pages/login?type=logout'
+          })
+      } else {
+        useStore.Login(
+          {
+            username: decrypt(info.userName),
+            password: decrypt(info.passWord),
+            tenantId: id,
+            method:"switch",
+            cids: proxy.$settingStore.pushClientId || undefined,
+            type: proxy.$common.isWechatMp() ? "wx" : "app",
+            openId: proxy.$common.isWechatMp() ? localStorage.getItem("wxOpenId") : undefined,
+          }
+        ).then(() => {
+          // /** 获取用户信息 */
+          useStore.SET_STORAGE_OBJECT_KEYS({"tenantId":id})
+          proxy.$modal.closeLoading();
+          useStore.GetInfo().then((res) => {
+            proxy.$settingStore.initThemeColor(storageSystem.get("themeColor")); //初始化默认主题
+            init()
+            closeDrawer()
+          });
+        });
+      }
+  });
 }
 /**
  * @初始化
  */
 async function init(options) {
-  setTimeout(()=>{
     if(useStore?.userId){
       tenantIdChange.value = useStore.tenantId; //切换租户ID
-      console.log("切换租户ID", useStore)
       getTenantList(useStore.userId); //调用获取企业列表方法
     }
-  },2000)
   //#ifdef H5
   await useStore.GetWxOpenId(2, options); //调用获取微信公众号openId
   //#endif
@@ -490,4 +536,65 @@ onShow(() => {
     }
   }
 }
+.unit-change{
+  width:18px;
+  height:18px;
+  position:fixed;
+  top:12px;
+  left:12px;
+}
+.unit{
+  width:100vw !important;
+  height:100%;
+  background: #0D2E59;
+  position:fixed;
+  top:0px;
+  left:0%;
+  &-title{
+    margin:15px 0 10px 10px;
+    color:#fff;
+  }
+  .list{
+    margin-top:10px;
+    padding:10px;
+    position:relative;
+    width:90%;
+    &-image{
+      width:29px;
+      height:29px;
+      vertical-align:middle;
+      margin-right:10px;
+    }
+    &-name{
+      vertical-align:middle;
+      color:#fff;
+      width:60%;
+      display:inline-block;
+      white-space: nowrap; /* 防止文本换行 */
+      overflow: hidden; /* 隐藏超出容器的文本 */
+      text-overflow: ellipsis; /* 显示省略号以代表被隐藏的文本 */
+    }
+    &-right{
+      position:absolute;
+      top:38%;
+      right:30%;
+      width:16px;
+      height:11px;
+      vertical-align:middle;
+    }
+    &-state{
+      position:absolute;
+      right:20px;
+      top:16px;
+      font-size:12px;
+      color:#2A98FF;
+    }
+    &-state.active{
+      color:#999;
+    }
+  }
+  .list.active{
+    background:#193B61;
+  }
+}
 </style>

+ 0 - 4
src/pages/login.vue

@@ -304,10 +304,6 @@ onShow(() => {
 });
 
 onLoad((options) => {
-  // console.log(linkUrl.value)
-  console.log("options");
-  console.log(options);
-
   if (options.dataToken) {
     localStorage.setItem("App-Token", options.dataToken);
     localStorage.setItem("type", "innerH5");

+ 1 - 1
src/pages/mine.vue

@@ -52,7 +52,7 @@
                 <view>新消息通知</view>
               </view>
             </view>
-            <view class="list-cell list-cell-arrow" @click="proxy.$settingStore.handleAbout()" v-if="config.appInfo.appid != '__UNI__BF1A1F0'">
+            <view class="list-cell list-cell-arrow" @click="proxy.$settingStore.handleAbout()">
               <view class="menu-item">
                 <view class="iconfont oaIcon-aixin menu-item-icon"></view>
                 <view>关于我们</view>

+ 10 - 5
src/pages/mine/about/index.vue

@@ -8,7 +8,12 @@
       </template>
     </u-navbar>
 
-    <view class="oa-header-section text-center">
+    <view class="oa-header-section text-center" v-if="config.appInfo.appid != '__UNI__BF1A1F0'">
+      <image style="width: 130rpx; height: 130rpx" mode="heightFix" :src="useStore.loginLogo" v-if="useStore.loginLogo" />
+      <image style="width: 130rpx; height: 130rpx" mode="heightFix" src="@/static/logo200.png" v-else />
+      <uni-title type="h2" :title="useStore.loginTitle"></uni-title>
+    </view>
+    <view class="oa-header-section text-center" v-else>
       <image style="width: 130rpx; height: 130rpx" mode="heightFix" :src="useStore.loginLogo" v-if="useStore.loginLogo" />
       <image style="width: 130rpx; height: 130rpx" mode="heightFix" src="@/static/logo200.png" v-else />
       <uni-title type="h2" :title="useStore.loginTitle"></uni-title>
@@ -22,19 +27,19 @@
             <view class="mr15 ml-auto text-right">v{{ version }}</view>
           </view>
         </view>
-        <view class="list-cell list-cell-arrow">
+        <view class="list-cell list-cell-arrow" v-if="config.appInfo.appid != '__UNI__BF1A1F0'">
           <view class="menu-item">
             <view>官方邮箱</view>
             <view class="mr15 ml-auto text-right">{{ email }}</view>
           </view>
         </view>
-        <view class="list-cell list-cell-arrow">
+        <view class="list-cell list-cell-arrow" v-if="config.appInfo.appid != '__UNI__BF1A1F0'">
           <view class="menu-item">
             <view>服务热线</view>
             <view class="mr15 ml-auto text-right">{{ hotline }}</view>
           </view>
         </view>
-        <view class="list-cell list-cell-arrow">
+        <view class="list-cell list-cell-arrow" v-if="config.appInfo.appid != '__UNI__BF1A1F0'">
           <view class="menu-item">
             <view>公司网站</view>
             <view class="mr15 ml-auto text-right">
@@ -45,7 +50,7 @@
       </view>
     </view>
 
-    <view class="oa-footer-section">
+    <view class="oa-footer-section" v-if="config.appInfo.appid != '__UNI__BF1A1F0'">
       <view>{{ copyright }}</view>
       <u-text :text="filingInfo.code" :href="filingInfo.href" mode="link" align="center" size="12"></u-text>
     </view>

BIN
src/static/images/banner/banner01.jpg


BIN
src/static/images/banner/banner02.jpg


BIN
src/static/images/banner/banner03.jpg


BIN
src/static/images/index/right.png


BIN
src/static/images/index/unit-active.png


BIN
src/static/images/index/unit.png


BIN
src/static/images/index/unitChange.png


+ 23 - 18
src/store/modules/setting.js

@@ -307,32 +307,37 @@ const settingStores = defineStore("storage-setting", {
             }
             // 智能会议
             else if (config.appInfo.appid === "__UNI__F3963F8") {
+                data.appKey = platform === "android" ? "455032139442b1fe00b75b231474792e" : "455032139442b1fe00b75b231474792e"
             }
             // 智能门禁
             else if (config.appInfo.appid === "__UNI__8D6E9FD") {
+                data.appKey = platform === "android" ? "625265d978931967076754b784b676fe" : "625265d978931967076754b784b676fe"
             }
 
             modal.loading("加载中");
-            checkUpdates(data).then((res) => {
-                if (res.code == 0) {
-                    if (res.data.buildHaveNewVersion == true) {
+            checkUpdates(data)
+                .then((res) => {
+                    if (res.code == 0 && res.data.buildHaveNewVersion == true) {
                         //安卓手机弹窗升级
                         if (platform === "android") {
                             success(res)
                         }
                         //IOS无法在线升级提示到商店下载
                         else {
+                            //#ifdef APP-PLUS 
                             let appleId = 6449016600
                             plus.runtime.launchApplication({
                                 action: `itms-apps://itunes.apple.com/cn/app/id${appleId}`,
                             })
+                            //#endif
                         }
                     } else {
                         modal.msg("您的软件版本已是最新");
                     }
                     modal.closeLoading();
-                }
-            });
+                }).catch((err) => {
+                    modal.closeLoading();
+                });
         },
 
         /**
@@ -362,32 +367,32 @@ const settingStores = defineStore("storage-setting", {
         handleLogout() {
             const useStore = useStores();
             //#ifdef APP-PLUS
-            if(config.appInfo.appid == '__UNI__BF1A1F0'){
-                modal.confirmInput("确定注销并退出系统吗?","请输入密码").then((res) => {
-                    if(res.confirm){
-                        if(!res.content){
+            if (config.appInfo.appid == '__UNI__BF1A1F0') {
+                modal.confirmInput("确定注销并退出系统吗?", "请输入密码").then((res) => {
+                    if (res.confirm) {
+                        if (!res.content) {
                             modal.msg("请输入密码")
-                        }else if(res.content == "sh628628"){
+                        } else if (res.content == "sh628628") {
                             useStore.LogOut().then(() => {
                                 modal.msgSuccess("退出成功")
                                 tab.reLaunch("/pages/index");
                             });
-                        }else{
+                        } else {
                             modal.msg("密码错误")
                         }
                     }
                 });
-            }else{
-                modal.confirmInput("确定注销并退出系统吗?","请输入密码").then((res) => {
-                    if(res.confirm){
-                        if(!res.content){
+            } else {
+                modal.confirmInput("确定注销并退出系统吗?", "请输入密码").then((res) => {
+                    if (res.confirm) {
+                        if (!res.content) {
                             modal.msg("请输入密码")
-                        }else if(res.content == "sh628628"){
+                        } else if (res.content == "sh628628") {
                             useStore.LogOut().then(() => {
                                 modal.msgSuccess("退出成功")
                                 tab.reLaunch("/pages/index");
                             });
-                        }else{
+                        } else {
                             modal.msg("密码错误")
                         }
                     }
@@ -409,7 +414,7 @@ const settingStores = defineStore("storage-setting", {
                 });
             });
             //#endif
-            
+
         },
         /**
          * @初始化默认主题

+ 2 - 3
src/store/modules/user.js

@@ -28,7 +28,7 @@ const useStores = defineStore("useStores", {
     roles: storage.get("roles"),//用户权限
     permissions: storage.get("permissions"),
     userName: "",//用户名
-    password: "",//密码
+    passWord: "",//密码
 
     loginTitle: storage.get("loginTitle"),
     loginBottomTitle: storage.get("loginBottomTitle"),
@@ -53,8 +53,7 @@ const useStores = defineStore("useStores", {
             this.SET_TOKEN(res.data.access_token)
             setToken(res.data.access_token);
             this.codeTime = 0
-            this.userName = encrypt(data.username)
-            this.password = encrypt(data.password)
+            storage.set("account",{ userName:encrypt(data.username),passWord:encrypt(data.password) })
             resolve(res);
             resolve();
           })

+ 1 - 0
src/store/modules/xunJian.js

@@ -9,6 +9,7 @@ import keyListen from "@/plugins/keyListen.plugins.js";
 
 const xunJianStores = defineStore(`storage-xunJian`, {
   state: () => ({
+    planId: null, //巡检计划页 计划Id
     planTabs: 0, //巡检计划页 tabs切换值
     siteId: null, //巡检计划页 站点id
     planSonId: null, //巡检计划页 子计划id

+ 1 - 1
src/uni_modules/c-progress-circle/components/c-progress-circle/c-progress-circle.vue

@@ -9,7 +9,7 @@
 		</view>
 		<view class="cneter-box">
 			<slot>
-				{{(progress*100).toFixed(2)}}%
+				{{Math.round(progress*100)}}%
 			</slot>
 		</view>
 	</view>

+ 40 - 40
unpackage/config/setting.js

@@ -32,10 +32,10 @@ filesToModify.forEach((file) => {
                 geolocation.tencent.apikey_ios = "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX"
                 geolocation.tencent.apikey_android = "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX"
                 icons.android = {
-                    "hdpi" : "unpackage/res/icons/72x72.png",
-                    "xhdpi" : "unpackage/res/icons/96x96.png",
-                    "xxhdpi" : "unpackage/res/icons/144x144.png",
-                    "xxxhdpi" : "unpackage/res/icons/192x192.png"
+                    "hdpi": "unpackage/res/icons/72x72.png",
+                    "xhdpi": "unpackage/res/icons/96x96.png",
+                    "xxhdpi": "unpackage/res/icons/144x144.png",
+                    "xxxhdpi": "unpackage/res/icons/192x192.png"
                 }
                 icons.ios.appstore = "unpackage/res/icons/1024x1024.png"
                 icons.ios.ipad = {
@@ -60,11 +60,11 @@ filesToModify.forEach((file) => {
                     "spotlight@3x": "unpackage/res/icons/120x120.png"
                 }
                 push.unipush.icons.small = {
-                    "hdpi" : "unpackage/res/push/36x36.png",
-                    "ldpi" : "unpackage/res/push/18x18.png",
-                    "mdpi" : "unpackage/res/push/24x24.png",
-                    "xhdpi" : "unpackage/res/push/48x48.png",
-                    "xxhdpi" : "unpackage/res/push/72x72.png"
+                    "hdpi": "unpackage/res/push/36x36.png",
+                    "ldpi": "unpackage/res/push/18x18.png",
+                    "mdpi": "unpackage/res/push/24x24.png",
+                    "xhdpi": "unpackage/res/push/48x48.png",
+                    "xxhdpi": "unpackage/res/push/72x72.png"
                 }
             } else if (args === 'xunJian') {
                 state.name = '智能巡更'
@@ -84,10 +84,10 @@ filesToModify.forEach((file) => {
                 geolocation.tencent.apikey_ios = "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX"
                 geolocation.tencent.apikey_android = "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX"
                 icons.android = {
-                    "hdpi" : "unpackage/res/icons-xunJian/72x72.png",
-                    "xhdpi" : "unpackage/res/icons-xunJian/96x96.png",
-                    "xxhdpi" : "unpackage/res/icons-xunJian/144x144.png",
-                    "xxxhdpi" : "unpackage/res/icons-xunJian/192x192.png"
+                    "hdpi": "unpackage/res/icons-xunJian/72x72.png",
+                    "xhdpi": "unpackage/res/icons-xunJian/96x96.png",
+                    "xxhdpi": "unpackage/res/icons-xunJian/144x144.png",
+                    "xxxhdpi": "unpackage/res/icons-xunJian/192x192.png"
                 }
                 icons.ios.appstore = "unpackage/res/icons-xunJian/1024x1024.png"
                 icons.ios.ipad = {
@@ -112,18 +112,18 @@ filesToModify.forEach((file) => {
                     "spotlight@3x": "unpackage/res/icons-xunJian/120x120.png"
                 }
                 push.unipush.icons.small = {
-                    "hdpi" : "unpackage/res/push-xunJian/36x36.png",
-                    "ldpi" : "unpackage/res/push-xunJian/18x18.png",
-                    "mdpi" : "unpackage/res/push-xunJian/24x24.png",
-                    "xhdpi" : "unpackage/res/push-xunJian/48x48.png",
-                    "xxhdpi" : "unpackage/res/push-xunJian/72x72.png"
+                    "hdpi": "unpackage/res/push-xunJian/36x36.png",
+                    "ldpi": "unpackage/res/push-xunJian/18x18.png",
+                    "mdpi": "unpackage/res/push-xunJian/24x24.png",
+                    "xhdpi": "unpackage/res/push-xunJian/48x48.png",
+                    "xxhdpi": "unpackage/res/push-xunJian/72x72.png"
                 }
             } else if (args === 'huiYi') {
                 state.name = '智能会议'
                 state.appid = '__UNI__F3963F8'
                 state.description = '智能会议APP,是一款集成了现代信息技术和智能化管理功能的移动应用程序,旨在提升会议体验和管理效率。'
-                state.versionName = "2.0.5"
-                state.versionCode = 1
+                state.versionName = "1.0.3"
+                state.versionCode = 3
                 state.h5.title = '智能会议'
 
                 maps.amap.name = "amapBOujshtbA"
@@ -136,10 +136,10 @@ filesToModify.forEach((file) => {
                 geolocation.tencent.apikey_ios = "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX"
                 geolocation.tencent.apikey_android = "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX"
                 icons.android = {
-                    "hdpi" : "unpackage/res/icons/72x72.png",
-                    "xhdpi" : "unpackage/res/icons/96x96.png",
-                    "xxhdpi" : "unpackage/res/icons/144x144.png",
-                    "xxxhdpi" : "unpackage/res/icons/192x192.png"
+                    "hdpi": "unpackage/res/icons/72x72.png",
+                    "xhdpi": "unpackage/res/icons/96x96.png",
+                    "xxhdpi": "unpackage/res/icons/144x144.png",
+                    "xxxhdpi": "unpackage/res/icons/192x192.png"
                 }
                 icons.ios.appstore = "unpackage/res/icons/1024x1024.png"
                 icons.ios.ipad = {
@@ -164,18 +164,18 @@ filesToModify.forEach((file) => {
                     "spotlight@3x": "unpackage/res/icons/120x120.png"
                 }
                 push.unipush.icons.small = {
-                    "hdpi" : "unpackage/res/push/36x36.png",
-                    "ldpi" : "unpackage/res/push/18x18.png",
-                    "mdpi" : "unpackage/res/push/24x24.png",
-                    "xhdpi" : "unpackage/res/push/48x48.png",
-                    "xxhdpi" : "unpackage/res/push/72x72.png"
+                    "hdpi": "unpackage/res/push/36x36.png",
+                    "ldpi": "unpackage/res/push/18x18.png",
+                    "mdpi": "unpackage/res/push/24x24.png",
+                    "xhdpi": "unpackage/res/push/48x48.png",
+                    "xxhdpi": "unpackage/res/push/72x72.png"
                 }
             } else if (args === 'menJin') {
                 state.name = '智能门禁'
                 state.appid = '__UNI__8D6E9FD'
                 state.description = '智能门禁APP,是一款集成了现代信息技术和智能化管理功能的移动应用程序。'
-                state.versionName = "1.0.0"
-                state.versionCode = 1
+                state.versionName = "1.0.1"
+                state.versionCode = 2
                 state.h5.title = '智能门禁'
 
                 maps.amap.name = "amapBOujshtbA"
@@ -188,10 +188,10 @@ filesToModify.forEach((file) => {
                 geolocation.tencent.apikey_ios = "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX"
                 geolocation.tencent.apikey_android = "EGOBZ-74ZET-ST7XS-VYICT-RBLHZ-KLFEX"
                 icons.android = {
-                    "hdpi" : "unpackage/res/icons/72x72.png",
-                    "xhdpi" : "unpackage/res/icons/96x96.png",
-                    "xxhdpi" : "unpackage/res/icons/144x144.png",
-                    "xxxhdpi" : "unpackage/res/icons/192x192.png"
+                    "hdpi": "unpackage/res/icons/72x72.png",
+                    "xhdpi": "unpackage/res/icons/96x96.png",
+                    "xxhdpi": "unpackage/res/icons/144x144.png",
+                    "xxxhdpi": "unpackage/res/icons/192x192.png"
                 }
                 icons.ios.appstore = "unpackage/res/icons/1024x1024.png"
                 icons.ios.ipad = {
@@ -216,11 +216,11 @@ filesToModify.forEach((file) => {
                     "spotlight@3x": "unpackage/res/icons/120x120.png"
                 }
                 push.unipush.icons.small = {
-                    "hdpi" : "unpackage/res/push/36x36.png",
-                    "ldpi" : "unpackage/res/push/18x18.png",
-                    "mdpi" : "unpackage/res/push/24x24.png",
-                    "xhdpi" : "unpackage/res/push/48x48.png",
-                    "xxhdpi" : "unpackage/res/push/72x72.png"
+                    "hdpi": "unpackage/res/push/36x36.png",
+                    "ldpi": "unpackage/res/push/18x18.png",
+                    "mdpi": "unpackage/res/push/24x24.png",
+                    "xhdpi": "unpackage/res/push/48x48.png",
+                    "xxhdpi": "unpackage/res/push/72x72.png"
                 }
             }
         } else if ('./src/pages.json') {