gaoluyang
2025-03-04 6faa853025e72e965d77917b269e19cd14b31c39
首页调整,联调
已修改5个文件
465 ■■■■ 文件已修改
src/api/index/report.js 8 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/assets/images/bg1.png 补丁 | 查看 | 原始文档 | blame | 历史
src/components/echarts/echarts.vue 18 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/index.vue 433 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/statisticalCharts/qualificationRateStatistics/index.vue 6 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/index/report.js
@@ -9,17 +9,17 @@
  })
}
//首页-->首页工时统计
export function manHourByStation(query) {
export function currentUserWorkHourCount(query) {
  return request({
    url: '/report/manHourByStation',
    url: '/report/currentUserWorkHourCount',
    method: 'get',
    params: query
  })
}
//首页-->首页工时统计
export function manHourByPerson() {
export function msgRoll(query) {
  return request({
    url: '/report/manHourByPerson',
    url: '/informationNotification/msgRoll',
    method: 'get',
    params: query
  })
src/assets/images/bg1.png

src/components/echarts/echarts.vue
@@ -52,11 +52,15 @@
    },
    lineColors: {
      type: Array,
      default: () => ['#00BAFF', '#3DE7C9', '#CCEDF0', '#FFB71C', '#FF5A5A']
      default: () => ['#A4EEDA', '#86C1F4', '#91A0FC', '#F6C18B', '#F09595']
    },
    barColors: {
      type: Array,
      default: () => ['#ff8800', '#3DE7C9', '#CCEDF0', '#FFB71C', '#FF5A5A']
      default: () => ['#A4EEDA', '#86C1F4', '#91A0FC', '#F6C18B', '#F09595']
    },
    pieColors: {
      type: Array,
      default: () => ['#A4EEDA', '#86C1F4', '#91A0FC', '#F6C18B', '#F09595']
    },
    loadingOption: {
      type: Object,
@@ -165,6 +169,15 @@
        })
      },
    },
    pieColors: {
      deep: true,
      // immediate: true,
      handler(val) {
        this.$nextTick(() => {
          this.renderChart()
        })
      },
    },
  },
  mounted() {
    this.chartInstance = echarts.init(this.$refs.chart)
@@ -217,7 +230,6 @@
        })
      }
      this.chartInstance.clear()
      // 渲染图表
      this.chartInstance.setOption(option)
    },
src/views/index.vue
@@ -5,7 +5,7 @@
        <div class="left-1">
          <div class="say">
            <div style="display: flex;align-items: center;flex-wrap: wrap;">
              <div class="say-1">{{user.name}} 您好!祝您开心每一天</div>
              <div class="say-1">{{nickName}} 您好!祝您开心每一天</div>
              <div class="say-2">当前时间: {{now}}</div>
            </div>
          </div>
@@ -18,117 +18,69 @@
              <el-tag style="margin-top: 6px;" size="small">{{workList[index].length}} 条</el-tag>
            </div>
            <div class="left-item-body">
              <div class="body-item" v-for="(m,i) in workList[index]" :key="i" :class="{color0:m.type==0,color1:m.type==1,color2:m.type==2}" @click="goAddList(m)">
              <div class="body-item" v-for="(m,i) in workList[index]" :key="i" :class="{color0:m.type==0,color1:m.type==1,color2:m.type==2}">
                <div>
                  <span style="font-size: 12px;margin-bottom: 8px;">{{ m.text }}</span>
                  <div class="tags" style="display: flex;align-items: end;flex-wrap: wrap;margin-bottom: 8px;">
                    <el-tooltip class="item" effect="dark" :content="item" placement="top" v-for="(item,index) in m.sample?m.sample.split(','):[]"
                                :key="index">
                      <el-tag
                        :color="m.type==0?'#70A090':(m.type==1?'#EBD476':'#FF3838')"
                        effect="dark" size="mini" style="margin: 2px;" class="single-line-ellipsis">
                        {{ item }}
                      </el-tag>
                    </el-tooltip>
                  <span style="font-size: 12px;margin-bottom: 17px;">{{ m.text }}</span>
                  <div style="display: flex">
                    <span class="body-item-name">{{ m.name }}</span>
                    <span v-if="m.state == 0" class="body-item-insState" style="background-color: #909399;font-size: 12px;">待检验</span>
                    <span v-if="m.state == 1" class="body-item-insState" style="background-color: #E6A23C;font-size: 12px;">检验中</span>
                    <span v-if="m.state == 2" class="body-item-insState" style="background-color: #67C23A;font-size: 12px;">已检验</span>
                    <span v-if="m.state == 3" class="body-item-insState" style="background-color: #E6A23C;font-size: 12px;">待复核</span>
                    <span v-if="m.state == 4" class="body-item-insState" style="background-color: #F56C6C;font-size: 9px;">复核未通过</span>
                    <span v-if="m.state == 5" class="body-item-insState" style="background-color: #67C23A;font-size: 10px;">复核通过</span>
                  </div>
                  <span style="display: inline-block;height: 22px;width: 70px;border-radius: 10px;line-height: 22px;text-align: center;background: #C0C4CC;color: #fff;font-size: 14px;">{{ m.name }}</span>
                </div>
              </div>
            </div>
          </div>
        </div>
