[测评系统]--前端(用户答题页面)
src/views/exam/paper/values.vue
@@ -1,24 +1,44 @@
<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 class="text-line" 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 class="text-line" v-html="$t('values_title_description')"></div>
               <div class="text-line">{{$t('values_title_description_1')}}<img class="tools-button" src="@/assets/exam-paper/good.png" style="width: 15px;position: absolute;margin-top: 6px"/><span style="margin-left: 20px;">{{$t('values_title_description_1_2')}}</span></div>
               <div class="text-line">{{$t('values_title_description_2')}}<img class="tools-button" src="@/assets/exam-paper/nogood.png" style="width: 15px;position: absolute;margin-top: 6px"/><span style="margin-left: 20px;">{{$t('values_title_description_2_2')}}</span></div>
               <div class="text-line">{{$t('values_title_description_3')}}<img class="tools-button" src="@/assets/exam-paper/question.png" style="width: 15px;position: absolute;margin-top: 6px"/><span style="margin-left: 20px;">{{$t('values_title_description_3_2')}}</span></div>
               <div class="text-line">{{$t('values_title_description_4')}}<img class="tools-button" src="@/assets/exam-paper/scale.png" style="width: 15px;height: 15px;position: absolute;margin-top: 6px"/><span style="margin-left: 20px;">{{$t('values_title_description_4_2')}}</span></div>
               <div class="text-line">{{$t('values_title_description_5')}}</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')}}
               </el-button>
            </div>
            <div class="selectCount">
               {{ questionItems.filter(obj=>obj.content===null).length + $t('values_title_description_6') }}
            </div>
            <div class="mullinediv" v-if="step1Start">
               <div v-for="(question,index1) in questionItems" class="mullinediv-item"
                  v-if="isNull(question.content)">
                  <div style="display: flex; justify-content: flex-end;margin-right: -20px;">
                  <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>
@@ -36,30 +56,62 @@
            </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-header class="">
            <h1>{{$t('values_step_2_title')}}</h1>
         </el-header>
         <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>
                        <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 class="text-line" style="text-indent: 2em;">
                     <div v-if="step2SubStep == 1">
                        {{ $t('values_step_tips_for_1') }}
                     </div>
                     <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_0').replace('%N',getStep2StepItem(step2SubStep).quantity).replace('%C',getStep2StepItem(step2SubStep).stepName.toUpperCase())}}
                     </div>
                     <div v-else>
                        {{$t('values_step_tips_for_2').replace('%N',getStep2StepItem(step2SubStep).quantity).replace('%C',getStep2StepItem(step2SubStep).stepName.toLowerCase())}}
                     </div>
                     <div class="text-line">{{$t('values_step_tips_for_3')}}<img class="tools-button" src="@/assets/exam-paper/yes.png" style="width: 15px;position: absolute;margin-top: 6px;margin-left: 5px;"/><span style="margin-left: 22px;">{{$t('values_step_tips_for_3_1')}}</span></div>
                     <div class="text-line">{{$t('values_step_tips_for_4')}}<img class="tools-button" src="@/assets/exam-paper/no.png" style="width: 15px;position: absolute;margin-top: 6px;margin-left: 5px;"/><span style="margin-left: 22px;">{{$t('values_step_tips_for_4_1')}}</span></div>
                     <div class="text-line">{{$t('values_step_tips_for_5')}}<img class="tools-button" src="@/assets/exam-paper/scale.png" style="width: 15px;position: absolute;margin-top: 6px;margin-left: 5px;"/><span style="margin-left: 22px;">{{$t('values_step_tips_for_5_1')}}</span></div>
                     <div style="color: red;">
                        {{$t('values_step_tips').replace('%N',getStep2StepItem(step2SubStep).quantity)}}
                     </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>
@@ -74,8 +126,7 @@
                  <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)">
