SnnoForm.vue 5.46 KB
<template>
  <a-modal
    :width="modalWidth"
    :style="modalStyle"
    :visible="visible"
    :confirmLoading="confirmLoading"
    :maskClosable="false"
    @cancel="handleCancel">
    <template slot="footer">
      <a-button @click="handleCancel">关闭</a-button>
    </template>
    <a-spin :spinning="confirmLoading">
      <a-form :form="form">
        <a-row>
          <a-col :span="24">
            <a-form-item label="工厂" :labelCol="labelCol" :wrapperCol="wrapperCol">
              <j-dict-select-tag placeholder="请选择工厂"
                                 v-decorator="['factorytype',{rules: [{ required: true, message: '请选择工厂'}]}]"
                                 :triggerChange="true"
                                 dictCode="factoryType"/>
            </a-form-item>
          </a-col>

          <a-col :span="24">
            <a-form-item label=" 设备类型 " :labelCol="labelCol" :wrapperCol="wrapperCol">
              <j-dict-select-tag v-decorator="['devicetype',{rules: [{ required: true, message: '请选择设备类型'}]}]"
                                 :triggerChange="true"
                                 placeholder="请选择设备类型 " dictCode="deviceType"/>
            </a-form-item>
          </a-col>

          <a-col :span="24">
            <a-form-item label=" 货叉编码 " :labelCol="labelCol" :wrapperCol="wrapperCol">
              <a-input placeholder="请输入货叉编码" v-decorator.trim="['code']"/>
            </a-form-item>
          </a-col>

          <a-col :span="24">
            <a-form-item label=" 安装视频 " :labelCol="labelCol" :wrapperCol="wrapperCol">
              <a-input placeholder="请输入视频url" v-decorator.trim="['azurl']"/>
            </a-form-item>
          </a-col>

          <a-col :span="24">
            <a-form-item label=" 保养视频 " :labelCol="labelCol" :wrapperCol="wrapperCol">
              <a-input placeholder="请输入视频url" v-decorator.trim="['byurl']"/>
              <a-input v-decorator="['workno']" style="display:none"/>
              <a-input v-decorator="['field0048']" style="display:none"/>
              <a-input v-decorator="['field0050']" style="display:none"/>
              <a-input v-decorator="['field0068']" style="display:none"/>
              <a-input v-decorator="['field0172']" style="display:none"/>
              <a-input v-decorator="['projectName']" style="display:none"/>
            </a-form-item>
          </a-col>


          <a-col :span="24" style="text-align: center" class="table-page-search-submitButtons">
            <a-button type="primary" @click="submitForm" icon="check-circle">创建sn</a-button>
          </a-col>
        </a-row>

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

<script>

import {httpAction} from '@/api/manage'
import {JeecgListMixin} from '@/mixins/JeecgListMixin'

export default {
  name: 'ProjectCForm.vue',
  mixins: [JeecgListMixin],
  components: {},
  props: {
    //表单禁用
    disabled: {
      type: Boolean,
      default: false,
      required: false
    }
  },
  data() {
    return {
      visible: false,
      modalWidth: '50%',
      modalStyle: {'top': '20px'},
      form: this.$form.createForm(this),
      model: {},
      labelCol: {
        xs: {span: 24},
        sm: {span: 5},
      },
      wrapperCol: {
        xs: {span: 24},
        sm: {span: 16},
      },
      confirmLoading: false,
      validatorRules: {},
      searchOptions: [{
        text: "关闭",
        value: "1"
      },
        {
          text: "开启",
          value: "0"
        }],
      url: {
        list: "1",
      },
    }
  },
  computed: {
    formDisabled() {
      if (this.formBpm === true) {
        if (this.formData.disabled === false) {
          return false
        }
        return true
      }
      return this.disabled
    },
    showFlowSubmitButton() {
      if (this.formBpm === true) {
        if (this.formData.disabled === false) {
          return true
        }
      }
      return false
    },

  },
  created() {
    //如果是流程中表单,则需要加载流程表单data

  },
  methods: {
    edit(record) {
      this.form.resetFields();
      this.model = Object.assign({}, record);
      let timeSearch = setTimeout(() => {
        this.$nextTick(() => {
          this.form.setFieldsValue({
            factorytype: this.model.factorytype,
            projectName: record.field0047,
            workno: record.field0056,
            field0172: record.field0172,
            field0068: record.field0068,
            field0050: record.field0050,
            field0048: record.field0048
          })
        })
      }, 500)
      this.visible = true;

    },
    handleCancel() {
      this.visible = false
    },

    submitForm() {
      const that = this;
      // 触发表单验证
      this.form.validateFields((err, values) => {
        if (!err) {
          that.confirmLoading = true;
          let httpurl = '';
          let method = '';
          httpurl = "/projectsn/projectsn/createSn";
          method = 'post';
          let formData = Object.assign(this.model, values);
          httpAction(httpurl, formData, method).then((res) => {
            if (res.success) {
              that.$message.success(res.message);
              this.visible = false
              that.$emit('ok');

            } else {
              that.$message.warning(res.message);
            }
          }).finally(() => {
            that.confirmLoading = false;
          })
        }

      })
    },
  }
}
</script>