batchSingleApplication.vue 11.1 KB
Newer Older
1
<template>
2
  <el-dialog
dcy's avatar
dcy committed
3 4
    :visible.sync="dialogVisible"
    width="80%"
5 6 7 8
    :before-close="()=>{
      $emit('update:dialogVisible',false)
    }">
    <div class="batch-single-application">
dcy's avatar
dcy committed
9
      <h1 class="title">{{$t('调仓申请')}}</h1>
10
      <el-table :data="list">
dcy's avatar
dcy committed
11 12 13
        <el-table-column :label="$t('订单编号')" prop="orderNo"></el-table-column>
        <el-table-column :label="$t('唛头')" prop="marks"></el-table-column>
        <el-table-column :label="$t('已到箱数/总箱数')">
dcy's avatar
dcy committed
14
          <template v-slot={row}>
dcy's avatar
dcy committed
15
            {{ row.sumNum }}箱/{{ row.totalNum }}
16 17
          </template>
        </el-table-column>
dcy's avatar
dcy committed
18
        <el-table-column :label="$t('下单统计')">
19 20
          <template v-slot="{row}">
            <div v-if="row.costVO">
dcy's avatar
dcy committed
21
              {{$t('箱数')}}{{ row.costVO.totalNum }}
dcy's avatar
dcy committed
22 23
              {{ row.costVO.totalVolume }}
              {{ row.costVO.totalWeight }}kg
24 25 26
            </div>
          </template>
        </el-table-column>
dcy's avatar
dcy committed
27
        <el-table-column :label="$t('入仓统计')" width="150">
28
          <template v-slot="{row}">
dcy's avatar
dcy committed
29 30 31
            <div>{{$t('总箱数')}}{{ row.sumNum || 0 }}</div>
            <div>{{$t('体积')}}{{ row.sumVolume || 0 }}CBM</div>
            <div>{{$t('重量')}}{{ row.sumWeight || 0 }}KG</div>
32 33
          </template>
        </el-table-column>
dcy's avatar
dcy committed
34
        <el-table-column :label="$t('入仓时间')" prop="rucangTime">
dcy's avatar
dcy committed
35 36 37
           <template v-slot="{row}">
             {{parseTime(row.rucangTime)}}
           </template>
38
        </el-table-column>
dcy's avatar
dcy committed
39
        <el-table-column :label="$t('运输方式')">
dcy's avatar
dcy committed
40
          <template v-slot={row}>
41 42 43
            <dict-tag :type="DICT_TYPE.ECW_TRANSPORT_TYPE" :value="row.transportId"></dict-tag>
          </template>
        </el-table-column>
dcy's avatar
dcy committed
44
        <el-table-column :label="$t('出货渠道')">
dcy's avatar
dcy committed
45 46
          <template v-slot="{row}">
           {{row.channelName || '/'}}</template>
47
        </el-table-column>
Marcus's avatar
Marcus committed
48
        <!--      <el-table-column :label="$t('始发仓')" prop="startWarehouseName"></el-table-column>-->
dcy's avatar
dcy committed
49 50
        <el-table-column :label="$t('目的地')" prop="objectiveName"></el-table-column>
        <el-table-column :label="$t('始发仓')" prop="startWarehouseName">
dcy's avatar
dcy committed
51
        </el-table-column>
dcy's avatar
dcy committed
52
        <el-table-column :label="$t('发货人')">
53 54 55 56
          <template v-slot="{row}">
            <div>
              <div>
                <p>
dcy's avatar
dcy committed
57
                  {{ row.consignorName }}
58 59
                </p>
                <p>
邓春圆's avatar
邓春圆 committed
60
                  +{{row.consignorCountryCode}}   {{row.consignorPhone}}
61 62 63 64 65
                </p>
              </div>
            </div>
          </template>
        </el-table-column>
dcy's avatar
dcy committed
66
        <el-table-column :label="$t('收货人')">
67 68 69
          <template v-slot="{row}">
            <div>
              <p>
dcy's avatar
dcy committed
70
                {{ row.consigneeName }}
71 72
              </p>
              <p>
邓春圆's avatar
邓春圆 committed
73
               +{{row.consigneeCountryCode}}   {{ row.consigneePhone}}
