Browse Source

新增配载装车列表页面

myd
qb 1 year ago
parent
commit
0199bac426
  1. 24
      api/user.js
  2. 8
      compoment/BasicContainer/BasicContainer.vue
  3. 4
      config/host.js
  4. 6
      manifest.json
  5. 69
      pages.json
  6. 10
      pages/index/index.vue
  7. 4
      pagesHome/pages/CustomerSign/CustomerSign.vue
  8. 63
      pagesHome/pages/PeopleScanUp/PeopleScanUp.vue
  9. 13
      pagesHome/pages/PickingScanList/PickingScanList.vue
  10. 478
      pagesHome/pages/RelayScanList/RelayScanList.vue
  11. 14
      pagesHome/pages/StockUplist/StockUplist.vue
  12. 481
      pagesHome/pages/StowageList/StowageList.vue
  13. 700
      pagesHome/pages/StowageListDetails/StowageListDetails.vue
  14. 5
      pagesHome/pages/createAddServe/createAddServe.vue
  15. 283
      pagesHome/pages/loadingRetention/loadingRetention.vue
  16. 11
      pagesHome/pages/setbarcode/setbarcode.vue
  17. 10
      pagesHome/pages/signinScan/signinScan.vue
  18. 2
      unpackage/dist/build/app-plus/pages/index/index.css
  19. 2
      unpackage/dist/build/app-plus/pagesHome/pages/CustomerOrdersDetails/CustomerOrdersDetails.css
  20. 2
      unpackage/dist/build/app-plus/pagesHome/pages/DeliveryCustomerScan/DeliveryCustomerScan.css
  21. 2
      unpackage/dist/build/app-plus/pagesHome/pages/OrderSortingDetail/OrderSortingDetail.css
  22. 2
      unpackage/dist/build/app-plus/pagesHome/pages/RemoveTray/RemoveTray.css
  23. 2
      unpackage/dist/build/app-plus/pagesHome/pages/pickingScan/pickingScan.css
  24. 2
      unpackage/dist/build/app-plus/pagesHome/pages/scansorting/scansorting.css
  25. 2
      unpackage/dist/build/app-plus/pagesHome/pages/setbarcode/setbarcode.css
  26. 969
      unpackage/dist/dev/app-plus/app-service.js
  27. 6
      unpackage/dist/dev/app-plus/manifest.json

24
api/user.js

@ -1883,4 +1883,28 @@ export function $_retentionTrayScan(data) {
method: "post",
data
});
}
/**
* 配载列表
* @param {Object} data
*/
export function postCarsLoadPageList(data) {
return request({
url: `logpm-trunkline/api/carsLoad/carsLoadPageList`,
method: "post",
data
});
}
/**
* 配载列表
* @param {Object} data
*/
export function postFindCarsLoadingDetail(data) {
return request({
url: `logpm-trunkline/api/carsLoad/findCarsLoadingDetail`,
method: "post",
data
});
}

8
compoment/BasicContainer/BasicContainer.vue

