pending.vue 12.2 KB
Newer Older
我在何方's avatar
我在何方 committed
1 2 3 4
<template>
  <div class="app-container">
    <!-- 搜索工作栏 -->
    <el-card>
我在何方's avatar
我在何方 committed
5
        <div slot="header" class="card-title">{{$t('查看')}}</div>
我在何方's avatar
我在何方 committed
6
        <el-descriptions :column="4">
7 8 9
          <el-descriptions-item :label="$t('订单号')">
              {{orderData.orderNo||''}}
          </el-descriptions-item>
我在何方's avatar
我在何方 committed
10 11
            <el-descriptions-item :label="$t('唛头')">
                {{orderData.marks?orderData.marks:$t('')}}
我在何方's avatar
我在何方 committed
12
            </el-descriptions-item>
我在何方's avatar
我在何方 committed
13
            <el-descriptions-item :label="$t('已到箱数/总箱数')">
我在何方's avatar
我在何方 committed
14
                {{orderData.sumNum||0}}/{{orderData.costVO?orderData.costVO.totalNum:0}}
我在何方's avatar
我在何方 committed
15
            </el-descriptions-item>
我在何方's avatar
我在何方 committed
16
            <el-descriptions-item :label="$t('订单状态')">
我在何方's avatar
我在何方 committed
17 18
              <dict-tag :type="DICT_TYPE.ORDER_STATUS" :value="orderData.status" />
            </el-descriptions-item>
我在何方's avatar
我在何方 committed
19 20
            <el-descriptions-item :label="$t('送货日期')">
               {{orderData.deliveryDate||$t('')}}
我在何方's avatar
我在何方 committed
21
            </el-descriptions-item>
我在何方's avatar
我在何方 committed
22
            <el-descriptions-item :label="$t('运输方式')">
23 24
                <dict-tag :type="DICT_TYPE.ECW_TRANSPORT_TYPE" :value="orderData.transportId" />
              </el-descriptions-item>
我在何方's avatar
我在何方 committed
25 26
            <el-descriptions-item :label="$t('始发地')">
                 {{orderData.logisticsInfoDto?orderData.logisticsInfoDto.startTitleZh:$t('')}}
27
            </el-descriptions-item>
我在何方's avatar
我在何方 committed
28
            <el-descriptions-item :label="$t('目的地')">
我在何方's avatar
我在何方 committed
29
               {{orderData.logisticsInfoDto?orderData.logisticsInfoDto.destTitleZh:$t('')}}
30
            </el-descriptions-item>
31 32
        </el-descriptions>
        <el-descriptions :column="4">
我在何方's avatar
我在何方 committed
33 34
            <el-descriptions-item :label="$t('发货人')">
                {{orderData.consignorVO?orderData.consignorVO.name||$t(''):$t('')}}
我在何方's avatar
我在何方 committed
35
            </el-descriptions-item>
我在何方's avatar
我在何方 committed
36 37
            <el-descriptions-item :label="$t('发货公司')">
                {{orderData.consignorVO?orderData.consignorVO.company||$t(''):$t('')}}
我在何方's avatar
我在何方 committed
38
            </el-descriptions-item>
我在何方's avatar
我在何方 committed
39
            <el-descriptions-item :label="$t('发货电话')">
我在何方's avatar
我在何方 committed
40
                {{orderData.consignorVO?((orderData.consignorVO.countryCode?checkCode(orderData.consignorVO.countryCode):'')+orderData.consignorVO.phone)||$t(''):$t('')}}
我在何方's avatar
我在何方 committed
41
            </el-descriptions-item>
42 43
          </el-descriptions>
          <el-descriptions :column="4">
我在何方's avatar
我在何方 committed
44 45
            <el-descriptions-item :label="$t('收货人')">
                {{orderData.consigneeVO?orderData.consigneeVO.name||$t(''):$t('')}}
我在何方's avatar
我在何方 committed
46
            </el-descriptions-item>
我在何方's avatar
我在何方 committed
47 48
            <el-descriptions-item :label="$t('收货公司')">
                {{orderData.consigneeVO?orderData.consigneeVO.company||$t(''):$t('')}}
我在何方's avatar
我在何方 committed
49
            </el-descriptions-item>
我在何方's avatar
我在何方 committed
50
            <el-descriptions-item :label="$t('收货电话')">
我在何方's avatar
我在何方 committed
51
                {{orderData.consigneeVO?((orderData.consigneeVO.countryCode?checkCode(orderData.consigneeVO.countryCode):'')+orderData.consigneeVO.phone)||$t(''):$t('')}}
