<template>
  <div>
    <el-form ref="cusClearanceForm" :rules="rules" :model="cusClearanceObj" label-width="160px">
      <el-form-item :label="$t('清关情况')" prop="arriveType">
        <el-radio-group v-model="cusClearanceObj.clearanceType">
          <el-radio :label="0">{{ $t('一次清关') }}</el-radio>
          <el-radio :label="1">{{ $t('多次清关') }}</el-radio>
        </el-radio-group>
      </el-form-item>
      <el-form-item :label="$t('选择订单')" prop="clearanceOrderIdList" v-show="cusClearanceObj.clearanceType == 1">
        <span v-for="order in selectOrders" :key="order.id">{{ order.orderNo }} </span>
        <el-button type="primary" @click="orderdialogVisible = true">{{ $t('订单列表') }}</el-button>
      </el-form-item>
      <el-form-item :label="$t('已清关订单')" v-show="cusClearanceObj.clearanceType == 1">
        <span v-for="order in cusClearanceObj.clearanceOrderList" :key="order.id">{{ order.orderNo }} </span>
      </el-form-item>

      <div>
        <el-form ref="airArrivalForm" :rules="airArrivalrules" :model="airArrivalInfo" label-width="160px">
          <el-form-item :label="$t('实际二程起飞时间')" prop="actSecondTime">
            <el-date-picker type="datetime" :placeholder="$t('请选择日期')" v-model="airArrivalInfo.actSecondTime" value-format="yyyy-MM-dd HH:mm:ss"></el-date-picker>
          </el-form-item>
          <el-form-item :label="$t('预计到港时间')" prop="estTime">
            <el-date-picker type="datetime" :placeholder="$t('请选择日期')" v-model="airArrivalInfo.estTime" value-format="yyyy-MM-dd HH:mm:ss"></el-date-picker>
          </el-form-item>
          <el-form-item :label="$t('实际到港时间')" prop="actTime">
            <el-date-picker type="datetime" :placeholder="$t('请选择日期')" v-model="airArrivalInfo.actTime" value-format="yyyy-MM-dd HH:mm:ss"></el-date-picker>
          </el-form-item>
        </el-form>
      </div>

      <el-form-item :label="$t('预计清关时间')" prop="clEstTime">
        <el-date-picker type="datetime" :placeholder="$t('请选择日期')" v-model="cusClearanceObj.clEstTime" value-format="yyyy-MM-dd HH:mm:ss"></el-date-picker>
      </el-form-item>
      <el-form-item :label="$t('清关时间')" prop="clClearTime">
        <el-date-picker type="datetime" :placeholder="$t('请选择日期')" v-model="cusClearanceObj.clClearTime" value-format="yyyy-MM-dd HH:mm:ss"></el-date-picker>
        <p class="message-area" v-show="showMsg">
          {{ $t('清关时间与预计时间不符,如有异常请登记') }}
        </p>
      </el-form-item>
    </el-form>

    <el-row class="operate-button">
      <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>
    </el-row>

    <!-- 对话框 -->
    <el-dialog custom-class="shipping-dialog" :title="$t('票异常')" :visible.sync="dialogVisible" width="700px" :modal-append-to-body="false" append-to-body destroy-on-close>
      <regError @closeDialog="dialogVisible = false" v-bind="$attrs" />
    </el-dialog>
    <!-- 订单列表 -->
    <el-dialog width="70%" :title="$t('选择订单')" :visible.sync="orderdialogVisible" :modal-append-to-body="false" append-to-body destroy-on-close>
      <el-row :gutter="10">
        <el-col :span="7">
          {{ $t('关键字:') }}
          <el-input style="width: 300px" v-model="searchForm.orderKeyword" :placeholder="$t('请输入订单号、提单号、唛头')" />
        </el-col>
        <el-col :span="5">
          {{ $t('到港状态') }}
          <el-select v-model="searchForm.orderPortStatus">
            <el-option :value="0" :label="$t('未到港')" />
            <el-option :value="1" :label="$t('已到港')" />
          </el-select>
        </el-col>
        <el-col :span="5">
          {{ $t('清关状态') }}
          <el-select v-model="searchForm.orderCustomsClearanceStatus">
            <el-option :value="0" :label="$t('未清关')" />
            <el-option :value="1" :label="$t('已清关')" />
          </el-select>
        </el-col>
        <el-col :span="4">
          <el-button type="primary" @click="searchOrderList"> {{ $t('查询') }}</el-button>
          <el-button type="primary" @click="reloafSearch"> {{ $t('重置') }}</el-button>
        </el-col>
      </el-row>
      <div style="margin-top: 10px">
        <el-button type="primary" @click="multipleSelect">
          {{ $t('批量选择') }}
        </el-button>
      </div>
      <el-table style="margin-top: 10px" :data="statusOrderList" @selection-change="handleSelectionChange">
        <el-table-column type="selection" width="55"> </el-table-column>
        <el-table-column :label="$t('序号')" type="index" width="50"> </el-table-column>
        <el-table-column :label="$t('订单号')" prop="orderNo" />
        <el-table-column :label="$t('唛头')" prop="marks" />
        <el-table-column :label="$t('提单号')" prop="tidanNo" />
        <el-table-column width="150" :label="$t('总箱数/入仓箱数')">
          <template slot-scope="scope"> {{ scope.row.totalNum }}/{{ scope.row.sumNum }} </template>
        </el-table-column>
        <el-table-column :label="$t('体积/重量')" prop="">
          <template slot-scope="scope"> {{ scope.row.sumVolume }}/{{ scope.row.sumWeight }} </template>
        </el-table-column>
        <el-table-column :label="$t('到港状态')" prop="arrival" />
        <el-table-column :label="$t('到港状态')" prop="clear" />
        <el-table-column :label="$t('控货')">
          <template slot-scope="scope">
            {{ cargoControlStatus[scope.row.cargoControlStatus] }}
          </template>
        </el-table-column>
        <el-table-column :label="$t('订单状态')" prop="statusMsg" />
        <el-table-column :label="$t('操作')">
          <template slot-scope="scope">
            <el-button size="mini" type="primary" @click="selectOrder(scope.row)">{{ $t('选择') }}</el-button>
          </template>
        </el-table-column>
      </el-table>
    </el-dialog>
  </div>