@@ -86,7 +137,151 @@
                     </div>
                  </div>
               </div>
               <el-divider content-position="left">{{$t('values_select_tips')}}</el-divider>
               <!-- 选择相似的图片 -->
               <div v-if="step2SubStep % 2 >= 1">
                  <!-- 与我相似 -->
                  <el-divider content-position="left">{{$t('values_select_tips_like')}}</el-divider>
                  <div style="height: auto;overflow: auto;">
                     <div class="mullinediv" style="" v-if="questionItems && questionItems.filter(obj=>Number(obj.content)===0).length>0">
                        <div v-for="(question,index3) in questionItems.filter(obj=>Number(obj.content)===0)" 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="noSelect" style="" v-if="questionItems.filter(obj=>Number(obj.content)===0 && obj.subjectId===null).length==0">
                        {{$t('values_no_select')}}
                     </div>
                  </div>
                  <!-- 不确定 -->
                  <el-divider content-position="left">{{$t('values_select_tips_neutral')}}</el-divider>
                  <div style="height: auto;overflow: auto;">
                     <div class="mullinediv" style="" v-if="questionItems && questionItems.filter(obj=>Number(obj.content)===1).length>0">
                        <div v-for="(question,index3) in questionItems.filter(obj=>Number(obj.content)===1)" 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="noSelect" style="" v-if="questionItems.filter(obj=>Number(obj.content)===1 && obj.subjectId===null).length==0">
                        {{$t('values_no_select')}}
                     </div>
                  </div>
                  <!-- 与我不相似 -->
                  <el-divider content-position="left">{{$t('values_select_tips_unlike')}}</el-divider>
                  <div style="height: auto;overflow: auto;">
                     <div class="mullinediv" style="" v-if="questionItems && questionItems.filter(obj=>obj.content===2).length>0">
                        <div v-for="(question,index3) in questionItems.filter(obj=>obj.content===2)" 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 class="noSelect" style="" v-if="questionItems.filter(obj=>Number(obj.content)===2 && obj.subjectId===null).length==0">
                        {{$t('values_no_select')}}
                     </div>
                  </div>
               </div>
               <!-- 选择不相似的图片 -->
               <div v-if="step2SubStep % 2 == 0">
                  <!-- 与我不相似 -->
                  <el-divider content-position="left">{{$t('values_select_tips_unlike')}}</el-divider>
                  <div style="height: auto;overflow: auto;">
                     <div class="mullinediv" style="" v-if="questionItems && questionItems.filter(obj=>Number(obj.content)===2).length>0">
                        <div v-for="(question,index3) in questionItems.filter(obj=>Number(obj.content)===2)" 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="noSelect" style="" v-if="questionItems.filter(obj=>Number(obj.content)===2 && obj.subjectId===null).length==0">
                        {{$t('values_no_select')}}
                     </div>
                  </div>
                  <!-- 不确定 -->
                  <el-divider content-position="left">{{$t('values_select_tips_neutral')}}</el-divider>
                  <div style="height: auto;overflow: auto;">
                     <div class="mullinediv" style="" v-if="questionItems && questionItems.filter(obj=>Number(obj.content)===1).length>0">
                        <div v-for="(question,index3) in questionItems.filter(obj=>Number(obj.content)===1)" 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="noSelect" style="" v-if="questionItems.filter(obj=>Number(obj.content)===1 && obj.subjectId===null).length==0">
                        {{$t('values_no_select')}}
                     </div>
                  </div>
                  <!-- 与我相似 -->
                  <el-divider content-position="left">{{$t('values_select_tips_like')}}</el-divider>
                  <div style="height: auto;overflow: auto;">
                     <div class="mullinediv" style="" v-if="questionItems && questionItems.filter(obj=>Number(obj.content)===0).length>0">
                        <div v-for="(question,index3) in questionItems.filter(obj=>Number(obj.content)===0)" 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="noSelect" style="" v-if="questionItems.filter(obj=>Number(obj.content)===0 && obj.subjectId===null).length==0">
                        {{$t('values_no_select')}}
                     </div>
                  </div>
               </div>
               <!-- <el-divider content-position="left">{{$t('values_select_tips')}}</el-divider>
               <div style="height: auto;overflow: auto;">
                  <div class="mullinediv" style="" v-if="questionItems && questionItems.length>0">
                     <div v-for="(question,index3) in questionItems" class="mullinediv-item"
