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 |  402 ++++++++++++++++++++++++++++++++------------------------
 1 files changed, 230 insertions(+), 172 deletions(-)

diff --git a/packageDomain/pages/resourceDetails/myAudio/index.js b/packageDomain/pages/resourceDetails/myAudio/index.js
index 0fbf416..217aa09 100644
--- a/packageDomain/pages/resourceDetails/myAudio/index.js
+++ b/packageDomain/pages/resourceDetails/myAudio/index.js
@@ -13,12 +13,13 @@
     noteList: [],
     navBarHeight: '',
     barHeight: '',
-    flag: true, // 杈撳叆妗嗘槸鍚︽樉绀�
+    flag: false, // 杈撳叆妗嗘槸鍚︽樉绀�
     tabPanelstyle: 'display:flex;justify-content:center;align-items:center;',
     activeValues: [0],
     dialogKey: false,
     style: 'border: 2rpx solid rgba(220,220,220,1);border-radius: 12rpx;',
     activeId: '',
+    storeInfo: '',
     bookId: '',
     bookName: '',
     cmsId: '',
@@ -42,25 +43,24 @@
     isplay: false, //鏄惁榛樿鎾斁,
     selectId: '',
     speed: 1.0,
-    myAudioPos: ''
+    myAudioPos: '',
+    startTime: "", //杩涘叆椤甸潰褰撳墠鏃堕棿
+    pauseTime: 0, //鏆傚仠鏃堕棿
+    formPath: '',
+    loading: 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);
-    minute = minute < 10 ? ("0" + minute) : minute;
-    second = second < 10 ? ("0" + second) : second;
-    let res = minute + ":" + second;
-    return res;
+    let second = Math.round(time % 60);
+    let minuteStr = minute < 10 ? "0" + minute : "" + minute;
+    let secondStr = second < 10 ? "0" + second : "" + second;
+    return minuteStr + ":" + secondStr;
   },
+
   audio: null,
   // 鏍煎紡鍖栫瑪璁版椂闂�
   convertTimestamp(timestamp) {
@@ -75,75 +75,118 @@
     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; // 瀵艰埅鏍忛珮搴�
-    // console.log(options, 'options');
     this.setData({
       navBarHeight: navBarHeight,
       barHeight: systInfo.statusBarHeight,
       activeId: options.activeId,
+      storeInfo: options.storeInfo,
       bookId: options.bookId,
       bookName: options.bookName,
       cmsId: options.cmsId,
-      parentName: options.parentName,
       parentProductLinkPath: options.parentProductLinkPath,
-      productLinkPath: options.productLinkPath
+      productLinkPath: options.productLinkPath,
+      formPath: options.formPath
     })
 
+    if (options.parentName !== "鏁欏璧勬簮" && options.parentName !== "浜戝涔�") {
+      this.setData({
+        parentName: options.parentName,
+      })
+    }
     this.resourceDetailsData()
     this.getNoteList()
-
-
-    this.setData({
-      myAudioPos: '',
-      isplay: false, //鏄惁榛樿鎾斁,
-      myAudioCurrent: '00:00', // 褰撳墠鎾斁杩涘害
-      showData: '',
-    });
-    myAudio.src = ''
-
-
-    console.log(this.data.myAudioPos, this.data.isplay, this.data.myAudioCurrent, this.data.showData, myAudio.src);
   },
 
   /**
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鍒濇娓叉煋瀹屾垚
    * 
    */
-  onReady() {
-
-
-  },
+  onReady() {},
 
   /**
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鏄剧ず
    */
   onShow() {
-
-
+    this.setData({
+      startTime: Date.now()
+    })
   },
 
   /**
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰闅愯棌
    */
   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()
   },
 
   /**
    * 鐢熷懡鍛ㄦ湡鍑芥暟--鐩戝惉椤甸潰鍗歌浇
+   * 
+   * 閫�鍑洪〉闈㈡椂鍊欒皟鐢ㄧ殑
+   * 
    */
   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,
+    });
+    myAudio.playbackRate = this.data.speed;
+    // 鍋滄闊抽鎾斁
+    myAudio.stop();
+    // 閿�姣� InnerAudioContext 瀹炰緥
+    // myAudio.destroy();
+    this.setPlayerList()
   },
