From cac88b3bf823fedf18f0faa4ec96c3de224f30c0 Mon Sep 17 00:00:00 2001
From: litian <C21AF165>
Date: 星期一, 15 七月 2024 15:23:12 +0800
Subject: [PATCH] video

---
 packageDomain/pages/resourceDetails/myAudio/index.js |  163 +++++++++++++++++++++++------------------------------
 1 files changed, 71 insertions(+), 92 deletions(-)

diff --git a/packageDomain/pages/resourceDetails/myAudio/index.js b/packageDomain/pages/resourceDetails/myAudio/index.js
index ca60362..217aa09 100644
--- a/packageDomain/pages/resourceDetails/myAudio/index.js
+++ b/packageDomain/pages/resourceDetails/myAudio/index.js
@@ -19,6 +19,7 @@
     dialogKey: false,
     style: 'border: 2rpx solid rgba(220,220,220,1);border-radius: 12rpx;',
     activeId: '',
+    storeInfo: '',
     bookId: '',
     bookName: '',
     cmsId: '',
@@ -47,19 +48,14 @@
     pauseTime: 0, //鏆傚仠鏃堕棿
     formPath: '',
     loading: true,
-    hidden: true
+    hidden: true,
+    playerList: [],
+    progress: 0,
   },
-  // // 鏃堕棿鏍煎紡鍖�
-  // format(t) {
-  //   let time = Math.floor(t / 60) >= 10 ? Math.floor(t / 60) : '0' + Math.floor(t / 60);
-  //   t = time + ':' + ((t % 60) / 100).toFixed(2).slice(-2);
-  //   return t;
-  // },
-
 
   format(time) {
     let minute = Math.floor(time / 60);
-    let second = Math.floor(time % 60);
+    let second = Math.round(time % 60);
     let minuteStr = minute < 10 ? "0" + minute : "" + minute;
     let secondStr = second < 10 ? "0" + second : "" + second;
     return minuteStr + ":" + secondStr;
@@ -79,23 +75,14 @@
     return formattedDate
   },
 