@@ -105,55 +300,86 @@
                  <div class="mullinediv" style="" v-if="sumStep2UnSelectedNum()<=0">
                     {{$t('values_no_select')}}
                  </div>
               </div>
               </div> -->
            </div>
         </el-main>
      </el-container>
      <el-container class="app-item-contain step3" v-if="step === 'step3'">
         <el-main class="">
            <div style="position: fixed;z-index: 999; width:90%; top: 56px;">
               <div style="display: flex;justify-content: flex-end;">
                  <div style="padding: 0 10px;">{{$t('values_pic_tmpArea')}}</div>
            <div style="position: fixed;z-index: 999; width:90%; top: 50px;">
               <div style="display: flex;justify-content: flex-end;padding: 10px;background-color: #f5f7fa;">
                  <div class="text-line" style="padding-right: 20px;width:50%;">
                     <div v-html="$t('values_pic_tmpArea_desc')">
                     </div>
                     <el-button type="primary" round style="height: fit-content;margin-top:5px"
                        @click="step3_commit" :disabled="submitDisable">
                        {{$t('commit')}}
                     </el-button>
                  </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 type="primary" round style="height: fit-content;margin: 0 10px;"
                     @click="step3_commit" :disabled="submitDisable">
                     {{$t('commit')}}
                  </el-button>
                  </el-button> -->
               </div>
            </div>
            <div style="display:flex;margin-top: 160px;">
               <div style="display: inline-block;min-width: 150px;text-align: right;">
            <div style="display:flex;margin-top: 200px;">
               <div style="display: inline-block;min-width: 160px;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}}
                     <span v-if="item.stepName=='不确定是否相似'">
                        不确定是否与你相似 <span v-if="item.step<step2ScoreRanges.length">{{$t('values_step_names_unit')}}</span>
                     </span>
                     <span v-else>
                        {{$t('values_step_names_unit_pre')}}{{item.stepName}} <span v-if="item.step<step2ScoreRanges.length">{{$t('values_step_names_unit')}}</span>
                     </span>
                  </div>
               </div>
               <div style="display: inline-block;width: 20px;margin-top: 4px;">
                  <div class="mul-inlinediv-row mul-inlinediv-lineheight mul-inlinediv-down"
                     v-for="(item,index) in step2ScoreRanges">
                  </div>
               </div>
               <!--
               <div style="display: inline-block;min-width: 20px;text-align: right;">
                  <div class="mul-inlinediv-row mul-inlinediv-lineheight"
                     v-for="(item,index) in step2ScoreRanges">
                     {{$t('values_step_names_unit')}}
                  </div>
               </div>
               -->
               <div class="mul-inlinediv-box">
                  <div class="mul-inlinediv" v-for="item in step2ScoreRanges">
                     <div class="mul-inlinediv-row">
                        <draggable animation="300" :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>
@@ -185,6 +411,7 @@
   import examPaperAnswerApi from '@/api/examPaperAnswer'
   import demographyApi from '@/api/demography'
   import draggable from 'vuedraggable'
   import seedrandom from 'seedrandom'
   export default {
      name: 'values',
@@ -193,7 +420,7 @@
      },
      data() {
         return {
            step: 'step1',
            step: 'step0',
            step1Start: false,
            step1SelectedNum: 0,
            step2ScoreRanges: [
@@ -212,6 +439,7 @@
               "completed": false,
               "questionReports": null,
               "step": 0,
               "stepName":'',
               "selected": 0
            }],
            step2SubStep: 1,
@@ -220,210 +448,7 @@
               "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,
@@ -459,7 +484,9 @@
         }
      },
      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.......................")
@@ -475,6 +502,10 @@
            _this.titleItems.push(_this.form.titleItems[0])
            _this.questionItem = _this.form.titleItems[0].questionItems[0]
            _this.questionItems = _this.form.titleItems[0].questionItems
            // 使用token生成随机数排序数组
            _this.tokenSort(_this.questionItems)
            _this.partOrder = _this.questionItem.partOrder
            _this.itemOrder = _this.form.titleItems[0].questionItems[0].itemOrder
            _this.itemSize = _this.form.titleItems[0].questionItems.length