-
+  count(timeStr) {
+    const data = {
+      appRefCode: app.config.appRefCode,
+      type: 'LearningTime', //缁熻绫诲瀷--闃呰鏃堕暱
+      data: timeStr + '', //缁熻鍐呭--鏃堕暱姣
+      event: 'LearningTime',
+      sysType: 'App'
+    }
+    //闃呰鍟嗗搧鐨刬d
+    if (this.data.bookId) {
+      data.productId = this.data.bookId
+    }
+    //闃呰璧勬簮鐨刬d
+    if (this.data.cmsId) {
+      data.cmsItemId = this.data.cmsId
+    }
+    app.MG.job.newJobWithApiNewEvent(data).then((res) => {})
+  },
   /**
    * 椤甸潰鐩稿叧浜嬩欢澶勭悊鍑芥暟--鐩戝惉鐢ㄦ埛涓嬫媺鍔ㄤ綔
    */
@@ -164,34 +207,24 @@
   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.bookName,
+      submitTitle: this.data.titleName,
       dialogKey: true,
       textvalue: ''
-
-
     });
   },
 
   closeDialog() {
-
     this.setData({
       dialogKey: false
     });
@@ -207,7 +240,6 @@
       cmsPath: this.data.parentProductLinkPath,
       itemFields: {
         SysType: 'CmsFolder',
-        // 璧勬簮绫诲瀷锛岃瘯璇绘枃浠讹紝鏄惁鍏佽涓嬭浇绛夊弬鏁�
         selectType: [],
         freeFile: [],
         file: [],
@@ -217,6 +249,7 @@
         jsek_resourceBrief: [],
         jsek_link: [],
         jsek_questionBank: [],
+        learnSelectType: [],
         learnSelectType: []
       },
       pading: {
@@ -224,67 +257,79 @@
         size: 999
       }
     }
-
+    if (this.data.storeInfo) {
+      query.storeInfo = this.data.storeInfo
+    }
     app.MG.store.getProductDetail(query).then(res => {
+      let selectedId = -1; // 鍒濆鍖栭�変腑椤圭储寮�
+      let showDataUrl = '';
+      let titleName = '';
+
       res.datas.cmsDatas[0].datas.forEach((item, index) => {
-
-        if (item.selectType === "audio") {
-          this.data.threeLeveData.push(item)
-          this.setData({
-            threeLeveData: this.data.threeLeveData
-          })
-
-          this.data.threeLeveData.forEach((items, index) => { // 淇敼姝ゅ娣诲姞index鍙傛暟
-            if (this.data.productLinkPath == items.productLinkPath) {
-              this.setData({
-                showData: app.config.requestCtx + '/file/api/ApiDownload?md5=' + items.file,
-                titleName: items.name
-              })
-              this.pubulicPlayFun()
-              console.log(index, 'index');
-              let selectedIndex = index; // 瀛樺偍閫変腑椤圭殑绱㈠紩
-              this.setData({
-                selectedId: selectedIndex // 璁剧疆閫変腑椤圭殑绱㈠紩
-              });
-            }
-          });
-
-
+        if (item.selectType === "audio" || item.learnSelectType === "audio") {
+          this.data.threeLeveData.push(item);
         }
+      });
+      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') {
+          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
+        }
+        titleName = datas.name;
+      }
 
-      })
-      this.data.threeLeveData.forEach((item) => {
-        // console.log(item.name);
-      })
-    })
+      this.setData({
+        threeLeveData: this.data.threeLeveData,
+        selectedId: selectedId,
+        showData: showDataUrl,
+        titleName: titleName,
+        loading: false,
+        hidden: false
+      });
+      this.pubulicPlayFun();
+    });
   },
+
   onVideo(e) {
-    // console.log(e, 'e');
+    this.setPlayerList()
     this.setData({
       myAudioCurrent: '00:00',
       myAudioPos: '',
-
-
       isplay: false
     })
-
     const item = e.currentTarget.dataset.item
-    console.log(item, 'item0980');
+    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
+
       })
-      console.log(e.currentTarget.dataset.index, 'e.currentTarget.dataset.index');
-      if (item.selectType == "audio") {
-        this.setData({
-          showData: app.config.requestCtx + '/file/api/ApiDownload?md5=' + item.file
-        })
-        this.pubulicPlayFun()
+      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=' + 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()
+        }
       }
     }
   },
@@ -294,15 +339,11 @@
       productId: this.data.bookId,
       appRefCode: app.config.appRefCode
     }).then((res) => {
-      // console.log(res);
-
       this.setData({
         topicId: res.id
       })
     })
   },
