personalCredit.vue 10.9 KB
<template>
  <a-card :bordered="false">
    <!-- 查询区域 -->
    <div class="table-page-search-wrapper">
      <a-form layout="inline" @keyup.enter.native="searchQuery">
        <a-row :gutter="24">
          <a-col :md="6" :sm="12">
            <a-form-item label="授信申请编号">
              <a-input placeholder="输入授信申请编号" v-model="queryParam.creditApplyNo"></a-input>
            </a-form-item>
          </a-col>
          <a-col :md="6" :sm="12">
            <a-form-item label="客户名称">
              <a-input placeholder="输入客户名称" v-model="queryParam.idCardName"></a-input>
            </a-form-item>
          </a-col>
          <a-col :md="6" :sm="12">
            <a-form-item label="手机号码">
              <a-input placeholder="输入手机号码" v-model="queryParam.mobilePhone"></a-input>
            </a-form-item>
          </a-col>
          <template v-if="toggleSearchStatus">
            <a-col :md="6" :sm="12">
              <a-form-item label="申请产品名称">
                <a-input placeholder="输入申请产品名称" v-model="queryParam.productCategoryName"></a-input>
              </a-form-item>
            </a-col>
            <a-col :md="6" :sm="8">
              <a-form-item label="业务线编号">
                <a-input placeholder="输入业务线编号" v-model="queryParam.businessChannelNo"></a-input>
              </a-form-item>
            </a-col>
            <a-col :md="6" :sm="8">
              <a-form-item label="授信状态">
                <a-select v-model="queryParam.creditApplyStatus" placeholder="请选择">
                  <a-select-option v-for="(item, index) in creditApplyApprovalStatus" :key="index" :value="item.name">{{item.title}}</a-select-option>
                </a-select>
              </a-form-item>
            </a-col>
            <a-col :md="6" :sm="8">
              <a-form-item label="申请日期" :labelCol="{span:8}" :wrapperCol="{span:16}">
                <a-date-picker style="width: 100%" :disabledDate="disabledStartDate" :format="dateFormat" v-model="applyDateStart" @change="onChangeApplyDateStart" />
              </a-form-item>
            </a-col>
            <a-col :md="6" :sm="8">
              <a-form-item label="至" :labelCol="{span:8}" :wrapperCol="{span:16}">
                <a-date-picker style="width: 100%" :disabledDate="disabledEndDate" :format="dateFormat" v-model="applyDateEnd" @change="onChangeApplyDateEnd" />
              </a-form-item>
            </a-col>
            <a-col :md="6" :sm="8">
              <a-form-item label="产品分类编号">
                <a-input placeholder="输入产品分类编号" v-model="queryParam.productCategoryNo"></a-input>
              </a-form-item>
            </a-col>
            <a-col :md="6" :sm="12">
              <a-form-item label="进件流编号">
                <a-input placeholder="输入进件流编号" v-model="queryParam.collectionNo"></a-input>
              </a-form-item>
            </a-col>
            <a-col :md="6" :sm="8">
              <a-form-item label="组织机构">
                <a-select v-model="queryParam.businessDepartmentNo" placeholder="请选择">
                  <a-select-option v-for="(item, index) in programOffices" :key="index" :value="item.name">{{item.title}}</a-select-option>
                </a-select>
              </a-form-item>
            </a-col>
          </template>
          <a-col :md="6" :sm="8">
            <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
              <a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
              <a-button @click="searchResetTime" icon="reload" style="margin-left: 8px">重置</a-button>
              <a @click="handleToggleSearch" style="margin-left: 8px">
                {{ toggleSearchStatus ? '收起' : '展开' }}
                <a-icon :type="toggleSearchStatus ? 'up' : 'down'" />
              </a>
            </span>
          </a-col>
        </a-row>
      </a-form>
    </div>
    <!-- table区域-begin -->
    <div>
      <a-table ref="table" size="middle" bordered rowKey="id" :columns="columns" :dataSource="dataSource" :pagination="ipagination" :loading="loading" :scroll="{x:1800}" @change="handleTableChange">
        <!-- 字符串超长截取省略号显示-->
        <span slot="esContent" slot-scope="text">
          <j-ellipsis :value="text" :length="10" />
        </span>
        <span slot="action" slot-scope="text, record">
          <a-button
            type="link"
            size="small"
            @click="handleDetailBai(record,'个人授信资料')" v-has="'personalCredit:look'"
            icon="search"
            style="font-size: 12px"
            >查看</a-button
          >
        </span>
      </a-table>
    </div>
    <!-- table区域-end -->
    <personal-information-list-modal ref="modalForm" @ok="modalFormOk" :dai.sync="dai"></personal-information-list-modal>
  </a-card>
</template>
<script>
import PersonalInformationListModal from '../unified-into-manage/modules/PersonalInformationListModal';
import { JeecgListMixin } from '@/mixins/CoreListMixin'
import { queryCollPersonalApplyDetail } from '@/api/configApi'
// import { queryCusPhoneCheckInfo } from '@/api/configApi'

