southnote-mini-sdk 1.0.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 (309) hide show
  1. package/app.js +22 -0
  2. package/app.json +53 -0
  3. package/app.wxss +15 -0
  4. package/assets/file/badwords.js +63008 -0
  5. package/assets/file/rules.js +38 -0
  6. package/assets/images/emoji/smile001.png +0 -0
  7. package/assets/images/emoji/smile002.png +0 -0
  8. package/assets/images/emoji/smile003.png +0 -0
  9. package/assets/images/emoji/smile004.png +0 -0
  10. package/assets/images/emoji/smile005.png +0 -0
  11. package/assets/images/emoji/smile006.png +0 -0
  12. package/assets/images/emoji/smile007.png +0 -0
  13. package/assets/images/emoji/smile008.png +0 -0
  14. package/assets/images/emoji/smile009.png +0 -0
  15. package/assets/images/emoji/smile010.png +0 -0
  16. package/assets/images/emoji/smile011.png +0 -0
  17. package/assets/images/emoji/smile012.png +0 -0
  18. package/assets/images/emoji/smile013.png +0 -0
  19. package/assets/images/emoji/smile014.png +0 -0
  20. package/assets/images/emoji/smile015.png +0 -0
  21. package/assets/images/emoji/smile016.png +0 -0
  22. package/assets/images/emoji/smile017.png +0 -0
  23. package/assets/images/emoji/smile018.png +0 -0
  24. package/assets/images/emoji/smile019.png +0 -0
  25. package/assets/images/emoji/smile020.png +0 -0
  26. package/assets/images/emoji/smile021.png +0 -0
  27. package/assets/images/emoji/smile022.png +0 -0
  28. package/assets/images/emoji/smile023.png +0 -0
  29. package/assets/images/emoji/smile024.png +0 -0
  30. package/assets/images/emoji/smile025.png +0 -0
  31. package/assets/images/emoji/smile026.png +0 -0
  32. package/assets/images/emoji/smile027.png +0 -0
  33. package/assets/images/emoji/smile028.png +0 -0
  34. package/assets/images/emoji/smile029.png +0 -0
  35. package/assets/images/emoji/smile030.png +0 -0
  36. package/assets/images/emoji/smile031.png +0 -0
  37. package/assets/images/emoji/smile032.png +0 -0
  38. package/assets/images/emoji/smile033.png +0 -0
  39. package/assets/images/emoji/smile034.png +0 -0
  40. package/assets/images/emoji/smile035.png +0 -0
  41. package/assets/images/emoji/smile036.png +0 -0
  42. package/assets/images/emoji/smile037.png +0 -0
  43. package/assets/images/emoji/smile038.png +0 -0
  44. package/assets/images/emoji/smile039.png +0 -0
  45. package/assets/images/emoji/smile040.png +0 -0
  46. package/assets/images/emoji/smile041.png +0 -0
  47. package/assets/images/emoji/smile042.png +0 -0
  48. package/assets/images/emoji/smile043.png +0 -0
  49. package/assets/images/emoji/smile044.png +0 -0
  50. package/assets/images/emoji/smile045.png +0 -0
  51. package/assets/images/emoji/smile046.png +0 -0
  52. package/assets/images/emoji/smile047.png +0 -0
  53. package/assets/images/emoji/smile048.png +0 -0
  54. package/assets/images/emoji/smile049.png +0 -0
  55. package/assets/images/emoji/smile050.png +0 -0
  56. package/assets/images/emoji/smile051.png +0 -0
  57. package/assets/images/emoji/smile052.png +0 -0
  58. package/assets/images/icons/age1.png +0 -0
  59. package/assets/images/icons/age2.png +0 -0
  60. package/assets/images/icons/age3.png +0 -0
  61. package/assets/images/icons/attachment.png +0 -0
  62. package/assets/images/icons/clear.png +0 -0
  63. package/assets/images/icons/edit_input.png +0 -0
  64. package/assets/images/icons/header_placeholder.png +0 -0
  65. package/assets/images/icons/home_collect.png +0 -0
  66. package/assets/images/icons/home_collected.png +0 -0
  67. package/assets/images/icons/home_comment.png +0 -0
  68. package/assets/images/icons/home_like.png +0 -0
  69. package/assets/images/icons/home_liked.png +0 -0
  70. package/assets/images/icons/home_message.png +0 -0
  71. package/assets/images/icons/home_share.png +0 -0
  72. package/assets/images/icons/icon_more.png +0 -0
  73. package/assets/images/icons/input_game.png +0 -0
  74. package/assets/images/icons/logo.png +0 -0
  75. package/assets/images/icons/lv1.png +0 -0
  76. package/assets/images/icons/lv2.png +0 -0
  77. package/assets/images/icons/lv3.png +0 -0
  78. package/assets/images/icons/lv4.png +0 -0
  79. package/assets/images/icons/search.png +0 -0
  80. package/assets/images/icons/sex1.png +0 -0
  81. package/assets/images/icons/sex2.png +0 -0
  82. package/assets/images/icons/sign_empty.png +0 -0
  83. package/assets/images/icons/sign_login.png +0 -0
  84. package/assets/wheel/wheel_bg.png +0 -0
  85. package/assets/wheel/wheel_bg2.png +0 -0
  86. package/assets/wheel/wheel_fore.png +0 -0
  87. package/assets/wheel/wheel_to.png +0 -0
  88. package/components/bottomSheet/bottomSheet.js +473 -0
  89. package/components/bottomSheet/bottomSheet.json +3 -0
  90. package/components/bottomSheet/bottomSheet.wxml +73 -0
  91. package/components/bottomSheet/bottomSheet.wxss +238 -0
  92. package/components/experience-item/experience-item.js +105 -0
  93. package/components/experience-item/experience-item.json +4 -0
  94. package/components/experience-item/experience-item.wxml +39 -0
  95. package/components/experience-item/experience-item.wxss +110 -0
  96. package/components/grid-item/grid-item.js +8 -0
  97. package/components/grid-item/grid-item.json +4 -0
  98. package/components/grid-item/grid-item.wxml +62 -0
  99. package/components/grid-item/grid-item.wxss +191 -0
  100. package/components/post-item/post-item.js +1085 -0
  101. package/components/post-item/post-item.json +4 -0
  102. package/components/post-item/post-item.wxml +427 -0
  103. package/components/post-item/post-item.wxss +525 -0
  104. package/components/wiki-renderer/wiki-renderer.js +636 -0
  105. package/components/wiki-renderer/wiki-renderer.json +12 -0
  106. package/components/wiki-renderer/wiki-renderer.wxml +150 -0
  107. package/components/wiki-renderer/wiki-renderer.wxss +412 -0
  108. package/components/wiki-tabs/wiki-tabs.js +52 -0
  109. package/components/wiki-tabs/wiki-tabs.json +3 -0
  110. package/components/wiki-tabs/wiki-tabs.wxml +28 -0
  111. package/components/wiki-tabs/wiki-tabs.wxss +43 -0
  112. package/index.js +49 -0
  113. package/package.json +35 -0
  114. package/pages/addGame/addGame.js +454 -0
  115. package/pages/addGame/addGame.json +3 -0
  116. package/pages/addGame/addGame.wxml +71 -0
  117. package/pages/addGame/addGame.wxss +110 -0
  118. package/pages/addSubject/addSubject.js +199 -0
  119. package/pages/addSubject/addSubject.json +4 -0
  120. package/pages/addSubject/addSubject.wxml +78 -0
  121. package/pages/addSubject/addSubject.wxss +85 -0
  122. package/pages/commonLogin/commonLogin.js +269 -0
  123. package/pages/commonLogin/commonLogin.json +4 -0
  124. package/pages/commonLogin/commonLogin.wxml +57 -0
  125. package/pages/commonLogin/commonLogin.wxss +177 -0
  126. package/pages/copyOfficial/copyOfficial.js +25 -0
  127. package/pages/copyOfficial/copyOfficial.json +3 -0
  128. package/pages/copyOfficial/copyOfficial.wxml +22 -0
  129. package/pages/copyOfficial/copyOfficial.wxss +49 -0
  130. package/pages/demo/demo.js +23 -0
  131. package/pages/demo/demo.json +3 -0
  132. package/pages/demo/demo.wxml +8 -0
  133. package/pages/demo/demo.wxss +24 -0
  134. package/pages/game/game.js +1254 -0
  135. package/pages/game/game.json +8 -0
  136. package/pages/game/game.wxml +371 -0
  137. package/pages/game/game.wxss +672 -0
  138. package/pages/home/home.js +665 -0
  139. package/pages/home/home.json +10 -0
  140. package/pages/home/home.wxml +115 -0
  141. package/pages/home/home.wxss +231 -0
  142. package/pages/lottery-winners/lottery-winners.js +60 -0
  143. package/pages/lottery-winners/lottery-winners.json +4 -0
  144. package/pages/lottery-winners/lottery-winners.wxml +53 -0
  145. package/pages/lottery-winners/lottery-winners.wxss +127 -0
  146. package/pages/message/messageCommentsAndAt/messageCommentsAndAt.js +178 -0
  147. package/pages/message/messageCommentsAndAt/messageCommentsAndAt.json +5 -0
  148. package/pages/message/messageCommentsAndAt/messageCommentsAndAt.wxml +93 -0
  149. package/pages/message/messageCommentsAndAt/messageCommentsAndAt.wxss +177 -0
  150. package/pages/message/messageEntire/messageEntire.js +112 -0
  151. package/pages/message/messageEntire/messageEntire.json +4 -0
  152. package/pages/message/messageEntire/messageEntire.wxml +44 -0
  153. package/pages/message/messageEntire/messageEntire.wxss +88 -0
  154. package/pages/message/messageLikeAndCollect/messageLikeAndCollect.js +147 -0
  155. package/pages/message/messageLikeAndCollect/messageLikeAndCollect.json +5 -0
  156. package/pages/message/messageLikeAndCollect/messageLikeAndCollect.wxml +84 -0
  157. package/pages/message/messageLikeAndCollect/messageLikeAndCollect.wxss +166 -0
  158. package/pages/message/messageNewFans/messageNewFans.js +139 -0
  159. package/pages/message/messageNewFans/messageNewFans.json +5 -0
  160. package/pages/message/messageNewFans/messageNewFans.wxml +35 -0
  161. package/pages/message/messageNewFans/messageNewFans.wxss +85 -0
  162. package/pages/officialWebview/officialWebview.js +13 -0
  163. package/pages/officialWebview/officialWebview.json +3 -0
  164. package/pages/officialWebview/officialWebview.wxml +2 -0
  165. package/pages/officialWebview/officialWebview.wxss +1 -0
  166. package/pages/post/post.js +1856 -0
  167. package/pages/post/post.json +6 -0
  168. package/pages/post/post.wxml +694 -0
  169. package/pages/post/post.wxss +1003 -0
  170. package/pages/post-editor/post-editor.js +465 -0
  171. package/pages/post-editor/post-editor.json +4 -0
  172. package/pages/post-editor/post-editor.wxml +63 -0
  173. package/pages/post-editor/post-editor.wxss +195 -0
  174. package/pages/postDialog/postDialog.js +560 -0
  175. package/pages/postDialog/postDialog.json +6 -0
  176. package/pages/postDialog/postDialog.wxml +377 -0
  177. package/pages/postDialog/postDialog.wxss +979 -0
  178. package/pages/report-category/report-category.js +29 -0
  179. package/pages/report-category/report-category.json +4 -0
  180. package/pages/report-category/report-category.wxml +14 -0
  181. package/pages/report-category/report-category.wxss +43 -0
  182. package/pages/report-form/report-form.js +65 -0
  183. package/pages/report-form/report-form.json +3 -0
  184. package/pages/report-form/report-form.wxml +11 -0
  185. package/pages/report-form/report-form.wxss +44 -0
  186. package/pages/sevenDaySignDetail/sevenDaySignDetail.js +273 -0
  187. package/pages/sevenDaySignDetail/sevenDaySignDetail.json +3 -0
  188. package/pages/sevenDaySignDetail/sevenDaySignDetail.wxml +82 -0
  189. package/pages/sevenDaySignDetail/sevenDaySignDetail.wxss +173 -0
  190. package/pages/topic/topic.js +266 -0
  191. package/pages/topic/topic.json +6 -0
  192. package/pages/topic/topic.wxml +77 -0
  193. package/pages/topic/topic.wxss +162 -0
  194. package/pages/user/user.js +939 -0
  195. package/pages/user/user.json +5 -0
  196. package/pages/user/user.wxml +179 -0
  197. package/pages/user/user.wxss +340 -0
  198. package/pages/userDatum/userDatum.js +24 -0
  199. package/pages/userDatum/userDatum.json +4 -0
  200. package/pages/userDatum/userDatum.wxml +36 -0
  201. package/pages/userDatum/userDatum.wxss +41 -0
  202. package/pages/userGameLib/userGameLib.js +105 -0
  203. package/pages/userGameLib/userGameLib.json +4 -0
  204. package/pages/userGameLib/userGameLib.wxml +42 -0
  205. package/pages/userGameLib/userGameLib.wxss +119 -0
  206. package/pages/webview/webview.js +25 -0
  207. package/pages/webview/webview.json +3 -0
  208. package/pages/webview/webview.wxml +22 -0
  209. package/pages/webview/webview.wxss +50 -0
  210. package/pages/wheelActivivty/wheelActivivty.js +492 -0
  211. package/pages/wheelActivivty/wheelActivivty.json +8 -0
  212. package/pages/wheelActivivty/wheelActivivty.wxml +131 -0
  213. package/pages/wheelActivivty/wheelActivivty.wxss +459 -0
  214. package/pages/wiki/wiki.js +138 -0
  215. package/pages/wiki/wiki.json +6 -0
  216. package/pages/wiki/wiki.wxml +20 -0
  217. package/pages/wiki/wiki.wxss +44 -0
  218. package/request/JKRequest.js +177 -0
  219. package/services/home.js +603 -0
  220. package/towxml/config.js +291 -0
  221. package/towxml/decode.js +35 -0
  222. package/towxml/decode.json +11 -0
  223. package/towxml/decode.wxml +137 -0
  224. package/towxml/decode.wxss +0 -0
  225. package/towxml/img/img.js +98 -0
  226. package/towxml/img/img.json +3 -0
  227. package/towxml/img/img.wxml +1 -0
  228. package/towxml/img/img.wxss +0 -0
  229. package/towxml/index.js +19 -0
  230. package/towxml/latex/latex.js +53 -0
  231. package/towxml/latex/latex.json +5 -0
  232. package/towxml/latex/latex.wxml +1 -0
  233. package/towxml/latex/latex.wxss +0 -0
  234. package/towxml/parse/highlight/highlight.js +1 -0
  235. package/towxml/parse/highlight/index.js +8 -0
  236. package/towxml/parse/highlight/languages/bash.js +111 -0
  237. package/towxml/parse/highlight/languages/c-like.js +236 -0
  238. package/towxml/parse/highlight/languages/c.js +22 -0
  239. package/towxml/parse/highlight/languages/css.js +132 -0
  240. package/towxml/parse/highlight/languages/dart.js +134 -0
  241. package/towxml/parse/highlight/languages/go.js +63 -0
  242. package/towxml/parse/highlight/languages/htmlbars.js +80 -0
  243. package/towxml/parse/highlight/languages/java.js +125 -0
  244. package/towxml/parse/highlight/languages/javascript.js +265 -0
  245. package/towxml/parse/highlight/languages/json.js +52 -0
  246. package/towxml/parse/highlight/languages/less.js +148 -0
  247. package/towxml/parse/highlight/languages/nginx.js +101 -0
  248. package/towxml/parse/highlight/languages/php.js +161 -0
  249. package/towxml/parse/highlight/languages/python-repl.js +29 -0
  250. package/towxml/parse/highlight/languages/python.js +131 -0
  251. package/towxml/parse/highlight/languages/scss.js +122 -0
  252. package/towxml/parse/highlight/languages/shell.js +22 -0
  253. package/towxml/parse/highlight/languages/typescript.js +215 -0
  254. package/towxml/parse/highlight/languages/xml.js +139 -0
  255. package/towxml/parse/highlight/style/github.wxss +99 -0
  256. package/towxml/parse/highlight/style/monokai.wxss +70 -0
  257. package/towxml/parse/index.js +118 -0
  258. package/towxml/parse/markdown/index.js +67 -0
  259. package/towxml/parse/markdown/markdown.js +4 -0
  260. package/towxml/parse/markdown/plugins/echarts.js +11 -0
  261. package/towxml/parse/markdown/plugins/emoji.js +2 -0
  262. package/towxml/parse/markdown/plugins/ins.js +1 -0
  263. package/towxml/parse/markdown/plugins/latex.js +158 -0
  264. package/towxml/parse/markdown/plugins/mark.js +1 -0
  265. package/towxml/parse/markdown/plugins/sub.js +1 -0
  266. package/towxml/parse/markdown/plugins/sup.js +1 -0
  267. package/towxml/parse/markdown/plugins/todo.js +147 -0
  268. package/towxml/parse/markdown/plugins/yuml.js +20 -0
  269. package/towxml/parse/parse2/Parser.js +492 -0
  270. package/towxml/parse/parse2/Tokenizer.js +903 -0
  271. package/towxml/parse/parse2/domelementtype/index.js +55 -0
  272. package/towxml/parse/parse2/domhandler/index.js +145 -0
  273. package/towxml/parse/parse2/domhandler/node.js +474 -0
  274. package/towxml/parse/parse2/entities/decode.js +179 -0
  275. package/towxml/parse/parse2/entities/decode_codepoint.js +60 -0
  276. package/towxml/parse/parse2/entities/encode.js +77 -0
  277. package/towxml/parse/parse2/entities/escape.js +112 -0
  278. package/towxml/parse/parse2/entities/generated/decode-data-html.js +9 -0
  279. package/towxml/parse/parse2/entities/generated/decode-data-xml.js +9 -0
  280. package/towxml/parse/parse2/entities/generated/encode-html.js +12 -0
  281. package/towxml/parse/parse2/entities/index.js +137 -0
  282. package/towxml/parse/parse2/index.js +8 -0
  283. package/towxml/style/main.wxss +419 -0
  284. package/towxml/style/theme/dark.wxss +73 -0
  285. package/towxml/style/theme/light.wxss +63 -0
  286. package/towxml/table/table.js +11 -0
  287. package/towxml/table/table.json +6 -0
  288. package/towxml/table/table.wxml +24 -0
  289. package/towxml/table/table.wxss +0 -0
  290. package/towxml/todogroup/todogroup.js +20 -0
  291. package/towxml/todogroup/todogroup.json +6 -0
  292. package/towxml/todogroup/todogroup.wxml +12 -0
  293. package/towxml/todogroup/todogroup.wxss +3 -0
  294. package/towxml/towxml.js +22 -0
  295. package/towxml/towxml.json +6 -0
  296. package/towxml/towxml.wxml +5 -0
  297. package/towxml/towxml.wxss +8 -0
  298. package/towxml/yuml/yuml.js +51 -0
  299. package/towxml/yuml/yuml.json +5 -0
  300. package/towxml/yuml/yuml.wxml +5 -0
  301. package/towxml/yuml/yuml.wxss +0 -0
  302. package/utils/auth.js +17 -0
  303. package/utils/base64.js +67 -0
  304. package/utils/compressImage.js +41 -0
  305. package/utils/exp.js +49 -0
  306. package/utils/formatPost.js +18 -0
  307. package/utils/parseContent.js +191 -0
  308. package/utils/query-select.js +9 -0
  309. package/utils/sensitive.js +82 -0
