Files
ks-app-employment-service/packageB/pages/userCenter/fillInInformation.vue

690 lines
17 KiB
Vue
Raw Normal View History

2025-10-30 11:29:57 +08:00
<template>
<view class="index-wrap">
<view class="title-h1">
请先完善个人信息
</view>
<view class="item-list">
<!-- <view class="item">
<view class="title">就读学校</view>
<view class="input-wrap">
<view class="icon-input">
</view>
<input class="input-value" v-model="schoolName" placeholder="请输入您的学校" />
</view>
</view> -->
<view class="item">
<view class="title"><text>*</text>学历(必选)</view>
<view class="option">
<view class="subject-item" :class="eduLevel===3?'on':''" @click="changeEduLevel(3)">研究生</view>
<view class="subject-item" :class="eduLevel===2?'on':''" @click="changeEduLevel(2)">本科</view>
<view class="subject-item" :class="eduLevel===1?'on':''" @click="changeEduLevel(1)">专科</view>
</view>
</view>
<view class="item">
<view class="title"><text>*</text>专业类(必选)</view>
<view class="input-wrap">
<view class="input-value" :class="specialtyName!== ''?'':'placeholder'"
@click="showZhuanYeDialog(true)">
{{specialtyName !== ''? specialtyName: "请选择专业类"}}
</view>
<view class="icon-select">
</view>
</view>
</view>
<!-- <view class="item">
<view class="title">入学年份</view>
<view class="input-wrap">
<view class="input-value" :class="startYear!== ''?'':'placeholder'" @click="showYear = true">
{{startYear !== ''? startYear: "请选择您的入学年份"}}
</view>
<view class="icon-select">
</view>
</view>
</view>
<view class="item">
<view class="title">手机绑定</view>
<view class="input-wrap">
<input class="input-value" type="number" v-model="mobile" placeholder="请输入您的手机" />
</view>
</view>
<view class="item">
<view class="input-wrap" style="width: 710rpx;border: none; padding: 0;">
<input class="mb-input-value" type="number" v-model="code" placeholder="请输入验证码" />
<view class="get-code-btn" v-show="!isDownTime" @click="getCode">获取验证码</view>
<view class="get-code-btn disable" v-show="isDownTime">{{downTimeTxt}}</view>
</view>
</view> -->
</view>
<view class="btn-wrap">
<view class="btn" :class="isCommit?'':'disable'" @click="commitForm">
确认提交
</view>
</view>
<uni-popup ref="pop_zhuanye" type="bottom">
<view class="layer-inner">
<view class="head">
<text>选择专业类</text>
<view class="close-btn" @click="showZhuanYeDialog(false)"></view>
</view>
<view class="content">
<view class="li" :class="item.value == specialtyName?'on':''" v-for="(item,index) in showSpecialtyList"
:key="index" @click="checkSpecialty(item)">
<text>{{item.label}}</text>
</view>
</view>
</view>
</uni-popup>
<!-- <u-popup :show="showYear" @close="showYear=false" :round="10">
<view class="layer-inner">
<view class="head">
<text>选择入学年份</text>
<view class="close-btn" @click="showYear=false"></view>
</view>
<view class="content">
<view class="li" :class="item == startYear?'on':''" v-for="(item,index) in yearsList" :key="index"
@click="checkYear(item)">
<text>{{item}}</text>
</view>
</view>
</view>
</u-popup> -->
</view>
</template>
<script>
import api from "@/apiB/user.js"
2025-10-30 11:29:57 +08:00
export default {
data() {
return {
schoolName: "", //
eduLevel: 2, //3研究生2本科1专科
specialtyName: "", //
showSpecialtyName: false,
showSpecialtyList: [{
label: '哲学',
value: '哲学'
},
{
label: '经济学',
value: '经济学'
},
{
label: '法学',
value: '法学'
},
{
label: '教育学',
value: '教育学'
},
{
label: '文学',
value: '文学'
},
{
label: '历史学',
value: '历史学'
},
{
label: '理学',
value: '理学'
},
{
label: '工学',
value: '工学'
},
{
label: '农学',
value: '农学'
},
{
label: '医学',
value: '医学'
},
{
label: '管理学',
value: '管理学'
},
{
label: '艺术学',
value: '艺术学'
},
{
label: '军事学',
value: '军事学'
},
{
label: '交叉学科',
value: '交叉学科'
},],
specialtyOption1: [{
label: '农林牧渔大类',
value: '农林牧渔大类'
},
{
label: '资源环境与安全大类',
value: '资源环境与安全大类'
},
{
label: '能源动力与材料大类',
value: '能源动力与材料大类'
},
{
label: '土木建筑大类',
value: '土木建筑大类'
},
{
label: '水利大类',
value: '水利大类'
},
{
label: '装备制造大类',
value: '装备制造大类'
},
{
label: '生物与化工大类',
value: '生物与化工大类'
},
{
label: '轻工纺织大类',
value: '轻工纺织大类'
},
{
label: '食品药品与粮食',
value: '食品药品与粮食'
},
{
label: '交通运输大类',
value: '交通运输大类'
},
{
label: '电子信息大类',
value: '电子信息大类'
},
{
label: '医药卫生大类',
value: '医药卫生大类'
},
{
label: '财经商贸大类',
value: '财经商贸大类'
},
{
label: '旅游大类',
value: '旅游大类'
},
{
label: '文化艺术大类',
value: '文化艺术大类'
},
{
label: '新闻传播大类',
value: '新闻传播大类'
},
{
label: '教育与体育大类',
value: '教育与体育大类'
},
{
label: '公安与司法大类',
value: '公安与司法大类'
},
{
label: '公共管理与服务大类',
value: '公共管理与服务大类'
},
],
specialtyOption2: [{
label: '哲学',
value: '哲学'
},
{
label: '经济学',
value: '经济学'
},
{
label: '法学',
value: '法学'
},
{
label: '教育学',
value: '教育学'
},
{
label: '文学',
value: '文学'
},
{
label: '历史学',
value: '历史学'
},
{
label: '理学',
value: '理学'
},
{
label: '工学',
value: '工学'
},
{
label: '农学',
value: '农学'
},
{
label: '医学',
value: '医学'
},
{
label: '管理学',
value: '管理学'
},
{
label: '艺术学',
value: '艺术学'
},
{
label: '军事学',
value: '军事学'
},
{
label: '交叉学科',
value: '交叉学科'
},
],
showYear: false, //显示入学年份
yearsList: [], //入学年份
startYear: "", //入学年份
isDownTime: false,
downTimeTxt: '60s后获取',
mobile: "",
code: "",
isCommit:false,
}
},
computed: {
},
created() {
//this.initYear();
this.getUserInfor();
},
methods: {
async getUserInfor(){
const res = await api.getUserBasisInfo();
2025-10-30 11:29:57 +08:00
if (res.Result == 1) {
const data = res.Data.data;
this.specialtyName=data.SpecialtyName;
this.eduLevel=data.EduLevel;
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
//显示专业弹窗
showZhuanYeDialog(type){
if(type==false){
this.$refs.pop_zhuanye.close();
}else{
this.$refs.pop_zhuanye.open('bottom');
}
},
// 选年份
checkYear(ITEM) {
this.startYear = ITEM;
this.showYear = false;
},
// 初始年份
initYear() {
const currentYear = new Date().getFullYear()
const years = Array.from({
length: 5
}, (_, i) => currentYear - i);
this.yearsList = years;
},
// 改变学历
changeEduLevel(INDEX){
if(INDEX == 1){
this.showSpecialtyList = this.specialtyOption1;
}else {
this.showSpecialtyList = this.specialtyOption2;
}
this.specialtyName = "";
this.eduLevel = INDEX;
},
//选中专业类
checkSpecialty(ITEM) {
this.specialtyName = ITEM.value;
this.showSpecialtyName = false;
this.isCommit=true;
this.$refs.pop_zhuanye.close();
},
//获取验证码
async getCode(){
if (this.mobile.replace(/\s+/g, '') == "" || !/^1[3456789]\d{9}$/.test(this.mobile.replace(/\s+/g, ''))) {
uni.showToast({
title: "请输入正确的手机号",
icon: "none"
})
return;
}
this.isDownTime = true;
this.updateTimer(60)
// let data = {
// mobile: this.mobile.replace(/\s+/g, ''),
// smsType: 2
// }
const mobile = this.mobile.replace(/\s+/g, '')
const res = await api.querySendSmsCodeWithoutCode(mobile)
2025-10-30 11:29:57 +08:00
if (res.Result !== 1) {
uni.showToast({
title: res.Message,
icon: "none"
})
this.downTimeTxt = "60s后获取"
}
},
updateTimer(num){
if (num > 0) {
num--;
this.downTimeTxt = (num < 10 ? '0' + num : num) + "s后获取";
setTimeout(()=>{
this.updateTimer(num)
},1000)
}else {
this.isDownTime = false;
//提交题目
}
},
// 获取
async getExperienceWeekDesk() {
const departRes = await api.getDepartList();
if (departRes.Result == 1) {
this.deparList = departRes.Data.list;
}
const res = await api.getExperienceWeekDesk();
if (res.Result == 1) {
const data = res.Data.singleD;
if (data.DepartId > 0 && departRes.Data.list.length > 0) {
this.checkedDeparId = data.DepartId;
this.checkedDeparName = departRes.Data.list.find(item => item.Id === data.DepartId)?.Name;
this.startYear = data.StartYear;
this.userName = data.RealName;
this.sex = data.Sex;
}
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
//确认表单
async commitForm() {
if (!this.isCommit) {
return;
}
uni.showLoading({
title: "保存中..."
})
let mobileCode = this.code;
const data = {
//SchoolName: this.schoolName,
EduLevel: this.eduLevel,
SpecialtyName: this.specialtyName,
//Phone: this.mobile,
//StartYear: this.startYear
}
const res = await api.saveUserBasisInfo(mobileCode,data);
2025-10-30 11:29:57 +08:00
uni.hideLoading();
if (res.Result == 1) {
uni.navigateBack()
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
}
}
</script>
<style lang="scss" scoped>
.index-wrap {
padding: 40rpx 20rpx 60rpx;
.title-h1 {
font-size: 36rpx;
color: #000000;
font-weight: 600;
margin-bottom: 40rpx;
}
.item-list {
.item {
padding-bottom: 20px;
.title {
font-size: 28rpx;
color: #333;
margin-bottom: 20rpx;
text{
color:red;
}
}
.input-wrap {
width: 670rpx;
height: 84rpx;
border-radius: 12rpx;
border: 2rpx solid #EEEEEE;
padding: 0 20rpx;
display: flex;
align-items: center;
.icon-input {
width: 32rpx;
height: 32rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-select {
width: 16rpx;
height: 16rpx;
margin-left: 24rpx;
background: url("") no-repeat;
background-size: 100%;
}
.input-value {
width: 580rpx;
height: 84rpx;
font-size: 28rpx;
color: #333;
line-height: 84rpx;
padding-left: 20rpx;
&.placeholder {
font-size: 28rpx;
color: #999;
}
&::-webkit-input-placeholder {
font-size: 28rpx;
color: #999;
}
}
.mb-input-value {
width: 440rpx;
height: 84rpx;
font-size: 28rpx;
color: #333;
border-radius: 12rpx;
border: 2rpx solid #EEEEEE;
line-height: 84rpx;
padding-left: 40rpx;
&::-webkit-input-placeholder {
font-size: 28rpx;
color: #999;
}
}
.get-code-btn {
width: 240rpx;
height: 80rpx;
margin-left: 30rpx;
line-height: 80rpx;
background-color: #1b88ff;
border-radius: 12rpx;
font-size: 32rpx;
text-align: center;
color: #ffffff;
z-index: 9;
&.disable {
background: #9f9f9f;
}
}
}
.option {
display: flex;
flex-wrap: wrap;
2025-10-30 17:17:15 +08:00
justify-content: space-around;
2025-10-30 11:29:57 +08:00
.subject-item {
width: 210rpx;
height: 76rpx;
background: #F3F4F6;
border-radius: 12rpx;
font-size: 28rpx;
color: #333;
margin-bottom: 20rpx;
margin-right: 30rpx;
text-align: center;
line-height: 76rpx;
&:nth-child(3n) {
margin-right: 0;
}
&.on {
2025-10-30 17:17:15 +08:00
background: #F3F4F6;
color: #1677ff;
2025-10-30 11:29:57 +08:00
}
&.disadble {
color: #bbb;
}
}
}
}
}
.btn-wrap {
position: fixed;
bottom: 100rpx;
left: 50%;
transform: translateX(-50%);
display: flex;
justify-content: center;
z-index: 9;
.btn {
width: 688rpx;
height: 88rpx;
line-height: 88rpx;
text-align: center;
2025-10-30 17:17:15 +08:00
background: #1677ff;
2025-10-30 11:29:57 +08:00
font-size: 32rpx;
color: #fff;
border-radius: 60rpx;
&.disable {
background: #F3F4F6;
color: #bbb;
}
}
}
.layer-inner {
background:#fff;
border-radius:10px 10px 0 0;
.head {
position: relative;
display: flex;
align-items: center;
justify-content: center;
height: 120rpx;
width: 100%;
font-size: 34rpx;
color: #000000;
.close-btn {
position: absolute;
top: 39rpx;
right: 27rpx;
width: 52rpx;
height: 52rpx;
background: url("") center no-repeat;
background-size: 50%;
}
}
.content {
max-height: 640rpx;
overflow: auto;
padding: 0 40rpx;
.li {
position: relative;
height: 114rpx;
line-height: 114rpx;
border-bottom: 2rpx solid #f5f5f5;
text {
font-size: 30rpx;
color: #000000;
margin-right: 20rpx;
}
&.on {
text {
color: #1b88ff;
}
&::after {
position: absolute;
right: 10rpx;
top: 50%;
transform: translateY(-50%);
content: "";
background: url("") no-repeat;
background-size: 100%;
display: block;
width: 35rpx;
height: 25rpx;
}
}
}
}
.op-block {
display: flex;
align-items: center;
justify-content: center;
padding: 30rpx 40rpx 0;
width: 670rpx;
height: 115rpx;
.commit-btn {
width: 361rpx;
height: 77rpx;
line-height: 77rpx;
text-align: center;
background-color: #1b88ff;
border-radius: 38rpx;
font-size: 30rpx;
color: #ffffff;
}
}
}
}
</style>