From 2c08a98f7e85ec7c9376f27a7933e75e44d672f7 Mon Sep 17 00:00:00 2001
From: liukangdong <898885815@qq.com>
Date: 星期二, 27 八月 2024 15:52:59 +0800
Subject: [PATCH] ll
---
wechat_jiaxuan/pages/productVideo/index.js | 134 +++++++++++++++++++++++++++++++++++++++-----
1 files changed, 119 insertions(+), 15 deletions(-)
diff --git a/wechat_jiaxuan/pages/productVideo/index.js b/wechat_jiaxuan/pages/productVideo/index.js
index 4db093b..084b2f1 100644
--- a/wechat_jiaxuan/pages/productVideo/index.js
+++ b/wechat_jiaxuan/pages/productVideo/index.js
@@ -1,20 +1,80 @@
-import { getZhongTaiVideoPage, getCataLogTagList } from '../../api/index'
+import { getZhongTaiVideoPage, actionDo, getCataLogTagList } from '../../api/index'
Page({
/**
* 椤甸潰鐨勫垵濮嬫暟鎹�
*/
data: {
+ acVid: '',
+ viewIdList: [],
+
+ activeIndex: -1,
+ activeParam: [],
+ tagCodes: [],
+
+ videoContext:null,
category: [],
- tagCodes: '',
videoUrl: '',
showVideo: false,
-
+ isShow:false,
+ curVideoSrc:'',
dataList: [],
total: 0,
pageSize: 10,
pageNum: 1,
+ },
+ changeShowParams(e) {
+ const { category } = this.data
+ const activeIndex = e.currentTarget.dataset.index
+ if (activeIndex === this.data.activeIndex) {
+ this.setData({ activeIndex: -1, activeParam: [] })
+ } else {
+ this.setData({
+ activeIndex,
+ activeParam: category[activeIndex].valueVos
+ })
+ }
+ },
+ cancelParam() {
+ const { category } = this.data
+ category.forEach(item => {
+ item.tempParamIndex = item.paramIndex
+ item.tempParamName = item.paramName
+ item.tempParamCode = item.paramCode
+ })
+ this.setData({ activeParam: [],activeIndex: -1 ,category})
+ },
+ subParam() {
+ const { category } = this.data
+ var codes = []
+ category.forEach(item => {
+ item.paramIndex = item.tempParamIndex
+ item.paramName = item.tempParamName
+ item.paramCode = item.tempParamCode
+ if( item.paramIndex>-1 && item.tempParamCode){
+ codes.push( item.tempParamCode)
+ }
+ })
+ this.setData({tagCodes:codes})
+ this.setData({ pageNum: 1, activeParam: [] ,activeIndex: -1, dataList: [], total: 0 })
+ this.getList()
+ },
+ tagClick(e) {
+ const code = e.currentTarget.dataset.code
+ const paramIndex = e.currentTarget.dataset.index
+ const { category, tagCodes, activeParam, activeIndex } = this.data
+ const index = tagCodes.indexOf(code)
+ if ( category[activeIndex].tempParamIndex==null || category[activeIndex].tempParamIndex != paramIndex) {
+ category[activeIndex].tempParamIndex = paramIndex
+ category[activeIndex].tempParamCode = code
+ category[activeIndex].tempParamName = activeParam[paramIndex].labelValueName
+ } else {
+ category[activeIndex].tempParamIndex = -1
+ category[activeIndex].tempParamCode = ''
+ category[activeIndex].tempParamName = ''
+ }
+ this.setData({ category })
},
onReachBottom() {
console.log('瑙﹀簳浜嬩欢');
@@ -32,30 +92,60 @@
getList() {
const { pageSize, pageNum, tagCodes } = this.data
getZhongTaiVideoPage({
- pageSize,pageNum, tagCodes: tagCodes ? [tagCodes] : null
+ pageSize,pageNum, tagCodes
}).then(res => {
- this.setData({
- dataList: [...this.data.dataList, ...res.data.records],
- total: res.data.total
- })
+ if(res.data && res.data.records){
+ this.setData({
+ dataList: [...this.data.dataList, ...res.data.records],
+ total: res.data.total
+ })
+ }
})
},
getTagList() {
getCataLogTagList({
catalogCode: 'video_rec'
}).then(res => {
- this.setData({ category: res.data })
+ if(res.data){
+ this.setData({ category: [...res.data] })
+ }
+
})
},
itemClick(e) {
- const { videourl } = e.currentTarget.dataset
- wx.previewMedia({
- sources: [{ url: videourl, type: 'video' }]
+ const { id } = e.currentTarget.dataset.item
+ const { dataList, acVid, viewIdList } = this.data
+ const index = viewIdList.findIndex(i => i === id)
+ if(acVid){
+ if(id != acVid){
+ wx.createVideoContext(acVid).pause()
+ wx.createVideoContext(id).play()
+ this.setData({ acVid: id })
+ }
+ }else{
+ this.setData({ acVid: id })
+ wx.createVideoContext(id).play()
+ }
+ dataList.forEach(ite => {
+ if(id === ite.id && index === -1){
+ ite.viewCount += 1
+ viewIdList.push(id)
+ actionDo({
+ actionType: 'view',
+ id: id
+ })
+ this.setData({ viewIdList })
+ }
})
+ this.setData({ dataList })
},
cateClick(e) {
- const { code } = e.target.dataset
- this.setData({ tagCodes: code })
+ const { code, index } = e.target.dataset
+ if(this.data.activeIndex === index){
+ this.setData({ tagCodes: [], activeIndex: -1 })
+ }else{
+ this.setData({ tagCodes: [code], activeIndex: index })
+ }
this.setData({ total: 0, dataList: [], pageNum: 1 })
this.getList()
},
@@ -65,7 +155,8 @@
},
onLoad(options) {
this.getTagList()
- this.getList()
+ this.getList()
+ this.videoContext = wx.createVideoContext('myVideo')
},
/**
@@ -107,5 +198,18 @@
*/
onShareAppMessage() {
+ },
+ startPlayVideo(videourl){
+ this.setData({isShow:true, curVideoSrc:videourl})
+ console.log(videourl)
+ this.videoContext.requestFullScreen({
+ // direction: 0
+ });
+ },
+ onClose(){
+ this.setData({isShow:false})
+ if(this.videoContext){
+ this.videoContext.exitFullScreen()
+ }
}
})
\ No newline at end of file
--
Gitblit v1.9.3