我在何方's avatar
我在何方 committed
52 53 54 55 56
            </el-descriptions-item>
        </el-descriptions>
    </el-card>
    <el-card class="card">
      <!-- 列表 -->
我在何方's avatar
我在何方 committed
57
      <div slot="header" class="card-title">{{$t('问题详情')}}</div>
我在何方's avatar
我在何方 committed
58
      <el-table v-loading="loading" border :data="list">
我在何方's avatar
我在何方 committed
59
        <el-table-column :label="$t('序号')" align="center" prop="id" type="index">
我在何方's avatar
我在何方 committed
60 61 62 63
          <template slot-scope="scope">
              <span>{{scope.$index + 1}}</span>
          </template>
        </el-table-column>
我在何方's avatar
我在何方 committed
64
        <el-table-column :label="$t('异常类型')" align="center" >
我在何方's avatar
我在何方 committed
65
        <template slot-scope="scope">
我在何方's avatar
我在何方 committed
66
            <dict-tag :type="DICT_TYPE.ORDER_ERROR_TYPE" :value="scope.row.orderExceptionType" />
我在何方's avatar
我在何方 committed
67 68
          </template>
        </el-table-column>
我在何方's avatar
我在何方 committed
69
        <el-table-column :label="$t('异常描述')" align="center">
我在何方's avatar
我在何方 committed
70
            <template slot-scope="scope">
dragondean@qq.com's avatar
dragondean@qq.com committed
71
              <span v-if="scope.row.orderExceptionDescVO">{{$l(scope.row.orderExceptionDescVO, 'desc')}}</span>
我在何方's avatar
我在何方 committed
72 73
            </template>
        </el-table-column>
74 75 76 77 78 79 80 81
        <el-table-column :label="$t('金额')" align="center" scope="orderExceptionAmount">
          <template slot-scope="{row}">
            {{row.orderExceptionAmount}}
            {{currencyMap[row.orderExceptionAmountCurrencyId]}}
            </template>
        </el-table-column>
        </el-table-column>
        <el-table-column :label="$t('状态')" align="center">
我在何方's avatar
我在何方 committed
82 83 84
          <template slot-scope="scope">
              <dict-tag :type="DICT_TYPE.ORDER_EXCEPTION_STATUS" :value="scope.row.orderExceptionStatus" />
            </template>
85
        </el-table-column>
我在何方's avatar
我在何方 committed
86
        <el-table-column :label="$t('附件')" align="center">
我在何方's avatar
我在何方 committed
87
          <template slot-scope="scope">
我在何方's avatar
我在何方 committed
88
            <div class="filelist">
我在何方's avatar
我在何方 committed
89
              <span v-for="(item,index) in scope.row.orderExceptionAttr" :key="index" @click="onClickOpenPreview(item,scope.$index)">{{'附件'+(index+1)}}</span>
我在何方's avatar
我在何方 committed
90
            </div>
我在何方's avatar
我在何方 committed
91 92
          </template>
        </el-table-column>
93 94 95 96 97 98 99
        <el-table-column :label="$t('备注')" align="center">
          <template slot-scope="{row}">
            <el-tooltip class="item" effect="dark" :content="row.orderExceptionNotes" placement="top-start">
              <div class="clamp3">{{row.orderExceptionNotes}}</div>
            </el-tooltip>
          </template>
        </el-table-column>
我在何方's avatar
我在何方 committed
100 101
        <el-table-column :label="$t('处理人')" align="center" prop="userName" />
        <el-table-column :label="$t('处理时间')" align="center">
我在何方's avatar
我在何方 committed
102 103 104 105
          <template slot-scope="scope">
             <span>{{parseTime(scope.row.handlerTime)}}</span>
            </template>
          </el-table-column>
我在何方's avatar
我在何方 committed
106
        <el-table-column :label="$t('操作')" align="center">
我在何方's avatar
我在何方 committed
107
          <template slot-scope="scope">
我在何方's avatar
我在何方 committed
108
            <el-tag v-if="scope.row.orderExceptionStatus==2">{{$t('已完成')}}</el-tag>
我在何方's avatar
我在何方 committed
109
            <el-button v-else size="mini" type="text" icon="el-icon-edit" @click="handEdit(scope.row)">{{$t('处理')}}</el-button>
我在何方's avatar
我在何方 committed
110 111 112 113
          </template>
        </el-table-column>
      </el-table>
    </el-card>
我在何方's avatar
我在何方 committed
114 115 116
    <div class="preview" v-if="IsPreview">
      <file-preview :key="timers" :TragetPic="TragetPic" :FilePreAll="FilePreAll" @Close="onClickClosePreview"></file-preview>
    </div>
我在何方's avatar
我在何方 committed
117 118 119 120
  </div>
