alioss
yujialong 3 years ago
parent e10884c242
commit c5c2fa6421
  1. 8
      src/api/index.js
  2. BIN
      src/assets/img/course-bg2.png
  3. BIN
      src/assets/img/course-bg4.png
  4. BIN
      src/assets/img/course4.png
  5. BIN
      src/assets/img/info-bg7.png
  6. BIN
      src/assets/img/screen/medal.png
  7. 21
      src/layouts/navbar/index.vue
  8. 23
      src/pages/account/login/index.vue
  9. 34
      src/pages/course/details/index.vue
  10. 124
      src/pages/course/list/index.vue
  11. 6
      src/pages/info/details/index.vue
  12. 74
      src/pages/info/list/index.vue
  13. 363
      src/pages/screen/index.vue
  14. 1
      src/pages/station/preview/index.vue
  15. 2
      src/setting.js
  16. 6
      src/store/modules/project.js
  17. 103
      src/styles/page/screen.scss
  18. 5
      vue.config.js

@ -19,8 +19,8 @@ export default {
logNotification: `nakadai/nakadai/log/logNotification`, logNotification: `nakadai/nakadai/log/logNotification`,
//实验台 //实验台
curriculumDetail: `nakadai/nakadai/curriculum/curriculumDetail`, // 课程详情 curriculumDetail: `nakadai/nakadai/curriculum/curriculumDetail`, // 课程详情
curriculumChapter: `nakadai/nakadai/curriculum/chapter/queryChaptersAndSubsections`, // 根据课程id查询章节小节,树状结构 curriculumChapter: `nakadai/nakadai/curriculum/chapter/queryChaptersAndSubsections`,
queryChaptersAndSubsections: `occupationlab/occupationlab/management/edu/courseChapter/queryChaptersAndSubsections`, queryChaptersAndSubsections: `occupationlab/occupationlab/theoreticalCourseChapter/queryChaptersAndSubsections`,
curriculumGetSubsection: `nakadai/nakadai/curriculum/subsection/getSubsection`, // 根据小节id获取预览文件地址 curriculumGetSubsection: `nakadai/nakadai/curriculum/subsection/getSubsection`, // 根据小节id获取预览文件地址
getProjectBySystemId: 'occupationlab/occupationlab/projectManage/getProjectBySystemId', getProjectBySystemId: 'occupationlab/occupationlab/projectManage/getProjectBySystemId',
getTheMostRecentlyRunProject: 'python/python/getTheMostRecentlyRunProject', getTheMostRecentlyRunProject: 'python/python/getTheMostRecentlyRunProject',
@ -68,6 +68,8 @@ export default {
findByIdCourse: `occupationlab/occupationlab/theoreticalCourse/findById`, findByIdCourse: `occupationlab/occupationlab/theoreticalCourse/findById`,
playRecordSave: `occupationlab/occupationlab/playRecord/save`, playRecordSave: `occupationlab/occupationlab/playRecord/save`,
studentLoginPreCourse: `occupationlab/occupationlab/theoreticalCourse/studentLoginPreCourse`, studentLoginPreCourse: `occupationlab/occupationlab/theoreticalCourse/studentLoginPreCourse`,
getRedisCache: `occupationlab/occupationlab/theoreticalCourse/getRedisCache`,
getSubsection: `occupationlab/occupationlab/theoreticalCourseSubsection/getSubsection`,
// 资讯 // 资讯
queryAllColumns: `occupationlab/occupationlab/information/column/queryAllColumns`, // 栏目树 queryAllColumns: `occupationlab/occupationlab/information/column/queryAllColumns`, // 栏目树
@ -75,7 +77,7 @@ export default {
getArticle: `occupationlab/occupationlab/information/article/getArticle`, // 根据id查询文章 getArticle: `occupationlab/occupationlab/information/article/getArticle`, // 根据id查询文章
// 线上赛事 // 线上赛事
notLoggedInBeforeStudentEvents: `occupationlab/occupationlab/match/contest/notLoggedInBeforeStudentEvents`, notLoggedInBeforeStudentEvents: `occupationlab/occupationlab/enterprise/match/contest/notLoggedInBeforeStudentEvents`,
contestPageConditionQueryByOccupationlabStu: `occupationlab/occupationlab/match/contest/contestPageConditionQueryByOccupationlabStu`, contestPageConditionQueryByOccupationlabStu: `occupationlab/occupationlab/match/contest/contestPageConditionQueryByOccupationlabStu`,
contestPageConditionQueryByOccupationlab: `occupationlab/occupationlab/match/contest/onlineCompetitionByStudent`, contestPageConditionQueryByOccupationlab: `occupationlab/occupationlab/match/contest/onlineCompetitionByStudent`,
listOfRegisteredEvents: `occupationlab/occupationlab/match/contest/listOfRegisteredEvents`, listOfRegisteredEvents: `occupationlab/occupationlab/match/contest/listOfRegisteredEvents`,

Binary file not shown.

Before

Width:  |  Height:  |  Size: 7.4 KiB

After

Width:  |  Height:  |  Size: 193 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.7 KiB

After

Width:  |  Height:  |  Size: 32 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 586 B

@ -14,6 +14,7 @@
<script> <script>
import Setting from "@/setting" import Setting from "@/setting"
import util from "@/libs/util" import util from "@/libs/util"
import { mapActions } from "vuex";
export default { export default {
data() { data() {
return { return {
@ -65,14 +66,6 @@ export default {
index: "/touristMatch/list", index: "/touristMatch/list",
title: "大赛资讯" title: "大赛资讯"
}, },
{
index: 'data',
title: "数据科研"
},
{
index: "/log/list",
title: "更新日志"
},
{ {
index: "/preCourse/list", index: "/preCourse/list",
title: "精品课程" title: "精品课程"
@ -81,6 +74,14 @@ export default {
index: "/preInfo/list", index: "/preInfo/list",
title: "最新资讯" title: "最新资讯"
}, },
{
index: 'data',
title: "数据科研"
},
{
index: "/log/list",
title: "更新日志"
},
// { // {
// index: "trial", // index: "trial",
// title: "" // title: ""
@ -117,6 +118,9 @@ export default {
this.isTourist || this.getColumns() this.isTourist || this.getColumns()
}, },
methods: { methods: {
...mapActions("info", [
"setColumnId"
]),
// //
jump(item) { jump(item) {
const { index } = item const { index } = item
@ -141,6 +145,7 @@ export default {
} else { } else {
this.active = index this.active = index
this.columnActive = '' this.columnActive = ''
this.setColumnId('')
index === '/preInfo/list' || index === '/info/list' || this.$router.push(index).catch(err => {}) index === '/preInfo/list' || index === '/info/list' || this.$router.push(index).catch(err => {})
token !== this.token && location.reload() // tokentoken token !== this.token && location.reload() // tokentoken
} }

@ -208,9 +208,12 @@ export default {
}; };
}, },
computed: { computed: {
...mapState('match', [ ...mapState('match', [
'toMatch' 'toMatch'
]) ]),
...mapState('project', [
'courseId'
])
}, },
components: { components: {
vFooter vFooter
@ -320,11 +323,15 @@ export default {
}, },
// //
setLogin() { setLogin() {
util.local.set(Setting.tokenKey, this.token, Setting.tokenExpires) util.local.set(Setting.tokenKey, this.token, Setting.tokenExpires)
util.cookies.remove('serverLogin') util.cookies.remove('serverLogin')
this.reloadIndex() this.reloadIndex()
util.successMsg('登录成功') util.successMsg('登录成功')
this.$router.replace(this.toMatch ? `/touristMatch` : '/station') this.$router.replace(this.courseId ?
`/course/details?id=${this.courseId}` :
this.toMatch ?
`/touristMatch` :
'/station')
}, },
// //
submit() { submit() {

@ -1,6 +1,6 @@
<template> <template>
<div class="wrap pb"> <div class="wrap pb">
<breadcrumb ref="breadcrumb" :data="'课程学习/' + courseName"></breadcrumb> <breadcrumb ref="breadcrumb" :data="'课程学习/' + courseName" :query="breadcrumbQuery"></breadcrumb>
<div class="flex"> <div class="flex">
<div class="cover" :class="{'is-word': showMask1}"> <div class="cover" :class="{'is-word': showMask1}">
<img v-if="coverUrl" :src="coverUrl" alt="" width="100%" height="100%"> <img v-if="coverUrl" :src="coverUrl" alt="" width="100%" height="100%">
@ -43,8 +43,6 @@
<div class="desc-wrap"> <div class="desc-wrap">
<div class="desc" :class="{active: desShrink}" v-html="description"></div> <div class="desc" :class="{active: desShrink}" v-html="description"></div>
<i class="arrow" :class="{active: desShrink}" v-if="description && description.length > 40"> <i class="arrow" :class="{active: desShrink}" v-if="description && description.length > 40">
<!-- <span>...</span> -->
<i class="el-icon-arrow-down" @click="desShrink = !desShrink"></i>
</i> </i>
</div> </div>
<div class="chapters"> <div class="chapters">
@ -74,16 +72,20 @@
</template> </template>
<script> <script>
import { mapState } from 'vuex'; import { mapState, mapMutations } from 'vuex';
import pdf from "vue-pdf"; import pdf from "vue-pdf";
import 'quill/dist/quill.core.css'; import 'quill/dist/quill.core.css';
import 'quill/dist/quill.snow.css'; import 'quill/dist/quill.snow.css';
import 'quill/dist/quill.bubble.css'; import 'quill/dist/quill.bubble.css';
import bus from '@/libs/bus'
import breadcrumb from '@/components/breadcrumb' import breadcrumb from '@/components/breadcrumb'
import Setting from "@/setting"
import util from "@/libs/util"
export default { export default {
data() { data() {
return { return {
breadcrumbQuery: {
source: this.$route.query.source
},
startTime: Date.now(), // startTime: Date.now(), //
id: this.$route.query.id, id: this.$route.query.id,
video: 'http://liuwanr.oss-cn-shenzhen.aliyuncs.com/mp4/20200519/1589871025648.mp4', video: 'http://liuwanr.oss-cn-shenzhen.aliyuncs.com/mp4/20200519/1589871025648.mp4',
@ -126,23 +128,27 @@ export default {
this.getChapter() this.getChapter()
}, },
destroyed() { destroyed() {
this.$post(this.api.playRecordSave, { //
util.local.get(Setting.tokenKey) && this.$post(this.api.playRecordSave, {
courseId: this.id, courseId: this.id,
courseType: 1, courseType: 1,
playTime: Math.ceil((Date.now() - this.startTime) / 1000 / 60) playTime: Math.ceil((Date.now() - this.startTime) / 1000 / 60)
}).then(({ data }) => {}).catch(res => {}) }).then(({ data }) => {}).catch(res => {})
}, },
methods: { methods: {
...mapMutations('project', [
'SET_COURSE'
]),
getData(){ getData(){
this.$post(`${this.api.findByIdCourse}?id=${this.id}`).then(({ data }) => { this.$post(`${this.api.findByIdCourse}?id=${this.id}`).then(({ data }) => {
this.courseName = data.courseName this.courseName = data.courseName
this.description = data.courseIntroduction this.description = data.courseIntroduction
this.coverUrl = data.coverUrl || 'https://huoran.oss-cn-shenzhen.aliyuncs.com/20220224/png/1496735335294984192.png' this.coverUrl = data.coverUrl || 'https://huoran.oss-cn-shenzhen.aliyuncs.com/20220224/png/1496735335294984192.png'
this.$refs.breadcrumb.update('课程学习/' + this.courseName) this.$refs.breadcrumb.update('课程学习/' + (this.$route.query.source == 1 ? '本校课程' : '共享课程') + '/' + this.courseName)
}).catch(res => {}) }).catch(res => {})
}, },
async getChapter(){ async getChapter(){
let res = await this.$get(`${this.api.queryChaptersAndSubsections}/${this.id}`) let res = await this.$get(`${this.api.queryChaptersAndSubsections}?courseId=${this.id}`)
this.chapterList = res.chapterList this.chapterList = res.chapterList
if (this.chapterList.length && this.chapterList[0].subsectionList && this.chapterList[0].subsectionList.length) { if (this.chapterList.length && this.chapterList[0].subsectionList && this.chapterList[0].subsectionList.length) {
this.preview(this.chapterList[0].subsectionList[0], this.chapterList[0].name); this.preview(this.chapterList[0].subsectionList[0], this.chapterList[0].name);
@ -165,6 +171,16 @@ export default {
return ext return ext
}, },
preview(row, chapterName){ preview(row, chapterName){
//
if (!util.local.get(Setting.tokenKey)) {
this.$confirm('请先登录,是否直接前往登录?', "提示", {
type: 'success'
}).then(() => {
this.SET_COURSE(this.id)
this.$router.push('/login')
}).catch(() => {})
return false
}
this.curLink = `${chapterName}${row.name}`; this.curLink = `${chapterName}${row.name}`;
this.player = null this.player = null
this.playauth = '' this.playauth = ''
@ -199,7 +215,7 @@ export default {
this.pdfSrc = row.fileUrl this.pdfSrc = row.fileUrl
this.pdfVisible = true this.pdfVisible = true
}else{ }else{
this.$get(`${this.api.getSubsection}/${row.id}`).then(res => { this.$get(`${this.api.getSubsection}?subsectionId=${row.id}`).then(res => {
if(row.fileType == 'pptx'){ if(row.fileType == 'pptx'){
this.isPPT = true this.isPPT = true
this.isWord = false this.isWord = false

@ -26,33 +26,35 @@
</div> </div>
<!-- 课程列表 --> <!-- 课程列表 -->
<div class="courses"> <div class="courses">
<div class="wrap-inner"> <div class="course-bg"></div>
<template v-if="list.length"> <template v-if="list.length">
<ul> <ul>
<li v-for="(item, index) in list" :key="index" @click="toDetail(item.id)"> <li v-for="(item, index) in list" :key="index" @click="toDetail(item.id)">
<img :src="item.coverUrl" alt="" /> <img :src="item.coverUrl" alt="" />
<div class="title">{{ item.courseName }}</div> <div class="title">{{ item.courseName }}</div>
<div class="desc" :class="{ie: core.isIE(),ie: core.isFirefox()}" v-html="item.courseIntroduction"></div> <div class="desc" :class="{ie: core.isIE(),ie: core.isFirefox()}" v-html="item.courseIntroduction"></div>
<div class="metas"> <div class="metas">
<i class="el-icon-view"></i> <div class="meta">
{{ item.pageviews }} <i class="el-icon-view"></i>
</div> {{ item.pageviews }}
</li>
</ul>
<div class="pagination">
<el-pagination background layout="total, prev, pager, next" :total="total" @current-change="handleCurrentChange" :current-page="page">
</el-pagination>
</div>
</template>
<template v-else>
<div class="empty">
<div>
<img src="@/assets/img/none.png" alt="">
<p>暂无课程</p>
</div> </div>
</div> <span v-if="item.courseType == 0" class="type">{{ item.courseType == 1 ? '付费' : '免费'}}</span>
</template> </div>
</div> </li>
</ul>
<div class="pagination">
<el-pagination background layout="total, prev, pager, next" :total="total" @current-change="handleCurrentChange" :current-page="page">
</el-pagination>
</div>
</template>
<template v-else>
<div class="empty">
<div>
<img src="@/assets/img/none.png" alt="">
<p>暂无课程</p>
</div>
</div>
</template>
</div> </div>
</div> </div>
</template> </template>
@ -64,8 +66,9 @@ export default {
name: "course", name: "course",
data() { data() {
return { return {
timer: null,
isTourist: !!Setting.whiteList.find(e => e === this.$route.path), isTourist: !!Setting.whiteList.find(e => e === this.$route.path),
active: 0, active: +this.$route.query.source || 0,
tabs: [ tabs: [
{ {
id: 0, id: 0,
@ -95,7 +98,7 @@ export default {
keyword: '', keyword: '',
total: 0, total: 0,
page: 1, page: 1,
pageSize: 10, pageSize: window.innerWidth > 1700 ? 10 : 8,
searchTimer: null, searchTimer: null,
loadIns: null loadIns: null
}; };
@ -108,6 +111,9 @@ export default {
}) })
this.getClassification(0) this.getClassification(0)
this.getData() this.getData()
this.$once('hook:beforeDestroy', function() {
clearInterval(this.timer)
})
}, },
watch: { watch: {
keyword: function(val) { keyword: function(val) {
@ -118,8 +124,7 @@ export default {
} }
}, },
methods: { methods: {
getData() { getList() {
this.loadIns = Loading.service()
// //
this.$post(this.api[this.isTourist ? 'studentLoginPreCourse' : 'pageConditionalQueryCourseByStudent'], { this.$post(this.api[this.isTourist ? 'studentLoginPreCourse' : 'pageConditionalQueryCourseByStudent'], {
...this.form, ...this.form,
@ -138,6 +143,20 @@ export default {
this.loadIns.close() this.loadIns.close()
}) })
}, },
// redis
getRedis() {
this.$post(this.api.getRedisCache).then(({ data }) => {
data && this.getList()
}).catch(res => {})
},
getData() {
this.loadIns = Loading.service()
this.getList()
if (!Setting.isDev) {
clearInterval(this.timer)
this.timer = setInterval(this.getRedis, 1000)
}
},
initData() { initData() {
this.page = 1; this.page = 1;
this.getData(); this.getData();
@ -177,7 +196,7 @@ export default {
this.getData(); this.getData();
}, },
toDetail(id) { toDetail(id) {
this.$router.push(`/${this.isTourist ? 'preCourse' : 'course'}/details?id=${id}`); this.$router.push(`/${this.isTourist ? 'preCourse' : 'course'}/details?id=${id}&source=${this.active}`);
} }
} }
}; };
@ -188,7 +207,8 @@ export default {
position: relative; position: relative;
padding: 100px 0 130px; padding: 100px 0 130px;
text-align: center; text-align: center;
background: url(../../../assets/img/course-bg2.png) (73px 50px)/auto no-repeat, background: url(../../../assets/img/course-bg2.png) (73px 50px)/200px auto no-repeat,
url(../../../assets/img/course-bg4.png) (top left)/auto no-repeat,
url(../../../assets/img/course-bg3.png) (top right)/auto no-repeat, url(../../../assets/img/course-bg3.png) (top right)/auto no-repeat,
url(../../../assets/img/course-bg1.png) 0 0/100% 100% no-repeat; url(../../../assets/img/course-bg1.png) 0 0/100% 100% no-repeat;
h6 { h6 {
@ -266,29 +286,39 @@ export default {
} }
} }
.courses { .courses {
padding-top: 10px; position: relative;
padding: 10px 0 20px;
background: url(../../../assets/img/course3.png) 0 0/auto no-repeat; background: url(../../../assets/img/course3.png) 0 0/auto no-repeat;
.course-bg {
position: absolute;
top: 0;
right: 0;
width: 602px;
height: 100%;
background: url(../../../assets/img/course4.png) (0 -100px)/140% 140% no-repeat;
}
ul { ul {
position: relative;
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
width: 90%;
margin: 0 auto;
} }
li { li {
width: 24%; width: calc(20% - 20px);
min-height: 250px; min-height: 250px;
overflow: hidden; overflow: hidden;
padding: 18px; padding: 18px;
margin: 10px .5%; margin: 10px;
cursor: pointer; cursor: pointer;
border-radius: 8px; border-radius: 8px;
background-color: #fff; background-color: #fff;
transition: all 0.3s; transition: all 0.3s;
img { img {
width: 100%; width: 100%;
height: 165px; height: 165px;
transition: .3s; transition: .3s;
} }
.title { .title {
margin: 10px 0 5px; margin: 10px 0 5px;
color: #0B1D30; color: #0B1D30;
@ -299,13 +329,11 @@ export default {
text-overflow: ellipsis; text-overflow: ellipsis;
white-space: nowrap; white-space: nowrap;
} }
.desc span { .desc span {
color: #f00; color: #f00;
font-size: 14px; font-size: 14px;
background-color: #f00; background-color: #f00;
} }
.desc { .desc {
color: #757F92; color: #757F92;
font-size: 14px; font-size: 14px;
@ -320,12 +348,23 @@ export default {
white-space: nowrap; white-space: nowrap;
} }
} }
.type {
display: inline-block;
padding: 2px 10px;
border-radius: 20px;
color: #1cdbb8;
border: 1px solid;
}
.metas { .metas {
display: flex;
justify-content: space-between;
align-items: center;
margin-top: 10px; margin-top: 10px;
}
.meta {
color: #a9a9a9; color: #a9a9a9;
font-size: 12px; font-size: 12px;
} }
&:hover { &:hover {
box-shadow: 0px 5px 12px 4px rgba(142, 123, 253, 0.09), 0px 3px 6px 0px rgba(142, 123, 253, 0.12), 0px 1px 2px -2px rgba(142, 123, 253, 0.16); box-shadow: 0px 5px 12px 4px rgba(142, 123, 253, 0.09), 0px 3px 6px 0px rgba(142, 123, 253, 0.12), 0px 1px 2px -2px rgba(142, 123, 253, 0.16);
img { img {
@ -333,6 +372,11 @@ export default {
} }
} }
} }
@media (max-width: 1700px) {
li {
width: calc(25% - 20px);
}
}
} }
} }
</style> </style>

@ -27,10 +27,10 @@ import breadcrumb from '@/components/breadcrumb'
export default { export default {
data() { data() {
return { return {
firstName: this.$route.query.first, columnNames: this.$route.query.columnNames,
breadcrumbQuery: { breadcrumbQuery: {
parentId: this.$route.query.parentId, parentId: this.$route.query.parentId,
name: this.$route.query.first name: this.$route.query.name
}, },
id: this.$route.query.id, id: this.$route.query.id,
coverUrl: '', coverUrl: '',
@ -61,7 +61,7 @@ export default {
this.content = data.content this.content = data.content
this.viewCount = data.viewCount this.viewCount = data.viewCount
this.$forceUpdate() this.$forceUpdate()
this.$refs.breadcrumb.update('最新资讯/' + this.title) this.$refs.breadcrumb.update(`最新资讯/${this.$route.query.name}/${this.columnNames.split(',').join('/')}/${this.title}`)
this.loadIns.close() this.loadIns.close()
}) })
.catch(err => { .catch(err => {

@ -24,6 +24,8 @@
<span>作者{{item.author}}</span> <span>作者{{item.author}}</span>
<i class="spe">|</i> <i class="spe">|</i>
<span>{{item.date.replace(' 00:00:00','')}}</span> <span>{{item.date.replace(' 00:00:00','')}}</span>
<i class="spe">|</i>
<span>浏览量{{item.viewCount}}</span>
</div> </div>
<div class="desc" :class="{ie: core.isIE() || core.isEdge(),firefox: core.isFirefox() || core.isEdge()}" v-html="item.content"></div> <div class="desc" :class="{ie: core.isIE() || core.isEdge(),firefox: core.isFirefox() || core.isEdge()}" v-html="item.content"></div>
<a class="detail">查看详情 ></a> <a class="detail">查看详情 ></a>
@ -68,7 +70,9 @@ export default {
listData: [], listData: [],
loadIns: null, loadIns: null,
columnId: '', columnId: '',
menuRefresh: false menuRefresh: false,
deepId: '',
columnNames: []
}; };
}, },
components: { components: {
@ -112,21 +116,40 @@ export default {
}) })
data = res.columnTree data = res.columnTree
} }
this.menuRefresh = false if (data.length) {
this.menuList = data this.menuRefresh = false
// , this.menuList = data
const historyId = this.historyId // ,
if (historyId && data.find(e => e.id === historyId)) { const historyId = this.historyId
this.defaultIndex = historyId + '' console.log("🚀 ~ file: index.vue ~ line 122 ~ getData ~ historyId", historyId)
this.getContent(historyId) if (historyId) {
this.setColumnId('')
this.defaultIndex = historyId + ''
this.getContent(historyId)
} else {
//
data.length && this.getDeepId(data[0].children)
const id = this.deepId
if (id) {
this.getContent(id)
this.defaultIndex = id + ''
}
}
this.$nextTick(() => {
this.menuRefresh = true
})
} else { } else {
// this.loadIns.close()
const id = data.length ? data[0].id : parentId
this.getContent(id)
this.defaultIndex = id + ''
} }
this.$nextTick(() => { },
this.menuRefresh = true // id
getDeepId(data) {
data.map(e => {
if (e.children.length) {
this.getDeepId(e.children)
} else {
this.deepId = e.id
}
}) })
}, },
initData(index,indexPath){ initData(index,indexPath){
@ -156,10 +179,27 @@ export default {
this.page = val; this.page = val;
this.getContent(this.columnId); this.getContent(this.columnId);
}, },
toArticle(id){ //
getColumnName(data, names = []) {
for (let i = 0; i < data.length; i++) {
const e = data[i]
names.push(e.name)
if (e.id == this.columnId) {
console.log("🚀 ~ file: index.vue ~ line 188 ~ getColumnName ~ this.defaultIndex", this.defaultIndex)
this.columnNames = JSON.parse(JSON.stringify(names))
break
} else {
this.getColumnName(e.children, names)
}
names = []
}
},
toArticle(id) {
const columnId = this.columnId const columnId = this.columnId
this.setColumnId(columnId) this.setColumnId(columnId)
this.$router.push(`/${this.$route.path === '/info/list' ? 'info' : 'preInfo'}/details?parentId=${this.$route.query.parentId}&id=${id}`) this.getColumnName(this.menuList, [])
console.log("🚀 ~ file: index.vue ~ line 199 ~ toArticle ~ menuList", this.columnNames)
this.$router.push(`/${this.$route.path === '/info/list' ? 'info' : 'preInfo'}/details?parentId=${this.$route.query.parentId}&name=${this.$route.query.name}&id=${id}&columnNames=${this.columnNames}`)
} }
} }
}; };
@ -171,7 +211,7 @@ export default {
height: 350px; height: 350px;
padding: 100px 0 0 180px; padding: 100px 0 0 180px;
background: url(../../../assets/img/info-bg6.png) (0 0)/auto no-repeat, background: url(../../../assets/img/info-bg6.png) (0 0)/auto no-repeat,
url(../../../assets/img/info-bg7.png) (25% 140px)/auto no-repeat, url(../../../assets/img/info-bg7.png) (25% 110px)/400px auto no-repeat,
url(../../../assets/img/info-bg4.png) (top right)/auto no-repeat, url(../../../assets/img/info-bg4.png) (top right)/auto no-repeat,
url(../../../assets/img/info-bg5.png) (80% 20px)/auto no-repeat, url(../../../assets/img/info-bg5.png) (80% 20px)/auto no-repeat,
url(../../../assets/img/info-bg3.png) 0 0/100% 100% no-repeat; url(../../../assets/img/info-bg3.png) 0 0/100% 100% no-repeat;

@ -83,7 +83,7 @@
<i class="b_r_line"></i> <i class="b_r_line"></i>
</div> </div>
<div class="main_title"> <div class="main_title">
<img src="@/assets/img/screen/t_2.png" alt=""> <img src="@/assets/img/screen/t_7.png" alt="">
月人均在线学习时长情况 月人均在线学习时长情况
</div> </div>
<div id="chart3" class="chart t_btn9"></div> <div id="chart3" class="chart t_btn9"></div>
@ -206,7 +206,11 @@
本月综合学习积极性最高的实验课程 本月综合学习积极性最高的实验课程
</div> </div>
<ul class="list"> <ul class="list">
<li v-for="(item, i) in courses" :key="i">{{ item.curriculumName }}</li> <li v-for="(item, i) in courses" :key="i">
<span class="index">{{ i + 1 }}</span>
<p class="text">{{ item.curriculumName }}</p>
<img class="icon" src="@/assets/img/screen/medal.png" alt="">
</li>
</ul> </ul>
</div> </div>
<div class="item" style="height: 240px"> <div class="item" style="height: 240px">
@ -234,9 +238,14 @@
<img src="@/assets/img/screen/t_5.png" alt=""> <img src="@/assets/img/screen/t_5.png" alt="">
热门理论课程排行榜 热门理论课程排行榜
</div> </div>
<ul class="list" style="margin-top: 45px;"> <div class="popular-wrap" ref="popularCourses">
<li v-for="(item, i) in popularCourses" :key="i">{{ item }}</li> <ul class="list popular">
</ul> <li v-for="(item, i) in popularCourses" :key="i">
<span class="index">{{ i + 1 }}</span>
<p class="text">{{ item }}</p>
</li>
</ul>
</div>
</div> </div>
<div class="item" style="height: 630px"> <div class="item" style="height: 630px">
<div class="t_line_box"> <div class="t_line_box">
@ -267,12 +276,12 @@
<th width="20%">姓名</th> <th width="20%">姓名</th>
<th width="20%">班级</th> <th width="20%">班级</th>
<th width="20%">练习次数</th> <th width="20%">练习次数</th>
<th width="20%">练习平均分</th> <th width="20%">平均分</th>
</tr> </tr>
</thead> </thead>
</table> </table>
</div> </div>
<div class="main_table" ref="tableWrap" style="margin-top: 0;overflow: auto"> <div class="main_table" style="margin-top: 0;overflow: auto">
<table> <table>
<tbody> <tbody>
<tr v-for="(item, i) in achs" :key="i"> <tr v-for="(item, i) in achs" :key="i">
@ -314,7 +323,8 @@ export default {
cryptoList: [], cryptoList: [],
courses: [], courses: [],
popularCourses: [], popularCourses: [],
achs: [] achs: [],
examChart: null
} }
}, },
mounted() { mounted() {
@ -370,6 +380,7 @@ export default {
}) })
this.achs = data this.achs = data
}).catch(res => {}) }).catch(res => {})
this.scrollTable()
}, },
// //
switchTime(id) { switchTime(id) {
@ -434,7 +445,8 @@ export default {
} }
] ]
} }
echarts.init(document.querySelector(`#chart1`)).setOption(option) this.examChart = echarts.init(document.querySelector(`#chart1`))
this.examChart.setOption(option)
}).catch(res => {}) }).catch(res => {})
}, },
// //
@ -508,7 +520,7 @@ export default {
endValue: 5 // 6 endValue: 5 // 6
} }
], ],
color:['#56f3f7', '#b76fff', '#5492ff', '#e51579'], color:['#4388ff', '#44cfff', '#8c2bff', '#2defe2'],
xAxis: [ xAxis: [
{ {
type: 'category', type: 'category',
@ -517,7 +529,14 @@ export default {
lineStyle: { lineStyle: {
color: '#fff' color: '#fff'
} }
} },
axisLabel: {
interval: 0,
textStyle: {
color: '#fff',
},
rotate: 60
},
} }
], ],
yAxis: [ yAxis: [
@ -540,7 +559,7 @@ export default {
], ],
series: [ series: [
{ {
name: '不及格', name: '60以下',
type: 'bar', type: 'bar',
stack: 'Ad', stack: 'Ad',
emphasis: { emphasis: {
@ -549,7 +568,7 @@ export default {
data: data1 data: data1
}, },
{ {
name: '及格', name: '60-69',
type: 'bar', type: 'bar',
stack: 'Ad', stack: 'Ad',
emphasis: { emphasis: {
@ -558,7 +577,7 @@ export default {
data: data2 data: data2
}, },
{ {
name: '', name: '70-89',
type: 'bar', type: 'bar',
stack: 'Ad', stack: 'Ad',
emphasis: { emphasis: {
@ -601,152 +620,185 @@ export default {
{ {
color1: '#f9d437', color1: '#f9d437',
color2: 'rgba(255, 234, 144, 0.4)' color2: 'rgba(255, 234, 144, 0.4)'
},
{
color1: '#912892',
color2: 'rgba(31, 24, 153, 0.4)'
},
{
color1: '#f21259',
color2: 'rgba(213, 22, 11, 0.4)'
},
{
color1: '#7343fe',
color2: 'rgba(243, 123, 2, 0.4)'
},
{
color1: '#ea7321',
color2: 'rgba(65, 94, 123, 0.4)'
},
{
color1: '#934ea2',
color2: 'rgba(32, 123, 223, 0.4)'
},
{
color1: '#672313',
color2: 'rgba(156, 163, 2, 0.4)'
} }
] ]
this.$post(this.api.studentAssessSchievement, times).then(({ data }) => { this.$get(this.api.schoolCourse).then(({ data }) => {
const times = [] const courseList = data
const courses = [] const ids = data.map(e => e.cid)
const series = [] times.map(e => {
e.cid = ids
})
const courseData = {} const courseData = {}
data.map(e => { courseList.map(e => {
times.push(e.time) e.curriculumName = e.curriculumName.substring(0, 10)
e.assesScoreRespList.map(n => { courseData[e.curriculumName] = []
const name = n.curriculumName
courses.push(n.curriculumName)
if (courseData[name]) {
courseData[name].push(+n.avgScore)
} else {
courseData[name] = [+n.avgScore]
}
})
}) })
let index = 0 this.$post(this.api.studentAssessSchievement, times).then(({ data }) => {
// series const times = []
for (const i in courseData) { const series = []
series.push({ data.map(e => {
name: i, times.push(e.time)
type: 'line', e.assesScoreRespList.map(n => {
smooth: true, const item = courseList.find(j => j.cid == n.curriculumId)
symbol: 'circle', if (item) {
symbolSize: 5, const name = item.curriculumName
showSymbol: false, if (courseData[name]) {
lineStyle: { courseData[name].push(+n.avgScore)
normal: { }
color: colors[index].color1,
width: 2
}
},
areaStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: colors[index].color2
}, {
offset: 0.8,
color: colors[index].color2
}], false),
shadowColor: 'rgba(0, 0, 0, 0.1)',
}
},
itemStyle: {
normal: {
color: colors[index].color1,
borderColor: 'rgba(221, 220, 107, .1)',
borderWidth: 12
} }
}, })
data: courseData[i]
}) })
++index let index = 0
if (index > 3) index = 0 // series
} for (const i in courseData) {
const option = { series.push({
tooltip: { name: i,
trigger: 'axis', type: 'line',
axisPointer: { smooth: true,
symbol: 'circle',
symbolSize: 5,
showSymbol: false,
lineStyle: { lineStyle: {
color: '#dddc6b' normal: {
} color: colors[index].color1,
} width: 2
}, }
legend: {
top:'8%',
data: courses,
textStyle: {
color: 'rgba(255,255,255,.5)',
fontSize:'12',
}
},
dataZoom: [//
{
xAxisIndex: 0,//X0
show: false,//使
type: 'slider', // dataZoom slider dataZoom
startValue: 0, //
endValue: 6 // 6
}
],
grid: {
left: '30',
top: '27%',
right: '10',
bottom: '5%',
containLabel: true
},
xAxis: [{
type: 'category',
boundaryGap: false,
axisLabel: {
textStyle: {
color: "rgba(255,255,255,.9)",
fontSize:12,
}, },
}, areaStyle: {
axisLine: { normal: {
lineStyle: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
color: 'rgba(255,255,255,.2)' offset: 0,
color: colors[index].color2
}, {
offset: 0.8,
color: colors[index].color2
}], false),
shadowColor: 'rgba(0, 0, 0, 0.1)',
}
},
itemStyle: {
normal: {
color: colors[index].color1,
borderColor: 'rgba(221, 220, 107, .1)',
borderWidth: 12
}
},
data: courseData[i]
})
++index
if (index > 9) index = 0
}
const option = {
tooltip: {
trigger: 'axis',
axisPointer: {
lineStyle: {
color: '#dddc6b'
}
} }
}, },
data: times legend: {
}, { top:'8%',
axisPointer: {show: false}, data: courseList.map(e => e.curriculumName),
axisLine: {show: false}, textStyle: {
position: 'bottom', color: 'rgba(255,255,255,.5)',
offset: 20, fontSize:'12',
}], }
yAxis: [{
type: 'value',
name: '平均分',
nameTextStyle: {
color: '#fff'
}, },
axisTick: {show: false}, dataZoom: [//
axisLine: { {
lineStyle: { xAxisIndex: 0,//X0
color: 'rgba(255,255,255,.1)' show: false,//使
type: 'slider', // dataZoom slider dataZoom
startValue: 0, //
endValue: 6 // 6
} }
],
grid: {
left: '30',
top: '32%',
right: '10',
bottom: '5%',
containLabel: true
}, },
axisLabel: { xAxis: {
textStyle: { type: 'category',
color: "rgba(255,255,255,.9)", boundaryGap: false,
fontSize:12, axisLabel: {
textStyle: {
color: "rgba(255,255,255,.9)",
fontSize:12,
},
},
axisLine: {
lineStyle: {
color: 'rgba(255,255,255,.2)'
}
}, },
data: times
}, },
splitLine: { yAxis: [{
lineStyle: { type: 'value',
color: 'rgba(255,255,255,.1)' name: '平均分',
min: 0,
max: 100,
interval: 10,
splitNumber: 10,
nameTextStyle: {
color: '#fff'
},
axisTick: {show: false},
axisLine: {
lineStyle: {
color: 'rgba(255,255,255,.1)'
}
},
axisLabel: {
textStyle: {
color: "rgba(255,255,255,.9)",
fontSize:12,
},
},
splitLine: {
lineStyle: {
color: 'rgba(255,255,255,.1)'
}
} }
} }],
}], series
series }
} chart[1] = echarts.init(document.querySelector(`#chart5`))
chart[1] = echarts.init(document.querySelector(`#chart5`)) chart[1].setOption(option)
chart[1].setOption(option) // setInterval(function () {
setInterval(function () { // animateChart(chart[1], option, times)
animateChart(chart[1], option, times) // }, 5000)
}, 5000) }).catch(res => {})
}).catch(res => {}) }).catch(err => {})
// 线 // 线
const date = new Date() const date = new Date()
date.setMonth(date.getMonth() + 1) date.setMonth(date.getMonth() + 1)
@ -949,28 +1001,27 @@ export default {
animateChart(chart[3], option, data, 3) animateChart(chart[3], option, data, 3)
}, 1500) }, 1500)
}).catch(res => {}) }).catch(res => {})
// this.scrollTable()
// resizechart // resizechart
window.addEventListener('resize', () => { window.addEventListener('resize', () => {
this.examChart && this.examChart.resize()
for (let i = 0; i < 4; i++) { for (let i = 0; i < 4; i++) {
chart[i] && chart[i].resize() chart[i] && chart[i].resize()
} }
}) })
}, },
// //
// scrollTable() { scrollTable() {
// const dom = this.$refs.tableWrap const dom = this.$refs.popularCourses
// const dom1 = this.$refs.gdpList // const dom1 = this.$refs.gdpList
// setInterval(() => { setInterval(() => {
// dom.scrollTop += 1 dom.scrollTop += 1
// if (dom.clientHeight + dom.scrollTop === dom.scrollHeight) dom.scrollTop = 0 if (dom.clientHeight + dom.scrollTop === dom.scrollHeight) dom.scrollTop = 0
// dom1.scrollTop += 1 // dom1.scrollTop += 1
// if (dom1.clientHeight + dom1.scrollTop === dom1.scrollHeight) dom1.scrollTop = 0 // if (dom1.clientHeight + dom1.scrollTop === dom1.scrollHeight) dom1.scrollTop = 0
// }, 30) }, 30)
// } }
} }
}; };
</script> </script>

