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

    <el-row class="operate-button">
66 67 68
      <el-button type="primary" @click="onSubmit(1)">{{$t('保存')}}</el-button>
      <el-button type="success" @click="onSubmit(2)">{{$t('提交')}}</el-button>
      <el-button @click="cancel">{{$t('关闭')}}</el-button>
69
      <el-button :disabled="shipmentObj.ladingBillInfo == null" @click="download">{{$t('下载提单确认件')}}</el-button>
huhaiqing's avatar
huhaiqing committed
70 71 72 73 74
    </el-row>
  </div>
</template>

<script>
huhaiqing's avatar
huhaiqing committed
75 76 77
import supplierSelect from "./common/supplierSelect.vue";
import dockSelect from "./common/dockSelect.vue";
import userSelect from "./common/userSelect.vue";
78
import ladingSelect from "./common/ladingSelect.vue";
huhaiqing's avatar
huhaiqing committed
79 80
import { getUnitList } from "@/api/ecw/unit";
import { getCabinetPage } from "@/api/ecw/cabinet";
81
import { billCreate, getBoxLadingBillPdf } from "@/api/ecw/boxSea";
82
import { getSupplier } from "@/api/ecw/supplier";
huhaiqing's avatar
huhaiqing committed
83
import { formatNumberString, constantDict, serviceMsg } from "../utils";
84
import FileSaver from 'file-saver'
huhaiqing's avatar
huhaiqing committed
85

huhaiqing's avatar
huhaiqing committed
86 87 88 89 90
/**
 * 提单补料
 */
