Browse Source

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

gez 1 month ago
parent
commit
64d43c275e

+ 24 - 1
src/api/business/project.js

@@ -116,7 +116,30 @@ export function projectApi() {
                 method: 'get',
                 params: query
             })
-        }
+        },
+        usersProjectWorkTime(params) {
+            return request({
+                url: '/service-iot/pmProject/usersProjectWorkTime',
+                method: 'GET',
+                params
+            })
+        },
+        //日报统计
+        pmTimeConfCount(params) {
+            return request({
+                url: '/service-iot/pmTimeConf/submitCount',
+                method: 'GET',
+                params
+            })
+        },
+        //日报统计分页
+        pmTimeConfPage(params) {
+            return request({
+                url: '/service-iot/pmTimeConf/submitPage',
+                method: 'GET',
+                params
+            })
+        },
         
     }
 }

+ 2 - 1
src/config.js

@@ -9,7 +9,8 @@ export default {
   //#endif
 
   //#ifdef H5
-  baseUrl: import.meta.env.MODE === "production" ? `https://${window.location.host}/prod-api` : `http://192.168.10.165:801/dev-api`,
+  baseUrl: "https://gateWay.usky.cn/prod-api",
+  // baseUrl: import.meta.env.MODE === "production" ? `https://${window.location.host}/prod-api` : `http://192.168.10.165:801/dev-api`,
   //#endif
 
   websiteUrl: "https://qhome.usky.cn",

+ 39 - 39
src/manifest.json

@@ -1,9 +1,9 @@
 {
-    "name" : "智能巡更",
-    "appid" : "__UNI__BF1A1F0",
-    "description" : "智能巡更app,是一款用于监督和记录巡逻人员按照预定路线和时间进行巡逻的系统。",
-    "versionName" : "2.3.4",
-    "versionCode" : 34,
+    "name" : "综合智慧云",
+    "appid" : "__UNI__36DE3A0",
+    "description" : "综合智慧云APP,是一款助力于企业数字化的应用平台,帮助企业提升办公效率,实现组织数字化和业务数字化。",
+    "versionName" : "2.2.3",
+    "versionCode" : 23,
     "transformPx" : false,
     "app-plus" : {
         "compatible" : {
@@ -106,9 +106,9 @@
                 "ad" : {},
                 "maps" : {
                     "amap" : {
-                        "appkey_ios" : "4da4abbd317d0b083d6c25dd9b509eed",
-                        "appkey_android" : "63bef5d715bfa5433189e7b65516dfa5",
-                        "name" : "amap_15575941817CWPEQVCyc"
+                        "appkey_ios" : "fb35d03fbb17cbf7a8743a522da3c7fc",
+                        "appkey_android" : "ffc71dfd4e576596027f8f45a1b8fb2f",
+                        "name" : "amapBOujshtbA"
                     }
                 },
                 "geolocation" : {
@@ -117,9 +117,9 @@
                     },
                     "amap" : {
                         "__platform__" : [ "ios", "android" ],
-                        "appkey_ios" : "4da4abbd317d0b083d6c25dd9b509eed",
-                        "appkey_android" : "63bef5d715bfa5433189e7b65516dfa5",
-                        "name" : "amap_15575941817CWPEQVCyc"
+                        "appkey_ios" : "fb35d03fbb17cbf7a8743a522da3c7fc",
+                        "appkey_android" : "ffc71dfd4e576596027f8f45a1b8fb2f",
+                        "name" : "amapBOujshtbA"
                     },
                     "tencent" : {
                         "__platform__" : [ "ios", "android" ],
@@ -133,11 +133,11 @@
                         "offline" : true,
                         "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/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"
                             }
                         }
                     }
@@ -145,33 +145,33 @@
             },
             "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/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-xunJian/1024x1024.png",
+                    "appstore" : "unpackage/res/icons/1024x1024.png",
                     "ipad" : {
-                        "app" : "unpackage/res/icons-xunJian/76x76.png",
-                        "app@2x" : "unpackage/res/icons-xunJian/152x152.png",
-                        "notification" : "unpackage/res/icons-xunJian/20x20.png",
-                        "notification@2x" : "unpackage/res/icons-xunJian/40x40.png",
-                        "proapp@2x" : "unpackage/res/icons-xunJian/167x167.png",
-                        "settings" : "unpackage/res/icons-xunJian/29x29.png",
-                        "settings@2x" : "unpackage/res/icons-xunJian/58x58.png",
-                        "spotlight" : "unpackage/res/icons-xunJian/40x40.png",
-                        "spotlight@2x" : "unpackage/res/icons-xunJian/80x80.png"
+                        "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-xunJian/120x120.png",
-                        "app@3x" : "unpackage/res/icons-xunJian/180x180.png",
-                        "notification@2x" : "unpackage/res/icons-xunJian/40x40.png",
-                        "notification@3x" : "unpackage/res/icons-xunJian/60x60.png",
-                        "settings@2x" : "unpackage/res/icons-xunJian/58x58.png",
-                        "settings@3x" : "unpackage/res/icons-xunJian/87x87.png",
-                        "spotlight@2x" : "unpackage/res/icons-xunJian/80x80.png",
-                        "spotlight@3x" : "unpackage/res/icons-xunJian/120x120.png"
+                        "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"
                     }
                 }
             },
