index.vue 11 KB
<template>
  <div class="app-container">
    <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="130px">
      <el-form-item label="风控申请单号" prop="applyTransNo">
        <el-input v-model="queryParams.applyTransNo" placeholder="风控申请单号" clearable size="small"
          @keyup.enter.native="handleQuery" />
      </el-form-item>
      <el-form-item label="企业名称" prop="applyUserName">
        <el-input v-model="queryParams.applyUserName" placeholder="企业名称" clearable size="small"
          @keyup.enter.native="handleQuery" />
      </el-form-item>
      <template v-if="show">
        <el-form-item label="经办人手机号码" prop="phone">
          <el-input v-model="queryParams.phone" placeholder="经办人手机号码" clearable size="small"
            @keyup.enter.native="handleQuery" />
        </el-form-item>
        <el-form-item label="统一社会信用代码" prop="creditCode">
          <el-input v-model="queryParams.creditCode" placeholder="统一社会信用代码" clearable size="small"
            @keyup.enter.native="handleQuery" />
        </el-form-item>
        <el-form-item label="风控类型" prop="applyCreditType">
          <el-select v-model="queryParams.applyCreditType" placeholder="风控类型" clearable size="small"
            @keyup.enter.native="handleQuery">
            <el-option v-for="dict in dict.type.file_risk_type" :key="dict.value" :label="dict.label"
              :value="dict.value" />
          </el-select>
        </el-form-item>
        <el-form-item label="审核结果" prop="applyStatus">
          <el-select v-model="queryParams.applyStatus" placeholder="审核结果" clearable size="small"
            @keyup.enter.native="handleQuery">
            <el-option v-for="dict in dict.type.file_examine_type" :key="dict.value" :label="dict.label"
              :value="dict.value" />
          </el-select>
        </el-form-item>
        <el-form-item label="产品名称" prop="applyProductCode">
          <el-select v-model="queryParams.applyProductCode" placeholder="产品名称" clearable size="small">
            <el-option v-for="(item, index) in labelProduct" :key="index" :label="item.name"
              :value="item.businessCode" @keyup.enter.native="handleQuery" />
          </el-select>
        </el-form-item>
        <el-form-item label="申请时间" prop="datetimerange">
          <el-date-picker v-model="value2" type="datetimerange" value-format="yyyy-MM-dd HH:mm:ss"
            :picker-options="pickerOptions" @keyup.enter.native="handleQuery" range-separator="至"
            start-placeholder="开始日期" end-placeholder="结束日期" align="right">
          </el-date-picker>
        </el-form-item>
      </template>
      <el-form-item>
        <el-button type="primary" 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="text" @click="test()">{{ show ? '收起' : '展开' }}</el-button>
      </el-form-item>
    </el-form>

    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
          v-hasPermi="['system:post:add']">新增</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button type="success" plain icon="el-icon-edit" size="mini" :disabled="single" @click="handleUpdate"
          v-hasPermi="['system:post:edit']">修改</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button type="danger" plain icon="el-icon-delete" size="mini" :disabled="multiple" @click="handleDelete"
          v-hasPermi="['system:post:remove']">删除</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport"
          v-hasPermi="['system:post:export']">导出</el-button>
      </el-col>
      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
    </el-row>

    <el-table v-loading="loading" :data="postList" :border="true" @selection-change="handleSelectionChange">
      <el-table-column type="index" width="55" label="序号" align="center" />
      <el-table-column label="风控申请单号" align="center" prop="applyTransNo" width="300" />
      <el-table-column label="企业名称" align="center" prop="entName" width="300" />
      <el-table-column label="统一社会信用代码" align="center" prop="creditCode" width="200" />
      <el-table-column label="经办人手机号码" align="center" prop="phone" width="180" />
      <el-table-column label="产品名称" align="center" prop="applyProductCode" width="200">
        <template slot-scope="scope">
          <span>{{ ProductCode(scope.row.applyProductCode) }}</span>
        </template>
      </el-table-column>
      <el-table-column label="风控类型" align="center" prop="applyCreditType" width="120">
        <template slot-scope="scope">
          <span>{{ queryDict(scope.row.applyCreditType,dict.type.file_risk_type) }}</span>
        </template>
      </el-table-column>
      <el-table-column label="审核结果" align="center" prop="applyStatus" width="120">
        <template slot-scope="scope">
          <span>{{ queryDict(scope.row.applyStatus,dict.type.file_examine_type) }}</span>
        </template>
      </el-table-column>
      <el-table-column label="拒绝原因" align="center" prop="refuse" width="300" />
      <el-table-column label="申请时间" align="center" prop="applyTime" width="180">
        <template slot-scope="scope">
          <span>{{ parseTime(scope.row.applyTime) }}</span>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" width="120" fixed="right" class-name="small-padding fixed-width">
        <template slot-scope="scope">
          <el-button size="mini" type="text" icon="el-icon-search" @click="handleUpdate(scope.row)"
            v-hasPermi="['system:post:edit']">查看</el-button>
          <!-- <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
                        v-hasPermi="['system:post:remove']">删除</el-button> -->
        </template>
      </el-table-column>
    </el-table>

    <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
      @pagination="getList" />
    <addMobile ref="mobile" @getList="getList"></addMobile>
    <seeMobile ref="seMobile" @getList="getList"></seeMobile>
  </div>
