合并 智慧就业第一版

This commit is contained in:
2025-10-30 11:29:57 +08:00
parent 577b20661a
commit 6579abe021
166 changed files with 2818496 additions and 367 deletions

View File

@@ -0,0 +1,365 @@
<template>
<view class="index-wrap">
<view class="head-bar" :style="{'margin-top': barHeight + 5 + 'px'}">
<view class="go-back" @click="goBack"></view>
<text>生涯罗盘</text>
</view>
<view class="content">
<view class="title">
生涯罗盘
</view>
<view class="section">
<view class="table">
<view class="tr">
<view class="th">
</view>
<view class="th">
职业名称
</view>
<view class="th">
多元能力
</view>
<view class="th">
兴趣测评
</view>
<view class="th">
人格测评
</view>
</view>
<view class="tr" v-for="(item,index) in compassList" @click="checkedJob(item)" :key="index">
<view class="td">
<view class="checked-btn" :class="checkedIndex==item.JobId?'on':''"></view>
</view>
<view class="td">
{{item.Name}}
</view>
<view class="td">
<view class="is-has" v-if="item.IsMulti"></view>
</view>
<view class="td">
<view class="is-has" v-if="item.IsInterest"></view>
</view>
<view class="td">
<view class="is-has" v-if="item.IsPersonal"></view>
</view>
</view>
</view>
</view>
<view class="title">
我的职业
</view>
<view class="section">
<scroll-view
class="job-table"
scroll-y
scroll-x
@scrolltolower="loadMore"
:scroll-with-animation="false"
>
<view class="tr">
<view class="th">
职业规划方向
</view>
<view class="th">
能力要求
</view>
<view class="th">
推荐学习课程
</view>
<view class="th">
推荐岗位
</view>
</view>
<view
class="tr"
v-for="(item, index) in jobList"
:key="index"
>
<view class="td">
{{item.JobName}}
</view>
<view class="td">
<text v-for="(ritem,rindex) in item.AbilityPlanList">{{ritem}}</text>
</view>
<view class="td">
<text v-for="(ritem,rindex) in item.CoursePlanList">{{ritem.Name}}</text>
</view>
<view class="td">
<text v-for="(ritem,rindex) in item.JobNameList">{{ritem}}</text>
</view>
</view>
<view class="loading" v-if="isLoading">
加载中...
</view>
<view class="no-more" v-if="noMore">
没有更多数据了
</view>
</scroll-view>
</view>
</view>
</view>
</template>
<script>
import api from "@/apiB/studentProfile.js"
export default {
data() {
return {
barHeight: wx.getWindowInfo().statusBarHeight,
compassList: [],//罗盘列表
checkedIndex: null,
jobList: [],//我的职业
page: 1,
isLoading: false,
noMore: false,
}
},
created() {
this.getCareerCompassList();
this.getGXCareerPlanList();
},
methods: {
goBack() {
uni.navigateBack(-1);
},
//选中职业添加
async checkedJob(ITEM){
this.checkedIndex = ITEM.JobId;
const res = await api.saveGXCareerPlan(ITEM.JobId);
if (res.Result == 1) {
uni.showToast({
title: "添加成功",
icon: "none"
})
this.getGXCareerPlanList();
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
// 获取生涯罗盘
async getCareerCompassList() {
uni.showLoading({
title: "加载中..."
})
const res = await api.getCareerCompassList();
uni.hideLoading();
if (res.Result == 1) {
this.compassList = res.Data.list;
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
// 获取职业
async getGXCareerPlanList(){
this.noMore = false;
this.page = 1;
const res = await api.getGXCareerPlanList("",this.page,10);
if (res.Result == 1) {
this.jobList = res.Data.list;
// if(res.Data.list.length < 10){
// this.noMore = true;
// }
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
// 加载更多
async loadMore(){
if(this.noMore){
return;
}
this.isLoading = true;
const res = await api.getGXCareerPlanList("",++this.page,10);
this.isLoading = false;
if (res.Result == 1) {
this.jobList = this.jobList.concat(res.Data.list);
if(res.Data.list.length < 10){
this.noMore = true;
}
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
}
}
}
</script>
<style lang="scss">
$image-oss-url: "https://51xuanxiao.oss-cn-hangzhou.aliyuncs.com/Resource/xcx_sygh";
page {
background: #EEF1F8 url("#{$image-oss-url}/17.png") no-repeat;
background-size: contain;
}
</style>
<style lang="scss" scoped>
$image-oss-url: "https://51xuanxiao.oss-cn-hangzhou.aliyuncs.com/Resource/xcx_sygh";
.head-bar {
position: relative;
text-align: center;
font-size: 36rpx;
font-weight: 600;
height: 60rpx;
line-height: 60rpx;
.go-back {
position: absolute;
left: 10rpx;
top: 0;
width: 60rpx;
height: 60rpx;
background: url("") center no-repeat;
background-size: 38rpx 38rpx;
}
}
.index-wrap {
.content {
padding: 0 20rpx;
margin-top: 60rpx;
.title {
font-size: 36rpx;
color: #010101;
margin-bottom: 30rpx;
font-weight: 600;
}
.section {
width: 650rpx;
padding: 30rpx 30rpx 50rpx;
background-color: #ffffff;
border-radius: 14rpx;
margin-bottom: 50rpx;
.table {
border-left: 2rpx solid #eef2fd;
border-top: 2rpx solid #eef2fd;
border-right: 2rpx solid #eef2fd;
border-radius: 6rpx;
overflow-x: auto;
overflow-y: auto;
max-height: 470rpx;
.tr {
display: -webkit-box;
.th {
width: 192rpx;
height: 72rpx;
line-height: 72rpx;
text-align: center;
background: #F6F9FE;
font-size: 24rpx;
color: #333333;
border-bottom: 2rpx solid #eef2fd;
&:nth-child(1){
width: 60rpx;
}
&:nth-child(2){
width: 250rpx;
}
}
.td {
display: flex;
justify-content: center;
align-items: center;
width: 192rpx;
min-height: 72rpx;
font-size: 24rpx;
color: #333333;
text-align: center;
border-bottom: 2rpx solid #eef2fd;
&:nth-child(1){
width: 60rpx;
}
&:nth-child(2){
width: 250rpx;
word-break: break-all;
}
.checked-btn {
width: 28rpx;
height: 28rpx;
background: #FFFFFF;
border-radius: 50%;
border: 2rpx solid #999999;
&.on {
position: relative;
border-color: #1989fa;
background: #1989fa;
&:before {
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%,-50%);
content: "";
display: block;
width: 12rpx;
height: 12rpx;
border-radius: 50%;
background: #fff;
}
}
}
.is-has {
width: 48rpx;
height: 48rpx;
background: url("") center no-repeat;
background-size: 90%;
}
}
}
}
.job-table {
border-left: 2rpx solid #eef2fd;
border-top: 2rpx solid #eef2fd;
border-right: 2rpx solid #eef2fd;
border-radius: 6rpx;
height: 400rpx;
.tr {
display: -webkit-box;
.th {
width: 250rpx;
height: 72rpx;
line-height: 72rpx;
text-align: center;
background: #F6F9FE;
font-size: 24rpx;
color: #333333;
border-bottom: 2rpx solid #eef2fd;
}
.td {
display: flex;
flex-wrap: wrap;
justify-content: center;
align-items: center;
width: 250rpx;
padding: 10rpx 0;
min-height: 52rpx;
font-size: 24rpx;
color: #333333;
text-align: center;
border-bottom: 2rpx solid #eef2fd;
font-size: 24rpx;
color: #333333;
text {
margin: 0 5rpx 5rpx;
}
}
}
.no-more,
.loading {
font-size: 26rpx;
color: #999;
padding: 30rpx 0;
text-align: center;
}
}
}
}
}
</style>

View File

@@ -0,0 +1,690 @@
<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 api1 from "@/apiB/user.js"
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 api1.getUserBasisInfo();
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 api1.querySendSmsCodeWithoutCode(mobile)
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 api1.saveUserBasisInfo(mobileCode,data);
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;
.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 {
background: #EDF6FF;
color: #1989FA;
}
&.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;
background: #1989FA;
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>

View File

@@ -0,0 +1,447 @@
<template>
<view class="index-wrap">
<view class="head-bar" :style="{'margin-top': barHeight + 5 + 'px'}">
<view class="go-back" @click="goBack"></view>
<text>学习计划制定</text>
</view>
<view class="content">
<view class="title-h1">PDCA 循环法</view>
<view class="banner"></view>
<view class="txt-wrap">
<view class="p-txt">
PDCA循环由质量管理专家戴明于20世纪50年代优化完善并推广又称戴明环其核心是通过计划执行检查处理四个阶段的闭环管理进行目标执行效果的持续改进可适用于个人知识管理技能提升等学习场景
</view>
<view class="p-txt">
<text class="strong-txt">Plan(计划)</text>明确目标与步骤包括现状分析问题识别及解决方案制定
</view>
<view class="p-txt">
<text class="strong-txt">Do(执行)</text>根据计划实施具体措施如教学中的课堂授课企业中的产品生产
</view>
<view class="p-txt">
<text class="strong-txt">Check(检查)</text>评估执行效果通过数据对比因果图等方法发现偏差
</view>
<view class="p-txt">
<text class="strong-txt">Act(处理)</text>总结经验并标准化流程如将成功经验纳入培训体系或优化资源配置
</view>
</view>
<view class="title-h1">年度学习计划清单</view>
<view class="txt-wrap">
<view class="strong-txt mb30">
请填写你的年度学习计划清单并按照PDCA循环法执行和落实计划
</view>
<view class="p-txt">
说明:
</view>
<view class="gp-txt">
<text class="strong-txt">1总目标</text>
期望达到的综合成就和发展方向它是整个计划的核心和导向如成为金融领域具有深厚理论基础和丰富实践经验的高端专业人才
</view>
<view class="gp-txt">
<text class="strong-txt">2课程学习</text>
为了达到总目标需完成的各类课程,包括通识教育课程专业课程选修课程等如完成计量经济学的学习
</view>
<view class="gp-txt">
<text class="strong-txt">3实践活动</text>
为了达到总目标需参与的各类实践活动如志愿服务社团活动实习实训创新创业项目等如加入金融学术社团
</view>
<view class="gp-txt">
<text class="strong-txt">4技能提升</text>
通过自学或参加培训等方式提升个人技能包括外语能力计算机技能专业技能等如利用课余时间学习Python课程并考取相应资格证书
</view>
<view class="gp-txt">
<text class="strong-txt">5职业规划</text>
对个人未来职业发展的系统性安排核心包括职业方向定位职业成就预期职业路径设计等通过投行实习明确方向一3年内成为分析师5年内晋升经理
</view>
</view>
<view class="target-content">
<view class="target-tabbar">
<view class="item" :class="checkedTargetCode ==item.EncodeId?'on':''" v-for="(item,index) in targetList" :key="index" @click="changeTarget(item)">
<text v-text=" '学习'+ tabs[index]"></text>
</view>
</view>
<view class="desc-wrap">
<view class="h3-title">
目标描述
</view>
<view class="desc-txt">
<text class="blue-txt">SMART目标制定的数据中读取的内容:</text>
<text v-text="targetForm.TargetDesc?targetForm.TargetDesc:'无'"></text>
</view>
</view>
<view class="form-wrap">
<view class="year-plan-item" v-for="(item,index) in planList" :key="index">
<view class="plan-title">
{{index+1}}年度计划
</view>
<view class="form-item">
<view class="label">
课程学习
</view>
<view class="input-wrap">
<input v-model="item.CourseName" placeholder="通识教育课程、专业课程、选修课程等"></input>
</view>
</view>
<view class="form-item">
<view class="label">
实践活动
</view>
<view class="input-wrap">
<input v-model="item.ActivityName" placeholder="志愿服务、社团活动、实习实训、创新创业项目等"></input>
</view>
</view>
<view class="form-item">
<view class="label">
技能提升
</view>
<view class="input-wrap">
<input v-model="item.Ability" placeholder="外语能力、计算机技能、专业技能等,及计划考..."></input>
</view>
</view>
<view class="form-item">
<view class="label">
职业规划
</view>
<view class="input-wrap">
<input v-model="item.JobPlan" placeholder="职业方向定位、职业成就预期、职业路径设计等"></input>
</view>
</view>
<view class="del-year-btn" @click="deletePlan(index)">
删除该年度计划
</view>
</view>
</view>
</view>
<view class="btn-wrap">
<view class="add-btn" @click="addPlan" v-show="planList.length<5">
+增加年度计划
</view>
<view class="commit-btn" @click="commitForm">
确认提交
</view>
</view>
</view>
</view>
</template>
<script>
import api from "@/apiB/studentProfile.js"
export default {
data() {
return {
barHeight: wx.getWindowInfo().statusBarHeight,
tabs:['目标一 ', '目标二 ', '目标三 ', '目标四 ', '目标五 '],
targetForm: {}, //当前选中的目标
targetList: [],//目标列表
checkedTargetCode: "",// 目标码
planList: [], //年度计划列表
emptyPlanList: [
{
EncodeId: '',//Id
CourseName: '',//课程学习
ActivityName: '',//实践活动
Ability: '',//技能提升
JobPlan: ''//职业规划
}
], //空
delIds:[],//删除的计划id
}
},
created() {
this.queryPlanList();
},
methods: {
goBack(){
uni.navigateBack(-1);
},
// 切换目标标签
changeTarget(ITEM){
if(ITEM.EncodeId == this.checkedTargetCode){
return;
}
this.checkedTargetCode = ITEM.EncodeId;
this.targetForm = this.targetList.filter(item=>item.EncodeId == ITEM.EncodeId)[0];
this.queryPlanList();
},
// 获取学习目标
async querySmartTargets() {
const res = await api.querySmartTargets();
if (res.Result == 1) {
this.targetList = res.Data;
if(res.Data.length>0){
this.checkedTargetCode = res.Data[0].EncodeId;
this.targetForm = res.Data[0];
}
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
// 获取单个获取年度计划
async queryPlanList() {
if(this.targetList.length == 0){
await this.querySmartTargets();
}
if(!this.checkedTargetCode){
return;
}
const res = await api.queryPlanList(this.checkedTargetCode);
if (res.Result == 1) {
this.planList = res.Data;
if(res.Data.length == 0){
this.planList = [...this.emptyPlanList];
}
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
// 增加年度计划
addPlan(){
this.planList.push({...this.emptyPlanList[0]});
},
// 删除年度计划
deletePlan(INDEX){
if (this.planList[INDEX].EncodeId != '') {
this.delIds.push(this.planList[INDEX].EncodeId)
}
this.planList.splice(INDEX, 1);
},
//确认表单
async commitForm() {
uni.showLoading({
title: "保存中..."
})
const data = {
EncodeId: this.checkedTargetCode,
PlanList: this.planList,
DelIds: this.delIds,
}
const res = await api.savePlanList(data);
uni.hideLoading();
if (res.Result == 1) {
uni.showToast({
title: "保存成功",
icon: "success"
})
this.queryPlanList();
this.delIds=[];
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
}
}
</script>
<style lang="scss">
$image-oss-url: "https://51xuanxiao.oss-cn-hangzhou.aliyuncs.com/Resource/xcx_sygh";
page {
background: #f4f7fc url("#{$image-oss-url}/17.png") no-repeat;
background-size: contain;
overflow-y: scroll;
}
</style>
<style lang="scss" scoped>
$image-oss-url: "https://51xuanxiao.oss-cn-hangzhou.aliyuncs.com/Resource/xcx_sygh";
.head-bar {
position: relative;
text-align: center;
font-size: 36rpx;
font-weight: 600;
height: 60rpx;
line-height: 60rpx;
.go-back {
position: absolute;
left: 10rpx;
top: 0;
width: 60rpx;
height: 60rpx;
background: url("") center no-repeat;
background-size: 38rpx 38rpx;
}
}
.index-wrap {
.content {
padding-top: 40rpx;
.title-h1 {
font-size: 36rpx;
color: #333;
padding: 20rpx 30rpx;
font-weight: 600;
}
.banner {
width: 100%;
height: 423rpx;
background: url("#{$image-oss-url}/gaoxiao/academicEvaluation/pdca-banner.png");
background-size: 100%;
}
.txt-wrap {
padding: 50rpx 30rpx 20rpx;
background: #fff;
.p-txt {
font-size: 28rpx;
line-height: 48rpx;
color: #333333;
margin-bottom: 20rpx;
}
.gp-txt {
font-size: 28rpx;
line-height: 48rpx;
color: #666;
margin-bottom: 20rpx;
}
.mb30 {
margin-bottom: 30rpx;
}
.strong-txt {
color: #333333;
font-weight: 600;
}
}
.target-content {
background: #fff;
padding: 40rpx 30rpx 0;
margin-top: 40rpx;
.target-tabbar {
margin-bottom: 50rpx;
display: flex;
flex-wrap: wrap;
.item {
position: relative;
width: 155rpx;
height: 64rpx;
line-height: 64rpx;
text-align: center;
border-radius: 34rpx;
border: solid 2rpx #eeeeee;
font-size: 28rpx;
color: #999999;
margin-right: 20rpx;
&.on {
color: #1989fa;
border-color: #1989fa;
}
}
}
.desc-wrap {
margin-bottom: 40rpx;
.h3-title {
color: #333333;
font-size: 28rpx;
margin-bottom: 20rpx;
}
.desc-txt {
color: #666666;
font-size: 28rpx;
line-height: 48rpx;
.blue-txt {
color: #1989fa;
}
}
}
.form-wrap {
padding-bottom: 40rpx;
.year-plan-item {
.plan-title {
display: flex;
align-items: center;
justify-content: center;
color: #333333;
font-size: 32rpx;
padding: 50rpx 0;
font-weight: 600;
&:before {
content: "";
display: block;
width: 18rpx;
height: 6rpx;
margin-right: 40rpx;
background: url("");
background-size: 100%;
}
&::after {
content: "";
display: block;
margin-left: 40rpx;
width: 18rpx;
height: 6rpx;
background: url("");
background-size: 100%;
}
}
.form-item {
.label {
font-size: 28rpx;
color: #333333;
margin-bottom: 30rpx;
}
.input-wrap {
margin-bottom: 40rpx;
input {
width: 650rpx;
height: 76rpx;
line-height: 76rpx;
padding: 0 20rpx;
background-color: #ffffff;
border-radius: 6rpx;
border: solid 2rpx #eeeeee;
font-size: 28rpx;
&::-webkit-input-placeholder {
color: #bebebe;
font-size: 28rpx;
}
}
}
}
.del-year-btn {
width: 686rpx;
height: 74rpx;
line-height: 74rpx;
text-align: center;
border-radius: 6rpx;
margin-top: 50rpx;
border: solid 2rpx #ff625f;
color: #ff6157;
font-size: 32rpx;
}
}
}
}
.btn-wrap {
display: flex;
justify-content: center;
align-items: center;
padding: 50rpx 30rpx;
.commit-btn {
width: 335rpx;
height: 80rpx;
background-color: #1989fa;
border-radius: 40rpx;
font-size: 28rpx;
color: #fff;
text-align: center;
line-height: 80rpx;
}
.add-btn {
width: 331rpx;
height: 76rpx;
font-size: 28rpx;
text-align: center;
line-height: 76rpx;
border-radius: 40rpx;
color: #1989fa;
border: solid 2rpx #1989fa;
margin-right: 20rpx;
}
}
}
}
</style>

View File

@@ -0,0 +1,740 @@
<template>
<view class="document">
<view class="head-bar" :style="{'margin-top': barHeight + 5 + 'px'}">
<view class="go-back" @click="goback"></view>
<text>生涯档案</text>
</view>
<view class="person-info" style="display:none;">
<view class="img-wrap">
<image v-if="customInfo.AllHeadimgUrl" :src="customInfo.AllHeadimgUrl"></image>
<image v-else src="https://51xuanxiao.oss-cn-hangzhou.aliyuncs.com/Resource/xcx_sygh/avatar.png" mode=""></image>
</view>
<view class="txt-wrap">
<view class="top">
<view class="name">{{user.RealName}}</view>
<!-- <view class="grades">{{user.GradeName}}{{user.ClassName}}</view> -->
</view>
<view class="bottom">{{user.SchoolName}}</view>
</view>
</view>
<view class="section" style="margin-top:60rpx;">
<view class="head">
<view class="left-txt">
<view class="icon icon-1"></view>
意向职业
</view>
<view class="right-txt">
限5种
</view>
</view>
<view class="content" v-if="intentionJobList != null && intentionJobList.length > 0">
<view class="list">
<view class="item" v-for="(item, index) in intentionJobList" :key="index">
<text class="name">{{(index + 1) + '.' +item.Name}}</text>
<view class="cancel-btn" v-on:click="cancleIntention(index,2,item.EnCodeId)">取消</view>
</view>
</view>
</view>
<view class="content" v-else>
<view class="empty">
<view class="icon"></view>
<text>您还未添加意向职业</text>
</view>
</view>
<view class="footer">
<navigator url="/pagesStudent/job/index" class="btn">添加意向职业</navigator>
</view>
</view>
<view class="section">
<view class="head">
<view class="left-txt">
<view class="icon icon-4"></view>
职业兴趣测评
</view>
</view>
<view class="content" v-if="interestResult != null && interestResult !=''">
<view class="text-wrap">
<view class="row">
<text class="label">兴趣代码</text>
<view class="value">
<text v-for="(item, index) in interestCodeList" :key="index">
{{item}} <text v-if="index < interestCodeList.length -1"></text>
</text>
</view>
</view>
<view class="row">
<text class="label">对应学类</text>
<view class="value"><text v-for="(item, index) in interestRecommendSpecialty" :key="index">
{{item}} <text v-if="index < interestRecommendSpecialty.length -1"></text>
</text></view>
</view>
</view>
</view>
<view class="content" v-else>
<view class="empty">
<view class="icon"></view>
<text>您还未测评</text>
</view>
</view>
<view class="footer">
<navigator v-if="interestResult != null && interestResult !=''" url="/packageB/pages/testReport/interestTestReport" class="btn">查看报告</navigator>
<navigator v-if="!(interestResult != null && interestResult !='')" url="/packageB/pages/pagesTest/interestTestTitle" class="btn">去测评</navigator>
</view>
</view>
<view class="section">
<view class="head">
<view class="left-txt">
<view class="icon icon-6"></view>
工作价值观测评
</view>
</view>
<view class="content" v-if="workValueResult != null && workValueResult !=''">
<view class="text-wrap">
<view class="row">
<text class="label">高分价值观 </text>
<view class="long-value" v-if="workValueHight != null && workValueHight.length > 0">
<text v-for="(item, index) in workValueHight" :key="index">
{{item}} <text v-if="index < workValueHight.length -1"></text>
</text>
</view>
<view class="long-value" v-else>
<text></text>
</view>
</view>
</view>
</view>
<view class="content" v-else>
<view class="empty">
<view class="icon"></view>
<text>您还未测评</text>
</view>
</view>
<view class="footer">
<navigator class="btn" v-if="workValueResult != null && workValueResult !=''" url="/packageB/pages/testReport/workValuesTestReport">查看报告</navigator>
<navigator class="btn" v-else url="/packageB/pages/pagesTest/workValuesTestTitle">去测评</navigator>
</view>
</view>
<view class="section">
<view class="head">
<view class="left-txt">
<view class="icon icon-8"></view>
人格测评
</view>
</view>
<view class="content" v-if="personResult != null && personResult !=''">
<view class="text-wrap">
<view class="row">
<text class="label">内外向</text>
<view class="value" v-if="personGroupList1 != null && personGroupList1.length > 0">
<text v-for="(item, index) in personGroupList1" :key="index">
{{item}} <text v-if="index < personGroupList1.length -1"></text>
</text>
</view>
<view class="value" v-else>
<text></text>
</view>
</view>
<view class="row">
<text class="label">人际关系</text>
<view class="value" v-if="personGroupList2 != null && personGroupList2.length > 0" >
<text v-for="(item, index) in personGroupList2" :key="index">
{{item}} <text v-if="index < personGroupList2.length -1"></text>
</text>
</view>
<view class="value" v-else>
<text></text>
</view>
</view>
<view class="row">
<text class="label">严谨性</text>
<view class="value" v-if="personGroupList3 != null && personGroupList3.length > 0">
<text v-for="(item, index) in personGroupList3" :key="index">
{{item}} <text v-if="index < personGroupList3.length -1"></text>
</text>
</view>
<view class="value" v-else>
<text></text>
</view>
</view>
<view class="row">
<text class="label">开放性</text>
<view class="value" v-if="personGroupList4 != null && personGroupList4.length > 0" >
<text v-for="(item, index) in personGroupList4" :key="index">
{{item}} <text v-if="index < personGroupList4.length -1"></text>
</text>
</view>
<view class="value" v-else>
<text></text>
</view>
</view>
</view>
</view>
<view class="content" v-else>
<view class="empty">
<view class="icon"></view>
<text>您还未测评</text>
</view>
</view>
<view class="footer">
<navigator class="btn" v-if="personResult != null && personResult !=''" url="/packageB/pages/testReport/personalTestReport">查看报告</navigator>
<navigator class="btn" v-else url="/packageB/pages/pagesTest/personalTestTitle">去测评</navigator>
</view>
</view>
<view class="section" v-if="user.GradeLevel == 3">
<view class="head">
<view class="left-txt">
<view class="icon icon-11"></view>
多元能力测评
</view>
</view>
<view class="content" v-if="1">
<view class="text-wrap">
<view class="row">
<text class="label">能力强 </text>
<view class="long-value" v-if="multResult != null && multResult.length > 0 && multGroupList1.length > 0">
<text v-for="(item, index) in multGroupList1" :key="index">
{{item}} <text v-if="index < multGroupList1.length -1"></text>
</text>
</view>
<view class="long-value" v-else>
<text></text>
</view>
</view>
</view>
</view>
<view class="content" v-else>
<view class="empty">
<view class="icon"></view>
<text>您还未测评</text>
</view>
</view>
<view class="footer">
<navigator class="btn" v-if="1" :url="`/pagesTestReport/customTest/multipleAbilityTestReport`">查看报告</navigator>
<navigator class="btn" v-else url="/pagesTest/customTest/customTestTitle?testType=-27">去测评</navigator>
</view>
</view>
<view class="section" v-if="user.GradeLevel == 3">
<view class="head">
<view class="left-txt">
<view class="icon icon-12"></view>
通用能力测评
</view>
</view>
<view class="content" v-if="1">
<view class="text-wrap">
<view class="row">
<text class="label">优势的能力 </text>
<view class="long-value" v-if="universalResult != null && universalResult.length > 0 && universalGroupList1.length > 0">
<text v-for="(item, index) in universalGroupList1" :key="index">
{{item}} <text v-if="index < universalGroupList1.length -1"></text>
</text>
</view>
<view class="long-value" v-else>
<text></text>
</view>
</view>
</view>
</view>
<view class="content" v-else>
<view class="empty">
<view class="icon"></view>
<text>您还未测评</text>
</view>
</view>
<view class="footer">
<navigator class="btn" v-if="1" :url="`/pagesTestReport/customTest/generalCareerTestReport`">查看报告</navigator>
<navigator class="btn" v-else url="/pagesTest/customTest/customTestTitle?testType=-28">去测评</navigator>
</view>
</view>
</view>
</template>
<script>
import api from "@/apiB/user.js"
import api1 from "@/apiB/studentProfile.js"
export default {
data() {
return {
refreshIfNeeded: false, //是否返回刷新
barHeight: wx.getWindowInfo().statusBarHeight,
user: uni.getStorageSync("userInfo").user,
customInfo: uni.getStorageSync("customInfo"),
intentionJobList: [],//意向职业
intentionSpecialtyList: [],//意向专业
intentionUniversityList: [],//意向院校
interestCodeList: [],//兴趣码
interestRecommendSpecialty: [],//兴趣码
interestResult: "",//兴趣测评结果
customerGroup1: [],//学科效能
customerGroup2: [],//学科效能
customerResult: "",//学科效能
workValueHight: [],//工作价值
workValueResult: "",//工作价值
multHight: "",//多元智能
multResult: "",//多元智能
personGroupList1: [],//人格
personGroupList2: [],//人格
personGroupList3: [],//人格
personGroupList4: [],//人格
personResult: "",//人格
viewScores: false, //是否查看成绩
groupDataList: [],//志愿
examSoreInfo: {},//科目成绩
subjectMatching: 0,//学科信心匹配度 0无1低 2中 3高
groupMatching: 0,//选科组合匹配度 0无1低 2中 3高
specialtyMatching: 0,//意向专业院校匹配度 0无1低 2中 3高
recommendGroups: "",//推荐组合
suggestGroupName: null,//学校建议组合
suggestReason: null,//学校建议原因
scoreMatch: false,
subjectMatch: false,
specialtyUniversityMatch: false,
myStudyCourseList: [],
multResult: "",//多元能力
multGroupList1: [],//多元能力能力强
universalResult: "",//通用能力
universalGroupList1: [],//通用能力 优势
}
},
onShow() {
this.user = uni.getStorageSync("userInfo").user;
this.customInfo = uni.getStorageSync('customInfo');
this.queryStudentProfile();
},
created() {
},
methods: {
goback(){
uni.navigateBack(-1);
},
// 获取个人档案
async queryStudentProfile() {
uni.showLoading({
title: "加载中"
})
const gradeLevel = this.user.GradeLevel;
const res = gradeLevel == 3? await api1.getGXWechatStudentProfile() : await api.queryStudentProfile();
uni.hideLoading();
if(res.Result == 1){
let data = gradeLevel == 3? res.Data.list : res.Data;
// 意向职业
this.intentionJobList = data.IntentionJobList;
// 意向专业
this.intentionSpecialtyList = data.IntentionSpecialtyList;
// 意向院校
this.intentionUniversityList = data.IntentionUniversityList;
// 兴趣测评
this.interestCodeList = data.InterestCodeList;
this.interestRecommendSpecialty = data.InterestRecommendSpecialty;
this.interestResult = data.InterestResult;
// 人格测评
this.personGroupList1 = data.PersonGroupList1;
this.personGroupList2 = data.PersonGroupList2;
this.personGroupList3 = data.PersonGroupList3;
this.personGroupList4 = data.PersonGroupList4;
this.personResult = data.PersonResult;
// 工作价值
this.workValueHight = data.WorkValueHight;
this.workValueResult = data.WorkValueResult;
if(gradeLevel < 3){
// 多元智能
this.multHight = data.MultHight;
this.multResult = data.MultResult;
// 学科信心测评
this.customerGroup1 = data.CustomerGroup1;
this.customerGroup2 = data.CustomerGroup2;
this.customerResult = data.CustomerResult;
// 个人选科报告
this.viewScores = data.ViewScores;
this.scoreMatch = data.ScoreMatch;
this.subjectMatch = data.SubjectMatch;
this.specialtyUniversityMatch = data.SpecialtyUniversityMatch;
this.groupDataList = data.GroupDataList;
this.examSoreInfo = data.ExamSoreInfo;
this.subjectMatching = data.SubjectMatching;
this.groupMatching = data.GroupMatching;
this.specialtyMatching = data.SpecialtyMatching;
if (data.RecommendGroups != null && data.RecommendGroups != '') {
this.recommendGroups = data.RecommendGroups.split(",").join("、");
}else{
this.recommendGroups = "无"
}
if (data.SelectGroup != null) {
this.suggestGroupName = data.SelectGroup.SuggestGroupName;
this.suggestReason = data.SelectGroup.SuggestReason;
}
}else {
// 多元能力
this.multGroupList1 = data.MultGroupList1;
this.multResult = data.MultResult;
// 通用能力
this.universalGroupList1 = data.UniversalGroupList1;
this.universalResult = data.UniversalResult;
}
}
},
// 取消意向
cancleIntention(index,type, id) {
uni.showLoading({
title: "取消中"
})
api.doIntention(type,id,1).then((res)=>{
uni.hideLoading();
if(res.Result == 1){
this.queryStudentProfile()
// if(type == 2){
// this.intentionJobList.splice(index, 1);
// }else if(type == 3){
// this.intentionUniversityList.splice(index, 1);
// }else {
// this.intentionSpecialtyList.splice(index, 1);
// }
uni.showToast({
title: "取消成功",
icon: "success"
})
}
})
},
}
}
</script>
<style lang="scss">
$image-oss-url: "https://51xuanxiao.oss-cn-hangzhou.aliyuncs.com/Resource/xcx_sygh";
page {
background: url('#{$image-oss-url}/17.png') no-repeat;
background-size: contain;
background-color: #EEF1F8;
overflow-y:scroll;
}
</style>
<style lang="scss" scoped>
.head-bar {
position: relative;
text-align: center;
font-size: 36rpx;
font-weight: 600;
height: 60rpx;
line-height: 60rpx;
.go-back {
position: absolute;
left: 10rpx;
top: 0;
width: 60rpx;
height: 60rpx;
background: url("") center no-repeat;
background-size: 38rpx 38rpx;
}
}
.document {
padding-bottom: 60rpx;
.person-info {
position: relative;
display: flex;
align-items: center;
width: 664rpx;
height: 174rpx;
padding: 0 20rpx;
margin: 65rpx auto 20rpx;
border: 3px solid #FFFFFF;
background: #EDF5FE;
border-radius: 12px;
.img-wrap {
overflow: hidden;
width: 112rpx;
height: 112rpx;
border-radius: 50%;
margin-right: 20rpx;
image {
width: 100%;
height: 100%;
}
}
.txt-wrap {
.top {
display: flex;
align-items: flex-end;
margin-bottom: 10rpx;
.name {
color: #000000;
margin-right: 20rpx;
font-size: 36rpx;
}
.grades {
color: #666;
font-size: 26rpx;
}
}
.bottom {
color: #666;
font-size: 26rpx;
}
}
}
.section {
width: 670rpx;
padding: 30rpx 20rpx 40rpx;
background: #FFFFFF;
margin: 0 auto 24rpx;
border-radius: 12rpx;
.head {
display: flex;
justify-content: space-between;
.left-txt {
display: flex;
align-items: center;
font-size: 32rpx;
color: #000;
font-weight: 500;
.icon-1 {
width: 32rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-2 {
width: 27rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-3 {
width: 31rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-4 {
width: 32rpx;
height: 31rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-6 {
width: 32rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-7 {
width: 32rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-5 {
width: 32rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-8 {
width: 32rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-9 {
width: 26rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-10 {
width: 27rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-11 {
width: 32rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-12 {
width: 32rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
}
.right-txt {
font-size: 28rpx;
color: #999;
}
}
.content {
.report-wrap {
padding: 40rpx 0 0;
.row {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 35rpx;
&:last-child {
margin-bottom: 0;
}
.item {
.label {
color: #999999;
font-size: 28rpx;
}
.value {
color: #333;
font-size: 28rpx;
}
}
}
}
.course-list {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
padding: 40rpx 0 15rpx;
.item {
width: 320rpx;
background: #F8F9FB;
border-radius: 12rpx;
overflow: hidden;
margin-bottom: 20rpx;
.img-wrap {
display: flex;
justify-content: center;
overflow: hidden;
width: 320rpx;
height: 184rpx;
image {
height: 100%;
}
}
.title {
padding: 10rpx 20rpx 0;
height: 76rpx;
color: #333333;
font-size: 28rpx;
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 2;
/*! autoprefixer: ignore next */
-webkit-box-orient: vertical;
}
.count {
margin-top: 10rpx;
font-size: 24rpx;
color: #999999;
padding: 0 20rpx 20rpx;
}
}
}
.text-wrap {
padding: 40rpx 0 15rpx;
.row {
display: flex;
margin-bottom: 25rpx;
.label {
font-size: 28rpx;
color: #999;
}
.value {
width: 500rpx;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
font-size: 28rpx;
color: #333;
&.w450 {
width: 450rpx;
}
}
.long-value {
width: 450rpx;
font-size: 28rpx;
color: #333;
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 2;
/*! autoprefixer: ignore next */
-webkit-box-orient: vertical;
}
}
}
.list {
padding: 40rpx 0 15rpx;
.item {
display: flex;
align-items: center;
margin-bottom: 25rpx;
.name {
color: #1676FF;
font-size: 28rpx;
margin-right: 20rpx;
}
.cancel-btn {
width: 92rpx;
height: 48rpx;
line-height: 48rpx;
text-align: center;
background: #FCF6EC;
border-radius: 8rpx 8rpx 8rpx 8rpx;
border: 2rpx solid #FAECD8;
font-size: 26rpx;
color: #E6A23C;
}
}
}
.empty {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 40rpx 0 25rpx;
.icon {
width: 128rpx;
height: 128rpx;
background: url("") no-repeat;
background-size: 100%;
margin-bottom: 30rpx;
}
text {
font-size: 24rpx;
color: #A4B3E5;
}
}
}
.footer {
display: flex;
justify-content: center;
padding-top: 10rpx;
.btn {
width: 400rpx;
height: 80rpx;
text-align: center;
line-height: 80rpx;
background: #1676FF;
font-size: 28rpx;
color: #fff;
border-radius: 60rpx;
}
}
}
}
</style>

View File

@@ -0,0 +1,836 @@
<template>
<view class="document">
<view class="head-bar" :style="{'margin-top': barHeight + 5 + 'px'}">
<view class="go-back" @click="goback"></view>
<text>生涯档案</text>
</view>
<view style="display:none;" class="person-info">
<view class="img-wrap">
<image v-if="customInfo.AllHeadimgUrl" :src="customInfo.AllHeadimgUrl"></image>
<image v-else src="https://51xuanxiao.oss-cn-hangzhou.aliyuncs.com/Resource/xcx_sygh/avatar.png" mode=""></image>
</view>
<view class="txt-wrap">
<view class="top">
<view class="name">{{user.RealName}}</view>
<!-- <view class="grades">{{user.GradeName}}{{user.ClassName}}</view> -->
</view>
<view class="bottom">{{user.SchoolName}}</view>
</view>
</view>
<view style="margin-top:50rpx;" class="section">
<view class="head">
<view class="left-txt">
<view class="icon icon-1"></view>
意向职业
</view>
<view class="right-txt">
限5种
</view>
</view>
<view class="content" v-if="intentionJobList != null && intentionJobList.length > 0">
<view class="list">
<view class="item" v-for="(item, index) in intentionJobList" :key="index">
<text class="name">{{(index + 1) + '.' +item.Name}}</text>
<view class="cancel-btn" v-on:click="cancleIntention(index,2,item.EnCodeId)">取消</view>
</view>
</view>
</view>
<view class="content" v-else>
<view class="empty">
<view class="icon"></view>
<text>您还未添加意向职业</text>
</view>
</view>
<view class="footer">
<navigator url="/packageB/pages/job/index" class="btn">添加意向职业</navigator>
</view>
</view>
<view class="section">
<view class="head">
<view class="left-txt">
<view class="icon icon-4"></view>
职业兴趣测评
</view>
</view>
<view class="content" v-if="interestResult != null && interestResult !=''">
<view class="text-wrap">
<view class="row">
<text class="label">兴趣代码</text>
<view class="value">
<text v-for="(item, index) in interestCodeList" :key="index">
{{item}} <text v-if="index < interestCodeList.length -1"></text>
</text>
</view>
</view>
<view class="row">
<text class="label">对应学类</text>
<view class="value"><text v-for="(item, index) in interestRecommendSpecialty" :key="index">
{{item}} <text v-if="index < interestRecommendSpecialty.length -1"></text>
</text></view>
</view>
</view>
</view>
<view class="content" v-else>
<view class="empty">
<view class="icon"></view>
<text>您还未测评</text>
</view>
</view>
<view class="footer">
<navigator v-if="interestResult != null && interestResult !=''"
url="/packageB/pages/testReport/interestTestReport" class="btn">查看报告</navigator>
<navigator v-if="user.GradeLevel == 2 && !(interestResult != null && interestResult !='')"
url="/packageB/pages/pagesTest/interestTestTitle" class="btn">去测评</navigator>
<navigator v-if="user.GradeLevel == 1 && !(interestResult != null && interestResult !='')"
url="/packageB/pages/pagesTest/interestTestTitle" class="btn">去测评</navigator>
</view>
</view>
<view class="section">
<view class="head">
<view class="left-txt">
<view class="icon icon-6"></view>
工作价值观测评
</view>
</view>
<view class="content" v-if="workValueResult != null && workValueResult !=''">
<view class="text-wrap">
<view class="row">
<text class="label">高分价值观 </text>
<view class="long-value" v-if="workValueHight != null && workValueHight.length > 0">
<text v-for="(item, index) in workValueHight" :key="index">
{{item}} <text v-if="index < workValueHight.length -1"></text>
</text>
</view>
<view class="long-value" v-else>
<text></text>
</view>
</view>
</view>
</view>
<view class="content" v-else>
<view class="empty">
<view class="icon"></view>
<text>您还未测评</text>
</view>
</view>
<view class="footer">
<navigator class="btn" v-if="workValueResult != null && workValueResult !=''"
url="/packageB/pages/testReport/workValuesTestReport">查看报告</navigator>
<navigator class="btn" v-else url="/packageB/pages/pagesTest/workValuesTestTitle">去测评</navigator>
</view>
</view>
<view class="section">
<view class="head">
<view class="left-txt">
<view class="icon icon-8"></view>
人格测评
</view>
</view>
<view class="content" v-if="personResult != null && personResult !=''">
<view class="text-wrap">
<view class="row">
<text class="label">内外向</text>
<view class="value" v-if="personGroupList1 != null && personGroupList1.length > 0">
<text v-for="(item, index) in personGroupList1" :key="index">
{{item}} <text v-if="index < personGroupList1.length -1"></text>
</text>
</view>
<view class="value" v-else>
<text></text>
</view>
</view>
<view class="row">
<text class="label">人际关系</text>
<view class="value" v-if="personGroupList2 != null && personGroupList2.length > 0">
<text v-for="(item, index) in personGroupList2" :key="index">
{{item}} <text v-if="index < personGroupList2.length -1"></text>
</text>
</view>
<view class="value" v-else>
<text></text>
</view>
</view>
<view class="row">
<text class="label">严谨性</text>
<view class="value" v-if="personGroupList3 != null && personGroupList3.length > 0">
<text v-for="(item, index) in personGroupList3" :key="index">
{{item}} <text v-if="index < personGroupList3.length -1"></text>
</text>
</view>
<view class="value" v-else>
<text></text>
</view>
</view>
<view class="row">
<text class="label">开放性</text>
<view class="value" v-if="personGroupList4 != null && personGroupList4.length > 0">
<text v-for="(item, index) in personGroupList4" :key="index">
{{item}} <text v-if="index < personGroupList4.length -1"></text>
</text>
</view>
<view class="value" v-else>
<text></text>
</view>
</view>
</view>
</view>
<view class="content" v-else>
<view class="empty">
<view class="icon"></view>
<text>您还未测评</text>
</view>
</view>
<view class="footer">
<navigator class="btn" v-if="personResult != null && personResult !=''"
url="/packageB/pages/testReport/personalTestReport">查看报告</navigator>
<navigator class="btn" v-else url="/packageB/pages/pagesTest/personalTestTitle">去测评</navigator>
</view>
</view>
<view class="section" v-if="user.GradeLevel == 2">
<view class="head">
<view class="left-txt">
<view class="icon icon-9"></view>
个人选科报告
</view>
</view>
<view class="content">
<view class="report-wrap">
<view class="block" v-for="(item, index) in groupDataList" :key="index">
<view class="row">
<view class="item">
<text class="label" v-if="index==0">第一志愿</text>
<text class="label" v-if="index==1">第二志愿</text>
<text class="label" v-if="index==2">第三志愿</text>
<text class="value" v-text="item.GroupName != '' ? item.GroupName : '还未选择志愿'"></text>
</view>
</view>
<view class="row" v-show="viewScores">
<view class="item">
<text class="label">选科组合成绩</text>
<text class="value">{{item.Score}}</text>
</view>
</view>
<view class="row" v-show="viewScores">
<view class="item">
<text class="label">选科组合年级排名 </text>
<text class="value">{{item.GroupRank}}</text>
</view>
</view>
</view>
<view class="row" v-show="viewScores">
<view class="item">
<text class="label">物理</text>
<text class="value">{{examSoreInfo!=null?examSoreInfo.PhysicsScore + '分':'暂无分数'}}</text>
</view>
<view class="item">
<text class="label">化学</text>
<text class="value">{{examSoreInfo!=null?examSoreInfo.ChemistryScore + '分':'暂无分数'}}</text>
</view>
<view class="item">
<text class="label">生物</text>
<text class="value">{{examSoreInfo!=null?examSoreInfo.BiologyScore + '分':'暂无分数'}}</text>
</view>
</view>
<view class="row" v-show="viewScores">
<view class="item">
<text class="label">历史</text>
<text class="value">{{examSoreInfo!=null?examSoreInfo.HistoryScore + '分':'暂无分数'}}</text>
</view>
<view class="item">
<text class="label">地理</text>
<text class="value">{{examSoreInfo!=null?examSoreInfo.GeographyScore + '分':'暂无分数'}}</text>
</view>
<view class="item">
<text class="label">政治</text>
<text class="value">{{examSoreInfo!=null?examSoreInfo.PoliticsScore + '分':'暂无分数'}}</text>
</view>
</view>
<view class="row" v-show="scoreMatch">
<view class="item">
<text class="label">选科组合成绩匹配度 </text>
<text class="value" v-if="groupMatching==0">暂无数据</text>
<text class="value" v-if="groupMatching==1"></text>
<text class="value" v-if="groupMatching==2"></text>
<text class="value" v-if="groupMatching==3"></text>
</view>
</view>
<view class="row" v-show="subjectMatch">
<view class="item">
<text class="label">学科信心匹配度</text>
<text class="value" v-if="subjectMatching==0">暂无数据</text>
<text class="value" v-if="subjectMatching==1"></text>
<text class="value" v-if="subjectMatching==2"></text>
<text class="value" v-if="subjectMatching==3"></text>
</view>
</view>
<view class="row" v-show="specialtyUniversityMatch">
<view class="item">
<text class="label">意向专业院校与选科组合匹配度 </text>
<text class="value" v-if="specialtyMatching==0">暂无数据</text>
<text class="value" v-if="specialtyMatching==1"></text>
<text class="value" v-if="specialtyMatching==2"></text>
<text class="value" v-if="specialtyMatching==3"></text>
</view>
</view>
<view class="row">
<view class="item">
<text class="label">意向专业 </text>
<text class="value"
v-if="intentionSpecialtyList != null && intentionSpecialtyList.length > 0"> <text
v-if="intentionSpecialtyList.length > 0"
v-for="(item, index) in intentionSpecialtyList" :key="index">
{{item.Name}} <text v-if="index < intentionSpecialtyList.length -1"></text>
</text></text>
<text class="value" v-else>您还未添加意向信息</text>
</view>
</view>
<view class="row">
<view class="item">
<text class="label">意向院校</text>
<text class="value"
v-if="intentionUniversityList != null && intentionUniversityList.length > 0">
<text v-for="(item, index) in intentionUniversityList" :key="index">{{item.Name}} <text
v-if="index < intentionUniversityList.length -1"></text></text>
</text>
<text class="value" v-else>您还未添加意向信息</text>
</view>
</view>
<view class="row">
<view class="item">
<text class="label">系统推荐选科组合 </text>
<text class="value">{{recommendGroups}}</text>
</view>
</view>
<view class="row">
<view class="item">
<text class="label">学校建议选科 </text>
<text class="value" v-if="suggestGroupName != null">{{suggestGroupName}}
{{suggestReason}}</text>
<text class="value" v-else>学校暂无建议</text>
</view>
</view>
</view>
</view>
</view>
</view>
</template>
<script>
import api from "@/apiB/user.js";
export default {
data() {
return {
refreshIfNeeded: false, //是否返回刷新
barHeight: wx.getWindowInfo().statusBarHeight,
user: uni.getStorageSync("userInfo").user,
customInfo: uni.getStorageSync("customInfo"),
intentionJobList: [], //意向职业
intentionSpecialtyList: [], //意向专业
intentionUniversityList: [], //意向院校
interestCodeList: [], //兴趣码
interestRecommendSpecialty: [], //兴趣码
interestResult: "", //兴趣测评结果
customerGroup1: [], //学科效能
customerGroup2: [], //学科效能
customerResult: "", //学科效能
workValueHight: [], //工作价值
workValueResult: "", //工作价值
multHight: "", //多元智能
multResult: "", //多元智能
personGroupList1: [], //人格
personGroupList2: [], //人格
personGroupList3: [], //人格
personGroupList4: [], //人格
personResult: "", //人格
viewScores: false, //是否查看成绩
groupDataList: [], //志愿
examSoreInfo: {}, //科目成绩
subjectMatching: 0, //学科信心匹配度 0无1低 2中 3高
groupMatching: 0, //选科组合匹配度 0无1低 2中 3高
specialtyMatching: 0, //意向专业院校匹配度 0无1低 2中 3高
recommendGroups: "", //推荐组合
suggestGroupName: null, //学校建议组合
suggestReason: null, //学校建议原因
scoreMatch: false,
subjectMatch: false,
specialtyUniversityMatch: false,
myStudyCourseList: [],
}
},
onShow() {
// let pages = getCurrentPages(); // 获取当前页面栈
// let currentPage = pages[pages.length - 1]; // 当前页面
// //修改后刷新
// if (currentPage.data.refreshIfNeeded) {
// currentPage.data.refreshIfNeeded = false;
// }
this.queryStudentProfile();
this.user = uni.getStorageSync("userInfo").user;
console.log("user====",this.user);
this.customInfo = uni.getStorageSync('customInfo');
},
created() {
// this.queryStudentProfile()
},
methods: {
goback() {
uni.navigateBack(-1);
},
// 获取个人档案
queryStudentProfile() {
uni.showLoading({
title: "加载中"
})
api.queryStudentProfile().then((res) => {
uni.hideLoading();
if (res.Result == 1) {
let data = res.Data;
console.log("datas====",data);
// 意向职业
this.intentionJobList = data.IntentionJobList;
// 意向专业
this.intentionSpecialtyList = data.IntentionSpecialtyList;
// 意向院校
this.intentionUniversityList = data.IntentionUniversityList;
// 兴趣测评
this.interestCodeList = data.InterestCodeList;
this.interestRecommendSpecialty = data.InterestRecommendSpecialty;
this.interestResult = data.InterestResult;
// 学科信心测评
this.customerGroup1 = data.CustomerGroup1;
this.customerGroup2 = data.CustomerGroup2;
this.customerResult = data.CustomerResult;
// 工作价值
this.workValueHight = data.WorkValueHight;
this.workValueResult = data.WorkValueResult;
// 多元智能
this.multHight = data.MultHight;
this.multResult = data.MultResult;
// 人格测评
this.personGroupList1 = data.PersonGroupList1;
this.personGroupList2 = data.PersonGroupList2;
this.personGroupList3 = data.PersonGroupList3;
this.personGroupList4 = data.PersonGroupList4;
this.personResult = data.PersonResult;
// 个人选科报告
this.viewScores = data.ViewScores;
this.scoreMatch = data.ScoreMatch;
this.subjectMatch = data.SubjectMatch;
this.specialtyUniversityMatch = data.SpecialtyUniversityMatch;
this.groupDataList = data.GroupDataList;
this.examSoreInfo = data.ExamSoreInfo;
this.subjectMatching = data.SubjectMatching;
this.groupMatching = data.GroupMatching;
this.specialtyMatching = data.SpecialtyMatching;
if (data.RecommendGroups != null && data.RecommendGroups != '') {
this.recommendGroups = data.RecommendGroups.split(",").join("、");
} else {
this.recommendGroups = "无"
}
if (data.SelectGroup != null) {
this.suggestGroupName = data.SelectGroup.SuggestGroupName;
this.suggestReason = data.SelectGroup.SuggestReason;
}
}
})
},
// 取消意向
cancleIntention(index, type, id) {
uni.showLoading({
title: "取消中"
})
api.doIntention(type, id, 1).then((res) => {
uni.hideLoading();
if (res.Result == 1) {
this.queryStudentProfile()
// if(type == 2){
// this.intentionJobList.splice(index, 1);
// }else if(type == 3){
// this.intentionUniversityList.splice(index, 1);
// }else {
// this.intentionSpecialtyList.splice(index, 1);
// }
uni.showToast({
title: "取消成功",
icon: "success"
})
}
})
},
}
}
</script>
<style lang="scss">
$image-oss-url: "https://51xuanxiao.oss-cn-hangzhou.aliyuncs.com/Resource/xcx_sygh";
page {
background: url('#{$image-oss-url}/17.png') no-repeat;
background-size: contain;
background-color: #EEF1F8;
overflow-y:scroll;
}
</style>
<style lang="scss" scoped>
.head-bar {
position: relative;
text-align: center;
font-size: 36rpx;
font-weight: 600;
height: 60rpx;
line-height: 60rpx;
.go-back {
position: absolute;
left: 10rpx;
top: 0;
width: 60rpx;
height: 60rpx;
background: url("") center no-repeat;
background-size: 38rpx 38rpx;
}
}
.document {
padding-bottom: 60rpx;
.person-info {
position: relative;
display: flex;
align-items: center;
width: 664rpx;
height: 174rpx;
padding: 0 20rpx;
margin: 65rpx auto 20rpx;
border: 3px solid #FFFFFF;
background: #EDF5FE;
border-radius: 12px;
.img-wrap {
overflow: hidden;
width: 112rpx;
height: 112rpx;
border-radius: 50%;
margin-right: 20rpx;
image {
width: 100%;
height: 100%;
}
}
.txt-wrap {
.top {
display: flex;
align-items: flex-end;
margin-bottom: 10rpx;
.name {
color: #000000;
margin-right: 20rpx;
font-size: 36rpx;
}
.grades {
color: #666;
font-size: 26rpx;
}
}
.bottom {
color: #666;
font-size: 26rpx;
}
}
}
.section {
width: 670rpx;
padding: 30rpx 20rpx 40rpx;
background: #FFFFFF;
margin: 0 auto 24rpx;
border-radius: 12rpx;
.head {
display: flex;
justify-content: space-between;
.left-txt {
display: flex;
align-items: center;
font-size: 32rpx;
color: #000;
font-weight: 500;
.icon-1 {
width: 32rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-2 {
width: 27rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-3 {
width: 31rpx;
height: 32rpx;
margin-right: 10rpx;
//background: url("") no-repeat;
background-size: 100%;
}
.icon-4 {
width: 32rpx;
height: 31rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-6 {
width: 32rpx;
height: 31rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-7 {
width: 32rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-5 {
width: 32rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-8 {
width: 27rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-9 {
width: 26rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
.icon-10 {
width: 27rpx;
height: 32rpx;
margin-right: 10rpx;
background: url("") no-repeat;
background-size: 100%;
}
}
.right-txt {
font-size: 28rpx;
color: #999;
}
}
.content {
.report-wrap {
padding: 40rpx 0 0;
.row {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 35rpx;
&:last-child {
margin-bottom: 0;
}
.item {
.label {
color: #999999;
font-size: 28rpx;
}
.value {
color: #333;
font-size: 28rpx;
}
}
}
}
.course-list {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
padding: 40rpx 0 15rpx;
.item {
width: 320rpx;
background: #F8F9FB;
border-radius: 12rpx;
overflow: hidden;
margin-bottom: 20rpx;
.img-wrap {
display: flex;
justify-content: center;
overflow: hidden;
width: 320rpx;
height: 184rpx;
image {
height: 100%;
}
}
.title {
padding: 10rpx 20rpx 0;
height: 76rpx;
color: #333333;
font-size: 28rpx;
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 2;
/*! autoprefixer: ignore next */
-webkit-box-orient: vertical;
}
.count {
margin-top: 10rpx;
font-size: 24rpx;
color: #999999;
padding: 0 20rpx 20rpx;
}
}
}
.text-wrap {
padding: 40rpx 0 15rpx;
.row {
display: flex;
margin-bottom: 25rpx;
.label {
font-size: 28rpx;
color: #999;
}
.value {
width: 500rpx;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
font-size: 28rpx;
color: #333;
&.w450 {
width: 450rpx;
}
}
.long-value {
width: 450rpx;
font-size: 28rpx;
color: #333;
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 2;
/*! autoprefixer: ignore next */
-webkit-box-orient: vertical;
}
}
}
.list {
padding: 40rpx 0 15rpx;
.item {
display: flex;
align-items: center;
margin-bottom: 25rpx;
.name {
color: #1677ff;
font-size: 28rpx;
margin-right: 20rpx;
}
.cancel-btn {
width: 92rpx;
height: 48rpx;
line-height: 48rpx;
text-align: center;
background: #FCF6EC;
border-radius: 8rpx 8rpx 8rpx 8rpx;
border: 2rpx solid #FAECD8;
font-size: 26rpx;
color: #E6A23C;
}
}
}
.empty {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 40rpx 0 25rpx;
.icon {
width: 128rpx;
height: 128rpx;
background: url("") no-repeat;
background-size: 100%;
margin-bottom: 30rpx;
}
text {
font-size: 24rpx;
color: #A4B3E5;
}
}
}
.footer {
display: flex;
justify-content: center;
padding-top: 10rpx;
.btn {
width: 400rpx;
height: 80rpx;
text-align: center;
line-height: 80rpx;
background: #1677ff;
font-size: 28rpx;
color: #fff;
border-radius: 60rpx;
}
}
}
}
</style>

View File

@@ -0,0 +1,656 @@
<template>
<view class="index-wrap">
<view class="head-bar" :style="{'margin-top': barHeight + 5 + 'px'}">
<view class="go-back" @click="goBack"></view>
<text>smart目标制定</text>
</view>
<view class="content">
<view class="banner-wrap"></view>
<view class="desc">
SMART法则是目标设定和任务管理的一种结构化方法 用于设定和分析目标的可行性其核心是通过五个关键原则实现目标的科学设定与执行:
</view>
<view class="smart-item s-code">
<view class="code">
S
</view>
<view class="info">
<view class="title">
目标具体性
</view>
<view class="txt">
在大学四年内掌握英语教学法教育心理学等专业知识具备独立设计和实施英语课程的教学能力
</view>
</view>
</view>
<view class="smart-item m-code">
<view class="code">
M
</view>
<view class="info">
<view class="title">
目标可测量性
</view>
<view class="txt">
通过参加英语教师资格认证考试获得相关证书每年至少发表一篇英语教学方面的论文或参加一次学术研讨会
</view>
</view>
</view>
<view class="smart-item a-code">
<view class="code">
A
</view>
<view class="info">
<view class="title">
目标可实现性
</view>
<view class="txt">
参加培训课程阅读专业书籍进行教学实践等确保每周投入一定的时间进行学习和实践
</view>
</view>
</view>
<view class="smart-item r-code">
<view class="code">
R
</view>
<view class="info">
<view class="title">
目标相关性
</view>
<view class="txt">
考虑自己的英语水平和教学经验目标符合个人能力和职业发展规划同时关注英语教育行业的动态和趋势确保目标具有前瞻性
</view>
</view>
</view>
<view class="smart-item t-code">
<view class="code">
T
</view>
<view class="info">
<view class="title">
目标时限性
</view>
<view class="txt">
一年内完成英语教师资格认证考试的学习准备两年内积累一定的教学经验三年内发表第一篇教学论文等
</view>
</view>
</view>
<view class="target-content">
<view class="target-tabbar">
<view class="item" :class="checkedTargetCode ==item.EncodeId?'on':''" v-for="(item,index) in targetList" :key="index" @click="changeTarget(item)">
<text v-text="tabs[index]"></text>
<view class="del-btn" @click="delTarget(item)"></view>
</view>
<view class="add-btn" :class="checkedTargetCode ==-1?'on':''" v-if="targetList.length < 5" @click="addTarget">
+ 新增目标
</view>
</view>
<view class="form-wrap" >
<view class="form-item">
<view class="label">
目标描述
</view>
<view class="input-wrap">
<textarea v-model="targetForm.TargetDesc"
placeholder="如:在未来三年内成功考取国内知名大学计算机专业的硕士研究生,并在研究生期间发表至少一篇高水平学术论文"></textarea>
</view>
</view>
<view class="form-item">
<view class="label">
目标类型
</view>
<view class="check-wrap">
<view class="checked-item" @click="targetForm.TargetType = 1">
<view class="icon" :class="targetForm.TargetType == 1?'on':''"></view>
<text class="text">就业型</text>
</view>
<view class="checked-item" @click="targetForm.TargetType = 2">
<view class="icon" :class="targetForm.TargetType == 2?'on':''"></view>
<text class="text">创业型</text>
</view>
<view class="checked-item" @click="targetForm.TargetType = 3">
<view class="icon" :class="targetForm.TargetType == 3?'on':''"></view>
<text class="text">国内升学型</text>
</view>
<view class="checked-item" @click="targetForm.TargetType = 4">
<view class="icon" :class="targetForm.TargetType == 4?'on':''"></view>
<text class="text">国外升学型</text>
</view>
</view>
</view>
<view class="form-item">
<view class="label">
具体性
</view>
<view class="input-wrap">
<textarea v-model="targetForm.Targetspecificity" placeholder="该目标足够具体明确吗?请说明"></textarea>
</view>
</view>
<view class="form-item">
<view class="label">
可测量性
</view>
<view class="input-wrap">
<textarea v-model="targetForm.Measurability" placeholder="该目标的结果如何评估,是否可量化?请说明"></textarea>
</view>
</view>
<view class="form-item">
<view class="label">
可实现性
</view>
<view class="input-wrap">
<textarea v-model="targetForm.Realizability" placeholder="该目标是否考虑自身的条件和外部环境,真的可以实现吗?请说明"></textarea>
</view>
</view>
<view class="form-item">
<view class="label">
相关性
</view>
<view class="input-wrap">
<textarea v-model="targetForm.Correlation" placeholder="该目标符合你自己的兴趣、价值观与未来的人生规划吗?请说明"></textarea>
</view>
</view>
<view class="form-item">
<view class="label">
时限性
</view>
<view class="input-wrap">
<textarea v-model="targetForm.Timeliness" placeholder="该目标是否有明确的时间规划?请说明"></textarea>
</view>
</view>
<view class="tip">
如果分析不下去说明目标不可行需要优化或
重新设定目标
</view>
<view class="btn-wrap">
<view class="commit-btn" @click="saveTarget">
确认提交
</view>
<view @click="goPlan" class="nav-btn">
前往制定学习计划
</view>
</view>
</view>
</view>
</view>
</view>
</template>
<script>
import api from "@/apiB/studentProfile.js"
export default {
data() {
return {
barHeight: wx.getWindowInfo().statusBarHeight,
tabs:['目标一 ', '目标二 ', '目标三 ', '目标四 ', '目标五 '],
targetList: [],////目标列表
checkedTargetCode: "",//// 目标码
newTargetParams: {
Id: 0,
TargetDesc: "",
TargetType: "",
Targetspecificity: "",
Measurability: "",
Realizability: "",
Correlation: "",
Timeliness: "",
},//新增目标字段
targetForm: {},//当前选中的目标
}
},
created() {
this.querySmartTargets();
},
methods: {
goPlan(){
if(this.targetList.length==0){
uni.showToast({
title: "请先新增目标",
icon: "none"
})
return;
}
uni.navigateTo({
url:"/packageB/pages/userCenter/learningPlan"
})
},
goBack(){
uni.navigateBack(-1);
},
// 添加目标
addTarget(){
this.targetForm = {
Id: 0,
TargetDesc: "",
TargetType: "",
Targetspecificity: "",
Measurability: "",
Realizability: "",
Correlation: "",
Timeliness: "",
};
this.checkedTargetCode = -1;
},
// 保存目标
async saveTarget(){
const res = await api.saveSmartTarget(this.targetForm);
if (res.Result == 1) {
uni.showToast({
title: "保存成功",
icon: "success"
})
this.querySmartTargets();
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
// 切换目标标签
changeTarget(ITEM){
if(ITEM.EncodeId == this.checkedTargetCode){
return;
}
this.checkedTargetCode = ITEM.EncodeId;
this.targetForm = this.targetList.filter(item=>item.EncodeId == ITEM.EncodeId)[0];
},
// 删除目标
async delTarget(ITEM){
await new Promise((resolve,reject)=>{
uni.showModal({
title: '提示',
content: '是否确认删除该目标',
confirmText: '确定',
cancelText: '取消',
success: (res)=> {
if (res.confirm) {
resolve();
} else if (res.cancel) {
console.log('用户点击取消');
}
}
});
})
const res = await api.deleteSmartTarg(ITEM.EncodeId);
if (res.Result == 1) {
uni.showToast({
title: '删除成功',
icon: 'success'
});
this.checkedTargetCode="";
this.targetForm={
Id: 0,
TargetDesc: "",
TargetType: "",
Targetspecificity: "",
Measurability: "",
Realizability: "",
Correlation: "",
Timeliness: "",
};
this.querySmartTargets();
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
// 获取
async querySmartTargets() {
const res = await api.querySmartTargets();
if (res.Result == 1) {
this.targetList = res.Data;
if(res.Data.length > 0){
if(this.checkedTargetCode == ""){
this.checkedTargetCode = res.Data[0].EncodeId;
this.targetForm = res.Data[0];
}else if(this.checkedTargetCode == -1){
this.checkedTargetCode = res.Data[res.Data.length-1].EncodeId;
this.targetForm = res.Data[res.Data.length-1];
}else {
this.targetForm = this.targetList.filter(item=>item.EncodeId == this.checkedTargetCode)[0];
}
}
} 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 api1.saveUserBasisInfo(mobileCode, data);
uni.hideLoading();
if (res.Result == 1) {
uni.navigateBack()
} else {
uni.showToast({
title: res.Message,
icon: "none"
})
}
},
}
}
</script>
<style lang="scss">
$image-oss-url: "https://51xuanxiao.oss-cn-hangzhou.aliyuncs.com/Resource/xcx_sygh";
page {
background: #fff url("#{$image-oss-url}/17.png") no-repeat;
background-size: contain;
overflow-y: scroll;
}
</style>
<style lang="scss" scoped>
$image-oss-url: "https://51xuanxiao.oss-cn-hangzhou.aliyuncs.com/Resource/xcx_sygh";
.head-bar {
position: relative;
text-align: center;
font-size: 36rpx;
font-weight: 600;
height: 60rpx;
line-height: 60rpx;
.go-back {
position: absolute;
left: 10rpx;
top: 0;
width: 60rpx;
height: 60rpx;
background: url("") center no-repeat;
background-size: 38rpx 38rpx;
}
}
.index-wrap {
.content {
padding-top: 60rpx;
padding-bottom: 60rpx;
.banner-wrap {
width: 750rpx;
height: 423rpx;
background: url("#{$image-oss-url}/gaoxiao/academicEvaluation/smart-banner.png");
background-size: 100%;
margin-bottom: 50rpx;
}
.desc {
margin-bottom: 40rpx;
font-size: 28rpx;
line-height: 48rpx;
color: #666666;
padding: 0 30rpx;
}
.smart-item {
padding: 0 30rpx 0 55rpx;
position: relative;
margin-bottom: 25rpx;
.code {
position: absolute;
left: 30rpx;
top: 50%;
transform: translateY(-50%);
width: 86rpx;
height: 110rpx;
padding-right: 20rpx;
text-align: center;
line-height: 110rpx;
font-size: 50rpx;
color: #fff;
}
.info {
width: 530rpx;
padding: 30rpx 30rpx 30rpx 106rpx;
background-color: #ffedef;
border-radius: 10rpx;
.title {
font-size: 28rpx;
font-weight: 600;
color: #333333;
margin-bottom: 20rpx;
}
.txt {
font-size: 28rpx;
line-height: 40rpx;
color: #999999;
}
}
&.s-code {
.code {
background: url("#{$image-oss-url}/gaoxiao/academicEvaluation/smart-s.png") no-repeat;
background-size: 100%;
}
.info {
background: #ffedef;
}
}
&.m-code {
.code {
background: url("#{$image-oss-url}/gaoxiao/academicEvaluation/smart-m.png") no-repeat;
background-size: 100%;
}
.info {
background: #fff4e5;
}
}
&.a-code {
.code {
background: url("#{$image-oss-url}/gaoxiao/academicEvaluation/smart-a.png") no-repeat;
background-size: 100%;
}
.info {
background: #e9f8e0;
}
}
&.r-code {
.code {
background: url("#{$image-oss-url}/gaoxiao/academicEvaluation/smart-r.png") no-repeat;
background-size: 100%;
}
.info {
background: #edf3ff;
}
}
&.t-code {
.code {
background: url("#{$image-oss-url}/gaoxiao/academicEvaluation/smart-t.png") no-repeat;
background-size: 100%;
}
.info {
background: #fcedff;
}
}
}
.target-content {
padding: 0 30rpx;
.target-tabbar {
border-top: 2rpx solid #eee;
padding-top: 50rpx;
margin-bottom: 50rpx;
display: flex;
flex-wrap: wrap;
.item {
position: relative;
width: 205rpx;
height: 64rpx;
line-height: 64rpx;
text-align: center;
border-radius: 34rpx;
border: solid 2rpx #eeeeee;
font-size: 28rpx;
color: #999999;
margin-right: 15rpx;
margin-bottom: 15rpx;
&.on {
color: #1676FF;
border-color: #1676FF;
}
.del-btn {
position: absolute;
right: 10rpx;
top: 50%;
transform: translateY(-50%);
width: 48rpx;
height: 48rpx;
z-index: 8;
background: #fff url("") center no-repeat;
background-size: 60%;
}
}
.add-btn {
width: 155rpx;
height: 64rpx;
text-align: center;
line-height: 64rpx;
font-size: 28rpx;
color: #1676FF;
border-radius: 34rpx;
border: solid 2rpx #fff;
&.on {
border-color: #1676FF;
}
}
}
.form-wrap {
.form-item {
.label {
font-size: 28rpx;
color: #333333;
margin-bottom: 30rpx;
}
.check-wrap {
display: flex;
flex-wrap: wrap;
.checked-item {
width: 50%;
display: flex;
align-items: center;
margin-bottom: 30rpx;
.icon {
width: 20rpx;
height: 20rpx;
border-radius: 6rpx;
margin-right: 10rpx;
border: solid 2rpx #787a7c;
&.on {
width: 24rpx;
height: 24rpx;
border: none;
background: url("") no-repeat;
background-size: 100%;
}
}
.text {
font-size: 28rpx;
color: #787a7c;
}
}
}
.input-wrap {
margin-bottom: 40rpx;
textarea {
width: 650rpx;
height: 120rpx;
padding: 20rpx;
background-color: #ffffff;
border-radius: 6rpx;
border: solid 2rpx #eeeeee;
resize: none;
font-size: 28rpx;
line-height: 40rpx;
&::-webkit-input-placeholder {
color: #999999;
font-size: 28rpx;
}
}
}
}
.tip {
font-size: 28rpx;
line-height: 40rpx;
color: #1676FF;
margin-bottom: 50rpx;
}
.btn-wrap {
display: flex;
justify-content: space-between;
align-items: center;
padding-bottom: 50rpx;
.commit-btn {
width: 335rpx;
height: 80rpx;
background-color: #1676FF;
border-radius: 40rpx;
font-size: 28rpx;
color: #fff;
text-align: center;
line-height: 80rpx;
}
.nav-btn {
width: 331rpx;
height: 76rpx;
font-size: 28rpx;
text-align: center;
line-height: 76rpx;
background-color: #fff;
border-radius: 40rpx;
color: #1676FF;
border: solid 2rpx #1676FF;
}
}
}
}
}
}
</style>