<template>
|
<div>
|
<el-container class="app-item-contain step1" v-if="step === 'step0'">
|
<el-header class="">
|
<h1>{{$t('values_step_0_title')}}</h1>
|
</el-header>
|
<el-main class="">
|
<div v-html="$t('values_step_0_content')"></div>
|
<el-row class="do-align-center">
|
<el-button @click="step0_next" type="primary" round>{{$t('startDo')}}</el-button>
|
</el-row>
|
</el-main>
|
</el-container>
|
<el-container class="app-item-contain step1" v-if="step === 'step1'">
|
<el-header class="">
|
<h1>{{$t('values_title')}}</h1>
|
</el-header>
|
<el-main class="">
|
<div>
|
<div v-html="$t('values_title_description')"></div>
|
<div>{{$t('values_title_description_1')}}<img class="tools-button" src="@/assets/exam-paper/good.png" style="width: 15px;position: absolute;margin-top: 2px"/><span style="margin-left: 20px;">{{$t('values_title_description_1_2')}}</span></div>
|
<div>{{$t('values_title_description_2')}}<img class="tools-button" src="@/assets/exam-paper/nogood.png" style="width: 15px;position: absolute;margin-top: 2px"/><span style="margin-left: 20px;">{{$t('values_title_description_2_2')}}</span></div>
|
<div>{{$t('values_title_description_3')}}<img class="tools-button" src="@/assets/exam-paper/question.png" style="width: 15px;position: absolute;margin-top: 2px"/><span style="margin-left: 20px;">{{$t('values_title_description_3_2')}}</span></div>
|
<div>{{$t('values_title_description_4')}}<img class="tools-button" src="@/assets/exam-paper/scale.png" style="width: 15px;height: 15px;position: absolute;margin-top: 2px"/><span style="margin-left: 20px;">{{$t('values_title_description_4_2')}}</span></div>
|
</div>
|
|
<div style="display: flex;justify-content: flex-start;padding: 10px 0;">
|
<el-button style="margin-top: 12px;" @click="step1_start" type="primary" round v-if="!step1Start">{{$t('start')}}</el-button>
|
<el-button style="margin-top: 12px;" type="primary" round @click="step1_next"
|
v-if="(step1Start && itemSize>0)">
|
{{$t('next')}}
|
</el-button>
|
</div>
|
<div class="mullinediv" v-if="step1Start">
|
<div v-for="(question,index1) in questionItems" class="mullinediv-item"
|
v-if="isNull(question.content)">
|
<div style="display: flex; justify-content: flex-end;margin-right: -20px;margin-top: -10px;">
|
<el-image class="tools-button" :src="require('@/assets/exam-paper/scale.png')"
|
@click="previewImg('qImg'+question.id,question.id)"></el-image>
|
</div>
|
<el-image :ref="'qImg'+question.id" :src="question.imgUrl" lazy
|
:preview-src-list="[question.imgUrl]"></el-image>
|
<div style="display: flex; justify-content: space-between;">
|
<el-image class="tools-button" :src="require('@/assets/exam-paper/nogood.png')"
|
@click="unLikeMe(question.id)"></el-image>
|
<el-image class="tools-button" :src="require('@/assets/exam-paper/question.png')"
|
@click="iAmNotSure(question.id)"></el-image>
|
<el-image class="tools-button" :src="require('@/assets/exam-paper/good.png')"
|
@click="likeMe(question.id)"></el-image>
|
</div>
|
</div>
|
</div>
|
</el-main>
|
</el-container>
|
<el-container class="app-item-contain step1" v-if="step === 'step2-0'">
|
<el-header class="">
|
<h1>{{$t('values_step_2_title')}}</h1>
|
</el-header>
|
<el-main class="">
|
<div v-html="$t('values_step_2_content')"></div>
|
<el-row class="do-align-center">
|
<el-button @click="step2_0_next" type="primary" round>{{$t('startDo')}}</el-button>
|
</el-row>
|
</el-main>
|
</el-container>
|
<el-container class="app-item-contain step2" v-if="step === 'step2'">
|
<el-main class="">
|
<div>
|
<div class="tag-group" style="display: flex;">
|
<span class="tag-group__title"
|
style="padding-right: 10px;font-size: 26px;margin: auto 0px;">{{$t('values_cur_step')}}({{step2SubStep}} /
|
{{step2ScoreRanges.length}})</span>
|
<div>
|
<div style="display: flex;padding: 5px 0;">
|
<div v-for="item in step2ScoreRanges" :key="item.itemOrder" style="margin: 0 2px;font-size: 12px;width: 100px;text-align: center;" size="large">
|
{{ item.stepName }}
|
</div>
|
</div>
|
<div>
|
<el-tag v-for="item in step2ScoreRanges" :key="item.itemOrder"
|
:type="getStep2StepTagType(item.step)" style="margin: 0 2px;font-size: 26px;width: 100px;text-align: center;" size="large"
|
effect="light">
|
{{ item.quantity }}
|
</el-tag>
|
</div>
|
</div>
|
</div>
|
<div style="display: flex;justify-content: space-between;">
|
<div style="line-height: 50px;text-indent: 2em;">
|
<div
|
v-if="(step2SubStep == step2ScoreRanges.length) && (step2ScoreRanges.length % 2 == 1)">
|
{{$t('values_step_tips_for_3').replace('%N',getStep2StepItem(step2SubStep).quantity).replace('%C',getStep2StepItem(step2SubStep).stepName.toUpperCase())}}
|
</div>
|
<div v-else>
|
{{$t('values_step_tips_for_1').replace('%N',getStep2StepItem(step2SubStep).quantity).replace('%C',getStep2StepItem(step2SubStep).stepName.toUpperCase())}}
|
</div>
|
<div style="color: red;">
|
{{$t('values_step_tips')}}
|
</div>
|
</div>
|
<div style="margin-top: auto;">
|
<el-button type="primary" round @click="step2_pre" v-if="step2SubStep>1">{{$t('pre')}}
|
</el-button>
|
<el-button type="primary" round @click="step2_next">{{$t('next')}}</el-button>
|
</div>
|
</div>
|
</div>
|
<div>
|
<el-divider content-position="left"><span
|
:style="'padding: 0 10px;background-color: ' + ((getStep2StepItem(step2SubStep).selected>getStep2StepItem(step2SubStep).quantity)?'red;':'#c8c3c3;')">{{getStep2StepItem(step2SubStep).selected}}
|
/ {{getStep2StepItem(step2SubStep).quantity}}</span> </el-divider>
|
<div style="">
|
<div class="inlinediv">
|
<div v-for="(question,index2) in questionItems" class="mullinediv-item"
|
v-if="getStep2StepItem(step2SubStep).itemOrder == question.subjectId">
|
<el-image :ref="'q2SelectImg'+question.id" :src="question.imgUrl" :preview-src-list="[question.imgUrl]"></el-image>
|
<div style="display: flex; justify-content: space-between;">
|
<el-image class="tools-button" :src="require('@/assets/exam-paper/no.png')"
|
@click="step2Delete(question.id,getStep2StepItem(step2SubStep).itemOrder)">
|
</el-image>
|
<el-image class="tools-button" :src="require('@/assets/exam-paper/scale.png')"
|
@click="previewImg('q2SelectImg'+question.id)"></el-image>
|
</div>
|
</div>
|
</div>
|
</div>
|
<el-divider content-position="left">{{$t('values_select_tips')}}</el-divider>
|
<div style="height: auto;overflow: auto;">
|
<div class="mullinediv" style="" v-if="questionItems && questionItems.length>0">
|
<div v-for="(question,index3) in questionItems" class="mullinediv-item"
|
v-if="isNull(question.subjectId)">
|
<el-image :ref="'q2Img'+question.id" :src="question.imgUrl" lazy
|
:preview-src-list="[question.imgUrl]"></el-image>
|
<div style="display: flex; justify-content: space-between;">
|
<el-image class="tools-button" :src="require('@/assets/exam-paper/yes.png')"
|
@click="step2Add(question.id,getStep2StepItem(step2SubStep).itemOrder)">
|
</el-image>
|
<el-image class="tools-button" :src="require('@/assets/exam-paper/scale.png')"
|
@click="previewImg('q2Img'+question.id)"></el-image>
|
</div>
|
</div>
|
</div>
|
<div class="mullinediv" style="" v-if="sumStep2UnSelectedNum()<=0">
|
{{$t('values_no_select')}}
|
</div>
|
</div>
|
</div>
|
</el-main>
|
</el-container>
|
<el-container class="app-item-contain step3" v-if="step === 'step3'">
|
<el-main class="">
|
<div style="position: fixed;z-index: 999; width:90%; top: 56px;">
|
<div style="display: flex;justify-content: flex-end;padding: 10px;background-color: #f5f7fa;">
|
<div style="padding-right: 20px;width:50%;" v-html="$t('values_pic_tmpArea_desc')"></div>
|
<div style="padding: 0 10px;width:80px;">{{$t('values_pic_tmpArea')}}</div>
|
<draggable animation="300" class="pic-tmparea-div"
|
style="border: 1px solid gray;padding: 10px;width: 45%;"
|
:list="step3EWEIArea[0]" :options="{group:{name:'EWEIArea',pull:'clone'}}"
|
@start="ev=>step3TmpAreaStart(ev,0)"
|
@end="step3TmpAreaMoveEnd">
|
<div v-for="q in step3EWEIArea[0]" :key="q.id" class="mullinediv-item2"
|
:questionID="q.id" :questionIMGURL="q.imgUrl">
|
<el-image :src="q.imgUrl" :preview-src-list="[q.imgUrl]" fit="fill"></el-image>
|
</div>
|
</draggable>
|
<el-button type="primary" round style="height: fit-content;margin: 0 10px;"
|
@click="step3_commit" :disabled="submitDisable">
|
{{$t('commit')}}
|
</el-button>
|
</div>
|
</div>
|
<div style="display:flex;margin-top: 200px;">
|
<div style="display: inline-block;min-width: 150px;text-align: right;padding-right: 5px;">
|
<div class="mul-inlinediv-row mul-inlinediv-lineheight"
|
v-for="(item,index) in step2ScoreRanges">
|
<span v-if="item.stepName=='不确定是否相似'">
|
不确定是否与你相似 <span v-if="item.step<step2ScoreRanges.length">{{$t('values_step_names_unit')}}</span>
|
</span>
|
<span v-else>
|
{{$t('values_step_names_unit_pre')}}{{item.stepName}} <span v-if="item.step<step2ScoreRanges.length">{{$t('values_step_names_unit')}}</span>
|
</span>
|
</div>
|
</div>
|
<div style="display: inline-block;width: 20px;margin-top: 4px;">
|
<div class="mul-inlinediv-row mul-inlinediv-lineheight mul-inlinediv-down"
|
v-for="(item,index) in step2ScoreRanges">
|
</div>
|
</div>
|
<!--
|
<div style="display: inline-block;min-width: 20px;text-align: right;">
|
<div class="mul-inlinediv-row mul-inlinediv-lineheight"
|
v-for="(item,index) in step2ScoreRanges">
|
{{$t('values_step_names_unit')}}
|
</div>
|
</div>
|
-->
|
<div class="mul-inlinediv-box">
|
|
<div class="mul-inlinediv" v-for="item in step2ScoreRanges">
|
<div class="mul-inlinediv-row">
|
<draggable animation="300" classa="pic-eweiarea-div" :class="'pic-eweiarea-div-'+item.itemOrder"
|
:list="step3EWEIArea[item.itemOrder]"
|
:options="{group:{name:'EWEIArea',pull:'clone'}}" filter=".undraggable"
|
@end="ev=>step3EWEIAreaMoveEnd(ev,item.itemOrder)" :scoreRangeId="item.itemOrder">
|
<div v-for="q in step3EWEIArea[item.itemOrder]" :key="q.id"
|
class="mul-inlinediv-item" :questionID="q.id" :questionIMGURL="q.imgUrl">
|
<el-image :src="q.imgUrl" :preview-src-list="[q.imgUrl]" v-if="q.imgUrl">
|
</el-image>
|
</div>
|
<div v-if="item.quantity >= step3EWEIArea[item.itemOrder].length">
|
<div class="mul-inlinediv-item"
|
v-for="c in (item.quantity - step3EWEIArea[item.itemOrder].length)">
|
<el-image :src="require('@/assets/exam-paper/none.png')" class="undraggable">
|
</el-image>
|
</div>
|
</div>
|
</draggable>
|
</div>
|
</div>
|
|
</div>
|
</div>
|
</el-main>
|
</el-container>
|
<el-row class="do-exam-title footer">
|
<el-col :span="24">
|
<span class="do-exam-time">
|
</span>
|
</el-col>
|
</el-row>
|
</div>
|
</template>
|
|
<script>
|
import {
|
mapState,
|
mapGetters,
|
mapMutations
|
} from 'vuex'
|
import {
|
formatDate
|
} from '@/utils'
|
import examPaperApi from '@/api/examPaper'
|
import examPaperAnswerApi from '@/api/examPaperAnswer'
|
import demographyApi from '@/api/demography'
|
import draggable from 'vuedraggable'
|
|
export default {
|
name: 'values',
|
components: {
|
draggable
|
},
|
data() {
|
return {
|
step: 'step0',
|
step1Start: false,
|
step1SelectedNum: 0,
|
step2ScoreRanges: [
|
// {
|
// "itemOrder": 1,
|
// "quantity": 2,
|
// "score": 5,
|
// "completed": false,
|
// "questionReports": null
|
// }
|
],
|
step2ScoreRangesDefault: [{
|
"itemOrder": 0,
|
"quantity": 0,
|
"score": 0,
|
"completed": false,
|
"questionReports": null,
|
"step": 0,
|
"stepName":'',
|
"selected": 0
|
}],
|
step2SubStep: 1,
|
step3ChangeSrc: {
|
"id": null,
|
"subjectId": null,
|
},
|
step3EWEIArea: [1],
|
form:{},
|
formLoading: false,
|
answer: {
|
questionId: null,
|
doTime: 0,
|
answerItems: [],
|
verifyStatus: 2
|
},
|
timer: null,
|
|
titleItemsLength: 0,
|
remainTime: 0,
|
titleItemName: '', // 考试第二标题
|
itemOrder: '', // 题目的序号
|
questionItem: {}, // 题目
|
questionItems: [], // 题目集
|
itemSize: '', // 题目长度
|
titleItems: [],
|
|
order: 0,
|
guide: false,
|
answered: [],
|
submitDisable: false,
|
doTime: 0,
|
preDisable: false,
|
nextDisable: false,
|
partOrder: 0,
|
parts: [],
|
guideTitle: '',
|
guideDescirption: '',
|
isCallTain: '',
|
memberName: '',
|
startDoDisable: true,
|
|
}
|
},
|
//created: function() {
|
mounted: function() {
|
console.log(".....................mounted start......................")
|
//console.log(".....................Test. config start......................")
|
//if(this.memberToken == '' || this.memberToken == undefined) this.setMemberTocken("4bdcf437-185c-4f4e-9528-382c99509ea6")
|
//console.log(".....................Test. config ednd.......................")
|
let _this = this
|
// 多语言
|
_this.setLangFlag(false)
|
_this.form = this.$route.query.formDo
|
if (_this.form !== {} && _this.form !== undefined && typeof(_this.form) !== "string") {
|
console.log("created......get from query", _this.form)
|
_this.formLoading = true
|
_this.remainTime = _this.form.suggestTime * 60
|
_this.titleItemsLength = _this.form.titleItems.length
|
_this.titleItems.push(_this.form.titleItems[0])
|
_this.questionItem = _this.form.titleItems[0].questionItems[0]
|
_this.questionItems = _this.form.titleItems[0].questionItems
|
_this.partOrder = _this.questionItem.partOrder
|
_this.itemOrder = _this.form.titleItems[0].questionItems[0].itemOrder
|
_this.itemSize = _this.form.titleItems[0].questionItems.length
|
_this.timeReduce()
|
_this.initAnswer()
|
_this.formLoading = false
|
_this.memberName = _this.form.memberName
|
_this.initStep2ScoreRanges(_this.form.titleItems[0].scoreRanges)
|
|
} else {
|
console.log(".....................mounted 刷新......................")
|
_this.formLoading = true
|
// 防止刷新成了不同的语言
|
demographyApi.queryDemographyParamInfo(_this.memberToken).then(
|
re => {
|
if (re.response[0].langType !== null || re.response[0].langType.trim() !== '') {
|
_this.setLangType(re.response[0].langType)
|
console.log("lang type",re.response[0].langType,_this.langType)
|
}
|
// 加载题目
|
examPaperApi.select(_this.memberToken, _this.langType).then(re => {
|
console.log("created......get from db", re.response)
|
_this.form = re.response
|
_this.remainTime = re.response.suggestTime * 60
|
_this.titleItemsLength = _this.form.titleItems.length
|
_this.titleItems.push(_this.form.titleItems[0])
|
_this.itemOrder = _this.form.titleItems[0].questionItems[_this.order].itemOrder
|
_this.itemSize = _this.form.titleItems[0].questionItems.length
|
_this.questionItem = _this.form.titleItems[0].questionItems[_this.order]
|
_this.questionItems = _this.form.titleItems[0].questionItems
|
_this.partOrder = _this.questionItem.partOrder
|
_this.initAnswer()
|
_this.formLoading = false
|
_this.memberName = _this.form.memberName
|
_this.initStep2ScoreRanges(_this.form.titleItems[0].scoreRanges)
|
|
examPaperApi.selectTokenId(_this.memberToken).then(re => {
|
_this.answered = re.response.examItemOrderAndContentList
|
_this.doTime = re.response.doTime
|
_this.timeReduce()
|
|
if (_this.answered !== null) {
|
_this.answered.forEach(it => {
|
_this.answer.answerItems[parseInt(it.itemOrder) -
|
1].content = it.content
|
_this.answer.answerItems[parseInt(it.itemOrder) -
|
1].completed = true
|
})
|
}
|
|
for (let i = 0; i < _this.answer.answerItems.length; i++) {
|
if (!_this.answer.answerItems[i].completed || _this.answer
|
.answerItems[i].content === null || _this.answer
|
.answerItems[i].content === '') {
|
_this.questionItem = _this.form.titleItems[0]
|
.questionItems[i]
|
_this.partOrder = _this.questionItem.partOrder
|
_this.itemOrder = _this.form.titleItems[0].questionItems[i]
|
.itemOrder
|
_this.order = i
|
_this.preDisable = true
|
break
|
}
|
|
if (_this.isForFinish(i)) {
|
_this.$router.push({
|
path: '/exam/finish',
|
query: {
|
name: '',
|
content: _this.$t('finishMsg'),
|
tokenId: _this.memberToken
|
}
|
})
|
}
|
}
|
// 如果上一题不是本段,则不能返回上一段
|
if (this.isDiffPartOrder()) {
|
_this.preDisable = false
|
}
|
|
if (this.isDiffPartOrder()) {
|
_this.showNextGuide(re.response.signalObject, false)
|
}
|
}).catch(e => {
|
// _this.$message.error('题目查询异常')
|
})
|
}).catch(e => {
|
_this.$message.info(_this.$t('noquestionMsg'))
|
})
|
}
|
).catch(e => {})
|
}
|
|
document.body.ondrop = function(event) {
|
event.preventDefault();
|
event.stopPropagation();
|
}
|
},
|
// mounted() {
|
// //console.log("mounted......")
|
// document.body.ondrop = function(event) {
|
// event.preventDefault();
|
// event.stopPropagation();
|
// }
|
// },
|
beforeDestroy() {
|
window.clearInterval(this.timer)
|
},
|
methods: {
|
step0_next(){
|
this.step = "step1"
|
},
|
step1_start() {
|
this.step = "step1"
|
this.step1Start = true
|
this.questionItems.sort(function(i2, i1) {
|
return (i2.id - i1.id)
|
})
|
//test
|
//this.initTestData()
|
//回显,没有可选的时候,进入下一步
|
let c = this.sumStep1UnSelectedNum()
|
if (c <= 0 && this.itemSize > 0) {
|
this.step1_next()
|
}
|
},
|
step1_next() {
|
let _this = this
|
let c = this.sumStep1UnSelectedNum()
|
if (c > 0) {
|
this.$message.error(_this.$t('values_nextStepTips_choices_all'))
|
return
|
}
|
/*
|
this.$confirm(_this.$t('values_nextStepTips_tips'), _this.$t('prompt'), {
|
confirmButtonText: _this.$t('determine'),
|
cancelButtonText: _this.$t('cancel'),
|
type: 'warning'
|
}).then(() => {
|
_this.step = "step2"
|
_this.sortQuestions()
|
_this.caculateScoreRangeSelectedById(this.getStep2StepItem(this.step2SubStep).itemOrder)
|
}).catch(() => {
|
|
});
|
*/
|
this.step = "step2-0"
|
},
|
step2_0_next(){
|
let _this = this
|
_this.step = "step2"
|
_this.sortQuestions()
|
_this.caculateScoreRangeSelectedById(this.getStep2StepItem(this.step2SubStep).itemOrder)
|
},
|
step2_pre() {
|
if (this.step2SubStep > 1) {
|
this.step2SubStep = this.step2SubStep - 1
|
}
|
},
|
step2_next() {
|
let _this = this
|
let stepItem = this.getStep2StepItem(this.step2SubStep)
|
if (stepItem.selected == stepItem.quantity || this.sumStep2UnSelectedNum() == 0) {
|
_this.answer.verifyStatus = 2
|
_this.submitSubAnswer()
|
|
this.step2SubStep = this.step2SubStep + 1
|
if (this.step2SubStep == this.step2ScoreRanges.length) { //进入最后一步骤
|
this.resetAllQuestionItemsValueByKeyWhenNull("subjectId", this.getStep2StepItem(this.step2SubStep)
|
.itemOrder)
|
}
|
if (this.step2SubStep > this.step2ScoreRanges.length) { //完成最后一步骤
|
this.step = "step3"
|
this.buildStep3EWEIArea()
|
}
|
|
this.sortQuestions()
|
this.caculateScoreRangeSelectedById(this.getStep2StepItem(this.step2SubStep).itemOrder)
|
} else {
|
//this.$message.error(_this.$t('noquestionMsg'))
|
if (stepItem.selected > stepItem.quantity) {
|
this.$message.error(_this.$t('values_nextStepTips_del_unnecessary'))
|
} else {
|
this.$message.error(_this.$t('values_nextStepTips_add_enough'))
|
}
|
}
|
},
|
step2Delete(qid, sid) {
|
this.resetQuestionItemsSubjectIdById(qid, null) //借用subjectId,存储
|
this.caculateScoreRangeSelectedById(sid, -1)
|
},
|
step2Add(qid, sid) {
|
//console.log("step2Add....",value,qid,sid)
|
this.resetQuestionItemsSubjectIdById(qid, sid) //借用subjectId,存储
|
this.caculateScoreRangeSelectedById(sid, 1)
|
},
|
step3Change(value, question) {
|
if (this.step3ChangeSrc.id == null) {
|
//首次点击,临时存储
|
this.step3ChangeSrc.id = question.id
|
this.step3ChangeSrc.subjectId = question.subjectId
|
for (let item of this.questionItems) {
|
if (item.id == question.id) item['checked'] = true
|
}
|
} else {
|
if (this.step3ChangeSrc.id == question.id) {
|
//对调自己
|
} else {
|
//对调
|
this.resetQuestionItemsSubjectIdById(this.step3ChangeSrc.id, question
|
.subjectId) //借用subjectId,存储
|
this.resetQuestionItemsSubjectIdById(question.id, this.step3ChangeSrc
|
.subjectId) //借用subjectId,存储
|
}
|
//清理
|
this.step3ChangeSrc.id = null
|
this.step3ChangeSrc.subjectId = null
|
for (let item of this.questionItems) {
|
item['checked'] = false
|
}
|
}
|
},
|
/**
|
* 根据QuestionItems,构建二维图表数据
|
*/
|
buildStep3EWEIArea() {
|
this.step3EWEIArea = [this.step2ScoreRanges.length + 1]
|
this.step3EWEIArea[0] = []
|
this.$set(this.step3EWEIArea, 0, this.step3EWEIArea[0])
|
for (let item of this.step2ScoreRanges) {
|
this.step3EWEIArea[item.itemOrder] = []
|
for (let q = 1; q <= item.quantity; q++) {
|
let t = this.getQuestionItemsByKey("subjectId", item.itemOrder, q)
|
if (t.id) {
|
this.step3EWEIArea[item.itemOrder].push(t)
|
}
|
}
|
this.$set(this.step3EWEIArea, item.itemOrder, this.step3EWEIArea[item
|
.itemOrder])
|
}
|
console.log('buildStep3EWEIArea', this.step3EWEIArea)
|
},
|
addStep3EWEIArea(index,question){
|
//console.log('addStep3EWEIArea',index,question)
|
this.step3EWEIArea[index].push(question)
|
this.$set(this.step3EWEIArea, index, this.step3EWEIArea[index])
|
},
|
delStep3EWEIArea(index,question){
|
//console.log('delStep3EWEIArea s',index,question,this.step3EWEIArea[index])
|
for(let i=0;i<this.step3EWEIArea[index].length;i++){
|
if(question.id == this.step3EWEIArea[index][i].id){
|
this.step3EWEIArea[index].splice(i,1)
|
}
|
}
|
this.$set(this.step3EWEIArea, index, this.step3EWEIArea[index])
|
//console.log('delStep3EWEIArea e',this.step3EWEIArea[index])
|
},
|
hasStep3EWEIAreaOverflow(index,question){
|
//console.log('hasStep3EWEIAreaOverflow e',this.step3EWEIArea[index])
|
if(this.step3EWEIArea[index].length>this.step2ScoreRanges[index-1].quantity){
|
return true
|
}
|
return false
|
},
|
|
step3TmpAreaStart(ev,i) {
|
console.log('step3TmpAreaStart', ev,i)
|
},
|
step3TmpAreaMoveAdd(ev) {
|
console.log('step3TmpAreaMoveAdd', ev)
|
return false
|
},
|
step3TmpAreaMoveEnd(ev) {
|
console.log('step3TmpAreaMoveEnd s', ev)
|
console.log('step3TmpAreaMoveEnd from,to', ev.from.className,ev.to.className)
|
let to = ev.to.className.replace("pic-eweiarea-div-","")
|
let qId = ev.item.attributes.questionID.value
|
let qImg = ev.item.attributes.questionIMGURL.value
|
if("pic-tmparea-div"===ev.to.className){
|
//this.delStep3EWEIArea(to,{'id':qId,'imgUrl':qImg})
|
} else {
|
let of = this.hasStep3EWEIAreaOverflow(to,{'id':qId,'imgUrl':qImg})
|
if(of){
|
this.delStep3EWEIArea(to,{'id':qId,'imgUrl':qImg})
|
} else {
|
this.delStep3EWEIArea(0,{'id':qId,'imgUrl':qImg})
|
}
|
}
|
},
|
|
step3EWEIAreaMoveEnd(ev,fid) {
|
console.log('step3EWEIAreaMoveEnd',ev)
|
console.log('step3EWEIAreaMoveEnd from,to,id', ev.from.className,ev.to.className,fid)
|
let to = ev.to.className.replace("pic-eweiarea-div-","")
|
let qId = ev.item.attributes.questionID.value
|
let qImg = ev.item.attributes.questionIMGURL.value
|
if("pic-tmparea-div"===ev.to.className){
|
this.delStep3EWEIArea(fid,{'id':qId,'imgUrl':qImg})
|
} else {
|
if(fid != to) this.delStep3EWEIArea(to,{'id':qId,'imgUrl':qImg})
|
}
|
},
|
|
sumStep2UnSelectedNum() {
|
let count = 0
|
for (let item of this.questionItems) {
|
if (this.isNull(item['subjectId'])) {
|
count = count + 1
|
}
|
}
|
return count
|
},
|
sumStep1UnSelectedNum() {
|
let count = 0
|
for (let item of this.questionItems) {
|
if (this.isNull(item['content'])) {
|
count = count + 1
|
}
|
}
|
return count
|
},
|
step3_commit() {
|
let _this = this
|
|
if (_this.step3EWEIArea[0].length > 0) {
|
this.$message.error(_this.$t('values_nextStepTips_choices_all'))
|
return
|
}
|
_this.resetAllQuestionItemsValueByEWEIArea()
|
|
window.clearInterval(_this.timer)
|
_this.submitDisable = true
|
_this.formLoading = true
|
_this.answer.verifyStatus = 1
|
_this.answer.finish = 1
|
_this.submitAnswer(_this.$t('values_finishValuesInfo'))
|
},
|
getLikeTypeByScoreRangeItemOrder(itemOrder) {
|
if (this.isNull(itemOrder)) return null;
|
let step = 0
|
for (let item of this.step2ScoreRanges) {
|
if (item.itemOrder === itemOrder) {
|
step = item['step']
|
break
|
}
|
}
|
return this.getLikeType(step)
|
},
|
getLikeType(step) {
|
if (this.step2ScoreRanges.length % 2 == 0) { //偶数步骤
|
if (step % 2 == 0) {
|
//2-UnLike
|
return 2
|
} else {
|
//0-Like
|
return 0
|
}
|
} else { //奇数步骤
|
if (step == this.step2ScoreRanges.length) {
|
//1-NotSure
|
return 1
|
} else {
|
if (step % 2 == 0) {
|
//2-UnLike
|
return 2
|
} else {
|
//0-Like
|
return 0
|
}
|
}
|
}
|
},
|
sortQuestions() {
|
let type = this.getLikeType(this.step2SubStep)
|
switch (type) {
|
case 0: //0:最像我 数字排序(数字和升序)
|
this.questionItems.sort(function(a, b) {
|
return a.content - b.content
|
})
|
break
|
case 1: //1:有疑问
|
this.questionItems.sort(function(i2, i1) {
|
return (i2.content == 1) ? -1 : 1
|
})
|
break
|
case 2: //2:最不像我 数字排序(数字和降序)
|
this.questionItems.sort(function(a, b) {
|
return b.content - a.content
|
})
|
break
|
}
|
},
|
|
likeMe(id) {
|
let _this = this
|
this.step1SelectedNum = this.step1SelectedNum + 1
|
this.resetQuestionItemsContentById(id, 0) //借用analyze,存储"Like"
|
|
_this.answer.verifyStatus = 2
|
_this.submitSubAnswer()
|
},
|
iAmNotSure(id) {
|
let _this = this
|
this.step1SelectedNum = this.step1SelectedNum + 1
|
this.resetQuestionItemsContentById(id, 1) //"NotSure"
|
|
_this.answer.verifyStatus = 2
|
_this.submitSubAnswer()
|
},
|
unLikeMe(id) {
|
let _this = this
|
this.step1SelectedNum = this.step1SelectedNum + 1
|
this.resetQuestionItemsContentById(id, 2) //"UnLike"
|
|
_this.answer.verifyStatus = 2
|
_this.submitSubAnswer()
|
},
|
resetQuestionItemsContentById(id, value) {
|
for (let item of this.questionItems) {
|
if (item.id == id) {
|
item["content"] = value
|
}
|
}
|
//console.log('resetQuestionItems...', id, value, this.questionItems)
|
},
|
resetQuestionItemsSubjectIdById(id, value) {
|
for (let item of this.questionItems) {
|
if (item.id == id) {
|
item["subjectId"] = value
|
item['content'] = this.getLikeTypeByScoreRangeItemOrder(value)
|
}
|
}
|
//console.log('resetQuestionItems...', id, value, this.questionItems)
|
},
|
//设置所有未有归属步骤(subjectId)的QuestionItems为新的归属步骤(subjectId)
|
resetAllQuestionItemsValueByKeyWhenNull(key, value) {
|
for (let item of this.questionItems) {
|
if (this.isNull(item[key])) {
|
item[key] = value
|
if ("subjectId" == key) {
|
item['content'] = this.getLikeTypeByScoreRangeItemOrder(value)
|
}
|
}
|
}
|
//console.log('resetQuestionItems...',id,key,value,this.questionItems)
|
},
|
//根据二维图表数据重设QuestionItems的归属步骤(subjectId)
|
resetAllQuestionItemsValueByEWEIArea() {
|
for (let i = 1; i < this.step3EWEIArea.length; i++) {
|
for (let q of this.step3EWEIArea[i]) {
|
this.resetQuestionItemsSubjectIdById(q.id, i)
|
}
|
}
|
console.log('resetQuestionItems...by EWEIArea', this.questionItems)
|
},
|
getQuestionItemsByKey(key, stepOrder, index) {
|
let arr = []
|
for (let item of this.questionItems) {
|
if (!this.isNull(item[key])) {
|
if (item[key] == stepOrder) {
|
arr.push(item)
|
}
|
}
|
}
|
//console.log('getQuestionItemsByKey',key,stepOrder,index,arr,this.questionItems)
|
if (index <= arr.length) {
|
return arr[index - 1]
|
}
|
return {
|
id: null,
|
imgUrl: null,
|
subjectId: null
|
}
|
},
|
/**
|
* 计算步骤id的已选择数量
|
* @param {Object} id
|
* @param {Object} value
|
*/
|
caculateScoreRangeSelectedById(id, value) {
|
let sum = 0
|
for (let item of this.questionItems) {
|
if (item.subjectId === id) {
|
sum = sum + 1
|
}
|
}
|
for (let item of this.step2ScoreRanges) {
|
if (item.itemOrder == id) {
|
item['selected'] = sum
|
}
|
}
|
},
|
initTestData() {
|
//console.log('initTestData...s',this.questionItems)
|
for (let item of this.questionItems) {
|
item['content'] = 1
|
}
|
for (let i = 0; i < this.step2ScoreRanges.length; i++) {
|
for (let j = 1; j <= this.step2ScoreRanges[i].quantity; j++) {
|
//console.log('for',i,j,this.step2ScoreRanges,this.questionItems)
|
for (let item of this.questionItems) {
|
if (this.isNull(item["subjectId"])) {
|
item["subjectId"] = this.step2ScoreRanges[i].itemOrder
|
break
|
}
|
}
|
}
|
}
|
console.log('initTestData...e', this.questionItems)
|
},
|
/**
|
* 设置step2ScoreRanges子项的步骤顺序及正负距离值
|
* @param {Object} arr
|
*/
|
initStep2ScoreRanges(arr) {
|
//console.log('initStep2ScoreRanges...s', arr)
|
let _this = this
|
_this.step2ScoreRanges = _this.step2ScoreRanges.concat(arr)
|
let s = 1
|
let a = 2 //-2
|
let max = _this.step2ScoreRanges.length
|
let max4O = (max % 2 == 0) ? (max) : (max + 1)
|
let max4J = (max % 2 == 0) ? (max + 1) : (max)
|
let deviate = 0 //偏离值
|
for (let i = 0; i < _this.step2ScoreRanges.length; i++) {
|
//设置每项step数
|
if (a > 0) { //+
|
if (s < max) {
|
_this.step2ScoreRanges[i]['step'] = s
|
a = 2
|
s = s + a
|
} else if (s == max) {
|
_this.step2ScoreRanges[i]['step'] = s
|
a = -2
|
s = s + 1
|
} else {
|
_this.step2ScoreRanges[i]['step'] = s - 1
|
a = -2
|
s = s - 1
|
}
|
} else { //-
|
s = s + a
|
_this.step2ScoreRanges[i]['step'] = s
|
}
|
//设置每项step偏离最后step的正负距离值(奇数step正偏离,偶数step负偏离)
|
if (_this.step2ScoreRanges[i]['step'] % 2 == 0) { //偶数
|
deviate = (max4O - _this.step2ScoreRanges[i]['step']) - (max4O - _this.step2ScoreRanges[i][
|
'step'
|
]) / 2
|
_this.step2ScoreRanges[i]['deviate'] = 0 - deviate
|
} else {
|
deviate = (max4J - _this.step2ScoreRanges[i]['step']) - (max4J - _this.step2ScoreRanges[i][
|
'step'
|
]) / 2
|
_this.step2ScoreRanges[i]['deviate'] = deviate
|
}
|
//设置每项已选择的数量
|
_this.step2ScoreRanges[i]['selected'] = 0
|
}
|
//console.log('initStep2ScoreRanges...e', this.step2ScoreRanges)
|
_this.initStep2ScoreRangesStepName()
|
_this.initQuestionItems()
|
},
|
initStep2ScoreRangesStepName(){
|
let _this = this
|
let max = _this.step2ScoreRanges.length
|
let splitChar = ","
|
if(_this.$t('values_step_names').indexOf(",")>=0){
|
splitChar = ","
|
}
|
//console.log('lang type',_this.langType)
|
let names = _this.$t('values_step_names').split(splitChar)
|
console.log('initStep2ScoreRangesStepName',names)
|
for (let i = 0; i < _this.step2ScoreRanges.length; i++) {
|
if(_this.step2ScoreRanges[i]['step'] > names.length){
|
_this.step2ScoreRanges[i]['stepName'] = names[names.length-1]
|
} else {
|
_this.step2ScoreRanges[i]['stepName'] = names[_this.step2ScoreRanges[i]['step']-1]
|
}
|
//设置最后的Step的StepName为固定值
|
if(_this.step2ScoreRanges[i]['step'] >= max){
|
if(max % 2 == 0){//偶数
|
|
} else {//奇数
|
_this.step2ScoreRanges[i]['stepName'] = names[names.length-1]
|
}
|
}
|
}
|
console.log('initStep2ScoreRangesStepName',_this.step2ScoreRanges)
|
},
|
initQuestionItems(){
|
let _this = this
|
for (let sr of _this.step2ScoreRanges) {
|
if(_this.isNotEmpty(sr['questionReports'])){
|
for(let q of sr.questionReports){
|
_this.resetQuestionItemsSubjectIdById(q.questionId,sr.itemOrder)
|
}
|
}
|
}
|
console.log('initQuestionItems...e', this.questionItems)
|
},
|
getStep2StepTagType(step) {
|
if (this.step2SubStep > step) {
|
return ''
|
} else if (this.step2SubStep == step) {
|
return 'success'
|
} else {
|
return 'info'
|
}
|
},
|
getStep2StepTagTypeName(step) {
|
if (this.step2SubStep > step) {
|
return ''
|
} else if (this.step2SubStep == step) {
|
return 'success'
|
} else {
|
return 'info'
|
}
|
},
|
getStep2StepItem(step) {
|
//console.log('getStep2StepItem',step,this.step2ScoreRanges)
|
let _this = this
|
for (let i = 0; i < _this.step2ScoreRanges.length; i++) {
|
if (_this.step2ScoreRanges[i]['step'] == step) {
|
return _this.step2ScoreRanges[i]
|
}
|
}
|
return _this.step2ScoreRangesDefault[0];
|
},
|
formatDate(time, formatsrc) {
|
return formatDate(time, formatsrc)
|
},
|
timeReduce: function() {
|
let _this = this
|
_this.answer.doTime += _this.doTime
|
this.timer = setInterval(function() {
|
if (_this.answer.doTime <= 0) {
|
_this.answer.doTime = 0
|
}
|
++_this.answer.doTime
|
}, 1000)
|
},
|
|
initAnswer() {
|
this.answer.id = this.form.id
|
this.answer.questionOrder = this.form.questionOrder
|
let titleItemArray = this.form.titleItems
|
for (let tIndex in titleItemArray) {
|
let questionArray = titleItemArray[tIndex].questionItems
|
for (let qIndex in questionArray) {
|
let question = questionArray[qIndex]
|
this.answer.answerItems.push({
|
title: question.title,
|
permanentId: question.permanentId,
|
questionId: question.id,
|
content: question.content,
|
contentArray: [],
|
completed: false,
|
itemOrder: question.itemOrder,
|
lastContent: null,
|
startTime: question.startTime,
|
endTime: question.endTime,
|
partOrder: question.partOrder,
|
questionReport: {},
|
readOnly: false,
|
imgUrl: question.imgUrl
|
})
|
}
|
}
|
|
// 初始化开始时间,设置第一个时间
|
for (let i = 0; i < this.answer.answerItems.length; i++) {
|
if (this.answer.answerItems[i].startTime == null || this.answer.answerItems[i].startTime.trim() ==
|
'') {
|
this.answer.answerItems[i].startTime = this.formatDate(new Date(), 'yyyy-MM-dd hh:mm:ss')
|
break
|
}
|
}
|
},
|
isContentNotEmpty: function(num) {
|
let _this = this
|
return _this.answer.answerItems[num].content !== '' && _this.answer.answerItems[num].content !==
|
null && _this.answer.answerItems[num].content.trim() !== ''
|
},
|
nextQuestion: function(nowPartOrder) {
|
let _this = this
|
let num = ++_this.order
|
_this.itemOrder = _this.form.titleItems[0].questionItems[num].itemOrder
|
// 跳到没有答的题目
|
while (_this.isContentNotEmpty(num) && num !== _this.answer.answerItems.length - 1) {
|
num = ++_this.order
|
this.getEmptySubjct(num)
|
}
|
_this.questionItem = _this.form.titleItems[0].questionItems[num]
|
_this.partOrder = _this.questionItem.partOrder
|
if (_this.partOrder !== nowPartOrder) {
|
_this.isShowGuide(true)
|
}
|
_this.preDisable = true
|
_this.nextDisable = false
|
_this.answer.answerItems[_this.order].startTime = _this.formatDate(new Date(), 'yyyy-MM-dd hh:mm:ss')
|
|
// 如果是最后一个并且已经完成了,就提交
|
if (num === _this.answer.answerItems.length - 1 && _this.isForFinish(num)) {
|
this.submitForm()
|
}
|
},
|
nextQuestionOrder: function(nowPartOrder) {
|
if (this.order < this.itemSize - 1) {
|
this.nextQuestion(nowPartOrder)
|
} else {
|
this.submitDisable = false
|
}
|
},
|
isNextShowGuide: function(nowPartOrder) {
|
let _this = this
|
// 本段的每一题都打完要指导语
|
let showGuideFlag = true
|
for (let i = 0; i < _this.answer.answerItems.length; i++) {
|
if (_this.form.titleItems[0].questionItems[i].partOrder === nowPartOrder && !_this
|
.isContentNotEmpty(i)) {
|
showGuideFlag = false
|
}
|
}
|
return showGuideFlag
|
},
|
catThaiSubmit: function(answerSubmit) {
|
answerSubmit.isCallTain = 'CallThai'
|
},
|
getEmptySubjct: function(order) {
|
let _this = this
|
_this.itemOrder = _this.form.titleItems[0].questionItems[order].itemOrder
|
_this.questionItem = _this.form.titleItems[0].questionItems[order]
|
_this.partOrder = _this.questionItem.partOrder
|
_this.preDisable = false
|
_this.answer.answerItems[order].readOnly = false
|
// _this.answer.answerItems[order].content = ''
|
// _this.answer.answerItems[order].completed = false
|
_this.order = order
|
},
|
isNotEmpty(obj) {
|
return obj !== null && obj !== undefined && obj !== ''
|
},
|
isEmpty(obj) {
|
return !this.isNotEmpty(obj)
|
},
|
getContentByQuestionId(id) {
|
let cont
|
for (let item of this.questionItems) {
|
if (item.id == id) {
|
cont = item.content
|
break
|
}
|
}
|
return cont;
|
},
|
getSubmitAnswerValue(nowPartOrder) {
|
let _this = this
|
let answerSubmit = JSON.parse(JSON.stringify(_this.answer))
|
//add answerItems
|
answerSubmit.answerItems.forEach(answerItem => {
|
// 题目报表,如果没有结束时间,开始时间也不需要
|
if (answerItem.endTime == null || answerItem.endTime === '') {
|
answerItem.startTime = ''
|
}
|
answerItem.completed = true
|
answerItem.content = this.getContentByQuestionId(answerItem.questionId)
|
//this.getLikeTypeByScoreRangeItemOrder(answerItem.subjectId)
|
answerItem.questionReport = {
|
questionOrder: answerItem.questionId,
|
questionTitle: answerItem.title,
|
permanentId: answerItem.permanentId,
|
startTime: answerItem.startTime,
|
endTime: answerItem.endTime,
|
langType: _this.langType,
|
partOrder: answerItem.partOrder,
|
imgUrl: answerItem.imgUrl,
|
answer: answerItem.content
|
}
|
})
|
answerSubmit.langType = _this.langType
|
answerSubmit.isCallTain = _this.isCallTain
|
answerSubmit.partOrder = nowPartOrder
|
answerSubmit.itemOrder = _this.itemOrder
|
//add scoreRanges
|
if (_this.step2SubStep >= _this.step2ScoreRanges.length || true) {//传递全部
|
answerSubmit['scoreRanges'] = _this.form.titleItems[0].scoreRanges
|
} else {
|
let item = _this.getStep2StepItem(_this.step2SubStep)
|
//console.log('getStep2StepItem', _this.step2SubStep, item)
|
answerSubmit['scoreRanges'] = []
|
answerSubmit['scoreRanges'].push(item)
|
}
|
//console.log('answerSubmit.scoreRanges=', answerSubmit['scoreRanges'])
|
for (let item of answerSubmit['scoreRanges']) {
|
item['completed'] = true
|
item['questionReports'] = []
|
for (let question of _this.questionItems) {
|
if (question.subjectId == item.itemOrder) {
|
item['questionReports'].push({
|
questionId: question.id, //题目ID
|
questionOrder: question.questionOrder, //题目序号
|
questionTitle: question.questionTitle, //题目标题
|
permanentId: question.permanentId, //题目永久编号
|
startTime: question.startTime, //答题开始时间
|
endTime: question.endTime, //答题结束时间
|
langType: question.langType, //答题语言
|
partOrder: question.partOrder, //分片
|
imgUrl: question.imgUrl, //图片地址
|
answer: question.content //题目答案
|
})
|
}
|
}
|
}
|
return answerSubmit
|
},
|
/*
|
* 过程中的提交
|
*/
|
submitSubAnswer: function() {
|
console.log('submitSubAnswer...')
|
let _this = this
|
//this.answer.answerItems[_this.order].endTime = this.formatDate(new Date(), 'yyyy-MM-dd hh:mm:ss')
|
// 提交部分
|
let answerSubmit = _this.getSubmitAnswerValue(_this.partOrder)
|
examPaperAnswerApi.answerSubmit(answerSubmit, _this.memberToken).then(re => {
|
if (re.code === 1) {
|
//console.log('answerSubmit...', re)
|
}
|
_this.formLoading = false
|
}).catch(e => {
|
_this.reloadPage(e)
|
})
|
},
|
/**
|
* 最后环节的提交
|
* @param {Object} mess
|
*/
|
submitAnswer: function(mess) {
|
let _this = this
|
this.answer.answerItems[_this.order].endTime = this.formatDate(new Date(), 'yyyy-MM-dd hh:mm:ss')
|
// 提交之前提交最后一段
|
let answerSubmit = _this.getSubmitAnswerValue(_this.partOrder)
|
let loading = _this.$loading({
|
lock: false,
|
text: _this.$t('uploadInfo'),
|
spinner: 'el-icon-loading'
|
})
|
examPaperAnswerApi.answerSubmit(answerSubmit, _this.memberToken).then(re => {
|
loading.close()
|
if (re.code === 1) {
|
_this.$router.push({
|
path: '/exam/finish',
|
query: {
|
name: _this.form.name,
|
content: mess,
|
tokenId: _this.memberToken
|
}
|
})
|
} else {
|
_this.$message.error(re.message + '/exam/finish')
|
}
|
_this.formLoading = false
|
}).catch(e => {
|
_this.reloadPage(e)
|
loading.close()
|
})
|
},
|
showNextGuide: function(signalObject, nextQuestion) {
|
let _this = this
|
_this.guideDescirption = signalObject.signalDescription
|
if (_this.guideDescirption !== null && _this.guideDescirption !== undefined && _this
|
.guideDescirption !== '') {
|
_this.isShowGuide(true)
|
_this.preDisable = false
|
} else {
|
throw (signalObject.message)
|
}
|
if (Object.keys(_this.guideDescirption).length === 0) {
|
_this.isShowGuide(false)
|
_this.preDisable = false
|
}
|
_this.startDoDisable = false
|
if (!nextQuestion) {
|
return
|
}
|
_this.nextQuestionOrder()
|
},
|
isNull: function(obj) {
|
return obj === null || obj === undefined
|
},
|
isShowGuide(flag) {
|
let _this = this
|
_this.guide = flag
|
// _this.isCallTain = flag ? 'callTain' : ''
|
},
|
reloadPage(e) {
|
let _this = this
|
let mes = ''
|
if (e.message !== null && e.message !== undefined && e.message.indexOf('timeout') !== -1) {
|
mes = _this.$t('submitTimeout') + ',' + 'order:' + _this.order + ',' + e.message // 提交后台超时
|
} else {
|
mes = JSON.stringify(e) + ',' + 'order:' + _this.order + ',' + e.message
|
}
|
_this.$router.push({
|
path: '/exam/exception',
|
query: {
|
name: _this.form.name,
|
content: _this.$t('submitExceptionInfo')
|
}
|
})
|
_this.formLoading = false
|
_this.submitDisable = false
|
},
|
isForFinish(i) {
|
return false
|
//return i === this.answer.answerItems.length - 1 && (this.answer.answerItems[i].content !== null && this.answer.answerItems[i].content !== '')
|
},
|
isDiffPartOrder: function() {
|
let _this = this
|
return _this.form.titleItems[0].questionItems[_this.order].partOrder !== _this.form.titleItems[0]
|
.questionItems[_this.order - 1].partOrder
|
},
|
previewImg(refName) {
|
this.$refs[refName][0].showViewer = true
|
},
|
...mapMutations('user', ['setMemberTocken']),
|
...mapMutations('user', ['setLangType']),
|
...mapMutations('user', ['setLangFlag'])
|
},
|
computed: {
|
...mapState('enumItem', {
|
doCompletedTag: state => state.exam.question.answer.doCompletedTag
|
}),
|
...mapState('user', {
|
memberToken: state => state.memberToken
|
}),
|
...mapState('user', {
|
langType: state => state.langType
|
}),
|
...mapState('user', {
|
langFlag: state => state.langFlag
|
}),
|
...mapState('exam', {
|
doUrl: state => state.doUrl
|
})
|
}
|
}
|
</script>
|
|
<style lang="scss" scoped>
|
.app-item-contain {
|
margin-top: 45px;
|
}
|
|
.footer {
|
position: absolute;
|
position: fixed;
|
z-index: 1000;
|
bottom: 0px;
|
}
|
|
.mul-inlinediv-box {
|
overflow: auto;
|
display: block;
|
-webkit-box-flex: 1;
|
margin-left: 10px;
|
}
|
|
.mul-inlinediv {
|
overflow-y: hidden;
|
overflow-x: auto;
|
white-space: nowrap;
|
//border: 1px solid gray;
|
padding: 2px 0;
|
width: fit-content;
|
}
|
|
.mul-inlinediv div div {
|
display: inline-table;
|
vertical-align: top;
|
width: 80px;
|
height: 80px;
|
min-width: 80px;
|
min-height: 80px;
|
margin: 0px;
|
}
|
|
.mul-inlinediv-row {
|
min-height: 100px;
|
//margin: 0 10px;
|
}
|
|
.mul-inlinediv-lineheight {
|
line-height: 106px;
|
//margin: 3px 0 4px 0;
|
//margin: 2px 0;
|
}
|
|
.mul-inlinediv-item {
|
display: flex;
|
display: inline-block;
|
border: 1px solid gray;
|
width: 100px;
|
height: 100px;
|
padding: 10px;
|
|
.tools-button {
|
width: 20px;
|
height: 20px;
|
cursor: pointer;
|
}
|
}
|
|
.inlinediv {
|
overflow-y: hidden;
|
overflow-x: auto;
|
white-space: nowrap;
|
min-height: 180px;
|
padding: 10px 0px;
|
//display: flex;
|
}
|
|
.inlinediv div {
|
//display: inline-table;
|
//vertical-align: top;
|
//width: 360px;
|
// margin: auto 2px;
|
}
|
|
.pic-tmparea-div {
|
overflow-y: hidden;
|
overflow-x: auto;
|
white-space: nowrap;
|
min-height: 180px;
|
padding: 10px 0px;
|
//display: flex;
|
}
|
|
.mullinediv {
|
display: contents;
|
}
|
|
.mullinediv-item {
|
display: flex;
|
display: inline-block;
|
width: 360px;
|
margin: 5px 20px 20px 5px;
|
padding: 30px 30px 10px 30px;
|
box-shadow: 1px 1px 1px grey, 0 0 5px grey, 0 0 10px grey;
|
|
.tools-button {
|
width: 20px;
|
height: 20px;
|
cursor: pointer;
|
}
|
}
|
|
.mullinediv-item2 {
|
display: inline-block;
|
width: 180px;
|
height: 180px;
|
// margin: 5px 4px;
|
padding: 10px;
|
box-shadow: 1px 1px 1px grey, 0 0 5px grey, 0 0 10px grey;
|
|
div {
|
height: 160px;
|
}
|
}
|
|
img:hover {
|
// transform: scale(2);
|
// -ms-transform: scale(2);
|
// -webkit-transform: scale(2);
|
// -o-transform: scale(2);
|
// -moz-transform: scale(2);
|
// transition-duration: 0.5s;
|
}
|
|
.container {
|
padding: 32px 20px;
|
|
.configuration {
|
width: 600px;
|
}
|
}
|
|
.wrapper {
|
display: flex;
|
justify-content: center;
|
width: 100%;
|
}
|
|
.mul-inlinediv-down {
|
min-width: 16px;
|
//line-height: 106px;
|
height: 106px;
|
background-size: 80% 100%;
|
background-image:url();
|
}
|
.mul-inlinediv-down:first-child {
|
margin-top: 44px;
|
height: 62px;
|
min-height: 62px;
|
background-size: 80% 100%;
|
background-image:url();
|
}
|
.mul-inlinediv-down:last-child {
|
background-size: 82% 60%;
|
background-repeat: no-repeat;
|
background-image:url();
|
}
|
</style>
|