Blame view

src/views/zsgl/zsff/components/addDialog.vue 6.65 KB
蔡俊立 committed
1
<template>
任超 committed
2 3
  <dialogBox title="证书分发" @submitForm="submitForm" saveButton="保存" width="50%" :isFullscreen="false"
    @closeDialog="closeDialog" v-model="myValue">
蔡俊立 committed
4
    <div>
任超 committed
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
      <el-form ref="ruleForm" :model="ruleForm" label-width="100px" :rules="rules">
        <el-row>
          <el-col :span="12">
            <el-form-item label="发放编号:" prop="batchno">
              <el-input v-model="ruleForm.batchno" :disabled="true"></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="领取时间:" prop="rksj">
              <el-date-picker v-model="ruleForm.rksj" class="width100" type="datetime" placeholder="选择日期时间">
              </el-date-picker>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="12">
            <el-form-item label="入库人员:">
              <el-input v-model="ruleForm.rkry" :disabled="true"></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="领取人:" prop="receiver">
              <el-select v-model="ruleForm.receiver" class="width100" placeholder="请选择">
                <el-option v-for="item in usernames" :key="item" :label="item" :value="item"></el-option>
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>
        <div>
          <el-table :data="tableForm" border
            :header-cell-style="{'text-align':'center',background: 'rgb(236, 245, 255)'}"
            :cell-style="{'text-align':'center'}">
            <el-table-column prop="name" label="纸质证书类型" width="200"></el-table-column>
            <el-table-column prop="ksysxlh" label="开始印刷序列号" width="200"></el-table-column>
            <el-table-column prop="bs" label="本数">
              <template slot-scope="scope">
                <el-input v-model="scope.row.bs" @blur="ysxlhDeal(scope.row)"
                  oninput="value=value.replace(/[^\d.]/g,'')" maxlength="6"></el-input>
              </template>
            </el-table-column>
            <el-table-column prop="jsysxlh" label="结束印刷序列号" width="200">
              <template slot-scope="scope">
                <span v-if="scope.row.jsysxlh == ''" class="font-red">系统计算</span>
                <span v-else>{{scope.row.jsysxlh}}</span>
              </template>
            </el-table-column>
          </el-table>
        </div>
        <el-form-item label="备注" class="middle-margin-bottom">
          <el-input type="textarea" v-model="ruleForm.bz" :rows="4"></el-input>
        </el-form-item>
      </el-form>
蔡俊立 committed
57 58 59 60 61
    </div>
  </dialogBox>
</template>

