Newer
Older
urbanLifeline_YanAn / src / views / oneMap / components / monitorCalender.vue
@zhangdeliang zhangdeliang on 7 Oct 8 KB update
<template>
  <!-- 海绵监测分析--降雨日历统计 -->
  <div class="monitorCalenderHM">
    <div class="selectTitleHM">
      <div class="flex select_box">
        <!-- 日期类型选择 -->
        <div class="typeDate flex">
          <p :class="['partD', dateIndex == 'day' ? 'active' : '']" @click="changeDate('day')">日</p>
          <p :class="['partD', dateIndex == 'month' ? 'active' : '']" @click="changeDate('month')">月</p>
          <p :class="['partD', dateIndex == 'year' ? 'active' : '']" @click="changeDate('year')">年</p>
        </div>
        <!-- 日历 -->
        <el-date-picker
          format="YYYY-MM"
          value-format="YYYY-MM"
          type="month"
          v-model="datevalue"
          placeholder="选择日期"
          style="width: 140px; margin: 10px 10px"
          @change="timeChange"
          class="datePickerHM"
          popper-class="haiMianScreenPopper"
          size="small"
        />
        <!-- 雨量站选择 -->
        <el-select
          clearable
          filterable
          v-model="rainStation"
          placeholder="请选择雨量站"
          style="margin-top: 10px"
          size="small"
          class="picker"
        >
          <el-option v-for="dict in rainList" :key="dict.value" :label="dict.label" :value="dict.value" />
        </el-select>
      </div>
    </div>

    <!-- 日 -->
    <el-calendar class="elCalendar" v-model="datevalueNew" v-loading="loading" element-loading-background="rgba(0, 0, 0, 0.6)">
      <template #date-cell="{ data }">
        <div
          class="flex flex-v data-day"
          :class="[{ active: data.day === selectVal }]"
          @click="changepeople(data.day)"
          style="position: relative"
        >
          <div class="date_box">{{ moment(data.day).format('DD') }}</div>
          <div
            class="datadiv flex"
            :style="{
              background:
                rainLevel(scheduleData[moment(data.day).format('YYYY-MM-DD')]) == '1'
                  ? '#009DE2'
                  : rainLevel(scheduleData[moment(data.day).format('YYYY-MM-DD')]) == '2'
                  ? '#6A01E1'
                  : rainLevel(scheduleData[moment(data.day).format('YYYY-MM-DD')]) == '3'
                  ? '#FF9F15'
                  : rainLevel(scheduleData[moment(data.day).format('YYYY-MM-DD')]) == '4'
                  ? '#E20F36'
                  : '',
            }"
          >
            {{
              rainLevel(scheduleData[moment(data.day).format('YYYY-MM-DD')]) == '1'
                ? '小雨'
                : rainLevel(scheduleData[moment(data.day).format('YYYY-MM-DD')]) == '2'
                ? '中雨'
                : rainLevel(scheduleData[moment(data.day).format('YYYY-MM-DD')]) == '3'
                ? '大雨'
                : rainLevel(scheduleData[moment(data.day).format('YYYY-MM-DD')]) == '4'
                ? '暴雨'
                : ''
            }}
          </div>
        </div>
      </template>
    </el-calendar>
  </div>
</template>

<script setup>
// import { rainTimeDay } from '@/api/zongHeDD.js';
const props = defineProps({
  defaultDate: {
    type: String,
    default: '',
  },
  hasClose: {
    type: Boolean,
    default: false,
  },
});
const dateIndex = ref('month');
const { proxy } = getCurrentInstance();
const curDate = props.defaultDate ? proxy.moment(props.defaultDate).format('YYYY-MM') : proxy.moment().format('YYYY-MM');
const curDateNew = props.defaultDate ? new Date(props.defaultDate) : new Date();
const datevalue = ref('2024-08'); //curDate
const datevalueNew = ref('2024-08-07'); //curDateNew
const emits = defineEmits(['change', 'close']);
const selectVal = ref(props.defaultDate);
const scheduleData = ref({});
const loading = ref(false);
const rainStation = ref('1');
const rainList = ref([
  { value: '1', label: '雨量站1' },
  { value: '2', label: '雨量站2' },
]);

function timeChange(val) {
  console.log(val);
  datevalueNew.value = new Date(val);
  getRainTimeDayData();
}

