@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,431 @@
1
+ <template>
2
+ <qt-view
3
+ class="history"
4
+ :gradientBackground="{
5
+ colors: themeConfig.bgGradientColor,
6
+ orientation: 4,
7
+ }"
8
+ >
9
+ <!-- 左侧列表 -->
10
+ <qt-view
11
+ class="history-sidebar"
12
+ :descendantFocusability="isEditing ? 2 : 1"
13
+ >
14
+ <!-- 顶部提示 -->
15
+ <qt-text
16
+ class="history-sidebar-tips"
17
+ text="全部记录"
18
+ gravity="center"
19
+ :focusable="false"
20
+ ></qt-text>
21
+
22
+ <!-- 数据渲染 -->
23
+ <qt-ul
24
+ class="history-sidebar"
25
+ ref="sidebarRef"
26
+ :data="sidebarData"
27
+ :autofocusPosition="0"
28
+ >
29
+ <template #default="{ index, item }">
30
+ <qt-view
31
+ class="history-sidebar-item"
32
+ :type="1"
33
+ :focusable="true"
34
+ @focus="(e) => onSidebarItemFocus(e, index)"
35
+ >
36
+ <qt-text
37
+ class="history-sidebar-item-text"
38
+ :text="item.text"
39
+ gravity="center"
40
+ :showOnState="['normal', 'selected']"
41
+ :focusable="false"
42
+ :duplicateParentState="true"
43
+ ></qt-text>
44
+ <qt-text
45
+ class="history-sidebar-item-text"
46
+ :text="item.text"
47
+ gravity="center"
48
+ :showOnState="'focused'"
49
+ :focusable="false"
50
+ :duplicateParentState="true"
51
+ ></qt-text>
52
+ </qt-view>
53
+ </template>
54
+ </qt-ul>
55
+ </qt-view>
56
+
57
+ <!-- 右侧列表 -->
58
+ <qt-view class="history-content" :clipChildren="true">
59
+ <!-- 数据管理 -->
60
+ <qt-view v-if="isEditing" class="history-content-btns">
61
+ <qt-button
62
+ text="取消"
63
+ :style="btnStyle"
64
+ :textStyle="textStyle"
65
+ :focusScale="1"
66
+ @click="onBtnClick('cancel')"
67
+ />
68
+ <qt-button
69
+ text="一键清空"
70
+ :style="btnStyle"
71
+ :textStyle="textStyle"
72
+ :focusScale="1"
73
+ @click="onBtnClick('clear')"
74
+ />
75
+ </qt-view>
76
+ <qt-text
77
+ v-else
78
+ class="history-content-tips"
79
+ text="按【菜单键】或长按【OK键】管理记录"
80
+ gravity="center|end"
81
+ ></qt-text>
82
+
83
+ <!-- 半屏loading -->
84
+ <qt-view
85
+ v-if="isLoading"
86
+ class="history-content-loading"
87
+ :gradientBackground="{ colors: ['#1A2029', '#00040B'], orientation: 0 }"
88
+ >
89
+ <qt-loading-view
90
+ style="height: 100px; width: 100px"
91
+ color="rgba(21,122,252,0.3)"
92
+ :focusable="false"
93
+ ></qt-loading-view>
94
+ </qt-view>
95
+
96
+ <!-- 暂无数据 -->
97
+ <qt-view v-if="isEmpty" class="history-content-empty">
98
+ <qt-image
99
+ style="width: 186px; height: 174px; margin-bottom: 35px"
100
+ :src="icEmpty"
101
+ ></qt-image>
102
+ <qt-text
103
+ class="history-content-empty-text"
104
+ text="暂无数据"
105
+ gravity="center"
106
+ ></qt-text>
107
+ </qt-view>
108
+
109
+ <!-- 数据渲染 -->
110
+ <qt-ul
111
+ class="history-content-ul"
112
+ ref="ulRef"
113
+ :data="contentData"
114
+ :useDiff="true"
115
+ :spanCount="4"
116
+ :clipChildren="false"
117
+ :verticalFadingEdgeEnabled="true"
118
+ :blockFocusDirections="['down']"
119
+ :openPage="true"
120
+ :listenBoundEvent="true"
121
+ @item-bind="onItemBind"
122
+ :listenHasFocusChange="true"
123
+ :loadMore="onContentloadMore"
124
+ @scroll-state-changed="onScrollStateChanged"
125
+ >
126
+ <template #default="{ index, item }">
127
+ <!-- 常规 -->
128
+ <qt-view
129
+ class="history-content-ul-item"
130
+ v-if="item.type === ContentType.Normal"
131
+ :focusable="true"
132
+ :focusScale="1.03"
133
+ @focus="onContentItemFocus"
134
+ @click="onContentItemClick(index)"
135
+ >
136
+ <!-- 焦点状态下的删除样式 -->
137
+ <qt-view
138
+ class="history-content-ul-item-delete"
139
+ v-if="isEditing"
140
+ :showOnState="'focused'"
141
+ :focusable="false"
142
+ :duplicateParentState="true"
143
+ >
144
+ <qt-image
145
+ style="width: 40px; height: 50px"
146
+ :src="icDelete"
147
+ :focusable="false"
148
+ ></qt-image>
149
+ </qt-view>
150
+ <qt-image
151
+ style="
152
+ width: 325px;
153
+ height: 186px;
154
+ background-color: transparent;
155
+ border-radius: 16px;
156
+ "
157
+ :src="item.image"
158
+ :enableFocusBorder="true"
159
+ :focusable="false"
160
+ :duplicateParentState="true"
161
+ ></qt-image>
162
+ <qt-view
163
+ style="
164
+ height: 40px;
165
+ background-color: transparent;
166
+ margin-top: 11px;
167
+ "
168
+ :focusable="false"
169
+ :duplicateParentState="true"
170
+ >
171
+ <qt-text
172
+ class="history-content-ul-item-title"
173
+ :text="item.title"
174
+ gravity="center|start"
175
+ :showOnState="['normal', 'selected']"
176
+ :focusable="false"
177
+ :duplicateParentState="true"
178
+ ></qt-text>
179
+ <qt-text
180
+ class="history-content-ul-item-title"
181
+ :text="item.title"
182
+ gravity="center|start"
183
+ :showOnState="'focused'"
184
+ :focusable="false"
185
+ :duplicateParentState="true"
186
+ ></qt-text>
187
+ </qt-view>
188
+ <qt-text
189
+ class="history-content-ul-item-progress"
190
+ :text="item.progress"
191
+ gravity="center|start"
192
+ :focusable="false"
193
+ ></qt-text>
194
+ </qt-view>
195
+ <!-- 到底提示 -->
196
+ <qt-view
197
+ class="history-content-ul-item-end"
198
+ v-if="item.type === ContentType.End"
199
+ :focusable="false"
200
+ >
201
+ <qt-text
202
+ class="history-content-ul-item-end-text"
203
+ text="已经到底啦,按【返回键】回到顶部"
204
+ gravity="center"
205
+ :focusable="false"
206
+ ></qt-text>
207
+ </qt-view>
208
+ </template>
209
+ </qt-ul>
210
+ </qt-view>
211
+ </qt-view>
212
+ </template>
213
+
214
+ <script setup lang="ts">
215
+ import { ref, onMounted, onUnmounted } from "vue";
216
+ import { ESKeyEvent, useESToast, useESEventBus } from "@extscreen/es3-core";
217
+ import { useESRouter } from "@extscreen/es3-router";
218
+ import { QTIListView, QTListViewItem } from "@quicktvui/quicktvui3";
219
+ import { buildContents, buildEndContent } from "./adapter/index";
220
+ import { ContentType } from "./adapter/interface";
221
+ import historyManager from "./api/index";
222
+ import launch from "../../tools/launch";
223
+ import icEmpty from "../../assets/history/ic_empty.png";
224
+ import icDelete from "../../assets/history/ic_delete.png";
225
+ import themeConfig from "../../config/theme-config";
226
+ import config from "./config";
227
+
228
+ const toast = useESToast();
229
+ const router = useESRouter();
230
+ const eventBus = useESEventBus();
231
+ const isLoading = ref<boolean>(false);
232
+ const isEmpty = ref<boolean>(false);
233
+ const isEditing = ref<boolean>(false);
234
+ const sidebarRef = ref<QTIListView>();
235
+ const ulRef = ref<QTIListView>();
236
+ const sidebarData = ref<QTListViewItem[]>([]);
237
+ const contentData = ref<QTListViewItem[]>([]);
238
+ const btnStyle = {
239
+ width: `180px`,
240
+ height: `60px`,
241
+ borderRadius: `34px`,
242
+ backgroundColor: "rgba(255, 255, 255, 0.06)",
243
+ focusBackgroundColor: "#FFFFFF",
244
+ marginLeft: "30px",
245
+ };
246
+ const textStyle = {
247
+ color: "rgba(255, 255, 255, 0.55)",
248
+ fontSize: `30px`,
249
+ focusColor: "#13161B",
250
+ };
251
+
252
+ let page = 1;
253
+ let stopPage = false;
254
+
255
+ onMounted(() => {
256
+ eventBus.on("clearPageData", clearPageData);
257
+ // 初始化左侧列表
258
+ sidebarData.value = [
259
+ { type: 1, itemSize: 106, id: 1, text: "观看历史" },
260
+ { type: 1, itemSize: 106, id: 2, text: "我的收藏" },
261
+ { type: 1, itemSize: 106, id: 3, text: "已购内容" },
262
+ ];
263
+ });
264
+
265
+ onUnmounted(() => {
266
+ eventBus.off("clearPageData");
267
+ });
268
+
269
+ let lastIndex = -1;
270
+ let lastFocusName = "";
271
+ function onSidebarItemFocus(evt, index) {
272
+ if (evt.isFocused) {
273
+ lastFocusName = "sidebar";
274
+
275
+ if (lastIndex !== index) {
276
+ page = 1;
277
+ stopPage = false;
278
+ lastIndex = index;
279
+ isLoading.value = true;
280
+ // 右侧内容复原
281
+ ulRef.value?.scrollToTop();
282
+ // 加载新数据
283
+ loadRecords(index);
284
+ }
285
+ }
286
+ }
287
+
288
+ function onContentItemFocus(evt) {
289
+ if (evt.isFocused) {
290
+ lastFocusName = "content";
291
+ }
292
+ }
293
+
294
+ function onContentItemClick(index) {
295
+ if (isEditing.value) {
296
+ historyManager
297
+ .delRecords(
298
+ "xxx",
299
+ lastIndex === 0 ? "history" : "favorite",
300
+ contentData.value[index].id,
301
+ )
302
+ .then(() => {
303
+ contentData.value.splice(index, 1);
304
+ })
305
+ .catch(() => {
306
+ toast.showToast("删除失败");
307
+ });
308
+ } else {
309
+ launch.launchDetail(contentData.value[index].id);
310
+ }
311
+ }
312
+
313
+ let loadingDelayTimer: any = -1;
314
+ async function loadRecords(
315
+ menuIndex: number,
316
+ page: number = 1,
317
+ limit: number = config.ContentsLimit,
318
+ ) {
319
+ console.log("ok->", menuIndex, page);
320
+ if (menuIndex === 2) {
321
+ contentData.value = [];
322
+ } else {
323
+ const records = await historyManager.getRecords(
324
+ "xxx",
325
+ menuIndex === 0 ? "history" : "favorite",
326
+ page,
327
+ limit,
328
+ );
329
+ if (page === 1) {
330
+ contentData.value = buildContents(records);
331
+ } else {
332
+ contentData.value = contentData.value.concat(buildContents(records));
333
+ // contentData.value.push(...buildContents(records))
334
+ }
335
+ // 到底提示
336
+ if (contentData.value.length > config.ContentsLimit) {
337
+ contentData.value.push(buildEndContent());
338
+ }
339
+ // 结束分页
340
+ stopPage = records.items.length < config.ContentsLimit;
341
+ }
342
+ isEmpty.value = contentData.value.length === 0;
343
+
344
+ // 延迟关闭loading
345
+ clearTimeout(loadingDelayTimer);
346
+ loadingDelayTimer = setTimeout(() => (isLoading.value = false), 300);
347
+ }
348
+
349
+ function onContentloadMore() {
350
+ if (!stopPage) {
351
+ loadRecords(lastIndex, ++page);
352
+ console.log(page, "32323444444444444444");
353
+ }
354
+ }
355
+
356
+ let offsetY = 0;
357
+ function onScrollStateChanged(evt) {
358
+ offsetY = evt.offsetY;
359
+ }
360
+
361
+ function onBtnClick(name: "cancel" | "clear") {
362
+ if (name === "cancel") {
363
+ isEditing.value = false;
364
+ } else {
365
+ router.push({
366
+ name: "confirm",
367
+ params: {
368
+ text: "清空之后什么都没有了哦~",
369
+ btnL: "确定",
370
+ btnR: "取消",
371
+ menuIndex: lastIndex,
372
+ clearHistory: true,
373
+ },
374
+ });
375
+ }
376
+ }
377
+
378
+ function onItemBind() {}
379
+
380
+ function clearPageData() {
381
+ isEmpty.value = true;
382
+ isEditing.value = false;
383
+ // 清空本地数据
384
+ contentData.value = [];
385
+ }
386
+
387
+ let oKCounter = 0;
388
+ function onKeyDown(keyEvent: ESKeyEvent) {
389
+ if (lastFocusName === "content") {
390
+ switch (keyEvent.keyCode) {
391
+ case 82: // 菜单键
392
+ isEditing.value = true;
393
+ break;
394
+ case 23: // 长按OK键
395
+ if ((oKCounter++, oKCounter > 10)) {
396
+ isEditing.value = true;
397
+ oKCounter = 0;
398
+ }
399
+ break;
400
+ default:
401
+ oKCounter = 0;
402
+ }
403
+ }
404
+ }
405
+
406
+ function onBackPressed() {
407
+ // 编辑状态检查
408
+ if (isEditing.value) {
409
+ isEditing.value = false;
410
+ return;
411
+ }
412
+
413
+ // 右侧内容滚动状态检查
414
+ if (offsetY > 0) {
415
+ ulRef.value?.scrollToTop();
416
+ return;
417
+ }
418
+
419
+ // 左侧列表焦点
420
+ if (lastFocusName !== "sidebar") {
421
+ sidebarRef.value?.setItemFocused(0);
422
+ return;
423
+ }
424
+
425
+ router.back();
426
+ }
427
+
428
+ defineExpose({ onKeyDown, onBackPressed });
429
+ </script>
430
+
431
+ <style scoped lang="scss" src="./scss/history.scss"></style>
@@ -0,0 +1,32 @@
1
+ import { numberToChinese } from "../../tools";
2
+
3
+ export interface Item {
4
+ type: number;
5
+ itemSize: number;
6
+ title?: string;
7
+ progress?: string;
8
+ image?: string;
9
+ decoration?: any;
10
+ }
11
+
12
+ export const buildMockData = (
13
+ tag: string = "观看历史",
14
+ limit: number = 100,
15
+ ): Item[] => {
16
+ const arr: Item[] = [];
17
+ for (let i = 1; i <= limit; i++) {
18
+ arr.push({
19
+ type: 1,
20
+ itemSize: 266,
21
+ title: `${tag}:第${numberToChinese(i)}回`,
22
+ progress: `${i}%`,
23
+ image:
24
+ "https://extcdn.hsrc.tv/channelzero_image/2023/12/15/5e84c591-038c-47d1-a266-46058d229d3b.png",
25
+ decoration: { left: 20, top: 20, right: 20, bottom: 20 },
26
+ });
27
+ }
28
+ // 到底提示
29
+ arr.push({ type: 1002, itemSize: 100, decoration: { bottom: 140 } });
30
+
31
+ return arr;
32
+ };
@@ -0,0 +1,181 @@
1
+ .history-raw {
2
+ width: 1920px;
3
+ height: 1080px;
4
+ background-color: transparent;
5
+ flex-direction: row;
6
+ }
7
+
8
+ .history-raw-focus-placeholder {
9
+ width: 1px;
10
+ height: 1px;
11
+ background-color: transparent;
12
+ position: absolute;
13
+ top: 0px;
14
+ left: 0px;
15
+ }
16
+
17
+ .history-raw-sidebar {
18
+ width: 340px;
19
+ height: 1080px;
20
+ background-color: rgba(255, 255, 255, 0.03);
21
+ }
22
+
23
+ .history-raw-sidebar-tips {
24
+ width: 250px;
25
+ height: 50px;
26
+ background-color: transparent;
27
+ margin-top: 75px;
28
+ margin-bottom: 30px;
29
+ color: white;
30
+ font-size: 40px;
31
+ }
32
+
33
+ .history-raw-sidebar-list {
34
+ width: 340px;
35
+ height: 1080px;
36
+ background-color: transparent;
37
+ }
38
+
39
+ .history-raw-sidebar-list-item {
40
+ width: 340px;
41
+ height: 106px;
42
+ background-color: transparent;
43
+ border-top-right-radius: 8px;
44
+ border-bottom-right-radius: 8px;
45
+ align-items: center;
46
+ justify-content: center;
47
+ focus-background-color: $theme-btn-focus-color;
48
+ }
49
+
50
+ .history-raw-sidebar-list-item-text {
51
+ width: 160px;
52
+ height: 106px;
53
+ background-color: transparent;
54
+ position: absolute;
55
+ color: $theme-text-normal-color;
56
+ font-size: 36px;
57
+ focus-color: $theme-text-focus-color;
58
+ select-color: $theme-text-select-color;
59
+ }
60
+
61
+ .history-raw-content {
62
+ width: 1580px;
63
+ height: 1080px;
64
+ background-color: transparent;
65
+ }
66
+
67
+ .history-raw-content-btns {
68
+ width: 1500px;
69
+ height: 60px;
70
+ background-color: transparent;
71
+ margin-top: 40px;
72
+ flex-direction: row;
73
+ align-items: center;
74
+ justify-content: flex-end;
75
+ }
76
+
77
+ .history-raw-content-btns-item {
78
+ width: 180px;
79
+ height: 60px;
80
+ background-color: rgba(255, 255, 255, 0.06);
81
+ align-items: center;
82
+ justify-content: center;
83
+ focus-background-color: #ffffff;
84
+ border-radius: 30px;
85
+ }
86
+
87
+ .history-raw-content-btns-item-text {
88
+ position: absolute;
89
+ width: 180px;
90
+ height: 60px;
91
+ background-color: transparent;
92
+ color: rgba(255, 255, 255, 0.55);
93
+ focus-color: #13161b;
94
+ font-size: 30px;
95
+ }
96
+
97
+ .history-raw-content-tips {
98
+ width: 1500px;
99
+ height: 60px;
100
+ background-color: transparent;
101
+ margin-top: 40px;
102
+ color: rgba(255, 255, 255, 0.55);
103
+ font-size: 24px;
104
+ }
105
+
106
+ .history-raw-content-loading {
107
+ width: 1580px;
108
+ height: 1000px;
109
+ background-color: transparent;
110
+ align-items: center;
111
+ justify-content: center;
112
+ }
113
+
114
+ .history-raw-content-empty {
115
+ width: 1580px;
116
+ height: 1000px;
117
+ background-color: transparent;
118
+ align-items: center;
119
+ justify-content: center;
120
+ }
121
+
122
+ .history-raw-content-empty-text {
123
+ width: 180px;
124
+ height: 40px;
125
+ background-color: transparent;
126
+ color: rgba(255, 255, 255, 0.55);
127
+ font-size: 30px;
128
+ }
129
+
130
+ .history-raw-content-grid {
131
+ width: 1460px;
132
+ height: 955px;
133
+ background-color: transparent;
134
+ margin-top: 25px;
135
+ margin-left: 60px;
136
+ }
137
+
138
+ .history-raw-content-grid-item {
139
+ width: 325px;
140
+ background-color: transparent;
141
+ }
142
+
143
+ .history-raw-content-grid-item-delete {
144
+ width: 321px;
145
+ height: 182px;
146
+ background-color: rgba(0, 0, 0, 0.65);
147
+ border-radius: 16px;
148
+ align-items: center;
149
+ justify-content: center;
150
+ position: absolute;
151
+ top: 1px;
152
+ left: 1px;
153
+ z-index: 100;
154
+ }
155
+
156
+ .history-raw-content-grid-item-title {
157
+ width: 325px;
158
+ height: 40px;
159
+ background-color: transparent;
160
+ margin-top: 11px;
161
+ color: $theme-text-normal-color;
162
+ font-size: 30px;
163
+ focus-color: white;
164
+ }
165
+
166
+ .history-raw-content-grid-item-progress {
167
+ width: 325px;
168
+ height: 34px;
169
+ background-color: transparent;
170
+ color: $theme-text-normal-color;
171
+ font-size: 24px;
172
+ focus-color: white;
173
+ }
174
+
175
+ .history-raw-content-grid-item-end-text {
176
+ width: 1460px;
177
+ height: 100px;
178
+ background-color: transparent;
179
+ color: rgba(255, 255, 255, 0.55);
180
+ font-size: 28px;
181
+ }