<template>
  <div class="listPage H100">
    <div class="search-container">
      <el-form :inline="true" :model="form" ref="form" onsubmit="return false;">
        <el-form-item label>
          <el-input
            placeholder="请输入展板名称或提交人"
            v-model="form.name"
            @keyup.enter.native="Search"
            clearable
          ></el-input>
        </el-form-item>
        <el-form-item>
          <el-select v-model="form.status" placeholder="请选择审核状态">
            <el-option label="待初审" value="TBC"></el-option>
            <el-option label="已驳回" value="REFUSED"></el-option>
            <el-option label="待复审" value="TBCA"></el-option>
            <el-option label="通过" value="APPROVED_FINAL"></el-option>
          </el-select>
        </el-form-item>
        <el-form-item>
          <div class="btn-group">
            <el-button type="primary" @click="Search">查询</el-button>
            <el-button @click="Reset">重置</el-button>
          </div>
        </el-form-item>
      </el-form>
      <div class="page-tip">
        <span class="page-tip-title">页面说明:</span>
        <span class="page-tips">可查看展板待审核的所有内容,可根据审核类别进行筛选</span>
      </div>
    </div>
    <div class="table-content">
      <div class="party-table noAdd">
        <el-table
          border
          style="width: 100%; height: 100%"
          height="100%"
          ref="multipleTable"
          :data="tableData"
          @selection-change="handleSelectionChange"
        >
          <el-table-column type="index" width="120" label="序号">
            <template slot-scope="scope">
              <span>{{ (page.currentPage - 1) * 10 + scope.$index + 1 }}</span>
            </template>
          </el-table-column>
          <el-table-column label="展板名称" prop="content"></el-table-column>
          <el-table-column label="提交人" prop="userName"></el-table-column>
          <el-table-column label="提交日期" prop="createTime"></el-table-column>
          <el-table-column label="审核项" prop="operation">
            <template slot-scope="scope">
              <span class="input-item">{{keyMap[scope.row.operation]}}</span>
            </template>
          </el-table-column>
          <el-table-column label="审核状态" prop="status">
            <template slot-scope="scope">
              <span v-if="scope.row.status === 'TBC'">待初审</span>
              <span v-else-if="scope.row.status === 'REFUSED'">已驳回</span>
              <span v-else-if="scope.row.status === 'TBCA'">待复审</span>
              <span v-else-if="scope.row.status === 'APPROVED_FINAL'">通过</span>
            </template>
          </el-table-column>
          <el-table-column label="操作" header-align="center" align="center">
            <template slot-scope="scope" width="220">
              <div class="table-btn-group">
                <el-tooltip content="详情" placement="top">
                  <el-button
                    :disabled="
                scope.row.operation === 'REMOVE' &&
                scope.row.status === 'APPROVED_FINAL'
              "
                    circle
                    @click="openDetails(scope.row)"
                  >
                    <i class="icon-table icon-detail"></i>
                  </el-button>
                </el-tooltip>
              </div>
            </template>
          </el-table-column>
          <el-table-column label="审核" width="220" header-align="center" align="center">
            
            <template slot-scope="scope">
               <!-- 管理员、初审员、复审员 -->
              <div v-if="((scope.row.one)&&(scope.row.two))" class="table-btn-group">
                <el-button round class="passed" :disabled="scope.row.status === 'REFUSED' ||scope.row.status === 'APPROVED_FINAL'" @click="adopt(scope.row)">通过</el-button>
                <el-button round class="rejected" :disabled="scope.row.status === 'REFUSED' ||scope.row.status === 'APPROVED_FINAL'" @click="reject(scope.row)">驳回</el-button>
              </div>
              <div v-else-if="((scope.row.one === true)&&(scope.row.two === false))" class="table-btn-group">
                 <el-button round class="passed" :disabled="scope.row.status === 'TBCA'||scope.row.status === 'REFUSED' ||scope.row.status === 'APPROVED_FINAL'" @click="adopt(scope.row)">通过</el-button>
                <el-button round class="rejected" :disabled="scope.row.status === 'TBCA'||scope.row.status === 'REFUSED' ||scope.row.status === 'APPROVED_FINAL'" @click="reject(scope.row)">驳回</el-button>
              </div>
               <div v-else-if="((scope.row.one === false)&&(scope.row.two === true))" class="table-btn-group">
                 <el-button round class="passed" :disabled="scope.row.status === 'TBC'||scope.row.status === 'REFUSED' ||scope.row.status === 'APPROVED_FINAL'" @click="adopt(scope.row)">通过</el-button>
                <el-button round class="rejected" :disabled="scope.row.status === 'TBC'||scope.row.status === 'REFUSED' ||scope.row.status === 'APPROVED_FINAL'" @click="reject(scope.row)">驳回</el-button>
              </div>
            </template>
          </el-table-column>
        </el-table>
      </div>
      <div class="partyt-pagination">
        <el-pagination
          @current-change="handleCurrentChange"
          :current-page="page.currentPage"
          :page-size="page.pageSize"
          layout="prev, pager, next, jumper"
          :total="page.total"
        ></el-pagination>
      </div>
    </div>
    <!--新增弹框-->
    <el-dialog
      title="新建"
      custom-class="party-dialog"
      width="468px"
      :visible.sync="FormVisible1"
      :before-close="close1"
    >
      <div class="dialog-content">
        <el-form
          :model="classForm"
          ref="classForm"
          label-width="80px"
          label-position="top"
          :rules="rules"
          id="ruleo"
          class="party-form"
        >
          <el-form-item label="驳回原因:">
            <el-input type="textarea" v-model="classForm.remarks"></el-input>
          </el-form-item>
        </el-form>
      </div>
      <div slot="footer" class="dialog-footer btn-group">
        <el-button size="mini" type="primary" @click="permisSave">确定</el-button>
        <!-- <el-button size="mini" v-show="!type" type="primary" @click="permisEdit">确定</el-button> -->
        <el-button size="mini" @click="close1">取 消</el-button>
      </div>
    </el-dialog>
    <!--请填写驳回原因-->
    <el-dialog
      custom-class="party-dialog"
      title="展板详情"
      width="468px"
      :visible.sync="FormVisible"
      :before-close="close"
    >
      <div class="dialog-content">
        <el-form
          :model="editForm"
          disabled
          class="party-form demo-form-inline"
          ref="editForm"
          label-width="80px"
          label-position="top"
          :rules="rules"
        >
          <el-form-item label="展板名称" :label-width="formLabelWidth">
            <el-input size="small" v-model="editForm.name" auto-complete="off"></el-input>
          </el-form-item>
          <el-form-item label="版权方" :label-width="formLabelWidth">
            <el-input
              size="small"
              v-model="editForm.boardCopyrightOwnerName"
              auto-complete="off"
              clearable
              onkeyup="this.value=this.value.replace(/^ +| +$/g,'')"
            ></el-input>
          </el-form-item>
          <el-form-item label="宣传图" :label-width="formLabelWidth">
            <img v-if="editForm.cover !== ''" class="imgSize" :src="editForm.cover" alt />
            <div v-else>暂无数据</div>
          </el-form-item>
          <el-form-item label="二维码" :label-width="formLabelWidth">
            <img v-if="editForm.qrcodeUrl !== ''" class="imgSize" :src="editForm.qrcodeUrl" alt />
            <div v-else>暂无数据</div>
          </el-form-item>
          <el-form-item label="简介" :label-width="formLabelWidth">
            <el-input type="textarea" v-model="editForm.remarks"></el-input>
          </el-form-item>
          <el-form-item label="展板视频" :label-width="formLabelWidth">
            <div class="video-box" @contextmenu.prevent>
              <template v-if="this.editForm.videoList && this.editForm.videoList.length >0">
                <div class="video-item" v-for="(item, index) in editForm.videoList" :key="index">
                  <video  :poster="item.thumbnail" :src="item.fileUrl" controls  controlsList='nodownload noremote footbar' />
                  <span>{{ item.fileName }}</span>
                </div>
              </template>
              <template v-else>
                <div>暂无数据</div>
              </template>
            </div>
          </el-form-item>
          <el-form-item label="展板音频" :label-width="formLabelWidth">
            <div class="audio-box">
              <template v-if="this.editForm.audioList && this.editForm.audioList.length >0">
              <div class="audio-item" v-for="(item, index) in editForm.audioList" :key="index">
                <audio v-if="item.fileExtName ==='mp3'" :src="item.fileUrl" controls controlsList='nodownload' oncontextmenu="return false"/>
                <span v-if="item.fileExtName ==='mp3'">{{ item.fileName }}</span>
              </div>
              </template>
              <template v-else>
                <div>暂无数据</div>
              </template>
            </div>
          </el-form-item>
           <el-form-item label="参考资料" :label-width="formLabelWidth">
            <div class="audio-box">
              <template v-if="this.editForm.datumList && this.editForm.datumList.length >0">
              <div class="audio-item ckzl" v-for="(item, index) in editForm.datumList" :key="index">
                <div>
                <iframe class="imgSize" v-if="item.fileExtName === 'pdf'" :src="item.fileUrl" controls controlsList='nodownload' oncontextmenu="return false"/>
                <img :src="item.fileUrl" v-else-if="item.fileExtName === 'jpg' || item.fileExtName === 'png'" class="imgSize"/>
                <img v-else-if="item.fileExtName === 'docx'" src=""/>
                <video :src="item.fileUrl" v-else="item.fileExtName === 'mp4'" class="imgSize" controls />
                </div>
                <div>
                <a v-if="item.fileExtName === 'docx'" :href="item.fileUrl">{{item.fileName}}</a>
                <span v-else>{{ item.fileName }}</span>
                </div>
              </div>
              </template>
              <template v-else>
                <div>暂无数据</div>
              </template>
            </div>
          </el-form-item>
        </el-form>
      </div>
      <div slot="footer" class="dialog-footer btn-group">
        <el-button size="mini" type="primary" @click="close">关闭</el-button>
      </div>
    </el-dialog>
  </div>