@@ -212,7 +212,7 @@
     },
     "h5" : {
         "publicPath" : "./",
-        "title" : "智能巡更",
+        "title" : "综合智慧云",
         "router" : {
             "mode" : "hash"
         },

+ 24 - 1
src/pages.json

@@ -888,6 +888,30 @@
                         }
                     }
                 },
+                {
+                    "path": "projectMange/statistics/index",
+                    "style": {
+                        "navigationBarTitleText": "报告统计",
+                        "enablePullDownRefresh": false,
+                        "navigationStyle": "custom",
+                        "app-plus": {
+                            "bounce": "none",
+                            "titleNView": false
+                        }
+                    }
+                },
+                {
+                    "path": "projectMange/statistics/dailyReport",
+                    "style": {
+                        "navigationBarTitleText": "日报",
+                        "enablePullDownRefresh": false,
+                        "navigationStyle": "custom",
+                        "app-plus": {
+                            "bounce": "none",
+                            "titleNView": false
+                        }
+                    }
+                },
                 {
                     "path": "projectMange/list/index",
                     "style": {
@@ -1032,7 +1056,6 @@
                         }
                     }
                 }
-                
             ]
         },
         {

+ 2 - 1
src/pages/business/common/projectMange/list/index.vue

@@ -91,7 +91,7 @@
             </view> -->
             <view class="content-area-row_wrap-view">
               类型:
-              {{ proxy.$common.mapping("label", "value", base.projectStatus, project_type) }}
+              {{ proxy.$common.mapping("label", "value", base.projectType, project_type) }}
             </view>
             <view class="content-area-row_wrap-view">
               公开状态:
@@ -276,6 +276,7 @@ function handleAction(value, event, index, ind) {
 function selectAction(e) {
   state.projectType = e.value[0].value;
   state.projectTypeName = e.value[0].label;
+  console.log(state.projectType, state.projectTypeName,e)
   state.actionShow = false;
 }
 

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

@@ -0,0 +1,371 @@
+<template>
+    <u-sticky class="shadow-default" bgColor="#fff" style="top: 0">
+      <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>
+          </view>
+        </template>
+      </u-navbar>
+    </u-sticky>
+    <view class="timeSelect">
+      <view @click="daySwitch(0)"><u-icon name="arrow-left" size="14" color="#000" class="left"></u-icon></view>
+      <view><text>{{ day }}</text></view>
+      <view @click="daySwitch(1)" ><u-icon name="arrow-right" size="14" :color="statusNext ? '#000' : '#ccc'" class="right" aria-disabled="true"></u-icon></view>
+    </view>
+    <view class="container">
+      <view class="menu-list">
+        <view class="list-cell">
+          <view class="list"  :class="{ active: query.queryType == item.value }" @click="tabsClick(item.value)" v-for="(item,index) in activeList" :key="index">
+            <text>{{ index == 0 ? statistics.submitOnTime :index == 1 ? statistics.submitLate : index == 2 ? statistics.notSubmitted : '' }}</text> 
+            <text>{{ item.name }}</text> 
+            <text v-if="item.value == 0 || item.value == 1"></text> 
+            <text class="line"></text> 
+          </view>
+        </view>
+      </view>
+    </view>
+    <oa-scroll
+    customClass="record-container scroll-height"
+    :pageSize="query.pageSize"
+    :total="total"
+    :isSticky="true"
+    :customStyle="{
+      //#ifdef APP-PLUS || MP-WEIXIN
+      height: `calc(100vh - (138px + ${proxy.$settingStore.StatusBarHeight}))`,
+      //#endif
+      //#ifdef H5
+      height: `calc(100vh - (138px))`,
+      //#endif
+    }"
+    :refresherLoad="true"
+    :refresherEnabled="true"
+    :refresherDefaultStyle="'none'"
+    :refresherThreshold="44"
+    :lowerThreshold="44"
+    :refresherBackground="'#f5f6f7'"
+    @load="load"
+    @refresh="refresh"
+    :data-theme="'theme-' + proxy.$settingStore.themeColor.name"
+  >
+    <template #default>
+      <!-- <u-loading-page :loading="state.loading" fontSize="16" style="z-index: 99"></u-loading-page> -->
+      <!-- start -->
+      <view class="content-area" v-for="(el, index) in reportList" :key="index">
+        <!-- <view class="flex mb10" @click="goContentDetails(el)">
+            <img :src="el.avatar" class="content-area-center-avatarImg mr10" v-if="el.avatar" />
+            <u-avatar
+              v-if="!el.avatar"
+              class="content-area-center-avatar mr10"
+              :text="el.createBy.length > 2 ? el.createBy.slice(1, 3) : el.createBy"
+              shape="square"
+              size="35"
+              fontSize="10"
+              color="#ffffff"
+              :bgColor="proxy.$settingStore.themeColor.color"
+            ></u-avatar>
+            <view>
+              <view class="content-area-center-title font14 mb5">{{ el.createBy }}的日报</view>
+              <view class="content-area-center-time font12">{{ proxy.$time.jktTimes(el.submitDate.replace("T", " ")) }}</view>
+            </view>
+          </view> -->
+        <!-- <view class="content-area-center bg-white" v-else style="margin: 0 10px 10px; border-radius: 10px">
+          <view class="content-area-top menu-item" style="float: right; padding: 10px 0px">
+            <view class="content-area-top-time"> </view>
+            <u-icon class="content-area-top-icon" name="more-dot-fill" size="20" color="#000" @click="moreClick(el)"></u-icon>
+          </view>
+          <view class="flex mb10" @click="goContentDetails(el)">
+            <img :src="el.avatar" class="content-area-center-avatarImg mr10" v-if="el.avatar" />
+            <u-avatar
+              v-if="!el.avatar"
+              class="content-area-center-avatar mr10"
+              :text="el.createBy.length > 2 ? el.createBy.slice(1, 3) : el.createBy"
+              shape="square"
+              size="35"
+              fontSize="10"
+              color="#ffffff"
+              :bgColor="proxy.$settingStore.themeColor.color"
+            ></u-avatar>
+            <view>
+              <view class="content-area-center-title font14 mb5">{{ el.createBy }}的日报</view>
+              <view class="content-area-center-time font12">{{ proxy.$time.jktTimes(el.submitDate.replace("T", " ")) }}</view>
+            </view>
+          </view>
+          <view class="mb5" @click="goContentDetails(el)">
+            <u-text :text="el.contentText.length >= 100 ? el.contentText.slice(0, 100) + '···' : el.contentText" color="#666666" size="14"></u-text>
+          </view>
+          <view class="flex" v-if="el.createBy != useStore.nickName" @click="goContentDetails(el)">
+            <u-tag class="mr10" type="info" text="已读" size="mini" plain v-if="el.readFlag === 1" style="margin: 0 auto"></u-tag>
+            <u-tag class="mr10" type="error" text="未读" size="mini" plain v-if="el.readFlag === 0" style="margin: 0 auto"></u-tag>
+            <u-text text="全文" :color="proxy.$settingStore.themeColor.color" size="14"></u-text>
+          </view>
+        </view> -->
+      </view>
+      <!-- end -->
+    </template>
+  </oa-scroll>
+</template>
+  
+  <script setup>
+  /*----------------------------------依赖引入-----------------------------------*/
+  import { onLoad, onShow, onReady } from "@dcloudio/uni-app";
+  import { ref, getCurrentInstance, reactive } from "vue";
+  import { useRouter, useRoute } from "vue-router";
+  /*----------------------------------接口引入-----------------------------------*/
+  import { projectApi } from "@/api/business/project.js";
+  // import dayjs from 'dayjs/esm/index'
+  /*----------------------------------组件引入-----------------------------------*/
+  /*----------------------------------store引入-----------------------------------*/
+  import dayjs from "dayjs";
+  const route = useRoute();
+  /*----------------------------------公共方法引入-----------------------------------*/
+  /*----------------------------------公共变量-----------------------------------*/
+  const { proxy } = getCurrentInstance();
+  const day = ref("")
+  const statusNext = ref(false)//下一天按钮状态
+  const currentDate = ref("")//当前日期
+  const date = reactive({
+    year:"",
+    month:"",
+    day:""
+  })
+  const activeList = reactive([
+    {name:"按时提交",value:0},
+    {name:"迟交",value:1},
+    {name:"未提交",value:2},
+  ])
+  const query = ref({
+    queryType:0,
+    submitDate:dayjs().format("YYYY-MM-DD"),
+    reportId:null,
+    pageNum:1,
+    pageSize:10,
+  })
+  /*----------------------------------变量声明-----------------------------------*/
+  const statistics = ref({
+    submitOnTime: 0, //按时提交
+    submitLate: 0, //迟交
+    notSubmitted:0,  //未交
+  })
+  const loading = ref(false)
+  const reportList =reactive([])
+  const pageSize = ref(20)
+  const current = ref(1)
+  const total = ref(0)
+  /**
+   * @页面初始化
+   */
+  function init(id) {
+    if(id){
+      query.value.queryType = id
+    }
+    var time = dayjs().format("YYYY-MM-DD").split("-")
+    currentDate.value = `${time[0]}${time[1]}${time[2]}`
+    day.value = `${time[0]}年${time[1]}月${time[2]}日`
+    date.value = {
+      year:time[0],
+      month:time[1],
+      day:time[2]
+    }
+    getStatistics()
+    getPageList()
+  }
+  //获取统计数据
+  function getStatistics(time) {
+    projectApi().pmTimeConfCount(time ? {submitDate:query.value.submitDate} : null ).then((res) => {
+      statistics.value = res.data;
+    });
+  }
+  //获取分页数据
+  function getPageList() {
+    projectApi().pmTimeConfPage(query.value).then((res) => {
+      reportList.value = res.data.records[0];
+      console.log(reportList.value)
+    });
+  }
+  /** 日期选择*/
+  function daySwitch(id){
+    //获取前一天/后一天日期
+      if(id == 1 && statusNext.value == false){
+        return
+      }
+      const targetDate = dayjs(`${date.value.year}-${date.value.month}-${date.value.day}`);
+      var previousDay;
+      if(id == 0){
+        previousDay = targetDate.subtract(1, 'day');
+      }
+      if(id == 1){
+        previousDay = targetDate.subtract(-1, 'day');
+      }
+      var time = previousDay.format("YYYY-MM-DD").split("-")
+      day.value = `${time[0]}年${time[1]}月${time[2]}日`
+      date.value = {
+        year:time[0],
+        month:time[1],
+        day:time[2]
+      }
+      query.value.submitDate = `${time[0]}-${time[1]}-${time[2]}`
+    //获取下一天按钮状态
+      var changeDate = `${date.value.year}${date.value.month}${date.value.day}`
+      if(changeDate >= currentDate.value){
+        statusNext.value = false
+      }else{
+        statusNext.value = true
+      }
+    getStatistics(query.value.submitDate)
+    getPageList()
+  }
+  /**
+   * @scrollView加载数据
+   */
+  function load() {
+    query.value.current ++;
+    init();
+  }
+  /**
+   * @scrollView刷新数据
+   */
+  function refresh() {
+    query.value.current = 1;
+    init();
+  }
+
+
+  onLoad(() => {
+  });
+  
+  onShow(() => {
+    if(route?.query?.id){
+      init(route.query.id)
+    }else{
+      init()
+    }
+    //调用系统主题颜色
+    proxy.$settingStore.systemThemeColor([1]);
+  });
+  </script>
+  <style lang="scss" scoped>
+  :deep(.u-modal__content) {
+    font-size: 14px;
+    justify-content: left;
+  }
+  :deep(.list-container .content-area-top-name) {
+    font-size: 16px !important;
+  }
+  </style>
+  <style lang="scss" scoped>
+  .timeSelect{
+    width:100%;
+    height:35px;
+    background: #fff;
+    >view{
+      display: inline-block;
+      height:35px;
+      line-height: 35px;
+      position: relative;
+      .left{
+        position: absolute;
+        top:11px;
+        right:20px;
+      }
+      .right{
+        position: absolute;
+        top:11px;
+        left:20px;
+      }
+    }
+    view:nth-child(1),view:nth-child(3){
+      width:20%;
+    }
+    view:nth-child(2){
+      width:60%;
+      text{
+        position: absolute;
+        width:100%;
+        text-align: center;
+      }
+    }
+  }
+  .container{
+    width:100%;
+    height:calc(100% - 20px);
+    margin:10px 0;
+    .statisticsSearchBox {
+      width: 100%;
+      vertical-align: middle;
+      position: relative;
+      display: flex;
+      .uni-input-input {
+        font-size: 12px !important;
+      }
+      :deep(.u-input__content__prefix-icon) {
+        position: absolute;
+        right: 8px;
+        .uicon-search {
+          font-size: 16px;
+        }
+      }
+    }
+    .u-input {
+      display: inline-block;
+      background: #fff;
+      height: 34px;
+      line-height: 34px;
+      border-radius: 10px
+    }
+    .menu-list{
+      width:100%;
+      margin:0px 0 0 0px;
+      padding:15px 10px;
+      background: #ffffff;
+      border-radius: 10px;
+      .list-cell{
+        display: flex;
+        padding:0;
+        .list{
+          flex:1;
+          text-align: center;
+          position: relative;
+          text{
+            display: block;
+            color:#999999;
+          }
+          text:nth-child(1){
+            font-weight: 700;
+            font-size: 14px;
+          }
+          text:nth-child(2){
+            font-size: 12px;
+            margin-top:10px;
+          }
+          
+        }
+        .list:nth-child(1),.list:nth-child(2){
+            text:nth-child(3){
+                width:1px;
+                height:50%;
+                position: absolute;
+                top:25%;
+                right:0;
+                background: #E7E7E7;
+            }
+        }
+        .active{
+            text{
+                color:#000;
+            }
+            .line{
+                position: absolute;
+                bottom:-36%;
+                left:25%;
+                width:50%;
+                height:4px;
+                border-radius: 2px;
+                background: #000;
+            }
+        }
+      }
+    }
+  }
+  </style>
+  

+ 169 - 0
src/pages/business/common/projectMange/statistics/index.vue

@@ -0,0 +1,169 @@
+<template>
+  <u-sticky class="shadow-default" bgColor="#fff" style="top: 0">
+    <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>
+        </view>
+      </template>
+    </u-navbar>
+  </u-sticky>
+  <view class="container">
+    <!-- <view class="statisticsSearchBox">
+      <u-input v-model="projectName" placeholder="请输入时间" clearable prefixIcon="search" size="small" />
+    </view> -->
+    <view style="width: calc(100% - 51px); display: flex; padding-right: 10px">
+          <view>统计时间:18:00 ~ 22:00</view>
+        </view>
+    <view class="menu-list">
+      <view class="title">{{ statistics?.statisticalDate == currentDate ? '今日' : statistics?.statisticalDate }}报告</view>
+      <view class="list-cell">
+        <view class="list"  @click="toPage(item.value)" v-for="(item,index) in activeList" :key="index">
+            <text>{{ index == 0 ? statistics.submitOnTime :index == 1 ? statistics.submitLate : index == 2 ? statistics.notSubmitted : '' }}</text> 
+            <text>{{ item.name }}</text> 
+            <text v-if="item.value == 0 || item.value == 1"></text> 
+        </view>
+      </view>
+    </view>
+  </view>
+</template>
+
+<script setup>
+/*----------------------------------依赖引入-----------------------------------*/
+import { onLoad, onShow, onReady } from "@dcloudio/uni-app";
+import { ref, reactive, getCurrentInstance } from "vue";
+/*----------------------------------接口引入-----------------------------------*/
+import { projectApi } from "@/api/business/project.js";
+/*----------------------------------组件引入-----------------------------------*/
+/*----------------------------------store引入-----------------------------------*/
+import dayjs from "dayjs";
+/*----------------------------------公共方法引入-----------------------------------*/
+/*----------------------------------公共变量-----------------------------------*/
+const { proxy } = getCurrentInstance();
+/*----------------------------------变量声明-----------------------------------*/
+const statistics = ref({
+  submitOnTime: 0, //按时提交
+  submitLate: 0, //迟交
+  notSubmitted:0,  //未交
+  statisticalDate:null, //统计日期
+})
+const activeList = reactive([
+  {name:"按时提交",value:0},
+  {name:"迟交",value:1},
+  {name:"未提交",value:2},
+])
+const currentDate = dayjs().format('YYYY-MM-DD');
+/**
+ * @页面初始化
+ */
+function init() {
+  projectApi().pmTimeConfCount().then((res) => {
+    statistics.value = res.data;
+  });
+}
+/**
+ * 跳转项目概览
+ * @param id 项目id
+ */
+function toPage(id) {
+  proxy.$tab.navigateTo(`/pages/business/common/projectMange/statistics/dailyReport?id=${id}&statisticalDate=2025-02-20`);
+}
+
+onReady(() => {});
+
+onShow(() => {
+  init();
+  //调用系统主题颜色
+  proxy.$settingStore.systemThemeColor([1]);
+});
+</script>
+<style lang="scss" scoped>
+:deep(.u-modal__content) {
+  font-size: 14px;
+  justify-content: left;
+}
+:deep(.list-container .content-area-top-name) {
+  font-size: 16px !important;
+}
+</style>
+<style lang="scss" scoped>
+.container{
+  width:calc(100% - 20px);
+  height:calc(100% - 20px);
+  margin:10px;
+  .statisticsSearchBox {
+    width: 100%;
+    vertical-align: middle;
+    position: relative;
+    display: flex;
+    .uni-input-input {
+      font-size: 12px !important;
+    }
+    :deep(.u-input__content__prefix-icon) {
+      position: absolute;
+      right: 8px;
+      .uicon-search {
+        font-size: 16px;
+      }
+    }
+  }
+  .u-input {
+    display: inline-block;
+    background: #fff;
+    height: 34px;
+    line-height: 34px;
+    border-radius: 10px
+  }
+  .menu-list{
+    width:100%;
+    margin:10px 0 0 0px;
+    padding:15px 10px;
+    background: #ffffff;
+    border-radius: 10px;
+    .title{
+      font-size: 14px;
+      font-weight: 600;
+      color: #333333;
+    }
+    .list-cell{
+      margin-top:20px;
+      display: flex;
+      padding:0;
+      .list{
+        flex:1;
+        text-align: center;
+        position: relative;
+        text{
+          display: block;
+        }
+        text:nth-child(1){
+          font-weight: 700;
+          font-size: 14px;
+        }
+        text:nth-child(2){
+          font-size: 12px;
+          margin-top:10px;
+        }
+        text:nth-child(3){
+          width:1px;
+          height:50%;
+          position: absolute;
+          top:25%;
+          right:0;
+          background: #E7E7E7;
+        }
+      }
+      .list:nth-child(2){
+        text:nth-child(1){
+          color:#E6A23C;
+        }
+      }
+      .list:nth-child(3){
+        text:nth-child(1){
+          color:#F56C6C;
+        }
+      }
+    }
+  }
+}
+</style>

+ 4 - 3
src/pages/business/oa/approval/components/jbd.vue

@@ -181,11 +181,11 @@
           </view>
         </view>
       </view>
-      <view class="app-button">
-        <u-button  type="primary" @click="handleSubmit('提交')" shape="circle"> 提交 </u-button>
-      </view>
     </template>
   </oa-scroll>
+  <view class="app-button">
+    <u-button  type="primary" @click="handleSubmit('提交')" shape="circle"> 提交 </u-button>
+  </view>
 </template>
 
 <script setup>
@@ -429,6 +429,7 @@ onShow(() => {
   bottom:10px;
   left:10px;
   width:calc(100% - 20px);
+  background: #fff;
   button{
     border-radius: 10px !important;
   }

+ 4 - 3
src/pages/business/oa/approval/components/qjd.vue

@@ -181,11 +181,11 @@
           </view>
         </view>
       </view>
-      <view class="app-button">
-        <u-button  type="primary" @click="handleSubmit('提交')" shape="circle"> 提交 </u-button>
-      </view>
     </template>
   </oa-scroll>
+  <view class="app-button">
+    <u-button  type="primary" @click="handleSubmit('提交')" shape="circle"> 提交 </u-button>
+  </view>
 </template>
 
 <script setup>
@@ -427,6 +427,7 @@ onShow(() => {
   bottom:10px;
   left:10px;
   width:calc(100% - 20px);
+  background: #fff;
   button{
     border-radius: 10px !important;
   }

+ 2 - 0
src/pages/business/oa/approval/formType.vue

@@ -1,4 +1,5 @@
 <template>
+  <view style="height: 100%;">
     <u-navbar
       :autoBack="false"
       :placeholder="true"
@@ -21,6 +22,7 @@
     </u-navbar>
     <qjd v-if="datail?.fieldInfo == 'QJD' && pageStatus " :data="{form:datail,ccTo:ccTo,nodeList:nodeList,type:formType,docNoDetail:docNoDetail}" />
     <jbd v-if="datail?.fieldInfo == 'JBD' && pageStatus " :data="{form:datail,ccTo:ccTo,nodeList:nodeList,type:formType,docNoDetail:docNoDetail}" />
+  </view>
     <!-- :data="{form:form,nodeList:nodeList,ccTo:ccTo}" -->
 </template>
   

+ 6 - 1
src/pages/business/oa/approval/index.vue

@@ -84,6 +84,7 @@
   import { useStores } from "@/store/modules/index";
   /*----------------------------------公共方法引入-----------------------------------*/
   import * as jwx from "@/utils/jssdk.js"; //引入js sdk的封装
+  import config from "@/config";
   import { getToken, setToken, removeToken } from "@/utils/auth";
   import { storage, storageSystem } from "@/utils/storage"; // 公共方法引用
   /*----------------------------------公共变量-----------------------------------*/
@@ -129,10 +130,14 @@
    * 表单权限列表
    */
   function getFormList(){
+    console.log(config.baseUrl)
+    var prefix = ""
+    prefix = "https://manager.usky.cn/mobile/static/"
     getOaFormDefinition().then((res) => {
       state.formList = res.data;
       for(let i=0;i<state.formList.length;i++){
-        state.formList[i].icon = proxy.$common.getAssetsFile(`images/oa/${state.formList[i].formImage}.png`);
+        state.formList[i].icon = prefix + `images/oa/${state.formList[i].formImage}.png`
+        console.log(state.formList[i].icon)
       }
       state.appContent[0].array = state.formList
     })

+ 78 - 49
src/pages/business/oa/toDo/detail.vue

@@ -7,15 +7,15 @@
       <text class="grid-area_center_item_title" style="color: #fff;">详情</text>
     </template>
   </u-navbar>
-  <view class="menu-list m0" style="overflow-y:scroll">
+  <view class="menu-list m0" style="overflow-y:scroll !important; height: 100%;" v-if="state.loading">
     <view class="list-cell" style="color: #666666; line-height: 25px; width: auto; ">
       <view class="content-area-top menu-item">
         <view class="content-area-top-name" >{{ state?.detail?.createBy + '提交的' + state?.detail?.formName }} </view>
       </view>
       <view class="content-area-row_wrap menu-item">
-        <img class="typeIcon" src="@/static/images/oa/approval.png" v-if="state.approvalStatus === '1' "/>
-        <img class="typeIcon" src="@/static/images/oa/pass.png" v-if="state.approvalStatus === '2' "/>
-        <img class="typeIcon" src="@/static/images/oa/refuse.png" v-if="state.approvalStatus === '3' "/>
+        <image class="typeIcon" src="@/static/images/oa/approval.png" v-if="state.approvalStatus === '1' "/>
+        <image class="typeIcon" src="@/static/images/oa/pass.png" v-if="state.approvalStatus === '2' "/>
+        <image class="typeIcon" src="@/static/images/oa/refuse.png" v-if="state.approvalStatus === '3' "/>
         <view class="content-area-row_wrap-view gray"> 上海永天科技股份有限公司 </view>
         <view class="content-area-row_wrap-view gray"> 单据编号:{{ state.detail.docNo }} </view>
         <view class="content-area-row_wrap-view" style="display: block">
@@ -29,7 +29,7 @@
         <view class="content-area-row_wrap-view gray black" v-if="state.detail.reason">{{ state.detail.reason }}</view>
       </view>
     </view>
-    <view class="list-cell" style="color: #666666; line-height: 25px; width: auto;margin:10px 0 60px 0;">
+    <view class="list-cell" style="color: #666666; line-height: 25px; width: auto;margin-top:10px;">
       <view class="content-area-top">
         <view style="width:100%;">流程</view>
         <view class="stepBar">
@@ -74,7 +74,8 @@
             <view class="right">
               <!-- 2021-08-01 10:30:00 -->
             </view>
-            <view class="center" v-if="item.nodeType == 2 && item.appointApprover.indexOf(',') && item.appointApprover.split(',').length > 1">
+            <view class="center" v-if="item.nodeType == 2 && item.appointApprover.indexOf(',') && item.appointApprover.split(',').length > 1" 
+              :style="{paddingBottom:state.approvalStatus == 1 || (state.approvalStatus == 2 || state.approvalStatus == 3)  && state.detail.proposer == useStore.userId  && state.detail.docNo.split('-')[0] == 'JBD' ? '0px' : '30px'}">
               <view class="content-area-header  mb10 text-center" style="display: inline-block"  v-for="(approver, index2) in item.appointApprover.split(',')" :key="index2">
                 <img v-if='proxy.$common.mapping("avatar", "userId", approver, state.userData)' class="content-area-header-avatarImg mlr5" :src='proxy.$common.mapping("avatar", "userId", approver, state.userData)' style="display: block; width: 40px; height: 40px" />
                 <u-avatar
@@ -90,20 +91,32 @@
                 <u-text :text='proxy.$common.mapping("nickName", "userId", approver, state.userData)' color="#000000" size="14" align="center"></u-text>
               </view>
             </view>
-            <view class="line gray" v-if="item.nodeType == 1">
+            <view class="line gray" v-if="item.nodeType == 1 && nodeList.length-1 != index">
             </view>
           </view>
         </view>
       </view>
     </view>
-    <view class="fixedBottom" v-if="(state.approvalStatus == 2 || state.approvalStatus == 3)  && state.detail.proposer == useStore.userId  && state.detail.docNo.split('-')[0] == 'JBD'" @click="handle('again')">
+    <view class="list-cell list-cell-bottom againWrap" v-if="(state.approvalStatus == 2 || state.approvalStatus == 3)  && state.detail.proposer == useStore.userId  && state.detail.docNo.split('-')[0] == 'JBD'" @click="handle('again')">
+      <view class="again">
+        <img src="@/static/images/oa/loading.png" alt="">
+        <span>再次提交</span>
+      </view>
+    </view>
+    <view class="list-cell list-cell-bottom approvalWrap" v-if="state.approvalStatus == 1">
+      <view class="approval">
+        <button class="refuse" @click="handle('refuse',2)">拒绝</button>
+        <button class="pass" @click="handle('pass',2)">同意</button>
+      </view>
+    </view>
+    <!-- <view class="fixedBottom" v-if="(state.approvalStatus == 2 || state.approvalStatus == 3)  && state.detail.proposer == useStore.userId  && state.detail.docNo.split('-')[0] == 'JBD'" @click="handle('again')">
       <img src="@/static/images/oa/loading.png" alt="">
       <span>再次提交</span>
     </view>
     <view class="approval" v-if="state.approvalStatus == 1">
       <button class="refuse" @click="handle('refuse',2)">拒绝</button>
       <button class="pass" @click="handle('pass',2)">同意</button>
-    </view>
+    </view> -->
   </view>
 </template>
 <script setup>
@@ -173,11 +186,12 @@ function handle(type) {
  * @api接口查询
  */
 function getDetail(type) {
-  state.loading = true;
+  state.loading = false;
   // getFormName().then((res1) => {
   //   state.formList = res1.data;
     getDocumentDetails(state.queryParams)
     .then((requset) => {
+      if(requset.data){
         state.detail = requset.data;
         state.detail.id = state.id;
         listDept({id:state.detail.deptId}).then((res2) => {
@@ -190,10 +204,17 @@ function getDetail(type) {
               var info = res4.data[0]
               state.nodeList = JSON.parse(info.flowInfo).node
               state.detail.formName = info.formName
+              state.loading = true;
             }
           })
         })
-        state.loading = false;
+        
+      }else{
+        proxy.$modal.msgError("详情数据异常");
+        setTimeout(()=>{
+          returnTo("business/oa/toDo/index")
+        },2000)
+      }
     })
     .catch((err) => {
       state.loading = false;
@@ -320,29 +341,11 @@ onLoad((options) => {
   }
   .typeIcon{
     width:55px;
+    height:48px;
     position: absolute;
     top:25px;
     right:10px;
   }
-  .fixedBottom{
-    width:100%;
-    height:36px;
-    line-height: 36px;
-    position: fixed;
-    bottom: 0;
-    left:0;
-    background-color: #fff;
-    text-align: center;
-    color:#000;
-    img{
-      vertical-align: middle;
-      margin-right:10px;
-      margin-top:-2px;
-    }
-    span{
-      vertical-align: middle;
-    }
-  }
   .stepBar{
     margin-top:-20px;
     font-weight: 400;
@@ -402,7 +405,7 @@ onLoad((options) => {
         background: #999;
       }
       .center{
-        width:100%;
+        width:calc(100% - 40px);
         margin:10px 0 0 40px;
         padding-right:10px;
       }
@@ -438,25 +441,51 @@ onLoad((options) => {
       }
     }
   }
-  .approval{
-    position: fixed;
-    width:100%;
-    bottom: 10px;
-    left:0;
-    button{
-      width:calc(50% - 15px);
-      height:50px;
-      margin-left:10px;
-      display: inline-block;
-      border-radius: 16px !important;
-      
-    }
-    button.pass{
-      background: #2A98FF;
-      color:#fff;
+  .list-cell-bottom{
+    padding:0;
+    margin:10px 0 20px;
+    background-color: #fff;
+    .approval{
+      height:auto;
+      button{
+        width:calc(50% - 15px);
+        height:50px;
+        margin-left:10px;
+        display: inline-block;
+        border-radius: 16px !important;
+        
+      }
+      button.pass{
+        background: #2A98FF;
+        color:#fff;
+      }
+      button.refuse{
+        border:1px solid #CFCFCF;
+      }
     }
-    button.refuse{
-      border:1px solid #CFCFCF;
+    .again{
+      width:100%;
+      height:36px;
+      line-height: 36px;
+      text-align: center;
+      color:#000;
+      img{
+        vertical-align: middle;
+        margin-right:10px;
+        margin-top:-2px;
+      }
+      span{
+        vertical-align: middle;
+      }
     }
   }
+  .approvalWrap{
+    height:133px;
+    padding:20px 0;
+  }
+  .againWrap{
+    height:90px;
+    padding:5px 0;
+  }
+  
 </style>

+ 2 - 2
src/pages/login.vue

@@ -180,11 +180,11 @@ function init() {
   useStore.GetWxOpenId(1); //调用获取微信公众号openId
 
   if (window.location.host) {
-    linkUrl.value = window.location.host;
+    // linkUrl.value = window.location.host;
     // linkUrl.value = "192.168.10.165:13200";
     // linkUrl.value = "localhost:81";
     // linkUrl.value = "120.26.164.249:13212";
-    // linkUrl.value = "manager.usky.cn";
+    linkUrl.value = "manager.usky.cn";
     useStore.GetMobileTenantConfig({ url: linkUrl.value });
   }
   //#endif

+ 8 - 0
src/plugins/constData.plugins.js

@@ -115,6 +115,14 @@ let projectTabbar = [
 		text: "报告填写",
 		dot: false,
 	},
+	{
+		pagePath: "/pages/business/common/projectMange/statistics/index",
+		iconClass: "oaIcon-tab-reportInsert",
+		iconPath: "",
+		selectedIconPath: "",
+		text: "报告统计",
+		dot: false,
+	},
 	{
 		pagePath: "/pages/business/common/projectMange/list/index",
 		iconClass: "oaIcon-tab-projectsList",