From 8a27f5724e10e82cc5a30bf7051397da2e697e63 Mon Sep 17 00:00:00 2001
From: zhongshujie <2862698242@qq.com>
Date: 星期四, 19 十二月 2024 10:49:11 +0800
Subject: [PATCH] bug优化,答题卡初始化

---
 packageBookService/pages/psychologyAnswer/psychologyAnswer.js |  186 +++++++++++++++++++++++++++++++++++-----------
 1 files changed, 142 insertions(+), 44 deletions(-)

diff --git a/packageBookService/pages/psychologyAnswer/psychologyAnswer.js b/packageBookService/pages/psychologyAnswer/psychologyAnswer.js
index 1c612c6..5f5ffde 100644
--- a/packageBookService/pages/psychologyAnswer/psychologyAnswer.js
+++ b/packageBookService/pages/psychologyAnswer/psychologyAnswer.js
@@ -1,8 +1,5 @@
 // packageBookService/pages/psychologyAnswer/psychologyAnswer.js
 import {
-  getPublicImage
-} from "../../../assets/js/middleGround/tool";
-import {
   loginInfo
 } from '../../../assets/js/login';
 const app = getApp();
@@ -12,6 +9,7 @@
    * 椤甸潰鐨勫垵濮嬫暟鎹�
    */
   data: {
+    questuionName: "", //璇曞嵎鍚嶇О
     dataList: "",
     barHeight: "",
     navBarHeight: "",
@@ -31,6 +29,7 @@
     sliderValue: 0, // 瀛椾綋婊戝潡
     showDialog: false, // 鏈彁浜ら��鍑烘嫤鎴脊绐�
     showId: '',
+    uuid: "",
     isShowDialog: false, // 娴嬭瘯鎶ュ憡寮圭獥鏄惁鏄剧ず
   },
 
