trailer.vue 3.5 KB
Newer Older
huhaiiqng's avatar
huhaiiqng committed
1
<template>
huhaiiqng's avatar
huhaiiqng committed
2
  <div>
huhaiqing's avatar
huhaiqing committed
3
    <el-form ref="trailerForm" :rules="rules" :model="trailerObj" label-width="120px">
4 5
      <el-form-item :label="$t('状态')">
        <el-select v-model="trailerObj.tlContainerStatus" :placeholder="$t('请选择状态')">
huhaiqing's avatar
huhaiqing committed
6
          <el-option v-for="type in this.getDictDatas(DICT_TYPE.BOX_SHIPPING_TRAILER_STATUS)" :key="type.value" :label="$l(type, 'label')" :value="type.value"></el-option>
huhaiiqng's avatar
huhaiiqng committed
7 8
        </el-select>
      </el-form-item>
9
      <el-form-item :label="$t('拖车公司')">
zhoutong's avatar
zhoutong committed
10
        <supplierSelect v-model="trailerObj.tlCompanyId" :companyType="'4'" :areaType="0" :placeholder="$t('请选择拖车公司')" :allSupplier="this.$attrs.allSupplier" />
huhaiiqng's avatar
huhaiiqng committed
11
      </el-form-item>
12 13
      <el-form-item :label="$t('拖车时间')" prop="tlTime">
        <el-date-picker type="datetime" :placeholder="$t('请选择日期')" value-format="yyyy-MM-dd HH:mm:ss" v-model="trailerObj.tlTime"></el-date-picker>
huhaiiqng's avatar
huhaiiqng committed
14
      </el-form-item>
15 16
      <el-form-item :label="$t('车牌')">
        <el-input v-model="trailerObj.tlLicensePlate	" :placeholder="$t('请输入车牌')"></el-input>
huhaiiqng's avatar
huhaiiqng committed
17
      </el-form-item>
18 19
      <el-form-item :label="$t('司机')">
        <el-input v-model="trailerObj.tlDriver" :placeholder="$t('请输入司机')"></el-input>
huhaiiqng's avatar
huhaiiqng committed
20
      </el-form-item>
21 22
      <el-form-item :label="$t('司机联系方式')">
        <el-input v-model="trailerObj.tlDriverContact" :placeholder="$t('请输入司机联系方式')"></el-input>
huhaiiqng's avatar
huhaiiqng committed
23
      </el-form-item>
24 25
      <el-form-item :label="$t('货柜号')">
        <el-input v-model="trailerObj.tlContainerNo" :placeholder="$t('请输入货柜号')"></el-input>
huhaiiqng's avatar
huhaiiqng committed
26
      </el-form-item>
27 28
      <el-form-item :label="$t('封条')">
        <el-input v-model="trailerObj.tlStripSeal" :placeholder="$t('请输入封条')"></el-input>
huhaiiqng's avatar
huhaiiqng committed
29 30 31
      </el-form-item>
    </el-form>
    <el-row class="operate-button">
32 33 34
      <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>
huhaiiqng's avatar
huhaiiqng committed
35 36
    </el-row>
  </div>
huhaiiqng's avatar
huhaiiqng committed
37 38 39
</template>

<script>
huhaiqing's avatar
huhaiqing committed
40
import { trailer } from "@/api/ecw/boxSea";
huhaiqing's avatar
huhaiqing committed
41
import supplierSelect from "./common/supplierSelect.vue";
42 43 44 45
import {
  formatStringNumber,
  formatDateStr,
  formatNumberString,
huhaiqing's avatar
huhaiqing committed
46
  serviceMsg,
47
} from "../utils";
huhaiqing's avatar
huhaiqing committed
48 49 50
/**
 * 拖车
 */
huhaiiqng's avatar
huhaiiqng committed
51
export default {
huhaiqing's avatar
huhaiqing committed
52
  inheritAttrs: false,
huhaiiqng's avatar
huhaiiqng committed
53
  name: "trailer",
huhaiqing's avatar
huhaiqing committed
54
  components: { supplierSelect },
huhaiiqng's avatar
huhaiiqng committed
55 56
  data() {
    return {
huhaiqing's avatar
huhaiqing committed
57
      // 拖车对象
huhaiqing's avatar
huhaiqing committed
58
      trailerObj: {},
huhaiqing's avatar
huhaiqing committed
59
      // 校验
huhaiiqng's avatar
huhaiiqng committed
60
      rules: {
61
        tlTime: [{ required: true, message: this.$t("必填"), trigger: "change" }],
huhaiiqng's avatar
huhaiiqng committed
62 63 64
      },
    };
  },
65 66
  created() {
    const { currNode, shipmentObj } = this.$attrs;
67
    const voName = currNode.voName;console.log(shipmentObj[voName])
68 69 70 71 72 73
    let oldData = { ...shipmentObj[voName] };
    oldData = formatNumberString(oldData, ["tlContainerStatus"]);
    oldData = formatStringNumber(oldData, ["tlCompanyId"]);
    oldData = formatDateStr(oldData, ["tlTime"]);
    this.trailerObj = oldData;
  },
huhaiiqng's avatar
huhaiiqng committed
74
  methods: {
huhaiqing's avatar
huhaiqing committed
75
    /** 提交 */
huhaiqing's avatar
huhaiqing committed
76
    onSubmit(operateType) {
huhaiiqng's avatar
huhaiiqng committed
77 78
      this.$refs["trailerForm"].validate((valid) => {
        if (valid) {
huhaiqing's avatar
huhaiqing committed
79 80
          trailer({
            ...this.trailerObj,
huhaiqing's avatar
huhaiqing committed
81
            shipmentId: this.$attrs.shipmentObj.id,
huhaiqing's avatar
huhaiqing committed
82 83 84
            operateType,
          }).then((res) => {
            serviceMsg(res, this).then(() => {
85
              this.cancel("submit");
huhaiqing's avatar
huhaiqing committed
86 87
            });
          });
huhaiiqng's avatar
huhaiiqng committed
88 89 90
        }
      });
    },
huhaiqing's avatar
huhaiqing committed
91
    /** 取消 */
92 93
    cancel(type) {
      this.$emit("closeDialog", type);
huhaiiqng's avatar
huhaiiqng committed
94 95 96 97
    },
  },
};
</script>