@ -102,14 +102,14 @@
//
onPullDownRefresh(() => {
const timer = setTimeout(async () => {
onPullDownRefresh(async () => {
await pullDownRefreshInitPage()
const timer = setTimeout(() => {
//
await pullDownRefreshInitPage()
uni.stopPullDownRefresh()
//
clearTimeout(timer)
}, 500)
}, 300)
})
//

4
config/host.js

@ -4,11 +4,11 @@
* 测试域名
* */
//测试域名
const devhost = 'http://test.api.huitongys.com/'
// const devhost = 'http://test.api.huitongys.com/'
// lmy
// const devhost = 'http://192.168.10.123:8889/'
// zhy
// const devhost = 'http://192.168.10.48:8888/'
const devhost = 'http://192.168.10.48:13000/'
// tjj
// const devhost = 'http://192.168.10.25:13000/'
// cyz

6
manifest.json

@ -1,9 +1,9 @@
{
"name" : "货无忧",
"appid" : "__UNI__FC20B18",
"appid" : "__UNI__EB22F37",
"description" : "",
"versionName" : "1.0.31",
"versionCode" : 1031,
"versionName" : "1.0.32",
"versionCode" : 1032,
"transformPx" : false,
/* 5+App */
"app-plus" : {

69
pages.json

@ -134,6 +134,63 @@
}
}
},
{
"path": "pages/StowageList/StowageList",
"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/StowageListDetails/StowageListDetails",
"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/RelayScanList/RelayScanList",
"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/codePlateBracket/codePlateBracket",
@ -1310,12 +1367,12 @@
// "selectedIconPath": "/static/TabberIcon/icon3check.png",
// "text": "报表"
// },
{
"pagePath": "pages/news/news",
"iconPath": "/static/TabberIcon/icon4.png",
"selectedIconPath": "/static/TabberIcon/icon4check.png",
"text": "消息"
},
// {
// "pagePath": "pages/news/news",
// "iconPath": "/static/TabberIcon/icon4.png",
// "selectedIconPath": "/static/TabberIcon/icon4check.png",
// "text": "消息"
// },
{
"pagePath": "pages/user/user",
"iconPath": "/static/TabberIcon/icon5.png",

10
pages/index/index.vue

@ -144,6 +144,16 @@
name: '自提扫描',
router: '/pagesHome/pages/SelfPickupScan/SelfPickupScan',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '配载装车',
router: '/pagesHome/pages/StowageList/StowageList',
},
{
icon: 'http://htys.oss-cn-chengdu.aliyuncs.com/htys/afb031efec7d2f8620ee68c71f87a80e.png',
name: '中转装车',
router: '/pagesHome/pages/RelayScanList/RelayScanList',
},
]
},
{

4
pagesHome/pages/CustomerSign/CustomerSign.vue

@ -79,9 +79,9 @@
<view @click="gosinorderscan(item)">签收扫描</view>
<view @click="uplodimg(item)">上传签收图片</view>
</view>
<!-- <view @click="gosetorice(item)" class="mabut">
<view @click="gosetorice(item)" class="mabut">
设置增值服务
</view> -->
</view>
<view class="mabut" @click="allclick(item)"
v-if="authbuts.findIndex(val => val.code === '127')!=-1&&item.deliveryStatus!='完成配送'">
批量签收

63
pagesHome/pages/PeopleScanUp/PeopleScanUp.vue

@ -128,6 +128,7 @@
<view class="tpbx">
<image src="/pagesHome/static/kuweiicon.png"></image>
<view>总包数{{item.totalNumber}}</view>
<view>上架数{{item.enterNum}}</view>
</view>
</view>
@ -216,6 +217,7 @@
<view class="tpbx">
<image src="/pagesHome/static/kuweiicon.png"></image>
<view>总包数{{item.totalNum}}</view>
<view>上架数{{item.stockNum}}</view>
</view>
<image v-if="Number(details.upshelfScanType)!=3" class="qtimgzt"
@ -308,8 +310,8 @@
</view>
<view class="rksu" @click.stop.prevent>
<view>
<view class="title">入库</view>
<input placeholder="请输入入库数" v-model="item.enterNum" @input="inputNum(item)" />
<view class="title">上架</view>
<input placeholder="请输入上架数" v-model="item.enterNum" @input="inputNum(item)" />
</view>
</view>
<view class="lisbite" v-if="checkinarr.indexOf(index)!=-1">
@ -427,10 +429,8 @@
watchEffect(() => {
if (Number(details.upshelfScanType) == 1 || Number(details.upshelfScanType) == 2) {
details.uplistarr = fn2(details.uplistarr, 'orderCode')
} else if (Number(details.upshelfScanType) == 3) {
details.uplistarr = fn2(details.uplistarr, 'orderPackageCode')
} else if (Number(details.upshelfScanType) == 4) {
details.uplistarr = fn2(details.uplistarr, 'trayCode')
} else if (Number(details.upshelfScanType) == 3 || Number(details.upshelfScanType) == 4) {
details.uplistarr = fn2(details.uplistarr, 'materialCode,incomingBatch')
}
})
function goorderdetail(item) {
@ -521,7 +521,7 @@
// })
}
})
details.uplistarr = fn2(details.uplistarr, 'orderCode')
details.uplistarr = fn2(details.uplistarr, 'materialCode,incomingBatch')
details.showstate = 0
details.codelist = []
details.waybillCode = ''
@ -627,21 +627,6 @@
}
// loading
uni.hideLoading()
console.log('res上架 :>> ', res);
if (res.code == 200) {
uni.showToast({
title: '上架成功',
icon: 'none'
})
details.uplistarr = []
details.scancode = details.allocationId
scandata()
} else {
uni.showToast({
title: '上架失败',
icon: 'error'
})
}
tip.value.setisshow(false)
},
cancel: () => {
@ -663,27 +648,45 @@
details.checkstate = state
}
//
function fn2(tempArr, fnname) {
function fn2(tempArr, fnname : string) {
//
const _fnnameArr = fnname.split(',')
console.log('_fnnameArr :>> ', _fnnameArr);
console.log('tempArr :>> ', tempArr);
let result = [];
tempArr.map((item) => {
if (result.length == 0) {
item.enterNum = Number(item.enterNum)
result.push(item)
} else {
let ckindex = -1
result.map((ite, index) => {
if (ite[fnname] == item[fnname]) {
ckindex = index
}
/* let ckindex = -1
result.map((ite, index) => {
if (ite[fnname] == item[fnname]) {
ckindex = index
}
}) */
const _ckindex = result.findIndex(ite => {
return _fnnameArr.every(key => {
console.log('key :>> ', key);
console.log('ite[key] == item[key] :>> ', ite[key] == item[key]);
return ite[key] == item[key]
})
})
if (ckindex != -1) {
result[ckindex].enterNum += Number(item.enterNum)
console.log('_ckindex :>> ', _ckindex);
if (_ckindex != -1) {
result[_ckindex].enterNum += Number(item.enterNum)
} else {
item.enterNum = Number(item.enterNum)
result.push(item)
}
}
})
console.log('result :>> ', result);
return result;
};

13
pagesHome/pages/PickingScanList/PickingScanList.vue

@ -33,9 +33,13 @@
<view>订单总数</view>
<view>{{item.orderNum}}</view>
</view>
<view>
<view>库存品数量</view>
<view>{{item.inventoryNub || 0}}</view>
</view>
<view>
<view>计划件数</view>
<view>{{item.planNum}}</view>
<view>{{item.planNum + item.inventoryNub}}</view>
</view>
<view>
<view>已备数量</view>
@ -190,7 +194,12 @@
}
let response = await distributionStockuppageListClient(data)
if (response.code !== 200) return
details.datalist = response.data.orderList
details.datalist = []
if (response.data && response.data.orderList) details.datalist = response.data.orderList.map(val => {
val.inventoryNub = val.inventoryNub !== 0 ? val.inventoryNub : 0
val.planNum = val.planNum !== 0 ? val.planNum : 0
return val
})
details.items = response.data
}

478
pagesHome/pages/RelayScanList/RelayScanList.vue

@ -0,0 +1,478 @@
<template>
<!-- <u-navbar title="拣货扫描" placeholder border=true :autoBack="true" leftIconSize='35'></u-navbar> -->
<BasicContainer ref="basicContainer" :option="option" :leftClick="backPreviousPage">
<template #head>
<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: 10rpx;" v-if="!datatime" name="calendar"
color="#999999" size="50"></u-icon>
<u-icon @click="cleartime" style="margin-right: 10rpx;" v-else name="close-circle" color="#999999"
size="40"></u-icon>
</view>
</view>
<view @click="init">
查询
</view>
</view>
<view class="tabtip">
<view @click="setstate(1)">
<view :class="status==1?'xz':''">为发车</view>
</view>
<view @click="setstate(2)">
<view :class="status==2?'xz':''">已发车</view>
</view>
</view>
</template>
<template #body>
<scroll-view class="sccv" scroll-y="true" @scrolltolower="jiazai">
<view class="mabx">
<view v-for="item in dataList" :key="item">
<view class="topbox">
<view class="type1">
<view>
<text style="color: #90A0AF;">配车类型</text>{{item.typeServiceStr}}
</view>
<view>
<text style="color: #90A0AF;">备货是否完成</text>{{item.stockupStatusStr}}
</view>
</view>
<view class="type1">
<view>
<text style="color: #90A0AF;">客户</text>{{item.customer}}
</view>
<view>
<text style="color: #90A0AF;">备货区域</text>{{item.stockupArea}}
</view>
</view>
<view class="type3">
<view>
<text style="color: #90A0AF;">库位</text>{{item.warehouseArea}}
</view>
</view>
<view class="type3">
<view>
<text style="color: #90A0AF;">托盘</text>{{item.trays}}
</view>
</view>
<view class="type2">
<view>
<view>订单总数</view>
<view>{{item.orderNum}}</view>
</view>
<view>
<view>计划备货件数</view>
<view>{{item.planNum}}</view>
</view>
<view>
<view>备货件数</view>
<view>{{item.realNum}}</view>
</view>
<view>
<view>库存品数</view>
<view>{{item.inventoryNub}}</view>
</view>
</view>
</view>
<view class="bts" v-if="Number(item.stockupStatus)!=40">
<!-- <view @click="submitsuccess">
备货完成
</view> -->
<view @click="gostockuplist(item)">
去备货
</view>
</view>
</view>
</view>
</scroll-view>
</template>
</BasicContainer>
<tips ref="tip"></tips>
<l-calendar v-model:value="show" :initStartDate='date[0]' :initEndDate='date[1]' @hide='showCalendar'
@change="onConfirm"></l-calendar>
<!-- <hd-calendar mode="range" color='#D3832A' minDate='2023-01-01' @confirm="onConfirm" /> -->
</template>
<script lang="ts" setup>
import {
onLoad,
onShow,
onHide,
onUnload,
onPullDownRefresh
} from '@dcloudio/uni-app'
import { postCarsLoadPageList } from '@/api/user.js'
import { timeType } from '@/interfaces/pagesHome/allType'
import { inject, reactive, ref, toRefs, watchEffect } from "vue";
import utils from '@/utils/utils';
const option = {
title: '配载装车',
haveData: true,
async pullDownRefreshInitPage() {
details.dataList = []
return await init()
}
}
let details = reactive({
datatime: '',
dataList: [],
show: false,
pageNum: 1,
size: 10,
stockupDate: '',
status: 1,
})
let tip = ref(null)
const basicContainer = ref(null)
const date = ref<number | string[]>([])
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]
}
})
onShow(() => {
// #ifdef APP
uni.$off('scancodedate')
// #endif
const timer = setTimeout(() => {
basicContainer.value.startPullDownRefresh()
clearTimeout(timer)
}, 200)
})
onLoad(() => {
date.value[0] = (uni as any).$u.timeFormat((new Date().valueOf() - 1000 * 60 * 60 * 24 * 3), 'yyyy-mm-dd')
date.value[1] = (uni as any).$u.timeFormat((new Date().valueOf()), 'yyyy-mm-dd')
utils.ttsspke('请选择拣货任务')
})
async function init() {
details.pageNum = 1
details.dataList = []
return initpage()
}
function jiazai() {
details.pageNum++
initpage()
}
async function initpage() {
try {
uni.showLoading({
title: '数据加载中',
mask: true
})
let data = {
pageNum: details.pageNum,
pageSize: details.size,
startDate: date.value[0],
endDate: date.value[1],
type: details.status,
}
let response = await postCarsLoadPageList(data)
if (response.code !== 200) return
if (details.pageNum == 1 && response.data) {
details.dataList = response.data.records
} else {
if (response.data.records.length == 0) {
uni.showToast({
title: '已经到底了。',
icon: 'none'
})
details.pageNum--
return
}
details.dataList = details.dataList.concat(response.data.records)
}
} catch (e) {
//TODO handle the exception
} finally {
uni.hideLoading()
details.dataList = [{}]
return null
}
}
function checktime(event : timeType) {
console.log(event);
details.datatime = (uni as any).$u.timeFormat(event.value, 'yyyy-mm-dd');
details.show = false
console.log(details.datatime);
}
function gostockuplist(item : any) {
uni.reLaunch({
url: '/pagesHome/pages/PickingScanList/PickingScanList?id=' + item.id + '&stockupArea=' + item.stockupArea,
})
}
function cleartime() {
// console.log(1231211);
details.datatime = ''
date.value = []
basicContainer.value.startPullDownRefresh()
}
function setstate(state : number) {
details.status = state
basicContainer.value.startPullDownRefresh()
}
//
function backPreviousPage() {
uni.reLaunch({
url: '/pages/index/index'
})
}
const { datatime, dataList, show, status } = toRefs(details)
</script>
<style lang="scss">
.inputsr {
width: 400upx !important;
height: 64upx;
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;
}
}
.sccv {
width: 100%;
height: 74vh;
margin-top: 20upx;
.mabx {
display: flex;
flex-direction: column;
align-items: center;
width: 100%;
box-sizing: border-box;
padding: 20upx 32upx;
padding-top: 0upx;
>view {
width: 686upx;
background: #FFFFFF;
display: flex;
flex-direction: column;
box-sizing: border-box;
border-bottom: 1upx solid #ebebeb;
padding-bottom: 30upx;
background-color: #ffffff;
margin-bottom: 20upx;
padding-top: 20upx;
border-radius: 8upx;
>view:nth-last-child(1) {
border-bottom: none !important;
}
.topbox {
display: flex;
flex-direction: column;
padding: 24upx;
border-bottom: 2upx solid #EEEEEE;
>.type1 {
width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 20upx;
font-size: 28upx;
color: #161616;
>view {
width: 50%;
}
}
>.type2 {
width: 100%;
display: flex;
align-items: center;
justify-content: space-around;
margin-bottom: 15upx;
font-size: 28upx;
color: #161616;
margin-top: 20upx;
>view {
display: flex;
flex-direction: column;
align-items: center;
>view:nth-of-type(1) {
font-size: 28upx;
font-weight: 400;
color: #092C4D;
}
&:nth-of-type(1) {
>view:nth-of-type(2) {
color: #092C4D;
}
}
&:nth-of-type(2) {
>view:nth-of-type(2) {
color: #3AD8BC;
}
}
&:nth-of-type(3) {
>view:nth-of-type(2) {
color: #FA8C16;
}
}
>view:nth-of-type(2) {
font-size: 36upx;
margin-top: 10upx;
}
}
}
>.type3 {
width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 20upx;
font-size: 26upx;
color: #161616;
}
}
>.bts {
display: flex;
align-items: center;
justify-content: center;
margin-top: 20upx;
>view:nth-of-type(1) {
width: 204upx;
height: 64upx;
background: #FFFFFF;
border-radius: 8upx;
opacity: 1;
border: 2upx solid #0086F1;
display: flex;
align-items: center;
justify-content: center;
font-size: 28upx;
font-weight: 400;
color: #0086F1;
}
>view:nth-of-type(2) {
width: 204upx;
height: 64upx;
background: #FFFFFF;
border-radius: 8upx;
opacity: 1;
border: 2upx solid #D3832A;
display: flex;
align-items: center;
justify-content: center;
font-size: 28upx;
font-weight: 400;
color: #D3832A;
margin-left: 100upx;
}
}
}
}
}
.tabtip {
display: flex;
align-items: center;
justify-content: space-between;
>view {
width: 50%;
display: flex;
align-items: center;
justify-content: center;
background-color: #ffffff;
font-size: 32upx;
font-weight: 400;
color: #90A0AF;
>view {
height: 80upx;
border-bottom: 8upx solid #ffffff;
display: flex;
align-items: center;
justify-content: center;
}
}
.xz {
color: #D3832A;
border-bottom: 8upx solid #D3832A;
// border-radius: 5upx;
}
}
.schbox {
display: flex;
align-items: center;
justify-content: space-between;
padding: 15upx 32upx;
box-sizing: border-box;
background-color: #ffffff;
>view:nth-of-type(1) {
// width: 150upx;
font-size: 28upx;
font-weight: 400;
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;
}
}
</style>

