detailaddDialog.vue 11.4 KB
<template>
  <el-dialog
    title="添加调整明细"
    :visible.sync="visible"
    :show="show"
    width="1100px"
    append-to-body
    @close="$emit('update:show', false)"
    @open="openDia"
  >
     <el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="140px">
       <el-row>
        <el-col :span="8">
          <el-form-item label="调整单编号" prop="adjustCode">
            <el-input v-model="ruleForm.adjustCode" :disabled="true"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="库存明细id" prop="inventoryDetailId">
            <el-input placeholder="请输入库存明细id" v-model="ruleForm.inventoryDetailId"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="调整单关联单号" prop="referCode">
            <el-input placeholder="请输入调整单关联单号" v-model="ruleForm.referCode"></el-input>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="8">
          <el-form-item label="调整单关联明细行号" prop="referDetailId">
            <el-input placeholder="请输入调整单关联明细行号" v-model="ruleForm.referDetailId"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="库位编码" prop="locationCode">
            <el-input placeholder="请输入库位编码" v-model="ruleForm.locationCode"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="容器编号" prop="containerCode">
            <el-input placeholder="请输入容器编号" v-model="ruleForm.containerCode"></el-input>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="8">
          <el-form-item label="物料编码" prop="materialCode">
           <el-input placeholder="请输入物料编码" v-model="ruleForm.materialCode"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="物料名称" prop="materialName">
          <el-input placeholder="请输入物料名称" v-model="ruleForm.materialName"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="属性号" prop="attributeId">
            <el-input placeholder="请输入属性号" v-model="ruleForm.attributeId"></el-input>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="8">
          <el-form-item label="调整前数量" prop="fromQty">
            <el-input placeholder="请输入调整前数量" v-model="ruleForm.fromQty"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="调整后数量" prop="toQty">
            <el-input placeholder="请输入调整后数量" v-model="ruleForm.toQty"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="调整前库存状态" prop="fromInventorySts">
            <el-select
              v-model="ruleForm.fromInventorySts"
              placeholder="请选择"
              style="width: 100%"
            >
              <el-option
                v-for="dict in inventoryStatusOptions"
                :key="dict.dictValue"
                :label="dict.dictLabel"
                :value="dict.dictValue"
              />
            </el-select>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="8">
          <el-form-item label="调整后库存状态" prop="toInventorySts">
            <el-select
              v-model="ruleForm.toInventorySts"
              placeholder="请选择"
              style="width: 100%"
            >
              <el-option
                v-for="dict in inventoryStatusOptions"
                :key="dict.dictValue"
                :label="dict.dictLabel"
                :value="dict.dictValue"
              />
            </el-select>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="重量" prop="weight">
            <el-input placeholder="请输入重量" v-model="ruleForm.weight"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="批次" prop="batch">
            <el-input placeholder="请输入批次" v-model="ruleForm.batch"></el-input>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="8">
          <el-form-item label="批号" prop="lot">
            <el-input placeholder="请输入批号" v-model="ruleForm.lot"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="项目号" prop="projectNO">
            <el-input placeholder="请输入项目号" v-model="ruleForm.projectNO"></el-input>
          </el-form-item>
        </el-col>
       <el-col :span="8">
          <el-form-item label="货主" prop="companyCode">
           <el-select
              v-model="ruleForm.companyCode"
              placeholder="请选择"
              style="width:100%"
            >
              <el-option
                v-for="item in companyArr"
                :key="item.id"
                :label="item.name"
                :value="item.code"
              ></el-option>
            </el-select>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
         <el-col :span="8">
          <el-form-item label="供应商" prop="supplierCode">
            <el-select
          v-model="ruleForm.supplierCode"
          placeholder="请选择"
          style="width:100%"
         
        >
          <el-option
            v-for="item in suppierArr"
            :key="item.id"
            :label="item.name"
            :value="item.code"
          />
        </el-select>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="生产日期">
            <el-date-picker
              v-model="ruleForm.manufactureDate"
              type="datetime"
              placeholder="选择生产日期"
              value-format="yyyy-MM-dd HH:mm:ss"
              style="width:100%"
            >
            </el-date-picker>
          </el-form-item>
        </el-col>
        <el-col :span="8">
          <el-form-item label="失效日期">
            <el-date-picker
              v-model="ruleForm.expirationDate"
              type="datetime"
              placeholder="选择失效日期"
              value-format="yyyy-MM-dd HH:mm:ss"
              style="width:100%"
            >
            </el-date-picker>
          </el-form-item>
        </el-col>
      </el-row>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="submitForm">确 定</el-button>
        <el-button @click="cancel">取 消</el-button>
      </div>
  </el-dialog>
