MaterialPlModal.vue 4.34 KB
<template>
  <a-modal
    :title="title"
    :width="800"
    :visible="visible"
    :maskClosable="false"
    :confirmLoading="confirmLoading"
    @ok="handleOk"
    @cancel="handleCancel"
    cancelText="关闭">

    <a-spin :spinning="confirmLoading">
      <a-form :form="form">

<!--        <a-form-item-->
<!--          :labelCol="labelCol"-->
<!--          :wrapperCol="wrapperCol"-->
<!--          label="物料编码">-->
<!--          <a-input placeholder="请输入物料编码" v-decorator="['code', { rules: [{ required: true, message: '请输入编码!' }] }]"-->
<!--                   :read-only="readOnly"/>-->
<!--        </a-form-item>-->


        <a-form-item
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
          label="水位上限">
          <a-input placeholder="请输入水位上限"
                   v-decorator="['upperLimit']"/>
        </a-form-item>
        <a-form-item
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
          label="水位下限">
          <a-input placeholder="请输入水位下限"
                   v-decorator="['downLimit']"/>
        </a-form-item>

        <a-form-item
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
          label="排除件标识"
          hasFeedback>
          <a-switch checkedChildren="启用" unCheckedChildren="禁用" @change="onChose" v-model="visibleCheck" />
        </a-form-item>
        <p style="color: red;margin: 0 auto;text-align: center">注:启用排除件标识,该物料不会计入领料和缺料清单</p>

      </a-form>
    </a-spin>
  </a-modal>
</template>

<script>
import JDictSelectTag from '@comp/dict/JDictSelectTag'
import JMultiSelectTag from '@/components/dict/JMultiSelectTag'
import {editBatchMaterial, getCodeList} from "../../../api/api";

export default {
  name: 'MaterialModal',
  components: {JDictSelectTag,JMultiSelectTag},
  data() {
    return {
      title: '操作',
      codeValue:'',
      visible: false,
      model: {},
      codeArr:[],
      linkCode:"",
      ids:"",
      excludeFlag:"",
      visibleCheck: false,
      labelCol: {
        xs: {span: 24},
        sm: {span: 5},
      },
      wrapperCol: {
        xs: {span: 24},
        sm: {span: 16},
      },
      confirmLoading: false,
      form: this.$form.createForm(this),
      readOnly: false
    }
  } ,
  created() {
    this.loadFrom();
  },
  methods: {
    loadFrom() {
      getCodeList().then((res) => {
        if (res.success) {
          this.codeArr=res.result
        }
      })
    },

    changCodeArr(){
      this.codeArr=[];
    },

    onChose(checked) {
      if (checked) {
        this.excludeFlag = 1
        this.visibleCheck = true
      } else {
        this.excludeFlag = 0
        this.visibleCheck = false
      }
    },

    validateDigits(rule, value, callback) {
      if (!(/(^[1-9]\d*$)/.test(value))) {
        callback("输入正整数!")
      } else {
        callback()
      }
    },

    validateCode(rule, value, callback) {
      const reg=/[^\d+(,\d\d\d)*.\d+$]/g;
      if (value.trim()!=''){
        if(reg.test(value)) {
          callback("仅允许输入数字,多个物料编码以,隔开")
        } else {
          callback()
        }
      }else{
        callback()
      }
    },

    add() {
      this.edit({})
    },
    edit(ids) {
      this.visible = true
      this.ids=ids;
      // this.$nextTick(() =>  {
      //   this.form.setFieldsValue({
      //     code:  ids
      //   })
      // })
    },
    close() {
      this.$emit('close')
      this.visible = false
    },
    handleOk() {
      const that = this
      // 触发表单验证
      this.form.validateFields((err, values) => {
        if (!err) {
          that.confirmLoading = true
          values.id=this.ids
          let formData = Object.assign(this.model, values)
          formData.excludeFlag = this.excludeFlag
          editBatchMaterial(formData).then((res)=>{
            if(res.success){
              that.$message.success(res.message);
              that.$emit('ok');
              that.$emit('fatherMethod', '');
            }else{
              that.$message.warning(res.message);
            }
          }).finally(() => {
            that.confirmLoading = false;
            that.close();
          })
        }
      })
    },
    handleCancel() {
      this.close()
    },

  }
}
</script>

<style scoped>

</style>