366 lines
466 KiB
Vue
366 lines
466 KiB
Vue
|
<template>
|
||
|
<view>
|
||
|
<view class="background">
|
||
|
<view class="front">
|
||
|
<view class="front-form">
|
||
|
<view class="logo">
|
||
|
<image src="../../static/logo.png" mode="aspectFit"></image>
|
||
|
<text class="title">新生报到系统</text>
|
||
|
</view>
|
||
|
<view class="front-form-text">
|
||
|
<!-- 账号登录 -->
|
||
|
</view>
|
||
|
<view class="front-form-input">
|
||
|
<input type="text" v-model="username" placeholder="请输入考生号">
|
||
|
</view>
|
||
|
<view class="front-form-input">
|
||
|
<input type="password" v-model="password" placeholder="请输入密码">
|
||
|
</view>
|
||
|
<view class="front-form-button">
|
||
|
<button @click="doLogin">登录</button>
|
||
|
</view>
|
||
|
<view class="front-help">
|
||
|
<text @click="toHelpPage">查看操作手册</text>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<uni-popup class="popup-check" ref="inputDialog" type="dialog">
|
||
|
<view style="background-color: white;width: 570rpx;padding:10rpx 54rpx;border-radius: 20rpx;">
|
||
|
<view class="row">
|
||
|
请输入以下信息进行账号激活
|
||
|
</view>
|
||
|
<view class="row">
|
||
|
<input v-model="actForm.SFZH" class="uni-input" focus placeholder="身份证号" />
|
||
|
</view>
|
||
|
<view class="row">
|
||
|
<input v-model="actForm.KSH" class="uni-input" focus placeholder="考生号" />
|
||
|
</view>
|
||
|
<view class="row phone">
|
||
|
<input v-model="actForm.SJH" :disabled="true" class="uni-input" focus placeholder="高考预留手机号" />
|
||
|
<button @click="editPhone" class="mini-btn" type="primary" size="mini">更换手机号</button>
|
||
|
</view>
|
||
|
<view class="row code">
|
||
|
<input v-model="actForm.code" class="uni-input" focus placeholder="手机验证码" />
|
||
|
<button @click="doSend" class="mini-btn" type="primary" :disabled="can_send"
|
||
|
size="mini">{{code_text}}</button>
|
||
|
</view>
|
||
|
<view class="row btns" style="padding: 20rpx 10rpx 20rpx 10rpx ;">
|
||
|
<button class="activate" @tap="doAct">激活</button>
|
||
|
<button class="activate" @tap="exit">退出</button>
|
||
|
</view>
|
||
|
</view>
|
||
|
</uni-popup>
|
||
|
<u-toast ref="uToast" @show="submit"></u-toast>
|
||
|
</view>
|
||
|
</template>
|
||
|
<script>
|
||
|
import {
|
||
|
isEmpty
|
||
|
} from "@/api/helpFunc.js";
|
||
|
|
||
|
import {
|
||
|
doLogin,
|
||
|
getOwnInfo,
|
||
|
getUserInfo,
|
||
|
doAct,
|
||
|
doSendMsg
|
||
|
} from "@/api/validApi.js";
|
||
|
import {
|
||
|
setInfo,
|
||
|
logOut
|
||
|
} from "@/middleware/storage.js";
|
||
|
export default {
|
||
|
data() {
|
||
|
return {
|
||
|
// imgSrc: 'https://wap.wzzyhp.com//profile/uniapp/static/bg.png',
|
||
|
username: "",
|
||
|
password: "",
|
||
|
msgType: null,
|
||
|
messageText: "",
|
||
|
submit: false,
|
||
|
code_text: "获取验证码",
|
||
|
is_send: 60,
|
||
|
can_send: false,
|
||
|
stu_no: "",
|
||
|
actForm: {
|
||
|
KSH: "",
|
||
|
SFZH: "",
|
||
|
SJH: "",
|
||
|
code: ""
|
||
|
},
|
||
|
sfzh: ""
|
||
|
}
|
||
|
},
|
||
|
onShow() {
|
||
|
//this.$refs.inputDialog.close();
|
||
|
},
|
||
|
methods: {
|
||
|
editPhone() {
|
||
|
uni.setStorageSync("ksh", this.username)
|
||
|
uni.setStorageSync("loginInfo", {
|
||
|
username: this.username,
|
||
|
password: this.password
|
||
|
});
|
||
|
uni.navigateTo({
|
||
|
url: "/pages/login/editphone"
|
||
|
})
|
||
|
},
|
||
|
exit(){
|
||
|
this.$refs.inputDialog.close();
|
||
|
},
|
||
|
async doAct() {
|
||
|
const requiredFields = {
|
||
|
SFZH: '身份证号不能为空',
|
||
|
KSH: "考生号不能为空",
|
||
|
SJH: "手机号不能为空",
|
||
|
code: '验证码不能为空'
|
||
|
};
|
||
|
//检验非空
|
||
|
const emptyField = Object.keys(requiredFields).find(field => this.actForm[field] === "");
|
||
|
if (emptyField) {
|
||
|
uni.showToast({
|
||
|
title: requiredFields[emptyField], // 显示对应字段的提示信息
|
||
|
icon: "none"
|
||
|
});
|
||
|
return;
|
||
|
}
|
||
|
this.actForm.KSH = this.username;
|
||
|
let sdata = {
|
||
|
...this.actForm
|
||
|
};
|
||
|
let res = await doAct(sdata);
|
||
|
if (res.msg == "200") {
|
||
|
this.$refs.inputDialog.close();
|
||
|
this.$refs.uToast.show({
|
||
|
type: "success",
|
||
|
message: "激活成功,请点击登录",
|
||
|
duration: 1500,
|
||
|
});
|
||
|
} else {
|
||
|
this.$refs.uToast.show({
|
||
|
type: "error",
|
||
|
message: res.msg,
|
||
|
duration: 1500,
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
|
||
|
toHelpPage(){
|
||
|
uni.navigateTo({
|
||
|
url: "/pages/help/helpword"
|
||
|
})
|
||
|
},
|
||
|
|
||
|
async doSend() {
|
||
|
let sdata = {
|
||
|
KSH: this.username,
|
||
|
SFZH: this.actForm.SFZH,
|
||
|
SJH: this.actForm.SJH
|
||
|
};
|
||
|
let res = await doSendMsg(sdata);
|
||
|
if (res.code == 200) {
|
||
|
this.$refs.uToast.show({
|
||
|
type: "success",
|
||
|
message: res.msg,
|
||
|
duration: 1500,
|
||
|
});
|
||
|
let tick = setInterval(() => {
|
||
|
this.is_send -= 1;
|
||
|
this.can_send = true;
|
||
|
this.code_text = this.is_send + "s";
|
||
|
if (this.is_send == 0) {
|
||
|
this.code_text = "获取验证码";
|
||
|
this.is_send = 60;
|
||
|
this.can_send = false;
|
||
|
clearInterval(tick);
|
||
|
}
|
||
|
}, 1000);
|
||
|
} else {
|
||
|
this.$refs.uToast.show({
|
||
|
type: "error",
|
||
|
message: res.msg,
|
||
|
duration: 1500,
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
async doLogin() {
|
||
|
if (isEmpty(this.username) || isEmpty(this.password)) {
|
||
|
this.msgType = "error"
|
||
|
this.messageText = `不能为空`;
|
||
|
uni.showToast({
|
||
|
title: "考生号或密码不能为空",
|
||
|
icon: "none"
|
||
|
});
|
||
|
// this.$refs.message.open();
|
||
|
return;
|
||
|
}
|
||
|
let sdata = {
|
||
|
username: this.username,
|
||
|
password: this.password
|
||
|
}
|
||
|
let res = await doLogin(sdata);
|
||
|
|
||
|
if (res.code != 200) {
|
||
|
this.$refs.uToast.show({
|
||
|
type: "error",
|
||
|
message: res.msg,
|
||
|
duration: 1500,
|
||
|
})
|
||
|
return;
|
||
|
} else {
|
||
|
if (res.regStatus == "0") {
|
||
|
this.$refs.inputDialog.open();
|
||
|
getOwnInfo(this.username).then(res => {
|
||
|
console.log(res);
|
||
|
this.actForm.SJH = res.data.sjh;
|
||
|
this.actForm.KSH = res.data.ksh;
|
||
|
this.sfzh = res.data.sfzh;
|
||
|
})
|
||
|
} else {
|
||
|
uni.setStorageSync("token", res.token);
|
||
|
uni.redirectTo({
|
||
|
url: "/pages/newindex/newindex"
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style scoped lang="scss">
|
||
|
.popup-check {
|
||
|
.row {
|
||
|
padding: 40rpx 5rpx 40rpx 5rpx;
|
||
|
border-bottom: 1rpx solid lightgray;
|
||
|
font-size: 40rpx;
|
||
|
&.btns{
|
||
|
display: flex;
|
||
|
button{
|
||
|
flex: 1;
|
||
|
&:last-child{
|
||
|
background-color: white;
|
||
|
color: #007AFF;
|
||
|
border: 1px solid #007AFF;
|
||
|
}
|
||
|
&:first-child{
|
||
|
margin-right: 10px;
|
||
|
flex: 3;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
&:first-child {
|
||
|
text-align: center;
|
||
|
}
|
||
|
|
||
|
&:last-child {
|
||
|
border-bottom: none;
|
||
|
}
|
||
|
|
||
|
&.phone,
|
||
|
&.code {
|
||
|
display: flex;
|
||
|
justify-content: space-between;
|
||
|
|
||
|
input {
|
||
|
flex: 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.activate {
|
||
|
background-color: #007AFF;
|
||
|
color: white;
|
||
|
margin: 20px 0;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.background {
|
||
|
position: fixed;
|
||
|
top: 0;
|
||
|
left: 0;
|
||
|
width: 100%;
|
||
|
height: 100%;
|
||
|
background: url("
|
||
|
}
|
||
|
|
||
|
.imgSrc {
|
||
|
height: 100%;
|
||
|
width: 100%;
|
||
|
}
|
||
|
|
||
|
.front {
|
||
|
width: 100%;
|
||
|
height: 100vh;
|
||
|
z-index: 1;
|
||
|
position: absolute;
|
||
|
|
||
|
.logo {
|
||
|
display: flex;
|
||
|
flex-direction: column;
|
||
|
justify-content: space-between;
|
||
|
align-items: center;
|
||
|
margin-bottom: 100rpx;
|
||
|
|
||
|
.title {
|
||
|
font-weight: bold;
|
||
|
font-size: 48rpx;
|
||
|
margin-top: 10px;
|
||
|
font-family: douyin;
|
||
|
}
|
||
|
|
||
|
image {
|
||
|
width: 200rpx;
|
||
|
height: 200rpx;
|
||
|
margin-bottom: 20rpx;
|
||
|
|
||
|
}
|
||
|
|
||
|
text {
|
||
|
color: #404040;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.front-top {
|
||
|
margin: 20rpx 80rpx 20rpx 80rpx;
|
||
|
padding-top: 180rpx;
|
||
|
}
|
||
|
|
||
|
.front-form {
|
||
|
margin: 200rpx 80rpx 20rpx 80rpx;
|
||
|
|
||
|
.front-form-text {
|
||
|
font-size: 0.8rem;
|
||
|
margin-bottom: 20rpx;
|
||
|
}
|
||
|
|
||
|
.front-form-input {
|
||
|
margin: 40rpx 0;
|
||
|
|
||
|
input {
|
||
|
border: 1px solid #DCDFE6;
|
||
|
background-color: white;
|
||
|
height: 1.5rem;
|
||
|
padding: 10px;
|
||
|
border-radius: 40rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.front-form-button {
|
||
|
margin: 80rpx 0;
|
||
|
|
||
|
button {
|
||
|
background-color: #0081FF;
|
||
|
color: white;
|
||
|
border-radius: 40rpx;
|
||
|
}
|
||
|
}
|
||
|
.front-help{
|
||
|
font-size: 0.8rem;
|
||
|
text-align: center;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</style>
|