74 75 76 77 78
              </p>
            </div>
          </template>
        </el-table-column>
      </el-table>
dcy's avatar
dcy committed
79 80 81
      <el-row style="margin-top: 30px">
        <el-col :span="8">
          <div style="text-align: right;">
邓春圆's avatar
邓春圆 committed
82
            {{ list[0] && list[0].adjustToDestWarehouseName ? list[0].adjustToDestWarehouseName : list[0] ? [14,16,15].includes(this.list[0].status) ? list[0].dstWarehouseName : list[0].startWarehouseName : '' }}
dcy's avatar
dcy committed
83 84 85
          </div>
        </el-col>
        <el-col :span="3"><div style="text-align:center">
dcy's avatar
dcy committed
86
          {{$t('调至')}}
dcy's avatar
dcy committed
87
        </div></el-col>
88 89
        <el-col :span="8">
          <el-select clearable v-model="params.warehouseInId">
dcy's avatar
dcy committed
90
          <el-option  v-for="(item ,index) in availableWarehouse" v-if="item.status !== 1"  :value="item.id" :label="item.titleZh"
dcy's avatar
dcy committed
91 92 93
                     :key="index"></el-option>
        </el-select></el-col>
      </el-row>
dcy's avatar
dcy committed
94
      <el-divider contentPosition="left">{{$t('调仓明细')}}</el-divider>
dcy's avatar
dcy committed
95 96
      <el-card class="box-card">
          <el-table :data="warehouseList">
dcy's avatar
dcy committed
97 98 99 100 101
            <el-table-column :label="$t('调仓编号')" prop="id"></el-table-column>
            <el-table-column :label="$t('调出仓库')" prop="warehouseOutName" ></el-table-column>
            <el-table-column :label="$t('调入仓库')" prop="warehouseInName"></el-table-column>
            <el-table-column :label="$t('申请人')" prop="creatorName"></el-table-column>
            <el-table-column :label="$t('申请时间')">
dcy's avatar
dcy committed
102 103 104 105
              <template v-slot="{row}">
                {{parseTime(row.createTime)}}
              </template>
            </el-table-column>
dcy's avatar
dcy committed
106
            <el-table-column :label="$t('状态')">
dcy's avatar
dcy committed
107 108 109 110
              <template v-slot="{row}">
                {{STATUS[row.status]}}
              </template>
            </el-table-column>
111 112 113 114 115 116 117 118 119 120
            <el-table-column :label="$t('出仓影像')">
              <template v-slot="{row}">
                <warehouse-video-list :modal="false" :status="2" :item ="row"></warehouse-video-list>
              </template>
            </el-table-column>
            <el-table-column :label="$t('入仓影像')">
              <template v-slot="{row}">
                <warehouse-video-list :modal="false" :status="3" :item ="row"></warehouse-video-list>
              </template>
            </el-table-column>
邓春圆's avatar
邓春圆 committed
121
            <el-table-column :label="$t('调拨出仓备注')" prop="deliveryRemark">
122
            </el-table-column>
邓春圆's avatar
邓春圆 committed
123
            <el-table-column :label="$t('调拨到仓备注')" prop="arrivalRemark">
124
            </el-table-column>
dcy's avatar
dcy committed
125 126
          </el-table>
      </el-card>
dcy's avatar
dcy committed
127
      <el-divider contentPosition="left">{{$t('审批流程')}}</el-divider>
128
      <div style="padding: 20px">
dcy's avatar
dcy committed
129
        <work-flow xmlkey="warehouse_transfer" v-model="params.copyUserId"/>
130
      </div>
dcy's avatar
dcy committed
131
      <div style="text-align: center" v-if="!adjustmentBol">
dcy's avatar
dcy committed
132 133
        <el-button :disabled="!params.warehouseInId" style="margin-right: 50px" @click="submit">{{$t('提交申请')}}</el-button>
        <el-button @click="$emit('update:dialogVisible',false)">{{$t('取消')}}</el-button>
134
      </div>
dcy's avatar
dcy committed
135 136
      <div style="text-align: center" v-else>
        <el-button @click="()=>{
dragondean@qq.com's avatar
dragondean@qq.com committed
137
          $emit('update:dialogVisible',false)
