Bladeren bron

出库增加扫码入库功能

htc 8 maanden geleden
bovenliggende
commit
40836ccdf7
3 gewijzigde bestanden met toevoegingen van 227 en 12 verwijderingen
  1. 7 0
      pages.json
  2. 37 12
      pagesStorage/outStorage/add.vue
  3. 183 0
      pagesStorage/outStorage/scan.vue

+ 7 - 0
pages.json

@@ -169,6 +169,13 @@
 						"enablePullDownRefresh": true
 					}
 				},
+				{
+					"path": "outStorage/scan",
+					"style": {
+						"navigationStyle": "custom",
+						"enablePullDownRefresh": true
+					}
+				},
 				{
 					"path": "moveStorage/index",
 					"style": {

+ 37 - 12
pagesStorage/outStorage/add.vue

@@ -74,7 +74,10 @@
 		</div>
 		<div class="box" :style="{'padding-bottom':shipmentDto.details.length?'0':'48rpx'}">
 			<div class="title">商品明细</div>
-			<div class="btn" @tap="toAddGoods">+ 添加商品</div>
+			<div class="btns">
+				<div class="btn" @tap="toAddGoods">+ 添加商品</div>
+				<div class="btn" @tap="toScan">+ 扫码添加</div>
+			</div>
 			<div class="goods">
 				<template v-if="shipmentDto.details.length">
 					<div class="good" v-for="(good,idx) in shipmentDto.details" :key="good.skuId">
@@ -251,6 +254,22 @@
 					}
 				})
 			},