export default {
  name: 'personalInformationList',
  mixins: [JeecgListMixin],
  components: {
    PersonalInformationListModal
  },
  data () {
    return {
      queryParam: {},
      creditApplyApprovalStatus: JSON.parse(sessionStorage.getItem('CREDIT_APPLY_APPROVAL_STATUS')), // 授信状态
      dbCooPerationPlatform: JSON.parse(sessionStorage.getItem('DB_COOPERATION_PLATFORM')), // 合作平台
      programOffices: JSON.parse(sessionStorage.getItem('PROGRAMOFFICES')), // 组织机构
      visible: false,
      dateFormat: 'YYYY-MM-DD 00:00:00',
      dai:"",
      value: [],
      customerNo: '',
      columns: [
        {
          title: '序号',
          dataIndex: '',
          key: 'rowIndex',
          align: 'center',
          width:55,
          customRender: function (t, r, index) {
            return parseInt(index) + 1
          }
        },
        {
          title: '授信申请编号',
          align: 'center',
          dataIndex: 'creditApplyNo',
          width:300,
        },
        {
          title: '客户名称',
          align: 'center',
          dataIndex: 'idCardName',
          width:120,
        },
        {
          title: '证件号码',
          align: 'center',
          dataIndex: 'idCardNoView',
          width:180,
        },
        {
          title: '手机号码',
          align: 'center',
          dataIndex: 'mobilePhoneView',
          width:120
        },
        {
          title: '进件来源',
          align: 'center',
          dataIndex: 'collectionSource',
          width:100,
          customRender: (t, r, index) => {
            if(t == 1){
              return "移动平台"
            }else if(t == 2){
              return "管理后台"
            }else{
              return "三方接口"
            }
          }
        },
        {
          title: '业务线名称',
          align: 'center',
          dataIndex: 'businessChannelName',
          width:180,
        },
        {
          title: '产品编号',
          align: 'center',
          dataIndex: 'productCategoryNo',
          width:200,
        },
        {
          title: '产品名称',
          align: 'center',
          dataIndex: 'productCategoryName',
          width:200,
        },
        {
          title: '组织机构',
          align: 'center',
          dataIndex: 'businessDepartmentNo',
          width:180,
          // customRender: (t, r, index) => {
          //   for (var i = 0; i < this.programOffices.length; i++) {
          //     if (t === this.programOffices[i].name) {
          //       return this.programOffices[i].title
          //     }
          //   }
          // }
        },
        {
          title: '业务主办经理',
          align: 'center',
          dataIndex: 'businessManageName',
          width:180,
        },
        {
          title: '授信额度(元)',
          align: 'center',
          dataIndex: 'creditApplyAmount',
          width:180,
          customRender: (t, r, index) => {
            return this.$numMoney(t)
          }
        },
        {
          title: '年利率(%)',
          align: 'center',
          dataIndex: 'annualRate',
          width:120,
        },
        {
          title: '逾期年利率(%)',
          align: 'center',
          dataIndex: 'overdueAnnualRate',
          width:120,
        },
        {
          title: '授信状态',
          align: 'center',
          dataIndex: 'creditApplyStatus',
          width:120,
          customRender: (t, r, index) => {
            if(t == 1){
              return "有效"
            }else if(t == 2){
              return "无效"
            }else{
              return "处理中"
            }
          }
        },
        {
          title: '借款订单编号',
          align: 'center',
          dataIndex: 'borrowingOrderNo',
          width:300,
        },
        {
          title: '授信生效日期',
          align: 'center',
          dataIndex: 'creditStartDate',
          width:180,
        },
        {
          title: '授信失效日期',
          align: 'center',
          dataIndex: 'creditEndDate',
          width:180,
        },
        {
          title: '申请时间',
          align: 'center',
          dataIndex: 'creditApplyTime',
          width:180,
        },
        {
          title: '更新时间',
          align: 'center',
          dataIndex: 'updateTime',
          width:180,
        },
        {
          title: '操作',
          dataIndex: 'action',
          scopedSlots: { customRender: 'action' },
          align: 'center',
          width: 100,
          fixed: 'right'
        }
      ],
      url: {
        list: '/credit/admin/queryCreditApplyPersonalPage'
      },
      applyDateStart: undefined,
      applyDateEnd: undefined
    }
  },
  created () {

  },
  methods: {
    handleDetailBai: function (record, title) {
      console.log(record)
      let _p = {
        "applyNo": record.creditApplyNo,
      };
      this.dai = 1
      queryCollPersonalApplyDetail(_p).then(res => {
        if (res.status.statusCode == 0) {
          localStorage.setItem("dh", record.creditApplyNo)
          this.$refs.modalForm.edit(res.result, record.creditApplyNo,record.organizationId,record,record.businessChannelNo)
          this.$refs.modalForm.up1()
          this.$refs.modalForm.up2()
          this.$refs.modalForm.up3()
          this.$refs.modalForm.up4()
          this.$refs.modalForm.up5()
        } else {
          this.$message.warning(res.status.statusReason)
        }
      })
      this.$refs.modalForm.titles = title
      this.$refs.modalForm.disableSubmit = true
      this.$refs.modalForm.onlyread = true
    },
  }
}
</script>
<style scoped>
@import '~@assets/less/common.less';
</style>