From a22c86c0a14de6fe7e7110f158beefa86ebc58ad Mon Sep 17 00:00:00 2001
From: 闫增涛 <1829501689@qq.com>
Date: 星期四, 19 九月 2024 19:52:43 +0800
Subject: [PATCH] 资源播放器,是否购买判断

---
 packageDomain/pages/resourceDetails/myAudio/index.js |  209 +++++++++++++++++++++++++--------------------------
 1 files changed, 102 insertions(+), 107 deletions(-)

diff --git a/packageDomain/pages/resourceDetails/myAudio/index.js b/packageDomain/pages/resourceDetails/myAudio/index.js
index d87cef4..624b1dc 100644
--- a/packageDomain/pages/resourceDetails/myAudio/index.js
+++ b/packageDomain/pages/resourceDetails/myAudio/index.js
@@ -30,6 +30,7 @@
     parentProductLinkPath: '',
     productLinkPath: '',
     threeLeveData: [],
+    source: "",
     showData: '',
     src: '',
     selectedId: null,
@@ -44,7 +45,6 @@
     myAudioDuration: '00:00', // 瑙嗛鏃堕棿
     myAudioCurrent: '00:00', // 褰撳墠鎾斁杩涘害
     isplay: false, //鏄惁榛樿鎾斁,
-    selectId: '',
     speed: 1.0,
     myAudioPos: '',
     startTime: "", //杩涘叆椤甸潰褰撳墠鏃堕棿
@@ -54,6 +54,10 @@
     hidden: true,
     playerList: [],
     progress: 0,
+    buyIdList: [],
+    buyList: [],
+    learnClassData: null,
+    bookDetail: null
   },
 
   format(time) {
@@ -99,9 +103,9 @@
       cmsId: options.cmsId,
       parentProductLinkPath: options.parentProductLinkPath,
       productLinkPath: options.productLinkPath,
-      formPath: options.formPath
+      formPath: options.formPath,
+      source: options.source,
     })
