@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,56 @@
1
+ .player-tips {
2
+ width: 900px;
3
+ height: 200px;
4
+ background-color: transparent;
5
+ flex-direction: row;
6
+ position: absolute;
7
+ left: 510px;
8
+ bottom: 47px;
9
+ }
10
+
11
+ .player-tips-corner {
12
+ width: 90px;
13
+ height: 40px;
14
+ background-color: transparent;
15
+ position: absolute;
16
+ top: -4px;
17
+ }
18
+
19
+ .player-tips-left {
20
+ width: 274px;
21
+ height: 200px;
22
+ background-color: transparent;
23
+ align-items: center;
24
+ justify-content: center;
25
+ }
26
+
27
+ .player-tips-right {
28
+ width: 626px;
29
+ height: 200px;
30
+ background-color: transparent;
31
+ justify-content: center;
32
+ padding-right: 50px;
33
+ }
34
+
35
+ .player-tips-right-box {
36
+ height: 40px;
37
+ flex-direction: row;
38
+ align-items: center;
39
+ justify-content: space-between;
40
+ }
41
+
42
+ .player-tips-text {
43
+ width: 470px;
44
+ height: 40px;
45
+ color: rgba(255, 255, 255, 0.7);
46
+ font-size: 22px;
47
+ }
48
+
49
+ .player-tips-line {
50
+ width: 576px;
51
+ height: 2px;
52
+ background-color: rgba(255, 255, 255, 0.7);
53
+ border: 1 solid #ffffff;
54
+ margin-top: 13px;
55
+ margin-bottom: 14px;
56
+ }
@@ -0,0 +1,128 @@
1
+ <template>
2
+ <qt-view class="live">
3
+ <!-- 全屏播放 -->
4
+ <player-live ref="playerRef" @closeMenu="closeMenu" />
5
+ <!-- 频道列表 -->
6
+ <channel-menu
7
+ v-show="showMenu"
8
+ ref="menuRef"
9
+ @loadPrograms="loadPrograms"
10
+ @playMediaByIndex="playMediaByIndex"
11
+ @closeMenu="closeMenu"
12
+ />
13
+ <!-- 占位填充 -->
14
+ <qt-view
15
+ style="width: 1920px; height: 1080px; background-color: transparent"
16
+ :focusable="false"
17
+ ></qt-view>
18
+ </qt-view>
19
+ </template>
20
+
21
+ <script setup lang="ts">
22
+ import { onMounted, ref } from "vue";
23
+ import { ESKeyEvent, ESKeyCode, useESToast } from "@extscreen/es3-core";
24
+ import { useESRouter } from "@extscreen/es3-router";
25
+ import {
26
+ mockMediaList,
27
+ mockCategories,
28
+ mockChannels,
29
+ mockPrograms,
30
+ } from "./mock/index";
31
+ import playerLive from "./components/player/index.vue";
32
+ import channelMenu from "./components/menu/index.vue";
33
+
34
+ const toast = useESToast();
35
+ const router = useESRouter();
36
+ const playerRef = ref();
37
+ const menuRef = ref();
38
+ const showMenu = ref(false);
39
+
40
+ onMounted(() => {
41
+ playerRef.value?.init({ mediaList: mockMediaList });
42
+ menuRef.value?.init({ categories: mockCategories, channels: mockChannels });
43
+ });
44
+
45
+ function loadPrograms(
46
+ channelId: string,
47
+ callback: (channelId: string) => object,
48
+ ) {
49
+ callback(mockPrograms[channelId]);
50
+ }
51
+
52
+ function playMediaByIndex(index: number) {
53
+ playerRef.value?.playMediaByIndex(index);
54
+ }
55
+
56
+ function closeMenu() {
57
+ showMenu.value = false;
58
+ menuRef.value?.onBackPressed();
59
+ }
60
+
61
+ function onKeyDown(keyEvent: ESKeyEvent) {
62
+ switch (keyEvent.keyCode) {
63
+ case ESKeyCode.ES_KEYCODE_DPAD_UP:
64
+ if (!showMenu.value) {
65
+ playerRef.value.onKeyDown(keyEvent);
66
+ }
67
+ break;
68
+ case ESKeyCode.ES_KEYCODE_DPAD_DOWN:
69
+ if (!showMenu.value) {
70
+ playerRef.value.onKeyDown(keyEvent);
71
+ }
72
+ break;
73
+ case ESKeyCode.ES_KEYCODE_DPAD_LEFT:
74
+ break;
75
+ case ESKeyCode.ES_KEYCODE_DPAD_RIGHT:
76
+ if (showMenu.value) {
77
+ menuRef.value.onKeyDown(keyEvent);
78
+ } else {
79
+ toast.showToast("打开支付页");
80
+ }
81
+ break;
82
+ case ESKeyCode.ES_KEYCODE_DPAD_CENTER:
83
+ if (!showMenu.value) {
84
+ showMenu.value = true;
85
+ }
86
+ break;
87
+ }
88
+ }
89
+
90
+ function onKeyUp(keyEvent: ESKeyEvent) {
91
+ if (keyEvent.keyCode != ESKeyCode.ES_KEYCODE_BACK) {
92
+ isBack = false;
93
+ }
94
+ }
95
+
96
+ let isBack = false;
97
+ function onBackPressed() {
98
+ if (showMenu.value) {
99
+ isBack = false;
100
+ closeMenu();
101
+ } else {
102
+ if (isBack) {
103
+ router.back();
104
+ } else {
105
+ isBack = true;
106
+ toast.showToast("再按一次返回退出");
107
+ }
108
+ }
109
+ }
110
+
111
+ function onESResume() {
112
+ playerRef.value?.resume();
113
+ }
114
+
115
+ function onESDestroy() {
116
+ playerRef.value?.stop();
117
+ }
118
+
119
+ defineExpose({ onKeyDown, onKeyUp, onBackPressed, onESResume, onESDestroy });
120
+ </script>
121
+
122
+ <style scoped>
123
+ .live {
124
+ width: 1920px;
125
+ height: 1080px;
126
+ background-color: transparent;
127
+ }
128
+ </style>
@@ -0,0 +1,263 @@
1
+ export const mockMediaList = [
2
+ {
3
+ channelId: "001",
4
+ channelName: "CCTV-1高清",
5
+ isVip: true,
6
+ program: "我的阿勒泰02",
7
+ nextProgram: "边水往事08",
8
+ mediaSourceList: {
9
+ index: 0,
10
+ list: [
11
+ {
12
+ uri: "https://extcdn.hsrc.tv/channelzero/2024/02/06/004d30f9-1d06-4ee4-9d96-bb5fdb14f52f.mp4",
13
+ },
14
+ ],
15
+ },
16
+ },
17
+ {
18
+ channelId: "002",
19
+ channelName: "CCTV-2高清",
20
+ isVip: false,
21
+ program: "舌尖上的中国",
22
+ nextProgram: "大明王朝1566(28)",
23
+ mediaSourceList: {
24
+ index: 0,
25
+ list: [
26
+ {
27
+ uri: "https://extcdn.hsrc.tv/channelzero/2024/01/29/6f0a3144-7f22-4f9d-9691-cc7f2263e2fd.mp4",
28
+ },
29
+ ],
30
+ },
31
+ },
32
+ {
33
+ channelId: "003",
34
+ channelName: "CCTV-3高清",
35
+ isVip: false,
36
+ program: "在中国大地上边走边看",
37
+ nextProgram: "新闻联播",
38
+ mediaSourceList: {
39
+ index: 0,
40
+ list: [
41
+ {
42
+ uri: "https://extcdn.hsrc.tv/data_center/videos/SHORT/DEFAULT/2022/10/27/d4e29cbf-5b15-4523-b9c8-80f18fa76275.mp4",
43
+ },
44
+ ],
45
+ },
46
+ },
47
+ {
48
+ channelId: "004",
49
+ channelName: "CCTV-4高清",
50
+ isVip: false,
51
+ program: "边水往事08",
52
+ nextProgram: "大头儿子小头爸爸",
53
+ mediaSourceList: {
54
+ index: 0,
55
+ list: [
56
+ {
57
+ uri: "https://extcdn.hsrc.tv/data_center/videos/SHORT/DEFAULT/2023/09/17/22edb94d-8ffc-4736-a633-3f9e38c096e8.mp4",
58
+ },
59
+ ],
60
+ },
61
+ },
62
+ {
63
+ channelId: "005",
64
+ channelName: "CCTV-5高清",
65
+ isVip: false,
66
+ program: "龙的传人",
67
+ nextProgram: "家有喜事2022",
68
+ mediaSourceList: {
69
+ index: 0,
70
+ list: [
71
+ {
72
+ uri: "https://extcdn.hsrc.tv/channelzero/2024/02/05/a87f2fd0-579c-4d4e-9bb7-4183f6bd3604.mp4",
73
+ },
74
+ ],
75
+ },
76
+ },
77
+ ];
78
+
79
+ export const mockCategories = [
80
+ { type: 1, name: "开通服务" },
81
+ { type: 2, name: "央视频道", startIndex: 0 },
82
+ { type: 2, name: "卫视频道", startIndex: 3 },
83
+ { type: 2, name: "热门频道", startIndex: 6 },
84
+ { type: 3, name: "个人中心" },
85
+ ];
86
+
87
+ export const mockChannels = [
88
+ {
89
+ type: 1,
90
+ categoryIndex: 1,
91
+ id: "001",
92
+ name: "CCTV-1高清",
93
+ program: "我的阿勒泰02",
94
+ isVip: true,
95
+ },
96
+ {
97
+ type: 1,
98
+ categoryIndex: 1,
99
+ id: "002",
100
+ name: "CCTV-2高清",
101
+ program: "舌尖上的中国",
102
+ },
103
+ {
104
+ type: 1,
105
+ categoryIndex: 1,
106
+ id: "003",
107
+ name: "CCTV-3高清",
108
+ program: "在中国大地上边走边边边边边",
109
+ },
110
+ {
111
+ type: 1,
112
+ categoryIndex: 2,
113
+ id: "004",
114
+ name: "CCTV-4高清",
115
+ program: "边水往事08",
116
+ isVip: true,
117
+ },
118
+ {
119
+ type: 1,
120
+ categoryIndex: 2,
121
+ id: "005",
122
+ name: "CCTV-5高清",
123
+ program: "边水往事09",
124
+ },
125
+ {
126
+ type: 1,
127
+ categoryIndex: 2,
128
+ id: "006",
129
+ name: "CCTV-6高清",
130
+ program: "龙的传人",
131
+ isVip: true,
132
+ },
133
+ {
134
+ type: 1,
135
+ categoryIndex: 3,
136
+ id: "007",
137
+ name: "CCTV-7高清",
138
+ program: "新闻联播",
139
+ },
140
+ {
141
+ type: 1,
142
+ categoryIndex: 3,
143
+ id: "008",
144
+ name: "CCTV-8高清",
145
+ program: "国足0-7大败日本",
146
+ },
147
+ {
148
+ type: 1,
149
+ categoryIndex: 3,
150
+ id: "009",
151
+ name: "CCTV-9高清",
152
+ program: "大头儿子小头爸爸",
153
+ },
154
+ {
155
+ type: 1,
156
+ categoryIndex: 3,
157
+ id: "010",
158
+ name: "CCTV-10高清",
159
+ program: "家有喜事2022",
160
+ },
161
+ ];
162
+
163
+ export const mockPrograms = {
164
+ "001": [
165
+ {
166
+ type: 1,
167
+ channelId: "001",
168
+ program: "我的阿勒泰02",
169
+ time: "15:00-17:45",
170
+ tips: "正在播放",
171
+ isVip: true,
172
+ isPlaying: true,
173
+ },
174
+ {
175
+ type: 1,
176
+ channelId: "001",
177
+ program: "我的阿勒泰03",
178
+ time: "17:45-19:00",
179
+ tips: "未开始",
180
+ },
181
+ {
182
+ type: 1,
183
+ channelId: "001",
184
+ program: "我的阿勒泰04",
185
+ time: "19:00-21:45",
186
+ tips: "未开始",
187
+ },
188
+ {
189
+ type: 1,
190
+ channelId: "001",
191
+ program: "我的阿勒泰05",
192
+ time: "21:45-23:00",
193
+ tips: "未开始",
194
+ },
195
+ {
196
+ type: 1,
197
+ channelId: "001",
198
+ program: "我的阿勒泰06",
199
+ time: "23:00-01:45",
200
+ tips: "未开始",
201
+ },
202
+ ],
203
+ "003": [
204
+ {
205
+ type: 1,
206
+ channelId: "003",
207
+ program: "大头儿子小头爸爸10",
208
+ time: "15:00-17:45",
209
+ tips: "正在播放",
210
+ isVip: false,
211
+ isPlaying: true,
212
+ },
213
+ {
214
+ type: 1,
215
+ channelId: "003",
216
+ program: "大头儿子小头爸爸11",
217
+ time: "17:45-19:00",
218
+ tips: "未开始",
219
+ },
220
+ {
221
+ type: 1,
222
+ channelId: "003",
223
+ program: "大头儿子小头爸爸12",
224
+ time: "19:00-21:45",
225
+ tips: "未开始",
226
+ },
227
+ {
228
+ type: 1,
229
+ channelId: "003",
230
+ program: "大头儿子小头爸爸13",
231
+ time: "21:45-23:00",
232
+ tips: "未开始",
233
+ },
234
+ {
235
+ type: 1,
236
+ channelId: "003",
237
+ program: "大头儿子小头爸爸14",
238
+ time: "23:00-01:45",
239
+ tips: "未开始",
240
+ },
241
+ {
242
+ type: 1,
243
+ channelId: "003",
244
+ program: "大头儿子小头爸爸15",
245
+ time: "23:00-01:45",
246
+ tips: "未开始",
247
+ },
248
+ {
249
+ type: 1,
250
+ channelId: "003",
251
+ program: "大头儿子小头爸爸16",
252
+ time: "23:00-01:45",
253
+ tips: "未开始",
254
+ },
255
+ {
256
+ type: 1,
257
+ channelId: "003",
258
+ program: "大头儿子小头爸爸17",
259
+ time: "23:00-01:45",
260
+ tips: "未开始",
261
+ },
262
+ ],
263
+ };
@@ -0,0 +1,42 @@
1
+ export interface RouteParams {
2
+ url: string;
3
+ lives: string;
4
+ }
5
+
6
+ export type Lives = Live[];
7
+
8
+ export interface Live {
9
+ name: string;
10
+ type: string;
11
+ pass: boolean;
12
+ url: string;
13
+ epg: string;
14
+ logo: string;
15
+ }
16
+
17
+ export interface Category {
18
+ name: string;
19
+ data: Channel[];
20
+ }
21
+
22
+ export interface Channel {
23
+ // 频道ID
24
+ id: number;
25
+ // 频道名称
26
+ name: string;
27
+ // 频道播放地址
28
+ addrs: string[];
29
+ // 频道节目列表
30
+ programs?: Program[];
31
+ // 分类索引
32
+ categoryIndex?: number;
33
+ // 分类名称
34
+ category?: string;
35
+ }
36
+
37
+ export interface Program {
38
+ title?: string;
39
+ start?: string;
40
+ end?: string;
41
+ desc?: string;
42
+ }
@@ -0,0 +1,116 @@
1
+ <template>
2
+ <div class="login-root-css">
3
+ <!--背景图-->
4
+ <img class="login-img-css" :src="background" />
5
+ <!--二维码-->
6
+ <qt-view class="login-qr-code-view-css">
7
+ <!--文字二维码 -->
8
+ <qt-qr-code
9
+ class="login-qr-code-css"
10
+ v-if="isNetQrCode"
11
+ :content="qrCodeUrl"
12
+ :optimize="true"
13
+ />
14
+ <!--图片二维码-->
15
+ <img class="login-qr-code-css" v-else :src="qrCodeUrl" />
16
+ <!--扫码提示-->
17
+ <qt-text
18
+ class="login-qr-code-tip-css"
19
+ :gradientBackground="{
20
+ colors: ['#F4F4F4', '#F4F4F4'],
21
+ cornerRadii4: [0, 0, 20, 20],
22
+ orientation: 0,
23
+ }"
24
+ :focusable="false"
25
+ gravity="center"
26
+ :font-size="36"
27
+ text="微信扫码登录"
28
+ />
29
+ </qt-view>
30
+ <!-- 协议-->
31
+ <qt-view
32
+ class="login-agreement-root-css"
33
+ :focusable="true"
34
+ :requestFocus="true"
35
+ @click="onAgreementClick"
36
+ >
37
+ <qt-text
38
+ class="login-agreement-text-css"
39
+ :focusable="false"
40
+ gravity="center"
41
+ :font-size="30"
42
+ text="登录即代表您同意《用户协议》和《隐私协议》"
43
+ />
44
+ <qt-view class="login-agreement-bottom-line-css" />
45
+ </qt-view>
46
+ </div>
47
+ </template>
48
+
49
+ <script lang="ts" setup name="index">
50
+ import { useESRouter } from "@extscreen/es3-router";
51
+ import { ref, watch } from "vue";
52
+ import { UserChangeListener, UserInfo } from "../../api/user/impl-user";
53
+ import userManager from "../../api/user/user-manager";
54
+
55
+ const router = useESRouter();
56
+ //全局背景图
57
+ let background = ref("");
58
+ //是否网络地址
59
+ let isNetQrCode = ref(false);
60
+ //二维码地址
61
+ let qrCodeUrl = ref("");
62
+ //获取scene
63
+ let scene = ref("");
64
+ //用户信息事件监听
65
+ const listener: UserChangeListener = {
66
+ onUserChanged(user: UserInfo | null) {
67
+ if (user) {
68
+ //todo 模拟扫码登录成功后关闭操作
69
+ setTimeout(() => {
70
+ router.back();
71
+ }, 5000);
72
+ }
73
+ },
74
+ };
75
+ const onESCreate = () => {
76
+ //添加监听
77
+ userManager.addUserChangeListener(listener);
78
+ //获取背景
79
+ userManager.getLoginBackground().then((res) => {
80
+ background.value = res;
81
+ });
82
+ //获取登录二维码
83
+ userManager.getLoginQrCode().then((res) => {
84
+ const codeUrl = res.qrCodeUrl;
85
+ if (res.scene != null) {
86
+ scene.value = res.scene;
87
+ }
88
+ isNetQrCode.value = codeUrl.substring(0, 4) === "http";
89
+ if (!isNetQrCode.value) {
90
+ qrCodeUrl.value = `data:image/png;base64,${res.qrCodeUrl}`;
91
+ } else {
92
+ qrCodeUrl.value = res.qrCodeUrl;
93
+ }
94
+ });
95
+ };
96
+ watch([() => scene.value], async (newValue) => {
97
+ if (newValue[0]) {
98
+ //todo 此处可以注册接收推送的服务接收用户数据或者轮询获取用户数据的接口
99
+ const user = await userManager.getUserInfoByScene(newValue[0]);
100
+ if (user) {
101
+ //存储用户信息
102
+ userManager.updateUserInfo(user);
103
+ }
104
+ }
105
+ });
106
+ const onESDestroy = () => {
107
+ //退出界面 移除监听
108
+ userManager.removeUserChangeListener(listener);
109
+ };
110
+
111
+ function onAgreementClick() {}
112
+
113
+ defineExpose({ onESCreate, onESDestroy });
114
+ </script>
115
+
116
+ <style lang="scss" src="./scss/login.scss"></style>
@@ -0,0 +1,61 @@
1
+ $home-width:1920px;
2
+ $home-height:1080px;
3
+
4
+ .login-root-css{
5
+ width: $home-width;
6
+ height: $home-height;
7
+ background-color: $theme-bg-color;
8
+ }
9
+
10
+ .login-img-css{
11
+ position: absolute;
12
+ width: $home-width;
13
+ height: $home-height;
14
+ background-color: transparent;
15
+ }
16
+
17
+ .login-qr-code-view-css{
18
+ position: absolute;
19
+ width: 540px;
20
+ height: 638px;
21
+ top: 218px;
22
+ right: 140px;
23
+ border-radius: 9px;
24
+ background-color: white;
25
+ }
26
+
27
+ .login-qr-code-tip-css{
28
+ width: 540px;
29
+ height: 100px;
30
+ position: absolute;
31
+ color: black;
32
+ bottom: 0;
33
+ background-color:transparent;
34
+ }
35
+
36
+ .login-qr-code-css{
37
+ width: 480px;
38
+ height: 480px;
39
+ margin-top: 29px;
40
+ margin-left: 30px;
41
+ }
42
+
43
+ .login-agreement-root-css{
44
+ width: 1920px;
45
+ height: 39px;
46
+ position: absolute;
47
+ bottom: 60px;
48
+ background-color: transparent;
49
+ align-items: center;
50
+ }
51
+ .login-agreement-text-css{
52
+ width: 1920px;
53
+ height: 36px;
54
+ color: rgba(255, 255, 255, .5);
55
+ }
56
+ .login-agreement-bottom-line-css{
57
+ height: 1px;
58
+ width: 640px;
59
+ margin-top: 2px;
60
+ background-color: rgba(255, 255, 255, .5);
61
+ }