14
pagesHome/pages/StockUplist/StockUplist.vue

@ -271,11 +271,11 @@
console.log('details.orderStatus :>> ', details.orderStatus);
details.user.consignee = response.data?.consignee
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.user.planNum = response.data?.planNum
details.user.scanNum = response.data?.scanNum
details.isscan = false
return null
}
@ -321,6 +321,16 @@
basicContainer.value.startPullDownRefresh()
}
async function goBarCode(item : any) {
if (!item.allocationList || item.allocationList.length === 0) {
// #ifdef APP
utils.ttsspke('该库存品没有上架数据')
// #endif
uni.showToast({
title: '该库存品没有上架数据',
icon: 'none'
})
return
}
console.log('item :>> ', item);
const _allocationList = item.allocationList.map(val => val.name)
console.log('_allocationList :>> ', _allocationList);

481
pagesHome/pages/StowageList/StowageList.vue

@ -0,0 +1,481 @@
<template>
<!-- <u-navbar title="拣货扫描" placeholder border=true :autoBack="true" leftIconSize='35'></u-navbar> -->
<BasicContainer ref="basicContainer" :option="option" :leftClick="backPreviousPage">
<template #head>
<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: 10rpx;" v-if="!datatime" name="calendar"
color="#999999" size="50"></u-icon>
<u-icon @click="cleartime" style="margin-right: 10rpx;" v-else name="close-circle" color="#999999"
size="40"></u-icon>
</view>
</view>
<view @click="init">
查询
</view>
</view>
<view class="tabtip">
<view @click="setstate(1)">
<view :class="status==1?'xz':''">未发车</view>
</view>
<view @click="setstate(2)">
<view :class="status==2?'xz':''">已发车</view>
</view>
</view>
</template>
<template #body>
<scroll-view class="sccv" scroll-y="true" @scrolltolower="jiazai">
<view class="mabx">
<view v-for="item in dataList" :key="item">
<view class="topbox font-color">
<view class="type1">
<view>
<text>车次号</text>
<text>{{item.carsNo}}</text>
</view>
<view>
<text>车牌</text>
<text>{{item.carNumber}}</text>
</view>
</view>
<view class="type1">
<view>
<text>总件数/装车件数</text>
<text>{{item.planLoadingNumber + '/' + item.realLoadingNumber}}</text>
</view>
<view>
<text>车长</text>
<text>{{''}}</text>
</view>
</view>
<view class="type1">
<view>
<text>主驾司机</text>
<text>{{item.driverName}}</text>
</view>
<view>
<text>电话</text>
<text>{{item.driverMobile}}</text>
</view>
</view>
<view>
<text>类型</text>
<text>{{item.carsNo}}</text>
</view>
<view>
<text>线路</text>
<text>{{item.carsLineName}}</text>
</view>
</view>
<view class="bts" v-if="Number(item.stockupStatus)!=40">
<view @click="gostockuplist(item)">
整托装车
</view>
<view @click="gostockuplist(item)">
按件装车
</view>
</view>
</view>
</view>
</scroll-view>
</template>
</BasicContainer>
<tips ref="tip"></tips>
<l-calendar v-model:value="show" :initStartDate='date[0]' :initEndDate='date[1]' @hide='showCalendar'
@change="onConfirm"></l-calendar>
<!-- <hd-calendar mode="range" color='#D3832A' minDate='2023-01-01' @confirm="onConfirm" /> -->
</template>
<script lang="ts" setup>
import {
onLoad,
onShow,
onHide,
onUnload,
onPullDownRefresh
} from '@dcloudio/uni-app'
import { postCarsLoadPageList } from '@/api/user.js'
import { timeType } from '@/interfaces/pagesHome/allType'
import { inject, reactive, ref, toRefs, watchEffect } from "vue";
import utils from '@/utils/utils';
const option = {
title: '配载装车',
haveData: true,
async pullDownRefreshInitPage() {
// details.dataList.splice(0)
return await init()
}
}
let details = reactive({
datatime: '',
/** 页面渲染数组 */
dataList: [],
/** 未发车数据 */
NoTrainData: [],
/** 已发车数据 */
HaveLeftnData: [],
show: false,
pageNum: 1,
size: 10,
stockupDate: '',
status: 1,
})
//
details.dataList = details.NoTrainData
let tip = ref(null)
const basicContainer = ref(null)
const date = ref<number | string[]>([])
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]
}
})
onShow(() => {
// #ifdef APP
uni.$off('scancodedate')
// #endif
const timer = setTimeout(() => {
basicContainer.value.startPullDownRefresh()
clearTimeout(timer)
}, 200)
})
onLoad(() => {
date.value[0] = (uni as any).$u.timeFormat((new Date().valueOf() - 1000 * 60 * 60 * 24 * 3), 'yyyy-mm-dd')
date.value[1] = (uni as any).$u.timeFormat((new Date().valueOf()), 'yyyy-mm-dd')
utils.ttsspke('请选择拣货任务')
})
async function init() {
details.pageNum = 1
details.dataList.splice(0)
return initpage()
}
function jiazai() {
details.pageNum++
initpage()
}
async function initpage() {
try {
uni.showLoading({
title: '数据加载中',
mask: true
})
let data = {
pageNum: details.pageNum,
pageSize: details.size,
startDate: date.value[0],
endDate: date.value[1],
type: details.status,
}
let response = await postCarsLoadPageList(data)
if (response.code !== 200 || !response.data) return
if (details.pageNum > 1) {
if (response.data.records.length == 0) {
uni.showToast({
title: '已经到底了。',
icon: 'none'
})
details.pageNum--
}
}
if (data.type === 1) {
for (let item of response.data.records) {
details.NoTrainData.push(item)
}
} else {
for (let item of response.data.records) {
details.HaveLeftnData.push(item)
}
}
} catch (err) {
console.log('err :>> ', err);
//TODO handle the exception
} finally {
uni.hideLoading()
return null
}
}
function checktime(event : timeType) {
console.log(event);
details.datatime = (uni as any).$u.timeFormat(event.value, 'yyyy-mm-dd');
details.show = false
console.log(details.datatime);
}
function gostockuplist(item : any) {
uni.reLaunch({
url: '/pagesHome/pages/StowageListDetails/StowageListDetails?id=' + item.id
})
}
function cleartime() {
// console.log(1231211);
details.datatime = ''
date.value = []
basicContainer.value.startPullDownRefresh()
}
function setstate(state : number) {
details.status = state
details.dataList = state === 1 ? details.NoTrainData : details.HaveLeftnData
basicContainer.value.startPullDownRefresh()
}
//
function backPreviousPage() {
uni.reLaunch({
url: '/pages/index/index'
})
}
const { datatime, dataList, show, status } = toRefs(details)
</script>
<style lang="scss" scoped>
.inputsr {
width: 400upx !important;
height: 64upx;
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;
}
}
.sccv {
width: 100%;
height: 74vh;
margin-top: 20upx;
.mabx {
display: flex;
flex-direction: column;
align-items: center;
width: 100%;
box-sizing: border-box;
padding: 20upx 32upx;
padding-top: 0upx;
>view {
width: 686upx;
background: #FFFFFF;
display: flex;
flex-direction: column;
box-sizing: border-box;
border-bottom: 1upx solid #ebebeb;
padding-bottom: 30upx;
background-color: #ffffff;
margin-bottom: 20upx;
padding-top: 20upx;
border-radius: 8upx;
>view:nth-last-child(1) {
border-bottom: none !important;
}
.topbox {
display: flex;
flex-direction: column;
padding: 24upx;
border-bottom: 2upx solid #EEEEEE;
>.type1 {
width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 20upx;
zoom: 0.9;
>view {
width: 50%;
}
}
>.type2 {
width: 100%;
display: flex;
align-items: center;
justify-content: space-around;
margin-bottom: 15upx;
font-size: 28upx;
color: #161616;
margin-top: 20upx;
>view {
display: flex;
flex-direction: column;
align-items: center;
>view:nth-of-type(1) {
font-size: 28upx;
font-weight: 400;
color: #092C4D;
}
&:nth-of-type(1) {
>view:nth-of-type(2) {
color: #092C4D;
}
}
&:nth-of-type(2) {
>view:nth-of-type(2) {
color: #3AD8BC;
}
}
&:nth-of-type(3) {
>view:nth-of-type(2) {
color: #FA8C16;
}
}
>view:nth-of-type(2) {
font-size: 36upx;
margin-top: 10upx;
}
}
}
>.type3 {
width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 20upx;
font-size: 26upx;
color: #161616;
}
}
>.bts {
display: flex;
align-items: center;
justify-content: center;
margin-top: 20upx;
>view {
border-radius: 8upx;
background: #FFFFFF;
opacity: 1;
border: 2upx solid #0086F1;
display: flex;
align-items: center;
justify-content: center;
font-size: 28upx;
font-weight: 400;
padding: 10upx 30upx;
color: #0086F1;
}
>view:nth-of-type(2) {
border-color: #D3832A;
color: #D3832A;
margin-left: 100upx;
}
}
}
}
}
.tabtip {
display: flex;
align-items: center;
justify-content: space-between;
>view {
width: 50%;
display: flex;
align-items: center;
justify-content: center;
background-color: #ffffff;
font-size: 32upx;
font-weight: 400;
color: #90A0AF;
>view {
height: 80upx;
border-bottom: 8upx solid #ffffff;
display: flex;
align-items: center;
justify-content: center;
}
}
.xz {
color: #D3832A;
border-bottom: 8upx solid #D3832A;
// border-radius: 5upx;
}
}
.schbox {
display: flex;
align-items: center;
justify-content: space-between;
padding: 15upx 32upx;
box-sizing: border-box;
background-color: #ffffff;
>view:nth-of-type(1) {
// width: 150upx;
font-size: 28upx;
font-weight: 400;
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;
}
}
.font-color {
// color: #90A0AF;
font-size: 28upx;
}
</style>

