arrival.vue 4.42 KB
Newer Older
huhaiqing's avatar
huhaiqing committed
1 2 3
<template>
  <div>
    <el-form ref="arrivalForm" :rules="rules" :model="arrivalObj" label-width="120px">
4 5 6
      <el-form-item :label="$t('预计到港时间')">{{getExpectedTime()}}</el-form-item>
      <el-form-item :label="$t('实际到港时间')" prop="apRealTime">
        <el-date-picker type="datetime" :placeholder="$t('请选择日期')" v-model="arrivalObj.apRealTime" value-format="yyyy-MM-dd HH:mm:ss"></el-date-picker>
huhaiqing's avatar
huhaiqing committed
7
      </el-form-item>
8 9
      <el-form-item :label="$t('确认到港')">
        <el-date-picker type="datetime" :placeholder="$t('请选择日期')" v-model="arrivalObj.apConfirmTime" value-format="yyyy-MM-dd HH:mm:ss">
huhaiqing's avatar
huhaiqing committed
10
        </el-date-picker>
11
        <p class="message-area" v-show="showMsg">{{$t('请确认是否有异常,如有异常请进行异常登记')}}</p>
huhaiqing's avatar
huhaiqing committed
12
      </el-form-item>
13 14
      <el-form-item :label="$t('卸港时间')">
        <el-date-picker type="datetime" :placeholder="$t('请选择日期')" v-model="arrivalObj.apUnloadPortTime" 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 22
      <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>
      <el-button type="primary" @click="exceptionReg" :disabled="!showMsg">{{$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 dayjs from "dayjs";
huhaiqing's avatar
huhaiqing committed
35 36
import { arrivalCreate } from "@/api/ecw/boxSea";
import { formatDateStr, serviceMsg } from "../utils";
huhaiqing's avatar
huhaiqing committed
37 38 39 40 41 42

/**
 * 到港
 */
export default {
  name: "arrival",
huhaiqing's avatar
huhaiqing committed
43
  inheritAttrs: false,
huhaiqing's avatar
huhaiqing committed
44 45 46 47 48 49
  components: {
    regError,
  },
  data() {
    return {
      // 到港对象
huhaiqing's avatar
huhaiqing committed
50
      arrivalObj: {},
huhaiqing's avatar
huhaiqing committed
51 52
      // 校验
      rules: {
huhaiqing's avatar
huhaiqing committed
53 54 55
        apRealTime: [
          { required: true, message: this.$t("必填"), trigger: "change" },
        ],
huhaiqing's avatar
huhaiqing committed
56 57 58 59 60
      },
      // 弹窗配置
      dialogVisible: false,
      // 提示消息
      showMsg: false,
huhaiqing's avatar
huhaiqing committed
61 62 63
      inspectionTimeArrival: this.getDictDatas(
        this.DICT_TYPE.BOX_INSPECTION_TIME_ARRIVAL
      )[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 71 72 73 74
    oldData = formatDateStr(
      oldData,
      ["apRealTime", "apConfirmTime"],
      "YYYY-MM-DD HH:mm:ss"
    );
    oldData = formatDateStr(oldData, ["apUnloadPortTime"]);
huhaiqing's avatar
huhaiqing committed
75 76
    this.arrivalObj = oldData;
  },
huhaiqing's avatar
huhaiqing committed
77 78
  watch: {
    // 确认到港时间
huhaiqing's avatar
huhaiqing committed
79
    "arrivalObj.apConfirmTime"(val) {
huhaiqing's avatar
huhaiqing committed
80
      this.compareDate(this.getExpectedTime(), val);
huhaiqing's avatar
huhaiqing committed
81 82 83
    },
  },
  methods: {
huhaiqing's avatar
huhaiqing committed
84 85 86 87 88 89
    regCloseDialog(type) {
      this.dialogVisible = false;
      if (type === "error") {
        this.$emit("getBoxInfo");
      }
    },
huhaiqing's avatar
huhaiqing committed
90 91
    // 获取预计到港时间
    getExpectedTime() {
huhaiqing's avatar
huhaiqing committed
92 93
      const { shippingInfo } = this.$attrs.shipmentObj;
      if (shippingInfo) {
huhaiqing's avatar
huhaiqing committed
94 95 96
        return dayjs(shippingInfo.dtEstArrivalTime).format(
          "YYYY-MM-DD HH:mm:ss"
        );
huhaiqing's avatar
huhaiqing committed
97 98
      }
      return null;
huhaiqing's avatar
huhaiqing committed
99
    },
huhaiqing's avatar
huhaiqing committed
100
    // 时间比较
huhaiqing's avatar
huhaiqing committed
101
    compareDate(expectedTime, apConfirmTime) {
huhaiqing's avatar
huhaiqing committed
102 103 104 105
      this.showMsg = false;
      let date1 = null,
        date2 = null;
      if (expectedTime) date1 = dayjs(expectedTime);
huhaiqing's avatar
huhaiqing committed
106
      if (apConfirmTime) date2 = dayjs(apConfirmTime);
huhaiqing's avatar
huhaiqing committed
107
      if (date1 && date2) {
huhaiqing's avatar
huhaiqing committed
108
        const days = date2.diff(date1, "day");
huhaiqing's avatar
huhaiqing committed
109
        if (days > this.inspectionTimeArrival) {
huhaiqing's avatar
huhaiqing committed
110 111 112 113 114 115 116 117 118
          this.showMsg = true;
        }
      }
    },
    // 异常登记
    exceptionReg() {
      this.dialogVisible = true;
    },
    /** 提交 */
huhaiqing's avatar
huhaiqing committed
119
    onSubmit(operateType) {
huhaiqing's avatar
huhaiqing committed
120 121
      this.$refs["arrivalForm"].validate((valid) => {
        if (valid) {
huhaiqing's avatar
huhaiqing committed
122 123 124 125 126 127
          arrivalCreate({
            ...this.arrivalObj,
            shipmentId: this.$attrs.shipmentObj.id,
            operateType,
          }).then((res) => {
            serviceMsg(res, this).then(() => {
huhaiqing's avatar
huhaiqing committed
128
              this.cancel("submit");
huhaiqing's avatar
huhaiqing committed
129 130
            });
          });
huhaiqing's avatar
huhaiqing committed
131 132 133 134
        }
      });
    },
    /** 取消 */
huhaiqing's avatar
huhaiqing committed
135 136
    cancel(type) {
      this.$emit("closeDialog", type);
huhaiqing's avatar
huhaiqing committed
137 138 139 140 141 142 143 144 145 146 147
    },
  },
};
</script>

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