departure.vue 4.62 KB
Newer Older
huhaiqing's avatar
huhaiqing committed
1 2 3
<template>
  <div class="app-departure">
    <el-form ref="departureForm" :rules="rules" :model="departureObj" label-width="120px">
4
      <el-form-item :label="$t('预计开船时间')">
huhaiqing's avatar
huhaiqing committed
5
        {{getSailingTime()}}
huhaiqing's avatar
huhaiqing committed
6
      </el-form-item>
7 8 9 10
      <el-form-item :label="$t('实际开船时间')">
        <el-date-picker type="datetime" :placeholder="$t('请选择日期')" v-model="departureObj.dtRealShipTime" value-format="yyyy-MM-dd HH:mm:ss"></el-date-picker>
        <p class="message-area">{{$t('订单状态与短信通知,将到指定时间更新与发送')}}</p>
        <p class="message-area" v-show="showMsg">{{$t('实际开船实际与预计时间不符')}}</p>
huhaiqing's avatar
huhaiqing committed
11 12
      </el-form-item>

13 14
      <el-form-item :label="$t('预期到港时间')" prop="dtEstArrivalTime">
        <el-date-picker type="datetime" :placeholder="$t('请选择日期')" v-model="departureObj.dtEstArrivalTime" value-format="yyyy-MM-dd HH:mm:ss"></el-date-picker>
huhaiqing's avatar
huhaiqing committed
15 16 17 18
      </el-form-item>
    </el-form>

    <el-row class="operate-button">
19 20 21
      <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>
huhaiqing's avatar
huhaiqing committed
22
      <el-button type="primary" @click="exceptionReg" :disabled="!isShowError">{{$t('异常登记')}}</el-button>
huhaiqing's avatar
huhaiqing committed
23 24 25
    </el-row>

    <!-- 对话框 -->
26
    <el-dialog custom-class="shipping-dialog" :title="$t('票异常')" :visible.sync="dialogVisible" width="700px" :modal-append-to-body=false append-to-body destroy-on-close>
huhaiqing's avatar
huhaiqing committed
27
      <regError @closeDialog="regCloseDialog" v-bind="$attrs" />
huhaiqing's avatar
huhaiqing committed
28 29 30 31 32
    </el-dialog>
  </div>
</template>

<script>
huhaiqing's avatar
huhaiqing committed
33
import regError from "../../regError";
huhaiqing's avatar
huhaiqing committed
34
import { shippingCreate } from "@/api/ecw/boxSea";
huhaiqing's avatar
huhaiqing committed
35
import dayjs from "dayjs";
huhaiqing's avatar
huhaiqing committed
36
import { formatDateStr, serviceMsg } from "../utils";
huhaiqing's avatar
huhaiqing committed
37

huhaiqing's avatar
huhaiqing committed
38 39 40 41 42
/**
 * 起运
 */
