From 9d5789148e866f95f86d975011a9ef39d534c807 Mon Sep 17 00:00:00 2001
From: 闫增涛 <1829501689@qq.com>
Date: 星期三, 17 七月 2024 17:37:19 +0800
Subject: [PATCH] 拼树结构优化

---
 packageBookService/pages/bookServices/detail/index.js |   94 ++++++++++++++++++++++++++++-------------------
 1 files changed, 56 insertions(+), 38 deletions(-)

diff --git a/packageBookService/pages/bookServices/detail/index.js b/packageBookService/pages/bookServices/detail/index.js
index e500b90..d0fa544 100644
--- a/packageBookService/pages/bookServices/detail/index.js
+++ b/packageBookService/pages/bookServices/detail/index.js
@@ -187,7 +187,7 @@
       title: options.name,
     })
     this.getBookInfo(options.id);
-    this.getResourceClass(); // 鑾峰彇璧勬簮鎵�灞炲垎绫�
+    // this.getResourceClass(); // 鑾峰彇璧勬簮鎵�灞炲垎绫�
     const token = wx.getStorageSync(app.config.tokenKey);
     if (token) {
       this.getShoppingCartProductGet();
@@ -389,6 +389,7 @@
       this.setData({
         bookDetail: res.datas,
         buyIdList: res.datas.purchasedSaleMethodIdList,
+        pageLoading: false
       });
       if (res.datas.cmsDatas && res.datas.cmsDatas.length) {
         this.setData({
@@ -404,14 +405,19 @@
       this.getSubTtem();
       // 鑾峰彇鍥句功鍒嗙被
       if (res.datas.bookClassification) {
+        let classData = []
         const bookClassification = JSON.parse(res.datas.bookClassification);
         if (Array.isArray(bookClassification) && bookClassification.length) {
           for (let index = 0; index < bookClassification.length; index++) {
             const element = bookClassification[index];
             const iconType = element[0];
             const classType = element[1];
-            await this.getBookClass(iconType, classType);
+            classData.push({
+              iconType,
+              classType
+            })
           }
+          await this.getBookClass(classData);
         }
       }
 
@@ -449,7 +455,7 @@
         "bookDetail.paperPrice": this.numFormat(
           this.data.bookDetail.paperPrice
         ),
-        pageLoading: false,
+
       });
       console.log("鍥句功淇℃伅", this.data.bookClass);
     });
@@ -512,14 +518,14 @@
               "fileInfo.bookName": this.data.bookDetail.name,
               "fileInfo.fileType": "pdf",
               "fileInfo.md5": res.datas[0].bookshelf_pdf,
-              "fileInfo.freePage": res.datas[0].bookshelf_probationPage,
+              "fileInfo.freePage": res.datas[0].bookshelf_probationPage ? res.datas[0].bookshelf_probationPage : 30,
             });
           } else if (res.datas[0].bookshelf_protectedEpub) {
             this.setData({
               "fileInfo.bookName": this.data.bookDetail.name,
               "fileInfo.fileType": "epub",
               "fileInfo.md5": res.datas[0].bookshelf_protectedEpub,
-              "fileInfo.freePage": res.datas[0].bookshelf_freeEpub,
+              "fileInfo.freePage": res.datas[0].bookshelf_freeEpub ? res.datas[0].bookshelf_freeEpub : 30,
             });
           }
         }
@@ -533,7 +539,7 @@
               "fileInfo.bookName": this.data.bookDetail.name,
               "fileInfo.fileType": "pdf",
               "fileInfo.md5": this.data.bookDetail.pdf,
-              "fileInfo.freePage": this.data.bookDetail.probationPage,
+              "fileInfo.freePage": this.data.bookDetail.probationPage ? this.data.bookDetail.probationPage : 30,
             });
           } else if (this.data.bookDetail.protectedEpub) {
 
@@ -541,7 +547,7 @@
               "fileInfo.bookName": this.data.bookDetail.name,
               "fileInfo.fileType": "epub",
               "fileInfo.md5": this.data.bookDetail.protectedEpub,
-              "fileInfo.freePage": this.data.bookDetail.freeEpubPage,
+              "fileInfo.freePage": this.data.bookDetail.freeEpubPage ? this.data.bookDetail.freeEpubPage : 30,
             });
           }
         }
