| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423 | <template>	<view class="nvue-page-root">		<view class="uni-common-mt" style="padding: 5px;">			<view class="uni-form-item uni-column">				<view class="uni-input-wrapper" style="margin: 5px auto;">					<text class="uni-form-item__title">批次</text>					<input class="uni-input" value="202312111231" />					<button class="mini-btn" type="primary" size="mini">创建新批次</button>				</view>				<view class="uni-input-wrapper product_code">					<!-- <input class="uni-input" focus placeholder="请扫描存货编码" value="" @input="hideKeyboard" /> -->					<input class="uni-input" placeholder="请扫描存货编码" value="" @input="hideKeyboard" />				</view>				<view class="uni-input-wrapper table-title">					<view class="tab-tr" style="width: 12%;">序号</view>					<view class="tab-tr" style="width: 40%;">存货编码</view>					<view class="tab-tr" style="width: 36%;">名称</view>					<view class="tab-tr-end" style="width: 12%;">数量</view>				</view>				<view style="min-height:280px;overflow-y:auto;max-height:280px">					<view class="uni-input-wrapper table-data" v-for="(item,index) in tableData" :key="index">						<view class="tab-tr" style="width: 12%;">{{index+1}}</view>						<view class="tab-tr" style="width: 40%;">{{item.product_code}}</view>						<view class="tab-tr" style="width: 36%;">{{item.product_name}}</view>						<view class="tab-tr-end" style="width: 12%;">{{item.num}}</view>					</view>				</view>				<view class="uni-input-wrapper button-sp-area">					<button type="primary" plain="true" @click="groupDisk()">组盘</button>					<button type="primary" plain="true" @click="in_stock()">入库单</button>				</view>				<!-- 	<textarea v-model="localtion"></textarea>				<view class="bluetoothItem" v-if="GET_INFODATA">					<view class="bluetoothList" v-for="(item,index) in GET_INFODATA" :key="index"						@tap="confirm_bluetooth(item)">						<view class="bluetoothList-name">名称:{{item.name}}</view>						<view class="bluetoothList-mac">地址:{{item.mac}}</view>						<view class="bluetoothList-jange">--------------</view>					</view>				</view> -->			</view>		</view>	</view></template><script>	// import printConnect from "@/common/print.js"; //引入打印机模板文件	let _this = null;	import {		mapGetters,		mapActions	} from 'vuex';	import {		GET_INFODATA,		GET_CONNECTBLEDATA	} from "@/store/gettersType.js";	import {		SET_CONNECTBLEDATA	} from '@/store/actionsType.js';	// #ifdef APP-PLUS	const modal = uni.requireNativePlugin('modal');	// const HPRT = uni.requireNativePlugin('DCloud-RichAlert');	const printModule = uni.requireNativePlugin('PrintModuleCPCL');	// #endif	let print;	var reqRootUrl = plus.storage.getItem("reqRootUrl");	let rData = [];	export default {		data() {			return {				isStart: true,				bArray: [], //用于搜索蓝牙去重用的				no_match_list: [], //没有配对的蓝牙列表				match_list: "", //已连接蓝牙打印机				val: "",				localtion: '',				dateTimer: "",				valArr: [],				url: '',				item: {					name: "HM",					mac: "E0:6E:41:34:E0:93",				},				result: -1,				title: 'input',				focus: false,				inputValue: '',				showClearIcon: false,				inputClearValue: '',				changeValue: '',				showPassword: true,				src: '../../../static/eye-1.png',				platform: '',				isNvue: false,				tableData: [{						name: '张三',						age: 20					},					{						name: '李四',						age: 22					},					{						name: '王五',						age: 23					},					// 其他数据...  				],			}		},		computed: {			...mapGetters([GET_INFODATA, GET_CONNECTBLEDATA])		},		methods: {			onLoad() {				this.platform = uni.getSystemInfoSync().platform				// #ifdef APP-PLUS-NVUE				this.isNvue = true				// #endif				_this = this;				setTimeout(() => {					this.getList();				}, 350);				// 打印相关				setTimeout(() => {					this.$init_bluetooth();				}, 500);				if (this.result !== 0) {					this.closeBT()					setTimeout(() => {						let item = {							name: "HM-A300-E093",							mac: "60:6E:41:34:E0:93",						};						this.confirm_bluetooth(item)					}, 1500);				} else {					console.log("scssssss")				}			},			onShow() {				uni.hideKeyboard();				setTimeout(() => {					// this.getList();				}, 350);			},			onKeyInput: function(event) {				this.inputValue = event.detail.value			},			replaceInput: function(event) {				var value = event.detail.value;				if (value === '11') {					this.changeValue = '2';				}			},			hideKeyboard: function(event) {				uni.hideKeyboard();			},			changePassword: function() {				this.showPassword = !this.showPassword;			},			onFocus() {				this.$mp.page.$getAppWebview().setStyle({					softinputNavBar: 'none'				})			},			onBlur() {				this.$mp.page.$getAppWebview().setStyle({					softinputNavBar: 'auto'				})			},			getList() {				console.log("获取列表");				uni.request({					url: reqRootUrl + '/wms/api',					method: 'POST',					headers: {						'Content-Type': 'application/json'					},					data: JSON.stringify({						"method": "GroupDiskGet",						"param": {							"status": "status_wait",						}					}),					success: (ret) => {						// console.log("ret.data ", ret.data.data)						// $("#dataList").html("")						let rows = ret.data.data;						// alert(rows)						rData = rows;						this.tableData = rows;						// $("#dataList").html(html)						//处理成功逻辑					},					fail: (err) => {						// console.log('request fail', err);					},					complete: () => {						// console.log('complete');					}				})			},			//  			groupDisk: function() {				uni.showModal({					title: "提示",					content: "确定组盘?",					success: function(res) {						if (res.confirm) {							let sns = [];							for (var i = 0; i < rData.length; i++) {								if (rData[i]["status"] !== "status_wait") {									continue								}								sns.push(rData[i].sn)							}							uni.request({								url: reqRootUrl + '/wms/api',								method: 'POST',								headers: {									'Content-Type': 'application/json'								},								data: JSON.stringify({									"method": "ReceiptAdd",									"param": {										"group_disk_sn_list": sns,									}								}),								success: (ret) => {									if (ret.data.ret === "ok") {										let code = ret.data.data["container_code"]										console.log("code ", code)										_this.goDetail(code)									} else {										console.log('request fail', ret.data.msg);									}								},								fail: (err) => {									// console.log('request fail', err);								},								complete: () => {									// console.log('complete');								}							})						} else {						}					}				})			},			in_stock: function(code) {				setTimeout(() => {					uni.navigateTo({						url: '/pages/sample/in_stock',					})				}, 500);			},			goDetail: function(code) {				this.handlePrint(code)			},			isEmpty: function(obj) {				return typeof obj === undefined || obj == null || obj === "" || obj === "000000000000000000000000" ||					obj.length === 0;			},			// 打印机相关			...mapActions([SET_CONNECTBLEDATA]),			// 连接打印机			confirm_bluetooth(item) {				// let {				// 	name,				// 	mac				// } = item;				uni.showLoading({					title: "连接中...",					mask: true				})				let mac = item.mac;				try {					printModule.connectionBT({						'address': mac					}, result => {						const msg = JSON.stringify(result);						this.result = JSON.parse(msg).result;						modal.toast({							message: msg,							duration: 6						});						uni.hideLoading()						printModule.setDisConnectBTListener((ret) => {							modal.toast({								message: '蓝牙断开',								duration: 6							});						})					})				} catch (e) {					console.log(e)				}			},			//搜索没匹配的蓝牙设备			search_bluetooth(address) {				let _this = this;				//检查蓝牙是否开启				this.$check_bluetooth_open().then(ores => {					if (ores) {						console.log(ores);						//搜索蓝牙						_this.$search_bluetooth().then(bres => {							console.log(bres);							if (bres.code) {								_this.$search_pipei().then(pres => {									console.log(pres);								})							}						})					}				})			},			handlePrint(code) {				printModule.printAreaSize({					'height': '400',					'number': '1'				}, result => {})					printModule.printBarCode({					'x_pos': '10',					'y_pos': '0',					'code_type': '128',					'ratio': '2',					'height': '240',					'width': '1',					'rotation': 'BARCODE',					'undertext': true,					'number': '4',					'offset': '5',					"textAlign": "right",					'code_data': code				});				console.log("printModule ", printModule)				printModule.print()			},			closeBT() {				printModule.closeBT();			},		},	}</script><style scoped>	.nvue-page-root {		background-color: #F8F8F8;		padding-bottom: 0px;	}	.uni-form-item__title {		margin: 5px auto;	}	.uni-input-wrapper {		/* #ifndef APP-NVUE */		display: flex;		/* #endif */		flex-direction: row;		flex-wrap: nowrap;		background-color: #FFFFFF;	}	.uni-input {		height: 28px;		line-height: 28px;		font-size: 15px;		padding: 1px;		flex: 1;		border-radius: 5px;		border: 1px solid #cfdadd;		background-color: #FFFFFF;	}	.mini-btn {		height: 30px;		padding-left: 1px;		padding-right: 1px;	}	.uni-eye-active {		color: #007AFF;	}	.table-title {		background-color: aliceblue;		font-weight: 700;		margin-top: 10px;		height: 40px;	}	.table-data {		background-color: aliceblue;		font-weight: 700;		margin-top: 1px;		height: 40px;	}	.tab-tr {		width: 25%;		line-height: 25px;		border-right: 1px solid #ccc;		margin: auto;		text-align: center;	}	.tab-tr-end {		width: 25%;		line-height: 25px;		border-right: 0px solid #ccc;		margin: auto;		text-align: center;	}</style>
 |