index.vue 5.23 KB
Newer Older
dragondean@qq.com's avatar
dragondean@qq.com committed
1 2
<template>
  <div class="app-container">
3 4 5 6 7 8
      <div class="mb-10 flex items-center">
          <div class="flex-1">
              <h2 class="page-title mb-5">下载队列</h2>
              <div>*{{$t('文件生成成功后,保留12小时,12小时后自动删除')}}</div>
          </div>
          <el-button class="" @click="handleQuery" type="primary">刷新</el-button>
dragondean@qq.com's avatar
dragondean@qq.com committed
9 10 11 12 13 14 15 16 17 18 19 20 21
      </div>
    <!--el-form :model="queryParams" ref="queryForm" size="small" :inline="true" label-width="68px">
      <el-form-item :label="$t('文件名称')" prop="fileName">
        <el-input v-model="queryParams.fileName" :placeholder="$t('请输入文件名称')" clearable @keyup.enter.native="handleQuery"/>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" icon="el-icon-search" @click="handleQuery">{{$t('搜索')}}</el-button>
        <el-button icon="el-icon-refresh" @click="resetQuery">{{$t('重置')}}</el-button>
      </el-form-item>
    </el-form-->

    <el-table v-loading="loading" :data="list">
      <el-table-column :label="$t('下载编号')" align="center" prop="id" width="100" />
22 23 24 25 26
      <el-table-column :label="$t('分类')" align="center" prop="type" width="100" >
          <template v-slot:default="{row}">
              <dict-tag :type="DICT_TYPE.DOWNLOAD_TYPE" :value="row.type"/>
          </template>
      </el-table-column>
dragondean@qq.com's avatar
dragondean@qq.com committed
27
      <!--<el-table-column :label="$t('业务编号')" align="center" prop="type" width="100" /-->
28 29 30 31 32 33
      <el-table-column :label="$t('下载内容')" align="center" prop="name" />
      <el-table-column :label="$t('开始下载时间')" align="center" prop="createTime"  width="150">
          <template slot-scope="scope">
              <span>{{ parseTime(scope.row.createTime) }}</span>
          </template>
      </el-table-column>
34 35 36 37 38
      <!--<el-table-column :label="$t('结果')" align="center" prop="createTime"  width="150">
        <template slot-scope="scope">
          {{scope.row.result}}
        </template>
      </el-table-column>-->
dragondean@qq.com's avatar
dragondean@qq.com committed
39 40
      <el-table-column :label="$t('下载状态')" align="center" prop="createBy"  width="150">
          <template v-slot:default="{row}">
41 42 43 44
              <!--status ==2 表示已处理,配合downNum来判断是否已下载-->
              <template v-if="row.status == 2 && row.downNum > 0">{{$t('已下载')}}</template>
              <template v-else-if="row.status == 2">{{$t('待下载')}}</template>
              <dict-tag v-else :type="DICT_TYPE.DOWNLOAD_LOG_STATUS" :value="row.status"/>
dragondean@qq.com's avatar
dragondean@qq.com committed
45 46
          </template>
      </el-table-column>
47
      <el-table-column :label="$t('操作')" align="center" class-name="small-padding fixed-width" width="100">
dragondean@qq.com's avatar
dragondean@qq.com committed
48 49
        <template slot-scope="scope" >
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleDownload(scope.row)"
50 51 52 53 54
                     v-hasPermi="['system:notice:update']" v-if="scope.row.status == 2">{{$t('下载')}}</el-button>
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleRetry(scope.row)"
                     v-hasPermi="['system:notice:update']" v-if="scope.row.status == 3">{{$t('重试')}}</el-button>
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleDel(scope.row)"
                     v-hasPermi="['system:notice:update']">{{$t('删除')}}</el-button>
dragondean@qq.com's avatar
dragondean@qq.com committed
55 56 57 58
        </template>
      </el-table-column>
    </el-table>

59
    <pagination v-show="total>0" :total="total" :page.sync="queryParams.page" :limit.sync="queryParams.rows"
dragondean@qq.com's avatar
dragondean@qq.com committed
60 61 62 63 64 65
                @pagination="getList"/>

  </div>
</template>

<script>
66
import {deleteLog, download, downloadFileResponse, downloadPage, retry} from "@/api/system/download";
dragondean@qq.com's avatar
dragondean@qq.com committed
67 68 69 70 71 72 73 74 75 76 77 78
import {parseTime} from "../../../utils/ruoyi";

export default {
  name: "Download",
  data() {
    return {
      // 遮罩层
      loading: true,
      // 总条数
      total: 0,
      list: [],
      queryParams: {
79 80
        page: 1,
        rows: 10
81
      }
dragondean@qq.com's avatar
dragondean@qq.com committed
82 83 84 85 86 87 88 89
    };
  },
  created() {
    this.getList();
  },
  methods: {
      parseTime,
      handleDownload(row){
90 91 92 93
          const loading = this.$loading()
          download(row.id).then(res => {
              return downloadFileResponse(res.data)
          }).then(res => {
dragondean@qq.com's avatar
dragondean@qq.com committed
94
              console.log({res})
95
              this.$download.download0(res.data, row.name + '.' + row.fileSuffix, res.headers['content-type'])
96
          }).finally(() => {
97 98
              // 刷新列表状态
              this.getList()
99 100
              loading.close()
          })
dragondean@qq.com's avatar
dragondean@qq.com committed
101 102 103 104 105
      },
    /** 查询公告列表 */
    getList() {
      this.loading = true;
      downloadPage(this.queryParams).then(response => {
106
        this.list = response.data.list;
dragondean@qq.com's avatar
dragondean@qq.com committed
107 108 109 110 111 112
        this.total = response.data.total;
        this.loading = false;
      }).finally(() => {
        this.loading = false;
      })
    },
113 114 115 116 117 118 119 120 121 122 123 124
    handleRetry(row){
        retry(row.id).then(res => {
            this.$message.success('重试已提交')
            this.getList()
        })
    },
    handleDel(row){
      deleteLog(row.id).then(res => {
          this.$message.success('删除成功')
          this.getList()
      })
    },
dragondean@qq.com's avatar
dragondean@qq.com committed
125 126
    /** 搜索按钮操作 */
    handleQuery() {
127
      this.queryParams.page = 1;
dragondean@qq.com's avatar
dragondean@qq.com committed
128 129 130 131 132 133 134 135 136 137
      this.getList();
    },
    /** 重置按钮操作 */
    resetQuery() {
      this.resetForm("queryForm");
      this.handleQuery();
    }
  }
};
</script>