700
pagesHome/pages/StowageListDetails/StowageListDetails.vue

@ -0,0 +1,700 @@
<template>
<BasicContainer ref="basicContainer" :option="option">
<template #head>
<view class="hdtp">
<view>
<view>
配载批次{{details.pageInfo.carNo}}
</view>
<view class="butlur" @click="showsdqs">
录入包条码
</view>
</view>
<!-- <view>
<view>备货是否完成{{items.isstock}}</view>
<view>装车是否完成{{items.isload}}</view>
</view> -->
</view>
<view class="hdtpnum">
<view>
<view>订单总数</view>
<view>{{items.ordNub || 0}}</view>
</view>
<view>
<view>计划件数</view>
<view>{{details.pageInfo.planLoadingNumber || 0}}</view>
</view>
<view>
<view>装车件数</view>
<view>{{details.pageInfo.realLoadingNumber || 0}}</view>
</view>
</view>
<view class="tabtip">
<view @click="setorderStatus(1)">
<view :class="orderStatus==1?'xz':''">定制品</view>
</view>
<view @click="setorderStatus(2)">
<view :class="orderStatus==2?'xz':''">零担</view>
</view>
</view>
</template>
<template #body>
<scroll-view class="scve" scroll-y="true" @refresherpulling="" @scrolltolower="reatchBottom">
<view class="mabx">
<block v-for="(item,index) in datalist" :key="item">
<!-- 定制品 -->
<template v-if="orderStatus== 1">
<view class="itec" @click="checkphon(item,index)">
<view class="contenbx1">
<view><text style="color: #90A0AF;"
@click.stop="goorderdetail(item)">订单编号</text>{{item.orderCode}}
</view>
</view>
<view class="contenbx1">
<view><text style="color: #90A0AF;">配送数</text>{{item.reservationNum}}</view>
<view><text style="color: #90A0AF;">已扫码数</text>{{item.loadingNub}}</view>
</view>
<view class="xialaxz" v-if="listcheckindex==index">
<view v-for="ite in item.distributionAppParcelListVOS">
<view>包条码{{ite.orderPackageCode}}</view>
<view>货物品类{{ite.thirdProduct}}</view>
<view>扫描状态{{ite.isScan?ite.isScan:'未扫'}}</view>
</view>
</view>
<view v-if="item.complete"
:class="item.completecode==3?'tip tp1':item.completecode==1?'tip tp2':'tip tp3'">
{{item.complete}}
</view>
<!-- 当有异常状态时, 显示异常状态 -->
<template v-if="item.isHaveAbnormalPackageName">
<view class="abnormalStyleContainer">
<view class="abnormalStyle">
{{item.isHaveAbnormalPackageName}}
</view>
</view>
</template>
</view>
</template>
<!-- 零担 -->
<template v-else-if="orderStatus == 2">
<view class="itec" @click="checkphon(item,index)">
<view class="contenbx1">
<view><text style="color: #90A0AF;"
@click.stop="goorderdetail(item)">订单编号</text>{{item.orderCode}}
</view>
</view>
<view class="contenbx1">
<view><text style="color: #90A0AF;"
@click.stop="goorderdetail(item)">产品名称</text>{{item.descriptionGoods}}
</view>
</view>
<view class="contenbx1">
<view><text style="color: #90A0AF;">计划数量</text>{{item.reservationNum}}</view>
<view><text style="color: #90A0AF;">装车数量</text>{{item.loadingNub}}</view>
</view>
<view v-if="item.complete"
:class="item.completecode==3?'tip tp1':item.completecode==1?'tip tp2':'tip tp3'">
{{item.complete}}
</view>
</view>
</template>
</block>
</view>
</scroll-view>
</template>
</BasicContainer>
<tiplist ref="tiplists"></tiplist>
<!-- #ifdef APP -->
<saomiao2 :ishidestop="scanState !== 0"></saomiao2>
<!-- #endif -->
</template>
<script lang="ts" setup>
import {
postFindCarsLoadingDetail
} from '@/api/user.js'
import {
onLoad,
onShow,
onHide,
onUnload,
onPullDownRefresh
} from '@dcloudio/uni-app'
import { computed, inject, nextTick, reactive, ref, toRefs, } from "vue";
import useSystemSettingsStore from '@/store/useSystemSettingsStore';
import { storeToRefs } from 'pinia';
const { scanState } = storeToRefs(useSystemSettingsStore())
const utils = inject('utils') as any
const option = reactive({
title: '配载按件装车',
haveData: true,
async pullDownRefreshInitPage() {
details.datalist = []
return await initpage()
}
})
let details = reactive({
schanvalue: '',
typearr: [
{
value: 3,
label: '齐套'
},
{
value: 2,
label: '部分扫'
},
{
value: 1,
label: '未扫'
}
],
items: {} as any,
datalist: [],
scancode: '',
orderStatus: 1,
loadId: '',
orderType: 0,
inputtxt: '',
listcheckindex: -1,
isscan: false,
order: [],
zero: [],
pageInfo: {}
})
//
const tiplists = ref(null)
const basicContainer = ref(null)
onLoad((op) => {
details.loadId = op.id
})
function goorderdetail(item) {
uni.navigateTo({
url: '/pagesHome/pages/orderDetails/orderDetails?orderCode=' + item.orderCode
})
}
onShow(async () => {
// #ifdef APP
uni.$off('scancodedate')
uni.$on('scancodedate', function (code) {
if (code) {
console.log('code', code);
details.scancode = code
details.isscan = true
scandata()
}
})
// #endif
await nextTick()
//
// const timer = setTimeout(() => {
basicContainer.value.startPullDownRefresh()
// clearTimeout(timer)
// }, 10)
})
const loadingNub = computed(() => {
//
let num = 0
if (details.order) num += details.order.reduce((curr, item) => curr + item.loadingNub, 0)
if (details.zero) num += details.zero.reduce((curr, item) => curr + item.loadingNub, 0)
console.log('num :>> ', num);
return num
})
function showsdqs() {
tiplists.value.setdetails({
isshow: true,
tipstate: 1,
title: '请输入扫描的码',
placeholder: '请输入扫描的码',
inputtext: '',
success: (detail) => {
details.scancode = detail.inputtext
scandata()
tiplists.value.setdetails({ isshow: false })
},
cancel: () => {
tiplists.value.setdetails({ isshow: false })
},
close: () => {
tiplists.value.setdetails({ isshow: false })
}
})
}
async function initpage() {
try {
const response = await postFindCarsLoadingDetail({
loadId: details.loadId
})
const { code, data } = response
console.log('response :>> ', response);
if (code === 200) {
details.pageInfo = data
}
// const { data } = response
// if (response.code !== 200) return
// details.zero.data = []
// details.order.data = []
// data.forEach(val => {
// //
// if (val.isZero === '1') return details.zero.data.push(val)
// details.order.data.push(val)
// })
// //
// if (details.orderStatus === 1) details.datalist = details.order.data
// //
// else if (details.orderStatus === 2) details.datalist = details.zero.data
} catch (err) {
console.log('err :>> ', err);
//TODO handle the exception
} finally {
return null
}
}
function checktype(e) {
if (e == '') {
details.schanvalue = ''
details.orderType = 0
}
details.typearr.map(item => {
if (item.value == e) {
details.schanvalue = item.label
details.orderType = item.value
}
})
}
/**
* 切换tabBer状态
* @param {type} state 选中的状态
*/
function setorderStatus(state : number) {
if (details.orderStatus === state) return
details.orderStatus = state
//
details.datalist = []
//
basicContainer.value.startPullDownRefresh()
}
/**
* 触底加载
*/
function reatchBottom() {
}
/**
* */
async function scandata() {
try {
} catch (err) {
console.log('err :>> ', err);
//TODO handle the exception
} finally {
//
basicContainer.value.startPullDownRefresh()
}
}
function checkphon(item : object, index : number) {
//
if (item.isZero === '1') {
const inpList = item.distributionAppParcelListVOS.map(val => {
return {
id: val.id,
title: val.firsts,
value: val.loadingNum || val.reservationNum,
maxNum: val.reservationNum,
minNum: 0,
type: 'Number',
disabled: (val.loadingNum === val.reservationNum),
allocationId: val.allocationId,
orderCode: val.orderCode,
stockArticleId: val.stockArticleId
}
})
//
tiplists.value.setdetails({
title: '设置零担物料数量',
isshow: true,
tipstate: 4,
inpList,
inputtext: '',
confirmTxt: '确认',
isonecheck: true,
success: async (deta) => {
try {
//
if (deta.inpList.every(val => val.disabled)) return tiplists.value.setdetails({ isshow: false })
uni.showLoading({
mask: true,
title: "提交中"
})
if (deta.inpList.length === 0 || item.completeStact) return tiplists.value.setdetails({ isshow: false })
let data = {
reservationId: details.items.id,
deliveryId: details.id,
orderId: deta.inpList[0].stockArticleId,
loadingId: uni.getStorageSync('checkvehicle').id,
parcelListDTOS: []
}
data.parcelListDTOS = deta.inpList.map(val => {
return {
parcelListId: val.id,
stockArticleId: val.stockArticleId,
loadingNum: val.value,
}
})
const res = await deliveryZeroLoading(data)
if (res.audio) {
// #ifdef APP
utils.ttsspke(res.audio)
// #endif
}
//
basicContainer.value.startPullDownRefresh()
} catch (err) {
console.log('err :>> ', err);
//TODO handle the exception
} finally {
uni.hideLoading()
tiplists.value.setdetails({ isshow: false })
}
},
cancel: (details) => {
tiplists.value.setdetails({ isshow: false })
},
close: (details) => {
tiplists.value.setdetails({ isshow: false })
}
})
return
}
// details.listcheckindex=index
if (details.listcheckindex == index) {
details.listcheckindex = -1
} else {
details.listcheckindex = index
}
}
const { listcheckindex, inputtxt, orderStatus, schanvalue, typearr, items, datalist } = toRefs(details)
</script>
<style lang="scss">
.xialaxz {
display: flex;
flex-direction: column;
>view {
display: flex;
align-items: flex-start;
justify-content: space-between;
border-top: 1upx solid #00000010;
padding: 20upx 0;
box-sizing: border-box;
font-size: 28upx;
color: #092C4D;
>view {
word-wrap: break-word;
word-break: break-all;
margin-right: 10upx;
&:nth-last-child(1) {
margin-right: 0upx;
}
}
}
}
.butlur {
width: 200upx !important;
height: 64upx !important;
background: #D3832A;
border-radius: 8upx;
display: flex;
align-items: center;
justify-content: center;
font-size: 32upx;
font-weight: 400;
color: #FFFFFF;
}
.tabtip {
display: flex;
align-items: center;
justify-content: space-between;
>view {
width: 50%;
display: flex;
align-items: center;
justify-content: center;
background-color: #ffffff;
font-size: 32upx;
font-weight: 400;
color: #90A0AF;
>view {
height: 80upx;
border-bottom: 8upx solid #ffffff;
display: flex;
align-items: center;
justify-content: center;
}
}
.xz {
color: #D3832A;
border-bottom: 8upx solid #D3832A;
// border-radius: 5upx;
}
}
.hdtp {
padding: 34upx 32upx;
box-sizing: border-box;
background-color: #ffffff;
display: flex;
flex-direction: column;
align-items: center;
>view {
width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
font-size: 28upx;
font-weight: 400;
color: #092C4D;
margin-bottom: 24upx;
&:nth-last-child(1) {
margin-bottom: 0;
}
>view {
width: 50%;
// flex: 1;
}
}
}
.scve {
width: 100%;
height: 50vh;
margin-top: 20upx;
.mabx {
display: flex;
flex-direction: column;
align-items: center;
>.itec {
width: 686upx;
// height: 176upx;
background: #FFFFFF;
border-radius: 8upx;
padding: 36upx 24upx;
box-sizing: border-box;
position: relative;
margin-bottom: 20upx;
overflow: hidden;
&:nth-last-child(1) {
margin-bottom: 0;
}
>.contenbx1 {
display: flex;
align-items: center;
justify-content: space-between;
font-size: 28upx;
color: #092C4D;
margin-bottom: 20upx;
&:nth-last-child(1) {
margin-bottom: 0;
}
>view {
flex: 1;
}
}
.tip {
position: absolute;
right: 0;
top: 0;
width: 96upx;
height: 48upx;
border-radius: 0 8upx 0 8upx;
display: flex;
align-items: center;
justify-content: center;
font-size: 24upx;
}
.tp1 {
background-color: #0086F120;
color: #0086F1;
}
.tp2 {
background-color: #F8544B20;
color: #F8544B;
}
.tp3 {
background-color: #FA8C1620;
color: #FA8C16;
}
}
}
}
.scinp {
display: flex;
align-items: center;
justify-content: space-between;
padding: 12upx 32upx;
box-sizing: border-box;
background-color: #ffffff;
>view:nth-of-type(1) {
font-size: 28upx;
font-weight: 400;
color: #092C4D;
}
.inputs {
width: 276upx;
height: 64upx;
background: #F5F5F6;
border-radius: 8upx;
opacity: 1;
border: 2upx solid #EEEEEE;
padding: 10upx;
box-sizing: border-box;
font-size: 24upx;
font-weight: 400;
color: #AFB4BA;
>input {
flex: 1;
font-size: 24upx;
color: #092C4D;
}
}
.btscan {
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;
}
}
.hdtpnum {
display: flex;
align-items: center;
justify-content: space-around;
background-color: #ffffff;
padding: 28upx 0;
border-bottom: 3upx solid #EEEEEE;
>view {
display: flex;
align-items: center;
flex-direction: column;
font-size: 28upx;
font-weight: 400;
color: #092C4D;
&:nth-of-type(1) {
>view:nth-of-type(2) {
color: #092C4D;
}
}
&:nth-of-type(2) {
>view:nth-of-type(2) {
color: #0086F1;
}
}
&:nth-of-type(3) {
>view:nth-of-type(2) {
color: #3AD8BC;
}
}
&:nth-of-type(4) {
>view:nth-of-type(2) {
color: #FA8C16;
}
}
>view:nth-of-type(2) {
font-size: 36upx;
font-weight: 400;
color: #092C4D;
margin-top: 20upx;
}
}
}
.abnormalStyleContainer {
top: -20upx;
left: -20upx;
position: absolute;
padding: 10upx;
border: 1upx solid #f8544b;
border-radius: 50%;
}
//
.abnormalStyle {
font-size: 28upx;
height: 80upx;
width: 80upx;
display: flex;
align-items: center;
text-align: center;
color: #f8544b;
padding: 10upx;
border-radius: 50%;
border: 1upx solid #f8544b;
opacity: 0.6;
}
</style>

