index.vue 6.64 KB
<template>
  <div class="fdcqdz from-clues">
    <div class="from-clues-header">
      <el-form ref="form" :model="form" label-width="120px">
        <el-row>
          <el-col :span="6">
            <el-form-item label="行政区" prop="pcode">
              <el-select v-model="form.pcode" class="width100" clearable placeholder="行政区">
                  <el-option v-for="item in dicData['A20']" :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="权属状态" prop="qszt">
              <el-select :disabled="$store.state.business.Edit"  class="width100" v-model="form.qszt" placeholder="权属状态">
                <el-option v-for="item in dicData['A22']" :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="坐落">
              <el-input v-model="form.zl" placeholder="坐落"></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="权利人" label-width="80px">
                <el-input v-model="form.qlr" placeholder="权利人"></el-input>
              </el-form-item>
          </el-col>
        </el-row>
        <el-row class="mt-10">
          <el-col :span="6">
            <el-form-item label="登记类型">
              <el-select v-model="form.DJLX" clearable class="width100" ref="selectlandDJ" @visible-change="isShowSelectOptions"
                placeholder="请选择登记类型">
                <el-option v-for="item in DJLXOptions" :key="item.value" :label="item.label" :value="item.value">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="不动产单元号" label-width="120px">
              <el-input v-model="form.bdcdyh" placeholder="不动产权证号"></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="不动产权证号" label-width="120px">
              <el-input v-model="form.bdcqzh" placeholder="不动产权证号"></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="6" class="btnColRight">
              <btn nativeType="cx" @click="handleSubmit">查询</btn>
          </el-col>
        </el-row>
      </el-form>
    </div>
    <div class="from-clues-content">
      <lb-table :page-size="pageData.size" :current-page.sync="pageData.current" :total="pageData.total"
        @size-change="handleSizeChange" @p-current-change="handleCurrentChange" :column="tableData.columns"
        :data="tableData.data">
      </lb-table>
      <message-tips ref="msg" :message="message" />
    </div>
    <!-- XML报文 -->
    <xml-message ref="dialog" :xml="xml" />
    <!-- 数据详情 -->
    <edit-dialog ref="editLog" :bsmSjsb="bsmSjsb" :diaData="diaData" />
  </div>
</template>

<script>
//  房地产权(项目内多幢房屋)
import data from "./data"
import business from '@/api/business'
import dataReporting from '@/api/dataReporting'
import tableMixin from '@/mixins/tableMixin.js'
import treeSelect from '@/components/treeSelect/index.vue'
import editDialog from '@/components/dataDetails/edit-dialog.vue'
export default {
  name: "fdcqdz",
  mixins: [tableMixin],
  components: {
    treeSelect,
    editDialog
  },
  data () {
    return {
      form: {
        pcode:'',
        qszt:'',
        zl: '',
        qlr: '',
        djlx:'',
        bdcqzh: '',
        bdcdyh:'',
        currentPage: 1
      },
      tableData: {
        columns: [{
          label: '序号',
          type: 'index',
          width: '50',
          index: this.indexMethod,
        }].concat(data.columns()).concat([
          {
            label: "操作",
            width: 170,
            render: (h, scope) => {
              return (
                <div>
                  <el-button
                    type="text"
                    size="mini"
                    icon="el-icon-folder"
                    style="color:#67C23A"
                    onClick={() => { this.handleXmlres(scope.$index, scope.row) }}
                  >
                    XML报文
                  </el-button>
                  <el-button
                    type="text"
                    size="mini"
                    icon="el-icon-view"
                    onClick={() => { this.handlDatadetails(scope.$index, scope.row) }}
                  >
                    数据详情
                  </el-button>
                </div>
              );
            },
          },

        ]),
        data: []
      },
      pageData: {
        total: 0,
        pageSize: 15,
        current: 1,
      },
      diaData: null,
      bsmSjsb: '',
      QLLXOptions: [
        {
          label: '国有建设用地使用权/房屋所有权',
          value: '4'
        },
        {
          label: '宅基地使用权/房屋所有权',
          value: '6'
        },
        {
          label: '集体建设用地使用权/构筑物所有权',
          value: '8'
        }
      ],
      DJLXOptions: [
        {
          label: '首次登记',
          value: '100'
        },
        {
          label: '转移登记',
          value: '200'
        },
        {
          label: '变更登记',
          value: '300'
        },
        {
          label: '更正登记',
          value: '500'
        }
      ],
    }
  },
  methods: {
    // 是否显示下拉框
    isShowSelectOptions (e) {
      if (!e) this.$refs.selectmanyQL.blur()
      if (!e) this.$refs.selectmanyDJ.blur()
    },
    async featchData () {
      try {
        this.form = Object.assign(this.form, this.formData)
        let { result: { list, total, pages: pageSize, pageNum: current }
        } = await business.getQltFwFdcqDzList(this.form)
        this.tableData.data = list
        this.pageData = {
          pageSize,
          current,
          total
        }
      } catch (error) {
        this.message = error
        this.$refs.msg.messageShow()
      }
    },
    async handlDatadetails (index, row) {
      let { result: res, message } = await dataReporting.getQltFwFdcqYzByCondition(row.BSM_SJSB)
      if (res != null) {
        this.diaData = res
        this.bsmSjsb = row.BSM_SJSB
        this.$store.dispatch('business/setEdit'); this.$refs.editLog.isShow()
      } else {
        this.$message(message);
      }
    }
  }
}
</script>
<style scoped lang="scss">
@import "~@/styles/public.scss";
</style>