-
     if (options.parentName !== "鏁欏璧勬簮" && options.parentName !== "浜戝涔�") {
       this.setData({
         parentName: options.parentName,
@@ -122,6 +126,7 @@
       this.resourceDetailsData()
       this.getNoteList()
     }
+    if (options.formPath == 'jsek_cloudLearning') this.getBookInfo(options.bookId)
   },
 
   /**
@@ -143,14 +148,17 @@
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰闅愯棌
    */
   onHide() {
+    // this.setData({
+    //   pauseTime: Date.now()
+    // })
+    // if (wx.getStorageSync(app.config.tokenKey)) {
+    //   let duration = this.data.pauseTime - this.data.startTime
+    //   this.count(duration)
+    // }
+    // this.setPlayerList()
     this.setData({
-      pauseTime: Date.now()
+      isplay: true
     })
-    if (wx.getStorageSync(app.config.tokenKey)) {
-      let duration = this.data.pauseTime - this.data.startTime
-      this.count(duration)
-    }
-    this.setPlayerList()
   },
 
   /**
@@ -160,29 +168,24 @@
    * 
    */
   onUnload() {
-    // this.setData({
-    //   pauseTime: Date.now()
-    // })
-    // if (wx.getStorageSync(app.config.tokenKey)) {
-    //   let duration = this.data.pauseTime - this.data.startTime
-    //   this.count(duration)
-    // }
-
-
-    // myAudio.src = ''
-    // myAudio.destroy()
     this.setData({
       // myAudioPos: '',
       isplay: false, //鏄惁榛樿鎾斁,
       myAudioCurrent: '00:00', // 褰撳墠鎾斁杩涘害
       showData: '',
       speed: 1.0,
+      pauseTime: Date.now()
     });
     myAudio.playbackRate = this.data.speed;
     // 鍋滄闊抽鎾斁
     myAudio.stop();
     // 閿�姣� InnerAudioContext 瀹炰緥
     // myAudio.destroy();
+    // 缁熻瀛︿範鏃堕暱
+    if (wx.getStorageSync(app.config.tokenKey)) {
+      let duration = this.data.pauseTime - this.data.startTime
+      this.count(duration)
+    }
     this.setPlayerList()
   },
   count(timeStr) {
@@ -201,30 +204,64 @@
     if (this.data.cmsId) {
       data.cmsItemId = this.data.cmsId
     }
+    console.log('缁熻', data)
     app.MG.job.newJobWithApiNewEvent(data).then((res) => {})
   },
-  /**
-   * 椤甸潰鐩稿叧浜嬩欢澶勭悊鍑芥暟--鐩戝惉鐢ㄦ埛涓嬫媺鍔ㄤ綔
-   */
-  onPullDownRefresh() {
-
+  // 鑾峰彇鍥句功璇︽儏
+  getBookInfo(id) {
+    const query = {
+      path: "*",
+      queryType: "*",
+      productId: id,
+      favoriteTypes: "FavoriteBookCity",
+      itemFields: {
+        "SysType=": "CmsFolder",
+      },
+      coverSize: {
+        height: 1,
+      },
+      fields: {},
+    };
+    app.MG.store.getProductDetail(query).then(async (res) => {
+      console.log('鍥句功璇︽儏', res);
+      this.setData({
+        bookDetail: res.datas,
+        buyIdList: res.datas.purchasedSaleMethodIdList,
+        learnClassData: res.datas.cmsDatas[0].datas.find(item => item.refCode == "jsek_cloudLearning")
+      })
+      this.getResourceDataList(this.data.learnClassData)
+    });
+  },
+  // 鏁欏璧勬簮 浜戝涔� 鑾峰彇
+  getResourceDataList(type) {
+    let query = {
+      path: '*',
+      queryType: '*',
+      productId: this.data.bookDetail.id,
+      cmsPath: type.productLinkPath,
+      cmsType: '*',
+      itemFields: {
+        SysType: 'CmsFolder',
+      },
+      pading: {
+        start: 0,
+        size: 999
+      },
+    }
+    app.MG.store.getProductDetailNoChildren(query).then((res) => {
+      const buyList = res.datas.cmsDatas[0].datas.filter(item => item.saleMethod.length && this.data.buyIdList.includes(item.saleMethod.find(citem => citem.SaleType == 'Normal').Id))
+      if (this.data.learnClassData && this.data.learnClassData.saleMethod.length) {
+        const learnSaleMethod = this.data.learnClassData.saleMethod.find(citem => citem.SaleType == 'Normal')
+        if (this.data.buyIdList.includes(learnSaleMethod.Id)) buyList.push(learnClassData)
+      }
+      this.setData({
+        buyList
+      })
+      console.log('浜戝涔�', buyList);
+    })
   },
 
-  /**
-   * 椤甸潰涓婃媺瑙﹀簳浜嬩欢鐨勫鐞嗗嚱鏁�
-   */
-  onReachBottom() {
-
-  },
-
-  /**
-   * 鐢ㄦ埛鐐瑰嚮鍙充笂瑙掑垎浜�
-   */
-  onShareAppMessage() {
-
-  },
   onTabsChange(event) {},
-
   onTabsClick(event) {},
   handleChange(e) {
     this.setData({
@@ -280,17 +317,31 @@
       let selectedId = -1; // 鍒濆鍖栭�変腑椤圭储寮�
       let showDataUrl = '';
       let titleName = '';
-
       res.datas.cmsDatas[0].datas.forEach((item, index) => {
-        if (item.selectType === "audio" || item.learnSelectType === "audio") {
-          this.data.threeLeveData.push(item);
+        if (this.data.source == 'qrcode') {
+          if (item.id == this.data.activeId) {
+            this.data.threeLeveData.push(item);
+          }
+        } else {
+          if (item.selectType === "audio" || item.learnSelectType === "audio") {
+            if (this.data.storeInfo == 'jsek_digitalCourses') {
+              if (item.sysType == 'CmsItem') {
+                this.data.threeLeveData.push(item)
+              }
+              if (item.sysType == 'CmsItem' && item.freeFile) {
+                this.data.threeLeveData.push(item)
+              }
+            } 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)
+              }
+            }
+          }
         }
       });
-      this.data.threeLeveData.forEach((items, indexs) => {
-        if (this.data.productLinkPath == items.productLinkPath) {
-          selectedId = indexs;
-        }
-      })
+      selectedId = this.data.threeLeveData.findIndex(items => items.productLinkPath == this.data.productLinkPath)
       if (selectedId !== -1) {
         let datas = this.data.threeLeveData[selectedId];
         if (this.data.formPath == 'jsek_cloudLearning') {
@@ -310,6 +361,7 @@
         loading: false,
         hidden: false
       });
+      console.log(1, this.data);
       this.pubulicPlayFun();
     });
   },