5
pagesHome/pages/createAddServe/createAddServe.vue

@ -389,6 +389,11 @@
return response
}
function showlist() {
if (details.addvalueType) return uni.showToast({
title: '不能修改增值类型',
icon: 'none'
})
let list = []
details.priceType.map(item => {
list.push(item.typename)

283
pagesHome/pages/loadingRetention/loadingRetention.vue

@ -16,7 +16,7 @@
<view>备货是否完成{{items.isstock}}</view>
</view>
<view class="kehupeison">
<view>
<!-- <view>
<view>配送客户数</view>
<view>{{items.customersNumber}}</view>
</view>
@ -31,7 +31,7 @@
<view>
<view>装车件数</view>
<view>{{scannedNumber}}</view>
</view>
</view> -->
<view>
<view>滞留数</view>
<view>{{scannedNumber}}</view>
@ -54,6 +54,32 @@
</view>
</view>
<scroll-view class="Zelold" scroll-y="true" @touchmove.stop v-if='tabBarCode==2 && ZelNum'>
<text class="title">设置零担物料数量</text>
<view class="content" v-for="item in NumList" :key="item.id">
<view class="num">
<text class="name">物料名称:</text>{{item.materialName}}
</view>
<view class="num">
<text class="name">物料总数:</text>{{item.maxQuantity}}
</view>
<view class="num">
<text class="name">物料数量:</text> <u-number-box :min='0' :max='item.retentionQuantity'
v-model="item.retentionQuantity" button-size="36" color="#ffffff" bgColor="#d3832a"
iconStyle="color: #fff"> </u-number-box>
</view>
</view>
<view class="zelBtn">
<view class="yes" @click="ZelYes">确定</view>
<view class="no" @click="ZelNum=false">取消</view>
</view>
</scroll-view>
<scroll-view class="scoolv" scroll-y="true">
<!-- 加载动画 -->
<u-overlay :show="show">
@ -64,20 +90,26 @@
<view class="InfoList transition" v-for="(item,index) in DataList1" :key='item.id'>
<view>
<u-icon name="car" top='5'></u-icon> <text class="title"></text><text
<u-icon name="car" top='5'></u-icon> <text class="title"></text>
<text
:class="{ 'type1':item.conditions==1,'type2':item.conditions==2,'type3': item.conditions==3 }">{{item.conditions==1?'定制品':item.conditions==2?'库存品':'暂无信息'}}</text>
</view>
<view>
<u-icon name="scan" top='5'></u-icon> <text
class="title">包条码</text><text>{{item.orderPackageCode}}</text>
<u-icon name="scan" top='5'></u-icon>
<text class="title">包条码</text>
<text>{{item.orderPackageCode}}</text>
</view>
<view>
<u-icon name="grid" top='5'></u-icon> <text class="title"></text><text>{{item.orderCode}}</text>
<u-icon name="grid" top='5'>
</u-icon> <text class="title">
<text class="title">订单自编号</text>
</text><text>{{item.orderCode}}</text>
</view>
<view>
<u-icon name="tags" top='5'></u-icon> <text
class="title">预约单号</text><text>{{item.reservationCode}}</text>
<u-icon name="tags" top='5'></u-icon>
<text class="title">预约单号</text>
<text>{{item.reservationCode}}</text>
</view>
<u-button v-if='item.parameter' @click="RemoveData(item,index)" class="uni-Btn" type="primary" icon="close"
text="移除"></u-button>
@ -96,19 +128,23 @@
<view class="InfoList" v-for="item in DataList2" :key='item.id'>
<view>
<u-icon name="car" top='5'></u-icon> <text class="title"></text><text
:class="{ 'type1':item.conditions==1,'type2':item.conditions==2,'type3': item.conditions==3 }">{{item.conditions==1?'定制品':item.conditions==2?'库存品':'暂无信息'}}</text>
:class="{ 'type1':item.conditions==1,'type2':item.conditions==2,'type3': item.conditions==3 }">{{item.conditions==1?'定制品':item.conditions==2?'库存品':item.conditions==3?'零担':'暂无信息'}}</text>
</view>
<view>
<u-icon name="scan" top='5'></u-icon> <text
class="title">包条码</text><text>{{item.orderPackageCode}}</text>
<u-icon name="scan" top='5'></u-icon>
<text class="title">包条码</text>
<text>{{item.orderPackageCode?item.orderPackageCode:'暂无数据'}}</text>
</view>
<view>
<u-icon name="grid" top='5'></u-icon> <text class="title"></text><text>{{item.orderCode}}</text>
<u-icon name="grid" top='5'></u-icon>
<text class="title">订单自编号</text>
<text>{{item.orderCode}}</text>
</view>
<view>
<u-icon name="tags" top='5'></u-icon> <text
class="title">预约单号</text><text>{{item.reservationCode}}</text>
<u-icon name="tags" top='5'></u-icon>
<text class="title">预约单号</text>
<text>{{item.reservationCode}}</text>
</view>
<u-button v-if='item.parameter' @click="RemoveData(item,index)" class="uni-Btn" type="primary" icon="close"
text="移除"></u-button>
@ -122,24 +158,25 @@
</view>
<!-- 托盘 -->
<view v-if='tabBarCode==3'>
<view class="InfoMax" v-for="(item ,index) in DataList3" :key='index'>
<view class="InfoList InfoListTP">
<view>
<u-icon name="car" top='5'></u-icon> <text class="title"></text><text>{{item[0].trayCode}}</text>
<u-icon name="car" top='5'></u-icon>
<text class="title">托盘码</text>
<text>{{item[0].trayCode}}</text>
</view>
<view>
<u-icon name="scan" top='5'></u-icon> <text
class="title">托盘名称</text><text>{{item[0].trayName?item[0].trayName:'暂无名称'}}</text>
<u-icon name="scan" top='5'></u-icon>
<text class="title">托盘名称</text>
<text>{{item[0].trayName?item[0].trayName:'暂无名称'}}</text>
</view>
<view>
<u-icon name="scan" top='5'></u-icon> <text class="title"></text><text>{{item.length}}</text>
<u-icon name="scan" top='5'></u-icon>
<text class="title">托盘数量</text>
<text>{{item.length}}</text>
</view>
<u-button v-if='item[0].parameter' @click="RemoveData(item,index)" class="uni-Btn" type="primary"
icon="close" text="移除"></u-button>
@ -151,20 +188,23 @@
<view class="InfoList" v-for="(items,indexs) in item" :key='items.id'>
<view>
<u-icon name="car" top='5'></u-icon> <text class="title"></text><text
:class="{ 'type1':items.conditions==1,'type2':item.conditions==2,'type3': items.conditions==3 }">{{items.conditions==1?'定制品':items.conditions==2?'库存品':'暂无信息'}}</text>
:class="{ 'type1':items.conditions==1,'type2':item.conditions==2,'type3': items.conditions==3 }">{{items.conditions==1?'定制品':items.conditions==2?'库存品':items.conditions==3?'零担':'暂无信息'}}</text>
</view>
<view>
<u-icon name="scan" top='5'></u-icon> <text
class="title">包条码</text><text>{{items.orderPackageCode}}</text>
<u-icon name="scan" top='5'></u-icon>
<text class="title">包条码</text>
<text>{{items.orderPackageCode}}</text>
</view>
<view>
<u-icon name="grid" top='5'></u-icon> <text
class="title">订单自编号</text><text>{{items.orderCode}}</text>
<u-icon name="grid" top='5'></u-icon>
<text class="title">订单自编号</text>
<text>{{items.orderCode}}</text>
</view>
<view>
<u-icon name="tags" top='5'></u-icon> <text
class="title">预约单号</text><text>{{items.reservationCode}}</text>
<u-icon name="tags" top='5'></u-icon>
<text class="title">预约单号</text>
<text>{{items.reservationCode}}</text>
</view>
<u-button v-if='items.parameter' @click="RemoveData(items,indexs,index)" class="uni-Btn"
type="primary" icon="close" text="移除"></u-button>
@ -206,8 +246,6 @@
<script lang="ts" setup>
import {
deliverycustom,
deliveryloadingscan,
$_initRetentionList,
$_retentionScan,
$_saveRetentionList,
@ -220,10 +258,9 @@
onHide,
onPullDownRefresh
} from '@dcloudio/uni-app'
import { computed, reactive, ref, toRefs } from "vue";
import { computed, onMounted, reactive, ref, toRefs } from "vue";
import useSystemSettingsStore from '@/store/useSystemSettingsStore';
import { storeToRefs } from 'pinia';
import loginVue from '../../../pages/login/login.vue';
import utils from '@/utils/utils.js';
const { scanState } = storeToRefs(useSystemSettingsStore())
let details = reactive({
@ -243,11 +280,17 @@
const DataList1 = ref([])///
const DataList2 = ref([])//
const DataList3 = ref([])//
const NumList = ref([]);//
const ZelNum = ref(false);//
const show = ref(false);
const OrType = ref(1)//
const id = ref(null);//
const transition = ref(false)//
//
const refresherrefreshFun = () => {
}
onLoad((op) => {
details.id = op.id
details.items = JSON.parse(op.item)
@ -308,6 +351,12 @@
// uni.$off('scancodedate')
// console.log("uni", uni)
// })
const handleDivTouchMove = (event) => {
//
event.stopPropagation();
//
}
onShow(() => {
initpage()
// #ifdef APP
@ -317,17 +366,32 @@
console.log(code, '扫码的参数');
details.scancode = code
scandata()
console.log(OrType.value);
QRcodeScanning(code, OrType.value)
}
})
// #endif
})
//
const ZelYes = () => {
console.log(NumList.value);
ZelNum.value = false;//
NumList.value.forEach(item => {
if (item.retentionQuantity) {
item.parameter = true;//
DataList2.value.unshift(item)
}
})
}
//
function keyInput(val) {
show.value = true;//
console.log(val, '来自搜索框的值');
QRcodeScanning(val, OrType.value)
}
//
function QRcodeScanning(val, type) {
show.value = true;//
@ -338,6 +402,7 @@
barcode: val,
retentionType: type,
}).then(res => {
show.value = false;//
console.log(res, '添加获取的值============>');
console.log(DataList1, '移除之前的值');
@ -345,20 +410,42 @@
utils.ttsspke(res.audio)//
return;
}
res.data.forEach(item => {
item.parameter = true;//
if (item.scanType == 1) {
DataList1.value.unshift(item)///
}
if (item.scanType == 2) {
DataList2.value.unshift(item)//
if (res.data.length) {
console.log(res.data, '数据');
NumList.value = res.data
ZelNum.value = true;//
return
}
if (OrType.value == 1) {
// ,
let hasDuplicate = DataList1.value.some(item => item.orderPackageCode == res.data[0].orderPackageCode);
if (!hasDuplicate) {
res.data.forEach(item => {
item.parameter = true;//
if (item.scanType == 1) {
DataList1.value.unshift(item)///
}
if (item.scanType == 2) {
NumList.value.unshift(item)//
}
})
}
// if (item.scanType == 3) {
// DataList3.value.unshift(item)//
// }
})
}
if (OrType.value == 2) {
console.log('OrType.value==2');
res.data.forEach(item => {
item.parameter = true;//
if (item.scanType == 1) {
DataList1.value.unshift(item)///
}
if (item.scanType == 2) {
NumList.value.unshift(item)//
}
})
}
})
} else {
//
@ -376,6 +463,17 @@
utils.ttsspke(res.data.audio)//
return;
}
//
if (DataList3.value.length) {
for (let i = 0; i < DataList3.value.length; i++) {
for (let j = 0; j < DataList3.value[i].length; j++) {
if (DataList3.value[i][j].trayCode == res.data.data.trayCode) {
return;
}
}
}
}
if (res.data.data.goodsList) {
res.data.data.goodsList.forEach(item => {
item.trayCode = res.data.data.trayCode;
@ -444,16 +542,15 @@
};
//
function RemoveData(val, indexs, index) {
// if (OrType.value == 1) {
// removeItem(DataList1.value, indexs)
// }
// if (OrType.value == 2) {
// removeItem(DataList2.value, indexs)
// }
// if (OrType.value == 3) {
// removeItem(DataList3.value, indexs)
// }
if (OrType.value == 1) {
removeItem(DataList1.value, indexs)
}
if (OrType.value == 2) {
removeItem(DataList2.value, indexs)
}
if (OrType.value == 3) {
removeItem(DataList3.value, indexs)
}
console.log(val, '点击移除的信息');
console.log(indexs, '点击移除的下标');
console.log(index, '点击移除的下标');
@ -571,6 +668,7 @@
align-items: center;
justify-content: space-around;
margin-top: 20upx;
justify-content: flex-start;
>view {
display: flex;
@ -728,7 +826,7 @@
.title {
margin-right: 3px;
width: 78px;
width: 100px;
background-color: #ffffff;
display: inline-block;
padding: 4px;
@ -853,4 +951,77 @@
}
}
.Zelold {
width: 90%;
height: 400px;
background-color: #ffffff;
border: 1px solid #ccc;
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
z-index: 99999999999999999999999999999;
overflow-y: auto;
.title {
width: 100%;
display: block;
padding: 4px 0;
text-align: center;
border-bottom: 1px solid #ccc;
}
.content {
display: flex;
flex-direction: column;
padding: 6px;
border-bottom: 1px solid #ccc;
.name {
margin-right: 4px;
}
}
.num {
display: flex;
uni-text {
span {
display: flex;
}
}
}
:deep(.u-number-box__plus) {
height: 100% !important;
}
:deep(.u-number-box__minus) {
height: 100% !important;
}
:deep(.u-number-box__input) {
width: 30px !important;
}
}
.zelBtn {
display: flex;
position: absolute;
bottom: 16px;
justify-content: space-around;
width: 100%;
.yes,
.no {
width: 100px;
height: 30px;
border: 1px solid #ccc;
border-radius: 3px;
display: flex;
align-items: center;
justify-content: center;
}
}
</style>

11
pagesHome/pages/setbarcode/setbarcode.vue

@ -284,6 +284,12 @@
})
}
async function ctokListpackage() {
uni.showLoading({
mask: true,
title: '数据请求中'
})
let data = {
reservationId: details.reservationId,
stockListId: details.items.stockListId,
@ -293,8 +299,13 @@
cargoNumber: details.items.cargoNumber
}
let response = await distributionStockupstockupStockListPackageCode(data)
// loading
uni.hideLoading()
if (response.code !== 200) return
popUp_AddPrint.value.details.showPopUp = false
console.log(response);
details.printlist = response.data
let checklist = []

10
pagesHome/pages/signinScan/signinScan.vue

@ -139,6 +139,8 @@
taskTime_start: '',
taskTime_end: '',
datalist: [] as any,
orderList: [] as any,
stockList: [] as any,
current: 1,
size: 5,
checkstate: 1,
@ -210,7 +212,9 @@
if (response.code !== 200) return
console.log('response :>> ', response);
if (details.current == 1) {
details.datalist = response.data.records
if (details.checkstate === data.type) {
details.datalist = response.data.records
}
} else {
if (response.data.records.lngth == 0) {
uni.showToast({
@ -220,7 +224,9 @@
details.current--
return
}
details.datalist = details.datalist.concat(response.data.records)
if (details.checkstate === data.type) {
details.datalist = details.datalist.concat(response.data.records)
}
}
return

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

@ -1 +1 @@
.u-status-bar[data-v-31491727]{width:100%}uni-view[data-v-5c79ae5e],uni-scroll-view[data-v-5c79ae5e],uni-swiper-item[data-v-5c79ae5e]{display:flex;flex-direction:column;flex-shrink:0;flex-grow:0;flex-basis:auto;align-items:stretch;align-content:flex-start}@font-face{font-family:uicon-iconfont;src:url(https://at.alicdn.com/t/font_2225171_8kdcwk4po24.ttf) format("truetype")}.u-icon[data-v-5c79ae5e]{display:flex;align-items:center}.u-icon--left[data-v-5c79ae5e]{flex-direction:row-reverse;align-items:center}.u-icon--right[data-v-5c79ae5e]{flex-direction:row;align-items:center}.u-icon--top[data-v-5c79ae5e]{flex-direction:column-reverse;justify-content:center}.u-icon--bottom[data-v-5c79ae5e]{flex-direction:column;justify-content:center}.u-icon__icon[data-v-5c79ae5e]{font-family:uicon-iconfont;position:relative;display:flex;flex-direction:row;align-items:center}.u-icon__icon--primary[data-v-5c79ae5e]{color:#3c9cff}.u-icon__icon--success[data-v-5c79ae5e]{color:#5ac725}.u-icon__icon--error[data-v-5c79ae5e]{color:#f56c6c}.u-icon__icon--warning[data-v-5c79ae5e]{color:#f9ae3d}.u-icon__icon--info[data-v-5c79ae5e]{color:#909399}.u-icon__img[data-v-5c79ae5e]{height:auto;will-change:transform}.u-icon__label[data-v-5c79ae5e]{line-height:1}uni-view[data-v-917ffc31],uni-scroll-view[data-v-917ffc31],uni-swiper-item[data-v-917ffc31]{display:flex;flex-direction:column;flex-shrink:0;flex-grow:0;flex-basis:auto;align-items:stretch;align-content:flex-start}.u-navbar--fixed[data-v-917ffc31]{position:fixed;left:0;right:0;top:0;z-index:11}.u-navbar__content[data-v-917ffc31]{display:flex;flex-direction:row;align-items:center;height:44px;background-color:#9acafc;position:relative;justify-content:center}.u-navbar__content__left[data-v-917ffc31],.u-navbar__content__right[data-v-917ffc31]{padding:0 13px;position:absolute;top:0;bottom:0;display:flex;flex-direction:row;align-items:center}.u-navbar__content__left[data-v-917ffc31]{left:0}.u-navbar__content__left--hover[data-v-917ffc31]{opacity:.7}.u-navbar__content__left__text[data-v-917ffc31]{font-size:15px;margin-left:3px}.u-navbar__content__title[data-v-917ffc31]{text-align:center;font-size:16px;color:#303133}.u-navbar__content__right[data-v-917ffc31]{right:0}.u-navbar__content__right__text[data-v-917ffc31]{font-size:15px;margin-left:3px}.mabox{display:flex;flex-direction:column;padding:.625rem 0;box-sizing:border-box;width:21.4375rem;margin:auto;background-color:#fff;margin-bottom:.625rem;margin-top:.3125rem;border-radius:.3125rem;box-shadow:0 .0625rem .3125rem rgba(226,226,227,.5)}.mabox .boxtitl{font-size:1.0625rem;font-weight:500;margin-bottom:.3125rem;border-bottom:.03125rem solid #EEEEEE;padding:0 .625rem .625rem;color:#092c4d}.mabox .minboxlist{display:flex;flex-wrap:wrap;align-items:center;padding-top:.3125rem}.mabox .minboxlist>uni-view{width:25%;display:flex;flex-direction:column;align-items:center;margin-bottom:.46875rem}.mabox .minboxlist>uni-view>uni-image{width:3.125rem}.mabox .minboxlist>uni-view>uni-view{font-size:.8125rem}
.u-status-bar[data-v-31491727]{width:100%}uni-view[data-v-5c79ae5e],uni-scroll-view[data-v-5c79ae5e],uni-swiper-item[data-v-5c79ae5e]{display:flex;flex-direction:column;flex-shrink:0;flex-grow:0;flex-basis:auto;align-items:stretch;align-content:flex-start}@font-face{font-family:uicon-iconfont;src:url(https://at.alicdn.com/t/font_2225171_8kdcwk4po24.ttf) format("truetype")}.u-icon[data-v-5c79ae5e]{display:flex;align-items:center}.u-icon--left[data-v-5c79ae5e]{flex-direction:row-reverse;align-items:center}.u-icon--right[data-v-5c79ae5e]{flex-direction:row;align-items:center}.u-icon--top[data-v-5c79ae5e]{flex-direction:column-reverse;justify-content:center}.u-icon--bottom[data-v-5c79ae5e]{flex-direction:column;justify-content:center}.u-icon__icon[data-v-5c79ae5e]{font-family:uicon-iconfont;position:relative;display:flex;flex-direction:row;align-items:center}.u-icon__icon--primary[data-v-5c79ae5e]{color:#3c9cff}.u-icon__icon--success[data-v-5c79ae5e]{color:#5ac725}.u-icon__icon--error[data-v-5c79ae5e]{color:#f56c6c}.u-icon__icon--warning[data-v-5c79ae5e]{color:#f9ae3d}.u-icon__icon--info[data-v-5c79ae5e]{color:#909399}.u-icon__img[data-v-5c79ae5e]{height:auto;will-change:transform}.u-icon__label[data-v-5c79ae5e]{line-height:1}uni-view[data-v-917ffc31],uni-scroll-view[data-v-917ffc31],uni-swiper-item[data-v-917ffc31]{display:flex;flex-direction:column;flex-shrink:0;flex-grow:0;flex-basis:auto;align-items:stretch;align-content:flex-start}.u-navbar--fixed[data-v-917ffc31]{position:fixed;left:0;right:0;top:0;z-index:11}.u-navbar__content[data-v-917ffc31]{display:flex;flex-direction:row;align-items:center;height:44px;background-color:#9acafc;position:relative;justify-content:center}.u-navbar__content__left[data-v-917ffc31],.u-navbar__content__right[data-v-917ffc31]{padding:0 13px;position:absolute;top:0;bottom:0;display:flex;flex-direction:row;align-items:center}.u-navbar__content__left[data-v-917ffc31]{left:0}.u-navbar__content__left--hover[data-v-917ffc31]{opacity:.7}.u-navbar__content__left__text[data-v-917ffc31]{font-size:15px;margin-left:3px}.u-navbar__content__title[data-v-917ffc31]{text-align:center;font-size:16px;color:#303133}.u-navbar__content__right[data-v-917ffc31]{right:0}.u-navbar__content__right__text[data-v-917ffc31]{font-size:15px;margin-left:3px}.mabox{display:flex;flex-direction:column;box-sizing:border-box;width:21.4375rem;margin:auto;background-color:#fff;margin-bottom:.3125rem;margin-top:.3125rem;border-radius:.3125rem;box-shadow:0 .0625rem .3125rem rgba(226,226,227,.5)}.mabox .boxtitl{font-size:.9375rem;font-weight:500;margin-bottom:.3125rem;border-bottom:.03125rem solid #EEEEEE;padding:.625rem;color:#092c4d}.mabox .minboxlist{display:flex;flex-wrap:wrap;align-items:center;padding:.3125rem 0}.mabox .minboxlist>uni-view{width:25%;display:flex;flex-direction:column;align-items:center;margin-bottom:.46875rem}.mabox .minboxlist>uni-view>uni-image{width:3.125rem}.mabox .minboxlist>uni-view>uni-view{font-size:.8125rem}

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

File diff suppressed because one or more lines are too long

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

File diff suppressed because one or more lines are too long

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

File diff suppressed because one or more lines are too long

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

File diff suppressed because one or more lines are too long

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

File diff suppressed because one or more lines are too long

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

File diff suppressed because one or more lines are too long

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

@ -1 +1 @@
.scrollv{width:21.4375rem;height:60vh;background-color:#fff;margin:auto;margin-top:.625rem;padding:.625rem;box-sizing:border-box;border-radius:.3125rem}.scrollv .mabxs{display:flex;flex-direction:column;align-items:center;padding-top:.15625rem}.scrollv .mabxs .ite{width:96%;display:flex;flex-direction:column;align-items:center;padding:.625rem .46875rem .3125rem;box-sizing:border-box;border-radius:.25rem;box-shadow:0 .0625rem .3125rem #e2e2e3;margin-bottom:.625rem;font-size:.8125rem}.scrollv .mabxs .ite:nth-last-child(1){margin-bottom:.15625rem}.scrollv .mabxs .ite>uni-view{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:.625rem}.scrollv .mabxs .ite>uni-view:nth-last-child(1){margin-bottom:none!important}.scrollv .mabxs .ite>uni-view>uni-view{font-size:.8125rem;font-weight:400;color:#092c4d}.butsbx{display:flex;align-items:center;margin-top:.78125rem;padding:0 4%}.butsbx>uni-view{width:6.375rem;height:2rem;background:#FFFFFF;border-radius:.25rem;opacity:1;font-size:.875rem;display:flex;align-items:center;justify-content:center;border:.0625rem solid #D3832A;color:#d3832a}.butsbx>uni-view:nth-of-type(2){margin-left:.625rem}.head{display:flex;flex-direction:column;align-items:center;justify-content:space-around;padding:.625rem;box-sizing:border-box;background-color:#fff}.head>.type1{width:100%;display:flex;align-items:flex-start;justify-content:space-between;font-size:.875rem;font-weight:400;color:#90a0af;margin-bottom:.3125rem}.head>.type1>uni-view{flex:1;display:flex;align-items:flex-start}.head>.type1>uni-view>uni-view:nth-of-type(1){flex:1}
.scrollv{width:21.4375rem;height:60vh;background-color:#fff;margin:auto;margin-top:.625rem;padding:.625rem;box-sizing:border-box;border-radius:.3125rem}.scrollv .mabxs{display:flex;flex-direction:column;align-items:center;padding-top:.15625rem}.scrollv .mabxs .ite{width:96%;display:flex;flex-direction:column;align-items:center;padding:.625rem .46875rem .3125rem;box-sizing:border-box;border-radius:.25rem;box-shadow:0 .0625rem .3125rem #e2e2e3;margin-bottom:.625rem;font-size:.8125rem}.scrollv .mabxs .ite:nth-last-child(1){margin-bottom:.15625rem}.scrollv .mabxs .ite>uni-view{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:.625rem}.scrollv .mabxs .ite>uni-view:nth-last-child(1){margin-bottom:none!important}.scrollv .mabxs .ite>uni-view>uni-view{font-size:.8125rem;font-weight:400;color:#092c4d}.butsbx{display:flex;align-items:center;margin-top:.78125rem;padding:0 4%}.butsbx>uni-view{width:6.375rem;height:2rem;background:#FFFFFF;border-radius:.25rem;opacity:1;font-size:.875rem;display:flex;align-items:center;justify-content:center;border:.0625rem solid #D3832A;color:#d3832a;margin-left:.625rem}.head{display:flex;flex-direction:column;align-items:center;justify-content:space-around;padding:.625rem;box-sizing:border-box;background-color:#fff}.head>.type1{width:100%;display:flex;align-items:flex-start;justify-content:space-between;font-size:.875rem;font-weight:400;color:#90a0af;margin-bottom:.3125rem}.head>.type1>uni-view{flex:1;display:flex;align-items:flex-start}.head>.type1>uni-view>uni-view:nth-of-type(1){flex:1}.popUpInput{border:.09375rem solid #ccc;margin-top:.3125rem;border-radius:.15625rem;padding:.15625rem .3125rem}.popUp_Edit_text{font-size:.875rem;color:red}

969
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

@ -4,11 +4,11 @@
"iPhone",
"iPad"
],
"id": "__UNI__FC20B18",
"id": "__UNI__EB22F37",
"name": "货无忧",
"version": {
"name": "1.0.31",
"code": 1031
"name": "1.0.32",
"code": 1032
},
"description": "",
"developer": {

Loading…
Cancel
Save