436 lines
12 KiB
Vue
436 lines
12 KiB
Vue
<template style="position: relative;">
|
||
<view class="bjInfo">
|
||
<view class="cardss">
|
||
<view class="cardss-title">
|
||
<up-avatar :src="avatar" shape="circle" size="180rpx" ></up-avatar>
|
||
<image @click="toCropping" :src="upavatar2" style="width: 48rpx; height: 48rpx; position: absolute; left: 417rpx"></image>
|
||
</view>
|
||
</view>
|
||
<view class="cardz">
|
||
<view class="gridLine">
|
||
<span class="text1">用户昵称</span>
|
||
<view class="text2" @click="upNickInfo(1)">
|
||
<span v-if="nickName != ''">{{ nickName }}</span>
|
||
<span v-else>这个人很懒,什么都没有留下</span>
|
||
<image @click="upNickInfo(1)" :src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
<view class="gridLine">
|
||
<span class="text1">个人简介</span>
|
||
<view class="text2" @click="upNickInfo(2)">
|
||
<span v-if="remark != ''">{{ remark }}</span>
|
||
<span v-else>介绍一下自己吧</span>
|
||
<image @click="upNickInfo(2)" :src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
|
||
|
||
<view class="gridLine" @click="showsex = true">
|
||
<span class="text1">性别</span>
|
||
<view class="text2">
|
||
<span>{{ dictSex(sex) }}</span>
|
||
<image @click="showsex = true":src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
<view class="gridLine" @click="showyear = true">
|
||
<span class="text1">出生年月</span>
|
||
<view class="text2">
|
||
<span>{{ birthday }}</span>
|
||
<image @click="showyear = true" :src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
<view class="gridLine">
|
||
<span class="text1">地区</span>
|
||
<view class="text2">
|
||
<span>{{ area }}</span>
|
||
<image @click="showarea = true" :src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
<view class="gridLine" style="margin-bottom: 0;">
|
||
<span class="text1">背景</span>
|
||
<view class="text2">
|
||
<fileUpload v-model="fileList" limit="1" @upInfo="upInfo" pwidth="120rpx" pheight="80rpx">
|
||
<template #default-image>点击上传</template>
|
||
</fileUpload>
|
||
<image @click="show1 = true" :src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
</view>
|
||
<view class="cardx">
|
||
<view class="gridLine" v-if="auditInfo != 3">
|
||
<span class="text1">学生认证</span>
|
||
<view class="text3">
|
||
<span>未认证</span>
|
||
<image :src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
<view v-else>
|
||
<view class="gridLine" >
|
||
<span class="text1">学生认证</span>
|
||
<view class="text2">
|
||
<span>已认证</span>
|
||
<image :src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
<view class="gridLine" >
|
||
<span class="text1">学校</span>
|
||
<view class="text2">
|
||
<span>{{infoSchool}}</span>
|
||
<image :src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
<view class="gridLine" >
|
||
<span class="text1">系别</span>
|
||
<view class="text2">
|
||
<span>{{infoDepartment}}</span>
|
||
<image :src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
<view class="gridLine" >
|
||
<span class="text1">年级</span>
|
||
<view class="text2">
|
||
<span>{{infoGrade}}</span>
|
||
<image :src="right3" style="width: 18rpx; height: 30rpx; margin-left: 12rpx;">
|
||
</image>
|
||
</view>
|
||
</view>
|
||
<view class="gridLine" >
|
||
<up-image :src="QNDomain +infoDocument" width="686rpx" height="400rpx" ></up-image>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view v-if="showyear">
|
||
<up-datetime-picker
|
||
hasInput
|
||
:minDate="0"
|
||
:show="showyear"
|
||
v-model="newData"
|
||
@confirm="confirmyear"
|
||
@cancel="cancelyear"
|
||
mode="date"
|
||
></up-datetime-picker>
|
||
|
||
</view>
|
||
<view v-if="showsex">
|
||
<up-picker :show="showsex" :columns="columnssex" @cancel="showsex = false" @confirm="confirmsex" keyName="label"></up-picker>
|
||
</view>
|
||
<view v-if="showarea">
|
||
<up-picker :show="showarea" :columns="range" @cancel="showarea = false"
|
||
@confirm="confirmarea" keyName="label"></up-picker>
|
||
</view>
|
||
</template>
|
||
|
||
<script setup>
|
||
import fileUpload from '@/pages/common/file/fileUpload/index.vue'
|
||
import {updateUserinfo} from "@/api/system/userinfo"
|
||
import {updateUserProfile} from "@/api/system/user"
|
||
import { useStore } from 'vuex'
|
||
import { getUserInfo } from "@/api/login";
|
||
import { useRouter } from 'vue-router'
|
||
import { ref, getCurrentInstance,reactive } from 'vue';
|
||
import { getDicts } from "@/api/system/dict/data";
|
||
import { onShow, onLoad } from '@dcloudio/uni-app'
|
||
import image from 'uview-plus/libs/config/props/image';
|
||
import {
|
||
addressData
|
||
} from "../../signln/data";
|
||
|
||
const timeFormat = uni.$u.timeFormat;
|
||
const { proxy } = getCurrentInstance();
|
||
const newData = ref(new Date().getTime());
|
||
const QNDomain = proxy.$store.state.user.QNDomain
|
||
const dictSexInfo = ref('')
|
||
const showyear = ref(false)
|
||
const showarea = ref(false)
|
||
const showsex = ref(false)
|
||
const isOfficial = ref(true)
|
||
const iconConfig = proxy.iconConfig;
|
||
|
||
const range = ref([
|
||
[]
|
||
]);
|
||
const columnssex = reactive([
|
||
[
|
||
{
|
||
label: '男',
|
||
id: "0"
|
||
},
|
||
{
|
||
label: '女',
|
||
id: "1"
|
||
}
|
||
,
|
||
{
|
||
label: '未知',
|
||
id: "2"
|
||
}
|
||
]
|
||
]);
|
||
const right3 = iconConfig.right3;
|
||
const upavatar2 = iconConfig.upavatar2;
|
||
const auditInfo = ref(proxy.$store.state.userInfo.auditInfo)//审核状态
|
||
const avatar = ref(proxy.$store.state.user.avatar)
|
||
const name = ref(proxy.$store.state.user.name)
|
||
const nickName = ref(proxy.$store.state.user.nickName)
|
||
const sex = ref(proxy.$store.state.user.sex)
|
||
|
||
const infoSchool = ref(proxy.$store.state.userInfo.infoSchool)//学校
|
||
const backgroundImage = ref(proxy.$store.state.userInfo.backgroundImage)//背景
|
||
const remark = ref(proxy.$store.state.userInfo.remark)//签名
|
||
const area = ref(proxy.$store.state.userInfo.area)//地区
|
||
const birthday = ref(proxy.$store.state.userInfo.birthday)//生日
|
||
const birthdayInfo = ref('')
|
||
const infoDepartment = ref(proxy.$store.state.userInfo.infoDepartment)//系别
|
||
const infoGrade = ref(proxy.$store.state.userInfo.infoGrade)//年纪
|
||
const infoName = ref(proxy.$store.state.userInfo.infoName)//名字
|
||
const infoCode = ref(proxy.$store.state.userInfo.infoCode)//学号
|
||
const infoDocument = ref(proxy.$store.state.userInfo.infoDocument)//学生证
|
||
const fileList = ref([])
|
||
const form1 = ref({
|
||
userId: null,
|
||
doingsStatus: null,
|
||
newUser: null,
|
||
birthday: null,
|
||
infoName: null,
|
||
infoSchool: null,
|
||
infoDepartment: null,
|
||
infoGrade: null,
|
||
infoCode: null,
|
||
infoDocument: null,
|
||
codeDocument: null,
|
||
codeInfo: null,
|
||
backgroundImage: null,
|
||
auditInfo: null,
|
||
auditTime: null,
|
||
auditUserId: null,
|
||
area: null,
|
||
infoRank: null,
|
||
infoCoin: null,
|
||
infoActive: null,
|
||
infoAssist: null,
|
||
followCount: null,
|
||
fanCount: null,
|
||
createBy: null,
|
||
createTime: null,
|
||
updateBy: null,
|
||
updateTime: null,
|
||
remark: null
|
||
})
|
||
const form2 = ref({
|
||
|
||
nickName: undefined,
|
||
sex: undefined,
|
||
})
|
||
const gotoAuthentication = () => {
|
||
proxy.$tab.navigateTo('/pages/mine/studentCard/authentication')
|
||
}
|
||
const gotoStuCardInfo = () => {
|
||
proxy.$tab.navigateTo('/pages/mine/studentCard/stuCardInfo')
|
||
}
|
||
const toCropping = () => {
|
||
proxy.$tab.navigateTo('/pages/common/avatar/index')
|
||
}
|
||
const getImageback = () => {
|
||
fileList.value[0] = backgroundImage.value
|
||
return fileList.value;
|
||
}
|
||
const dictSex = (state) => {
|
||
// 查找匹配的字典项
|
||
const dict = dictSexInfo.value.find((dict) => dict.dictValue == state);
|
||
return dict ? dict.dictLabel : '未知状态';
|
||
}
|
||
const cancelyear = () => {
|
||
showyear.value = false
|
||
birthdayInfo.value = ''
|
||
}
|
||
//生日选择器
|
||
const confirmyear = (e) => {
|
||
showyear.value = false
|
||
birthdayInfo.value = timeFormat(e.value, 'yyyy-mm-dd');
|
||
if(birthdayInfo.value == ''){
|
||
proxy.$modal.msgError('信息不能为空');
|
||
}else{
|
||
form1.value.birthday = birthdayInfo.value;
|
||
proxy.$modal.loading('正在提交数据,请稍候...');
|
||
upbirthday();
|
||
}
|
||
}
|
||
const upbirthday = () => {
|
||
updateUserinfo(form1.value).then( e=> {
|
||
proxy.$modal.closeLoading();
|
||
proxy.$modal.msgSuccess("修改成功");
|
||
birthday.value = form1.value.birthday
|
||
proxy.$store.commit("SET_BIRTHDAY",form1.value.birthday)
|
||
})
|
||
}
|
||
//性别选择器
|
||
const closesex = () => {
|
||
showsex.value = false;
|
||
}
|
||
const confirmsex = (e) => {
|
||
form2.value.sex = e.indexs[0];
|
||
|
||
showsex.value = false;
|
||
proxy.$modal.loading('正在提交数据,请稍候...');
|
||
upsex();
|
||
|
||
}
|
||
const upsex =() => {
|
||
updateUserProfile(form2.value).then( e=> {
|
||
proxy.$modal.closeLoading();
|
||
proxy.$modal.msgSuccess("修改成功");
|
||
sex.value = form2.value.sex
|
||
proxy.$store.commit("SET_SEX",form2.value.sex)
|
||
uni.setStorageSync("SET_SEX",form2.value.sex)
|
||
})
|
||
}
|
||
|
||
onLoad((options) => {
|
||
initRange();
|
||
getDicts('sys_user_sex').then(e => {
|
||
dictSexInfo.value = e.data
|
||
})
|
||
|
||
getImageback()
|
||
})
|
||
const upNickInfo = (e) => {
|
||
proxy.$tab.navigateTo('/pages/mine/info/upInfo?type='+e)
|
||
|
||
}
|
||
const initRange = async () => {
|
||
const provinces = addressData.map(province => province.name);
|
||
range.value = [provinces];
|
||
};
|
||
|
||
const confirmarea = (e) => {
|
||
form1.value.area = e.value[0]
|
||
area.value = e.value[0]
|
||
proxy.$store.commit("SET_area",e.value[0])
|
||
updateUserinfo(form1.value).then( e=> {
|
||
proxy.$modal.msgSuccess("修改成功");
|
||
area.value = e.value[0]
|
||
proxy.$store.commit("SET_area",e.value[0])
|
||
})
|
||
showarea.value = false
|
||
}
|
||
const upInfo = (e) =>{
|
||
form1.value.backgroundImage = e;
|
||
updateUserinfo(form1.value).then( er=> {
|
||
|
||
backgroundImage.value = e
|
||
uni.setStorageSync("SET_backgroundImage",e)
|
||
proxy.$store.commit("SET_backgroundImage",e)
|
||
proxy.$modal.msgSuccess("修改成功");
|
||
})
|
||
}
|
||
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
page {
|
||
background-color: #F4F5F6;
|
||
}
|
||
|
||
.bjInfo {
|
||
background-color: #ffffff;
|
||
width: 100%;
|
||
height: 912rpx;
|
||
}
|
||
|
||
.cardss {
|
||
.cardss-title {
|
||
display: flex;
|
||
justify-content: center;
|
||
align-items: flex-end;
|
||
padding-top: 48rpx;
|
||
padding-bottom: 60rpx;
|
||
}
|
||
}
|
||
|
||
.cardz {
|
||
|
||
.gridLine {
|
||
margin-left: 32rpx;
|
||
margin-right: 32rpx;
|
||
margin-bottom: 64rpx;
|
||
display: flex;
|
||
justify-content: space-between;
|
||
align-items: center;
|
||
|
||
.text1 {
|
||
font-weight: 400;
|
||
font-size: 32rpx;
|
||
text-align: left;
|
||
color: #666666 !important;
|
||
}
|
||
|
||
.text2 {
|
||
display: flex;
|
||
justify-content: center;
|
||
align-items: center;
|
||
font-weight: 400;
|
||
font-size: 30rpx;
|
||
text-align: center;
|
||
color: #333333 !important;
|
||
}
|
||
}
|
||
|
||
|
||
}
|
||
|
||
.cardx {
|
||
background-color: #ffffff;
|
||
width: 100%;
|
||
margin-top: 6rpx;
|
||
|
||
.gridLine {
|
||
padding-top: 32rpx;
|
||
padding-bottom: 32rpx;
|
||
margin-left: 32rpx;
|
||
margin-right: 32rpx;
|
||
display: flex;
|
||
justify-content: space-between;
|
||
align-items: center;
|
||
|
||
.text1 {
|
||
font-weight: 400;
|
||
font-size: 32rpx;
|
||
text-align: left;
|
||
color: #666666 !important;
|
||
}
|
||
|
||
.text2 {
|
||
display: flex;
|
||
justify-content: center;
|
||
align-items: center;
|
||
font-weight: 400;
|
||
font-size: 30rpx;
|
||
text-align: center;
|
||
color: #333333 !important;
|
||
}
|
||
|
||
.text3 {
|
||
display: flex;
|
||
justify-content: center;
|
||
align-items: center;
|
||
font-weight: 400;
|
||
font-size: 30rpx;
|
||
text-align: right;
|
||
color: #999999 !important;
|
||
}
|
||
}
|
||
}
|
||
</style> |