-
-
 
   newTopicMessageGet() {
     let query = {
@@ -314,33 +355,31 @@
       newDataListRequest: []
     }
     app.MG.ugc.newTopicMessage(query).then(res => {
-      // console.log(res);
+
     })
   },
 
   // 鏍囬鏀瑰彉
   changeTitle(e) {
-    // console.log(e.currentTarget.dataset.value);
     this.setData({
       flag: e.currentTarget.dataset.value
-
     })
   },
   // 鏍囬杈撳叆妗嗗��
   inputChange(e) {
     this.setData({
-      titleName: e.detail.value
+      submitTitle: e.detail.value
     })
   },
 
   confirmSuggest() {
-    if (!this.data.textvalue) {
+    if (!this.data.textvalue.trim()) {
       return wx.showToast({
         icon: 'error',
         title: '璇峰~鍐欑瑪璁板唴瀹�',
       })
 
-    } else if (!this.data.titleName) {
+    } else if (!this.data.submitTitle) {
       return wx.showToast({
         icon: 'error',
         title: '璇峰~鍐欑瑪璁版爣棰�',
@@ -351,21 +390,20 @@
     } else if (this.data.submitType == 'edit') {
       this.updateNote()
     }
-    // console.log(this.data.textvalue);
-    // console.log(this.data.titleName);
+
     this.setData({
       dialogKey: false
     });
+
+    this.getNoteList()
+
   },
-  onTextarea() {
-    // console.log(this.data.textvalue);
-  },
+  onTextarea() {},
   textareaChange(e) {
     this.setData({
       textvalue: e.detail.value
     })
   },
-
 
   // 鑾峰彇绗旇鍒楄〃
   async getNoteList() {
@@ -401,18 +439,14 @@
       topicIdOrRefCode: topicId + ''
     }
     await app.MG.ugc.getTopicMessageList(query).then((res) => {
-      // notePage.value.total = res.totalSize
       res.datas.forEach((item) => {
-
         item.createDate = this.convertTimestamp(item.createDate)
-        console.log(item, 'item789');
       })
       this.setData({
         "pageCount.total": res.totalSize,
         noteList: res.datas,
-        loading: false
       })
-      // console.log('绗旇鍒楄〃', res.datas);
+
     })
   },
   // 缂栬緫鎸夐挳
@@ -422,9 +456,12 @@
       submitType: "edit",
       textvalue: note.content,
       submitTitle: note.name,
-      noteId: note.id
+
+      noteId: note.id,
+      dialogKey: true,
     })
-    this.showDialog()
+
+    // this.showDialog()
   },
 
   // 鍒犻櫎绗旇
