From 188a925be5b1024608eba034d1225e126b3134a8 Mon Sep 17 00:00:00 2001
From: QYF-GitLab1 <1940665526@qq.com>
Date: 星期三, 16 七月 2025 16:46:41 +0800
Subject: [PATCH] 资源扫码

---
 packageDomain/pages/resourceDetails/myVideo/index.js |  120 +++++++++++++++++++++++++++++++++--------------------------
 1 files changed, 67 insertions(+), 53 deletions(-)

diff --git a/packageDomain/pages/resourceDetails/myVideo/index.js b/packageDomain/pages/resourceDetails/myVideo/index.js
index 42a6f61..ea072ff 100644
--- a/packageDomain/pages/resourceDetails/myVideo/index.js
+++ b/packageDomain/pages/resourceDetails/myVideo/index.js
@@ -5,7 +5,6 @@
 } from '../../../../assets/js/login';
 import moment from 'moment'
 Page({
-
   /**
    * 椤甸潰鐨勫垵濮嬫暟鎹�
    */
@@ -55,7 +54,7 @@
     buyIdList: [],
     buyList: [],
     learnClassData: null,
-    isLearnDataBuy: false,
+    isLearnDataBuy: true,
     bookDetail: null,
     learnStartTime: 0,
     learnTimeList: [],
@@ -117,7 +116,6 @@
     }
     this.getBookInfo(this.data.bookId)
   },
-
   /**
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鏄剧ず
    */
@@ -126,7 +124,6 @@
       startTime: Date.now()
     })
   },
-
   /**
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰闅愯棌
    */
@@ -144,7 +141,6 @@
     }
     this.setPlayerList()
   },
-
   /**
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鍗歌浇
    */
@@ -226,12 +222,15 @@
           buyIdList: res.datas.purchasedSaleMethodIdList,
           learnClassData: res.datas.cmsDatas[0].datas.length > 0 ? res.datas.cmsDatas[0].datas.find(item => item.refCode == "jsek_cloudLearning") : null
         })
-      } catch (error) {}
-      if (this.data.learnClassData) {
-        this.getResourceDataList(this.data.learnClassData)
-      } else {
-        this.resourceDetailsData()
+        if (this.data.learnClassData) {
+          this.getResourceDataList(this.data.learnClassData)
+        } else {
+          this.resourceDetailsData()
+        }
+      } catch (error) {
+        console.log(error)
       }
+
     });
   },
   // 鏁欏璧勬簮 浜戝涔� 鑾峰彇
@@ -307,9 +306,7 @@
       activeValues: e.detail.value,
     });
   },
