@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,238 @@
1
+ <template>
2
+ <qt-column class="media-introduction-root">
3
+ <!-- 标题 -->
4
+ <qt-text
5
+ class="title"
6
+ :duplicateParentState="true"
7
+ :focusable="false"
8
+ :fontSize="60"
9
+ :ellipsizeMode="2"
10
+ enablePostTask
11
+ postDelay="200"
12
+ :lines="1"
13
+ typeFace="bold"
14
+ gravity="left|top"
15
+ :text="title"
16
+ />
17
+
18
+ <!-- 底部介绍 -->
19
+ <qt-column
20
+ class="introduction-box"
21
+ :enableFocusBorder="true"
22
+ :clipChildren="false"
23
+ :focusable="true"
24
+ @click="onClick"
25
+ @focus="onFocus"
26
+ :focusScale="ThemeConfig.placeHolderFocusScale"
27
+ >
28
+ <!-- :style="{ 'focus-border-color': isFree ? '#FFFFFF' : '#FFD97C' }"-->
29
+ <!-- 第一行 -->
30
+ <qt-row :duplicateParentState="true">
31
+ <div
32
+ class="item-vip"
33
+ v-if="!isFree"
34
+ :gradientBackground="{
35
+ colors: ['#A06419', '#CDA048'],
36
+ orientation: 6,
37
+ cornerRadii4: [4, 4, 4, 4],
38
+ }"
39
+ >
40
+ <qt-text
41
+ class="item-vip-text"
42
+ :duplicateParentState="true"
43
+ :focusable="false"
44
+ :textSize="24"
45
+ :ellipsizeMode="2"
46
+ enablePostTask
47
+ postDelay="200"
48
+ :lines="1"
49
+ gravity="center"
50
+ text="影视VIP"
51
+ />
52
+ </div>
53
+
54
+ <div class="item-score" v-if="score">
55
+ <text-view
56
+ class="item-score-text"
57
+ :duplicateParentState="true"
58
+ :focusable="false"
59
+ :textSize="24"
60
+ :ellipsizeMode="2"
61
+ enablePostTask
62
+ postDelay="200"
63
+ :lines="1"
64
+ gravity="center"
65
+ :text="score"
66
+ />
67
+ </div>
68
+ </qt-row>
69
+ <!-- 第二行 -->
70
+ <qt-text
71
+ class="item-tag-text"
72
+ :duplicateParentState="true"
73
+ :focusable="false"
74
+ :fontSize="24"
75
+ :ellipsizeMode="2"
76
+ enablePostTask
77
+ postDelay="200"
78
+ :lines="1"
79
+ gravity="left|center"
80
+ :text="tag"
81
+ />
82
+
83
+ <!-- 第三行 -->
84
+ <qt-text
85
+ v-if="actors"
86
+ class="item-actors-text"
87
+ :duplicateParentState="true"
88
+ :focusable="false"
89
+ :textSize="24"
90
+ :ellipsizeMode="2"
91
+ enablePostTask
92
+ postDelay="200"
93
+ :lines="1"
94
+ gravity="left|center"
95
+ :text="actors"
96
+ />
97
+
98
+ <!-- 第四行 -->
99
+ <qt-text
100
+ class="item-desc-text"
101
+ :duplicateParentState="true"
102
+ :focusable="false"
103
+ :fontSize="24"
104
+ :ellipsizeMode="2"
105
+ enablePostTask
106
+ postDelay="200"
107
+ :lines="3"
108
+ :lineHeight="42"
109
+ gravity="left|center"
110
+ :text="description"
111
+ />
112
+ </qt-column>
113
+ </qt-column>
114
+ </template>
115
+
116
+ <script setup lang="ts" name="media-introduction">
117
+ import { ref } from "vue";
118
+ import { useESRouter } from "@extscreen/es3-router";
119
+ import { IMedia } from "../../../adapter/interface";
120
+ import ThemeConfig from "../../../../../config/theme-config";
121
+ const emits = defineEmits(["onIntroductionFocus"]);
122
+ const router = useESRouter();
123
+ let title = ref<string>("");
124
+ let score = ref<string>("");
125
+ let tag = ref<string>("");
126
+ let actors = ref<string>("");
127
+ let description = ref<string>("");
128
+ let isFree = ref<boolean>(true);
129
+ let m: IMedia;
130
+
131
+ const init = (media: IMedia) => {
132
+ m = media;
133
+ isFree.value = media.vipType == "0" ? true : false;
134
+ title.value = media.title;
135
+ score.value = media.score;
136
+ tag.value = media.tags;
137
+ actors.value = media.actors;
138
+ description.value = media.description;
139
+ };
140
+ const onClick = () => {
141
+ router.push({
142
+ name: "introduction",
143
+ params: m,
144
+ });
145
+ };
146
+ const onFocus = (e) => emits("onIntroductionFocus", e.isFocused);
147
+ defineExpose({
148
+ init,
149
+ });
150
+ </script>
151
+
152
+ <style lang="scss" scoped>
153
+ .media-introduction-root {
154
+ width: 810px;
155
+ height: 320px;
156
+ background-color: transparent;
157
+ margin-top: -15px;
158
+ .title {
159
+ width: 790px;
160
+ height: 72px;
161
+ margin-left: 20px;
162
+ color: #ffffff;
163
+ }
164
+ .introduction-box {
165
+ width: 810px;
166
+ height: 250px;
167
+ padding-left: 20px;
168
+ padding-top: 15px;
169
+ margin-top: 15px;
170
+ padding-bottom: 10px;
171
+ focus-border-color: $theme-focus-border-color;
172
+ border-radius: $theme-img-border;
173
+ focus-border-radius: $theme-img-border;
174
+ background-color: transparent;
175
+ focus-background-color: rgba(255, 255, 255, 0.1);
176
+ .item-vip {
177
+ margin-right: 20px;
178
+ border-color: #f7b500;
179
+ align-items: center;
180
+ display: flex;
181
+ height: 36px;
182
+ width: 100px;
183
+ flex-direction: row;
184
+ justify-content: center;
185
+ }
186
+ .item-vip-text {
187
+ font-size: 24px;
188
+ color: #ffffff;
189
+ margin-left: 12px;
190
+ margin-right: 12px;
191
+ height: 36px;
192
+ width: 100px;
193
+ }
194
+ .item-score {
195
+ border-radius: 4px;
196
+ margin-right: 20px;
197
+ border-color: #ffffff;
198
+ border-width: 1px;
199
+ align-items: center;
200
+ display: flex;
201
+ width: 60px;
202
+ height: 32px;
203
+ flex-direction: row;
204
+ justify-content: center;
205
+ background-color: rgba(255, 255, 255, 0.06);
206
+ }
207
+ .item-score-text {
208
+ top: -1px;
209
+ font-size: 24px;
210
+ color: #ffffff;
211
+ width: 60px;
212
+ height: 32px;
213
+ }
214
+ .item-tag-text {
215
+ color: rgba(255, 255, 255, 0.6);
216
+ focus-color: white;
217
+ height: 34px;
218
+ width: 668px;
219
+ margin-top: 15px;
220
+ margin-bottom: 8px;
221
+ }
222
+ .item-actors-text {
223
+ height: 28px;
224
+ width: 814px;
225
+ color: rgba(255, 255, 255, 0.6);
226
+ focus-color: white;
227
+ margin-top: 5px;
228
+ }
229
+ .item-desc-text {
230
+ color: rgba(255, 255, 255, 0.6);
231
+ focus-color: white;
232
+ width: 790px;
233
+ height: 118px;
234
+ margin-top: 5px;
235
+ }
236
+ }
237
+ }
238
+ </style>
@@ -0,0 +1,308 @@
1
+ <template>
2
+ <qt-view
3
+ class="media-series-root"
4
+ :clipChildren="false"
5
+ :clipPadding="false"
6
+ :focusable="false"
7
+ :visible="visible"
8
+ >
9
+ <!-- 选集标题 -->
10
+ <div class="media-series-title" :focusable="false">
11
+ <qt-text
12
+ class="media-series-title-text"
13
+ :focusable="false"
14
+ :fontSize="40"
15
+ text="选集"
16
+ />
17
+ </div>
18
+ <!-- 选集内容 -->
19
+ <qt-media-series
20
+ ref="mediaSeriesRef"
21
+ class="media-series"
22
+ :clipChildren="false"
23
+ :focusable="false"
24
+ :visible="visible"
25
+ :textColors="{
26
+ color: ThemeConfig.textNormalColor,
27
+ focusColor: ThemeConfig.textFocusColor,
28
+ selectColor: ThemeConfig.textSelectColor,
29
+ }"
30
+ :markColor="ThemeConfig.textFocusColor"
31
+ :gradientBackground="{
32
+ colors: ThemeConfig.btnGradientNormalColor,
33
+ cornerRadius: 8,
34
+ orientation: 6,
35
+ }"
36
+ :gradientFocusBackground="{
37
+ colors: ThemeConfig.btnGradientFocusColor,
38
+ cornerRadius: 8,
39
+ orientation: 6,
40
+ }"
41
+ :commonParam="{ itemGap: 32, contentWidth: 1760 }"
42
+ @loadData="onLoadData"
43
+ @itemClick="onItemClick"
44
+ @itemFocused="onItemFocused"
45
+ @groupItemFocused="onGroupItemFocused"
46
+ >
47
+ <template v-slot:default>
48
+ <qt-view
49
+ class="media-series-item"
50
+ :focusable="true"
51
+ :enableFocusBorder="true"
52
+ :focusScale="ThemeConfig.placeHolderFocusScale"
53
+ >
54
+ <qt-image
55
+ class="media-series-item-img"
56
+ src="${cover}"
57
+ :focusable="false"
58
+ ></qt-image>
59
+ <qt-view class="media-series-item-info" duplicateParentState>
60
+ <qt-text
61
+ class="media-series-item-text"
62
+ text="${text}"
63
+ :lines="2"
64
+ :ellipsizeMode="2"
65
+ :focusable="false"
66
+ duplicateParentState
67
+ :fontSize="26"
68
+ ></qt-text>
69
+ <qt-text
70
+ class="media-series-item-duartion"
71
+ text="${duartion}"
72
+ :lines="2"
73
+ :ellipsizeMode="2"
74
+ :focusable="false"
75
+ duplicateParentState
76
+ :fontSize="22"
77
+ ></qt-text>
78
+ <qt-view
79
+ class="play_Mark"
80
+ :focusable="false"
81
+ :showOnState="['selected']"
82
+ duplicateParentState
83
+ >
84
+ <play-mark
85
+ :style="{ width: '18px', height: '20px' }"
86
+ markColor="#ffffff"
87
+ :focusable="false"
88
+ :showType="0"
89
+ :roundCorner="1"
90
+ />
91
+ </qt-view>
92
+ </qt-view>
93
+ </qt-view>
94
+ </template>
95
+ </qt-media-series>
96
+ </qt-view>
97
+ </template>
98
+
99
+ <script setup lang="ts" name="MediaSeries">
100
+ import { ref, onMounted, onUnmounted } from "vue";
101
+ import { ESLogLevel, useESEventBus, useESLog } from "@extscreen/es3-core";
102
+ import { QTIMediaSeries, QTMediaSeriesEvent } from "@quicktvui/quicktvui3";
103
+ import { IMedia, IMediaItem } from "../../../adapter/interface";
104
+ import ThemeConfig from "../../../../../config/theme-config";
105
+ import {
106
+ buildMediaSeriesType,
107
+ buildMediaSeriesGroup,
108
+ buildMediaSeriesStyleType,
109
+ buildMediaSeriesData,
110
+ buildMediaSeriesList,
111
+ } from "../../../adapter/index";
112
+ import detailManager from "../../../api/index";
113
+ const TAG = "MediaSeriesView";
114
+ const emits = defineEmits([
115
+ "onMediaSeriesItemLoad",
116
+ "onMediaSeriesItemFocus",
117
+ "onMediaSeriesItemClick",
118
+ "onMediaSeriesGroupItemFocus",
119
+ ]);
120
+ const log = useESLog();
121
+ const eventbus = useESEventBus();
122
+ const mediaSeriesRef = ref<QTIMediaSeries>();
123
+ let m: IMedia;
124
+ let visible = ref(false);
125
+ let selectedIndex = ref(0);
126
+ const dataMap = new Map<number, Array<IMediaItem>>();
127
+ const init = (media: IMedia) => {
128
+ m = media;
129
+ if (media.episodes > 1) visible.value = true;
130
+ mediaSeriesRef.value?.setInitData(
131
+ buildMediaSeriesType(media.mediaSeriesType),
132
+ buildMediaSeriesGroup(),
133
+ buildMediaSeriesStyleType(),
134
+ buildMediaSeriesData(media),
135
+ );
136
+ if (!visible.value) {
137
+ getMediaList(m.episodesId, 1);
138
+ }
139
+ };
140
+ onMounted(() => {
141
+ eventbus.on("onMediaSeriesLoadData", onMediaSeriesLoadData);
142
+ });
143
+ onUnmounted(() => {
144
+ eventbus.off("onMediaSeriesLoadData", onMediaSeriesLoadData);
145
+ });
146
+ const onMediaSeriesLoadData = (page: number) => {
147
+ page = page || 1;
148
+ getMediaList(m.episodesId, page);
149
+ };
150
+ const getMediaList = (episodesId: string, pageNo: number) => {
151
+ if (dataMap.has(pageNo)) {
152
+ //TODO 等待左图右文修改获取数据的bug
153
+ return;
154
+ }
155
+ detailManager.getMediaSeriesList(episodesId, pageNo, 10).then(
156
+ (mediaList: Array<IMediaItem>) => {
157
+ dataMap.set(pageNo, mediaList);
158
+ if (log.isLoggable(ESLogLevel.DEBUG)) {
159
+ log.d(
160
+ TAG,
161
+ "-------getMediaList----success------>>>>>",
162
+ pageNo,
163
+ mediaList,
164
+ );
165
+ }
166
+ mediaSeriesRef.value?.setPageData(
167
+ pageNo - 1,
168
+ buildMediaSeriesList(mediaList),
169
+ );
170
+ setSelected(0);
171
+ emits("onMediaSeriesItemLoad", pageNo, mediaList);
172
+ },
173
+ (error) => {
174
+ if (log.isLoggable(ESLogLevel.DEBUG)) {
175
+ log.d(TAG, "-------getMediaList----error------>>>>>", error);
176
+ }
177
+ },
178
+ );
179
+ };
180
+ const onLoadData = (event: QTMediaSeriesEvent) => {
181
+ const page = event.page || 1;
182
+ getMediaList(m.episodesId, page);
183
+ };
184
+ const onItemClick = (event: QTMediaSeriesEvent) => {
185
+ if (log.isLoggable(ESLogLevel.DEBUG)) {
186
+ log.d(TAG, "--------onItemClick----->>>>>", event);
187
+ }
188
+ let index = event.position;
189
+ let data = event.data;
190
+ emits("onMediaSeriesItemClick", index, data);
191
+ };
192
+ const onItemFocused = (event: QTMediaSeriesEvent) => {
193
+ if (log.isLoggable(ESLogLevel.DEBUG)) {
194
+ log.d(TAG, "-------onItemFocused----->>>>>", event);
195
+ }
196
+ let index = event.position;
197
+ emits("onMediaSeriesItemFocus", index);
198
+ };
199
+ const onGroupItemFocused = (event: QTMediaSeriesEvent) => {
200
+ let index = event.position;
201
+ emits("onMediaSeriesGroupItemFocus", index);
202
+ };
203
+ const setSelected = (position: number): void => {
204
+ if (log.isLoggable(ESLogLevel.DEBUG)) {
205
+ log.d(TAG, "-------选集组件----setSelected------>>>>>" + position);
206
+ }
207
+ selectedIndex.value = position;
208
+ mediaSeriesRef.value?.setSelected(selectedIndex.value);
209
+ };
210
+ const scrollTo = (position: number): void => {
211
+ if (log.isLoggable(ESLogLevel.DEBUG)) {
212
+ log.d(TAG, "-------选集组件----scrollTo------>>>>>" + position);
213
+ }
214
+ mediaSeriesRef.value?.scrollTo(position);
215
+ };
216
+ const getSelectedPosition = (): number => {
217
+ return selectedIndex.value;
218
+ };
219
+ const requestFocus = (position: number): void => {
220
+ mediaSeriesRef.value?.requestFocus(position);
221
+ };
222
+ const release = (): void => {
223
+ if (log.isLoggable(ESLogLevel.DEBUG)) {
224
+ log.d(TAG, "-------选集组件----release------>>>>>");
225
+ }
226
+ dataMap.clear();
227
+ mediaSeriesRef.value?.release();
228
+ };
229
+ defineExpose({
230
+ init,
231
+ setSelected,
232
+ scrollTo,
233
+ getSelectedPosition,
234
+ requestFocus,
235
+ release,
236
+ });
237
+ </script>
238
+
239
+ <style lang="scss" scoped>
240
+ .media-series-root {
241
+ width: 1920px;
242
+ height: 299px;
243
+ margin-top: 30px;
244
+ background-color: transparent;
245
+ .media-series-title {
246
+ flex-direction: row;
247
+ align-items: center;
248
+ justify-content: flex-start;
249
+ margin-left: 80px;
250
+ width: 180px;
251
+ height: 50px;
252
+ .media-series-title-text {
253
+ width: 180px;
254
+ height: 50px;
255
+ color: #fff;
256
+ }
257
+ }
258
+ .media-series {
259
+ width: 1920px;
260
+ margin-top: 40px;
261
+ background-color: transparent;
262
+ .media-series-item {
263
+ width: 434px;
264
+ height: 137px;
265
+ border-radius: 8px;
266
+ background-color: rgba(255, 255, 255, 0.1);
267
+ flex-direction: row;
268
+ padding-top: 12px;
269
+ padding-left: 10px;
270
+ padding-bottom: 12px;
271
+ .media-series-item-img {
272
+ width: 202px;
273
+ height: 114px;
274
+ border-radius: 8px;
275
+ }
276
+ .media-series-item-info {
277
+ width: 200px;
278
+ height: 113px;
279
+ margin-left: 20px;
280
+ background-color: transparent;
281
+ flex-direction: row;
282
+ flex-wrap: wrap;
283
+ .media-series-item-text {
284
+ width: 195px;
285
+ height: 80px;
286
+ color: rgba(255, 255, 255, 0.5);
287
+ focus-color: rgba(255, 255, 255, 1);
288
+ select-color: rgba(255, 255, 255, 1);
289
+ }
290
+ .media-series-item-duartion {
291
+ width: 60px;
292
+ height: 30px;
293
+ color: rgba(255, 255, 255, 0.5);
294
+ focus-color: rgba(255, 255, 255, 1);
295
+ select-color: rgba(255, 255, 255, 1);
296
+ }
297
+ .play_Mark {
298
+ width: 42px;
299
+ height: 30px;
300
+ background-color: transparent;
301
+ margin-top: 5px;
302
+ margin-left: 95px;
303
+ }
304
+ }
305
+ }
306
+ }
307
+ }
308
+ </style>
@@ -0,0 +1,88 @@
1
+ <template>
2
+ <div
3
+ class="player-placeholder-root"
4
+ ref="placeholder"
5
+ @click="onClick"
6
+ @focus="onFocus"
7
+ name="placeholder"
8
+ :autofocus="autofocus"
9
+ :focusable="true"
10
+ :blockFocusDirections="['left']"
11
+ :enableFocusBorder="true"
12
+ >
13
+ <qt-view class="player-placeholder-mask" :focusable="false"></qt-view>
14
+ <qt-image
15
+ class="player-placeholder-img"
16
+ v-if="isShowPlayerPlaceholderImg"
17
+ :duplicateParentState="true"
18
+ :focusable="false"
19
+ :enableFocusBorder="false"
20
+ :src="playerPplaceholderUrl"
21
+ />
22
+ </div>
23
+ </template>
24
+
25
+ <script setup lang="ts" name="PlayerPlaceholder">
26
+ import { ref } from "vue";
27
+ import { ESFocusable, useESFocus } from "@extscreen/es3-core";
28
+ import { IMedia } from "../../../adapter/interface";
29
+ const emits = defineEmits(["onPlaceholderClick", "onPlaceholderFocus"]);
30
+ const focus = useESFocus();
31
+ const placeholder = ref<ESFocusable>();
32
+ let autofocus = ref<boolean>(false);
33
+ let isFree = ref<boolean>(true);
34
+ let isShowPlayerPlaceholderImg = ref<boolean>(true);
35
+ let playerPplaceholderUrl = ref<string>("");
36
+
37
+ const showPlayerPlaceholderImg = (value: boolean) => {
38
+ isShowPlayerPlaceholderImg.value = value;
39
+ };
40
+ const init = (media: IMedia) => {
41
+ playerPplaceholderUrl.value = media.cover;
42
+ };
43
+ const requestFocus = () => {
44
+ if (placeholder.value) focus.requestFocusDirectly(placeholder.value!);
45
+ };
46
+ const setAutofocus = (enable: boolean) => (autofocus.value = enable);
47
+ const onClick = () => emits("onPlaceholderClick");
48
+ const onFocus = (e) => emits("onPlaceholderFocus", e.isFocused);
49
+
50
+ defineExpose({
51
+ init,
52
+ requestFocus,
53
+ setAutofocus,
54
+ showPlayerPlaceholderImg,
55
+ });
56
+ </script>
57
+
58
+ <style lang="scss" scoped>
59
+ .player-placeholder-root {
60
+ width: 894px;
61
+ height: 504px;
62
+ margin-left: 78px;
63
+ margin-top: -2px;
64
+ flex-direction: row;
65
+ align-items: center;
66
+ justify-content: center;
67
+ focus-border-color: $theme-focus-border-color;
68
+ focus-border-width: 3;
69
+ focus-border-radius: $theme-img-border;
70
+ .player-placeholder-mask {
71
+ width: 890px;
72
+ height: 500px;
73
+ position: absolute;
74
+ left: 2px;
75
+ top: 2px;
76
+ background-color: rgba(255, 255, 255, 0.1);
77
+ display: flex;
78
+ flex-direction: row;
79
+ align-items: center;
80
+ justify-content: center;
81
+ }
82
+ .player-placeholder-img {
83
+ width: 890px;
84
+ height: 500px;
85
+ background-color: transparent;
86
+ }
87
+ }
88
+ </style>