tend.vue 4.99 KB
Newer Older
xulili's avatar
xulili committed
1 2
/* 点播趋势图 */
<template>
xulili's avatar
xulili committed
3
  <div class="trend-wrapper height100 overview-detail">
xulili's avatar
xulili committed
4
    <div class="btn-group"  v-if="isExport">
xulili's avatar
xulili committed
5 6 7 8 9 10 11
      <el-button
        class="export"
        type="primary"
        icon="el-icon-download"
        @click="handleExport"
        >导出文件</el-button
      >
xulili's avatar
xulili committed
12
    </div>
xulili's avatar
xulili committed
13
    <div id="bodyCanvas" :class="isExport?'':'export'">
xulili's avatar
xulili committed
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
      <div class="ecahrts-panel-box">
        <div class="panel-box-header">
          <span class="title">趋势图</span>
          <el-select v-model="playDate" @change="handleChange">
            <el-option
              v-for="item in options"
              :key="item.value"
              :label="item.label"
              :value="item.value"
            >
            </el-option>
          </el-select>
          <div class="tip">
            <span class="tip-title">页面说明:</span>
            <span
xulili's avatar
xulili committed
29
              >默认展示当月点播总量趋势图及详情表格,可按照时间段进行检索,图表可以联动变化。。</span
xulili's avatar
xulili committed
30 31 32 33 34 35
            >
          </div>
        </div>
        <div class="panel-box-content">
          <trend-line ref="echarts" :data="echartsData" />
        </div>
xulili's avatar
xulili committed
36
      </div>
xulili's avatar
xulili committed
37 38 39 40 41 42 43
      <div class="rank-panel-box">
        <div class="panel-box-header">
          <span class="title">点播趋势排行</span>
        </div>
        <div class="panel-box-content">
          <rank-table :tList="tList" :data="data" />
        </div>
xulili's avatar
xulili committed
44
      </div>
xulili's avatar
xulili committed
45
    </div>
xulili's avatar
xulili committed
46
  </div>
xulili's avatar
xulili committed
47 48
</template>
<script>
xulili's avatar
xulili committed
49
import { trendLine, rankTable } from "./components";
xulili's avatar
xulili committed
50
import { getCurDate } from "@/utils/util.time";
xulili's avatar
xulili committed
51
export default {
xulili's avatar
xulili committed
52 53 54 55
  data() {
    return {
      value1: "",
      tList: ["排名", "统计时间", "点播总量"],
xulili's avatar
xulili committed
56
      playDate: "1",
xulili's avatar
xulili committed
57
      data: [],
xulili's avatar
xulili committed
58
      echartsData: {},
xulili's avatar
xulili committed
59 60 61
      options: [
        { label: "年", value: "1" },
        { label: "月", value: "2" },
xulili's avatar
xulili committed
62
        // { label: "日", value: "3" },
xulili's avatar
xulili committed
63
      ],
xulili's avatar
xulili committed
64
      timer: null,
xulili's avatar
xulili committed
65
      isExport: false,
xulili's avatar
xulili committed
66 67 68
    };
  },
  components: { trendLine, rankTable },
xulili's avatar
xulili committed
69
  mounted() {
xulili's avatar
xulili committed
70 71 72 73
    let roleList = localStorage.getItem("roleList");
    if (roleList) {
      this.isExport = localStorage.getItem("roleList").includes("1");
    }
xulili's avatar
xulili committed
74 75
    this.handleChange("1");
  },
xulili's avatar
xulili committed
76
  methods: {
xulili's avatar
xulili committed
77
    getList(frequencyDate) {
xulili's avatar
xulili committed
78 79 80 81 82
      let _this = this;
      _this
        .$https({
          method: "post",
          url:
xulili's avatar
xulili committed
83
            "tBoardStatistic/getBoardTrendPageList?playDate=" + frequencyDate,
xulili's avatar
xulili committed
84 85 86 87 88 89
          authType: this.backToken,
        })
        .then((res) => {
          if (res.status == 200) {
            if (res.data.resultCode == 200) {
              _this.echartsData = {};
xulili's avatar
xulili committed
90
              _this.echartsData.xAxisData = res.data.data.dateList;
xulili's avatar
xulili committed
91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110
              _this.echartsData.yAxisData = res.data.data.cntList;
              _this.data = res.data.data.page.records;
            } else {
              _this.echartsData = {};
              _this.data = [];
            }
          } else {
            _this.echartsData = {};
            _this.data = [];
          }
          setTimeout(() => {
            _this.init();
          }, 100);
        })
        .catch((err) => {
          _this.$message.error(err.message);
          _this.echartsData = {};
          _this.data = [];
        });
    },
xulili's avatar
xulili committed
111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135
    handleChange(val) {
      let frequencyDate = this.getCurTime(val);
      this.getList(frequencyDate);
    },
    getCurTime(type) {
      let curTime = getCurDate();
      let frequencyDate = curTime.year + curTime.month;
      switch (type) {
        case "1":
          frequencyDate = curTime.year;
          return frequencyDate;
          break;
        case "2":
          frequencyDate = curTime.year + curTime.month;
          return frequencyDate;
          break;
        case "3":
          frequencyDate = curTime.year + curTime.month + curTime.date;
          return frequencyDate;
          break;
        default:
          return "";
          break;
      }
    },
xulili's avatar
xulili committed
136 137
    init() {
      this.$refs.echarts.init();
xulili's avatar
xulili committed
138
    },
xulili's avatar
xulili committed
139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158
    handleExport() {
      let _this = this;
      if (this.timer) {
        return false;
      }
      this.timer = setTimeout(() => {
        clearTimeout(_this.timer);
        _this.timer = null;
      }, 30000);
      _this.getPdf("#bodyCanvas", "趋势分析");
      const loading = this.$loading({
        lock: true,
        text: "Loading",
        spinner: "el-icon-loading",
        background: "rgba(0, 0, 0, 0.7)",
      });
      setTimeout(() => {
        loading.close();
      }, 2000);
    },
xulili's avatar
xulili committed
159 160
  },
};
xulili's avatar
xulili committed
161 162 163
</script>

<style lang="less" scoped>
xulili's avatar
xulili committed
164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186
.trend-wrapper {
  .btn-group {
    margin-bottom: 20px;
    height: 36px;
  }
  /deep/ .el-button.export {
    width: 128px;
    float: right;
    .el-icon-download {
      font-size: 18px;
      font-weight: bold;
    }
  }
  .el-select {
    margin-left: 40px;
    /deep/.el-input__inner {
      border-radius: 22px;
      background-color: @party-bg-gray;
      border-color: @party-border-color;
    }
  }
  #bodyCanvas {
    height: calc(100% - 56px);
xulili's avatar
xulili committed
187 188 189
    &.export {
      height: 100%;
    }
xulili's avatar
xulili committed
190 191 192 193 194
  }
  .ul-wrapper {
    background-color: @party-white;
  }
}
xulili's avatar
xulili committed
195
</style>