</template>

<script>
import { listPost, applyInfoGetOne, delPost,selectAll } from "@/api/postList/list";
import addMobile from "./mobile/add.vue";
import seeMobile from "./mobile/see2.vue";
export default {
  name: "Post",
  dicts: ['file_risk_type', 'file_examine_type', 'strategy_fund_code'],
  components: {
    addMobile,
    seeMobile
  },
  data() {
    return {
      // 遮罩层
      loading: true,
      product: [],
      labelProduct:[],
      // 选中数组
      ids: [],
      // 非单个禁用
      single: true,
      // 非多个禁用
      multiple: true,
      // 显示搜索条件
      showSearch: true,
      // 总条数
      total: 0,
      // 岗位表格数据
      postList: [],
      // 查询参数
      queryParams: {
        pageNum: 1,
        pageSize: 10,
        applyUserType: 'ENTERPRISE',
        applyTransNo: undefined,
        applyUserName: undefined,
        phone: undefined,
        creditCode: undefined,
        applyCreditType: undefined,
        applyProductCode: undefined,
        beginTime: undefined,
        endTime: undefined
      },
      show: false,
      pickerOptions: {
        shortcuts: [{
          text: '最近一周',
          onClick(picker) {
            const end = new Date();
            const start = new Date();
            start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
            picker.$emit('pick', [start, end]);
          }
        }, {
          text: '最近一个月',
          onClick(picker) {
            const end = new Date();
            const start = new Date();
            start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
            picker.$emit('pick', [start, end]);
          }
        }, {
          text: '最近三个月',
          onClick(picker) {
            const end = new Date();
            const start = new Date();
            start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
            picker.$emit('pick', [start, end]);
          }
        }]
      },
      value2: ''
    };
  },
  created() {
    this.getList();
  },
  methods: {
    /** 查询岗位列表 */
    getList() {
      this.loading = true;
      listPost(this.queryParams).then(response => {
        this.postList = response.rows;
        this.total = response.total;
        this.loading = false;
      });
      var lis = {
        pageNum: 1,
        pageSize: 10000,
      }
      selectAll(lis).then(response => {
        this.product = response.data;
        this.labelProduct = response.data;
      });
    },
    // 表单重置
    reset() {
      this.form = {
        pageNum: 1,
        pageSize: 10,
        applyTransNo: undefined,
        applyUserName: undefined,
        phone: undefined,
        creditCode: undefined,
        applyCreditType: undefined,
        applyProductCode: undefined,
      };
      this.value2 = []
      this.resetForm("form");
    },
    /** 搜索按钮操作 */
    handleQuery() {
      this.queryParams.pageNum = 1;
      this.queryParams.beginTime = this.value2[0]
      this.queryParams.endTime = this.value2[1]
      this.getList();
    },
    /** 重置按钮操作 */
    resetQuery() {
      this.value2 = ''
      this.resetForm("queryForm");
      this.handleQuery();
    },
    // 多选框选中数据
    handleSelectionChange(selection) {
      this.ids = selection.map(item => item.postId)
      this.single = selection.length != 1
      this.multiple = !selection.length
    },
    /** 新增按钮操作 */
    handleAdd() {
      this.$refs.mobile.add()
    },
    /** 查看按钮操作 */
    handleUpdate(row) {
      const applyTransNo = { applyTransNo: row.applyTransNo }
      applyInfoGetOne(applyTransNo).then(response => {
        this.$refs.seMobile.see(response.data)
      });
    },
    /** 删除按钮操作 */
    handleDelete(row) {
      const postIds = row.postId || this.ids;
      this.$modal.confirm('是否确认删除岗位编号为"' + postIds + '"的数据项?').then(function () {
        return delPost(postIds);
      }).then(() => {
        this.getList();
        this.$modal.msgSuccess("删除成功");
      }).catch(() => { });
    },
    /** 导出按钮操作 */
    handleExport() {
      this.download('system/post/export', {
        ...this.queryParams
      }, `post_${new Date().getTime()}.xlsx`)
    },
    test() {
      this.show = !this.show;
    },
    ProductCode(t) {
      for (var i = 0; i < this.product.length; i++) {
        if (t == this.product[i].businessCode) {
          return this.product[i].name
        }
      }
    },
  }
};
</script>