</template>

<script>
我在何方's avatar
我在何方 committed
121
import {getExceptionListByOrderId} from "@/api/ecw/orderException"
122
import { getCurrencyList } from '@/api/ecw/currency'
我在何方's avatar
我在何方 committed
123
import {getOrder} from '@/api/ecw/order'
我在何方's avatar
我在何方 committed
124
import FilePreview from '@/components/FilePreview'
我在何方's avatar
我在何方 committed
125
import {getProduct} from '@/api/ecw/product'
我在何方's avatar
我在何方 committed
126
import {getProductPriceGetPrice} from '@/api/ecw/productPrice'
我在何方's avatar
我在何方 committed
127 128 129 130

export default {
  name: "Pending",
  components: {
我在何方's avatar
我在何方 committed
131
    FilePreview
我在何方's avatar
我在何方 committed
132 133 134 135
  },
  data() {
    return {
      // 遮罩层
我在何方's avatar
我在何方 committed
136
      loading: true,
我在何方's avatar
我在何方 committed
137 138 139
      orderData:{},
      // 订单异常列表
      list: [],
我在何方's avatar
我在何方 committed
140 141 142 143 144
      orderId:0,
      IsPreview:false, // 控制预览弹窗字段
      timers:"", //时间戳
      FilePreAll:[], // 预览数组
      TragetPic:{},
145
      currencyList:[]
我在何方's avatar
我在何方 committed
146 147
    };
  },
148 149 150 151 152 153 154 155 156
  computed:{
    currencyMap(){
        let map = {}
        this.currencyList.forEach(item => {
          map[item.id] = this.$l(item, 'title')
        })
        return map
      },
  },
我在何方's avatar
我在何方 committed
157
  created() {
158
    getCurrencyList().then(res => this.currencyList = res.data)
我在何方's avatar
我在何方 committed
159 160 161 162 163
    if(this.$route.query.id){
      this.orderId = this.$route.query.id
      this.getList()
      this.getOrders()
    }
我在何方's avatar
我在何方 committed
164 165 166 167 168 169
  },
  methods: {
    /** 查询列表 */
    getList() {
      this.loading = true;
      // 执行查询
我在何方's avatar
我在何方 committed
170 171
      getExceptionListByOrderId(this.orderId).then(response => {
        this.list = response.data;
我在何方's avatar
我在何方 committed
172 173 174 175 176 177 178
        this.list.forEach((item)=>{
          if(item.orderExceptionAttr){
            item.orderExceptionAttr = item.orderExceptionAttr.split(',')
          }else{
            item.orderExceptionAttr = []
          }
        })
我在何方's avatar
我在何方 committed
179 180 181
        this.loading = false;
      });
    },
我在何方's avatar
我在何方 committed
182 183 184 185 186 187
    checkCode(data){
      if(data.indexOf('+')==-1){
      	return '+'+data
      }
      return data
    },
我在何方's avatar
我在何方 committed
188 189 190 191 192
    getOrders(){
      getOrder(this.orderId).then(response => {
        this.orderData = response.data
      });
    },
我在何方's avatar
我在何方 committed
193

194
    handEdit(row){
dragondean@qq.com's avatar
dragondean@qq.com committed
195
      // 未报价异常
196
      if(row.orderExceptionType=='order_no_quote_exception'){
我在何方's avatar
我在何方 committed
197

我在何方's avatar
我在何方 committed
198 199 200 201
        if(row.orderItemId){
          var productData = this.orderData.orderItemVOList.find(item=>item.orderItemId==row.orderItemId)
          if(productData){
            getProduct(productData.prodId).then(res=>{
202 203 204 205 206 207 208 209 210 211 212
                let params = {
                  product_id: productData.prodId,
                  product_type: res.data.typeId,
                  transportId: this.orderData.transportId,
                  exportCity: this.orderData.logisticsInfoDto.startCityId,
                  importCity: this.orderData.logisticsInfoDto.destCityId,
                  startWarehouseId: this.orderData.logisticsInfoDto.startWarehouseId,
                  destWarehouseId: this.orderData.logisticsInfoDto.destWarehouseId,
                  lineId: this.orderData.logisticsInfoDto.lineId,
                  channelId: this.orderData.logisticsInfoDto.channelId
                }
我在何方's avatar
我在何方 committed
213 214 215 216 217
                let queryParams = {
                  productId: productData.prodId,
                  lineId: this.orderData.logisticsInfoDto.lineId,
                  channelId: this.orderData.logisticsInfoDto.channelId
                }
218
                let url = '../../lineProject/product-price/edit?' + (new URLSearchParams(params)).toString()
我在何方's avatar
我在何方 committed
219 220 221 222 223 224 225 226
                getProductPriceGetPrice(queryParams).then(res=>{
                  console.log(res)
                  if(res.data){
                    url =  '../../lineProject/product-price/edit?action=update&id='+res.data.id
                  }
                  return this.$router.push(url)
                })

227 228 229 230
                /* +productData.prodId
                +'&product_type='+res.data.typeId
                +'&transportId='+this.orderData.transportId
                +'&exportCity='+this.orderData.logisticsInfoDto.startCityId+'&importCity='+this.orderData.logisticsInfoDto.destCityId */
我在何方's avatar
我在何方 committed
231

我在何方's avatar
我在何方 committed
232 233 234
            })
          }
        }else{
dragondean@qq.com's avatar
dragondean@qq.com committed
235 236 237 238
          return this.$confirm(this.$t('数据缺少orderItemId参数,确定要跳转设置路线价格么?')).then(res => {
            let url = '../../lineProject/product-price/edit'
            this.$router.push(url)
          })
我在何方's avatar
我在何方 committed
239

我在何方's avatar
我在何方 committed
240
        }
我在何方's avatar
我在何方 committed
241

dragondean@qq.com's avatar
dragondean@qq.com committed
242 243 244
      }
      // 重泡货异常
      else if(row.orderExceptionType == 'order_heavy_cargo_exception'||row.orderExceptionType=='order_bulky_cargo_exception'){
我在何方's avatar
我在何方 committed
245
        this.$router.push({
246
          path:"/order/weightDeal?id="+row.id+'&type='+row.orderExceptionType,
我在何方's avatar
我在何方 committed
247
        })
dragondean@qq.com's avatar
dragondean@qq.com committed
248 249 250
       }
       // 其他异常
       else{
我在何方's avatar
我在何方 committed
251
        this.$router.push({
252
          path:"/order/prepayDeal?id="+row.id,
我在何方's avatar
我在何方 committed
253
        })
我在何方's avatar
我在何方 committed
254
       }
我在何方's avatar
我在何方 committed
255

我在何方's avatar
我在何方 committed
256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273
    },
    getFileName(fileName){
      var fileArr = fileName.split('/')
      return fileArr[fileArr.length-1]
    },
    getFileFormat(fileName){
      var fileArr = this.getFileName(fileName).split('.')
      return fileArr[fileArr.length-1]
    },
    	// 打开预览
    onClickOpenPreview(val,index){
      this.TragetPic  = { // 当前点击的文件
        FileName: this.getFileName(val), // 文件名称
        name: this.getFileName(val), // 文件名称(可以不传)
        format:this.getFileFormat(val), // 文件格式
        url: val,  // 预览地址
        downUrl:"", // 下载地址
      } // 目标对象
我在何方's avatar
我在何方 committed
274
        var fileArr = this.list[index].orderExceptionAttr
我在何方's avatar
我在何方 committed
275 276 277 278 279 280 281 282 283 284
        fileArr.forEach(item =>{ // 需要预览的文件数组(可以传空数组就是单张预览)
          let obj = {
            FileName: this.getFileName(item),
            name: this.getFileName(item),
            format:this.getFileFormat(item),
            url: item,
            downUrl:"",
          }
          this.FilePreAll.push(obj)
        })
285
        console.log(this.fileArr)
我在何方's avatar
我在何方 committed
286 287 288 289 290 291 292
      this.IsPreview = true // 打开预览弹窗
      this.timers = new Date().getTime() // 刷新预览地址
    },
  // 关闭预览
    onClickClosePreview(val){
      this.IsPreview = val  // 由组件内部传入的关闭数据赋值关闭
    },
我在何方's avatar
我在何方 committed
293 294 295
  }
}
</script>
我在何方's avatar
我在何方 committed
296 297 298 299 300
<style scoped>
  .filelist{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
我在何方's avatar
我在何方 committed
301
    flex-direction: column
我在何方's avatar
我在何方 committed
302 303 304 305
  }
  .filelist span{
    color: #1E98D7;
  }
我在何方's avatar
我在何方 committed
306 307 308
  .card-title{
      font-size: 18px;
      font-weight: bold;
我在何方's avatar
我在何方 committed
309
      margin-top: 10px;
我在何方's avatar
我在何方 committed
310 311 312 313
  }
  .card{
    margin-top: 20px;
  }
314
  .clamp3{
我在何方's avatar
我在何方 committed
315 316
    overflow: hidden;
    display: -webkit-box;
317
    -webkit-box-orient: vertical;
我在何方's avatar
我在何方 committed
318
    -webkit-line-clamp: 3;
319
  }
我在何方's avatar
我在何方 committed
320
</style>