From ea92a004d52ce8a49356d8cf81152f565bae71b7 Mon Sep 17 00:00:00 2001
From: whycq <913841844@qq.com>
Date: 星期三, 01 二月 2023 09:44:14 +0800
Subject: [PATCH] #

---
 pages/login/login.vue |  589 ++++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 426 insertions(+), 163 deletions(-)

diff --git a/pages/login/login.vue b/pages/login/login.vue
index 96e2a12..71310b7 100644
--- a/pages/login/login.vue
+++ b/pages/login/login.vue
@@ -1,51 +1,82 @@
-  <template>
+<template>
 	<view class="zai-box">
-        <scroll-view scroll-y class="page">
-			<view class="changIP">
-				<button @click="changeIP()">璁剧疆IP</button>
+
+		<scroll-view scroll-y class="page">
+
+			<view class="text-center" :style="[{animation: 'show ' + 0.4+ 's 1'}]">
+				<image src="../../static/logo.png" mode='aspectFit' class="zai-logo" @longtap='longpressImg'></image>
 			</view>
-            <view class="text-center" :style="[{animation: 'show ' + 0.4+ 's 1'}]">
-				<image src="../../static/logo.png" mode='aspectFit' class="zai-logo "></image>
-				<view class="zai-title text-shadow ">Zoneyung</view>
-			</view>
-            <view class="box padding-lr-xl login-paddingtop" :style="[{animation: 'show ' + 0.6+ 's 1'}]">
+			<view class="box padding-lr-xl login-paddingtop" :style="[{animation: 'show ' + 0.6+ 's 1'}]">
 				<block v-if="loginWay==1">
 					<view class="cu-form-group margin-top  shadow-warp" :class="[shape=='round'?'round':'']">
-						<view class="title"><text class="cuIcon-people margin-right-xs"></text>璐﹀彿:</view>
-						<input placeholder="璇疯緭鍏ヨ处鍙�" name="input" v-model="info.userName"></input>
+						<view class="title-login"><text class="cuIcon-people margin-right-xs"></text>璐﹀彿:</view>
+						<input placeholder="璇疯緭鍏ヨ处鍙�" name="input" v-model="userName"></input>
 					</view>
 					<view class="cu-form-group margin-top shadow-warp" :class="[shape=='round'?'round':'']">
-						<view class="title"><text class="cuIcon-lock margin-right-xs"></text>瀵嗙爜:</view>
-						<input class="uni-input" placeholder="璇疯緭鍏ュ瘑鐮�" :password="!showPassword" v-model="info.password" />
+						<view class="title-login"><text class="cuIcon-lock margin-right-xs"></text>瀵嗙爜:</view>
+						<input class="uni-input" placeholder="璇疯緭鍏ュ瘑鐮�" :password="!showPassword" v-model="password" />
 						<view class="action text-lg">
-						    <text :class="[showPassword ? 'cuIcon-attention' : 'cuIcon-attentionforbid']" @click="changePassword"></text>
+							<text :class="[showPassword ? 'cuIcon-attention' : 'cuIcon-attentionforbid']"
+								@click="changePassword"></text>
 						</view>
 					</view>
-					<view>
-						<checkbox-group>
+					<view class="flex margin-xs justify-between">
+						<checkbox-group class="rember">
 							<label>
-								<checkbox value="cb" checked="true" color="#FFCC33" style="transform:scale(0.7)" />閫変腑
-							</label>
-							<label>
-								<checkbox value="cb" checked="true"/>鏈�変腑
+								<checkbox value="cb" :checked="rember" @tap="rember = !rember"
+									style="transform:scale(0.7)" /><text>璁颁綇瀵嗙爜</text>
 							</label>
 						</checkbox-group>
+						<!-- <text class="changeIP" @click="changeIP()">璁剧疆IP</text> -->
+						<text class="changeIP" @click="config()">閰嶇疆</text>
 					</view>