dcy's avatar
dcy committed
138
          $router.push({path:'/bpm/process-instance/detail',query:{id:this.applyStatus.orderWarehouseApprovalBackVO.formId}})
dcy's avatar
dcy committed
139 140 141
        }">{{$t('审核中')}}</el-button>
        <el-button @click="cancellationOfOrder" >{{$t('取消审核')}}</el-button>
        <el-button @click="$emit('update:dialogVisible',false)" >{{$t('取消')}}</el-button>
dcy's avatar
dcy committed
142
      </div>
143
    </div>
144
  </el-dialog>
145 146 147
</template>

<script>
148 149
import {DICT_TYPE, getDictDatas} from "@/utils/dict";
import {
dcy's avatar
dcy committed
150
  adjustApplyStatus, adjustLastWithStatus, cancelAdjustApply,
151 152
  ecwOrderList,
  orderWarehouseInAdjustApply,
dcy's avatar
dcy committed
153
  warehouseAdjustmentList, warehouseApprovalCancel,
154
} from "@/api/ecw/batchSingleApplication";
155 156
import {getProcessDefinitionBpmnXMLByKey} from "@/api/bpm/definition";
import warehouseDetails from "@/views/ecw/order/components/warehouseDetails";
dcy's avatar
dcy committed
157
import {getAdjustInfo, getOrderPage} from "@/api/ecw/order";
dcy's avatar
dcy committed
158
import workFlow from "@/components/WorkFlow";
159
import Template from "@/views/cms/template";
dcy's avatar
dcy committed
160 161
import {arrryToKeyedObjectBy} from "@/utils";
import {getChannelList} from "@/api/ecw/channel";
162
import WarehouseVideoList from "@/views/ecw/order/components/warehouse-video-list.vue";
dcy's avatar
dcy committed
163