@@ -0,0 +1,150 @@
1
+ <view class="wiki-root">
2
+ <block wx:for="{{parsedBlocks}}" wx:key="index" wx:for-index="index">
3
+
4
+ <!-- Banner -->
5
+ <swiper circular wx:if="{{item.type === 'banner'}}" class="banner-swipe" autoplay="true" interval="3000" indicator-dots="true" indicator-color="white" style="aspect-ratio: {{item.ratio}}">
6
+ <swiper-item wx:for="{{item.children}}" wx:key="id" wx:for-item="bannerItem">
7
+ <image src="{{bannerItem.image.url}}" mode="aspectFill" class="banner-img" />
8
+ </swiper-item>
9
+ </swiper>
10
+
11
+ <!-- 文本 -->
12
+ <view wx:if="{{item.type === 'text'}}" class="wiki-text">{{item.desc}}</view>
13
+
14
+ <!-- 富文本 / 表格:用 towxml 渲染 -->
15
+ <view wx:if="{{item.type === 'richText' || item.type === 'table'}}" class="wiki-richtext" catch:tap="onRichTextTap" data-index="{{index}}">
16
+ <towxml nodes="{{item.towxmlNodes}}" bind:linktap="onTowxmlLinkTap" />
17
+ </view>
18
+
19
+ <!-- 图片 -->
20
+ <view wx:if="{{item.type === 'image'}}" class="image-block" style="aspect-ratio: {{item.ratio}}">
21
+ <image wx:if="{{item.visible}}" src="{{item.url}}" mode="aspectFill" class="block-img" bindtap="onImageTap" data-jump="{{item.jump}}" />
22
+ </view>
23
+
24
+ <!-- 评分 type=6 -->
25
+
26
+ <view wx:if="{{item.type === 'score'}}" class="score-block">
27
+ <view class="score-header">
28
+ <text class="score-title">{{item.title}}</text>
29
+ <view class="score-edit-btn" bindtap="onOpenScoreModal" data-index="{{index}}">
30
+ <van-icon name="edit" size="22px" />
31
+ </view>
32
+ </view>
33
+
34
+ <view class="container-divider"></view>
35
+
36
+ <view class="score-body">
37
+ <van-rate value="{{item.averageScore}}" allow-half readonly color="#f5a623" void-color="#e0e0e0" size="32px" />
38
+ <view class="score-right">
39
+ <text class="score-avg">{{item.averageScore}}</text>
40
+ <text class="score-count">{{item.voteCount}} 评分</text>
41
+ </view>
42
+ </view>
43
+ </view>
44
+
45
+ <!-- 评分弹窗 -->
46
+
47
+ <view wx:if="{{scoreModal.visible}}" class="score-modal-mask" catchtap="onCloseScoreModal">
48
+ <view class="score-modal" catchtap="stopPropagation">
49
+ <text class="score-modal-title">{{scoreModal.title}}</text>
50
+ <van-rate value="{{scoreModal.selected}}" allow-half color="#f5a623" void-color="#e0e0e0" size="40px" bind:change="onSelectStar" />
51
+ <view class="score-modal-btns">
52
+ <view class="score-modal-cancel" bindtap="onCloseScoreModal">取消</view>
53
+ <view class="score-modal-confirm {{scoreModal.selected > 0 ? '' : 'disabled'}}" bindtap="onSubmitScore">确认</view>
54
+ </view>
55
+ </view>
56
+ </view>
57
+
58
+ <!-- Grid 菜单 -->
59
+ <view wx:if="{{item.type === 'grid' && item.title}}" class="menu-title" style="background-color: {{item.color}}; color: {{item.titleTextColor}}">{{item.title}}</view>
60
+ <view wx:if="{{item.type === 'grid'}}" class="menu-tabs">
61
+
62
+ <view class="grid" style="grid-template-columns: repeat({{item.count}}, 1fr)">
63
+ <view wx:for="{{item.children}}" wx:key="index" wx:for-index="gi" wx:for-item="gitem" class="grid-item" bindtap="onJump" data-jump="{{gitem.jump}}">
64
+ <grid-item data="{{gitem}}" />
65
+ </view>
66
+ </view>
67
+ </view>
68
+
69
+ <!-- Tabs(图标网格型) -->
70
+ <view wx:if="{{item.type === 'tabs' && item.title}}" class="menu-title" style="background-color: {{item.color}}; color: {{item.titleTextColor}}">{{item.title}}</view>
71
+ <wiki-tabs wx:if="{{item.type === 'tabs'}}" tabs="{{item.tabs}}" color="{{'#002fa7'}}" active="{{tabActiveMap[index]}}" bind:change="onVanTabChange" data-block-index="{{index}}" data-tab-type="tabs">
72
+ <view wx:for="{{item.tabs}}" wx:key="name" wx:for-item="tab" slot="{{tab.name}}">
73
+ <view class="grid" style="grid-template-columns: repeat({{item.count}}, 1fr)">
74
+ <view wx:for="{{tab.children}}" wx:key="index" wx:for-item="gitem" wx:for-index="gi" class="grid-item" bindtap="onJump" data-jump="{{gitem.jump}}">
75
+ <grid-item data="{{gitem}}" />
76
+ </view>
77
+ </view>
78
+ </view>
79
+ </wiki-tabs>
80
+
81
+ <!-- 内容型 Tabs(递归子块) -->
82
+ <view wx:if="{{item.type === 'content-tabs' && item.title}}" class="menu-title" style="background-color: {{item.color}}; color: {{item.titleTextColor}}">{{item.title}}</view>
83
+ <wiki-tabs wx:if="{{item.type === 'content-tabs'}}" tabs="{{item.tabs}}" color="{{'#002fa7'}}" active="{{tabActiveMap[index]}}" bind:change="onVanTabChange" data-block-index="{{index}}" data-tab-type="content-tabs">
84
+ <view wx:for="{{item.tabs}}" wx:key="name" wx:for-item="tab" slot="{{tab.name}}">
85
+ <wiki-renderer images="{{images}}" data="{{tab.children}}" game-id="{{gameId}}" wiki-users="{{wikiUsers}}" />
86
+ </view>
87
+ </wiki-tabs>
88
+
89
+ <!-- 筛选 Tabs -->
90
+ <view wx:if="{{item.type === 'filter-tabs' && item.title}}" class="menu-title" style="background-color: {{item.color}}; color: {{item.titleTextColor}}">{{item.title}}</view>
91
+ <view wx:if="{{item.type === 'filter-tabs'}}" class="menu-tabs">
92
+ <view class="filter-classes">
93
+ <view wx:for="{{item.classes}}" wx:key="index" wx:for-index="ci" wx:for-item="cls" class="filter-class">
94
+ <view wx:for="{{cls.allKeys}}" wx:key="index" wx:for-item="key" class="filter-btn {{filterMap[ci] === key || (!filterMap[ci] && key === '不限') ? 'active' : ''}}" bindtap="onFilterChange" data-ci="{{ci}}" data-key="{{key}}">{{key}}</view>
95
+ </view>
96
+ </view>
97
+ <view class="grid" style="grid-template-columns: repeat({{item.count}}, 1fr)">
98
+ <view wx:for="{{item.filteredChildren}}" wx:key="index" wx:for-item="gitem" wx:for-index="fi" class="grid-item" bindtap="onJump" data-jump="{{gitem.jump}}">
99
+ <grid-item data="{{gitem}}" />
100
+ </view>
101
+ </view>
102
+ </view>
103
+
104
+ <!-- 攻略组成员 -->
105
+ <view wx:if="{{item.type === 'info'}}" class="info">
106
+ <view wx:if="{{item.title}}" class="menu-title" style="background-color: {{item.color}}">{{item.title}}</view>
107
+ <view style="font-size: 14px; line-height: 1.7; margin-top: 10px">{{item.info}}</view>
108
+ <view class="info-users">
109
+ <view wx:for="{{wikiUsers}}" wx:key="nickname" wx:for-item="user" class="user-item" bindtap="gotoUserCenter" data-id="{{user.id}}">
110
+ <image src="{{user.avatar}}" class="user-avatar" />
111
+ <text class="user-name">{{user.nickname}}</text>
112
+ </view>
113
+ </view>
114
+ </view>
115
+
116
+ <!-- 折叠容器 -->
117
+ <view wx:if="{{item.type === 'container' && item.key === 'collapse'}}" class="wiki-container">
118
+ <view class="collapse-title" style="background-color: {{item.color}}; color: {{item.titleTextColor}}" bindtap="onToggleCollapse" data-index="{{index}}">
119
+ <text>{{item.title}}</text>
120
+ <text class="collapse-arrow {{collapseActive[index] ? 'open' : ''}}">▾</text>
121
+ </view>
122
+ <view wx:if="{{collapseActive[index]}}">
123
+ <wiki-renderer images="{{images}}" data="{{item.children}}" game-id="{{gameId}}" wiki-users="{{wikiUsers}}" />
124
+ </view>
125
+ </view>
126
+
127
+ <!-- 带背景色容器 / 普通容器 / 标题容器 -->
128
+ <view wx:if="{{item.type === 'container' && item.key !== 'collapse'}}">
129
+ <view wx:if="{{item.title}}" class="menu-title" style="background-color: {{item.color}}; color: {{item.titleTextColor}}">{{item.title}}</view>
130
+ <view wx:if="{{item.hasDivider}}" class="container-divider"></view>
131
+ <view class="wiki-container" style="background-color: {{item.key === 'hasBGC' ? item.color : ''}}">
132
+ <wiki-renderer images="{{images}}" data="{{item.children}}" game-id="{{gameId}}" wiki-users="{{wikiUsers}}" />
133
+ </view>
134
+ </view>
135
+
136
+ <!-- 左右布局 -->
137
+ <view wx:if="{{item.type === 'lr'}}" class="wiki-container">
138
+ <view wx:if="{{item.title}}" class="menu-title" style="background-color: {{item.color}}; color: {{item.titleTextColor}}">{{item.title}}</view>
139
+ <view class="lr-block">
140
+ <view class="lr-side" style="flex: {{item.percent / 100}}">
141
+ <wiki-renderer wx:if="{{item.left}}" images="{{images}}" data="{{[item.left]}}" game-id="{{gameId}}" wiki-users="{{wikiUsers}}" />
142
+ </view>
143
+ <view class="lr-side" style="flex: {{1 - item.percent / 100}}">
144
+ <wiki-renderer wx:if="{{item.right}}" images="{{images}}" data="{{[item.right]}}" game-id="{{gameId}}" wiki-users="{{wikiUsers}}" />
145
+ </view>
146
+ </view>
147
+ </view>
148
+
149
+ </block>
150
+ </view>
@@ -0,0 +1,412 @@
1
+ .wiki-root {}
2
+
3
+ /* Banner */
4
+ .banner-swipe {
5
+ border-radius: 8px;
6
+ overflow: hidden;
7
+ margin: 15px 0;
8
+ width: 100%;
9
+ height: auto;
10
+ }
11
+
12
+ .banner-img {
13
+ width: 100%;
14
+ height: 100%;
15
+ border-radius: 12px;
16
+ }
17
+
18
+ /* Image */
19
+ .image-block {
20
+ position: relative;
21
+ margin: 15px 0;
22
+ width: 100%;
23
+ background-color: #e0e0e0;
24
+ border-radius: 10rpx;
25
+ }
26
+
27
+ .block-img {
28
+ width: 100%;
29
+ height: 100%;
30
+ border-radius: 12px;
31
+ }
32
+
33
+ /* Text */
34
+ .wiki-text {
35
+ margin: 15px 0;
36
+ line-height: 2.0;
37
+ font-size: 14px;
38
+ color: black;
39
+ }
40
+
41
+ .wiki-richtext {
42
+ margin: 15px 0;
43
+ font-size: 14px;
44
+ line-height: 2.0;
45
+ padding: 0 10px;
46
+ }
47
+
48
+ /* Menu */
49
+ .menu-tabs {
50
+ background-color: #f5f5f5;
51
+ padding: 15px;
52
+ }
53
+
54
+ .menu-title {
55
+ font-size: 20px;
56
+ font-weight: bold;
57
+ text-align: left;
58
+ padding: 8px;
59
+ margin-top: 15px;
60
+ }
61
+
62
+ /* Tabs */
63
+ .tab-bar {
64
+ display: flex;
65
+ flex-direction: row;
66
+ white-space: nowrap;
67
+ margin-bottom: 15px;
68
+ }
69
+
70
+ .tab-btn {
71
+ display: inline-block;
72
+ padding: 6px 16px;
73
+ margin-right: 8px;
74
+ border-radius: 16px;
75
+ background: #f5f5f5;
76
+ font-size: 14px;
77
+ }
78
+
79
+ .tab-btn-active {
80
+ background: #409eff;
81
+ color: white;
82
+ }
83
+
84
+ /* Grid */
85
+ .grid {
86
+ display: grid;
87
+ gap: 0;
88
+ }
89
+
90
+ .grid-item {
91
+ padding: 6px 0;
92
+ text-align: center;
93
+ }
94
+
95
+ /* Filter */
96
+ .filter-classes {
97
+ display: flex;
98
+ flex-direction: column;
99
+ gap: 8px;
100
+ margin: 15px 0;
101
+ }
102
+
103
+ .filter-class {
104
+ display: flex;
105
+ flex-wrap: wrap;
106
+ gap: 6px;
107
+ }
108
+
109
+ .filter-btn {
110
+ padding: 4px 12px;
111
+ border: 1px solid #ccc;
112
+ border-radius: 12px;
113
+ background: #f5f5f5;
114
+ font-size: 14px;
115
+ }
116
+
117
+ .filter-btn.active {
118
+ background: #409eff;
119
+ color: white;
120
+ border-color: #409eff;
121
+ }
122
+
123
+ /* Info */
124
+ .info {
125
+ margin-top: 15px;
126
+ padding: 10px;
127
+ border-radius: 12px;
128
+ }
129
+
130
+ .info-users {
131
+ display: flex;
132
+ flex-wrap: wrap;
133
+ gap: 10px;
134
+ background: white;
135
+ padding: 10px;
136
+ }
137
+
138
+ .user-item {
139
+ display: flex;
140
+ flex-direction: column;
141
+ align-items: center;
142
+ gap: 6px;
143
+ }
144
+
145
+ .user-avatar {
146
+ width: 40px;
147
+ height: 40px;
148
+ border-radius: 50%;
149
+ }
150
+
151
+ .user-name {
152
+ width: 60px;
153
+ text-align: center;
154
+ overflow: hidden;
155
+ text-overflow: ellipsis;
156
+ white-space: nowrap;
157
+ color: #a7a7a7;
158
+ font-size: 12px;
159
+ }
160
+
161
+ /* Container */
162
+ .wiki-container {
163
+ padding: 5px;
164
+ border-radius: 12px;
165
+ background: #f8f8f8;
166
+ }
167
+
168
+ .collapse-title {
169
+ display: flex;
170
+ justify-content: space-between;
171
+ padding: 10px;
172
+ font-weight: bold;
173
+ border-radius: 8px;
174
+ }
175
+
176
+ .collapse-arrow {
177
+ transition: transform 0.2s;
178
+ }
179
+
180
+ .collapse-arrow.open {
181
+ transform: rotate(180deg);
182
+ }
183
+
184
+ /* LR */
185
+ .lr-block {
186
+ display: flex;
187
+ gap: 12px;
188
+ margin: 15px 0;
189
+ }
190
+
191
+ .lr-side {
192
+ display: flex;
193
+ flex-direction: column;
194
+ gap: 8px;
195
+ }
196
+
197
+ .container-divider {
198
+ height: 1px;
199
+ background-color: #e0e0e0;
200
+ margin: 10px 0;
201
+ }
202
+
203
+
204
+ /* 评分块 */
205
+ .score-block {
206
+ margin: 15px 0;
207
+ padding: 15px 0px;
208
+ background: #fff;
209
+ border-radius: 12px;
210
+ }
211
+
212
+ .score-header {
213
+ display: flex;
214
+ justify-content: space-between;
215
+ align-items: center;
216
+ margin-bottom: 10px;
217
+ }
218
+
219
+ .score-title {
220
+ font-size: 20px;
221
+ font-weight: bold;
222
+ text-align: left;
223
+ }
224
+
225
+ .score-edit-btn {
226
+ padding: 4px 8px;
227
+ }
228
+
229
+ .score-edit-icon {
230
+ font-size: 18px;
231
+ color: #333;
232
+ }
233
+
234
+
235
+
236
+ .score-stars {
237
+ display: flex;
238
+ gap: 4px;
239
+ }
240
+
241
+ .score-star {
242
+ font-size: 32px;
243
+ color: #e0e0e0;
244
+ }
245
+
246
+ .score-star.filled {
247
+ color: #f5a623;
248
+ }
249
+
250
+ .score-right {
251
+ display: flex;
252
+ flex-direction: column;
253
+ align-items: flex-start;
254
+ }
255
+
256
+ .score-avg {
257
+ font-size: 28px;
258
+ font-weight: bold;
259
+ line-height: 1.2;
260
+ }
261
+
262
+ .score-count {
263
+ font-size: 12px;
264
+ color: #999;
265
+ }
266
+
267
+ /* 评分弹窗 */
268
+ /* 蒙层透明度 0.2 */
269
+ .score-modal-mask {
270
+ position: fixed;
271
+ inset: 0;
272
+ background: rgba(0, 0, 0, 0.2);
273
+ z-index: 999;
274
+ display: flex;
275
+ align-items: center;
276
+ justify-content: center;
277
+ }
278
+
279
+ /* score-body 改为 space-between */
280
+ .score-body {
281
+ display: flex;
282
+ align-items: center;
283
+ justify-content: space-between;
284
+ /* ← 关键改动 */
285
+ width: 100%;
286
+ }
287
+
288
+ .score-modal {
289
+ background: #fff;
290
+ border-radius: 16px;
291
+ padding: 24px 20px;
292
+ width: 72vw;
293
+ display: flex;
294
+ flex-direction: column;
295
+ align-items: center;
296
+ gap: 16px;
297
+ }
298
+
299
+ .score-modal-title {
300
+ font-size: 16px;
301
+ font-weight: bold;
302
+ text-align: center;
303
+ }
304
+
305
+ .score-modal-stars {
306
+ display: flex;
307
+ gap: 8px;
308
+ }
309
+
310
+ .score-modal-star {
311
+ font-size: 40px;
312
+ color: #e0e0e0;
313
+ }
314
+
315
+ .score-modal-star.filled {
316
+ color: #f5a623;
317
+ }
318
+
319
+ .score-modal-hint {
320
+ font-size: 13px;
321
+ color: #888;
322
+ }
323
+
324
+ .score-modal-btns {
325
+ display: flex;
326
+ gap: 12px;
327
+ width: 100%;
328
+ }
329
+
330
+ .score-modal-cancel,
331
+ .score-modal-confirm {
332
+ flex: 1;
333
+ text-align: center;
334
+ padding: 10px 0;
335
+ border-radius: 20px;
336
+ font-size: 15px;
337
+ }
338
+
339
+ .score-modal-cancel {
340
+ background: #f5f5f5;
341
+ color: #333;
342
+ }
343
+
344
+ .score-modal-confirm {
345
+ background: #002fa7;
346
+ color: #fff;
347
+ }
348
+
349
+ .score-modal-confirm.disabled {
350
+ background: #b0b0b0;
351
+ }
352
+
353
+ /* 星星容器:相对定位,用于叠加填充层 */
354
+ .star-wrap {
355
+ position: relative;
356
+ display: inline-flex;
357
+ align-items: center;
358
+ }
359
+
360
+ /* 填充层:绝对定位,从左边开始裁剪 */
361
+ .star-fill {
362
+ position: absolute;
363
+ left: 0;
364
+ top: 0;
365
+ overflow: hidden;
366
+ /* width 由内联 style 动态设置 0% / 50% / 100% */
367
+ }
368
+
369
+ /* 弹窗里的星星需要更大触控区 */
370
+ .modal-star {
371
+ margin: 0 4px;
372
+ }
373
+
374
+ /* 左半点击区 */
375
+ .star-tap-left {
376
+ position: absolute;
377
+ left: 0;
378
+ top: 0;
379
+ width: 50%;
380
+ height: 100%;
381
+ }
382
+
383
+ /* 右半点击区 */
384
+ .star-tap-right {
385
+ position: absolute;
386
+ right: 0;
387
+ top: 0;
388
+ width: 50%;
389
+ height: 100%;
390
+ }
391
+
392
+ /* wxss */
393
+ .star-wrap {
394
+ position: relative;
395
+ display: inline-flex;
396
+ width: 32px; /* 和 van-icon size 保持一致 */
397
+ height: 32px;
398
+ overflow: hidden; /* 不需要,填充层自己 overflow hidden */
399
+ }
400
+
401
+ .star-fill {
402
+ position: absolute;
403
+ left: 0;
404
+ top: 0;
405
+ overflow: hidden;
406
+ /* width 由 style 动态设置,此时 % 相对于 32px 父容器计算,正常生效 */
407
+ }
408
+
409
+ .modal-star {
410
+ width: 40px;
411
+ height: 40px;
412
+ }
@@ -0,0 +1,52 @@
1
+ Component({
2
+ options: {
3
+ styleIsolation: 'apply-shared',
4
+ multipleSlots: true
5
+ },
6
+
7
+ properties: {
8
+ tabs: {
9
+ // 格式: [{ name: 'Tab A' }, { name: 'Tab B' }]
10
+ type: Array,
11
+ value: []
12
+ },
13
+ // 激活颜色,对应 van-tabs 的 color 参数
14
+ color: {
15
+ type: String,
16
+ value: '#1989fa'
17
+ },
18
+ // 受控模式:外部传入当前激活 tab 名
19
+ active: {
20
+ type: String,
21
+ value: ''
22
+ }
23
+ },
24
+
25
+ data: {
26
+ activeTab: ''
27
+ },
28
+
29
+ observers: {
30
+ 'tabs, active': function (tabs, active) {
31
+ if (!tabs || !tabs.length) return
32
+
33
+ // 如果外部传了 active 且合法,就用外部的;否则默认第一个
34
+ const names = tabs.map(t => t.name)
35
+ if (active && names.includes(active)) {
36
+ this.setData({ activeTab: active })
37
+ } else if (!this.data.activeTab || !names.includes(this.data.activeTab)) {
38
+ this.setData({ activeTab: tabs[0].name })
39
+ }
40
+ }
41
+ },
42
+
43
+ methods: {
44
+ onTabTap(e) {
45
+ const name = e.currentTarget.dataset.name
46
+ if (name === this.data.activeTab) return
47
+ this.setData({ activeTab: name })
48
+ // 触发 change 事件,与 van-tabs 保持一致,detail.name 是新 tab 名
49
+ this.triggerEvent('change', { name })
50
+ }
51
+ }
52
+ })
@@ -0,0 +1,3 @@
1
+ {
2
+ "component": true
3
+ }
@@ -0,0 +1,28 @@
1
+ <view class="wiki-tabs-root">
2
+ <!-- Tab 按钮栏 -->
3
+ <scroll-view scroll-x class="wiki-tabs-bar" enhanced="true" show-scrollbar="false">
4
+ <view class="wiki-tabs-bar-inner">
5
+ <view
6
+ wx:for="{{tabs}}"
7
+ wx:key="name"
8
+ wx:for-item="tab"
9
+ wx:for-index="ti"
10
+ class="wiki-tab-btn {{activeTab === tab.name ? 'active' : ''}}"
11
+ style="{{activeTab === tab.name ? 'background-color:' + (color || '#1989fa') + '; border-color:' + (color || '#1989fa') + ';' : ''}}"
12
+ bindtap="onTabTap"
13
+ data-name="{{tab.name}}"
14
+ >
15
+ <text class="wiki-tab-label {{activeTab === tab.name ? 'active' : ''}}">{{tab.name}}</text>
16
+ </view>
17
+ </view>
18
+ </scroll-view>
19
+
20
+ <!-- Tab 内容区 -->
21
+ <view class="wiki-tabs-content">
22
+ <block wx:for="{{tabs}}" wx:key="name" wx:for-item="tab">
23
+ <view wx:if="{{activeTab === tab.name}}">
24
+ <slot name="{{tab.name}}" />
25
+ </view>
26
+ </block>
27
+ </view>
28
+ </view>
@@ -0,0 +1,43 @@
1
+ .wiki-tabs-root {
2
+ width: 100%;
3
+ }
4
+
5
+ .wiki-tabs-bar {
6
+ width: 100%;
7
+ white-space: nowrap;
8
+ }
9
+
10
+ .wiki-tabs-bar-inner {
11
+ display: flex;
12
+ flex-direction: row;
13
+ align-items: center;
14
+ gap: 8rpx;
15
+ padding: 15px 0 15px;
16
+ }
17
+
18
+ .wiki-tab-btn {
19
+ flex-shrink: 0;
20
+ display: inline-flex;
21
+ align-items: center;
22
+ justify-content: center;
23
+ padding: 10rpx 28rpx;
24
+ border-radius: 40rpx;
25
+ border: 2rpx solid #d9d9d9;
26
+ background-color: #f5f5f5;
27
+ }
28
+
29
+ .wiki-tab-label {
30
+ font-size: 26rpx;
31
+ color: #555555;
32
+ font-weight: 400;
33
+ line-height: 1;
34
+ }
35
+
36
+ .wiki-tab-label.active {
37
+ color: #ffffff;
38
+ font-weight: 600;
39
+ }
40
+
41
+ .wiki-tabs-content {
42
+ width: 100%;
43
+ }