@shijiu/jsview-vue 0.0.1-beta.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 (252) hide show
  1. package/docs/IMPORT_CHANGE_LOG.txt +3 -0
  2. package/docs/git_commit.md +15 -0
  3. package/docs/test_version_up.txt +1 -0
  4. package/dom/bin/jsview-dom-1.0.313.tgz +0 -0
  5. package/dom/browser-root-style.css +21 -0
  6. package/dom/jsv-browser-debug-dom.js +8 -0
  7. package/dom/jsv-dom.js +6 -0
  8. package/dom/jsv-forge-define.js +6 -0
  9. package/dom/target_core_revision.js +14 -0
  10. package/load/header_script_loader.js +134 -0
  11. package/load/jsview-main.js +42 -0
  12. package/load/jsview.config.default.js +37 -0
  13. package/load/jsview.default.config.js +37 -0
  14. package/load/loader.js +172 -0
  15. package/load/loader_webkit.js +40 -0
  16. package/package.json +27 -0
  17. package/patch/node_modules/@babel/preset-env/lib/available-plugins.js +219 -0
  18. package/patch/node_modules/@vue/cli-plugin-typescript/index.js +100 -0
  19. package/patch/node_modules/@vue/cli-service/lib/commands/serve.js +395 -0
  20. package/patch/node_modules/@vue/cli-service/lib/config/app.js +272 -0
  21. package/patch/node_modules/@vue/cli-service/lib/config/assets.js +70 -0
  22. package/patch/node_modules/@vue/cli-service/lib/config/base.js +212 -0
  23. package/patch/node_modules/@vue/compiler-sfc/dist/compiler-sfc.cjs.js +2566 -0
  24. package/patch/node_modules/@vue/compiler-sfc/dist/jsview-css-to-js.js +274 -0
  25. package/patch/node_modules/@vue/runtime-dom/dist/runtime-dom.esm-bundler.js +1596 -0
  26. package/patch/node_modules/postcss-js/objectifier.js +90 -0
  27. package/patch/node_modules/vue-loader/dist/resolveScript.js +70 -0
  28. package/patch/package-lock.json +30051 -0
  29. package/samples/AdvanceMetroWidget/App.vue +123 -0
  30. package/samples/AdvanceMetroWidget/Frame.vue +101 -0
  31. package/samples/AdvanceMetroWidget/Item.vue +58 -0
  32. package/samples/AdvanceMetroWidget/data.js +137 -0
  33. package/samples/AnimPicture/App.vue +224 -0
  34. package/samples/AnimPicture/assets/animated_webp.webp +0 -0
  35. package/samples/AnimPicture/assets/ball_3.webp +0 -0
  36. package/samples/AnimPicture/assets/girl_run.gif +0 -0
  37. package/samples/AnimPicture/assets/quan.webp +0 -0
  38. package/samples/Basic/App.vue +129 -0
  39. package/samples/Basic/assets/border.png +0 -0
  40. package/samples/Basic/assets/border2.png +0 -0
  41. package/samples/Basic/assets/icon.png +0 -0
  42. package/samples/Basic/assets/test.jpg +0 -0
  43. package/samples/Basic/components/ContentBlock.vue +36 -0
  44. package/samples/Basic/components/FontStyle.css +10 -0
  45. package/samples/Basic/components/TitleBar.vue +29 -0
  46. package/samples/Basic/components/anim/AnimGroup.vue +68 -0
  47. package/samples/Basic/components/anim/AnimKeyframeBasic.vue +102 -0
  48. package/samples/Basic/components/anim/AnimKeyframeComposite.vue +53 -0
  49. package/samples/Basic/components/anim/AnimTransition.vue +116 -0
  50. package/samples/Basic/components/div/DivBackground.vue +15 -0
  51. package/samples/Basic/components/div/DivClip.vue +81 -0
  52. package/samples/Basic/components/div/DivCssScoped.vue +27 -0
  53. package/samples/Basic/components/div/DivCssVar.vue +50 -0
  54. package/samples/Basic/components/div/DivGroup1.vue +33 -0
  55. package/samples/Basic/components/div/DivGroup2.vue +41 -0
  56. package/samples/Basic/components/div/DivLayout.vue +12 -0
  57. package/samples/Basic/components/div/DivRadius.vue +47 -0
  58. package/samples/Basic/components/text/TextAlign.vue +48 -0
  59. package/samples/Basic/components/text/TextFontStyle.vue +58 -0
  60. package/samples/Basic/components/text/TextGroup.vue +32 -0
  61. package/samples/Basic/components/text/TextOverflow.vue +78 -0
  62. package/samples/BasicFocusControl/App.vue +125 -0
  63. package/samples/BasicFocusControl/components/BaseBlock.vue +51 -0
  64. package/samples/BasicFocusControl/components/MainArea.vue +98 -0
  65. package/samples/BasicFocusControl/components/MainAreaLeftBlock.vue +21 -0
  66. package/samples/BasicFocusControl/components/MainAreaRightBlock.vue +30 -0
  67. package/samples/BasicFocusControl/components/SideBar.vue +73 -0
  68. package/samples/BasicFocusControl/components/SideBarBlock.vue +30 -0
  69. package/samples/ClassNameDemo/App.vue +119 -0
  70. package/samples/ClassNameDemo/assets/bg.jpg +0 -0
  71. package/samples/ClassNameDemo/assets/coupon_content.png +0 -0
  72. package/samples/ClassNameDemo/assets/coupon_left.png +0 -0
  73. package/samples/ClassNameDemo/assets/coupon_mid.png +0 -0
  74. package/samples/ClassNameDemo/assets/coupon_right.png +0 -0
  75. package/samples/ClassNameDemo/assets/focus_border.png +0 -0
  76. package/samples/ClassNameDemo/assets/holder_logo.png +0 -0
  77. package/samples/ClassNameDemo/assets/jrbm.png +0 -0
  78. package/samples/ClassNameDemo/assets/line_left.png +0 -0
  79. package/samples/ClassNameDemo/assets/line_mid.png +0 -0
  80. package/samples/ClassNameDemo/assets/line_right.png +0 -0
  81. package/samples/ClassNameDemo/assets/loading.png +0 -0
  82. package/samples/ClassNameDemo/assets/logo.png +0 -0
  83. package/samples/ClassNameDemo/assets/mcjx.png +0 -0
  84. package/samples/ClassNameDemo/assets/tao.png +0 -0
  85. package/samples/ClassNameDemo/assets/tmall.png +0 -0
  86. package/samples/ClassNameDemo/components/ContentItem.vue +253 -0
  87. package/samples/ClassNameDemo/components/LoadingView.vue +43 -0
  88. package/samples/ClassNameDemo/components/TitleView.vue +24 -0
  89. package/samples/ClassNameDemo/data.js +24 -0
  90. package/samples/ColorSpace/App.vue +135 -0
  91. package/samples/ColorSpace/bmpDemo.bmp +0 -0
  92. package/samples/ColorSpace/jpegDemo.jpeg +0 -0
  93. package/samples/ColorSpace/pngDemo.png +0 -0
  94. package/samples/ColorSpace/pngNoAlphaDemo.png +0 -0
  95. package/samples/DemoHomepage/App.vue +31 -0
  96. package/samples/DemoHomepage/components/BodyFrame.vue +82 -0
  97. package/samples/DemoHomepage/components/Dialog.vue +94 -0
  98. package/samples/DemoHomepage/components/Item.vue +77 -0
  99. package/samples/DemoHomepage/components/TabFrame.vue +86 -0
  100. package/samples/DemoHomepage/router.js +132 -0
  101. package/samples/DemoHomepage/views/Homepage.vue +186 -0
  102. package/samples/FlipCard/App.vue +80 -0
  103. package/samples/FlipCard/FlipCard.vue +124 -0
  104. package/samples/FlipCard/assets/blue_egg.png +0 -0
  105. package/samples/FlipCard/assets/red_egg.png +0 -0
  106. package/samples/FlipCard/data.js +13 -0
  107. package/samples/FlowMultiWidget/App.vue +91 -0
  108. package/samples/FlowMultiWidget/assets/nine_patch_focus.png +0 -0
  109. package/samples/FlowMultiWidget/components/Block.vue +107 -0
  110. package/samples/FlowMultiWidget/components/FlowPage.vue +60 -0
  111. package/samples/FlowMultiWidget/components/Item.vue +103 -0
  112. package/samples/FlowMultiWidget/components/MenuItem.vue +72 -0
  113. package/samples/FlowMultiWidget/components/MyMenu.vue +90 -0
  114. package/samples/FlowMultiWidget/data.js +446 -0
  115. package/samples/HashHistory/App.vue +124 -0
  116. package/samples/HashHistory/components/HorizontalButtonList.vue +114 -0
  117. package/samples/HashHistory/components/Item.vue +74 -0
  118. package/samples/HashHistory/router.js +30 -0
  119. package/samples/HashHistory/views/BasePage.vue +19 -0
  120. package/samples/HashHistory/views/MainPage.vue +68 -0
  121. package/samples/HashHistory/views/SubPage.vue +79 -0
  122. package/samples/HashHistory/views/SubPageFirst.vue +10 -0
  123. package/samples/HashHistory/views/SubPageSecond.vue +10 -0
  124. package/samples/LongImage/App.vue +96 -0
  125. package/samples/LongImage/Button.vue +153 -0
  126. package/samples/LongImage/LongImageScroll.vue +127 -0
  127. package/samples/LongImage/Scroll.vue +16 -0
  128. package/samples/LongImage/assets/1280x7200.jpg +0 -0
  129. package/samples/LongText/App.vue +111 -0
  130. package/samples/LongText/Button.vue +153 -0
  131. package/samples/LongText/LongTextScroll.vue +225 -0
  132. package/samples/LongText/Scroll.vue +16 -0
  133. package/samples/Preload/App.vue +146 -0
  134. package/samples/Preload/data.js +23 -0
  135. package/samples/Preload/images/awesomeface.png +0 -0
  136. package/samples/Preload/images/cat.jpg +0 -0
  137. package/samples/Preload/images/rank.png +0 -0
  138. package/samples/Preload/images/rank_focus.png +0 -0
  139. package/samples/Preload/images/rule.png +0 -0
  140. package/samples/Preload/images/rule_focus.png +0 -0
  141. package/samples/Preload/images/start.png +0 -0
  142. package/samples/Preload/images/start_focus.png +0 -0
  143. package/samples/Preload/preloadItem.vue +22 -0
  144. package/samples/QrcodeDemo/App.vue +73 -0
  145. package/samples/SimpleWidgetDemo/App.vue +204 -0
  146. package/samples/SimpleWidgetDemo/Item.vue +83 -0
  147. package/samples/SimpleWidgetDemo/assets/bg.jpg +0 -0
  148. package/samples/SimpleWidgetDemo/assets/coupon_content.png +0 -0
  149. package/samples/SimpleWidgetDemo/assets/coupon_left.png +0 -0
  150. package/samples/SimpleWidgetDemo/assets/coupon_mid.png +0 -0
  151. package/samples/SimpleWidgetDemo/assets/coupon_right.png +0 -0
  152. package/samples/SimpleWidgetDemo/assets/focus_border.png +0 -0
  153. package/samples/SimpleWidgetDemo/assets/holder_logo.png +0 -0
  154. package/samples/SimpleWidgetDemo/assets/jrbm.png +0 -0
  155. package/samples/SimpleWidgetDemo/assets/line_left.png +0 -0
  156. package/samples/SimpleWidgetDemo/assets/line_mid.png +0 -0
  157. package/samples/SimpleWidgetDemo/assets/line_right.png +0 -0
  158. package/samples/SimpleWidgetDemo/assets/loading.png +0 -0
  159. package/samples/SimpleWidgetDemo/assets/logo.png +0 -0
  160. package/samples/SimpleWidgetDemo/assets/mcjx.png +0 -0
  161. package/samples/SimpleWidgetDemo/assets/tao.png +0 -0
  162. package/samples/SimpleWidgetDemo/assets/tmall.png +0 -0
  163. package/samples/SimpleWidgetDemo/border.png +0 -0
  164. package/samples/SimpleWidgetDemo/components/ContentItem.vue +412 -0
  165. package/samples/SimpleWidgetDemo/components/MyTab.vue +117 -0
  166. package/samples/SimpleWidgetDemo/data.js +110 -0
  167. package/samples/SprayView/App.vue +270 -0
  168. package/samples/SprayView/assets/snow.png +0 -0
  169. package/samples/SpriteImage/App.vue +174 -0
  170. package/samples/SpriteImage/images/cat_run.png +0 -0
  171. package/samples/SpriteImage/images/egg_break.json +116 -0
  172. package/samples/SpriteImage/images/egg_break.png +0 -0
  173. package/samples/SpriteImage/images/sprite.png +0 -0
  174. package/samples/TextBox/App.vue +179 -0
  175. package/samples/TextBox/RenderCenter.vue +109 -0
  176. package/samples/TextBox/RenderLeft.vue +109 -0
  177. package/samples/TextBox/RenderOneLine.vue +120 -0
  178. package/samples/TextBox/RenderRight.vue +107 -0
  179. package/samples/TextShadowDemo/App.vue +98 -0
  180. package/samples/TextureSize/App.vue +142 -0
  181. package/samples/TextureSize/bmpDemo.bmp +0 -0
  182. package/samples/TextureSize/jpegDemo.jpeg +0 -0
  183. package/samples/TextureSize/jpgDemo.jpg +0 -0
  184. package/samples/TextureSize/pngDemo.png +0 -0
  185. package/samples/TextureSize/pngNoAlphaDemo.png +0 -0
  186. package/samples/ThrowMoveDemo/AccelerateDemo.vue +118 -0
  187. package/samples/ThrowMoveDemo/App.vue +114 -0
  188. package/samples/ThrowMoveDemo/LRParabolicDemo.vue +116 -0
  189. package/samples/ThrowMoveDemo/TargetDemo.vue +117 -0
  190. package/samples/ThrowMoveDemo/UDParabolicDemo.vue +122 -0
  191. package/samples/TransitPage/App.vue +41 -0
  192. package/samples/VideoDemo/App.vue +137 -0
  193. package/samples/VideoDemo/components/Button.vue +69 -0
  194. package/samples/VideoDemo/components/Controllor.vue +195 -0
  195. package/samples/VideoDemo/components/VideoFrame.vue +152 -0
  196. package/scripts/git-commit-empty.js +21 -0
  197. package/scripts/install-local-packages.js +121 -0
  198. package/scripts/make-js.sh +181 -0
  199. package/scripts/post-build.js +132 -0
  200. package/scripts/post-install.js +127 -0
  201. package/scripts/pre-pack.js +2 -0
  202. package/scripts/run-android.js +64 -0
  203. package/utils/JsViewEngineWidget/bin/shijiu-jsview-vue-widget-1.0.1.tgz +0 -0
  204. package/utils/JsViewEngineWidget/index.d.ts +32 -0
  205. package/utils/JsViewEngineWidget/index.js +6 -0
  206. package/utils/JsViewVueTools/DebugContentShellJBridge.js +16 -0
  207. package/utils/JsViewVueTools/DebugTool.js +21 -0
  208. package/utils/JsViewVueTools/DefaultKeyMap.js +12 -0
  209. package/utils/JsViewVueTools/JsvDynamicCssStyle.js +73 -0
  210. package/utils/JsViewVueTools/JsvDynamicKeyFrames.js +128 -0
  211. package/utils/JsViewVueTools/JsvHashHistory.js +112 -0
  212. package/utils/JsViewVueTools/JsvRuntimeBridge.js +417 -0
  213. package/utils/JsViewVueTools/JsvStyleClass.js +290 -0
  214. package/utils/JsViewVueWidget/BrowserDebugWidget/BrowserPreload.vue +80 -0
  215. package/utils/JsViewVueWidget/BrowserDebugWidget/BrowserQrcode.vue +148 -0
  216. package/utils/JsViewVueWidget/BrowserDebugWidget/BrowserSpray.vue +55 -0
  217. package/utils/JsViewVueWidget/BrowserDebugWidget/JsvApic/ApicDataBase.js +29 -0
  218. package/utils/JsViewVueWidget/BrowserDebugWidget/JsvApic/BrowserApic.vue +124 -0
  219. package/utils/JsViewVueWidget/BrowserDebugWidget/JsvApic/GifData.js +83 -0
  220. package/utils/JsViewVueWidget/BrowserDebugWidget/JsvApic/LoopToolBase.js +25 -0
  221. package/utils/JsViewVueWidget/BrowserDebugWidget/JsvApic/NormalLoopTool.js +61 -0
  222. package/utils/JsViewVueWidget/BrowserDebugWidget/JsvApic/PartLoopTool.js +119 -0
  223. package/utils/JsViewVueWidget/BrowserDebugWidget/JsvApic/Viewer.js +106 -0
  224. package/utils/JsViewVueWidget/BrowserDebugWidget/JsvApic/WebpData.js +141 -0
  225. package/utils/JsViewVueWidget/BrowserDebugWidget/WidgetLoader.js +20 -0
  226. package/utils/JsViewVueWidget/BrowserDebugWidget/WidgetWrapper.js +11 -0
  227. package/utils/JsViewVueWidget/JsvActorMove/ActorControlBase.js +204 -0
  228. package/utils/JsViewVueWidget/JsvActorMove/JsvActorMove.vue +64 -0
  229. package/utils/JsViewVueWidget/JsvActorMove/JsvActorMoveControl.js +427 -0
  230. package/utils/JsViewVueWidget/JsvActorMove/index.js +12 -0
  231. package/utils/JsViewVueWidget/JsvApic/JsvApic.vue +179 -0
  232. package/utils/JsViewVueWidget/JsvApic/index.js +17 -0
  233. package/utils/JsViewVueWidget/JsvMarquee.vue +197 -0
  234. package/utils/JsViewVueWidget/JsvNativeSharedDiv.vue +92 -0
  235. package/utils/JsViewVueWidget/JsvNinePatch.vue +76 -0
  236. package/utils/JsViewVueWidget/JsvPreload/JsvPreload.vue +351 -0
  237. package/utils/JsViewVueWidget/JsvPreload/index.js +21 -0
  238. package/utils/JsViewVueWidget/JsvQrcode/JsvQrcode.vue +140 -0
  239. package/utils/JsViewVueWidget/JsvQrcode/index.js +18 -0
  240. package/utils/JsViewVueWidget/JsvSpray/JsvSpray.vue +140 -0
  241. package/utils/JsViewVueWidget/JsvSpray/index.js +15 -0
  242. package/utils/JsViewVueWidget/JsvSpriteAnim/JsvSpriteAnim.vue +448 -0
  243. package/utils/JsViewVueWidget/JsvSpriteAnim/SpriteController.js +57 -0
  244. package/utils/JsViewVueWidget/JsvSpriteAnim/index.js +6 -0
  245. package/utils/JsViewVueWidget/JsvSwiper/Indicator.vue +35 -0
  246. package/utils/JsViewVueWidget/JsvSwiper/JsvSwiper.vue +495 -0
  247. package/utils/JsViewVueWidget/JsvSwiper/index.js +10 -0
  248. package/utils/JsViewVueWidget/JsvSwiper3D/Indicator.vue +35 -0
  249. package/utils/JsViewVueWidget/JsvSwiper3D/JsvSwiper.vue +404 -0
  250. package/utils/JsViewVueWidget/JsvSwiper3D/index.js +10 -0
  251. package/utils/JsViewVueWidget/JsvTextBox.vue +111 -0
  252. package/utils/JsViewVueWidget/JsvVideo.vue +36 -0
