From 3549b2fd37fe56a1c5cddd626ce53a5d720d4d0a Mon Sep 17 00:00:00 2001 From: linzhijie <1003392067@qq.com> Date: 星期三, 10 五月 2023 15:00:09 +0800 Subject: [PATCH] 职业兴趣bugfix --- src/views/exam/paper/values.vue | 2852 ++++++++++++++++++++++++++++------------------------------ 1 files changed, 1,371 insertions(+), 1,481 deletions(-) diff --git a/src/views/exam/paper/values.vue b/src/views/exam/paper/values.vue index d8da3b6..88b961c 100644 --- a/src/views/exam/paper/values.vue +++ b/src/views/exam/paper/values.vue @@ -1,1555 +1,1445 @@ <template> - <div> + <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> + <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" v-if="!step1Start">{{$t('start')}}</el-button> - <el-button style="margin-top: 12px;" @click="step1_next" v-if="(step1Start && itemSize>0)">{{$t('next')}}</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')}} + </el-button> </div> <div class="mullinediv" v-if="step1Start"> - <div v-for="question in questionItems" class="mullinediv-item" v-if="isNull(question.analyze)"> - <el-image :src="question.imgUrl" lazy :preview-src-list="[question.imgUrl]"></el-image> - <div style="display: flex; justify-content: space-between;padding: 5px 10px;margin-top: -5px;"> - <i class="el-icon-success" @click="likeMe(question.id)"></i> - <i class="el-icon-question" @click="iAmNotSure(question.id)"></i> - <i class="el-icon-error" @click="unLikeMe(question.id)"></i> - </div> + <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"> - <span class="tag-group__title" style="padding-right: 20px;">{{$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 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;"> - {{$t('values_step_tips1')}}{{(step2SubStep % 2 == 0)?$t('values_step_tips4'):''}}{{$t('values_step_tips2')}}{{getStep2StepItem(step2SubStep).quantity}}{{$t('values_step_tips3')}} + <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="display: flex;justify-content: flex-end;"> - <el-button style="" @click="step2_pre" v-if="step2SubStep>1">{{$t('pre')}}</el-button> - <el-button style="" @click="step2_next">{{$t('next')}}</el-button> + <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> + <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 in questionItems" class="mullinediv-item" v-if="getStep2StepItem(step2SubStep).itemOrder == question.subjectId"> - <el-image :src="question.imgUrl" lazy :preview-src-list="[question.imgUrl]"></el-image> - <div style="display: flex;justify-content: center;padding: 5px 10px;"><!--/*background-color: #c8c3c3;*/--> - <i class="el-icon-delete" @click="step2Delete(question.id,getStep2StepItem(step2SubStep).itemOrder)"></i> - <!-- <i class="el-icon-zoom-in"></i> --> + <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 in questionItems" class="mullinediv-item" v-if="isNull(question.subjectId)"> - <el-image :src="question.imgUrl" lazy :preview-src-list="[question.imgUrl]"></el-image> - <div style="display: flex; justify-content: center;padding: 5px 10px;margin-top: -5px;"> - <el-checkbox @change="checked=>step2Add(checked,question.id,getStep2StepItem(step2SubStep).itemOrder)">{{$t('values_select')}}</el-checkbox> - <!-- <i class="el-icon-check"></i> --> - <!-- <i class="el-icon-zoom-in"></i> --> + <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> - <div class="mullinediv" style="" v-if="sumUnSelectedNum()<=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="display:flex;"> - <div style="display: inline-block;min-width: 110px;text-align: right;"> - <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}} - </div> - </div> - <div class="mul-inlinediv-box"> + <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"> + {{item.stepName}} + </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"> + {{item.deviate}} + </div> + </div> + --> + <div class="mul-inlinediv-box"> + <div class="mul-inlinediv" v-for="item in step2ScoreRanges"> <div class="mul-inlinediv-row"> - <div v-for="question in questionItems" class="mullinediv-item" v-if="question.subjectId == item.itemOrder"> - <el-image :src="question.imgUrl" lazy :preview-src-list="[question.imgUrl]"></el-image> - <div style="display: flex;justify-content: center;padding: 5px 10px;"><!--/*background-color: #c8c3c3;*/--> - <el-checkbox v-model="question['checked']" @change="checked=>step3Change(checked,question)" :disabled="(step3ChangeSrc.subjectId != question.subjectId || step3ChangeSrc.id == question.id)?false:true"> - {{(step3ChangeSrc.id==null)?$t('values_select'):(question.id==step3ChangeSrc.id)?$t('values_select'):$t('values_select_exchange')}} - </el-checkbox> - </div> - </div> + <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> - <div style="display: flex;justify-content: center;"> - <el-button style="margin-top: 12px;" @click="step3_commit" :disabled="submitDisable">{{$t('commit')}}</el-button> - </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> + <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 { + 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', - data () { - return { - step:'step1', - 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, - "selected":0 - } - ], - step2SubStep:1, - step3ChangeSrc:{ - "id": null, - "subjectId": null, - }, - 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 - }, - 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 () { - console.log("created......",this.$route.query.formDo,typeof(this.$route.query.formDo)) - //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") { - _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 { - _this.formLoading = true - // 闃叉鍒锋柊鎴愪簡涓嶅悓鐨勮瑷� - demographyApi.queryDemographyParamInfo(_this.memberToken).then( - re => { - console.log('queryDemographyParamInfo...',re) - if (re.response[0].langType !== null || re.response[0].langType.trim() !== '') { - _this.setLangType(re.response[0].langType) - } - // 鍔犺浇棰樼洰 - examPaperApi.select(_this.memberToken, _this.langType).then(re => { - console.log('select...',re) - _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 => { - }) - } - }, - mounted () { - //console.log("mounted......") - }, - beforeDestroy () { - window.clearInterval(this.timer) - }, - methods: { - step1_start(){ - this.step = "step1" - this.step1Start = true - this.questionItems.sort(function(i2, i1){return (i2.id - i1.id)}) - //console.log('step1_start...',this.questionItems) - }, - step1_next(){ - this.step = "step2" - this.sortQuestions() - this.caculateScoreRangeSelectedById(this.getStep2StepItem(this.step2SubStep).itemOrder) + export default { + name: 'values', + components: { + draggable }, - 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.sumUnSelectedNum() == 0 ){ - _this.answer.verifyStatus = 2 - _this.submitSubAnswer() - - this.step2SubStep = this.step2SubStep + 1 - if(this.step2SubStep > this.step2ScoreRanges.length){ - this.step = "step3" - } - - 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.resetQuestionItemsValueById(qid,"subjectId",null)//鍊熺敤subjectId锛屽瓨鍌� - this.caculateScoreRangeSelectedById(sid,-1) - }, - step2Add(value,qid,sid){ - //console.log("step2Add....",value,qid,sid) - this.resetQuestionItemsValueById(qid,"subjectId",sid)//鍊熺敤subjectId锛屽瓨鍌� - this.caculateScoreRangeSelectedById(sid,1) - }, - step3Change(value,question){ - console.log('step3Change...',this.step3ChangeSrc) - 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.resetQuestionItemsValueById(this.step3ChangeSrc.id,"subjectId",question.subjectId)//鍊熺敤subjectId锛屽瓨鍌� - this.resetQuestionItemsValueById(question.id,"subjectId",this.step3ChangeSrc.subjectId)//鍊熺敤subjectId锛屽瓨鍌� - } - //娓呯悊 - this.step3ChangeSrc.id = null - this.step3ChangeSrc.subjectId = null - for (let item of this.questionItems) { - item['checked'] = false - } - } - }, - sumUnSelectedNum(){ - let count = 0 - for (let item of this.questionItems) { - if(this.isNull(item['subjectId'])){ - count = count + 1 - } - } - return count - }, - step3_commit(){ - let _this = this - 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){ - let step = 0 - for (let item of this.step2ScoreRanges) { - if(item.itemOrder === itemOrder){ - step = item['step'] - break - } + 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, + } - 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 + //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() } - } else {//濂囨暟姝ラ - if(step == this.step2ScoreRanges.length) { - //1-NotSure - return 1 + }, + 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 { - if(step % 2 == 0){ + //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(i2, i1){return (i2.analyze == 'Like')?-1:1}) - break - case 1://1:鏈夌枒闂� - this.questionItems.sort(function(i2, i1){return (i2.analyze == 'NotSure')?-1:1}) - break - case 2://2:鏈�涓嶅儚鎴� - this.questionItems.sort(function(i2, i1){return (i2.analyze == 'UnLike')?-1:1}) - break - } - }, - - likeMe(id){ - this.step1SelectedNum = this.step1SelectedNum + 1 - this.resetQuestionItemsValueById(id,"analyze","Like")//鍊熺敤analyze锛屽瓨鍌� - }, - iAmNotSure(id){ - this.step1SelectedNum = this.step1SelectedNum + 1 - this.resetQuestionItemsValueById(id,"analyze","NotSure") - }, - unLikeMe(id){ - this.step1SelectedNum = this.step1SelectedNum + 1 - this.resetQuestionItemsValueById(id,"analyze","UnLike") - }, - resetQuestionItemsValueById(id,key,value){ - for (let item of this.questionItems) { - if(item.id === id){ - item[key] = value - if("subjectId" == key){ + }, + 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) - }, - 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(){ - let _this = this - //for test - _this.step2ScoreRanges = [].concat([ - { - "itemOrder": 1, - "quantity": 1, - "score": 5, - "completed": false, - "questionReports": null - }, - { - "itemOrder": 2, - "quantity": 2, - "score": 5, - "completed": false, - "questionReports": null - }, - { - "itemOrder": 3, - "quantity": 10, - "score": 5, - "completed": false, - "questionReports": null - }, - { - "itemOrder": 4, - "quantity": 2, - "score": 5, - "completed": false, - "questionReports": null - }, - { - "itemOrder": 5, - "quantity": 1, - "score": 5, - "completed": false, - "questionReports": null - }, - // { - // "itemOrder": 6, - // "quantity": 2, - // "score": 5, - // "completed": false, - // "questionReports": null - // }, - // { - // "itemOrder": 7, - // "quantity": 2, - // "score": 5, - // "completed": false, - // "questionReports": null - // }, - // { - // "itemOrder": 8, - // "quantity": 2, - // "score": 5, - // "completed": false, - // "questionReports": null - // }, - ]) - - _this.questionItems = _this.questionItems.concat([ - { - "id": 100, - "questionType": 1, - "subjectId": 3, - "title": "楹诲皢妗�", - "gradeLevel": null, - "items": [ - { - "prefix": "1", - "content": "0", - "score": "0" - } - ], - "analyze": "Like", - "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://47.114.179.216:8090/profile/images/2022/12/26/b698d623e7c9a55d9017ffa08477b121.jpg" - }, - { - "id": 101, - "questionType": 1, - "subjectId": 3, - "title": "楹诲皢妗�", - "gradeLevel": null, - "items": [ - { - "prefix": "1", - "content": "0", - "score": "0" - } - ], - "analyze": "UnLike", - "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://47.114.179.216:8090/profile/images/2022/12/26/b698d623e7c9a55d9017ffa08477b121.jpg" - }, - { - "id": 102, - "questionType": 1, - "subjectId": 3, - "title": "楹诲皢妗�", - "gradeLevel": null, - "items": [ - { - "prefix": "1", - "content": "0", - "score": "0" - } - ], - "analyze": "NotSure", - "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://47.114.179.216:8090/profile/images/2022/12/26/b698d623e7c9a55d9017ffa08477b121.jpg" - }, - { - "id": 103, - "questionType": 1, - "subjectId": 3, - "title": "楹诲皢妗�", - "gradeLevel": null, - "items": [ - { - "prefix": "1", - "content": "0", - "score": "0" - } - ], - "analyze": "Like", - "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://47.114.179.216:8090/profile/images/2022/12/26/b698d623e7c9a55d9017ffa08477b121.jpg" - }, - { - "id": 104, - "questionType": 1, - "subjectId": 3, - "title": "楹诲皢妗�", - "gradeLevel": null, - "items": [ - { - "prefix": "1", - "content": "0", - "score": "0" - } - ], - "analyze": "UnLike", - "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://47.114.179.216:8090/profile/images/2022/12/26/b698d623e7c9a55d9017ffa08477b121.jpg" - }, - { - "id": 105, - "questionType": 1, - "subjectId": 1, - "title": "楹诲皢妗�", - "gradeLevel": null, - "items": [ - { - "prefix": "1", - "content": "0", - "score": "0" - } - ], - "analyze": "NotSure", - "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://47.114.179.216:8090/profile/images/2022/12/26/b698d623e7c9a55d9017ffa08477b121.jpg" - }, - { - "id": 106, - "questionType": 1, - "subjectId": 1, - "title": "楹诲皢妗�", - "gradeLevel": null, - "items": [ - { - "prefix": "1", - "content": "0", - "score": "0" - } - ], - "analyze": "Like", - "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://47.114.179.216:8090/profile/images/2022/12/26/b698d623e7c9a55d9017ffa08477b121.jpg" - }, - { - "id": 107, - "questionType": 1, - "subjectId": 2, - "title": "楹诲皢妗�", - "gradeLevel": null, - "items": [ - { - "prefix": "1", - "content": "0", - "score": "0" - } - ], - "analyze": "NotSure", - "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://47.114.179.216:8090/profile/images/2022/12/26/b698d623e7c9a55d9017ffa08477b121.jpg" - }, - { - "id": 108, - "questionType": 1, - "subjectId": 2, - "title": "楹诲皢妗�", - "gradeLevel": null, - "items": [ - { - "prefix": "1", - "content": "0", - "score": "0" - } - ], - "analyze": "NotSure", - "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://47.114.179.216:8090/profile/images/2022/12/26/b698d623e7c9a55d9017ffa08477b121.jpg" - }, - ]) - }, - initStep2ScoreRanges(arr){ - let _this = this - _this.step2ScoreRanges = _this.step2ScoreRanges.concat(arr) - //this.initTestData() - 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鍋忕鏈�鍚巗tep鐨勬璐熻窛绂诲�硷紙濂囨暟step姝e亸绂伙紝鍋舵暟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...',this.step2ScoreRanges) - }, - getStep2StepTagType(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) - }, - 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 - 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) - }, - nextSubject: function () { - let _this = this - _this.isShowGuide(false) - let nowPartOrder = _this.partOrder - // 璁剧疆涓婁竴棰樼殑缁撴潫鏃堕棿 - this.answer.answerItems[_this.order].endTime = _this.formatDate(new Date(), 'yyyy-MM-dd hh:mm:ss') - // 寰幆娌℃湁绛旂殑棰樼洰,杩欓噷鍚屾椂鍐冲畾浜嗛棶绛旈鎵撳畬鍙互杩涘叆涓嬩竴棰� - for (let i = 0; i < _this.order; i++) { - if (!this.isContentNotEmpty(i)) { - // 杩斿洖涔嬪墠娌″仛鐨勯偅閬撻 - this.getEmptySubjct(i) - return - } - // 濡傛灉寰幆鍒版渶鍚庝竴棰樺氨鎻愪氦 - if (_this.isForFinish(i)) { - _this.submitForm() - return - } - } - - // 鍏ㄩ儴绛斿畬浜嗗氨鍙互鎻愪氦浜�,浣嗘槸濡傛灉鏄渶鍚庝竴棰樺氨鑷繁鎻愪氦 - for (let i = 0; i < _this.answer.answerItems.length; i++) { - if (!_this.isContentNotEmpty(i)) { - break - } - if (i === _this.answer.answerItems.length - 1 && _this.order !== _this.answer.answerItems.length - 1) { - _this.submitForm() - return - } - } - this.answer.answerItems[_this.order].readOnly = true - let answerSubmit = _this.getSubmitAnswerValue(nowPartOrder) - // 宸茬粡绛斿埌浜嗘渶鍚庝竴棰樹簡,涓嶇敤鑷姩璺冲埌涓嬩竴棰� - if (this.order + 1 > this.itemSize - 1) { - this.submitDisable = false - return - } - // 濡傛灉鏄渶鍚庝竴棰樺氨涓婇潰鎻愪氦浜嗭紝涓嶄細璧板埌杩欓噷 - let loading = null - if (this.isNextShowGuide(nowPartOrder)) { - this.catThaiSubmit(answerSubmit) - loading = _this.$loading({ - lock: false, - text: _this.$t('nextPartInfo'), - spinner: 'el-icon-loading' - }) - } - examPaperAnswerApi.answerSubmit(answerSubmit, _this.memberToken).then(re => { - if (_this.isNotEmpty(loading)) { - loading.close() - } - if (re.code !== 1) { - _this.$message.error(re.message) - throw (re.message) - } - - // 灞曠ず鎸囧璇� - if (this.isNextShowGuide(nowPartOrder)) { - // 灞曠ず鎸囧璇� - _this.showNextGuide(re.response.signalObject, true) - } else { - this.nextQuestionOrder(nowPartOrder) - } - }).catch(e => { - if (_this.isNotEmpty(loading)) { - loading.close() - } - _this.reloadPage(e) - }) - }, - 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.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){ - 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({ - questionOrder:question.questionOrder, //棰樼洰ID - 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 - }, - preSubject () { - let _this = this - _this.isShowGuide(false) - if (_this.order > 0) { - let num = --_this.order - _this.itemOrder = _this.form.titleItems[0].questionItems[num].itemOrder - _this.questionItem = _this.form.titleItems[0].questionItems[num] - _this.partOrder = _this.questionItem.partOrder - _this.preDisable = false - _this.nextDisable = true - _this.answer.answerItems[_this.order].readOnly = false - } - }, - submitSubAnswer: function () { - 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) { - console.log('answerSubmit...',re) - } - _this.formLoading = false - }).catch(e => { - _this.reloadPage(e) - loading.close() - }) - }, - 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') + '<br>' + mes } }) - _this.$router.push({ path: '/exam/exception', query: { name: _this.form.name, content: _this.$t('submitExceptionInfo') } }) - _this.formLoading = false - _this.submitDisable = false - }, - isForFinish (i) { - 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 - }, - ...mapMutations('user', ['setMemberTocken']), - ...mapMutations('user', ['setLangType']), - ...mapMutations('user', ['setLangFlag']) - }, - computed: { - ...mapGetters('enumItem', ['enumFormat']), - ...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 }) - } -} + //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瀛愰」鐨勬楠ら『搴忓強姝h礋璺濈鍊� + * @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鍋忕鏈�鍚巗tep鐨勬璐熻窛绂诲�硷紙濂囨暟step姝e亸绂伙紝鍋舵暟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鐨凷tepName涓哄浐瀹氬�� + 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; + .app-item-contain { + margin-top: 45px; } - .align-center { - text-align: center; - } - .exam-question-item { - padding: 10px; - font-size: large; + .footer { + position: absolute; + position: fixed; + z-index: 1000; + bottom: 0px; + } - .el-form-item__label { - font-size: large !important; - } - } - - .question-title-padding { - padding-left: 25px; - padding-right: 25px; - } - .footer { - position: absolute; - position: fixed; - z-index: 1000; - bottom: 0px; - } -</style> -<style lang="scss" scpoed> - .mul-inlinediv-box{ + .mul-inlinediv-box { overflow: auto; display: block; -webkit-box-flex: 1; - } - .mul-inlinediv { - overflow-y: hidden; - overflow-x: auto; - white-space: nowrap; - border: 1px solid gray; - padding: 10px 0; - width: fit-content; - } - .mul-inlinediv div div{ - display: inline-table; - vertical-align: top; - width: 180px; - margin: 0 2px; - } - .mul-inlinediv-row{ - min-height: 210px; - margin: 0 10px; - } - .mul-inlinediv-lineheight{ - line-height: 210px; - padding: 10px 0; - } - .inlinediv { - overflow-y: hidden; - overflow-x: auto; - white-space: nowrap; - min-height: 180px; - display: flex; - } - .inlinediv div{ - display: inline-table; - vertical-align: top; - width: 100px; - margin: auto 2px; - } - .mullinediv{ - display: contents; - } - .mullinediv-item{ - display: flex;display: - inline-block; - width: 180px; - margin: 5px 4px; - } - .mullinediv-item:hover { - } - 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; - } + margin-left: 10px; } - .bg-purple { - background: #d3dce6; - } + .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> -- Gitblit v1.9.1