</template>

<script>
import regError from '../../regError'
import dayjs from 'dayjs'
import { clearanceCreate } from '@/api/ecw/boxSea'
import { shipmentOrderList } from '@/api/ecw/boxAir'
import { formatDateStr, serviceMsg, formatDate } from '../utils'
import { updateOrderArrival } from '@/api/ecw/boxAir'

/**
 * 清关
 */
export default {
  name: 'cusClearance',
  inheritAttrs: false,
  components: {
    regError
  },
  data() {
    return {
      // 清关对象
      cusClearanceObj: {},
      // 校验
      rules: {
        clEstTime: [{ required: true, message: this.$t('必填'), trigger: 'change' }],
        clClearTime: [{ required: true, message: this.$t('必填'), trigger: 'change' }]
      },
      airArrivalrules: {
        actSecondTime: [{ required: true, message: this.$t('必填'), trigger: 'change' }],
        actTime: [{ required: true, message: this.$t('必填'), trigger: 'change' }]
      },
      // 弹窗配置
      dialogVisible: false,
      // 提示消息
      showMsg: false,
      orderList: [],
      arrivalOrderList: [],
      clearanceOrderList: [],
      airArrivalInfo: {},
      orderdialogVisible: false,
      selectOrders: [],
      multipleSelectOrder: [],
      cargoControlStatus: [this.$t('控货中'), this.$t('已放完货'), this.$t('部分控货')],
      searchForm: {
        orderKeyword: null,
        orderPortStatus: null,
        orderCustomsClearanceStatus: null
      },
      searchFormFilter: {}
    }
  },
  created() {
    const voName = this.$attrs.currNode.voName
    let oldData = { ...this.$attrs.shipmentObj[voName] }
    oldData = formatDateStr(oldData, ['clEstTime'])
    oldData = formatDateStr(oldData, ['clClearTime'], 'YYYY-MM-DD HH:mm:ss')
    this.cusClearanceObj = oldData
    if (!this.cusClearanceObj.clearanceType) this.$set(this.cusClearanceObj, 'clearanceType', 0)
    this.$set(this.cusClearanceObj, 'clearanceOrderIdList', [])
    if (typeof this.$attrs.shipmentObj.airArrivalInfo?.arrivalOrderList != 'undefined' && this.$attrs.shipmentObj.airArrivalInfo.arrivalOrderList) this.arrivalOrderList = this.$attrs.shipmentObj.airArrivalInfo.arrivalOrderList
    if (typeof this.$attrs.shipmentObj.clearanceInfo?.clearanceOrderList != 'undefined' && this.$attrs.shipmentObj.clearanceInfo.clearanceOrderList) this.clearanceOrderList = this.$attrs.shipmentObj.clearanceInfo.clearanceOrderList
    shipmentOrderList(this.$attrs.shipmentObj.id).then((r) => {
      this.orderList = r.data
    })
  },
  watch: {
    // 预计清关时间
    'cusClearanceObj.clEstTime'(val) {
      this.compareDate(val, this.cusClearanceObj.clClearTime)
    },
    // 清关时间
    'cusClearanceObj.clClearTime'(val) {
      this.compareDate(this.cusClearanceObj.clEstTime, val)
    },
    'cusClearanceObj.clearanceType'(val) {
      if (val == 1) {
        this.$set(this.cusClearanceObj, 'clEstTime', null)
        this.$set(this.cusClearanceObj, 'clClearTime', null)
      } else {
        let oldData = {
          ...this.$attrs.shipmentObj[this.$attrs.currNode.voName]
        }
        oldData = formatDateStr(oldData, ['clEstTime', 'clClearTime'], 'YYYY-MM-DD HH:mm:ss')
        this.$set(this.cusClearanceObj, 'clClearTime', oldData.clClearTime)
        this.$set(this.cusClearanceObj, 'clEstTime', oldData.clEstTime)
      }
    }
  },
  computed: {
    statusOrderList() {
      let data = []
      this.orderList.forEach((item) => {
        let json = {
          orderId: item.orderId,
          orderNo: item.orderNo,
          tidanNo: item.tidanNo,
          marks: item.marks,
          sumNum: item.sumNum,
          totalNum: item.totalNum,
          sumVolume: item.sumVolume,
          sumWeight: item.sumWeight,
          statusMsg: item.statusMsg,
          cargoControlStatus: item.cargoControlStatus
        }
        let clearindex = this.cusClearanceObj.clearanceOrderList ? this.cusClearanceObj.clearanceOrderList.findIndex((p) => p.orderId == item.orderId) : -1
        if (clearindex != -1) {
          json.clear = this.$t('已清关')
          json.clearValue = 1
        } else {
          json.clear = this.$t('未清关')
          json.clearValue = 0
        }
        let arrivalindex = this.arrivalOrderList ? this.arrivalOrderList.findIndex((p) => p.orderId == item.orderId) : -1
        if (arrivalindex != -1) {
          json.arrival = this.$t('已到港')
          json.arrivalValue = 1
        } else {
          json.arrival = this.$t('未到港')
          json.arrivalValue = 0
        }
        data.push(json)
      })
      if (this.searchFormFilter.orderKeyword && this.searchFormFilter.orderKeyword != '') {
        data = data.filter((item) => {
          return (item.orderNo && item.orderNo.indexOf(this.searchFormFilter.orderKeyword) > -1) || (item.tidanNo && item.tidanNo.indexOf(this.searchFormFilter.orderKeyword) > -1) || (item.marks && item.marks.indexOf(this.searchFormFilter.orderKeyword) > -1)
        })
      }
      if (this.searchFormFilter.orderPortStatus != null) {
        data = data.filter((item) => {
          return item.arrivalValue == this.searchFormFilter.orderPortStatus
        })
      }
      if (this.searchFormFilter.orderCustomsClearanceStatus != null) {
        data = data.filter((item) => {
          return item.clearValue == this.searchFormFilter.orderCustomsClearanceStatus
        })
      }
      return data
    }
  },
  methods: {
    formatDate,
    searchOrderList() {
      this.searchFormFilter = JSON.parse(JSON.stringify(this.searchForm))
    },
    reloafSearch() {
      this.searchForm = {}
      this.searchOrderList()
    },
    selectOrder(val) {
      this.selectOrders = []
      this.selectOrders.push(val)
      let arr = this.arrivalOrderList.find((item) => item.orderId == val.orderId)
      if (arr) {
        this.$set(this.airArrivalInfo, 'actSecondTime', formatDate(arr.actSecondTime))
        this.$set(this.airArrivalInfo, 'estTime', formatDate(arr.estTime))
        this.$set(this.airArrivalInfo, 'actTime', formatDate(arr.actTime))
      }
      let clear = this.clearanceOrderList.find((item) => item.orderId == val.orderId)
      if (clear) {
        this.$set(this.cusClearanceObj, 'clEstTime', formatDate(clear.clEstTime))
        this.$set(this.cusClearanceObj, 'clClearTime', formatDate(clear.clClearTime))
      }
      this.orderdialogVisible = false
      this.cusClearanceObj.clearanceOrderIdList.push(val.orderId)
    },
    handleSelectionChange(val) {
      this.multipleSelectOrder = val
    },
    multipleSelect() {
      if (this.multipleSelectOrder.length == 0) {
        this.$message.error(this.$t('请先选择订单'))
        return
      }
      this.selectOrders = []
      this.selectOrders = this.multipleSelectOrder
      if (this.multipleSelectOrder.length == 1) {
        let arr = this.arrivalOrderList.find((item) => item.orderId == this.multipleSelectOrder[0].orderId)
        if (arr) {
          this.$set(this.airArrivalInfo, 'actSecondTime', formatDate(arr.actSecondTime))
          this.$set(this.airArrivalInfo, 'estTime', formatDate(arr.estTime))
          this.$set(this.airArrivalInfo, 'actTime', formatDate(arr.actTime))
        }
        let clear = this.clearanceOrderList.find((item) => item.orderId == this.multipleSelectOrder[0].orderId)
        if (clear) {
          this.$set(this.cusClearanceObj, 'clEstTime', formatDate(clear.clEstTime))
          this.$set(this.cusClearanceObj, 'clClearTime', formatDate(clear.clClearTime))
        }
      } else {
        this.$set(this.airArrivalInfo, 'actSecondTime', null)
        this.$set(this.airArrivalInfo, 'estTime', null)
        this.$set(this.airArrivalInfo, 'actTime', null)
        this.$set(this.cusClearanceObj, 'clEstTime', null)
        this.$set(this.cusClearanceObj, 'clClearTime', null)
      }
      this.orderdialogVisible = false
      this.cusClearanceObj.clearanceOrderIdList = this.multipleSelectOrder.map((item) => item.orderId)
    },
    getClAgent(type) {
      const agentId = this.$attrs.shipmentObj.agentInfo.agentId
      if (type === 'label') {
        const selected = this.$attrs.allSupplier.find((item) => item.id === agentId)
        return this.$l(selected, 'company') ?? agentId
      }
      return agentId
    },
    // 时间比较
    compareDate(clEstTime, clClearTime) {
      this.showMsg = false
      let date1 = null,
        date2 = null
      if (clEstTime) date1 = dayjs(clEstTime)
      if (clClearTime) date2 = dayjs(clClearTime)
      if (date1 && date2 && !date2.isSame(date1)) {
        this.showMsg = true
      }
    },
    // 异常登记
    exceptionReg() {
      this.dialogVisible = true
    },
    /** 提交 */
    onSubmit(operateType) {
      this.$refs['cusClearanceForm'].validate((valid) => {
        if (valid) {
          if (this.cusClearanceObj.clearanceType == 1 && this.cusClearanceObj.clearanceOrderIdList.length > 0) {
            this.$refs['airArrivalForm'].validate((arrvalid) => {
              if (arrvalid) {
                updateOrderArrival({
                  ...this.airArrivalInfo,
                  shipmentId: this.$attrs.shipmentObj.id,
                  orderIdList: this.cusClearanceObj.clearanceOrderIdList
                }).then(() => {
                  clearanceCreate({
                    ...this.cusClearanceObj,
                    shipmentId: this.$attrs.shipmentObj.id,
                    clAgentId: this.getClAgent(),
                    operateType
                  }).then((res) => {
                    serviceMsg(res, this).then(() => {
                      this.cancel('submit')
                    })
                  })
                })
              }
            })
          } else {
            clearanceCreate({
              ...this.cusClearanceObj,
              shipmentId: this.$attrs.shipmentObj.id,
              clAgentId: this.getClAgent(),
              operateType
            }).then((res) => {
              serviceMsg(res, this).then(() => {
                this.cancel('submit')
              })
            })
          }
        }
      })
    },
    /** 取消 */
    cancel(type) {
      this.$emit('closeDialog', type)
    }
  }
}
</script>

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