easypay-app/pages/user/index.vue
2024-02-27 15:35:03 +08:00

1020 lines
24 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<view :data-theme="theme">
<view class="new-users copy-data">
<view class="mid" style="flex:1;overflow: hidden;">
<scroll-view scroll-y="true">
<view class="bg"></view>
<view class="head pad30">
<view class="user-card">
<view class="user-info">
<image class="avatar" :src='userInfo.avatar' v-if="userInfo.avatar && uid"
@click="goEdit()"></image>
<image v-else class="avatar" src="/static/images/f.png" mode="" @click="goEdit()">
</image>
<view class="info">
<view class="name" v-if="!isLogin" @tap="openAuto">
请点击登录
</view>
<view class="name" v-if="userInfo && uid">
{{userInfo && userInfo.nickname && uid ? userInfo.nickname : ''}}
<view class="vip" v-if="userInfo.vip">
<image :src="userInfo.vipIcon" alt="">
<view style="margin-left: 10rpx;" class="vip-txt">
{{userInfo.vipName || ''}}
</view>
</view>
</view>
<view class="num" v-if="userInfo && userInfo.phone && uid">
<view class="num-txt">{{userInfo.phone}}</view>
<view class="icon">
<image src="/static/images/edit.png" mode="" @click="goEdit()"></image>
</view>
<view class="real_name" @click="btnreal">
{{realname}}
</view>
</view>
<view class="phone" v-if="!userInfo.phone && isLogin" @tap="bindPhone">绑定手机号</view>
<!-- #ifdef APP-PLUS -->
<text class="iconfont icon-shezhi app_set" @click.stop="appUpdate()"></text>
<!-- #endif -->
</view>
</view>
<view class="num-wrapper">
<view class="num-item" @click="goMenuPage('/pages/users/user_money/index')">
<text class="num">{{userInfo.nowMoney && uid ? userInfo.nowMoney:0}}</text>
<view class="txt">余额</view>
</view>
<!-- <view class="num-item" @click="goMenuPage('/pages/users/user_integral/index')">
<text class="num">{{userInfo.integral && uid ? userInfo.integral: 0}}</text>
<view class="txt">积分</view>
</view> -->
<view class="num-item" @click="goMenuPage('/pages/users/user_coupon/index')">
<text class="num">{{userInfo.couponCount && uid ? userInfo.couponCount : 0}}</text>
<view class="txt">优惠券</view>
</view>
<view class="num-item" @click="goMenuPage('/pages/users/user_goods_collection/index')">
<text
class="num">{{userInfo.collectCount && uid ? userInfo.collectCount : 0}}</text>
<view class="txt">收藏</view>
</view>
</view>
</view>
<view class="order-wrapper">
<view class="order-hd flex">
<view class="left">订单中心</view>
<view class="right flex" @click="menusTap('/pages/users/order_list/index')">查看全部
<text class="iconfont icon-xiangyou"></text>
</view>
</view>
<view class="order-bd">
<block v-for="(item,index) in orderMenu" :key="index">
<view class="order-item" @click="menusTap(item.url)">
<view class="pic">
<text class="iconfont pic_status" :class="item.img"></text>
<text class="order-status-num" v-if="item.num > 0">{{ item.num }}</text>
</view>
<view class="txt">{{item.title}}</view>
</view>
</block>
</view>
</view>
</view>
<!-- 待还款 -->
<navigator url="/pages/users/repayment/index" class="repayment">
<view>待还款</view> <uni-text data-v-137d5072=""
class="iconfont icon-xiangyou"><span></span></uni-text>
</navigator>
<view class="contenBox" id="pageIndex">
<!-- 轮播 -->
<view class="slider-wrapper" @click.native="bindEdit('userBanner')"
v-if="imgUrls != null && imgUrls.length > 0">
<swiper v-if="imgUrls.length>0" indicator-dots="true" :autoplay="autoplay"
:circular="circular" :interval="interval" :duration="duration"
indicator-color="rgba(255,255,255,0.6)" indicator-active-color="#fff">
<block v-for="(item,index) in imgUrls" :key="index">
<swiper-item class="borRadius14">
<image :src="item.pic" class="slide-image" @click="navito(item.url)"></image>
</swiper-item>
</block>
</swiper>
</view>
<!-- 会员菜单 -->
<view class="user-menus" style="margin-top: 20rpx;" @click.native="bindEdit('userMenus')">
<view class="menu-title">我的服务</view>
<view class="list-box">
<block v-for="(item,index) in MyMenus" :key="index"
v-if="item.id != 1751 && item.id != 1754 && item.id !=1752 &&item.id !=1744">
<view class="item" @click="menusTap(item.url)"
v-if="!(item.url =='/pages/service/index' || (item.url =='/pages/users/user_spread_user/index' && !userInfo.isPromoter))">
<image :src="item.pic"></image>
<text>{{item.name}}</text>
</view>
</block>
<!-- #ifndef MP -->
<!-- <view class="item" @click="onClickService">
<image :src="servicePic"></image>
<text>联系客服</text>
</view> -->
<!-- #endif -->
<!-- #ifdef MP -->
<!-- v-if="chatConfig.telephone_service_switch" -->
<!-- <button class="item" hover-class='none' @click="onClickService"
v-if="chatConfig.telephone_service_switch === '1'">
<image :src="servicePic"></image>
<text>联系客服</text>
</button>
<button class="item" open-type='contact' hover-class='none' v-else>
<image :src="servicePic"></image>
<text>联系客服</text>
</button> -->
<!-- #endif -->
</view>
</view>
<image :src="copyImage" alt="" class='support'>
</view>
</scroll-view>
</view>
</view>
</view>
</template>
<script>
import{
getidentity
}from '@/api/myapi.js';
let sysHeight = uni.getSystemInfoSync().statusBarHeight + 'px';
import Cache from '@/utils/cache';
import {
goPage
} from '@/libs/iframe.js'
import {
BACK_URL
} from '@/config/cache';
import {
getMenuList,
copyrightApi,
getUserInfo
} from '@/api/user.js';
import {
orderData,
sendwxcodes
} from '@/api/order.js';
import {
getCity,
tokenIsExistApi
} from '@/api/api.js';
import {
toLogin
} from '@/libs/login.js';
import {
mapGetters
} from "vuex";
import {
getCityList
} from "@/utils";
// #ifdef H5
import Auth from '@/libs/wechat';
// #endif
import {
getShare
} from '@/api/public.js';
import {
setThemeColor
} from '@/utils/setTheme.js'
import animationType from '@/utils/animationType.js'
const app = getApp();
export default {
computed: mapGetters(['isLogin', 'chatUrl', 'uid']),
data() {
return {
orderMenu: [{
img: 'icon-daifukuan',
title: '审核中',
url: '/pages/users/order_list/index?status=6',
num: 0
},
{
img: 'icon-a-shouhoutuikuan',
title: '待签约',
url: '/pages/users/order_list/index?status=7',
num: 0
},
{
img: 'icon-daifahuo',
title: '待发货',
url: '/pages/users/order_list/index?status=2',
num: 0
},
{
img: 'icon-daishouhuo',
title: '使用中',
url: '/pages/users/order_list/index?status=8',
num: 0
},
{
img: 'icon-daipingjia',
title: '已完成',
url: '/pages/users/order_list/index?status=4',
num: 0
},
// {img: 'icon-a-shouhoutuikuan',title: '已完成',url: '/pages/users/user_return_list/index',num: 0},
],
imgUrls: [],
userMenu: [],
autoplay: true,
circular: true,
interval: 3000,
duration: 500,
isAuto: false, //没有授权的不会自动授权
isShowAuth: false, //是否隐藏授权
orderStatusNum: {},
MyMenus: [],
wechatUrl: [],
realname:'未实名',
servicePic: '/static/images/customer.png',
sysHeight: sysHeight,
// #ifdef MP
pageHeight: '100%',
// #endif
// #ifdef H5 || APP-PLUS
pageHeight: app.globalData.windowHeight,
// #endif
// #ifdef H5
isWeixin: Auth.isWeixin(),
//#endif
configApi: {}, //分享类容配置
theme: '',
bgColor: '#e93323',
chatConfig: {
consumer_hotline: '',
telephone_service_switch: '0'
}, //客服配置
userInfo: {},
copyImage: '', //版权图片
identification:{}
}
},
onLoad() {
app.globalData.theme = this.$Cache.get('theme')
if (app.globalData.isIframe) {
setTimeout(() => {
let active;
document.getElementById('pageIndex').children.forEach(dom => {
dom.addEventListener('click', (e) => {
e.stopPropagation();
e.preventDefault();
if (dom === active) return;
dom.classList.add('borderShow');
active && active.classList.remove('borderShow');
active = dom;
})
})
});
}
let that = this;
// #ifdef H5 || APP-PLUS
that.$set(that, 'pageHeight', app.globalData.windowHeight);
// #endif
that.$set(that, 'MyMenus', app.globalData.MyMenus);
that.$set(that, 'chatConfig', Cache.getItem('chatConfig'));
// #ifdef H5
that.shareApi();
// #endif
that.bgColor = setThemeColor();
// #ifdef APP-PLUS
setTimeout(() => {
uni.setNavigationBarColor({
frontColor: '#ffffff',
backgroundColor: that.bgColor,
});
}, 500)
// #endif
// #ifdef MP
uni.setNavigationBarColor({
frontColor: '#ffffff',
backgroundColor: that.bgColor,
});
// #endif
},
onShow: function() {
// 调用查询是否实名
this.getidentityq()
this.getTokenIsExist();
this.copyrightImage();
this.theme = this.$Cache.get('theme')
app.globalData.theme = this.$Cache.get('theme')
if (!this.$Cache.getItem('cityList')) getCityList();
uni.showTabBar();
// #ifdef H5
let that = this;
uni.getSystemInfo({
success: function(res) {
that.pageHeight = res.windowHeight + 'px'
}
});
let currentUrl = window.location.href;
// 解析URL提取参数
let urlParams = new URLSearchParams(currentUrl);
// 获取名为code的参数的值
let codeValue = urlParams.get('code');
console.log(currentUrl,'codeValuecodeValuecodeValue');
if(codeValue){
console.log('进入判断2');
uni.setStorageSync('openid', codeValue);
let stause= uni.getStorageSync('loginstause');
console.log(stause,'stausestause');
if(uni.getStorageSync('loginstause')){
console.log('进入判断3');
}else{
if(uni.getStorageSync('loginopen')){
uni.navigateTo({
url:'/pages/users/logins/index'
})
}else{
this.sendwxcode(codeValue)
}
console.log('进入判断4');
// uni.navigateTo({
// url:'/pages/users/login/index'
// })
}
}else{
}
// 判断id是否存在
// 打印code的值
// #endif
// #ifdef MP
let query = uni.createSelectorQuery();
let dom = query.select('.new-users');
// #endif
},
methods: {
sendwxcode(code){
let data={
spread_spid: '',
code: code,
channel_id:''
}
console.log(code,'wxcodewxcodewxcodewxcode');
// sendwxcodes(code).then(res => {
// console.log('wxcodewxcodewxcodewxcode');
// //
// })
uni.request({
url: 'https://yruibao.com/prod/api/front/login/wxpublic',
// url: 'http://192.168.2.26:20411/api/front/login/wxpublic', //仅为示例,并非真实接口地址。
data: data,
method:'POST',
success: (res) => {
console.log(res.data);
if(res.data.data.isBandPhone==false){
console.log('调换 aaaaaaaaaa');
uni.setStorageSync('loginopen', res.data.data.openid);
uni.navigateTo({
url:'/pages/users/logins/index'
})
}else{
console.log(res.data.data.token,'');
this.$store.commit("LOGIN", {
'token': res.data.data.token
});
// uni.switchTab({
// url:'/pages/index/index'
// })
let login = true
uni.setStorageSync('loginstause',login);
let data = res.data.data;
this.getUserInfo(data)
}
// this.text = 'request success';
}
});
},
getUserInfo(data){
console.log(data,'dadadada');
this.$store.commit("SETUID", data.uid);
getUserInfo().then(res => {
this.$store.commit("UPDATE_USERINFO", res.data);
console.log('成功登录了');
this.$forceUpdate()
let backUrl = this.$Cache.get(BACK_URL) || "/pages/index/index";
if (backUrl.indexOf('/pages/users/login/index') !== -1) {
backUrl = '/pages/index/index';
}
uni.reLaunch({
url: backUrl
});
})
},
// 查询是否进行过身份保存
getidentityq:function(){
let data = {
uid: this.$store.getters.uid
}
getidentity(data).then(res=>{
if (res.message == '操作成功' && res.data != '') {
this.realname = '已实名'
this.identification = res.data
}
})
},
// 点击跳转到身份信息
btnreal(){
uni.navigateTo({
url: '/pages/users/order_improves/index?identification=' + JSON.stringify(this.identification),
})
},
//校验token是否有效,true为有效false为无效
getTokenIsExist(){
tokenIsExistApi().then(res => {
let tokenIsExist = res.data;
if (this.isLogin && tokenIsExist) {
this.getMyMenus();
this.getOrderData();
this.$store.dispatch('USERINFO').then(res => {
this.userInfo = res;
});
} else {
this.$store.commit("LOGOUT");
this.$store.commit('UPDATE_LOGIN', '');
this.$store.commit('UPDATE_USERINFO', {});
}
})
},
//获取授权图片
copyrightImage(){
copyrightApi().then(res => {
if (res.data) {
this.copyImage = res.data.companyImage;
} else {
this.copyImage = '/static/images/support.png';
}
}).catch(err => {
return this.$util.Tips({
title: err
})
});
},
bindEdit(name) {
if (app.globalData.isIframe) {
window.parent.postMessage({
name: name
},
'*'
);
return;
}
},
menusTap(url) {
if (!this.isLogin) {
this.openAuto();
} else {
goPage().then(res => {
uni.navigateTo({
animationType: animationType.type,
animationDuration: animationType.duration,
url: url
})
})
}
},
navito(url) {
if (url.indexOf("http") !== -1) {
// #ifdef H5
location.href = url
// #endif
// #ifdef APP-PLUS || MP
uni.navigateTo({
url: '/pages/users/web_page/index?webUel=' + url
})
// #endif
} else {
if (['/pages/goods_cate/goods_cate', '/pages/order_addcart/order_addcart', '/pages/user/index']
.indexOf(url) == -1) {
uni.navigateTo({
url: url
})
} else {
uni.switchTab({
url: url
})
}
}
},
onClickService() {
if (this.chatConfig.telephone_service_switch === '1') {
uni.makePhoneCall({
phoneNumber: this.chatConfig.consumer_hotline //仅为示例
});
} else {
// #ifdef APP-PLUS
uni.navigateTo({
animationType: animationType.type,
animationDuration: animationType.duration,
url: '/pages/users/web_page/index?webUel=' + this.chatUrl + '&title=客服'
})
// #endif
// #ifndef APP-PLUS
if (!app.globalData.isIframe) {
location.href = this.chatUrl;
} else {
return false
}
// #endif
}
},
getOrderData() {
let that = this;
orderData().then(res => {
that.orderMenu.forEach((item, index) => {
switch (item.title) {
case '审核中':
item.num = res.data.notAuditCount
break
case '待签约':
item.num = res.data.unsignedCount
break
case '待发货':
item.num = res.data.receivedCount
break
case '使用中':
item.num = res.data.inUseCount
break
case '已完成':
item.num = res.data.completeCount
break
}
})
that.$set(that, 'orderMenu', that.orderMenu);
})
},
// 打开授权
openAuto() {
Cache.set(BACK_URL, '')
toLogin();
},
// 绑定手机
bindPhone() {
uni.navigateTo({
animationType: animationType.type,
animationDuration: animationType.duration,
url: '/pages/users/app_login/index'
})
},
/**
*
* 获取个人中心图标
*/
getMyMenus: function() {
let that = this;
// if (this.MyMenus.length) return;
getMenuList().then(res => {
that.$set(that, 'MyMenus', res.data.routine_my_menus);
// console.log(this.MyMenus,11)
that.wechatUrl = res.data.routine_my_menus.filter((item) => {
return item.url.indexOf('service') !== -1
})
res.data.routine_my_menus.map((item) => {
if (item.url.indexOf('service') !== -1) that.servicePic = item.pic
})
if (res.data.routine_my_banner) {
that.imgUrls = res.data.routine_my_banner
}
});
},
// 编辑页面
goEdit() {
if (this.isLogin == false) {
this.openAuto();
} else {
uni.navigateTo({
animationType: animationType.type,
animationDuration: animationType.duration,
url: '/pages/users/user_info/index'
})
}
},
goMenuPage(url) {
if (this.isLogin) {
uni.navigateTo({
animationType: animationType.type,
animationDuration: animationType.duration,
url
})
} else {
// #ifdef MP
this.openAuto()
// #endif
}
},
appUpdate() {
uni.navigateTo({
url: '/pages/users/app_update/app_update',
animationType: animationType.type,
animationDuration: animationType.duration,
})
},
shareApi: function() {
getShare().then(res => {
this.$set(this, 'configApi', res.data);
// #ifdef H5
this.setOpenShare(res.data);
// #endif
})
},
// 微信分享;
setOpenShare: function(data) {
let that = this;
if (that.$wechat.isWeixin()) {
let configAppMessage = {
desc: data.synopsis,
title: data.title,
link: location.href,
imgUrl: data.img
};
that.$wechat.wechatEvevt(["updateAppMessageShareData", "updateTimelineShareData"],
configAppMessage);
}
}
}
}
</script>
<style lang="scss" scoped>
// 实名样式
.real_name{
margin-left: 20rpx;
width: 100rpx;
text-align: center;
background: rgba(0, 0, 0, 0.2);
padding: 10rpx;
box-sizing: border-box;
border-radius: 20rpx;
font-size: 12px;
color: #fff;
position: absolute;
top: -10rpx;
right: 0;
}
page,
body {
height: 100%;
}
.mp-header {
@include main_bg_color(theme);
}
.bg {
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 420rpx;
background-image: url('~@/static/images/user_bg.png');
background-repeat: no-repeat;
background-size: 100% 100%;
}
.contenBox {
padding: 0 30rpx 100rpx 30rpx;
}
.support {
width: 219rpx;
height: 74rpx;
margin: 54rpx auto;
display: block;
}
.new-users {
display: flex;
flex-direction: column;
height: 100%;
.sys-head {
position: relative;
width: 100%;
background: linear-gradient(90deg, $bg-star1 0%, $bg-end1 100%);
.sys-title {
z-index: 10;
position: relative;
height: 43px;
text-align: center;
line-height: 43px;
font-size: 36rpx;
color: #FFFFFF;
}
}
.head {
@include index-gradient(theme);
.user-card {
position: relative;
width: 100%;
margin: 0 auto;
padding: 35rpx 0 30rpx 0;
.user-info {
z-index: 20;
position: relative;
display: flex;
.avatar {
width: 120rpx;
height: 120rpx;
border-radius: 50%;
}
.info {
flex: 1;
display: flex;
flex-direction: column;
justify-content: space-between;
margin-left: 20rpx;
padding: 15rpx 0;
position: relative;
.name {
display: flex;
align-items: center;
color: #fff;
font-size: 31rpx;
.vip {
display: flex;
align-items: center;
padding: 6rpx 20rpx;
background: rgba(0, 0, 0, 0.2);
border-radius: 18px;
font-size: 20rpx;
margin-left: 12rpx;
image {
width: 27rpx;
height: 27rpx;
}
}
}
.app_set {
position: absolute;
font-size: 36rpx;
color: #fff;
top: 40rpx;
right: 20rpx;
}
.num {
display: flex;
align-items: center;
font-size: 26rpx;
color: rgba(255, 255, 255, 0.6);
position: relative;
image {
width: 22rpx;
height: 23rpx;
margin-left: 20rpx;
}
}
}
}
.num-wrapper {
z-index: 30;
position: relative;
display: flex;
align-items: center;
justify-content: space-between;
margin-top: 30rpx;
color: #fff;
.num-item {
width: 33.33%;
text-align: center;
.num {
font-size: 42rpx;
font-weight: bold;
}
.txt {
margin-top: 10rpx;
font-size: 26rpx;
color: rgba(255, 255, 255, 0.6);
}
}
}
.sign {
z-index: 200;
position: absolute;
right: -12rpx;
top: 80rpx;
display: flex;
align-items: center;
justify-content: center;
width: 120rpx;
height: 60rpx;
background: linear-gradient(90deg, rgba(255, 225, 87, 1) 0%, rgba(238, 193, 15, 1) 100%);
border-radius: 29rpx 4rpx 4rpx 29rpx;
color: #282828;
font-size: 28rpx;
font-weight: bold;
}
}
.order-wrapper {
background-color: #fff;
border-radius: 14rpx;
padding: 30rpx 16rpx;
position: relative;
z-index: 11;
.order-hd {
justify-content: space-between;
font-size: 30rpx;
color: #282828;
margin-bottom: 40rpx;
padding: 0 16rpx;
.left {
color: #282828;
font-size: 30rpx;
font-weight: 600;
}
.right {
align-items: center;
color: #666666;
font-size: 26rpx;
.icon-xiangyou {
margin-left: 5rpx;
font-size: 24rpx;
}
}
}
.order-bd {
display: flex;
justify-content: space-between;
padding: 0;
.order-item {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
.pic {
position: relative;
text-align: center;
image {
width: 48rpx;
height: 48rpx;
}
}
.txt {
margin-top: 15rpx;
font-size: 26rpx;
color: #454545;
}
}
}
}
}
.slider-wrapper {
margin: 20rpx 0;
height: 138rpx;
swiper,
swiper-item {
height: 100%;
}
image {
width: 100%;
height: 100%;
}
}
.user-menus {
background-color: #fff;
border-radius: 14rpx;
.menu-title {
padding: 30rpx 30rpx 40rpx;
font-size: 30rpx;
color: #282828;
font-weight: 600;
}
.list-box {
display: flex;
flex-wrap: wrap;
padding: 0;
}
.item {
position: relative;
display: flex;
align-items: center;
justify-content: space-between;
flex-direction: column;
width: 25%;
margin-bottom: 47rpx;
font-size: 26rpx;
color: #333333;
image {
width: 52rpx;
height: 52rpx;
margin-bottom: 18rpx;
}
&:last-child::before {
display: none;
}
}
button {
font-size: 28rpx;
}
}
.phone {
color: #fff;
}
.pic_status {
font-size: 43rpx;
@include main_color(theme);
}
.order-status-num {
min-width: 13rpx;
background-color: #fff;
@include main_color(theme);
border-radius: 15px;
position: absolute;
right: -14rpx;
top: -15rpx;
font-size: 20rpx;
padding: 0 8rpx;
@include coupons_border_color(theme);
}
}
.sub_btn {
width: 690rpx;
height: 86rpx;
line-height: 86rpx;
margin-top: 60rpx;
background: $theme-color;
border-radius: 43rpx;
color: #fff;
font-size: 28rpx;
text-align: center;
}
// 待还款
.repayment {
display: flex;
justify-content: space-between;
margin: 0 34rpx;
margin-top: 20rpx;
box-sizing: border-box;
height: 96rpx;
line-height: 96rpx;
box-sizing: border-box;
background-color: #fff;
padding: 0 36rpx;
border-radius: 20rpx;
}
</style>