@quicktvui/ai 1.0.9 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (348) hide show
  1. package/README.md +31 -0
  2. package/USAGE.md +22 -7
  3. package/package.json +1 -1
  4. package/rules/.clinerules +1 -0
  5. package/rules/.cursorrules +1 -0
  6. package/rules/.docs/zh-CN/guide/ai/ai-assistant.md +16 -6
  7. package/rules/.github/copilot-instructions.md +1 -0
  8. package/rules/.source/hellotv/PROJECT-README.md +52 -0
  9. package/rules/.source/hellotv/app.d.ts +11 -0
  10. package/rules/.source/hellotv/package.json +146 -0
  11. package/rules/.source/hellotv/scripts/build-apk.ts +12 -0
  12. package/rules/.source/hellotv/scripts/build.ts +35 -0
  13. package/rules/.source/hellotv/scripts/dev.ts +12 -0
  14. package/rules/.source/hellotv/scripts/pack.ts +24 -0
  15. package/rules/.source/hellotv/scripts/process.ts +37 -0
  16. package/rules/.source/hellotv/scripts/quicktvui-webpack.android.ts +187 -0
  17. package/rules/.source/hellotv/scripts/quicktvui-webpack.dev.ts +147 -0
  18. package/rules/.source/hellotv/scripts/webpack-watch.ts +24 -0
  19. package/rules/.source/hellotv/src/App.vue +192 -0
  20. package/rules/.source/hellotv/src/api/my/index.ts +198 -0
  21. package/rules/.source/hellotv/src/api/user/impl-user.ts +52 -0
  22. package/rules/.source/hellotv/src/api/user/qr-code-mock.ts +2 -0
  23. package/rules/.source/hellotv/src/api/user/request-url.ts +11 -0
  24. package/rules/.source/hellotv/src/api/user/user-manager.ts +258 -0
  25. package/rules/.source/hellotv/src/app.scss +8 -0
  26. package/rules/.source/hellotv/src/assets/component-media/ic_media_btn_pause.png +0 -0
  27. package/rules/.source/hellotv/src/assets/component-media/ic_media_btn_play.png +0 -0
  28. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_setting_focused.png +0 -0
  29. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_setting_normal.png +0 -0
  30. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_xuanji_focused.png +0 -0
  31. package/rules/.source/hellotv/src/assets/component-media/ic_media_menu_xuanji_normal.png +0 -0
  32. package/rules/.source/hellotv/src/assets/component-media/ic_media_ok_focused.png +0 -0
  33. package/rules/.source/hellotv/src/assets/component-media/ic_media_ok_selected.png +0 -0
  34. package/rules/.source/hellotv/src/assets/detail/ic_collect_focused.png +0 -0
  35. package/rules/.source/hellotv/src/assets/detail/ic_collect_normal.png +0 -0
  36. package/rules/.source/hellotv/src/assets/detail/ic_full_focused.png +0 -0
  37. package/rules/.source/hellotv/src/assets/detail/ic_full_normal.png +0 -0
  38. package/rules/.source/hellotv/src/assets/detail/ic_info_focused.png +0 -0
  39. package/rules/.source/hellotv/src/assets/detail/ic_info_normal.png +0 -0
  40. package/rules/.source/hellotv/src/assets/detail/ic_introduction_bg.png +0 -0
  41. package/rules/.source/hellotv/src/assets/detail/ic_media_list_item_normal.png +0 -0
  42. package/rules/.source/hellotv/src/assets/detail/ic_media_list_item_selected.png +0 -0
  43. package/rules/.source/hellotv/src/assets/detail/ic_media_player_pause.png +0 -0
  44. package/rules/.source/hellotv/src/assets/detail/ic_media_player_placeholder.png +0 -0
  45. package/rules/.source/hellotv/src/assets/detail/ic_media_player_play.png +0 -0
  46. package/rules/.source/hellotv/src/assets/detail/ic_vip_focused.png +0 -0
  47. package/rules/.source/hellotv/src/assets/detail/ic_vip_normal.png +0 -0
  48. package/rules/.source/hellotv/src/assets/detail/skeleton.png +0 -0
  49. package/rules/.source/hellotv/src/assets/filter/ic_empty.png +0 -0
  50. package/rules/.source/hellotv/src/assets/filter/ic_filter_focused.png +0 -0
  51. package/rules/.source/hellotv/src/assets/filter/ic_filter_normal.png +0 -0
  52. package/rules/.source/hellotv/src/assets/filter/ic_filter_selected.png +0 -0
  53. package/rules/.source/hellotv/src/assets/filter/ic_left_focused.png +0 -0
  54. package/rules/.source/hellotv/src/assets/filter/ic_left_normal.png +0 -0
  55. package/rules/.source/hellotv/src/assets/filter/ic_left_selected.png +0 -0
  56. package/rules/.source/hellotv/src/assets/history/ic_delete.png +0 -0
  57. package/rules/.source/hellotv/src/assets/history/ic_empty.png +0 -0
  58. package/rules/.source/hellotv/src/assets/home/bg_history_item.png +0 -0
  59. package/rules/.source/hellotv/src/assets/home/bg_shadow.png +0 -0
  60. package/rules/.source/hellotv/src/assets/home/ic_4k_logo.png +0 -0
  61. package/rules/.source/hellotv/src/assets/home/ic_4k_play_focused.png +0 -0
  62. package/rules/.source/hellotv/src/assets/home/ic_4k_subtitle_normal.png +0 -0
  63. package/rules/.source/hellotv/src/assets/home/ic_arrow_focused.png +0 -0
  64. package/rules/.source/hellotv/src/assets/home/ic_arrow_normal.png +0 -0
  65. package/rules/.source/hellotv/src/assets/home/ic_exit_corner.png +0 -0
  66. package/rules/.source/hellotv/src/assets/home/ic_exit_header.png +0 -0
  67. package/rules/.source/hellotv/src/assets/home/ic_play.png +0 -0
  68. package/rules/.source/hellotv/src/assets/live/bg-error.png +0 -0
  69. package/rules/.source/hellotv/src/assets/live/bg-play-info.png +0 -0
  70. package/rules/.source/hellotv/src/assets/live/ic-arrow-left.png +0 -0
  71. package/rules/.source/hellotv/src/assets/live/ic-arrow-right.png +0 -0
  72. package/rules/.source/hellotv/src/assets/live/ic-back.png +0 -0
  73. package/rules/.source/hellotv/src/assets/live/ic-change.png +0 -0
  74. package/rules/.source/hellotv/src/assets/live/ic-corner-vip-tips.png +0 -0
  75. package/rules/.source/hellotv/src/assets/live/ic-corner-vip.png +0 -0
  76. package/rules/.source/hellotv/src/assets/live/ic-key.png +0 -0
  77. package/rules/.source/hellotv/src/assets/live/ic-loading-error.png +0 -0
  78. package/rules/.source/hellotv/src/assets/live/ic-menu-ext-arrow.png +0 -0
  79. package/rules/.source/hellotv/src/assets/live/ic-menu-ext.png +0 -0
  80. package/rules/.source/hellotv/src/assets/live/ic-menu.png +0 -0
  81. package/rules/.source/hellotv/src/assets/live/ic-mine.png +0 -0
  82. package/rules/.source/hellotv/src/assets/live/ic-network-error.png +0 -0
  83. package/rules/.source/hellotv/src/assets/live/ic-ok.png +0 -0
  84. package/rules/.source/hellotv/src/assets/live/ic-playing.png +0 -0
  85. package/rules/.source/hellotv/src/assets/live/ic-playing2.png +0 -0
  86. package/rules/.source/hellotv/src/assets/live/ic-playing3.png +0 -0
  87. package/rules/.source/hellotv/src/assets/live/ic-service.png +0 -0
  88. package/rules/.source/hellotv/src/assets/live/ic_live_broadcast.png +0 -0
  89. package/rules/.source/hellotv/src/assets/live/ic_live_broadcast_focused.png +0 -0
  90. package/rules/.source/hellotv/src/assets/my/ic_collect_focus.png +0 -0
  91. package/rules/.source/hellotv/src/assets/my/ic_collect_normal.png +0 -0
  92. package/rules/.source/hellotv/src/assets/my/ic_order_focus.png +0 -0
  93. package/rules/.source/hellotv/src/assets/my/ic_order_normal.png +0 -0
  94. package/rules/.source/hellotv/src/assets/my/ic_record_focus.png +0 -0
  95. package/rules/.source/hellotv/src/assets/my/ic_record_normal.png +0 -0
  96. package/rules/.source/hellotv/src/assets/my/ic_user.png +0 -0
  97. package/rules/.source/hellotv/src/assets/my/ic_vip_normal.png +0 -0
  98. package/rules/.source/hellotv/src/assets/search/ic_back.png +0 -0
  99. package/rules/.source/hellotv/src/assets/search/ic_back_focused.png +0 -0
  100. package/rules/.source/hellotv/src/assets/search/ic_clear.png +0 -0
  101. package/rules/.source/hellotv/src/assets/search/ic_clear_dark.png +0 -0
  102. package/rules/.source/hellotv/src/assets/search/ic_clear_focused.png +0 -0
  103. package/rules/.source/hellotv/src/assets/search/ic_search.png +0 -0
  104. package/rules/.source/hellotv/src/assets/top-view/ic_logo.png +0 -0
  105. package/rules/.source/hellotv/src/assets/top-view/ic_top_search_focused.png +0 -0
  106. package/rules/.source/hellotv/src/assets/top-view/ic_top_search_normal.png +0 -0
  107. package/rules/.source/hellotv/src/assets/top-view/ic_top_user_focused.png +0 -0
  108. package/rules/.source/hellotv/src/assets/top-view/ic_top_user_normal.png +0 -0
  109. package/rules/.source/hellotv/src/components/bg-animation.scss +14 -0
  110. package/rules/.source/hellotv/src/components/bg-animation.vue +176 -0
  111. package/rules/.source/hellotv/src/components/btn-pack-view.vue +172 -0
  112. package/rules/.source/hellotv/src/components/btn-pack.scss +53 -0
  113. package/rules/.source/hellotv/src/components/grid-item-horizontal.vue +203 -0
  114. package/rules/.source/hellotv/src/components/grid-item-vertical.vue +201 -0
  115. package/rules/.source/hellotv/src/components/media/build-data/media-config.ts +4 -0
  116. package/rules/.source/hellotv/src/components/media/build-data/media-control-adapter.ts +378 -0
  117. package/rules/.source/hellotv/src/components/media/build-data/media-imp.ts +44 -0
  118. package/rules/.source/hellotv/src/components/media/view/media-loading-component.vue +50 -0
  119. package/rules/.source/hellotv/src/components/media/view/media-loading-view.vue +154 -0
  120. package/rules/.source/hellotv/src/components/media/view/media-manager-view.vue +931 -0
  121. package/rules/.source/hellotv/src/components/media/view/media-menu-detail-item.vue +42 -0
  122. package/rules/.source/hellotv/src/components/media/view/media-menu-detail-view.vue +109 -0
  123. package/rules/.source/hellotv/src/components/media/view/media-menu-icon-item.vue +43 -0
  124. package/rules/.source/hellotv/src/components/media/view/media-menu-text-item.vue +27 -0
  125. package/rules/.source/hellotv/src/components/media/view/media-menu-view.vue +88 -0
  126. package/rules/.source/hellotv/src/components/media/view/media-player-view.vue +408 -0
  127. package/rules/.source/hellotv/src/components/media/view/scss/media-loading.scss +51 -0
  128. package/rules/.source/hellotv/src/components/media/view/scss/media-manager.scss +79 -0
  129. package/rules/.source/hellotv/src/components/media/view/scss/media-menu.scss +114 -0
  130. package/rules/.source/hellotv/src/components/media/view/scss/media-player.scss +6 -0
  131. package/rules/.source/hellotv/src/components/qt-tabs-component.ts +268 -0
  132. package/rules/.source/hellotv/src/components/qt-ul-component.ts +792 -0
  133. package/rules/.source/hellotv/src/components/top-view.scss +38 -0
  134. package/rules/.source/hellotv/src/components/top-view.vue +114 -0
  135. package/rules/.source/hellotv/src/config/README.md +22 -0
  136. package/rules/.source/hellotv/src/config/build-config.ts +22 -0
  137. package/rules/.source/hellotv/src/config/private-theme-config.ts +21 -0
  138. package/rules/.source/hellotv/src/config/public-config.scss +16 -0
  139. package/rules/.source/hellotv/src/config/test.scss +45 -0
  140. package/rules/.source/hellotv/src/config/theme-config.ts +51 -0
  141. package/rules/.source/hellotv/src/main.ts +45 -0
  142. package/rules/.source/hellotv/src/pages/activity/adapter/config.ts +37 -0
  143. package/rules/.source/hellotv/src/pages/activity/adapter/index.ts +849 -0
  144. package/rules/.source/hellotv/src/pages/activity/adapter/interface.ts +173 -0
  145. package/rules/.source/hellotv/src/pages/activity/api/index.ts +36 -0
  146. package/rules/.source/hellotv/src/pages/activity/api/interface.ts +11 -0
  147. package/rules/.source/hellotv/src/pages/activity/api/request-url.ts +10 -0
  148. package/rules/.source/hellotv/src/pages/activity/components/item/focus-change-img-item.vue +40 -0
  149. package/rules/.source/hellotv/src/pages/activity/components/item/inner-out-title-item.vue +59 -0
  150. package/rules/.source/hellotv/src/pages/activity/components/item/no-title-item.vue +45 -0
  151. package/rules/.source/hellotv/src/pages/activity/components/item/placeholder-item.vue +25 -0
  152. package/rules/.source/hellotv/src/pages/activity/index.vue +219 -0
  153. package/rules/.source/hellotv/src/pages/activity/scss/index.scss +46 -0
  154. package/rules/.source/hellotv/src/pages/activity/scss/item.scss +69 -0
  155. package/rules/.source/hellotv/src/pages/detail/adapter/index.ts +317 -0
  156. package/rules/.source/hellotv/src/pages/detail/adapter/interface.ts +150 -0
  157. package/rules/.source/hellotv/src/pages/detail/adapter/media-player.ts +378 -0
  158. package/rules/.source/hellotv/src/pages/detail/api/index.ts +77 -0
  159. package/rules/.source/hellotv/src/pages/detail/api/request-url.ts +8 -0
  160. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-definition.vue +192 -0
  161. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-list-item.vue +108 -0
  162. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-media-series.vue +349 -0
  163. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-order.vue +194 -0
  164. package/rules/.source/hellotv/src/pages/detail/components/media-player/collapse/media-collapse-speed.vue +192 -0
  165. package/rules/.source/hellotv/src/pages/detail/components/media-player/index.vue +404 -0
  166. package/rules/.source/hellotv/src/pages/detail/components/media-player/media-player-small-view.vue +382 -0
  167. package/rules/.source/hellotv/src/pages/detail/components/media-player/media-player-view.vue +1099 -0
  168. package/rules/.source/hellotv/src/pages/detail/components/recommend-item.vue +167 -0
  169. package/rules/.source/hellotv/src/pages/detail/components/section/basic-section.vue +218 -0
  170. package/rules/.source/hellotv/src/pages/detail/components/section/config.ts +6 -0
  171. package/rules/.source/hellotv/src/pages/detail/components/section/header-section.vue +15 -0
  172. package/rules/.source/hellotv/src/pages/detail/components/section/item/button-menu.vue +259 -0
  173. package/rules/.source/hellotv/src/pages/detail/components/section/item/media-introduction.vue +238 -0
  174. package/rules/.source/hellotv/src/pages/detail/components/section/item/media-series.vue +308 -0
  175. package/rules/.source/hellotv/src/pages/detail/components/section/item/player-placeholder.vue +88 -0
  176. package/rules/.source/hellotv/src/pages/detail/index.vue +571 -0
  177. package/rules/.source/hellotv/src/pages/detail/scss/index.scss +22 -0
  178. package/rules/.source/hellotv/src/pages/detail-full-player/components/media-player/full-player-loading.vue +78 -0
  179. package/rules/.source/hellotv/src/pages/detail-full-player/components/media-player/full-player-menu-view.vue +803 -0
  180. package/rules/.source/hellotv/src/pages/detail-full-player/components/media-player/full-player-view.vue +219 -0
  181. package/rules/.source/hellotv/src/pages/detail-full-player/index.vue +101 -0
  182. package/rules/.source/hellotv/src/pages/detail-full-player/scss/full-player-view.scss +6 -0
  183. package/rules/.source/hellotv/src/pages/detail-full-screen/adapter/index.ts +0 -0
  184. package/rules/.source/hellotv/src/pages/detail-full-screen/adapter/interface.ts +133 -0
  185. package/rules/.source/hellotv/src/pages/detail-full-screen/api/index.ts +77 -0
  186. package/rules/.source/hellotv/src/pages/detail-full-screen/api/request-url.ts +8 -0
  187. package/rules/.source/hellotv/src/pages/detail-full-screen/components/media-info.vue +263 -0
  188. package/rules/.source/hellotv/src/pages/detail-full-screen/components/media-player.vue +42 -0
  189. package/rules/.source/hellotv/src/pages/detail-full-screen/components/media-series-section.vue +26 -0
  190. package/rules/.source/hellotv/src/pages/detail-full-screen/components/recommend-item.vue +167 -0
  191. package/rules/.source/hellotv/src/pages/detail-full-screen/index.vue +163 -0
  192. package/rules/.source/hellotv/src/pages/detail-full-screen/scss/index.scss +41 -0
  193. package/rules/.source/hellotv/src/pages/device-info/index.vue +106 -0
  194. package/rules/.source/hellotv/src/pages/device-info/scss/device-info.scss +49 -0
  195. package/rules/.source/hellotv/src/pages/filter/README.md +66 -0
  196. package/rules/.source/hellotv/src/pages/filter/adapter/index.ts +180 -0
  197. package/rules/.source/hellotv/src/pages/filter/adapter/interface.ts +111 -0
  198. package/rules/.source/hellotv/src/pages/filter/api/index.ts +38 -0
  199. package/rules/.source/hellotv/src/pages/filter/api/interface.ts +44 -0
  200. package/rules/.source/hellotv/src/pages/filter/api/request-url.ts +8 -0
  201. package/rules/.source/hellotv/src/pages/filter/components/content/index.vue +469 -0
  202. package/rules/.source/hellotv/src/pages/filter/components/content/list-item-record.vue +16 -0
  203. package/rules/.source/hellotv/src/pages/filter/components/content/list-item.vue +78 -0
  204. package/rules/.source/hellotv/src/pages/filter/components/expand/index.vue +83 -0
  205. package/rules/.source/hellotv/src/pages/filter/components/sidebar/index.vue +81 -0
  206. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-filter-title.vue +78 -0
  207. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-filter.vue +68 -0
  208. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-line.vue +11 -0
  209. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-text.vue +43 -0
  210. package/rules/.source/hellotv/src/pages/filter/components/sidebar/list-item-title.vue +14 -0
  211. package/rules/.source/hellotv/src/pages/filter/config.ts +10 -0
  212. package/rules/.source/hellotv/src/pages/filter/expand-sidebar-contents.vue +203 -0
  213. package/rules/.source/hellotv/src/pages/filter/scss/filter-content-list-item.scss +42 -0
  214. package/rules/.source/hellotv/src/pages/filter/scss/filter-content.scss +60 -0
  215. package/rules/.source/hellotv/src/pages/filter/scss/filter-expand.scss +30 -0
  216. package/rules/.source/hellotv/src/pages/filter/scss/filter-sidebar.scss +45 -0
  217. package/rules/.source/hellotv/src/pages/filter/scss/filter.scss +21 -0
  218. package/rules/.source/hellotv/src/pages/filter/sidebar-contents.vue +145 -0
  219. package/rules/.source/hellotv/src/pages/filter/single-contents.vue +61 -0
  220. package/rules/.source/hellotv/src/pages/history/adapter/index.ts +51 -0
  221. package/rules/.source/hellotv/src/pages/history/adapter/interface.ts +22 -0
  222. package/rules/.source/hellotv/src/pages/history/api/index.ts +54 -0
  223. package/rules/.source/hellotv/src/pages/history/api/interface.ts +41 -0
  224. package/rules/.source/hellotv/src/pages/history/api/request-url.ts +10 -0
  225. package/rules/.source/hellotv/src/pages/history/components/confirm-dialog.vue +155 -0
  226. package/rules/.source/hellotv/src/pages/history/config.ts +8 -0
  227. package/rules/.source/hellotv/src/pages/history/index-raw.vue +540 -0
  228. package/rules/.source/hellotv/src/pages/history/index.vue +431 -0
  229. package/rules/.source/hellotv/src/pages/history/mock.ts +32 -0
  230. package/rules/.source/hellotv/src/pages/history/scss/history-raw.scss +181 -0
  231. package/rules/.source/hellotv/src/pages/history/scss/history.scss +148 -0
  232. package/rules/.source/hellotv/src/pages/home/adapter/exit/home-exit-adapter.ts +20 -0
  233. package/rules/.source/hellotv/src/pages/home/adapter/exit/home-exit-imp.ts +13 -0
  234. package/rules/.source/hellotv/src/pages/home/adapter/media/create-home-player-interceptor.ts +50 -0
  235. package/rules/.source/hellotv/src/pages/home/adapter/media/home-media-imp.ts +74 -0
  236. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-adapter.ts +151 -0
  237. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-config.ts +17 -0
  238. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-imp.ts +53 -0
  239. package/rules/.source/hellotv/src/pages/home/adapter/tab-bar/tab-bar-item-type.ts +6 -0
  240. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-adapter.ts +1304 -0
  241. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-config.ts +30 -0
  242. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-imp.ts +173 -0
  243. package/rules/.source/hellotv/src/pages/home/adapter/tab-content/tab-content-item-type.ts +17 -0
  244. package/rules/.source/hellotv/src/pages/home/api/index.ts +157 -0
  245. package/rules/.source/hellotv/src/pages/home/api/interface.ts +56 -0
  246. package/rules/.source/hellotv/src/pages/home/api/request-url.ts +22 -0
  247. package/rules/.source/hellotv/src/pages/home/components/exit-dialog.vue +148 -0
  248. package/rules/.source/hellotv/src/pages/home/components/media/bg-player.vue +440 -0
  249. package/rules/.source/hellotv/src/pages/home/components/nav-bar/bar-img-item.vue +39 -0
  250. package/rules/.source/hellotv/src/pages/home/components/nav-bar/bar-text-item.vue +100 -0
  251. package/rules/.source/hellotv/src/pages/home/components/tab-content/bg-player-cell-list-item-img.vue +54 -0
  252. package/rules/.source/hellotv/src/pages/home/components/tab-content/bg-player-cell-list-item-text.vue +67 -0
  253. package/rules/.source/hellotv/src/pages/home/components/tab-content/cell-list-player-item.vue +74 -0
  254. package/rules/.source/hellotv/src/pages/home/components/tab-content/cell-player-item.vue +40 -0
  255. package/rules/.source/hellotv/src/pages/home/components/tab-content/focus-change-img-item.vue +41 -0
  256. package/rules/.source/hellotv/src/pages/home/components/tab-content/history-item.vue +362 -0
  257. package/rules/.source/hellotv/src/pages/home/components/tab-content/inner-out-title-item.vue +60 -0
  258. package/rules/.source/hellotv/src/pages/home/components/tab-content/no-title-item.vue +46 -0
  259. package/rules/.source/hellotv/src/pages/home/components/tab-content/placeholder-item.vue +25 -0
  260. package/rules/.source/hellotv/src/pages/home/components/tab-content/short-video/short-video-section-item.vue +80 -0
  261. package/rules/.source/hellotv/src/pages/home/components/tab-content/short-video/short-video-section.vue +70 -0
  262. package/rules/.source/hellotv/src/pages/home/components/tab-content/small-4k/small-four-section.vue +76 -0
  263. package/rules/.source/hellotv/src/pages/home/components/tab-content/world-4k/world-four-section-item.vue +90 -0
  264. package/rules/.source/hellotv/src/pages/home/components/tab-content/world-4k/world-four-section.vue +57 -0
  265. package/rules/.source/hellotv/src/pages/home/components/waterfall-tabs.vue +1307 -0
  266. package/rules/.source/hellotv/src/pages/home/index.vue +117 -0
  267. package/rules/.source/hellotv/src/pages/home/scss/bar-img-item.scss +11 -0
  268. package/rules/.source/hellotv/src/pages/home/scss/bar-text-item.scss +80 -0
  269. package/rules/.source/hellotv/src/pages/home/scss/base.scss +8 -0
  270. package/rules/.source/hellotv/src/pages/home/scss/bg-player-cell-list-item.scss +24 -0
  271. package/rules/.source/hellotv/src/pages/home/scss/bg-player.scss +50 -0
  272. package/rules/.source/hellotv/src/pages/home/scss/cell-player-item.scss +24 -0
  273. package/rules/.source/hellotv/src/pages/home/scss/exit-dialog.scss +89 -0
  274. package/rules/.source/hellotv/src/pages/home/scss/focus-change-img-item.scss +12 -0
  275. package/rules/.source/hellotv/src/pages/home/scss/home.scss +32 -0
  276. package/rules/.source/hellotv/src/pages/home/scss/inner-out-title-item.scss +24 -0
  277. package/rules/.source/hellotv/src/pages/home/scss/no-title-item.scss +15 -0
  278. package/rules/.source/hellotv/src/pages/home/scss/placeholder-item.scss +14 -0
  279. package/rules/.source/hellotv/src/pages/home/scss/short-video-section.scss +59 -0
  280. package/rules/.source/hellotv/src/pages/home/scss/small-four-section.scss +14 -0
  281. package/rules/.source/hellotv/src/pages/home/scss/waterfall-tabs.scss +50 -0
  282. package/rules/.source/hellotv/src/pages/home/scss/world-four-section.scss +106 -0
  283. package/rules/.source/hellotv/src/pages/introduction/index.vue +227 -0
  284. package/rules/.source/hellotv/src/pages/live/components/menu/first-list-item-icon-text.vue +35 -0
  285. package/rules/.source/hellotv/src/pages/live/components/menu/first-list-item-img.vue +16 -0
  286. package/rules/.source/hellotv/src/pages/live/components/menu/first-list-item-text.vue +16 -0
  287. package/rules/.source/hellotv/src/pages/live/components/menu/index.vue +266 -0
  288. package/rules/.source/hellotv/src/pages/live/components/menu/second-list-item.vue +80 -0
  289. package/rules/.source/hellotv/src/pages/live/components/menu/third-list-item.vue +68 -0
  290. package/rules/.source/hellotv/src/pages/live/components/player/index.vue +168 -0
  291. package/rules/.source/hellotv/src/pages/live/components/player/player-error.vue +48 -0
  292. package/rules/.source/hellotv/src/pages/live/components/player/player-loading.vue +50 -0
  293. package/rules/.source/hellotv/src/pages/live/components/player/player-tips.vue +125 -0
  294. package/rules/.source/hellotv/src/pages/live/components/player/tips-icon-text.vue +27 -0
  295. package/rules/.source/hellotv/src/pages/live/css/menu.css +109 -0
  296. package/rules/.source/hellotv/src/pages/live/css/player.css +56 -0
  297. package/rules/.source/hellotv/src/pages/live/index.vue +128 -0
  298. package/rules/.source/hellotv/src/pages/live/mock/index.ts +263 -0
  299. package/rules/.source/hellotv/src/pages/live/types/index.ts +42 -0
  300. package/rules/.source/hellotv/src/pages/login/index.vue +116 -0
  301. package/rules/.source/hellotv/src/pages/login/scss/login.scss +61 -0
  302. package/rules/.source/hellotv/src/pages/m-test.vue +84 -0
  303. package/rules/.source/hellotv/src/pages/my/README.md +87 -0
  304. package/rules/.source/hellotv/src/pages/my/index.vue +177 -0
  305. package/rules/.source/hellotv/src/pages/my/my-data-manager.ts +606 -0
  306. package/rules/.source/hellotv/src/pages/my/my-templates.vue +24 -0
  307. package/rules/.source/hellotv/src/pages/my/poster/index.vue +98 -0
  308. package/rules/.source/hellotv/src/pages/my/poster/my-card2.vue +90 -0
  309. package/rules/.source/hellotv/src/pages/my/poster/my-icon-title-col.vue +72 -0
  310. package/rules/.source/hellotv/src/pages/my/poster/my-icon-title-row.vue +72 -0
  311. package/rules/.source/hellotv/src/pages/my/poster/my-info.vue +50 -0
  312. package/rules/.source/hellotv/src/pages/my/poster/my-user.vue +126 -0
  313. package/rules/.source/hellotv/src/pages/play-test.vue +95 -0
  314. package/rules/.source/hellotv/src/pages/search/README.md +57 -0
  315. package/rules/.source/hellotv/src/pages/search/adapter/index.ts +285 -0
  316. package/rules/.source/hellotv/src/pages/search/adapter/interface.ts +60 -0
  317. package/rules/.source/hellotv/src/pages/search/api/index.ts +100 -0
  318. package/rules/.source/hellotv/src/pages/search/api/interface.ts +64 -0
  319. package/rules/.source/hellotv/src/pages/search/api/request-url.ts +20 -0
  320. package/rules/.source/hellotv/src/pages/search/components/search-content-tabs.vue +153 -0
  321. package/rules/.source/hellotv/src/pages/search/components/search-content.vue +282 -0
  322. package/rules/.source/hellotv/src/pages/search/components/search-keyboard.vue +252 -0
  323. package/rules/.source/hellotv/src/pages/search/components/search-keyword-grid.vue +85 -0
  324. package/rules/.source/hellotv/src/pages/search/components/search-keyword.vue +346 -0
  325. package/rules/.source/hellotv/src/pages/search/config.ts +10 -0
  326. package/rules/.source/hellotv/src/pages/search/scss/search-content.scss +130 -0
  327. package/rules/.source/hellotv/src/pages/search/scss/search-keyboard.scss +91 -0
  328. package/rules/.source/hellotv/src/pages/search/scss/search-keyword-grid.scss +30 -0
  329. package/rules/.source/hellotv/src/pages/search/scss/search-keyword.scss +104 -0
  330. package/rules/.source/hellotv/src/pages/search/scss/search.scss +18 -0
  331. package/rules/.source/hellotv/src/pages/search/three-columns.vue +164 -0
  332. package/rules/.source/hellotv/src/pages/search/two-columns.vue +128 -0
  333. package/rules/.source/hellotv/src/pages/tabs-test.vue +339 -0
  334. package/rules/.source/hellotv/src/pages/webview/load-web-view.vue +44 -0
  335. package/rules/.source/hellotv/src/routes.ts +142 -0
  336. package/rules/.source/hellotv/src/tools/common.ts +18 -0
  337. package/rules/.source/hellotv/src/tools/format-date.ts +16 -0
  338. package/rules/.source/hellotv/src/tools/index.ts +58 -0
  339. package/rules/.source/hellotv/src/tools/launch.ts +339 -0
  340. package/rules/.source/hellotv/src/tools/request/index.ts +206 -0
  341. package/rules/.source/hellotv/src/tools/request/interface.ts +64 -0
  342. package/rules/.source/hellotv/src/typings/shims-vue.d.ts +6 -0
  343. package/rules/.source/hellotv/src/vue.config.js +3 -0
  344. package/rules/.source/hellotv/tsconfig.json +34 -0
  345. package/rules/.windsurfrules +1 -0
  346. package/rules/AGENTS.md +1 -0
  347. package/rules/CLAUDE.md +1 -0
  348. package/rules/GEMINI.md +1 -0