@@ -460,15 +497,6 @@
   },
   // 鏂板缓绗旇鎺ュ彛
   async makeNote() {
-    const token = wx.getStorageSync('jsek-token')
-    if (!token) {
-      return wx.getUserProfile({
-        desc: '鐢ㄦ埛鐧诲綍',
-        success: (res) => {
-          // console.log(res);
-        }
-      })
-    }
     let topicId
     await app.MG.ugc
       .getProductUserSubmitTopic({
@@ -546,13 +574,18 @@
   },
   // 鎾斁鍏叡浠g爜
   pubulicPlayFun() {
+    // debugger
+    this.setData({
+      speed: 1.0,
+    })
+    myAudio.playbackRate = this.data.speed;
     myAudio.src = this.data.showData
-    console.log(myAudio.src);
     // 鍦╫nCanplay閲岃幏鍙栧苟璁剧疆闊抽鏃堕暱鍜屾挱鏀捐繘搴�
     myAudio.onCanplay(() => {
-      myAudio.duration; //蹇呴』鍐欙紝涓嶇劧鑾峰彇涓嶅埌銆傘�傘��
+      myAudio.duration; //蹇呴』鍐欙紝涓嶇劧鑾峰彇涓嶅埌
       setTimeout(() => {
-        console.log(myAudio.duration, 'myAudio.duration');
+        // 瑕佸垵濮嬪寲闊抽鐨勬椂闂�
+        // myAudio.startTime = myAudio.currentTime //寮�濮嬫椂闂�
         this.setData({
           myAudioDuration: this.format(myAudio.duration),
           myAudioCurrent: this.format(myAudio.currentTime)
@@ -560,55 +593,53 @@
       }, 100);
     });
 
-    // myAudio.onSeeked(() => {
-    //   this.setData({
-    //     myAudioDuration: this.format(myAudio.duration),
-    //     myAudioCurrent: this.format(myAudio.currentTime)
-    //   })
-    // })
+
+    //鎾斁浜嬩欢
+    myAudio.play();
+
     // 鎾斁瀹屾垚澶勭悊锛屾寜閽彉涓�涓�
     myAudio.onEnded((res) => {
       this.setData({
-        isplay: false
+        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)
+        myAudioCurrent: this.format(myAudio.currentTime),
+        myAudioDuration: this.format(myAudio.duration),
+        progress: ((myAudio.currentTime / myAudio.duration) * 100).toFixed(2)
       });
+      // console.log(myAudio.currentTime.toFixed(3), myAudio.duration);
     })
-
   },
-
 
   //鎾斁  
   play() {
-    console.log(22222);
     myAudio.startTime = this.data.myAudioCurrent; //鑰冭檻鍒拌繘搴︽潯琚嫋鍔紝涓嶄竴瀹氫粠00:00:00寮�濮�
     myAudio.play();
     this.setData({
-      isplay: true
+      isplay: false
     });
-
-
   },
 
   // 鍋滄
   stop() {
-
     myAudio.pause();
     this.setData({
-      isplay: false
-    });
-  },
-  adsfhaewlf() {
-    myAudio.pause();
-    this.setData({
-      isplay: false
+      isplay: true
     });
   },
 
@@ -623,27 +654,22 @@
       this.changeItem(this.data.threeLeveData[index - 1])
       this.setData({
         selectedId: index - 1,
-
       })
     } else {
       console.log('宸茬粡鏄涓�棣栦簡');
     }
-
   },
-
   //鍙冲垏鎹�
   onRightSwitch() {
     this.setData({
       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])
       this.setData({
         selectedId: index + 1,
-
       })
     } else {
       console.log('宸茬粡鏄渶鍚庝竴棣栦簡');
@@ -652,8 +678,6 @@
 
   // 宸﹀彸鍒囨崲
   changeItem(item) {
-    console.log(item);
-
     if (this.data.showData != '') {
       this.setData({
         showData: ''
@@ -663,7 +687,6 @@
       titleName: item.name,
       selectId: item.id
     })
-
     if (item.selectType == "audio") {
       this.setData({
         showData: app.config.requestCtx + '/file/api/ApiDownload?md5=' + item.file
@@ -687,7 +710,7 @@
     }
 
     setTimeout(() => {
-      console.log(this.data.speed, 'this.data.speed');
+
       myAudio.startTime = this.data.myAudioDuration //寮�濮嬫椂闂�  
       myAudio.playbackRate = this.data.speed; //  鎾斁閫熺巼
     }, 200);
@@ -704,12 +727,10 @@
     })
   },
 
-
   toggleDropdown() {
     this.setData({
       showDropdown: !this.data.showDropdown
     });
-
   },
   smallSpeed() {
     this.setData({
@@ -717,7 +738,7 @@
       showDropdown: !this.data.showDropdown
     })
     setTimeout(() => {
-      // myAudio.startTime = this.data.myAudioDuration  //寮�濮嬫椂闂�  
+      myAudio.startTime = this.data.myAudioDuration //寮�濮嬫椂闂�  
       myAudio.playbackRate = this.data.speed; //  鎾斁閫熺巼
     }, 200);
   },
@@ -727,7 +748,7 @@
       showDropdown: !this.data.showDropdown
     })
     setTimeout(() => {
-      // myAudio.startTime = this.data.myAudioDuration  //寮�濮嬫椂闂�  
+      myAudio.startTime = this.data.myAudioDuration //寮�濮嬫椂闂�  
       myAudio.playbackRate = this.data.speed; //  鎾斁閫熺巼
     }, 200);
   },
@@ -737,7 +758,7 @@
       showDropdown: !this.data.showDropdown
     })
     setTimeout(() => {
-      // myAudio.startTime = this.data.myAudioDuration  //寮�濮嬫椂闂�  
+      myAudio.startTime = this.data.myAudioDuration //寮�濮嬫椂闂�  
       myAudio.playbackRate = this.data.speed; //  鎾斁閫熺巼
     }, 200);
   },
@@ -747,8 +768,45 @@
       showDropdown: !this.data.showDropdown
     })
     setTimeout(() => {
-      // myAudio.startTime = this.data.myAudioDuration  //寮�濮嬫椂闂�  
+      myAudio.startTime = this.data.myAudioDuration //寮�濮嬫椂闂�  
       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