@quicktvui/ai 1.0.9 → 1.1.0

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 (345) hide show
  1. package/package.json +1 -1
  2. package/rules/.clinerules +1 -0
  3. package/rules/.cursorrules +1 -0
  4. package/rules/.github/copilot-instructions.md +1 -0
  5. package/rules/.source/hellotv/PROJECT-README.md +52 -0
  6. package/rules/.source/hellotv/app.d.ts +11 -0
  7. package/rules/.source/hellotv/package.json +146 -0
  8. package/rules/.source/hellotv/scripts/build-apk.ts +12 -0
  9. package/rules/.source/hellotv/scripts/build.ts +35 -0
  10. package/rules/.source/hellotv/scripts/dev.ts +12 -0
  11. package/rules/.source/hellotv/scripts/pack.ts +24 -0
  12. package/rules/.source/hellotv/scripts/process.ts +37 -0
  13. package/rules/.source/hellotv/scripts/quicktvui-webpack.android.ts +187 -0
  14. package/rules/.source/hellotv/scripts/quicktvui-webpack.dev.ts +147 -0
  15. package/rules/.source/hellotv/scripts/webpack-watch.ts +24 -0
  16. package/rules/.source/hellotv/src/App.vue +192 -0
  17. package/rules/.source/hellotv/src/api/my/index.ts +198 -0
  18. package/rules/.source/hellotv/src/api/user/impl-user.ts +52 -0
  19. package/rules/.source/hellotv/src/api/user/qr-code-mock.ts +2 -0
  20. package/rules/.source/hellotv/src/api/user/request-url.ts +11 -0
  21. package/rules/.source/hellotv/src/api/user/user-manager.ts +258 -0
  22. package/rules/.source/hellotv/src/app.scss +8 -0
  23. package/rules/.source/hellotv/src/assets/component-media/ic_media_btn_pause.png +0 -0
  24. package/rules/.source/hellotv/src/assets/component-media/ic_media_btn_play.png +0 -0
  25. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_setting_focused.png +0 -0
  26. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_setting_normal.png +0 -0
  27. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_xuanji_focused.png +0 -0
  28. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_xuanji_normal.png +0 -0
  29. package/rules/.source/hellotv/src/assets/component-media/ic_media_ok_focused.png +0 -0
  30. package/rules/.source/hellotv/src/assets/component-media/ic_media_ok_selected.png +0 -0
  31. package/rules/.source/hellotv/src/assets/detail/ic_collect_focused.png +0 -0
  32. package/rules/.source/hellotv/src/assets/detail/ic_collect_normal.png +0 -0
  33. package/rules/.source/hellotv/src/assets/detail/ic_full_focused.png +0 -0
  34. package/rules/.source/hellotv/src/assets/detail/ic_full_normal.png +0 -0
  35. package/rules/.source/hellotv/src/assets/detail/ic_info_focused.png +0 -0
  36. package/rules/.source/hellotv/src/assets/detail/ic_info_normal.png +0 -0
  37. package/rules/.source/hellotv/src/assets/detail/ic_introduction_bg.png +0 -0
  38. package/rules/.source/hellotv/src/assets/detail/ic_media_list_item_normal.png +0 -0
  39. package/rules/.source/hellotv/src/assets/detail/ic_media_list_item_selected.png +0 -0
  40. package/rules/.source/hellotv/src/assets/detail/ic_media_player_pause.png +0 -0
  41. package/rules/.source/hellotv/src/assets/detail/ic_media_player_placeholder.png +0 -0
  42. package/rules/.source/hellotv/src/assets/detail/ic_media_player_play.png +0 -0
  43. package/rules/.source/hellotv/src/assets/detail/ic_vip_focused.png +0 -0
  44. package/rules/.source/hellotv/src/assets/detail/ic_vip_normal.png +0 -0
  45. package/rules/.source/hellotv/src/assets/detail/skeleton.png +0 -0
  46. package/rules/.source/hellotv/src/assets/filter/ic_empty.png +0 -0
  47. package/rules/.source/hellotv/src/assets/filter/ic_filter_focused.png +0 -0
  48. package/rules/.source/hellotv/src/assets/filter/ic_filter_normal.png +0 -0
  49. package/rules/.source/hellotv/src/assets/filter/ic_filter_selected.png +0 -0
  50. package/rules/.source/hellotv/src/assets/filter/ic_left_focused.png +0 -0
  51. package/rules/.source/hellotv/src/assets/filter/ic_left_normal.png +0 -0
  52. package/rules/.source/hellotv/src/assets/filter/ic_left_selected.png +0 -0
  53. package/rules/.source/hellotv/src/assets/history/ic_delete.png +0 -0
  54. package/rules/.source/hellotv/src/assets/history/ic_empty.png +0 -0
  55. package/rules/.source/hellotv/src/assets/home/bg_history_item.png +0 -0
  56. package/rules/.source/hellotv/src/assets/home/bg_shadow.png +0 -0
  57. package/rules/.source/hellotv/src/assets/home/ic_4k_logo.png +0 -0
  58. package/rules/.source/hellotv/src/assets/home/ic_4k_play_focused.png +0 -0
  59. package/rules/.source/hellotv/src/assets/home/ic_4k_subtitle_normal.png +0 -0
  60. package/rules/.source/hellotv/src/assets/home/ic_arrow_focused.png +0 -0
  61. package/rules/.source/hellotv/src/assets/home/ic_arrow_normal.png +0 -0
  62. package/rules/.source/hellotv/src/assets/home/ic_exit_corner.png +0 -0
  63. package/rules/.source/hellotv/src/assets/home/ic_exit_header.png +0 -0
  64. package/rules/.source/hellotv/src/assets/home/ic_play.png +0 -0
  65. package/rules/.source/hellotv/src/assets/live/bg-error.png +0 -0
  66. package/rules/.source/hellotv/src/assets/live/bg-play-info.png +0 -0
  67. package/rules/.source/hellotv/src/assets/live/ic-arrow-left.png +0 -0
  68. package/rules/.source/hellotv/src/assets/live/ic-arrow-right.png +0 -0
  69. package/rules/.source/hellotv/src/assets/live/ic-back.png +0 -0
  70. package/rules/.source/hellotv/src/assets/live/ic-change.png +0 -0
  71. package/rules/.source/hellotv/src/assets/live/ic-corner-vip-tips.png +0 -0
  72. package/rules/.source/hellotv/src/assets/live/ic-corner-vip.png +0 -0
  73. package/rules/.source/hellotv/src/assets/live/ic-key.png +0 -0
  74. package/rules/.source/hellotv/src/assets/live/ic-loading-error.png +0 -0
  75. package/rules/.source/hellotv/src/assets/live/ic-menu-ext-arrow.png +0 -0
  76. package/rules/.source/hellotv/src/assets/live/ic-menu-ext.png +0 -0
  77. package/rules/.source/hellotv/src/assets/live/ic-menu.png +0 -0
  78. package/rules/.source/hellotv/src/assets/live/ic-mine.png +0 -0
  79. package/rules/.source/hellotv/src/assets/live/ic-network-error.png +0 -0
  80. package/rules/.source/hellotv/src/assets/live/ic-ok.png +0 -0
  81. package/rules/.source/hellotv/src/assets/live/ic-playing.png +0 -0
  82. package/rules/.source/hellotv/src/assets/live/ic-playing2.png +0 -0
  83. package/rules/.source/hellotv/src/assets/live/ic-playing3.png +0 -0
  84. package/rules/.source/hellotv/src/assets/live/ic-service.png +0 -0
  85. package/rules/.source/hellotv/src/assets/live/ic_live_broadcast.png +0 -0
  86. package/rules/.source/hellotv/src/assets/live/ic_live_broadcast_focused.png +0 -0
  87. package/rules/.source/hellotv/src/assets/my/ic_collect_focus.png +0 -0
  88. package/rules/.source/hellotv/src/assets/my/ic_collect_normal.png +0 -0
  89. package/rules/.source/hellotv/src/assets/my/ic_order_focus.png +0 -0
  90. package/rules/.source/hellotv/src/assets/my/ic_order_normal.png +0 -0
  91. package/rules/.source/hellotv/src/assets/my/ic_record_focus.png +0 -0
  92. package/rules/.source/hellotv/src/assets/my/ic_record_normal.png +0 -0
  93. package/rules/.source/hellotv/src/assets/my/ic_user.png +0 -0
  94. package/rules/.source/hellotv/src/assets/my/ic_vip_normal.png +0 -0
  95. package/rules/.source/hellotv/src/assets/search/ic_back.png +0 -0
  96. package/rules/.source/hellotv/src/assets/search/ic_back_focused.png +0 -0
  97. package/rules/.source/hellotv/src/assets/search/ic_clear.png +0 -0
  98. package/rules/.source/hellotv/src/assets/search/ic_clear_dark.png +0 -0
  99. package/rules/.source/hellotv/src/assets/search/ic_clear_focused.png +0 -0
  100. package/rules/.source/hellotv/src/assets/search/ic_search.png +0 -0
  101. package/rules/.source/hellotv/src/assets/top-view/ic_logo.png +0 -0
  102. package/rules/.source/hellotv/src/assets/top-view/ic_top_search_focused.png +0 -0
  103. package/rules/.source/hellotv/src/assets/top-view/ic_top_search_normal.png +0 -0
  104. package/rules/.source/hellotv/src/assets/top-view/ic_top_user_focused.png +0 -0
  105. package/rules/.source/hellotv/src/assets/top-view/ic_top_user_normal.png +0 -0
  106. package/rules/.source/hellotv/src/components/bg-animation.scss +14 -0
  107. package/rules/.source/hellotv/src/components/bg-animation.vue +176 -0
  108. package/rules/.source/hellotv/src/components/btn-pack-view.vue +172 -0
  109. package/rules/.source/hellotv/src/components/btn-pack.scss +53 -0
  110. package/rules/.source/hellotv/src/components/grid-item-horizontal.vue +203 -0
  111. package/rules/.source/hellotv/src/components/grid-item-vertical.vue +201 -0
  112. package/rules/.source/hellotv/src/components/media/build-data/media-config.ts +4 -0
  113. package/rules/.source/hellotv/src/components/media/build-data/media-control-adapter.ts +378 -0
  114. package/rules/.source/hellotv/src/components/media/build-data/media-imp.ts +44 -0
  115. package/rules/.source/hellotv/src/components/media/view/media-loading-component.vue +50 -0
  116. package/rules/.source/hellotv/src/components/media/view/media-loading-view.vue +154 -0
  117. package/rules/.source/hellotv/src/components/media/view/media-manager-view.vue +931 -0
  118. package/rules/.source/hellotv/src/components/media/view/media-menu-detail-item.vue +42 -0
  119. package/rules/.source/hellotv/src/components/media/view/media-menu-detail-view.vue +109 -0
  120. package/rules/.source/hellotv/src/components/media/view/media-menu-icon-item.vue +43 -0
  121. package/rules/.source/hellotv/src/components/media/view/media-menu-text-item.vue +27 -0
  122. package/rules/.source/hellotv/src/components/media/view/media-menu-view.vue +88 -0
  123. package/rules/.source/hellotv/src/components/media/view/media-player-view.vue +408 -0
  124. package/rules/.source/hellotv/src/components/media/view/scss/media-loading.scss +51 -0
  125. package/rules/.source/hellotv/src/components/media/view/scss/media-manager.scss +79 -0
  126. package/rules/.source/hellotv/src/components/media/view/scss/media-menu.scss +114 -0
  127. package/rules/.source/hellotv/src/components/media/view/scss/media-player.scss +6 -0
  128. package/rules/.source/hellotv/src/components/qt-tabs-component.ts +268 -0
  129. package/rules/.source/hellotv/src/components/qt-ul-component.ts +792 -0
  130. package/rules/.source/hellotv/src/components/top-view.scss +38 -0
  131. package/rules/.source/hellotv/src/components/top-view.vue +114 -0
  132. package/rules/.source/hellotv/src/config/README.md +22 -0
  133. package/rules/.source/hellotv/src/config/build-config.ts +22 -0
  134. package/rules/.source/hellotv/src/config/private-theme-config.ts +21 -0
  135. package/rules/.source/hellotv/src/config/public-config.scss +16 -0
  136. package/rules/.source/hellotv/src/config/test.scss +45 -0
  137. package/rules/.source/hellotv/src/config/theme-config.ts +51 -0
  138. package/rules/.source/hellotv/src/main.ts +45 -0
  139. package/rules/.source/hellotv/src/pages/activity/adapter/config.ts +37 -0
  140. package/rules/.source/hellotv/src/pages/activity/adapter/index.ts +849 -0
  141. package/rules/.source/hellotv/src/pages/activity/adapter/interface.ts +173 -0
  142. package/rules/.source/hellotv/src/pages/activity/api/index.ts +36 -0
  143. package/rules/.source/hellotv/src/pages/activity/api/interface.ts +11 -0
  144. package/rules/.source/hellotv/src/pages/activity/api/request-url.ts +10 -0
  145. package/rules/.source/hellotv/src/pages/activity/components/item/focus-change-img-item.vue +40 -0
  146. package/rules/.source/hellotv/src/pages/activity/components/item/inner-out-title-item.vue +59 -0
  147. package/rules/.source/hellotv/src/pages/activity/components/item/no-title-item.vue +45 -0
  148. package/rules/.source/hellotv/src/pages/activity/components/item/placeholder-item.vue +25 -0
  149. package/rules/.source/hellotv/src/pages/activity/index.vue +219 -0
  150. package/rules/.source/hellotv/src/pages/activity/scss/index.scss +46 -0
  151. package/rules/.source/hellotv/src/pages/activity/scss/item.scss +69 -0
  152. package/rules/.source/hellotv/src/pages/detail/adapter/index.ts +317 -0
  153. package/rules/.source/hellotv/src/pages/detail/adapter/interface.ts +150 -0
  154. package/rules/.source/hellotv/src/pages/detail/adapter/media-player.ts +378 -0
  155. package/rules/.source/hellotv/src/pages/detail/api/index.ts +77 -0
  156. package/rules/.source/hellotv/src/pages/detail/api/request-url.ts +8 -0
  157. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-definition.vue +192 -0
  158. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-list-item.vue +108 -0
  159. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-media-series.vue +349 -0
  160. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-order.vue +194 -0
  161. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-speed.vue +192 -0
  162. package/rules/.source/hellotv/src/pages/detail/components/media-player/index.vue +404 -0
  163. package/rules/.source/hellotv/src/pages/detail/components/media-player/media-player-small-view.vue +382 -0
  164. package/rules/.source/hellotv/src/pages/detail/components/media-player/media-player-view.vue +1099 -0
  165. package/rules/.source/hellotv/src/pages/detail/components/recommend-item.vue +167 -0
  166. package/rules/.source/hellotv/src/pages/detail/components/section/basic-section.vue +218 -0
  167. package/rules/.source/hellotv/src/pages/detail/components/section/config.ts +6 -0
  168. package/rules/.source/hellotv/src/pages/detail/components/section/header-section.vue +15 -0
  169. package/rules/.source/hellotv/src/pages/detail/components/section/item/button-menu.vue +259 -0
  170. package/rules/.source/hellotv/src/pages/detail/components/section/item/media-introduction.vue +238 -0
  171. package/rules/.source/hellotv/src/pages/detail/components/section/item/media-series.vue +308 -0
  172. package/rules/.source/hellotv/src/pages/detail/components/section/item/player-placeholder.vue +88 -0
  173. package/rules/.source/hellotv/src/pages/detail/index.vue +571 -0
  174. package/rules/.source/hellotv/src/pages/detail/scss/index.scss +22 -0
  175. package/rules/.source/hellotv/src/pages/detail-full-player/components/media-player/full-player-loading.vue +78 -0
  176. package/rules/.source/hellotv/src/pages/detail-full-player/components/media-player/full-player-menu-view.vue +803 -0
  177. package/rules/.source/hellotv/src/pages/detail-full-player/components/media-player/full-player-view.vue +219 -0
  178. package/rules/.source/hellotv/src/pages/detail-full-player/index.vue +101 -0
  179. package/rules/.source/hellotv/src/pages/detail-full-player/scss/full-player-view.scss +6 -0
  180. package/rules/.source/hellotv/src/pages/detail-full-screen/adapter/index.ts +0 -0
  181. package/rules/.source/hellotv/src/pages/detail-full-screen/adapter/interface.ts +133 -0
  182. package/rules/.source/hellotv/src/pages/detail-full-screen/api/index.ts +77 -0
  183. package/rules/.source/hellotv/src/pages/detail-full-screen/api/request-url.ts +8 -0
  184. package/rules/.source/hellotv/src/pages/detail-full-screen/components/media-info.vue +263 -0
  185. package/rules/.source/hellotv/src/pages/detail-full-screen/components/media-player.vue +42 -0
  186. package/rules/.source/hellotv/src/pages/detail-full-screen/components/media-series-section.vue +26 -0
  187. package/rules/.source/hellotv/src/pages/detail-full-screen/components/recommend-item.vue +167 -0
  188. package/rules/.source/hellotv/src/pages/detail-full-screen/index.vue +163 -0
  189. package/rules/.source/hellotv/src/pages/detail-full-screen/scss/index.scss +41 -0
  190. package/rules/.source/hellotv/src/pages/device-info/index.vue +106 -0
  191. package/rules/.source/hellotv/src/pages/device-info/scss/device-info.scss +49 -0
  192. package/rules/.source/hellotv/src/pages/filter/README.md +66 -0
  193. package/rules/.source/hellotv/src/pages/filter/adapter/index.ts +180 -0
  194. package/rules/.source/hellotv/src/pages/filter/adapter/interface.ts +111 -0
  195. package/rules/.source/hellotv/src/pages/filter/api/index.ts +38 -0
  196. package/rules/.source/hellotv/src/pages/filter/api/interface.ts +44 -0
  197. package/rules/.source/hellotv/src/pages/filter/api/request-url.ts +8 -0
  198. package/rules/.source/hellotv/src/pages/filter/components/content/index.vue +469 -0
  199. package/rules/.source/hellotv/src/pages/filter/components/content/list-item-record.vue +16 -0
  200. package/rules/.source/hellotv/src/pages/filter/components/content/list-item.vue +78 -0
  201. package/rules/.source/hellotv/src/pages/filter/components/expand/index.vue +83 -0
  202. package/rules/.source/hellotv/src/pages/filter/components/sidebar/index.vue +81 -0
  203. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-filter-title.vue +78 -0
  204. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-filter.vue +68 -0
  205. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-line.vue +11 -0
  206. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-text.vue +43 -0
  207. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-title.vue +14 -0
  208. package/rules/.source/hellotv/src/pages/filter/config.ts +10 -0
  209. package/rules/.source/hellotv/src/pages/filter/expand-sidebar-contents.vue +203 -0
  210. package/rules/.source/hellotv/src/pages/filter/scss/filter-content-list-item.scss +42 -0
  211. package/rules/.source/hellotv/src/pages/filter/scss/filter-content.scss +60 -0
  212. package/rules/.source/hellotv/src/pages/filter/scss/filter-expand.scss +30 -0
  213. package/rules/.source/hellotv/src/pages/filter/scss/filter-sidebar.scss +45 -0
  214. package/rules/.source/hellotv/src/pages/filter/scss/filter.scss +21 -0
  215. package/rules/.source/hellotv/src/pages/filter/sidebar-contents.vue +145 -0
  216. package/rules/.source/hellotv/src/pages/filter/single-contents.vue +61 -0
  217. package/rules/.source/hellotv/src/pages/history/adapter/index.ts +51 -0
  218. package/rules/.source/hellotv/src/pages/history/adapter/interface.ts +22 -0
  219. package/rules/.source/hellotv/src/pages/history/api/index.ts +54 -0
  220. package/rules/.source/hellotv/src/pages/history/api/interface.ts +41 -0
  221. package/rules/.source/hellotv/src/pages/history/api/request-url.ts +10 -0
  222. package/rules/.source/hellotv/src/pages/history/components/confirm-dialog.vue +155 -0
  223. package/rules/.source/hellotv/src/pages/history/config.ts +8 -0
  224. package/rules/.source/hellotv/src/pages/history/index-raw.vue +540 -0
  225. package/rules/.source/hellotv/src/pages/history/index.vue +431 -0
  226. package/rules/.source/hellotv/src/pages/history/mock.ts +32 -0
  227. package/rules/.source/hellotv/src/pages/history/scss/history-raw.scss +181 -0
  228. package/rules/.source/hellotv/src/pages/history/scss/history.scss +148 -0
  229. package/rules/.source/hellotv/src/pages/home/adapter/exit/home-exit-adapter.ts +20 -0
  230. package/rules/.source/hellotv/src/pages/home/adapter/exit/home-exit-imp.ts +13 -0
  231. package/rules/.source/hellotv/src/pages/home/adapter/media/create-home-player-interceptor.ts +50 -0
  232. package/rules/.source/hellotv/src/pages/home/adapter/media/home-media-imp.ts +74 -0
  233. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-adapter.ts +151 -0
  234. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-config.ts +17 -0
  235. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-imp.ts +53 -0
  236. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-item-type.ts +6 -0
  237. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-adapter.ts +1304 -0
  238. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-config.ts +30 -0
  239. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-imp.ts +173 -0
  240. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-item-type.ts +17 -0
  241. package/rules/.source/hellotv/src/pages/home/api/index.ts +157 -0
  242. package/rules/.source/hellotv/src/pages/home/api/interface.ts +56 -0
  243. package/rules/.source/hellotv/src/pages/home/api/request-url.ts +22 -0
  244. package/rules/.source/hellotv/src/pages/home/components/exit-dialog.vue +148 -0
  245. package/rules/.source/hellotv/src/pages/home/components/media/bg-player.vue +440 -0
  246. package/rules/.source/hellotv/src/pages/home/components/nav-bar/bar-img-item.vue +39 -0
  247. package/rules/.source/hellotv/src/pages/home/components/nav-bar/bar-text-item.vue +100 -0
  248. package/rules/.source/hellotv/src/pages/home/components/tab-content/bg-player-cell-list-item-img.vue +54 -0
  249. package/rules/.source/hellotv/src/pages/home/components/tab-content/bg-player-cell-list-item-text.vue +67 -0
  250. package/rules/.source/hellotv/src/pages/home/components/tab-content/cell-list-player-item.vue +74 -0
  251. package/rules/.source/hellotv/src/pages/home/components/tab-content/cell-player-item.vue +40 -0
  252. package/rules/.source/hellotv/src/pages/home/components/tab-content/focus-change-img-item.vue +41 -0
  253. package/rules/.source/hellotv/src/pages/home/components/tab-content/history-item.vue +362 -0
  254. package/rules/.source/hellotv/src/pages/home/components/tab-content/inner-out-title-item.vue +60 -0
  255. package/rules/.source/hellotv/src/pages/home/components/tab-content/no-title-item.vue +46 -0
  256. package/rules/.source/hellotv/src/pages/home/components/tab-content/placeholder-item.vue +25 -0
  257. package/rules/.source/hellotv/src/pages/home/components/tab-content/short-video/short-video-section-item.vue +80 -0
  258. package/rules/.source/hellotv/src/pages/home/components/tab-content/short-video/short-video-section.vue +70 -0
  259. package/rules/.source/hellotv/src/pages/home/components/tab-content/small-4k/small-four-section.vue +76 -0
  260. package/rules/.source/hellotv/src/pages/home/components/tab-content/world-4k/world-four-section-item.vue +90 -0
  261. package/rules/.source/hellotv/src/pages/home/components/tab-content/world-4k/world-four-section.vue +57 -0
  262. package/rules/.source/hellotv/src/pages/home/components/waterfall-tabs.vue +1307 -0
  263. package/rules/.source/hellotv/src/pages/home/index.vue +117 -0
  264. package/rules/.source/hellotv/src/pages/home/scss/bar-img-item.scss +11 -0
  265. package/rules/.source/hellotv/src/pages/home/scss/bar-text-item.scss +80 -0
  266. package/rules/.source/hellotv/src/pages/home/scss/base.scss +8 -0
  267. package/rules/.source/hellotv/src/pages/home/scss/bg-player-cell-list-item.scss +24 -0
  268. package/rules/.source/hellotv/src/pages/home/scss/bg-player.scss +50 -0
  269. package/rules/.source/hellotv/src/pages/home/scss/cell-player-item.scss +24 -0
  270. package/rules/.source/hellotv/src/pages/home/scss/exit-dialog.scss +89 -0
  271. package/rules/.source/hellotv/src/pages/home/scss/focus-change-img-item.scss +12 -0
  272. package/rules/.source/hellotv/src/pages/home/scss/home.scss +32 -0
  273. package/rules/.source/hellotv/src/pages/home/scss/inner-out-title-item.scss +24 -0
  274. package/rules/.source/hellotv/src/pages/home/scss/no-title-item.scss +15 -0
  275. package/rules/.source/hellotv/src/pages/home/scss/placeholder-item.scss +14 -0
  276. package/rules/.source/hellotv/src/pages/home/scss/short-video-section.scss +59 -0
  277. package/rules/.source/hellotv/src/pages/home/scss/small-four-section.scss +14 -0
  278. package/rules/.source/hellotv/src/pages/home/scss/waterfall-tabs.scss +50 -0
  279. package/rules/.source/hellotv/src/pages/home/scss/world-four-section.scss +106 -0
  280. package/rules/.source/hellotv/src/pages/introduction/index.vue +227 -0
  281. package/rules/.source/hellotv/src/pages/live/components/menu/first-list-item-icon-text.vue +35 -0
  282. package/rules/.source/hellotv/src/pages/live/components/menu/first-list-item-img.vue +16 -0
  283. package/rules/.source/hellotv/src/pages/live/components/menu/first-list-item-text.vue +16 -0
  284. package/rules/.source/hellotv/src/pages/live/components/menu/index.vue +266 -0
  285. package/rules/.source/hellotv/src/pages/live/components/menu/second-list-item.vue +80 -0
  286. package/rules/.source/hellotv/src/pages/live/components/menu/third-list-item.vue +68 -0
  287. package/rules/.source/hellotv/src/pages/live/components/player/index.vue +168 -0
  288. package/rules/.source/hellotv/src/pages/live/components/player/player-error.vue +48 -0
  289. package/rules/.source/hellotv/src/pages/live/components/player/player-loading.vue +50 -0
  290. package/rules/.source/hellotv/src/pages/live/components/player/player-tips.vue +125 -0
  291. package/rules/.source/hellotv/src/pages/live/components/player/tips-icon-text.vue +27 -0
  292. package/rules/.source/hellotv/src/pages/live/css/menu.css +109 -0
  293. package/rules/.source/hellotv/src/pages/live/css/player.css +56 -0
  294. package/rules/.source/hellotv/src/pages/live/index.vue +128 -0
  295. package/rules/.source/hellotv/src/pages/live/mock/index.ts +263 -0
  296. package/rules/.source/hellotv/src/pages/live/types/index.ts +42 -0
  297. package/rules/.source/hellotv/src/pages/login/index.vue +116 -0
  298. package/rules/.source/hellotv/src/pages/login/scss/login.scss +61 -0
  299. package/rules/.source/hellotv/src/pages/m-test.vue +84 -0
  300. package/rules/.source/hellotv/src/pages/my/README.md +87 -0
  301. package/rules/.source/hellotv/src/pages/my/index.vue +177 -0
  302. package/rules/.source/hellotv/src/pages/my/my-data-manager.ts +606 -0
  303. package/rules/.source/hellotv/src/pages/my/my-templates.vue +24 -0
  304. package/rules/.source/hellotv/src/pages/my/poster/index.vue +98 -0
  305. package/rules/.source/hellotv/src/pages/my/poster/my-card2.vue +90 -0
  306. package/rules/.source/hellotv/src/pages/my/poster/my-icon-title-col.vue +72 -0
  307. package/rules/.source/hellotv/src/pages/my/poster/my-icon-title-row.vue +72 -0
  308. package/rules/.source/hellotv/src/pages/my/poster/my-info.vue +50 -0
  309. package/rules/.source/hellotv/src/pages/my/poster/my-user.vue +126 -0
  310. package/rules/.source/hellotv/src/pages/play-test.vue +95 -0
  311. package/rules/.source/hellotv/src/pages/search/README.md +57 -0
  312. package/rules/.source/hellotv/src/pages/search/adapter/index.ts +285 -0
  313. package/rules/.source/hellotv/src/pages/search/adapter/interface.ts +60 -0
  314. package/rules/.source/hellotv/src/pages/search/api/index.ts +100 -0
  315. package/rules/.source/hellotv/src/pages/search/api/interface.ts +64 -0
  316. package/rules/.source/hellotv/src/pages/search/api/request-url.ts +20 -0
  317. package/rules/.source/hellotv/src/pages/search/components/search-content-tabs.vue +153 -0
  318. package/rules/.source/hellotv/src/pages/search/components/search-content.vue +282 -0
  319. package/rules/.source/hellotv/src/pages/search/components/search-keyboard.vue +252 -0
  320. package/rules/.source/hellotv/src/pages/search/components/search-keyword-grid.vue +85 -0
  321. package/rules/.source/hellotv/src/pages/search/components/search-keyword.vue +346 -0
  322. package/rules/.source/hellotv/src/pages/search/config.ts +10 -0
  323. package/rules/.source/hellotv/src/pages/search/scss/search-content.scss +130 -0
  324. package/rules/.source/hellotv/src/pages/search/scss/search-keyboard.scss +91 -0
  325. package/rules/.source/hellotv/src/pages/search/scss/search-keyword-grid.scss +30 -0
  326. package/rules/.source/hellotv/src/pages/search/scss/search-keyword.scss +104 -0
  327. package/rules/.source/hellotv/src/pages/search/scss/search.scss +18 -0
  328. package/rules/.source/hellotv/src/pages/search/three-columns.vue +164 -0
  329. package/rules/.source/hellotv/src/pages/search/two-columns.vue +128 -0
  330. package/rules/.source/hellotv/src/pages/tabs-test.vue +339 -0
  331. package/rules/.source/hellotv/src/pages/webview/load-web-view.vue +44 -0
  332. package/rules/.source/hellotv/src/routes.ts +142 -0
  333. package/rules/.source/hellotv/src/tools/common.ts +18 -0
  334. package/rules/.source/hellotv/src/tools/format-date.ts +16 -0
  335. package/rules/.source/hellotv/src/tools/index.ts +58 -0
  336. package/rules/.source/hellotv/src/tools/launch.ts +339 -0
  337. package/rules/.source/hellotv/src/tools/request/index.ts +206 -0
  338. package/rules/.source/hellotv/src/tools/request/interface.ts +64 -0
  339. package/rules/.source/hellotv/src/typings/shims-vue.d.ts +6 -0
  340. package/rules/.source/hellotv/src/vue.config.js +3 -0
  341. package/rules/.source/hellotv/tsconfig.json +34 -0
  342. package/rules/.windsurfrules +1 -0
  343. package/rules/AGENTS.md +1 -0
  344. package/rules/CLAUDE.md +1 -0
  345. package/rules/GEMINI.md +1 -0