@@ -570,28 +576,37 @@
     });
   },
   // 鑾峰彇鍥句功鍒嗙被
-  async getBookClass(iconType, classType) {
+  async getBookClass(list) {
     let name = "";
     const query = {
       refCodes: ["bookClassification"],
     };
     await app.MG.store.getProductTypeField(query).then((res) => {
-      JSON.parse(res[0].config).option.forEach((item) => {
-        if (item.value == iconType) {
-          item.child.forEach((citem) => {
-            if (citem.value == classType) {
-              const flag = this.data.bookClass.findIndex((ditem) => ditem == citem.name)
-              if (flag == -1) {
-                let list = this.data.bookClass
-                list.push(citem.name)
-                this.setData({
-                  bookClass: list
-                })
-              }
+      for (let aindex = 0; aindex < list.length; aindex++) {
+        const aitem = list[aindex];
+        const iconType = aitem.iconType
+        const classType = aitem.classType
+        JSON.parse(res[0].config).option.forEach((item) => {
+          if (item.value == iconType) {
+            if (item.child && item.child.length) {
+              item.child.forEach((citem) => {
+                if (citem.value == classType) {
+                  const flag = this.data.bookClass.findIndex((ditem) => ditem == citem.name)
+                  if (flag == -1) {
+                    let list = this.data.bookClass
+                    list.push(citem.name)
+                    this.setData({
+                      bookClass: list
+                    })
+                  }
+                }
+              });
             }
-          });
-        }
-      });
+
+          }
+        });
+      }
+
     });
   },
   // 鏀惰棌
@@ -670,7 +685,7 @@
       const checkData = this.data.cmsDatas.find(
         (item) => item.refCode == e.detail.value
       );
-
+      if (!this.data.resourceClassList.length) this.getResourceClass()
       if (checkData) {
         if (e.detail.value == "jsek_cloudLearning") {
           this.setData({
@@ -690,9 +705,7 @@
         //   this.getResourceData(checkData);
         // }
         if ((e.detail.value == "jsek_teachingResources" && !this.data.teach.length) || (e.detail.value == "jsek_cloudLearning" && !this.data.learn.length)) {
-          if (e.detail.value == "jsek_teachingResources") {
-            wx.setStorageSync('teachResourcesPath', checkData.productLinkPath)
-          }
+          wx.setStorageSync('teachResourcesPath', checkData.productLinkPath)
           this.getResourceDataList(checkData)
         } else if (e.detail.value == "questionBank" && !this.data.test.length) {
           this.getResourceData(checkData);
@@ -792,12 +805,16 @@
         // newArr.push(item)
         // 鍦ㄦ彃鍏ヨ繃绋嬩腑瀵规暟鎹繘琛屾帓搴�
         newArr = this.insertAndSortObjectsByProductLinkPath(newArr, item, addNum)
+        // 鎻掕繘鏁扮粍鍚� 浠庡師鏁版嵁涓垹闄�
+        rootList = rootList.filter(nitem => nitem.id != item.id)
       }
     }
     //缁欐暟缁勯噷闈㈠啀娣诲姞涓�涓猚hildren鐨勭┖鏁扮粍
+    // let addnum1 = pathLength - path.length == 6 ? 6 : 7
     for (const i of newArr) {
       i.children = []
-      this.getTreeList(rootList, pathLength + addNum, i.children, i.productLinkPath, addNum)
+      let addnum1 = i.productLinkPath.length - path.length == 6 ? 6 : 7
+      this.getTreeList(rootList, pathLength + addnum1, i.children, i.productLinkPath, addnum1)
       if (i.children.length == 0) {
         delete i.children
       }
@@ -825,7 +842,6 @@
   insertAndSortObjectsByProductLinkPath(array, newObj, addNum) {
     // 鏌ユ壘鏂板璞″簲璇ユ彃鍏ョ殑浣嶇疆  
     let insertIndex = array.findIndex(obj => Number(newObj.productLinkPath.substring(newObj.productLinkPath.length - addNum, newObj.productLinkPath.length)) < Number(obj.productLinkPath.substring(obj.productLinkPath.length - addNum, obj.productLinkPath.length)));
-
     // 濡傛灉娌℃湁鎵惧埌鍚堥�傜殑浣嶇疆锛屽垯鏀惧湪鏁扮粍鏈熬  
     if (insertIndex === -1) {
       insertIndex = array.length;
@@ -880,7 +896,7 @@
         size: 999
       },
     }
-    app.MG.store.getProductDetail(query).then((res) => {
+    app.MG.store.getProductDetailNoChildren(query).then((res) => {
       if (!res.datas.cmsDatas[0].datas.length) {
         return this.setData({
           noResources: true,
@@ -924,19 +940,19 @@
             })
           }
         }
-        const addNum = query.cmsPath.length > 12 ? 7 : query.cmsPath.length > 14 ? 8 : 6
+        const addNum = query.cmsPath.length > 10 ? 7 : query.cmsPath.length > 14 ? 8 : 6
         const num = query.cmsPath.length + addNum
         this.getTreeList(res.datas.cmsDatas[0].datas, num, list, '\\', addNum)
         list = this.ensureTreeConsistency(list)
         list = this.changeResourceChildren(list)
-        console.log('淇敼鍚庝簯', list);
+        console.log('淇敼鍚�', list);
         let result = [];
         if (type.refCode == "jsek_teachingResources") {
           this.findChildIds(list, result);
           this.setData({
-            teach: list,
-            loading: false,
             openTeachids: result,
+            loading: false,
+            teach: list,
           });
         } else if (type.refCode == "jsek_cloudLearning") {
           let arr = this.handleTreeData(list).filter(
@@ -1015,7 +1031,8 @@
             if (data.length > 0) {
               let list = []
               // 娴嬭瘯 6浣�// 姝e紡 5浣�//  娴嬭瘯璋冪敤浼�20锛屽唴閮�7  姝e紡璋冪敤浼�17 鍐呴儴浼�6
-              const addNum = query.cmsPath.length > 12 ? 7 : query.cmsPath.length > 14 ? 8 : 6
+
+              const addNum = query.cmsPath.length > 10 ? 7 : query.cmsPath.length > 14 ? 8 : 6
               const num = query.cmsPath.length + addNum
               this.getTreeList(data, num, list, '\\', addNum)
               list = this.ensureTreeConsistency(list)
@@ -1130,7 +1147,7 @@
       for (let i = 0; i < data.length; i++) {
         if (index < 3) {
           const item = data[i]
-          if (item.childrenFolderCount > 0) {
+          if (item.children && item.children.length > 0) {
             result.push(item.id)
             if (item.children) {
               for (let j = 0; j < item.children.length; j++) {
@@ -2101,7 +2118,7 @@
         const smBook = list.find(item => item.content[0].id == this.data.bookDetail.id)
         console.log('宸茬敵璇�', smBook);
         if (smBook && smBook.state == 'Normal') {
-          const flag = new Date(smBook.feedBack.endDate + '23:59:59').getTime() > new Date().getTime()
+          const flag = new Date(smBook.feedBack.endDate + ' 23:59:59').getTime() > new Date().getTime()
           if (flag) {
             this.setData({
               applicationState: 'Normal'
@@ -2211,7 +2228,8 @@
             });
             return false;
           } else if (isApply.state == 'Normal') {
-            const flag = new Date(isApply.feedBack.endDate + '23:59:59').getTime() > new Date().getTime()
+            console.log(isApply.state, "isApply.state")
+            const flag = new Date(isApply.feedBack.endDate + ' 23:59:59').getTime() > new Date().getTime()
             if (flag) {
               wx.showToast({
                 title: "璇ヤ功宸茬敵璇凤紒",

--
Gitblit v1.9.1