Browse Source

新增运单搜索

dev
qb 1 year ago
parent
commit
555f3f510e
  1. 13
      api/user.js
  2. 4
      config/host.js
  3. 6
      manifest.json
  4. 18
      pages.json
  5. 5
      pages/index/index.vue
  6. 6
      pagesHome/pages/CustomerTrayDetails/CustomerTrayDetails.vue
  7. 3
      pagesHome/pages/LoadingScan/LoadingScan.vue
  8. 3
      pagesHome/pages/SelfPickupScan/SelfPickupScan.vue
  9. 7
      pagesHome/pages/StowageList/StowageList.vue
  10. 24
      pagesHome/pages/StowageListDetails/StowageListDetails.vue
  11. 6
      pagesHome/pages/TranNumber/TranNumber.vue
  12. 59
      pagesHome/pages/VehicleArrivalDetails/VehicleArrivalDetails.vue
  13. 2
      pagesHome/pages/VehicleArrivalDetailsByTray/VehicleArrivalDetailsByTray.vue
  14. 2
      pagesHome/pages/codePlateBracket/codePlateBracket.vue
  15. 30
      pagesHome/pages/directGoMarketDetails/directGoMarketDetails.vue
  16. 2
      pagesHome/pages/onLoadByScan/onLoadByScan.vue
  17. 1
      pagesHome/pages/orderInquiry/orderInquiry.vue
  18. 4
      pagesHome/pages/pickingScan/pickingScan.vue
  19. 8
      pagesHome/pages/signOrderScan/signOrderScan.vue
  20. 3
      pagesHome/pages/signPackageScan/signPackageScan.vue
  21. 2
      pagesHome/pages/signinScan/signinScan.vue
  22. 12
      pagesHome/pages/storageInquiry/storageInquiry.vue
  23. 12
      pagesHome/pages/trayInquiry/trayInquiry.vue
  24. 614
      pagesHome/pages/waybillInquiry/waybillInquiry.vue
  25. 2
      unpackage/dist/build/app-plus/pagesHome/pages/SelfPickupScan/SelfPickupScan.css
  26. 4
      unpackage/dist/dev/app-plus/app-config-service.js
  27. 1155
      unpackage/dist/dev/app-plus/app-service.js
  28. 6
      unpackage/dist/dev/app-plus/manifest.json
  29. 11
      unpackage/dist/dev/mp-weixin/api/user.js
  30. 1
      unpackage/dist/dev/mp-weixin/app.js
  31. 1
      unpackage/dist/dev/mp-weixin/app.json
  32. 22
      unpackage/dist/dev/mp-weixin/common/vendor.js
  33. 2
      unpackage/dist/dev/mp-weixin/config/host.js
  34. 8
      unpackage/dist/dev/mp-weixin/project.config.json
  35. 49
      utils/request.js
  36. 121
      utils/style/common.scss
  37. 7
      utils/utils.js

13
api/user.js

@ -2948,4 +2948,17 @@ export function postFindLoadZeroList(data, loadingObj = {}) {
},
loadingObj
);
}
/**
* 获取运单 / 订单数据
*/
export function postDeliveryInfo(data, loadingObj = {}) {
return request({
url: `logpm-distribution/app/delivery/deliveryInfo`,
method: "get",
data
},
loadingObj
);
}

4
config/host.js

@ -23,9 +23,9 @@ const devhost = 'http://test.api.huo5you.com/'
/**
* 正式域名
* */
// const prohost = 'http://h5uapi.huitongys.com/'
const prohost = 'http://h5uapi.huitongys.com/'
// const prohost = 'https://h5uapi.huitongys.com/' // 小程序
const prohost = 'http://test.api.huo5you.com/'
// const prohost = 'http://test.api.huo5you.com/'
/**
* 图片域名
* */

6
manifest.json

