| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <view class="main"> | 
					
						
							|  |  |  |     <view class="title"> | 
					
						
							| 
									
										
										
										
											2025-04-01 21:35:18 +08:00
										 |  |  |       {{ '会员登录' }} | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |     </view> | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |     <u-form :model="loginForm" labelWidth="auto" ref="uForm"> | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |       <view class="view-class pa"> | 
					
						
							|  |  |  |         <!-- <view class="account-s"> | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |         </view> --> | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |         <u-form-item label="" prop="username"> | 
					
						
							|  |  |  |           <u-input | 
					
						
							|  |  |  |             v-model="loginForm.username" | 
					
						
							|  |  |  |             clearable | 
					
						
							|  |  |  |             placeholder-class="place-class" | 
					
						
							|  |  |  |             class="border-color" | 
					
						
							|  |  |  |             :placeholder="'会员账号'" | 
					
						
							|  |  |  |           > | 
					
						
							|  |  |  |             <image | 
					
						
							|  |  |  |               class="tou" | 
					
						
							|  |  |  |               slot="prefix" | 
					
						
							|  |  |  |               src="../../static/images/login/index-icon4.png" | 
					
						
							|  |  |  |             ></image> | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |           </u-input> | 
					
						
							|  |  |  |         </u-form-item> | 
					
						
							|  |  |  |         <!-- <view class="close-s" | 
					
						
							|  |  |  |               v-if="loginForm.username!=''" | 
					
						
							|  |  |  |               @click="clearAccount"> | 
					
						
							|  |  |  |           <image src="../../static/images/login/index-icon3.png"></image> | 
					
						
							|  |  |  |         </view> --> | 
					
						
							|  |  |  |       </view> | 
					
						
							|  |  |  |       <view class="view-class"> | 
					
						
							|  |  |  |         <!-- <view class="account-s widths"> | 
					
						
							|  |  |  | 				<image src="../../static/images/login/index-icon2.png"></image> | 
					
						
							|  |  |  | 			</view> --> | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |         <u-form-item label="" prop="password"> | 
					
						
							|  |  |  |           <u-input | 
					
						
							|  |  |  |             placeholder-style="color:#333" | 
					
						
							|  |  |  |             :type="password" | 
					
						
							|  |  |  |             class="border-color" | 
					
						
							|  |  |  |             v-model="loginForm.password" | 
					
						
							|  |  |  |             :placeholder="'登录密码'" | 
					
						
							|  |  |  |           > | 
					
						
							|  |  |  |             <image | 
					
						
							|  |  |  |               class="mm" | 
					
						
							|  |  |  |               slot="prefix" | 
					
						
							|  |  |  |               src="../../static/images/login/index-icon2.png" | 
					
						
							|  |  |  |             ></image> | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |             <view slot="suffix"> | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |               <view | 
					
						
							|  |  |  |                 v-if="password == 'text'" | 
					
						
							|  |  |  |                 @click="changeFlagTap('password')" | 
					
						
							|  |  |  |               > | 
					
						
							|  |  |  |                 <image | 
					
						
							|  |  |  |                   class="eye" | 
					
						
							|  |  |  |                   src="../../static/images/login/icon1.png" | 
					
						
							|  |  |  |                 ></image> | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |               </view> | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |               <view v-else @click="changeFlagTap('text')"> | 
					
						
							|  |  |  |                 <image | 
					
						
							|  |  |  |                   class="eye" | 
					
						
							|  |  |  |                   src="../../static/images/login/icon2.png" | 
					
						
							|  |  |  |                 ></image> | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |               </view> | 
					
						
							|  |  |  |             </view> | 
					
						
							|  |  |  |           </u-input> | 
					
						
							|  |  |  |         </u-form-item> | 
					
						
							|  |  |  |       </view> | 
					
						
							|  |  |  |       <view class="view-class"> | 
					
						
							|  |  |  |         <!-- <view class="account-s yzm"> | 
					
						
							|  |  |  | 		  	<image src="../../static/images/login/index-icon1.png"></image> | 
					
						
							|  |  |  | 		  </view> --> | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |         <u-form-item label="" prop="code"> | 
					
						
							|  |  |  |           <u-input | 
					
						
							|  |  |  |             v-model="loginForm.code" | 
					
						
							|  |  |  |             placeholder-class="place-class" | 
					
						
							|  |  |  |             class="border-color" | 
					
						
							|  |  |  |             :placeholder="'验证码'" | 
					
						
							|  |  |  |           > | 
					
						
							|  |  |  |             <image | 
					
						
							|  |  |  |               class="mm" | 
					
						
							|  |  |  |               slot="prefix" | 
					
						
							|  |  |  |               src="../../static/images/login/index-icon1.png" | 
					
						
							|  |  |  |             ></image> | 
					
						
							|  |  |  |             <img | 
					
						
							|  |  |  |               :src="codeUrl" | 
					
						
							|  |  |  |               slot="suffix" | 
					
						
							|  |  |  |               style="height: 38px" | 
					
						
							|  |  |  |               @click="getVerifyCode" | 
					
						
							|  |  |  |             /> | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |           </u-input> | 
					
						
							|  |  |  |         </u-form-item> | 
					
						
							|  |  |  |       </view> | 
					
						
							|  |  |  |     </u-form> | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |     <u-button | 
					
						
							|  |  |  |       type="success" | 
					
						
							|  |  |  |       shape="circle" | 
					
						
							|  |  |  |       class="btn" | 
					
						
							|  |  |  |       :loading="isLoading" | 
					
						
							|  |  |  |       :loadingText="'登录中'" | 
					
						
							|  |  |  |       @click="toLogin" | 
					
						
							|  |  |  |       >{{ '登录' }}</u-button | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |     <view class="paswwrod_btn" @click="submit">{{ '忘记密码' }}</view> | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |   </view> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | import * as api from '@/config/login.js' | 
					
						
							|  |  |  | import { setToken } from '@/config/auth.js' | 
					
						
							|  |  |  | import store from '@/store' | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       password: 'password', | 
					
						
							|  |  |  |       index: 0, | 
					
						
							|  |  |  |       getList: [], | 
					
						
							|  |  |  |       changeFlag: true, | 
					
						
							|  |  |  |       isLoading: false, | 
					
						
							|  |  |  |       loginForm: { | 
					
						
							|  |  |  |         username: '', | 
					
						
							|  |  |  |         password: '', | 
					
						
							|  |  |  |         code: '', | 
					
						
							|  |  |  |         uuid: '', | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       codeUrl: '', | 
					
						
							|  |  |  |       getLanguageList: [], | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   onLoad() { | 
					
						
							|  |  |  |     this.getVerifyCode() | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |     this.loginForm.username = uni.getStorageSync('username') || '' | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |     // this.getLanguage()
 | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							|  |  |  |     changeFlagTap(text) { | 
					
						
							|  |  |  |       this.password = text | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     submit() { | 
					
						
							|  |  |  |       uni.navigateTo({ | 
					
						
							|  |  |  |         url: '/pages/forgetPassword/index', | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     bindPickerChange(e) { | 
					
						
							|  |  |  |       this.index = e.detail.value | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     clearAccount() { | 
					
						
							|  |  |  |       this.loginForm.username = '' | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     getVerifyCode() { | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |       api.captchaImage().then(res => { | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |         this.codeUrl = 'data:image/gif;base64,' + res.img | 
					
						
							|  |  |  |         this.loginForm.uuid = res.uuid | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     toLogin() { | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |       api.login(this.loginForm).then(res => { | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |         this.isLoading = false | 
					
						
							|  |  |  |         if (!res) { | 
					
						
							|  |  |  |           // uni.showToast({
 | 
					
						
							|  |  |  |           //   title: res.msg,
 | 
					
						
							|  |  |  |           //   icon: 'none',
 | 
					
						
							|  |  |  |           //   duration: 1500,
 | 
					
						
							|  |  |  |           // })
 | 
					
						
							|  |  |  |           this.getVerifyCode() | 
					
						
							|  |  |  |         } else if (res.code == 500) { | 
					
						
							|  |  |  |           this.getVerifyCode() | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |           uni.setStorageSync('username', this.loginForm.username) | 
					
						
							| 
									
										
										
										
											2025-04-11 11:10:38 +08:00
										 |  |  |           setToken(res.data.access_token) | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |           this.getUseInfo() | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     urlToBase64(url) { | 
					
						
							|  |  |  |       return new Promise((resolve, reject) => { | 
					
						
							|  |  |  |         uni.request({ | 
					
						
							|  |  |  |           url: url, | 
					
						
							|  |  |  |           method: 'GET', | 
					
						
							|  |  |  |           responseType: 'arraybuffer', | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |           success: res => {}, | 
					
						
							|  |  |  |           fail: err => { | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |             reject(err) | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     getUseInfo() { | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |       store.dispatch('GetInfo').then(res => { | 
					
						
							| 
									
										
										
										
											2025-04-07 16:42:52 +08:00
										 |  |  |         uni.switchTab({ url: '/pages/index/index' }) | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |       }) | 
					
						
							|  |  |  |       // api.getInfo().then((res) => {
 | 
					
						
							|  |  |  |       //   uni.setStorage('User', res.data)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // })
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | page, | 
					
						
							|  |  |  | body { | 
					
						
							|  |  |  |   background-color: #fff !important; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | ::placeholder { | 
					
						
							|  |  |  |   color: #333; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .style-s { | 
					
						
							|  |  |  |   height: 68rpx; | 
					
						
							|  |  |  |   margin-left: 40rpx !important; | 
					
						
							|  |  |  |   color: #333; | 
					
						
							|  |  |  |   font-size: 28rpx; | 
					
						
							|  |  |  |   border: none !important; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   outline: none; | 
					
						
							|  |  |  |   -webkit-appearance: button; | 
					
						
							|  |  |  |   -webkit-appearance: none; | 
					
						
							|  |  |  |   border-radius: 0; | 
					
						
							|  |  |  |   background: none; | 
					
						
							|  |  |  |   border: none; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .select-text { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .selIcon { | 
					
						
							|  |  |  |   width: 40rpx; | 
					
						
							|  |  |  |   height: 40rpx; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .changeLanguages { | 
					
						
							|  |  |  |   position: absolute; | 
					
						
							|  |  |  |   right: 30rpx; | 
					
						
							|  |  |  |   top: 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .paswwrod_btn { | 
					
						
							|  |  |  |   color: #666666; | 
					
						
							|  |  |  |   font-size: 26rpx; | 
					
						
							|  |  |  |   margin: 40rpx auto; | 
					
						
							|  |  |  |   text-align: center; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .btn { | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  |   background-color: #005bac; | 
					
						
							| 
									
										
										
										
											2025-03-23 09:29:40 +08:00
										 |  |  |   border: none; | 
					
						
							|  |  |  |   height: 92rpx; | 
					
						
							|  |  |  |   line-height: 92rpx; | 
					
						
							|  |  |  |   font-size: 36rpx; | 
					
						
							|  |  |  |   margin: 110rpx auto 0 auto; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .close-s { | 
					
						
							|  |  |  |   position: absolute; | 
					
						
							|  |  |  |   top: 35rpx; | 
					
						
							|  |  |  |   right: 40rpx; | 
					
						
							|  |  |  |   image { | 
					
						
							|  |  |  |     width: 25rpx; | 
					
						
							|  |  |  |     height: 25rpx; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .right-s { | 
					
						
							|  |  |  |   position: absolute; | 
					
						
							|  |  |  |   top: 35rpx; | 
					
						
							|  |  |  |   right: 40rpx; | 
					
						
							|  |  |  |   image { | 
					
						
							|  |  |  |     width: 45rpx; | 
					
						
							|  |  |  |     height: 45rpx; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .place-class { | 
					
						
							|  |  |  |   color: #333 !important; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .border-color { | 
					
						
							|  |  |  |   background: none; | 
					
						
							|  |  |  |   width: 100%; | 
					
						
							|  |  |  |   border: none; | 
					
						
							|  |  |  |   // margin-left: 30rpx;
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .main { | 
					
						
							|  |  |  |   padding: 20rpx 40rpx; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .title { | 
					
						
							|  |  |  |   font-size: 52rpx; | 
					
						
							|  |  |  |   font-weight: bold; | 
					
						
							|  |  |  |   margin: 120rpx auto; | 
					
						
							|  |  |  |   text-align: center; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .view-class { | 
					
						
							|  |  |  |   // display: flex;
 | 
					
						
							|  |  |  |   background: #f2f2f2; | 
					
						
							|  |  |  |   border-radius: 46rpx; | 
					
						
							|  |  |  |   padding: 0 20rpx; | 
					
						
							|  |  |  |   // position: relative;
 | 
					
						
							|  |  |  |   margin-bottom: 30rpx; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .widths { | 
					
						
							|  |  |  |   image { | 
					
						
							|  |  |  |     width: 28rpx !important; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .yzm { | 
					
						
							|  |  |  |   image { | 
					
						
							|  |  |  |     width: 26rpx !important; | 
					
						
							|  |  |  |     height: 30rpx !important; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .account-s { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   align-items: center; | 
					
						
							|  |  |  |   // line-height: 50%;
 | 
					
						
							|  |  |  |   height: 105rpx; | 
					
						
							|  |  |  |   position: absolute; | 
					
						
							|  |  |  |   // top: 38rpx;
 | 
					
						
							|  |  |  |   image { | 
					
						
							|  |  |  |     width: 34rpx; | 
					
						
							|  |  |  |     height: 34rpx; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .tou { | 
					
						
							|  |  |  |   width: 34rpx; | 
					
						
							|  |  |  |   height: 34rpx; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .mm { | 
					
						
							|  |  |  |   width: 34rpx !important; | 
					
						
							|  |  |  |   height: 34rpx !important; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .eye { | 
					
						
							|  |  |  |   width: 45rpx !important; | 
					
						
							|  |  |  |   height: 45rpx !important; | 
					
						
							|  |  |  |   padding-top: 10px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .pa { | 
					
						
							|  |  |  |   padding: 7px 20rpx; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-09-02 13:54:39 +08:00
										 |  |  | </style> |