seaSpaceAttribute.vue 3.65 KB
<template>
  <div class="seaSpaceAttribute itemForm">
    <el-form :model="ruleForm" :rules="rules" ref="formList" label-width="115px" :key="key">
      <el-row>
        <el-col :span="8">
          <el-form-item prop="BDCDYH">
            <span slot="label">
              不动产单元号: <br />
              <p class="label-detail">(BDCDYH)</p>
            </span>
            <el-input :disabled="$store.state.business.Edit" v-model="ruleForm.BDCDYH" maxlength="28"
              placeholder="不动产单元号"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item prop="ZDX" :rules="{ type: 'number' }">
            <span slot="label">
              子对象: <br />
              <p class="label-detail">(ZDX)</p>
            </span>
            <el-input :disabled="$store.state.business.Edit" v-model.number="ruleForm.ZDX" type="number"
              v-only-number="{ max: 9999, min: 0, precision: 0 }" placeholder="子对象"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item prop="XH" :rules="{ type: 'number' }">
            <span slot="label">
              序号: <br />
              <p class="label-detail">(XH)</p>
            </span>
            <el-input :disabled="$store.state.business.Edit" v-model.number="ruleForm.XH" type="number"
              v-only-number="{ max: 9999, min: 0, precision: 0 }" placeholder="序号"></el-input>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="8">
          <el-form-item prop="XZB" :rules="{ type: 'number' }">
            <span slot="label">
              X坐标: <br />
              <p class="label-detail">(XZB)</p>
            </span>
            <el-input :disabled="$store.state.business.Edit" v-model.number="ruleForm.XZB"
              v-only-number="{ max: 999999999999999, min: 0, precision: 8 }" type="number" placeholder="X坐标"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item prop="YZB" :rules="{ type: 'number' }">
            <span slot="label">
              Y坐标: <br />
              <p class="label-detail">(YZB)</p>
            </span>
            <el-input :disabled="$store.state.business.Edit" v-model.number="ruleForm.YZB" type="number"
              v-only-number="{ max: 999999999999999, min: 0, precision: 8 }" placeholder="Y坐标"></el-input>
          </el-form-item>
        </el-col>
      </el-row>
    </el-form>
    <message-tips ref="msg" />
  </div>
</template>
<script>
// 宗海空间属性
import business from '@/api/business'
import ruleMixin from '@/mixins/ruleMixin.js'
export default {
  mixins: [ruleMixin],
  props: {
    bsmSjsb: {
      type: String,
      default: ''
    },
    dataTable: {
      type: String,
      default: ''
    }
  },
  data () {
    return {
      ruleForm: {
        BDCDYH: '',
        zhdm: '',
        ZDX: '',
        XH: '',
        XZB: '',
        YZB: ''
      }
    }
  },
  methods: {
    async featchData () {
      try {
        let { result: res } = await business.getZhK105ById(this.bsmSjsb)
        this.ruleForm = res
        this.featchRule()
      } catch (error) {
        this.$refs.msg.messageShow()
      }
    },
    handleUpdateForm () {
      return new Promise(async (resolve) => {
        try {
          let res = await business.updateZhK105(this.ruleForm)
          // this.$refs['formList'].resetFields();
          resolve(res.code)
        } catch (error) {
          this.$refs.msg.messageShow()
        }
      })
    }
  }
}
</script>
<style scoped lang="scss">
@import "./css/itemForm.scss";
</style>