+			toScan(){
+				uni.navigateTo({
+					url:'/pagesStorage/outStorage/scan',
+					events:{
+						addGoods:list=>{
+							let aList = JSON.parse(JSON.stringify(list));
+							this.shipmentDto.details.forEach(d=>{
+								aList = aList.filter(l=>l.skuId!=d.skuId)
+							})
+							this.shipmentDto.details = [...this.shipmentDto.details,...aList];
+							this.computeNum();
+							this.autoCalculate();
+						}
+					}
+				})
+			},
 			deleteGood(index){
 				this.shipmentDto.details.splice(index,1);
 				this.$nextTick(()=>{
@@ -394,20 +413,26 @@
 					margin-top: 9rpx;
 				}
 			}
-		
-			.btn{
+			
+			.btns{
 				width: 100%;
 				height: 64rpx;
-				border-radius: 16rpx;
-				border: 1rpx solid #198CFF;
+				display: flex;
+				justify-content: space-between;
 				margin-top: 26rpx;
-				font-family: PingFang-SC, PingFang-SC;
-				font-weight: bold;
-				font-size: 26rpx;
-				color: #198CFF;
-				line-height: 64rpx;
-				text-align: center;
-				letter-spacing: 2rpx;
+				.btn{
+					width: calc(50% - 12rpx);
+					height: 62rpx;
+					border-radius: 16rpx;
+					border: 1rpx solid #198CFF;
+					font-family: PingFang-SC, PingFang-SC;
+					font-weight: bold;
+					font-size: 26rpx;
+					color: #198CFF;
+					line-height: 62rpx;
+					text-align: center;
+					letter-spacing: 2rpx;
+				}
 			}
 		
 			.goods{

+ 183 - 0
pagesStorage/outStorage/scan.vue

@@ -0,0 +1,183 @@
+<template>
+	<view class="page" :style="{'min-height':h+'px', 'padding-top':mt+'px'}">
+		<cus-header title='扫码出库'></cus-header>
+		<div class="boxs" v-if="list.length">
+			<div class="box" v-for="(item,index) in list" :key="item.skuId">
+				<div class="name">{{item.item.itemName}}</div>
+				<div class="info">规格信息:<span>{{item.itemSku.skuName||''}} / {{item.itemSku.unit||''}}</span></div>
+				<div class="cz">
+					<div class="pre">
+						<div class="text">出库</div>
+						<div class="num">
+							<u-number-box v-model="item.quantity" button-size="48" :integer="true" inputWidth="82rpx"
+							 @change="e=>changeNum(e,index)" bgColor="#F5F8FA"></u-number-box>
+						</div>
+					</div>
+					<div class="pre">
+						<div class="text">金额</div>
+						<div class="num">
+							<u-number-box v-model="item.amount" :integer="false" :canSmall="true" button-size="48" inputWidth="82rpx"
+							 @change="e=>changeMoney(e,index)" bgColor="#F5F8FA"></u-number-box>
+							 <span>元</span>
+						</div>
+					</div>
+				</div>
+			</div>
+		</div>
+		<template v-else>
+			<page-empty :height="'calc(100vh - 180px)'"></page-empty>
+		</template>
+		<div class="btns">
+			<div class="btn" @tap="scan">扫码添加</div>
+			<div class="btn" @tap="save">保存</div>
+		</div>
+	</view>
+</template>
+
+<script>
+	import pageEmpty from '../components/pageEmpty/index.vue'
+	export default {
+		components:{ pageEmpty },
+		data(){
+			return {
+				list:[]
+			}
+		},
+		methods:{
+			scan(){
+				uni.scanCode({
+					success: (res) => {
+						try{
+							let r = res.result.replace(/^\uFEFF/, '');
+							let d = JSON.parse(r);
+							if(!d.hasOwnProperty('skuId')||!d){
+								this.$showToast('请扫描正确的商品二维码');
+								return
+							} 
+							let fi = this.list.findIndex(l=>l.skuId==d.skuId);
+							if(fi>=0){
+								this.$set(this.list[fi],'quantity',++this.list[fi].quantity);
+							}else{
+								d.quantity = 1;
+								d.amount = 0;
+								this.list = [...this.list,d]
+							}
+						}catch(e){
+							this.$showToast('请扫描正确的商品二维码');
+						}
+					},
+					fail: (err) => {
+						this.$showToast('请扫描正确的商品二维码');
+					}
+				})
+			},
+			changeNum(e,index){
+				this.$set(this.list[index],'quantity',e.value);
+			},
+			changeMoney(e,index){
+				this.$set(this.list[index],'amount',e.value);
+			},
+			save(){
+				this.getOpenerEventChannel().emit('addGoods', this.list);
+				uni.navigateBack();
+			}
+		}
+	}
+</script>
+
+<style scoped lang="less">
+	::v-deep .u-number-box__minus{
+		width: 25px !important;
+	}
+	.page{
+		background: #F5F8FA;
+		padding-bottom: 168rpx;
+		box-sizing: border-box;
+		
+		.boxs{
+			padding: 0 24rpx;
+			box-sizing: border-box;
+			.box{
+				background: #FFFFFF;
+				border-radius: 16rpx;
+				padding: 32rpx 24rpx 36rpx;
+				margin-top: 20rpx;
+				.name{
+					font-family: PingFang-SC, PingFang-SC;
+					font-weight: bold;
+					font-size: 30rpx;
+					color: #1D2129;
+					text-align: left;
+				}
+				.info{
+					font-family: PingFangSC, PingFang SC;
+					font-weight: 400;
+					font-size: 24rpx;
+					color: #86909C;
+					text-align: left;
+					margin-top: 24rpx;
+					span{
+						color: #4E5969;
+					}
+				}
+				.cz{
+					margin-top: 46rpx;
+					display: flex;
+					justify-content: space-between;
+					.pre{
+						width: calc(50% - 30rpx);
+						display: flex;
+						align-items: center;
+						justify-content: space-between;
+						.text{
+							font-family: PingFangSC, PingFang SC;
+							font-weight: 400;
+							font-size: 24rpx;
+							color: #86909C;
+							line-height: 26rpx;
+							text-align: left;
+						}
+						.num{
+							display: flex;
+							align-items: center;
+							span{
+								font-family: PingFangSC, PingFang SC;
+								font-weight: 400;
+								font-size: 24rpx;
+								color: #1D2129;
+								text-align: left;
+								padding-left: 8rpx;
+							}
+						}
+					}
+				}
+			}
+		}
+		
+		.btns{
+			width: 100%;
+			height: 148rpx;
+			background: #FFFFFF;
+			padding: 20rpx 24rpx 0;
+			box-sizing: border-box;
+			display: flex;
+			justify-content: space-between;
+			position: fixed;
+			left: 0;
+			bottom: 0;
+			.btn{
+				width: calc(50% - 11rpx);
+				height: 88rpx;
+				background: #198CFF;
+				border-radius: 16rpx;
+				font-family: PingFang-SC, PingFang-SC;
+				font-weight: bold;
+				font-size: 32rpx;
+				color: #FFFFFF;
+				line-height: 88rpx;
+				text-align: center;
+				letter-spacing: 2rpx;
+			}
+		}
+	}
+</style>