//获取降雨日历数据
const getRainTimeDayData = () => {
  let data = {
    fromTime: proxy.moment(datevalue.value).startOf('month').format('YYYY-MM-DD'),
    toTime: proxy.moment(datevalue.value).endOf('month').format('YYYY-MM-DD'),
  };
  // loading.value = true;
  // rainTimeDay(data)
  //   .then(res => {
  //     res.data &&
  //       res.data.forEach(item => {
  //         scheduleData.value[item.rainTime] = item.rainCumulative;
  //       });
  //   })
  //   .finally(() => {
  //     loading.value = false;
  //   });
  let datas = [
    { rainTime: '2024-08-07', rainCumulative: 35 },
    { rainTime: '2024-08-08', rainCumulative: 52 },
    { rainTime: '2024-08-15', rainCumulative: 8 },
  ];
  datas.forEach(item => {
    scheduleData.value[item.rainTime] = item.rainCumulative;
  });
};
// 降雨日历点击事件
const changepeople = val => {
  selectVal.value = val;
  emits('change', val);
};

function changeDate(val) {
  dateIndex.value = val;
  let valueFormat =
    dateIndex.value == 'day' ? 'YYYY-MM-DD' : dateIndex.value == 'month' ? 'YYYY-MM' : dateIndex.value == 'year' ? 'YYYY' : '';
  datevalue.value = proxy.moment().format(valueFormat);
}

// 根据降雨量计算对应等级
function rainLevel(val) {
  if (val > 0 && val <= 10) {
    return '1'; //小雨
  } else if (val > 10 && val <= 25) {
    return '2'; //中雨
  } else if (val > 25 && val <= 50) {
    return '3'; //大雨
  } else if (val > 50) {
    return '4'; //暴雨
  }
}

onMounted(() => {
  getRainTimeDayData();
});
</script>

<style lang="scss" scoped>
.monitorCalenderHM {
  .selectTitleHM {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 40px;
    background-size: 100% 100%;
    padding: 0 10px;

    .name {
      font-family: YouSheBiaoTiHei;
      font-weight: bold;
      font-size: 17px;
      line-height: normal;
      letter-spacing: 2px;
      color: #e0e5fa;
      padding-left: 10px;
    }

    .select_box {
      margin-bottom: 0;
    }
    .typeDate {
      color: #fff;
      .partD {
        width: 50px;
        height: 22px;
        line-height: 22px;
        text-align: center;
        cursor: pointer;
        background: #00344f;
        border-radius: 2px;
        margin-right: 5px;
      }
      .active {
        background: #002d44;
        border-radius: 2px;
        border: 1px solid #1cf5fc;
      }
    }

    .closeBtn {
      margin-left: 10px;
      margin-top: 5px;
      cursor: pointer;
      .el-icon {
        color: rgb(0, 238, 255);
      }
    }
  }

  .calendar-day {
    width: 30px;
    height: 30px;
    line-height: 30px;
    border-radius: 50%;
    color: #fff;

    &.active {
      background-color: #21adda;
    }
  }

  .datadiv {
    font-size: 10px;
    height: 20px;
  }
}

:deep(.elCalendar) {
  border: none !important;
  background-color: #043864;

  .is-today {
    width: 30px !important;
    height: 30px !important;
    // background-color: #1EFFFF !important;
    border-radius: 15px;
    font-family: Source Han Sans CN;
    font-weight: 500;
    font-size: 14px;
  }

  .el-calendar-table tr:first-child td,
  .el-calendar-table td,
  .el-calendar-table tr td:first-child {
    border: none;
  }

  .el-calendar-table {
    padding: 2px;
  }

  //取消日历选中背景颜色
  .el-calendar-table td.is-selected {
    background-color: inherit;
  }

  .el-calendar-table thead th {
    color: #c6c6c6;
    font-size: 16px;
  }

  .el-calendar__header {
    display: none;
  }

  .el-calendar-day {
    margin: 0 auto;
    width: 100%;
    height: 40px !important;
    line-height: 40px !important;
    border: none;
    text-align: center;
    padding: 0px !important;
    background: #003958;
    font-size: 12px;
    border-radius: 50%;
    .data-day {
      width: 46%;
      height: 80%;
      position: relative;
      left: 50%;
      top: 50%;
      transform: translate(-50%, -50%);
      border-radius: 50%;
      &.active {
        background-color: #1effff;
        color: #042e77;
        .datadiv {
          bottom: -10px;
        }
      }
    }
    .date_box {
      width: 100%;
      font-size: 15px;
      margin-top: -5px;
      color: #ebfeff !important;
    }

    .datadiv {
      width: 100%;
      position: absolute;
      bottom: -10px;
      font-size: 11px;
      height: 16px;
      line-height: 16px;
      text-align: center;
      padding-left: 2px;
      color: #fff;
    }
  }

  .is-today {
    .data-day {
      background-color: #047af3;
      color: #fff;
    }
  }

  .el-calendar__body {
    padding: 0 0 10px 0 !important;
    background: #003958;
  }

  /* 日历单元格鼠标经过背景色 */
  .el-calendar-table .el-calendar-day:hover {
    background-color: transparent !important;
  }

  .el-calendar-table:not(.is-range) td.next {
    .calendar-day {
      color: #a8abb2 !important;
    }
  }
}
</style>