<script>
任超 committed
62
import { getZsStartNo, getSysSerialSingle, getZsEndNo, zsff } from "@/api/zsgl.js"
蔡俊立 committed
63 64 65 66 67 68 69 70 71 72
export default {
  components: {
  },
  computed: {
  },
  props: {
    value: { type: Boolean, default: false },
  },
  data () {
    return {
任超 committed
73
      myValue: this.value,
蔡俊立 committed
74
      //表单提交数据
蔡俊立 committed
75
      ruleForm: {
任超 committed
76 77 78 79 80 81 82 83 84 85 86 87
        batchno: '',
        receiver: '',
        rkry: '超级管理员',
        rksj: '',
        bz: '',
        zsstarno: '',
        zsendno: '',
        zsnum: '',
        zmstarno: '',
        zmendno: '',
        zmnum: ''
      },
蔡俊立 committed
88
      //表格数据
蔡俊立 committed
89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
      tableForm: [
        {
          name: '不动产权证书',
          ksysxlh: '',
          jsysxlh: '',
          bs: '',
          zslx: 'zs'
        },
        {
          name: '不动产权登记证明',
          ksysxlh: '',
          jsysxlh: '',
          bs: '',
          zslx: 'zm'
        }
任超 committed
104
      ],
蔡俊立 committed
105
      //证书分发业务号固定参数
蔡俊立 committed
106 107 108 109 110 111
      ywhQueryForm: {
        serialtype: 'zsffbh',
        serialname: '证书分发编号',
        serialcode: 'zsff',
        digit: '5'
      },
蔡俊立 committed
112
      //用户列表
任超 committed
113
      usernames: ['张三', '李四'],
蔡俊立 committed
114
      rules: {
任超 committed
115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
        batchNo: [
          { required: true, message: '入库编号不能为空', trigger: 'blur' }
        ],
        lqr: [
          { required: true, message: '请选择领取人', trigger: 'change' }
        ],
        rksj: [
          { required: true, message: '请选择入库时间', trigger: 'change' }
        ],
      },
    }
  },
  watch: {
    value (val) {
      this.myValue = val
蔡俊立 committed
130 131 132 133 134
    }
  },
  methods: {
    //表单提交
    submitForm () {
蔡俊立 committed
135
      zsff(this.ruleForm).then(res => {
任超 committed
136
        if (res.code == 200) {
蔡俊立 committed
137 138
          this.$message.success('保存成功')
          this.$emit("input", false);
任超 committed
139
          this.$refs['ruleForm'].resetFields();
蔡俊立 committed
140 141
          this.resetTableFields();
          this.$parent.fetchData();
任超 committed
142
        } else {
蔡俊立 committed
143 144 145
          this.$message.error(res.message)
        }
      })
蔡俊立 committed
146 147
    },
    //序列号获取
任超 committed
148
    ywhSerial () {
蔡俊立 committed
149
      getSysSerialSingle(this.ywhQueryForm).then(res => {
任超 committed
150 151
        if (res.code == 200) {
          this.ruleForm.batchno = res.message;
蔡俊立 committed
152 153
        }
      })
蔡俊立 committed
154
    },
任超 committed
155 156 157 158 159 160 161
    initStartNo () {
      getZsStartNo().then(res => {
        if (res.code == 200) {
          this.tableForm[0].ksysxlh = res.result.zsstarno
          this.tableForm[1].ksysxlh = res.result.zmstarno
        }
      })
蔡俊立 committed
162 163
    },
    //印刷序列号处理
任超 committed
164 165
    ysxlhDeal (item) {
      if (item.bs) {
蔡俊立 committed
166
        //存在本数
任超 committed
167 168
        getZsEndNo({ "bookNumber": item.bs, "zslx": item.zslx }).then(res => {
          if (res.code == 200) {
蔡俊立 committed
169 170
            item.jsysxlh = res.result.endno
            item.bs = res.result.bookNumber
任超 committed
171 172
            this.updateRuleForm(res.result.endno, res.result.bookNumber, item);
          } else {
蔡俊立 committed
173
            this.$message.error(res.message)
任超 committed
174
          }
蔡俊立 committed
175
        })
任超 committed
176
      } else {
蔡俊立 committed
177 178 179
        //不存在本数
        item.bs = 0;
        item.jsysxlh = '';
任超 committed
180 181
        this.updateRuleForm('', 0, item);
      }
蔡俊立 committed
182 183
    },
    //更新表单数据
任超 committed
184 185
    updateRuleForm (endno, bookNumber, item) {
      if (item.zslx == 'zs') {
蔡俊立 committed
186 187 188
        this.ruleForm.zsstarno = item.ksysxlh;
        this.ruleForm.zsendno = endno;
        this.ruleForm.zsnum = bookNumber;
任超 committed
189
      } else if (item.zslx == 'zm') {
蔡俊立 committed
190 191 192 193
        this.ruleForm.zmstarno = item.ksysxlh;
        this.ruleForm.zmendno = endno;
        this.ruleForm.zmnum = bookNumber;
      }
蔡俊立 committed
194
    },
任超 committed
195
    resetTableFields () {
蔡俊立 committed
196 197 198 199 200 201
      this.tableForm = [
        {
          name: '不动产权证书',
          ksysxlh: '',
          jsysxlh: '',
          bs: 0,
蔡俊立 committed
202
          zslx: 'zs'
蔡俊立 committed
203 204 205 206 207 208
        },
        {
          name: '不动产权登记证明',
          ksysxlh: '',
          jsysxlh: '',
          bs: 0,
蔡俊立 committed
209
          zslx: 'zm'
蔡俊立 committed
210 211 212 213 214
        }
      ]
    },
    closeDialog () {
      this.$emit("input", false);
任超 committed
215 216
      this.$refs['ruleForm'].resetFields();
    }
蔡俊立 committed
217 218 219 220 221
  }
}
</script>
<style scoped lang="scss">
@import "~@/styles/mixin.scss";
任超 committed
222 223

.font-red {
蔡俊立 committed
224 225
  color: red
}
任超 committed
226 227 228

.middle-margin-bottom {
  margin-top: 20px
蔡俊立 committed
229
}
蔡俊立 committed
230
</style>