@ -162,6 +162,7 @@ export default {
this.getChapter(); this.getChapter();
}, },
destroyed() { destroyed() {
//
this.$post(this.api.playRecordSave, { this.$post(this.api.playRecordSave, {
courseId: this.courseId, courseId: this.courseId,
courseType: 0, courseType: 0,

@ -27,7 +27,7 @@ if (isPro) {
systemPath = `http://${location.hostname}:8093` systemPath = `http://${location.hostname}:8093`
host = "http://121.37.12.51/"; // 测试服 host = "http://121.37.12.51/"; // 测试服
// host = 'https://www.occupationlab.com/' // 正式服 // host = 'https://www.occupationlab.com/' // 正式服
host = "http://192.168.31.151:9000/"; // 榕 // host = "http://192.168.31.151:9000/"; // 榕
// host = "http://192.168.31.137:9000/"; // 赓 // host = "http://192.168.31.137:9000/"; // 赓
} }

@ -5,7 +5,8 @@ export default {
namespaced: true, namespaced: true,
state: { state: {
currId: '', currId: '',
lastRecordType: "practice" lastRecordType: "practice",
courseId: ''
}, },
mutations: { mutations: {
SET_CURRICULUM: (state, currId) => { SET_CURRICULUM: (state, currId) => {
@ -13,6 +14,9 @@ export default {
}, },
SET_RECORD: (state, type) => { SET_RECORD: (state, type) => {
state.lastRecordType = type; state.lastRecordType = type;
},
SET_COURSE: (state, courseId) => {
state.courseId = courseId
} }
}, },
actions: { actions: {

@ -1,6 +1,15 @@
@import "../var.scss"; @import "../var.scss";
// ::-webkit-scrollbar-thumb {
// display: none;
// }
::-webkit-scrollbar {
width: 8px;
height: 8px;
}
::-webkit-scrollbar-thumb { ::-webkit-scrollbar-thumb {
display: none; width: 5px;
border-radius: 6px;
background: rgba(85, 219, 255, .8);
} }
.video { .video {
position: absolute; position: absolute;
@ -144,7 +153,7 @@
z-index: 2; z-index: 2;
position: absolute; position: absolute;
display: flex; display: flex;
top: 10px; top: 24px;
right: 10px; right: 10px;
li { li {
padding: 0 14px; padding: 0 14px;
@ -288,7 +297,9 @@ $height: 250px;
width: 24%; width: 24%;
} }
.middle { .middle {
flex: 1; // flex: 1;
width: 913px;
min-width: 913px;
margin: 0 30px; margin: 0 30px;
} }
.item { .item {
@ -297,21 +308,101 @@ $height: 250px;
margin-bottom: 30px; margin-bottom: 30px;
border: 1px solid #2C58A6; border: 1px solid #2C58A6;
box-shadow: 0 0 10px #2C58A6; box-shadow: 0 0 10px #2C58A6;
// background-color: #073a7d;
} }
} }
.chart { .chart {
height: $height; height: $height;
} }
.popular-wrap {
height: 170px;
margin-top: 45px;
overflow: auto;
&::-webkit-scrollbar-thumb {
display: none;
}
}
.list { .list {
padding: 0 15px; padding: 0 15px;
margin-top: 25px; margin-top: 25px;
text-align: center; overflow: auto;
li { li {
line-height: 40px; position: relative;
padding: 10px 10px;
&:nth-child(2) {
.index {
background-color: #67a0ff;
}
}
&:nth-child(3) {
.index {
background-color: #2b71ff;
}
}
&:nth-child(4) {
.index {
background-color: #8c2bff;
}
}
&:nth-child(5) {
.index {
background-color: #ff612b;
}
}
&:nth-child(6) {
.index {
background-color: #4152f1;
}
}
&:nth-child(7) {
.index {
background-color: #d14cc9;
}
}
&:nth-child(8) {
.index {
background-color: #f52c8d;
}
}
&:nth-child(9) {
.index {
background-color: #f1561b;
}
}
&:nth-child(10) {
.index {
background-color: #f50000;
}
}
}
&.popular {
margin-top: 0;
li:nth-child(odd) {
background-color: #072951;
box-shadow:-10px 0px 15px #2C58A6 inset, 10px 0px 15px #2C58A6 inset;
}
}
.index {
position: absolute;
width: 20px;
line-height: 20px;
color: #fff;
font-size: 12px;
text-align: center;
border-radius: 50%;
background-color: #2defe2;
}
.text {
width: 60%;
margin: 0 auto;
color: #61d2f7; color: #61d2f7;
text-align: center;
@include ellipsis; @include ellipsis;
} }
.icon {
position: absolute;
top: 10px;
right: 10%;
}
} }
.main_title{ .main_title{
display: flex; display: flex;

@ -13,6 +13,9 @@ module.exports = {
outputDir: Setting.outputDir, outputDir: Setting.outputDir,
assetsDir: Setting.assetsDir, assetsDir: Setting.assetsDir,
devServer: { devServer: {
port: 8082 // 固定端口 // client: {
// webSocketURL: 'ws://0.0.0.0:8082/notice',
// },
port: 8082 // 固定端口
} }
}; };
Loading…
Cancel
Save