<template>
  <div class="app-container">
    <!-- 搜索工作栏 -->
    <el-form
      :model="queryParams"
      ref="queryForm"
      size="small"
      :inline="true"
      v-show="showSearch"
      label-width="68px"
    >
      <el-form-item label="自编号" prop="selfNo">
        <el-input
          v-model="queryParams.selfNo"
          placeholder="请输入自编号"
          clearable
          @keyup.enter.native="handleQuery"
        />
      </el-form-item>
      <el-form-item label="柜号" prop="cubNo">
        <el-input
          v-model="queryParams.cubNo"
          placeholder="请输入柜号"
          clearable
          @keyup.enter.native="handleQuery"
        />
      </el-form-item>
      <el-form-item label="柜型" prop="cabinetId">
        <el-select v-model="queryParams.cabinetId" placeholder="请选择柜型">
          <el-option
            v-for="item in cabinetList"
            :label="item.name"
            :value="item.name"
            :key="item.id"
          ></el-option>
        </el-select>
      </el-form-item>

      <el-form-item label="始发地" prop="startWarehouseId">
        <el-select
          v-model="queryParams.startWarehouseId"
          placeholder="请选择始发地"
        >
          <el-option
            v-for="item in exportWarehouseList"
            :label="item.titleZh"
            :value="item.id"
            :key="item.id"
          ></el-option>
        </el-select>
      </el-form-item>

      <el-form-item label="目的地" prop="destWarehouseId">
        <el-select
          v-model="queryParams.destWarehouseId"
          placeholder="请选择目的地"
        >
          <el-option
            v-for="item in importWarehouseList"
            :label="item.titleZh"
            :value="item.id"
            :key="item.id"
          ></el-option>
        </el-select>
      </el-form-item>

      <el-form-item label="" prop="date">
        <el-select
          v-model="queryParams.dateType"
          placeholder="请选择时间类型"
          clearable
          size="small"
        >
          <el-option
            v-for="item in dateTypes"
            :key="item.value"
            :label="item.label"
            :value="item.value"
          />
        </el-select>
      </el-form-item>

      <el-form-item label="">
        <el-date-picker
          v-model="queryParams.dateRangeCreateTime"
          style="width: 240px"
          value-format="yyyy-MM-dd HH:mm:ss"
          type="datetimerange"
          range-separator="-"
          start-placeholder="开始日期"
          end-placeholder="结束日期"
        />
      </el-form-item>

      <el-form-item label="状态" prop="boxStatus">
        <el-select
          v-model="queryParams.boxStatus"
          placeholder="请选择状态"
          clearable
          size="small"
        >
          <el-option
            v-for="dict in this.getDictDatas(DICT_TYPE.BOX_SHIPMENT_STATUS)"
            :key="dict.value"
            :label="dict.label"
            :value="dict.value"
          />
        </el-select>
      </el-form-item>

      <el-form-item>
        <el-button type="primary" icon="el-icon-search" @click="handleQuery"
          >搜索</el-button
        >
        <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
      </el-form-item>
    </el-form>

    <!-- 操作工具栏 -->
    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button
          type="primary"
          plain
          icon="el-icon-plus"
          size="mini"
          @click="handleAdd"
          v-hasPermi="['shipment:box:create']"
          >出货安排
        </el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="warning"
          plain
          icon="el-icon-download"
          size="mini"
          @click="handleExport"
          :loading="exportLoading"
          v-hasPermi="['shipment:box:export']"
          >导出
        </el-button>
      </el-col>
      <right-toolbar
        :showSearch.sync="showSearch"
        @queryTable="getList"
      ></right-toolbar>
    </el-row>

    <!-- 列表 -->
    <el-table v-loading="loading" :data="list">
      <el-table-column label="自编号" align="center" prop="selfNo">
        <template slot-scope="scope">
          <a href="javascript:void(0)" @click="handleCommand(scope.row, 'detail')">{{ scope.row.selfNo }}</a>
        </template>
      </el-table-column>
      <el-table-column label="柜号" align="center" prop="cubNo" />
      <el-table-column label="柜型" align="center" prop="cabinetId">
        <template slot-scope="scope">
          <span>{{ getCabinetName(scope.row.cabinetId) }}</span>
        </template>
      </el-table-column>
      <el-table-column label="运输方式" align="center" prop="transportType">
        <template slot-scope="scope">
          <dict-tag
            :type="DICT_TYPE.ECW_TRANSPORT_TYPE"
            :value="scope.row.transportType"
          />
        </template>
      </el-table-column>

      <el-table-column label="出货渠道" align="center" prop="shippingChannelId">
        <template slot-scope="scope">
          <span>{{ getShipChannelName(scope.row.shippingChannelId) }}</span>
        </template>
      </el-table-column>

      <el-table-column
        label="方数(预装/已装)"
        align="center"
        prop="squareNumber"
      >
        <template slot-scope="{ row }">
          {{ row.boxStatistics.volume }}/{{ row.boxStatistics.loadVolume }}
        </template>
      </el-table-column>
      <el-table-column label="重量(预装/已装)" align="center" prop="weight">
        <template slot-scope="{ row }">
          {{ row.boxStatistics.weight }}/{{ row.boxStatistics.loadWeight }}
        </template>
      </el-table-column>

      <el-table-column label="状态" align="center" prop="shipmentStatusText" />

      <el-table-column
        label="日期"
        align="center"
        prop="createTime"
        width="180"
      >
        <template slot-scope="scope">
          <span>{{
            new Date(scope.row.createTime).format('yyyy-MM-dd hh:mm:ss')
          }}</span>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" width="200px">
        <template slot-scope="scope">
          <!-- <el-button size="mini" type="text" icon="el-icon-view" @click="handleView(scope.row)"
                     v-hasPermi="['shipment:box:query']">查看</el-button>
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
                     v-hasPermi="['shipment:box:update']">修改</el-button>
          <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
                     v-hasPermi="['shipment:box:delete']">删除</el-button> -->
          <el-dropdown
            trigger="click"
            @command="(command) => handleCommand(scope.row, command)"
            style="marginRight:10px;"
          >
            <el-button type="primary">
              操作<i class="el-icon-arrow-down el-icon--right"></i>
            </el-button>
            <el-dropdown-menu slot="dropdown">
              <el-dropdown-item command="edit">编辑</el-dropdown-item>
              <el-dropdown-item command="seaAir"
                >操作-海空联运</el-dropdown-item
              >
              <el-dropdown-item command="error">异常登记</el-dropdown-item>
              <el-dropdown-item command="cost">费用登记</el-dropdown-item>
              <el-dropdown-item command="delete">删除</el-dropdown-item>
              <el-dropdown-item v-if="scope.row.ldStatus>42" command="editLadingBill">编辑提货单</el-dropdown-item>
            </el-dropdown-menu>
          </el-dropdown>
          <el-dropdown trigger="click" @command="(command)=>handleCommand(scope.row, command)">
            <el-button type="primary">
              下载<i class="el-icon-arrow-down el-icon--right"></i>
            </el-button>
            <el-dropdown-menu slot="dropdown">
              <el-dropdown-item command="downloadPreloadGoodsList">预装单</el-dropdown-item>
              <el-dropdown-item command="downloadLoadGoodsList">已装单</el-dropdown-item>
              <el-dropdown-item command="downloadReceivableList">应收汇总表</el-dropdown-item>
              <el-dropdown-item command="downloadAgentListFiles">agent list</el-dropdown-item>
              <el-dropdown-item command="downloadSoncapFiles">soncap</el-dropdown-item>
              <el-dropdown-item command="zipDownload">提货单</el-dropdown-item>
              <el-dropdown-item command="downloadLadingCopy">提单Copy</el-dropdown-item>
            </el-dropdown-menu>
          </el-dropdown>
        </template>
      </el-table-column>
    </el-table>
    <!-- 分页组件 -->
    <pagination
      v-show="total > 0"
      :total="total"
      :page.sync="queryParams.pageNo"
      :limit.sync="queryParams.pageSize"
      @pagination="getList"
    />

    <!-- 对话框(添加 / 修改) -->
    <el-dialog
      :title="dialogCfg.title"
      :visible.sync="dialogCfg.open"
      :width="dialogCfg.width"
      :fullscreen="dialogCfg.fullscreen"
      append-to-body
      class="shippingSea-dialog"
    >
      <template
        v-if="
          dialogCfg.dialogType === 'edit' || dialogCfg.dialogType === 'add'
        "
      >
        <editForm
          v-if="dialogCfg.open"
          @closeDialog="closeDialog"
          :shipmentObj="currRow"
          :warehouseList="warehouseList"
          :transportTypes="transportTypes"
          :cabinetList="cabinetList"
        />
      </template>
      <template v-if="dialogCfg.dialogType === 'cost'">
        <costForm
          v-if="dialogCfg.open"
          @closeDialog="closeDialog"
          :shipmentObj="currRow"
        />
      </template>
      <template v-if="dialogCfg.dialogType === 'error'">
        <regError
          v-if="dialogCfg.open"
          @closeDialog="closeDialog"
          :shipmentObj="currRow"
        />
      </template>
      <template v-if="dialogCfg.dialogType === 'editLadingBill'">
        <ladingBill v-if="dialogCfg.open" @closeDialog="closeDialog" :shipmentObj="currRow" :getCabinetName="getCabinetName" />
      </template>
    </el-dialog>
  </div>
