From 4e9e45df5d7caeb151e5d3199bdc96db85539ac8 Mon Sep 17 00:00:00 2001
From: yujialong <479214531@qq.com>
Date: Thu, 27 Apr 2023 10:29:21 +0800
Subject: [PATCH] =?UTF-8?q?=E5=AD=A6=E4=B9=A0=E8=BF=9B=E5=BA=A6=E3=80=81?=
=?UTF-8?q?=E6=95=B0=E6=8D=AE=E7=9C=8B=E6=9D=BF?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/api/index.js | 6 ++
src/layouts/navbar/index.vue | 4 ++
src/pages/screen/index.vue | 63 +++++++++++++++--
src/pages/station/preview/index.vue | 104 ++++++++++++++++++++++++++--
src/setting.js | 2 +-
5 files changed, 167 insertions(+), 12 deletions(-)
diff --git a/src/api/index.js b/src/api/index.js
index 2425ef5..fc5421a 100644
--- a/src/api/index.js
+++ b/src/api/index.js
@@ -27,6 +27,11 @@ export default {
getProjectBySystemId: 'occupationlab/occupationlab/projectManage/getProjectBySystemId',
getTheMostRecentlyRunProject: 'python/python/getTheMostRecentlyRunProject',
whetherToRenewTheFee: 'nakadai/nakadai/curriculum/whetherToRenewTheFee',
+ courseLearningProgress: 'nakadai/nakadai/curriculum/learning/progressprogress/courseLearningProgress',
+ deleteLearningProgress: 'nakadai/nakadai/curriculum/learning/progressprogress/delete',
+ findLearningProgress: 'nakadai/nakadai/curriculum/learning/progressprogress/findById',
+ saveLearningProgress: 'nakadai/nakadai/curriculum/learning/progressprogress/save',
+ updateLearningProgress: 'nakadai/nakadai/curriculum/learning/progressprogress/update',
// 能力测评
canExperiment: `occupationlab/occupationlab/evaluationrecord/can_experiment`, // 查询是否能够开启实验
@@ -151,4 +156,5 @@ export default {
monthlyAverageOnlineTime: `occupationlab/occupationlab/data/kanban/monthlyAverageOnlineTime`,
courseRankings: `occupationlab/occupationlab/data/kanban/courseRankings`,
platformLoginStatistics: `users/users/user/platformLoginStatistics`,
+ activityRanking: `occupationlab/occupationlab/data/kanban/activityRanking`,
};
\ No newline at end of file
diff --git a/src/layouts/navbar/index.vue b/src/layouts/navbar/index.vue
index 64759e9..655119d 100644
--- a/src/layouts/navbar/index.vue
+++ b/src/layouts/navbar/index.vue
@@ -82,6 +82,10 @@ export default {
index: "/log/list",
title: "更新日志"
},
+ {
+ index: "/screen",
+ title: "数据看板"
+ }
// {
// index: "trial",
// title: "试用申请"
diff --git a/src/pages/screen/index.vue b/src/pages/screen/index.vue
index c8db9fa..2de225c 100644
--- a/src/pages/screen/index.vue
+++ b/src/pages/screen/index.vue
@@ -247,7 +247,7 @@
-
+
@@ -274,20 +274,20 @@
名次 |
姓名 |
- 班级 |
+ {{ token ? '班级' : '学校' }} |
练习次数 |
平均分 |
-
+
{{ i + 1 }} |
{{ item.userName }} |
- {{ item.className }} |
+ {{ token ? item.className : item.schoolName }} |
{{ item.practiceNumber }} |
{{ item.avgScore }} |
@@ -295,6 +295,50 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+

+ 活跃度排行榜
+
+
+
+
+
+ 名次 |
+ {{ token ? '班级' : '学校' }} |
+ 活跃指数 |
+
+
+
+
+
+
+
+
+ {{ i + 1 }} |
+ {{ token ? item.className : item.schoolName }} |
+ {{ item.activityIndex }} |
+
+
+
+
+
@@ -307,6 +351,7 @@ import Setting from '@/setting'
export default {
data() {
return {
+ token: Util.local.get(Setting.tokenKey),
time: 0,
times: [
{
@@ -324,6 +369,7 @@ export default {
courses: [],
popularCourses: [],
achs: [],
+ actives: [],
examChart: null
}
},
@@ -381,6 +427,11 @@ export default {
})
this.achs = list
}).catch(res => {})
+
+ // 活跃度排行榜
+ this.$post(this.api.activityRanking).then(({ list }) => {
+ this.actives = list
+ }).catch(res => {})
this.scrollTable()
},
// 切换时间单位
@@ -1018,12 +1069,16 @@ export default {
scrollTable() {
const dom = this.$refs.popularCourses
const dom1 = this.$refs.ach
+ const dom2 = this.$refs.active
setInterval(() => {
dom.scrollTop += 1
if (dom.clientHeight + dom.scrollTop === dom.scrollHeight) dom.scrollTop = 0
dom1.scrollTop += 1
if (dom1.clientHeight + dom1.scrollTop === dom1.scrollHeight) dom1.scrollTop = 0
+
+ dom2.scrollTop += 1
+ if (dom2.clientHeight + dom2.scrollTop === dom2.scrollHeight) dom2.scrollTop = 0
}, 30)
}
}
diff --git a/src/pages/station/preview/index.vue b/src/pages/station/preview/index.vue
index 9df0022..25ef62d 100644
--- a/src/pages/station/preview/index.vue
+++ b/src/pages/station/preview/index.vue
@@ -48,6 +48,10 @@
{{ courseName }}
+
+
我的学习进度
+
+
@@ -61,6 +65,7 @@

{{ section.name }}
+
@@ -69,7 +74,10 @@
-
+
+
@@ -127,7 +135,7 @@ export default {
return {
startTime: Date.now(), // 页面进来的时间
systemIds: '',
- courseId: this.$route.query.courseId,
+ courseId: +this.$route.query.courseId,
curriculumName: this.$route.query.curriculumName,
video: "http://liuwanr.oss-cn-shenzhen.aliyuncs.com/mp4/20200519/1589871025648.mp4",
chapterList: [], // 章节列表
@@ -137,6 +145,25 @@ export default {
teachingObjectives: "", // 课程目标
assessmentList: "", // 考核列表
curLink: "", // 当前选中
+ active: 1,
+ tabs: [
+ {
+ id: 1,
+ name: '课程介绍'
+ },
+ {
+ id: 2,
+ name: '课程笔记'
+ },
+ {
+ id: 3,
+ name: '全国排行榜'
+ },
+ {
+ id: 4,
+ name: '教学互动'
+ }
+ ],
playAuth: "",
player: null,
previewImg: "",
@@ -161,7 +188,7 @@ export default {
loading: false,
curProject: '',
overdue: 0, //是否过期
- buyVisible: false
+ buyVisible: false,
};
},
computed: {
@@ -207,13 +234,14 @@ export default {
}).then(({ isRenew }) => {
// 1正常显示资源,0显示续费
this.overdue = isRenew
- this.getChapter()
+ this.getChapter(1)
}).catch(res => {})
},
- async getChapter() {
- let res = await this.$get(`${this.api.curriculumChapter}/${this.courseId}`);
+ async getChapter(first) {
+ let res = await this.$post(`${this.api.courseLearningProgress}?courseId=${this.courseId}`);
this.chapterList = res.chapterList;
- if (this.chapterList.length && this.chapterList[0].subsectionList && this.chapterList[0].subsectionList.length) {
+ this.schedule = res.schedule.replace('%', '')
+ if (first && this.chapterList.length && this.chapterList[0].subsectionList && this.chapterList[0].subsectionList.length) {
this.preview(this.chapterList[0].subsectionList[0], this.chapterList[0].name, 1);
}
},
@@ -245,6 +273,24 @@ export default {
if('mp4,3gp,mov,m4v,avi,dat,mkv,flv,vob,rmvb,rm,qlv'.includes(suf)) return '视频'
return suf
},
+ // tab切换
+ tabChange(item) {
+ this.active = item.id
+ },
+ // 勾选/取消勾选学习进度
+ studySection(chapter, section) {
+ section.whetherToStudyOrNot ?
+ this.$post(`${this.api.deleteLearningProgress}?id=${section.learningProgressId}`).then(({ isRenew }) => {
+ this.getChapter()
+ }).catch(res => {}) :
+ this.$post(this.api.saveLearningProgress, {
+ chapterId: chapter.id,
+ cid: this.courseId,
+ subsectionId: section.id,
+ }).then(({ isRenew }) => {
+ this.getChapter()
+ }).catch(res => {})
+ },
preview(row, chapterName, showDia = 0) {
// 如果没过期,则正常预览,否则显示购买弹框
if (this.overdue || showDia) {
@@ -513,6 +559,17 @@ $height: 700px;
color: #fff;
font-size: 16px;
}
+ .pro-title {
+ margin-bottom: 5px;
+ color: #fff;
+ font-size: 12px;
+ }
+ /deep/.el-progress-bar {
+ width: 95%;
+ }
+ /deep/.el-progress__text {
+ color: #fff;
+ }
.desc-wrap{
position: relative;
.desc{
@@ -567,6 +624,8 @@ $height: 700px;
margin-top: 12px;
background-color: #121214;
.sectionName{
+ position: relative;
+ padding-right: 15px;
margin: 12px 0;
font-size: 12px;
color: #999;
@@ -575,6 +634,18 @@ $height: 700px;
img {
margin-right: 8px;
}
+ .icon {
+ position: absolute;
+ right: 0;
+ font-size: 14px;
+ color: #00c935;
+ }
+ .circle {
+ width: 14px;
+ height: 14px;
+ border-radius: 50%;
+ border: 1px solid #ccc;
+ }
&.active{
color: #fff;
}
@@ -736,6 +807,25 @@ $height: 700px;
color: #333;
}
}
+.tabs {
+ display: flex;
+ align-items: center;
+ margin-top: 10px;
+ .item {
+ padding: 0 10px;
+ margin-right: 16px;
+ font-size: 17px;
+ text-align: center;
+ color: #333;
+ line-height: 50px;
+ border-bottom: 3px solid transparent;
+ cursor: pointer;
+ &.active {
+ color: #007EFF;
+ border-color: #007EFF;
+ }
+ }
+}
@media (max-width: 1430px) {
.wrap {
padding: 12px 100px 20px;
diff --git a/src/setting.js b/src/setting.js
index 2ea8a70..e4142f4 100644
--- a/src/setting.js
+++ b/src/setting.js
@@ -59,7 +59,7 @@ const Setting = {
/**
* 路由白名单
* */
- whiteList: ['/login', '/index/list', '/index/zxy', '/product', '/cityPartner/list', '/devPlatform/list', '/log/list', '/touristMatch/list', '/touristMatch/details', '/touristMatch/noticeDetail', '/preCourse/list', '/preCourse/details', '/preInfo/list', '/preInfo/details'],
+ whiteList: ['/login', '/index/list', '/index/zxy', '/product', '/cityPartner/list', '/devPlatform/list', '/log/list', '/touristMatch/list', '/touristMatch/details', '/touristMatch/noticeDetail', '/preCourse/list', '/preCourse/details', '/preInfo/list', '/preInfo/details', '/screen'],
/**
* 平台列表
* */