From a25c7697644a40d3aa3a9746085a9a7618dd098a Mon Sep 17 00:00:00 2001
From: qingyiay <2386314947@qq.com>
Date: 星期二, 10 十月 2023 08:15:09 +0800
Subject: [PATCH] 修改称重提示错误 修改判断

---
 store/index.js |  206 +++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 190 insertions(+), 16 deletions(-)

diff --git a/store/index.js b/store/index.js
index 1ce1db3..fd6fdcb 100644
--- a/store/index.js
+++ b/store/index.js
@@ -42,13 +42,26 @@
 			selectedIconPath: '../../static/tabBar-icon/Bmine57.png',
 			text: '鎴戠殑'
 		}
+	],
+	three: [{
+			pagePath: 'pages/tabbar-page/index-tabbar/index-tabbar',
+			iconPath: '../../static/tabBar-icon/home.png',
+			selectedIconPath: '../../static/tabBar-icon/homeblue.png',
+			text: '棣栭〉'
+		},
+		{
+			pagePath: 'pages/tabbar-page/myPage-tabbar/myPage-tabbar',
+			iconPath: '../../static/tabBar-icon/Gmine10.png',
+			selectedIconPath: '../../static/tabBar-icon/Bmine57.png',
+			text: '鎴戠殑'
+		}
 	]
 }
 const store = new Vuex.Store({
 	state: {
 		// 鐢ㄦ埗鐣岄潰鍒ゆ柗
 		userInfo: {},
-		roleType: null, // 1瀹㈡埛锛�2璐т唬锛�3鍙告満
+		roleType: null, // 1瀹㈡埛锛�2璐т唬锛�3鍙告満 5瑁呭嵏鍛�
 		userTabbar: [], // 鐢ㄦ埛鎵�鍦ㄨ鑹插簳閮ㄨ彍鍗曪紝
 		// 绉伴噸鏃剁殑閲嶉噺
 		globalweigh: 0,
@@ -78,6 +91,63 @@
 		socketTask: null,
 		websocketData: null, // 瀛樻斁浠庡悗绔帴鏀跺埌鐨剋ebsocket鏁版嵁
 		globalIntervalId: null,
+		is_open_socket: false, //閬垮厤閲嶅杩炴帴
+		connectNum: 1, //閲嶈繛娆℃暟,
+		reconnectTimeOut: null,
+		// 鎵撳嵃鍑哄叆闂ㄨ瘉  涓�娆″氨鍙互鏈夋墦鍗板叆闂ㄨ瘉锛�  涓ゆ鍙互鏈夊叆闂ㄨ瘉 鍑洪棬璇�  0娆′竴寮犻兘娌℃湁 
+		ablePrintInduction: false, //鍏ラ棬璇�
+		ablePrintOut: false, //鍑洪棬璇�
+		driverTourImgList: ['https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj1.png',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj2.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj3.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj4.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj5.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj6.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj7.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj8.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj9.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj10.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj11.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj12.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj13.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj14.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj15.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj16.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj17.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj18.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj19.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj20.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj21.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj22.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj23.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj24.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj25.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj26.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj27.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj28.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj29.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj30.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj31.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj32.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj33.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj33-1.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj34.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj35.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj36.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj37.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj38.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj39.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj40.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj41.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj42.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj43.jpg',
+			'https://mx.jzeg.cn:9096/appimg/image/tour/driver/sj44.jpg',
+		],
+		wsgVisiable: false, //纾呮埧蹇欑寮圭獥鎺у埗
+		wsgContent: '',
+		globalIsFirstWeighing: 1, //鏄惁鏄涓�娆′笂纾�
+		confirmWeighVisiable: false, //纾呮埧绠$悊纭绉伴噸瀹屾垚鎻愮ず寮圭獥
+		confirmWeighContent: ''
 	},
 	mutations: {
 		lengthchange(state, payload) {
@@ -94,6 +164,9 @@
 				uni.setStorageSync('userTabbar', state.userTabbar)
 			} else if (roleType == 2 || roleType == 3) {
 				state.userTabbar = userRoleTabbar.second
+				uni.setStorageSync('userTabbar', state.userTabbar)
+			} else if (roleType == 5) {
+				state.userTabbar = userRoleTabbar.three
 				uni.setStorageSync('userTabbar', state.userTabbar)
 			}
 		},
@@ -118,6 +191,9 @@
 		changeuserInfo(state, payload) {
 			state.globaluserInfo = payload
 		},
+		changesocketTask(state, payload) {
+			state.socketTask = payload
+		},
 		// 鏀圭増鍏ㄥ眬websocket鐘舵��
 		changeisconnect(state, payload) {
 			state.globalisconnect = payload
@@ -131,30 +207,77 @@
 		},
 		setWebsocketData(state, data) {
 			state.websocketData = data
+		},
+		// 鏀瑰彉閲嶈繛鐘舵��
+		changereconnectState(state, payload) {
+			state.is_open_socket = payload
+		},
+		// 鏀瑰彉閲嶈繛娆℃暟
+		changereconnectNum(state, payload) {
+			if (payload.isWeigh) {
+				state.connectNum = payload.connectNum
+			} else {
+				if (state.connectNum < 6) {
+					state.connectNum += payload.connectNum
+				} else {
+					state.connectNum = payload.connectNum
+				}
+			}
+		},
+		changeablePrintInduction(state, payload) {
+			state.ablePrintInduction = payload
+		},
+		changeablePrintOut(state, payload) {
+			state.ablePrintOut = payload
+		},
+		changewsgVisiable(state, payload) {
+			state.wsgVisiable = payload
+		},
+		changewsgContent(state, payload) {
+			state.wsgContent = payload
+		},
+		changeglobalIsFirstWeighing(state, payload) {
+			state.globalIsFirstWeighing = payload
+		},
+		changeconfirmWeighVisiable(state, payload) {
+			state.confirmWeighVisiable = payload
+		},
+		changeconfirmWeighContent(state, payload) {
+			state.confirmWeighContent = payload
 		}
 	},
 	actions: {
 		websocketInit({ state, dispatch, commit }) {
 			let wsUrl = `${webSocketUrl}?access_token=${uni.getStorageSync('token')}`
-			state.socketTast = uni.connectSocket({
+			state.socketTask = uni.connectSocket({
 				url: wsUrl,
 				header: { CLIENT_TOC: 'Y' },
-				complete: res => {
-					console.log(res, 'socket缁撴灉')
+				success: res => {
+					console.log(res, 'socketSuccess')
 					if (res.errMsg === 'connectSocket:ok') {
 						commit('changeisconnect', true)
+						commit('changereconnectState', true)
 					}
+				},
+				fail: res => {
+					console.log(res, 'socketFail')
+					console.log('ws澶辫触');
+					commit('changereconnectState', false)
+					dispatch('reconnect')
+					commit('changeisconnect', false)
 				}
 			})
-			state.socketTast.onOpen(() => dispatch('websocketOnOpen'))
-			state.socketTast.onMessage(result => dispatch('websocketOnMessage', result.data))
-			state.socketTast.onClose(e => dispatch('websocketOnClose', e))
-			state.socketTast.onError(e => dispatch('websocketOnError'))
+			state.socketTask.onOpen(() => dispatch('websocketOnOpen'))
+			state.socketTask.onMessage(result => dispatch('websocketOnMessage', result.data))
+			state.socketTask.onClose(e => dispatch('websocketOnClose', e))
+			state.socketTask.onError(e => dispatch('websocketOnError', e))
 		},
 		websocketOnOpen({ state, commit }) {
-			console.log('onOpen')
+			console.log('ws鎵撳紑')
+			clearInterval(state.reconnectTimeOut)
+			clearInterval(state.globalIntervalId)
 			state.globalIntervalId = setInterval(() => {
-				state.socketTast.send({
+				state.socketTask.send({
 					data: JSON.stringify({ type: 'ping' }),
 					success(e) {
 						console.log(e, '鍙戦�佸績璺虫垚鍔�')
@@ -162,19 +285,70 @@
 				})
 			}, 30000)
 		},
-		websocketOnClose({ state, commit }) {
-			if (!state.socketTast) return
-			state.socketTast.close(e => {
+		websocketOnClose({ state, commit, dispatch }, e) {
+			if (!state.socketTask) return
+			console.log('ws鍏抽棴', e)
+			state.socketTask.close(e => {
 				commit('changeisconnect', false)
 			})
-			console.log('ws鍏抽棴')
+			clearInterval(state.globalIntervalId)
+			clearInterval(state.reconnectTimeOut)
+			state.socketTask = null
+			commit('changereconnectState', false)
+			if ((state.connectNum < 6 || state.connectNum.connectNum < 6) && state.globalisLogin) {
+				uni.showToast({
+					title: '杩炴帴澶辫触锛屾鍦ㄥ皾璇曢噸鏂拌繛鎺�',
+					icon: 'none'
+				})
+				commit('changereconnectNum', { connectNum: 1, isWeigh: false })
+				dispatch('reconnect')
+			} else if (state.connectNum >= 6 && state.globalisLogin) {
+				commit('changereconnectNum', { connectNum: 1, isWeigh: false })
+				uni.showToast({
+					title: '缃戠粶寮傚父,璇风◢鍚庨噸璇�',
+					icon: 'none'
+				})
+			} else {
+				return
+			}
 		},
-		websocketOnError(e) {
-			console.log('socket鎶ラ敊', e)
+		websocketOnError({ state, commit, dispatch }, e) {
+			// 濡傛灉閲嶈繛鐘舵�佷负false鍒欎笉杩涜閲嶈繛锛屼负true鎵嶄細
+			console.log('ws鎶ラ敊', e)
+			clearInterval(state.globalIntervalId)
+			clearInterval(state.reconnectTimeOut)
+			state.socketTask = null
+			commit('changereconnectState', false)
+			if (state.connectNum < 6 || state.connectNum.connectNum < 6 && state.globalisLogin) {
+				uni.showToast({
+					title: '杩炴帴澶辫触锛屾鍦ㄥ皾璇曢噸鏂拌繛鎺�',
+					icon: 'none'
+				})
+				commit('changereconnectNum', { connectNum: 1, isWeigh: false })
+				dispatch('reconnect')
+			} else if (state.connectNum > 6 && state.globalisLogin) {
+				commit('changereconnectNum', { connectNum: 1, isWeigh: false })
+				uni.showToast({
+					title: '缃戠粶寮傚父,璇风◢鍚庨噸璇�',
+					icon: 'none'
+				})
+			} else {
+				return
+			}
 		},
 		// 鎺ユ敹鏁版嵁
 		websocketOnMessage({ state, commit }, result) {
 			commit('setWebsocketData', result)
+		},
+		// 閲嶆柊杩炴帴
+		reconnect({ state, commit, dispatch }) {
+			console.log(state.is_open_socket, '閲嶆柊杩炴帴socket鐘舵��');
+			clearInterval(state.globalIntervalId)
+			if (!state.is_open_socket && state.globalisLogin) {
+				state.reconnectTimeOut = setInterval(() => {
+					dispatch('websocketInit')
+				}, 5000)
+			}
 		}
 	}
 })

--
Gitblit v1.9.1