caseoffline.js 9.42 KB
import { listCaseOffline, getCaseOffline, delCaseOffline, addCaseOffline, updateCaseOffline, exportCaseOffline } from "@/api/caseOffline/caseOffline";


import h5Info from "@/views/h5/caseOffline/caseOfflineInfo";

import h5Page from '@/views/h5/Pagination';



  import caseOfflineInfo from "@/views/caseOffline/caseOffline/caseOfflineInfo";
  import {
    getArea,
    earthsitesList,
    constructionsitesList,
    getDict,
  } from "@/api/dict";
  import {
    getThreestep,
  } from "@/api/business/threestep";

  import {
    getToken
  } from "@/utils/auth";
export default {
  name: "CaseOffline",

  components: {
    caseOfflineInfo,
    h5Info,
    h5Page
  },
  data() {
    return {
      // 遮罩层
      loading: true,
      // 选中数组
      ids: [],
      // 非单个禁用
      single: true,
      // 非多个禁用
      multiple: true,
      // 显示搜索条件
      showSearch: true,
      // 总条数
      total: 0,
      // 线下交办案卷表格数据
      caseOfflineList: [],
      // 弹出层标题
      title: "",
      // 是否显示弹出层
      open: false,
      open2:false,
      // 查询参数
      queryParams: {
        pageNum: 1,
        pageSize: 10,
        type: null,
        place: null,
        createTime: null,
        isAsc:"DESC",
        orderByColumn:"createTime"
      },
      uploadImageDialog:false,
      // 表单参数
      form: {},
      // 表单校验
      rules: {
      },
      caseType:[
        {code:0,name:"渣土处置工地(含消纳场)的渣土运输车辆出场车身不洁,车轮带泥"},
        {code:1,name:"未洗车出场或者出场清洁不彻底"},
        {code:2,name:"渣土运输车辆货箱顶盖未按规定关闭到位或未按规定和标准装载渣土出场"},
        {code:3,name:"非核准车辆进入渣土处置工地运输渣土"},
        {code:4,name:"渣土处置工地未按规定时间开停工"},
        {code:5,name:"渣土处置工地洗车设施等破损、未正常使用及措施不到位的"},
        {code:6,name:"渣土处置工地、消纳场(含回填场)出入口两侧50米范围内出现渣土污染、污水外排等现象"},
        {code:7,name:"其他1"},
        {code:8,name:"其他2"},
        {code:9,name:"其他3"}
      ],
      areas:null,
      fileList:[],
      areas: [],
      upload: {
        // 是否显示弹出层(用户导入)
        open: false,
        // 弹出层标题(用户导入)
        title: "",
        // 是否禁用上传
        isUploading: false,
        // 设置上传的请求头部
        headers: {
          Authorization: "Bearer " + getToken()
        },
        // 上传的地址
        url: process.env.VUE_APP_BASE_API + "/business/threestep/upload",
      },
      data:{},
      objId:null
    };
  },
  created() {



    this.getList();

      if(window.location.search){
        let businessKey = window.location.search.split("=")[1];
        if(window.location.search.split("=")[0] == "?businessKey"){
          let id;
          if(businessKey.split(":").length == 2){
              id = businessKey.split(":")[1];
            }else{
              id = businessKey;
            }

            getThreestep(id).then(response => {
              let data = response.data;

              this.handleAdd();

              this.form.siteType = data.type + "";
              this.form.siteName = data.name;
              this.form.place = Number(data.place);
            });
        }

      }



    let remoteQueryData = {
      "page": 1,
      "size": 9999
    }

    constructionsitesList(remoteQueryData).then(res => {
       this.data[0]= res.result.list;
    });

    earthsitesList(remoteQueryData).then(res => {
        this.data[1]= res.result.list;
    });
  },
  methods: {
    getSite(item){
      this.form.objectId = item.id;
    },
    /** 查询线下交办案卷列表 */
    getList() {
      this.loading = true;
      listCaseOffline(this.queryParams).then(response => {
        this.caseOfflineList = response.rows;

        for(let i in this.caseOfflineList){
          this.caseOfflineList[i].type = this.getCaseType(Number(this.caseOfflineList[i].type));

        }

        getArea().then(res => {
            this.areas = res.result;
            for(let i =0;i< this.caseOfflineList.length;i++){
              this.caseOfflineList[i].place = this.getAreaName(this.caseOfflineList[i].place);
            }
          });

        this.total = response.total;
        this.loading = false;
      });
    },
    // 取消按钮
    cancel() {
      this.open = false;
      this.open2 = false;
      this.reset();
    },
    // 表单重置
    reset() {
      this.form = {
        id: null,
        type: null,
        siteName: null,
        locationDec: null,
        caseDec: null,
        status: 0,
        place: null,
        number: null,
        siteType: null,
        objectId: null,
        createTime: null,
        createBy: null,
        advice1: null,
        advice2: null,
        advice3: null,
        advice4: null,
          attach:[]
      };
      this.resetForm("form");
    },
    /** 搜索按钮操作 */
    handleQuery() {
      this.queryParams.pageNum = 1;
      this.getList();
    },
    /** 重置按钮操作 */
    resetQuery() {
      this.resetForm("queryForm");
      this.handleQuery();
    },
    // 多选框选中数据
    handleSelectionChange(selection) {
      this.ids = selection.map(item => item.id)
      this.single = selection.length!==1
      this.multiple = !selection.length
    },
   getAreaName(code){
     for(let i =0;i<this.areas.length;i++){
       if(Number(code) == this.areas[i].code){
         return this.areas[i].name;
         break;
       }
     }
     return code;
   },
    getCaseType(type){
      for(let i in this.caseType){


        if(this.caseType[i].code==type)
          return this.caseType[i].name
      }
    },
    /** 新增按钮操作 */
    handleAdd() {
      this.reset();
      this.open = true;
      this.title = "添加线下交办案卷";

      let date = new Date();


      this.form.number = date.getFullYear()
                          +""+((date.getMonth()+1) < 10 ? "0" + (date.getMonth()+1) : (date.getMonth()+1))
                          +""+ ((date.getDate()) < 10 ? "0" + (date.getDate()) : (date.getDate()))
                          +""+ ((date.getHours()) < 10 ? "0" + (date.getHours()) : (date.getHours()))
                          +""+ ((date.getMinutes()) < 10 ? "0" + (date.getMinutes()) : (date.getMinutes()))
                          +""+ ((date.getSeconds()) < 10 ? "0" + (date.getSeconds()*1000) : (date.getSeconds()*1000))
    },
    /** 修改按钮操作 */
    handleUpdate(row) {
      this.reset();
      this.businessKey =row.id + "";
      this.open2 = true;
    },
    /** 提交按钮 */
    submitForm() {
      this.$refs["form"].validate(valid => {
        if (valid) {
          this.form.attach  = this.form.attach +"";
          if (this.form.id != null) {
            updateCaseOffline(this.form).then(response => {
              this.msgSuccess("修改成功");
              this.open = false;
              this.getList();
            });
          } else {
            addCaseOffline(this.form).then(response => {
              this.msgSuccess("新增成功");
              this.open = false;
              this.getList();
            });
          }
        }
      });
    },
    /** 删除按钮操作 */
    handleDelete(row) {
      const ids = row.id || this.ids;
      this.$confirm('是否确认删除线下交办案卷编号为"' + ids + '"的数据项?', "警告", {
          confirmButtonText: "确定",
          cancelButtonText: "取消",
          type: "warning"
        }).then(function() {
          return delCaseOffline(ids);
        }).then(() => {
          this.getList();
          this.msgSuccess("删除成功");
        })
    },
    /** 导出按钮操作 */
    handleExport() {
      const queryParams = this.queryParams;
      this.$confirm('是否确认导出所有线下交办案卷数据项?', "警告", {
          confirmButtonText: "确定",
          cancelButtonText: "取消",
          type: "warning"
        }).then(function() {
          return exportCaseOffline(queryParams);
        }).then(response => {
          this.download(response.message);
        })
    },
    removeAttchItem(index, img) {
      this.form.attach.splice(this.form.attach.indexOf(img), 1);
      this.$forceUpdate();
    },
    uploadSuccess(res, file, fileList) {
		if(res.code){
			this.$message(res.message);
			return;
		}
      if(!this.form.attach){
        this.form.attach = [];
      }
      this.form.attach.push(res);
    },
    showFileUpload(i) {
      this.uploadImageDialog = true;
      this.picIndex = i;
    },
    beforeUpload(file) {
      let isRightSize = file.size / 1024 / 1024 < 20
      if (!isRightSize) {
        this.$message.error('文件大小超过 20MB')
        return isRightSize;
      }
      let isAccept = false;
      if (file.name.indexOf('.docx') > -1 || file.name.indexOf(".jpg") > -1 || file.name.indexOf('.doc') > -1 || file
        .name.indexOf('.pdf') > -1) {
        isAccept = true;
      }
      if (!isAccept) {
        this.$message.error('应该选择PDF、JPG、WORD类型的文件')
        return isAccept;
      }
    },
      downloadFile(path) {
        window.location.href = process.env.VUE_APP_BASE_API + "/business/threestep/download?path=" + encodeURI(path);
      },
      handleClose() {
        this.uploadImageDialog = false;
        this.fileList = [];
      },
  }
};