<!--        <div v-loading="workLoading" class="left-2 card" style="overflow: hidden;">-->
<!--          <div v-for="(item,index) in workDay" :key="index" class="left-2-item">-->
<!--            <div class="left-item-title">-->
<!--              <span style="font-size: 18px;">{{ item }}</span>-->
<!--              <span style="font-size: 14px;color: #999999;">{{ weekdays[index] }}</span>-->
<!--            </div>-->
<!--            <div class="left-item-body">-->
<!--              <div v-for="(m,i) in workList[index]" :key="i" :class="{color0:m.type==0,color1:m.type==1,color2:m.type==2}" class="body-item">-->
<!--                <div>-->
<!--                  <span style="font-size: 12px;margin-bottom: 17px;">{{ m.text }}</span>-->
<!--                  <div style="display: flex">-->
<!--                    <span class="body-item-name">{{ m.name }}</span>-->
<!--                    <span v-if="m.insState == 0" class="body-item-insState" style="background-color: #909399;font-size: 12px;">待检验</span>-->
<!--                    <span v-if="m.insState == 1" class="body-item-insState" style="background-color: #E6A23C;font-size: 12px;">检验中</span>-->
<!--                    <span v-if="m.insState == 2" class="body-item-insState" style="background-color: #67C23A;font-size: 12px;">已检验</span>-->
<!--                    <span v-if="m.insState == 3" class="body-item-insState" style="background-color: #E6A23C;font-size: 12px;">待复核</span>-->
<!--                    <span v-if="m.insState == 4" class="body-item-insState" style="background-color: #F56C6C;font-size: 9px;">复核未通过</span>-->
<!--                    <span v-if="m.insState == 5" class="body-item-insState" style="background-color: #67C23A;font-size: 10px;">复核通过</span>-->
<!--                  </div>-->
<!--                </div>-->
<!--              </div>-->
<!--            </div>-->
<!--          </div>-->
<!--        </div>-->
      </el-col>
      <el-col :lg="10" :md="10" :sm="24" :xl="10" :xs="24">
        <div class="right-2 card">
          <span style="color: #333333;font-size: 16px;">工时统计</span>
          <div>
            <el-select v-model="sonLaboratory" placeholder="站点" size="mini" style="width: 100px;" @change="initEchart">
              <el-option
                v-for="item in dict.type.sys_sub_lab"
                :key="item.value"
                :label="item.label"
                :value="item.value">
              </el-option>
            </el-select>
            <el-radio-group v-model="type" size="mini">
              <el-radio-button label="周" ></el-radio-button>
              <el-radio-button label="月"></el-radio-button>
              <el-radio-button label="年"></el-radio-button>
            </el-radio-group>
            <el-date-picker
              v-model="time.week"
              type="week"
              format="yyyy 第 WW 周"
              placeholder="选择周" size="mini" v-if="type=='周'" @change="m=>changeTime(type,m)" style="width: 130px;">
            </el-date-picker>
          <div style="display: flex;align-items: center;justify-content: space-between;margin-bottom: 10px">
            <span style="color: #333333;font-size: 16px;">工时统计</span>
            <el-date-picker
              v-model="time.month"
              type="month"
              placeholder="选择月" size="mini" v-if="type=='月'" @change="m=>changeTime(type,m)" style="width: 130px;">
            </el-date-picker>
            <el-date-picker
              v-model="time.year"
              type="year"
              placeholder="选择年" size="mini" v-if="type=='年'" @change="m=>changeTime(type,m)" style="width: 130px;">
              date-format="yyyy-MM"
              value-format="yyyy-MM"
              placeholder="选择月" size="mini" @change="changeTime" style="width: 130px;">
            </el-date-picker>
          </div>
        </div>
        <div class="right-2-body">
          <el-row :gutter="10" style="width: 100%;height: 80px;">
            <el-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
              <div style="height: 100%;background: url(~@/assets/images/bg1.png) no-repeat;background-size: 100% 100%;padding: 12px 0;box-sizing: border-box;">
                <p style="text-align: center;font-size: 14px;color: #606266;line-height: 20px;margin-bottom: 4px;">总工时(小时)</p>
                <p style="text-align: center;font-family: DIN Alternate, DIN Alternate;font-weight: 700;font-size: 30px;color: #3D3D3D;line-height: 35px;">{{chartData0.total}}</p>
          <el-row :gutter="10" style="width: 100%;">
            <el-col :span="12">
              <div class="right-time-1">
                <div style="text-align: center;font-size: 14px;color: #606266;line-height: 60px;">总工时(小时)</div>
                <div style="text-align: center;font-family: DIN Alternate, DIN Alternate;font-weight: 700;font-size: 26px;color: #3D3D3D;line-height: 40px;">{{totalHour}}</div>
              </div>
            </el-col>
            <el-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
              <div style="height: 100%;background: url(~@/assets/images/bg2.png) no-repeat;background-size: 100% 100%;padding: 12px 0;box-sizing: border-box;">
                <p style="text-align: center;font-size: 14px;color: #606266;line-height: 20px;margin-bottom: 4px;">检验员(个)</p>
                <p style="text-align: center;font-family: DIN Alternate, DIN Alternate;font-weight: 700;font-size: 30px;color: #3D3D3D;line-height: 35px;">{{chartData0.personNum}}</p>
              </div>
            <el-col :span="12">
              <Echarts ref="chart"
                       :legend="pieLegend"
                       :series="materialPieSeries"
                       :tooltip="pieTooltip"
                       style="height: 150px;width: 100%;"></Echarts>
            </el-col>
          </el-row>
          <echart-module :id="'index-1'" :config="chartConfig0" :datas="chartData0" style="height: 250px;width: 100%;"></echart-module>
        </div>
        <div class="right-3 card" style="overflow: hidden;">
          <div class="right-3-tab">
            <div :class="{active:currentIndex==5}" class="tab-item">待办事项</div>
            <div class="tab-item">待办事项</div>
            <div class="tab-item2">{{'您有' + total + '项任务待完成'}}</div>
          </div>
          <div v-loading="listLoading" class="right-3-list">
            <scroll-pagination v-if="list.length>0||listLoading" :finishLoding="finishLoding" :list="list" @load="getList">
              <div v-for="(m,i) in list" :key="i" class="list3-item">
                <div class="list3-item-title">
                  <p style="color: #FF7756">{{ m.theme }}</p>
                  <span class="blue-dot">{{ m.theme }}</span>
                  <el-link class="blue-dot1" @click="goAddList(m)">查看</el-link>
                </div>
                <div class="list3-item-info">
                  <p class="ellipsis-multiline" style="width: 73%;-webkit-line-clamp: 1;cursor: pointer;" @click="goNoticeDetail(m)">
                  <div class="ellipsis-multiline" @click="goNoticeDetail(m)">
                    {{ m.content }}
                  </p>
                  <p>{{ m.createTime }}</p>
                  </div>
                  <div class="createTime-info">时间:{{ m.createTime }}</div>
                </div>
              </div>
            </scroll-pagination>