@ -1,9 +1,9 @@
{
"name" : "货无忧测试版",
"name" : "货无忧",
"appid" : "__UNI__EB22F37",
"description" : "",
"versionName" : "1.1.18",
"versionCode" : 1118,
"versionName" : "1.1.19",
"versionCode" : 1119,
"transformPx" : false,
/* 5+App */
"app-plus" : {

18
pages.json

@ -1339,6 +1339,24 @@
}
}
}, {
"path": "pages/waybillInquiry/waybillInquiry",
"style": {
"navigationBarTitleText": "订单查询",
"enablePullDownRefresh": true,
"onReachBottomDistance": 1,
"navigationStyle": "custom",
"app-plus": {
"animationDuration": 300,
"animationType": "zoom-fade-out",
"pullToRefresh": {
"support": true,
"color": "#d3832a", //
"style": "circle" //
}
}
}
},
{
"path": "pages/storageInquiry/storageInquiry",

5
pages/index/index.vue

@ -52,6 +52,11 @@
name: '订单查询',
router: '/pagesHome/pages/orderInquiry/orderInquiry',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '运单查询',
router: '/pagesHome/pages/waybillInquiry/waybillInquiry',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '库位查询',

6
pagesHome/pages/CustomerTrayDetails/CustomerTrayDetails.vue

@ -33,9 +33,9 @@
<view class="mabx">
<view class="itec" @click="checkphon(index)" v-if="orderStatus==1" v-for="(item,index) in datalist">
<view class="contenbx1">
<view><text style="color: #90A0AF;" @click.stop="goorderdetail(item)">托盘编码</text>{{item.trayCode}}
</view>
<view><text style="color: #90A0AF;">托盘名称</text>{{item.trayName}}</view>
<!-- <view><text style="color: #90A0AF;" @click.stop="goorderdetail(item)">托盘编码</text>{{item.trayCode}}
</view> -->
<view><text style="color: #90A0AF;">托盘名称</text>{{item.palletName}}</view>
</view>
<view class="contenbx1">
<view><text style="color: #90A0AF;">货物类型</text>{{item.associationType}}</view>

3
pagesHome/pages/LoadingScan/LoadingScan.vue

@ -141,6 +141,7 @@
} from '@/api/user.js'
import { detailType } from '@/interfaces/pagesHome/LoadingScan'
import { reactive, toRefs, ref, watchEffect } from "vue";
import utils from '../../../utils/utils';
//
const tip = ref<any>(null)
@ -327,6 +328,8 @@
details.show = value
}
async function initpage() {
if (date.value.length === 0) return utils.handleToast('请选择时间')
let data = {
current: details.current,
size: details.size,

3
pagesHome/pages/SelfPickupScan/SelfPickupScan.vue

@ -266,10 +266,9 @@
initpage()
}
async function initpage() {
console.log('details :>> ', details);
console.log('date.value :>> ', date.value);
if (details.tabBarCode === 10) details.searchInfo1.date = [...date.value]
else if (details.tabBarCode === 20) details.searchInfo2.date = [...date.value]
if (date.value.length === 0) return utils.handleToast('请选择自提时间')
let data = {
current: details.current,
size: details.size,

7
pagesHome/pages/StowageList/StowageList.vue

@ -176,12 +176,7 @@
initpage()
}
async function initpage() {
if (date.value.length === 0) {
return uni.showToast({
title: '请选择拣货日期',
icon: 'none'
})
}
if (date.value.length === 0) return utils.handleToast('请选择时间')
try {
uni.showLoading({

24
pagesHome/pages/StowageListDetails/StowageListDetails.vue

@ -7,7 +7,7 @@
配载批次{{details.pageInfo.carsNo}}
</view>
<view class="butlur" @click="showsdqs">
录入包条码
{{details.pageType === 1? '录入包条码': '录入托盘码'}}
</view>
</view>
<view>
@ -130,7 +130,6 @@
</view>
<view class="w100 flex-c-sb">
<view class="">
</view>
<view class="button abnormalBtn" @click.stop="handleDelete(ite, 1)">删除</view>
</view>
@ -335,6 +334,7 @@
details.pageType = op.type
option.title = Number(op.type) === 2 ? '配载整托装车' : '配载按件装车'
utils.handleToast(Number(op.type) === 2 ? '请扫描托盘码' : '请扫描包件码')
})
function goorderdetail(item) {
uni.navigateTo({
@ -516,12 +516,12 @@
} finally {
uni.hideLoading()
// Promise
resolve(null)
resolve({})
}
},
close() {
// Promise,
reject()
reject({})
TrayStowage.value.details.showPopUp = false
}
})
@ -533,18 +533,20 @@
* */
async function scandata() {
try {
uni.showLoading()
let res : any = {}
//
if (Number(details.pageType) === 1) await scanOrder()
if (Number(details.pageType) === 1) res = await scanOrder()
//
else if (Number(details.pageType) === 2) await scanTray()
else if (Number(details.pageType) === 2) res = await scanTray()
console.log('res :>> ', res);
if (res.code !== 200) return
//
basicContainer.value.startPullDownRefresh()
} catch (err) {
console.log('err :>> ', err);
//TODO handle the exception
} finally {
uni.hideLoading()
//
basicContainer.value.startPullDownRefresh()
}
}

6
pagesHome/pages/TranNumber/TranNumber.vue

@ -164,9 +164,9 @@
onLoad((op) => {
details.pageInfo = op
// #ifdef APP
utils.ttsspke('请扫描或输入托盘码')
// #endif
// // #ifdef APP
// utils.ttsspke('')
// // #endif
})
onShow(async () => {
// #ifdef APP

59
pagesHome/pages/VehicleArrivalDetails/VehicleArrivalDetails.vue

@ -448,65 +448,6 @@
})
}
/** 请求页面 -- 按件装车 */
const initPageByOrder = async () => {
try {
const response = await postArriveUnloadCarsDetail({
loadId: details.loadId
})
const { code, data } = response
console.log('response :>> ', response);
if (code === 200) {
details.pageInfo = data
details.datalist = details.orderStatus === 1 ?
details.pageInfo.unloadScanOrderList :
details.orderStatus === 2 ?
details.pageInfo.unloadZeroList :
details.pageInfo.exceptionList
if (details.isscan || details.isAbnormal) {
//
let _total = 0
let _abnormal = 0
//
for (let iterator of details.pageInfo.unloadScanOrderList) {
if (iterator.unloadNum)
_total += iterator.unloadNum || 0
}
//
for (let iterator of details.pageInfo.unloadZeroList) {
if (iterator.unloadNum)
_total += iterator.unloadNum || 0
}
_total += details.pageInfo.exceptionList.length
_abnormal += details.pageInfo.exceptionList.length
// #ifdef APP
if (details.isAbnormal) {
utils.handleToast(`卸车${_total}件, 异常卸车${_abnormal}`)
return
}
utils.handleToast(`卸车${_total}`)
// #endif
}
}
} catch (e) {
//TODO handle the exception
} finally {
details.isscan = false
details.isAbnormal = false
return null
}
}
/** 请求页面数据 */
async function initpage() {
try {

2
pagesHome/pages/VehicleArrivalDetailsByTray/VehicleArrivalDetailsByTray.vue

@ -567,7 +567,7 @@
if (details.orderCode) {
const _item = details.info.packageList.find(val => val.dataCode === details.orderCode)
let _content = ''
if (_item.scanNum === _item.orderTotalNum) _content = `${_item.dataCode}齐套`
if (_item.scanNum === _item.orderTotalNum) _content = `${data.data.orderlNum}件, ${_item.dataCode}齐套`
else _content = data.data.orderlNum + '件'
console.log('_content :>> ', _content);
// #ifdef APP

2
pagesHome/pages/codePlateBracket/codePlateBracket.vue

@ -207,7 +207,7 @@
// #ifdef APP
utils.ttsspke('请扫描或输入包条码')
utils.ttsspke('请扫描或输入托盘码')
// #endif
})
onShow(async () => {

30
pagesHome/pages/directGoMarketDetails/directGoMarketDetails.vue

@ -31,15 +31,15 @@
<view class="hdtpnum">
<view>
<view>计划件数</view>
<view>{{details.pageInfo.planLoadingNumber || 0}}</view>
<view>{{details.pageInfo.planNum || 0}}</view>
</view>
<view>
<view>装车件数</view>
<view>{{details.pageInfo.realLoadingNumber || 0}}</view>
<view>{{details.pageInfo.loadingNum || 0}}</view>
</view>
<view>
<view>计划卸车数量 </view>
<view>{{details.pageInfo.plansignNum || 0}}</view>
<view>{{details.pageInfo.loadingNum || 0}}</view>
</view>
<view>
<view>卸车数</view>
@ -317,7 +317,9 @@
},
page: 'ArrivalList' as 'ArrivalList' | 'RelayScanList',
//
zeroList: [],
signScanZeroOrderList: [],
signScanOrderList: [],
exceptionList: [],
/** 页面类型 1: 按件装车 2: 整托卸车 */
pageType: 1,
/** 整托渲染列表 */
@ -429,12 +431,16 @@
const { code, data } = response
console.log('response :>> ', response);
if (code === 200) {
details.pageInfo = data
details.pageInfo = data.signOrder
details.exceptionList = data.exceptionList
details.signScanOrderList = data.signScanOrderList
details.signScanZeroOrderList = data.signScanZeroOrderList
details.datalist = details.orderStatus === 1 ?
details.pageInfo.signScanOrderList :
details.signScanOrderList :
details.orderStatus === 2 ?
details.pageInfo.signScanZeroOrderList :
details.pageInfo.exceptionList
details.signScanZeroOrderList :
details.exceptionList
if (details.isscan) {
//
@ -500,10 +506,10 @@
details.datalist = details.orderStatus === 1 ?
details.pageInfo.signScanOrderList :
details.signScanOrderList :
details.orderStatus === 2 ?
details.pageInfo.signScanZeroOrderList :
details.pageInfo.exceptionList
details.signScanZeroOrderList :
details.exceptionList
// for (let i = 0; i < 1000; i++) {
// details.datalist.push({ orderCode: i, signPackageList: [] })
// }
@ -653,7 +659,7 @@
if (Number(_value.scanStatus) === 2) {
content = '该零担已卸车'
}
else if (Number(_value.scanStatus) === 2) {
else if (Number(_value.scanStatus) === 3) {
content = '该零担已签收'
}

2
pagesHome/pages/onLoadByScan/onLoadByScan.vue

@ -240,6 +240,8 @@
incomingType: "2",
}
if (details.pageInfo.tranNumber) _submitData.tranNumber = details.pageInfo.tranNumber
const res = await postIncomingIncomingPackage(_submitData)
if (res.code !== 200) return

1
pagesHome/pages/orderInquiry/orderInquiry.vue

@ -557,6 +557,7 @@
width: 160upx;
text-align: right;
margin-right: 20rpx;
flex: none;
}
}

4
pagesHome/pages/pickingScan/pickingScan.vue

@ -185,6 +185,8 @@
date.value[1] = (uni as any).$u.timeFormat((new Date().valueOf()), 'yyyy-mm-dd')
}
datatime.value = date.value[0] + ' 至 ' + date.value[1]
await nextTick()
basicContainer.value.startPullDownRefresh()
details.scrollHeight = await utils.getViewDistanceFormTop('.sccv')
@ -203,6 +205,8 @@
initpage()
}
async function initpage() {
if (date.value.length === 0) return utils.handleToast('请选择拣货时间')
try {
uni.showLoading({
title: '数据加载中',

8
pagesHome/pages/signOrderScan/signOrderScan.vue

@ -124,7 +124,9 @@
</view>
<view class="contenbx1">
<view><text style="color: #90A0AF;">计划签收</text>{{item.reservationNum}}</view>
<view><text style="color: #90A0AF;">实际签收</text>{{item.loadingNub}}</view>
<view><text
style="color: #90A0AF;">实际签收</text>{{item.distributionParcelNumberVOS.reduce((cur, item)=>cur += item.signingNum || 0 ,0)}}
</view>
</view>
<view v-if="item.complete"
@ -507,6 +509,9 @@
}
async function initpage() {
try {
uni.showLoading({
mask: true
})
details.listcheckindex = -1
let data = {
@ -557,6 +562,7 @@
//TODO handle the exception
} finally {
computedNum()
uni.hideLoading()
return null
}
}

3
pagesHome/pages/signPackageScan/signPackageScan.vue

@ -244,6 +244,9 @@
}
}
console.log('_signArr :>> ', _signArr);
console.log('_signArr.length :>> ', _signArr.length);
details.datalist = _value ? [_value, ..._noSignArr, ..._signArr] : [..._noSignArr, ..._signArr]
}

2
pagesHome/pages/signinScan/signinScan.vue

@ -204,6 +204,8 @@
initpage()
}
async function initpage() {
if (date.value.length === 0) return utils.handleToast('请选择配送时间')
let data = {
current: details.current,
size: details.size,

12
pagesHome/pages/storageInquiry/storageInquiry.vue

@ -43,22 +43,22 @@
<view class="orderInfo_title_row">
<view class="">
<view class="row_title1">
<text class="row_title1">
托盘名称
</view>
<view>
</text>
<text>
{{info.trayInfo.palletName || '暂无数据'}}
</view>
</text>
</view>
<view class="">
<!-- <view class="">
<view class="row_title2">
托盘码
</view>
<view class="">
{{info.trayInfo.palletCode || '暂无数据'}}
</view>
</view>
</view> -->
</view>
<view class="orderInfo_title_row">

12
pagesHome/pages/trayInquiry/trayInquiry.vue

@ -23,22 +23,22 @@
<view class="orderInfo_title">
<view class="orderInfo_title_row">
<view class="">
<view class="row_title1">
<text class="row_title1">
托盘名称
</view>
<view>
</text>
<text>
{{info.trayInfo.palletName || '暂无数据'}}
</view>
</text>
</view>
<view class="">
<!-- <view class="">
<view class="row_title2">
托盘码
</view>
<view class="">
{{info.trayInfo.palletCode || '暂无数据'}}
</view>
</view>
</view> -->
</view>
<view class="orderInfo_title_row">

614
pagesHome/pages/waybillInquiry/waybillInquiry.vue

@ -0,0 +1,614 @@
<template>
<!-- 顶部导航栏 -->
<u-navbar title="运单查询" placeholder :autoBack="true" leftIconSize='35' bgColor='#d3832a' leftIconColor='#ffffff'
titleStyle='color:#ffffff'></u-navbar>
<view class="container primaryColor">
<!-- 顶部搜索栏 -->
<view class="header-search">
<view class="mr20 flex-c-c picker rem-0-8">
<picker @change="bindPickerChange" :value="searchForm.scanStateChooseIndex"
:range="searchForm.searchTypeList.map(val => val.label)">
<view class="uni-input">
{{searchForm.searchTypeList.map(val => val.label)[searchForm.scanStateChooseIndex]}}
</view>
</picker>
</view>
<view class="search flex1 mr20">
<input class="searchInput" v-model="searchForm.code" type="text">
<view class="clear_icon" v-if="searchForm.code" @click="searchForm.code = ''">
<u-icon size="40" color="#172e60" name="close-circle"></u-icon>
</view>
</view>
<view class="search">
<view class="searchType" @click="scandata">
搜索
</view>
</view>
</view>
<!-- 数据详情 -->
<view class="dataInfo">
<!-- 运单数据 -->
<view class="pd15">
<!-- 运单号 -->
<view class="mb10 fwb rem-1 flex">
<view>
运单号
</view>
<view>
{{waybillInfo.waybillNo}}
</view>
</view>
<!-- 发货仓和目的仓 -->
<view class="mb20 rem-0-9 flex-c-sb">
<!-- 发货仓 -->
<view class="text-start">
<view>
发货仓
</view>
<view class="mt20">
发货单位
</view>
</view>
<view class="text-center">
<!-- 箭头 -->
<view class="flex-c-c">
<view class="status-garden">
</view>
<view class="status-line">
</view>
<view class="status-triangle">
</view>
</view>
<view class="">
状态
</view>
</view>
<view class="text-end">
<view>
目的仓
</view>
<view class="mt20">
收货单位
</view>
</view>
</view>
</view>
<!-- 虚线 -->
<view class="border-bottom-dashed mb20"></view>
<!-- 服务信息 -->
<view class="mb20 pd15 rem-0-9">
<view class="flex mb10">
<view class="mr10">
<u-icon size="40" color="#172e60" name="server-man"></u-icon>
</view>
<view class="">
服务类型
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
发货人
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
发货人联系方式
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
收件人
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
收件人联系方式
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
收货地址
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
货物总数
</view>
<view class="">
1
</view>
</view>
</view>
<!-- 虚线 -->
<view class="border-bottom-dashed mb20"></view>
<!-- 始发仓数据 -->
<view class="mb20 pd15 rem-0-9">
<view class="flex mb10">
<view class="mr10">
<u-icon size="40" color='#172e60' name="map-fill"></u-icon>
</view>
<view class="">
始发仓
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
在库数量
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
在途数量
</view>
<view class="">
1
</view>
</view>
</view>
<!-- 虚线 -->
<view class="border-bottom-dashed mb20"></view>
<!-- 中转仓数据 -->
<view class="mb20 pd15 rem-0-9">
<view class="flex mb10">
<view class="mr10">
<u-icon size="40" color='#172e60' name="map-fill"></u-icon>
</view>
<view class="">
中转仓
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
在途数量
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
中转仓A
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
在库数量
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
中转仓B
</view>
<view class="">
1
</view>
</view>
<view class="flex">
<view class="label">
在库数量
</view>
<view class="">
1
</view>
</view>
</view>
<!-- 虚线 -->
<view class="border-bottom-dashed mb20"></view>
<!-- 目的仓数据 -->
<view class="mb20 pd15 rem-0-9">
<view class="flex mb10">
<view class="mr10">
<u-icon size="40" color='#172e60' name="map-fill"></u-icon>
</view>
<view class="">
目的仓
</view>
<view class="">
1
</view>
</view>
<view class="flex mb10">
<view class="label">
在库数量
</view>
<view class="">
1
</view>
</view>
<view class="flex">
<view class="label">
在途数量
</view>
<view class="">
1
</view>
</view>
</view>
<!-- 虚线 -->
<view class="border-bottom-dashed mb20"></view>
<!-- 目的仓数据 -->
<view class=" pd15 rem-0-9">
<view class="flex mb10">
<view class="mr10 ">
<u-icon size="40" color="#172e60" name="car-fill"></u-icon>
</view>
<view class="">
配送
</view>
<view class="">
{{waybillInfo.deliveryNum || 0}}
</view>
</view>
<view class="flex mb10">
<view class="label">
已签收数量
</view>
<view class="success">
{{waybillInfo.signingNum || 0}}
</view>
</view>
<view class="flex">
<view class="label">
未签收数量
</view>
<view class="danger">
{{(waybillInfo.deliveryNum || 0) - (waybillInfo.signingNum || 0)}}
</view>
</view>
</view>
</view>
</view>
<tiplist ref="tiplists"></tiplist>
<!-- #ifdef APP -->
<saomiao2 :ishidestop="scanState !== 0"></saomiao2>
<!-- #endif -->
</template>
<script lang="ts" setup>
import { ref, reactive, shallowRef } from 'vue';
import {
onShow,
onLoad,
onPullDownRefresh
} from '@dcloudio/uni-app'
import utils from '@/utils/utils.js';
import {
postDeliveryInfo,
} from '@/api/user.js'
import useSystemSettingsStore from '@/store/useSystemSettingsStore';
import { storeToRefs } from 'pinia';
const { scanState } = storeToRefs(useSystemSettingsStore())
/** 订单详情 */
const dataInfo = shallowRef<any>({})
/** 包件列表 */
const packageList = ref([])
/** 扫码码值 */
const scancode = ref<string>('')
/** 订单状态字典 */
const orderStateDictionaries = reactive({
'10': '部分入库',
'20': '已入库',
'30': '部分出库',
'40': '已出库',
'50': '部分装车',
'60': '已装车',
'70': '部分签收',
'80': '已签收',
})
/** 顶部搜素表单 */
const searchForm = reactive({
code: '',
searchTypeList: [
{
label: '运单查询',
type: 1
},
{
label: '订单查询',
type: 2
},
],
scanStateChooseIndex: 0,
})
const waybillInfo = ref({})
//
const tiplists = ref(null)
onLoad(() => {
// #ifdef APP
utils.ttsspke('订单查询, 请扫描或输入包条码')
// #endif
})
//
onShow(async () => {
// #ifdef APP
uni.$off('scancodedate')
uni.$on('scancodedate', function (code) {
if (code) {
scancode.value = code
searchForm.code = code
scandata()
}
})
// #endif
})
onPullDownRefresh(() => {
const timer = setTimeout(() => {
dataInfo.value = {}
searchForm.code = ''
packageList.value = []
uni.stopPullDownRefresh()
clearTimeout(timer)
}, 500)
})
async function scandata() {
if (searchForm.code === '') return utils.handleToast('请输入正确的订单号')
const submitData = {
type: searchForm.searchTypeList[searchForm.scanStateChooseIndex].type,
code: searchForm.code
}
const res = await postDeliveryInfo(submitData)
const { code, data } = res
if (code !== 200) return
waybillInfo.value = data
waybillInfo.value.waybillNo = searchForm.code
}
/**
* 选择搜索类型
*/
function bindPickerChange(e) {
if (e.detail.value !== searchForm.scanStateChooseIndex) uni.showToast({
title: '切换成功',
icon: 'none',
duration: 1500
})
console.log('picker发送选择改变,携带值为', e.detail.value)
searchForm.scanStateChooseIndex = e.detail.value
// ,
}
</script>
<style lang="scss" scoped>
@import url("@/utils/style/common.scss");
//
.container {
padding: 20upx;
font-size: 28upx; //
}
//
.header-search {
height: 60upx;
padding: 0 0 20upx;
// border-bottom: 1upx solid #aaa;
display: flex;
justify-content: space-between;
.picker {
color: #fff;
background: var(--subjectColor);
padding: 0 30upx;
border-radius: 10upx;
}
}
.search {
position: relative;
//
.searchResultList {
position: absolute;
top: 120%;
width: 100%;
background: #fff;
z-index: 80;
text-align: center;
line-height: 60upx;
max-height: 300upx;
overflow-y: scroll;
}
.clear_icon {
position: absolute;
top: 52%;
right: 20upx;
transform: translateY(-50%);
}
}
//
.searchInput {
background: #fff;
// width: 500upx;
height: 100%;
padding-left: 20upx;
border: 1upx solid var(--subjectColor);
border-radius: 30upx;
padding-right: 60upx;
box-sizing: border-box;
}
//
.searchType {
height: 100%;
display: flex;
align-items: center;
padding: 0 40upx;
background: var(--subjectColor);
border-radius: 10upx;
color: #fff;
}
//
.dataInfo {
// border: 1upx solid #aaa;
background: #fff;
border-radius: 10upx;
.label {
min-width: 150upx;
flex: none;
}
}
.border-bottom-solid {
border-bottom: 1upx solid #172e60;
}
.border-bottom-dashed {
border-bottom: 1upx dashed #172e60;
}
$arrowsColor: #f94a56;
.status-garden {
width: 24upx;
height: 24upx;
background: $arrowsColor;
border-radius: 50%;
margin-left: 10upx;
}
.status-line {
width: 200upx;
height: 6upx;
background: $arrowsColor;
}
.status-triangle {
width: 0;
height: 0;
border: 16upx solid transparent;
border-right: none;
border-left: 34upx solid;
border-left-color: $arrowsColor;
border-radius: 10upx;
}
.success {
color: #0f0;
}
.danger {
color: #f94a56;
}
</style>

2
unpackage/dist/build/app-plus/pagesHome/pages/SelfPickupScan/SelfPickupScan.css vendored

File diff suppressed because one or more lines are too long

4
unpackage/dist/dev/app-plus/app-config-service.js vendored

File diff suppressed because one or more lines are too long

1155
unpackage/dist/dev/app-plus/app-service.js vendored

File diff suppressed because it is too large Load Diff

6
unpackage/dist/dev/app-plus/manifest.json vendored

@ -5,10 +5,10 @@
"iPad"
],
"id": "__UNI__EB22F37",
"name": "货无忧测试版",
"name": "货无忧",
"version": {
"name": "1.1.18",
"code": 1118
"name": "1.1.19",
"code": 1119
},
"description": "",
"developer": {

11
unpackage/dist/dev/mp-weixin/api/user.js vendored

@ -1920,6 +1920,16 @@ function postFindLoadZeroList(data, loadingObj = {}) {
loadingObj
);
}
function postDeliveryInfo(data, loadingObj = {}) {
return utils_request.service(
{
url: `logpm-distribution/app/delivery/deliveryInfo`,
method: "get",
data
},
loadingObj
);
}
exports.$_initRetentionList = $_initRetentionList;
exports.$_retentionScan = $_retentionScan;
exports.$_retentionTrayScan = $_retentionTrayScan;
@ -2003,6 +2013,7 @@ exports.postArriveUnloadPageList = postArriveUnloadPageList;
exports.postCarsLoadPageList = postCarsLoadPageList;
exports.postCarsLoadUnloadPackage = postCarsLoadUnloadPackage;
exports.postCarsLoadUnloadZero = postCarsLoadUnloadZero;
exports.postDeliveryInfo = postDeliveryInfo;
exports.postFinaSignOrderDetail = postFinaSignOrderDetail;
exports.postFinaSignOrderList = postFinaSignOrderList;
exports.postFindAdvanceDetailList = postFindAdvanceDetailList;

1
unpackage/dist/dev/mp-weixin/app.js vendored

@ -82,6 +82,7 @@ if (!Math) {
"./pagesHome/pages/RelocationAllocationId/RelocationAllocationId.js";
"./pagesHome/pages/orderDetails/orderDetails.js";
"./pagesHome/pages/orderInquiry/orderInquiry.js";
"./pagesHome/pages/waybillInquiry/waybillInquiry.js";
"./pagesHome/pages/storageInquiry/storageInquiry.js";
"./pagesHome/pages/trayInquiry/trayInquiry.js";
"./pagesHome/pages/inventoryInquiry/inventoryInquiry.js";

1
unpackage/dist/dev/mp-weixin/app.json vendored

@ -78,6 +78,7 @@
"pages/RelocationAllocationId/RelocationAllocationId",
"pages/orderDetails/orderDetails",
"pages/orderInquiry/orderInquiry",
"pages/waybillInquiry/waybillInquiry",
"pages/storageInquiry/storageInquiry",
"pages/trayInquiry/trayInquiry",
"pages/inventoryInquiry/inventoryInquiry",

22
unpackage/dist/dev/mp-weixin/common/vendor.js vendored

@ -1261,7 +1261,7 @@ function populateParameters(fromRes, toRes) {
const hostLanguage = language.replace(/_/g, "-");
const parameters = {
appId: "__UNI__EB22F37",
appName: "货无忧",
appName: "货无忧测试版",
appVersion: "1.1.18",
appVersionCode: 1118,
appLanguage: getAppLanguage(hostLanguage),
@ -1405,7 +1405,7 @@ const getAppBaseInfo = {
hostSDKVersion: SDKVersion,
hostTheme: theme,
appId: "__UNI__EB22F37",
appName: "货无忧",
appName: "货无忧测试版",
appVersion: "1.1.18",
appVersionCode: 1118,
appLanguage: getAppLanguage(hostLanguage)
@ -13037,6 +13037,24 @@ const subPackages = [
}
}
},
{
path: "pages/waybillInquiry/waybillInquiry",
style: {
navigationBarTitleText: "订单查询",
enablePullDownRefresh: true,
onReachBottomDistance: 1,
navigationStyle: "custom",
"app-plus": {
animationDuration: 300,
animationType: "zoom-fade-out",
pullToRefresh: {
support: true,
color: "#d3832a",
style: "circle"
}
}
}
},
{
path: "pages/storageInquiry/storageInquiry",
style: {

2
unpackage/dist/dev/mp-weixin/config/host.js vendored

@ -1,5 +1,5 @@
"use strict";
const devhost = "https://h5uapi.huitongys.com/";
const devhost = "http://test.api.huo5you.com/";
const imghost = "";
const host = devhost;
const APPKEY = "h5u:h5u_secret";

8
unpackage/dist/dev/mp-weixin/project.config.json vendored

@ -6,14 +6,14 @@
},
"setting": {
"urlCheck": false,
"es6": true,
"es6": false,
"postcss": false,
"minified": true,
"newFeature": true,
"bigPackageSizeSupport": true,
"ignoreDevUnusedFiles": false,
"lazyCodeLoading": "requiredComponents",
"enhance": true,
"enhance": false,
"packNpmRelationList": [],
"babelSetting": {
"ignore": [],
@ -23,8 +23,8 @@
},
"compileType": "miniprogram",
"libVersion": "3.1.2",
"appid": "wx35c7fb77840097de",
"projectname": "货无忧",
"appid": "wxedb0d10ea46a0113",
"projectname": "货无忧测试版",
"condition": {
"search": {
"current": -1,

49
utils/request.js

@ -163,30 +163,35 @@ const HandleRequest = (params, key, loadingObj) => {
}
// #endif
let response = {}
const request = uni.request(submitData)
request.then(res => {
// console.log(res);
console.log('请求res :>> ', res);
response = res
if (res.statusCode == 200) {
let data = res.data;
// #ifdef APP
utils.ttsspke(data.audio || '')
// #endif
if (data.code != 200 && data?.msg) {
uni.hideLoading()
uni.showToast({
title: data?.msg || '',
icon: 'none'
})
} else if (data.audio) {
uni.hideLoading()
uni.showToast({
title: data.msg,
icon: 'none'
})
}
// // #ifdef APP
// utils.ttsspke(data.audio || '')
// // #endif
// if (data.code != 200 && data?.msg) {
// uni.hideLoading()
// uni.showToast({
// title: data?.msg || '',
// icon: 'none'
// })
// } else if (data.audio) {
// uni.hideLoading()
// uni.showToast({
// title: data.msg,
// icon: 'none'
// })
// }
// 请求成功, 删除请求记录
delete requestObj[key]
@ -271,9 +276,21 @@ const HandleRequest = (params, key, loadingObj) => {
utils.ttsspke('请检查是否连接到无线网络')
// #endif
}).finally(async res => {
console.log('response :>> ', response);
console.log('res-finally :>> ', res);
await nextTick()
if (loadingObj.isShowLoading !== false) uni.hideLoading()
const {
data
} = response
if (data) {
if (data.code !== 200) {
if (data.msg) utils.handleToast(data.msg)
} else if (data.audio) utils.handleToast(data.audio)
}
})
})

121
utils/style/common.scss

@ -0,0 +1,121 @@
.flex{
display: flex;
}
.flex-c-c{
display: flex;
align-items: center;
justify-content: center;
}
.flex-c-sb{
display: flex;
align-items: center;
justify-content: space-between;
}
.flex-c-sa{
display: flex;
align-items: center;
justify-content: space-around;
}
.flex1{
flex: 1;
}
.flexnone{
flex: none;
}
.mt10{
margin-top: 10upx;
}
.mt20{
margin-top: 20upx;
}
.ml10{
margin-left: 10upx;
}
.ml20{
margin-left: 20upx;
}
.mb10{
margin-bottom: 10upx;
}
.mb20{
margin-bottom: 20upx;
}
.mr10{
margin-right: 10upx;
}
.mr20{
margin-right: 20upx;
}
.pd10{
padding: 10upx;
}
.pd15{
padding: 15upx;
}
.pd20{
padding: 20upx;
}
.w100{
width: 100%;
}
.h100{
height: 100%;
}
.text-center{
text-align: center;
}
.text-start{
text-align: start;
}
.text-end{
text-align: end;
}
.fwb{
font-weight: bold;
}
.rem-1{
font-size: 1rem;
}
.rem-0-8{
font-size: 0.8rem;
}
.rem-0-9{
font-size: 0.9rem;
}
.rem-1-5{
font-size: 1.5rem;
}
.primaryColor{
color: #172e60;
}
.primaryColorIm{
color: #172e60 !important;
}

7
utils/utils.js

@ -461,7 +461,8 @@ const utils = {
handleToast(content, icon = 'none') {
uni.showToast({
title: content,
icon: icon
icon: icon,
duration: 1500
})
// #ifdef APP
@ -478,8 +479,8 @@ const utils = {
const args = arguments;
clearTimeout(timer);
timer = setTimeout(function() {
// func.apply(context, args);
func();
func.apply(context, args);
// func();
console.log('timer :>> ', timer);
clearTimeout(timer);
}, delay);

Loading…
Cancel
Save