"use strict"; import httpRequestApi from '../../utils/APIClient'; Component({ options: { addGlobalClass: true, pureDataPattern: /^_/ }, properties: { showMyBtn: { type: Boolean, value: false }, ifHeadTap: { type: Boolean, value: true }, isSwiper: { type: Boolean, value: true }, duration: { type: Number, value: 500 }, easingFunction: { type: String, value: 'easeInOutCubic' // easeInCubic 缓入 easeOutCubic 缓出 easeInOutCubic 缓入缓出 default linear }, loop: { type: Boolean, value: true }, videoList: { type: Array, value: [], observer: function observer() { if (!this.data.isSwiper) return; var newVal = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; this._videoListChanged(newVal); } }, nextMargin: { type: String, value: '400rpx' } }, data: { nextQueue: [], prevQueue: [], curQueue: [], circular: false, // nextMargin: '400rpx', _last: 0, // _last: 1, _change: -1, _invalidUp: 0, _invalidDown: 0, _videoContexts: [], inputValue: '', showControl: 0 }, lifetimes: { attached: function attached() { this.data._videoContexts = [wx.createVideoContext('video_0', this), wx.createVideoContext('video_1', this), wx.createVideoContext('video_2', this)]; } }, methods: { _videoListChanged: function _videoListChanged(newVal) { var _this = this; var data = this.data; console.log('newVal', newVal) newVal.forEach(function (item) { data.nextQueue.push(item); }); if (data.curQueue.length === 0) { this.setData({ curQueue: data.nextQueue.splice(0, 3) }, function () { _this.playCurrent(1); // _this.playCurrent(0); }); } }, animationfinish: function animationfinish(e) { var _data = this.data, _last = _data._last, _change = _data._change, curQueue = _data.curQueue, prevQueue = _data.prevQueue, nextQueue = _data.nextQueue; var current = e.detail.current; var diff = current - _last; if (diff === 0) return; this.data._last = current; this.playCurrent(current); this.triggerEvent('change', { activeId: curQueue[current].id, // index: current, // _last, // nextQueue, }); var direction = diff === 1 || diff === -2 ? 'up' : 'down'; if (direction === 'up') { if (this.data._invalidDown === 0) { var change = (_change + 1) % 3; var add = nextQueue.shift(); var remove = curQueue[change]; if (add) { prevQueue.push(remove); curQueue[change] = add; this.data._change = change; } else { this.data._invalidUp += 1; } } else { this.data._invalidDown -= 1; } } if (direction === 'down') { if (this.data._invalidUp === 0) { var _change2 = _change; var _remove = curQueue[_change2]; var _add = prevQueue.pop(); if (_add) { curQueue[_change2] = _add; nextQueue.unshift(_remove); this.data._change = (_change2 - 1 + 3) % 3; } else { this.data._invalidDown += 1; } } else { this.data._invalidUp -= 1; } } var circular = true; if (nextQueue.length === 0 && current !== 0) { circular = false; } if (prevQueue.length === 0 && current !== 2) { circular = false; } this.setData({ curQueue: curQueue, circular: circular }); }, playCurrent: function playCurrent(current) { console.log('playCurrent', current) // return; // 注掉自动播放 this.data._videoContexts.forEach(function (ctx, index) { index !== current ? ctx.pause() : ctx.play(); }); }, onPlay: function onPlay(e) { console.log('播放记录', e) httpRequestApi.playLogReport({ userReadId: e.currentTarget.dataset.id, playStopTime: 1000 }).success(res => { console.log('播放记录', res) }) // this.trigger(e, 'play'); }, onPlayList: function onPlayList(e) { console.log('lastVideoId', this.data.lastVideoId); console.log('lastVideoId', e); httpRequestApi.playLogReport({ userReadId: e.target.dataset.id, playStopTime: 1000 }).success(res => { console.log('播放记录', res) }) if (this.data.lastVideoId && e.target.id !== this.data.lastVideoId) { const lastVideo = wx.createVideoContext(this.data.lastVideoId, this) lastVideo.stop(); this.setData({ lastVideoId: e.target.id }) } if (!this.data.lastVideoId) { this.setData({ lastVideoId: e.target.id }) } this.triggerEvent('onPlay') }, onPause: function onPause(e) { this.trigger(e, 'pause'); }, onEnded: function onEnded(e) { console.log('播放结束', e) // this.trigger(e, 'ended'); }, onError: function onError(e) { console.log('视频出错', e) // this.trigger(e, 'error'); }, onTimeUpdate: function onTimeUpdate(e) { this.trigger(e, 'timeupdate'); }, onWaiting: function onWaiting(e) { this.trigger(e, 'wait'); }, onProgress: function onProgress(e) { this.trigger(e, 'progress'); }, onLoadedMetaData: function onLoadedMetaData(e) { this.trigger(e, 'loadedmetadata'); }, onTimeUpdate: function onTimeUpdate(e) { }, openComment: function openComment(e) { console.log(e) this.trigger(e, 'openComment') }, // 展示视频 showVideo: function showVideo(e) { let index = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index; console.log('showVideo') const str = `videoList[${index}].videoShow`; if (this.data.lastIndex || this.data.lastIndex === 0) { const lastStr = `videoList[${this.data.lastIndex}].videoShow`; this.setData({ lastIndex: index, [lastStr]: false, [str]: true }) } else { this.setData({ lastIndex: index, [str]: true }) } }, // 点击头部 headTap: function headTap(e) { if (!wx.getStorageSync('user').wechatName) { wx.navigateTo({ url: `../../pages/login/login` }); return; } let uid = e.target.dataset.uid ? e.target.dataset.uid : e.currentTarget.dataset.uid; // this.trigger(e, 'headTap') console.log('点击头像', e) wx.navigateTo({ url: `../../pages/myworks/myworks?uid=${uid}`, fail: (err) => { console.log('跳转错误', err) wx.navigateTo({ url: `../../../pages/myworks/myworks?uid=${uid}` }); } }); }, // 去朗读 goToReading: function goToReading(e) { this.trigger(e, 'goToReading') }, // 收藏课程 collectTap: function collectClass(e) { if (!wx.getStorageSync('user').wechatName) { wx.navigateTo({ url: `../../pages/login/login` }); return; } console.log('收藏按钮', e); const data = { targetCode: e.target.dataset.id ? e.target.dataset.id : e.currentTarget.dataset.id, favoritesType: e.target.dataset.type ? e.target.dataset.type : e.currentTarget.dataset.type } const index = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index; console.log('视频index', index); if (this.data.curQueue.length <= 0) { let str = `videoList[${index}].isFavorite` httpRequestApi.collectClass(data).success((res) => { let isCollect = res.data.data.status === 'NORMAL' ? true : false; // this.setData({ // [str]: isCollect // }) this.triggerEvent('collectTap',{ index, isCollect }) }); } else { let str = `curQueue[${index}].isFavorite` httpRequestApi.collectClass(data).success((res) => { this.setData({ [str]: !this.data.curQueue[index].isFavorite }) }); } }, // 点赞 likeTap: function likeTap(e) { if (!wx.getStorageSync('user').wechatName) { wx.navigateTo({ url: `../../pages/login/login` }); return; } const isLike = e.target.dataset.islike ? e.target.dataset.islike : e.currentTarget.dataset.islike; console.log('isLike', isLike) if (isLike) { return; } const id = e.target.dataset.id ? e.target.dataset.id : e.currentTarget.dataset.id; const index = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index; console.log('视频index', index); if (this.data.isSwiper) { let likeStr = `curQueue[${index}].isLike`; let likeNumStr = `curQueue[${index}].likes`; httpRequestApi.likeWorks(id).success((res) => { this.setData({ [likeStr]: true, [likeNumStr]: this.data.curQueue[index].likes + 1 }) }); } else { let likeStr = `videoList[${index}].isLike`; let likeNumStr = `videoList[${index}].likes`; httpRequestApi.likeWorks(id).success((res) => { // this.setData({ // [likeStr]: true, // [likeNumStr]: this.data.videoList[index].likes + 1 // }) this.triggerEvent('likeTap',{ index, }) }); } }, // 下载视频 download: function (e) { // console.log(e.currentTarget.dataset) wx.showLoading({ title: '保存到本地', mask: true }) const { url } = e.currentTarget.dataset; wx.downloadFile({ url, success (res) { // 只要服务器有响应数据,就会把响应内容写入文件并进入 success 回调,业务需要自行判断是否下载到了想要的内容 if (res.statusCode === 200) { console.log(res.tempFilePath) wx.saveVideoToPhotosAlbum({ filePath: res.tempFilePath, success (res) { wx.hideLoading() wx.showToast({ title: '保存成功', icon: 'success', duration: 2000, mask: true }) }, fail (error) { console.log(error) } }) } }, fail () { wx.hideLoading() wx.showToast({ title: '网络不给力', icon: 'error', duration: 2000, mask: true }) } }) }, delete: function (e) { console.log('删除', e) wx.showModal({ title: '确认删除吗?', content: '作品将被永久删除,无法找回。', confirmText: '确认', cancelText: '取消', success: (res) => { if (res.confirm) { /* let data = { id: e.currentTarget.dataset.id, status: status === 'NORMAL' ? 'DISABLE' : 'NORMAL' } httpRequestApi.putWork(data).success(res => { console.log('已隐藏', res) this.triggerEvent('delHideMyWork'); }) */ let data = { id: e.currentTarget.dataset.id, status: 'DEL' } httpRequestApi.putWork(data).success(res => { console.log('已删除', res) this.triggerEvent('delHideMyWork'); }) } else if (res.cancel) { console.log('用户点击取消') } } }) }, hide: function (e) { console.log('隐藏', e) const status = e.currentTarget.dataset.status ? e.currentTarget.dataset.status : e.target.dataset.status console.log('当前状态', status) let data = { id: e.currentTarget.dataset.id, status: status === 'NORMAL' ? 'DISABLE' : 'NORMAL' } httpRequestApi.putWork(data).success(res => { console.log('已隐藏', res) if (res.data.data.status === 'DISABLE') { wx.showToast({ title: '该作品仅自己可见', icon: 'none', duration: 2000 }) } this.triggerEvent('delHideMyWork'); }) }, openShare: function (e) { const obj = e.currentTarget.dataset console.log('分享的dataset', obj) console.log('分享', e) if (1) { this.shareDialog = this.selectComponent("#share-dialog"); const data = { avatar: obj.avatar, author: obj.author, iconImg: obj.iconImg, title: obj.title, path: `pages/index/index`, scene: obj.id, type:obj.type, grade:obj.grade, productId: 1, shareImg:obj.shareImg // tip: this.data.tip, } // console.log(data) this.setData({ noScroll: 'noScroll' }) this.shareDialog.share(data); } this.triggerEvent('openShare', e) }, trigger: function trigger(e, type) { if (!wx.getStorageSync('user').wechatName) { wx.navigateTo({ url: `../../pages/login/login` }); return; } var ext = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; // var detail = e.detail; var activeId = e.target.dataset.id ? e.target.dataset.id : e.currentTarget.dataset.id; this.triggerEvent(type, { activeId: activeId }, { bubbles: false }); /* this.triggerEvent(type, Object.assign(Object.assign(Object.assign({}, detail), { activeId: activeId }), ext)); */ } } });