| | |
| | | <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="" style="padding-top: 3%;"> |
| | | <el-main class=""> |
| | | <div> |
| | | {{$t('values_title_description')}} |
| | | <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 @click="step1_start" type="primary" round v-if="!step1Start">{{$t('start')}}</el-button> |
| | | <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')}} |
| | |
| | | <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;"> |
| | | <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> |
| | |
| | | </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"> |
| | | <div class="tag-group" style="display: flex;"> |
| | | <span class="tag-group__title" |
| | | style="padding-right: 20px;font-size: 26px;">{{$t('values_cur_step')}}({{step2SubStep}} / |
| | | style="padding-right: 10px;font-size: 26px;margin: auto 0px;">{{$t('values_cur_step')}}({{step2SubStep}} / |
| | | {{step2ScoreRanges.length}})</span> |
| | | <el-tag v-for="item in step2ScoreRanges" :key="item.itemOrder" |
| | | :type="getStep2StepTagType(item.step)" style="margin: 0 2px;font-size: 26px;" size="large" |
| | | effect="light"> |
| | | {{ item.quantity }} |
| | | </el-tag> |
| | | <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;"> |
| | | <span |
| | | <div |
| | | v-if="(step2SubStep == step2ScoreRanges.length) && (step2ScoreRanges.length % 2 == 1)"> |
| | | {{$t('values_step_tips_for_3').replace('%N',getStep2StepItem(step2SubStep).quantity)}} |
| | | </span> |
| | | <span v-else> |
| | | {{(step2SubStep % 2 == 1)?$t('values_step_tips_for_1').replace('%N',getStep2StepItem(step2SubStep).quantity):$t('values_step_tips_for_2').replace('%N',getStep2StepItem(step2SubStep).quantity)}} |
| | | </span> |
| | | {{$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="display: flex;justify-content: flex-end;"> |
| | | <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 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" lazy |
| | | :preview-src-list="[question.imgUrl]"></el-image> |
| | | <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-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;"> |
| | | <div style="padding: 0 10px;">{{$t('values_pic_tmpArea')}}</div> |
| | | <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="background-color: #f5f7fa;border: 1px solid gray;padding: 10px;width: 50%;" |
| | | :list="step3EWEIArea[0]" group="article" @start="step3TmpAreaStart" |
| | | @end="step3MoveFromTmpAreaEnd"> |
| | | 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" |
| | | :qId="q.id"> |
| | | <el-image :src="q.imgUrl" lazy :preview-src-list="[q.imgUrl]" fit="fill"></el-image> |
| | | :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;" |
| | |
| | | </el-button> |
| | | </div> |
| | | </div> |
| | | <div style="display:flex;margin-top: 160px;"> |
| | | <div style="display: inline-block;min-width: 150px;text-align: right;"> |
| | | <div class="mul-inlinediv-row mul-inlinediv-lineheight" |
| | | <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"> |
| | | {{(index == 0)?$t('values_mostLikeMe'):''}}{{(index == (step2ScoreRanges.length-1))?$t('values_mostUnLikeMe'):''}} |
| | | {{item.deviate}} |
| | | {{$t('values_step_names_unit_pre')}}{{item.stepName}} <span v-if="item.step<step2ScoreRanges.length">{{$t('values_step_names_unit')}}</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" :class="item.itemOrder" |
| | | <draggable animation="300" classa="pic-eweiarea-div" :class="'pic-eweiarea-div-'+item.itemOrder" |
| | | :list="step3EWEIArea[item.itemOrder]" |
| | | :options="{group:{name:'article'}}" filter=".undraggable" |
| | | @end="step3MoveToTmpAreaEnd" :scoreRangeId="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" :qId="q.id"> |
| | | <el-image :src="q.imgUrl" lazy :preview-src-list="[q.imgUrl]" v-if="q.imgUrl"> |
| | | 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> |
| | |
| | | }, |
| | | data() { |
| | | return { |
| | | step: 'step1', |
| | | step: 'step0', |
| | | step1Start: false, |
| | | step1SelectedNum: 0, |
| | | step2ScoreRanges: [ |
| | |
| | | "completed": false, |
| | | "questionReports": null, |
| | | "step": 0, |
| | | "stepName":'', |
| | | "selected": 0 |
| | | }], |
| | | step2SubStep: 1, |
| | |
| | | "subjectId": null, |
| | | }, |
| | | step3EWEIArea: [1], |
| | | form: { |
| | | "id": 92, |
| | | "level": 1, |
| | | "subjectId": null, |
| | | "paperType": 1, |
| | | "name": "VAQ", |
| | | "suggestTime": null, |
| | | "limitDateTime": null, |
| | | "titleItems": [{ |
| | | "guide": "", |
| | | "name": "", |
| | | "description": "", |
| | | "permanentId": null, |
| | | "questionOrder": 0, |
| | | "questionReport": null, |
| | | "questionItems": [{ |
| | | "id": 786, |
| | | "questionType": 1, |
| | | "subjectId": null, |
| | | "title": "麻将桌", |
| | | "gradeLevel": null, |
| | | "items": [{ |
| | | "prefix": "1", |
| | | "content": "0", |
| | | "score": "0" |
| | | }], |
| | | "analyze": null, |
| | | "correctArray": null, |
| | | "correct": null, |
| | | "score": "0", |
| | | "difficult": null, |
| | | "itemOrder": 1, |
| | | "questionOrder": 0, |
| | | "permanentId": "VAQ00001", |
| | | "questionReport": null, |
| | | "startTime": null, |
| | | "endTime": null, |
| | | "partOrder": 1, |
| | | "parentQuestionId": null, |
| | | "template": null, |
| | | "questionNumber": null, |
| | | "content": null, |
| | | "imgUrl": "http://127.0.0.1:8090/profile/images/2022/12/26/b698d623e7c9a55d9017ffa08477b121.jpg" |
| | | }, |
| | | { |
| | | "id": 787, |
| | | "questionType": 1, |
| | | "subjectId": null, |
| | | "title": "麻将桌2", |
| | | "gradeLevel": null, |
| | | "items": [{ |
| | | "prefix": "1", |
| | | "content": "0", |
| | | "score": "0" |
| | | }], |
| | | "analyze": null, |
| | | "correctArray": null, |
| | | "correct": null, |
| | | "score": "0", |
| | | "difficult": null, |
| | | "itemOrder": 2, |
| | | "questionOrder": 1, |
| | | "permanentId": "VAQ00002", |
| | | "questionReport": null, |
| | | "startTime": null, |
| | | "endTime": null, |
| | | "partOrder": 2, |
| | | "parentQuestionId": null, |
| | | "template": null, |
| | | "questionNumber": null, |
| | | "content": null, |
| | | "imgUrl": "http://127.0.0.1:8090/profile/images/2022/12/26/123f79ad0cc38507368c22b8a7ec9b09.jpg" |
| | | }, |
| | | { |
| | | "id": 788, |
| | | "questionType": 1, |
| | | "subjectId": null, |
| | | "title": "测试1", |
| | | "gradeLevel": null, |
| | | "items": [{ |
| | | "prefix": "1", |
| | | "content": "0", |
| | | "score": "0" |
| | | }], |
| | | "analyze": null, |
| | | "correctArray": null, |
| | | "correct": null, |
| | | "score": "0", |
| | | "difficult": null, |
| | | "itemOrder": 3, |
| | | "questionOrder": 2, |
| | | "permanentId": "VAQ00003", |
| | | "questionReport": null, |
| | | "startTime": null, |
| | | "endTime": null, |
| | | "partOrder": 3, |
| | | "parentQuestionId": null, |
| | | "template": null, |
| | | "questionNumber": null, |
| | | "content": null, |
| | | "imgUrl": "http://127.0.0.1:8090/profile/images/2023/01/09/6b80baab47a9eba6ceeec5a723397109.jpg" |
| | | }, |
| | | { |
| | | "id": 789, |
| | | "questionType": 1, |
| | | "subjectId": null, |
| | | "title": "测试2", |
| | | "gradeLevel": null, |
| | | "items": [{ |
| | | "prefix": "1", |
| | | "content": "0", |
| | | "score": "0" |
| | | }], |
| | | "analyze": null, |
| | | "correctArray": null, |
| | | "correct": null, |
| | | "score": "0", |
| | | "difficult": null, |
| | | "itemOrder": 4, |
| | | "questionOrder": 3, |
| | | "permanentId": "VAQ00004", |
| | | "questionReport": null, |
| | | "startTime": null, |
| | | "endTime": null, |
| | | "partOrder": 4, |
| | | "parentQuestionId": null, |
| | | "template": null, |
| | | "questionNumber": null, |
| | | "content": null, |
| | | "imgUrl": "http://127.0.0.1:8090/profile/images/2023/01/09/3f8e18280f1d47362c69b18e80ddf1a3.jpg" |
| | | }, |
| | | { |
| | | "id": 790, |
| | | "questionType": 1, |
| | | "subjectId": null, |
| | | "title": "测试3", |
| | | "gradeLevel": null, |
| | | "items": [{ |
| | | "prefix": "1", |
| | | "content": "0", |
| | | "score": "0" |
| | | }], |
| | | "analyze": null, |
| | | "correctArray": null, |
| | | "correct": null, |
| | | "score": "0", |
| | | "difficult": null, |
| | | "itemOrder": 5, |
| | | "questionOrder": 4, |
| | | "permanentId": "VAQ00005", |
| | | "questionReport": null, |
| | | "startTime": null, |
| | | "endTime": null, |
| | | "partOrder": 5, |
| | | "parentQuestionId": null, |
| | | "template": null, |
| | | "questionNumber": null, |
| | | "content": null, |
| | | "imgUrl": "http://127.0.0.1:8090/profile/images/2023/01/09/447616cb14745241f0ac700b56d0770b.jpg" |
| | | } |
| | | ], |
| | | "startTime": null, |
| | | "endTime": null, |
| | | "parts": [], |
| | | "scoreRanges": [{ |
| | | "itemOrder": 1, |
| | | "quantity": 2, |
| | | "score": 5, |
| | | "completed": false, |
| | | "questionReports": null |
| | | }, |
| | | { |
| | | "itemOrder": 2, |
| | | "quantity": 1, |
| | | "score": 10, |
| | | "completed": false, |
| | | "questionReports": null |
| | | }, |
| | | { |
| | | "itemOrder": 3, |
| | | "quantity": 2, |
| | | "score": 5, |
| | | "completed": false, |
| | | "questionReports": null |
| | | } |
| | | ] |
| | | }], |
| | | "score": null, |
| | | "guide": "VAQ", |
| | | "questionOrder": [ |
| | | 0, |
| | | 1, |
| | | 2, |
| | | 3, |
| | | 4 |
| | | ], |
| | | "parts": [], |
| | | "questionTemplateId": "values", |
| | | "reportTemplateId": "61", |
| | | "memberName": "test4", |
| | | "optionOrder": null, |
| | | "timeOut": null, |
| | | "jobDescriptionFile": null |
| | | }, |
| | | form:{}, |
| | | formLoading: false, |
| | | answer: { |
| | | questionId: null, |
| | |
| | | |
| | | } |
| | | }, |
| | | created: function() { |
| | | //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.......................") |
| | |
| | | _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 => { |
| | |
| | | } |
| | | ).catch(e => {}) |
| | | } |
| | | }, |
| | | mounted() { |
| | | //console.log("mounted......") |
| | | |
| | | 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 |
| | |
| | | //回显,没有可选的时候,进入下一步 |
| | | let c = this.sumStep1UnSelectedNum() |
| | | if (c <= 0 && this.itemSize > 0) { |
| | | this.step = "step2" |
| | | this.sortQuestions() |
| | | this.caculateScoreRangeSelectedById(this.getStep2StepItem(this.step2SubStep).itemOrder) |
| | | this.step1_next() |
| | | } |
| | | }, |
| | | step1_next() { |
| | |
| | | this.$message.error(_this.$t('values_nextStepTips_choices_all')) |
| | | return |
| | | } |
| | | this.step = "step2" |
| | | this.sortQuestions() |
| | | this.caculateScoreRangeSelectedById(this.getStep2StepItem(this.step2SubStep).itemOrder) |
| | | /* |
| | | 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) { |
| | |
| | | } |
| | | console.log('buildStep3EWEIArea', this.step3EWEIArea) |
| | | }, |
| | | |
| | | step3TmpAreaStart(ev) { |
| | | //console.log('step3TmpAreaStart', ev) |
| | | addStep3EWEIArea(index,question){ |
| | | //console.log('addStep3EWEIArea',index,question) |
| | | this.step3EWEIArea[index].push(question) |
| | | this.$set(this.step3EWEIArea, index, this.step3EWEIArea[index]) |
| | | }, |
| | | step3MoveFromTmpAreaEnd(ev) { |
| | | //console.log('step3MoveFromTmpAreaEnd s', ev, ev.to) |
| | | // let options,qId |
| | | // qId = ev.item.attributes.qId.value |
| | | // for(let p of ev.to){ |
| | | // if(this.isNotEmpty(p['options'])) { |
| | | // options = p['options'] |
| | | // break |
| | | // } |
| | | // } |
| | | // let scoreRangeId = options.scoreRangeId |
| | | 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 |
| | | }, |
| | | |
| | | step3MoveToTmpAreaEnd(ev) { |
| | | //console.log('step3MoveToTmpAreaEnd') |
| | | //let qId = ev.item.attributes.qId.value |
| | | //console.log('step3MoveToTmpAreaEnd end', this.step3EWEIArea) |
| | | 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() { |
| | |
| | | sortQuestions() { |
| | | let type = this.getLikeType(this.step2SubStep) |
| | | switch (type) { |
| | | case 0: //0:最像我 |
| | | this.questionItems.sort(function(i2, i1) { |
| | | return (i2.content == 0) ? -1 : 1 |
| | | case 0: //0:最像我 数字排序(数字和升序) |
| | | this.questionItems.sort(function(a, b) { |
| | | return a.content - b.content |
| | | }) |
| | | break |
| | | case 1: //1:有疑问 |
| | |
| | | return (i2.content == 1) ? -1 : 1 |
| | | }) |
| | | break |
| | | case 2: //2:最不像我 |
| | | this.questionItems.sort(function(i2, i1) { |
| | | return (i2.content == 2) ? -1 : 1 |
| | | case 2: //2:最不像我 数字排序(数字和降序) |
| | | this.questionItems.sort(function(a, b) { |
| | | return b.content - a.content |
| | | }) |
| | | break |
| | | } |
| | |
| | | } |
| | | console.log('initTestData...e', this.questionItems) |
| | | }, |
| | | /** |
| | | * 设置step2ScoreRanges子项的步骤顺序及正负距离值 |
| | | * @param {Object} arr |
| | | */ |
| | | initStep2ScoreRanges(arr) { |
| | | //console.log('initStep2ScoreRanges...s', arr) |
| | | let _this = this |
| | |
| | | //设置每项已选择的数量 |
| | | _this.step2ScoreRanges[i]['selected'] = 0 |
| | | } |
| | | console.log('initStep2ScoreRanges...e', this.step2ScoreRanges) |
| | | //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 |
| | |
| | | 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) { |
| | |
| | | ++_this.answer.doTime |
| | | }, 1000) |
| | | }, |
| | | questionCompleted(completed) { |
| | | return this.enumFormat(this.doCompletedTag, completed) |
| | | }, |
| | | goAnchor(selector) { |
| | | let _this = this |
| | | let num = parseInt(selector.substr(10)) - 1 |
| | | this.itemOrder = _this.form.titleItems[0].questionItems[num].itemOrder |
| | | this.questionItem = _this.form.titleItems[0].questionItems[num] |
| | | _this.order = num |
| | | setTimeout(function() { |
| | | _this.$el.querySelector(selector).scrollIntoView({ |
| | | behavior: 'instant', |
| | | block: 'center', |
| | | inline: 'nearest' |
| | | }) |
| | | }, 200) |
| | | _this.$refs['popovertag'].doClose() |
| | | }, |
| | | |
| | | initAnswer() { |
| | | this.answer.id = this.form.id |
| | | this.answer.questionOrder = this.form.questionOrder |
| | |
| | | answerItem.startTime = '' |
| | | } |
| | | answerItem.completed = true |
| | | answerItem.content = this.getContentByQuestionId(answerItem |
| | | .questionId) //this.getLikeTypeByScoreRangeItemOrder(answerItem.subjectId) |
| | | answerItem.content = this.getContentByQuestionId(answerItem.questionId) |
| | | //this.getLikeTypeByScoreRangeItemOrder(answerItem.subjectId) |
| | | answerItem.questionReport = { |
| | | questionOrder: answerItem.questionId, |
| | | questionTitle: answerItem.title, |
| | |
| | | answerSubmit.partOrder = nowPartOrder |
| | | answerSubmit.itemOrder = _this.itemOrder |
| | | //add scoreRanges |
| | | if (_this.step2SubStep >= _this.step2ScoreRanges.length) { |
| | | if (_this.step2SubStep >= _this.step2ScoreRanges.length || true) {//传递全部 |
| | | answerSubmit['scoreRanges'] = _this.form.titleItems[0].scoreRanges |
| | | } else { |
| | | let item = _this.getStep2StepItem(_this.step2SubStep) |
| | |
| | | } |
| | | 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') |
| | | //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) { |
| | | //console.log('answerSubmit...', re) |
| | | } |
| | | _this.formLoading = false |
| | | }).catch(e => { |
| | | _this.reloadPage(e) |
| | | loading.close() |
| | | }) |
| | | }, |
| | | /** |
| | | * 最后环节的提交 |
| | | * @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') |
| | |
| | | } 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') + '<br>' + mes } }) |
| | | _this.$router.push({ |
| | | path: '/exam/exception', |
| | | query: { |
| | |
| | | }, |
| | | isForFinish(i) { |
| | | return false |
| | | return i === this.answer.answerItems.length - 1 && (this.answer.answerItems[i].content !== null && this |
| | | .answer.answerItems[i].content !== '') |
| | | //return i === this.answer.answerItems.length - 1 && (this.answer.answerItems[i].content !== null && this.answer.answerItems[i].content !== '') |
| | | }, |
| | | isDiffPartOrder: function() { |
| | | let _this = this |
| | |
| | | ...mapMutations('user', ['setLangFlag']) |
| | | }, |
| | | computed: { |
| | | ...mapGetters('enumItem', ['enumFormat']), |
| | | ...mapState('enumItem', { |
| | | doCompletedTag: state => state.exam.question.answer.doCompletedTag |
| | | }), |
| | |
| | | overflow: auto; |
| | | display: block; |
| | | -webkit-box-flex: 1; |
| | | margin-left: 10px; |
| | | } |
| | | |
| | | .mul-inlinediv { |
| | |
| | | |
| | | .mul-inlinediv-row { |
| | | min-height: 100px; |
| | | margin: 0 10px; |
| | | //margin: 0 10px; |
| | | } |
| | | |
| | | .mul-inlinediv-lineheight { |
| | | line-height: 100px; |
| | | margin: 3px 0 4px 0; |
| | | line-height: 106px; |
| | | //margin: 3px 0 4px 0; |
| | | //margin: 2px 0; |
| | | } |
| | | |
| | | .mul-inlinediv-item { |
| | |
| | | display: flex; |
| | | display: inline-block; |
| | | width: 360px; |
| | | margin: 5px 4px; |
| | | padding: 10px 30px; |
| | | 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 { |
| | |
| | | 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> |