@@ -322,15 +374,12 @@
       isplay: false
     })
     const item = e.currentTarget.dataset.item
-    console.log(item, 222)
     if (this.data.showData != '') {
       this.setData({
         titleName: item.name,
-        selectId: item.id,
         selectedId: e.currentTarget.dataset.index,
         showData: '',
         activeId: item.id
-
       })
       if (item.selectType == "audio" || item.learnSelectType === "audio") {
         if (this.data.formPath == 'jsek_cloudLearning') {
@@ -344,6 +393,7 @@
           this.setData({
             showData: item.file ? app.config.requestCtx + '/file/api/ApiDownload?md5=' + item.file : app.config.requestCtx + '/file/api/ApiDownload?md5=' + item.freeFile
           })
+          console.log(2, this.data);
           this.pubulicPlayFun()
         }
       }
@@ -590,7 +640,6 @@
   },
   // 鎾斁鍏叡浠g爜
   pubulicPlayFun() {
-    // debugger
     this.setData({
       speed: 1.0,
     })
@@ -624,9 +673,6 @@
         myAudioCurrent: '00:00',
         myAudioPos: '',
       })
-
-
-
     });
 
     //杩涘害鏉″彉鍖�   
@@ -659,57 +705,6 @@
     });
   },
 
-  //鍙冲垏鎹�
-  onLeftSwitch() {
-    this.setData({
-      speed: 1.0,
-      myAudioCurrent: '00:00'
-    })
-    const index = this.data.threeLeveData.findIndex((item) => item.id == this.data.selectId)
-    if (this.data.threeLeveData[index - 1]) {
-      this.changeItem(this.data.threeLeveData[index - 1])
-      this.setData({
-        selectedId: index - 1,
-      })
-    } else {
-      console.log('宸茬粡鏄涓�棣栦簡');
-    }
-  },
-  //鍙冲垏鎹�
-  onRightSwitch() {
-    this.setData({
-      speed: 1.0,
-      myAudioCurrent: '00:00'
-    })
-    const index = this.data.threeLeveData.findIndex((item) => item.id == this.data.selectId)
-    if (this.data.threeLeveData[index + 1]) {
-      this.changeItem(this.data.threeLeveData[index + 1])
-      this.setData({
-        selectedId: index + 1,
-      })
-    } else {
-      console.log('宸茬粡鏄渶鍚庝竴棣栦簡');
-    }
-  },
-
-  // 宸﹀彸鍒囨崲
-  changeItem(item) {
-    if (this.data.showData != '') {
-      this.setData({
-        showData: ''
-      })
-    }
-    this.setData({
-      titleName: item.name,
-      selectId: item.id
-    })
-    if (item.selectType == "audio") {
-      this.setData({
-        showData: app.config.requestCtx + '/file/api/ApiDownload?md5=' + item.file
-      })
-      this.pubulicPlayFun()
-    }
-  },
   // 鎾斁鍊嶉��
   onSpeed() {
     let c = this.data.speed;
@@ -806,12 +801,12 @@
   setPlayerList() {
     let that = this
     if (that.data.progress > 0) {
-      let index = that.data.playerList.findIndex((itemData) => itemData.cmsItemId == that.data.selectId)
+      let index = that.data.playerList.findIndex((itemData) => itemData.cmsItemId == that.data.activeId)
       if (index > -1) {
         that.data.playerList.splice(index, 1)
       }
       that.data.playerList.push({
-        cmsItemId: that.data.selectId,
+        cmsItemId: that.data.activeId,
         progress: that.data.progress
       })
       app.MG.identity

--
Gitblit v1.9.1