@@ -0,0 +1,931 @@
1
+ <template>
2
+ <div
3
+ class="media-manager-root-css"
4
+ :focusable="false"
5
+ :style="{ width: `${playerWidth}px`, height: `${playerHeight}px` }"
6
+ :blockFocusDirections="['left', 'right', 'down', 'up']"
7
+ :showDialog="isFullWindow && isShowManagerView"
8
+ >
9
+ <!-- 底部菜单 View-->
10
+ <div
11
+ class="media-manager-bg-css"
12
+ :visible="isShowBottomView"
13
+ :style="{ width: `${playerWidth}px`, height: `540px` }"
14
+ :focusable="false"
15
+ :gradientBackground="{
16
+ colors: ThemeConfig.tabContentFloatBgColor,
17
+ orientation: 4,
18
+ }"
19
+ >
20
+ <!-- 播放标题-->
21
+ <span
22
+ class="media-manager-title-css main-title-css"
23
+ :visible="!isShowSeekBarTip"
24
+ :focusable="false"
25
+ >{{ mediaMainTitle }}</span
26
+ >
27
+ <!-- 播放副标题-->
28
+ <span
29
+ class="media-manager-title-css sub-title-css"
30
+ v-if="mediaSubTitle"
31
+ :visible="!isShowSeekBarTip"
32
+ :focusable="false"
33
+ >{{ mediaSubTitle }}</span
34
+ >
35
+ <!-- 进度条-->
36
+ <div
37
+ class="media-manager-progress-root-css"
38
+ :focusable="false"
39
+ :autofocus="autofocusType === 0"
40
+ >
41
+ <!-- 播放状态-->
42
+ <div class="media-manager-play-state-root-css" :focusable="false">
43
+ <img
44
+ class="media-manager-img-play-state-css"
45
+ :focusable="false"
46
+ :visible="!isPlayerPlaying"
47
+ :src="playIcon"
48
+ />
49
+ <img
50
+ class="media-manager-img-play-state-css"
51
+ :focusable="false"
52
+ :visible="isPlayerPlaying"
53
+ :src="pauseIcon"
54
+ />
55
+ </div>
56
+ <qt-seek-bar
57
+ class="media-manager-seekbar-css"
58
+ ref="mediaManagerSeekBarRef"
59
+ name="seekBar"
60
+ :color="{ startColor: '#FFFF', endColor: '#FFFFFF' }"
61
+ :nextFocusName="{
62
+ down: 'mediaControlView',
63
+ left: 'seekBar',
64
+ right: 'seekBar',
65
+ }"
66
+ :focusable="true"
67
+ @onSeekStart="onSeekBarSeekStart"
68
+ @onSeekStop="onSeekBarSeekStop"
69
+ @focus="onSeekbarFocusChanged"
70
+ />
71
+ </div>
72
+ <!-- 底部按钮组-->
73
+ <div
74
+ class="media-manager-setting-root-css"
75
+ :autofocus="autofocusType === 1"
76
+ >
77
+ <media-menu-view
78
+ v-if="isShowList"
79
+ :visible="!isShowSeekBarTip"
80
+ ref="mediaMenuViewRef"
81
+ name="mediaMenuView"
82
+ :nextFocusName="{ up: 'seekBar' }"
83
+ :menuList="menuList"
84
+ @onItemFocused="onItemFocused"
85
+ @onItemClicked="onItemClicked"
86
+ />
87
+ <!-- 进度提示-->
88
+ <div class="media-manager-text-root-css" :focusable="false">
89
+ <span
90
+ class="media-manager-progress-text-css"
91
+ style="color: #bfbfbf"
92
+ :numberOfLines="1"
93
+ :focusable="false"
94
+ >{{ " / " + duration }}</span
95
+ >
96
+ <span
97
+ class="media-manager-progress-text-css"
98
+ style="color: white; margin-right: 5px"
99
+ :numberOfLines="1"
100
+ :focusable="false"
101
+ >{{ progress }}</span
102
+ >
103
+ </div>
104
+ </div>
105
+ </div>
106
+ <!-- 倍速-->
107
+ <media-menu-detail-view
108
+ ref="mediaMenuSpeedRateRef"
109
+ :itemName="PlayMenuNameFlag.RATE_ITEM"
110
+ title="倍速"
111
+ @onItemClicked="onItemClicked"
112
+ />
113
+ <!-- 清晰度-->
114
+ <!-- <media-menu-detail-view-->
115
+ <!-- ref='mediaMenuDefinitionRef'-->
116
+ <!-- :item-name='PlayMenuNameFlag.DEFINITION_ITEM'-->
117
+ <!-- title='清晰度'-->
118
+ <!-- @onItemClicked="onItemClicked"-->
119
+ <!-- />-->
120
+ <media-menu-detail-view
121
+ ref="mediaMenuModeRef"
122
+ :itemName="PlayMenuNameFlag.SETTING_ITEM"
123
+ title="设置"
124
+ @onItemClicked="onItemClicked"
125
+ />
126
+ </div>
127
+ </template>
128
+
129
+ <script lang="ts" setup name="media-manager-view">
130
+ import {
131
+ ESKeyCode,
132
+ ESKeyEvent,
133
+ ESLogLevel,
134
+ useESLog,
135
+ useESToast,
136
+ } from "@extscreen/es3-core";
137
+ import {
138
+ ESPlayerDefinition,
139
+ ESPlayerPlayMode,
140
+ ESPlayerRate,
141
+ ESPlayerWindowType,
142
+ } from "@extscreen/es3-player";
143
+ import { ESIPlayerManager, ESMediaItem } from "@extscreen/es3-player-manager";
144
+ import { QTISeekBar, QTSeekBarMode } from "@quicktvui/quicktvui3";
145
+ import { onMounted, ref } from "vue";
146
+ import ThemeConfig from "../../../config/theme-config.ts";
147
+ import playIcon from "../../../assets/component-media/ic_media_btn_play.png";
148
+ import pauseIcon from "../../../assets/component-media/ic_media_btn_pause.png";
149
+ import {
150
+ buildModes,
151
+ buildPlayRates,
152
+ getCurModeIndex,
153
+ getCurRateIndex,
154
+ IMediaViewState,
155
+ s_to_hs,
156
+ } from "../build-data/media-control-adapter";
157
+ import { IMediaMenu, PlayMenuNameFlag } from "../build-data/media-imp";
158
+ import MediaMenuDetailView from "./media-menu-detail-view.vue";
159
+ import MediaMenuView from "./media-menu-view.vue";
160
+ import BuildConfig from "../../../config/build-config.ts";
161
+
162
+ const TAG = "MEDIA_MANAGER_VIEW";
163
+ const log = useESLog();
164
+ const toast = useESToast();
165
+ /*******************组件声明******************/
166
+ //进度条
167
+ const mediaManagerSeekBarRef = ref<QTISeekBar>();
168
+ //底部按钮组
169
+ const mediaMenuViewRef = ref();
170
+ //倍速
171
+ const mediaMenuSpeedRateRef = ref();
172
+ //清晰度
173
+ // const mediaMenuDefinitionRef = ref()
174
+ //播放模式
175
+ const mediaMenuModeRef = ref();
176
+ //当前 控制菜单的 ref
177
+ let curControlRef;
178
+ /*******************播放器相关******************/
179
+ //播放管理类
180
+ let playerManager: ESIPlayerManager;
181
+ //播放器宽高
182
+ const playerWidth = ref<number>(0);
183
+ const playerHeight = ref<number>(0);
184
+ //播放器全屏状态
185
+ const isFullWindow = ref<boolean>(false);
186
+ //播放中/播放暂停状态
187
+ const isPlayerPlaying = ref<boolean>(false);
188
+ //进度条展示值---当前时长
189
+ const d_time_str = "00:00";
190
+ const progress = ref<string>(d_time_str);
191
+ //进度条展示值---总时长
192
+ const duration = ref<string>(d_time_str);
193
+
194
+ let autofocusType = ref(0);
195
+ //当前视频总时长
196
+ let curDuration = 0;
197
+ //防止快进快退当前展示时长频繁修改
198
+ let isSeeking = false;
199
+ //播放标题
200
+ let mediaMainTitle = ref("");
201
+ //播放副标题
202
+ let mediaSubTitle = ref("");
203
+
204
+ /********************数据***************************/
205
+ //主动控制当前控制 View 是否展示 默认隐藏
206
+ let isShowManagerView = ref(false);
207
+ //底部菜单列表是否展示 默认显示
208
+ let isShowBottomView = ref(true);
209
+ //控制进度条快进快退提示信息是否展示
210
+ let isShowSeekBarTip = ref(false);
211
+ // 当前 view 显示隐藏状态
212
+ let viewState: IMediaViewState | undefined =
213
+ IMediaViewState.STATE_MANAGER_VIEW_DISMISS;
214
+ // manager view 隐藏延时器
215
+ let dismissTimer: any;
216
+ // 速率原始列表
217
+ let rateList: Array<ESPlayerRate>;
218
+ // 当前速率
219
+ let rate: ESPlayerRate;
220
+ // 清晰度原始列表
221
+ // let definitionList: Array<ESPlayerDefinition>
222
+ // 当前清晰度
223
+ // let definition: ESPlayerDefinition
224
+ // 播放模式原始列表
225
+ let playModeList: Array<ESPlayerPlayMode>;
226
+ // 当前播放模式
227
+ let playMode: ESPlayerPlayMode;
228
+ // 底部菜单列表 点击位置
229
+ // let curMenuClickPosition = -1
230
+ let bottomViewFocus = false;
231
+ //菜单数据
232
+ let menuList = ref<Array<IMediaMenu>>([]);
233
+ //初始菜单创建标志
234
+ let isShowList = ref(false);
235
+ onMounted(() => {
236
+ initSeekBar();
237
+ });
238
+ /**
239
+ * 初始化进度条数据
240
+ */
241
+ const initSeekBar = () => {
242
+ mediaManagerSeekBarRef.value?.setSeekBarMode(
243
+ QTSeekBarMode.QT_SEEK_BAR_MODE_SINGLE,
244
+ );
245
+ mediaManagerSeekBarRef.value?.setProgressHeight(18);
246
+ mediaManagerSeekBarRef.value?.setProgressRadius(9);
247
+ mediaManagerSeekBarRef.value?.setThumbWidth(60);
248
+ mediaManagerSeekBarRef.value?.setThumbHeight(60);
249
+ mediaManagerSeekBarRef.value?.setLeftThumbUrl(
250
+ "http://extcdn.hsrc.tv/extend_screen/images/default/ic_1905_thumb.png",
251
+ );
252
+ mediaManagerSeekBarRef.value?.setLeftThumbInactivatedDrawable({
253
+ colors: ["#00000000", "#00000000"],
254
+ cornerRadius: 4,
255
+ });
256
+ // mediaManagerSeekBarRef.value?.setLeftThumbInactivatedUrl('https://bilibilisx.huan.tv/upload/public/icon/ic_thumb.png');
257
+ };
258
+ /**
259
+ * 初始化菜单数据
260
+ * @param menuData
261
+ */
262
+ const initMenuList = (menuData: Array<IMediaMenu>) => {
263
+ menuList.value = menuData;
264
+ // //初始化底部菜单列表
265
+ isShowList.value = true;
266
+ };
267
+ /**
268
+ * 设置 view 是否展示
269
+ * @param isShow
270
+ */
271
+ const setShowView = (isShow: boolean): void => {
272
+ isShowManagerView.value = isShow;
273
+ };
274
+ const getId = () => {
275
+ return "MediaManagerView";
276
+ };
277
+ /**
278
+ * 设置播放管理类 回调
279
+ * @param value
280
+ */
281
+ const setPlayerManager = (value: ESIPlayerManager): void => {
282
+ playerManager = value;
283
+ };
284
+ /**
285
+ * 获取播放管理类
286
+ * @param value
287
+ */
288
+ const getPlayerManager = (): ESIPlayerManager => {
289
+ return playerManager;
290
+ };
291
+ const onPlayerPlayMedia = (mediaItem: ESMediaItem): void => {
292
+ //初始化进度条数据
293
+ if (curDuration && curDuration > 0) {
294
+ curDuration = 0;
295
+ mediaManagerSeekBarRef.value?.setProgress(0);
296
+ }
297
+ progress.value = d_time_str;
298
+ duration.value = d_time_str;
299
+ if (mediaItem) {
300
+ const albumName = mediaItem?.albumName;
301
+ mediaMainTitle.value = (albumName ? albumName + "-" : "") + mediaItem.title;
302
+ mediaSubTitle.value = mediaItem.subTitle;
303
+ }
304
+ };
305
+ /**
306
+ * 开始播放 回调
307
+ */
308
+ const onPlayerPlaying = (): void => {
309
+ isPlayerPlaying.value = true;
310
+ };
311
+ /**
312
+ * 播放暂停 回调
313
+ */
314
+ const onPlayerPaused = (): void => {
315
+ isPlayerPlaying.value = false;
316
+ };
317
+ /**
318
+ * 调用 setSize 触发窗口尺寸改变 回调
319
+ * @param width
320
+ * @param height
321
+ */
322
+ const onPlayerWindowSizeChanged = (width: number, height: number): void => {
323
+ playerWidth.value = width;
324
+ playerHeight.value = height;
325
+ isFullWindow.value =
326
+ (width === 1920 && height === 1080) || (width === 1280 && height === 720);
327
+ };
328
+ /**
329
+ * 调用 setFullWindow/setSmallWindow/setFloatWindow 触发窗口类型改变 回调
330
+ * @param windowType
331
+ */
332
+ const onPlayerWindowTypeChanged = (windowType: ESPlayerWindowType): void => {
333
+ isFullWindow.value =
334
+ windowType == ESPlayerWindowType.ES_PLAYER_WINDOW_TYPE_FULL;
335
+ };
336
+ /**
337
+ * 播放进度改变 回调
338
+ * @param p 播放进度 单位:毫秒
339
+ */
340
+ const onPlayerProgressChanged = (p: number): void => {
341
+ if (isSeeking) {
342
+ return;
343
+ }
344
+ mediaManagerSeekBarRef.value?.setProgress(p);
345
+ progress.value = s_to_hs(Math.floor(p / 1000));
346
+ };
347
+ /**
348
+ * 当前总播放时长 回调
349
+ * @param d 总时长 单位:毫秒
350
+ */
351
+ const onPlayerDurationChanged = (d: number): void => {
352
+ if (isSeeking) {
353
+ return;
354
+ }
355
+ curDuration = d;
356
+ mediaManagerSeekBarRef.value?.setMaxProgress(d);
357
+ duration.value = s_to_hs(Math.floor(d / 1000));
358
+ };
359
+
360
+ /**
361
+ * 进度条快进快退开始 回调
362
+ * @param progress
363
+ */
364
+ const onSeekBarSeekStart = (progress) => {
365
+ isSeeking = true;
366
+ viewState = IMediaViewState.STATE_SEEK_BAR_START;
367
+ resetShowViewState();
368
+ };
369
+ /**
370
+ * 进度条快进快退结束 回调
371
+ * @param progress
372
+ */
373
+ const onSeekBarSeekStop = (progress) => {
374
+ if (log.isLoggable(ESLogLevel.DEBUG)) {
375
+ log.e(TAG, "-------onSeekBarSeekStop-------->>>>>", progress);
376
+ }
377
+ isSeeking = false;
378
+ viewState = IMediaViewState.STATE_SEEK_BAR_END;
379
+ resetShowViewState(IMediaViewState.STATE_MANAGER_VIEW_SHOW);
380
+ if (playerManager && progress >= 0) {
381
+ playerManager.seekTo(progress);
382
+ }
383
+ };
384
+ /**
385
+ * 进度条焦点改变 回调
386
+ * @param event
387
+ */
388
+ const onSeekbarFocusChanged = (event) => {
389
+ if (log.isLoggable(ESLogLevel.DEBUG)) {
390
+ log.e(TAG, "-------onSeekbarFocusChanged-------->>>>>", event);
391
+ }
392
+ let focused = event.isFocused;
393
+ mediaManagerSeekBarRef.value?.setThumbActivate(focused);
394
+ };
395
+ /**
396
+ * 播放速率 回调
397
+ * @param list 速率列表
398
+ */
399
+ const onPlayerPlayRateListChanged = (list: Array<ESPlayerRate>): void => {
400
+ rateList = BuildConfig.isLowEndDev ? [ESPlayerRate.ES_PLAYER_RATE_1] : list;
401
+ mediaMenuSpeedRateRef.value.setList(buildPlayRates(rateList));
402
+ };
403
+ /**
404
+ * 当前速率 回调
405
+ * @param r
406
+ */
407
+ const onPlayerPlayRateChanged = (r: ESPlayerRate): void => {
408
+ rate = r;
409
+ initRateItemSelected();
410
+ };
411
+ /**
412
+ * 播放清晰度 回调 需要播放数据中设置播放清晰度{{uri:"",definition:1}}
413
+ * @param list 播放清晰度列表
414
+ */
415
+ const onPlayerDefinitionListChanged = (
416
+ list: Array<ESPlayerDefinition>,
417
+ ): void => {
418
+ // definitionList = list
419
+ // mediaControlDefinitionRef.value.setList(buildDefinitions(definitionList))
420
+ };
421
+ /**
422
+ * 当前清晰度 回调
423
+ * @param d
424
+ */
425
+ const onPlayerDefinitionChanged = (d: ESPlayerDefinition): void => {
426
+ // definition = d
427
+ // initDefinitionItemSelected()
428
+ };
429
+ /**
430
+ * 播放模式列表 回调
431
+ * @param modeList
432
+ */
433
+ const onPlayerPlayMediaListModeListChanged = (
434
+ modeList: Array<ESPlayerPlayMode>,
435
+ ): void => {
436
+ //获取 2 中播放模式展示
437
+ if (modeList && modeList.length > 0) {
438
+ playModeList = modeList.filter((mode) => {
439
+ return (
440
+ mode === ESPlayerPlayMode.ES_PLAYER_PLAY_MODE_REPEAT ||
441
+ mode == ESPlayerPlayMode.ES_PLAYER_PLAY_MODE_LOOP ||
442
+ mode == ESPlayerPlayMode.ES_PLAYER_PLAY_MODE_ORDER
443
+ );
444
+ });
445
+ }
446
+ if (playModeList && playModeList.length > 0) {
447
+ mediaMenuModeRef.value.setList(buildModes(playModeList));
448
+ }
449
+ };
450
+ /**
451
+ * 当前播放模式 回调
452
+ * @param mode
453
+ */
454
+ const onPlayerPlayMediaListModeChanged = (mode: ESPlayerPlayMode): void => {
455
+ playMode = mode;
456
+ initModeItemSelected();
457
+ };
458
+ /**
459
+ * 初始化速率默认选中项
460
+ */
461
+ const initRateItemSelected = () => {
462
+ if (rateList) {
463
+ const index = getCurRateIndex(rate, rateList);
464
+ mediaMenuSpeedRateRef.value.setSelectedIndex(index);
465
+ //更新当前底部列表中速率项的值
466
+ if (!mediaMenuSpeedRateRef.value.initMenu) {
467
+ const menuRateP: number | undefined = menuList.value?.findIndex(
468
+ (mlItem) => mlItem.nameFlag == PlayMenuNameFlag.RATE,
469
+ ); //resultMap.get(PlayMenuNameFlag.RATE)
470
+ if (menuRateP !== undefined && menuRateP > -1) {
471
+ //解决-底部按钮出现两个倍速的问题
472
+ const mRate = rate === 1 ? "1.0" : rate;
473
+ if (menuList && menuList.value) {
474
+ const length = menuList.value.length;
475
+ if (length > 0) {
476
+ const menuItem = menuList.value[menuRateP];
477
+ menuItem.name = `倍速 ${mRate}x`; //解决-切换选集后倍速不正确的问题
478
+ }
479
+ }
480
+ mediaMenuViewRef.value.update(menuRateP, `倍速 ${mRate}x`);
481
+ }
482
+ }
483
+ }
484
+ };
485
+ /**
486
+ * 初始化清晰度默认选中项
487
+ */
488
+ // const initDefinitionItemSelected = ()=>{
489
+ // if (definitionList){
490
+ // const index = getCurDefinitionIndex(definition,definitionList)
491
+ // mediaMenuDefinitionRef.value.setSelectedIndex(index)
492
+ // //更新当前底部列表中清晰度项的值
493
+ // if (!mediaMenuDefinitionRef.value.initMenu){
494
+ // const menuDefinitionP = resultMap.get(PlayMenuNameFlag.DEFINITION)
495
+ // const str = decodeDefinition(definition)
496
+ // mediaMenuViewRef.value.update(menuDefinitionP,str)
497
+ // }
498
+ // }
499
+ // }
500
+ /**
501
+ * 初始化播放模式默认选中项
502
+ */
503
+ const initModeItemSelected = () => {
504
+ if (playModeList) {
505
+ const index = getCurModeIndex(playMode, playModeList);
506
+ mediaMenuModeRef.value.setSelectedIndex(index);
507
+ }
508
+ };
509
+
510
+ /**
511
+ * 底部菜单 item 焦点 事件
512
+ * @param focused 是否有焦点
513
+ * @param name 焦点 Item 名称
514
+ */
515
+ const onItemFocused = (focused, name) => {
516
+ bottomViewFocus = focused;
517
+ switch (name) {
518
+ case PlayMenuNameFlag.RATE:
519
+ if (focused) {
520
+ initRightRateMenu();
521
+ }
522
+ break;
523
+ // case PlayMenuNameFlag.DEFINITION:
524
+ // if (focused){
525
+ // initRightDefinition()
526
+ // }
527
+ // break;
528
+ case PlayMenuNameFlag.SETTING:
529
+ if (focused) {
530
+ initRightMode();
531
+ }
532
+ break;
533
+ }
534
+ };
535
+ /**
536
+ * 初始化速率列表
537
+ */
538
+ const initRightRateMenu = () => {
539
+ if (mediaMenuSpeedRateRef.value.initMenu) return;
540
+ mediaMenuSpeedRateRef.value.init();
541
+ };
542
+ /**
543
+ * 初始化清晰度列表
544
+ */
545
+ // const initRightDefinition=()=>{
546
+ // if (mediaMenuDefinitionRef.value.initMenu)return
547
+ // mediaMenuDefinitionRef.value.init()
548
+ // }
549
+ /**
550
+ * 初始化播放模式
551
+ */
552
+ const initRightMode = () => {
553
+ if (mediaMenuModeRef.value.initMenu) return;
554
+ mediaMenuModeRef.value.init();
555
+ };
556
+ /**
557
+ * 底部菜单/右侧菜单 item 点击 事件
558
+ * @param name 是否有焦点
559
+ * @param e 焦点 Item 名称
560
+ */
561
+ const onItemClicked = (name, e, isSameLocation?: number) => {
562
+ switch (name) {
563
+ case PlayMenuNameFlag.NEXT:
564
+ if (playerManager) {
565
+ playerManager?.stop();
566
+ curDuration = 0;
567
+ mediaManagerSeekBarRef.value?.setProgress(0);
568
+ // 播放下一集先设置回当前速率
569
+ playerManager?.setPlayRate(rate);
570
+ playerManager.playNextMedia();
571
+ setPlayerViewStateDismiss();
572
+ }
573
+ break;
574
+ case PlayMenuNameFlag.EPISODES:
575
+ //todo 跳转待实现
576
+ // router.push({
577
+ // name: 'detail2',
578
+ // params: {packageId:cid}
579
+ // })
580
+ setPlayerViewStateDismiss();
581
+ break;
582
+ case PlayMenuNameFlag.RATE:
583
+ curControlRef = mediaMenuSpeedRateRef;
584
+ // curMenuClickPosition = e.position
585
+ viewState = IMediaViewState.STATE_MENU_RATE_VIEW_SHOW;
586
+ resetShowViewState();
587
+ break;
588
+ // case PlayMenuNameFlag.DEFINITION:
589
+ // curControlRef = mediaMenuDefinitionRef
590
+ // curMenuClickPosition = e.position
591
+ // viewState = IMediaViewState.STATE_MENU_DEFINITION_VIEW_SHOW
592
+ // resetShowViewState()
593
+ // break;
594
+ case PlayMenuNameFlag.SETTING:
595
+ curControlRef = mediaMenuModeRef;
596
+ // curMenuClickPosition = e.position
597
+ viewState = IMediaViewState.STATE_MENU_MODE_VIEW_SHOW;
598
+ resetShowViewState();
599
+ break;
600
+ case PlayMenuNameFlag.RATE_ITEM:
601
+ viewState = IMediaViewState.STATE_MENU_RATE_VIEW_DISMISS;
602
+ if (!isSameLocation) {
603
+ const _ratePosition: number | undefined = menuList.value?.findIndex(
604
+ (mlItem) => mlItem.nameFlag == PlayMenuNameFlag.RATE,
605
+ );
606
+ if (_ratePosition != undefined && _ratePosition > -1) {
607
+ mediaMenuViewRef.value.update(_ratePosition, `倍速${e.text}`);
608
+ if (menuList && menuList.value) {
609
+ const length = menuList.value.length;
610
+ if (length > 0) {
611
+ const menuItem = menuList.value[_ratePosition];
612
+ menuItem.name = `倍速${e.text}`; //解决-切换选集后倍速不正确的问题
613
+ }
614
+ }
615
+ }
616
+ playerManager?.setPlayRate(e.rate);
617
+ toast.showToast("切换成功"); //+e.rate
618
+ }
619
+ if (!isPlayerPlaying.value) {
620
+ playerManager.start(0);
621
+ isPlayerPlaying.value = true;
622
+ }
623
+ resetShowViewState(IMediaViewState.STATE_MANAGER_VIEW_DISMISS);
624
+ break;
625
+ // case PlayMenuNameFlag.DEFINITION_ITEM:
626
+ // viewState = IMediaViewState.STATE_MENU_DEFINITION_VIEW_DISMISS
627
+ // if (!isSameLocation){
628
+ // mediaMenuViewRef.value.update(curMenuClickPosition,e.text)
629
+ // playerManager?.setDefinition(e.definition)
630
+ // toast.showToast("切换成功")
631
+ // }
632
+ // if (!isPlayerPlaying.value) {
633
+ // playerManager.start(0)
634
+ // isPlayerPlaying.value = true
635
+ // }
636
+ // resetShowViewState(IMediaViewState.STATE_MANAGER_VIEW_DISMISS)
637
+ // break;
638
+ case PlayMenuNameFlag.SETTING_ITEM:
639
+ viewState = IMediaViewState.STATE_MENU_MODE_VIEW_DISMISS;
640
+ if (!isSameLocation) {
641
+ playerManager?.setPlayMediaListMode(e.mode);
642
+ toast.showToast("切换成功");
643
+ }
644
+ if (!isPlayerPlaying.value) {
645
+ playerManager.start(0);
646
+ isPlayerPlaying.value = true;
647
+ }
648
+ resetShowViewState(IMediaViewState.STATE_MANAGER_VIEW_DISMISS);
649
+ break;
650
+ default:
651
+ // eventBus.emit(bottomMenuClickEventBusName,e)
652
+ setPlayerViewStateDismiss();
653
+ break;
654
+ }
655
+ };
656
+
657
+ /**
658
+ * 重置当前 View 展示状态
659
+ * @param ref
660
+ * @param position
661
+ */
662
+ const resetShowViewState = (waitStatus?: IMediaViewState) => {
663
+ switch (viewState) {
664
+ case IMediaViewState.STATE_MANAGER_VIEW_SHOW:
665
+ isShowManagerView.value = true;
666
+ isShowBottomView.value = true;
667
+ if (curControlRef && curControlRef.value.getViewShowState()) {
668
+ curControlRef.value.dismissView();
669
+ }
670
+ break;
671
+ case IMediaViewState.STATE_MANAGER_VIEW_DISMISS:
672
+ autofocusType.value = 0;
673
+ isShowManagerView.value = false;
674
+ isShowBottomView.value = true;
675
+ isShowSeekBarTip.value = false;
676
+ if (curControlRef && curControlRef.value.getViewShowState()) {
677
+ curControlRef.value.dismissView();
678
+ }
679
+ break;
680
+ case IMediaViewState.STATE_MENU_RATE_VIEW_SHOW:
681
+ case IMediaViewState.STATE_MENU_DEFINITION_VIEW_SHOW:
682
+ case IMediaViewState.STATE_MENU_MODE_VIEW_SHOW:
683
+ curControlRef.value.showView();
684
+ isShowBottomView.value = false;
685
+ break;
686
+ case IMediaViewState.STATE_MENU_RATE_VIEW_DISMISS:
687
+ case IMediaViewState.STATE_MENU_DEFINITION_VIEW_DISMISS:
688
+ case IMediaViewState.STATE_MENU_MODE_VIEW_DISMISS:
689
+ if (curControlRef.value.getViewShowState()) {
690
+ curControlRef.value.dismissView();
691
+ }
692
+ if (waitStatus === IMediaViewState.STATE_MANAGER_VIEW_DISMISS) {
693
+ setPlayerViewStateDismiss();
694
+ }
695
+ break;
696
+ case IMediaViewState.STATE_SEEK_BAR_START:
697
+ isShowSeekBarTip.value = true;
698
+ break;
699
+ case IMediaViewState.STATE_SEEK_BAR_END:
700
+ viewState = waitStatus;
701
+ break;
702
+ }
703
+ };
704
+
705
+ /**
706
+ * 当前 manager view 是否隐藏
707
+ */
708
+ function isPlayerViewStateDismiss() {
709
+ return IMediaViewState.STATE_MANAGER_VIEW_DISMISS === viewState;
710
+ }
711
+
712
+ /**
713
+ * 右侧菜单是否展示
714
+ */
715
+ function isMenuViewStateShow() {
716
+ return (
717
+ IMediaViewState.STATE_MENU_RATE_VIEW_SHOW === viewState ||
718
+ IMediaViewState.STATE_MENU_DEFINITION_VIEW_SHOW === viewState ||
719
+ IMediaViewState.STATE_MENU_MODE_VIEW_SHOW === viewState
720
+ );
721
+ }
722
+
723
+ /**
724
+ * 当前 manager view 是否显示
725
+ */
726
+ function isPlayerViewStateShow() {
727
+ return (
728
+ IMediaViewState.STATE_MANAGER_VIEW_SHOW === viewState ||
729
+ IMediaViewState.STATE_SEEK_BAR_START === viewState
730
+ );
731
+ }
732
+
733
+ /**
734
+ * 设置当前 manager view 显示
735
+ */
736
+ function setPlayerViewStateShow() {
737
+ viewState = IMediaViewState.STATE_MANAGER_VIEW_SHOW;
738
+ resetShowViewState();
739
+ //这里通过autofocus来请求焦点,去掉此处调用
740
+ // requestFocus()
741
+ }
742
+
743
+ /**
744
+ * 设置当前 manager view 隐藏
745
+ */
746
+ function setPlayerViewStateDismiss() {
747
+ viewState = IMediaViewState.STATE_MANAGER_VIEW_DISMISS;
748
+ resetShowViewState();
749
+ }
750
+
751
+ /**
752
+ * 设置当前 view 隐藏
753
+ * @param delay 延时
754
+ */
755
+ function setPlayerViewStateDismissDelay(delay: number = 4000) {
756
+ clearDismissTimer();
757
+ dismissTimer = setTimeout(() => {
758
+ setPlayerViewStateDismiss();
759
+ }, delay);
760
+ }
761
+
762
+ /**
763
+ * 清除定时器
764
+ */
765
+ function clearDismissTimer() {
766
+ if (dismissTimer) {
767
+ clearTimeout(dismissTimer);
768
+ }
769
+ }
770
+
771
+ function onKeyDown(keyEvent: ESKeyEvent): boolean {
772
+ if (
773
+ playerManager &&
774
+ playerManager.getWindowType() !=
775
+ ESPlayerWindowType.ES_PLAYER_WINDOW_TYPE_FULL
776
+ ) {
777
+ return false;
778
+ }
779
+ if (isPlayerPlaying.value) {
780
+ setPlayerViewStateDismissDelay(4000);
781
+ }
782
+ switch (keyEvent.keyCode) {
783
+ case ESKeyCode.ES_KEYCODE_DPAD_CENTER:
784
+ case ESKeyCode.ES_KEYCODE_ENTER:
785
+ if (isPlayerViewStateDismiss()) {
786
+ setPlayerViewStateShow();
787
+ }
788
+ if (isMenuViewStateShow()) {
789
+ return true;
790
+ }
791
+ if (isPlayerViewStateShow()) {
792
+ if (bottomViewFocus) {
793
+ return true;
794
+ }
795
+ if (isPlayerPlaying.value) {
796
+ playerManager.pause();
797
+ isPlayerPlaying.value = false;
798
+ clearDismissTimer();
799
+ } else {
800
+ playerManager.start(0);
801
+ isPlayerPlaying.value = true;
802
+ }
803
+ return true;
804
+ }
805
+ break;
806
+ case ESKeyCode.ES_KEYCODE_DPAD_LEFT:
807
+ case ESKeyCode.ES_KEYCODE_DPAD_RIGHT:
808
+ autofocusType.value = 0;
809
+ if (isPlayerViewStateDismiss()) {
810
+ setPlayerViewStateShow();
811
+ return true;
812
+ }
813
+ if (isPlayerViewStateShow()) {
814
+ if (mediaManagerSeekBarRef.value?.isFocused() && curDuration > 0) {
815
+ mediaManagerSeekBarRef.value?.startSeek(
816
+ keyEvent.keyCode === ESKeyCode.ES_KEYCODE_DPAD_RIGHT,
817
+ );
818
+ }
819
+ return true;
820
+ }
821
+ break;
822
+ case ESKeyCode.ES_KEYCODE_DPAD_DOWN:
823
+ autofocusType.value = 1;
824
+ if (isPlayerViewStateDismiss()) {
825
+ setPlayerViewStateShow();
826
+ }
827
+ break;
828
+ }
829
+ return true;
830
+ }
831
+
832
+ function onKeyUp(keyEvent: ESKeyEvent): boolean {
833
+ if (
834
+ playerManager.getWindowType() !=
835
+ ESPlayerWindowType.ES_PLAYER_WINDOW_TYPE_FULL
836
+ ) {
837
+ return false;
838
+ }
839
+ if (
840
+ isPlayerPlaying.value ||
841
+ isMenuViewStateShow() ||
842
+ viewState === IMediaViewState.STATE_SEEK_BAR_START
843
+ ) {
844
+ const delay =
845
+ viewState === IMediaViewState.STATE_SEEK_BAR_START ? 3000 : 4000;
846
+ setPlayerViewStateDismissDelay(delay);
847
+ }
848
+ switch (keyEvent.keyCode) {
849
+ case ESKeyCode.ES_KEYCODE_DPAD_LEFT:
850
+ case ESKeyCode.ES_KEYCODE_DPAD_RIGHT:
851
+ if (
852
+ isPlayerViewStateShow() &&
853
+ mediaManagerSeekBarRef.value?.isFocused() &&
854
+ curDuration > 0
855
+ ) {
856
+ mediaManagerSeekBarRef.value?.stopSeek();
857
+ }
858
+ isSeeking = false;
859
+ return true;
860
+ }
861
+ return true;
862
+ }
863
+
864
+ function onBackPressed(): boolean {
865
+ if (
866
+ playerManager.getWindowType() !=
867
+ ESPlayerWindowType.ES_PLAYER_WINDOW_TYPE_FULL
868
+ ) {
869
+ return false;
870
+ }
871
+ if (isMenuViewStateShow()) {
872
+ setPlayerViewStateDismiss();
873
+ return true;
874
+ }
875
+ if (!isPlayerPlaying.value) {
876
+ isPlayerPlaying.value = true;
877
+ playerManager.start(0);
878
+ setPlayerViewStateDismissDelay(4000); //暂停播放,再恢复播放时,4秒后隐藏控制条
879
+ return true;
880
+ }
881
+ if (isPlayerViewStateShow()) {
882
+ setPlayerViewStateDismiss();
883
+ return true;
884
+ }
885
+ return false;
886
+ }
887
+
888
+ function isViewShow(): boolean {
889
+ return isFullWindow.value && isShowManagerView.value;
890
+ }
891
+
892
+ const replyRate = (r?: any) => {
893
+ playerManager?.setPlayRate(r || rate); //恢复播放倍速为上次设置的值
894
+ };
895
+ const clear = () => {
896
+ playerManager?.setPlayRate(ESPlayerRate.ES_PLAYER_RATE_1); //页面退出时,恢复播放倍速为1.0
897
+ };
898
+ defineExpose({
899
+ getId,
900
+ initMenuList,
901
+ setShowView,
902
+ setPlayerManager,
903
+ getPlayerManager,
904
+ onPlayerPlayMedia,
905
+ onPlayerPlaying,
906
+ onPlayerPaused,
907
+ onPlayerWindowSizeChanged,
908
+ onPlayerWindowTypeChanged,
909
+ onPlayerProgressChanged,
910
+ onPlayerDurationChanged,
911
+ onSeekBarSeekStart,
912
+ onSeekBarSeekStop,
913
+ onSeekbarFocusChanged,
914
+ onPlayerPlayRateListChanged,
915
+ onPlayerPlayRateChanged,
916
+ onPlayerDefinitionListChanged,
917
+ onPlayerDefinitionChanged,
918
+ onPlayerPlayMediaListModeListChanged,
919
+ onPlayerPlayMediaListModeChanged,
920
+ onItemFocused,
921
+ onItemClicked,
922
+ onKeyDown,
923
+ onKeyUp,
924
+ onBackPressed,
925
+ replyRate,
926
+ clear,
927
+ isViewShow,
928
+ });
929
+ </script>
930
+
931
+ <style lang="scss" src="./scss/media-manager.scss"></style>