-					<view class="padding text-center margin-top">
-						<button class="cu-btn bg-blue lg margin-right shadow" :loading="loading" :class="[shape=='round'?'round':'']"
-							@tap="onLogin"><text space="emsp">{{loading ? "鐧诲綍涓�...":" 鐧诲綍 "}}</text>
+					<view class="flex padding justify-center margin-top">
+						<button class="cu-btn bg-blue lg  shadow" :loading="loading"
+							:class="[shape=='round'?'round':'']" @tap="onLogin"><text
+								space="emsp">{{loading ? "鐧诲綍涓�...":" 鐧诲綍 "}}</text>
 						</button>
 					</view>
 				</block>
-	
+
 				<!-- #ifdef APP-PLUS -->
-				<view class="padding flex flex-direction  text-center">
+				<view class="padding flex flex-direction  text-center"
+					style="position: fixed;width: 80%;bottom: 0;text-align: center;">
 					褰撳墠鐗堟湰:{{version}}
 				</view>
 				<!-- #endif -->
-				
-            </view>
-        </scroll-view>
+
+			</view>
+		</scroll-view>
+
+		<view>
+			<uni-popup ref="popup" type="right">
+				<view class="config">
+					<view class="config-title"><text>閰嶇疆</text></view>
+					<view class="config-item">
+						<text>ip鍦板潃锛�</text>
+						<input v-model="IP" type="text" placeholder="192.168.1.1"
+							placeholder-style="font-size:16rpx;text-indent: 10rpx;">
+					</view>
+					<view class="config-item">
+						<text>绔彛鍙凤細</text>
+						<input v-model="PORT" type="text" placeholder="8080"
+							placeholder-style="font-size:16rpx;text-indent: 10rpx;">
+					</view>
+					<view class="config-item">
+						<text>椤圭洰锛�</text>
+						<input v-model="PROJECT" type="text" placeholder="wms"
+							placeholder-style="font-size:16rpx;text-indent: 10rpx;">
+					</view>
+					<view class="flex justify-around">
+						<button class="cu-btn bg-blue lg" @click="configConfirm">纭</button>
+					</view>
+				</view>
+			</uni-popup>
+		</view>
+
+
+
+
 		<!-- 鐧诲綍鍔犺浇寮圭獥 -->
 		<view class="cu-load load-modal" v-if="loading">
 			<!-- <view class="cuIcon-emojifill text-orange"></view> -->
@@ -53,27 +84,35 @@
 			<view class="gray-text">鐧诲綍涓�...</view>
 		</view>
 		<view>
-			<!-- 杈撳叆妗嗙ず渚� -->
 			<uni-popup ref="inputDialog" type="dialog">
-				<uni-popup-dialog ref="inputClose" mode="input" title="璇疯緭鍏P" value="http://192.168.4.123:8082/xgmwms"
-					placeholder="璇疯緭鍏P" @confirm="dialogInputConfirm">
+				<uni-popup-dialog ref="inputClose" mode="input" title="璁剧疆IP" v-model="IP" placeholder="璇疯緭鍏ユ湇鍔″櫒IP"
+					@confirm="dialogInputConfirm">
 				</uni-popup-dialog>
 			</uni-popup>
 		</view>
-    </view>
+		<view style="margin-top: 10rpx;">
+			<uni-popup ref="serverPort" type="dialog">
+				<uni-popup-dialog ref="inputClose" mode="input" title="璁剧疆绔彛" v-model="PORT" placeholder="璇疯緭鍏ユ湇鍔″櫒绔彛鍙�"
+					@confirm="serverPortConfirm">
+				</uni-popup-dialog>
+			</uni-popup>
+		</view>
+	</view>
 
 </template>
 
 <script>
 	// import { ACCESS_TOKEN,USER_NAME,USER_INFO } from "@/common/util/constants"
-	import { mapActions } from "vuex"
+	import {
+		mapActions
+	} from "vuex"
 	import md5 from '../../common/md5.js'