164
export default {
165
  name: "batchSingleApplication",
dcy's avatar
dcy committed
166 167 168 169 170
  props: {
    orderList: [String, Number],
    dialogVisible: {
      type: Boolean,
      default: false,
171
    }
172
  },
dcy's avatar
dcy committed
173
  components: {
174
    WarehouseVideoList,
175
    Template,
dcy's avatar
dcy committed
176 177
    warehouseDetails,
    workFlow
178
  },
dcy's avatar
dcy committed
179 180
  created() {
    getChannelList().then(res => this.channelList = res.data)
dcy's avatar
dcy committed
181

dcy's avatar
dcy committed
182
    },
dcy's avatar
dcy committed
183

dcy's avatar
dcy committed
184 185 186 187
  watch: {
    dialogVisible(val) {
      if (val) {
        this.getOrderListFn()
dcy's avatar
dcy committed
188 189 190
        getAdjustInfo({orderId:this.orderList,lang:0}).then(r => {
          this.warehouseList = r.data
        })
dcy's avatar
dcy committed
191 192 193 194 195 196 197 198
      } else {
        this.params = {
          orderIds: undefined,
          warehouseInId: undefined,
          warehouseOutId: undefined,
          copyUserId: [],
        }
      }
199
    }
200
  },
dcy's avatar
dcy committed
201 202
  computed: {
    adjustmentBol() {
dcy's avatar
dcy committed
203
      return this.applyStatus?.orderWarehouseAdjustBackVO?.status === 1
dcy's avatar
dcy committed
204 205 206 207 208 209 210 211 212 213 214
    },
    getShipChannelName() {
      return shippingChannelId => {
        for (let index in this.channelList) {
          let channelItem = this.channelList[index];
          if (channelItem.channelId == shippingChannelId) {
            return channelItem.nameZh;
          }
        }
        return '/'
      }
215
    }
216
  },
dcy's avatar
dcy committed
217
  data() {
218
    return {
dcy's avatar
dcy committed
219
      STATUS : {1:this.$t('申请中'), 2:this.$t('通过'), 3:this.$t('不通过'), 4:this.$t('已取消'), 5:this.$t('已出仓'),6:this.$t('已到仓')},
dcy's avatar
dcy committed
220 221 222
      list: [],
      selectedUsers: [],
      availableWarehouse: [],
223
      DICT_TYPE,
dcy's avatar
dcy committed
224 225 226 227 228
      departureWarehouse: undefined,
      adjustment: undefined,
      params: {
        orderIds: undefined,
        warehouseInId: undefined,
dcy's avatar
dcy committed
229
        warehouseOutId: undefined,
dcy's avatar
dcy committed
230
        copyUserId: [],
231
      },
dcy's avatar
dcy committed
232
      applyStatus:{},//调仓-查看状态,
dcy's avatar
dcy committed
233 234
      channelList:[],
      warehouseList:[]
dcy's avatar
dcy committed
235

236 237
    }
  },
dcy's avatar
dcy committed
238 239 240 241
  methods: {
    getOrderListFn() {
      getOrderPage({orderIdList: this.orderList}).then(r => {
        this.list = r.data.list
邓春圆's avatar
邓春圆 committed
242
        warehouseAdjustmentList({id: this.list[0].adjustToDestWarehouseId  ? this.list[0].adjustToDestWarehouseId  :[14,16,15].includes(this.list[0].status) ? this.list[0].dstWarehouseId : this.list[0].startWarehouseId }).then(r => this.availableWarehouse = r.data)
dcy's avatar
dcy committed
243 244 245 246 247 248
        adjustLastWithStatus({orderId:this.list[0].orderId,lang:0}).then(r =>{
          this.applyStatus = r.data
          if(r.data?.orderWarehouseAdjustBackVO?.status === 1){
            this.params.warehouseInId = r.data.orderWarehouseAdjustBackVO?.warehouseInId
          }
        })
dcy's avatar
dcy committed
249 250 251
      })
    },
    submit() {
252 253
      let p = this.list.map(e => e.orderId).join(',');
      this.params.orderIds = p;
邓春圆's avatar
邓春圆 committed
254
      this.params.warehouseOutId = this.list[0].adjustToDestWarehouseId  ? this.list[0].adjustToDestWarehouseId  : [14,16,15].includes(this.list[0].status) ? this.list[0].dstWarehouseId : this.list[0].startWarehouseId;
255
      this.params.orderNo = this.list[0].orderNo
dcy's avatar
dcy committed
256 257 258
      orderWarehouseInAdjustApply(this.params).then(r => {
        if (r.code === 0) {
          this.$emit('update:dialogVisible', false)
dcy's avatar
dcy committed
259
          this.$message.success(this.$t('调仓申请提交成功,请耐心等待审核'));
260 261
        }
      })
dcy's avatar
dcy committed
262
    },
dcy's avatar
dcy committed
263
    cancellationOfOrder(){
dcy's avatar
dcy committed
264 265 266
      this.$prompt(this.$t('请输入审核调仓原因'), this.$t('提示'), {
        confirmButtonText: this.$t('确定'),
        cancelButtonText: this.$t('取消'),
dcy's avatar
dcy committed
267 268 269
      }).then(({ value }) => {
        warehouseApprovalCancel(this.applyStatus.orderWarehouseApprovalBackVO.id,value) .then(r => {
          if(r.data){
dcy's avatar
dcy committed
270
            this.$message.success(this.$t('取消调仓成功'))
dcy's avatar
dcy committed
271
            this.$emit('update:dialogVisible',false)
dcy's avatar
dcy committed
272

dcy's avatar
dcy committed
273 274 275 276 277
          }
        })
      }).catch(() => {
        this.$message({
          type: 'info',
dcy's avatar
dcy committed
278
          message: this.$t('取消成功')
dcy's avatar
dcy committed
279
        });
dcy's avatar
dcy committed
280
      });
dcy's avatar
dcy committed
281 282
    },

283
  }
284 285 286 287
}
</script>

<style scoped lang="scss">
dcy's avatar
dcy committed
288
.batch-single-application {
289 290
  padding: 20px;
  box-sizing: border-box;
dcy's avatar
dcy committed
291 292 293 294 295

  .title {
    font-weight: 600;
    text-align: left;
  }
296
}
dcy's avatar
dcy committed
297

298 299 300 301 302 303 304 305
.my-process-designer {
  height: calc(100vh - 200px);
}

.box-card {
  width: 100%;
  margin-bottom: 20px;
}
306
</style>