@@ -38,21 +37,14 @@
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鍔犺浇
    */
   onLoad(options) {
-    const indexof = options.listIndex;
+    const questuionName = options.listName
+    this.setData({
+      questuionName: questuionName
+    })
     const systInfo = wx.getSystemInfoSync();
     const menu = wx.getMenuButtonBoundingClientRect(); // 鑳跺泭淇℃伅
     const navBarHeight =
       (menu.top - systInfo.statusBarHeight) * 2 + menu.height; // 瀵艰埅鏍忛珮搴�
-    this.setData({
-      dataList: pastData,
-      questionDataList: pastData.postData.list[indexof].list,
-      questionDataTitle: pastData.postData.list[indexof].title,
-      questionDataOptions: pastData.postData.list[indexof].optionList,
-      scoreDataList: pastData.postData.list[indexof].scoreData
-    });
-    wx.setNavigationBarTitle({
-      title: pastData.postData.list[indexof].name,
-    })
     const token = wx.getStorageSync(app.config.tokenKey)
     if (!token) {
       loginInfo(app, (data) => {
@@ -290,21 +282,12 @@
   },
   // 鍒囨崲棰樼洰
   changeSwiper(e) {
-    let index = e.detail.index - 1 >= 0 ? e.detail.index - 1 : 0;
-    const item = this.data.questionDataList[index];
-    const lastItem = this.data.questionDataList[index + 1];
+    let index = e.detail.index;
+    const lastItem = this.data.questionDataList[index];
     this.setData({
       currentIndex: e.detail.index,
       showId: lastItem.id
     });
-    if (
-      (this.data.answerType == "collectQuestion" ||
-        this.data.answerType == "errorQuestion") &&
-      !item.isComplete
-    ) {
-      let flag = this.isHaveAnswer(item.userAnswer);
-      if (flag) this.handleQuestion(index);
-    }
   },
   // 鎴戠殑閿欓锛屾敹钘忔煡鐪嬭В鏋愭寜閽�
   viewParsing() {
@@ -479,10 +462,6 @@
     // 鍏堥亶鍘嗘墍鏈夐鐩紝灏嗘湭鎵规敼鐨勯鐩壒鏀�
     const qustionList = this.data.questionDataList;
     if (qustionList.length) this.handleQuestion();
-    this.setData({
-      isShowDialog: true,
-      submitStatus: true,
-    })
     // 璁板綍鐢ㄦ埛绛旈鏁版嵁
     let saveData = [];
     for (let index = 0; index < this.data.questionDataList.length; index++) {
@@ -493,16 +472,61 @@
         isRight: item.isRight,
       });
     }
+    app.MG.identity.setUserKey({
+      setKeyRequests: [{
+        domain: "answerData",
+        key: this.data.uuid,
+        value: JSON.stringify({
+          answerData: saveData,
+          scoreData: this.data.scoreDataList
+        }),
+      }, ],
+    });
     this.setData({
       loading: false,
       showDialog: false,
     });
+    this.setData({
+      isShowDialog: true,
+      submitStatus: true,
+    });
   },
   // 鍒濆鍖栧嚱鏁�
-  async init() {
+  async init(isReset) {
     this.setData({
-      loading: false,
+      loading: true,
     });
+    const questuionName = this.data.questuionName
+    const questuionList = pastData.postData.list
+    var listIndex = 0
+    for (let index = 0; index < questuionList.length; index++) {
+      const item = questuionList[index];
+      if (item.name == questuionName) {
+        listIndex = index
+      }
+    }
+    const indexof = listIndex;
+    this.setData({
+      dataList: pastData,
+      // questionDataList: pastData.postData.list[indexof].list,
+      questionDataTitle: pastData.postData.list[indexof].title,
+      questionDataOptions: pastData.postData.list[indexof].optionList,
+      // scoreDataList: pastData.postData.list[indexof].scoreData,
+      uuid: pastData.postData.list[indexof].name
+    });
+    wx.setNavigationBarTitle({
+      title: pastData.postData.list[indexof].name,
+    })
+    const list = [...pastData.postData.list[indexof].list]
+    const scoreList = [...pastData.postData.list[indexof].scoreData]
+    if (isReset) {
+      list.forEach(item => item.userAnswer = "")
+      scoreList.forEach(item => {
+        item.dispatch = "",
+          item.score = 0
+      })
+    }
+    this.getAnswerInfo(list, scoreList)
   },
 
   // 鑾峰彇棰樺簱棰樼洰
@@ -510,7 +534,6 @@
     // 娓呯┖姝g‘棰樻暟璁板綍
     this.setData({
       noData: false,
-      cardList: [],
       correctNum: 0,
     });
   },
@@ -555,7 +578,9 @@
       const scoreItem = scoreData[cindex];
       if (scoreItem.range == 'all') {
         questionList.forEach((item) => {
-          scoreItem.score += item.score
+          if (item.score) {
+            scoreItem.score += item.score
+          }
         })
       } else {
         questionList.forEach((item, index) => {
@@ -624,16 +649,89 @@
       })
       .then((res) => {});
   },
-
-
-
-
-
-
-
-
-
-
+  async restart() {
+    this.setData({
+      currentIndex: 0,
+      submitStatus: false,
+    });
+    await app.MG.identity.setUserKey({
+      setKeyRequests: [{
+        domain: "answerData",
+        key: this.data.uuid,
+        value: JSON.stringify({
+          answerData: [],
+        }),
+      }, ],
+    });
+    this.init(true);
+  },
+  openIsShowDialog() {
+    this.setData({
+      isShowDialog: true,
+    })
+  },
+  // 鑾峰彇鏃х瓟棰樻暟鎹�
+  getAnswerInfo(arr, scoreListArr) {
+    let newArr = [...arr];
+    let scoreArr = [...scoreListArr];
+    app.MG.identity
+      .getUserKey({
+        domain: "answerData",
+        keys: [this.data.uuid],
+      })
+      .then((res) => {
+        try {
+          const data = JSON.parse(res[0].value)
+          if (data.answerData?.length > 0 && newArr.length) {
+            this.setData({
+              isShowDialog: true,
+              submitStatus: true,
+            })
+            newArr.forEach(item => {
+              const obj = data.answerData.find(citem => citem.id == item.id)
+              if (obj?.answer) {
+                item.userAnswer = obj.answer
+              } else {
+                item.userAnswer = ""
+              }
+            })
+          }
+          if (data.scoreData?.length > 0 && scoreArr.length) {
+            scoreArr.forEach(item => {
+              const obj = data.scoreData.find(citem => citem.name == item.name)
+              if (obj?.score) {
+                item.score = obj.score
+              } else {
+                item.score = 0
+              }
+              if (obj?.dispatch) {
+                item.dispatch = obj.dispatch
+              } else {
+                item.dispatch = ""
+              }
+            })
+          }
+          this.setData({
+            questionDataList: newArr,
+            scoreDataList: scoreArr,
+            loading: false,
+          })
+        } catch (error) {
+          this.setData({
+            questionDataList: newArr,
+            scoreDataList: scoreArr,
+            loading: false,
+          })
+          console.log(error);
+        }
+        const e = {
+          detail: {
+            index: 0
+          }
+        };
+        this.changeSwiper(e)
+      });
+  },
 
   // 璁板綍妯¤�冪瓟棰樻暟鎹�
   saveMockData() {
@@ -670,7 +768,7 @@
     app.MG.identity
       .setUserKey({
         setKeyRequests: [{
-          domain: "mockAnswerData",
+          domain: "answerData",
           key: this.data.uuid,
           value: JSON.stringify({
             currentIndex: this.data.currentIndex,

--
Gitblit v1.9.1