@@ -0,0 +1,103 @@
1
+ <!--
2
+ * @Author: ChenChanghua
3
+ * @Date: 2021-09-27 13:49:54
4
+ * @LastEditors: ChenChanghua
5
+ * @LastEditTime: 2021-10-15 10:53:13
6
+ * @Description: file content
7
+ -->
8
+ <script>
9
+ import borderImg from "../assets/nine_patch_focus.png";
10
+
11
+ export default {
12
+ props: {
13
+ data: Object,
14
+ query: Object,
15
+ onEdge: Function,
16
+ onAction: Object,
17
+ },
18
+ computed: {
19
+ imgClass() {
20
+ return this.focused ? "focus" : "blur";
21
+ },
22
+ },
23
+ setup(props) {
24
+ let borderStyle = {
25
+ borderImage: `url(${borderImg}) 40 fill`,
26
+ borderImageOutset: "28px 28px 28px 28px",
27
+ borderImageWidth: "40px",
28
+ width: 89,
29
+ height: 121,
30
+ };
31
+ let imageStyle = {
32
+ backgroundImage: props.data.content.url,
33
+ width: 89,
34
+ height: 121,
35
+ borderRadius: "8px 8px 8px 8px",
36
+ };
37
+ return {
38
+ borderImg,
39
+ borderStyle,
40
+ imageStyle,
41
+ };
42
+ },
43
+ data() {
44
+ return {
45
+ focused: false,
46
+ };
47
+ },
48
+ methods: {
49
+ onFocus() {
50
+ this.focused = true;
51
+ },
52
+ onBlur() {
53
+ this.focused = false;
54
+ },
55
+ onClick() {},
56
+ },
57
+ created() {
58
+ this.onAction.register("onFocus", this.onFocus);
59
+ this.onAction.register("onBlur", this.onBlur);
60
+ this.onAction.register("onClick", this.onClick);
61
+ },
62
+ };
63
+ </script>
64
+
65
+ <template>
66
+ <div :class="imgClass">
67
+ <div :style="imageStyle" />
68
+ <div v-if="focused" :style="borderStyle" />
69
+ </div>
70
+ <div class="text">
71
+ {{ this.data.content.title }}
72
+ </div>
73
+ </template>
74
+
75
+ <style scoped>
76
+ .focus {
77
+ width: 89px;
78
+ height: 121px;
79
+ transform: scale3d(1.05, 1.05, 1);
80
+ border-radius: 8px 8px 8px 8px;
81
+ transition: transform 0.25s linear;
82
+ }
83
+
84
+ .blur {
85
+ width: 89px;
86
+ height: 121px;
87
+ transform: scale3d(1, 1, 1);
88
+ border-radius: 8px 8px 8px 8px;
89
+ transition: transform 0.25s linear;
90
+ }
91
+
92
+ .text {
93
+ top: 121px;
94
+ width: 89px;
95
+ height: 25px;
96
+ color: #ffffff;
97
+ font-size: 12px;
98
+ line-height: 25px;
99
+ overflow: hidden;
100
+ text-overflow: ellipsis;
101
+ white-space: nowrap;
102
+ }
103
+ </style>
@@ -0,0 +1,72 @@
1
+ <!--
2
+ * @Author: ChenChanghua
3
+ * @Date: 2021-09-28 16:02:50
4
+ * @LastEditors: ChenChanghua
5
+ * @LastEditTime: 2021-09-28 16:22:24
6
+ * @Description: file content
7
+ -->
8
+ <!--
9
+ * @Author: ChenChanghua
10
+ * @Date: 2021-09-27 13:49:54
11
+ * @LastEditors: ChenChanghua
12
+ * @LastEditTime: 2021-09-28 15:42:49
13
+ * @Description: file content
14
+ -->
15
+ <script>
16
+ export default {
17
+ props: {
18
+ data: Object,
19
+ query: Object,
20
+ onEdge: Function,
21
+ onAction: Object,
22
+ },
23
+ computed: {
24
+ bgStyle() {
25
+ return {
26
+ width: 280,
27
+ height: 40,
28
+ backgroundColor: this.isFocus ? "#06a7ff" : "#575d8d",
29
+ };
30
+ },
31
+ },
32
+ data() {
33
+ return {
34
+ isFocus: false,
35
+ };
36
+ },
37
+ methods: {
38
+ onFocus() {
39
+ this.isFocus = true;
40
+ },
41
+ onBlur() {
42
+ this.isFocus = false;
43
+ },
44
+ onClick() {},
45
+ },
46
+ created() {
47
+ this.onAction.register("onFocus", this.onFocus);
48
+ this.onAction.register("onBlur", this.onBlur);
49
+ this.onAction.register("onClick", this.onClick);
50
+ },
51
+ };
52
+ </script>
53
+
54
+ <template>
55
+ <div :style="bgStyle">
56
+ <div class="text">
57
+ {{ data.title }}
58
+ </div>
59
+ </div>
60
+ </template>
61
+
62
+ <style scoped>
63
+ .text {
64
+ width: 280px;
65
+ height: 40px;
66
+ color: #ececec;
67
+ font-size: 12px;
68
+ line-height: 40px;
69
+ white-space: nowrap;
70
+ text-align: left;
71
+ }
72
+ </style>
@@ -0,0 +1,90 @@
1
+ <!--
2
+ * @Author: ChenChanghua
3
+ * @Date: 2021-09-27 13:49:54
4
+ * @LastEditors: ChenChanghua
5
+ * @LastEditTime: 2021-10-25 09:56:36
6
+ * @Description: file content
7
+ -->
8
+ <script>
9
+ import {
10
+ VERTICAL,
11
+ SimpleWidget,
12
+ } from "jsview/utils/JsViewEngineWidget";
13
+ import MenuItem from "./MenuItem.vue";
14
+
15
+ export default {
16
+ components: {
17
+ SimpleWidget,
18
+ MenuItem,
19
+ },
20
+ props: {
21
+ data: Array,
22
+ name: String,
23
+ },
24
+ setup() {
25
+ let measures = () => {
26
+ return {
27
+ width: 280,
28
+ height: 50,
29
+ focusable: true,
30
+ hasSub: false,
31
+ };
32
+ };
33
+ return {
34
+ direction: VERTICAL,
35
+ measures,
36
+ };
37
+ },
38
+ mounted() {
39
+ this.$refs.focusNode.findBlockByName(this.name).requestFocus();
40
+ },
41
+ };
42
+ </script>
43
+
44
+ <template>
45
+ <div
46
+ :style="{
47
+ left: (1280 - 300) / 2,
48
+ top: (720 - 255) / 2,
49
+ width: 300,
50
+ height: 255,
51
+ backgroundColor: '#000000',
52
+ }"
53
+ >
54
+ <div class="title">菜单</div>
55
+ <div :style="{ left: 10, top: 45 }">
56
+ <jsv-focus-block ref="focusNode">
57
+ <simple-widget
58
+ :name="name"
59
+ :width="280"
60
+ :height="200"
61
+ :direction="direction"
62
+ :data="data"
63
+ :measures="measures"
64
+ >
65
+ <template #renderItem="{ data, query, onEdge, onAction }">
66
+ <menu-item
67
+ :data="data"
68
+ :query="query"
69
+ :onEdge="onEdge"
70
+ :onAction="onAction"
71
+ />
72
+ </template>
73
+ </simple-widget>
74
+ </jsv-focus-block>
75
+ </div>
76
+ </div>
77
+ </template>
78
+
79
+ <style scoped>
80
+ .title {
81
+ top: 10px;
82
+ left: 40px;
83
+ width: 200px;
84
+ height: 25px;
85
+ color: #ffffff;
86
+ font-size: 22px;
87
+ white-space: nowrap;
88
+ text-align: center;
89
+ }
90
+ </style>
@@ -0,0 +1,446 @@
1
+ /*
2
+ * @Author: ChenChanghua
3
+ * @Date: 2021-09-27 14:33:12
4
+ * @LastEditors: ChenChanghua
5
+ * @LastEditTime: 2021-09-28 16:27:04
6
+ * @Description: file content
7
+ */
8
+ const menuData = [
9
+ {
10
+ focusable: true,
11
+ hasSub: false,
12
+ id: 0,
13
+ title: "电视剧",
14
+ },
15
+ {
16
+ focusable: true,
17
+ hasSub: false,
18
+ id: 1,
19
+ title: "影视",
20
+ },
21
+ {
22
+ focusable: true,
23
+ hasSub: false,
24
+ id: 2,
25
+ title: "综艺",
26
+ },
27
+ {
28
+ focusable: true,
29
+ hasSub: false,
30
+ id: 3,
31
+ title: "综艺",
32
+ },
33
+ ];
34
+
35
+ const contentData = [
36
+ {
37
+ blocks: {
38
+ w: 800,
39
+ h: 200,
40
+ },
41
+ focusable: true,
42
+ hasSub: true,
43
+ id: 0,
44
+ title: "电视剧",
45
+ data: [
46
+ {
47
+ focusable: true,
48
+ color: "#000022",
49
+ content: {
50
+ url:
51
+ "http://oss.image.51vtv.cn/homepage/20191224/0fdcdc8b258fe7baac16b73f58f8989d.jpg",
52
+ title: "剑王朝",
53
+ },
54
+ },
55
+ {
56
+ focusable: true,
57
+ color: "#003300",
58
+ content: {
59
+ url:
60
+ "http://oss.image.51vtv.cn/homepage/20191216/d0b14128b1783e5188de6ca98e6b5d05.jpg",
61
+ title: "我和我的祖国",
62
+ },
63
+ },
64
+
65
+ {
66
+ focusable: true,
67
+ color: "#000055",
68
+ content: {
69
+ url:
70
+ "http://oss.image.51vtv.cn/homepage/20191224/6235ab61a3c89ef2997b4c0441d91eae.jpg",
71
+ title: "汪汪队立大功第4季",
72
+ },
73
+ },
74
+
75
+ {
76
+ focusable: true,
77
+ color: "#0000CD",
78
+ content: {
79
+ url:
80
+ "http://oss.image.51vtv.cn/homepage/20191224/bded4e88fd610b7107c9836f5d5db959.jpg",
81
+ title: "变形警车珀利消防安全篇",
82
+ },
83
+ },
84
+ {
85
+ focusable: true,
86
+ color: "#000022",
87
+ content: {
88
+ url:
89
+ "http://oss.image.51vtv.cn/homepage/20191224/259f41751aa9642c5d543114a71b070a.png",
90
+ title: "迪士尼电影",
91
+ },
92
+ },
93
+ {
94
+ focusable: true,
95
+ color: "#000022",
96
+ content: {
97
+ url:
98
+ "http://oss.image.51vtv.cn/homepage/20190618/e449792161d2e66f39f6608f70c6c89b.png",
99
+ title: "灯塔慧",
100
+ },
101
+ },
102
+ ],
103
+ },
104
+ {
105
+ blocks: {
106
+ w: 800,
107
+ h: 200,
108
+ },
109
+ focusable: true,
110
+ hasSub: true,
111
+ id: 1,
112
+ title: "影视",
113
+ data: [
114
+ {
115
+ focusable: true,
116
+ color: "#000022",
117
+ content: {
118
+ url:
119
+ "http://oss.image.51vtv.cn/homepage/20191224/0fdcdc8b258fe7baac16b73f58f8989d.jpg",
120
+ title: "剑王朝",
121
+ },
122
+ },
123
+ {
124
+ focusable: true,
125
+ color: "#003300",
126
+ content: {
127
+ url:
128
+ "http://oss.image.51vtv.cn/homepage/20191216/d0b14128b1783e5188de6ca98e6b5d05.jpg",
129
+ title: "我和我的祖国",
130
+ },
131
+ },
132
+
133
+ {
134
+ focusable: true,
135
+ color: "#000055",
136
+ content: {
137
+ url:
138
+ "http://oss.image.51vtv.cn/homepage/20191224/6235ab61a3c89ef2997b4c0441d91eae.jpg",
139
+ title: "汪汪队立大功第4季",
140
+ },
141
+ },
142
+
143
+ {
144
+ focusable: true,
145
+ color: "#0000CD",
146
+ content: {
147
+ url:
148
+ "http://oss.image.51vtv.cn/homepage/20191224/bded4e88fd610b7107c9836f5d5db959.jpg",
149
+ title: "变形警车珀利消防安全篇",
150
+ },
151
+ },
152
+ {
153
+ focusable: true,
154
+ color: "#000022",
155
+ content: {
156
+ url:
157
+ "http://oss.image.51vtv.cn/homepage/20191224/259f41751aa9642c5d543114a71b070a.png",
158
+ title: "迪士尼电影",
159
+ },
160
+ },
161
+ {
162
+ focusable: true,
163
+ color: "#000022",
164
+ content: {
165
+ url:
166
+ "http://oss.image.51vtv.cn/homepage/20190618/e449792161d2e66f39f6608f70c6c89b.png",
167
+ title: "灯塔慧",
168
+ },
169
+ },
170
+ ],
171
+ },
172
+ {
173
+ blocks: {
174
+ w: 800,
175
+ h: 200,
176
+ },
177
+ focusable: true,
178
+ hasSub: true,
179
+ id: 2,
180
+ title: "综艺",
181
+ data: [
182
+ {
183
+ focusable: true,
184
+ color: "#000022",
185
+ content: {
186
+ url:
187
+ "http://oss.image.51vtv.cn/homepage/20191224/0fdcdc8b258fe7baac16b73f58f8989d.jpg",
188
+ title: "剑王朝",
189
+ },
190
+ },
191
+ {
192
+ focusable: true,
193
+ color: "#003300",
194
+ content: {
195
+ url:
196
+ "http://oss.image.51vtv.cn/homepage/20191216/d0b14128b1783e5188de6ca98e6b5d05.jpg",
197
+ title: "我和我的祖国",
198
+ },
199
+ },
200
+
201
+ {
202
+ focusable: true,
203
+ color: "#000055",
204
+ content: {
205
+ url:
206
+ "http://oss.image.51vtv.cn/homepage/20191224/6235ab61a3c89ef2997b4c0441d91eae.jpg",
207
+ title: "汪汪队立大功第4季",
208
+ },
209
+ },
210
+
211
+ {
212
+ focusable: true,
213
+ color: "#0000CD",
214
+ content: {
215
+ url:
216
+ "http://oss.image.51vtv.cn/homepage/20191224/bded4e88fd610b7107c9836f5d5db959.jpg",
217
+ title: "变形警车珀利消防安全篇",
218
+ },
219
+ },
220
+ {
221
+ focusable: true,
222
+ color: "#000022",
223
+ content: {
224
+ url:
225
+ "http://oss.image.51vtv.cn/homepage/20191224/259f41751aa9642c5d543114a71b070a.png",
226
+ title: "迪士尼电影",
227
+ },
228
+ },
229
+ {
230
+ focusable: true,
231
+ color: "#000022",
232
+ content: {
233
+ url:
234
+ "http://oss.image.51vtv.cn/homepage/20190618/e449792161d2e66f39f6608f70c6c89b.png",
235
+ title: "灯塔慧",
236
+ },
237
+ },
238
+ ],
239
+ },
240
+ {
241
+ blocks: {
242
+ w: 800,
243
+ h: 200,
244
+ },
245
+ focusable: true,
246
+ hasSub: true,
247
+ id: 3,
248
+ title: "电视剧",
249
+ data: [
250
+ {
251
+ focusable: true,
252
+ color: "#000022",
253
+ content: {
254
+ url:
255
+ "http://oss.image.51vtv.cn/homepage/20191224/0fdcdc8b258fe7baac16b73f58f8989d.jpg",
256
+ title: "剑王朝",
257
+ },
258
+ },
259
+ {
260
+ focusable: true,
261
+ color: "#003300",
262
+ content: {
263
+ url:
264
+ "http://oss.image.51vtv.cn/homepage/20191216/d0b14128b1783e5188de6ca98e6b5d05.jpg",
265
+ title: "我和我的祖国",
266
+ },
267
+ },
268
+
269
+ {
270
+ focusable: true,
271
+ color: "#000055",
272
+ content: {
273
+ url:
274
+ "http://oss.image.51vtv.cn/homepage/20191224/6235ab61a3c89ef2997b4c0441d91eae.jpg",
275
+ title: "汪汪队立大功第4季",
276
+ },
277
+ },
278
+
279
+ {
280
+ focusable: true,
281
+ color: "#0000CD",
282
+ content: {
283
+ url:
284
+ "http://oss.image.51vtv.cn/homepage/20191224/bded4e88fd610b7107c9836f5d5db959.jpg",
285
+ title: "变形警车珀利消防安全篇",
286
+ },
287
+ },
288
+ {
289
+ focusable: true,
290
+ color: "#000022",
291
+ content: {
292
+ url:
293
+ "http://oss.image.51vtv.cn/homepage/20191224/259f41751aa9642c5d543114a71b070a.png",
294
+ title: "迪士尼电影",
295
+ },
296
+ },
297
+ {
298
+ focusable: true,
299
+ color: "#000022",
300
+ content: {
301
+ url:
302
+ "http://oss.image.51vtv.cn/homepage/20190618/e449792161d2e66f39f6608f70c6c89b.png",
303
+ title: "灯塔慧",
304
+ },
305
+ },
306
+ ],
307
+ },
308
+ {
309
+ blocks: {
310
+ w: 800,
311
+ h: 200,
312
+ },
313
+ focusable: true,
314
+ hasSub: true,
315
+ id: 4,
316
+ title: "影视",
317
+ data: [
318
+ {
319
+ focusable: true,
320
+ color: "#000022",
321
+ content: {
322
+ url:
323
+ "http://oss.image.51vtv.cn/homepage/20191224/0fdcdc8b258fe7baac16b73f58f8989d.jpg",
324
+ title: "剑王朝",
325
+ },
326
+ },
327
+ {
328
+ focusable: true,
329
+ color: "#003300",
330
+ content: {
331
+ url:
332
+ "http://oss.image.51vtv.cn/homepage/20191216/d0b14128b1783e5188de6ca98e6b5d05.jpg",
333
+ title: "我和我的祖国",
334
+ },
335
+ },
336
+
337
+ {
338
+ focusable: true,
339
+ color: "#000055",
340
+ content: {
341
+ url:
342
+ "http://oss.image.51vtv.cn/homepage/20191224/6235ab61a3c89ef2997b4c0441d91eae.jpg",
343
+ title: "汪汪队立大功第4季",
344
+ },
345
+ },
346
+
347
+ {
348
+ focusable: true,
349
+ color: "#0000CD",
350
+ content: {
351
+ url:
352
+ "http://oss.image.51vtv.cn/homepage/20191224/bded4e88fd610b7107c9836f5d5db959.jpg",
353
+ title: "变形警车珀利消防安全篇",
354
+ },
355
+ },
356
+ {
357
+ focusable: true,
358
+ color: "#000022",
359
+ content: {
360
+ url:
361
+ "http://oss.image.51vtv.cn/homepage/20191224/259f41751aa9642c5d543114a71b070a.png",
362
+ title: "迪士尼电影",
363
+ },
364
+ },
365
+ {
366
+ focusable: true,
367
+ color: "#000022",
368
+ content: {
369
+ url:
370
+ "http://oss.image.51vtv.cn/homepage/20190618/e449792161d2e66f39f6608f70c6c89b.png",
371
+ title: "灯塔慧",
372
+ },
373
+ },
374
+ ],
375
+ },
376
+ {
377
+ blocks: {
378
+ w: 800,
379
+ h: 200,
380
+ },
381
+ focusable: true,
382
+ hasSub: true,
383
+ id: 5,
384
+ title: "综艺",
385
+ data: [
386
+ {
387
+ focusable: true,
388
+ color: "#000022",
389
+ content: {
390
+ url:
391
+ "http://oss.image.51vtv.cn/homepage/20191224/0fdcdc8b258fe7baac16b73f58f8989d.jpg",
392
+ title: "剑王朝",
393
+ },
394
+ },
395
+ {
396
+ focusable: true,
397
+ color: "#003300",
398
+ content: {
399
+ url:
400
+ "http://oss.image.51vtv.cn/homepage/20191216/d0b14128b1783e5188de6ca98e6b5d05.jpg",
401
+ title: "我和我的祖国",
402
+ },
403
+ },
404
+
405
+ {
406
+ focusable: true,
407
+ color: "#000055",
408
+ content: {
409
+ url:
410
+ "http://oss.image.51vtv.cn/homepage/20191224/6235ab61a3c89ef2997b4c0441d91eae.jpg",
411
+ title: "汪汪队立大功第4季",
412
+ },
413
+ },
414
+
415
+ {
416
+ focusable: true,
417
+ color: "#0000CD",
418
+ content: {
419
+ url:
420
+ "http://oss.image.51vtv.cn/homepage/20191224/bded4e88fd610b7107c9836f5d5db959.jpg",
421
+ title: "变形警车珀利消防安全篇",
422
+ },
423
+ },
424
+ {
425
+ focusable: true,
426
+ color: "#000022",
427
+ content: {
428
+ url:
429
+ "http://oss.image.51vtv.cn/homepage/20191224/259f41751aa9642c5d543114a71b070a.png",
430
+ title: "迪士尼电影",
431
+ },
432
+ },
433
+ {
434
+ focusable: true,
435
+ color: "#000022",
436
+ content: {
437
+ url:
438
+ "http://oss.image.51vtv.cn/homepage/20190618/e449792161d2e66f39f6608f70c6c89b.png",
439
+ title: "灯塔慧",
440
+ },
441
+ },
442
+ ],
443
+ },
444
+ ];
445
+
446
+ export { menuData, contentData };