subMaterial.vue 5.9 KB
Newer Older
huhaiqing's avatar
huhaiqing committed
1
<template>
huhaiqing's avatar
huhaiqing committed
2
  <div>
huhaiqing's avatar
huhaiqing committed
3 4
    <el-form ref="subMaterialForm" :model="subMaterialObj" label-width="140px">
      <el-form-item label="代理商AGENT">
huhaiqing's avatar
huhaiqing committed
5
        <supplierSelect v-model="subMaterialObj.agentId" :companyType="'1'" placeholder="请选择供应商" :allSupplier="this.$attrs.allSupplier" />
huhaiqing's avatar
huhaiqing committed
6
      </el-form-item>
huhaiqing's avatar
huhaiqing committed
7
      <el-form-item label="提单号M/BL NO." class="two-element">
huhaiqing's avatar
huhaiqing committed
8 9
        <el-input v-model="subMaterialObj.blMblNo" placeholder="请输入提单号"></el-input>
        <el-button type="primary">提单确认件</el-button>
huhaiqing's avatar
huhaiqing committed
10 11
      </el-form-item>
      <el-form-item label="SO NO.">
huhaiqing's avatar
huhaiqing committed
12
        <el-input v-model="subMaterialObj.soNo" placeholder="请输入SO NO"></el-input>
huhaiqing's avatar
huhaiqing committed
13 14
      </el-form-item>
      <el-form-item label="装货港">
huhaiqing's avatar
huhaiqing committed
15
        <dockSelect v-model="subMaterialObj.startPortId" placeholder="请选择装货港" :allDocks="this.$attrs.allDocks" />
huhaiqing's avatar
huhaiqing committed
16 17
      </el-form-item>
      <el-form-item label="目的港">
huhaiqing's avatar
huhaiqing committed
18
        <dockSelect v-model="subMaterialObj.destPortId" placeholder="请选择目的港" :allDocks="this.$attrs.allDocks" />
huhaiqing's avatar
huhaiqing committed
19 20
      </el-form-item>
      <el-form-item label="船公司">
huhaiqing's avatar
huhaiqing committed
21
        <supplierSelect v-model="subMaterialObj.shipCompanyId" :companyType="'9'" placeholder="请选择船公司" :allSupplier="this.$attrs.allSupplier" />
huhaiqing's avatar
huhaiqing committed
22 23
      </el-form-item>
      <el-form-item label="托运人">
huhaiqing's avatar
huhaiqing committed
24
        <userSelect v-model="subMaterialObj.shipperId" placeholder="请选择托运人" :allUsers="this.$attrs.allUsers" />
huhaiqing's avatar
huhaiqing committed
25 26
      </el-form-item>
      <el-form-item label="收货人">
huhaiqing's avatar
huhaiqing committed
27
        <userSelect v-model="subMaterialObj.consigneeId" placeholder="请选择收货人" :allUsers="this.$attrs.allUsers" />
huhaiqing's avatar
huhaiqing committed
28 29
      </el-form-item>
      <el-form-item label="通知方">
huhaiqing's avatar
huhaiqing committed
30
        <userSelect v-model="subMaterialObj.notifyingId" placeholder="请选择通知方" :allUsers="this.$attrs.allUsers" />
huhaiqing's avatar
huhaiqing committed
31 32
      </el-form-item>
      <el-form-item label="Mark & No.">
huhaiqing's avatar
huhaiqing committed
33
        <el-input v-model="subMaterialObj.markNo" placeholder="请输入Mark & No."></el-input>
huhaiqing's avatar
huhaiqing committed
34
      </el-form-item>
huhaiqing's avatar
huhaiqing committed
35
      <el-form-item label="包装数量与单位" class="two-element">
huhaiqing's avatar
huhaiqing committed
36 37
        <el-input v-model="subMaterialObj.packageNum" placeholder="请输入包装数量"></el-input>
        <el-select v-model="subMaterialObj.packageUnit" placeholder="请选择单位">
38
          <el-option v-for="unit in units" :key="unit.id" :value="unit.id" :label="unit.titleZh"></el-option>
huhaiqing's avatar
huhaiqing committed
39 40 41
        </el-select>
      </el-form-item>
      <el-form-item label="毛重(KGS)">
huhaiqing's avatar
huhaiqing committed
42
        <el-input v-model="subMaterialObj.kgs" placeholder="请输入毛重(KGS)"></el-input>
huhaiqing's avatar
huhaiqing committed
43 44
      </el-form-item>
      <el-form-item label="立方数(CBM)">
huhaiqing's avatar
huhaiqing committed
45
        <el-input v-model="subMaterialObj.cbm" placeholder="请输入立方数(CBM)"></el-input>
huhaiqing's avatar
huhaiqing committed
46 47
      </el-form-item>
      <el-form-item label="货物描述">
huhaiqing's avatar
huhaiqing committed
48
        <el-input v-model="subMaterialObj.goodsDesc" placeholder="请输入货物描述"></el-input>
huhaiqing's avatar
huhaiqing committed
49 50
      </el-form-item>
      <el-form-item label="柜号/封条">
huhaiqing's avatar
huhaiqing committed
51
        <el-input v-model="subMaterialObj.containerSealNo" placeholder="请输入柜号/封条"></el-input>
huhaiqing's avatar
huhaiqing committed
52 53
      </el-form-item>
      <el-form-item label="柜型">