@@ -0,0 +1,74 @@
1
+ <template>
2
+ <tv-item
3
+ class="cell-player-item-root-css"
4
+ layout="${layout}"
5
+ flexStyle="${style}"
6
+ :enableFocusBorder="false"
7
+ :focusScale="1"
8
+ disablePlaceholderFocus
9
+ :focusable="false"
10
+ :clipChildren="true"
11
+ eventClick
12
+ eventFocus
13
+ >
14
+ <img
15
+ class="cell-player-list-item-bg"
16
+ sid="${image.sid}"
17
+ flexStyle="${image.style}"
18
+ src="${image.normal}"
19
+ :postDelay="100"
20
+ :duplicateParentState="true"
21
+ :enableFocusBorder="true"
22
+ :focusable="false"
23
+ />
24
+ <qt-replace-child
25
+ class="cell-player-item-replace"
26
+ flexStyle="${play.style}"
27
+ sid="${play.sid}"
28
+ eventReceiverSID="homeTabsSid"
29
+ :postDelay="300"
30
+ :focusable="false"
31
+ :clipChildren="false"
32
+ :replaceOnVisibilityChanged="false"
33
+ :markChildSID="TabContentConfig.homeBgPlaySid"
34
+ >
35
+ </qt-replace-child>
36
+ <qt-list-view
37
+ flexStyle="${listStyle}"
38
+ sid="${cellListSid}"
39
+ :clipChildren="true"
40
+ :clipPadding="true"
41
+ :singleSelectPosition="0"
42
+ list="${play.buildPlayData}"
43
+ :refocusType="'KeepPosition'"
44
+ :skipRequestFocus="true"
45
+ :resetOnDetach="true"
46
+ :endHintEnabled="false"
47
+ :verticalFadingEdgeEnabled="true"
48
+ >
49
+ <!-- 文字-->
50
+ <bg-player-cell-list-item-text :type="86" />
51
+ <bg-player-cell-list-item-img
52
+ :type="82"
53
+ :imgStyle="{ borderTopRightRadius: `${borderRadius}px` }"
54
+ />
55
+ <bg-player-cell-list-item-img :type="83" />
56
+ <bg-player-cell-list-item-img
57
+ :type="84"
58
+ :imgStyle="{ borderBottomRightRadius: `${borderRadius}px` }"
59
+ />
60
+ </qt-list-view>
61
+ </tv-item>
62
+ </template>
63
+
64
+ <script lang="ts" setup name="cell-list-player-item">
65
+ import { ref } from "vue";
66
+ import TabContentConfig from "../../adapter/tab-content/tab-content-config";
67
+ import BgPlayerCellListItemImg from "./bg-player-cell-list-item-img.vue";
68
+ import BgPlayerCellListItemText from "./bg-player-cell-list-item-text.vue";
69
+ import ThemeConfig from "../../../../config/theme-config.ts";
70
+ const borderRadius = ref(ThemeConfig.focusBorderCorner);
71
+ defineExpose({});
72
+ </script>
73
+
74
+ <style lang="scss" src="../../scss/cell-player-item.scss"></style>
@@ -0,0 +1,40 @@
1
+ <template>
2
+ <tv-item
3
+ class="cell-player-item-root-css"
4
+ layout="${layout}"
5
+ flexStyle="${style}"
6
+ :focusable="true"
7
+ :clipChildren="false"
8
+ eventClick
9
+ eventFocus
10
+ >
11
+ <img
12
+ class="cell-player-item-bg"
13
+ flexStyle="${image.style}"
14
+ src="${image.normal}"
15
+ :postDelay="100"
16
+ :duplicateParentState="true"
17
+ :enableFocusBorder="true"
18
+ :focusable="false"
19
+ />
20
+ <qt-replace-child
21
+ class="cell-player-item-replace"
22
+ flexStyle="${play.style}"
23
+ sid="${play.sid}"
24
+ :postDelay="300"
25
+ eventReceiverSID="homeTabsSid"
26
+ :focusable="false"
27
+ :clipChildren="false"
28
+ :replaceOnVisibilityChanged="false"
29
+ :markChildSID="TabContentConfig.homeBgPlaySid"
30
+ >
31
+ </qt-replace-child>
32
+ </tv-item>
33
+ </template>
34
+
35
+ <script lang="ts" setup name="cell-player-item">
36
+ import TabContentConfig from "../../adapter/tab-content/tab-content-config";
37
+ defineExpose({});
38
+ </script>
39
+
40
+ <style lang="scss" src="../../scss/cell-player-item.scss"></style>
@@ -0,0 +1,41 @@
1
+ <template>
2
+ <item-frame
3
+ class="focus-change-img-root-css"
4
+ layout="${layout}"
5
+ flexStyle="${style}"
6
+ :focusable="true"
7
+ :clipChildren="false"
8
+ eventClick
9
+ eventFocus
10
+ itemShowShimmer="${shimmer.enable}"
11
+ shimmerSize="${shimmer.size}"
12
+ >
13
+ <img
14
+ class="focus-change-img-css"
15
+ flexStyle="${image.style}"
16
+ :showOnState="['normal', 'selected']"
17
+ :postDelay="100"
18
+ :focusable="false"
19
+ :duplicateParentState="true"
20
+ :enablePlaceholder="true"
21
+ :enableFocusBorder="false"
22
+ src="${image.normal}"
23
+ />
24
+ <img
25
+ class="focus-change-img-css"
26
+ flexStyle="${style}"
27
+ showOnState="focused"
28
+ :postDelay="100"
29
+ :focusable="false"
30
+ :duplicateParentState="true"
31
+ :enableFocusBorder="false"
32
+ src="${image.focused}"
33
+ />
34
+ </item-frame>
35
+ </template>
36
+
37
+ <script lang="ts" setup name="focus-change-img-item">
38
+ defineExpose({});
39
+ </script>
40
+
41
+ <style lang="scss" src="../../scss/focus-change-img-item.scss"></style>
@@ -0,0 +1,362 @@
1
+ <template>
2
+ <div
3
+ class="history-item-root-css"
4
+ eventClick
5
+ eventFocus
6
+ :focusable="false"
7
+ :enablePlaceholder="true"
8
+ :clipChildren="false"
9
+ flexStyle="${style}"
10
+ gradientBackground="${gradientBackground}"
11
+ layout="${layout}"
12
+ >
13
+ <qt-list-view
14
+ list="${historyList}"
15
+ :clipChildren="false"
16
+ :focusable="false"
17
+ class="h-list"
18
+ :refocusType="'KeepPosition'"
19
+ :skipRequestFocus="true"
20
+ :resetOnDetach="true"
21
+ :endHintEnabled="false"
22
+ flexStyle="${style}"
23
+ >
24
+ <!-- 无历史 item-->
25
+ <qt-view
26
+ :type="4001"
27
+ class="no-history-item"
28
+ flexStyle="${style}"
29
+ eventClick
30
+ eventFocus
31
+ :focusable="true"
32
+ :enableFocusBorder="true"
33
+ :focusScale="ThemeConfig.placeHolderFocusScale"
34
+ :clipChildren="false"
35
+ >
36
+ <img
37
+ class="no-history-item-img"
38
+ :src="bg_history_item"
39
+ :focusable="false"
40
+ />
41
+ <qt-text
42
+ class="no-history-item-title"
43
+ text="历史记录"
44
+ typeface="bold"
45
+ :fontSize="36"
46
+ />
47
+ <qt-text class="no-history-item-text" text="${text}" :fontSIze="28" />
48
+ </qt-view>
49
+ <!-- 历史 item -->
50
+ <qt-view
51
+ :type="4002"
52
+ name="history-item"
53
+ class="history-item"
54
+ :focusable="true"
55
+ flexStyle="${style}"
56
+ :clipChildren="false"
57
+ eventClick
58
+ eventFocus
59
+ :enableFocusBorder="true"
60
+ :focusScale="ThemeConfig.placeHolderFocusScale"
61
+ >
62
+ <div
63
+ duplicateParentState
64
+ class="history-item-text-box"
65
+ :focusable="false"
66
+ >
67
+ <qt-text
68
+ :focusable="false"
69
+ text="${text}"
70
+ :lines="1"
71
+ :maxLines="1"
72
+ :ellipsizeMode="2"
73
+ :fontSize="30"
74
+ gravity="start|center"
75
+ :showOnState="['normal', 'selected']"
76
+ class="history-item-text"
77
+ duplicateParentState
78
+ />
79
+ <qt-text
80
+ :focusable="false"
81
+ text="${text}"
82
+ :lines="1"
83
+ :maxLines="1"
84
+ :ellipsizeMode="4"
85
+ :horizontalFadingEdgeEnabled="true"
86
+ :fontSize="30"
87
+ gravity="start|center"
88
+ typeface="bold"
89
+ showOnState="focused"
90
+ style="color: #13161b"
91
+ class="history-item-text"
92
+ duplicateParentState
93
+ />
94
+ </div>
95
+ <qt-text
96
+ :focusable="false"
97
+ text="${progress}"
98
+ :lines="1"
99
+ :maxLines="1"
100
+ :ellipsizeMode="2"
101
+ :fontSize="24"
102
+ gravity="end|center"
103
+ class="history-item-progress"
104
+ duplicateParentState
105
+ />
106
+ </qt-view>
107
+ <!-- 历史 login-item -->
108
+ <qt-view
109
+ :type="4003"
110
+ name="history-login-item"
111
+ class="history-login-item"
112
+ :focusable="true"
113
+ flexStyle="${style}"
114
+ :clipChildren="false"
115
+ eventClick
116
+ eventFocus
117
+ :enableFocusBorder="true"
118
+ :focusScale="ThemeConfig.placeHolderFocusScale"
119
+ >
120
+ <div
121
+ duplicateParentState
122
+ class="history-login-item-text-box"
123
+ :focusable="false"
124
+ >
125
+ <qt-text
126
+ :focusable="false"
127
+ text="${text}"
128
+ :lines="1"
129
+ :maxLines="1"
130
+ :ellipsizeMode="2"
131
+ :fontSize="30"
132
+ gravity="start|center"
133
+ :showOnState="['normal', 'selected']"
134
+ class="history-login-item-text"
135
+ duplicateParentState
136
+ />
137
+ <qt-text
138
+ :focusable="false"
139
+ text="${text}"
140
+ :lines="1"
141
+ :maxLines="1"
142
+ :ellipsizeMode="2"
143
+ :fontSize="30"
144
+ gravity="start|center"
145
+ typeface="bold"
146
+ showOnState="focused"
147
+ style="color: #13161b"
148
+ class="history-login-item-text"
149
+ duplicateParentState
150
+ />
151
+ </div>
152
+ <div duplicateParentState class="history-login-item-icon">
153
+ <img
154
+ :src="ic_arrow_normal"
155
+ :focusable="false"
156
+ :showOnState="['normal', 'selected']"
157
+ duplicateParentState
158
+ />
159
+ <img
160
+ :src="ic_arrow_focused"
161
+ :focusable="false"
162
+ showOnState="focused"
163
+ duplicateParentState
164
+ />
165
+ </div>
166
+ </qt-view>
167
+ <!-- line -->
168
+ <div
169
+ :type="4004"
170
+ class="history-item-line"
171
+ :focusable="false"
172
+ flexStyle="${style}"
173
+ :clipChildren="false"
174
+ ></div>
175
+ <!-- 历史图片样式 -->
176
+ <qt-view
177
+ :type="4005"
178
+ style="background-color: transparent"
179
+ flexStyle="${style}"
180
+ :clipChildren="false"
181
+ :focusable="true"
182
+ :focusScale="ThemeConfig.placeHolderFocusScale"
183
+ :enableFocusBorder="true"
184
+ eventFocus
185
+ eventClick
186
+ >
187
+ <qt-image
188
+ style="
189
+ width: 410px;
190
+ height: 161px;
191
+ background-color: transparent;
192
+ border-top-left-radius: 16px;
193
+ border-top-right-radius: 16px;
194
+ position: absolute;
195
+ "
196
+ src="${cover}"
197
+ :showOnState="['normal', 'selected']"
198
+ :focusable="false"
199
+ :duplicateParentState="true"
200
+ ></qt-image>
201
+ <qt-image
202
+ style="
203
+ width: 410px;
204
+ height: 161px;
205
+ background-color: transparent;
206
+ border-radius: 16px;
207
+ position: absolute;
208
+ "
209
+ src="${cover}"
210
+ :showOnState="'focused'"
211
+ :focusable="false"
212
+ :duplicateParentState="true"
213
+ ></qt-image>
214
+ <qt-text
215
+ class="history-image-item-text"
216
+ text="${text}"
217
+ gravity="center|start"
218
+ typeface="bold"
219
+ :focusable="false"
220
+ :ellipsizeMode="4"
221
+ :duplicateParentState="true"
222
+ ></qt-text>
223
+ <qt-text
224
+ class="history-image-item-progress"
225
+ text="${progress}"
226
+ gravity="center|start"
227
+ :focusable="false"
228
+ ></qt-text>
229
+ </qt-view>
230
+ </qt-list-view>
231
+ </div>
232
+ </template>
233
+
234
+ <script lang="ts" setup name="history-text-item">
235
+ import ThemeConfig from "../../../../config/theme-config";
236
+ import bg_history_item from "../../../../assets/home/bg_history_item.png";
237
+ import ic_arrow_normal from "../../../../assets/home/ic_arrow_normal.png";
238
+ import ic_arrow_focused from "../../../../assets/home/ic_arrow_focused.png";
239
+
240
+ defineExpose({});
241
+ </script>
242
+
243
+ <style lang="scss" scoped>
244
+ .history-item-root-css {
245
+ background-color: transparent;
246
+ border-radius: $theme-img-border;
247
+ .h-list {
248
+ background-color: transparent;
249
+ .no-history-item {
250
+ background-color: rgba(255, 255, 255, 0.06);
251
+ border-radius: $theme-img-border;
252
+ .no-history-item-title {
253
+ margin-top: 26px;
254
+ margin-left: 36px;
255
+ color: white;
256
+ width: 144px;
257
+ height: 45px;
258
+ background-color: transparent;
259
+ }
260
+ .no-history-item-text {
261
+ width: 230px;
262
+ height: 36px;
263
+ color: rgba(255, 255, 255, 0.5);
264
+ margin-top: 14px;
265
+ margin-left: 36px;
266
+ background-color: transparent;
267
+ }
268
+ }
269
+ .no-history-item-img {
270
+ position: absolute;
271
+ left: 269px;
272
+ top: 116px;
273
+ width: 139px;
274
+ height: 115px;
275
+ border-bottom-right-radius: $theme-img-border;
276
+ }
277
+ .history-item {
278
+ flex-direction: row;
279
+ background-color: transparent;
280
+ border-radius: $theme-img-border;
281
+ padding-left: 20px;
282
+ padding-right: 20px;
283
+ focus-background-color: rgba(255, 255, 255, 0.95);
284
+ .history-item-text-box {
285
+ width: 280px;
286
+ height: 76px;
287
+ background-color: transparent;
288
+ }
289
+ .history-item-text {
290
+ position: absolute;
291
+ width: 280px;
292
+ height: 76px;
293
+ color: #fff;
294
+ }
295
+ .history-item-progress {
296
+ width: 70px;
297
+ margin-left: 23px;
298
+ background-color: transparent;
299
+ color: rgba(255, 255, 255, 0.55);
300
+ focus-color: #13161b;
301
+ }
302
+ }
303
+ .history-login-item {
304
+ flex-direction: row;
305
+ background-color: transparent;
306
+ border-radius: $theme-img-border;
307
+ padding-left: 20px;
308
+ padding-right: 20px;
309
+ focus-background-color: rgba(255, 255, 255, 0.95);
310
+ align-items: center;
311
+ .history-login-item-text-box {
312
+ width: 280px;
313
+ height: 76px;
314
+ background-color: transparent;
315
+ }
316
+ .history-login-item-text {
317
+ position: absolute;
318
+ width: 280px;
319
+ height: 76px;
320
+ color: #fff;
321
+ }
322
+ .history-login-item-icon {
323
+ width: 13px;
324
+ height: 76px;
325
+ background-color: transparent;
326
+ margin-left: 75px;
327
+ img {
328
+ width: 13px;
329
+ height: 22px;
330
+ margin-top: 27px;
331
+ position: absolute;
332
+ }
333
+ }
334
+ }
335
+ .history-item-line {
336
+ background-color: rgba(255, 255, 255, 0.1);
337
+ }
338
+
339
+ .history-image-item-text {
340
+ width: 200px;
341
+ height: 40px;
342
+ background-color: transparent;
343
+ position: absolute;
344
+ top: 41px;
345
+ left: 20px;
346
+ font-size: 30px;
347
+ color: white;
348
+ }
349
+
350
+ .history-image-item-progress {
351
+ width: 200px;
352
+ height: 34px;
353
+ background-color: transparent;
354
+ position: absolute;
355
+ top: 86px;
356
+ left: 20px;
357
+ font-size: 24px;
358
+ color: rgba(255, 255, 255, 0.55);
359
+ }
360
+ }
361
+ }
362
+ </style>
@@ -0,0 +1,60 @@
1
+ <template>
2
+ <item-frame
3
+ class="inner-out-title-root-css"
4
+ layout="${layout}"
5
+ flexStyle="${style}"
6
+ :focusable="true"
7
+ :clipChildren="false"
8
+ name="innerItem"
9
+ itemShowShimmer="${shimmer.enable}"
10
+ shimmerSize="${shimmer.size}"
11
+ eventClick
12
+ eventFocus
13
+ >
14
+ <img
15
+ class="inner-out-title-img"
16
+ :postDelay="100"
17
+ :duplicateParentState="true"
18
+ :focusable="false"
19
+ :enableFocusBorder="true"
20
+ :enablePlaceholder="true"
21
+ flexStyle="${image.style}"
22
+ src="${image.normal}"
23
+ />
24
+ <qt-text
25
+ class="inner-out-title-text"
26
+ flexStyle="${title.style}"
27
+ enablePostTask
28
+ :postDelay="100"
29
+ :duplicateParentState="true"
30
+ :focusable="false"
31
+ :textSize="28"
32
+ :paddingRect="[12, 16, 0, 0]"
33
+ :ellipsizeMode="4"
34
+ :lines="1"
35
+ gravity="left"
36
+ gradientBackground="${title.background}"
37
+ text="${title.text}"
38
+ />
39
+ <qt-text
40
+ showIf="${corner.enable==true}"
41
+ class="item-corner"
42
+ gradientBackground="${corner.background}"
43
+ autoWidth
44
+ typeface="bold"
45
+ gravity="center"
46
+ :focusable="false"
47
+ :postDelay="100"
48
+ :textSize="20"
49
+ :ellipsizeMode="2"
50
+ :lines="1"
51
+ text="${corner.text}"
52
+ />
53
+ </item-frame>
54
+ </template>
55
+
56
+ <script lang="ts" setup name="inner-out-title-item">
57
+ defineExpose({});
58
+ </script>
59
+
60
+ <style lang="scss" src="../../scss/inner-out-title-item.scss"></style>
@@ -0,0 +1,46 @@
1
+ <template>
2
+ <item-frame
3
+ class="no-title-item-root-css"
4
+ layout="${layout}"
5
+ flexStyle="${style}"
6
+ :focusable="true"
7
+ :clipChildren="false"
8
+ eventClick
9
+ eventFocus
10
+ itemShowShimmer="${shimmer.enable}"
11
+ shimmerSize="${shimmer.size}"
12
+ >
13
+ <!-- 海报图-->
14
+ <img
15
+ class="no-title-item-img"
16
+ flexStyle="${image.style}"
17
+ :enableFocusBorder="true"
18
+ :enablePlaceholder="true"
19
+ :duplicateParentState="true"
20
+ :postDelay="100"
21
+ :focusable="false"
22
+ src="${image.normal}"
23
+ />
24
+ <!-- 文字角标-->
25
+ <qt-text
26
+ showIf="${corner.enable==true}"
27
+ class="item-corner"
28
+ gradientBackground="${corner.background}"
29
+ autoWidth
30
+ typeface="bold"
31
+ gravity="center"
32
+ :focusable="false"
33
+ :postDelay="100"
34
+ :textSize="20"
35
+ :ellipsizeMode="2"
36
+ :lines="1"
37
+ text="${corner.text}"
38
+ />
39
+ </item-frame>
40
+ </template>
41
+
42
+ <script lang="ts" setup name="no-title-item">
43
+ defineExpose({});
44
+ </script>
45
+
46
+ <style lang="scss" src="../../scss/no-title-item.scss"></style>
@@ -0,0 +1,25 @@
1
+ <template>
2
+ <div
3
+ class="placeholder-root-css"
4
+ layout="${layout}"
5
+ flexStyle="${style}"
6
+ :focusable="false"
7
+ :disablePlaceholder="false"
8
+ :enableFocusBorder="false"
9
+ >
10
+ <img
11
+ class="placeholder-img"
12
+ flexStyle="${image.style}"
13
+ :postDelay="100"
14
+ :focusable="false"
15
+ :enableFocusBorder="false"
16
+ src="${image.normal}"
17
+ />
18
+ </div>
19
+ </template>
20
+
21
+ <script lang="ts" setup name="placeholder-item">
22
+ defineExpose({});
23
+ </script>
24
+
25
+ <style lang="scss" src="../../scss/placeholder-item.scss"></style>