@@ -141,22 +93,20 @@
</template>
<script>
import {getYearAndMonthAndDays} from '@/utils/date.js'
import ScrollPagination from '@/components/index/scroll-paging.vue'
import {calendarWorkByWeek, manHourByPerson, manHourByStation} from "@/api/index/report";
import EchartModule from '@/components/echarts/echart.vue'
import {calendarWorkByWeek, currentUserWorkHourCount, msgRoll, page} from "@/api/index/report";
import Echarts from "@/components/echarts/echarts.vue";
import {mapGetters} from "vuex";
export default {
  components: {
    Echarts,
    ScrollPagination,
    EchartModule
  },
  dicts: ['sys_sub_lab'],
  data() {
    return {
      user: {},
      now: null,
      calendarValue: new Date(),
      currentIndex:5,
      workLoading:false,
      workList:[],
      workDay:[],
@@ -172,15 +122,43 @@
      timer:null,
      keyMap:{},
      sonLaboratory:null,
      chartData0:{
        total:0,
        personNum:0,
        data:[]
      },
      chartConfig0:{
        height: '',
        isLoading:false,
        type:'pie0'
      totalHour: 0,
      materialPieSeries: [
        {
          name: 'Access From',
          type: 'pie',
          radius: ['40%', '60%'],
          avoidLabelOverlap: false,
          itemStyle: {
            borderRadius: 5,
            borderColor: '#fff',
            borderWidth: 2
          },
          label: {
            alignTo: 'edge',
            edgeDistance: 10,
            lineHeight: 15,
            formatter: '{name|{b}}\n{time|{c} 小时}',
            rich: {
              time: {
                fontSize: 10,
                color: '#999'
              }
            },
          },
          labelLine: {
            length: 10,
            length2: 10,
          },
          data: [
            { value: 0, name: '辅助工时', itemStyle: {color: '#A4EEDA'} },
            { value: 0, name: '产量工时', itemStyle: {color: '#86C1F4'} },
          ]
        }
      ],
      pieLegend: {show: false},
      pieTooltip: {
        trigger: 'item'
      },
      type:'月',
      time:{
@@ -190,16 +168,10 @@
      },
    }
  },
  watch:{
    currentIndex(){
      this.keyMap = {}
      this.currentPage = 1;
      this.list = [];
      this.getList();
    }
  computed: {
    ...mapGetters(['nickName'])
  },
  mounted() {
    // this.user = JSON.parse(localStorage.getItem('user'))
    this.nowTime()
    setInterval(() => {
      this.nowTime()
@@ -210,6 +182,7 @@
    this.keyMap = {}
    this.list = [];
    this.getList();
    this.initEchart()
    this.timer&&clearInterval(this.timer)
    this.timer = setInterval(() => {
      this.init();
@@ -223,11 +196,6 @@
    // 跳转页面
    goAddList() {
    },
    changeState (val) {
      if (val == 0) {
        return '待检验'
      }
    },
    getList(){
      const key = `_${this.currentPage}`
@@ -244,25 +212,29 @@
      if(this.list.length==0){
        this.finishLoding = false;
      }
      // this.$axios.get(this.$api.informationNotification.page+'?size='+this.pageSize+'&current='+this.currentPage+'&messageType='+this.currentIndex).then(res => {
      //   this.listLoading = false
      //   let list = res.data.records;
      //   this.total = res.data.total;
      //   if(list.length==0){
      //     this.finishLoding = true;
      //   }else{
      //     if(list.length<this.pageSize){
      //       this.finishLoding = true;
      //     }
      //     this.list = this.list.concat(list)
      //     if(this.total==this.list.length){
      //       this.finishLoding = true;
      //     }
      //     this.currentPage++;
      //   }
      // }).catch(err => {
      //   this.listLoading = false
      // })
      const params = {
        size: this.pageSize,
        currentPage: this.currentPage,
      }
      msgRoll(params).then(res => {
        let list = res.data.records;
        this.total = res.data.total;
        if(list.length==0){
          this.finishLoding = true;
        }else{
          if(list.length<this.pageSize){
            this.finishLoding = true;
          }
          this.list = this.list.concat(list)
          if(this.total==this.list.length){
            this.finishLoding = true;
          }
          this.currentPage++;
        }
        this.listLoading = false
      }).catch(err=>{
        this.listLoading = false
      })
    },
    nowTime() {
      var date = new Date();
@@ -346,76 +318,47 @@
      return weekdays;
    },
    goNoticeDetail(row){
      this.$axios.put(this.$api.informationNotification.triggerModificationStatusToRead+'/'+row.id).then(res => {
        row.num = Math.random(100);
        this.$bus.$emit("change", JSON.stringify(row));
        this.$parent.addTab({
          v: "消息详情",
          i: "el-icon-s-tools",
          u: "notice-detail",
          k:35,
          p: "abcd"
        },29);
      })
      // this.$axios.put(this.$api.informationNotification.triggerModificationStatusToRead+'/'+row.id).then(res => {
      //   row.num = Math.random(100);
      //   this.$bus.$emit("change", JSON.stringify(row));
      //   this.$parent.addTab({
      //     v: "消息详情",
      //     i: "el-icon-s-tools",
      //     u: "notice-detail",
      //     k:35,
      //     p: "abcd"
      //   },29);
      // })
    },
    changeTime(type,m){
      if(m){
        switch(type){
          case '周':
            this.startTime  = getYearAndMonthAndDays(new Date(this.time.week.getTime() - 24 * 60 * 60 * 1000))
            this.endTime = getYearAndMonthAndDays(new Date(this.time.week.getTime() + 24 * 60 * 60 * 1000 * 5))
            break;
          case '月':
            const year = new Date(this.time.month).getFullYear();
            const month = new Date(this.time.month).getMonth();
            const day = new Date(year, month + 1, 0).getDate(); //
            // 设置起始日期和结束日期
            this.startTime = `${year}-${month + 1}-01`
            this.endTime = `${year}-${month + 1}-${day}` // 月末
            break;
          case '年':
            const year0 = new Date(this.time.year).getFullYear();
            this.startTime = `${year0}-01-01`; // 年初
            this.endTime = `${year0}-12-31`; // 年末
            break;
        }
      }else{
        const year = new Date().getFullYear();
        const month = new Date().getMonth();
        // 设置起始日期和结束日期
        this.startTime = new Date(year, month, 1).toISOString().slice(0, 10); // 月初
        this.endTime = new Date(year, month + 1, 0).toISOString().slice(0, 10); // 月末
        this.time.month = new Date()
    changeTime(m){
      this.initEchart(m)
    },
    async initEchart(m){
      let month = ''
      if (m) {
        month = m
      } else {
        // 获取时间
        const nowDate = new Date();
        // 分别获取年、月
        const date = {
          year: nowDate.getFullYear(),
          month: nowDate.getMonth() + 1,
        };
        // 月份为单数时十位显示0
        const newMonth = date.month >= 10 ? date.month : "0" + date.month;
        // 返回格式为yyyymm的年月
        month = date.year + '-' + newMonth;
      }
      this.initEchart()
    },
    async initEchart(){
      this.chartConfig0.isLoading = false
      const params = {
        startTime: this.startTime,
        endTime: this.endTime,
        sonLaboratory: this.sonLaboratory,
        month: month,
      }
      let res0 = await manHourByStation(params)
      if (res0.code == 500) return
      this.chartData0.total = res0.message
      let res1 = await manHourByPerson(params)
      if (res1.code == 500) return
      this.chartData0.personNum = 0
      this.chartData0.data = []
      if(res1.data){
        for(let m in res1.data){
          this.chartData0.personNum ++
          let obj = {
            name:m,
            value:res1.data[m],
            penl:this.chartData0.total>0?((res1.data[m]/this.chartData0.total)*100).toFixed(2):0
          }
          this.chartData0.data.push(obj)
        }
      }
      this.chartConfig0.isLoading = true
      currentUserWorkHourCount(params).then(res => {
        console.log(res)
        this.totalHour = res.data.totalHour
        this.materialPieSeries[0].data[0].value = res.data.subsidiaryHour
        this.materialPieSeries[0].data[1].value = res.data.yieldHour
      })
    },
  },
  deactivated(){
@@ -439,6 +382,14 @@
  height: 118px;
  margin-bottom: 16px;
  border-radius: 16px;
}
.right-time-1 {
  background: url("~@/assets/images/bg1.png") no-repeat;
  background-size: 100% 100%;
  padding: 4px 0 4px 50px;
  box-sizing: border-box;
  width: 100%;
  height: 122px;
}
.left-1 .say {
@@ -500,22 +451,8 @@
}
.right-2{
  padding: 13px 14px 8px;
  margin-bottom: 16px;
}
.right-2-title{
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.right-2-body{
  width: 100%;
  margin-top: 20px;
  /* display: flex;
  align-items: start;
  justify-content: space-between; */
  padding: 10px;
  margin-bottom: 20px;
}
>>>.el-calendar__header {
  display: none;
@@ -561,8 +498,9 @@
  font-size: 14px;
}
.right-3-tab{
  padding: 20px 0 0 20px;
  margin-bottom: 16px;
  padding: 20px 20px 10px 20px;
  display: flex;
  justify-content: space-between;
}
.tab-item{
  font-weight: 500;
@@ -573,30 +511,65 @@
  font-style: normal;
  text-transform: none;
}
.tab-item2{
  font-weight: 500;
  font-size: 14px;
  color: #FD8504;
}
.right-3-list{
  padding: 0 12px 8px;
  padding: 0 20px 20px 20px;
  box-sizing: border-box;
  height: 390px;
  overflow-y: auto;
}
.list3-item{
  padding: 6px 4px;
  padding: 10px;
  margin: 8px 0;
  height: 94px;
  background: #F7F7F7;
}
.list3-item:hover{
  background: rgba(58, 123, 250,0.05);
}
.list3-item-title{
  margin-bottom: 6px;
  font-weight: 600;
  font-size: 14px;
  color: #3D3D3D;
  display: flex;
  align-items: start;
  margin-bottom: 10px;
  justify-content: space-between;
}
.blue-dot::before {
  content: "•"; /* 这是小蓝点的字符 */
  color: #3A7BFA; /* 设置颜色为蓝色 */
  font-size: 20px; /* 设置大小 */
  line-height: 20px;
  margin-right: 5px; /* 与<span>内容之间的间距 */
  vertical-align: middle;
}
.blue-dot1 {
  font-weight: 500;
  font-size: 14px;
  color: #3A7BFA;
}
.list3-item-info{
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: space-between;
  color: #666666;
  font-weight: 400;
  font-size: 14px;
  color: #3D3D3D;
  height: 60%;
}
.ellipsis-multiline {
  font-weight: 400;
  font-size: 14px;
  color: #3D3D3D;
}
.createTime-info {
  font-weight: 400;
  font-size: 12px;
  color: #9F9F9F;
}
.left-2{
  display: grid;
@@ -635,7 +608,6 @@
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 8px;
  cursor: pointer;
}
.body-item.color0{
  background: #70A090;
@@ -693,4 +665,25 @@
>>>.el-tag--dark{
  border: 0;
}
.body-item-name {
  display: inline-block;
  height: 22px;
  width: 60px;
  border-radius: 10px;
  line-height: 22px;
  text-align: center;
  background: #C0C4CC;
  color: #fff;
  font-size: 12px
}
.body-item-insState {
  margin-left: 2px;
  display: inline-block;
  height: 22px;width: 60px;
  border-radius: 10px;
  line-height: 22px;
  text-align: center;
  color: #fff;
  font-size: 12px
}
</style>
src/views/statisticalCharts/qualificationRateStatistics/index.vue
@@ -197,9 +197,9 @@
          type: 'shadow'
        }
      },
      lineColors: ['#409EFF'],
      barColors: ['#E6A23C'],
      barColors2: ['#adde8b'],
      lineColors: ['#91A0FC'],
      barColors: ['#86C1F4'],
      barColors2: ['#A4EEDA'],
      pieTooltip: {
        trigger: 'item'
      },