-
-
   /**
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鍔犺浇
    */
   onLoad(options) {
-
+    console.log(options);
     wx.setNavigationBarTitle({
-
       title: '璧勬簮璇︽儏-闊抽'
-
     });
-
-
-
-
-
     const systInfo = wx.getSystemInfoSync();
     const menu = wx.getMenuButtonBoundingClientRect(); // 鑳跺泭淇℃伅
     const navBarHeight = (menu.top - systInfo.statusBarHeight) * 2 + menu.height; // 瀵艰埅鏍忛珮搴�
@@ -103,6 +90,7 @@
       navBarHeight: navBarHeight,
       barHeight: systInfo.statusBarHeight,
       activeId: options.activeId,
+      storeInfo: options.storeInfo,
       bookId: options.bookId,
       bookName: options.bookName,
       cmsId: options.cmsId,
@@ -124,10 +112,7 @@
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鍒濇娓叉煋瀹屾垚
    * 
    */
-  onReady() {
-
-
-  },
+  onReady() {},
 
   /**
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鏄剧ず
@@ -149,6 +134,7 @@
       let duration = this.data.pauseTime - this.data.startTime
       this.count(duration)
     }
+    this.setPlayerList()
   },
 
   /**
@@ -181,6 +167,7 @@
     myAudio.stop();
     // 閿�姣� InnerAudioContext 瀹炰緥
     // myAudio.destroy();
+    this.setPlayerList()
   },
   count(timeStr) {
     const data = {
@@ -220,21 +207,15 @@
   onShareAppMessage() {
 
   },
-  onTabsChange(event) {
+  onTabsChange(event) {},
 
-  },
-
-  onTabsClick(event) {
-
-  },
+  onTabsClick(event) {},
   handleChange(e) {
     this.setData({
       activeValues: e.detail.value,
     });
   },
-  onTakeNotes() {
-
-  },
+  onTakeNotes() {},
   showDialog(e) {
     this.setData({
       submitTitle: this.data.titleName,
@@ -268,6 +249,7 @@
         jsek_resourceBrief: [],
         jsek_link: [],
         jsek_questionBank: [],
+        learnSelectType: [],
         learnSelectType: []
       },
       pading: {
@@ -275,7 +257,9 @@
         size: 999
       }
     }
-
+    if (this.data.storeInfo) {
+      query.storeInfo = this.data.storeInfo
+    }
     app.MG.store.getProductDetail(query).then(res => {
       let selectedId = -1; // 鍒濆鍖栭�変腑椤圭储寮�
       let showDataUrl = '';
@@ -289,14 +273,13 @@
       this.data.threeLeveData.forEach((items, indexs) => {
         if (this.data.productLinkPath == items.productLinkPath) {
           selectedId = indexs;
-
         }
       })
       if (selectedId !== -1) {
         let datas = this.data.threeLeveData[selectedId];
-
         if (this.data.formPath == 'jsek_cloudLearning') {
-          showDataUrl = app.config.requestCtx + '/file/api/ApiDownloadForAuthorize?md5=' + datas.protectedFile + '&token=' + wx.getStorageSync(app.config.tokenKey);
+          let file = datas.protectedFile ? datas.protectedFile : datas.file
+          showDataUrl = app.config.requestCtx + '/file/api/ApiDownloadForAuthorize?md5=' + file + '&token=' + wx.getStorageSync(app.config.tokenKey);
         } else {
           showDataUrl = datas.file ? app.config.requestCtx + '/file/api/ApiDownload?md5=' + datas.file : app.config.requestCtx + '/file/api/ApiDownload?md5=' + datas.freeFile
         }
@@ -312,45 +295,40 @@
         hidden: false
       });
       this.pubulicPlayFun();
-
     });
   },
 
   onVideo(e) {
-    // myAudio.destroy();
-
+    this.setPlayerList()
     this.setData({
       myAudioCurrent: '00:00',
       myAudioPos: '',
       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: ''
-      })
+        showData: '',
+        activeId: item.id
 
+      })
       if (item.selectType == "audio" || item.learnSelectType === "audio") {
         if (this.data.formPath == 'jsek_cloudLearning') {
+          let file = item.protectedFile ? item.protectedFile : item.file
           // 杩欓噷澶勭悊浜戝涔犵殑
           this.setData({
-            showData: app.config.requestCtx + '/file/api/ApiDownloadForAuthorize?md5=' + item.protectedFile + '&token=' + wx.getStorageSync(app.config.tokenKey)
+            showData: app.config.requestCtx + '/file/api/ApiDownloadForAuthorize?md5=' + file + '&token=' + wx.getStorageSync(app.config.tokenKey)
           })
           this.pubulicPlayFun()
-
         } else {
-
-
           this.setData({
             showData: item.file ? app.config.requestCtx + '/file/api/ApiDownload?md5=' + item.file : app.config.requestCtx + '/file/api/ApiDownload?md5=' + item.freeFile
           })
           this.pubulicPlayFun()
-
-
         }
       }
     }
@@ -366,8 +344,6 @@
       })
     })
   },
-
-
 
   newTopicMessageGet() {
     let query = {
@@ -385,7 +361,6 @@
 
   // 鏍囬鏀瑰彉
   changeTitle(e) {
-
     this.setData({
       flag: e.currentTarget.dataset.value
     })
@@ -423,15 +398,12 @@
     this.getNoteList()
 
   },
-  onTextarea() {
-
-  },
+  onTextarea() {},
   textareaChange(e) {
     this.setData({
       textvalue: e.detail.value
     })
   },
-
 
   // 鑾峰彇绗旇鍒楄〃
   async getNoteList() {
@@ -525,7 +497,6 @@
   },
   // 鏂板缓绗旇鎺ュ彛
   async makeNote() {
-
     let topicId
     await app.MG.ugc
       .getProductUserSubmitTopic({
@@ -613,6 +584,8 @@
     myAudio.onCanplay(() => {
       myAudio.duration; //蹇呴』鍐欙紝涓嶇劧鑾峰彇涓嶅埌
       setTimeout(() => {
+        // 瑕佸垵濮嬪寲闊抽鐨勬椂闂�
+        // myAudio.startTime = myAudio.currentTime //寮�濮嬫椂闂�
         this.setData({
           myAudioDuration: this.format(myAudio.duration),
           myAudioCurrent: this.format(myAudio.currentTime)
@@ -624,54 +597,34 @@
     //鎾斁浜嬩欢
     myAudio.play();
 
-
-
-
     // 鎾斁瀹屾垚澶勭悊锛屾寜閽彉涓�涓�
     myAudio.onEnded((res) => {
       this.setData({
         speed: 1.0,
       })
       myAudio.playbackRate = this.data.speed;
-
       this.setData({
         isplay: true,
         myAudioCurrent: '00:00',
         myAudioPos: '',
       })
 
+
+
     });
 
     //杩涘害鏉″彉鍖�   
     myAudio.onTimeUpdate(() => {
-
-
-
+      myAudio.startTime = 0
       this.setData({
         myAudioPos: myAudio.currentTime / myAudio.duration * 100,
         myAudioCurrent: this.format(myAudio.currentTime),
         myAudioDuration: this.format(myAudio.duration),
+        progress: ((myAudio.currentTime / myAudio.duration) * 100).toFixed(2)
       });
-      // debugger
-
-      console.log(this.data.myAudioPos);
+      // console.log(myAudio.currentTime.toFixed(3), myAudio.duration);
     })
-
-    // if (this.data.myAudioDuration !== this.data.myAudioCurrent) {
-    //   this.setData({
-    //     myAudioPos: myAudio.currentTime / myAudio.duration * 100,
-    //     myAudioCurrent: this.format(myAudio.currentTime),
-    //     myAudioDuration: this.format(myAudio.duration),
-    //   });
-
-    // }else{
-    //   myAudio.pause();
-    //   this.setData({
-    //     isplay: true
-    //   });
-    // }
   },
-
 
   //鎾斁  
   play() {
@@ -689,7 +642,6 @@
       isplay: true
     });
   },
-
 
   //鍙冲垏鎹�
   onLeftSwitch() {
@@ -713,7 +665,6 @@
       speed: 1.0,
       myAudioCurrent: '00:00'
     })
-    console.log('鍙冲垏鎹�');
     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])
@@ -727,8 +678,6 @@
 
   // 宸﹀彸鍒囨崲
   changeItem(item) {
-
-
     if (this.data.showData != '') {
       this.setData({
         showData: ''
@@ -769,7 +718,6 @@
 
   // 鎷栧姩杩涘害鏉★紝鍒版寚瀹氫綅缃�
   hanle_slider_change(e) {
-
     const position = e.detail.value;
     var currentTime = position / 100 * myAudio.duration;
     myAudio.seek(currentTime);
@@ -777,17 +725,12 @@
       myAudioPos: position,
       myAudioCurrent: this.format(currentTime)
     })
-
-
-
   },
-
 
   toggleDropdown() {
     this.setData({
       showDropdown: !this.data.showDropdown
     });
-
   },
   smallSpeed() {
     this.setData({
@@ -829,5 +772,41 @@
       myAudio.playbackRate = this.data.speed; //  鎾斁閫熺巼
     }, 200);
   },
-
+  //鑾峰彇闊抽瀛︿範
+  getPlayerList() {
+    app.MG.identity
+      .getUserKey({
+        domain: 'videoPlayer',
+        keys: [this.data.bookId]
+      })
+      .then((res) => {
+        if (res.length > 0) {
+          this.setData({
+            playerList: JSON.parse(res[0].value)
+          })
+        }
+      })
+  },
+  setPlayerList() {
+    let that = this
+    if (that.data.progress > 0) {
+      let index = that.data.playerList.findIndex((itemData) => itemData.cmsItemId == that.data.selectId)
+      if (index > -1) {
+        that.data.playerList.splice(index, 1)
+      }
+      that.data.playerList.push({
+        cmsItemId: that.data.selectId,
+        progress: that.data.progress
+      })
+      app.MG.identity
+        .setUserKey({
+          setKeyRequests: [{
+            domain: 'videoPlayer',
+            key: that.data.bookId,
+            value: JSON.stringify(that.data.playerList)
+          }]
+        })
+        .then((res) => {})
+    }
+  },
 })
\ No newline at end of file

--
Gitblit v1.9.1