-    // import configService from '@/common/service/config.service.js';
-	
-    export default {
-        data() {
-            return {
-				shape:'',//round 鍦嗗舰
+	// import configService from '@/common/service/config.service.js';
+
+	export default {
+		data() {
+			return {
+				shape: '', //round 鍦嗗舰
 				loading: false,
 				phoneNo: '',
 				smsCode: '',
@@ -82,82 +121,245 @@
 				smsCountDown: 0,
 				smsCountInterval: null,
 				toggleDelay: false,
-				version:'',
+				version: '',
 				//绗笁鏂圭櫥褰曠浉鍏充俊鎭�
-				thirdType:"",
-				thirdLoginInfo:"",
-				thirdLoginState:false,
-				bindingPhoneModal:false,
-				thirdUserUuid:'',
+				thirdType: "",
+				thirdLoginInfo: "",
+				thirdLoginState: false,
+				bindingPhoneModal: false,
+				thirdUserUuid: '',
 				url: {
 					bindingThirdPhone: '/sys/thirdLogin/bindingThirdPhone'
 				},
-				baseIP:'',
-				type:'',
-				info:{
-					userName:'',
-					password:''
-				},
-				rember:true,
-			
-            };
-        },
-		onLoad:function(){
+				type: '',
+				userName: '',
+				password: '',
+				rember: true,
+				IP: '10.20.192.200',
+				PORT: '', // 榛樿绔彛鍙�
+				PROJECT: ''
+			};
+		},
+		mounted() {
+			let that = this;
+			//缂撳瓨鐨勮处鍙�
+			const HCuname = uni.getStorageSync('HCuname');
+			//缂撳瓨鐨勫瘑鐮�
+			const HCpassw = uni.getStorageSync('HCpassw');
+			//鏈夌紦瀛樺氨璧嬪�肩粰鏂囨湰娌℃湁灏辨竻绌�
+			if (HCuname && HCpassw) {
+				that.userName = HCuname;
+				that.password = HCpassw;
+			} else {
+				that.userName = '';
+				that.password = '';
+			}
+			const UIP = uni.getStorageSync('UIP');
+			if (UIP) {
+				that.IP = UIP;
+				that.baseIP = UIP;
+			} else {
+				that.IP = '';
+			}
+
+			const UPORT = uni.getStorageSync('UPORT');
+			if (UPORT) {
+				that.PORT = UPORT;
+				that.basePORT = UPORT;
+			} else {
+				that.PORT = '';
+			}
+			const PROJ = uni.getStorageSync('UPROJ');
+			this.PROJECT = PROJ;
+			this.baseUrl = PROJ
+		},
+		onLoad: function() {
 			// #ifdef APP-PLUS
-			var that=this
-			plus.runtime.getProperty( plus.runtime.appid, function ( wgtinfo ) {
-				that.version=wgtinfo.version
+			var that = this
+			plus.runtime.getProperty(plus.runtime.appid, function(wgtinfo) {
+				that.version = wgtinfo.version
 			});
 			// #endif
+			// this.getVersion()
+			// this.downWgt()
 		},
 		computed: {
-		      isSendSMSEnable() {
-		        return this.smsCountDown <= 0 && this.phoneNo.length > 4;
-		      },
-		      getSendBtnText() {
-		        if (this.smsCountDown > 0) {
-		          return this.smsCountDown + '绉掑悗鍙戦��';
-		        } else {
-		          return '鍙戦�侀獙璇佺爜';
-		        }
-		      },
-		      canSMSLogin() {
-		        return this.info.userName.length > 4 && this.smsCode.length > 4;
-		      },
-		      canPwdLogin() {
-		        return this.info.userName.length > 4 && this.info.password.length > 4;
-		      },
+			isSendSMSEnable() {
+				return this.smsCountDown <= 0 && this.phoneNo.length > 4;
+			},
+			getSendBtnText() {
+				if (this.smsCountDown > 0) {
+					return this.smsCountDown + '绉掑悗鍙戦��';
+				} else {
+					return '鍙戦�侀獙璇佺爜';
+				}
+			},
+			canSMSLogin() {
+				return this.userName.length > 4 && this.smsCode.length > 4;
+			},
+			canPwdLogin() {
+				return this.userName.length > 4 && this.password.length > 4;
+			},
 		},
-        methods: {
-			changeIP(){
+		methods: {
+			downWgt() {
+				let that = this;
+				const downloadUrl = "http://192.168.4.188:8088/jfwms/static/appupload/android_debug.apk"
+				console.log('url:' + downloadUrl)
+				uni.showLoading({
+					title: '鏇存柊涓�︹��'
+				})
+				// return
+				const downloadTask = uni.downloadFile({ //鎵ц涓嬭浇
+					url: downloadUrl, //涓嬭浇鍦板潃
+					timeout: 1000 * 30, //30绉掕秴鏃舵椂闂�
+					success: downloadResult => { //涓嬭浇鎴愬姛
+						console.log(downloadResult);
+						that.showdownLine = false
+						uni.hideLoading();
+						console.log('downloadResult.statusCode' + downloadResult.statusCode)
+						if (downloadResult.statusCode == 200) {
+							console.log('鏇存柊涓�')
+							uni.showModal({
+								title: '',
+								content: '鏇存柊鎴愬姛锛岀‘瀹氱幇鍦ㄩ噸鍚悧锛�',
+								confirmText: '閲嶅惎',
+								confirmColor: '#EE8F57',
+								success: function(res) {
+									if (res.confirm == true) {
+										plus.runtime.install( //瀹夎
+											downloadResult.tempFilePath, {
+												force: true
+											},
+											function(res) {
+												utils.showToast('鏇存柊鎴愬姛锛岄噸鍚腑');
+												plus.runtime.restart();
+											}
+										);
+									}
+								}
+							});
+						}
+					},
+					fail: err => {
+						uni.hideLoading();
+						that.showdownLine = false
+						that.$u.toast(err.errMsg)
+						console.log(err)
+					},
+					complete: com => {
+						console.log(com)
+					}
+				});
+
+				// 涓嬭浇杩涘害
+				downloadTask.onProgressUpdate(res => {
+					// that.$u.toast(res.progress)
+					that.downloadNum = res.progress
+					console.log('涓嬭浇杩涘害' + that.downloadNum);
+					// console.log('宸茬粡涓嬭浇鐨勬暟鎹暱搴�' + res.totalBytesWritten);
+					// console.log('棰勬湡闇�瑕佷笅杞界殑鏁版嵁鎬婚暱搴�' + res.totalBytesExpectedToWrite);
+
+					// 婊¤冻娴嬭瘯鏉′欢锛屽彇娑堜笅杞戒换鍔°��
+					// if (res.progress > 50) {
+					// 	downloadTask.abort();
+					// }
+				});
+			},
+			// 閰嶇疆 URL PORT 椤圭洰(jkwms)
+			config() {
+				this.$refs.popup.open("center")
+			},
+			// 纭閰嶇疆
+			configConfirm() {
+				this.baseIP = this.IP
+				uni.setStorageSync('UIP', this.baseIP)
+				this.basePORT = this.PORT
+				uni.setStorageSync('UPORT', this.basePORT)
+				this.baseUrl = this.PROJECT
+				uni.setStorageSync('UPROJ', this.baseUrl)
+				var baseUrl = this.baseHttp + this.baseIP + ':' + this.basePORT + "/" + this.baseUrl
+				uni.setStorageSync("baseUrl", baseUrl)
+				this.$refs.popup.close()
+			},
+			longpressImg() { // 闀挎寜鍥剧墖
+				this.$refs.serverPort.open()
+			},
+			serverPortConfirm(type) {
+				this.basePORT = type
+				// 瀛樺叆鏈湴缂撳瓨
+				this.PORT = type
+				uni.setStorageSync('UPORT', this.basePORT)
+			},
+			changeIP() {
 				this.$refs.inputDialog.open()
 			},
-			dialogInputConfirm(type){
-				this.baseUrl=type
+			dialogInputConfirm(type) {
+				this.baseIP = type
+				// 瀛樺叆鏈湴缂撳瓨
+				this.IP = type;
+				uni.setStorageSync('UIP', this.baseIP)
 			},
-			chk(e){
-				console.log(e)
+			checkboxChange: function(e) {
+				if (e.detail.value.length == 1) {
+
+					//鑾峰彇缂撳瓨鐨勮处鍙�
+					uni.getStorageSync('HCuname', this.userName);
+					uni.getStorageSync('HCpassw', this.password);
+				} else {
+					uni.removeStorageSync('HCuname');
+					uni.removeStorageSync('HCpassw');
+				}
 			},
-			onLogin: function (){
-				if(!this.info.userName || this.info.userName.length==0){
-					uni.showToast({title: '璇峰~鍐欒处鍙�',icon: "none"})
+			onLogin: function() {
+				if (!this.userName || this.userName.length == 0) {
+					uni.showToast({
+						title: '璇峰~鍐欒处鍙�',
+						icon: "none"
+					})
 					return;
 				}
-				if(!this.info.password || this.info.password.length==0){
-					uni.showToast({title: '璇峰~鍐欏瘑鐮�',icon: "none"})
+				if (!this.password || this.password.length == 0) {
+					uni.showToast({
+						title: '璇峰~鍐欏瘑鐮�',
+						icon: "none"
+					})
+					return;
+				}
+				if (this.baseIP == undefined || this.baseIP == '') {
+					uni.showToast({
+						title: '璇峰厛璁剧疆IP',
+						icon: 'none'
+					})
+					return;
+				}
+				if (this.basePORT == undefined) {
+					uni.showToast({
+						title: '闀挎寜鍥剧墖杈撳叆绔彛鍙�',
+						icon: 'none'
+					})
 					return;
 				}
 				uni.showLoading();
+				setTimeout(function() {
+					uni.hideLoading();
+					uni.showToast({
+						title: '鐧诲綍瓒呮椂',
+						position: 'bottom',
+						duration: 1000
+					});
+				}, 6000)
 				uni.request({
-				    url: this.baseUrl + '/login.action',
-				    data: {
-				      mobile:this.info.userName,
-				      password:md5.hex_md5(this.info.password) 
-				    },
-				    header: {
+					url: this.baseHttp + this.baseIP + ':' + this.basePORT + "/" + this.baseUrl +
+						'/login.action',
+					data: {
+						username: this.userName,
+						password: md5.hex_md5(this.password)
+					},
+					header: {
 						"content-type": "application/json"
-				    },
-				    success: (result) => {
+					},
+					success: (result) => {
 						let res = result.data;
 						uni.hideLoading();
 						if (res.code == 200) {
@@ -166,11 +368,18 @@
 								position: 'bottom',
 								duration: 1000
 							});
+							if (this.rember) {
+								uni.setStorageSync('HCuname', this.userName);
+								uni.setStorageSync('HCpassw', this.password);
+							} else {
+								uni.removeStorageSync('HCuname');
+								uni.removeStorageSync('HCpassw');
+							}
 							uni.setStorageSync('token', res.data.token);
 							setTimeout(() => {
-								uni.navigateBack();		//   灏忕▼搴忕敤杩欎釜  鎶婇椤佃矾鐢辨斁绗竴涓�
+								// uni.navigateBack();		//   灏忕▼搴忕敤杩欎釜  鎶婇椤佃矾鐢辨斁绗竴涓�
 								uni.reLaunch({
-									url: '../index/index'
+									url: '../index/index2'
 								});
 							}, 1000);
 						} else {
@@ -180,95 +389,149 @@
 								position: 'top'
 							})
 						}
-						
-				    }
+
+					}
 				});
 			},
-			saveClientId(){
+			saveClientId() {
 				var info = plus.push.getClientInfo();
 				var cid = info.clientid;
-				this.$http.get("/sys/user/saveClientId",{params:{clientId:cid}}).then(res=>{
-					console.log("res::saveClientId>",res)
+				this.$http.get("/sys/user/saveClientId", {
+					params: {
+						clientId: cid
+					}
+				}).then(res => {
 					this.$tip.success('鐧诲綍鎴愬姛!')
-					this.$Router.replaceAll({name:'index'})
+					this.$Router.replaceAll({
+						name: 'index'
+					})
 				})
 			},
 			changePassword() {
 				this.showPassword = !this.showPassword;
 			},
 			loginSuccess() {
-			  // 鐧婚檰鎴愬姛锛岄噸瀹氬悜鍒颁富椤�
-			  this.$Router.replace({name:'index'})
+				// 鐧婚檰鎴愬姛锛岄噸瀹氬悜鍒颁富椤�
+				this.$Router.replace({
+					name: 'index'
+				})
 			},
 			requestFailed(err) {
-			  this.$message.warning("鐧诲綍澶辫触")
+				this.$message.warning("鐧诲綍澶辫触")
 			},
-        },
-		beforeDestroy() {
-		    if (this.smsCountInterval) {
-		        clearInterval(this.smsCountInterval);
-		    }
 		},
-		
-		
-    }
+		beforeDestroy() {
+			if (this.smsCountInterval) {
+				clearInterval(this.smsCountInterval);
+			}
+		},
+
+
+	}
 </script>
 
 <style>
 	@import "../../colorui/main.css";
 	@import "../../colorui/icon.css";
 	@import "../../colorui/animation.css";
-	
-    .login-paddingtop {
-        padding-top: 50upx;
-    }
 
-    .zai-box {
-        /* padding: 0 20upx;
-        padding-top: 100upx;
-        position: relative; */
-    }
-
-    .zai-logo {
-        width: 200upx;
-        height: 150px;
-    }
-
-    .zai-title {
-       font-size: 58upx;
-       color: #000000;
-       text-align: center;
-    }
-
-    .input-placeholder, .zai-input {
-        color: #94afce;
-    }
-
-    .zai-label {
-        padding: 60upx 0;
-        text-align: center;
-        font-size: 30upx;
-        color: #a7b6d0;
-    }
-
-    .zai-btn {
-        background: #ff65a3;
-        color: #fff;
-        border: 0;
-        border-radius: 100upx;
-        font-size: 36upx;
-    }
-
-    .zai-btn:after {
-        border: 0;
-    }
-
-    /*鎸夐挳鐐瑰嚮鏁堟灉*/
-    .zai-btn.button-hover {
-        transform: translate(1upx, 1upx);
-    }
-	.changIP {
-		margin-top: 0rpx;
+	.config {
+		width: 500rpx;
+		height: 500rpx;
+		background-color: #fff;
+		border-radius: 20px;
 	}
 
+	.config-title {
+		height: 100rpx;
+		font-size: 32rpx;
+		text-align: center;
+		line-height: 100rpx;
+	}
+
+	.config-item {
+		height: 100rpx;
+	}
+
+	.config-item text {
+		display: inline-block;
+		float: left;
+		text-indent: 1em;
+	}
+
+	.config-item input {
+		display: inline-block;
+		float: right;
+		margin-right: 50rpx;
+		width: 300rpx;
+		height: 50rpx;
+		border: 1px solid #aaaaaa;
+		border-radius: 10rpx;
+		font-size: 16rpx;
+		text-indent: 10rpx;
+
+	}
+
+	.login-paddingtop {
+		padding-top: 50upx;
+	}
+
+	.zai-box {
+		padding: 0 20upx;
+		padding-top: 100upx;
+		position: relative;
+	}
+
+	.zai-logo {
+		width: 600upx;
+		height: 150px;
+	}
+
+	.zai-title {
+		font-size: 58upx;
+		color: #000000;
+		text-align: center;
+	}
+
+	.input-placeholder,
+	.zai-input {
+		color: #94afce;
+	}
+
+	.zai-label {
+		padding: 60upx 0;
+		text-align: center;
+		font-size: 30upx;
+		color: #a7b6d0;
+	}
+
+	.zai-btn {
+		background: #ff65a3;
+		color: #fff;
+		border: 0;
+		border-radius: 100upx;
+		font-size: 36upx;
+	}
+
+	.zai-btn:after {
+		border: 0;
+	}
+
+	/*鎸夐挳鐐瑰嚮鏁堟灉*/
+	.zai-btn.button-hover {
+		transform: translate(1upx, 1upx);
+	}
+
+	.changeBox {
+		margin-top: 20upx;
+	}
+
+	.rember {
+		display: inline-block;
+	}
+
+	.changeIP {
+		float: right;
+		margin-right: 15upx;
+	}
 </style>

--
Gitblit v1.9.1