| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711 |
- <template>
- <el-dialog
- :title="title"
- :visible.sync="dialogVisible"
- :close-on-click-modal="false"
- :close-on-press-escape="false"
- append-to-body
- width="60%"
- class="dialog exam-dialog"
- top="6vh"
- @close="closeDialog"
- @open="getExamData"
- >
- <el-form
- ref="form"
- :label-width="formLabelWidth"
- :model="form"
- :rules="rules"
- class="exam-form"
- @submit.native.prevent
- >
- <el-form-item label="考试名称:" prop="kao_shi_ming_chen">
- <el-input
- v-model="form.kao_shi_ming_chen"
- type="text"
- :maxlength="256"
- placeholder="请输入考试名称"
- :disabled="isDisabled"
- />
- </el-form-item>
- <!-- <el-form-item label="考试类型:" prop="kao_shi_lei_xing_">
- <el-select
- v-model="form.kao_shi_lei_xing_"
- filterable
- allow-create
- width="100%"
- placeholder="请选择考试类型"
- >
- <el-option
- v-for="item in examTypeOptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item> -->
- <el-form-item label="考试题库:" prop="ti_ku_id_">
- <div class="tiku">
- <div>
- <ibps-custom-dialog
- v-model="form.ti_ku_id_"
- size="small"
- template-key="tkdhk"
- :multiple="false"
- :disabled="isDisabled"
- type="dialog"
- class="custom-dialog"
- placeholder="请选择考试题库"
- />
- </div>
- <!-- <el-button
- type="primary"
- @click="randTiku"
- :disabled="randButtonDisabled"
- >随机题库</el-button
- > -->
- </div>
- </el-form-item>
- <el-form-item>
- <template slot="label">
- 随机抽题
- <el-tooltip
- effect="dark"
- content="是否开启从题库中随机抽题。"
- placement="top"
- >
- <i class="el-icon-question question-icon">:</i>
- </el-tooltip>
- </template>
- <el-radio-group v-model="form.sui_ji_chou_ti_" :disabled="isDisabled">
- <el-radio label="0">关闭</el-radio>
- <el-radio label="1" :disabled="!(!!form.ti_ku_id_)">开启</el-radio>
- </el-radio-group>
- </el-form-item>
- <el-form-item v-if="form.sui_ji_chou_ti_ === '1'" class="handrand">
- <template slot="label">
- 抽题规则
- <el-tooltip
- effect="dark"
- content="设置每类题型的抽题数量,相同题型相同分值可以自由选择抽题数量,相同题型不同分值只能全抽或不抽。"
- placement="top"
- >
- <i class="el-icon-question question-icon">:</i>
- </el-tooltip>
- </template>
- <div v-for="item in handList" :key="item.itemType" class="hand-item">
- <template v-if="item.list.length>0">
- <span>{{ item.itemType }}:</span>
- <el-input-number
- v-model="item.questionNumber"
- style="width:120px"
- :min="0"
- :max="item.list.length"
- :precision="0"
- :disabled="form.sui_ji_chou_ti_ === '0' || isDisabled"
- placeholder="请输入抽题数量"
- :step="item.step"
- step-strictly
- />
- </template>
- </div>
- </el-form-item>
- <el-form-item prop="xian_kao_shi_jian">
- <template slot="label">
- 限考时间
- <el-tooltip
- effect="dark"
- content="设置该考试的提交截至时间。"
- placement="top"
- >
- <i class="el-icon-question question-icon">:</i>
- </el-tooltip>
- </template>
- <el-radio-group
- v-model="form.isDateLimit"
- @change="changeLimit(form.isDateLimit, 'xian_kao_shi_jian', null)"
- >
- <el-radio label="0">不限</el-radio>
- <el-radio label="1">限制</el-radio>
- </el-radio-group>
- <el-date-picker
- v-if="form.isDateLimit === '1'"
- v-model="form.xian_kao_shi_jian"
- type="datetime"
- placeholder="请选择考试限制提交时间"
- align="right"
- default-time="12:00:00"
- class="date-picker"
- :picker-options="pickerOptions"
- />
- </el-form-item>
- <el-form-item label="参考人员:" prop="can_kao_ren_yuan_">
- <ibps-custom-dialog
- v-model="form.can_kao_ren_yuan_"
- size="small"
- template-key="gjxcxryk"
- multiple
- :disabled="isDisabled"
- type="dialog"
- class="custom-dialog"
- placeholder="请选择需参加考试的人员"
- />
- </el-form-item>
- <el-form-item prop="isCountLimit" class="inline-item">
- <template slot="label">
- 限考次数
- <el-tooltip
- effect="dark"
- content="限制是否可重复参加,以及可参加考试的最大次数。"
- placement="top"
- >
- <i class="el-icon-question question-icon">:</i>
- </el-tooltip>
- </template>
- <el-radio-group
- v-model="form.isCountLimit"
- :disabled="isDisabled"
- @change="changeLimit(form.isCountLimit, 'xian_kao_ci_shu_', 1)"
- >
- <el-radio label="0">不限</el-radio>
- <el-radio label="1">限制</el-radio>
- </el-radio-group>
- <div v-if="form.isCountLimit === '1'" class="time">
- <el-input-number
- v-model="form.xian_kao_ci_shu_"
- :min="1"
- :precision="0"
- :disabled="isDisabled"
- placeholder="请输入单个用户最大限考次数"
- />
- <div class="unit">次</div>
- </div>
- </el-form-item>
- <el-form-item
- v-if="
- form.isCountLimit === '0' ||
- (form.isCountLimit === '1' && form.xian_kao_ci_shu_ > 1)
- "
- prop="ji_fen_fang_shi_"
- >
- <template slot="label">
- 计分方式
- <el-tooltip
- effect="dark"
- content="设置对于可重复参加的考试,最终得分的计算方式(仅限考次数大于1时有效)。"
- placement="top"
- >
- <i class="el-icon-question question-icon">:</i>
- </el-tooltip>
- </template>
- <el-radio-group v-model="form.ji_fen_fang_shi_" :disabled="isDisabled">
- <el-radio label="平均分">平均分</el-radio>
- <el-radio label="最高分">最高分</el-radio>
- <el-radio label="最近得分">最近得分</el-radio>
- </el-radio-group>
- </el-form-item>
- <el-form-item prop="isTimeLimit" class="inline-item">
- <template slot="label">
- 考试时长
- <el-tooltip
- effect="dark"
- content="设置该考试单次作答的最大时长。"
- placement="top"
- >
- <i class="el-icon-question question-icon">:</i>
- </el-tooltip>
- </template>
- <el-radio-group v-model="form.isTimeLimit" :disabled="isDisabled">
- <el-radio label="0">不限</el-radio>
- <el-radio label="1">限制</el-radio>
- </el-radio-group>
- <template v-if="form.isTimeLimit === '1'">
- <div class="time">
- <el-input-number
- v-model="form.hours"
- :min="0"
- :max="72"
- :precision="0"
- :disabled="isDisabled"
- />
- <div class="unit">小时</div>
- </div>
- <div class="time">
- <el-input-number
- v-model="form.minutes"
- :min="0"
- :max="59"
- :precision="0"
- :disabled="isDisabled"
- />
- <div class="unit">分钟</div>
- </div>
- </template>
- </el-form-item>
- <el-form-item prop="da_biao_zhan_bi_">
- <template slot="label">
- 达标分值占比
- <el-tooltip
- effect="dark"
- content="设置该考试的达标分数线占试题总分的百分比。"
- placement="top"
- >
- <i class="el-icon-question question-icon">:</i>
- </el-tooltip>
- </template>
- <el-input-number
- v-model="form.da_biao_zhan_bi_"
- :min="50"
- :max="100"
- :precision="0"
- :disabled="isDisabled"
- placeholder="请输入达标分值占比"
- />
- <div class="unit">%</div>
- </el-form-item>
- <el-form-item prop="yun_xu_bao_ming_">
- <template slot="label">
- 允许自主报名
- <el-tooltip
- effect="dark"
- content="限制非本考试的参考人员是否可报名参加该考试。"
- placement="top"
- >
- <i class="el-icon-question question-icon">:</i>
- </el-tooltip>
- </template>
- <el-radio-group v-model="form.yun_xu_bao_ming_" :disabled="isDisabled">
- <el-radio label="是">是</el-radio>
- <el-radio label="否">否</el-radio>
- </el-radio-group>
- </el-form-item>
- <el-form-item
- v-if="!isDisabled || form.guan_lian_id_"
- prop="guan_lian_id_"
- >
- <template slot="label">
- 关联培训记录
- <el-tooltip effect="dark" content="关联培训记录。" placement="top">
- <i class="el-icon-question question-icon">:</i>
- </el-tooltip>
- </template>
- <ibps-custom-dialog
- v-model="form.guan_lian_id_"
- size="small"
- template-key="pxjldhk"
- :multiple="false"
- :disabled="isDisabled"
- type="dialog"
- class="custom-dialog"
- placeholder="请选择培训记录"
- />
- </el-form-item>
- <el-form-item
- v-if="!isDisabled || form.kao_shi_miao_shu_"
- label="考试描述:"
- prop="kao_shi_miao_shu_"
- >
- <el-input
- v-model="form.kao_shi_miao_shu_"
- type="textarea"
- :rows="4"
- :maxlength="512"
- placeholder="请输入描述内容"
- :disabled="isDisabled"
- />
- </el-form-item>
- </el-form>
- <div slot="footer" class="el-dialog--center">
- <ibps-toolbar :actions="toolbars" @action-event="handleActionEvent" />
- </div>
- </el-dialog>
- </template>
- <script>
- import ActionUtils from '@/utils/action'
- import { examTypeOptions, scoringType } from '../constants'
- export default {
- components: {
- IbpsCustomDialog: () =>
- import('@/business/platform/data/templaterender/custom-dialog')
- },
- props: {
- visible: {
- type: Boolean,
- default: false
- },
- id: {
- type: String,
- default: ''
- },
- isDisabled: {
- type: Boolean,
- default: false
- }
- },
- data () {
- const {
- userList = [],
- deptList = [],
- userId,
- level
- } = this.$store.getters || {}
- return {
- handList: [
- { itemType: '单选题', questionNumber: 0, list: [], step: 1 },
- { itemType: '多选题', questionNumber: 0, list: [], step: 1 },
- { itemType: '判断题', questionNumber: 0, list: [], step: 1 },
- { itemType: '填空题', questionNumber: 0, list: [], step: 1 },
- { itemType: '简答题', questionNumber: 0, list: [], step: 1 }
- ],
- userList,
- examTypeOptions,
- deptList: deptList.filter((i) => i.depth === 4),
- title: this.id ? '编辑考试' : '新建考试',
- formLabelWidth: '150px',
- dialogVisible: this.visible,
- dialogLoading: false,
- randButtonDisabled: false,
- isFirst: true,
- form: {
- di_dian_: level.second || level.first,
- chuang_jian_shi_j: '',
- kao_shi_ming_chen: '',
- kao_shi_lei_xing_: '常规',
- ti_ku_id_: '',
- guan_lian_id_: '',
- xian_kao_shi_jian: '不限',
- xian_kao_ci_shu_: '不限',
- can_kao_ren_yuan_: '',
- kao_shi_shi_chang: '',
- zhuang_tai_: '未发布',
- da_biao_zhan_bi_: 60,
- ji_fen_fang_shi_: scoringType.length ? scoringType[0].value : '',
- kao_shi_miao_shu_: '',
- yun_xu_bao_ming_: '否',
- isCountLimit: '0',
- isTimeLimit: '0',
- isDateLimit: '0',
- sui_ji_chou_ti_: '0',
- chou_ti_zong_fen_: 0,
- ti_mu_zong_shu_: 0,
- sui_ji_ti_shu_: [],
- hours: 2,
- minutes: 30
- },
- pickerOptions: {
- disabledDate (time) {
- // 禁用当前日期之前的日期
- return time.getTime() < Date.now() - 8.64e7
- }
- },
- toolbars: [
- {
- key: 'submit',
- icon: 'ibps-icon-save',
- label: '保存',
- hidden: () => {
- return this.readonly
- }
- },
- { key: 'cancel', label: '关闭' }
- ],
- rules: {
- kao_shi_ming_chen: [
- { required: true, message: this.$t('validate.required') }
- ],
- // kao_shi_lei_xing_: [{ required: true, message: this.$t('validate.required') }],
- ti_ku_id_: [{ required: true, message: this.$t('validate.required') }],
- xian_kao_shi_jian: [
- { required: true, message: this.$t('validate.required') }
- ],
- xian_kao_ci_shu_: [
- { required: true, message: this.$t('validate.required') }
- ],
- can_kao_ren_yuan_: [
- { required: true, message: this.$t('validate.required') }
- ],
- kao_shi_shi_chang: [
- { required: true, message: this.$t('validate.required') }
- ],
- da_biao_zhan_bi_: [
- { required: true, message: this.$t('validate.required') }
- ]
- }
- }
- },
- watch: {
- visible: {
- handler: function (val, oldVal) {
- this.dialogVisible = this.visible
- }
- // immediate: true
- },
- 'form.ti_ku_id_': {
- handler (val) {
- if (val) {
- const sql = `select * from t_questions where parent_id_ = '${val}' and zhuang_tai_ = '启用' order by field(ti_xing_, '单选题', '多选题', '判断题', '填空题', '简答题')`
- this.$common.request('sql', sql).then((res) => {
- const { data = [] } = res.variables || {}
- this.getHandList(data)
- })
- }
- }
- }
- },
- mounted () {
- this.getExamData()
- },
- methods: {
- // 题型分类
- getHandList (data) {
- // 确定每种类型的题目
- this.handList.forEach(hand => {
- hand.list = data.filter(item => item.ti_xing_ === hand.itemType)
- })
- if (this.$utils.isEmpty(this.id)) {
- // 设置每种类型题目的默认题数
- this.handList.forEach(hand => {
- hand.questionNumber = hand.list.length
- })
- } else {
- if (!this.isFirst) {
- this.handList.forEach(hand => {
- hand.questionNumber = hand.list.length
- })
- } else {
- this.isFirst = false
- }
- }
- // 设置每种类型题目的步数
- this.handList.forEach(hand => {
- if (hand.list.length > 0) {
- const isSame = hand.list.every(item => item.fen_zhi_ === hand.list[0].fen_zhi_)
- hand.step = isSame ? 1 : hand.list.length
- }
- })
- },
- changeLimit (e, type, defaultValue) {
- this.form[type] = e === '1' ? defaultValue : '不限'
- },
- handleActionEvent ({ key }) {
- switch (key) {
- case 'submit':
- this.handleSubmit()
- break
- case 'cancel':
- this.closeDialog()
- break
- default:
- break
- }
- },
- // 获取考试数据
- getExamData () {
- if (this.$utils.isEmpty(this.id)) {
- return
- }
- if (this.isDisabled) {
- this.randButtonDisabled = true
- this.$message.info('非未发布状态的考试仅可修改限考时间!')
- }
- const sql = `select id_, create_by_, ti_ku_id_, guan_lian_id_, kao_shi_ming_chen, kao_shi_lei_xing_, chuang_jian_shi_j, fa_bu_shi_jian_, fa_bu_ren_, xian_kao_shi_jian, xian_kao_ci_shu_, kao_shi_shi_chang, can_kao_ren_yuan_, zhuang_tai_, da_biao_zhan_bi_, ji_fen_fang_shi_, kao_shi_miao_shu_, yun_xu_bao_ming_, sui_ji_chou_ti_, sui_ji_ti_shu_,chou_ti_zong_fen_,ti_mu_zong_shu_ from t_exams where id_ = '${this.id}'`
- this.$common.request('sql', sql).then((res) => {
- const { data = [] } = res.variables || {}
- if (!data.length) {
- this.$message.error('数据不存在')
- return
- }
- data[0].isCountLimit = data[0].xian_kao_ci_shu_ === '不限' ? '0' : '1'
- data[0].isDateLimit = data[0].xian_kao_shi_jian === '不限' ? '0' : '1'
- if (data[0].kao_shi_shi_chang === '不限') {
- data[0].isTimeLimit = '0'
- data[0].hours = null
- data[0].minutes = null
- } else {
- data[0].isTimeLimit = '1'
- data[0].hours = Math.floor(
- data[0].kao_shi_shi_chang / (1000 * 60 * 60)
- )
- data[0].minutes =
- (data[0].kao_shi_shi_chang % (1000 * 60 * 60)) / (60 * 1000)
- }
- this.form = data[0]
- if (this.form.sui_ji_chou_ti_ === '1') {
- this.form.sui_ji_ti_shu_ = this.form.sui_ji_ti_shu_.split(',')
- this.form.sui_ji_ti_shu_.forEach((item, index) => {
- this.handList[index].questionNumber = item
- })
- }
- })
- },
- // 随机题库 弃用
- randTiku () {
- this.randButtonDisabled = true
- const sql = `select id_ from t_question_bank where ti_ku_zhuang_tai_='可用'`
- this.$common.request('sql', sql).then((res) => {
- const { data = [] } = res.variables || {}
- const randNumber = Math.floor(Math.random() * data.length)
- this.form.ti_ku_id_ = data[randNumber].id_
- this.randButtonDisabled = false
- })
- },
- handleSubmit () {
- this.$refs.form.validate((valid) => {
- if (valid) {
- this.form.sui_ji_ti_shu_ = []
- this.form.chou_ti_zong_fen_ = 0
- this.form.ti_mu_zong_shu_ = 0
- if (this.form.sui_ji_chou_ti_ === '1') {
- // 计算总分 总数量
- this.handList.forEach(item => {
- if (item.list.length > 0) {
- this.form.sui_ji_ti_shu_.push(item.questionNumber)
- this.form.ti_mu_zong_shu_ += item.questionNumber
- this.form.chou_ti_zong_fen_ += item.list.slice(0, item.questionNumber).reduce((pre, cur) => {
- return pre + +cur.fen_zhi_
- }, 0)
- } else {
- this.form.sui_ji_ti_shu_.push(0)
- }
- })
- if (this.form.ti_mu_zong_shu_ === 0) {
- return this.$message.warning('请填写需要抽取的题目数量!')
- }
- }
- this.form.chou_ti_zong_fen_ += ''
- this.form.ti_mu_zong_shu_ += ''
- this.form.sui_ji_ti_shu_ = this.form.sui_ji_ti_shu_.join(',')
- const { isTimeLimit, xian_kao_shi_jian = '' } = this.form || {}
- // 转换考试时长
- if (isTimeLimit === '0') {
- this.form.kao_shi_shi_chang = '不限'
- } else {
- this.form.kao_shi_shi_chang =
- (this.form.hours * 60 + this.form.minutes) * 60 * 1000
- }
- delete this.form.isDateLimit
- delete this.form.isCountLimit
- delete this.form.isTimeLimit
- delete this.form.hours
- delete this.form.minutes
- this.form.chuang_jian_shi_j = this.$common.getDateNow(19)
- this.form.xian_kao_shi_jian =
- xian_kao_shi_jian !== '不限'
- ? this.$common.getFormatDate('string', 16, xian_kao_shi_jian)
- : xian_kao_shi_jian
- // 表单验证通过,提交表单
- this.submitForm()
- } else {
- ActionUtils.saveErrorMessage()
- }
- })
- },
- submitForm () {
- const addParams = {
- tableName: 't_exams',
- paramWhere: [this.form]
- }
- const updateParams = {
- tableName: 't_exams',
- updList: [
- {
- where: {
- id_: this.id
- },
- param: this.form
- }
- ]
- }
- const type = this.id ? 'update' : 'add'
- const params = type === 'add' ? addParams : updateParams
- this.$common.request(type, params).then(() => {
- this.$message.success(this.id ? '修改考试成功' : '新建考试成功')
- this.closeDialog()
- })
- },
- // 关闭当前窗口
- closeDialog () {
- this.$emit('close', false)
- }
- }
- }
- </script>
- <style lang="scss" scoped>
- .exam-dialog {
- ::v-deep {
- .el-dialog {
- max-width: 1080px;
- }
- .el-dialog__body {
- height: calc(88vh - 150px);
- }
- .el-form-item {
- margin-bottom: 14px !important;
- &:last-child {
- margin-bottom: 0 !important;
- }
- .el-form-item__label {
- font-size: 14px !important;
- }
- }
- .el-form-item--small .el-form-item__error {
- padding-top: 6px;
- }
- }
- .exam-form {
- padding: 20px;
- .question-icon {
- font-size: 13px;
- color: #606060;
- }
- .date-picker {
- margin-left: 20px;
- }
- .custom-dialog {
- ::v-deep {
- .el-input--prefix .el-input__inner {
- padding-left: 15px;
- }
- }
- }
- }
- .inline-item {
- ::v-deep {
- .el-radio-group {
- margin-right: 20px;
- }
- }
- .time {
- display: inline-block;
- }
- }
- .unit {
- display: inline-block;
- margin: 0 20px 0 5px;
- }
- .handrand{
- ::v-deep .el-form-item__content{
- display: flex;
- flex-wrap: wrap;
- }
- .hand-item{
- display: flex;
- margin-right: 20px;
- margin-bottom: 10px;
- }
- }
- }
- .tiku {
- .el-button {
- margin-left: 20px;
- }
- }
- </style>
|