</template>

<script>
import {
  addAdjustDetail,
} from "@/api/cycle/adjustHeader/detail";

export default {
  props: {
    show: {
      type: Boolean,
      default: false,
    },
    adjustCode: {
      type: String,
      default:''
    },
    suppierOptions: {
      type: Array,
      default: () => []
    },
  
    companyOptions: {
      type: Array,
     default: () => []
    }
  },
  data() {
    return {
      visible: this.show,
      // 库存状态数据字典
      inventoryStatusOptions: [],
       // 供应商下拉数据
      suppierArr: this.suppierOptions,
      
      companyArr: this.companyOptions,
      ruleForm: {
        adjustCode: this.adjustCode,
        inventoryDetailId: undefined,
        referCode: undefined,
        referDetailId: undefined,
        locationCode: undefined,
        containerCode: undefined,
        materialCode: undefined,
        materialName: undefined,
        attributeId: undefined,
        fromQty: undefined,
        toQty: undefined,
        fromInventorySts: undefined,
        toInventorySts: undefined,
        weight: undefined,
        batch: undefined,
        lot: undefined,
        projectNO: undefined,
        companyCode: undefined,
        supplierCode: undefined,
        manufactureDate: undefined,
        expirationDate: undefined,
      },
      rules: {
        inventoryDetailId: [
          {
            required: true,
            message: "库存明细id不能为空",
            trigger: ["blur", "change"],
          },
          {
            pattern: /^[0-9]\d*$/,
            message: "只能正数",
            trigger: ["blur", "change"],
          }
        ],
        locationCode: [
          {
            required: true,
            message: "库位编码不能为空",
            trigger: ["blur", "change"],
          },
        ],
        containerCode: [
          {
            required: true,
            message: "容器编号不能为空",
            trigger: ["blur", "change"],
          },
        ],
        materialCode: [
          {
            required: true,
            message: "物料编码不能为空",
            trigger: ["blur", "change"],
          },
        ],
        fromInventorySts: [
          {
            required: true,
            message: "调整前库存状态不能为空",
            trigger: ["blur", "change"],
          },
        ],
        toInventorySts: [
          {
            required: true,
            message: "调整后库存状态不能为空",
            trigger: ["blur", "change"],
          },
        ],
         fromQty: [
            {
            required: true,
            message: "调整前数量不能为空",
            trigger: ["blur", "change"],
          },
          {
            pattern: /^[0-9]\d*$/,
            message: "只能正数",
            trigger: ["blur", "change"],
          }
        ],
         toQty: [
             {
            required: true,
            message: "调整后数量不能为空",
            trigger: ["blur", "change"],
          },
          {
            pattern: /^[0-9]\d*$/,
            message: "只能正数",
            trigger: ["blur", "change"],
          }
        ],
        companyCode: [
             {
            required: true,
            message: "货主不能为空",
            trigger: ["blur", "change"],
          }
      
        ],
      },
    };
  },
  watch: {
    show() {
      this.visible = this.show;
    },
    adjustCode(newValue) {
      this.ruleForm.adjustCode = newValue;
    },
    suppierOptions(newValue) {
      this.suppierArr = newValue;
    },
  
    companyOptions(newValue) {
      this.companyArr = newValue
    }
  },
created() {
  this.getDicts("inventorySts").then((response) => {
      this.inventoryStatusOptions = response.data;
    });
    
},
mounted() {
  
},
  methods: {
    openDia() {
      this.resetForm("ruleForm");
      this.ruleForm.manufactureDate = undefined;
      this.ruleForm.expirationDate = undefined
    },
    submitForm: function () {
      this.$refs["ruleForm"].validate((valid) => {
        if (valid) {
          addAdjustDetail(this.ruleForm).then((response) => {
            if (response.code == 200) {
              this.msgSuccess("新增成功");
              this.visible = false;
              this.$parent.getDetailList();
            } else {
              this.msgError(response.msg);
            }
          });
        }
      });
    },
    cancel() {
      this.resetForm("ruleForm");
      this.visible = false;
    },
  },
};
</script>