</template>
<script>
 let Base64 = require('js-base64').Base64

export default {
  data() {
    var checkIsNull = (rule, value, callback) => {
      if (value) {
        if (value.trim() == "") {
          callback(new Error("不允许只输入空格"));
        } else {
          callback();
        }
      }
    };
    const keyMap = {
      ADD: "新增",
      EDIT: "修改",
      REMOVE: "删除",
      DISABLE: "禁用",
      ENABLE: "启用",
      UPPER: "上架",
      LOWER: "下架"
    };

    return {
      keyMap: keyMap,
      type: true,
      value1: "",
      page: { currentPage: 1, pageSize: 10, total: 0 },
      tableData: [],
      FormVisible: false,
      FormVisible1: false,
      formLabelWidth: "100px",
      form: {
        name: "",
        type: "EXHIBITION_BOARD"
      },
      editForm: {
        name: "",
        cover: "",
        sort: ""
      },
      classForm: {
        status: "",
        remarks: "",
        id: ""
      },
      typeList: [],
      rules: {
        sort: [
          { required: true, message: "请输入顺序值", trigger: "change" },
          { pattern: /^(\d{1,5})?$/, message: "排序值为低于5位数的纯数字" }
        ],
        menuName: [
          { required: true, message: "请输入菜单名称", trigger: "change" },
          { max: 20, message: "不能超过20个字符", trigger: "change" },
          { validator: checkIsNull, trigger: "blur" }
        ],
        menuUrl: [
          { required: true, message: "请输入菜单地址", trigger: "change" },
          { validator: checkIsNull, trigger: "blur" }
        ],
        parentId: [
          { required: true, message: "请输入父级菜单", trigger: "change" }
        ]
      },
      value: "",
      name: ""
    };
  },
  computed: {},
  mounted() {
    this.onSearch();
    // this.getPermis();
  },
  components: {},
  methods: {
    // 渲染父级权限
    getPermis() {
      let vm = this;
      vm.$https({
        method: "get",
        url: "menu/getRoleMenu?roleId=" + sessionStorage.getItem("roleId"),
        authType: this.backToken
      }).then(
        res => {
          let data = res.data;
          vm.typeList = data.map((e, i) => {
            return {
              id: e.id,
              name:
                e.menuName.indexOf("-") == -1
                  ? e.menuName
                  : e.menuName.split("-")[1]
            };
          });
        },
        error => {
          console.log(error);
        }
      );
    },
    // 获得数据接口
    getTableData(param) {
      let vm = this;
      vm.$https(
        {
          url: "audit/getPageAllList",
          method: "get",
          authType: this.backToken
        },
        // vm.$qs.stringify(param)
        param
      )
        .then(res => {
          let data = res.data.data;
          vm.page.pageSize = data.size;
          vm.page.total = data.total;
          vm.tableData = data.records;
        })
        .catch(function(err) {
          console.log(err);
        });
    },
    // 分页
    handleCurrentChange(val) {
      let _this = this;
      _this.page.currentPage = val;
      _this.onSearch();
    },
    onSearch() {
      let _this = this;
      let param = _this.getSearchQuery();
      _this.getTableData(param);
    },
    Search() {
      let _this = this;
      _this.page.currentPage = 1;
      let searchObj = {
        _index: 1,
        _size: _this.page.pageSize,
        name: _this.form.name,
        status: _this.form.status,
        type: "EXHIBITION_BOARD"
      };
      this.getTableData(searchObj);
    },
    // 重置
    Reset() {
      // this.$refs["form"].resetFields();
      this.form = { type: "EXHIBITION_BOARD" };
      this.Search();
    },
    // // 获取当前查询参数
    getSearchQuery() {
      let _this = this;
      let searchObj = {
        _index: _this.page.currentPage,
        _size: _this.page.pageSize
      };
      for (let key in _this.form) {
        if (_this.form[key]) {
          searchObj[key] = _this.form[key];
        }
      }
      return searchObj;
    },
    // 添加
    addPermis() {
      // this.$router.push({ path: "videoContentAdd", query: { type: "add" } });
      $(".el-dialog__title").html("新建");
      this.FormVisible1 = true;
      this.type = true;
    },

    // 请填写驳回原因视频分类确认保存
    permisEdit() {
      let _this = this;
      _this.$refs.classForm.validate(valid => {
        if (valid) {
          _this
            .$https(
              {
                url: "videoContentCat/update",
                method: "put",
                authType: this.backToken
              },
              _this.$qs.stringify(_this.classForm)
              // _this.classForm
            )
            .then(
              res => {
                if (res.data.resultCode == 200 || res.data.resultCode == 201) {
                  _this.$message({
                    type: "success",
                    message: "新建成功!"
                  });
                  //跳回用户列表
                  _this.onSearch();
                  _this.FormVisible1 = false;
                  for (let key in _this.classForm) {
                    _this.classForm[key] = null;
                  }
                  _this.$refs["classForm"].resetFields();
                } else {
                  _this.$message({
                    type: "error",
                    message: res.data.msg
                  });
                }
              },
              error => {
                _this.$message({
                  type: "error",
                  message: error
                });
              }
            );
        }
      });
    },
    // 请填写驳回原因关闭
    close() {
      this.editForm = {};
      this.FormVisible = false;
      // for (let key in this.classForm) {
      //   this.classForm[key] = null;
      // }
      // this.$refs["classForm"].resetFields();
      // this.FormVisible = false;
      // this.$refs["editForm"].resetFields();
    },
    // 新增关闭
    close1() {
      this.FormVisible1 = false;
      for (let key in this.classForm) {
        this.classForm[key] = null;
      }
      this.$refs["classForm"].resetFields();
    },
    // 通过
    adopt(row) {
      this.classForm.id = row.id;
      this.classForm.status = "APPROVED_FINAL";
      this.classForm.remarks = "";
      this.permisSave("classForm");
    },
    // 请填写驳回原因弹框
    reject(row) {
      this.type = false;
      $(".el-dialog__title").html("请填写驳回原因");
      let _this = this;
      _this.classForm.id = row.id;
      _this.classForm.status = "REFUSED";
      _this.FormVisible1 = true;
    },
    // 驳回原因保存
    permisSave() {
      let _this = this;
      _this
        .$https(
          {
            url: "audit/updateAuditAllById",
            headers: { "Content-Type": "application/json" },
            method: "put",
            authType: this.backToken
          },
          // _this.$qs.stringify(_this.classForm)
          _this.classForm
        )
        .then(
          res => {
            if (res.data.resultCode == 200 || res.data.resultCode == 201) {
              _this.$message({
                type: "success",
                message: "操作成功!"
              });
              //跳回用户列表
              _this.onSearch();
              _this.FormVisible1 = false;
              for (let key in _this.classForm) {
                _this.classForm[key] = null;
              }
              _this.$refs["classForm"].resetFields();
            } else {
              _this.$message({
                type: "error",
                message: res.data.msg
              });
            }
          },
          error => {
            _this.$message({
              type: "error",
              message: error
            });
          }
        );
      // _this.$refs.classForm.validate(valid => {
      //   if (valid) {

      //   }
      // });
    },
    // 获取视频分类详情
    getAssetTypeInfo(id) {
      let vm = this;
      vm.$https(
        {
          url: "videoContentCat/get/" + id,
          method: "get",
          authType: this.backToken
        }
        // param
      )
        .then(res => {
          let data = res.data.data;
          this.classForm = data;
        })
        .catch(function(err) {
          console.log(err);
        });
    },
    openDetails(row) {
      let _this = this;
      _this.FormVisible = true;
       if(row.operation === 'EDIT'){
         // 参照后台更改文档审核记录的"operation"为"EDIT"时,调用的详情接口
        this.getInfo(row.id,"exhibitionBoard/getAudit/")
      }else{
        this.getInfo(row.refItemId,"exhibitionBoard/get/");
      }
       $(".el-dialog__title").html(row.name + "展板详情");
    },
    
    //  获取版权方详情
    getInfo(id,url) {
      let vm = this;
      vm.$https(
        {
          url: url + id,
          method: "get",
          authType: this.backToken
        }
        // param
      )
        .then(res => {
          let resData = res.data.data;
          const videos = res.data.data.videoList
          for(var i=0;i<videos.length;i++){
            videos[i].fileUrl = Base64.decode(videos[i].intro)
          }
          this.editForm = resData;
          this.editForm.videoList = videos
          console.log(this.editForm.videoList)
          
          
          
         
        })
        .catch(function(err) {
          console.log(err);
        });
    },
    // 删除
    handleDelete(row) {
      let _this = this;
      this.$confirm("此操作将永久删除, 是否继续?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      })
        .then(() => {
          _this
            .$https({
              method: "delete",
              url: "videoContentCat/delete/" + row.id,
              authType: this.backToken
            })
            .then(
              res => {
                this.$message({ type: "success", message: "删除成功!" });
                _this.Search();
              },
              error => {
                this.$message({
                  type: "fail",
                  message: "删除失败!" + error.response.data
                });
              }
            );
        })
        .catch(() => {});
    },
    // // 保存请填写驳回原因信息
    // submitForm() {
    //   let _this = this;
    //   _this.$refs.editForm.validate(valid => {
    //     if (valid) {
    //       let searchObj = {};
    //       for (let key in _this.editForm) {
    //         if (this.editForm[key]) {
    //           searchObj[key] = _this.editForm[key];
    //         }
    //       }
    //       let str = _this.editForm.menuName;
    //       let index = str.lastIndexOf("-");
    //       str = str.substring(index + 1, str.length);
    //       searchObj.menuName = str;
    //       _this
    //         .$https(
    //           {
    //             url: "menu/edit",
    //             method: "put",
    //             authType: this.backToken
    //           },
    //           _this.$qs.stringify(searchObj)
    //         )
    //         .then(
    //           res => {
    //             if (res.data.status == 200 || res.data.status == 201) {
    //               _this.$message({
    //                 type: "success",
    //                 message: res.data.message
    //               });
    //               _this.onSearch();
    //               _this.FormVisible = false;
    //               _this.$refs["editForm"].resetFields();
    //             } else {
    //               _this.$message({
    //                 type: "error",
    //                 message: res.data.message
    //               });
    //             }
    //           },
    //           error => {
    //             _this.$message({
    //               type: "error",
    //               message: error
    //             });
    //           }
    //         );
    //     }
    //   });
    // },

    // 批量操作
    handleSelectionChange(selection) {
      let _this = this;
      _this.selection = selection;
    },
    getMultipleSelect() {
      let _this = this;
      let arr = [];
      let str = "";
      if (_this.selection) {
        _this.selection.forEach(function(e) {
          arr.push(e.id);
        });
        str = arr.join(",");
      } else {
        str = "";
      }
      return str;
    },
    // 批量删除
    multipleDelete() {
      let _this = this;
      let str = _this.getMultipleSelect();
      if (str) {
        this.$confirm("此操作将删除选中菜单, 是否继续?", "提示", {
          confirmButtonText: "确定",
          cancelButtonText: "取消",
          type: "warning"
        }).then(() => {
          _this
            .$https({
              url: "menu/batchDel?menuIds=" + str,
              method: "DELETE",
              authType: this.backToken
            })
            .then(
              res => {
                if (res.data.status == 201 || res.data.status == 200) {
                  this.$message({
                    type: "success",
                    message: "删除成功!"
                  });
                }
                //重新查询数据
                _this.onSearch();
              },
              error => {}
            );
        });
      } else {
        this.$message({
          type: "info",
          message: "请至少选择一个选项!"
        });
      }
    }
  }
};
</script>

<style lang="less">
.ckzl {
  display: flex;
  flex-direction: column;
}
.imgSize {
  width: 160px;
  height: 100px;
}
.iconImg {
  height: 32px;
  width: 32px;
  margin-right: 8px;
}
// @import "../../../../style/common";
// @import "../../style/list";
@import "../../../style/dialog.less";
@import "../../../style/table.less";
@import "../../../style/pagination.less";
.video-box {
  width: 100%;
  .video-item {
    width: 100%;
  }
  video {
    width: 100%;
    height: 200px;
  }
}
audio:focus {
  outline: none;
}
</style>