export default {
  name: "departure",
huhaiqing's avatar
huhaiqing committed
43
  inheritAttrs: false,
huhaiqing's avatar
huhaiqing committed
44
  components: { regError },
huhaiqing's avatar
huhaiqing committed
45 46 47 48 49 50
  data() {
    return {
      // 起运对象
      departureObj: {},
      // 校验
      rules: {
huhaiqing's avatar
huhaiqing committed
51
        dtEstArrivalTime: [
52
          { required: true, message: this.$t("必填"), trigger: "change" },
huhaiqing's avatar
huhaiqing committed
53
        ],
huhaiqing's avatar
huhaiqing committed
54 55 56 57 58
      },
      // 弹窗配置
      dialogVisible: false,
      // 提示消息
      showMsg: false,
huhaiqing's avatar
huhaiqing committed
59 60 61 62 63
      // 异常登记
      isShowError: false,
      inspectionTimeShipping: this.getDictDatas(
        this.DICT_TYPE.BOX_INSPECTION_TIME_SHIPPING
      )[0].value,
huhaiqing's avatar
huhaiqing committed
64 65
    };
  },
huhaiqing's avatar
huhaiqing committed
66 67 68
  created() {
    const voName = this.$attrs.currNode.voName;
    let oldData = { ...this.$attrs.shipmentObj[voName] };
huhaiqing's avatar
huhaiqing committed
69 70
    oldData = formatDateStr(oldData, ["dtRealShipTime"], "YYYY-MM-DD HH:mm:ss");
    oldData = formatDateStr(oldData, ["dtEstArrivalTime"]);
huhaiqing's avatar
huhaiqing committed
71 72
    this.departureObj = oldData;
  },
huhaiqing's avatar
huhaiqing committed
73 74
  watch: {
    // 实际开船时间
huhaiqing's avatar
huhaiqing committed
75
    "departureObj.dtRealShipTime"(val) {
huhaiqing's avatar
huhaiqing committed
76
      this.compareDate(val, this.getSailingTime());
huhaiqing's avatar
huhaiqing committed
77
      this.compareDate1(val, this.getSailingTime());
huhaiqing's avatar
huhaiqing committed
78 79 80
    },
  },
  methods: {
huhaiqing's avatar
huhaiqing committed
81 82 83 84 85 86
    regCloseDialog(type) {
      this.dialogVisible = false;
      if (type === "error") {
        this.$emit("getBoxInfo");
      }
    },
huhaiqing's avatar
huhaiqing committed
87
    // 时间比较
huhaiqing's avatar
huhaiqing committed
88
    compareDate(dtRealShipTime, sailTime) {
huhaiqing's avatar
huhaiqing committed
89 90 91
      this.showMsg = false;
      let date1 = null,
        date2 = null;
huhaiqing's avatar
huhaiqing committed
92 93 94
      if (dtRealShipTime) date1 = dayjs(dtRealShipTime);
      if (sailTime) date2 = dayjs(sailTime);
      if (date1 && date2 && date1.isAfter(date2)) {
huhaiqing's avatar
huhaiqing committed
95 96 97
        this.showMsg = true;
      }
    },
huhaiqing's avatar
huhaiqing committed
98 99 100 101 102 103 104 105 106 107 108
    compareDate1(dtRealShipTime, sailTime) {
      this.isShowError = false;
      let date1 = null,
        date2 = null;
      if (dtRealShipTime) date1 = dayjs(dtRealShipTime);
      if (sailTime) date2 = dayjs(sailTime);
      if (date1 && date2) {
        const delayDay = date1.diff(date2, "day");
        if (delayDay >= this.inspectionTimeShipping) this.isShowError = true;
      }
    },
huhaiqing's avatar
huhaiqing committed
109 110 111 112 113
    // 异常登记
    exceptionReg() {
      this.dialogVisible = true;
    },
    /** 提交 */
huhaiqing's avatar
huhaiqing committed
114
    onSubmit(operateType) {
huhaiqing's avatar
huhaiqing committed
115
      this.$refs["departureForm"].validate((valid) => {
huhaiqing's avatar
huhaiqing committed
116
        if (valid) {
huhaiqing's avatar
huhaiqing committed
117 118 119 120 121 122
          shippingCreate({
            ...this.departureObj,
            shipmentId: this.$attrs.shipmentObj.id,
            operateType,
          }).then((res) => {
            serviceMsg(res, this).then(() => {
huhaiqing's avatar
huhaiqing committed
123
              this.cancel("submit");
huhaiqing's avatar
huhaiqing committed
124 125
            });
          });
huhaiqing's avatar
huhaiqing committed
126 127 128 129
        }
      });
    },
    /** 取消 */
huhaiqing's avatar
huhaiqing committed
130 131 132 133 134 135
    cancel(type) {
      this.$emit("closeDialog", type);
    },
    // 预计开船时间
    getSailingTime() {
      return dayjs(this.$attrs.shipmentObj.bookSeaInfo.sailTime).format(
huhaiqing's avatar
huhaiqing committed
136
        "YYYY-MM-DD HH:mm:ss"
huhaiqing's avatar
huhaiqing committed
137
      );
huhaiqing's avatar
huhaiqing committed
138 139 140 141 142 143 144 145 146 147 148 149 150
    },
  },
};
</script>

<style lang="scss" scoped>
.app-departure {
  .message-area {
    margin: 0;
    color: red;
  }
}
</style>