@quicktvui/ai 1.0.9 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (348) hide show
  1. package/README.md +31 -0
  2. package/USAGE.md +22 -7
  3. package/package.json +1 -1
  4. package/rules/.clinerules +1 -0
  5. package/rules/.cursorrules +1 -0
  6. package/rules/.docs/zh-CN/guide/ai/ai-assistant.md +16 -6
  7. package/rules/.github/copilot-instructions.md +1 -0
  8. package/rules/.source/hellotv/PROJECT-README.md +52 -0
  9. package/rules/.source/hellotv/app.d.ts +11 -0
  10. package/rules/.source/hellotv/package.json +146 -0
  11. package/rules/.source/hellotv/scripts/build-apk.ts +12 -0
  12. package/rules/.source/hellotv/scripts/build.ts +35 -0
  13. package/rules/.source/hellotv/scripts/dev.ts +12 -0
  14. package/rules/.source/hellotv/scripts/pack.ts +24 -0
  15. package/rules/.source/hellotv/scripts/process.ts +37 -0
  16. package/rules/.source/hellotv/scripts/quicktvui-webpack.android.ts +187 -0
  17. package/rules/.source/hellotv/scripts/quicktvui-webpack.dev.ts +147 -0
  18. package/rules/.source/hellotv/scripts/webpack-watch.ts +24 -0
  19. package/rules/.source/hellotv/src/App.vue +192 -0
  20. package/rules/.source/hellotv/src/api/my/index.ts +198 -0
  21. package/rules/.source/hellotv/src/api/user/impl-user.ts +52 -0
  22. package/rules/.source/hellotv/src/api/user/qr-code-mock.ts +2 -0
  23. package/rules/.source/hellotv/src/api/user/request-url.ts +11 -0
  24. package/rules/.source/hellotv/src/api/user/user-manager.ts +258 -0
  25. package/rules/.source/hellotv/src/app.scss +8 -0
  26. package/rules/.source/hellotv/src/assets/component-media/ic_media_btn_pause.png +0 -0
  27. package/rules/.source/hellotv/src/assets/component-media/ic_media_btn_play.png +0 -0
  28. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_setting_focused.png +0 -0
  29. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_setting_normal.png +0 -0
  30. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_xuanji_focused.png +0 -0
  31. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_xuanji_normal.png +0 -0
  32. package/rules/.source/hellotv/src/assets/component-media/ic_media_ok_focused.png +0 -0
  33. package/rules/.source/hellotv/src/assets/component-media/ic_media_ok_selected.png +0 -0
  34. package/rules/.source/hellotv/src/assets/detail/ic_collect_focused.png +0 -0
  35. package/rules/.source/hellotv/src/assets/detail/ic_collect_normal.png +0 -0
  36. package/rules/.source/hellotv/src/assets/detail/ic_full_focused.png +0 -0
  37. package/rules/.source/hellotv/src/assets/detail/ic_full_normal.png +0 -0
  38. package/rules/.source/hellotv/src/assets/detail/ic_info_focused.png +0 -0
  39. package/rules/.source/hellotv/src/assets/detail/ic_info_normal.png +0 -0
  40. package/rules/.source/hellotv/src/assets/detail/ic_introduction_bg.png +0 -0
  41. package/rules/.source/hellotv/src/assets/detail/ic_media_list_item_normal.png +0 -0
  42. package/rules/.source/hellotv/src/assets/detail/ic_media_list_item_selected.png +0 -0
  43. package/rules/.source/hellotv/src/assets/detail/ic_media_player_pause.png +0 -0
  44. package/rules/.source/hellotv/src/assets/detail/ic_media_player_placeholder.png +0 -0
  45. package/rules/.source/hellotv/src/assets/detail/ic_media_player_play.png +0 -0
  46. package/rules/.source/hellotv/src/assets/detail/ic_vip_focused.png +0 -0
  47. package/rules/.source/hellotv/src/assets/detail/ic_vip_normal.png +0 -0
  48. package/rules/.source/hellotv/src/assets/detail/skeleton.png +0 -0
  49. package/rules/.source/hellotv/src/assets/filter/ic_empty.png +0 -0
  50. package/rules/.source/hellotv/src/assets/filter/ic_filter_focused.png +0 -0
  51. package/rules/.source/hellotv/src/assets/filter/ic_filter_normal.png +0 -0
  52. package/rules/.source/hellotv/src/assets/filter/ic_filter_selected.png +0 -0
  53. package/rules/.source/hellotv/src/assets/filter/ic_left_focused.png +0 -0
  54. package/rules/.source/hellotv/src/assets/filter/ic_left_normal.png +0 -0
  55. package/rules/.source/hellotv/src/assets/filter/ic_left_selected.png +0 -0
  56. package/rules/.source/hellotv/src/assets/history/ic_delete.png +0 -0
  57. package/rules/.source/hellotv/src/assets/history/ic_empty.png +0 -0
  58. package/rules/.source/hellotv/src/assets/home/bg_history_item.png +0 -0
  59. package/rules/.source/hellotv/src/assets/home/bg_shadow.png +0 -0
  60. package/rules/.source/hellotv/src/assets/home/ic_4k_logo.png +0 -0
  61. package/rules/.source/hellotv/src/assets/home/ic_4k_play_focused.png +0 -0
  62. package/rules/.source/hellotv/src/assets/home/ic_4k_subtitle_normal.png +0 -0
  63. package/rules/.source/hellotv/src/assets/home/ic_arrow_focused.png +0 -0
  64. package/rules/.source/hellotv/src/assets/home/ic_arrow_normal.png +0 -0
  65. package/rules/.source/hellotv/src/assets/home/ic_exit_corner.png +0 -0
  66. package/rules/.source/hellotv/src/assets/home/ic_exit_header.png +0 -0
  67. package/rules/.source/hellotv/src/assets/home/ic_play.png +0 -0
  68. package/rules/.source/hellotv/src/assets/live/bg-error.png +0 -0
  69. package/rules/.source/hellotv/src/assets/live/bg-play-info.png +0 -0
  70. package/rules/.source/hellotv/src/assets/live/ic-arrow-left.png +0 -0
  71. package/rules/.source/hellotv/src/assets/live/ic-arrow-right.png +0 -0
  72. package/rules/.source/hellotv/src/assets/live/ic-back.png +0 -0
  73. package/rules/.source/hellotv/src/assets/live/ic-change.png +0 -0
  74. package/rules/.source/hellotv/src/assets/live/ic-corner-vip-tips.png +0 -0
  75. package/rules/.source/hellotv/src/assets/live/ic-corner-vip.png +0 -0
  76. package/rules/.source/hellotv/src/assets/live/ic-key.png +0 -0
  77. package/rules/.source/hellotv/src/assets/live/ic-loading-error.png +0 -0
  78. package/rules/.source/hellotv/src/assets/live/ic-menu-ext-arrow.png +0 -0
  79. package/rules/.source/hellotv/src/assets/live/ic-menu-ext.png +0 -0
  80. package/rules/.source/hellotv/src/assets/live/ic-menu.png +0 -0
  81. package/rules/.source/hellotv/src/assets/live/ic-mine.png +0 -0
  82. package/rules/.source/hellotv/src/assets/live/ic-network-error.png +0 -0
  83. package/rules/.source/hellotv/src/assets/live/ic-ok.png +0 -0
  84. package/rules/.source/hellotv/src/assets/live/ic-playing.png +0 -0
  85. package/rules/.source/hellotv/src/assets/live/ic-playing2.png +0 -0
  86. package/rules/.source/hellotv/src/assets/live/ic-playing3.png +0 -0
  87. package/rules/.source/hellotv/src/assets/live/ic-service.png +0 -0
  88. package/rules/.source/hellotv/src/assets/live/ic_live_broadcast.png +0 -0
  89. package/rules/.source/hellotv/src/assets/live/ic_live_broadcast_focused.png +0 -0
  90. package/rules/.source/hellotv/src/assets/my/ic_collect_focus.png +0 -0
  91. package/rules/.source/hellotv/src/assets/my/ic_collect_normal.png +0 -0
  92. package/rules/.source/hellotv/src/assets/my/ic_order_focus.png +0 -0
  93. package/rules/.source/hellotv/src/assets/my/ic_order_normal.png +0 -0
  94. package/rules/.source/hellotv/src/assets/my/ic_record_focus.png +0 -0
  95. package/rules/.source/hellotv/src/assets/my/ic_record_normal.png +0 -0
  96. package/rules/.source/hellotv/src/assets/my/ic_user.png +0 -0
  97. package/rules/.source/hellotv/src/assets/my/ic_vip_normal.png +0 -0
  98. package/rules/.source/hellotv/src/assets/search/ic_back.png +0 -0
  99. package/rules/.source/hellotv/src/assets/search/ic_back_focused.png +0 -0
  100. package/rules/.source/hellotv/src/assets/search/ic_clear.png +0 -0
  101. package/rules/.source/hellotv/src/assets/search/ic_clear_dark.png +0 -0
  102. package/rules/.source/hellotv/src/assets/search/ic_clear_focused.png +0 -0
  103. package/rules/.source/hellotv/src/assets/search/ic_search.png +0 -0
  104. package/rules/.source/hellotv/src/assets/top-view/ic_logo.png +0 -0
  105. package/rules/.source/hellotv/src/assets/top-view/ic_top_search_focused.png +0 -0
  106. package/rules/.source/hellotv/src/assets/top-view/ic_top_search_normal.png +0 -0
  107. package/rules/.source/hellotv/src/assets/top-view/ic_top_user_focused.png +0 -0
  108. package/rules/.source/hellotv/src/assets/top-view/ic_top_user_normal.png +0 -0
  109. package/rules/.source/hellotv/src/components/bg-animation.scss +14 -0
  110. package/rules/.source/hellotv/src/components/bg-animation.vue +176 -0
  111. package/rules/.source/hellotv/src/components/btn-pack-view.vue +172 -0
  112. package/rules/.source/hellotv/src/components/btn-pack.scss +53 -0
  113. package/rules/.source/hellotv/src/components/grid-item-horizontal.vue +203 -0
  114. package/rules/.source/hellotv/src/components/grid-item-vertical.vue +201 -0
  115. package/rules/.source/hellotv/src/components/media/build-data/media-config.ts +4 -0
  116. package/rules/.source/hellotv/src/components/media/build-data/media-control-adapter.ts +378 -0
  117. package/rules/.source/hellotv/src/components/media/build-data/media-imp.ts +44 -0
  118. package/rules/.source/hellotv/src/components/media/view/media-loading-component.vue +50 -0
  119. package/rules/.source/hellotv/src/components/media/view/media-loading-view.vue +154 -0
  120. package/rules/.source/hellotv/src/components/media/view/media-manager-view.vue +931 -0
  121. package/rules/.source/hellotv/src/components/media/view/media-menu-detail-item.vue +42 -0
  122. package/rules/.source/hellotv/src/components/media/view/media-menu-detail-view.vue +109 -0
  123. package/rules/.source/hellotv/src/components/media/view/media-menu-icon-item.vue +43 -0
  124. package/rules/.source/hellotv/src/components/media/view/media-menu-text-item.vue +27 -0
  125. package/rules/.source/hellotv/src/components/media/view/media-menu-view.vue +88 -0
  126. package/rules/.source/hellotv/src/components/media/view/media-player-view.vue +408 -0
  127. package/rules/.source/hellotv/src/components/media/view/scss/media-loading.scss +51 -0
  128. package/rules/.source/hellotv/src/components/media/view/scss/media-manager.scss +79 -0
  129. package/rules/.source/hellotv/src/components/media/view/scss/media-menu.scss +114 -0
  130. package/rules/.source/hellotv/src/components/media/view/scss/media-player.scss +6 -0
  131. package/rules/.source/hellotv/src/components/qt-tabs-component.ts +268 -0
  132. package/rules/.source/hellotv/src/components/qt-ul-component.ts +792 -0
  133. package/rules/.source/hellotv/src/components/top-view.scss +38 -0
  134. package/rules/.source/hellotv/src/components/top-view.vue +114 -0
  135. package/rules/.source/hellotv/src/config/README.md +22 -0
  136. package/rules/.source/hellotv/src/config/build-config.ts +22 -0
  137. package/rules/.source/hellotv/src/config/private-theme-config.ts +21 -0
  138. package/rules/.source/hellotv/src/config/public-config.scss +16 -0
  139. package/rules/.source/hellotv/src/config/test.scss +45 -0
  140. package/rules/.source/hellotv/src/config/theme-config.ts +51 -0
  141. package/rules/.source/hellotv/src/main.ts +45 -0
  142. package/rules/.source/hellotv/src/pages/activity/adapter/config.ts +37 -0
  143. package/rules/.source/hellotv/src/pages/activity/adapter/index.ts +849 -0
  144. package/rules/.source/hellotv/src/pages/activity/adapter/interface.ts +173 -0
  145. package/rules/.source/hellotv/src/pages/activity/api/index.ts +36 -0
  146. package/rules/.source/hellotv/src/pages/activity/api/interface.ts +11 -0
  147. package/rules/.source/hellotv/src/pages/activity/api/request-url.ts +10 -0
  148. package/rules/.source/hellotv/src/pages/activity/components/item/focus-change-img-item.vue +40 -0
  149. package/rules/.source/hellotv/src/pages/activity/components/item/inner-out-title-item.vue +59 -0
  150. package/rules/.source/hellotv/src/pages/activity/components/item/no-title-item.vue +45 -0
  151. package/rules/.source/hellotv/src/pages/activity/components/item/placeholder-item.vue +25 -0
  152. package/rules/.source/hellotv/src/pages/activity/index.vue +219 -0
  153. package/rules/.source/hellotv/src/pages/activity/scss/index.scss +46 -0
  154. package/rules/.source/hellotv/src/pages/activity/scss/item.scss +69 -0
  155. package/rules/.source/hellotv/src/pages/detail/adapter/index.ts +317 -0
  156. package/rules/.source/hellotv/src/pages/detail/adapter/interface.ts +150 -0
  157. package/rules/.source/hellotv/src/pages/detail/adapter/media-player.ts +378 -0
  158. package/rules/.source/hellotv/src/pages/detail/api/index.ts +77 -0
  159. package/rules/.source/hellotv/src/pages/detail/api/request-url.ts +8 -0
  160. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-definition.vue +192 -0
  161. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-list-item.vue +108 -0
  162. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-media-series.vue +349 -0
  163. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-order.vue +194 -0
  164. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-speed.vue +192 -0
  165. package/rules/.source/hellotv/src/pages/detail/components/media-player/index.vue +404 -0
  166. package/rules/.source/hellotv/src/pages/detail/components/media-player/media-player-small-view.vue +382 -0
  167. package/rules/.source/hellotv/src/pages/detail/components/media-player/media-player-view.vue +1099 -0
  168. package/rules/.source/hellotv/src/pages/detail/components/recommend-item.vue +167 -0
  169. package/rules/.source/hellotv/src/pages/detail/components/section/basic-section.vue +218 -0
  170. package/rules/.source/hellotv/src/pages/detail/components/section/config.ts +6 -0
  171. package/rules/.source/hellotv/src/pages/detail/components/section/header-section.vue +15 -0
  172. package/rules/.source/hellotv/src/pages/detail/components/section/item/button-menu.vue +259 -0
  173. package/rules/.source/hellotv/src/pages/detail/components/section/item/media-introduction.vue +238 -0
  174. package/rules/.source/hellotv/src/pages/detail/components/section/item/media-series.vue +308 -0
  175. package/rules/.source/hellotv/src/pages/detail/components/section/item/player-placeholder.vue +88 -0
  176. package/rules/.source/hellotv/src/pages/detail/index.vue +571 -0
  177. package/rules/.source/hellotv/src/pages/detail/scss/index.scss +22 -0
  178. package/rules/.source/hellotv/src/pages/detail-full-player/components/media-player/full-player-loading.vue +78 -0
  179. package/rules/.source/hellotv/src/pages/detail-full-player/components/media-player/full-player-menu-view.vue +803 -0
  180. package/rules/.source/hellotv/src/pages/detail-full-player/components/media-player/full-player-view.vue +219 -0
  181. package/rules/.source/hellotv/src/pages/detail-full-player/index.vue +101 -0
  182. package/rules/.source/hellotv/src/pages/detail-full-player/scss/full-player-view.scss +6 -0
  183. package/rules/.source/hellotv/src/pages/detail-full-screen/adapter/index.ts +0 -0
  184. package/rules/.source/hellotv/src/pages/detail-full-screen/adapter/interface.ts +133 -0
  185. package/rules/.source/hellotv/src/pages/detail-full-screen/api/index.ts +77 -0
  186. package/rules/.source/hellotv/src/pages/detail-full-screen/api/request-url.ts +8 -0
  187. package/rules/.source/hellotv/src/pages/detail-full-screen/components/media-info.vue +263 -0
  188. package/rules/.source/hellotv/src/pages/detail-full-screen/components/media-player.vue +42 -0
  189. package/rules/.source/hellotv/src/pages/detail-full-screen/components/media-series-section.vue +26 -0
  190. package/rules/.source/hellotv/src/pages/detail-full-screen/components/recommend-item.vue +167 -0
  191. package/rules/.source/hellotv/src/pages/detail-full-screen/index.vue +163 -0
  192. package/rules/.source/hellotv/src/pages/detail-full-screen/scss/index.scss +41 -0
  193. package/rules/.source/hellotv/src/pages/device-info/index.vue +106 -0
  194. package/rules/.source/hellotv/src/pages/device-info/scss/device-info.scss +49 -0
  195. package/rules/.source/hellotv/src/pages/filter/README.md +66 -0
  196. package/rules/.source/hellotv/src/pages/filter/adapter/index.ts +180 -0
  197. package/rules/.source/hellotv/src/pages/filter/adapter/interface.ts +111 -0
  198. package/rules/.source/hellotv/src/pages/filter/api/index.ts +38 -0
  199. package/rules/.source/hellotv/src/pages/filter/api/interface.ts +44 -0
  200. package/rules/.source/hellotv/src/pages/filter/api/request-url.ts +8 -0
  201. package/rules/.source/hellotv/src/pages/filter/components/content/index.vue +469 -0
  202. package/rules/.source/hellotv/src/pages/filter/components/content/list-item-record.vue +16 -0
  203. package/rules/.source/hellotv/src/pages/filter/components/content/list-item.vue +78 -0
  204. package/rules/.source/hellotv/src/pages/filter/components/expand/index.vue +83 -0
  205. package/rules/.source/hellotv/src/pages/filter/components/sidebar/index.vue +81 -0
  206. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-filter-title.vue +78 -0
  207. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-filter.vue +68 -0
  208. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-line.vue +11 -0
  209. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-text.vue +43 -0
  210. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-title.vue +14 -0
  211. package/rules/.source/hellotv/src/pages/filter/config.ts +10 -0
  212. package/rules/.source/hellotv/src/pages/filter/expand-sidebar-contents.vue +203 -0
  213. package/rules/.source/hellotv/src/pages/filter/scss/filter-content-list-item.scss +42 -0
  214. package/rules/.source/hellotv/src/pages/filter/scss/filter-content.scss +60 -0
  215. package/rules/.source/hellotv/src/pages/filter/scss/filter-expand.scss +30 -0
  216. package/rules/.source/hellotv/src/pages/filter/scss/filter-sidebar.scss +45 -0
  217. package/rules/.source/hellotv/src/pages/filter/scss/filter.scss +21 -0
  218. package/rules/.source/hellotv/src/pages/filter/sidebar-contents.vue +145 -0
  219. package/rules/.source/hellotv/src/pages/filter/single-contents.vue +61 -0
  220. package/rules/.source/hellotv/src/pages/history/adapter/index.ts +51 -0
  221. package/rules/.source/hellotv/src/pages/history/adapter/interface.ts +22 -0
  222. package/rules/.source/hellotv/src/pages/history/api/index.ts +54 -0
  223. package/rules/.source/hellotv/src/pages/history/api/interface.ts +41 -0
  224. package/rules/.source/hellotv/src/pages/history/api/request-url.ts +10 -0
  225. package/rules/.source/hellotv/src/pages/history/components/confirm-dialog.vue +155 -0
  226. package/rules/.source/hellotv/src/pages/history/config.ts +8 -0
  227. package/rules/.source/hellotv/src/pages/history/index-raw.vue +540 -0
  228. package/rules/.source/hellotv/src/pages/history/index.vue +431 -0
  229. package/rules/.source/hellotv/src/pages/history/mock.ts +32 -0
  230. package/rules/.source/hellotv/src/pages/history/scss/history-raw.scss +181 -0
  231. package/rules/.source/hellotv/src/pages/history/scss/history.scss +148 -0
  232. package/rules/.source/hellotv/src/pages/home/adapter/exit/home-exit-adapter.ts +20 -0
  233. package/rules/.source/hellotv/src/pages/home/adapter/exit/home-exit-imp.ts +13 -0
  234. package/rules/.source/hellotv/src/pages/home/adapter/media/create-home-player-interceptor.ts +50 -0
  235. package/rules/.source/hellotv/src/pages/home/adapter/media/home-media-imp.ts +74 -0
  236. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-adapter.ts +151 -0
  237. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-config.ts +17 -0
  238. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-imp.ts +53 -0
  239. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-item-type.ts +6 -0
  240. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-adapter.ts +1304 -0
  241. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-config.ts +30 -0
  242. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-imp.ts +173 -0
  243. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-item-type.ts +17 -0
  244. package/rules/.source/hellotv/src/pages/home/api/index.ts +157 -0
  245. package/rules/.source/hellotv/src/pages/home/api/interface.ts +56 -0
  246. package/rules/.source/hellotv/src/pages/home/api/request-url.ts +22 -0
  247. package/rules/.source/hellotv/src/pages/home/components/exit-dialog.vue +148 -0
  248. package/rules/.source/hellotv/src/pages/home/components/media/bg-player.vue +440 -0
  249. package/rules/.source/hellotv/src/pages/home/components/nav-bar/bar-img-item.vue +39 -0
  250. package/rules/.source/hellotv/src/pages/home/components/nav-bar/bar-text-item.vue +100 -0
  251. package/rules/.source/hellotv/src/pages/home/components/tab-content/bg-player-cell-list-item-img.vue +54 -0
  252. package/rules/.source/hellotv/src/pages/home/components/tab-content/bg-player-cell-list-item-text.vue +67 -0
  253. package/rules/.source/hellotv/src/pages/home/components/tab-content/cell-list-player-item.vue +74 -0
  254. package/rules/.source/hellotv/src/pages/home/components/tab-content/cell-player-item.vue +40 -0
  255. package/rules/.source/hellotv/src/pages/home/components/tab-content/focus-change-img-item.vue +41 -0
  256. package/rules/.source/hellotv/src/pages/home/components/tab-content/history-item.vue +362 -0
  257. package/rules/.source/hellotv/src/pages/home/components/tab-content/inner-out-title-item.vue +60 -0
  258. package/rules/.source/hellotv/src/pages/home/components/tab-content/no-title-item.vue +46 -0
  259. package/rules/.source/hellotv/src/pages/home/components/tab-content/placeholder-item.vue +25 -0
  260. package/rules/.source/hellotv/src/pages/home/components/tab-content/short-video/short-video-section-item.vue +80 -0
  261. package/rules/.source/hellotv/src/pages/home/components/tab-content/short-video/short-video-section.vue +70 -0
  262. package/rules/.source/hellotv/src/pages/home/components/tab-content/small-4k/small-four-section.vue +76 -0
  263. package/rules/.source/hellotv/src/pages/home/components/tab-content/world-4k/world-four-section-item.vue +90 -0
  264. package/rules/.source/hellotv/src/pages/home/components/tab-content/world-4k/world-four-section.vue +57 -0
  265. package/rules/.source/hellotv/src/pages/home/components/waterfall-tabs.vue +1307 -0
  266. package/rules/.source/hellotv/src/pages/home/index.vue +117 -0
  267. package/rules/.source/hellotv/src/pages/home/scss/bar-img-item.scss +11 -0
  268. package/rules/.source/hellotv/src/pages/home/scss/bar-text-item.scss +80 -0
  269. package/rules/.source/hellotv/src/pages/home/scss/base.scss +8 -0
  270. package/rules/.source/hellotv/src/pages/home/scss/bg-player-cell-list-item.scss +24 -0
  271. package/rules/.source/hellotv/src/pages/home/scss/bg-player.scss +50 -0
  272. package/rules/.source/hellotv/src/pages/home/scss/cell-player-item.scss +24 -0
  273. package/rules/.source/hellotv/src/pages/home/scss/exit-dialog.scss +89 -0
  274. package/rules/.source/hellotv/src/pages/home/scss/focus-change-img-item.scss +12 -0
  275. package/rules/.source/hellotv/src/pages/home/scss/home.scss +32 -0
  276. package/rules/.source/hellotv/src/pages/home/scss/inner-out-title-item.scss +24 -0
  277. package/rules/.source/hellotv/src/pages/home/scss/no-title-item.scss +15 -0
  278. package/rules/.source/hellotv/src/pages/home/scss/placeholder-item.scss +14 -0
  279. package/rules/.source/hellotv/src/pages/home/scss/short-video-section.scss +59 -0
  280. package/rules/.source/hellotv/src/pages/home/scss/small-four-section.scss +14 -0
  281. package/rules/.source/hellotv/src/pages/home/scss/waterfall-tabs.scss +50 -0
  282. package/rules/.source/hellotv/src/pages/home/scss/world-four-section.scss +106 -0
  283. package/rules/.source/hellotv/src/pages/introduction/index.vue +227 -0
  284. package/rules/.source/hellotv/src/pages/live/components/menu/first-list-item-icon-text.vue +35 -0
  285. package/rules/.source/hellotv/src/pages/live/components/menu/first-list-item-img.vue +16 -0
  286. package/rules/.source/hellotv/src/pages/live/components/menu/first-list-item-text.vue +16 -0
  287. package/rules/.source/hellotv/src/pages/live/components/menu/index.vue +266 -0
  288. package/rules/.source/hellotv/src/pages/live/components/menu/second-list-item.vue +80 -0
  289. package/rules/.source/hellotv/src/pages/live/components/menu/third-list-item.vue +68 -0
  290. package/rules/.source/hellotv/src/pages/live/components/player/index.vue +168 -0
  291. package/rules/.source/hellotv/src/pages/live/components/player/player-error.vue +48 -0
  292. package/rules/.source/hellotv/src/pages/live/components/player/player-loading.vue +50 -0
  293. package/rules/.source/hellotv/src/pages/live/components/player/player-tips.vue +125 -0
  294. package/rules/.source/hellotv/src/pages/live/components/player/tips-icon-text.vue +27 -0
  295. package/rules/.source/hellotv/src/pages/live/css/menu.css +109 -0
  296. package/rules/.source/hellotv/src/pages/live/css/player.css +56 -0
  297. package/rules/.source/hellotv/src/pages/live/index.vue +128 -0
  298. package/rules/.source/hellotv/src/pages/live/mock/index.ts +263 -0
  299. package/rules/.source/hellotv/src/pages/live/types/index.ts +42 -0
  300. package/rules/.source/hellotv/src/pages/login/index.vue +116 -0
  301. package/rules/.source/hellotv/src/pages/login/scss/login.scss +61 -0
  302. package/rules/.source/hellotv/src/pages/m-test.vue +84 -0
  303. package/rules/.source/hellotv/src/pages/my/README.md +87 -0
  304. package/rules/.source/hellotv/src/pages/my/index.vue +177 -0
  305. package/rules/.source/hellotv/src/pages/my/my-data-manager.ts +606 -0
  306. package/rules/.source/hellotv/src/pages/my/my-templates.vue +24 -0
  307. package/rules/.source/hellotv/src/pages/my/poster/index.vue +98 -0
  308. package/rules/.source/hellotv/src/pages/my/poster/my-card2.vue +90 -0
  309. package/rules/.source/hellotv/src/pages/my/poster/my-icon-title-col.vue +72 -0
  310. package/rules/.source/hellotv/src/pages/my/poster/my-icon-title-row.vue +72 -0
  311. package/rules/.source/hellotv/src/pages/my/poster/my-info.vue +50 -0
  312. package/rules/.source/hellotv/src/pages/my/poster/my-user.vue +126 -0
  313. package/rules/.source/hellotv/src/pages/play-test.vue +95 -0
  314. package/rules/.source/hellotv/src/pages/search/README.md +57 -0
  315. package/rules/.source/hellotv/src/pages/search/adapter/index.ts +285 -0
  316. package/rules/.source/hellotv/src/pages/search/adapter/interface.ts +60 -0
  317. package/rules/.source/hellotv/src/pages/search/api/index.ts +100 -0
  318. package/rules/.source/hellotv/src/pages/search/api/interface.ts +64 -0
  319. package/rules/.source/hellotv/src/pages/search/api/request-url.ts +20 -0
  320. package/rules/.source/hellotv/src/pages/search/components/search-content-tabs.vue +153 -0
  321. package/rules/.source/hellotv/src/pages/search/components/search-content.vue +282 -0
  322. package/rules/.source/hellotv/src/pages/search/components/search-keyboard.vue +252 -0
  323. package/rules/.source/hellotv/src/pages/search/components/search-keyword-grid.vue +85 -0
  324. package/rules/.source/hellotv/src/pages/search/components/search-keyword.vue +346 -0
  325. package/rules/.source/hellotv/src/pages/search/config.ts +10 -0
  326. package/rules/.source/hellotv/src/pages/search/scss/search-content.scss +130 -0
  327. package/rules/.source/hellotv/src/pages/search/scss/search-keyboard.scss +91 -0
  328. package/rules/.source/hellotv/src/pages/search/scss/search-keyword-grid.scss +30 -0
  329. package/rules/.source/hellotv/src/pages/search/scss/search-keyword.scss +104 -0
  330. package/rules/.source/hellotv/src/pages/search/scss/search.scss +18 -0
  331. package/rules/.source/hellotv/src/pages/search/three-columns.vue +164 -0
  332. package/rules/.source/hellotv/src/pages/search/two-columns.vue +128 -0
  333. package/rules/.source/hellotv/src/pages/tabs-test.vue +339 -0
  334. package/rules/.source/hellotv/src/pages/webview/load-web-view.vue +44 -0
  335. package/rules/.source/hellotv/src/routes.ts +142 -0
  336. package/rules/.source/hellotv/src/tools/common.ts +18 -0
  337. package/rules/.source/hellotv/src/tools/format-date.ts +16 -0
  338. package/rules/.source/hellotv/src/tools/index.ts +58 -0
  339. package/rules/.source/hellotv/src/tools/launch.ts +339 -0
  340. package/rules/.source/hellotv/src/tools/request/index.ts +206 -0
  341. package/rules/.source/hellotv/src/tools/request/interface.ts +64 -0
  342. package/rules/.source/hellotv/src/typings/shims-vue.d.ts +6 -0
  343. package/rules/.source/hellotv/src/vue.config.js +3 -0
  344. package/rules/.source/hellotv/tsconfig.json +34 -0
  345. package/rules/.windsurfrules +1 -0
  346. package/rules/AGENTS.md +1 -0
  347. package/rules/CLAUDE.md +1 -0
  348. package/rules/GEMINI.md +1 -0
