From dc9c1c7c486ee140f1cdc64d0aeafffdced612f4 Mon Sep 17 00:00:00 2001
From: zhijie <1003392067@qq.com>
Date: 星期一, 11 十二月 2023 23:21:07 +0800
Subject: [PATCH] 新增LAQ支持

---
 src/views/exam/paper/values.vue | 2857 ++++++++++++++++++++++++++++------------------------------
 1 files changed, 1,376 insertions(+), 1,481 deletions(-)

diff --git a/src/views/exam/paper/values.vue b/src/views/exam/paper/values.vue
index d8da3b6..11c2df3 100644
--- a/src/views/exam/paper/values.vue
+++ b/src/views/exam/paper/values.vue
@@ -1,1555 +1,1450 @@
 <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">
+							<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">
-							<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