@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,98 @@
1
+ <template>
2
+ <item-frame
3
+ class="qt-ui-poster-root-css"
4
+ :type="101"
5
+ layout="${layout}"
6
+ flexStyle="${style}"
7
+ :focusable="true"
8
+ :clipChildren="false"
9
+ name="innerItem"
10
+ itemShowShimmer="${shimmer.enable}"
11
+ shimmerSize="${shimmer.size}"
12
+ eventClick
13
+ eventFocus
14
+ >
15
+ <img
16
+ class="my-poster-img-css"
17
+ :duplicateParentState="true"
18
+ :postDelay="300"
19
+ :focusable="false"
20
+ :enableFocusBorder="true"
21
+ flexStyle="${image.style}"
22
+ src="${image.src}"
23
+ />
24
+ <div
25
+ class="poster-title"
26
+ flexStyle="${titleBoxStyle}"
27
+ :duplicateParentState="true"
28
+ :focusable="false"
29
+ >
30
+ <text-view
31
+ :duplicateParentState="true"
32
+ :focusable="false"
33
+ textSize="${title.style.fontSize}"
34
+ :ellipsizeMode="4"
35
+ :lines="1"
36
+ :postDelay="200"
37
+ gravity="center|left"
38
+ flexStyle="${title.style}"
39
+ text="${title.text}"
40
+ showIf="${title.enable}"
41
+ :paddingRect="[5, 0, 0, 0]"
42
+ class="poster-title-text"
43
+ />
44
+ <text-view
45
+ class="poster-subtitle"
46
+ :focusable="false"
47
+ fontSize="${subTitle.style.fontSize}"
48
+ :ellipsizeMode="2"
49
+ :lines="1"
50
+ gravity="centerVertical|left"
51
+ flexStyle="${subTitle.style}"
52
+ :duplicateParentState="true"
53
+ text="${subTitle.text}"
54
+ visibility="${subTitle}"
55
+ :paddingRect="[5, 0, 0, 0]"
56
+ />
57
+ </div>
58
+ </item-frame>
59
+ </template>
60
+
61
+ <script lang="ts">
62
+ import { defineComponent } from "vue";
63
+ export default defineComponent({
64
+ name: "my-poster",
65
+ setup() {
66
+ return {};
67
+ },
68
+ });
69
+ </script>
70
+
71
+ <style scoped>
72
+ .qt-ui-poster-root-css {
73
+ position: relative;
74
+ background-color: transparent;
75
+ overflow: hidden;
76
+ }
77
+ .my-poster-img-css {
78
+ background-color: transparent;
79
+ z-index: 1;
80
+ border-radius: 9px;
81
+ }
82
+ .poster-title {
83
+ position: absolute;
84
+ left: 0;
85
+ top: 0;
86
+ background-color: transparent;
87
+ z-index: 1;
88
+ }
89
+ .poster-title-text {
90
+ color: rgba(255, 255, 255, 0.55);
91
+ focus-color: #ffffff;
92
+ background-color: transparent;
93
+ }
94
+ .poster-subtitle {
95
+ color: rgba(255, 255, 255, 0.55);
96
+ background-color: transparent;
97
+ }
98
+ </style>
@@ -0,0 +1,90 @@
1
+ <template>
2
+ <div
3
+ :type="106"
4
+ layout="${layout}"
5
+ flexStyle="${style}"
6
+ :enableFocusBorder="true"
7
+ :focusable="true"
8
+ eventClick
9
+ :clipChildren="false"
10
+ eventFocus
11
+ class="my-poster-card2"
12
+ sid="${_id}"
13
+ >
14
+ <text-view
15
+ class="my-poster-card2-text"
16
+ :focusable="false"
17
+ autoWidth
18
+ autoHeight
19
+ textSize="${title.style.fontSize}"
20
+ textColor="${titleFontColor}"
21
+ :ellipsizeMode="2"
22
+ :lines="1"
23
+ gravity="center"
24
+ text="${title.text}"
25
+ />
26
+ <div class="my-poster-card2-icon" :duplicateParentState="true">
27
+ <img
28
+ class="my-poster-card2-icon-inner"
29
+ flexStyle="${icon.style}"
30
+ :duplicateParentState="true"
31
+ :showOnState="['normal', 'selected']"
32
+ :focusable="false"
33
+ src="${image.src}"
34
+ />
35
+ <img
36
+ class="my-poster-card2-icon-inner"
37
+ flexStyle="${icon.style}"
38
+ :duplicateParentState="true"
39
+ :showOnState="'focused'"
40
+ :focusable="false"
41
+ src="${focusedImageSrc}"
42
+ />
43
+ </div>
44
+
45
+ <text-view
46
+ class="my-poster-card2-tip"
47
+ :focusable="false"
48
+ autoWidth
49
+ autoHeight
50
+ :ellipsizeMode="2"
51
+ :lines="1"
52
+ gravity="center"
53
+ text="${tip}"
54
+ />
55
+ </div>
56
+ </template>
57
+ <script lang="ts" setup></script>
58
+ <style scoped>
59
+ .my-poster-card2 {
60
+ position: absolute;
61
+ align-items: center;
62
+ justify-content: center;
63
+ background-color: rgba(255, 255, 255, 0.06);
64
+ flex-direction: column;
65
+ border-radius: 16px;
66
+ focus-border-radius: 16px;
67
+ }
68
+ .my-poster-card2-text {
69
+ margin-top: 30px;
70
+ background-color: transparent;
71
+ font-weight: 500;
72
+ }
73
+ .my-poster-card2-icon {
74
+ margin-top: 40px;
75
+ background-color: transparent;
76
+ width: 100px;
77
+ height: 80px;
78
+ }
79
+ .my-poster-card2-icon-inner {
80
+ position: absolute;
81
+ top: 0;
82
+ left: 0;
83
+ }
84
+ .my-poster-card2-tip {
85
+ margin-top: 31px;
86
+ color: rgba(255, 255, 255, 0.55);
87
+ font-size: 24px;
88
+ height: 24px;
89
+ }
90
+ </style>
@@ -0,0 +1,72 @@
1
+ <template>
2
+ <div
3
+ :type="105"
4
+ layout="${layout}"
5
+ flexStyle="${style}"
6
+ :enableFocusBorder="true"
7
+ :focusable="true"
8
+ eventClick
9
+ :clipChildren="false"
10
+ eventFocus
11
+ class="my-icon-title-col"
12
+ sid="${_id}"
13
+ >
14
+ <div class="my-icon-title-col-icon" :duplicateParentState="true">
15
+ <img
16
+ class="my-icon-title-col-icon-inner"
17
+ flexStyle="${icon.style}"
18
+ :duplicateParentState="true"
19
+ :showOnState="['normal', 'selected']"
20
+ :focusable="false"
21
+ src="${image.src}"
22
+ />
23
+ <img
24
+ class="my-icon-title-col-icon-inner"
25
+ flexStyle="${icon.style}"
26
+ :duplicateParentState="true"
27
+ :showOnState="'focused'"
28
+ :focusable="false"
29
+ src="${focusedImageSrc}"
30
+ />
31
+ </div>
32
+ <text-view
33
+ class="my-icon-title-col-text"
34
+ :focusable="false"
35
+ autoWidth
36
+ autoHeight
37
+ textSize="${title.style.fontSize}"
38
+ textColor="${title.style.color}"
39
+ :ellipsizeMode="2"
40
+ :lines="1"
41
+ gravity="center"
42
+ text="${title.text}"
43
+ />
44
+ </div>
45
+ </template>
46
+ <script lang="ts" setup></script>
47
+ <style scoped>
48
+ .my-icon-title-col {
49
+ position: absolute;
50
+ align-items: center;
51
+ justify-content: center;
52
+ background-color: rgba(255, 255, 255, 0.06);
53
+ flex-direction: column;
54
+ border-radius: 16px;
55
+ focus-border-radius: 16px;
56
+ }
57
+ .my-icon-title-col-text {
58
+ background-color: transparent;
59
+ font-weight: 500;
60
+ }
61
+ .my-icon-title-col-icon {
62
+ background-color: transparent;
63
+ width: 80px;
64
+ height: 80px;
65
+ margin-bottom: 30px;
66
+ }
67
+ .my-icon-title-col-icon-inner {
68
+ position: absolute;
69
+ top: 0;
70
+ left: 0;
71
+ }
72
+ </style>
@@ -0,0 +1,72 @@
1
+ <template>
2
+ <div
3
+ :type="102"
4
+ layout="${layout}"
5
+ flexStyle="${style}"
6
+ :enableFocusBorder="true"
7
+ :focusable="true"
8
+ eventClick
9
+ :clipChildren="false"
10
+ eventFocus
11
+ class="my-icon-title-row"
12
+ sid="${_id}"
13
+ >
14
+ <div class="my-icon-title-row-icon" :duplicateParentState="true">
15
+ <img
16
+ class="my-icon-title-row-icon-inner"
17
+ flexStyle="${icon.style}"
18
+ :duplicateParentState="true"
19
+ :showOnState="['normal', 'selected']"
20
+ :focusable="false"
21
+ src="${image.src}"
22
+ />
23
+ <img
24
+ class="my-icon-title-row-icon-inner"
25
+ flexStyle="${icon.style}"
26
+ :duplicateParentState="true"
27
+ :showOnState="'focused'"
28
+ :focusable="false"
29
+ src="${focusedImageSrc}"
30
+ />
31
+ </div>
32
+ <text-view
33
+ class="my-icon-title-row-text"
34
+ :focusable="false"
35
+ autoWidth
36
+ autoHeight
37
+ textSize="${title.style.fontSize}"
38
+ textColor="${title.style.color}"
39
+ :ellipsizeMode="2"
40
+ :lines="1"
41
+ gravity="center"
42
+ text="${title.text}"
43
+ />
44
+ </div>
45
+ </template>
46
+ <script lang="ts" setup></script>
47
+ <style scoped>
48
+ .my-icon-title-row {
49
+ position: absolute;
50
+ align-items: center;
51
+ justify-content: center;
52
+ background-color: rgba(255, 255, 255, 0.06);
53
+ flex-direction: row;
54
+ border-radius: 16px;
55
+ focus-border-radius: 16px;
56
+ }
57
+ .my-icon-title-row-text {
58
+ margin-left: 30px;
59
+ background-color: transparent;
60
+ font-weight: 500;
61
+ }
62
+ .my-icon-title-row-icon {
63
+ background-color: transparent;
64
+ width: 80px;
65
+ height: 80px;
66
+ }
67
+ .my-icon-title-row-icon-inner {
68
+ position: absolute;
69
+ top: 0;
70
+ left: 0;
71
+ }
72
+ </style>
@@ -0,0 +1,50 @@
1
+ <template>
2
+ <div
3
+ :type="103"
4
+ layout="${layout}"
5
+ flexStyle="${style}"
6
+ :focusScale="false"
7
+ :focusable="true"
8
+ eventClick
9
+ :enableFocusBorder="true"
10
+ eventFocus
11
+ class="my-poster-into"
12
+ :clipChildren="false"
13
+ sid="${_id}"
14
+ >
15
+ <text-view
16
+ class="poster-into-title"
17
+ :focusable="false"
18
+ autoWidth
19
+ duplicateParentState
20
+ textSize="${title.style.fontSize}"
21
+ :ellipsizeMode="2"
22
+ :lines="1"
23
+ gravity="center"
24
+ text="${title.text}"
25
+ showIf="${title.enable}"
26
+ />
27
+ </div>
28
+ </template>
29
+ <script lang="ts" setup></script>
30
+ <style scoped>
31
+ .my-poster-into {
32
+ position: relative;
33
+ background-color: rgba(255, 255, 255, 0.06);
34
+ border-width: 1px;
35
+ border-radius: 20px;
36
+ focus-border-radius: 20px;
37
+ border-color: rgba(255, 255, 255, 0.1);
38
+ display: flex;
39
+ justify-content: center;
40
+ align-items: center;
41
+ }
42
+
43
+ .poster-into-title {
44
+ background-color: transparent;
45
+ height: 50px;
46
+ color: rgba(255, 255, 255, 0.55);
47
+ focus-color: #ffffff;
48
+ font-weight: 500;
49
+ }
50
+ </style>
@@ -0,0 +1,126 @@
1
+ <template>
2
+ <div
3
+ :type="104"
4
+ layout="${layout}"
5
+ :focusable="true"
6
+ eventClick
7
+ eventFocus
8
+ :clipChildren="true"
9
+ :enableFocusBorder="true"
10
+ class="poster-user-content-box"
11
+ flexStyle="${image.style}"
12
+ sid="${_id}"
13
+ >
14
+ <div class="poster-user-icon-container">
15
+ <img
16
+ class="poster-user-icon-bg"
17
+ :focusable="false"
18
+ src="../../../assets/my/ic_user.png"
19
+ />
20
+ <img
21
+ class="poster-user-icon"
22
+ :focusable="false"
23
+ src="${image.src}"
24
+ showIf="${image.enable}"
25
+ />
26
+ </div>
27
+
28
+ <div
29
+ class="poster-user-content-box-info"
30
+ :focusable="false"
31
+ duplicateParentState
32
+ >
33
+ <text-view
34
+ class="poster-user-title"
35
+ style="margin-top: 40px; color: #ffffff"
36
+ :focusable="false"
37
+ :ellipsizeMode="4"
38
+ :fontSize="36"
39
+ :lines="1"
40
+ gravity="centerVertical|start"
41
+ text="${title.text}"
42
+ showIf="${title.enable}"
43
+ />
44
+ <div class="poster-user-title-tip" duplicateParentState>
45
+ <text-view
46
+ class="poster-user-title-tip-txt"
47
+ :focusable="false"
48
+ :ellipsizeMode="2"
49
+ duplicateParentState
50
+ :lines="1"
51
+ gravity="center"
52
+ text="${subTitle.text}"
53
+ />
54
+ </div>
55
+ </div>
56
+ </div>
57
+ </template>
58
+ <script lang="ts" setup></script>
59
+ <style scoped>
60
+ .poster-user-content-box {
61
+ display: flex;
62
+ flex-direction: row;
63
+ align-items: center;
64
+ justify-content: flex-start;
65
+ background-color: rgba(255, 255, 255, 0.06);
66
+ border-radius: 16px;
67
+ focus-border-radius: 16px;
68
+ }
69
+
70
+ .poster-user-icon-container {
71
+ width: 160px;
72
+ height: 160px;
73
+ margin-left: 40px;
74
+ background-color: rgba(255, 255, 255, 0.06);
75
+ display: flex;
76
+ justify-content: center;
77
+ align-items: center;
78
+ border-radius: 80px;
79
+ }
80
+ .poster-user-icon-bg {
81
+ position: absolute;
82
+ top: 41px;
83
+ left: 47px;
84
+ width: 66px;
85
+ height: 78px;
86
+ }
87
+ .poster-user-icon {
88
+ width: 160px;
89
+ height: 160px;
90
+ border-radius: 80px;
91
+ }
92
+
93
+ .poster-user-content-box-info {
94
+ margin-top: 20px;
95
+ margin-left: 30px;
96
+ width: 288px;
97
+ height: 237px;
98
+ border-top-right-radius: 42px;
99
+ border-bottom-right-radius: 42px;
100
+ display: flex;
101
+ flex-direction: column;
102
+ background-color: transparent;
103
+ }
104
+
105
+ .poster-user-title {
106
+ width: 288px;
107
+ background-color: transparent;
108
+ height: 44px;
109
+ }
110
+
111
+ .poster-user-title-tip {
112
+ width: 210px;
113
+ height: 60px;
114
+ background-color: rgba(255, 255, 255, 0.06);
115
+ focus-background-color: white;
116
+ margin-top: 30px;
117
+ border-radius: 30px;
118
+ }
119
+ .poster-user-title-tip-txt {
120
+ font-size: 26px;
121
+ color: rgba(255, 255, 255, 0.55);
122
+ focus-color: #000000;
123
+ width: 210px;
124
+ height: 60px;
125
+ }
126
+ </style>
@@ -0,0 +1,95 @@
1
+ <template>
2
+ <div style="width: 1920px; height: 1080px; background-color: #669940">
3
+ <media-player-view
4
+ ref="mediaPlayerViewRef"
5
+ style="position: absolute; background-color: transparent"
6
+ :initPlayerWindowType="2"
7
+ :isShowPlayerController="true"
8
+ @onPlayerPlaying="onVideoPlayerPlaying"
9
+ />
10
+ <bg-animation ref="itemCellBgImgRef" :focusable="false" />
11
+ </div>
12
+ </template>
13
+
14
+ <script lang="ts" setup name="play-test">
15
+ import { ESKeyEvent } from "@extscreen/es3-core";
16
+ import { ref } from "vue";
17
+ import BgAnimation from "../components/bg-animation.vue";
18
+ import { IMediaList } from "../components/media/build-data/media-imp";
19
+ import MediaPlayerView from "../components/media/view/media-player-view.vue";
20
+ import launch from "../tools/launch";
21
+ import { PlayType } from "./home/adapter/tab-content/tab-content-imp.ts";
22
+
23
+ const mediaPlayerViewRef = ref();
24
+ const itemCellBgImgRef = ref();
25
+
26
+ const playData: Array<IMediaList> = [
27
+ {
28
+ id: "1532310053293928449",
29
+ type: PlayType.TYPE_LONG,
30
+ title: "111特斯拉自动驾驶遭遇“水土不服”?懂车帝原创全面评测Model 3",
31
+ cover:
32
+ "http://cms.hmon.tv/common/static/file/2024/05/31/ce5b63bc-5f2f-4171-871c-b709b9cb822a.png",
33
+ url: [
34
+ {
35
+ playUrl:
36
+ "http://extcdn.hsrc.tv/channelzero/2024/02/05/d477660a-3eb6-4c7f-b82b-0b61c035505c.mp4",
37
+ definition: "1",
38
+ },
39
+ ],
40
+ isRequestUrl: false,
41
+ },
42
+ {
43
+ id: "1532309801724030977",
44
+ type: PlayType.TYPE_LONG,
45
+ title: "222特斯拉自动驾驶遭遇“水土不服”?懂车帝原创全面评测Model 3",
46
+ cover:
47
+ "http://cms.hmon.tv/common/static/file/2024/05/31/ce5b63bc-5f2f-4171-871c-b709b9cb822a.png",
48
+ url: [
49
+ {
50
+ playUrl:
51
+ "http://extcdn.hsrc.tv/channelzero/2024/02/05/5fc2d6dd-0566-4c70-a4ba-be6e47e39252.mp4",
52
+ definition: "1",
53
+ },
54
+ ],
55
+ isRequestUrl: false,
56
+ },
57
+ ];
58
+
59
+ const onESCreate = () => {
60
+ let imgBg = playData[0].cover;
61
+ setBgImage(imgBg);
62
+ const list = mediaPlayerViewRef.value.initPlayData(playData);
63
+ mediaPlayerViewRef.value.playMediaList(list);
64
+ };
65
+
66
+ const onVideoPlayerPlaying = () => {
67
+ setBgImage("");
68
+ };
69
+ const setBgImage = (imgUrl: string) => {
70
+ if (imgUrl) itemCellBgImgRef.value.setImg(imgUrl);
71
+ else itemCellBgImgRef.value.clearImg();
72
+ };
73
+ const onKeyDown = (keyEvent: ESKeyEvent): boolean => {
74
+ if (mediaPlayerViewRef.value?.onKeyDown(keyEvent)) {
75
+ return true;
76
+ }
77
+ return false;
78
+ };
79
+ const onKeyUp = (keyEvent: ESKeyEvent): boolean => {
80
+ if (mediaPlayerViewRef.value?.onKeyUp(keyEvent)) {
81
+ return true;
82
+ }
83
+ return false;
84
+ };
85
+ const onBackPressed = (): boolean => {
86
+ if (mediaPlayerViewRef.value?.onBackPressed()) {
87
+ return true;
88
+ }
89
+ launch.launchBack();
90
+ return true;
91
+ };
92
+ defineExpose({ onESCreate, onKeyDown, onKeyUp, onBackPressed });
93
+ </script>
94
+
95
+ <style lang="scss"></style>
@@ -0,0 +1,57 @@
1
+ # 搜索
2
+
3
+ ## 页面功能
4
+
5
+ 页面支持两种布局方式,通过页面级配置文件config.ts中layoutMode来控制。
6
+
7
+ layoutMode: 2 # 两栏布局,左侧键盘区域、右侧搜索关键词或搜索结果
8
+ 3 # 三栏布局,左侧键盘区域、中间搜索关键词、右侧搜索结果
9
+
10
+ ## 页面布局
11
+
12
+ ![image](../../../doc/search/design.png)
13
+
14
+ ### 两栏页面(two-columns.vue)
15
+
16
+ 左侧键盘区域、右侧关键词或搜索结果。当右侧展示搜索结果时,页面支持横向滚动。
17
+
18
+ ![image](../../../doc/search/two-columns.png)
19
+
20
+ ![image](../../../doc/search/two-columns-2.png)
21
+
22
+ ### 三栏页面(three-columns.vue)
23
+
24
+ 左侧键盘区域、中间搜索关键词、右侧搜索结果,页面支持横向滚动。
25
+
26
+ ![image](../../../doc/search/three-columns.png)
27
+
28
+ ## 目录结构
29
+
30
+ ```bash
31
+ src/pages/search
32
+ ├── README.md // 自述文件
33
+ ├── adapter // 数据转换及类型定义
34
+ │ ├── index.ts
35
+ │ └── interface.ts
36
+ ├── api // 网络请求
37
+ │ ├── index.ts
38
+ │ ├── interface.ts
39
+ │ └── request-url.ts
40
+ ├── components // 页面组件
41
+ │ ├── search-content-item-h.vue
42
+ │ ├── search-content-item-v.vue
43
+ │ ├── search-content-tabs.vue
44
+ │ ├── search-content.vue
45
+ │ ├── search-keyboard.vue
46
+ │ ├── search-keyword-grid.vue
47
+ │ └── search-keyword.vue
48
+ ├── scss // 样式文件
49
+ │ ├── search-content.scss
50
+ │ ├── search-keyboard.scss
51
+ │ ├── search-keyword-grid.scss
52
+ │ ├── search-keyword.scss
53
+ │ └── search.scss
54
+ ├── config.ts // 页面配置
55
+ ├── three-columns.vue
56
+ └── two-columns.vue
57
+ ```