@@ -0,0 +1,803 @@
1
+ <template>
2
+ <qt-view class="full-player-menu-view" name="mediaRoot" :focusable="false">
3
+ <!-- 顶部条 -->
4
+ <qt-view
5
+ class="full-player-menu-view-title"
6
+ v-if="isTitleBarShowing"
7
+ :gradientBackground="{ colors: ['#E6000000', '#00000000'] }"
8
+ >
9
+ <qt-text
10
+ class="full-player-menu-view-title-text"
11
+ :focusable="false"
12
+ :fontSize="30"
13
+ :text="mediaTitle"
14
+ />
15
+ </qt-view>
16
+ <!-- 底部进度条 -->
17
+ <qt-view class="full-player-menu-view-bottom" :visible="isProgressShowing">
18
+ <!-- 进度条背景渐变 -->
19
+ <qt-view
20
+ class="full-player-menu-view-bottom-bg"
21
+ :gradientBackground="{ colors: ['#00000000', '#E6000000'] }"
22
+ />
23
+ <div class="full-player-menu-view-state-progress">
24
+ <!-- 播放状态 -->
25
+ <div class="full-player-menu-state-img">
26
+ <img
27
+ :visible="!isPlayerPlaying"
28
+ :focusable="false"
29
+ :src="playIcon"
30
+ postDelay="100"
31
+ />
32
+ <img
33
+ :visible="isPlayerPlaying"
34
+ :focusable="false"
35
+ :src="pauseIcon"
36
+ postDelay="100"
37
+ />
38
+ </div>
39
+ <!-- 进度条-->
40
+ <div class="full-player-menu-progress" :autofocus="autofocusType === 0">
41
+ <qt-text
42
+ class="full-player-menu-progress-text"
43
+ :focusable="false"
44
+ gravity="center"
45
+ :fontSize="30"
46
+ :text="progress"
47
+ />
48
+ <qt-seek-bar
49
+ class="full-player-menu-progress-seekbar"
50
+ ref="seekBarRef"
51
+ name="seekBar"
52
+ :blockFocusDirections="['left', 'right', 'up']"
53
+ :color="{ startColor: '#FFFFFF', endColor: '#FFFFFF' }"
54
+ :nextFocusName="{ left: 'seekBar', right: 'seekBar' }"
55
+ :focusable="true"
56
+ @onSeekStart="onSeekBarSeekStart"
57
+ @onSeekStop="onSeekBarSeekStop"
58
+ @focus="onSeekbarFocusChanged"
59
+ />
60
+ <qt-text
61
+ class="full-player-menu-progress-text"
62
+ :focusable="false"
63
+ gravity="center"
64
+ :fontSize="30"
65
+ :text="duration"
66
+ />
67
+ </div>
68
+ <!-- 下一个按钮-->
69
+ <div
70
+ class="full-player-menu-next"
71
+ :nextFocusName="{
72
+ up: 'seekBar',
73
+ down: 'nextButton',
74
+ right: 'nextButton',
75
+ left: 'nextButton',
76
+ }"
77
+ :focusable="true"
78
+ name="nextButton"
79
+ :visible="mediaSeriesVisible"
80
+ @click="onNextButtonClicked"
81
+ @focus="onNextButtonFocusChanged"
82
+ >
83
+ <div
84
+ class="full-player-menu-next-text-focus"
85
+ :focusable="false"
86
+ showOnState="focused"
87
+ duplicateParentState
88
+ :gradientBackground="{
89
+ colors: ThemeConfig.btnGradientFocusColor,
90
+ cornerRadius: 8,
91
+ orientation: 6,
92
+ }"
93
+ ></div>
94
+ <qt-text
95
+ class="full-player-menu-next-text"
96
+ gravity="center"
97
+ typeface="bold"
98
+ :focusable="false"
99
+ duplicateParentState
100
+ :fontSize="30"
101
+ text="下一个"
102
+ />
103
+ </div>
104
+ </div>
105
+ </qt-view>
106
+ <!-- 底部菜单 -->
107
+ <qt-view class="full-player-menu-list" :visible="isMenuShowing">
108
+ <qt-view
109
+ class="full-player-menu-list-bg"
110
+ :gradientBackground="{ colors: ['#00000000', '#E6000000'] }"
111
+ />
112
+ <qt-collapse
113
+ ref="mediaCollapseRef"
114
+ :visible="isMenuShowing"
115
+ v-if="mediaCollapseMenuInit"
116
+ class="full-player-menu-list-collapse"
117
+ >
118
+ <media-collapse-order
119
+ ref="mediaCollapseOrderRef"
120
+ :blockFocusDirections="['left', 'right', 'down', 'up']"
121
+ name="mediaCollapseOrder"
122
+ @onCollapseItemFocused="onCollapseItemOrderFocused"
123
+ @onCollapseItemClicked="onCollapseItemOrderClicked"
124
+ />
125
+ <media-collapse-speed
126
+ ref="mediaCollapseSpeedRef"
127
+ :blockFocusDirections="['left', 'right', 'up']"
128
+ name="mediaCollapseSpeed"
129
+ @onCollapseItemFocused="onCollapseItemSpeedFocused"
130
+ @onCollapseItemClicked="onCollapseItemSpeedClicked"
131
+ />
132
+ <media-collapse-definition
133
+ ref="mediaCollapseDefinitionRef"
134
+ :blockFocusDirections="['left', 'right']"
135
+ name="mediaCollapseDefinition"
136
+ @onCollapseItemFocused="onCollapseItemDefinitionFocused"
137
+ @onCollapseItemClicked="onCollapseItemDefinitionClicked"
138
+ />
139
+ <media-collapse-media-series
140
+ ref="mediaCollapseMediaSeriesRef"
141
+ :blockFocusDirections="['left', 'right', 'down']"
142
+ name="mediaCollapseMediaSeries"
143
+ @onMediaSeriesGroupItemFocus="onMediaSeriesGroupItemFocus"
144
+ @onMediaSeriesItemFocus="onMediaSeriesItemFocus"
145
+ @onMediaSeriesItemClick="onMediaSeriesItemClick"
146
+ />
147
+ </qt-collapse>
148
+ </qt-view>
149
+ </qt-view>
150
+ </template>
151
+
152
+ <script lang="ts" setup>
153
+ import {
154
+ ESKeyCode,
155
+ ESKeyEvent,
156
+ ESLogLevel,
157
+ useESEventBus,
158
+ } from "@extscreen/es3-core";
159
+ import {
160
+ ESPlayerDefinition,
161
+ ESPlayerPlayMode,
162
+ ESPlayerRate,
163
+ } from "@extscreen/es3-player";
164
+ import { ESIPlayerManager, ESMediaItem } from "@extscreen/es3-player-manager";
165
+ import {
166
+ QTCollapse,
167
+ QTICollapse,
168
+ QTISeekBar,
169
+ QTListViewItem,
170
+ } from "@quicktvui/quicktvui3";
171
+ import { nextTick, onMounted, onUnmounted, ref, watch } from "vue";
172
+ import BuildConfig from "../../../../config/build-config";
173
+ import ThemeConfig from "../../../../config/theme-config";
174
+ import playIcon from "../../../../assets/detail/ic_media_player_play.png";
175
+ import pauseIcon from "../../../../assets/detail/ic_media_player_pause.png";
176
+ import {
177
+ IMediaViewState,
178
+ s_to_hs,
179
+ } from "../../../../components/media/build-data/media-control-adapter";
180
+ import {
181
+ IMediaCollapseItemListView,
182
+ IMediaCollapseMediaSeriesView,
183
+ IMediaItem,
184
+ IMediaPlayerViewState,
185
+ } from "../../../detail/adapter/interface";
186
+ import {
187
+ buildCollapseMenu,
188
+ buildDefinitionList,
189
+ buildPlayModeList,
190
+ buildPlayRateList,
191
+ getDefinitionIndex,
192
+ getPlayModeIndex,
193
+ getPlayRateIndex,
194
+ } from "../../../detail/adapter/media-player";
195
+ import MediaCollapseDefinition from "../../../detail/components/media-player/collapse/media-collapse-definition.vue";
196
+ import MediaCollapseMediaSeries from "../../../detail/components/media-player/collapse/media-collapse-media-series.vue";
197
+ import MediaCollapseOrder from "../../../detail/components/media-player/collapse/media-collapse-order.vue";
198
+ import MediaCollapseSpeed from "../../../detail/components/media-player/collapse/media-collapse-speed.vue";
199
+
200
+ defineOptions({
201
+ name: "FullPlayerMenuView",
202
+ });
203
+ const eventBus = useESEventBus();
204
+ /***************组件声明********************/
205
+ const seekBarRef = ref<QTISeekBar>();
206
+ const mediaCollapseRef = ref<QTICollapse>();
207
+ const mediaCollapseOrderRef = ref<IMediaCollapseItemListView>();
208
+ const mediaCollapseSpeedRef = ref<IMediaCollapseItemListView>();
209
+ const mediaCollapseDefinitionRef = ref<IMediaCollapseItemListView>();
210
+ const mediaCollapseMediaSeriesRef = ref<IMediaCollapseMediaSeriesView>();
211
+
212
+ /**************播放器相关**********************/
213
+ //播放管理类
214
+ let playerManager: ESIPlayerManager;
215
+ const isPlayerPlaying = ref<boolean>(true);
216
+ const progress = ref<string>("00:00");
217
+ const duration = ref<string>("00:00");
218
+
219
+ const autofocusType = ref(0);
220
+ //防止快进快退当前展示时长频繁修改
221
+ let isSeeking = false;
222
+ const mediaTitle = ref<string>("");
223
+ const isTitleBarShowing = ref<boolean>(true);
224
+ /********************数据***************************/
225
+
226
+ const isProgressShowing = ref<boolean>(false);
227
+ const mediaSeriesVisible = ref<boolean>(true);
228
+ const isMenuShowing = ref<boolean>(false);
229
+ const mediaCollapseMenuInit = ref<boolean>(false);
230
+ const viewState = ref<number>(1);
231
+
232
+ //当前视频总时长
233
+ let curDuration = 0;
234
+ let collapse: QTCollapse;
235
+ let collapseItemIndex = 0;
236
+ let collapseItemList: any = [];
237
+ let playMode: ESPlayerPlayMode;
238
+ let playModeList: Array<ESPlayerPlayMode>;
239
+ let rate: ESPlayerRate;
240
+ let rateList: Array<ESPlayerRate>;
241
+ let definition: ESPlayerDefinition;
242
+ let definitionList: Array<ESPlayerDefinition>;
243
+ let nextButtonFocused = false;
244
+ let mediaListGroupItemFocused = false;
245
+ // manager view 隐藏延时器
246
+ let dismissTimer: any;
247
+
248
+ watch(
249
+ () => [mediaCollapseRef] as const,
250
+ ([newV], [oldV]) => {
251
+ if (newV) {
252
+ collapse = buildCollapseMenu(true);
253
+ collapseItemIndex = collapse.defaultIndex ?? 0;
254
+ collapseItemList = collapse.itemList;
255
+ mediaCollapseRef.value?.init(collapse);
256
+ }
257
+ },
258
+ );
259
+
260
+ onMounted(() => {
261
+ initSeekBar();
262
+ initCollapseMenu();
263
+ eventBus.on("onFullPlayerMediaListLoad", collapseMediaLoadData);
264
+ });
265
+ onUnmounted(() => {
266
+ eventBus.off("onFullPlayerMediaListLoad");
267
+ });
268
+ const initSeekBar = () => {
269
+ seekBarRef.value?.setSeekBarMode(1);
270
+ seekBarRef.value?.setProgressHeight(12);
271
+ seekBarRef.value?.setProgressRadius(6);
272
+ seekBarRef.value?.setThumbWidth(60);
273
+ seekBarRef.value?.setThumbHeight(60);
274
+ seekBarRef.value?.setLeftThumbUrl(
275
+ "http://extcdn.hsrc.tv/extend_screen/images/default/ic_1905_thumb.png",
276
+ );
277
+ seekBarRef.value?.setLeftThumbInactivatedDrawable({
278
+ colors: ["#00000000", "#00000000"],
279
+ cornerRadius: 4,
280
+ });
281
+ };
282
+ const initCollapseMenu = () => {
283
+ if (!mediaCollapseMenuInit.value) {
284
+ mediaCollapseMenuInit.value = true;
285
+ }
286
+ };
287
+
288
+ const collapseMediaLoadData = (page: number, mediaList: Array<IMediaItem>) => {
289
+ if (mediaCollapseMenuInit.value) {
290
+ nextTick(() => {
291
+ mediaCollapseMediaSeriesRef.value?.setListData(page - 1, mediaList);
292
+ });
293
+ }
294
+ };
295
+
296
+ const onNextButtonClicked = () => {
297
+ // if (player) player.playNextMedia()
298
+ };
299
+ const onNextButtonFocusChanged = (e) => {
300
+ // nextButtonFocused = e.isFocused
301
+ };
302
+ const onCollapseItemOrderFocused = () => {
303
+ mediaListGroupItemFocused = false;
304
+ };
305
+ const onCollapseItemOrderClicked = (index: number, item: QTListViewItem) => {
306
+ // if (playMode == item.mode) return
307
+ // player?.setPlayMediaListMode(item.mode)
308
+ };
309
+ const onCollapseItemSpeedFocused = () => {
310
+ mediaListGroupItemFocused = false;
311
+ };
312
+ const onCollapseItemSpeedClicked = (index: number, item: QTListViewItem) => {
313
+ // if (rate == item.rate) return
314
+ // player?.setPlayRate(item.rate)
315
+ };
316
+ const onCollapseItemDefinitionFocused = () => {
317
+ mediaListGroupItemFocused = false;
318
+ };
319
+ const onCollapseItemDefinitionClicked = (
320
+ index: number,
321
+ item: QTListViewItem,
322
+ ) => {
323
+ // if (definition == item.definition) return
324
+ // player?.setDefinition(item.definition)
325
+ };
326
+ const onMediaSeriesGroupItemFocus = (index: number) => {
327
+ mediaListGroupItemFocused = true;
328
+ };
329
+ const onMediaSeriesItemFocus = (index: number) => {
330
+ mediaListGroupItemFocused = false;
331
+ };
332
+ const onMediaSeriesItemClick = (index: number, item: QTListViewItem) => {
333
+ // player?.stop()
334
+ // player?.playMediaById(item.id)
335
+ };
336
+ /**
337
+ * 设置播放管理类 回调
338
+ * @param value
339
+ */
340
+ const setPlayerManager = (value: ESIPlayerManager): void => {
341
+ playerManager = value;
342
+ };
343
+ /**
344
+ * 获取播放管理类
345
+ * @param value
346
+ */
347
+ const getPlayerManager = (): ESIPlayerManager => {
348
+ return playerManager;
349
+ };
350
+ /**
351
+ * 进度条快进快退开始 回调
352
+ * @param progress
353
+ */
354
+ const onSeekBarSeekStart = (progress) => {
355
+ isSeeking = true;
356
+ };
357
+ /**
358
+ * 进度条快进快退结束 回调
359
+ * @param progress
360
+ */
361
+ const onSeekBarSeekStop = (progress) => {
362
+ isSeeking = false;
363
+ if (playerManager && progress >= 0) {
364
+ playerManager.seekTo(progress);
365
+ }
366
+ };
367
+ /**
368
+ * 进度条焦点改变 回调
369
+ * @param event
370
+ */
371
+ const onSeekbarFocusChanged = (event) => {
372
+ // let focused = event.isFocused
373
+ // seekBarRef.value?.setThumbActivate(focused)
374
+ };
375
+ /**
376
+ * 播放模式列表 回调
377
+ * @param modeList
378
+ */
379
+ const onPlayerPlayMediaListModeListChanged = (
380
+ modeList: Array<ESPlayerPlayMode>,
381
+ ): void => {
382
+ if (modeList && modeList.length > 0) {
383
+ playModeList = modeList.filter((mode) => {
384
+ return (
385
+ mode === ESPlayerPlayMode.ES_PLAYER_PLAY_MODE_REPEAT ||
386
+ mode == ESPlayerPlayMode.ES_PLAYER_PLAY_MODE_LOOP ||
387
+ mode == ESPlayerPlayMode.ES_PLAYER_PLAY_MODE_ORDER
388
+ );
389
+ });
390
+ }
391
+ if (playModeList && playModeList.length > 0) {
392
+ const buildModeList = buildPlayModeList(playModeList);
393
+ mediaCollapseOrderRef.value?.setListData(buildModeList);
394
+ }
395
+ };
396
+ /**
397
+ * 当前播放模式 回调
398
+ * @param mode
399
+ */
400
+ const onPlayerPlayMediaListModeChanged = (mode: ESPlayerPlayMode): void => {
401
+ playMode = mode;
402
+ setModeItemSelected();
403
+ };
404
+ /**
405
+ * 初始化播放模式默认选中项
406
+ */
407
+ const setModeItemSelected = () => {
408
+ if (playModeList) {
409
+ const index = getPlayModeIndex(playMode, playModeList);
410
+ mediaCollapseOrderRef.value?.setItemSelected(index);
411
+ }
412
+ };
413
+ /**
414
+ * 播放速率 回调
415
+ * @param list 速率列表
416
+ */
417
+ const onPlayerPlayRateListChanged = (list: Array<ESPlayerRate>): void => {
418
+ rateList = BuildConfig.isLowEndDev ? [ESPlayerRate.ES_PLAYER_RATE_1] : list;
419
+ if (rateList && rateList.length > 0) {
420
+ const buildRateList = buildPlayRateList(rateList);
421
+ mediaCollapseSpeedRef.value?.setListData(buildRateList);
422
+ }
423
+ };
424
+ /**
425
+ * 当前速率 回调
426
+ * @param r
427
+ */
428
+ const onPlayerPlayRateChanged = (r: ESPlayerRate): void => {
429
+ rate = r;
430
+ setRateItemSelected();
431
+ };
432
+ /**
433
+ * 初始化速率默认选中项
434
+ */
435
+ const setRateItemSelected = () => {
436
+ if (rateList) {
437
+ const index = getPlayRateIndex(rate, rateList);
438
+ if (index > -1) {
439
+ mediaCollapseSpeedRef.value?.setItemSelected(index);
440
+ }
441
+ }
442
+ };
443
+ /**
444
+ * 播放清晰度 回调 需要播放数据中设置播放清晰度{{uri:"",definition:1}}
445
+ * @param list 播放清晰度列表
446
+ */
447
+ const onPlayerDefinitionListChanged = (
448
+ list: Array<ESPlayerDefinition>,
449
+ ): void => {
450
+ definitionList = list;
451
+ if (definitionList && definitionList.length > 0) {
452
+ const buildDefinitionList = buildDefinitionList(definitionList);
453
+ mediaCollapseDefinitionRef.value?.setListData(buildDefinitionList);
454
+ }
455
+ };
456
+ /**
457
+ * 当前清晰度 回调
458
+ * @param d
459
+ */
460
+ const onPlayerDefinitionChanged = (d: ESPlayerDefinition): void => {
461
+ definition = d;
462
+ setDefinitionItemSelected();
463
+ };
464
+ /**
465
+ * 初始化清晰度默认选中项
466
+ */
467
+ const setDefinitionItemSelected = () => {
468
+ if (definitionList) {
469
+ const index = getDefinitionIndex(definition, definitionList);
470
+ if (index > -1) {
471
+ mediaCollapseDefinitionRef.value?.setItemSelected(index);
472
+ }
473
+ }
474
+ };
475
+ /**
476
+ * 设置当前 view 隐藏
477
+ * @param delay 延时
478
+ */
479
+ function setPlayerViewStateDismissDelay(delay: number = 4000) {
480
+ clearDismissTimer();
481
+ dismissTimer = setTimeout(() => {
482
+ setPlayerViewStateDismiss();
483
+ }, delay);
484
+ }
485
+ /**
486
+ * 清除定时器
487
+ */
488
+ function clearDismissTimer() {
489
+ if (dismissTimer) {
490
+ clearTimeout(dismissTimer);
491
+ }
492
+ }
493
+ const onKeyDown = (keyEvent: ESKeyEvent): boolean => {
494
+ if (isPlayerPlaying.value) {
495
+ setPlayerViewStateDismissDelay(4000);
496
+ }
497
+ switch (keyEvent.keyCode) {
498
+ case ESKeyCode.ES_KEYCODE_DPAD_CENTER:
499
+ case ESKeyCode.ES_KEYCODE_ENTER:
500
+ if (isPlayerViewStateDismiss()) {
501
+ setPlayerViewStateProgress();
502
+ }
503
+ if (isPlayerViewStateProgress()) {
504
+ if (isPlayerPlaying.value) {
505
+ playerManager.pause();
506
+ isPlayerPlaying.value = false;
507
+ } else {
508
+ playerManager.start(0);
509
+ isPlayerPlaying.value = true;
510
+ }
511
+ return true;
512
+ }
513
+ break;
514
+ case ESKeyCode.ES_KEYCODE_DPAD_LEFT:
515
+ case ESKeyCode.ES_KEYCODE_DPAD_RIGHT:
516
+ autofocusType.value = 0;
517
+ if (isPlayerViewStateDismiss()) {
518
+ setPlayerViewStateProgress();
519
+ return true;
520
+ }
521
+ if (isPlayerViewStateProgress()) {
522
+ if (seekBarRef.value?.isFocused() && curDuration > 0) {
523
+ seekBarRef.value?.startSeek(
524
+ keyEvent.keyCode === ESKeyCode.ES_KEYCODE_DPAD_RIGHT,
525
+ );
526
+ }
527
+ return true;
528
+ }
529
+ break;
530
+ }
531
+ };
532
+ const onKeyUp = (keyEvent: ESKeyEvent): boolean => {
533
+ setPlayerViewStateDismissDelay(5000);
534
+ switch (keyEvent.keyCode) {
535
+ case ESKeyCode.ES_KEYCODE_DPAD_LEFT:
536
+ case ESKeyCode.ES_KEYCODE_DPAD_RIGHT:
537
+ if (
538
+ isPlayerViewStateProgress() &&
539
+ seekBarRef.value?.isFocused() &&
540
+ curDuration > 0
541
+ ) {
542
+ seekBarRef.value?.stopSeek();
543
+ }
544
+ isSeeking = false;
545
+ return true;
546
+ }
547
+ return true;
548
+ };
549
+ const onBackPressed = () => {};
550
+ const onPlayerPlayMedia = (mediaItem: ESMediaItem): void => {
551
+ if (curDuration && curDuration > 0) {
552
+ curDuration = 0;
553
+ seekBarRef.value?.setProgress(0);
554
+ }
555
+ progress.value = "00:00";
556
+ duration.value = "00:00";
557
+ mediaTitle.value = mediaItem.title;
558
+ setCollapseItemMediaListSelected(mediaItem.index);
559
+ };
560
+ const onPlayerPrepared = (): void => {
561
+ initPlayerViewState(1);
562
+ };
563
+ const onPlayerPlaying = (): void => {
564
+ isPlayerPlaying.value = true;
565
+ };
566
+ /**
567
+ * 播放进度改变 回调
568
+ * @param p 播放进度 单位:毫秒
569
+ */
570
+ const onPlayerProgressChanged = (p: number): void => {
571
+ if (isSeeking) {
572
+ return;
573
+ }
574
+ seekBarRef.value?.setProgress(p);
575
+ progress.value = s_to_hs(Math.floor(p / 1000));
576
+ };
577
+ const onPlayerDurationChanged = (d: number): void => {
578
+ if (isSeeking) {
579
+ return;
580
+ }
581
+ curDuration = d;
582
+ seekBarRef.value?.setMaxProgress(d);
583
+ duration.value = s_to_hs(Math.floor(d / 1000));
584
+ };
585
+ const setCollapseItemMediaListSelected = (index) => {
586
+ if (index > -1) {
587
+ mediaCollapseMediaSeriesRef.value?.setItemSelected(index);
588
+ }
589
+ };
590
+
591
+ const isPlayerViewStateMenu = () => {
592
+ return IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_MENU === viewState.value;
593
+ };
594
+ const isPlayerViewStateDismiss = () => {
595
+ return (
596
+ IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_DISMISS === viewState.value
597
+ );
598
+ };
599
+ const isPlayerViewStateProgress = () => {
600
+ return (
601
+ IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_PROGRESS === viewState.value
602
+ );
603
+ };
604
+ const setPlayerViewStateDismiss = () => {
605
+ const lastViewState = viewState.value;
606
+ viewState.value = IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_DISMISS;
607
+ initPlayerViewState(lastViewState);
608
+ };
609
+ const setPlayerViewStateProgress = () => {
610
+ const lastViewState = viewState.value;
611
+ viewState.value = IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_PROGRESS;
612
+ initPlayerViewState(lastViewState);
613
+ };
614
+ const initPlayerViewState = (lastViewState: number) => {
615
+ switch (viewState.value) {
616
+ case IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_DISMISS:
617
+ isTitleBarShowing.value = false;
618
+ isMenuShowing.value = false;
619
+ isProgressShowing.value = false;
620
+ mediaListGroupItemFocused = false;
621
+ if (lastViewState == IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_MENU) {
622
+ mediaCollapseRef.value?.collapse();
623
+ collapseItemIndex = collapse.defaultIndex ?? 0;
624
+ }
625
+ break;
626
+ case IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_MENU:
627
+ isMenuShowing.value = true;
628
+ isProgressShowing.value = false;
629
+ if (!mediaCollapseMenuInit.value) {
630
+ initCollapseMenu();
631
+ }
632
+ mediaCollapseRef.value?.expandItem(collapseItemIndex);
633
+ break;
634
+ case IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_PROGRESS:
635
+ isMenuShowing.value = false;
636
+ isTitleBarShowing.value = true;
637
+ isProgressShowing.value = true;
638
+ mediaListGroupItemFocused = false;
639
+ if (lastViewState == IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_MENU) {
640
+ mediaCollapseRef.value?.collapse();
641
+ collapseItemIndex = collapse.defaultIndex ?? 0;
642
+ }
643
+ break;
644
+ }
645
+ if (
646
+ viewState.value !== IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_DISMISS
647
+ ) {
648
+ setPlayerViewStateDismissDelay(5000);
649
+ }
650
+ };
651
+ const setPlayerViewStateMenu = () => {
652
+ const lastViewState = viewState.value;
653
+ viewState.value = IMediaPlayerViewState.MEDIA_PLAYER_VIEW_STATE_MENU;
654
+ initPlayerViewState(lastViewState);
655
+ };
656
+ defineExpose({
657
+ setPlayerManager,
658
+ getPlayerManager,
659
+ onPlayerPlayMedia,
660
+ onPlayerPrepared,
661
+ onPlayerPlaying,
662
+ onPlayerProgressChanged,
663
+ onPlayerDurationChanged,
664
+ onSeekBarSeekStart,
665
+ onSeekBarSeekStop,
666
+ onSeekbarFocusChanged,
667
+ onPlayerPlayRateListChanged,
668
+ onPlayerPlayRateChanged,
669
+ onPlayerPlayMediaListModeListChanged,
670
+ onPlayerPlayMediaListModeChanged,
671
+ onKeyDown,
672
+ onKeyUp,
673
+ });
674
+ </script>
675
+
676
+ <style lang="scss">
677
+ .full-player-menu-view {
678
+ background-color: transparent;
679
+ width: 1920px;
680
+ height: 1080px;
681
+ }
682
+ .full-player-menu-view-title {
683
+ background-color: transparent;
684
+ .full-player-menu-view-title-text {
685
+ width: 1740px;
686
+ height: 50px;
687
+ font-size: 44px;
688
+ font-weight: 400;
689
+ color: white;
690
+ margin-left: 90px;
691
+ margin-top: 50px;
692
+ }
693
+ }
694
+ .full-player-menu-view-bottom {
695
+ width: 1920px;
696
+ height: 700px;
697
+ background-color: transparent;
698
+ position: absolute;
699
+ bottom: 0;
700
+ left: 0;
701
+ align-items: flex-start;
702
+ justify-content: flex-end;
703
+ .full-player-menu-view-bottom-bg {
704
+ width: 1920px;
705
+ height: 700px;
706
+ background-color: transparent;
707
+ position: absolute;
708
+ bottom: 0;
709
+ left: 0;
710
+ }
711
+ .full-player-menu-view-state-progress {
712
+ align-items: flex-start;
713
+ justify-content: flex-end;
714
+ background-color: transparent;
715
+ .full-player-menu-state-img {
716
+ width: 80px;
717
+ height: 80px;
718
+ margin-left: 90px;
719
+ margin-bottom: 14px;
720
+ background-color: transparent;
721
+ > img {
722
+ width: 80px;
723
+ height: 80px;
724
+ position: absolute;
725
+ }
726
+ }
727
+ .full-player-menu-progress {
728
+ width: 1740px;
729
+ height: 60px;
730
+ flex-direction: row;
731
+ display: flex;
732
+ align-items: center;
733
+ justify-content: center;
734
+ margin-bottom: 25px;
735
+ margin-left: 90px;
736
+ .full-player-menu-progress-text {
737
+ width: 100px;
738
+ height: 60px;
739
+ font-size: 30px;
740
+ font-weight: 400;
741
+ color: white;
742
+ }
743
+ .full-player-menu-progress-seekbar {
744
+ width: 1512px;
745
+ height: 60px;
746
+ margin-left: 20px;
747
+ margin-right: 20px;
748
+ background-color: transparent;
749
+ }
750
+ }
751
+ .full-player-menu-next {
752
+ width: 130px;
753
+ height: 60px;
754
+ margin-left: 90px;
755
+ margin-bottom: 40px;
756
+ background-color: rgba(255, 255, 255, 0.2);
757
+ border-radius: 8px;
758
+ display: flex;
759
+ align-items: center;
760
+ justify-content: center;
761
+ .full-player-menu-next-text-focus {
762
+ width: 130px;
763
+ height: 60px;
764
+ background-color: transparent;
765
+ border-radius: 8px;
766
+ position: absolute;
767
+ }
768
+ .full-player-menu-next-text {
769
+ width: 130px;
770
+ height: 60px;
771
+ font-size: 30px;
772
+ font-weight: 400;
773
+ color: white;
774
+ focus-color: #000;
775
+ }
776
+ }
777
+ }
778
+ }
779
+ .full-player-menu-list {
780
+ width: 1920px;
781
+ height: 700px;
782
+ background-color: transparent;
783
+ position: absolute;
784
+ bottom: 0;
785
+ left: 0;
786
+ align-items: flex-start;
787
+ justify-content: flex-end;
788
+ .full-player-menu-list-bg {
789
+ width: 1920px;
790
+ height: 640px;
791
+ position: absolute;
792
+ left: 0;
793
+ background-color: transparent;
794
+ }
795
+ .full-player-menu-list-collapse {
796
+ width: 1920px;
797
+ height: 640px;
798
+ position: absolute;
799
+ left: 0;
800
+ background-color: transparent;
801
+ }
802
+ }
803
+ </style>