index.wxml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. <view class="swiper_container">
  2. <swiper wx:if="{{isSwiper}}" class="video-swiper" circular="{{circular}}" easing-function="{{easingFunction}}"
  3. vertical current="0" duration="{{duration}}" next-margin="{{nextMargin}}" bindanimationfinish="animationfinish">
  4. <!-- curQueue 循环会导致video重新插入,objectFit 不可变更 -->
  5. <swiper-item class="swiper_item" wx:for="{{curQueue}}" data-id="{{item.id}}" wx:key="id">
  6. <view class="head_box">
  7. <image class="tag_icon" wx:if="{{item.hasTag}}" src="{{item.tagUrl}}" />
  8. <view class="user_box" catchtap="{{ifHeadTap ? 'headTap' : null}}" data-uid="{{item.uid}}">
  9. <image class="avatar" lazy-load="true" src="{{item.avatar}}" />
  10. <image class="avatar_fans" src="../../static/index/add_follow.png" />
  11. <view class="user_right">
  12. <view class="nickname">{{item.nickName}}</view>
  13. <image class="efun_tag" src="../../static/index/efun_tag.png" wx:if="{{item.isEfun}}"></image>
  14. </view>
  15. </view>
  16. <view wx:if="{{!item.showMyBtn}}" class="time">
  17. <text>发布时间:{{item.time}}</text>
  18. </view>
  19. <view wx:if="{{item.showMyBtn}}" class="my_btn">
  20. <view catchtap="delete" data-id="{{item.id}}">
  21. <image src="../../static/index/delete.png" />
  22. <text>删除</text>
  23. </view>
  24. <view catchtap="hide" data-status="{{item.status}}" data-id="{{item.id}}">
  25. <image
  26. src="{{item.status==='NORMAL'? '../../static/index/show_icon.png': '../../static/index/hide_icon.png'}}" />
  27. <text>{{item.status==='NORMAL'? '隐藏': '展示'}}</text>
  28. </view>
  29. </view>
  30. </view>
  31. <video id="video_{{index}}" class="video_item" loop="{{loop}}" enable-play-gesture enable-progress-gesture
  32. show-center-play-btn="{{false}}" controls="{{true}}" src="{{item.url}}" object-fit="contain"
  33. data-index="{{index}}" data-id="{{item.id}}" bindplay="onPlay" bindended="onEnded">
  34. </video>
  35. <view class="video_title">
  36. <text>{{item.title}}</text>
  37. </view>
  38. <view class="foot_box">
  39. <view class="foot_left">
  40. <view class="video_btn collect_btn" catchtap="collectTap" data-index="{{index}}"
  41. data-id="{{item.id}}" data-type="{{item.type}}">
  42. <image class="collect_btn_icon"
  43. src="{{item.isFavorite ? '../../static/index/star_colored.png' : '../../static/index/star.png'}}" />
  44. <text>收藏</text>
  45. </view>
  46. <view class="video_btn share_btn" bindtap="openShare" data-index="{{index}}" data-id="{{item.id}}"
  47. data-avatar="{{item.avatar}}" data-author="{{item.nickName}}" data-uid="{{item.uid}}"
  48. data-img="{{item.img}}" data-title="{{item.title}}" data-type="{{item.type}}"
  49. ata-activity="{{item.activity}}">
  50. <image class="share_btn_icon" src="../../static/index/share.png" lazy-load="true" />
  51. <text>分享</text>
  52. </view>
  53. </view>
  54. <view class="foot_right">
  55. <view class="video_btn flower_btn" catchtap="{{item.isLike ? null : 'likeTap'}}"
  56. data-index="{{index}}" data-id="{{item.id}}" data-islike="{{item.isLike}}">
  57. <image class="flower_btn_icon"
  58. src="{{item.isLike ? '../../static/index/heart_colored.png' : '../../static/index/heart.png'}}" />
  59. <text>{{item.likes}}</text>
  60. </view>
  61. <view class="video_btn comment_btn" catchtap="openComment" data-id="{{item.id}}">
  62. <image class="comment_btn_icon" src="../../static/index/comment.png" lazy-load="true" />
  63. <text>{{item.commentAmount}}</text>
  64. </view>
  65. </view>
  66. </view>
  67. <view class="btn_wrapper" catchtap="goToReading" data-id="{{item.classId}}">
  68. <view class="reading_btn">
  69. <image src="../../static/index/microphone.png" />
  70. <text>我要配音</text>
  71. </view>
  72. </view>
  73. </swiper-item>
  74. </swiper>
  75. <!-- // 非swiper -->
  76. <view wx:if="{{!isSwiper}}" class="swiper_item no_swiper" wx:for="{{sonVideoList}}" data-id="{{item.id}}"
  77. wx:key="id">
  78. <view class="head_box">
  79. <image class="tag_icon" wx:if="{{item.hasTag}}" src="{{item.tagUrl}}" />
  80. <view class="user_box" catchtap="{{ifHeadTap ? 'headTap' : null}}" data-uid="{{item.uid}}">
  81. <image class="avatar" lazy-load="true" src="{{item.avatar}}" />
  82. <image class="avatar_fans" wx:if="{{!item.isFans}}" src="../../static/index/add_follow.png" />
  83. <view class="user_right">
  84. <view class="nickname">{{item.nickName}}</view>
  85. <image class="efun_tag" src="../../static/index/efun_tag.png" wx:if="{{item.isEfun}}"></image>
  86. </view>
  87. </view>
  88. <view wx:if="{{!item.showMyBtn && item.type != 'EXAMPLE'}}" class="time">
  89. <text>发布时间:{{item.time}}</text>
  90. </view>
  91. <view wx:if="{{item.showMyBtn && !item.ifCheck}}" class="my_btn">
  92. <view class="delete" catchtap="download" data-url="{{item.markPath ? item.markPath : '' }}"
  93. data-id="{{item.id}}">
  94. <image class="download_image" src="../../static/index/down.png" />
  95. <text class="delete_text">下载</text>
  96. </view>
  97. <view class="delete" catchtap="delete" data-id="{{item.id}}">
  98. <image class="delete_image" src="../../static/index/delete.png" />
  99. <text class="delete_text">删除</text>
  100. </view>
  101. <view class="hide" catchtap="hide" wx:if="{{!item.activity}}" data-status="{{item.status}}"
  102. data-id="{{item.id}}">
  103. <!-- <image class="hide_image" src="{{item.status==='NORMAL'? '../../static/index/hide_icon.png': '../../static/index/show_icon.png'}}" /> -->
  104. <image class="hide_image"
  105. src="{{item.status==='NORMAL'? '../../static/index/unlock.png': '../../static/index/lock.png'}}" />
  106. <text class="hide_text">{{item.status==='NORMAL'? '公开': '私密'}}</text>
  107. </view>
  108. </view>
  109. </view>
  110. <view class="video_place" wx:if="{{!item.videoShow}}" catchtap="{{item.ifCheck ? null : 'showVideo'}}"
  111. data-index="{{index}}">
  112. <image class="place_img" src="{{item.coverImg}}" />
  113. <image class="play_btn" src="../../static/image/play-btn.png" />
  114. <image class="activity_tigs" wx:if="{{item.activity && item.type != 'EXAMPLE'}}"
  115. src="http://reader-wx.ai160.com/images/reader/activity/activity1.png" />
  116. <view class="video_item_dialog" wx:if="{{item.ifCheck}}">
  117. <image class="video_item_dialog_img" src="../../static/index/checking.png"
  118. mode="aspectFit|aspectFill|widthFix" />
  119. </view>
  120. </view>
  121. <video wx:if="{{item.videoShow}}" id="video_{{index}}" class="video_item" loop="{{loop}}"
  122. show-center-play-btn="{{!item.ifCheck ? true : false}}" controls="{{!item.ifCheck ? true : false}}"
  123. src="{{item.url ? item.url : '' }}" autoplay="{{true}}" object-fit="contain" data-index="{{index}}"
  124. data-id="{{item.id}}" bindplay="onPlayList" bindended="onEndedList" binderror="onError">
  125. </video>
  126. <view class="video_title">
  127. <text>{{item.title}}</text>
  128. </view>
  129. <view class="foot_box" wx:if="{{!item.ifCheck}}">
  130. <view class="foot_left">
  131. <view class="video_btn collect_btn" catchtap="collectTap" data-index="{{index}}" data-id="{{item.id}}"
  132. data-type="{{item.type}}">
  133. <image class="collect_btn_icon"
  134. src="{{item.isFavorite ? '../../static/index/star_colored.png' : '../../static/index/star.png'}}" />
  135. <text>{{item.favoritesAmount === 0 ? '收藏' : item.favoritesAmount}}</text>
  136. </view>
  137. <view class="video_btn share_btn" bindtap="openShare" data-author="{{item.nickName}}"
  138. data-index="{{index}}" data-id="{{item.id}}" data-avatar="{{item.avatar}}" data-uid="{{item.uid}}"
  139. data-img="{{item.img}}" data-title="{{item.title}}" data-shareimg="{{item.shareImg}}"
  140. data-grade="{{item.grade}}" data-type="{{item.type}}" data-activity="{{item.activity}}">
  141. <image class="share_btn_icon" src="../../static/index/share.png" />
  142. <text>{{item.shareAmount === 0 ? '分享' : item.shareAmount}}</text>
  143. </view>
  144. </view>
  145. <view class="foot_right">
  146. <view class="video_btn flower_btn" catchtap="{{item.isLike ? null : 'likeTap'}}" data-index="{{index}}"
  147. data-id="{{item.id}}" data-islike="{{item.isLike}}">
  148. <view class="animation-flower {{addComeOut === index ? 'add-one-come-out' : ''}}">
  149. <image class="animation-flower-icon"
  150. src="{{item.activity ? '../../static/activity/popularity1.png' : '../../static/image/flower_small.png'}}" />
  151. <text>+1</text>
  152. </view>
  153. <image class="flower_btn_icon"
  154. src="{{item.isLike ? '../../static/index/heart_colored.png' : '../../static/index/heart.png'}}" />
  155. <text>{{item.likes === 0 ? '点赞' : item.likes}}</text>
  156. </view>
  157. <view class="video_btn comment_btn" catchtap="openComment" data-id="{{item.id}}" data-index="{{index}}">
  158. <image class="comment_btn_icon" src="../../static/index/comment.png" lazy-load="true" />
  159. <text>{{item.commentAmount === 0 ?'评论' : item.commentAmount}}</text>
  160. </view>
  161. </view>
  162. </view>
  163. <view class="btn_wrapper" wx:if="{{!item.noReading && !item.ifCheck}}" catchtap="goToReading"
  164. data-id="{{item.classId}}">
  165. <view class="reading_btn">
  166. <image src="../../static/index/microphone.png" />
  167. <text>我要配音</text>
  168. </view>
  169. </view>
  170. </view>
  171. <view class="no_work" wx:if="{{!isSwiper && noMoreWork}}">
  172. <text class="no_work_text">已经到底啦!</text>
  173. </view>
  174. </view>
  175. <flowerBox id="flower-toast" flowerNum="{{flowerNum}}" />
  176. <shareDialog id="share-dialog" shareType='works' bindShareDialogClose="shareDialogClose"
  177. bindaddShareAmount="addShareAmount" shareId="{{id}}" />