Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
zhengyuan-danger-chemistry-manage
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
耿迪迪
zhengyuan-danger-chemistry-manage
Commits
65a65910
Commit
65a65910
authored
Jan 06, 2023
by
耿迪迪
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of
ssh://111.61.77.35:15/gengdidi/zhengyuan-danger-chemistry-manage
parents
c6edf1f9
ced5dcd4
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
21 changed files
with
523 additions
and
161 deletions
+523
-161
TTrainCourseController.java
...m/zehong/web/controller/train/TTrainCourseController.java
+19
-0
TTrainCourse.java
.../src/main/java/com/zehong/system/domain/TTrainCourse.java
+10
-0
TTrainUserCourse.java
.../main/java/com/zehong/system/domain/TTrainUserCourse.java
+19
-0
UserCourseVo.java
...c/main/java/com/zehong/system/domain/vo/UserCourseVo.java
+5
-0
ITTrainCourseService.java
.../java/com/zehong/system/service/ITTrainCourseService.java
+4
-0
TTrainCourseServiceImpl.java
...m/zehong/system/service/impl/TTrainCourseServiceImpl.java
+32
-0
TTrainCourseMapper.xml
...m/src/main/resources/mapper/system/TTrainCourseMapper.xml
+8
-2
TTrainUserCourseMapper.xml
...c/main/resources/mapper/system/TTrainUserCourseMapper.xml
+9
-1
lessonsProgram.js
...er-manage-web/src/api/educationPlanExam/lessonsProgram.js
+16
-1
request.js
danger-manage-web/src/utils/request.js
+2
-1
Dia.vue
...views/educationPlanExam/lessonsProgram/components/Dia.vue
+1
-1
Lesson.vue
...ws/educationPlanExam/lessonsProgram/components/Lesson.vue
+57
-4
index.vue
...c/views/educationPlanExam/myLessons/CheckLesson/index.vue
+85
-6
LearnAfter.vue
...ews/educationPlanExam/myLessons/components/LearnAfter.vue
+1
-1
LearnBefore.vue
...ws/educationPlanExam/myLessons/components/LearnBefore.vue
+1
-1
LearnItem.vue
...iews/educationPlanExam/myLessons/components/LearnItem.vue
+62
-4
Left.vue
...src/views/educationPlanExam/myLessons/components/Left.vue
+4
-2
Lesson.vue
...s/educationPlanExam/trainingProgram/components/Lesson.vue
+11
-11
index.vue
danger-manage-web/src/views/system/book/index.vue
+143
-101
index.vue
danger-manage-web/src/views/system/drill/index.vue
+31
-22
index.vue
danger-manage-web/src/views/system/library/index.vue
+3
-3
No files found.
danger-manage-admin/src/main/java/com/zehong/web/controller/train/TTrainCourseController.java
View file @
65a65910
...
...
@@ -91,6 +91,15 @@ public class TTrainCourseController extends BaseController
{
return
AjaxResult
.
success
(
tTrainCourseService
.
selectTTrainCourseById
(
courseId
));
}
/**
* 获取培训课程详细信息
*/
@ApiOperation
(
"用户课程详情"
)
@GetMapping
(
value
=
"/userCourse"
)
public
AjaxResult
getUserCourse
(
Long
userCourseId
)
{
return
AjaxResult
.
success
(
tTrainCourseService
.
getUserCourse
(
userCourseId
));
}
/**
* 获取培训课程详细信息
...
...
@@ -123,6 +132,16 @@ public class TTrainCourseController extends BaseController
{
return
toAjax
(
tTrainCourseService
.
updateTTrainCourse
(
tTrainCourse
));
}
/**
* 修改用户课程
*/
@ApiOperation
(
"修改用户课程"
)
@Log
(
title
=
"修改用户课程"
,
businessType
=
BusinessType
.
UPDATE
)
@PutMapping
(
"/editUserCourse"
)
public
AjaxResult
editUserCourse
(
@RequestBody
TTrainUserCourse
tTrainUserCourse
)
{
return
toAjax
(
tTrainCourseService
.
updateTTrainUserCourse
(
tTrainUserCourse
));
}
/**
* 删除培训课程
...
...
danger-manage-system/src/main/java/com/zehong/system/domain/TTrainCourse.java
View file @
65a65910
...
...
@@ -89,6 +89,16 @@ public class TTrainCourse extends BaseEntity
private
Integer
personnelType
;
private
Integer
duration
;
public
Integer
getDuration
()
{
return
duration
;
}
public
void
setDuration
(
Integer
duration
)
{
this
.
duration
=
duration
;
}
public
String
getPlanName
()
{
return
planName
;
}
...
...
danger-manage-system/src/main/java/com/zehong/system/domain/TTrainUserCourse.java
View file @
65a65910
...
...
@@ -54,6 +54,25 @@ public class TTrainUserCourse extends BaseEntity
private
Integer
personnelType
;
private
Integer
finishDuration
;
private
Integer
trainState
;
public
Integer
getFinishDuration
()
{
return
finishDuration
;
}
public
void
setFinishDuration
(
Integer
finishDuration
)
{
this
.
finishDuration
=
finishDuration
;
}
public
Integer
getTrainState
()
{
return
trainState
;
}
public
void
setTrainState
(
Integer
trainState
)
{
this
.
trainState
=
trainState
;
}
public
Integer
getPersonnelType
()
{
return
personnelType
;
}
...
...
danger-manage-system/src/main/java/com/zehong/system/domain/vo/UserCourseVo.java
View file @
65a65910
...
...
@@ -35,4 +35,9 @@ public class UserCourseVo {
private
String
dataKind
;
private
Integer
personnelType
;
@JsonFormat
(
pattern
=
"yyyy-MM-dd HH:mm:ss"
)
private
Date
testStartTime
;
@JsonFormat
(
pattern
=
"yyyy-MM-dd HH:mm:ss"
)
private
Date
testEndTime
;
}
danger-manage-system/src/main/java/com/zehong/system/service/ITTrainCourseService.java
View file @
65a65910
...
...
@@ -54,6 +54,7 @@ public interface ITTrainCourseService
* @return 结果
*/
public
int
updateTTrainCourse
(
TTrainCourse
tTrainCourse
);
public
int
updateTTrainUserCourse
(
TTrainUserCourse
tTrainUserCourse
);
/**
* 批量删除培训课程
...
...
@@ -71,6 +72,9 @@ public interface ITTrainCourseService
*/
public
int
deleteTTrainCourseById
(
Long
courseId
);
public
TTrainUserCourse
getUserCourse
(
Long
userCourseId
);
/**
* 用户id
* @param userId
...
...
danger-manage-system/src/main/java/com/zehong/system/service/impl/TTrainCourseServiceImpl.java
View file @
65a65910
...
...
@@ -89,6 +89,9 @@ public class TTrainCourseServiceImpl implements ITTrainCourseService
@Override
public
Long
insertTTrainCourse
(
TTrainCourse
tTrainCourse
)
{
if
(
tTrainCourse
.
getDuration
()!=
null
){
//分钟转化秒
tTrainCourse
.
setDuration
(
tTrainCourse
.
getDuration
()*
60
);
}
if
(
tTrainCourse
.
getCourseType
()!=
null
){
TTrainPlan
p
=
tTrainPlanMapper
.
selectTTrainPlanById
(
tTrainCourse
.
getCourseType
());
if
(
p
!=
null
){
...
...
@@ -109,8 +112,17 @@ public class TTrainCourseServiceImpl implements ITTrainCourseService
@Override
public
int
updateTTrainCourse
(
TTrainCourse
tTrainCourse
)
{
if
(
tTrainCourse
.
getDuration
()!=
null
){
//分钟转化秒
tTrainCourse
.
setDuration
(
tTrainCourse
.
getDuration
()*
60
);
}
return
tTrainCourseMapper
.
updateTTrainCourse
(
tTrainCourse
);
}
@Override
public
int
updateTTrainUserCourse
(
TTrainUserCourse
tTrainUserCourse
)
{
return
tTrainUserCourseMapper
.
updateTTrainUserCourse
(
tTrainUserCourse
);
}
/**
* 批量删除培训课程
...
...
@@ -143,6 +155,14 @@ public class TTrainCourseServiceImpl implements ITTrainCourseService
@Override
public
List
<
UserCourseVo
>
userCourseList
(
Long
userId
,
Integer
type
){
List
<
UserCourseVo
>
list
=
tTrainCourseMapper
.
userCourseList
(
userId
,
type
,
1
);
for
(
UserCourseVo
v
:
list
){
if
(
v
.
getTestEndTime
()!=
null
&&
v
.
getTestEndTime
().
getTime
()<
new
Date
().
getTime
()){
v
.
setState
(
3
);
}
if
(
v
.
getTestStartTime
()!=
null
&&
v
.
getTestStartTime
().
getTime
()>
new
Date
().
getTime
()){
v
.
setState
(
4
);
}
}
return
list
;
}
...
...
@@ -231,4 +251,16 @@ public class TTrainCourseServiceImpl implements ITTrainCourseService
public
List
<
TTrainUserCourse
>
testPersonDetailByCourseId
(
Long
courseId
){
return
tTrainUserCourseMapper
.
testPersonDetailByCourseId
(
courseId
);
}
@Override
public
TTrainUserCourse
getUserCourse
(
Long
userCourseId
){
TTrainUserCourse
userCourse
=
tTrainUserCourseMapper
.
selectTTrainUserCourseById
(
userCourseId
);
TTrainCourse
v
=
tTrainCourseMapper
.
selectTTrainCourseById
(
userCourse
.
getCourseId
());
if
(
v
.
getTestEndTime
()!=
null
&&
v
.
getTestEndTime
().
getTime
()<
new
Date
().
getTime
()){
userCourse
.
setState
(
3
);
}
return
userCourse
;
}
}
danger-manage-system/src/main/resources/mapper/system/TTrainCourseMapper.xml
View file @
65a65910
...
...
@@ -24,6 +24,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<result
property=
"testStartTime"
column=
"test_start_time"
/>
<result
property=
"testEndTime"
column=
"test_end_time"
/>
<result
property=
"testPersons"
column=
"test_persons"
/>
<result
property=
"duration"
column=
"duration"
/>
</resultMap>
<resultMap
id=
"StatisticsTrainCourseResult"
type=
"StatisticsTrainCourse"
>
...
...
@@ -38,7 +39,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</resultMap>
<sql
id=
"selectTTrainCourseVo"
>
select course_id, course_name, course_type, course_conent, status,personnel_type, release_time, enclosure, video, qualified_num, topic_num, create_time, create_user, is_del, data_kind, test_start_time, test_end_time, test_persons from t_train_course
select course_id, course_name, course_type, course_conent, status,personnel_type, release_time, enclosure, video, qualified_num, topic_num, create_time, create_user, is_del, data_kind, test_start_time, test_end_time, test_persons
,duration
from t_train_course
</sql>
<select
id=
"selectTTrainCourseList"
parameterType=
"TTrainCourse"
resultMap=
"TTrainCourseResult"
>
...
...
@@ -88,6 +89,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if
test=
"testStartTime != null"
>
test_start_time,
</if>
<if
test=
"testEndTime != null"
>
test_end_time,
</if>
<if
test=
"testPersons != null"
>
test_persons,
</if>
<if
test=
"duration != null"
>
duration,
</if>
</trim>
<trim
prefix=
"values ("
suffix=
")"
suffixOverrides=
","
>
<if
test=
"courseName != null"
>
#{courseName},
</if>
...
...
@@ -107,6 +110,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if
test=
"testStartTime != null"
>
#{testStartTime},
</if>
<if
test=
"testEndTime != null"
>
#{testEndTime},
</if>
<if
test=
"testPersons != null"
>
#{testPersons},
</if>
<if
test=
"duration != null"
>
#{duration},
</if>
</trim>
</insert>
...
...
@@ -130,6 +135,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if
test=
"testStartTime != null"
>
test_start_time = #{testStartTime},
</if>
<if
test=
"testEndTime != null"
>
test_end_time = #{testEndTime},
</if>
<if
test=
"testPersons != null"
>
test_persons = #{testPersons},
</if>
<if
test=
"duration != null"
>
duration = #{duration},
</if>
</trim>
where course_id = #{courseId}
</update>
...
...
@@ -152,7 +158,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</insert>
<select
id=
"userCourseList"
resultType=
"com.zehong.system.domain.vo.UserCourseVo"
>
SELECT uc.user_course_id AS userCourseId,uc.state ,uc.examination_time AS examinationTime,
uc.`examination_result` AS examinationResult,uc.`create_time` AS createTime,
uc.`examination_result` AS examinationResult,uc.`create_time` AS createTime,
c.test_start_time as testStartTime,c.test_end_time as testEndTime,
c.`course_name` AS courseName, c.`topic_num` AS topicNum,c.`release_time` AS releaseTime,c.data_kind as dataKind,c.personnel_type as personnelType,
p.`plan_name` AS courseType,c.course_id as courseId,c.qualified_num as qualifiedNum
FROM t_train_user_course uc
...
...
danger-manage-system/src/main/resources/mapper/system/TTrainUserCourseMapper.xml
View file @
65a65910
...
...
@@ -16,10 +16,12 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<result
property=
"createUser"
column=
"create_user"
/>
<result
property=
"staffName"
column=
"staff_name"
/>
<result
property=
"deptName"
column=
"dept_name"
/>
<result
property=
"finishDuration"
column=
"finish_duration"
/>
<result
property=
"trainState"
column=
"train_state"
/>
</resultMap>
<sql
id=
"selectTTrainUserCourseVo"
>
select user_course_id, user_id, course_id, state, examination_time, personnel_type,examination_result, create_time, create_user from t_train_user_course
select user_course_id, user_id, course_id, state, examination_time, personnel_type,examination_result, create_time, create_user
,finish_duration,train_state
from t_train_user_course
</sql>
<select
id=
"selectTTrainUserCourseList"
parameterType=
"TTrainUserCourse"
resultMap=
"TTrainUserCourseResult"
>
...
...
@@ -50,6 +52,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if
test=
"examinationResult != null"
>
examination_result,
</if>
<if
test=
"createTime != null"
>
create_time,
</if>
<if
test=
"createUser != null"
>
create_user,
</if>
<if
test=
"finishDuration != null"
>
finish_duration,
</if>
<if
test=
"trainState != null"
>
train_state,
</if>
</trim>
<trim
prefix=
"values ("
suffix=
")"
suffixOverrides=
","
>
<if
test=
"userId != null"
>
#{userId},
</if>
...
...
@@ -60,6 +64,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if
test=
"examinationResult != null"
>
#{examinationResult},
</if>
<if
test=
"createTime != null"
>
#{createTime},
</if>
<if
test=
"createUser != null"
>
#{createUser},
</if>
<if
test=
"finishDuration != null"
>
#{finishDuration},
</if>
<if
test=
"trainState != null"
>
#{trainState},
</if>
</trim>
</insert>
...
...
@@ -74,6 +80,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if
test=
"examinationResult != null"
>
examination_result = #{examinationResult},
</if>
<if
test=
"createTime != null"
>
create_time = #{createTime},
</if>
<if
test=
"createUser != null"
>
create_user = #{createUser},
</if>
<if
test=
"finishDuration != null"
>
finish_duration = #{finishDuration},
</if>
<if
test=
"trainState != null"
>
train_state = #{trainState},
</if>
</trim>
where user_course_id = #{userCourseId}
</update>
...
...
danger-manage-web/src/api/educationPlanExam/lessonsProgram.js
View file @
65a65910
...
...
@@ -34,6 +34,14 @@ export function getLessonById(id) {
method
:
'get'
,
})
}
//用户课程状态
export
function
getUserLessonById
(
query
)
{
return
request
({
url
:
'system/course/userCourse'
,
method
:
'get'
,
params
:
query
})
}
// 添加课程
export
function
addLessons
(
data
)
{
return
request
({
...
...
@@ -50,7 +58,14 @@ export function changeLesson(data) {
data
:
data
})
}
// // 修改用户课程
export
function
changeUserLesson
(
data
)
{
return
request
({
url
:
'/system/course/editUserCourse'
,
method
:
'put'
,
data
:
data
})
}
// 发布课程
export
function
issue
(
query
)
{
return
request
({
...
...
danger-manage-web/src/utils/request.js
View file @
65a65910
...
...
@@ -55,7 +55,8 @@ service.interceptors.response.use(res => {
const
msg
=
errorCode
[
code
]
||
res
.
data
.
msg
||
errorCode
[
'default'
]
if
(
code
===
401
)
{
MessageBox
.
confirm
(
'登录状态已过期,您可以继续留在该页面,或者重新登录'
,
'系统提示'
,
{
confirmButtonText
:
'重新登录'
,
// 重新登录
confirmButtonText
:
'确定'
,
cancelButtonText
:
'取消'
,
type
:
'warning'
}
...
...
danger-manage-web/src/views/educationPlanExam/lessonsProgram/components/Dia.vue
View file @
65a65910
...
...
@@ -2,7 +2,7 @@
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-09-22 10:38:49
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 202
2-12-26 09:54:47
* @LastEditTime: 202
3-01-04 17:50:46
* @FilePath: /danger-manage-web/src/views/lessonsProgram/components/addLesson.vue
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
-->
...
...
danger-manage-web/src/views/educationPlanExam/lessonsProgram/components/Lesson.vue
View file @
65a65910
...
...
@@ -2,7 +2,7 @@
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-09-22 10:59:44
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 202
2-09-28 17:52:32
* @LastEditTime: 202
3-01-04 17:47:53
* @FilePath: /danger-manage-web/src/views/lessonsProgram/components/Lession.vue
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
-->
...
...
@@ -17,9 +17,28 @@
>
<div
class=
"top flex"
>
<el-form-item
label=
"课程标题"
prop=
"courseName"
>
<el-input
style=
"width:
5
00px"
v-model=
"form.courseName"
></el-input>
<el-input
style=
"width:
4
00px"
v-model=
"form.courseName"
></el-input>
</el-form-item>
<!--
<el-form-item
label=
"培训计划"
prop=
"courseType"
>
-->
<!--
<el-select-->
<!--v-model="form.courseType"-->
<!--placeholder="请选择培训计划"-->
<!--clearable-->
<!--size="small"-->
<!-->-->
<!--
<el-option-->
<!--v-for="course in courseOptions"-->
<!--:key="course.planId"-->
<!--:label="course.planName"-->
<!--:value="course.planId"-->
<!--/>-->
<!--
</el-select>
-->
<!--
</el-form-item>
-->
</div>
<div
class=
"flex"
>
<el-form-item
label=
"培训计划"
prop=
"courseType"
>
<el-select
v-model=
"form.courseType"
...
...
@@ -35,8 +54,31 @@
/>
</el-select>
</el-form-item>
<el-form-item
label=
"培训时长"
prop=
"duration"
style=
"margin-left: 55px"
>
<el-input
style=
"width: 220px"
placeholder=
"分钟"
type=
"number"
v-model=
"form.duration"
></el-input>
</el-form-item>
</div>
<div
class=
"flex"
>
<el-form-item
label=
"开始时间"
prop=
"testStartTime"
>
<el-date-picker
style=
"margin-right: 50px"
v-model=
"form.testStartTime"
value-format=
"yyyy-MM-dd HH:mm:ss"
type=
"datetime"
placeholder=
"选择日期时间"
default-time=
"00:00:00"
/>
</el-form-item>
<el-form-item
label=
"结束时间"
prop=
"testEndTime"
>
<el-date-picker
v-model=
"form.testEndTime"
value-format=
"yyyy-MM-dd HH:mm:ss"
type=
"datetime"
placeholder=
"选择日期时间"
default-time=
"00:00:00"
/>
</el-form-item>
</div>
<!--
</div>
-->
<el-form-item
label=
"课程内容"
prop=
"courseConent"
>
<Editor
v-model=
"form.courseConent"
:min-height=
"192"
/>
...
...
@@ -65,6 +107,7 @@
@
resFun=
"getFileInfoFile"
@
remove=
"listRemoveFile"
:fileArr=
"fileListFile"
:fileType=
"fileType"
/>
<el-input
v-show=
"false"
disabled
v-model=
"form.enclosure"
></el-input>
</el-form-item>
...
...
@@ -104,12 +147,13 @@ export default {
video
:
""
,
enclosure
:
""
,
},
fileType
:
[
"doc"
,
"docx"
,
"xls"
,
"xlsx"
,
"ppt"
,
"txt"
,
"pdf"
],
fileListVideo
:
[],
fileListFile
:
[],
readOnly
:
false
,
rules
:
{
courseName
:
[
{
required
:
true
,
trigger
:
"blur"
,
message
:
"课程
名称
不能为空"
},
{
required
:
true
,
trigger
:
"blur"
,
message
:
"课程
标题
不能为空"
},
],
courseType
:
[
{
required
:
true
,
trigger
:
"change"
,
message
:
"课程类型不能为空"
},
...
...
@@ -121,6 +165,15 @@ export default {
enclosure
:
[
{
required
:
true
,
trigger
:
"blur"
,
message
:
"附件不能为空"
},
],
duration
:
[
{
required
:
true
,
trigger
:
"blur"
,
message
:
"培训时长不能为空"
},
],
testStartTime
:
[
{
required
:
true
,
trigger
:
"blur"
,
message
:
"开始时间不能为空"
},
],
testEndTime
:
[
{
required
:
true
,
trigger
:
"blur"
,
message
:
"结束时间不能为空"
},
],
},
};
},
...
...
danger-manage-web/src/views/educationPlanExam/myLessons/CheckLesson/index.vue
View file @
65a65910
...
...
@@ -2,15 +2,17 @@
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-09-20 20:14:18
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 202
2-09-28 16:59:32
* @LastEditTime: 202
3-01-05 09:38:13
* @FilePath: /danger-manage-web/src/views/myLessons/CheckLesson.vue
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
-->
<
template
>
<div
class=
"check-lession flex"
>
<div
class=
"top-title"
>
<div
class=
"item"
>
<div
class=
"item
allone
"
>
<div
class=
"text"
>
{{
state
!=
2
?
"学习课程"
:
"查看课程"
}}
</div>
<div
v-if=
"userlessonData.state!=3"
class=
"gotime"
>
{{
minute
}}
:
{{
calculation
(
second
)
}}
/
{{
parseInt
(
lessonData
.
duration
/
60
)
}}
:
{{
calculation
(
lessonData
.
duration
%
60
)
}}
</div>
<div
v-if=
"userlessonData.state==3"
style=
"background: red"
class=
"gotime"
>
已过期
</div>
</div>
<div
class=
"bt flex fz14 border-bottom"
>
...
...
@@ -38,10 +40,10 @@
</div>
</div>
<div
class=
"bt flex fz14 video"
>
<div
class=
"bt flex fz14 video"
>
<div
class=
"a"
>
视频文件
</div>
<div
class=
"b"
>
<div
class=
"video"
>
<div
class=
"video"
v-if=
"lessonData.video"
>
<video-player
class=
"video-player vjs-custom-skin"
ref=
"videoPlayer"
...
...
@@ -49,6 +51,7 @@
:options=
"playerOptions"
></video-player>
</div>
<div
v-else
>
未上传视频
</div>
</div>
</div>
...
...
@@ -60,6 +63,9 @@
<el-button
style=
"padding: 0; margin-left: 20px"
type=
"text"
>
<a
:href=
"lessonData.enclosure"
>
下载
</a>
</el-button>
<el-button
style=
"padding: 0; margin-left: 20px"
type=
"text"
>
<a
@
click=
"openXslx(lessonData.enclosure)"
>
预览
</a>
</el-button>
</div>
</div>
</div>
...
...
@@ -86,7 +92,7 @@
</div>
<div
class=
"btn-wrapper flex"
>
<el-button
@
click=
"againQuesstion"
type=
"primary"
>
{{
<el-button
v-if=
"this.finish"
@
click=
"againQuesstion"
type=
"primary"
>
{{
state
==
2
||
state
==
1
?
"重新考试"
:
"开始考试"
}}
</el-button>
<el-button
@
click=
"$router.back()"
type=
"primary"
plain
>
取消
</el-button>
...
...
@@ -99,11 +105,14 @@
:visible
.
sync=
"answerOpen"
@
jj=
"jj"
/>
<el-dialog
:visible
.
sync=
"iframeVisible"
width=
"80%"
>
<iframe
style=
"width: 100%; height: 600px"
:src=
"ky"
></iframe>
</el-dialog>
</div>
</
template
>
<
script
>
import
{
getLessonById
}
from
"@/api/educationPlanExam/lessonsProgram"
;
import
{
getLessonById
,
getUserLessonById
,
changeUserLesson
}
from
"@/api/educationPlanExam/lessonsProgram"
;
import
{
getPlanList
}
from
"@/api/educationPlanExam/trainingProgram"
;
import
AnswerLesson
from
"../components/AnswerLesson"
;
...
...
@@ -114,12 +123,18 @@ export default {
},
data
()
{
return
{
finish
:
false
,
minute
:
0
,
second
:
0
,
playerOptions
:
{
aspectRatio
:
"16:9"
,
},
dingshi
:
null
,
// 课程类型
courseOptions
:
[],
lessonData
:
{},
userlessonData
:{},
// 课程id
courseId
:
0
,
// 用户学习id
...
...
@@ -128,6 +143,8 @@ export default {
fenshu
:
0
,
answerOpen
:
false
,
lessonTypeName
:
""
,
iframeVisible
:
false
,
ky
:
"https://view.xdocin.com/222-223-203-154-8082_o52uv3.htm"
,
};
},
created
()
{
...
...
@@ -135,6 +152,11 @@ export default {
this
.
getPlanList
();
this
.
getLessonById
();
},
destroyed
(){
console
.
log
(
'销毁'
);
this
.
updateUserCourse
();
clearInterval
(
this
.
dingshi
);
},
methods
:
{
getPlanList
()
{
getPlanList
().
then
((
res
)
=>
{
...
...
@@ -162,9 +184,52 @@ export default {
getLessonById
(
courseId
).
then
((
res
)
=>
{
if
(
res
.
code
==
200
)
{
this
.
lessonData
=
res
.
data
;
console
.
log
(
this
.
lessonData
);
this
.
changeVideo
(
this
.
lessonData
.
video
);
}
});
getUserLessonById
({
"userCourseId"
:
userCourseId
}).
then
((
res
)
=>
{
if
(
res
.
code
==
200
)
{
this
.
userlessonData
=
res
.
data
;
this
.
second
=
this
.
userlessonData
.
finishDuration
%
60
;
this
.
minute
=
parseInt
(
this
.
userlessonData
.
finishDuration
/
60
);
if
(
this
.
userlessonData
.
state
!=
3
){
this
.
dingshi
=
setInterval
(
this
.
goTime
,
1000
);
}
}
});
},
goTime
(){
if
(
this
.
userlessonData
.
finishDuration
>=
this
.
lessonData
.
duration
){
console
.
log
(
"结束"
);
clearInterval
(
this
.
dingshi
);
this
.
userlessonData
.
trainState
=
1
;
this
.
userlessonData
.
finishDuration
=
this
.
lessonData
.
duration
;
this
.
updateUserCourse
();
}
else
{
this
.
userlessonData
.
finishDuration
=
this
.
userlessonData
.
finishDuration
+
1
;
//console.log(this.userlessonData.finishDuration);
this
.
second
=
this
.
userlessonData
.
finishDuration
%
60
;
this
.
minute
=
parseInt
(
this
.
userlessonData
.
finishDuration
/
60
);
if
(
this
.
userlessonData
.
finishDuration
%
60
==
0
){
this
.
updateUserCourse
();
}
}
},
updateUserCourse
(){
changeUserLesson
(
this
.
userlessonData
).
then
(
response
=>
{
if
(
this
.
userlessonData
.
finishDuration
==
this
.
lessonData
.
duration
){
this
.
finish
=
true
;
}
})
},
calculation
(
num
){
if
(
num
<
10
){
num
=
"0"
+
num
;
}
return
num
;
},
changeVideo
(
src
)
{
this
.
playerOptions
=
{
...
...
@@ -287,4 +352,18 @@ export default {
}
}
}
.allone
{
display
:flex
;
flex-direction
:row
;
justify-content
:flex-start
;
}
.gotime
{
background
:
#1c84c6
;
width
:
80px
;
text-align
:
center
;
line-height
:
22px
;
color
:
white
;
margin-left
:
40px
;
border-radius
:
10px
;
}
</
style
>
danger-manage-web/src/views/educationPlanExam/myLessons/components/LearnAfter.vue
View file @
65a65910
...
...
@@ -78,7 +78,7 @@ export default {
},
computed
:
{
afterList
()
{
return
this
.
list
.
filter
((
item
)
=>
item
.
state
>
1
);
return
this
.
list
.
filter
((
item
)
=>
item
.
state
==
2
);
},
},
created
()
{
...
...
danger-manage-web/src/views/educationPlanExam/myLessons/components/LearnBefore.vue
View file @
65a65910
...
...
@@ -77,7 +77,7 @@ export default {
},
computed
:
{
beforeList
()
{
return
this
.
list
.
filter
((
item
)
=>
item
.
state
<
2
);
return
this
.
list
.
filter
((
item
)
=>
item
.
state
!=
2
);
},
},
created
()
{
...
...
danger-manage-web/src/views/educationPlanExam/myLessons/components/LearnItem.vue
View file @
65a65910
...
...
@@ -16,8 +16,8 @@
</div>
<div
class=
"time"
>
发布时间:
{{
itemData
.
createTime
}}
</div>
<div
class=
"bottom flex"
>
<div
@
click=
"click"
class=
"btn"
:class=
"
{ again: yesOrNo }">
{{
yesOrNo
?
"重新考试"
:
"开始学习"
}}
<div
v-if=
"!itemData.state===4 || !(itemData.state===3 && itemData.dataKind==='1')"
@
click=
"click"
class=
"btn"
:class=
"
{ again: yesOrNo }">
{{
yesOrNo
}}
</div>
</div>
<div
...
...
@@ -25,16 +25,29 @@
:class=
"
{
no: itemData.state === 1,
yes: itemData.state === 2,
ygq:itemData.state === 3,
wks:itemData.state === 4,
}"
>
{{
state
[
itemData
.
state
]
}}
</div>
<AnswerLesson
v-if=
"answerOpen"
:courseId=
"itemData.courseId"
:userCourseId=
"itemData.userCourseId"
:visible
.
sync=
"answerOpen"
@
jj=
"jj"
/>
</div>
</
template
>
<
script
>
import
AnswerLesson
from
"./AnswerLesson"
;
export
default
{
name
:
""
,
components
:
{
AnswerLesson
,
},
props
:
{
itemData
:
{
type
:
Object
,
...
...
@@ -50,14 +63,52 @@ export default {
},
computed
:
{
yesOrNo
()
{
return
this
.
itemData
.
state
==
1
||
this
.
itemData
.
state
==
2
;
console
.
log
(
this
.
itemData
)
if
(
this
.
itemData
.
dataKind
===
"0"
){
if
(
this
.
itemData
.
state
===
0
){
return
'开始学习'
}
else
if
(
this
.
itemData
.
state
===
1
){
return
'重新考试'
}
else
if
(
this
.
itemData
.
state
===
2
){
return
'重新考试'
}
else
if
(
this
.
itemData
.
state
===
3
){
return
'开始学习'
}
else
if
(
this
.
itemData
.
state
===
4
){
return
'还未开始'
}
}
else
{
if
(
this
.
itemData
.
state
===
0
){
return
'开始考试'
}
else
if
(
this
.
itemData
.
state
===
1
){
return
'重新考试'
}
else
if
(
this
.
itemData
.
state
===
2
){
return
'重新考试'
}
else
if
(
this
.
itemData
.
state
===
3
){
return
'开始学习'
}
else
if
(
this
.
itemData
.
state
===
4
){
return
'还未开始'
}
}
},
},
data
()
{
return
{};
return
{
answerOpen
:
false
};
},
methods
:
{
jj
(
e
)
{
if
(
e
.
answer
>=
e
.
qualifiedNum
)
{
this
.
fenshu
=
Math
.
floor
((
e
.
answer
/
e
.
topicNum
)
*
100
);
this
.
state
=
2
;
}
},
click
()
{
if
(
this
.
itemData
.
dataKind
===
'1'
){
this
.
answerOpen
=
true
;
return
;
}
const
{
courseId
,
userCourseId
,
state
,
examinationResult
,
topicNum
}
=
this
.
itemData
;
// if (!this.yesOrNo) {
...
...
@@ -73,6 +124,7 @@ export default {
path
:
"myLessons/CheckLesson"
,
query
:
{
courseId
,
userCourseId
,
state
,
fenshu
},
});
// } else {
// this.$emit("examination", { courseId, userCourseId });
// }
...
...
@@ -161,6 +213,12 @@ export default {
&
.yes
{
background
:
#3cc426
!
important
;
}
&
.ygq
{
background
:
red
!
important
;
}
&
.wks
{
background
:
yellow
!
important
;
}
}
}
</
style
>
danger-manage-web/src/views/educationPlanExam/myLessons/components/Left.vue
View file @
65a65910
...
...
@@ -38,9 +38,11 @@ export default {
currentTabComponent
:
LearnBefore
,
list
:[],
state
:{
"0"
:
'未
学习
'
,
"0"
:
'未
完成
'
,
"1"
:
'未通过'
,
"2"
:
"通过"
"2"
:
"已完成"
,
"3"
:
"已过期"
,
"4"
:
"未开始"
},
};
},
...
...
danger-manage-web/src/views/educationPlanExam/trainingProgram/components/Lesson.vue
View file @
65a65910
...
...
@@ -19,17 +19,17 @@
<el-form-item
label=
"计划名称"
prop=
"bankName"
>
<el-input
style=
"width: 500px"
v-model=
"form.bankName"
></el-input>
</el-form-item>
<
el-form-item
label=
"人员类型"
prop=
"personnelType"
>
<
el-select
v-model=
"form.personnelType"
placeholder=
"请选择"
>
<
el-option
v-for=
"item in options"
:key=
"item.value"
:label=
"item.label"
:value=
"item.value"
>
<
/el-option
>
<
/el-select
>
<
/el-form-item
>
<
!--
<el-form-item
label=
"人员类型"
prop=
"personnelType"
>
--
>
<
!--
<el-select
v-model=
"form.personnelType"
placeholder=
"请选择"
>
--
>
<
!--
<el-option-->
<!--v-for="item in options"-->
<!--:key="item.value"-->
<!--:label="item.label"-->
<!--:value="item.value"-->
<!-->--
>
<
!--
</el-option>
--
>
<
!--
</el-select>
--
>
<
!--
</el-form-item>
--
>
<!--
<el-form-item
label=
"开始时间"
prop=
"releaseTime"
>
-->
<!--
<el-date-picker-->
<!--v-model="form.startTime"-->
...
...
danger-manage-web/src/views/system/book/index.vue
View file @
65a65910
This diff is collapsed.
Click to expand it.
danger-manage-web/src/views/system/drill/index.vue
View file @
65a65910
...
...
@@ -143,9 +143,10 @@
/>
<!-- 添加或修改应急演练对话框 -->
<el-dialog
:title=
"title"
:visible
.
sync=
"open"
width=
"1
8
00px"
append-to-body
>
<el-dialog
:title=
"title"
:visible
.
sync=
"open"
width=
"1
1
00px"
append-to-body
>
<el-form
ref=
"form"
:model=
"form"
:rules=
"rules"
label-width=
"90px"
>
<div
class=
"division"
>
<div
class=
"division"
style=
"margin-bottom:20px"
>
<div
class=
"div-kuang"
style=
"width: 50%;"
>
<el-form-item
label=
"演练名称"
prop=
"drillName"
>
<el-input
v-model=
"form.drillName"
placeholder=
"请输入演练名称"
/>
...
...
@@ -199,21 +200,20 @@
</el-form-item>
</div>
</div>
<div
class=
"div-kuang"
style=
"width: 95%;margin-left: 2%"
>
<el-form-item
label=
"选择人员"
prop=
"releaseTime"
>
<!-- table -->
<!-- jsonSelectNameList就是呗选中的人员的json -->
<!-- getPeopleList 是每次选中或者删除人员都会返回 一个所有人员列表的json串,[{staffId:staffId,staffName:staffName},{staffId:staffId,staffName:staffName}] -->
<!-- 要在jsonSelectNameList赋值完毕之后 调用一下 this.$refs.changePaple.changeNameList 135行 -->
<ChangePapel
ref=
"changePaple"
:jsonSelectNameList=
"jsonSelectNameList"
@
getPeopleList=
"getPeopleList"
/>
</el-form-item>
</div>
<div
class=
"div-kuang"
style=
"width: 100%;"
>
<el-form-item
label=
"选择人员"
prop=
"releaseTime"
>
<!-- table -->
<!-- jsonSelectNameList就是呗选中的人员的json -->
<!-- getPeopleList 是每次选中或者删除人员都会返回 一个所有人员列表的json串,[{staffId:staffId,staffName:staffName},{staffId:staffId,staffName:staffName}] -->
<!-- 要在jsonSelectNameList赋值完毕之后 调用一下 this.$refs.changePaple.changeNameList 135行 -->
<ChangePapel
ref=
"changePaple"
:jsonSelectNameList=
"jsonSelectNameList"
@
getPeopleList=
"getPeopleList"
/>
</el-form-item>
</div>
...
...
@@ -258,7 +258,7 @@
</div>
<div
class=
"div-kuang"
style=
"width: 58%;margin-left: 2%"
>
<el-form-item
label=
"参演人员:"
prop=
"drillPeople"
>
<span
>
{{form.drillPeopl
e}}
</span>
<span
style=
"margin-right:5px"
v-for=
'item in form.jsonPeople'
:key=
"item.peoPleId"
>
{{item.peoPleNam
e}}
</span>
</el-form-item>
<el-form-item
label=
"演练内容:"
>
<editor
v-model=
"form.drillContent"
:min-height=
"240"
:readOnly=
"readOnly"
/>
...
...
@@ -396,10 +396,6 @@ export default {
});
},
mounted
()
{
// this.jsonSelectNameList
// '[{"staffId":880,"staffName":"孙卓亚"},{"staffId":871,"staffName":"张玉宾"},{"staffId":869,"staffName":"李二朝"},{"staffId":870,"staffName":"盖永峰"},{"staffId":868,"staffName":"刘丽艳"},{"staffId":867,"staffName":"霍文俊"},{"staffId":866,"staffName":"刘志坚"},{"staffId":865,"staffName":"郝文权"},{"staffId":864,"staffName":"齐雪军"},{"staffId":852,"staffName":"刘江平"},{"staffId":853,"staffName":"谷建海"},{"staffId":851,"staffName":"丁振国"},{"staffId":850,"staffName":"齐江波"},{"staffId":849,"staffName":"周立新"},{"staffId":848,"staffName":"史志波"},{"staffId":847,"staffName":"王增波"},{"staffId":846,"staffName":"杨彦龙"},{"staffId":845,"staffName":"杨华国"},{"staffId":844,"staffName":"王青华"}]';
this
.
$refs
.
changePaple
.
changeNameList
(
this
.
jsonSelectNameList
);
},
methods
:
{
// 获取参考人员的list
...
...
@@ -428,6 +424,9 @@ export default {
const
data
=
[];
TStaffList
(
this
.
addDateRange
(
this
.
queryParams
,
this
.
dateRange
)).
then
(
response
=>
{
this
.
jsonSelectNameList
=
response
;
this
.
$nextTick
(()
=>
{
this
.
$refs
.
changePaple
.
changeNameList
(
this
.
jsonSelectNameList
);
})
// response.rows.forEach((city, index) => {
// data.push({
// label: city.staffName,
...
...
@@ -511,11 +510,13 @@ export default {
// this.cities = response.rows.staffName;
// generateData.cities=['shanghai', 'beijing', 'guangzhou', 'shenzhen', 'nanjing', 'xian', 'chengdu']
// });
this
.
generateData
();
this
.
reset
();
this
.
open
=
true
;
this
.
title
=
"添加应急演练"
;
this
.
$nextTick
(()
=>
{
this
.
$refs
.
changePaple
.
changeNameList
(
this
.
jsonSelectNameList
);
})
},
/** 修改按钮操作 */
handleUpdate
(
row
)
{
...
...
@@ -525,6 +526,11 @@ export default {
this
.
form
=
response
.
data
;
this
.
open
=
true
;
this
.
title
=
"修改应急演练"
;
console
.
log
(
response
.
data
.
drillPeople
)
this
.
jsonSelectNameList
=
response
.
data
.
drillPeople
;
this
.
$nextTick
(()
=>
{
this
.
$refs
.
changePaple
.
changeNameList
(
this
.
jsonSelectNameList
);
})
});
},
/** 评估按钮操作 */
...
...
@@ -565,6 +571,8 @@ export default {
handleDetail
(
row
)
{
getDrill
(
row
.
drillId
).
then
(
response
=>
{
this
.
form
=
response
.
data
;
this
.
form
.
jsonPeople
=
JSON
.
parse
(
this
.
form
.
drillPeople
)
console
.
log
(
this
.
form
.
jsonPeople
)
this
.
form
.
drillType
=
this
.
selectDictLabel
(
this
.
drillTypeOptions
,
row
.
drillType
);
this
.
form
.
drillForm
=
this
.
selectDictLabel
(
this
.
drillFormOptions
,
row
.
drillForm
);
this
.
open2
=
true
;
...
...
@@ -607,6 +615,7 @@ export default {
background
:
white
;
padding-top
:
20px
;
padding-right
:
20px
;
padding-bottom
:
10px
;
border-radius
:
10px
;
}
.division
{
...
...
danger-manage-web/src/views/system/library/index.vue
View file @
65a65910
...
...
@@ -189,9 +189,9 @@ export default {
inspectTerm
:
[
{
required
:
true
,
message
:
"隐患名称不能为空"
,
trigger
:
"change"
}
],
inspectBasis
:
[
{
required
:
true
,
message
:
"检查依据不能为空"
,
trigger
:
"change"
}
],
//
inspectBasis: [
//
{ required: true, message: "检查依据不能为空", trigger: "change" }
//
],
// libraryContent: [
// { required: true, message: "内容/标准不能为空", trigger: "change" }
// ],
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment