From 690a0b08ef4df6f15157eaf1294b500767e2ac24 Mon Sep 17 00:00:00 2001 From: whycq <10027870+whycq@user.noreply.gitee.com> Date: 星期日, 29 一月 2023 16:25:29 +0800 Subject: [PATCH] # --- pages/login/login.vue | 590 ++++++++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 428 insertions(+), 162 deletions(-) diff --git a/pages/login/login.vue b/pages/login/login.vue index 69f3dd1..71310b7 100644 --- a/pages/login/login.vue +++ b/pages/login/login.vue @@ -1,48 +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" style="transform:scale(0.7)" />璁颁綇瀵嗙爜 + <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> --> @@ -50,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: '', @@ -79,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) { @@ -163,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 { @@ -177,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; - } + @import "../../colorui/icon.css"; + @import "../../colorui/animation.css"; - .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