-  onTakeNotes() {
-
-  },
+  onTakeNotes() {},
   showDialog(e) {
     const token = wx.getStorageSync(app.config.tokenKey);
     if (token) {
@@ -332,6 +329,15 @@
   goBack() {
     wx.navigateBack();
   },
+
+  // 鍒ゆ柇褰撳墠鐩爣鏄惁宸茶喘涔�
+  async getCmsDataByQrcode() {
+    const query = {
+      cmsItemId: Number(this.data.activeId)
+    };
+    return app.MG.file.checkCmsItem(query)
+  },
+
   resourceDetailsData() {
     this.setData({
       videoLoading: true,
@@ -362,14 +368,13 @@
         size: 999
       }
     }
-    app.MG.store.getProductDetail(query).then(res => {
+    app.MG.store.getProductDetail(query).then(async (res) => {
       this.setData({
         isBuy: res.datas.purchasedSaleMethodIdList.includes(res.datas.defaultSaleMethodId)
       })
       res.datas.cmsDatas[0].datas.forEach((item) => {
         if (item.selectType === "video" || item.learnSelectType === "video") {
           if (this.data.storeInfo == 'jsek_digitalCourses') {
-            // if (item.sysType == 'CmsItem') this.data.threeLeveData.push(item)
             if (this.data.isBuy) {
               if (item.sysType == 'CmsItem') {
                 this.data.threeLeveData.push(item)
@@ -380,42 +385,49 @@
               }
             }
           } else {
-            // 涔颁簡
-            if (this.data.buyList.length) {
-              if (this.data.buyList.some(citem => item.productLinkPath.includes(citem.productLinkPath))) {
-                this.data.threeLeveData.push(item)
-              }
-            } else {
-              if (!item.saleMethod.length) {
-                // 娌′拱涓旀棤閿�鍞柟寮�
-                this.data.threeLeveData.push(item)
-              } else {
-                // 娌′拱涓旈攢鍞柟寮忚繃鏈�//娌′拱锛岄攢鍞柟寮忎环鏍间负0
-                const itemSaleMethod = item.saleMethod.find(citem => citem.SaleType == 'Normal')
-                if (new Date().getTime() > new Date(itemSaleMethod.EndDate).getTime() || itemSaleMethod.Price == 0) {
+            if (this.data.productLinkPath == item.productLinkPath) {
+              // 涔颁簡
+              if (this.data.buyList.length) {
+                if (this.data.buyList.some(citem => item.productLinkPath.includes(citem.productLinkPath))) {
                   this.data.threeLeveData.push(item)
                 }
-                //  娌′拱涓斿彧鏈夎瘯璇昏祫婧�
-                if (!item.file && item.freeFile) this.data.threeLeveData.push(item)
+              } else {
+                if (!item.saleMethod.length) {
+                  // 娌′拱涓旀棤閿�鍞柟寮�
+                  this.data.threeLeveData.push(item)
+                } else {
+                  // 娌′拱涓旈攢鍞柟寮忚繃鏈�//娌′拱锛岄攢鍞柟寮忎环鏍间负0
+                  const itemSaleMethod = item.saleMethod.find(citem => citem.SaleType == 'Normal')
+                  if (new Date().getTime() > new Date(itemSaleMethod.EndDate).getTime() || itemSaleMethod.Price == 0) {
+                    this.data.threeLeveData.push(item)
+                  }
+                  //  娌′拱涓斿彧鏈夎瘯璇昏祫婧�
+                  if (!item.file && item.freeFile) this.data.threeLeveData.push(item)
+                }
               }
             }
           }
-
         }
-        // }
       })
       if (this.data.source == 'qrcode') {
         let qrData = this.data.threeLeveData.find(ditem => ditem.id == this.data.activeId)
-        if (qrData && this.data.isLearnDataBuy) {
-          if (qrData) {
+        const isBuyCms = await this.getCmsDataByQrcode() // 褰撳墠璧勬簮鎴栫埗绾х洰褰曟槸鍚﹁喘涔�
+        const isDefualtPrice = this.data.bookDetail?.defaultSaleMethod?.price // 褰撳墠涔︾殑浠烽粯璁ら攢鍞柟寮忎环鏍兼槸鍚︿负0
+        const isBuyBook = this.data.bookDetail?.alreadyBuy // 褰撳墠涔︽槸鍚﹁喘涔�
+        if (isBuyCms) {
+          this.setData({
+            threeLeveData: [qrData]
+          })
+        } else {
+          if (isDefualtPrice == 0 || isBuyBook) {
             this.setData({
               threeLeveData: [qrData]
             })
+          } else {
+            this.setData({
+              threeLeveData: []
+            })
           }
-        } else {
-          this.setData({
-            threeLeveData: []
-          })
         }
       } else {
         this.setData({
@@ -447,8 +459,9 @@
               })
               this.aliVod(file, this.data.showData)
             } else {
+              let file = items.file ? items.file : items.freeFile
               this.setData({
-                showData: items.file ? app.config.requestCtx + '/file/api/ApiDownload?md5=' + items.file : app.config.requestCtx + '/file/api/ApiDownload?md5=' + items.freeFile,
+                showData: app.config.requestCtx + '/file/api/ApiDownload?md5=' + file,
                 titleName: items.name,
                 selectedId: index
               })
@@ -457,13 +470,22 @@
           }
         });
       } else {
-        wx.showToast({
-          icon: 'none',
-          title: '璇峰厛杩斿洖璧勬簮鎵�鍦ㄥ浘涔﹁鎯呰喘涔拌棰戣祫婧�',
+        wx.showModal({
+          title: '娓╅Θ鎻愮ず',
+          content: '璇ヨ祫婧愭湭璐拱锛屽皢杩斿洖璐拱',
+          success: (res) => {
+            if (res.confirm) {
+              if (this.data.source == 'qrcode') {
+                wx.navigateTo({
+                  url: `/packageBookService/pages/bookServices/detail/index?id=${this.data.bookDetail.id}&name=${this.data.bookDetail.name}&tabValue=${this.data.formPath}`,
+                });
+              } else {
+                wx.navigateBack()
+              }
+            }
+          }
         })
-        wx.navigateTo({
-          url: `/packageBookService/pages/bookServices/detail/index?id=${this.data.bookDetail.id}&name=${this.data.bookDetail.name}&tabValue=${this.data.formPath}`,
-        });
+
       }
       this.setData({
         loading: false,
@@ -517,7 +539,6 @@
       }
     }
   },
-
   aliVod(md5, currentVideo) {
     if (md5) {
       let query = {
@@ -560,13 +581,11 @@
       })
     }
   },
-
   timeUpdate(e) {
     let {
       currentTime,
       duration
     } = e.detail
-
     this.setData({
       progress: ((currentTime / duration) * 100).toFixed(2)
     })
@@ -610,7 +629,6 @@
         .then((res) => {})
     }
   },
-
   getProductUserSubmitTopicGet() {
     app.MG.ugc.getProductUserSubmitTopic({
       productId: this.data.bookId,
@@ -621,7 +639,6 @@
       })
     })
   },
-
   newTopicMessageGet() {
     let query = {
       topicIdOrRefCode: topicId + '',
@@ -635,7 +652,6 @@
       console.log(res);
     })
   },
-
   // 鏍囬鏀瑰彉
   changeTitle(e) {
     this.setData({
@@ -648,7 +664,6 @@
       submitTitle: e.detail.value
     })
   },
-
   confirmSuggest() {
     if (!this.data.textvalue.trim()) {
       return wx.showToast({
@@ -736,7 +751,6 @@
       dialogKey: true,
     })
   },
-
   // 鍒犻櫎绗旇
   deleteNote(e) {
     const id = e.currentTarget.dataset.id

--
Gitblit v1.9.1