huhaiqing's avatar
huhaiqing committed
54
        {{cabinetType}}
huhaiqing's avatar
huhaiqing committed
55 56
      </el-form-item>
      <el-form-item label="出单方式">
huhaiqing's avatar
huhaiqing committed
57
        <el-radio-group v-model="subMaterialObj.issueType">
huhaiqing's avatar
huhaiqing committed
58
          <el-radio v-for="item in method" :key="item.value" :label="item.value">{{item.label}}</el-radio>
huhaiqing's avatar
huhaiqing committed
59 60 61
        </el-radio-group>
      </el-form-item>
      <el-form-item label="备注">
huhaiqing's avatar
huhaiqing committed
62
        <el-input v-model="subMaterialObj.remarks" type="textarea" rows="2" placeholder="请输入备注"></el-input>
huhaiqing's avatar
huhaiqing committed
63 64 65 66
      </el-form-item>
    </el-form>

    <el-row class="operate-button">
huhaiqing's avatar
huhaiqing committed
67 68
      <el-button type="primary" @click="onSubmit(1)">保存</el-button>
      <el-button type="success" @click="onSubmit(2)">提交</el-button>
huhaiqing's avatar
huhaiqing committed
69 70 71 72 73 74
      <el-button @click="cancel">关闭</el-button>
    </el-row>
  </div>
</template>

<script>
huhaiqing's avatar
huhaiqing committed
75 76 77 78 79
import supplierSelect from "./common/supplierSelect.vue";
import dockSelect from "./common/dockSelect.vue";
import userSelect from "./common/userSelect.vue";
import { getUnitList } from "@/api/ecw/unit";
import { getCabinetPage } from "@/api/ecw/cabinet";
huhaiqing's avatar
huhaiqing committed
80 81
import { billCreate } from "@/api/ecw/boxSea";
import { formatNumberString, constantDict, serviceMsg } from "../utils";
huhaiqing's avatar
huhaiqing committed
82

huhaiqing's avatar
huhaiqing committed
83 84 85 86 87
/**
 * 提单补料
 */
export default {
  name: "subMaterial",
huhaiqing's avatar
huhaiqing committed
88
  inheritAttrs: false,
huhaiqing's avatar
huhaiqing committed
89 90 91 92
  components: { supplierSelect, dockSelect, userSelect },
  props: {
    shipmentObj: Object,
  },
huhaiqing's avatar
huhaiqing committed
93 94 95 96 97 98 99
  data() {
    return {
      // 提单补料对象
      subMaterialObj: {
        markNo: "N/M",
      },
      // 出单方式
huhaiqing's avatar
huhaiqing committed
100
      method: constantDict.billingMethod,
huhaiqing's avatar
huhaiqing committed
101 102
      // 单位
      units: [],
huhaiqing's avatar
huhaiqing committed
103 104
      // 柜型
      cabinetType: "/",
huhaiqing's avatar
huhaiqing committed
105 106
    };
  },
huhaiqing's avatar
huhaiqing committed
107 108 109 110 111 112 113 114
  created() {
    // 获取单位
    getUnitList().then((res) => {
      const { data } = res;
      this.units = data ?? [];
    });
    // 柜型
    getCabinetPage(null).then((response) => {
huhaiqing's avatar
huhaiqing committed
115 116 117 118 119 120 121
      const cabinetList = response.data.list;
      for (let index in cabinetList) {
        let cabinetItem = cabinetList[index];
        if (cabinetItem.id == this.shipmentObj.cabinetId) {
          this.cabinetType = cabinetItem.name;
        }
      }
huhaiqing's avatar
huhaiqing committed
122
    });
huhaiqing's avatar
huhaiqing committed
123 124 125

    const voName = this.$attrs.currNode.voName;
    let oldData = { ...this.shipmentObj[voName] };
huhaiqing's avatar
huhaiqing committed
126
    oldData = formatNumberString(oldData, ["issueType"]);
huhaiqing's avatar
huhaiqing committed
127 128 129 130
    this.subMaterialObj = {
      ...oldData,
      packageUnit: oldData.packageUnit === 0 ? undefined : oldData.packageUnit,
    };
huhaiqing's avatar
huhaiqing committed
131
  },
huhaiqing's avatar
huhaiqing committed
132 133
  methods: {
    /** 提交 */
huhaiqing's avatar
huhaiqing committed
134
    onSubmit(operateType) {
huhaiqing's avatar
huhaiqing committed
135 136
      this.$refs["subMaterialForm"].validate((valid) => {
        if (valid) {
huhaiqing's avatar
huhaiqing committed
137 138 139 140 141 142
          billCreate({
            ...this.subMaterialObj,
            shipmentId: this.shipmentObj.id,
            operateType,
          }).then((res) => {
            serviceMsg(res, this).then(() => {
huhaiqing's avatar
huhaiqing committed
143
              this.cancel("submit");
huhaiqing's avatar
huhaiqing committed
144 145
            });
          });
huhaiqing's avatar
huhaiqing committed
146 147 148 149
        }
      });
    },
    /** 取消 */
huhaiqing's avatar
huhaiqing committed
150 151
    cancel(type) {
      this.$emit("closeDialog", type);
huhaiqing's avatar
huhaiqing committed
152
    },
huhaiqing's avatar
huhaiqing committed
153 154 155 156 157 158
  },
};
</script>

<style lang="scss">
</style>