mutexOrder.vue 5.04 KB
Newer Older
dcy's avatar
dcy committed
1 2 3 4 5 6 7 8 9 10
<template>
  <div class="associated-order">
    <h1 class="title">
      互斥订单-{{orderDetails.orderNo}}
    </h1>
    <el-divider></el-divider>
    <orde-details-form  :details ="orderDetails" ></orde-details-form>
    <el-divider></el-divider>
    <el-form inline label-width="100px">
      <el-form-item label="订单号"><div class="content">
dcy's avatar
dcy committed
11
        <el-input v-model.trim="params.mutualOrderNo"></el-input>
dcy's avatar
dcy committed
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
      </div></el-form-item>
      <el-form-item><div class="content">
        <el-button @click="getList">查询</el-button>
      </div></el-form-item>
    </el-form>
    <el-divider></el-divider>
    <div style="display: flex;align-items: center;">
      <h1 class="title">
        已加入互斥订单列表
      </h1>
      <div style="flex: 1;margin-left: 20px;">
        <el-button :disabled="multipleSelection.length === 0" type="primary" @click="batchGuanlianOrderByOrderId(multipleSelection.map(e =>({orderId:orderId,mutualOrderId:e.orderId})))" >批量移出</el-button>
      </div>
      <div>
        <el-button type="primary" @click="$router.push('/order/not-mutex-order/'+ orderId)" >添加互斥订单</el-button>
      </div>
    </div>
    <el-table :data="list"  @selection-change="handleSelectionChange" >
      <el-table-column
        type="selection"
        width="55">
      </el-table-column>
      <el-table-column type="index" label="序号"></el-table-column>
35 36 37 38 39 40 41 42 43 44 45
      <el-table-column label="订单号" prop="orderBackVO.orderNo"></el-table-column>
      <el-table-column label="唛头" prop="orderBackVO.marks"></el-table-column>
      <el-table-column label="货物数据">
        <template v-slot="{row}">
          <div>
            {{row.orderBackVO.costVO.totalNum}}
          </div>
          <div>
            {{row.orderBackVO.costVO.totalVolume}}
          </div>
          <div>
46
            {{row.orderBackVO.costVO.totalWeight}}KG
47 48 49 50 51 52 53 54
          </div>
          </template>
      </el-table-column>
      <el-table-column label="入仓时间">
        <template v-slot="{row}">
          {{parseTime(row.orderBackVO.rucangTime)}}
        </template>
      </el-table-column>
dcy's avatar
dcy committed
55 56
      <el-table-column label="状态" prop="status" >
        <template v-slot:default="scope">
57
          <dict-tag :value="scope.row.orderBackVO.status" :type="DICT_TYPE.ORDER_STATUS" ></dict-tag>
dcy's avatar
dcy committed
58 59
        </template>
      </el-table-column>
dcy's avatar
dcy committed
60 61 62 63 64
      <el-table-column label="操作人">
        <template v-slot="{row}">
          {{userList.find( i => row.creator == i.id).nickname}}
        </template>
      </el-table-column>
65 66 67 68 69
      <el-table-column label="操作时间" prop="createTime">
        <template v-slot="{row}">{{
            parseTime(row.orderBackVO.createTime)
          }}</template>
      </el-table-column>
dcy's avatar
dcy committed
70 71 72 73 74 75 76 77
      <el-table-column label="操作">
        <template v-slot:default='scope'>
          <el-button type="text"  @click ="guanlianOrderByOrderId(scope.row.orderId)">
            移出
          </el-button>
        </template>
      </el-table-column>
    </el-table>
dcy's avatar
dcy committed
78 79
    <pagination v-show="total > 0" :total="total" :page.sync="params.page" :limit.sync="params.rows"
                @pagination="getList" />
dcy's avatar
dcy committed
80 81 82 83 84 85 86 87 88 89 90 91 92
  </div>
</template>

<script>
//关联订单
import ordeDetailsForm from "@/views/ecw/order/components/ordeDetailsForm";
import {getOrder} from "@/api/ecw/order";
import {
  deleteBatchGuanlianOrderByOrderId,
  deleteGuanlianOrderByOrderId,
  guanlianList,
} from "@/api/ecw/mutexOrder";
import {getDictDatas,DICT_TYPE} from '@/utils/dict'
93
import Template from "@/views/cms/template";
dcy's avatar
dcy committed
94
import {listSimpleUsers} from "@/api/system/user";
dcy's avatar
dcy committed
95 96 97 98 99 100
export default {
  name: "mutexOrder",
  props:{
    orderId:[String,Boolean]
  },
  components:{
101
    Template,
dcy's avatar
dcy committed
102 103 104 105 106 107 108
    ordeDetailsForm
  },
  data(){
    return {
      orderDetails:{},
      params:{
        orderId:undefined,
dcy's avatar
dcy committed
109 110
        page:1,
        rows:10,
dcy's avatar
dcy committed
111
      },
dcy's avatar
dcy committed
112
      total:0,
dcy's avatar
dcy committed
113 114 115
      list:[],
      DICT_TYPE,
      getDictDatas,
dcy's avatar
dcy committed
116 117
      multipleSelection:[],
      userList:[]
dcy's avatar
dcy committed
118 119 120 121 122 123 124 125 126 127
    }
  },
  created() {
    this.params.orderId = this.orderId;
    this.getList();
    getOrder(this.orderId).then( r =>{
      if(r.code === 0){
        this.orderDetails = r.data;
      }
    })
dcy's avatar
dcy committed
128
    listSimpleUsers().then(r => this.userList = r.data)
dcy's avatar
dcy committed
129 130 131 132 133
  },
  methods:{
    getList(){
      guanlianList(this.params).then(r => {
        if(r.code === 0){
dcy's avatar
dcy committed
134 135
          this.list = r.data.list;
          this.total = r.data.total;
dcy's avatar
dcy committed
136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171
        }
      })
    },
    guanlianOrderByOrderId(id){
      deleteGuanlianOrderByOrderId({orderId:this.orderId,mutualOrderId:id}).then(r =>{
        if(r.code === 0){
          this.getList()
          this.$message.success('操作成功');
        }
      })
    },
    batchGuanlianOrderByOrderId(val){
      deleteBatchGuanlianOrderByOrderId(val).then(r => {
        this.getList()
        this.$message.success('操作成功');
        this.multipleSelection = []
      })
    },
    handleSelectionChange(val) {
      this.multipleSelection = val;
    }
  },

}
</script>

<style scoped lang="scss">
.associated-order{
  padding: 20px;
  box-sizing: border-box;
  .title{
    font-size: 30px;
    font-weight: 600;
  }
}
</style>