djbcx.vue 6.46 KB
<!--
 * @Description:
 * @Autor: renchao
 * @LastEditTime: 2023-09-21 10:39:16
-->
<template>
  <div class="from-clues">
    <!-- 表单部分 -->
    <div class="from-clues-header">
      <el-form :model="queryForm" ref="queryForm" @submit.native.prevent label-width="70px">
        <el-row>
          <el-col :span="4">
            <el-form-item label="权利类型">
              <el-select v-model="queryForm.qllx" filterable class="width100" clearable placeholder="请选择权利类型">
                <el-option v-for="item in dictData['A8']" :key="item.dcode" :label="item.dname" :value="item.dcode">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="4">
            <el-form-item label="登记类型">
              <el-select v-model="queryForm.djlx" filterable class="width100" clearable placeholder="请选择登记类型">
                <el-option v-for="item in dictData['A21']" :key="item.dcode" :label="item.dname" :value="item.dcode">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="4">
            <el-form-item label="权属状态">
              <el-select v-model="queryForm.qszt" filterable class="width100" clearable placeholder="请选择登记类型">
                <el-option
                  v-for="item in qsztlist"
                  :key="item.dcode"
                  :label="item.dname"
                  :value="item.dcode"></el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="不动产单元号" label-width="105px">
              <el-input placeholder="请输入不动产单元号" maxlength="28" v-model="queryForm.bdcdyh" clearable class="width100">
              </el-input>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="不动产权证号" label-width="105px">
              <el-input placeholder="请输入不动产权证号" v-model="queryForm.bdcqzh" clearable class="width100">
              </el-input>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="5">
            <el-form-item label="业务号:">
              <el-input placeholder="请输入业务号" v-model="queryForm.ywh" clearable class="width100">
              </el-input>
            </el-form-item>
          </el-col>
          <el-col :span="5">
            <el-form-item label="坐落:" label-width="105px">
              <el-input v-model="queryForm.zl" placeholder="坐落" clearable class="width100">
              </el-input>
            </el-form-item>
          </el-col>
          <el-col :span="5">
            <el-form-item label="权利人:" label-width="105px">
              <el-input v-model="queryForm.qlrmc" placeholder="权利人" clearable class="width100">
              </el-input>
            </el-form-item>
          </el-col>
          <el-col :span="5">
            <el-form-item label="义务人:">
              <el-input v-model="queryForm.ywrmc" placeholder="义务人" clearable class="width100">
              </el-input>
            </el-form-item>
          </el-col>

          <el-col :span="4" class="btnColRight">
            <el-form-item>
              <el-button type="primary" native-type="submit" @click="handleSearch">查询</el-button>
            </el-form-item>
          </el-col>
        </el-row>
      </el-form>
    </div>
    <!-- 表格 -->
    <div class="from-clues-content">
      <lb-table :page-size="pageData.size" class="loadingtext" @sort-change="handleSort"
        :current-page.sync="pageData.current" :total="tableData.total" @size-change="handleSizeChange"
        @p-current-change="handleCurrentChange" :column="tableData.columns" :data="tableData.data">
      </lb-table>
    </div>
  </div>
</template>
<script>
  import { mapGetters } from "vuex";
  import table from "@/utils/mixin/table";
  import { datas, sendThis } from "./djbcxdata";
  import { getDjbBysearch } from "@/api/search.js";

  export default {
    name: "djbcx",
    mixins: [table],
    mounted () {
      sendThis(this);
      this.queryClick()
    },
    data () {
      return {
        // 权属状态
        qsztlist: [
          {
            dcode: "1",
            dname: "现势",
          },
          {
            dcode: "2",
            dname: "历史",
          },
        ],
        queryForm: {
          qszt: "1",
          qllx: "",
          bdcdyh: "",
          bdcqzh: "",
          ywh: "",
        },
        pageData: {
          current: 1,
          size: 10,
          total: 0,
        },
        tableData: {
          columns: datas.columns(),
          data: [],
        },
        qllxs: [],
        isDialog: false,
        djbxxData: {}
      }
    },
    computed: {
      ...mapGetters(["dictData"])
    },
    activated () {
      this.queryClick()
    },
    methods: {
      /**
       * @description: 初始化数据
       * @author: renchao
       */
      queryClick () {
        this.$startLoading()
        getDjbBysearch({ ...this.queryForm, ...this.pageData }).then((res) => {
          this.$endLoading()
          if (res.code === 200) {
            let { total, records } = res.result;
            this.tableData.data = records;
            this.tableData.total = total;
          }
        });
      },
      /**
       * @description: handleSort
       * @param {*} name
       * @param {*} sort
       * @author: renchao
       */
      handleSort (name, sort) {
        console.log(name, sort);
      },
      /**
       * @description: openDialog
       * @param {*} scroll
       * @author: renchao
       */
      openDialog (scroll) {
        this.$popupDialog('登记簿详情', 'registerBook/djbFrame', scroll, '85%');
      },
      /**
       * @description: handleLpbClick
       * @param {*} item
       * @author: renchao
       */
      handleLpbClick (item) {
        this.$popup('楼盘表', 'lpb/index', {
          width: '85%',
          formData: {
            bsm: item.zrzbsm,
            zrzbsm: item.zrzbsm,
            zdbsm: item.zrzbsm,
            onlyShow: true
          }
        })
      }
    }
  }
</script>
<style scoped lang="scss">
  @import "~@/styles/public.scss";

  .icon-circle {
    position: relative;
  }

  .icon-circle::before {
    content: "";
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: #000;
    top: 0px;
    left: 0px;
  }
</style>