pending.vue 11.6 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 127 128 129

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

193
    handEdit(row){
dragondean@qq.com's avatar
dragondean@qq.com committed
194
      // 未报价异常
195
      if(row.orderExceptionType=='order_no_quote_exception'){
我在何方's avatar
我在何方 committed
196 197 198 199
        if(row.orderItemId){
          var productData = this.orderData.orderItemVOList.find(item=>item.orderItemId==row.orderItemId)
          if(productData){
            getProduct(productData.prodId).then(res=>{
200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215
                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
                }
                let url = '../../lineProject/product-price/edit?' + (new URLSearchParams(params)).toString()
                /* +productData.prodId
                +'&product_type='+res.data.typeId
                +'&transportId='+this.orderData.transportId
                +'&exportCity='+this.orderData.logisticsInfoDto.startCityId+'&importCity='+this.orderData.logisticsInfoDto.destCityId */
我在何方's avatar
我在何方 committed
216 217 218 219
                return this.$router.push(url)
            })
          }
        }else{
dragondean@qq.com's avatar
dragondean@qq.com committed
220 221 222 223
          return this.$confirm(this.$t('数据缺少orderItemId参数,确定要跳转设置路线价格么?')).then(res => {
            let url = '../../lineProject/product-price/edit'
            this.$router.push(url)
          })
我在何方's avatar
我在何方 committed
224

我在何方's avatar
我在何方 committed
225
        }
我在何方's avatar
我在何方 committed
226

dragondean@qq.com's avatar
dragondean@qq.com committed
227 228 229
      }
      // 重泡货异常
      else if(row.orderExceptionType == 'order_heavy_cargo_exception'||row.orderExceptionType=='order_bulky_cargo_exception'){
我在何方's avatar
我在何方 committed
230
        this.$router.push({
231
          path:"/order/weightDeal?id="+row.id+'&type='+row.orderExceptionType,
我在何方's avatar
我在何方 committed
232
        })
dragondean@qq.com's avatar
dragondean@qq.com committed
233 234 235
       }
       // 其他异常
       else{
我在何方's avatar
我在何方 committed
236
        this.$router.push({
237
          path:"/order/prepayDeal?id="+row.id,
我在何方's avatar
我在何方 committed
238
        })
我在何方's avatar
我在何方 committed
239
       }
我在何方's avatar
我在何方 committed
240

我在何方's avatar
我在何方 committed
241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258
    },
    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
259
        var fileArr = this.list[index].orderExceptionAttr
我在何方's avatar
我在何方 committed
260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276
        fileArr.forEach(item =>{ // 需要预览的文件数组(可以传空数组就是单张预览)
          let obj = {
            FileName: this.getFileName(item),
            name: this.getFileName(item),
            format:this.getFileFormat(item),
            url: item,
            downUrl:"",
          }
          this.FilePreAll.push(obj)
        })
      this.IsPreview = true // 打开预览弹窗
      this.timers = new Date().getTime() // 刷新预览地址
    },
  // 关闭预览
    onClickClosePreview(val){
      this.IsPreview = val  // 由组件内部传入的关闭数据赋值关闭
    },
我在何方's avatar
我在何方 committed
277 278 279
  }
}
</script>
我在何方's avatar
我在何方 committed
280 281 282 283 284
<style scoped>
  .filelist{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
我在何方's avatar
我在何方 committed
285
    flex-direction: column
我在何方's avatar
我在何方 committed
286 287 288 289
  }
  .filelist span{
    color: #1E98D7;
  }
我在何方's avatar
我在何方 committed
290 291 292
  .card-title{
      font-size: 18px;
      font-weight: bold;
我在何方's avatar
我在何方 committed
293
      margin-top: 10px;
我在何方's avatar
我在何方 committed
294 295 296 297
  }
  .card{
    margin-top: 20px;
  }
298
  .clamp3{
我在何方's avatar
我在何方 committed
299 300
    overflow: hidden;
    display: -webkit-box;
301
    -webkit-box-orient: vertical;
我在何方's avatar
我在何方 committed
302
    -webkit-line-clamp: 3;
303
  }
我在何方's avatar
我在何方 committed
304
</style>