</template>

<script>
import {
  deletebox,
  getbox,
  getboxPage,
  exportboxExcel
} from '@/api/ecw/box'
import {
  downloadFile,
  downloadFileByUrl,
  formatDate,
} from "./shippingSea/utils";
import { getCabinetPage } from '@/api/ecw/cabinet'
import { getChannelList } from '@/api/ecw/channel'
import { getWarehouseList } from '@/api/ecw/warehouse'
import costForm from './costForm.vue'
import regError from './regError.vue'
import editForm from './editSeaAirForm.vue'
import ladingBill from "./ladingBill/index.vue";

export default {
  name: 'box',
  components: {
    costForm,
    regError,
    editForm,
    ladingBill,
  },
  data() {
    return {
      dateTypes: [
        { value: '1', label: '预装时间' },
        { value: '2', label: '装柜时间' },
        { value: '3', label: '起运时间' },
        { value: '4', label: '到港时间' },
        { value: '5', label: '清关时间' },
        { value: '6', label: '提货时间' }
      ],

      // 遮罩层
      loading: true,
      // 导出遮罩层
      exportLoading: false,
      // 显示搜索条件
      showSearch: true,
      // 总条数
      total: 0,
      // 出货列表
      list: [],
      // 弹出层标题
      title: '',
      // 是否显示弹出层
      open: false,
      dialogCfg: {
        title: "",
        dialogType: "",
        width: "600px",
        // 是否显示弹出层
        open: false,
        fullscreen: false,
      },
      // 当前行
      currRow: {},
      dateRangeCreateTime: [],
      // 查询参数
      queryParams: {
        pageNo: 1,
        pageSize: 10,
        id: null,
        selfNo: null,
        cubNo: null,
        cabinetId: null,
        boxStatus: null,
        startWarehouseId: null,
        destWarehouseId: null,
        transportType: null
      },
      cabinetList: [],
      channelList: [],
      warehouseList: [],
    }
  },
  computed: {
    exportWarehouseList() {
      return this.warehouseList.filter(
        (item) => item.tradeType == '2' || item.type == '3'
      )
    },
    importWarehouseList() {
      return this.warehouseList.filter(
        (item) => item.tradeType == '1' || item.type == '3'
      )
    },

    getCabinetName() {
      return (cabinetId) => {
        for (let index in this.cabinetList) {
          let cabinetItem = this.cabinetList[index]
          if (cabinetItem.id == cabinetId) {
            return cabinetItem.name
          }
        }
        return '/'
      }
    },

    getShipChannelName() {
      return (shippingChannelId) => {
        for (let index in this.channelList) {
          let channelItem = this.channelList[index]
          if (channelItem.channelId == shippingChannelId) {
            return channelItem.nameZh
          }
        }
        return '/'
      }
    }
  },
  created() {
    this.transportTypes = this.getDictDatas(
      this.DICT_TYPE.ECW_TRANSPORT_TYPE
    ).filter((item) => item.value == '4')
    getWarehouseList().then((res) => (this.warehouseList = res.data))
    getCabinetPage(null).then((response) => {
      this.cabinetList = response.data.list
    })
    this.getList()
    this.getChannelList()
  },
  methods: {
    getChannelList() {
      getChannelList().then((res) => (this.channelList = res.data))
    },

    /** 查询列表 */
    getList() {
      this.loading = true
      // 处理查询参数
      let params = { ...this.queryParams }
      params.transportType = 4
      this.addBeginAndEndTime(params, this.dateRangeCreateTime, 'createTime')
      // 执行查询
      getboxPage(params).then((response) => {
        this.list = response.data.list
        this.total = response.data.total
        this.loading = false
      })
    },
    /** 取消按钮 */
    cancel() {
      this.open = false
      this.reset()
    },
    /** 表单重置 */
    reset() {
      this.form = {
        id: undefined,
        cabinetId: undefined,
        startWarehouseId: undefined,
        destWarehouseId: undefined,
        transportType: '4'
      }
      this.resetForm('form')
    },
    /** 搜索按钮操作 */
    handleQuery() {
      this.queryParams.pageNo = 1
      this.getList()
    },
    /** 重置按钮操作 */
    resetQuery() {
      this.dateRangeCreateTime = []
      this.resetForm('queryForm')
      this.handleQuery()
    },
    /** 新增按钮操作 */
    handleAdd() {
      this.$set(this.dialogCfg, "title", "添加出货");
      this.$set(this.dialogCfg, "dialogType", "add");
      this.$set(this.dialogCfg, "width", "600px");
      this.$set(this.dialogCfg, "fullscreen", false);
      this.$set(this.dialogCfg, "open", true);
    },
    /** 修改按钮操作 */
    handleUpdate(row) {
      const id = row.id;
      getbox(id).then((response) => {
        this.currRow = response.data;
        this.$set(this.dialogCfg, "title", "修改出货");
        this.$set(this.dialogCfg, "dialogType", "edit");
        this.$set(this.dialogCfg, "width", "600px");
        this.$set(this.dialogCfg, "open", true);
      });
    },
    /* 关闭弹窗 */
    closeDialog(type) {
      this.$set(this.dialogCfg, "open", false);
      if (type === "add" || type === "edit") {
        this.getList();
      }
    },

    /** 删除按钮操作 */
    handleDelete(row) {
      const id = row.id
      this.$modal
        .confirm('是否确认删除出货编号为"' + id + '"的数据项?')
        .then(function () {
          return deletebox(id)
        })
        .then(() => {
          this.getList()
          this.$modal.msgSuccess('删除成功')
        })
        .catch(() => {})
    },
    /** 导出按钮操作 */
    handleExport() {
      // 处理查询参数
      let params = { ...this.queryParams }
      params.pageNo = undefined
      params.pageSize = undefined
      this.addBeginAndEndTime(params, this.dateRangeCreateTime, 'createTime')
      // 执行导出
      this.$modal
        .confirm('是否确认导出所有出货数据项?')
        .then(() => {
          this.exportLoading = true
          return exportboxExcel(params)
        })
        .then((response) => {
          this.$download.excel(response, '${table.classComment}.xls')
          this.exportLoading = false
        })
        .catch(() => {})
    },
    /** 查看按钮操作 */
    handleCommand(row, command) {
      this.$set(this.dialogCfg, "fullscreen", false);
      switch (command) {
        case 'seaAir':
          this.$router.push('/boxSeaAir/shippingSeaAir/' + row.id)
          break

        case "detail":
        this.$router.push("/boxSeaAir/query/" + row.id);
          break;

        case 'edit':
          this.handleUpdate(row)
          break

        case 'delete':
          this.handleDelete(row)
          break

        case "editLadingBill":
            const cabinetLabel = this.getCabinetName(row.cabinetId);
            const title = `查看提单 ${row.selfNo ?? ""} 柜号:${
                row.cubNo ?? ""
            } 柜型:${cabinetLabel}`;
            this.$set(this.dialogCfg, "title", title);
            this.$set(this.dialogCfg, "fullscreen", true);
            break;

        case 'cost':
          this.$set(this.dialogCfg, 'title', '费用登记')
          break

        case 'error':
          this.$set(this.dialogCfg, 'title', '异常登记')
          break
        case "downloadPreloadGoodsList":
          downloadFile(
            command,
            { shipmentId: row.id },
            `预装单(${row.selfNo}).xlsx`,
            "xlsx"
          );
          break;
        case "downloadLoadGoodsList":
          downloadFile(
            command,
            { shipmentId: row.id },
            `已装单(${row.selfNo}).xlsx`,
            "xlsx"
          );
          break;
        case "downloadReceivableList":
          downloadFile(
            command,
            { shipmentId: row.id },
            `应收汇总表(${row.selfNo}).xlsx`,
            "xlsx"
          );
          break;
        case "zipDownload":
          downloadFile(
            command,
            { shipmentId: row.id },
            `提货单(${row.selfNo}).zip`,
            "zip"
          );
          break;
        case "downloadAgentListFiles":
        case "downloadSoncapFiles":
        case "downloadLadingCopy":
          downloadFileByUrl(command, { shipmentId: row.id });
          break;
      }
      if (["editLadingBill", "cost", "error"].includes(command)) {
        this.currRow = row;
        this.$set(this.dialogCfg, "dialogType", command);
        this.$set(this.dialogCfg, "width", "600px");
        this.$set(this.dialogCfg, "open", true);
      }
    }
  }
}
</script>