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
fa399a4b
Commit
fa399a4b
authored
Dec 21, 2022
by
纪泽龙
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
制作考试人员选择的组件
parent
12b3a02a
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
2466 additions
and
70 deletions
+2466
-70
zehong.scss
danger-manage-web/src/assets/styles/zehong.scss
+81
-0
ChangPapelTable.vue
...anage-web/src/components/PeopleChange/ChangPapelTable.vue
+133
-0
index.vue
danger-manage-web/src/components/PeopleChange/index.vue
+280
-0
AddQuestion.vue
...educationPlanExam/questionBank/components/AddQuestion.vue
+25
-25
Dia.vue
...c/views/educationPlanExam/questionBank/components/Dia.vue
+9
-9
Lesson.vue
...iews/educationPlanExam/questionBank/components/Lesson.vue
+14
-14
QuestionList.vue
...ducationPlanExam/questionBank/components/QuestionList.vue
+17
-17
index.vue
...ge-web/src/views/educationPlanExam/questionBank/index.vue
+5
-4
AddQuestion.vue
...ws/educationPlanExam/textPaper/components/AddQuestion.vue
+345
-0
Dia.vue
.../src/views/educationPlanExam/textPaper/components/Dia.vue
+173
-0
Editor.vue
...c/views/educationPlanExam/textPaper/components/Editor.vue
+262
-0
Lesson.vue
...c/views/educationPlanExam/textPaper/components/Lesson.vue
+257
-0
QuestionList.vue
...s/educationPlanExam/textPaper/components/QuestionList.vue
+333
-0
index.vue
...anage-web/src/views/educationPlanExam/textPaper/index.vue
+531
-0
vue.config.js
danger-manage-web/vue.config.js
+1
-1
No files found.
danger-manage-web/src/assets/styles/zehong.scss
View file @
fa399a4b
...
@@ -355,4 +355,85 @@
...
@@ -355,4 +355,85 @@
margin
:
0
;
margin
:
0
;
}
}
}
// text-Paper lession.vue table样式
.left-middle-table
{
.el-table
th
.el-table__cell.is-leaf
,
.el-table
td
.el-table__cell
{
border
:
none
}
.has-gutter
.el-table
th
.el-table__cell.is-leaf
,
.el-table
td
.el-table__cell
{
border-bottom
:
1px
solid
#E5E6EB
;
}
.el-table
th
.el-table__cell.is-leaf
,
.el-table
td
.el-table__cell
{
box-sizing
:
border-box
;
}
.el-table--medium
.el-table__cell
:nth-child
(
1
)
{
padding
:
0
;
}
.el-table
.el-table__header-wrapper
th
,
.el-table
.el-table__fixed-header-wrapper
th
{
background-color
:
#F7F7F7
;
}
.el-table--fit
{
// height: 100%;
}
.el-table
th
.el-table__cell
>
.cell
{
padding-left
:
14px
;
}
.
el-table
:
:
before
{
height
:
0px
;
}
// 表头的input样式
.el-checkbox__input.is-indeterminate
.el-checkbox__inner
{
background-color
:
rgba
(
0
,
0
,
0
,
0
);
border-color
:
#C4C4C4
;
}
.el-checkbox__input.is-indeterminate
.el-checkbox__inner
:before
{
background-color
:
#62656C
!
important
;
}
// 内容的
// 改变对钩颜色
.el-checkbox__inner
:after
{
border-color
:
#62656C
!
important
;
}
.el-checkbox__inner
{
border
:
1px
solid
#C4C4C4
;
}
.el-checkbox__input.is-checked
.el-checkbox__inner
{
background-color
:
rgba
(
0
,
0
,
0
,
0
);
border-color
:
#C4C4C4
;
}
.el-checkbox__input.is-checked
.el-checkbox__inner
{
border-color
:
#C4C4C4
;
}
.el-checkbox__input.is-focus
.el-checkbox__inner
{
border-color
:
#C4C4C4
;
}
.el-checkbox__inner
:hover
{
border-color
:
#C4C4C4
;
}
}
}
\ No newline at end of file
danger-manage-web/src/components/PeopleChange/ChangPapelTable.vue
0 → 100644
View file @
fa399a4b
<!--
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-12-19 15:23:58
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 2022-12-21 16:56:26
* @FilePath: /danger-manage-web/src/views/educationPlanExam/textPaper/components/Lesson-table.vue
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
-->
<
template
>
<div>
<el-table
v-loading=
"loading"
:data=
"nameList"
height=
"305"
@
select=
"select"
@
select-all=
"all"
ref=
"multipleTable"
>
<el-table-column
type=
"selection"
></el-table-column>
<el-table-column
label=
"姓名"
align=
"center"
prop=
"staffName"
>
</el-table-column>
<el-table-column
label=
"所属部门"
align=
"center"
prop=
"deptName"
:formatter=
"formatter"
>
</el-table-column>
<el-table-column
label=
"岗位"
align=
"center"
prop=
"profession"
:formatter=
"formatter"
>
</el-table-column>
</el-table>
<!--
<div>
-->
<el-pagination
:layout=
"'prev, pager, next'"
v-show=
"total > 0"
:total=
"total"
:current-page=
"queryParams.pageNum"
:page-sizes=
"[queryParams.pageSize]"
@
current-change=
"currentChangeClick"
/>
<!--
</div>
-->
</div>
</
template
>
<
script
>
import
{
listStaff
}
from
"@/api/safetyManagement/staff"
;
export
default
{
name
:
""
,
props
:
{
selectNameList
:
{
type
:
Array
,
},
},
created
()
{
// this.listStaff();
},
data
()
{
return
{
queryParams
:
{
pageNum
:
1
,
pageSize
:
10
,
deptId
:
null
,
staffName
:
null
,
},
total
:
0
,
nameList
:
[],
loading
:
false
,
};
},
methods
:
{
listStaff
()
{
this
.
loading
=
true
;
listStaff
(
this
.
queryParams
).
then
((
res
)
=>
{
this
.
total
=
res
.
total
;
this
.
nameList
=
res
.
rows
;
this
.
$nextTick
((
item
)
=>
{
this
.
selectNameList
.
forEach
((
item
)
=>
{
this
.
toggleSelection
(
item
.
staffId
,
true
);
});
this
.
loading
=
false
;
});
});
},
// toggleSelection(rows) {
// if (rows) {
// rows.forEach((row) => {
// this.$refs.multipleTable.toggleRowSelection(row);
// });
// } else {
// this.$refs.multipleTable.clearSelection();
// }
// },
select
(
all
,
row
)
{
this
.
$emit
(
"selectOne"
,
all
,
row
);
},
all
(
all
)
{
console
.
log
(
all
);
// true是全选,false是全清
let
allSelect
=
false
;
if
(
all
.
length
==
0
||
(
all
.
length
==
1
&&
[
0
]
==
undefined
))
{
allSelect
=
false
;
}
else
if
(
all
.
length
>
1
)
{
allSelect
=
true
;
}
this
.
$emit
(
"selectAll"
,
this
.
nameList
,
allSelect
);
},
// 切换选项
toggleSelection
(
staffId
,
SeclctFlag
=
false
)
{
const
item
=
this
.
nameList
.
find
((
item
)
=>
{
return
item
.
staffId
==
staffId
;
});
this
.
$refs
.
multipleTable
.
toggleRowSelection
(
item
,
SeclctFlag
);
},
currentChangeClick
(
val
)
{
this
.
queryParams
.
pageNum
=
val
;
this
.
listStaff
();
},
formatter
(
row
,
column
,
cellValue
,
index
)
{
// console.log(row, column, cellValue, index);
if
(
!
cellValue
)
return
"-"
;
else
return
cellValue
;
},
},
};
</
script
>
<
style
lang=
"scss"
scoped
>
</
style
>
danger-manage-web/src/components/PeopleChange/index.vue
0 → 100644
View file @
fa399a4b
<!--
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-12-19 17:39:55
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 2022-12-21 17:36:34
* @FilePath: /danger-manage-web/src/views/educationPlanExam/textPaper/components/ChangePapel.vue
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
-->
<
template
>
<div
class=
"changePeople-wrapper flex"
>
<div
class=
"changePeople-left"
>
<div
class=
"top-search flex"
>
<el-select
v-model=
"deptId"
filterable
placeholder=
"请选择"
size=
"mini"
style=
"width: 40%"
clearable
>
<el-option
v-for=
"item in searchList"
:key=
"item.deptId"
:label=
"item.deptName"
:value=
"item.deptId"
>
</el-option>
</el-select>
<el-input
v-model=
"staffName"
size=
"mini"
placeholder=
"请输入内容"
suffix-icon=
"el-icon-date"
style=
"width: 48%"
>
</el-input>
<div>
<el-button
@
click=
"searchTable"
size=
"mini"
>
搜索
</el-button>
</div>
</div>
<div
class=
"left-middle-table"
>
<ChangPapelTable
ref=
"table"
:selectNameList
.
sync=
"selectNameList"
@
selectOne=
"selectOne"
@
selectAll=
"selectAll"
/>
</div>
<!--
<div
class=
"bottom-text"
>
共有3n人
</div>
-->
</div>
<div
class=
"middle flex"
>
<div>
>>>
</div>
</div>
<div
class=
"changePeople-right flex"
>
<div
class=
"people-card flex zzz"
>
<div
class=
"item flex"
v-for=
"item in selectNameList"
:key=
"item.staffId"
>
<div>
{{
item
.
staffName
}}
</div>
<div
class=
"close"
@
click=
"deleteName(item.staffId)"
>
x
</div>
</div>
</div>
<div
class=
"bottom-text"
>
已选择n人
</div>
</div>
</div>
</
template
>
<
script
>
import
ChangPapelTable
from
"./ChangPapelTable"
;
import
{
listDept
}
from
"@/api/system/dept"
;
export
default
{
name
:
"changepeopel"
,
components
:
{
ChangPapelTable
,
},
props
:
{
// 传进组件的已经被选择的人名
jsonSelectNameList
:
{
type
:
String
,
default
:
null
,
},
},
data
()
{
return
{
selectNameList
:
[],
searchList
:
[],
deptId
:
null
,
staffName
:
null
,
};
},
created
()
{
listDept
().
then
((
res
)
=>
{
console
.
log
(
res
);
this
.
searchList
=
res
.
data
;
});
},
mounted
()
{},
watch
:
{
selectNameList
()
{
let
json
;
if
(
this
.
selectNameList
.
length
==
0
)
{
json
=
null
;
}
if
(
Array
.
isArray
(
this
.
selectNameList
))
{
json
=
this
.
selectNameList
.
map
((
item
)
=>
{
return
{
staffId
:
item
.
staffId
,
staffName
:
item
.
staffName
,
};
});
}
else
{
json
=
this
.
selectNameList
;
}
this
.
$emit
(
"getPeopleList"
,
JSON
.
stringify
(
json
));
},
},
methods
:
{
changeNameList
(
jsonSelectNameList
)
{
if
(
jsonSelectNameList
)
{
this
.
selectNameList
=
JSON
.
parse
(
jsonSelectNameList
);
}
else
{
this
.
selectNameList
=
[];
}
this
.
$refs
.
table
.
listStaff
();
},
searchTable
()
{
this
.
$refs
.
table
.
queryParams
=
{
pageNum
:
1
,
pageSize
:
10
,
deptId
:
this
.
deptId
,
staffName
:
this
.
staffName
,
};
this
.
$refs
.
table
.
listStaff
();
},
deleteName
(
staffId
)
{
const
index
=
this
.
selectNameList
.
findIndex
((
item
)
=>
{
return
item
.
staffId
==
staffId
;
});
if
(
index
>=
0
)
{
console
.
log
(
index
);
this
.
selectNameList
.
splice
(
index
,
1
);
this
.
$refs
.
table
.
toggleSelection
(
staffId
);
}
},
addName
(
row
)
{
const
index
=
this
.
selectNameList
.
findIndex
((
item
)
=>
{
// console.log(item.id)
return
item
.
staffId
==
row
.
staffId
;
});
console
.
log
(
index
);
if
(
index
>=
0
)
{
this
.
selectNameList
.
splice
(
index
,
1
);
}
else
{
this
.
selectNameList
.
push
(
row
);
}
},
selectAll
(
all
,
allSelect
)
{
// console.log(all);
console
.
log
(
allSelect
);
if
(
allSelect
)
{
all
.
forEach
((
item
)
=>
{
const
index
=
this
.
selectNameList
.
findIndex
((
iten
)
=>
{
return
iten
.
staffId
==
item
.
staffId
;
});
if
(
index
<
0
)
{
this
.
selectNameList
.
push
(
item
);
}
});
}
else
{
all
.
forEach
((
item
)
=>
{
this
.
deleteName
(
item
.
staffId
);
});
}
},
selectOne
(
all
,
row
)
{
this
.
addName
(
row
);
// console.log(all,row)
},
},
};
</
script
>
<
style
lang=
"scss"
scoped
>
.changePeople-wrapper
{
width
:
100%
;
height
:
400px
;
// background-color: red;
margin-top
:
10px
;
justify-content
:
space-between
;
&
>
div
{
flex-direction
:
column
;
}
.changePeople-left
,
.changePeople-right
{
width
:
415px
;
height
:
100%
;
border
:
1px
solid
#e5e6eb
;
}
.middle
{
align-items
:
center
;
justify-content
:
center
;
div
{
color
:
#1890FF
;
font-weight
:
2000
;
}
}
.changePeople-left
{
padding
:
14px
20px
11px
16px
;
flex-direction
:
column
;
.top-search
{
margin-bottom
:
12px
;
justify-content
:
space-between
;
}
.left-middle-table
{
flex
:
1
;
// background: red;
}
.bottom-text
{
padding-top
:
10px
;
font-size
:
12px
;
height
:
20px
;
line-height
:
20px
;
text-align
:
right
;
color
:
#1890ff
;
}
}
.changePeople-right
{
flex-direction
:
column
;
padding-top
:
14px
;
height
:
100%
;
.people-card
{
flex-wrap
:
wrap
;
align-content
:
flex-start
;
width
:
100%
;
flex
:
1
;
height
:
0
;
padding-left
:
11px
;
overflow-y
:
scroll
;
&
:
:-
webkit-scrollbar
{
display
:
none
;
/* Chrome Safari */
}
.item
{
width
:
70px
;
height
:
30px
;
line-height
:
30px
;
padding-left
:
10px
;
padding-right
:
5px
;
margin-right
:
10px
;
color
:
#3d3d3d
;
box-sizing
:
border-box
;
margin-bottom
:
10px
;
box-sizing
:
border-box
;
border
:
1px
solid
#a3d3ff
;
border-radius
:
3px
;
font-size
:
12px
;
position
:
relative
;
justify-content
:
space-between
;
}
.close
{
cursor
:
pointer
;
}
}
.bottom-text
{
// padding-top: 10px;
padding-right
:
10px
;
font-size
:
12px
;
height
:
20px
;
line-height
:
20px
;
text-align
:
right
;
color
:
#1890ff
;
}
}
}
</
style
>
danger-manage-web/src/views/educationPlanExam/questionBank/components/AddQuestion.vue
View file @
fa399a4b
...
@@ -116,13 +116,13 @@
...
@@ -116,13 +116,13 @@
</
template
>
</
template
>
<
script
>
<
script
>
import
{
//
import {
addQuestion
,
//
addQuestion,
checkQuestion
,
//
checkQuestion,
changeQuestion
,
//
changeQuestion,
getQuestion
,
//
getQuestion,
getLessonById
,
//
getLessonById,
}
from
"@/api/educationPlanExam/lessonsProgram.js"
;
//
} from "@/api/educationPlanExam/lessonsProgram.js";
import
{
addSubject
,
getSubject
,
listSubject
,
updateSubject
}
from
"@/api/educationPlanExam/subject"
;
import
{
addSubject
,
getSubject
,
listSubject
,
updateSubject
}
from
"@/api/educationPlanExam/subject"
;
export
default
{
export
default
{
...
@@ -132,10 +132,10 @@ export default {
...
@@ -132,10 +132,10 @@ export default {
// type: Boolean,
// type: Boolean,
// default: false,
// default: false,
// },
// },
course
Id
:
{
bank
Id
:
{
type
:
Number
,
type
:
Number
,
},
},
topic
Id
:
{
subject
Id
:
{
type
:
Number
,
type
:
Number
,
},
},
},
},
...
@@ -156,8 +156,8 @@ export default {
...
@@ -156,8 +156,8 @@ export default {
created
()
{
created
()
{
// 如果存在就是修改
// 如果存在就是修改
if
(
this
.
topic
Id
)
{
if
(
this
.
subject
Id
)
{
getSubject
(
this
.
topic
Id
).
then
((
res
)
=>
{
getSubject
(
this
.
subject
Id
).
then
((
res
)
=>
{
console
.
log
(
'?'
,
res
.
data
);
console
.
log
(
'?'
,
res
.
data
);
const
data
=
res
.
data
;
const
data
=
res
.
data
;
this
.
form
=
{
this
.
form
=
{
...
@@ -171,16 +171,16 @@ export default {
...
@@ -171,16 +171,16 @@ export default {
// 查询是第几道题
// 查询是第几道题
this
.
getQuestion
();
this
.
getQuestion
();
// 获取课程标题
// 获取课程标题
this
.
getLessonById
(
this
.
course
Id
);
// this.getLessonById(this.bank
Id);
},
},
methods
:
{
methods
:
{
getQuestion
()
{
getQuestion
()
{
listSubject
({
bankId
:
this
.
course
Id
}).
then
((
res
)
=>
{
listSubject
({
bankId
:
this
.
bank
Id
}).
then
((
res
)
=>
{
console
.
log
(
res
)
console
.
log
(
res
)
// 如果是修改 就是原来的值,如果不是,就是总数+1
// 如果是修改 就是原来的值,如果不是,就是总数+1
if
(
this
.
topic
Id
)
{
if
(
this
.
subject
Id
)
{
res
.
rows
.
forEach
((
item
,
index
)
=>
{
res
.
rows
.
forEach
((
item
,
index
)
=>
{
if
(
item
.
subjectId
==
this
.
topic
Id
)
{
if
(
item
.
subjectId
==
this
.
subject
Id
)
{
this
.
questionNextNum
=
index
+
1
;
this
.
questionNextNum
=
index
+
1
;
}
}
});
});
...
@@ -189,18 +189,18 @@ export default {
...
@@ -189,18 +189,18 @@ export default {
}
}
});
});
},
},
getLessonById
(
course
Id
)
{
// getLessonById(bank
Id) {
getLessonById
(
course
Id
).
then
((
res
)
=>
{
// getLessonById(bank
Id).then((res) => {
console
.
log
(
res
);
//
console.log(res);
this
.
courseName
=
res
.
data
.
courseName
;
//
this.courseName = res.data.courseName;
});
//
});
},
//
},
addQuestion
(
data
)
{
addQuestion
(
data
)
{
// 如果是修改,就用修改的方法,如果是新增,就用新增的方法
// 如果是修改,就用修改的方法,如果是新增,就用新增的方法
if
(
this
.
topic
Id
)
{
if
(
this
.
subject
Id
)
{
return
updateSubject
({
subjectId
:
this
.
topic
Id
,
...
data
});
return
updateSubject
({
subjectId
:
this
.
subject
Id
,
...
data
});
}
else
{
}
else
{
return
addSubject
({
bankId
:
this
.
course
Id
,
...
data
});
return
addSubject
({
bankId
:
this
.
bank
Id
,
...
data
});
}
}
},
},
rightAnswerClick
(
index
)
{
rightAnswerClick
(
index
)
{
...
@@ -241,7 +241,7 @@ export default {
...
@@ -241,7 +241,7 @@ export default {
this
.
addQuestion
(
data
).
then
((
res
)
=>
{
this
.
addQuestion
(
data
).
then
((
res
)
=>
{
if
(
res
.
code
==
200
)
{
if
(
res
.
code
==
200
)
{
// 把修改的这个归位,变成正常添加
// 把修改的这个归位,变成正常添加
this
.
$emit
(
"update:
topic
Id"
,
null
);
this
.
$emit
(
"update:
subject
Id"
,
null
);
this
.
$message
({
this
.
$message
({
message
:
"添加题目成功"
,
message
:
"添加题目成功"
,
type
:
"success"
,
type
:
"success"
,
...
...
danger-manage-web/src/views/educationPlanExam/questionBank/components/Dia.vue
View file @
fa399a4b
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* @Author: 纪泽龙 jizelong@qq.com
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-09-22 10:38:49
* @Date: 2022-09-22 10:38:49
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 2022-
09-28 17:48:07
* @LastEditTime: 2022-
12-17 14:28:56
* @FilePath: /danger-manage-web/src/views/lessonsProgram/components/addLesson.vue
* @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
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
-->
-->
...
@@ -22,8 +22,8 @@
...
@@ -22,8 +22,8 @@
<transition
name=
"fade"
mode=
"out-in"
>
<transition
name=
"fade"
mode=
"out-in"
>
<component
<component
:is=
"currentComponent"
:is=
"currentComponent"
:
courseId
.
sync=
"course
Id"
:
bankId
.
sync=
"bank
Id"
:
topicId
.
sync=
"topic
Id"
:
subjectId
.
sync=
"subject
Id"
ref=
"current"
ref=
"current"
></component>
></component>
</transition>
</transition>
...
@@ -70,7 +70,7 @@ export default {
...
@@ -70,7 +70,7 @@ export default {
type
:
Number
,
type
:
Number
,
default
:
1
,
default
:
1
,
},
},
course
Id
:
{
bank
Id
:
{
type
:
Number
,
type
:
Number
,
},
},
},
},
...
@@ -85,7 +85,7 @@ export default {
...
@@ -85,7 +85,7 @@ export default {
title
:
"录入课程"
,
title
:
"录入课程"
,
currentComponent
:
Lesson
,
currentComponent
:
Lesson
,
// 当前题目查看
// 当前题目查看
topic
Id
:
null
,
subject
Id
:
null
,
};
};
},
},
watch
:
{
watch
:
{
...
@@ -93,7 +93,7 @@ export default {
...
@@ -93,7 +93,7 @@ export default {
handler
(
num
)
{
handler
(
num
)
{
if
(
num
===
1
)
{
if
(
num
===
1
)
{
this
.
currentComponent
=
Lesson
;
this
.
currentComponent
=
Lesson
;
if
(
this
.
course
Id
)
{
if
(
this
.
bank
Id
)
{
this
.
title
=
"修改课程"
;
this
.
title
=
"修改课程"
;
}
else
{
}
else
{
this
.
title
=
"新增课程"
;
this
.
title
=
"新增课程"
;
...
@@ -104,7 +104,7 @@ export default {
...
@@ -104,7 +104,7 @@ export default {
this
.
title
=
"题目列表"
;
this
.
title
=
"题目列表"
;
}
else
{
}
else
{
this
.
currentComponent
=
AddQuestion
;
this
.
currentComponent
=
AddQuestion
;
if
(
this
.
topic
Id
)
{
if
(
this
.
subject
Id
)
{
this
.
title
=
"修改题目"
;
this
.
title
=
"修改题目"
;
}
else
{
}
else
{
this
.
title
=
"新增题目"
;
this
.
title
=
"新增题目"
;
...
@@ -148,8 +148,8 @@ export default {
...
@@ -148,8 +148,8 @@ export default {
this
.
$emit
(
"update:visible"
,
false
);
this
.
$emit
(
"update:visible"
,
false
);
},
},
// 把ID改变了
// 把ID改变了
changeCourseId
(
course
Id
)
{
changeCourseId
(
bank
Id
)
{
this
.
$emit
(
"update:
courseId"
,
course
Id
);
this
.
$emit
(
"update:
bankId"
,
bank
Id
);
},
},
// 改变当前组件
// 改变当前组件
componentsNumChange
(
num
)
{
componentsNumChange
(
num
)
{
...
...
danger-manage-web/src/views/educationPlanExam/questionBank/components/Lesson.vue
View file @
fa399a4b
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* @Author: 纪泽龙 jizelong@qq.com
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-09-22 10:59:44
* @Date: 2022-09-22 10:59:44
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 2022-12-1
6 17:35:0
4
* @LastEditTime: 2022-12-1
7 14:36:1
4
* @FilePath: /danger-manage-web/src/views/lessonsProgram/components/Lession.vue
* @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
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
-->
-->
...
@@ -79,12 +79,12 @@
...
@@ -79,12 +79,12 @@
import
Editor
from
"./Editor"
;
import
Editor
from
"./Editor"
;
import
FileUpload
from
"@/components/FileUpload"
;
import
FileUpload
from
"@/components/FileUpload"
;
import
uploadfile
from
"@/assets/uploadfile.png"
;
import
uploadfile
from
"@/assets/uploadfile.png"
;
import
{
mapGetters
}
from
"vuex"
;
//
import { mapGetters } from "vuex";
import
{
//
import {
addLessons
,
//
addLessons,
getLessonById
,
//
getLessonById,
changeLesson
,
//
changeLesson,
}
from
"@/api/educationPlanExam/lessonsProgram"
;
//
} from "@/api/educationPlanExam/lessonsProgram";
import
{
import
{
listBank
,
listBank
,
addBank
,
addBank
,
...
@@ -100,7 +100,7 @@ import "@riophae/vue-treeselect/dist/vue-treeselect.css";
...
@@ -100,7 +100,7 @@ import "@riophae/vue-treeselect/dist/vue-treeselect.css";
export
default
{
export
default
{
name
:
""
,
name
:
""
,
props
:
{
props
:
{
course
Id
:
{
bank
Id
:
{
type
:
Number
,
type
:
Number
,
},
},
},
},
...
@@ -150,7 +150,7 @@ export default {
...
@@ -150,7 +150,7 @@ export default {
// ...mapGetters(["courseOptions"]),
// ...mapGetters(["courseOptions"]),
},
},
created
()
{
created
()
{
if
(
this
.
course
Id
)
{
if
(
this
.
bank
Id
)
{
this
.
getLessonById
();
this
.
getLessonById
();
}
}
// 归属部门列表
// 归属部门列表
...
@@ -160,12 +160,12 @@ export default {
...
@@ -160,12 +160,12 @@ export default {
methods
:
{
methods
:
{
// 添加课程
// 添加课程
addLessons
(
data
)
{
addLessons
(
data
)
{
if
(
!
this
.
course
Id
)
{
if
(
!
this
.
bank
Id
)
{
console
.
log
(
"添加"
);
console
.
log
(
"添加"
);
return
addBank
(
data
);
return
addBank
(
data
);
}
else
{
}
else
{
console
.
log
(
"修改"
);
console
.
log
(
"修改"
);
return
updateBank
({
bankId
:
this
.
course
Id
,
...
data
});
return
updateBank
({
bankId
:
this
.
bank
Id
,
...
data
});
}
}
},
},
/** 查询部门下拉树结构 */
/** 查询部门下拉树结构 */
...
@@ -195,7 +195,7 @@ export default {
...
@@ -195,7 +195,7 @@ export default {
select
()
{},
select
()
{},
// 复现
// 复现
getLessonById
()
{
getLessonById
()
{
getBank
(
this
.
course
Id
).
then
((
res
)
=>
{
getBank
(
this
.
bank
Id
).
then
((
res
)
=>
{
console
.
log
(
"res"
,
res
);
console
.
log
(
"res"
,
res
);
if
(
res
.
code
==
200
)
{
if
(
res
.
code
==
200
)
{
this
.
form
=
{
this
.
form
=
{
...
@@ -267,7 +267,7 @@ export default {
...
@@ -267,7 +267,7 @@ export default {
this
.
addLessons
({
...
this
.
form
}).
then
((
res
)
=>
{
this
.
addLessons
({
...
this
.
form
}).
then
((
res
)
=>
{
// 如果添加会传回来,就用传回来的,如果是修改本身就有,就用本身的
// 如果添加会传回来,就用传回来的,如果是修改本身就有,就用本身的
// console.log('res',res)
// console.log('res',res)
const
courseId
=
this
.
course
Id
||
res
;
const
bankId
=
this
.
bank
Id
||
res
;
// if (res.code == 200) {
// if (res.code == 200) {
// 这样调比较纯函数一点
// 这样调比较纯函数一点
if
(
num
==
2
)
{
if
(
num
==
2
)
{
...
@@ -282,7 +282,7 @@ export default {
...
@@ -282,7 +282,7 @@ export default {
});
});
}
}
this
.
$parent
.
$parent
.
componentsNumChange
(
num
);
this
.
$parent
.
$parent
.
componentsNumChange
(
num
);
this
.
$parent
.
$parent
.
changeCourseId
(
course
Id
);
this
.
$parent
.
$parent
.
changeCourseId
(
bank
Id
);
this
.
$parent
.
$parent
.
$parent
.
getList
();
this
.
$parent
.
$parent
.
$parent
.
getList
();
return
true
;
return
true
;
...
...
danger-manage-web/src/views/educationPlanExam/questionBank/components/QuestionList.vue
View file @
fa399a4b
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* @Author: 纪泽龙 jizelong@qq.com
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-09-22 17:56:05
* @Date: 2022-09-22 17:56:05
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 2022-12-17 1
1:06:28
* @LastEditTime: 2022-12-17 1
4:28:57
* @FilePath: /danger-manage-web/src/views/lessonsProgram/components/QuestionList.vue
* @FilePath: /danger-manage-web/src/views/lessonsProgram/components/QuestionList.vue
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
-->
-->
...
@@ -25,7 +25,7 @@
...
@@ -25,7 +25,7 @@
<div
class=
"td-wrapper"
>
<div
class=
"td-wrapper"
>
<div
<div
v-for=
"(item, index) in questionList"
v-for=
"(item, index) in questionList"
:key=
"item.
topic
Id"
:key=
"item.
subject
Id"
class=
"td flex"
class=
"td flex"
>
>
<div
class=
"left"
>
{{
index
+
1
}}
</div>
<div
class=
"left"
>
{{
index
+
1
}}
</div>
...
@@ -91,7 +91,7 @@ import { getBank } from "@/api/educationPlanExam/questionBank";
...
@@ -91,7 +91,7 @@ import { getBank } from "@/api/educationPlanExam/questionBank";
export
default
{
export
default
{
name
:
"AnswerLesson"
,
name
:
"AnswerLesson"
,
props
:
{
props
:
{
course
Id
:
{
bank
Id
:
{
type
:
Number
,
type
:
Number
,
},
},
},
},
...
@@ -118,11 +118,11 @@ export default {
...
@@ -118,11 +118,11 @@ export default {
// },
// },
created
()
{
created
()
{
console
.
log
(
"this.
courseId"
,
this
.
course
Id
);
console
.
log
(
"this.
bankId"
,
this
.
bank
Id
);
if
(
this
.
course
Id
)
{
if
(
this
.
bank
Id
)
{
this
.
getQuestion
({
bankId
:
this
.
course
Id
});
this
.
getQuestion
({
bankId
:
this
.
bank
Id
});
// 获取只题目正确几题算过关
// 获取只题目正确几题算过关
this
.
getLessonById
(
this
.
course
Id
);
this
.
getLessonById
(
this
.
bank
Id
);
}
}
},
},
methods
:
{
methods
:
{
...
@@ -132,9 +132,9 @@ export default {
...
@@ -132,9 +132,9 @@ export default {
saveAndNext
()
{
saveAndNext
()
{
this
.
$parent
.
$parent
.
componentsNumChange
(
3
);
this
.
$parent
.
$parent
.
componentsNumChange
(
3
);
},
},
getQuestion
(
course
Id
)
{
getQuestion
(
bank
Id
)
{
console
.
log
(
course
Id
);
console
.
log
(
bank
Id
);
return
listSubject
(
course
Id
).
then
((
res
)
=>
{
return
listSubject
(
bank
Id
).
then
((
res
)
=>
{
console
.
log
(
"题库res"
,
res
);
console
.
log
(
"题库res"
,
res
);
this
.
questionList
=
res
.
rows
.
map
((
item
)
=>
{
this
.
questionList
=
res
.
rows
.
map
((
item
)
=>
{
...
@@ -147,18 +147,18 @@ export default {
...
@@ -147,18 +147,18 @@ export default {
return
true
;
return
true
;
});
});
},
},
getLessonById
(
course
Id
)
{
getLessonById
(
bank
Id
)
{
getBank
(
course
Id
).
then
((
res
)
=>
{
getBank
(
bank
Id
).
then
((
res
)
=>
{
// console.log(res);
// console.log(res);
// this.rightNum = res.data.qualifiedNum;
// this.rightNum = res.data.qualifiedNum;
this
.
courseName
=
res
.
data
.
bankName
;
this
.
courseName
=
res
.
data
.
bankName
;
});
});
},
},
edit
(
subjectId
)
{
edit
(
subjectId
)
{
this
.
$emit
(
"update:
topic
Id"
,
subjectId
);
this
.
$emit
(
"update:
subject
Id"
,
subjectId
);
this
.
$parent
.
$parent
.
componentsNumChange
(
3
);
this
.
$parent
.
$parent
.
componentsNumChange
(
3
);
},
},
deleteLesson
(
topic
Id
)
{
deleteLesson
(
subject
Id
)
{
this
.
$confirm
(
"请确定删除该题"
,
{
this
.
$confirm
(
"请确定删除该题"
,
{
confirmButtonText
:
"确定"
,
confirmButtonText
:
"确定"
,
cancelButtonText
:
"取消"
,
cancelButtonText
:
"取消"
,
...
@@ -166,7 +166,7 @@ export default {
...
@@ -166,7 +166,7 @@ export default {
})
})
.
then
(()
=>
{
.
then
(()
=>
{
this
.
loading
=
true
;
this
.
loading
=
true
;
return
delSubject
(
topic
Id
);
return
delSubject
(
subject
Id
);
})
})
.
then
((
res
)
=>
{
.
then
((
res
)
=>
{
if
(
res
.
code
==
200
)
{
if
(
res
.
code
==
200
)
{
...
@@ -175,7 +175,7 @@ export default {
...
@@ -175,7 +175,7 @@ export default {
type
:
"success"
,
type
:
"success"
,
});
});
}
}
return
this
.
getQuestion
({
bankId
:
this
.
course
Id
});
return
this
.
getQuestion
({
bankId
:
this
.
bank
Id
});
})
})
.
finally
(()
=>
{
.
finally
(()
=>
{
this
.
loading
=
false
;
this
.
loading
=
false
;
...
@@ -192,7 +192,7 @@ export default {
...
@@ -192,7 +192,7 @@ export default {
return
;
return
;
}
}
changeLesson
({
changeLesson
({
courseId
:
this
.
course
Id
,
bankId
:
this
.
bank
Id
,
qualifiedNum
:
this
.
rightNum
,
qualifiedNum
:
this
.
rightNum
,
}).
then
((
res
)
=>
{
}).
then
((
res
)
=>
{
if
(
res
.
code
==
200
)
{
if
(
res
.
code
==
200
)
{
...
...
danger-manage-web/src/views/educationPlanExam/questionBank/index.vue
View file @
fa399a4b
...
@@ -24,7 +24,7 @@
...
@@ -24,7 +24,7 @@
</el-form-item>
-->
</el-form-item>
-->
<el-form-item
<el-form-item
label=
"
归属部门
"
label=
"
考试名称
"
prop=
"deptId"
prop=
"deptId"
ref=
"treeItem"
ref=
"treeItem"
>
>
...
@@ -40,7 +40,7 @@
...
@@ -40,7 +40,7 @@
<el-form-item
label=
"名称"
prop=
"courseName"
>
<el-form-item
label=
"名称"
prop=
"courseName"
>
<el-input
<el-input
v-model=
"queryParams.courseName"
v-model=
"queryParams.courseName"
placeholder=
"
请输入课程名称
"
placeholder=
"
考试时间
"
clearable
clearable
size=
"small"
size=
"small"
/>
/>
...
@@ -85,7 +85,8 @@
...
@@ -85,7 +85,8 @@
</el-row>
</el-row>
<el-table
v-loading=
"loading"
:data=
"bankList"
>
<el-table
v-loading=
"loading"
:data=
"bankList"
>
<el-table-column
label=
"题库序号"
align=
"center"
prop=
"bankNum"
/>
<el-table-column
label=
"序号"
width=
'50'
align=
"center"
prop=
"bankNum"
/>
<el-table-column
label=
"题库名称"
align=
"center"
prop=
"bankName"
>
<el-table-column
label=
"题库名称"
align=
"center"
prop=
"bankName"
>
</el-table-column>
</el-table-column>
<el-table-column
<el-table-column
...
@@ -180,7 +181,7 @@
...
@@ -180,7 +181,7 @@
<
Dia
<
Dia
ref
=
"Dia"
ref
=
"Dia"
:
componentsNum
.
sync
=
"componentsNum"
:
componentsNum
.
sync
=
"componentsNum"
:
course
Id
.
sync
=
"bankId"
:
bank
Id
.
sync
=
"bankId"
:
visible
.
sync
=
"dilogFlag"
:
visible
.
sync
=
"dilogFlag"
/>
/>
...
...
danger-manage-web/src/views/educationPlanExam/textPaper/components/AddQuestion.vue
0 → 100644
View file @
fa399a4b
<
template
>
<div
ref=
"myBody"
class=
"add-question flex"
>
<div
class=
"text flex"
>
<div
class=
"left"
>
目前录入题目是第
<span>
{{
questionNextNum
}}
</span
>
道题
</div>
<div
class=
"right"
>
{{
courseName
}}
</div>
</div>
<el-form
class=
"form flex"
ref=
"form"
:model=
"form"
label-width=
"auto"
>
<!--
<div
class=
"top flex"
>
-->
<div>
<el-form-item
label=
"题目内容"
prop=
"topicTitle"
:rules=
"
{
required: true,
message: '必须输入题目内容',
trigger: 'blur',
}"
>
<el-input
type=
"textarea"
placeholder=
"多行输入"
resize=
"none"
rows=
"4"
v-model=
"form.topicTitle"
>
</el-input>
</el-form-item>
</div>
<div
class=
"bottom"
>
<!--
<el-form-item
label=
"选项1"
prop=
"title"
>
<el-input
v-model=
"form.title"
placeholder=
"请输入"
></el-input>
</el-form-item>
-->
<el-form-item
v-for=
"(question, index) in form.questions"
:label=
"'选项' + (index + 1)"
:key=
"question.key"
:prop=
"'questions.' + index + '.value'"
:rules=
"
index === 0
?
{
required: true,
message: '第一项不能为空不能为空',
trigger: 'blur',
}
: {}
"
>
<div
class=
"add-select flex"
>
<el-input
type=
"textarea"
placeholder=
"多行输入"
style=
"flex: 1; margin-right: 10px"
rows=
"2"
v-model=
"question.value"
></el-input>
<div
class=
"flex algin-items"
>
<div
@
click=
"rightAnswerClick(index)"
class=
"right"
:class=
"
{ active: answerNum === index }"
>
设为正确答案
</div>
<el-button
size=
"mini"
type=
"danger"
v-if=
"index > 0"
@
click
.
prevent=
"removeDomain(question)"
>
删除
</el-button
>
</div>
</div>
</el-form-item>
<el-form-item
class=
"noAttr"
:label=
"`选项$
{form.questions.length + 1}`"
prop=""
>
<div
class=
"add-select flex"
>
<el-input
type=
"textarea"
placeholder=
"多行输入"
resize=
"none"
rows=
"2"
v-model=
"addValue"
style=
"flex: 1; margin-right: 10px"
>
</el-input>
<div
class=
"flex algin-items"
>
<div
@
click=
"rightAnswerClick(form.questions.length)"
class=
"right"
:class=
"
{ active: answerNum === form.questions.length }"
>
设为正确答案
</div>
<el-button
size=
"mini"
type=
"primary"
@
click
.
prevent=
"add(addValue)"
>
新增
</el-button
>
</div>
</div>
</el-form-item>
</div>
</el-form>
</div>
</
template
>
<
script
>
// import {
// addQuestion,
// checkQuestion,
// changeQuestion,
// getQuestion,
// getLessonById,
// } from "@/api/educationPlanExam/lessonsProgram.js";
import
{
addSubject
,
getSubject
,
listSubject
,
updateSubject
}
from
"@/api/educationPlanExam/subject"
;
export
default
{
name
:
"AnswerLesson"
,
props
:
{
// visible: {
// type: Boolean,
// default: false,
// },
bankId
:
{
type
:
Number
,
},
subjectId
:
{
type
:
Number
,
},
},
components
:
{},
data
()
{
return
{
form
:
{
topicTitle
:
""
,
questions
:
[{
value
:
""
},
{
value
:
""
},
{
value
:
""
}],
},
answerNum
:
null
,
addValue
:
""
,
// 录入的是第几道题
questionNextNum
:
1
,
courseName
:
""
,
};
},
created
()
{
// 如果存在就是修改
if
(
this
.
subjectId
)
{
getSubject
(
this
.
subjectId
).
then
((
res
)
=>
{
console
.
log
(
'?'
,
res
.
data
);
const
data
=
res
.
data
;
this
.
form
=
{
topicTitle
:
data
.
topicTitle
,
questions
:
JSON
.
parse
(
data
.
topicOption
),
};
this
.
answerNum
=
data
.
answer
;
});
}
// 查询是第几道题
this
.
getQuestion
();
// 获取课程标题
// this.getLessonById(this.bankId);
},
methods
:
{
getQuestion
()
{
listSubject
({
bankId
:
this
.
bankId
}).
then
((
res
)
=>
{
console
.
log
(
res
)
// 如果是修改 就是原来的值,如果不是,就是总数+1
if
(
this
.
subjectId
)
{
res
.
rows
.
forEach
((
item
,
index
)
=>
{
if
(
item
.
subjectId
==
this
.
subjectId
)
{
this
.
questionNextNum
=
index
+
1
;
}
});
}
else
{
this
.
questionNextNum
=
res
.
total
+
1
;
}
});
},
// getLessonById(bankId) {
// getLessonById(bankId).then((res) => {
// console.log(res);
// this.courseName = res.data.courseName;
// });
// },
addQuestion
(
data
)
{
// 如果是修改,就用修改的方法,如果是新增,就用新增的方法
if
(
this
.
subjectId
)
{
return
updateSubject
({
subjectId
:
this
.
subjectId
,
...
data
});
}
else
{
return
addSubject
({
bankId
:
this
.
bankId
,
...
data
});
}
},
rightAnswerClick
(
index
)
{
this
.
answerNum
=
index
;
console
.
log
(
index
);
},
// 删除选项
removeDomain
(
question
)
{
const
index
=
this
.
form
.
questions
.
indexOf
(
question
);
// 如果是正确答案,就让正确答案清空
if
(
this
.
answerNum
===
index
)
{
this
.
answerNum
=
null
;
}
if
(
index
>=
0
)
{
this
.
form
.
questions
.
splice
(
index
,
1
);
}
},
// 新增选项
add
(
addValue
)
{
this
.
form
.
questions
.
push
({
value
:
addValue
});
console
.
log
();
},
save
(
num
=
2
)
{
return
new
Promise
((
resove
)
=>
{
if
(
!
this
.
answerNum
&&
this
.
answerNum
!==
0
)
{
this
.
$message
({
message
:
"警告,请设置一个正确答案"
,
type
:
"warning"
,
});
return
resove
(
false
);
}
this
.
$refs
.
form
.
validate
((
valid
)
=>
{
if
(
valid
)
{
const
data
=
{};
data
.
topicTitle
=
this
.
form
.
topicTitle
;
data
.
topicOption
=
JSON
.
stringify
(
this
.
form
.
questions
);
data
.
answer
=
this
.
answerNum
;
this
.
addQuestion
(
data
).
then
((
res
)
=>
{
if
(
res
.
code
==
200
)
{
// 把修改的这个归位,变成正常添加
this
.
$emit
(
"update:subjectId"
,
null
);
this
.
$message
({
message
:
"添加题目成功"
,
type
:
"success"
,
});
this
.
$parent
.
$parent
.
componentsNumChange
(
num
);
this
.
$parent
.
$parent
.
$parent
.
getList
();
resove
(
true
);
}
});
}
});
});
},
saveAndNext
()
{
this
.
save
(
3
).
then
((
res
)
=>
{
if
(
res
)
{
this
.
reset
();
// this.questionNextNum++;
this
.
getQuestion
();
}
});
},
reset
()
{
this
.
form
=
{
topicTitle
:
""
,
questions
:
[{
value
:
""
},
{
value
:
""
},
{
value
:
""
}],
};
this
.
answerNum
=
null
;
this
.
addValue
=
""
;
},
},
};
</
script
>
<
style
lang=
"scss"
scoped
>
.add-question
{
width
:
100%
;
height
:
550px
;
// overflow: hidden;
flex-direction
:
column
;
padding-bottom
:
7px
;
margin-bottom
:
20px
;
border-bottom
:
1px
solid
#bbbbbb
;
.form
{
flex
:
1
;
flex-direction
:
column
;
height
:
100%
;
.bottom
{
overflow-y
:
auto
;
height
:
330px
;
box-sizing
:
border-box
;
.algin-items
{
align-items
:
center
;
width
:
200px
;
}
.right
{
display
:
inline-block
;
width
:
133px
;
margin-right
:
10px
;
line-height
:
initial
;
padding
:
4px
0
;
border
:
1px
solid
#bbbbbb
;
color
:
#101010
;
font-size
:
12px
;
text-align
:
center
;
border-radius
:
4px
;
box-sizing
:
border-box
;
cursor
:
pointer
;
&
.active
{
background-color
:
#0bab0c
;
color
:
#ffffff
;
}
&
:hover
{
background-color
:
rgba
(
11
,
171
,
12
,
0
.5
);
color
:
#ffffff
;
}
}
}
}
.text
{
margin-top
:
13px
;
margin-bottom
:
34px
;
justify-content
:
space-between
;
height
:
28px
;
.left
{
line-height
:
28px
;
color
:
#101010
;
font-size
:
14px
;
}
.right
{
width
:
411px
;
line-height
:
28px
;
background
:
#1d84ff
;
padding-right
:
5px
;
color
:
#fff
;
text-align
:
right
;
}
}
}
</
style
>
danger-manage-web/src/views/educationPlanExam/textPaper/components/Dia.vue
0 → 100644
View file @
fa399a4b
<!--
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-09-22 10:38:49
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 2022-12-19 14:01:37
* @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
-->
<
template
>
<el-dialog
class=
"add-lession"
:title=
"title"
:visible
.
sync=
"visible"
width=
"1020px"
:close-on-click-modal=
"false"
:close-on-press-escape=
"false"
:before-close=
"dialogCancel"
@
closed=
"closeFinished"
destroy-on-close
>
<div
v-if=
"visible"
ref=
"myBody"
class=
"body"
>
<transition
name=
"fade"
mode=
"out-in"
>
<component
:is=
"currentComponent"
:bankId
.
sync=
"bankId"
:subjectId
.
sync=
"subjectId"
ref=
"current"
></component>
</transition>
<!--
<Lesson
ref=
'lesson'
/>
-->
<!--
<AddQuestion
/>
<QuestionList/>
-->
</div>
<div
slot=
"footer"
class=
"dialog-footer"
>
<el-button
type=
"primary"
v-if=
"this.componentsNum == 1 || this.componentsNum == 3"
@
click=
"save"
>
保存
</el-button
>
<el-button
type=
"primary"
@
click=
"saveAndNext"
>
{{
saveNextText
}}
</el-button>
<el-button
v-if=
"this.componentsNum == 2"
type=
"primary"
@
click=
"dialogCancel"
>
{{
"确认"
}}
</el-button
>
<el-button
@
click=
"dialogCancel"
>
取消
</el-button>
</div>
</el-dialog>
</
template
>
<
script
>
import
Lesson
from
"./Lesson"
;
import
AddQuestion
from
"./AddQuestion"
;
import
QuestionList
from
"./QuestionList"
;
export
default
{
name
:
"AnswerLesson"
,
props
:
{
visible
:
{
type
:
Boolean
,
default
:
false
,
},
componentsNum
:
{
type
:
Number
,
default
:
1
,
},
bankId
:
{
type
:
Number
,
},
},
// components: {
// Lesson,
// AddQuestion,
// QuestionList,
// },
data
()
{
return
{
title
:
"录入课程"
,
currentComponent
:
Lesson
,
// 当前题目查看
subjectId
:
null
,
};
},
watch
:
{
componentsNum
:
{
handler
(
num
)
{
if
(
num
===
1
)
{
this
.
currentComponent
=
Lesson
;
if
(
this
.
bankId
)
{
this
.
title
=
"修改课程"
;
}
else
{
this
.
title
=
"新增课程"
;
}
}
else
if
(
num
===
2
)
{
this
.
currentComponent
=
QuestionList
;
this
.
title
=
"题目列表"
;
}
else
{
this
.
currentComponent
=
AddQuestion
;
if
(
this
.
subjectId
)
{
this
.
title
=
"修改题目"
;
}
else
{
this
.
title
=
"新增题目"
;
}
}
},
deep
:
true
,
},
},
computed
:
{
saveNextText
()
{
let
text
;
if
(
this
.
componentsNum
==
1
)
{
text
=
"保存并录入题目"
;
}
else
if
(
this
.
componentsNum
==
2
)
{
text
=
"录入考题"
;
}
else
{
text
=
"保存并录入下一题"
;
}
return
text
;
},
},
methods
:
{
saveBody
()
{
this
.
startHeight
=
this
.
$refs
.
myBody
.
offsetHeight
-
55
+
"px"
;
},
closeFinished
()
{},
// 关闭之后
// 只保存
save
()
{
// this.answerClear();
this
.
$refs
.
current
.
save
();
},
// 保存并录入
saveAndNext
()
{
this
.
$refs
.
current
.
saveAndNext
();
},
// 隐藏与显示dialog
dialogCancel
()
{
this
.
$emit
(
"update:visible"
,
false
);
},
// 把ID改变了
changeCourseId
(
bankId
)
{
this
.
$emit
(
"update:bankId"
,
bankId
);
},
// 改变当前组件
componentsNumChange
(
num
)
{
this
.
$emit
(
"update:componentsNum"
,
num
);
},
answerClear
()
{
this
.
answerArr
=
[];
this
.
changeCourseId
(
null
);
},
},
};
</
script
>
<
style
lang=
"scss"
scoped
>
.body
{
width
:
100%
;
height
:
100%
;
padding-right
:
40px
;
padding-left
:
36px
;
}
</
style
>
danger-manage-web/src/views/educationPlanExam/textPaper/components/Editor.vue
0 → 100644
View file @
fa399a4b
<
template
>
<div>
<el-upload
:action=
"uploadUrl"
:on-success=
"handleUploadSuccess"
:on-error=
"handleUploadError"
name=
"file"
:show-file-list=
"false"
:headers=
"headers"
style=
"display: none"
ref=
"upload"
v-if=
"this.uploadUrl"
>
</el-upload>
<div
class=
"editor"
ref=
"editor"
:style=
"styles"
></div>
</div>
</
template
>
<
script
>
import
Quill
from
"quill"
;
import
"quill/dist/quill.core.css"
;
import
"quill/dist/quill.snow.css"
;
import
"quill/dist/quill.bubble.css"
;
import
{
getToken
}
from
"@/utils/auth"
;
export
default
{
name
:
"Editor"
,
props
:
{
/* 编辑器的内容 */
value
:
{
type
:
String
,
default
:
""
,
},
/* 高度 */
height
:
{
type
:
Number
,
default
:
null
,
},
/* 最小高度 */
minHeight
:
{
type
:
Number
,
default
:
null
,
},
/* 只读 */
readOnly
:
{
type
:
Boolean
,
default
:
false
,
},
/* 上传地址 */
uploadUrl
:
{
type
:
String
,
default
:
""
,
}
},
data
()
{
return
{
headers
:
{
Authorization
:
"Bearer "
+
getToken
()
},
Quill
:
null
,
currentValue
:
""
,
options
:
{
theme
:
"snow"
,
bounds
:
document
.
body
,
debug
:
"warn"
,
modules
:
{
// 工具栏配置
toolbar
:
[
[
"bold"
,
"italic"
,
"underline"
,
"strike"
],
// 加粗 斜体 下划线 删除线
[
"blockquote"
,
"code-block"
],
// 引用 代码块
[{
list
:
"ordered"
},
{
list
:
"bullet"
}],
// 有序、无序列表
[{
indent
:
"-1"
},
{
indent
:
"+1"
}],
// 缩进
[{
size
:
[
"small"
,
false
,
"large"
,
"huge"
]
}],
// 字体大小
[{
header
:
[
1
,
2
,
3
,
4
,
5
,
6
,
false
]
}],
// 标题
[{
color
:
[]
},
{
background
:
[]
}],
// 字体颜色、字体背景颜色
[{
align
:
[]
}],
// 对齐方式
[
"clean"
],
// 清除文本格式
[
"link"
,
"image"
]
// 链接、图片、视频"video"
],
},
placeholder
:
"请输入内容"
,
readOnly
:
this
.
readOnly
,
},
};
},
computed
:
{
styles
()
{
let
style
=
{};
if
(
this
.
minHeight
)
{
style
.
minHeight
=
`
${
this
.
minHeight
}
px`
;
}
if
(
this
.
height
)
{
style
.
height
=
`
${
this
.
height
}
px`
;
}
return
style
;
},
},
watch
:
{
value
:
{
handler
(
val
)
{
if
(
val
!==
this
.
currentValue
)
{
this
.
currentValue
=
val
===
null
?
""
:
val
;
if
(
this
.
Quill
)
{
this
.
Quill
.
pasteHTML
(
this
.
currentValue
);
}
}
},
immediate
:
true
,
},
},
mounted
()
{
this
.
init
();
},
beforeDestroy
()
{
this
.
Quill
=
null
;
},
methods
:
{
init
()
{
const
editor
=
this
.
$refs
.
editor
;
this
.
Quill
=
new
Quill
(
editor
,
this
.
options
);
// 如果设置了上传地址则自定义图片上传事件
if
(
this
.
uploadUrl
)
{
let
toolbar
=
this
.
Quill
.
getModule
(
"toolbar"
);
toolbar
.
addHandler
(
"image"
,
(
value
)
=>
{
this
.
uploadType
=
"image"
;
if
(
value
)
{
this
.
$refs
.
upload
.
$children
[
0
].
$refs
.
input
.
click
();
}
else
{
this
.
quill
.
format
(
"image"
,
false
);
}
});
toolbar
.
addHandler
(
"video"
,
(
value
)
=>
{
this
.
uploadType
=
"video"
;
if
(
value
)
{
this
.
$refs
.
upload
.
$children
[
0
].
$refs
.
input
.
click
();
}
else
{
this
.
quill
.
format
(
"video"
,
false
);
}
});
}
this
.
Quill
.
pasteHTML
(
this
.
currentValue
);
this
.
Quill
.
on
(
"text-change"
,
(
delta
,
oldDelta
,
source
)
=>
{
const
html
=
this
.
$refs
.
editor
.
children
[
0
].
innerHTML
;
const
text
=
this
.
Quill
.
getText
();
const
quill
=
this
.
Quill
;
this
.
currentValue
=
html
;
this
.
$emit
(
"input"
,
html
);
this
.
$emit
(
"on-change"
,
{
html
,
text
,
quill
});
});
this
.
Quill
.
on
(
"text-change"
,
(
delta
,
oldDelta
,
source
)
=>
{
this
.
$emit
(
"on-text-change"
,
delta
,
oldDelta
,
source
);
});
this
.
Quill
.
on
(
"selection-change"
,
(
range
,
oldRange
,
source
)
=>
{
this
.
$emit
(
"on-selection-change"
,
range
,
oldRange
,
source
);
});
this
.
Quill
.
on
(
"editor-change"
,
(
eventName
,
...
args
)
=>
{
this
.
$emit
(
"on-editor-change"
,
eventName
,
...
args
);
});
},
handleUploadSuccess
(
res
,
file
)
{
// 获取富文本组件实例
let
quill
=
this
.
Quill
;
// 如果上传成功
if
(
res
.
code
==
200
)
{
// 获取光标所在位置
let
length
=
quill
.
getSelection
().
index
;
// 插入图片 res.url为服务器返回的图片地址
quill
.
insertEmbed
(
length
,
"image"
,
res
.
url
);
// 调整光标到最后
quill
.
setSelection
(
length
+
1
);
}
else
{
this
.
$message
.
error
(
"图片插入失败"
);
}
},
handleUploadError
()
{
this
.
$message
.
error
(
"图片插入失败"
);
},
},
};
</
script
>
<
style
>
.editor
,
.ql-toolbar
{
white-space
:
pre-wrap
!important
;
line-height
:
normal
!important
;
}
.quill-img
{
display
:
none
;
}
.ql-snow
.ql-tooltip
[
data-mode
=
"link"
]
::before
{
content
:
"请输入链接地址:"
;
}
.ql-snow
.ql-tooltip.ql-editing
a
.ql-action
::after
{
border-right
:
0px
;
content
:
"保存"
;
padding-right
:
0px
;
}
.ql-snow
.ql-tooltip
[
data-mode
=
"video"
]
::before
{
content
:
"请输入视频地址:"
;
}
.ql-snow
.ql-picker.ql-size
.ql-picker-label
::before
,
.ql-snow
.ql-picker.ql-size
.ql-picker-item
::before
{
content
:
"14px"
;
}
.ql-snow
.ql-picker.ql-size
.ql-picker-label
[
data-value
=
"small"
]
::before
,
.ql-snow
.ql-picker.ql-size
.ql-picker-item
[
data-value
=
"small"
]
::before
{
content
:
"10px"
;
}
.ql-snow
.ql-picker.ql-size
.ql-picker-label
[
data-value
=
"large"
]
::before
,
.ql-snow
.ql-picker.ql-size
.ql-picker-item
[
data-value
=
"large"
]
::before
{
content
:
"18px"
;
}
.ql-snow
.ql-picker.ql-size
.ql-picker-label
[
data-value
=
"huge"
]
::before
,
.ql-snow
.ql-picker.ql-size
.ql-picker-item
[
data-value
=
"huge"
]
::before
{
content
:
"32px"
;
}
.ql-snow
.ql-picker.ql-header
.ql-picker-label
::before
,
.ql-snow
.ql-picker.ql-header
.ql-picker-item
::before
{
content
:
"文本"
;
}
.ql-snow
.ql-picker.ql-header
.ql-picker-label
[
data-value
=
"1"
]
::before
,
.ql-snow
.ql-picker.ql-header
.ql-picker-item
[
data-value
=
"1"
]
::before
{
content
:
"标题1"
;
}
.ql-snow
.ql-picker.ql-header
.ql-picker-label
[
data-value
=
"2"
]
::before
,
.ql-snow
.ql-picker.ql-header
.ql-picker-item
[
data-value
=
"2"
]
::before
{
content
:
"标题2"
;
}
.ql-snow
.ql-picker.ql-header
.ql-picker-label
[
data-value
=
"3"
]
::before
,
.ql-snow
.ql-picker.ql-header
.ql-picker-item
[
data-value
=
"3"
]
::before
{
content
:
"标题3"
;
}
.ql-snow
.ql-picker.ql-header
.ql-picker-label
[
data-value
=
"4"
]
::before
,
.ql-snow
.ql-picker.ql-header
.ql-picker-item
[
data-value
=
"4"
]
::before
{
content
:
"标题4"
;
}
.ql-snow
.ql-picker.ql-header
.ql-picker-label
[
data-value
=
"5"
]
::before
,
.ql-snow
.ql-picker.ql-header
.ql-picker-item
[
data-value
=
"5"
]
::before
{
content
:
"标题5"
;
}
.ql-snow
.ql-picker.ql-header
.ql-picker-label
[
data-value
=
"6"
]
::before
,
.ql-snow
.ql-picker.ql-header
.ql-picker-item
[
data-value
=
"6"
]
::before
{
content
:
"标题6"
;
}
.ql-snow
.ql-picker.ql-font
.ql-picker-label
::before
,
.ql-snow
.ql-picker.ql-font
.ql-picker-item
::before
{
content
:
"标准字体"
;
}
.ql-snow
.ql-picker.ql-font
.ql-picker-label
[
data-value
=
"serif"
]
::before
,
.ql-snow
.ql-picker.ql-font
.ql-picker-item
[
data-value
=
"serif"
]
::before
{
content
:
"衬线字体"
;
}
.ql-snow
.ql-picker.ql-font
.ql-picker-label
[
data-value
=
"monospace"
]
::before
,
.ql-snow
.ql-picker.ql-font
.ql-picker-item
[
data-value
=
"monospace"
]
::before
{
content
:
"等宽字体"
;
}
</
style
>
danger-manage-web/src/views/educationPlanExam/textPaper/components/Lesson.vue
0 → 100644
View file @
fa399a4b
<!--
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-09-22 10:59:44
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 2022-12-21 17:30:33
* @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
-->
<
template
>
<div
class=
"form-wrapper"
>
<el-form
class=
"form"
ref=
"form"
:model=
"form"
label-width=
"auto"
:rules=
"rules"
>
<div
class=
"top flex"
>
<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=
"releaseTime"
>
<el-date-picker
v-model=
"form.startTime"
value-format=
"yyyy-MM-dd HH:mm:ss"
type=
"datetime"
placeholder=
"开始时间"
default-time=
"12:00:00"
>
</el-date-picker>
</el-form-item>
</div>
<el-form-item
label=
"结束时间"
prop=
"releaseTime"
>
<el-date-picker
v-model=
"form.endTime"
value-format=
"yyyy-MM-dd HH:mm:ss"
type=
"datetime"
placeholder=
"结束时间"
default-time=
"12:00:00"
>
</el-date-picker>
</el-form-item>
<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>
</el-form>
</div>
</
template
>
<
script
>
import
ChangePapel
from
"@/components/PeopleChange"
;
// import { mapGetters } from "vuex";
// import {
// addLessons,
// getLessonById,
// changeLesson,
// } from "@/api/educationPlanExam/lessonsProgram";
import
{
listBank
,
addBank
,
updateBank
,
getBank
,
}
from
"@/api/educationPlanExam/questionBank"
;
// 所有部门
import
{
treeselect
}
from
"@/api/system/dept"
;
import
Treeselect
from
"@riophae/vue-treeselect"
;
import
"@riophae/vue-treeselect/dist/vue-treeselect.css"
;
export
default
{
name
:
""
,
props
:
{
bankId
:
{
type
:
Number
,
},
// jsonSelectNameList: {
// type: String,
// default:
// '[{"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":"王青华"}]',
// },
},
components
:
{
ChangePapel
,
},
data
()
{
return
{
form
:
{
bankName
:
""
,
// courseType: "",
// courseConent: "",
// video: "",
// enclosure: "",
deptId
:
null
,
abc
:
0
,
},
// 参考人员
jsonSelectNameList
:
null
,
// 归属部门列表
deptOptions
:
[],
fileListVideo
:
[],
fileListFile
:
[],
readOnly
:
false
,
// selectNameList: [],
rules
:
{
bankName
:
[
{
required
:
true
,
trigger
:
"blur"
,
message
:
"课程名称不能为空"
},
],
deptId
:
[
{
required
:
true
,
trigger
:
"blur"
,
message
:
"请选择所属部门"
},
],
},
};
},
computed
:
{
// 获取课程类型
// ...mapGetters(["courseOptions"]),
},
created
()
{
if
(
this
.
bankId
)
{
this
.
getLessonById
();
}
// 归属部门列表
// this.getTreeselect();
},
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
:
{
// 添加课程
addLessons
(
data
)
{
if
(
!
this
.
bankId
)
{
console
.
log
(
"添加"
);
return
addBank
(
data
);
}
else
{
console
.
log
(
"修改"
);
return
updateBank
({
bankId
:
this
.
bankId
,
...
data
});
}
},
// 复现
getLessonById
()
{
getBank
(
this
.
bankId
).
then
((
res
)
=>
{
console
.
log
(
"res"
,
res
);
if
(
res
.
code
==
200
)
{
this
.
form
=
{
bankName
:
res
.
data
.
bankName
,
deptId
:
res
.
data
.
deptId
,
};
// const data = res.data;
// const { bankName, courseType, courseConent, video, enclosure } =
// data;
// this.form = {
// bankName,
// courseType,
// courseConent,
// video,
// enclosure,
// };
// this.fileListVideo = [
// {
// name: bankName + "视频",
// url: uploadfile,
// },
// ];
// this.fileListFile = [
// {
// name: bankName + "附件",
// url: uploadfile,
// },
// ];
}
});
},
// 获取参考人员的list
getPeopleList
(
list
)
{
console
.
log
(
"参考人员"
,
list
);
},
save
(
num
=
2
)
{
// 因为富文本编辑器会残留
<
p
><
br
><
/p>,所以要清
空
// if (this.form.courseConent === "
<
p
><
br
><
/p>"
)
{
// this.form.courseConent = "";
// }
this
.
$refs
.
form
.
validate
((
valid
)
=>
{
if
(
valid
)
{
this
.
addLessons
({
...
this
.
form
}).
then
((
res
)
=>
{
// 如果添加会传回来,就用传回来的,如果是修改本身就有,就用本身的
// console.log('res',res)
const
bankId
=
this
.
bankId
||
res
;
// if (res.code == 200) {
// 这样调比较纯函数一点
if
(
num
==
2
)
{
this
.
$message
({
message
:
"保存题库成功"
,
type
:
"success"
,
});
}
else
if
(
num
==
3
)
{
this
.
$message
({
message
:
"保存题库成功,请开始录入题目"
,
type
:
"success"
,
});
}
this
.
$parent
.
$parent
.
componentsNumChange
(
num
);
this
.
$parent
.
$parent
.
changeCourseId
(
bankId
);
this
.
$parent
.
$parent
.
$parent
.
getList
();
return
true
;
// }
});
}
else
{
if
(
!
this
.
form
.
deptId
)
{
document
.
querySelector
(
".vue-treeselect__control"
).
style
.
borderColor
=
"red"
;
}
else
{
document
.
querySelector
(
".vue-treeselect__control"
).
style
.
borderColor
=
""
;
this
.
$refs
.
treeItem
.
clearValidate
();
}
}
});
},
// 保存并进入题目
saveAndNext
()
{
this
.
save
(
3
);
},
},
};
</
script
>
<
style
lang=
"scss"
scoped
>
.form-wrapper
{
padding-top
:
22px
;
width
:
100%
;
height
:
550px
;
// overflow: hidden;
// padding-bottom: 10px;
margin-bottom
:
20px
;
// border-bottom: 1px solid #bbbbbb;
.top
{
width
:
100%
;
justify-content
:
space-between
;
}
}
</
style
>
danger-manage-web/src/views/educationPlanExam/textPaper/components/QuestionList.vue
0 → 100644
View file @
fa399a4b
<!--
* @Author: 纪泽龙 jizelong@qq.com
* @Date: 2022-09-22 17:56:05
* @LastEditors: 纪泽龙 jizelong@qq.com
* @LastEditTime: 2022-12-17 14:28:57
* @FilePath: /danger-manage-web/src/views/lessonsProgram/components/QuestionList.vue
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
-->
<
template
>
<div
ref=
"myBody"
class=
"add-question flex"
>
<div
class=
"text flex"
>
<div
class=
"left"
>
目前有
<span>
{{
questionNum
||
0
}}
</span
>
道题
<!--
<span
class=
"warn"
>
温馨提示:发布课程前需要进行考试设置
</span>
-->
</div>
<div
class=
"right"
>
{{
courseName
}}
</div>
</div>
<div
class=
"table flex"
v-loading=
"loading"
>
<div
class=
"th flex"
>
<div
class=
"left"
>
序号
</div>
<div
class=
"middle"
>
题目名称
</div>
<div
class=
"right"
>
操作
</div>
</div>
<div
class=
"td-wrapper"
>
<div
v-for=
"(item, index) in questionList"
:key=
"item.subjectId"
class=
"td flex"
>
<div
class=
"left"
>
{{
index
+
1
}}
</div>
<div
class=
"middle zzz"
>
{{
item
.
topicTitle
}}
</div>
<div
class=
"right"
>
<div>
<el-button
@
click=
"edit(item.subjectId)"
icon=
"el-icon-edit"
type=
"text"
>
修改
</el-button
>
<el-button
@
click=
"deleteLesson(item.subjectId)"
icon=
"el-icon-delete"
type=
"text"
>
删除
</el-button
>
</div>
</div>
</div>
</div>
</div>
<!--
<div
class=
"rightNum flex"
>
<div
class=
"left"
>
录入考题
</div>
<div
class=
"middle flex"
>
<div
class=
"left-text"
>
答对题目大于
</div>
<div>
<el-input
v-model=
"rightNum"
style=
"width: 60px"
size=
"mini"
></el-input>
</div>
<div>
为合格
</div>
</div>
<div
class=
"right"
>
<el-button
@
click=
"saveRightNum"
icon=
"el-icon-check"
size=
"mini"
type=
"success"
>
保存
</el-button
>
</div>
</div>
-->
</div>
</
template
>
<
script
>
import
{
getQuestion
,
deleteQuestion
,
changeLesson
,
getLessonById
,
}
from
"@/api/educationPlanExam/lessonsProgram"
;
import
{
listSubject
,
delSubject
}
from
"@/api/educationPlanExam/subject"
;
import
{
getBank
}
from
"@/api/educationPlanExam/questionBank"
;
export
default
{
name
:
"AnswerLesson"
,
props
:
{
bankId
:
{
type
:
Number
,
},
},
components
:
{},
data
()
{
return
{
// 当前课程的第几题,调一遍接口
questionNum
:
null
,
// 答对几道题
rightNum
:
0
,
questionList
:
[],
loading
:
false
,
courseName
:
""
,
};
},
// watch: {
// visible(newValue) {
// if (newValue) {
// this.$nextTick(() => {
// this.saveBody();
// });
// }
// },
// },
created
()
{
console
.
log
(
"this.bankId"
,
this
.
bankId
);
if
(
this
.
bankId
)
{
this
.
getQuestion
({
bankId
:
this
.
bankId
});
// 获取只题目正确几题算过关
this
.
getLessonById
(
this
.
bankId
);
}
},
methods
:
{
save
()
{
console
.
log
(
"QuestionList"
);
},
saveAndNext
()
{
this
.
$parent
.
$parent
.
componentsNumChange
(
3
);
},
getQuestion
(
bankId
)
{
console
.
log
(
bankId
);
return
listSubject
(
bankId
).
then
((
res
)
=>
{
console
.
log
(
"题库res"
,
res
);
this
.
questionList
=
res
.
rows
.
map
((
item
)
=>
{
return
{
subjectId
:
item
.
subjectId
,
topicTitle
:
item
.
topicTitle
,
};
});
this
.
questionNum
=
res
.
total
;
return
true
;
});
},
getLessonById
(
bankId
)
{
getBank
(
bankId
).
then
((
res
)
=>
{
// console.log(res);
// this.rightNum = res.data.qualifiedNum;
this
.
courseName
=
res
.
data
.
bankName
;
});
},
edit
(
subjectId
)
{
this
.
$emit
(
"update:subjectId"
,
subjectId
);
this
.
$parent
.
$parent
.
componentsNumChange
(
3
);
},
deleteLesson
(
subjectId
)
{
this
.
$confirm
(
"请确定删除该题"
,
{
confirmButtonText
:
"确定"
,
cancelButtonText
:
"取消"
,
type
:
"warning"
,
})
.
then
(()
=>
{
this
.
loading
=
true
;
return
delSubject
(
subjectId
);
})
.
then
((
res
)
=>
{
if
(
res
.
code
==
200
)
{
this
.
$message
({
message
:
"删除成功"
,
type
:
"success"
,
});
}
return
this
.
getQuestion
({
bankId
:
this
.
bankId
});
})
.
finally
(()
=>
{
this
.
loading
=
false
;
// 课程列表重置一下
this
.
$parent
.
$parent
.
$parent
.
getList
();
});
},
saveRightNum
()
{
if
(
this
.
rightNum
>
this
.
questionList
.
length
)
{
this
.
$message
({
message
:
"答对题目数应小于等于考试题目总数"
,
type
:
"warning"
,
});
return
;
}
changeLesson
({
bankId
:
this
.
bankId
,
qualifiedNum
:
this
.
rightNum
,
}).
then
((
res
)
=>
{
if
(
res
.
code
==
200
)
{
this
.
$message
({
message
:
"答题合格数修改成功"
,
type
:
"success"
,
});
}
});
},
},
};
</
script
>
<
style
lang=
"scss"
scoped
>
.add-question
{
width
:
100%
;
height
:
550px
;
// overflow: hidden;
flex-direction
:
column
;
padding-bottom
:
7px
;
margin-bottom
:
20px
;
border-bottom
:
1px
solid
#bbbbbb
00
;
.text
{
margin-top
:
13px
;
margin-bottom
:
32px
;
justify-content
:
space-between
;
height
:
28px
;
.left
{
line-height
:
28px
;
color
:
#101010
;
font-size
:
14px
;
.warn
{
display
:
inline-flex
;
font-size
:
12px
;
color
:
red
;
margin-left
:
10px
;
}
}
.right
{
width
:
411px
;
line-height
:
28px
;
background
:
#1d84ff
;
padding-right
:
5px
;
color
:
#fff
;
text-align
:
right
;
}
}
.table
{
flex
:
1
;
height
:
0
;
flex-direction
:
column
;
.th
{
width
:
100%
;
height
:
70px
;
line-height
:
70px
;
background
:
#f5f5f5
;
color
:
#606266
;
>
div
{
height
:
100%
;
}
.left
{
width
:
15%
;
text-align
:
center
;
}
.middle
{
width
:
60%
;
padding-left
:
100px
;
}
.right
{
width
:
25%
;
text-align
:
center
;
}
}
.td-wrapper
{
flex
:
1
;
overflow-y
:
auto
;
// 这样子元素才能有滚动条
.td
{
height
:
68px
;
line-height
:
68px
;
box-sizing
:
border-box
;
border-bottom
:
1px
solid
#bbbbbb
;
&
:last-child
{
border-bottom
:
none
;
}
>
div
{
height
:
100%
;
}
.left
{
width
:
15%
;
text-align
:
center
;
}
.middle
{
width
:
60%
;
padding-left
:
10px
;
}
.right
{
width
:
25%
;
text-align
:
center
;
}
}
}
}
.rightNum
{
margin-top
:
5px
;
height
:
55px
;
box-sizing
:
border-box
;
border
:
1px
solid
#bbbbbb
;
line-height
:
55px
;
>
.left
{
width
:
140px
;
background
:
#0bab0c
;
font-size
:
14px
;
color
:
#fff
;
text-align
:
center
;
}
>
.middle
{
>
div
{
margin-right
:
5px
;
}
.left-text
{
margin-left
:
10px
;
}
.middle
{
margin-right
:
20px
;
}
}
.right
{
margin-left
:
20px
;
}
// background: black;
}
}
</
style
>
danger-manage-web/src/views/educationPlanExam/textPaper/index.vue
0 → 100644
View file @
fa399a4b
This diff is collapsed.
Click to expand it.
danger-manage-web/vue.config.js
View file @
fa399a4b
...
@@ -35,7 +35,7 @@ module.exports = {
...
@@ -35,7 +35,7 @@ module.exports = {
// detail: https://cli.vuejs.org/config/#devserver-proxy
// detail: https://cli.vuejs.org/config/#devserver-proxy
[
process
.
env
.
VUE_APP_BASE_API
]:
{
[
process
.
env
.
VUE_APP_BASE_API
]:
{
target
:
process
.
env
.
VUE_APP_TARGET
,
target
:
process
.
env
.
VUE_APP_TARGET
,
target
:
`http://192.168.2.2:8908/dangerManage`
,
//
target: `http://192.168.2.2:8908/dangerManage`,
changeOrigin
:
true
,
changeOrigin
:
true
,
pathRewrite
:
{
pathRewrite
:
{
[
'^'
+
process
.
env
.
VUE_APP_BASE_API
]:
''
[
'^'
+
process
.
env
.
VUE_APP_BASE_API
]:
''
...
...
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