Browse Source

修复盘点部分问题

myd
qb 1 year ago
parent
commit
3c9b20b68c
  1. 25
      api/user.js
  2. 1
      compoment/saomiao2.vue
  3. 4
      config/host.js
  4. 38
      pages.json
  5. 273
      pages/index/index.vue
  6. 514
      pagesHome/pages/ArrivalList/ArrivalList.vue
  7. 11
      pagesHome/pages/CustomerOrdersDetails/CustomerOrdersDetails.vue
  8. 6
      pagesHome/pages/StockUplist/StockUplist.vue
  9. 609
      pagesHome/pages/codePlateBracket/codePlateBracket.vue
  10. 2
      pagesHome/pages/scansorting/scansorting.vue
  11. 39
      pagesHome/pages/setbarcode/setbarcode.vue
  12. 2
      pagesHome/pages/signOrderScan/signOrderScan.vue
  13. 25
      pagesTask/pages/dynamicCheckDetails/dynamicCheckDetails.vue
  14. 2
      unpackage/dist/dev/app-plus/app-config-service.js
  15. 1158
      unpackage/dist/dev/app-plus/app-service.js
  16. 10
      unpackage/dist/dev/app-plus/pages/index/index.css
  17. 4
      unpackage/dist/dev/app-plus/pagesHome/pages/setbarcode/setbarcode.css

25
api/user.js

@ -122,6 +122,19 @@ export function distributionStockupstockupScanCheck(data) {
});
}
/**
* 切换批次号
* @param {Object} data
*/
export function distributionStockupstockupUpdateStockup(data) {
return request({
url: `logpm-distribution/app/distributionStockup/updateStockup`,
method: "post",
data
});
}
/**
* 备货扫码列表
@ -406,6 +419,18 @@ export function signforwrapIn(data) {
*/
export function signforinventory(data) {
return request({
url: `logpm-distribution/app/signfor/inventory`,
method: "get",
data
});
}
/**
* 客户查看库存品
* @param {Object} data
*/
export function deliveryInventory(data) {
return request({
url: `logpm-distribution/app/delivery/inventory`,
method: "get",

1
compoment/saomiao2.vue

@ -67,6 +67,7 @@
if (plus) {
console.log('getDeviceBrand() :>> ', uni.getSystemInfoSync());
const { brand } = uni.getSystemInfoSync()
console.log('brand :>> ', brand);
console.log('进入')
details.activity = plus.android.runtimeMainActivity(); //activity
console.log('details.activity :>> ', details.activity);

4
config/host.js

@ -4,7 +4,7 @@
* 测试域名
* */
//测试域名
// const devhost = 'http://test.api.huitongys.com/'
const devhost = 'http://test.api.huitongys.com/'
// lmy
// const devhost = 'http://192.168.10.123:8889/'
// zhy
@ -13,7 +13,7 @@
// const devhost = 'http://192.168.10.25:13000/'
// cyz
// const devhost = 'http://192.168.10.75:8777/'
const devhost = 'http://192.168.6.141:8777/'
// const devhost = 'http://192.168.6.141:8777/'
// 正式
// const devhost = 'http://h5uapi.huitongys.com/'
// cg

38
pages.json

@ -134,6 +134,44 @@
}
}
},
{
"path": "pages/codePlateBracket/codePlateBracket",
"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/ArrivalList/ArrivalList",
"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/SelfPickupScan/SelfPickupScan",

273
pages/index/index.vue

@ -34,126 +34,147 @@
import { inject, reactive, toRefs, watchEffect, ref } from "vue";
import utils from '../../utils/utils';
const tip = ref(null)
let details = reactive<listtype>({ tablist: [] });
// let details = reactive<listtype>({
// tablist: [
// {
// type: 1,
// name: '',
// minilist: [
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/orderInquiry/orderInquiry',
// },
// ]
// },
// {
// type: 1,
// name: '',
// minilist: [
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/scansorting/scansorting',
// },
// // {
// // icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// // name: '',
// // router: '/pagesHome/pages/ordersorting/ordersorting',
// // },
// // {
// // icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// // name: '',
// // router: '/pagesHome/pages/lnventorysorting/lnventorysorting',
// // },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/ScanUpType/ScanUpType',
// },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/PeopleScanUpType/PeopleScanUpType',
// },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/RelocationType/RelocationType',
// },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/Retention/Retention',
// },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/MergeTray/MergeTray',
// },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/DownGoodsType/DownGoodsType',
// },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/RemoveTray/RemoveTray',
// },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/Check/Check',
// },
// ]
// },
// {
// type: 1,
// name: '',
// minilist: [
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/pickingScan/pickingScan',
// },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/SelfPickupScan/SelfPickupScan',
// },
// ]
// },
// {
// type: 1,
// name: '',
// minilist: [
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/LoadingScan/LoadingScan',
// },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/signinScan/signinScan',
// },
// ]
// },
// {
// type: 1,
// name: '线',
// minilist: [
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '线',
// router: '/pagesHome/pages/OfflineUpload/OfflineUpload',
// },
// ]
// },
// ]
// })
// let details = reactive<listtype>({ tablist: [] });
let details = reactive<listtype>({
tablist: [
{
type: 1,
name: '工作台',
minilist: [
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '订单查询',
router: '/pagesHome/pages/orderInquiry/orderInquiry',
},
]
},
{
type: 1,
name: '入库',
minilist: [
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '码板打托',
router: '/pagesHome/pages/codePlateBracket/codePlateBracket',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '入库扫描',
router: '/pagesHome/pages/orderInquiry/orderInquiry',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '到车入库',
router: '/pagesHome/pages/ArrivalList/ArrivalList',
},
]
},
{
type: 1,
name: '库内',
minilist: [
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '分拣打托',
router: '/pagesHome/pages/scansorting/scansorting',
},
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/ordersorting/ordersorting',
// },
// {
// icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
// name: '',
// router: '/pagesHome/pages/lnventorysorting/lnventorysorting',
// },
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '扫码上架',
router: '/pagesHome/pages/ScanUpType/ScanUpType',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '手动上架',
router: '/pagesHome/pages/PeopleScanUpType/PeopleScanUpType',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '移库',
router: '/pagesHome/pages/RelocationType/RelocationType',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '滞留',
router: '/pagesHome/pages/Retention/Retention',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '合托',
router: '/pagesHome/pages/MergeTray/MergeTray',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '下架',
router: '/pagesHome/pages/DownGoodsType/DownGoodsType',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '空置托盘',
router: '/pagesHome/pages/RemoveTray/RemoveTray',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '复核',
router: '/pagesHome/pages/Check/Check',
},
]
},
{
type: 1,
name: '出库',
minilist: [
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '拣货扫描',
router: '/pagesHome/pages/pickingScan/pickingScan',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '自提扫描',
router: '/pagesHome/pages/SelfPickupScan/SelfPickupScan',
},
]
},
{
type: 1,
name: '配送',
minilist: [
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '装车扫描',
router: '/pagesHome/pages/LoadingScan/LoadingScan',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '签收扫描',
router: '/pagesHome/pages/signinScan/signinScan',
},
]
},
{
type: 1,
name: '离线上传',
minilist: [
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '离线上传',
router: '/pagesHome/pages/OfflineUpload/OfflineUpload',
},
]
},
]
})
function gopathpage(path : string) {
uni.navigateTo({
@ -464,24 +485,24 @@
.mabox {
display: flex;
flex-direction: column;
padding: 20upx 0;
// padding: 10upx 0;
box-sizing: border-box;
width: 686upx;
margin: auto;
background-color: #ffffff;
margin-bottom: 20upx;
margin-bottom: 10upx;
margin-top: 10upx;
border-radius: 10upx;
box-shadow: 0rpx 2rpx 10rpx 0rpx #e2e2e380;
.boxtitl {
font-size: 34upx;
font-size: 30upx;
font-weight: 500;
margin-bottom: 10upx;
// margin-left: 10upx;
border-bottom: 1upx solid #EEEEEE;
padding: 0upx 20upx;
padding-bottom: 20upx;
padding: 20upx;
// padding-bottom: 0upx;
color: #092C4D;
}
@ -490,7 +511,7 @@
flex-wrap: wrap;
align-items: center;
// justify-content: space-between;
padding-top: 10upx;
padding: 10upx 0;
>view {
width: 25%;

514
pagesHome/pages/ArrivalList/ArrivalList.vue

@ -0,0 +1,514 @@
<template>
<BasicContainer :option="option" :leftClick="option.leftClick">
<!-- 头部 -->
<template #head>
<view class="headtop">
<view @click='showCalendar' class="inputsr">
<input :value='datatime' disabled placeholder="请选择时间" />
<view @click.stop.prevent>
<u-icon @click='showCalendar' style="margin-right: 10upx;" v-if="!datatime" name="calendar"
color="#999999" size="50"></u-icon>
<u-icon @click="cleartime" style="margin-right: 10upx;" v-else name="close-circle" color="#999999"
size="40"></u-icon>
</view>
</view>
<view @click="scandata">查询</view>
</view>
</template>
<!-- 主体 -->
<template #body>
<scroll-view class="scvmabx" @scrolltolower="reachBottomInitPage" scroll-y="true" @touchmove.stop>
<view class="maxboxs">
<!-- <view class="items" v-for="item in datalist">
</view> -->
<template v-for="item in datalist">
<view class="items">
<view class="items_row">
<view>
车次号: {{1231231231}}
</view>
<view>
车牌号: {{123123}}
</view>
</view>
<view class="items_row">
<view>
实际装车/计划装车: {{'12/57'}}
</view>
<view>
车型: {{123123}}
</view>
</view>
<view class="items_row">
<view>
z主驾司机: {{'12/57'}}
</view>
<view>
电话: {{123123}}
</view>
</view>
<view class="items_row">
类型: 自由
</view>
<view class="items_row">
线路: 双流基地仓->龙泉仓->达州仓
</view>
<view class="items_row">
发车时间: 123123123
</view>
<view class="button-container">
<view class="button">
按键入库
</view>
<view class="button">
整托入库
</view>
<view class="button">
卸分一体
</view>
<view class="button">
按件装车
</view>
<view class="button">
整托装车
</view>
</view>
<!-- 标签 -->
<view class="tag">
网点到达
</view>
</view>
</template>
</view>
</scroll-view>
</template>
</BasicContainer>
<l-calendar v-model:value="show" :initStartDate='date[0]' :initEndDate='date[1]' @hide='showCalendar'
@change="onConfirm"></l-calendar>
<!-- #ifdef APP -->
<saomiao2 :ishidestop="scanState !== 0"></saomiao2>
<!-- #endif -->
</template>
<script lang="ts" setup>
import {
warehouseTrayTypeorderPageList,
warehouseTrayTypeorderScanTrayCode,
} from '@/api/user.js'
import {
onLoad,
onShow,
onHide,
} from '@dcloudio/uni-app'
import { reactive, ref, toRefs, watchEffect } from "vue";
import utils from '@/utils/utils.js'
import useSystemSettingsStore from '@/store/useSystemSettingsStore';
import { storeToRefs } from 'pinia';
const { scanState } = storeToRefs(useSystemSettingsStore())
//
const option = reactive({
leftClick() {
uni.reLaunch({
url: "/pages/index/index"
})
},
//
title: '已经打托列表',
//
async pullDownRefreshInitPage() {
//
details.pageNum = 1
//
details.datalist = []
//
option.isEnd = false
//
option.haveData = true
await initpage()
if (datalist.value.length === 0) {
uni.showToast({
title: '暂时没有数据',
icon: 'error'
})
option.haveData = false
}
if (option.isEnd) {
return uni.showToast({
icon: 'success',
title: '数据已加载完毕'
})
}
return null
},
//
reachBottomInitPage: async () => { return null },
haveData: true,
isEnd: false
})
//
let antiShake : any = null
//
function reachBottomInitPage() {
try {
// ,
if (option.isEnd) {
return uni.showToast({
icon: 'success',
title: '数据已加载完毕'
})
}
console.log('antiShake :>> ', antiShake);
if (antiShake) {
uni.hideLoading()
//
clearTimeout(antiShake)
return antiShake = null
}
// Loading,
uni.showLoading({
title: '正在加载',
mask: true
})
antiShake = setTimeout(async () => {
//
details.pageNum += 1
const res = await initpage()
// loading
uni.hideLoading()
//
antiShake = null
// ,
if (res.data && res.data.records.length < details.pageSize) {
uni.showToast({
title: '已经到底了',
icon: 'success'
})
clearTimeout(antiShake)
return option.isEnd = true
}
clearTimeout(antiShake)
}, 500)
} catch (err) {
//TODO handle the exception
console.log('err :>> ', err);
}
}
let details = reactive({
show: false,
datatime: '',
pageType: 1,
pageNum: 1,
pageSize: 10,
datalist: [],
scancode: '',
})
onLoad((op) => {
details.pageType = op.type
// #ifdef APP
utils.ttsspke('请扫描或输入托盘码')
// #endif
})
onShow(() => {
// #ifdef APP
//
uni.$off('scancodedate')
// init()
uni.$on('scancodedate', function (code) {
console.log('code :>> ', code);
if (code) {
console.log(code);
details.scancode = code
scandata()
}
})
// #endif
initpage()
})
// onHide(() => {
// uni.$off('scancodedate')
// })
const date = ref<(string | number)[]>([])
function init() {
details.pageNum = 1
initpage()
}
async function scandata() {
let data = {
trayCode: details.scancode
}
let res = await warehouseTrayTypeorderScanTrayCode(data)
if (res.code !== 200) return
console.log('res', res);
if (Number(res.data.isHasData) === 0) {
utils.ttsspke('请选择分拣方式')
uni.setStorageSync('trayCodeType', res.data.data)
uni.navigateTo({
url: '/pagesHome/pages/ScanSortingType/ScanSortingType?trayCode=' + details.scancode
})
} else {
uni.navigateTo({
url: '/pagesHome/pages/OrderSortingDetail/OrderSortingDetail?trayCode='
+ res.data.data.trayCode + '&trayType='
+ res.data.data.trayType
})
}
}
async function initpage() {
try {
let submitData = {
pageNum: details.pageNum,
pageSize: details.pageSize,
createDateStart: date.value[0] || '',
createDateEnd: date.value[1] || '',
}
const res = await warehouseTrayTypeorderPageList(submitData)
if (res.code !== 200) return
const { code, data } = res
if (code === 200 && data) details.datalist = [...details.datalist, ...data.records]
if (data && data.pages <= details.pageNum) option.isEnd = true
console.log('details.datalist :>> ', details.datalist);
return res
} catch (err) {
//TODO handle the exception
console.log('err :>> ', err);
}
}
function goorderdetail(item : any) {
//
uni.navigateTo({
url: '/pagesHome/pages/OrderSortingDetail/OrderSortingDetail?trayCode='
+ item.trayCode + '&trayType='
+ item.trayType
})
if (Number(details.pageType) == 2) {
uni.navigateTo({
url: '/pagesHome/pages/PeopleSortingDetail/PeopleSortingDetail?trayCode='
+ item.trayCode + '&trayType='
+ item.trayType
})
}
}
function showCalendar() {
details.show = !details.show
}
function onConfirm(e : any) {
console.log(e);
date.value[0] = e.startDate
date.value[1] = e.endDate
details.datatime = date.value[0] + ' 至 ' + date.value[1]
// details.datatime=(uni as any).$u.timeFormat(date.value[0], 'yyyy-mm-dd')+' '+(uni as any).$u.timeFormat(date.value[1], 'yyyy-mm-dd')
}
watchEffect(() => {
if ((date.value as []).length != 0) {
details.datatime = date.value[0] + ' 至 ' + date.value[1]
}
initpage()
})
function cleartime() {
// console.log(1231211);
details.datatime = ''
date.value = []
init()
}
const {
show,
datatime,
datalist,
scancode,
} = toRefs(details)
</script>
<style lang="scss" scoped>
.inputsr {
width: 550upx !important;
height: 75upx;
background: #F5F5F6;
border-radius: 8upx 8upx 8upx 8upx;
opacity: 1;
border: 2upx solid #EEEEEE;
padding: 16upx 18upx;
box-sizing: border-box;
padding-right: 0;
display: flex;
align-items: center;
justify-content: space-between;
font-size: 26upx;
font-weight: 400;
color: #092C4D;
>input {
flex: 1;
font-size: 26upx;
}
}
.schbox {
display: flex;
align-items: center;
justify-content: flex-start;
padding: 15upx 32upx;
box-sizing: border-box;
background-color: #ffffff;
>view:nth-of-type(1) {
// width: 150upx;
font-size: 28upx;
font-weight: 400;
flex: none;
color: #092C4D;
}
>view:nth-of-type(2) {
width: 380upx;
// height: 64upx;
}
>view:nth-of-type(3) {
width: 128upx;
height: 64upx;
background: #D3832A;
border-radius: 8upx;
display: flex;
align-items: center;
justify-content: center;
font-size: 32upx;
font-weight: 400;
color: #FFFFFF;
}
}
.headtop {
display: flex;
align-items: center;
justify-content: space-between;
// margin-top: 20upx;
background-color: #FFFFFF;
padding: 20upx 30upx;
box-sizing: border-box;
>view:nth-of-type(1) {
width: 540upx;
border: 1upx solid #00000020;
padding: 10upx 20upx;
box-sizing: border-box;
// flex: 1;
// margin-right: 50upx;
// border-radius: 10upx;
>input {
flex: 1;
font-size: 28upx;
}
}
>view:nth-of-type(2) {
width: 128upx;
height: 64upx;
background: #D3832A;
border-radius: 8upx;
display: flex;
align-items: center;
justify-content: center;
font-size: 32upx;
font-weight: 400;
color: #FFFFFF;
}
}
.scvmabx {
width: 100%;
height: 71vh;
margin-top: 20upx;
.maxboxs {
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
>.items {
width: 100%;
display: flex;
flex-direction: column;
background-color: #ffffff;
margin-bottom: 20upx;
padding: 16upx 30upx;
box-sizing: border-box;
position: relative;
.items_row {
zoom: 0.9;
display: flex;
font-size: 28upx;
padding-bottom: 15upx;
>view {
width: 60%;
&:nth-child(2) {
width: 40%;
}
}
}
}
//
.tag {
position: absolute;
right: 0;
top: 0;
font-size: 28upx;
padding: 10upx;
color: #fff;
background: #D3832A;
opacity: 0.7;
border-bottom-left-radius: 20upx;
}
.button-container {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
border-top: 4upx solid #eee;
padding-top: 10upx;
}
.button {
color: #fff;
border-radius: 5upx;
padding: 10upx 20upx;
font-size: 28upx;
background: #D3832A;
margin-bottom: 10upx;
}
}
}
</style>

11
pagesHome/pages/CustomerOrdersDetails/CustomerOrdersDetails.vue

@ -161,7 +161,7 @@
<script lang="ts" setup>
import {
deliveryorder,
signforinventory,
deliveryInventory,
deliveryloadingscan,
deliveryloadinginventory,
postAbnormalTruckLoading,
@ -290,7 +290,7 @@
}
//
let response1 = await signforinventory(data)
let response1 = await deliveryInventory(data)
details.stock.data = response1.data || []
})
@ -326,6 +326,7 @@
let num = 0
if (details.order.data) num += details.order.data.reduce((curr, item) => curr + item.loadingNub, 0)
if (details.zero.data) num += details.zero.data.reduce((curr, item) => curr + item.loadingNub, 0)
console.log('details.stock.data :>> ', details.stock.data);
if (details.stock.data) num += details.stock.data.reduce((curr, item) => {
if (item.loadingStatusName !== '未装车') return curr += 1
return curr
@ -389,6 +390,7 @@
try {
const response = await deliveryorder(submitData)
const { data } = response
if (response.code !== 200) return
details.zero.data = []
details.order.data = []
data.forEach(val => {
@ -408,9 +410,10 @@
async function initPageStock(submitData) {
try {
details.stock.data = []
const response = await signforinventory(submitData)
const response = await deliveryInventory(submitData)
const { data } = response
details.stock.data = data
if (response.code !== 200) return
details.stock.data = data || []
return response
} catch (err) {
//TODO handle the exception

6
pagesHome/pages/StockUplist/StockUplist.vue

@ -273,9 +273,9 @@
details.user.goodsAreaName = response.data?.goodsAreaName
details.user.planNum = response.data?.planNum
details.user.scanNum = response.data?.scanNum
details.orderList = response.data?.orderList
details.stockList = response.data?.stockList
if (details.orderStatus === 3) details.zeroOrderList = response.data?.orderList
details.orderList = response.data?.orderList || []
details.stockList = response.data?.stockList || []
if (details.orderStatus === 3) details.zeroOrderList = response.data?.orderList || []
details.isscan = false
return null
}

609
pagesHome/pages/codePlateBracket/codePlateBracket.vue

@ -0,0 +1,609 @@
<template>
<BasicContainer :option="option" :leftClick="option.leftClick">
<!-- 头部 -->
<template #head>
<view class="headtop">
<view>
<input v-model="scancode" placeholder="请输入托盘码" />
</view>
<view @click="scandata">查询</view>
</view>
<view class="schbox">
<view>分拣日期</view>
<view @click='showCalendar' class="inputsr">
<input :value='datatime' disabled placeholder="请选择时间" />
<view @click.stop.prevent>
<u-icon @click='showCalendar' style="margin-right: 10upx;" v-if="!datatime" name="calendar"
color="#999999" size="50"></u-icon>
<u-icon @click="cleartime" style="margin-right: 10upx;" v-else name="close-circle" color="#999999"
size="40"></u-icon>
</view>
</view>
</view>
<!-- 是否装车 -->
<view class="choose_container">
<view class="uni-list-cell-db">
<picker @change="bindPickerChange" :value="details.scanStateChooseIndex"
:range="details.scanStateList.map(val => val.title)">
<view class="uni-input">{{details.scanStateList.map(val => val.title)[details.scanStateChooseIndex]}}
</view>
</picker>
</view>
<view class=""></view>
<view class="uni-list-cell-left">
<u-icon name="arrow-right" color="#000"></u-icon>
</view>
</view>
</template>
<!-- 主体 -->
<template #body>
<scroll-view class="scvmabx" @scrolltolower="reachBottomInitPage" scroll-y="true" @touchmove.stop>
<view class="maxboxs">
<view class="items" v-for="item in datalist">
<view class="headtopv">
<view>
<image src="/pagesHome/static/tpicon.png"></image>
<view>{{`${item.trayName} ( ${item.trayCode} )`}}</view>
</view>
<view @click="goorderdetail(item)">继续分拣</view>
</view>
<view class="contentbx">
<view class="unames">
<view>
<view>
<image src="/pagesHome/static/uname.png"></image>
<view>名称</view>
</view>
<view>{{item.marketName}}{{item.filterValue}}</view>
</view>
<view>
<view>
<image src="/pagesHome/static/dttype.png"></image>
<view>打托方式</view>
</view>
<view>{{item.trayTypeName}}</view>
</view>
<view>
<view>
<image src="/pagesHome/static/dttype.png"></image>
<view>备注</view>
</view>
<view>{{item.remark}}</view>
</view>
</view>
<view class="numbox">
<view>
<view>订单数</view>
<view>{{item.totalNum}}</view>
</view>
<view>
<view>订单总数</view>
<view>{{item.orderTotalNum}}</view>
</view>
<view>
<view>库存品数</view>
<view>{{item.stockNum}}</view>
</view>
<view>
<view>库存品总数</view>
<view>{{item.stockTotalNum}}</view>
</view>
</view>
</view>
</view>
</view>
</scroll-view>
</template>
</BasicContainer>
<l-calendar v-model:value="show" :initStartDate='date[0]' :initEndDate='date[1]' @hide='showCalendar'
@change="onConfirm"></l-calendar>
<!-- #ifdef APP -->
<saomiao2 :ishidestop="scanState !== 0"></saomiao2>
<!-- #endif -->
</template>
<script lang="ts" setup>
import {
warehouseTrayTypeorderPageList,
warehouseTrayTypeorderScanTrayCode,
} from '@/api/user.js'
import {
onLoad,
onShow,
onHide,
} from '@dcloudio/uni-app'
import { reactive, ref, toRefs, watchEffect } from "vue";
import utils from '@/utils/utils.js'
import useSystemSettingsStore from '@/store/useSystemSettingsStore';
import { storeToRefs } from 'pinia';
const { scanState } = storeToRefs(useSystemSettingsStore())
//
const option = reactive({
leftClick() {
uni.reLaunch({
url: "/pages/index/index"
})
},
//
title: '已经打托列表',
//
async pullDownRefreshInitPage() {
//
details.pageNum = 1
//
details.datalist = []
//
option.isEnd = false
//
option.haveData = true
await initpage()
if (datalist.value.length === 0) {
uni.showToast({
title: '暂时没有数据',
icon: 'error'
})
option.haveData = false
}
if (option.isEnd) {
return uni.showToast({
icon: 'success',
title: '数据已加载完毕'
})
}
return null
},
//
reachBottomInitPage: async () => { return null },
haveData: true,
isEnd: false
})
//
let antiShake : any = null
//
function reachBottomInitPage() {
try {
// ,
if (option.isEnd) {
return uni.showToast({
icon: 'success',
title: '数据已加载完毕'
})
}
console.log('antiShake :>> ', antiShake);
if (antiShake) {
uni.hideLoading()
//
clearTimeout(antiShake)
return antiShake = null
}
// Loading,
uni.showLoading({
title: '正在加载',
mask: true
})
antiShake = setTimeout(async () => {
//
details.pageNum += 1
const res = await initpage()
// loading
uni.hideLoading()
//
antiShake = null
// ,
if (res.data && res.data.records.length < details.pageSize) {
uni.showToast({
title: '已经到底了',
icon: 'success'
})
clearTimeout(antiShake)
return option.isEnd = true
}
clearTimeout(antiShake)
}, 500)
} catch (err) {
//TODO handle the exception
console.log('err :>> ', err);
}
}
let details = reactive({
show: false,
datatime: '',
pageType: 1,
pageNum: 1,
pageSize: 10,
datalist: [],
scancode: '',
scanStateList: [{ title: '未装车', value: 1 }, { title: '已装车', value: 2 }],
// --
scanStateChooseIndex: 0
})
onLoad((op) => {
details.pageType = op.type
// #ifdef APP
utils.ttsspke('请扫描或输入托盘码')
// #endif
})
onShow(() => {
// #ifdef APP
//
uni.$off('scancodedate')
// init()
uni.$on('scancodedate', function (code) {
console.log('code :>> ', code);
if (code) {
console.log(code);
details.scancode = code
scandata()
}
})
// #endif
initpage()
})
// onHide(() => {
// uni.$off('scancodedate')
// })
const date = ref<(string | number)[]>([])
function init() {
details.pageNum = 1
initpage()
}
async function scandata() {
let data = {
trayCode: details.scancode
}
let res = await warehouseTrayTypeorderScanTrayCode(data)
if (res.code !== 200) return
console.log('res', res);
if (Number(res.data.isHasData) === 0) {
utils.ttsspke('请选择分拣方式')
uni.setStorageSync('trayCodeType', res.data.data)
uni.navigateTo({
url: '/pagesHome/pages/ScanSortingType/ScanSortingType?trayCode=' + details.scancode
})
} else {
uni.navigateTo({
url: '/pagesHome/pages/OrderSortingDetail/OrderSortingDetail?trayCode='
+ res.data.data.trayCode + '&trayType='
+ res.data.data.trayType
})
}
}
async function initpage() {
try {
let submitData = {
pageNum: details.pageNum,
pageSize: details.pageSize,
createDateStart: date.value[0] || '',
createDateEnd: date.value[1] || '',
}
const res = await warehouseTrayTypeorderPageList(submitData)
if (res.code !== 200) return
const { code, data } = res
if (code === 200 && data) details.datalist = [...details.datalist, ...data.records]
if (data && data.pages <= details.pageNum) option.isEnd = true
console.log('details.datalist :>> ', details.datalist);
return res
} catch (err) {
//TODO handle the exception
console.log('err :>> ', err);
}
}
function goorderdetail(item : any) {
//
uni.navigateTo({
url: '/pagesHome/pages/OrderSortingDetail/OrderSortingDetail?trayCode='
+ item.trayCode + '&trayType='
+ item.trayType
})
if (Number(details.pageType) == 2) {
uni.navigateTo({
url: '/pagesHome/pages/PeopleSortingDetail/PeopleSortingDetail?trayCode='
+ item.trayCode + '&trayType='
+ item.trayType
})
}
}
function showCalendar() {
details.show = !details.show
}
function onConfirm(e : any) {
console.log(e);
date.value[0] = e.startDate
date.value[1] = e.endDate
details.datatime = date.value[0] + ' 至 ' + date.value[1]
// details.datatime=(uni as any).$u.timeFormat(date.value[0], 'yyyy-mm-dd')+' '+(uni as any).$u.timeFormat(date.value[1], 'yyyy-mm-dd')
}
watchEffect(() => {
if ((date.value as []).length != 0) {
details.datatime = date.value[0] + ' 至 ' + date.value[1]
}
initpage()
})
function cleartime() {
// console.log(1231211);
details.datatime = ''
date.value = []
init()
}
/**
* 处理扫描后台监听状态
*/
function bindPickerChange(e) {
console.log('picker发送选择改变,携带值为', e.detail.value)
details.scanStateChooseIndex = e.detail.value
}
const {
show,
datatime,
datalist,
scancode,
} = toRefs(details)
</script>
<style lang="scss">
.inputsr {
width: 550upx !important;
height: 75upx;
background: #F5F5F6;
border-radius: 8upx 8upx 8upx 8upx;
opacity: 1;
border: 2upx solid #EEEEEE;
padding: 16upx 18upx;
box-sizing: border-box;
padding-right: 0;
display: flex;
align-items: center;
justify-content: space-between;
font-size: 26upx;
font-weight: 400;
color: #092C4D;
>input {
flex: 1;
font-size: 26upx;
}
}
.schbox {
display: flex;
align-items: center;
justify-content: flex-start;
padding: 15upx 32upx;
box-sizing: border-box;
background-color: #ffffff;
>view:nth-of-type(1) {
// width: 150upx;
font-size: 28upx;
font-weight: 400;
flex: none;
color: #092C4D;
}
>view:nth-of-type(2) {
width: 380upx;
// height: 64upx;
}
>view:nth-of-type(3) {
width: 128upx;
height: 64upx;
background: #D3832A;
border-radius: 8upx;
display: flex;
align-items: center;
justify-content: center;
font-size: 32upx;
font-weight: 400;
color: #FFFFFF;
}
}
.headtop {
display: flex;
align-items: center;
justify-content: space-between;
// margin-top: 20upx;
background-color: #FFFFFF;
padding: 20upx 30upx;
box-sizing: border-box;
>view:nth-of-type(1) {
width: 540upx;
border: 1upx solid #00000020;
padding: 10upx 20upx;
box-sizing: border-box;
// flex: 1;
// margin-right: 50upx;
// border-radius: 10upx;
>input {
flex: 1;
font-size: 28upx;
}
}
>view:nth-of-type(2) {
width: 128upx;
height: 64upx;
background: #D3832A;
border-radius: 8upx;
display: flex;
align-items: center;
justify-content: center;
font-size: 32upx;
font-weight: 400;
color: #FFFFFF;
}
}
.scvmabx {
width: 100%;
height: 71vh;
margin-top: 20upx;
.maxboxs {
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
>.items {
width: 100%;
display: flex;
flex-direction: column;
background-color: #ffffff;
margin-bottom: 20upx;
padding: 16upx 30upx;
box-sizing: border-box;
.contentbx {
display: flex;
flex-direction: column;
.unames {
display: flex;
flex-direction: column;
align-items: flex-start;
padding: 15upx 0;
>view {
display: flex;
align-items: center;
font-size: 28upx;
&:nth-of-type(1) {
margin-bottom: 20upx;
}
>view:nth-of-type(1) {
width: 180upx;
display: flex;
align-items: center;
justify-content: flex-start;
>image {
width: 42upx;
height: 42upx;
margin-right: 15upx;
}
}
}
}
.numbox {
width: 686upx;
height: 160upx;
background: #F5F7FB;
border-radius: 8upx;
display: flex;
align-items: center;
justify-content: space-between;
margin: auto;
>view {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
>view:nth-of-type(1) {
font-size: 28upx;
font-weight: 400;
color: #AFB4BA;
margin-bottom: 20upx;
}
>view:nth-of-type(2) {
font-size: 36upx;
font-weight: 400;
color: #020B18;
}
}
}
}
.headtopv {
display: flex;
align-items: center;
justify-content: space-between;
padding: 14upx 0;
border-bottom: 2upx solid #EEEEEE;
>view:nth-of-type(1) {
display: flex;
align-items: center;
justify-content: center;
color: #020B18;
font-size: 32upx;
>image {
width: 32upx;
height: 32upx;
margin-right: 10upx;
}
}
>view:last-child {
width: 192upx;
height: 72upx;
background: #D3832A;
border-radius: 8upx 8upx 8upx 8upx;
opacity: 1;
display: flex;
align-items: center;
justify-content: center;
font-size: 28upx;
font-weight: 400;
color: #FFFFFF;
}
}
}
}
}
</style>
<style lang='scss' scoped>
.choose_container {
display: flex;
justify-content: space-between;
align-items: center;
padding: 20upx;
background: #fff;
margin-top: 5upx;
position: relative;
.uni-list-cell-db {
position: absolute;
top: 0;
left: 0;
flex: 1;
padding-left: 20upx;
width: 100vw;
height: 100%;
/* text-align: right; */
box-sizing: border-box;
display: flex;
align-items: center;
&>uni-picker {
width: 100%;
}
}
}
</style>

2
pagesHome/pages/scansorting/scansorting.vue

@ -247,7 +247,7 @@
console.log('res', res);
if (Number(res.data.isHasData) === 0) {
utils.ttsspke('请选择分拣方式')
// utils.ttsspke('')
uni.setStorageSync('trayCodeType', res.data.data)
uni.navigateTo({
url: '/pagesHome/pages/ScanSortingType/ScanSortingType?trayCode=' + details.scancode

39
pagesHome/pages/setbarcode/setbarcode.vue

@ -72,6 +72,13 @@
</view>
<input class="popUpInput" v-model="details.packageNum" type="number" placeholder="新生成包条数量" />
</PopUp>
<!-- 修改批次 -->
<PopUp ref="popUp_Edit">
<view class="popUp_Edit_text">
检测当前批次和计划批次不同是否切换批次
</view>
</PopUp>
<!-- #ifdef APP -->
<saomiao2 :ishidestop="scanState !== 0"></saomiao2>
<!-- #endif -->
@ -90,6 +97,7 @@
distributionStockupstockupScan,
distributionStockuporderInfo,
distributionStockupstockupScanCheck,
distributionStockupstockupUpdateStockup,
stockConfigList
} from '@/api/user.js'
import { detailType } from '@/interfaces/pagesHome/setbarcode'
@ -122,6 +130,7 @@
const tips = ref(null)
const basicContainer = ref(null)
const popUp_AddPrint = ref(null)
const popUp_Edit = ref(null)
//
const option = {
title: '配置包条码',
@ -278,19 +287,21 @@
let data = {
reservationId: details.reservationId,
stockListId: details.items.stockListId,
packageNum: details.addNUm,
packageNum: details.packageNum,
allocationId: details.allocationId,
status: details.completeStact ? 1 : 0,
cargoNumber: details.items.cargoNumber
}
let response = await distributionStockupstockupStockListPackageCode(data)
if (response.code !== 200) return
popUp_AddPrint.value.details.showPopUp = false
console.log(response);
details.printlist = response.data
let checklist = []
response.data.map((item, index) => {
checklist.push(index)
})
console.log('tips :>> ', tips);
tips.value.setdetails({
title: '请选择要打印的包条',
tipstate: 2,
@ -298,6 +309,7 @@
checklist: checklist,
inputtext: '',
confirmTxt: '打印',
isshow: true,
success: (deta) => {
if (deta.checklist.length == 0) {
uni.showToast({
@ -365,13 +377,15 @@
stockPrint: details.stockPrint,
status: details.stockPrint,
id: details.orderpackgedetails.stockListId,
cargoNumber: details.items.cargoNumber
cargoNumber: details.items.cargoNumber,
marketCode: details.items.cargoNumber,
}
console.log('details.items.cargoNumber :>> ', details.items.cargoNumber);
// utils.ttsspke('stockPrint'+details.stockPrint)
if (details.stockPrint === 2) {
console.log('data :>> ', data);
delete data.marketCode
let res = await distributionStockupstockupScan(data)
console.log(res);
if (res.code == 200) {
@ -387,11 +401,25 @@
const { code: resCode } = response
if (resCode === 6002) {
if (resCode === 60002) {
console.log('123 :>> ', 123);
popUp_Edit.value.setDetails({
title: '切换批次',
showPopUp: true,
async success() {
data.stockListId = response.data
const resp = await distributionStockupstockupUpdateStockup(data)
console.log('resp :>> ', resp);
if (resp.code == 200) {
popUp_Edit.value.details.showPopUp = false
basicContainer.value.startPullDownRefresh()
}
}
})
}
//
else if (resCode === 200) {
delete data.marketCode
let res = await distributionStockupstockupScan(data)
console.log(res);
if (res.code == 200) {
@ -530,4 +558,9 @@
border-radius: 5upx;
padding: 5upx 10upx;
}
.popUp_Edit_text {
font-size: 28upx;
color: #f00;
}
</style>

2
pagesHome/pages/signOrderScan/signOrderScan.vue

@ -249,7 +249,7 @@
if (response.code !== 200) return
details.zeroArr = []
details.orderArr = []
response.data.records.forEach(val => {
if (response.data && response.data.records) response.data.records.forEach(val => {
//
if (val.isZero === '1') return details.zeroArr.push(val)
details.orderArr.push(val)

25
pagesTask/pages/dynamicCheckDetails/dynamicCheckDetails.vue

@ -717,7 +717,7 @@
}
}
// 退 ||
if (_flag && details.pageType === 3) return
if (_flag || details.pageType === 3) return
try {
uni.showLoading({
@ -995,7 +995,8 @@
}
//
}
content = '上架成功' + _number + '件'
if (_number !== 0) content = '上架成功' + _number + '件'
else content = '请先盘点再上架'
} else content = '上架失败, 库位数据有误'
uni.showToast({
@ -1536,10 +1537,10 @@
/** 新增库存品 */
const handleAddStock = () => {
popUp_AddStock.value.setDetails({
title: '新增零担',
title: '新增库存品',
showPopUp: true,
success() {
if (!details.addInfo.orderCode || !details.addInfo.incomingBatch) return uni.showToast({
if (!details.addInfo.orderCode && !details.addInfo.incomingBatch) return uni.showToast({
title: '请输入合同号或批次号',
icon: 'none'
})
@ -1787,8 +1788,12 @@
if (_item.isNew === 1) {
if (details.pageType === 2) {
_item.allocationId = details.pageInfos.allocationId
_item.groundingAllocationId = details.pageInfos.allocationId
_item.groundingPositionCode = details.pageInfos.positionCode
_item.positionCode = details.pageInfos.allocation
// Id,
if (_item.groundingAllocationId === _item.allocationId) {
delete _item.groundingAllocationId
delete _item.groundingPositionCode
}
}
else if (details.pageType === 4) {
_item.trayCode = val.trayCode
@ -1805,8 +1810,12 @@
console.log('res :>> ', res);
const { code } = res
if (code === 200) {
//
uni.navigateBack()
utils.ttsspke('盘点成功')
const timer = setTimeout(() => {
//
uni.navigateBack()
clearTimeout(timer)
}, 1000)
}
} catch (err) {
console.log('err :>> ', err);

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

File diff suppressed because one or more lines are too long

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

File diff suppressed because it is too large Load Diff

10
unpackage/dist/dev/app-plus/pages/index/index.css vendored

@ -228,30 +228,28 @@ uni-view[data-v-f631659b], uni-scroll-view[data-v-f631659b], uni-swiper-item[dat
.mabox {
display: flex;
flex-direction: column;
padding: 0.625rem 0;
box-sizing: border-box;
width: 21.4375rem;
margin: auto;
background-color: #ffffff;
margin-bottom: 0.625rem;
margin-bottom: 0.3125rem;
margin-top: 0.3125rem;
border-radius: 0.3125rem;
box-shadow: 0 0.0625rem 0.3125rem 0 #e2e2e380;
}
.mabox .boxtitl {
font-size: 1.0625rem;
font-size: 0.9375rem;
font-weight: 500;
margin-bottom: 0.3125rem;
border-bottom: 0.03125rem solid #EEEEEE;
padding: 0 0.625rem;
padding-bottom: 0.625rem;
padding: 0.625rem;
color: #092C4D;
}
.mabox .minboxlist {
display: flex;
flex-wrap: wrap;
align-items: center;
padding-top: 0.3125rem;
padding: 0.3125rem 0;
}
.mabox .minboxlist > uni-view {
width: 25%;

4
unpackage/dist/dev/app-plus/pagesHome/pages/setbarcode/setbarcode.css vendored

@ -124,3 +124,7 @@
border-radius: 0.15625rem;
padding: 0.15625rem 0.3125rem;
}
.popUp_Edit_text {
font-size: 0.875rem;
color: #f00;
}
Loading…
Cancel
Save