You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

198 lines
520 KiB

9 months ago
<template>
<view class="logo">
<image src="../../static/img/logo-one.png" mode="" class="logo-one"></image>
<view class="form">
<view class="userName-form">
<input placeholder="请输入用户名" class="userName" @input="inputHandle('account',$event)"
:value="dataForm.account" />
<image src="../../static/img/user.png" mode="" class="user-icon"></image>
<uni-icons type="clear" size="25" color="#717171" class="clear-icon" @click="clearInput('account')"
v-show="dataForm.account.length > 0"></uni-icons>
</view>
<view class="password-form">
<input placeholder="请输入密码" class="password" @input="inputHandle('password',$event)"
:value="dataForm.password" />
<image src="../../static/img/password.png" mode="" class="password-icon"></image>
<uni-icons type="clear" size="25" color="#717171" class="clear-icon" @click="clearInput('password')"
v-show="dataForm.password.length > 0"></uni-icons>
</view>
</view>
<view class="logo-button" @click="logoClick"> </view>
<uni-popup ref="alertDialog" type="dialog">
<uni-popup-dialog type="warn" confirmText="确定" title="提示" :content="messageText"></uni-popup-dialog>
</uni-popup>
<!-- <view class="webViewClass" style="height: 50vh;">
<web-view ref="webViewRef" @onPostMessage="messageData" v-if="webViewShow" :src="url" :fullscreen="false"
:webview-styles="webviewStyles" @load="pageLoadSuccess"></web-view>
</view> -->
</view>
</template>
<script>
import crypto from '@/utils/crypto.js'
export default {
data() {
return {
webViewShow:true,
webviewStyles: {
width: '200px',
height: '200px',
left:'100px',
// top:'-10000px'
top:'70px'
},
url:`${this.$portAdress.baseURL}?pdaTransfer`,
dataForm: {
account: '',
password: '',
captcha: 'hm',
uuid: 123456,
},
messageText: ''
}
},
mounted() {
},
methods: {
inputHandle(text, val) {
this.dataForm[text] = val.target.value
},
clearInput(text) {
this.dataForm[text] = ''
},
async logoClick() {
// console.log('11111111111',this.$portAdress.logo);
this.webViewShow = false
uni.showLoading({
title: '登陆中请稍等'
})
const res = await this.$baseAPI.request(this.$portAdress.logo, this.dataForm, 'post')
console.log('res登录',res);
if (res.code === 0) {
uni.setStorageSync('token', res.data.token)
uni.setStorageSync('userInfo', JSON.stringify(res.data.currentUser))
// 加密
let account = crypto.setAES(JSON.stringify(this.dataForm.account))
let password = crypto.setAES(JSON.stringify(this.dataForm.password))
console.log('加密',account,password);
uni.setStorageSync('userLoginAccount',account)
uni.setStorageSync('userLoginPassword',password)
// -----------------------------------------------------------
// 0:等待呼叫,1:呼叫中,2:术前,3:术中,4:术后,5离开
console.log("登录");
uni.hideLoading()
this.webViewShow = true
// console.log('url',`${this.$portAdress.baseURL}?pdaTransfer?account=${this.dataForm.account}&password=${this.dataForm.password}`);
// this.url = `${this.$portAdress.baseURL}/pdaTransfer?account=liucan&password=liucan`
this.url = `${this.$portAdress.baseURL}/pdaTransfer?account=${this.dataForm.account}&password=${this.dataForm.password}`
uni.navigateTo({
url: '/pages/patientList/index'
})
} else {
uni.hideLoading()
this.messageText = res.msg
this.$refs.alertDialog.open()
}
},
// 监听的参数
messageData(e) {
console.log('接收的H5参数', JSON.stringify(e.detail)) // 接收的参数
},
pageLoadSuccess() {
console.log('加载成功');
},
}
}
</script>
<style lang="less" scoped>
.logo {
position: relative;
width: 100vw;
height: 100vh;
background-size: 100vw 100vh;
background-color: #002648;
background-image: url(
.logo-one {
position: relative;
top: 200rpx;
left: 50%;
transform: translateX(-50%);
width: 96*2rpx;
height: 86*2rpx;
}
.form {
margin: 0 48rpx;
margin-top: 400rpx;
}
.userName-form,
.password-form {
position: relative;
input {
height: 96rpx;
line-height: 96rpx;
}
}
.userName,
.password {
background-color: #fff;
height: 96rpx;
border-radius: 8rpx;
padding-left: 100rpx;
}
.password {
margin-top: 32rpx;
}
.user-icon,
.password-icon {
width: 48rpx;
height: 48rpx;
}
.user-icon,
.password-icon {
position: absolute;
left: 26rpx;
top: 50%;
transform: translateY(-50%);
}
.clear-icon {
position: absolute;
z-index: 9;
right: 20rpx;
top: 50%;
transform: translateY(-50%);
}
.logo-button {
position: absolute;
margin: 0 48rpx;
bottom: 96rpx;
height: 96rpx;
width: 90vw;
line-height: 96rpx;
background: #001e3a;
border-radius: 108rpx;
color: #fff;
text-align: center;
}
.webViewClass {
position: fixed;
// left: -999999px;
// z-index: -99999;
}
}
</style>