@@ -485,12 +516,14 @@
            _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 => {
@@ -503,6 +536,10 @@
                     _this.itemSize = _this.form.titleItems[0].questionItems.length
                     _this.questionItem = _this.form.titleItems[0].questionItems[_this.order]
                     _this.questionItems = _this.form.titleItems[0].questionItems
                     // 使用token生成随机数排序数组
                     _this.tokenSort(_this.questionItems)
                     _this.partOrder = _this.questionItem.partOrder
                     _this.initAnswer()
                     _this.formLoading = false
@@ -565,32 +602,49 @@
               }
            ).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: {
         // 根据token生成随机数并根据随机数排序questionItems
         tokenSort(array) {
            // 使用token创建随机数生成器
            let rng = seedrandom(this.memberToken)
            if (array) {
               array.sort((a,b)=>{
                  return rng() - 0.5
               })
            }
            console.log("list:", this.questionItems)
         },
         step0_next(){
            this.step = "step1"
         },
         step1_start() {
            this.step = "step1"
            this.step1Start = true
            this.questionItems.sort(function(i2, i1) {
               return (i2.id - i1.id)
            })
            // 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.step = "step2"
               this.sortQuestions()
               this.caculateScoreRangeSelectedById(this.getStep2StepItem(this.step2SubStep).itemOrder)
               this.step1_next()
            }
         },
         step1_next() {
@@ -600,9 +654,26 @@
               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.step2_0_next()
         },
         step2_0_next(){
            let _this = this
            _this.step = "step2"
            _this.sortQuestions()
            _this.caculateScoreRangeSelectedById(this.getStep2StepItem(this.step2SubStep).itemOrder)
         },
         step2_pre() {
            if (this.step2SubStep > 1) {
@@ -612,6 +683,7 @@
         step2_next() {
            let _this = this
            let stepItem = this.getStep2StepItem(this.step2SubStep)
            console.log("questionItems.filter(obj=>Number(obj.content)===0)", this.questionItems.filter(obj=>Number(obj.content)===0))
            if (stepItem.selected == stepItem.quantity || this.sumStep2UnSelectedNum() == 0) {
               _this.answer.verifyStatus = 2
               _this.submitSubAnswer()
@@ -642,6 +714,11 @@
            this.caculateScoreRangeSelectedById(sid, -1)
         },
         step2Add(qid, sid) {
            let stepItem = this.getStep2StepItem(this.step2SubStep)
            if (stepItem.selected == stepItem.quantity || this.sumStep2UnSelectedNum() == 0) {
               this.$message.error(this.$t('values_nextStepTips_del_unnecessary'))
               return;
            }
            //console.log("step2Add....",value,qid,sid)
            this.resetQuestionItemsSubjectIdById(qid, sid) //借用subjectId,存储
            this.caculateScoreRangeSelectedById(sid, 1)
@@ -692,27 +769,65 @@
            }
            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() {
@@ -787,9 +902,9 @@
         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:有疑问
@@ -797,9 +912,9 @@
                     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
            }
@@ -840,8 +955,19 @@
         resetQuestionItemsSubjectIdById(id, value) {
            for (let item of this.questionItems) {
               if (item.id == id) {
                  item["subjectId"] = value
                  item['content'] = this.getLikeTypeByScoreRangeItemOrder(value)
                  // 如果为null,就是从选择中取消
                  if (value == null) {
                     item["subjectId"] = value
                     item['content'] = item['tempContent']
                  } else {
                     if (item['content'] != null && item['content'] != undefined) {
                        item['tempContent'] = item['content']
                     }
                     item["subjectId"] = value
                     item['content'] = this.getLikeTypeByScoreRangeItemOrder(value)
                  }
                  console.log("更改content:", item)
               }
            }
            //console.log('resetQuestionItems...', id, value, this.questionItems)
@@ -852,6 +978,9 @@
               if (this.isNull(item[key])) {
                  item[key] = value
                  if ("subjectId" == key) {
                     if (item['content'] != null && item['content'] != undefined) {
                        item['tempContent'] = item['content']
                     }
                     item['content'] = this.getLikeTypeByScoreRangeItemOrder(value)
                  }
               }
@@ -922,6 +1051,10 @@
            }
            console.log('initTestData...e', this.questionItems)
         },
         /**
          * 设置step2ScoreRanges子项的步骤顺序及正负距离值
          * @param {Object} arr
          */
         initStep2ScoreRanges(arr) {
            //console.log('initStep2ScoreRanges...s', arr)
            let _this = this
@@ -967,8 +1100,36 @@
               //设置每项已选择的数量
               _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
@@ -982,6 +1143,15 @@
            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) {
@@ -1013,24 +1183,7 @@
               ++_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
@@ -1154,8 +1307,8 @@
                  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,
@@ -1173,7 +1326,7 @@
            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)
@@ -1197,36 +1350,35 @@
                        langType: question.langType, //答题语言
                        partOrder: question.partOrder, //分片
                        imgUrl: question.imgUrl, //图片地址
                        answer: question.content //题目答案
                        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')
            //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')
@@ -1293,8 +1445,6 @@
            } 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: {
@@ -1307,8 +1457,7 @@
         },
         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
@@ -1323,7 +1472,6 @@
         ...mapMutations('user', ['setLangFlag'])
      },
      computed: {
         ...mapGetters('enumItem', ['enumFormat']),
         ...mapState('enumItem', {
            doCompletedTag: state => state.exam.question.answer.doCompletedTag
         }),
@@ -1348,6 +1496,10 @@
      margin-top: 45px;
   }
   .text-line {
      line-height: 1.5em;
   }
   .footer {
      position: absolute;
      position: fixed;
@@ -1359,6 +1511,7 @@
      overflow: auto;
      display: block;
      -webkit-box-flex: 1;
      margin-left: 10px;
   }
   .mul-inlinediv {
@@ -1382,12 +1535,13 @@
   .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 {
@@ -1432,14 +1586,21 @@
   .mullinediv {
      display: contents;
      width:100%;
   }
   .noSelect {
      width: 100%;
      text-align: center;
      color: #9f9f9f;
      font-size: 14px;
   }
   .mullinediv-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 {
@@ -1484,4 +1645,37 @@
      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();
      }
   .selectCount {
      width: 100%;
      height: 40px;
      line-height: 40px;
      background: #3c8dbc;
      border-radius: 5px;
      text-align: center;
      font-size: 18px;
      color: #fff;
      font-weight: bold;
      margin-bottom: 20px;
   }
</style>