export default {
  name: "subMaterial",
huhaiqing's avatar
huhaiqing committed
91
  inheritAttrs: false,
92
  components: { supplierSelect, dockSelect, userSelect, ladingSelect },
huhaiqing's avatar
huhaiqing committed
93 94 95
  props: {
    shipmentObj: Object,
  },
huhaiqing's avatar
huhaiqing committed
96 97 98 99 100 101 102
  data() {
    return {
      // 提单补料对象
      subMaterialObj: {
        markNo: "N/M",
      },
      // 出单方式
huhaiqing's avatar
huhaiqing committed
103
      method: constantDict.billingMethod,
huhaiqing's avatar
huhaiqing committed
104 105
      // 单位
      units: [],
huhaiqing's avatar
huhaiqing committed
106 107
      // 柜型
      cabinetType: "/",
huhaiqing's avatar
huhaiqing committed
108 109
    };
  },
huhaiqing's avatar
huhaiqing committed
110 111 112 113 114 115 116 117
  created() {
    // 获取单位
    getUnitList().then((res) => {
      const { data } = res;
      this.units = data ?? [];
    });
    // 柜型
    getCabinetPage(null).then((response) => {
huhaiqing's avatar
huhaiqing committed
118 119 120 121 122
      const cabinetList = response.data.list;
      for (let index in cabinetList) {
        let cabinetItem = cabinetList[index];
        if (cabinetItem.id == this.shipmentObj.cabinetId) {
          this.cabinetType = cabinetItem.name;
123
          this.$set(this.subMaterialObj,'cbm',cabinetItem.ladingBill)
huhaiqing's avatar
huhaiqing committed
124 125
        }
      }
huhaiqing's avatar
huhaiqing committed
126
    });
huhaiqing's avatar
huhaiqing committed
127 128
    const voName = this.$attrs.currNode.voName;
    let oldData = { ...this.shipmentObj[voName] };
zhoutong's avatar
zhoutong committed
129 130 131 132
    oldData = formatNumberString(oldData, ["issueType"]);this.subMaterialObj = {
      ...oldData,
      packageUnit: oldData.packageUnit === 0 ? undefined : oldData.packageUnit,
    };
zhoutong's avatar
zhoutong committed
133
    if(!this.shipmentObj.ladingBillInfo){
zhoutong's avatar
zhoutong committed
134
      
zhoutong's avatar
zhoutong committed
135 136 137 138 139 140 141 142 143
      this.$set(this.subMaterialObj,'agentId',this.shipmentObj.agentInfo?.agentId||undefined)
      this.$set(this.subMaterialObj,'soNo',this.shipmentObj.bookSeaInfo?.sono||undefined)
      this.$set(this.subMaterialObj,'blMblNo',this.shipmentObj.bookSeaInfo?.sono||undefined)
      this.$set(this.subMaterialObj,'markNo',"N/M")
      this.$set(this.subMaterialObj,'startPortId',this.shipmentObj.bookSeaInfo?.bigPortId||undefined)
      this.$set(this.subMaterialObj,'shipCompanyId',Number(this.shipmentObj.bookSeaInfo?.shipCompanyType)||undefined)
      this.$set(this.subMaterialObj,'destPortId',this.shipmentObj.bookSeaInfo?.destPortId||undefined)
      this.$set(this.subMaterialObj,'kgs',this.shipmentObj.customsInfo?.dcGoodsWgt||undefined)
      this.$set(this.subMaterialObj,'containerSealNo',(this.shipmentObj.trailerInfo?.tlContainerNo||'')+'/'+(this.shipmentObj.trailerInfo?.tlStripSeal||'/'))
zhoutong's avatar
zhoutong committed
144
      this.subMaterialObj.containerSealNo = this.subMaterialObj.containerSealNo.replace('//','')
zhoutong's avatar
zhoutong committed
145
      this.getSup(this.subMaterialObj.agentId)
zhoutong's avatar
zhoutong committed
146
    }
huhaiqing's avatar
huhaiqing committed
147
  },
huhaiqing's avatar
huhaiqing committed
148
  methods: {
149 150 151 152 153 154 155
    getSup(id) {
      getSupplier(id).then(response => {
        if(response.data.externalBackVO){
          this.$set(this.subMaterialObj,'consigneeName',response.data.externalBackVO?.receiveCompanyName||'/')
          this.$set(this.subMaterialObj,'notifyingName',response.data.externalBackVO?.notifyCompanyName||'/')
          this.$set(this.subMaterialObj,'packageNum',response.data.externalBackVO?.packNum)
          this.$set(this.subMaterialObj,'packageUnit',response.data.externalBackVO?.packUnit)
zhoutong's avatar
zhoutong committed
156 157 158 159 160 161
          var goodName = '',baNo = '',fromNo = '',ctnNo = ''
          if(response.data.externalBackVO.goodName && response.data.externalBackVO.goodName != '') goodName = response.data.externalBackVO.goodName
          if(response.data.externalBackVO.fromNo && response.data.externalBackVO.fromNo != '') fromNo = (goodName!=''?'\n':'')+'FROM M NO:'+response.data.externalBackVO.fromNo
          if(response.data.externalBackVO.baNo && response.data.externalBackVO.baNo != '') baNo = '\nBA NO:'+response.data.externalBackVO.baNo
          if(response.data.externalBackVO.ctnNo && response.data.externalBackVO.ctnNo != '') ctnNo = '\nCTN NO:'+response.data.externalBackVO.ctnNo
          this.$set(this.subMaterialObj,'goodsDesc',goodName+fromNo+baNo+ctnNo)
162 163 164 165 166 167
          if(this.subMaterialObj.goodsDesc == null){
            this.$set(this.subMaterialObj,'goodsDesc','/')
          }
        }
      })
    },
huhaiqing's avatar
huhaiqing committed
168
    /** 提交 */
huhaiqing's avatar
huhaiqing committed
169
    onSubmit(operateType) {
huhaiqing's avatar
huhaiqing committed
170 171
      this.$refs["subMaterialForm"].validate((valid) => {
        if (valid) {
huhaiqing's avatar
huhaiqing committed
172 173 174 175 176 177
          billCreate({
            ...this.subMaterialObj,
            shipmentId: this.shipmentObj.id,
            operateType,
          }).then((res) => {
            serviceMsg(res, this).then(() => {
178
              if(operateType == 2) this.download()
huhaiqing's avatar
huhaiqing committed
179
              this.cancel("submit");
huhaiqing's avatar
huhaiqing committed
180 181
            });
          });
huhaiqing's avatar
huhaiqing committed
182 183 184 185
        }
      });
    },
    /** 取消 */
huhaiqing's avatar
huhaiqing committed
186 187
    cancel(type) {
      this.$emit("closeDialog", type);
huhaiqing's avatar
huhaiqing committed
188
    },
189 190
    download() {
      getBoxLadingBillPdf({shipmentId: this.shipmentObj.id}).then(res=>{
zhoutong's avatar
zhoutong committed
191
        let blob = new Blob([res], {type: "application/vnd.ms-excel"})
zhoutong's avatar
zhoutong committed
192
        FileSaver.saveAs(blob, this.$t('提单确认件.xlsx')); 
193 194
      })
    }
huhaiqing's avatar
huhaiqing committed
195 196 197 198 199 200
  },
};
</script>

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