410 lines
10 KiB
Vue
Raw Normal View History

2025-06-14 14:08:44 +08:00
<template>
<BasicLayout>
<view class="container">
<uni-card :is-shadow="false" is-full>
<view class="header">
2025-08-02 11:15:22 +08:00
<text class="score">我的得分: {{ totalScore }}</text>
2025-06-14 14:08:44 +08:00
<view class="status">
<text>我的状态: </text>
<view class="status-indicator"></view>
2025-08-02 11:15:22 +08:00
<view class="review-count" v-if="reviewingCountComputed > 0">
{{ reviewingCountComputed }}项在审核
2025-06-14 14:08:44 +08:00
</view>
</view>
</view>
</uni-card>
<uni-card :is-shadow="false" is-full margin="10px 0 0 0">
<view class="list-header">
<text class="category-header">分类</text>
<text class="value-header">分值</text>
</view>
2025-08-02 11:15:22 +08:00
<view v-if="loading" class="loading-container">
<text class="loading-text">加载中...</text>
</view>
2025-06-14 14:08:44 +08:00
<view
2025-08-02 11:15:22 +08:00
v-else
2025-06-14 14:08:44 +08:00
class="list-item"
v-for="(item, index) in evaluationItems"
:key="index"
>
<view
class="flex-row items-center justify-between w-full"
@click="handleItemClick(item)"
>
<view class="category-name">{{ item.category }}</view>
<view class="flex-row items-center">
<text class="value">{{ item.value }}</text>
<view class="review-badge" v-if="item.isUnderReview"></view>
<u-icon name="arrow-right" size="16" color="#999"></u-icon
></view>
</view>
</view>
</uni-card>
</view>
<template #bottom>
<view class="white-bg-color py-5">
<view class="flex-row items-center pb-10 pt-5">
<u-button
2025-08-02 11:15:22 +08:00
text="个人荣誉申请"
2025-06-14 14:08:44 +08:00
class="ml-15 mr-7"
2025-08-02 11:15:22 +08:00
type="primary"
2025-06-14 14:08:44 +08:00
@click="scgrry"
/>
<u-button
2025-08-02 11:15:22 +08:00
text="公开课获奖申请"
2025-06-14 14:08:44 +08:00
class="mr-15 mr-7"
type="primary"
@click="scgkkhj"
/>
</view>
</view>
</template>
</BasicLayout>
</template>
<script lang="ts" setup>
2025-08-02 11:15:22 +08:00
import { ref, computed, onMounted } from "vue";
import { jsFindPageJfApi, inspectItemFindAllApi } from "@/api/base/server";
// 响应式数据
const evaluationItems = ref([]);
const totalScore = ref(0);
const loading = ref(false);
2025-06-14 14:08:44 +08:00
// 计算正在审核的项目数量
2025-08-02 11:15:22 +08:00
const reviewingCountComputed = computed(() => {
2025-06-14 14:08:44 +08:00
return evaluationItems.value.filter(item => item.isUnderReview).length;
});
2025-08-02 11:15:22 +08:00
// 获取检查项数据
const loadInspectItems = async () => {
try {
const res = await inspectItemFindAllApi({ type: 2 });
if (res && res.resultCode === 1 && res.result) {
return res.result;
}
return [];
} catch (error) {
console.error('获取检查项失败:', error);
return [];
}
};
// 获取教师积分数据
const loadTeacherScore = async () => {
loading.value = true;
try {
// 从本地缓存获取当前教师ID
const userDataStr = uni.getStorageSync('app-user');
let teacherId = '';
let userData = null;
if (userDataStr) {
try {
userData = typeof userDataStr === 'string' ? JSON.parse(userDataStr) : userDataStr;
if (userData && userData.jsData && userData.jsData.id) {
teacherId = userData.jsData.id;
console.log('当前教师ID:', teacherId);
console.log('教师信息:', userData.jsData);
} else {
console.error('未找到教师ID信息');
uni.showToast({
title: '未找到教师信息',
icon: 'none'
});
return;
}
} catch (error) {
console.error('解析用户数据失败:', error);
uni.showToast({
title: '用户数据解析失败',
icon: 'none'
});
return;
}
} else {
console.error('未找到用户数据');
uni.showToast({
title: '未找到用户数据',
icon: 'none'
});
return;
}
// 设置查询参数,获取当前教师的积分数据
const params = {
startTime: new Date().getFullYear() + '-01-01', // 当年开始时间
endTime: new Date().getFullYear() + '-12-31', // 当年结束时间
pageSize: 100, // 增大页面大小,确保能获取到当前教师数据
pageNum: 1,
id: teacherId // 使用教师ID过滤
};
const res = await jsFindPageJfApi(params);
console.log('查询参数:', params);
console.log('当前教师ID:', teacherId);
console.log('API返回结果:', res);
if (res && res.rows && res.rows.length > 0) {
// 查找当前教师的数据
const teacherData = res.rows.find(row => row.id === teacherId);
if (!teacherData) {
console.warn('未找到当前教师的积分数据');
uni.showToast({
title: '未找到积分数据',
icon: 'none'
});
return;
}
console.log('找到的教师积分数据:', teacherData);
console.log('教师姓名:', teacherData.jsxm);
console.log('总分:', teacherData.totalScore);
console.log('积分汇总数据:', teacherData.summaries);
// 获取检查项数据
const inspectItems = await loadInspectItems();
if (inspectItems.length === 0) {
console.warn('未获取到检查项数据');
return;
}
console.log('检查项数据:', inspectItems);
// 构建评价项目数据参考后端界面的getScore方法
const items = [];
let total = 0;
console.log('检查项数据:', inspectItems);
console.log('教师积分汇总:', teacherData.summaries);
inspectItems.forEach((item, index) => {
// 参考后端界面的getScore方法逻辑
let score = 0;
let num = 0;
if (teacherData.summaries && teacherData.summaries.length > 0) {
for (let i = 0; i < teacherData.summaries.length; i++) {
const summaryId = teacherData.summaries[i].inspectItemId;
const itemId = item.id;
// 使用宽松比较,并考虑大小写
if (summaryId == itemId || summaryId?.toUpperCase() == itemId?.toUpperCase()) {
score = parseFloat(teacherData.summaries[i].score) || 0;
num = parseInt(teacherData.summaries[i].num) || 0;
console.log(`✅ 匹配成功: ${item.name}, score=${score}, num=${num}`);
break;
}
}
}
items.push({
id: item.id,
category: item.name,
value: score,
isUnderReview: num > 0, // 如果有记录数,说明在审核中
num: num
});
total += score;
});
evaluationItems.value = items;
totalScore.value = total;
console.log('处理后的积分数据:', {
items: items,
totalScore: total,
reviewingCount: reviewingCountComputed.value
});
} else {
console.warn('查询结果为空或格式不正确');
uni.showToast({
title: '未获取到积分数据',
icon: 'none'
});
}
} catch (error) {
console.error('获取教师积分失败:', error);
uni.showToast({
title: '获取积分数据失败',
icon: 'none'
});
} finally {
loading.value = false;
}
};
2025-06-14 14:08:44 +08:00
function handleItemClick(item: any) {
2025-08-02 11:15:22 +08:00
// 检查该项积分是否为0
if (!item.value || item.value === 0 || item.value === '0' || item.value === 0.0 || item.value === null || item.value === undefined) {
uni.showToast({
title: '积分为0',
icon: 'none',
duration: 2000
});
return;
}
const url = `/pages/view/routine/JiFenPingJia/detail?inspectItemId=${item.id}`;
2025-06-14 14:08:44 +08:00
uni.navigateTo({
2025-08-02 11:15:22 +08:00
url: url,
2025-06-14 14:08:44 +08:00
});
}
function scgrry() {
uni.navigateTo({
2025-08-02 11:15:22 +08:00
url: `/pages/view/routine/JiFenPingJia/PersonalHonor`,
2025-06-14 14:08:44 +08:00
});
}
function scgkkhj() {
uni.navigateTo({
2025-08-02 11:15:22 +08:00
url: `/pages/view/routine/JiFenPingJia/PublicClassAwards`,
2025-06-14 14:08:44 +08:00
});
}
2025-08-02 11:15:22 +08:00
// 页面加载时获取数据
onMounted(() => {
loadTeacherScore();
});
2025-06-14 14:08:44 +08:00
</script>
<style scoped lang="scss">
.container {
background-color: #f8f8f8;
min-height: 100vh;
padding: 15px;
box-sizing: border-box;
}
.header {
display: flex;
justify-content: space-between;
align-items: center;
padding: 10px 0; // Adjusted padding
font-size: 16px;
}
.score {
color: #333;
font-weight: bold;
}
.status {
display: flex;
align-items: center;
color: #666;
}
.status-indicator {
width: 12px;
height: 12px;
background-color: #4caf50; // Green color from the image
margin-left: 8px;
border-radius: 2px; // Slightly rounded corners
}
.review-count {
background-color: #fff2e8;
color: #ff6b35;
font-size: 12px;
padding: 2px 8px;
border-radius: 12px;
margin-left: 12px;
border: 1px solid #ff6b35;
font-weight: bold;
}
2025-08-02 11:15:22 +08:00
.loading-container {
display: flex;
justify-content: center;
align-items: center;
padding: 40rpx 0;
}
.loading-text {
color: #999;
font-size: 28rpx;
}
2025-06-14 14:08:44 +08:00
// Remove default card padding if needed
::v-deep .uni-card .uni-card__content {
padding: 10px 15px !important; // Overwrite default padding
}
.list-header {
display: flex;
justify-content: space-between;
padding: 10px 0; // Adjust padding as needed
border-bottom: 1px solid #eee;
color: #666;
font-size: 14px;
}
.category-header {
flex: 3; // Give more space to category
}
.value-header {
flex: 1;
text-align: right;
}
.list-item {
display: flex;
justify-content: space-between;
align-items: center;
padding: 12px 0; // Vertical padding for spacing
border-bottom: 1px solid #eee;
font-size: 14px;
&:last-child {
border-bottom: none; // Remove border for the last item
}
}
.category-name {
flex: 3; // Corresponds to header
color: #333;
}
.value {
flex: 1; // Corresponds to header
text-align: right;
color: #333;
font-weight: 500;
}
.review-badge {
display: inline-flex;
align-items: center;
justify-content: center;
width: 20px;
height: 20px;
background-color: #ff6b35;
color: #ffffff;
font-size: 12px;
font-weight: bold;
border-radius: 50%;
margin-left: 8px;
margin-right: 8px;
animation: pulse 2s infinite;
}
@keyframes pulse {
0% {
box-shadow: 0 0 0 0 rgba(255, 107, 53, 0.7);
}
70% {
box-shadow: 0 0 0 10px rgba(255, 107, 53, 0);
}
100% {
box-shadow: 0 0 0 0 rgba(255, 107, 53, 0);
}
}
</style>