<template>
	<view class="background-none">
		<cu-custom bgColor="bg-gradual-blueness" :isBack="true" :isRingt="true">
			<block slot="backText">返回</block>
			<block slot="content">高危作业</block>
		</cu-custom>
    <view class="new-apps-box">
      <view class="new-apps-warp">
        <view class="new-apps-item" v-for="(item,index) in highRiskList" :key="index">
          <navigator class="a" hover-class="none" :url="item.url">
            <view class="image">
              <image :src="item.image" mode=""></image>
              <view v-if="item.hotWorkCount > 0" class="badge">{{ item.hotWorkCount }}</view>
              <view v-if="item.hightWorkCount > 0" class="badge">{{ item.hightWorkCount }}</view>
              <view v-if="item.blindBoardCount > 0" class="badge">{{ item.blindBoardCount }}</view>
              <view v-if="item.HoistingCount > 0" class="badge">{{ item.HoistingCount }}</view>
              <view v-if="item.confinedSpaceCount > 0" class="badge">{{ item.confinedSpaceCount }}</view>
              <view v-if="item.electricityCount > 0" class="badge">{{ item.electricityCount }}</view>
            </view>
            <view class="title">
              <text>{{ item.title }}</text>
            </view>
          </navigator>
        </view>
      </view>
    </view>
	</view>
</template>

<script>
import { basePath, loginUser } from '@/common/tool.js';

export default {
  data() {
    return {
      highRiskList: [
        {
          title: '动火作业',
          url: '/pages/application/eight-assignments/index',
          image: require('../../../static/new_images/i1.png'),
          hotWorkCount: 0,
        },
        {
          title: '高处作业',
          url: '/pages/application/gf-eight-work/high-work/home',
          image: require('../../../static/new_images/i2.png'),
          hightWorkCount: 0,
        },
        {
          title: '盲板作业',
          url: '/pages/application/gf-eight-work/blind-board/home',
          image: require('../../../static/new_images/i3.png'),
          blindBoardCount: 0,
        },
        {
          title: '吊装作业',
          url: '/pages/application/gf-eight-work/hoisting/home',
          image: require('../../../static/new_images/i4.png'),
          HoistingCount: 0,
        },
        {
          title: '有限空间安全作业',
          url: '/pages/application/gf-eight-work/confinedspace/home',
          image: require('../../../static/new_images/i5.png'),
          confinedSpaceCount: 0,
        },
        {
          title: '临时用电安全作业',
          url: '/pages/application/gf-eight-work/electricity/home',
          image: require('../../../static/new_images/i6.png'),
          electricityCount: 0,
        },
      ],
    };
  },
  onShow() {
    this.updateWorkCounts('/app/hotwork/cfd/countCheck', '动火作业', 'hotWorkCount');
    this.updateWorkCounts('/app/gfHighwork/countCheck', '高处作业', 'hightWorkCount');
    this.updateWorkCounts('/app/gfBlindBoard/countCheck', '盲板作业', 'blindBoardCount');
    this.updateWorkCounts('/app/gfHoisting/countCheck', '吊装作业', 'blindBoardCount');
    this.updateWorkCounts('/app/gfConfinedSpace/countCheck', '有限空间安全作业', 'blindBoardCount');
    this.updateWorkCounts('//app/gfElectricity/countCheck', '临时用电安全作业', 'electricityCount');
  },
  methods: {
    updateWorkCounts(url, title, countKey) {
      uni.showLoading({ title: "加载中..." }); // 加载中动画
      uni.request({
        url: basePath + url,
        method: 'POST',
        dataType: 'json',
        header: { 'Content-type': 'application/x-www-form-urlencoded' },
        data: {
          tm: new Date().getTime(),
          CORPINFO_ID: loginUser.CORPINFO_ID,
          USER_ID: loginUser.USER_ID,
        },
        success: (res) => {
          uni.hideLoading(); // 结束加载中动画
          if (res.data.result === "success") {
            let totalCount = res.data.count.SUMCOUNT;
            this.highRiskList = this.highRiskList.map(item => {
              if (item.title === title) {
                return { ...item, [countKey]: totalCount };
              }
              return item;
            });
          }
        }
      });
    }
  }
};
</script>

<style>
.new-apps-box {
  padding: 20upx;
}

.new-apps-warp {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.new-apps-item {
  position: relative;
  width: 30%;
  margin-bottom: 20upx;
  text-align: center;
}

.new-apps-item .image {
  position: relative;
  width: 100%;
  height: 100upx;
}

.new-apps-item .badge {
  position: absolute;
  top: -10px;
  right: 0;
  background-color: #dd514c;
  color: white;
  border-radius: 50%;
  padding: 2px 5px;
  font-size: 12px;
}

.new-apps-item .title {
  margin-top: -5upx;
}
</style>