143 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			143 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
<template>
 | 
						||
  <section class="AppPolicyBid">
 | 
						||
    <ai-list>
 | 
						||
      <ai-title slot="title" title="贷款联审数据统计" isShowBottomBorder></ai-title>
 | 
						||
      <template #content>
 | 
						||
        <ai-search-bar>
 | 
						||
          <template #left>
 | 
						||
            <ai-select placeholder="所属部门" v-model="search.department" @change="page.current=1,getTableData()" :selectList="departmentList"/>
 | 
						||
            <ai-select placeholder="所属分类" v-model="search.classificationName" :selectList="classList" @change="page.current=1,getTableData()"/>
 | 
						||
          </template>
 | 
						||
          <template #right>
 | 
						||
            <el-input size="small" placeholder="申请人/申请主体/事项名称" v-model="search.name" clearable @change="page.current=1,getTableData()"/>
 | 
						||
            <ai-import
 | 
						||
              ref="import"
 | 
						||
              title="导入"
 | 
						||
              name="贷款联审数据统计"
 | 
						||
              url="/appzwspstatistics/downloadTemplate"
 | 
						||
              importUrl="/appzwspstatistics/import"
 | 
						||
              suffixName="xlsx"
 | 
						||
              :customCliker="true"
 | 
						||
              :instance="instance"
 | 
						||
            >
 | 
						||
              <template slot="tips">
 | 
						||
                <p>
 | 
						||
                  如果表格中已经存在数据,则会被本次导入的数据覆盖;不存在数据,系统将生成新的标准记录;
 | 
						||
                </p>
 | 
						||
              </template>
 | 
						||
              <el-button size="small" icon="iconfont iconImport"
 | 
						||
                >导入</el-button
 | 
						||
              >
 | 
						||
            </ai-import>
 | 
						||
            <ai-download :instance="instance" url="/appzwspstatistics/export" :params="search" fileName="贷款联审数据统计" :disabled="tableData.length == 0">
 | 
						||
              <el-button icon="iconfont iconExported" :disabled="tableData.length == 0">导出</el-button>
 | 
						||
            </ai-download>
 | 
						||
          </template>
 | 
						||
        </ai-search-bar>
 | 
						||
        <ai-table :tableData="tableData" :total="page.total" :current.sync="page.current" :size.sync="page.size"
 | 
						||
          @getList="getTableData" :col-configs="colConfigs" :dict="dict">
 | 
						||
          <el-table-column slot="options" label="操作" fixed="right" align="center">
 | 
						||
            <template slot-scope="{row}">
 | 
						||
              <el-button type="text" @click="showDetail(row)" v-if="row.zwspId">详情</el-button>
 | 
						||
            </template>
 | 
						||
          </el-table-column>
 | 
						||
        </ai-table>
 | 
						||
      </template>
 | 
						||
    </ai-list>
 | 
						||
    <ai-dialog :visible.sync="dialog" :title="dialogTitle" @closed="dialog=false" @onConfirm="dialog=false" width="800px">
 | 
						||
      <img class="pdf-img" :src="dialogImgUrl" alt="">
 | 
						||
    </ai-dialog>
 | 
						||
  </section>
 | 
						||
</template>
 | 
						||
 | 
						||
<script>
 | 
						||
import {mapState} from "vuex";
 | 
						||
 | 
						||
export default {
 | 
						||
  name: "AppPolicyBid",
 | 
						||
  label: "贷款联审数据统计",
 | 
						||
  props: {
 | 
						||
    instance: Function,
 | 
						||
    dict: Object,
 | 
						||
    permissions: Function
 | 
						||
  },
 | 
						||
  computed: {
 | 
						||
    ...mapState(['user'])
 | 
						||
  },
 | 
						||
  data() {
 | 
						||
    return {
 | 
						||
      search: {name: '', classificationName: '', department: ''},
 | 
						||
      page: {current: 1, size: 10, total: 0},
 | 
						||
      tableData: [],
 | 
						||
      colConfigs: [
 | 
						||
        {label: "申请人/申请主体", prop: "name", align: "center", width: '200px'},
 | 
						||
        {label: "事项名称", prop: "processName", align: "center"},
 | 
						||
        {label: "所属分类", prop: "classificationName", align: "center"},
 | 
						||
        {label: "所属部门/机构", prop: "department", align: "center", width: '120px'},
 | 
						||
        {label: "意向金额(万)", prop: "intendedAmount", align: "center", width: '120px'},
 | 
						||
        {label: "放款金额(万)", prop: "loanAmount", align: "center", width: '120px'},
 | 
						||
        {label: "申请日期", prop: "applyDate", align: "center", width: '120px'},
 | 
						||
        {label: "放款日期", prop: "loanDate", align: "center", width: '120px'},
 | 
						||
        {slot: "options"}
 | 
						||
      ],
 | 
						||
      dialog: false,
 | 
						||
      dialogTitle: '',
 | 
						||
      classList: [],
 | 
						||
      departmentList: []
 | 
						||
    }
 | 
						||
  },
 | 
						||
  methods: {
 | 
						||
    getTableData() {
 | 
						||
      this.instance.post("/appzwspstatistics/list", null, {
 | 
						||
        params: {...this.page, ...this.search}
 | 
						||
      }).then(res => {
 | 
						||
        if (res?.data) {
 | 
						||
          this.tableData = res.data?.records
 | 
						||
          this.page.total = res.data.total
 | 
						||
        }
 | 
						||
      })
 | 
						||
    },
 | 
						||
    showDetail(row) {
 | 
						||
      this.dialogTitle = row.processName
 | 
						||
      this.dialogImgUrl = row.zwspPictureUrl
 | 
						||
      this.dialog = true
 | 
						||
    },
 | 
						||
    getClassTypeList() {
 | 
						||
      this.instance.post("/zwspapprovalclassification/list?size=100").then(res => {
 | 
						||
        if (res?.data) {
 | 
						||
          res.data.records.map((item) => {
 | 
						||
            item.dictName = item.name
 | 
						||
            item.dictValue = item.name
 | 
						||
          })
 | 
						||
          this.classList = res.data.records
 | 
						||
        }
 | 
						||
      })
 | 
						||
      this.instance.post("/appfinancialorganization/list?size=100").then(res => {
 | 
						||
        if (res?.data) {
 | 
						||
          res.data.records.map((item) => {
 | 
						||
            item.dictName = item.organizationName
 | 
						||
            item.dictValue = item.organizationName
 | 
						||
          })
 | 
						||
          this.departmentList = res.data.records
 | 
						||
        }
 | 
						||
      })
 | 
						||
    }
 | 
						||
  },
 | 
						||
  created() {
 | 
						||
    this.getClassTypeList()
 | 
						||
    this.dict.load("sex").then(() => {
 | 
						||
      this.getTableData()
 | 
						||
    })
 | 
						||
  }
 | 
						||
}
 | 
						||
</script>
 | 
						||
 | 
						||
<style lang="scss" scoped>
 | 
						||
.AppPolicyBid {
 | 
						||
  height: 100%;
 | 
						||
  .pdf-img{
 | 
						||
    width: 100%;
 | 
						||
  }
 | 
						||
}
 | 
						||
</style>
 |