|  | @@ -0,0 +1,170 @@
 | 
											
												
													
														|  | 
 |  | +<template>
 | 
											
												
													
														|  | 
 |  | +  <div class="app-container">
 | 
											
												
													
														|  | 
 |  | +    <div class="reward-container">
 | 
											
												
													
														|  | 
 |  | +      <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">
 | 
											
												
													
														|  | 
 |  | +        <el-form-item label="公司名" prop="companyId">
 | 
											
												
													
														|  | 
 |  | +          <el-select filterable  v-model="queryParams.companyId" placeholder="请选择公司名"  @change="companyChange" clearable size="small">
 | 
											
												
													
														|  | 
 |  | +            <el-option
 | 
											
												
													
														|  | 
 |  | +              v-for="item in companys"
 | 
											
												
													
														|  | 
 |  | +              :key="item.companyId"
 | 
											
												
													
														|  | 
 |  | +              :label="item.companyName"
 | 
											
												
													
														|  | 
 |  | +              :value="item.companyId"
 | 
											
												
													
														|  | 
 |  | +            />
 | 
											
												
													
														|  | 
 |  | +          </el-select>
 | 
											
												
													
														|  | 
 |  | +        </el-form-item>
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        <el-form-item label="查询日期" prop="step">
 | 
											
												
													
														|  | 
 |  | +          <el-date-picker
 | 
											
												
													
														|  | 
 |  | +            type="month"
 | 
											
												
													
														|  | 
 |  | +            v-model="selectedTimeStep"
 | 
											
												
													
														|  | 
 |  | +            @change="handleTimeStepChange"
 | 
											
												
													
														|  | 
 |  | +            placeholder="选择一个日期">
 | 
											
												
													
														|  | 
 |  | +          </el-date-picker>
 | 
											
												
													
														|  | 
 |  | +        </el-form-item>
 | 
											
												
													
														|  | 
 |  | +        <el-form-item>
 | 
											
												
													
														|  | 
 |  | +          <el-button type="cyan" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
 | 
											
												
													
														|  | 
 |  | +          <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
 | 
											
												
													
														|  | 
 |  | +          <el-button
 | 
											
												
													
														|  | 
 |  | +            type="warning"
 | 
											
												
													
														|  | 
 |  | +            plain
 | 
											
												
													
														|  | 
 |  | +            icon="el-icon-download"
 | 
											
												
													
														|  | 
 |  | +            size="mini"
 | 
											
												
													
														|  | 
 |  | +            :loading="exportLoading"
 | 
											
												
													
														|  | 
 |  | +            @click="handleExport"
 | 
											
												
													
														|  | 
 |  | +            style="margin-left: 10px"
 | 
											
												
													
														|  | 
 |  | +            v-hasPermi="['live:liveRewardRecord:export']"
 | 
											
												
													
														|  | 
 |  | +          >导出</el-button>
 | 
											
												
													
														|  | 
 |  | +        </el-form-item>
 | 
											
												
													
														|  | 
 |  | +      </el-form>
 | 
											
												
													
														|  | 
 |  | +      <!-- 时间步长选择 -->
 | 
											
												
													
														|  | 
 |  | +      <span class="demonstration">月份选择(可多选)</span>
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    </div>
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    <!-- 直播间数据表格 + 总消耗 -->
 | 
											
												
													
														|  | 
 |  | +    <div style="margin-top: 24px;">
 | 
											
												
													
														|  | 
 |  | +      <h3 style="font-size: 16px; font-weight: 600; margin-bottom: 12px;">直播间积分消耗明细</h3>
 | 
											
												
													
														|  | 
 |  | +      <el-table
 | 
											
												
													
														|  | 
 |  | +        :data="tableData"
 | 
											
												
													
														|  | 
 |  | +        border
 | 
											
												
													
														|  | 
 |  | +        show-summary
 | 
											
												
													
														|  | 
 |  | +        stripe
 | 
											
												
													
														|  | 
 |  | +        style="width: 100%; margin-bottom: 12px;"
 | 
											
												
													
														|  | 
 |  | +      >
 | 
											
												
													
														|  | 
 |  | +        <el-table-column label="直播名称" prop="liveNameAndId" width="100" align="center" />
 | 
											
												
													
														|  | 
 |  | +        <el-table-column
 | 
											
												
													
														|  | 
 |  | +          v-for="(date, index) in timeSeries"
 | 
											
												
													
														|  | 
 |  | +          :key="index"
 | 
											
												
													
														|  | 
 |  | +          :label="date"
 | 
											
												
													
														|  | 
 |  | +          align="center"
 | 
											
												
													
														|  | 
 |  | +        >
 | 
											
												
													
														|  | 
 |  | +          <template #default="scope">
 | 
											
												
													
														|  | 
 |  | +            {{ scope.row.dailyData[index] || '-' }}
 | 
											
												
													
														|  | 
 |  | +          </template>
 | 
											
												
													
														|  | 
 |  | +        </el-table-column>
 | 
											
												
													
														|  | 
 |  | +        <el-table-column label="单直播间总计" prop="total" width="120" align="center" />
 | 
											
												
													
														|  | 
 |  | +      </el-table>
 | 
											
												
													
														|  | 
 |  | +    </div>
 | 
											
												
													
														|  | 
 |  | +  </div>
 | 
											
												
													
														|  | 
 |  | +</template>
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +<script>
 | 
											
												
													
														|  | 
 |  | +import { statistics,exportLiveIntegral } from '@/api/live/liveRewardRecord'
 | 
											
												
													
														|  | 
 |  | +import Treeselect from "@riophae/vue-treeselect";
 | 
											
												
													
														|  | 
 |  | +import {getCompanyList} from "@/api/company/company";
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +export default {
 | 
											
												
													
														|  | 
 |  | +  name: 'liveRewardRecord',
 | 
											
												
													
														|  | 
 |  | +  components: {Treeselect},
 | 
											
												
													
														|  | 
 |  | +  data() {
 | 
											
												
													
														|  | 
 |  | +    return {
 | 
											
												
													
														|  | 
 |  | +      exportLoading: false,
 | 
											
												
													
														|  | 
 |  | +      selectedTimeStep: new Date(),
 | 
											
												
													
														|  | 
 |  | +      showSearch:true,
 | 
											
												
													
														|  | 
 |  | +      companys:[],
 | 
											
												
													
														|  | 
 |  | +      tableData: [],
 | 
											
												
													
														|  | 
 |  | +      chartSeries: [],
 | 
											
												
													
														|  | 
 |  | +      timeSeries: [],
 | 
											
												
													
														|  | 
 |  | +      queryParams:{
 | 
											
												
													
														|  | 
 |  | +        companyId:0,
 | 
											
												
													
														|  | 
 |  | +        step: []
 | 
											
												
													
														|  | 
 |  | +      },
 | 
											
												
													
														|  | 
 |  | +      colorList: [
 | 
											
												
													
														|  | 
 |  | +        '#34a853', '#fbbc05', '#4285f4', '#ea4335', '#9c27b0',
 | 
											
												
													
														|  | 
 |  | +        '#ff9800', '#673ab7', '#e91e63', '#00bcd4', '#8bc34a'
 | 
											
												
													
														|  | 
 |  | +      ]
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +  },
 | 
											
												
													
														|  | 
 |  | +  created() {
 | 
											
												
													
														|  | 
 |  | +    getCompanyList().then(response => {
 | 
											
												
													
														|  | 
 |  | +      this.companys = response.data;
 | 
											
												
													
														|  | 
 |  | +      this.companys.push({companyId:0,companyName:"全部公司"})
 | 
											
												
													
														|  | 
 |  | +      console.log(this.companys)
 | 
											
												
													
														|  | 
 |  | +      this.companyId=this.companys[0].companyId;
 | 
											
												
													
														|  | 
 |  | +      this.queryParams.companyId=this.companyId;
 | 
											
												
													
														|  | 
 |  | +      this.initData()
 | 
											
												
													
														|  | 
 |  | +    });
 | 
											
												
													
														|  | 
 |  | +  },
 | 
											
												
													
														|  | 
 |  | +  methods: {
 | 
											
												
													
														|  | 
 |  | +    handleExport(){
 | 
											
												
													
														|  | 
 |  | +      if(this.selectedTimeStep == null || this.selectedTimeStep.length < 1) {
 | 
											
												
													
														|  | 
 |  | +        this.$message.error('请选择导出月份')
 | 
											
												
													
														|  | 
 |  | +        return
 | 
											
												
													
														|  | 
 |  | +      }
 | 
											
												
													
														|  | 
 |  | +      this.queryParams.step=[]
 | 
											
												
													
														|  | 
 |  | +      this.queryParams.step.push(this.selectedTimeStep);
 | 
											
												
													
														|  | 
 |  | +      this.$confirm('是否确认导出所有直播积分记录?', "警告", {
 | 
											
												
													
														|  | 
 |  | +        confirmButtonText: "确定",
 | 
											
												
													
														|  | 
 |  | +        cancelButtonText: "取消",
 | 
											
												
													
														|  | 
 |  | +        type: "warning"
 | 
											
												
													
														|  | 
 |  | +      }).then(() => {
 | 
											
												
													
														|  | 
 |  | +        this.exportLoading = true;
 | 
											
												
													
														|  | 
 |  | +        return exportLiveIntegral(this.queryParams);
 | 
											
												
													
														|  | 
 |  | +      }).then(response => {
 | 
											
												
													
														|  | 
 |  | +        this.download(response.msg);
 | 
											
												
													
														|  | 
 |  | +        this.exportLoading = false;
 | 
											
												
													
														|  | 
 |  | +      }).catch(() => {});
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +    handleQuery(){
 | 
											
												
													
														|  | 
 |  | +      this.initData()
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +    resetQuery(){
 | 
											
												
													
														|  | 
 |  | +      this.resetForm("queryForm");
 | 
											
												
													
														|  | 
 |  | +      this.queryParams.companyId=this.companyId;
 | 
											
												
													
														|  | 
 |  | +      this.handleQuery();
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +    companyChange(){
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +    initData() {
 | 
											
												
													
														|  | 
 |  | +      this.queryParams.step=[]
 | 
											
												
													
														|  | 
 |  | +      this.queryParams.step.push(this.selectedTimeStep);
 | 
											
												
													
														|  | 
 |  | +      statistics(this.queryParams).then(res => {
 | 
											
												
													
														|  | 
 |  | +        this.timeSeries = res.timeSeries || []
 | 
											
												
													
														|  | 
 |  | +        this.tableData = res.data || []
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        this.processTableData()
 | 
											
												
													
														|  | 
 |  | +      }).catch(err => {
 | 
											
												
													
														|  | 
 |  | +        console.error('数据加载失败:', err)
 | 
											
												
													
														|  | 
 |  | +        this.$message.error('数据加载失败,请重试')
 | 
											
												
													
														|  | 
 |  | +      })
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +    processTableData() {
 | 
											
												
													
														|  | 
 |  | +      const liveList = this.tableData
 | 
											
												
													
														|  | 
 |  | +      this.tableData = liveList.map(liveItem => {
 | 
											
												
													
														|  | 
 |  | +        const dailyData = liveItem.dataList || []
 | 
											
												
													
														|  | 
 |  | +        const total = dailyData.reduce((sum, num) => sum + (num || 0), 0)
 | 
											
												
													
														|  | 
 |  | +        return { liveNameAndId: liveItem.liveNameAndId, dailyData, total }
 | 
											
												
													
														|  | 
 |  | +      })
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +    handleTimeStepChange() {
 | 
											
												
													
														|  | 
 |  | +      // this.initData()
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +  }
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +</script>
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +<style scoped>
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +</style>
 |