This commit is contained in:
Sliverber 2024-07-29 18:04:42 +08:00
parent 8fe880c588
commit 266d86da14
3 changed files with 520 additions and 33 deletions

View File

@ -22,10 +22,10 @@ const install = (Vue, vm) => {
uni.setStorageSync('deptId', 100);
Vue.prototype.$u.http.setConfig({
// baseUrl: 'http://61.174.243.28:15861',
// baseUrl: 'http://192.168.2.14:8080',
baseUrl: 'http://192.168.2.46:8080',
// baseUrl: 'http://124.221.246.124:2289',
// baseUrl: 'https://dianche.chuantewulian.cn/prod-api',
baseUrl: 'https://dche.ccttiot.com/prod-api',
// baseUrl: 'https://dche.ccttiot.com/prod-api',
loadingText: '努力加载中~',
loadingTime: 50000,
@ -52,9 +52,9 @@ const install = (Vue, vm) => {
// 方式四如果token放在了Storage本地存储中拦截是每次请求都执行的
// 所以哪怕您重新登录修改了Storage下一次的请求将会是最新值
const token = uni.getStorageSync('token');
// const token = uni.getStorageSync('token');
// const token = " eyJhbGciOiJIUzUxMiJ9.eyJsb2dpbl91c2VyX2tleSI6ImE1ZmE2YzM0LWM0Y2YtNGEwMS05YjY2LTE1M2M4YWY1YzU1YSJ9.Wze_tAjY7cCfw2K6mtDpTSd-QFLRF4A49Fx7bq7g2tVLKL4v5bqqHfpG0VQy7_a_CUQch5RPBTBIKMVCDupIqg"
const token = "Bearer eyJhbGciOiJIUzUxMiJ9.eyJsb2dpbl91c2VyX2tleSI6IjQ0ZDljYzBlLThjZjEtNGFkOC05OGFjLThlNThjMWIxYjQ3OSJ9.v-aMkp9t7Z_QfjfsZy6d_1Ng76hPYa0A--SWScMJY9to7UlNv9IxHQnTJylLKdYKGrr8fRZ47Bu12UPm1DgMQg"
// console.log("我是token", token)
config.header.Authorization = token;

View File

@ -17,8 +17,18 @@
</view>
<input type="text" class="ips" v-model="sn" placeholder="请扫描设备上的二维码" style="margin-left: 32rpx;"
placeholder-class="my-placeholder" />
</view>
<view class="iptbox" @click="show=true">
<view class="">
版本 版本id:
</view>
</view>
<view class="tips">
版本介绍
</view>
<u-select v-model="show" :list="list" title='选择运营区' @confirm="confirm"></u-select>
<view class="btn" @click="bind()">
确认添加
</view>
@ -91,8 +101,9 @@
},
sn:'',
carstause:false,
isbands:false
isbands:false,
show:false,
list:[]
@ -104,6 +115,9 @@
this.isbands=false
this.carstause=false
},
onShow() {
this.getlist()
},
onUnload: function() {
xBlufi.listenDeviceMsgEvent(false, this.funListenDeviceMsgEvent);
xBlufi.notifyStartDiscoverBle({
@ -128,6 +142,29 @@
},
methods: {
confirm(e){
// console.log(e);
uni.setStorageSync('adminAreaid', e[0].value);
this.areaId= e[0].value
},
getlist(){
this.$u.get('/app/hardwareVersion/list').then((res) => {
if (res.code === 200) {
this.list = res.data.map(item => ({
value: item.id,
label: item.version
}));
}else{
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}
})
},
send(){
this.$u.post('/app/device/ring?sn=' + this.sn).then((res) => {
if (res.code === 200) {
@ -639,6 +676,10 @@
font-size: 32rpx;
color: #FFFFFF;
}
.tips{
margin: 28rpx auto 0;
width: 658rpx;
}
.iptbox {
display: flex;
align-items: center;

View File

@ -25,13 +25,62 @@
<image src="https://lxnapi.ccttiot.com/bike/img/static/uka0jHcbyy1we0qwbiov" mode=""></image> 微信登录
</button>
<view class="button" style="margin-top: 20rpx;" @click="pageindex=1">
<image src="https://lxnapi.ccttiot.com/bike/img/static/ubSJ6aNMOUfPf80iotGv" mode=""></image>授权登录
<image src="https://lxnapi.ccttiot.com/bike/img/static/ubSJ6aNMOUfPf80iotGv" mode=""></image>手机号登录
</view>
<!-- <view class="button1" @click="back">
取消登录
</view> -->
</view>
<view class="page3" v-if="pageindex==1">
<view class="page3" v-if="pageindex == 1">
<view class="tit">
登录
</view>
<view class="tit_li" style="margin-top: 104rpx;">
<image src="https://lxnapi.ccttiot.com/bike/img/static/u3swF9YhZbUCuhGmrMrk" mode=""></image>
手机号
</view>
<view class="ipt">
<input type="number" class="ips" v-model="phone" placeholder="请输入您的手机号"
placeholder-style='font-weight: 400;font-size: 36rpx;color: #808080;' />
</view>
<view class="tit_li">
<image src="https://lxnapi.ccttiot.com/bike/img/static/ujOHD0RFCsOWAprtYLzj" mode=""
style="width: 50rpx;height: 54rpx;margin-right: 26rpx;"></image>
验证码
</view>
<view class="ipt">
<input type="number" class="ips" v-model="phoneCode" placeholder="请输入验证码"
placeholder-style='font-weight: 400;font-size: 36rpx;color: #808080;' style="width: 60%;" />
<view class="send_code" :class="{ disabled: isCodeButtonDisabled }" @click="getcode()">
{{ codeButtonText }}
</view>
</view>
<view class="tit_li">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uYkqUlpkl5VuksJhaPlW" mode=""
style="width: rpx;height: 54rpx;margin-right: 26rpx;"></image>
密码
</view>
<view class="ipt">
<input class="ips" v-model="password" placeholder="请输入密码"
placeholder-style='font-weight: 400;font-size: 36rpx;color: #808080;' />
</view>
<view class="sub_btn" @click="sub1()" :style="{ background: isSubButtonActive ? '#64B6A8' : '' }">
注册并登录
</view>
<view class="tips">
已有帐号<span @click="page2()">立即登录</span>
</view>
<view class="line_box">
<view class="lines"></view>
其他登录方式
<view class="lines"></view>
</view>
<view class="wxbtn">
<image @click="towx()" src="https://lxnapi.ccttiot.com/bike/img/static/uUCvpOwGG8McfpYSUye4" mode="">
</image>
</view>
</view>
<view class="page3" v-if="pageindex==2">
<view class="tit">
登录
</view>
@ -41,7 +90,52 @@
</view>
<view class="ipt">
<input type="number" class="ips" v-model="sn" placeholder=" 请输入您的手机号"
<input type="number" class="ips" v-model="phone1" placeholder=" 请输入您的手机号"
placeholder-style='font-weight: 400;font-size: 36rpx;color: #808080;' />
</view>
<view class="tit_li">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uYkqUlpkl5VuksJhaPlW" mode=""
style="width: rpx;height: 54rpx;margin-right: 26rpx;"></image>
密码
</view>
<view class="ipt">
<input type="number" class="ips" v-model="password1" placeholder=" 请输入密码"
placeholder-style='font-weight: 400;font-size: 36rpx;color: #808080;' />
</view>
<view class="tipss">
<view class="">
</view>
<span @click="page3">忘记密码</span>
</view>
<view class="sub_btn" :style="{ background: isSubButtonActive1 ? '#64B6A8' : '' }" @click="sub2()">
登录
</view>
<view class="tips">
没有账号<span @click="page1()">立即注册</span>
</view>
<view class="line_box">
<view class="lines"></view>
其他登录方式
<view class="lines"></view>
</view>
<view class="wxbtn">
<image @click="towx()" src="https://lxnapi.ccttiot.com/bike/img/static/uUCvpOwGG8McfpYSUye4" mode="">
</image>
</view>
</view>
<view class="page3" v-if="pageindex==3">
<view class="tit_li" style="margin-top: 104rpx;">
<image src="https://lxnapi.ccttiot.com/bike/img/static/u3swF9YhZbUCuhGmrMrk" mode=""></image>
手机号
</view>
<view class="ipt">
<input type="number" class="ips" v-model="phone2" placeholder=" 请输入您的手机号"
placeholder-style='font-weight: 400;font-size: 36rpx;color: #808080;' />
</view>
<view class="tit_li">
@ -50,38 +144,45 @@
验证码
</view>
<view class="ipt">
<input type="number" class="ips" v-model="sn" placeholder=" 请输入您的手机号"
<input type="number" class="ips" v-model="phoneCode2" placeholder="请输入验证码"
placeholder-style='font-weight: 400;font-size: 36rpx;color: #808080;' style="width: 60%;" />
<view class="send_code">
获取验证码
<view class="send_code" :class="{ disabled: isCodeButtonDisabled2 }" @click="getcode2()">
{{ codeButtonText2 }}
</view>
</view>
<view class="tit_li">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uYkqUlpkl5VuksJhaPlW" mode=""
style="width: rpx;height: 54rpx;margin-right: 26rpx;"></image>
密码
密码
</view>
<view class="ipt">
<input type="number" class="ips" v-model="sn" placeholder=" 请输入您的手机号"
<input type="number" class="ips" v-model="password2" placeholder=" 请输入新密码"
placeholder-style='font-weight: 400;font-size: 36rpx;color: #808080;' />
</view>
<view class="sub_btn">
注册并登录
<view class="tit_li" >
<image src="https://lxnapi.ccttiot.com/bike/img/static/uYkqUlpkl5VuksJhaPlW" mode=""
style="width: rpx;height: 54rpx;margin-right: 26rpx;"></image>
确认密码
</view>
<view class="tips">
已有帐号<span>立即登录</span>
<view class="ipt">
<input type="number" class="ips" v-model="subpassword2" placeholder=" 请再次输入密码"
placeholder-style='font-weight: 400;font-size: 36rpx;color: #808080;' />
</view>
<view class="line_box">
<view class="lines"></view>
其他登录方式
<view class="lines"></view>
<view class="tipss">
<view class="">
</view>
</view>
<view class="wxbtn">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uUCvpOwGG8McfpYSUye4" mode=""></image>
<view class="sub_btn" :style="{ background: isSubButtonActive2 ? '#64B6A8' : '' }" @click="sub3()">
确定
</view>
</view>
<view class="pages2" v-if="deptId==101">
<view class="imgbox">
@ -113,14 +214,338 @@
usertype: '',
login: false,
deptId: '',
pageindex: 1,
pageindex: 0,
phone: '',
phoneCode: '',
password: '',
isCodeButtonDisabled: false,
codeButtonText: '获取验证码',
countdown: 60,
uuid: '',
isSubButtonActive: false,
isSubButtonActive1: false,
isSubButtonActive2:false,
phone1:'',
password1:'',
interval:null,
phone2:'',
phoneCode2:'',
password2:'',
subpassword2:'',
isCodeButtonDisabled2: false,
codeButtonText2: '获取验证码',
countdown2: 60,
}
},
onLoad() {
this.deptId = uni.getStorageSync('deptId');
// this.deptId = 101
},
computed: {
codeButtonStyle() {
return this.isCodeButtonDisabled ? 'background: #979797;' : '';
},
},
watch: {
phone() {
this.checkInputFields();
},
phoneCode() {
this.checkInputFields();
},
password() {
this.checkInputFields();
},
phone1(){
this.checkInputFields1();
},
password1() {
this.checkInputFields1();
},
phone2(){
this.checkInputFields2();
},
phoneCode2() {
this.checkInputFields2();
},
password2(){
this.checkInputFields2();
},
subpassword2() {
this.checkInputFields2();
},
},
methods: {
page3(){
this.pageindex=3
this.phone1=''
this.password1=''
},
page1(){
// clearInterval(this.interval)
this.pageindex=1
this.phone1=''
this.password1=''
},
page2(){
// clearInterval(this.interval)
this.pageindex=2
this.phone=''
this.phoneCode=''
this.password=''
},
sub3(){
if (!this.phone2 || !this.phoneCode2|| !this.password2|| !this.subpassword2) {
uni.showToast({
title: '请完整填写信息',
icon: 'none',
duration: 2000
});
return;
}
if (!this.validatePhone(this.phone2)) {
uni.showToast({
title: '手机号格式不正确',
icon: 'none',
duration: 2000
});
return;
}
if (this.subpassword2 != this.password2) {
uni.showToast({
title: '两次密码输入不一致',
icon: 'none',
duration: 2000
});
return;
}
this.$u.put("/app/forgetAppPwd?phone="+this.phone2+'&newPassword='+this.password2+'&phoneCode='+this.phoneCode2+'&uuid='+this.uuid).then((res) => {
if (res.code == 200) {
//
this.pageindex=2
this.phone2=''
this.phoneCode2=''
this.uuid=''
this.password2=''
this.subpassword2=''
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}
});
},
//
sub2(){
if (!this.phone1 || !this.password1) {
uni.showToast({
title: '请完整填写信息',
icon: 'none',
duration: 2000
});
return;
}
if (!this.validatePhone(this.phone1)) {
uni.showToast({
title: '手机号格式不正确',
icon: 'none',
duration: 2000
});
return;
}
let areaId = uni.getStorageSync('areaId');
let data = {
phone: this.phone1,
password: this.password1,
areaId: areaId,
}
this.$u.post("/appCodeLogin", data).then((res) => {
if (res.code == 200) {
//
wx.setStorageSync('token', res.token);
this.ceshi()
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}
});
},
checkInputFields2() {
if (this.phone2&& this.phoneCode2 && this.password2&&this.subpassword2) {
this.isSubButtonActive2 = true;
} else {
this.isSubButtonActive2 = false;
}
},
checkInputFields1() {
if (this.phone1 && this.password1) {
this.isSubButtonActive1 = true;
} else {
this.isSubButtonActive1 = false;
}
},
checkInputFields() {
if (this.phone && this.phoneCode && this.password) {
this.isSubButtonActive = true;
} else {
this.isSubButtonActive = false;
}
},
validatePhone(phone) {
const phoneRegex = /^1[3-9]\d{9}$/;
return phoneRegex.test(phone);
},
getcode() {
if (this.isCodeButtonDisabled) return;
if (!this.phone) {
uni.showToast({
title: '请输入手机号',
icon: 'none',
duration: 2000
});
return;
}
if (!this.validatePhone(this.phone)) {
uni.showToast({
title: '手机号格式不正确',
icon: 'none',
duration: 2000
});
return;
}
this.isCodeButtonDisabled = true;
this.$u.get("/appCaptcha?type=1&phone=" + this.phone).then((res) => {
if (res.code == 200) {
this.uuid = res.uuid
this.startCountdown();
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
this.isCodeButtonDisabled = false;
}
});
},
getcode2() {
if (this.isCodeButtonDisabled) return;
if (!this.phone2) {
uni.showToast({
title: '请输入手机号',
icon: 'none',
duration: 2000
});
return;
}
if (!this.validatePhone(this.phone2)) {
uni.showToast({
title: '手机号格式不正确',
icon: 'none',
duration: 2000
});
return;
}
this.isCodeButtonDisabled2 = true;
this.$u.get("/appCaptcha?type=1&phone=" + this.phone2).then((res) => {
if (res.code == 200) {
this.uuid = res.uuid
this.startCountdown2();
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
this.isCodeButtonDisabled2 = false;
}
});
},
startCountdown2() {
this.codeButtonText2 = `${this.countdown}秒后重发`;
const interval = setInterval(() => {
this.countdown2--;
if (this.countdown2 <= 0) {
clearInterval(interval);
this.codeButtonText2 = '获取验证码';
this.isCodeButtonDisabled2 = false;
this.countdown2 = 60;
} else {
this.codeButtonText2 = `${this.countdown2}秒后重发`;
}
}, 1000);
},
startCountdown() {
this.codeButtonText = `${this.countdown}秒后重发`;
this.interval = setInterval(() => {
this.countdown--;
if (this.countdown <= 0) {
clearInterval(interval);
this.codeButtonText = '获取验证码';
this.isCodeButtonDisabled = false;
this.countdown = 60;
} else {
this.codeButtonText = `${this.countdown}秒后重发`;
}
}, 1000);
},
sub1() {
if (!this.phone || !this.phoneCode || !this.password) {
uni.showToast({
title: '请完整填写信息',
icon: 'none',
duration: 2000
});
return;
}
if (!this.validatePhone(this.phone)) {
uni.showToast({
title: '手机号格式不正确',
icon: 'none',
duration: 2000
});
return;
}
let areaId = uni.getStorageSync('areaId');
let data = {
phone: this.phone,
password: this.password,
areaId: areaId,
phoneCode: this.phoneCode,
uuid: this.uuid
}
this.$u.post("/appCodeLogin", data).then((res) => {
if (res.code == 200) {
//
wx.setStorageSync('token', res.token);
this.ceshi()
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}
});
},
towx() {
console.log('dianjile ');
this.pageindex = 0
},
userType(num) {
this.chooseType = false
this.login = true
@ -222,12 +647,24 @@
padding: 200rpx 60rpx 0 60rpx;
.tipss {
margin-top: 42rpx;
padding-right: 30rpx;
width: 620rpx;
display: flex;
justify-content: space-between;
font-weight: 400;
font-size: 28rpx;
color: #64B6A8;
}
.line_box {
.lines {
width: 162rpx;
height: 0rpx;
border: 1rpx solid #D8D8D8;
}
margin-top: 134rpx;
width: 620rpx;
display: flex;
@ -238,19 +675,22 @@
font-size: 32rpx;
color: #808080;
}
.wxbtn{
.wxbtn {
width: 100%;
margin-top: 30rpx;
display: flex;
align-items: center;
justify-content: center;
image{
image {
height: 64rpx;
width: 64rpx;
width: 64rpx;
}
}
.tips {
width: 258rpx;
margin: 0 auto;
@ -332,6 +772,12 @@
color: #FFFFFF;
}
.disabled {
pointer-events: none;
opacity: 0.6;
background: #979797;
}
.ips {
width: 100%;
}