@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,81 @@
1
+ <template>
2
+ <qt-view
3
+ class="filter-sidebar"
4
+ :gradientBackground="{ colors: ['#00000000', '#0DFFFFFF'], orientation: 0 }"
5
+ :blockFocusDirections="['right']"
6
+ >
7
+ <qt-list-view
8
+ class="filter-sidebar-list"
9
+ ref="listRef"
10
+ name="sidebarList"
11
+ :autoscroll="[$props.singleSelectPos, 432]"
12
+ :singleSelectPosition="$props.singleSelectPos"
13
+ :nextFocusName="{ up: 'topView', right: nextFocusNameRight }"
14
+ @item-focused="onItemFocused"
15
+ >
16
+ <list-item-title :type="SecondaryType.TITLE" />
17
+ <!-- 筛选按钮、图标 -->
18
+ <list-item-filter :type="SecondaryType.FILTER" />
19
+ <!-- 筛选按钮、图标样式二 -->
20
+ <list-item-filter-title :type="SecondaryType.FILTER_TITLE" />
21
+ <!-- 普通文本 -->
22
+ <list-item-text
23
+ :type="SecondaryType.TEXT"
24
+ :textStyle="$props.listItemTextStyle"
25
+ :textGravity="$props.listItemTextGravity"
26
+ />
27
+ <!-- 横线 -->
28
+ <list-item-line :type="SecondaryType.LINE" />
29
+ </qt-list-view>
30
+ </qt-view>
31
+ </template>
32
+
33
+ <script setup lang="ts" name="FilterSidebar">
34
+ import { ref } from "vue";
35
+ import { QTIListView } from "@quicktvui/quicktvui3";
36
+ import { Secondary, SecondaryType } from "../../adapter/interface";
37
+ import ListItemTitle from "./list-item-title.vue";
38
+ import ListItemFilter from "./list-item-filter.vue";
39
+ import ListItemFilterTitle from "./list-item-filter-title.vue";
40
+ import ListItemText from "./list-item-text.vue";
41
+ import ListItemLine from "./list-item-line.vue";
42
+
43
+ defineProps({
44
+ blockFocusDir: {
45
+ type: Array,
46
+ default: () => [],
47
+ },
48
+ singleSelectPos: {
49
+ type: Number,
50
+ default: 1,
51
+ },
52
+ listItemTextStyle: {
53
+ type: Object,
54
+ default: () => {},
55
+ },
56
+ listItemTextGravity: {
57
+ type: String,
58
+ default: "center",
59
+ },
60
+ });
61
+ const emits = defineEmits(["onListItemFocused"]);
62
+
63
+ const listRef = ref<QTIListView>();
64
+ const nextFocusNameRight = ref<string>("contentGrid");
65
+
66
+ function init(listData: Secondary[]) {
67
+ listRef.value?.init(listData);
68
+ }
69
+
70
+ function onItemFocused(evt) {
71
+ emits("onListItemFocused", evt);
72
+ }
73
+
74
+ function setNextFocusNameRight(s: string) {
75
+ nextFocusNameRight.value = s;
76
+ }
77
+
78
+ defineExpose({ init, setNextFocusNameRight });
79
+ </script>
80
+
81
+ <style scoped lang="scss" src="../../scss/filter-sidebar.scss"></style>
@@ -0,0 +1,78 @@
1
+ <template>
2
+ <qt-view
3
+ class="filter-sidebar-list-item"
4
+ style="flex-direction: row; align-items: center"
5
+ :focusable="true"
6
+ eventFocus
7
+ eventClick
8
+ >
9
+ <qt-image
10
+ style="
11
+ width: 36px;
12
+ height: 36px;
13
+ background-color: transparent;
14
+ position: absolute;
15
+ left: 50px;
16
+ "
17
+ src="${icon.normal}"
18
+ showOnState="normal"
19
+ :focusable="false"
20
+ :duplicateParentState="true"
21
+ ></qt-image>
22
+ <qt-image
23
+ style="
24
+ width: 36px;
25
+ height: 36px;
26
+ background-color: transparent;
27
+ position: absolute;
28
+ left: 50px;
29
+ "
30
+ src="${icon.focused}"
31
+ showOnState="focused"
32
+ :focusable="false"
33
+ :duplicateParentState="true"
34
+ ></qt-image>
35
+ <qt-image
36
+ style="
37
+ width: 36px;
38
+ height: 36px;
39
+ background-color: transparent;
40
+ position: absolute;
41
+ left: 50px;
42
+ "
43
+ src="${icon.selected}"
44
+ showOnState="selected"
45
+ :focusable="false"
46
+ :duplicateParentState="true"
47
+ ></qt-image>
48
+ <qt-text
49
+ class="filter-sidebar-list-item-text"
50
+ style="margin-left: 98px"
51
+ text="${name}"
52
+ autoWidth
53
+ gravity="center"
54
+ :showOnState="['normal', 'selected']"
55
+ :focusable="false"
56
+ :duplicateParentState="true"
57
+ ></qt-text>
58
+ <qt-text
59
+ class="filter-sidebar-list-item-text"
60
+ style="margin-left: 98px"
61
+ text="${name}"
62
+ autoWidth
63
+ gravity="center"
64
+ typeface="bold"
65
+ :showOnState="'focused'"
66
+ :focusable="false"
67
+ :duplicateParentState="true"
68
+ ></qt-text>
69
+ <!-- <qt-view
70
+ style="width: 4px; height: 30px; background-color: white; margin-left: 25px; margin-top: 6px"
71
+ showOnState="selected"
72
+ :focusable="false"
73
+ :duplicateParentState="true"
74
+ ></qt-view> -->
75
+ </qt-view>
76
+ </template>
77
+
78
+ <style scoped lang="scss" src="../../scss/filter-sidebar.scss"></style>
@@ -0,0 +1,68 @@
1
+ <template>
2
+ <qt-view
3
+ class="filter-sidebar-list-item"
4
+ style="flex-direction: row; align-items: center; justify-content: flex-end"
5
+ :focusable="true"
6
+ eventFocus
7
+ eventClick
8
+ >
9
+ <qt-view
10
+ class="filter-sidebar-list-item-img"
11
+ :focusable="false"
12
+ :duplicateParentState="true"
13
+ >
14
+ <qt-image
15
+ class="filter-sidebar-list-item-img"
16
+ style="position: absolute"
17
+ src="${icon.normal}"
18
+ showOnState="normal"
19
+ :focusable="false"
20
+ :duplicateParentState="true"
21
+ ></qt-image>
22
+ <qt-image
23
+ class="filter-sidebar-list-item-img"
24
+ style="position: absolute"
25
+ src="${icon.focused}"
26
+ showOnState="focused"
27
+ :focusable="false"
28
+ :duplicateParentState="true"
29
+ ></qt-image>
30
+ <qt-image
31
+ class="filter-sidebar-list-item-img"
32
+ style="position: absolute"
33
+ src="${icon.selected}"
34
+ showOnState="selected"
35
+ :focusable="false"
36
+ :duplicateParentState="true"
37
+ ></qt-image>
38
+ </qt-view>
39
+ <qt-view
40
+ style="height: 106px; background-color: transparent"
41
+ autoWidth
42
+ :focusable="false"
43
+ :duplicateParentState="true"
44
+ >
45
+ <qt-text
46
+ class="filter-sidebar-list-item-text"
47
+ text="${name}"
48
+ autoWidth
49
+ gravity="center"
50
+ :showOnState="'normal'"
51
+ :focusable="false"
52
+ :duplicateParentState="true"
53
+ ></qt-text>
54
+ <qt-text
55
+ class="filter-sidebar-list-item-text"
56
+ text="${name}"
57
+ autoWidth
58
+ gravity="center"
59
+ typeface="bold"
60
+ :showOnState="['focused', 'selected']"
61
+ :focusable="false"
62
+ :duplicateParentState="true"
63
+ ></qt-text>
64
+ </qt-view>
65
+ </qt-view>
66
+ </template>
67
+
68
+ <style scoped lang="scss" src="../../scss/filter-sidebar.scss"></style>
@@ -0,0 +1,11 @@
1
+ <template>
2
+ <qt-view
3
+ class="filter-sidebar-list-item"
4
+ style="height: 28px; align-items: center; justify-content: center"
5
+ :focusable="false"
6
+ >
7
+ <qt-view class="filter-sidebar-list-item-line" :focusable="false"></qt-view>
8
+ </qt-view>
9
+ </template>
10
+
11
+ <style scoped lang="scss" src="../../scss/filter-sidebar.scss"></style>
@@ -0,0 +1,43 @@
1
+ <template>
2
+ <qt-view
3
+ class="filter-sidebar-list-item"
4
+ :focusable="true"
5
+ eventFocus
6
+ eventClick
7
+ >
8
+ <qt-text
9
+ class="filter-sidebar-list-item-text"
10
+ text="${name}"
11
+ :style="$props.textStyle"
12
+ :gravity="$props.textGravity"
13
+ :showOnState="'normal'"
14
+ :focusable="false"
15
+ :duplicateParentState="true"
16
+ ></qt-text>
17
+ <qt-text
18
+ class="filter-sidebar-list-item-text"
19
+ text="${name}"
20
+ typeface="bold"
21
+ :style="$props.textStyle"
22
+ :gravity="$props.textGravity"
23
+ :showOnState="['focused', 'selected']"
24
+ :focusable="false"
25
+ :duplicateParentState="true"
26
+ ></qt-text>
27
+ </qt-view>
28
+ </template>
29
+
30
+ <script setup lang="ts">
31
+ defineProps({
32
+ textStyle: {
33
+ type: Object,
34
+ default: () => {},
35
+ },
36
+ textGravity: {
37
+ type: String,
38
+ default: "center",
39
+ },
40
+ });
41
+ </script>
42
+
43
+ <style scoped lang="scss" src="../../scss/filter-sidebar.scss"></style>
@@ -0,0 +1,14 @@
1
+ <template>
2
+ <qt-view class="filter-sidebar-list-item" :focusable="false">
3
+ <qt-text
4
+ class="filter-sidebar-list-item-text"
5
+ style="color: #ffffff; font-size: 40px"
6
+ text="${name}"
7
+ gravity="center|end"
8
+ typeface="bold"
9
+ :focusable="false"
10
+ ></qt-text>
11
+ </qt-view>
12
+ </template>
13
+
14
+ <style scoped lang="scss" src="../../scss/filter-sidebar.scss"></style>
@@ -0,0 +1,10 @@
1
+ export default {
2
+ // 布局模式, 1 单页面、2 两栏、3 三栏
3
+ layoutMode: 2,
4
+ // 筛选内容Item样式, 1 横图、2 竖图
5
+ gridItemMode: 2,
6
+ // 筛选内容区域一行展示个数
7
+ gridSpanCount: 5,
8
+ // 筛选内容分页大小
9
+ gridContentLimit: 60,
10
+ };
@@ -0,0 +1,203 @@
1
+ <template>
2
+ <qt-view
3
+ class="filter"
4
+ :gradientBackground="{
5
+ colors: themeConfig.bgGradientColor,
6
+ orientation: 4,
7
+ }"
8
+ >
9
+ <!-- 焦点占位, 解决页面跳焦的问题 -->
10
+ <qt-view class="filter-focus-placeholder" :focusable="true"></qt-view>
11
+ <!-- 顶部按钮 -->
12
+ <top-view
13
+ name="topView"
14
+ :logoRight="true"
15
+ :nextFocusName="{ down: 'sidebarList' }"
16
+ :blockFocusDirections="['left', 'up']"
17
+ />
18
+ <!-- 内容主体 -->
19
+ <scroll-view
20
+ name="filterScroll"
21
+ makeChildVisibleType="none"
22
+ :horizontal="true"
23
+ :onScrollEnable="true"
24
+ :initialContentOffset="210"
25
+ >
26
+ <qt-view class="filter-body" :clipChildren="true">
27
+ <!-- 筛选列表扩展项 -->
28
+ <filter-expand
29
+ ref="expandRef"
30
+ :blockFocusDir="expandBlockFocusDir"
31
+ :singleSelectPos="expandSinglePos"
32
+ :expandAvailable="expandAvailable"
33
+ :triggerTask="triggerTask"
34
+ @onListItemFocused="onExtListItemFocused"
35
+ />
36
+ <!-- 筛选列表 -->
37
+ <filter-sidebar
38
+ ref="sidebarRef"
39
+ :blockFocusDir="sidebarBlockFocusDir"
40
+ :singleSelectPos="sidebarSinglePos"
41
+ :listItemTextStyle="{ width: `222px`, marginLeft: `98px` }"
42
+ :listItemTextGravity="'center|start'"
43
+ @onListItemFocused="onListItemFocused"
44
+ />
45
+ <!-- 筛选内容 -->
46
+ <filter-content
47
+ ref="contentRef"
48
+ :descendantFocusability="contentDeny"
49
+ @setNextFocusNameRight="setNextFocusNameRight"
50
+ />
51
+ </qt-view>
52
+ </scroll-view>
53
+ </qt-view>
54
+ </template>
55
+
56
+ <script setup lang="ts">
57
+ import { ref } from "vue";
58
+ import { useESRouter } from "@extscreen/es3-router";
59
+ import { buildFilters } from "./adapter/index";
60
+ import { SecondaryType } from "./adapter/interface";
61
+ import themeConfig from "../../config/theme-config";
62
+ import TopView from "../../components/top-view.vue";
63
+ import FilterExpand from "./components/expand/index.vue";
64
+ import FilterSidebar from "./components/sidebar/index.vue";
65
+ import FilterContent from "./components/content/index.vue";
66
+ import filterManager from "./api/index";
67
+
68
+ const router = useESRouter();
69
+
70
+ // 扩展列表
71
+ const expandRef = ref();
72
+ const expandSinglePos = ref<number>(0);
73
+ const expandBlockFocusDir = ref();
74
+ const expandAvailable = ref<boolean>(false);
75
+ // 筛选列表
76
+ const sidebarRef = ref();
77
+ const sidebarSinglePos = ref<number>(0);
78
+ const sidebarBlockFocusDir = ref();
79
+ // 筛选内容
80
+ const contentRef = ref();
81
+ const contentDeny = ref<1 | 2>(1);
82
+
83
+ const triggerTask = [
84
+ {
85
+ event: "onFocusAcquired",
86
+ target: "filterScroll",
87
+ function: "scrollToWithOptions",
88
+ params: [{ x: -210, y: 0, duration: 300 }],
89
+ },
90
+ {
91
+ event: "onFocusLost",
92
+ target: "filterScroll",
93
+ function: "scrollToWithOptions",
94
+ params: [{ x: 210, y: 0, duration: 300 }],
95
+ },
96
+ ];
97
+
98
+ function onESCreate(params: {
99
+ screenId: string;
100
+ defaultSecondaryId?: string;
101
+ defaultTags?: string;
102
+ }) {
103
+ params.screenId = "1848555233454727169";
104
+ params.defaultSecondaryId = ""; // 默认选中的二级筛选项ID
105
+ loadFilters(
106
+ params.screenId,
107
+ params.defaultSecondaryId,
108
+ params.defaultTags || "",
109
+ true,
110
+ );
111
+ }
112
+
113
+ function loadFilters(
114
+ primaryId: string,
115
+ defaultSecondaryId: string,
116
+ defaultTags: string,
117
+ initExpand?: boolean,
118
+ ) {
119
+ filterManager.getFilters(primaryId).then((filters) => {
120
+ // 设置焦点向右方向
121
+ setExpandNextFocusNameRight("sidebarList");
122
+
123
+ const { primaries, secondaries, tertiaries } = buildFilters(
124
+ primaryId,
125
+ filters,
126
+ defaultTags.split(","),
127
+ );
128
+ // 设置左侧列表默认选中
129
+ const index = secondaries.findIndex(
130
+ (item) => item.id === defaultSecondaryId,
131
+ );
132
+ sidebarSinglePos.value = index !== -1 ? index : 0;
133
+ lastPosition = sidebarSinglePos.value;
134
+ // 初始化一级列表
135
+ if (initExpand) {
136
+ expandRef.value?.init(primaries);
137
+ }
138
+ // 初始化二级列表
139
+ sidebarRef.value?.init(secondaries);
140
+ // 初始化三级列表
141
+ contentRef.value?.init(primaryId, tertiaries, defaultSecondaryId);
142
+ });
143
+ }
144
+
145
+ let lastExtPosition = expandSinglePos.value;
146
+ let extListTimer: any = -1;
147
+ function onExtListItemFocused(evt) {
148
+ if (evt.isFocused && evt.position != lastExtPosition) {
149
+ // 禁止焦点向右
150
+ setExpandNextFocusNameRight("");
151
+ clearTimeout(extListTimer);
152
+ extListTimer = setTimeout(() => {
153
+ lastExtPosition = evt.position;
154
+ sidebarSinglePos.value = 0;
155
+ loadFilters(evt.item.id, "", "");
156
+ }, 300);
157
+ }
158
+ }
159
+
160
+ let lastPosition = sidebarSinglePos.value;
161
+ let listTimer: any = -1;
162
+ function onListItemFocused(evt) {
163
+ if (evt.isFocused) {
164
+ expandAvailable.value = evt.item.type === SecondaryType.FILTER_TITLE;
165
+
166
+ if (evt.position != lastPosition) {
167
+ // 禁止焦点向右
168
+ setNextFocusNameRight("");
169
+ clearTimeout(listTimer);
170
+ listTimer = setTimeout(() => {
171
+ lastPosition = evt.position;
172
+ sidebarSinglePos.value = lastPosition;
173
+ contentRef.value?.loadContents(
174
+ evt.item.id,
175
+ expandAvailable.value,
176
+ evt.item.type === SecondaryType.TEXT,
177
+ );
178
+ }, 300);
179
+ }
180
+ }
181
+ }
182
+
183
+ function setExpandNextFocusNameRight(s: string) {
184
+ expandBlockFocusDir.value = s === "" ? ["right"] : [];
185
+ expandRef.value?.setNextFocusNameRight(s);
186
+ }
187
+
188
+ function setNextFocusNameRight(s: string) {
189
+ contentDeny.value = s === "" ? 2 : 1;
190
+ sidebarBlockFocusDir.value = s === "" ? ["right"] : [];
191
+ sidebarRef.value?.setNextFocusNameRight(s);
192
+ }
193
+
194
+ function onBackPressed() {
195
+ if (contentRef.value?.onBackPressed()) {
196
+ router.back();
197
+ }
198
+ }
199
+
200
+ defineExpose({ onESCreate, onBackPressed });
201
+ </script>
202
+
203
+ <style scoped lang="scss" src="./scss/filter.scss"></style>
@@ -0,0 +1,42 @@
1
+ .filter-main-conditions-list-record-item {
2
+ height: 46px;
3
+ background-color: transparent;
4
+ align-items: center;
5
+ justify-content: center;
6
+ border-width: 1px;
7
+ border-style: solid;
8
+ border-color: #ffffff;
9
+ border-radius: 8px;
10
+ }
11
+
12
+ .filter-main-conditions-list-record-item-text {
13
+ height: 38px;
14
+ color: $theme-text-normal-color;
15
+ font-size: 28px;
16
+ padding-left: 8px;
17
+ padding-right: 8px;
18
+ }
19
+
20
+ .filter-main-conditions-list-row {
21
+ width: 1920px;
22
+ height: 66px;
23
+ background-color: transparent;
24
+ }
25
+
26
+ .filter-main-conditions-list-row-item {
27
+ height: 54px;
28
+ background-color: transparent;
29
+ padding: 24px;
30
+ border-radius: 30px;
31
+ justify-content: center;
32
+ focus-background-color: $theme-btn-focus-color;
33
+ }
34
+
35
+ .filter-main-conditions-list-row-item-text {
36
+ position: absolute;
37
+ height: 40px;
38
+ color: $theme-text-normal-color;
39
+ font-size: 30px;
40
+ focus-color: $theme-text-focus-color;
41
+ select-color: $theme-text-select-color;
42
+ }
@@ -0,0 +1,60 @@
1
+ .filter-main {
2
+ height: 950px;
3
+ background-color: transparent;
4
+ margin-top: 10px;
5
+ }
6
+
7
+ .filter-main-scroll {
8
+ height: 950px;
9
+ background-color: transparent;
10
+ }
11
+
12
+ .filter-main-box-img {
13
+ width: 160px;
14
+ height: 142px;
15
+ background-color: transparent;
16
+ }
17
+
18
+ .filter-main-box {
19
+ height: 950px;
20
+ background-color: transparent;
21
+ align-items: center;
22
+ justify-content: center;
23
+ position: absolute;
24
+ top: 0px;
25
+ }
26
+
27
+ .filter-main-box-text {
28
+ width: 140px;
29
+ height: 40px;
30
+ background-color: transparent;
31
+ color: rgba(255, 255, 255, 0.55);
32
+ font-size: 30px;
33
+ margin-top: 25px;
34
+ }
35
+
36
+ .filter-main-conditions {
37
+ background-color: transparent;
38
+ /* margin-top: 24px; */
39
+ margin-bottom: 15px;
40
+ }
41
+
42
+ .filter-main-conditions-list {
43
+ background-color: transparent;
44
+ }
45
+
46
+ .filter-main-conditions-record {
47
+ background-color: transparent;
48
+ position: absolute;
49
+ top: 0px;
50
+ }
51
+
52
+ .filter-main-contents {
53
+ height: 950px;
54
+ background-color: transparent;
55
+ }
56
+
57
+ .filter-main-contents-grid {
58
+ height: 950px;
59
+ background-color: transparent;
60
+ }
@@ -0,0 +1,30 @@
1
+ .filter-expand {
2
+ width: 210px;
3
+ height: 960px;
4
+ background-color: transparent;
5
+ }
6
+
7
+ .filter-expand-list {
8
+ width: 210px;
9
+ height: 960px;
10
+ background-color: transparent;
11
+ }
12
+
13
+ .filter-expand-list-item {
14
+ width: 210px;
15
+ height: 106px;
16
+ background-color: transparent;
17
+ border-top-right-radius: 8px;
18
+ border-bottom-right-radius: 8px;
19
+ focus-background-color: $theme-btn-focus-color;
20
+ }
21
+
22
+ .filter-expand-list-item-text {
23
+ position: absolute;
24
+ width: 179px;
25
+ height: 106px;
26
+ background-color: transparent;
27
+ color: $theme-text-select-color;
28
+ font-size: 36px;
29
+ focus-color: $theme-text-focus-color;
30
+ }
@@ -0,0 +1,45 @@
1
+ .filter-sidebar {
2
+ width: 340px;
3
+ height: 960px;
4
+ background-color: transparent;
5
+ }
6
+
7
+ .filter-sidebar-list {
8
+ width: 340px;
9
+ height: 960px;
10
+ background-color: transparent;
11
+ }
12
+
13
+ .filter-sidebar-list-item {
14
+ width: 340px;
15
+ height: 106px;
16
+ background-color: transparent;
17
+ border-radius: 8px;
18
+ padding-right: 80px;
19
+ focus-background-color: $theme-btn-focus-color;
20
+ }
21
+
22
+ .filter-sidebar-list-item-img {
23
+ width: 34px;
24
+ height: 34px;
25
+ background-color: transparent;
26
+ margin-right: 16px;
27
+ }
28
+
29
+ .filter-sidebar-list-item-text {
30
+ position: absolute;
31
+ width: 260px;
32
+ height: 106px;
33
+ background-color: transparent;
34
+ color: $theme-text-normal-color;
35
+ font-size: 36px;
36
+ focus-color: $theme-text-focus-color;
37
+ select-color: $theme-text-select-color;
38
+ }
39
+
40
+ .filter-sidebar-list-item-line {
41
+ width: 140px;
42
+ height: 2px;
43
+ background-color: #868686;
44
+ margin-left: 80px;
45
+ }