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.
- package/app.js +22 -0
- package/app.json +53 -0
- package/app.wxss +15 -0
- package/assets/file/badwords.js +63008 -0
- package/assets/file/rules.js +38 -0
- package/assets/images/emoji/smile001.png +0 -0
- package/assets/images/emoji/smile002.png +0 -0
- package/assets/images/emoji/smile003.png +0 -0
- package/assets/images/emoji/smile004.png +0 -0
- package/assets/images/emoji/smile005.png +0 -0
- package/assets/images/emoji/smile006.png +0 -0
- package/assets/images/emoji/smile007.png +0 -0
- package/assets/images/emoji/smile008.png +0 -0
- package/assets/images/emoji/smile009.png +0 -0
- package/assets/images/emoji/smile010.png +0 -0
- package/assets/images/emoji/smile011.png +0 -0
- package/assets/images/emoji/smile012.png +0 -0
- package/assets/images/emoji/smile013.png +0 -0
- package/assets/images/emoji/smile014.png +0 -0
- package/assets/images/emoji/smile015.png +0 -0
- package/assets/images/emoji/smile016.png +0 -0
- package/assets/images/emoji/smile017.png +0 -0
- package/assets/images/emoji/smile018.png +0 -0
- package/assets/images/emoji/smile019.png +0 -0
- package/assets/images/emoji/smile020.png +0 -0
- package/assets/images/emoji/smile021.png +0 -0
- package/assets/images/emoji/smile022.png +0 -0
- package/assets/images/emoji/smile023.png +0 -0
- package/assets/images/emoji/smile024.png +0 -0
- package/assets/images/emoji/smile025.png +0 -0
- package/assets/images/emoji/smile026.png +0 -0
- package/assets/images/emoji/smile027.png +0 -0
- package/assets/images/emoji/smile028.png +0 -0
- package/assets/images/emoji/smile029.png +0 -0
- package/assets/images/emoji/smile030.png +0 -0
- package/assets/images/emoji/smile031.png +0 -0
- package/assets/images/emoji/smile032.png +0 -0
- package/assets/images/emoji/smile033.png +0 -0
- package/assets/images/emoji/smile034.png +0 -0
- package/assets/images/emoji/smile035.png +0 -0
- package/assets/images/emoji/smile036.png +0 -0
- package/assets/images/emoji/smile037.png +0 -0
- package/assets/images/emoji/smile038.png +0 -0
- package/assets/images/emoji/smile039.png +0 -0
- package/assets/images/emoji/smile040.png +0 -0
- package/assets/images/emoji/smile041.png +0 -0
- package/assets/images/emoji/smile042.png +0 -0
- package/assets/images/emoji/smile043.png +0 -0
- package/assets/images/emoji/smile044.png +0 -0
- package/assets/images/emoji/smile045.png +0 -0
- package/assets/images/emoji/smile046.png +0 -0
- package/assets/images/emoji/smile047.png +0 -0
- package/assets/images/emoji/smile048.png +0 -0
- package/assets/images/emoji/smile049.png +0 -0
- package/assets/images/emoji/smile050.png +0 -0
- package/assets/images/emoji/smile051.png +0 -0
- package/assets/images/emoji/smile052.png +0 -0
- package/assets/images/icons/age1.png +0 -0
- package/assets/images/icons/age2.png +0 -0
- package/assets/images/icons/age3.png +0 -0
- package/assets/images/icons/attachment.png +0 -0
- package/assets/images/icons/clear.png +0 -0
- package/assets/images/icons/edit_input.png +0 -0
- package/assets/images/icons/header_placeholder.png +0 -0
- package/assets/images/icons/home_collect.png +0 -0
- package/assets/images/icons/home_collected.png +0 -0
- package/assets/images/icons/home_comment.png +0 -0
- package/assets/images/icons/home_like.png +0 -0
- package/assets/images/icons/home_liked.png +0 -0
- package/assets/images/icons/home_message.png +0 -0
- package/assets/images/icons/home_share.png +0 -0
- package/assets/images/icons/icon_more.png +0 -0
- package/assets/images/icons/input_game.png +0 -0
- package/assets/images/icons/logo.png +0 -0
- package/assets/images/icons/lv1.png +0 -0
- package/assets/images/icons/lv2.png +0 -0
- package/assets/images/icons/lv3.png +0 -0
- package/assets/images/icons/lv4.png +0 -0
- package/assets/images/icons/search.png +0 -0
- package/assets/images/icons/sex1.png +0 -0
- package/assets/images/icons/sex2.png +0 -0
- package/assets/images/icons/sign_empty.png +0 -0
- package/assets/images/icons/sign_login.png +0 -0
- package/assets/wheel/wheel_bg.png +0 -0
- package/assets/wheel/wheel_bg2.png +0 -0
- package/assets/wheel/wheel_fore.png +0 -0
- package/assets/wheel/wheel_to.png +0 -0
- package/components/bottomSheet/bottomSheet.js +473 -0
- package/components/bottomSheet/bottomSheet.json +3 -0
- package/components/bottomSheet/bottomSheet.wxml +73 -0
- package/components/bottomSheet/bottomSheet.wxss +238 -0
- package/components/experience-item/experience-item.js +105 -0
- package/components/experience-item/experience-item.json +4 -0
- package/components/experience-item/experience-item.wxml +39 -0
- package/components/experience-item/experience-item.wxss +110 -0
- package/components/grid-item/grid-item.js +8 -0
- package/components/grid-item/grid-item.json +4 -0
- package/components/grid-item/grid-item.wxml +62 -0
- package/components/grid-item/grid-item.wxss +191 -0
- package/components/post-item/post-item.js +1085 -0
- package/components/post-item/post-item.json +4 -0
- package/components/post-item/post-item.wxml +427 -0
- package/components/post-item/post-item.wxss +525 -0
- package/components/wiki-renderer/wiki-renderer.js +636 -0
- package/components/wiki-renderer/wiki-renderer.json +12 -0
- package/components/wiki-renderer/wiki-renderer.wxml +150 -0
- package/components/wiki-renderer/wiki-renderer.wxss +412 -0
- package/components/wiki-tabs/wiki-tabs.js +52 -0
- package/components/wiki-tabs/wiki-tabs.json +3 -0
- package/components/wiki-tabs/wiki-tabs.wxml +28 -0
- package/components/wiki-tabs/wiki-tabs.wxss +43 -0
- package/index.js +49 -0
- package/package.json +35 -0
- package/pages/addGame/addGame.js +454 -0
- package/pages/addGame/addGame.json +3 -0
- package/pages/addGame/addGame.wxml +71 -0
- package/pages/addGame/addGame.wxss +110 -0
- package/pages/addSubject/addSubject.js +199 -0
- package/pages/addSubject/addSubject.json +4 -0
- package/pages/addSubject/addSubject.wxml +78 -0
- package/pages/addSubject/addSubject.wxss +85 -0
- package/pages/commonLogin/commonLogin.js +269 -0
- package/pages/commonLogin/commonLogin.json +4 -0
- package/pages/commonLogin/commonLogin.wxml +57 -0
- package/pages/commonLogin/commonLogin.wxss +177 -0
- package/pages/copyOfficial/copyOfficial.js +25 -0
- package/pages/copyOfficial/copyOfficial.json +3 -0
- package/pages/copyOfficial/copyOfficial.wxml +22 -0
- package/pages/copyOfficial/copyOfficial.wxss +49 -0
- package/pages/demo/demo.js +23 -0
- package/pages/demo/demo.json +3 -0
- package/pages/demo/demo.wxml +8 -0
- package/pages/demo/demo.wxss +24 -0
- package/pages/game/game.js +1254 -0
- package/pages/game/game.json +8 -0
- package/pages/game/game.wxml +371 -0
- package/pages/game/game.wxss +672 -0
- package/pages/home/home.js +665 -0
- package/pages/home/home.json +10 -0
- package/pages/home/home.wxml +115 -0
- package/pages/home/home.wxss +231 -0
- package/pages/lottery-winners/lottery-winners.js +60 -0
- package/pages/lottery-winners/lottery-winners.json +4 -0
- package/pages/lottery-winners/lottery-winners.wxml +53 -0
- package/pages/lottery-winners/lottery-winners.wxss +127 -0
- package/pages/message/messageCommentsAndAt/messageCommentsAndAt.js +178 -0
- package/pages/message/messageCommentsAndAt/messageCommentsAndAt.json +5 -0
- package/pages/message/messageCommentsAndAt/messageCommentsAndAt.wxml +93 -0
- package/pages/message/messageCommentsAndAt/messageCommentsAndAt.wxss +177 -0
- package/pages/message/messageEntire/messageEntire.js +112 -0
- package/pages/message/messageEntire/messageEntire.json +4 -0
- package/pages/message/messageEntire/messageEntire.wxml +44 -0
- package/pages/message/messageEntire/messageEntire.wxss +88 -0
- package/pages/message/messageLikeAndCollect/messageLikeAndCollect.js +147 -0
- package/pages/message/messageLikeAndCollect/messageLikeAndCollect.json +5 -0
- package/pages/message/messageLikeAndCollect/messageLikeAndCollect.wxml +84 -0
- package/pages/message/messageLikeAndCollect/messageLikeAndCollect.wxss +166 -0
- package/pages/message/messageNewFans/messageNewFans.js +139 -0
- package/pages/message/messageNewFans/messageNewFans.json +5 -0
- package/pages/message/messageNewFans/messageNewFans.wxml +35 -0
- package/pages/message/messageNewFans/messageNewFans.wxss +85 -0
- package/pages/officialWebview/officialWebview.js +13 -0
- package/pages/officialWebview/officialWebview.json +3 -0
- package/pages/officialWebview/officialWebview.wxml +2 -0
- package/pages/officialWebview/officialWebview.wxss +1 -0
- package/pages/post/post.js +1856 -0
- package/pages/post/post.json +6 -0
- package/pages/post/post.wxml +694 -0
- package/pages/post/post.wxss +1003 -0
- package/pages/post-editor/post-editor.js +465 -0
- package/pages/post-editor/post-editor.json +4 -0
- package/pages/post-editor/post-editor.wxml +63 -0
- package/pages/post-editor/post-editor.wxss +195 -0
- package/pages/postDialog/postDialog.js +560 -0
- package/pages/postDialog/postDialog.json +6 -0
- package/pages/postDialog/postDialog.wxml +377 -0
- package/pages/postDialog/postDialog.wxss +979 -0
- package/pages/report-category/report-category.js +29 -0
- package/pages/report-category/report-category.json +4 -0
- package/pages/report-category/report-category.wxml +14 -0
- package/pages/report-category/report-category.wxss +43 -0
- package/pages/report-form/report-form.js +65 -0
- package/pages/report-form/report-form.json +3 -0
- package/pages/report-form/report-form.wxml +11 -0
- package/pages/report-form/report-form.wxss +44 -0
- package/pages/sevenDaySignDetail/sevenDaySignDetail.js +273 -0
- package/pages/sevenDaySignDetail/sevenDaySignDetail.json +3 -0
- package/pages/sevenDaySignDetail/sevenDaySignDetail.wxml +82 -0
- package/pages/sevenDaySignDetail/sevenDaySignDetail.wxss +173 -0
- package/pages/topic/topic.js +266 -0
- package/pages/topic/topic.json +6 -0
- package/pages/topic/topic.wxml +77 -0
- package/pages/topic/topic.wxss +162 -0
- package/pages/user/user.js +939 -0
- package/pages/user/user.json +5 -0
- package/pages/user/user.wxml +179 -0
- package/pages/user/user.wxss +340 -0
- package/pages/userDatum/userDatum.js +24 -0
- package/pages/userDatum/userDatum.json +4 -0
- package/pages/userDatum/userDatum.wxml +36 -0
- package/pages/userDatum/userDatum.wxss +41 -0
- package/pages/userGameLib/userGameLib.js +105 -0
- package/pages/userGameLib/userGameLib.json +4 -0
- package/pages/userGameLib/userGameLib.wxml +42 -0
- package/pages/userGameLib/userGameLib.wxss +119 -0
- package/pages/webview/webview.js +25 -0
- package/pages/webview/webview.json +3 -0
- package/pages/webview/webview.wxml +22 -0
- package/pages/webview/webview.wxss +50 -0
- package/pages/wheelActivivty/wheelActivivty.js +492 -0
- package/pages/wheelActivivty/wheelActivivty.json +8 -0
- package/pages/wheelActivivty/wheelActivivty.wxml +131 -0
- package/pages/wheelActivivty/wheelActivivty.wxss +459 -0
- package/pages/wiki/wiki.js +138 -0
- package/pages/wiki/wiki.json +6 -0
- package/pages/wiki/wiki.wxml +20 -0
- package/pages/wiki/wiki.wxss +44 -0
- package/request/JKRequest.js +177 -0
- package/services/home.js +603 -0
- package/towxml/config.js +291 -0
- package/towxml/decode.js +35 -0
- package/towxml/decode.json +11 -0
- package/towxml/decode.wxml +137 -0
- package/towxml/decode.wxss +0 -0
- package/towxml/img/img.js +98 -0
- package/towxml/img/img.json +3 -0
- package/towxml/img/img.wxml +1 -0
- package/towxml/img/img.wxss +0 -0
- package/towxml/index.js +19 -0
- package/towxml/latex/latex.js +53 -0
- package/towxml/latex/latex.json +5 -0
- package/towxml/latex/latex.wxml +1 -0
- package/towxml/latex/latex.wxss +0 -0
- package/towxml/parse/highlight/highlight.js +1 -0
- package/towxml/parse/highlight/index.js +8 -0
- package/towxml/parse/highlight/languages/bash.js +111 -0
- package/towxml/parse/highlight/languages/c-like.js +236 -0
- package/towxml/parse/highlight/languages/c.js +22 -0
- package/towxml/parse/highlight/languages/css.js +132 -0
- package/towxml/parse/highlight/languages/dart.js +134 -0
- package/towxml/parse/highlight/languages/go.js +63 -0
- package/towxml/parse/highlight/languages/htmlbars.js +80 -0
- package/towxml/parse/highlight/languages/java.js +125 -0
- package/towxml/parse/highlight/languages/javascript.js +265 -0
- package/towxml/parse/highlight/languages/json.js +52 -0
- package/towxml/parse/highlight/languages/less.js +148 -0
- package/towxml/parse/highlight/languages/nginx.js +101 -0
- package/towxml/parse/highlight/languages/php.js +161 -0
- package/towxml/parse/highlight/languages/python-repl.js +29 -0
- package/towxml/parse/highlight/languages/python.js +131 -0
- package/towxml/parse/highlight/languages/scss.js +122 -0
- package/towxml/parse/highlight/languages/shell.js +22 -0
- package/towxml/parse/highlight/languages/typescript.js +215 -0
- package/towxml/parse/highlight/languages/xml.js +139 -0
- package/towxml/parse/highlight/style/github.wxss +99 -0
- package/towxml/parse/highlight/style/monokai.wxss +70 -0
- package/towxml/parse/index.js +118 -0
- package/towxml/parse/markdown/index.js +67 -0
- package/towxml/parse/markdown/markdown.js +4 -0
- package/towxml/parse/markdown/plugins/echarts.js +11 -0
- package/towxml/parse/markdown/plugins/emoji.js +2 -0
- package/towxml/parse/markdown/plugins/ins.js +1 -0
- package/towxml/parse/markdown/plugins/latex.js +158 -0
- package/towxml/parse/markdown/plugins/mark.js +1 -0
- package/towxml/parse/markdown/plugins/sub.js +1 -0
- package/towxml/parse/markdown/plugins/sup.js +1 -0
- package/towxml/parse/markdown/plugins/todo.js +147 -0
- package/towxml/parse/markdown/plugins/yuml.js +20 -0
- package/towxml/parse/parse2/Parser.js +492 -0
- package/towxml/parse/parse2/Tokenizer.js +903 -0
- package/towxml/parse/parse2/domelementtype/index.js +55 -0
- package/towxml/parse/parse2/domhandler/index.js +145 -0
- package/towxml/parse/parse2/domhandler/node.js +474 -0
- package/towxml/parse/parse2/entities/decode.js +179 -0
- package/towxml/parse/parse2/entities/decode_codepoint.js +60 -0
- package/towxml/parse/parse2/entities/encode.js +77 -0
- package/towxml/parse/parse2/entities/escape.js +112 -0
- package/towxml/parse/parse2/entities/generated/decode-data-html.js +9 -0
- package/towxml/parse/parse2/entities/generated/decode-data-xml.js +9 -0
- package/towxml/parse/parse2/entities/generated/encode-html.js +12 -0
- package/towxml/parse/parse2/entities/index.js +137 -0
- package/towxml/parse/parse2/index.js +8 -0
- package/towxml/style/main.wxss +419 -0
- package/towxml/style/theme/dark.wxss +73 -0
- package/towxml/style/theme/light.wxss +63 -0
- package/towxml/table/table.js +11 -0
- package/towxml/table/table.json +6 -0
- package/towxml/table/table.wxml +24 -0
- package/towxml/table/table.wxss +0 -0
- package/towxml/todogroup/todogroup.js +20 -0
- package/towxml/todogroup/todogroup.json +6 -0
- package/towxml/todogroup/todogroup.wxml +12 -0
- package/towxml/todogroup/todogroup.wxss +3 -0
- package/towxml/towxml.js +22 -0
- package/towxml/towxml.json +6 -0
- package/towxml/towxml.wxml +5 -0
- package/towxml/towxml.wxss +8 -0
- package/towxml/yuml/yuml.js +51 -0
- package/towxml/yuml/yuml.json +5 -0
- package/towxml/yuml/yuml.wxml +5 -0
- package/towxml/yuml/yuml.wxss +0 -0
- package/utils/auth.js +17 -0
- package/utils/base64.js +67 -0
- package/utils/compressImage.js +41 -0
- package/utils/exp.js +49 -0
- package/utils/formatPost.js +18 -0
- package/utils/parseContent.js +191 -0
- package/utils/query-select.js +9 -0
- package/utils/sensitive.js +82 -0
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
import {
|
|
2
|
+
queryUserMessages
|
|
3
|
+
} from '../../../services/home';
|
|
4
|
+
import {
|
|
5
|
+
parseContent
|
|
6
|
+
} from '../../../utils/parseContent';
|
|
7
|
+
Page({
|
|
8
|
+
data: {
|
|
9
|
+
list: [],
|
|
10
|
+
page: 1,
|
|
11
|
+
isRefreshing: false,
|
|
12
|
+
isLoadingMore: false,
|
|
13
|
+
hasMore: true,
|
|
14
|
+
myAvatar: '',
|
|
15
|
+
loading: true,
|
|
16
|
+
},
|
|
17
|
+
|
|
18
|
+
onLoad() {
|
|
19
|
+
this.fetchData(true);
|
|
20
|
+
|
|
21
|
+
this.setData({
|
|
22
|
+
myAvatar: wx.getStorageSync('avatar') || '/assets/images/icons/header_placeholder.png',
|
|
23
|
+
})
|
|
24
|
+
},
|
|
25
|
+
|
|
26
|
+
onPullDownRefresh() {
|
|
27
|
+
if (this.data.isRefreshing) return;
|
|
28
|
+
|
|
29
|
+
this.setData({
|
|
30
|
+
page: 1,
|
|
31
|
+
isRefreshing: true,
|
|
32
|
+
hasMore: true
|
|
33
|
+
}, () => {
|
|
34
|
+
this.fetchData(true);
|
|
35
|
+
});
|
|
36
|
+
},
|
|
37
|
+
|
|
38
|
+
onReachBottom() {
|
|
39
|
+
if (!this.data.hasMore || this.data.isLoadingMore) return;
|
|
40
|
+
|
|
41
|
+
this.setData({
|
|
42
|
+
isLoadingMore: true
|
|
43
|
+
}, () => {
|
|
44
|
+
this.fetchData(false);
|
|
45
|
+
});
|
|
46
|
+
},
|
|
47
|
+
|
|
48
|
+
fetchData(isRefresh) {
|
|
49
|
+
const page = this.data.page;
|
|
50
|
+
|
|
51
|
+
queryUserMessages(page, 3).then(res => {
|
|
52
|
+
let newList = Array.isArray(res.data) ? res.data : [];
|
|
53
|
+
|
|
54
|
+
newList = newList.map(item => {
|
|
55
|
+
let cover = '/assets/images/icons/header_placeholder.png';
|
|
56
|
+
|
|
57
|
+
if (item.main?.post?.images) {
|
|
58
|
+
cover = item.main.post.images.split(',')[0];
|
|
59
|
+
} else if (item.main?.user?.avatar) {
|
|
60
|
+
cover = item.main.user.avatar;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
item.mainCover = cover;
|
|
64
|
+
|
|
65
|
+
// 时间
|
|
66
|
+
item.operation._timeText = this.formatTime(item.operation.created_at);
|
|
67
|
+
|
|
68
|
+
// ✅ 直接用你封装好的方法
|
|
69
|
+
item.roleContentParts = parseContent(
|
|
70
|
+
item.role?.post?.content || ''
|
|
71
|
+
);
|
|
72
|
+
item.mainContentParts = parseContent(
|
|
73
|
+
item.main?.post?.content || ''
|
|
74
|
+
);
|
|
75
|
+
|
|
76
|
+
// 解析 upper,如果存在
|
|
77
|
+
if (item.upper) {
|
|
78
|
+
const parts = [];
|
|
79
|
+
|
|
80
|
+
// 添加 @user.nickname
|
|
81
|
+
if (item.upper.user?.nickname) {
|
|
82
|
+
parts.push({
|
|
83
|
+
text: `@${item.upper.user.nickname}`,
|
|
84
|
+
color: '#406ce3'
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
// 如果 upper.post 有 reply_nickname
|
|
89
|
+
if (item.upper.post?.reply_nickname) {
|
|
90
|
+
parts.push({
|
|
91
|
+
text: ' 回复 ',
|
|
92
|
+
color: '#333'
|
|
93
|
+
});
|
|
94
|
+
parts.push({
|
|
95
|
+
text: `@${item.upper.post.reply_nickname}`,
|
|
96
|
+
color: '#406ce3'
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
// 补冒号
|
|
101
|
+
if (item.upper.post?.status !== 3) {
|
|
102
|
+
parts.push({
|
|
103
|
+
text: ': ',
|
|
104
|
+
color: '#333'
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
// 拼接正文
|
|
109
|
+
if (item.upper.post?.content) {
|
|
110
|
+
parts.push(...parseContent(item.upper.post.content));
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
|
|
114
|
+
|
|
115
|
+
// 图片数组转成 [查看图片]
|
|
116
|
+
if (item.upper.post?.images) {
|
|
117
|
+
const imgArray = item.upper.post.images.split(',');
|
|
118
|
+
imgArray.forEach((src, idx) => {
|
|
119
|
+
parts.push({
|
|
120
|
+
text: '[图片]',
|
|
121
|
+
type: 'view_img',
|
|
122
|
+
src,
|
|
123
|
+
index: idx,
|
|
124
|
+
from: 'upper',
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
item.upperContentParts = parts;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
// 如果你暂时不处理图片,这里可以先不加任何逻辑
|
|
132
|
+
|
|
133
|
+
return item;
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
this.setData({
|
|
137
|
+
list: isRefresh ? newList : this.data.list.concat(newList),
|
|
138
|
+
page: isRefresh ? 2 : page + 1,
|
|
139
|
+
hasMore: newList.length > 0,
|
|
140
|
+
isRefreshing: false,
|
|
141
|
+
isLoadingMore: false
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
wx.stopPullDownRefresh();
|
|
145
|
+
}).finally(() => {
|
|
146
|
+
this.setData({
|
|
147
|
+
loading: false
|
|
148
|
+
});
|
|
149
|
+
});
|
|
150
|
+
},
|
|
151
|
+
|
|
152
|
+
formatTime(timestamp) {
|
|
153
|
+
const date = new Date(timestamp * 1000);
|
|
154
|
+
const m = date.getMonth() + 1;
|
|
155
|
+
const d = date.getDate();
|
|
156
|
+
const h = date.getHours();
|
|
157
|
+
const mi = date.getMinutes();
|
|
158
|
+
return `${m}-${d} ${h}:${mi < 10 ? '0' + mi : mi}`;
|
|
159
|
+
},
|
|
160
|
+
|
|
161
|
+
goDetail(e) {
|
|
162
|
+
const postId = e.currentTarget.dataset.id;
|
|
163
|
+
wx.navigateTo({
|
|
164
|
+
url: `/pages/post/post?id=${postId}`
|
|
165
|
+
});
|
|
166
|
+
},
|
|
167
|
+
goUserDetail(e) {
|
|
168
|
+
const userId = e.currentTarget.dataset.id;
|
|
169
|
+
wx.navigateTo({
|
|
170
|
+
url: `/pages/user/user?id=${userId}`
|
|
171
|
+
// url: '/pages/customNavPage/customNavPage'
|
|
172
|
+
|
|
173
|
+
});
|
|
174
|
+
},
|
|
175
|
+
|
|
176
|
+
|
|
177
|
+
|
|
178
|
+
});
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
<van-van-skeleton title avatar row="8" loading="{{ loading }}">
|
|
2
|
+
<view class="container">
|
|
3
|
+
<!-- 列表 -->
|
|
4
|
+
<block wx:for="{{list}}" wx:key="index">
|
|
5
|
+
<view class="cell" catchtap="goDetail" data-id="{{item.role.post.id}}">
|
|
6
|
+
<!-- 左侧头像 -->
|
|
7
|
+
<image class="avatar" src="{{item.role.user.avatar || '/assets/images/icons/header_placeholder.png'}}" mode="cover" catchtap="goUserDetail" data-id="{{item.role.user.id}}" />
|
|
8
|
+
|
|
9
|
+
<!-- 右侧内容 -->
|
|
10
|
+
<view class="right">
|
|
11
|
+
<!-- 上行昵称 + 动作文字 -->
|
|
12
|
+
<view class="top">
|
|
13
|
+
<span class="nickname">{{item.role.user.nickname}}</span>
|
|
14
|
+
<span class="action-text">
|
|
15
|
+
{{item.operation.type === 'share' ? '转发了你' : (item.operation.type === 'comment' ? '回复了你' : ' @了你')}}
|
|
16
|
+
</span>
|
|
17
|
+
<text wx:if="{{item.operation.is_read === 0}}" style="background-color: #f44336;font-size: 20rpx;font-weight: bold;color: white;padding: 5rpx 9rpx;border-radius: 10rpx; margin-left:8rpx;">新</text>
|
|
18
|
+
</view>
|
|
19
|
+
|
|
20
|
+
<!-- 第二行:role.post内容 -->
|
|
21
|
+
<view class="comment-text" wx:if="{{item.roleContentParts.length}}">
|
|
22
|
+
<block wx:for="{{item.roleContentParts}}" wx:for-item="part" wx:key="index">
|
|
23
|
+
<!-- 普通文字 -->
|
|
24
|
+
<span wx:if="{{!part.type}}" style="color: {{part.color || '#333'}}; font-weight: {{part.bold ? 'bold' : 'normal'}};">{{part.text}}</span>
|
|
25
|
+
|
|
26
|
+
<!-- emoji -->
|
|
27
|
+
<image wx:if="{{part.type === 'emoji'}}" class="emoji" src="{{part.src}}" style="width:24rpx;height:24rpx;vertical-align:middle;" />
|
|
28
|
+
|
|
29
|
+
<!-- 换行 -->
|
|
30
|
+
<span wx:if="{{part.type === 'br'}}"><br /></span>
|
|
31
|
+
|
|
32
|
+
<!-- @用户 -->
|
|
33
|
+
<span wx:if="{{part.type === 'at'}}" data-userid="{{part.userId}}" bindtap="goUserDetail">{{part.text}}</span>
|
|
34
|
+
|
|
35
|
+
<!-- #话题# -->
|
|
36
|
+
<span wx:if="{{part.type === 'topic'}}">{{part.text}}</span>
|
|
37
|
+
</block>
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
<!-- upper 内容 -->
|
|
41
|
+
<span wx:if="{{item.upperContentParts && item.upperContentParts.length}}">//</span>
|
|
42
|
+
<block wx:if="{{item.upperContentParts && item.upperContentParts.length}}" wx:for="{{item.upperContentParts}}" wx:for-item="part" wx:key="index">
|
|
43
|
+
<span wx:if="{{!part.type}}" style=" font-weight: {{part.bold ? 'bold' : 'normal'}};">{{part.text}}</span>
|
|
44
|
+
<image wx:if="{{part.type === 'emoji'}}" class="emoji" src="{{part.src}}" style="width:24rpx;height:24rpx;vertical-align:middle;" />
|
|
45
|
+
<span wx:if="{{part.type === 'br'}}"><br /></span>
|
|
46
|
+
<span wx:if="{{part.type === 'at'}}" data-userid="{{part.userId}}" bindtap="goUserDetail">{{part.text}}</span>
|
|
47
|
+
<span wx:if="{{part.type === 'topic'}}">{{part.text}}</span>
|
|
48
|
+
<span wx:if="{{part.type === 'view_img'}}" bindtap="viewImage" data-src="{{part.src}}">[查看图片]</span>
|
|
49
|
+
</block>
|
|
50
|
+
|
|
51
|
+
</view>
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
<!-- 原帖内容 -->
|
|
56
|
+
<view class="post-content" wx:if="{{item.main && item.main.post}}">
|
|
57
|
+
<image class="post-img" src="{{item.mainCover }}" mode="cover" />
|
|
58
|
+
<view class="post-text" style="color: #919191;">
|
|
59
|
+
<span style="color: #919191; font-weight: {{part.bold ? 'bold' : 'normal'}};">@{{item.main.user.nickname}}:</span>
|
|
60
|
+
|
|
61
|
+
<block wx:for="{{item.mainContentParts}}" wx:for-item="part" wx:key="index">
|
|
62
|
+
<span wx:if="{{!part.type}}" style="color: #919191; font-weight: {{part.bold ? 'bold' : 'normal'}};">{{part.text}}</span>
|
|
63
|
+
<image wx:if="{{part.type === 'emoji'}}" class="emoji" src="{{part.src}}" style="width:24rpx;height:24rpx;vertical-align:middle;" />
|
|
64
|
+
<span wx:if="{{part.type === 'br'}}"><br /></span>
|
|
65
|
+
<span wx:if="{{part.type === 'at'}}" data-userid="{{part.userId}}" bindtap="goUserDetail">{{part.text}}</span>
|
|
66
|
+
<span wx:if="{{part.type === 'topic'}}">{{part.text}}</span>
|
|
67
|
+
</block>
|
|
68
|
+
</view>
|
|
69
|
+
</view>
|
|
70
|
+
|
|
71
|
+
<!-- 原帖已删除 -->
|
|
72
|
+
<view wx:if="{{item.main && !item.main.post}}" class="post-content deleted">
|
|
73
|
+
原文已被删除
|
|
74
|
+
</view>
|
|
75
|
+
|
|
76
|
+
<view wx:if="{{item.main && item.main.user.status === 3}}" class="post-content deleted">
|
|
77
|
+
原文账户被封禁,已无法查看
|
|
78
|
+
</view>
|
|
79
|
+
|
|
80
|
+
<!-- 操作时间 -->
|
|
81
|
+
<view class="time">{{item.operation._timeText}}</view>
|
|
82
|
+
</view>
|
|
83
|
+
</view>
|
|
84
|
+
</block>
|
|
85
|
+
|
|
86
|
+
<!-- 列表为空 -->
|
|
87
|
+
<view wx:if="{{list.length === 0 && !isRefreshing}}" class="no-data">暂无消息</view>
|
|
88
|
+
|
|
89
|
+
<!-- 底部加载/无更多 提示 -->
|
|
90
|
+
<view class="list-footer" wx:if="{{isLoadingMore}}">加载中...</view>
|
|
91
|
+
<view class="list-footer" wx:if="{{!hasMore && list.length>0}}">没有更多了</view>
|
|
92
|
+
</view>
|
|
93
|
+
</van-van-skeleton>
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
/* 容器 */
|
|
2
|
+
.container {
|
|
3
|
+
background-color: #f5f4f9;
|
|
4
|
+
padding: 0;
|
|
5
|
+
min-height: 100vh;
|
|
6
|
+
box-sizing: border-box;
|
|
7
|
+
display: flex;
|
|
8
|
+
flex-direction: column;
|
|
9
|
+
justify-content: flex-start;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
/* 每一条 cell */
|
|
13
|
+
.cell {
|
|
14
|
+
display: flex;
|
|
15
|
+
width: 100%;
|
|
16
|
+
padding: 10px 20px;
|
|
17
|
+
background-color: #fff;
|
|
18
|
+
border-radius: 6px;
|
|
19
|
+
align-items: flex-start;
|
|
20
|
+
box-sizing: border-box;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/* 头像 */
|
|
24
|
+
.avatar {
|
|
25
|
+
width: 40px;
|
|
26
|
+
height: 40px;
|
|
27
|
+
border-radius: 50%;
|
|
28
|
+
background-color: #eee;
|
|
29
|
+
flex-shrink: 0;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
/* 右侧内容 */
|
|
33
|
+
.right {
|
|
34
|
+
flex: 1;
|
|
35
|
+
margin-left: 10px;
|
|
36
|
+
display: flex;
|
|
37
|
+
flex-direction: column;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/* 上行昵称 + 动作文字 */
|
|
41
|
+
.top {
|
|
42
|
+
display: flex;
|
|
43
|
+
align-items: center;
|
|
44
|
+
margin-bottom: 6px;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
.nickname {
|
|
48
|
+
font-weight: bold;
|
|
49
|
+
margin-right: 6px;
|
|
50
|
+
font-size: 14px;
|
|
51
|
+
color: #333;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.action-text {
|
|
55
|
+
color: #666;
|
|
56
|
+
font-size: 14px;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/* comment-text 和 post-text */
|
|
60
|
+
.comment-text,
|
|
61
|
+
.post-text {
|
|
62
|
+
font-size: 14px;
|
|
63
|
+
line-height: 1.4;
|
|
64
|
+
|
|
65
|
+
display: -webkit-box; /* 关键 */
|
|
66
|
+
-webkit-box-orient: vertical; /* 关键 */
|
|
67
|
+
-webkit-line-clamp: 2; /* 显示 2 行 */
|
|
68
|
+
|
|
69
|
+
overflow: hidden;
|
|
70
|
+
text-overflow: ellipsis;
|
|
71
|
+
|
|
72
|
+
word-break: break-word;
|
|
73
|
+
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
/* 内部 span 和 emoji */
|
|
78
|
+
.comment-text span,
|
|
79
|
+
.comment-text image,
|
|
80
|
+
.post-text span,
|
|
81
|
+
.post-text image {
|
|
82
|
+
/* display: inline-block; */
|
|
83
|
+
vertical-align: middle;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
/* emoji 图片 */
|
|
87
|
+
.comment-text .emoji,
|
|
88
|
+
.post-text .emoji {
|
|
89
|
+
width: 18px;
|
|
90
|
+
height: 18px;
|
|
91
|
+
margin: 0 2px;
|
|
92
|
+
vertical-align: middle;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/* 游戏、网页链接、话题、@用户 */
|
|
96
|
+
.comment-text .game,
|
|
97
|
+
.comment-text .jump_url,
|
|
98
|
+
.comment-text .topic,
|
|
99
|
+
.comment-text .at,
|
|
100
|
+
.post-text .game,
|
|
101
|
+
.post-text .jump_url,
|
|
102
|
+
.post-text .topic,
|
|
103
|
+
.post-text .at {
|
|
104
|
+
color: #406ce3;
|
|
105
|
+
cursor: pointer;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
/* [查看图片] 占位 */
|
|
109
|
+
.comment-text .view_img,
|
|
110
|
+
.post-text .view_img {
|
|
111
|
+
color: #406ce3;
|
|
112
|
+
cursor: pointer;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
/* 换行 */
|
|
116
|
+
.comment-text .br,
|
|
117
|
+
.post-text .br {
|
|
118
|
+
display: block;
|
|
119
|
+
height: 4px;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
/* 加粗文字 */
|
|
123
|
+
.comment-text .bold,
|
|
124
|
+
.post-text .bold {
|
|
125
|
+
font-weight: bold;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
/* 原帖内容块 */
|
|
129
|
+
.post-content {
|
|
130
|
+
display: flex;
|
|
131
|
+
background-color: #f5f5f5;
|
|
132
|
+
border-radius: 4px;
|
|
133
|
+
margin: 6px 0;
|
|
134
|
+
align-items: flex-start;
|
|
135
|
+
box-sizing: border-box;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
/* 已删除的原帖 */
|
|
139
|
+
.post-content.deleted {
|
|
140
|
+
padding: 10px;
|
|
141
|
+
justify-content: center;
|
|
142
|
+
align-items: center;
|
|
143
|
+
color: #999;
|
|
144
|
+
font-size: 14px;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
/* 原帖图片 */
|
|
148
|
+
.post-img {
|
|
149
|
+
flex-shrink: 0;
|
|
150
|
+
width: 40px;
|
|
151
|
+
height: 40px;
|
|
152
|
+
margin-right: 8px;
|
|
153
|
+
object-fit: cover;
|
|
154
|
+
background-color: #ddd;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
/* 操作时间 */
|
|
158
|
+
.time {
|
|
159
|
+
margin-top: 3rpx;
|
|
160
|
+
font-size: 12px;
|
|
161
|
+
color: #999;
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
/* 列表为空提示 */
|
|
165
|
+
.no-data {
|
|
166
|
+
text-align: center;
|
|
167
|
+
color: #999;
|
|
168
|
+
margin-top: 20px;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
/* 底部加载提示 */
|
|
172
|
+
.list-footer {
|
|
173
|
+
text-align: center;
|
|
174
|
+
padding: 12px 0;
|
|
175
|
+
color: #999;
|
|
176
|
+
font-size: 13px;
|
|
177
|
+
}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import {
|
|
2
|
+
queryUserNotRead,
|
|
3
|
+
cleanUserMessages
|
|
4
|
+
} from '../../../services/home'
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
Page({
|
|
9
|
+
data: {
|
|
10
|
+
selectedType: 'like',
|
|
11
|
+
unread: {
|
|
12
|
+
like: 0,
|
|
13
|
+
fans: 0,
|
|
14
|
+
comment: 0
|
|
15
|
+
},
|
|
16
|
+
messages: {
|
|
17
|
+
like: [],
|
|
18
|
+
fans: [],
|
|
19
|
+
comment: []
|
|
20
|
+
},
|
|
21
|
+
statusBarHeight: 20,
|
|
22
|
+
navHeight: 44
|
|
23
|
+
},
|
|
24
|
+
|
|
25
|
+
onLoad() {
|
|
26
|
+
const systemInfo = wx.getWindowInfo();
|
|
27
|
+
const statusBarHeight = systemInfo.statusBarHeight;
|
|
28
|
+
const navHeight = 44; // 自定义导航栏高度
|
|
29
|
+
this.setData({
|
|
30
|
+
statusBarHeight,
|
|
31
|
+
navHeight,
|
|
32
|
+
topOffset: statusBarHeight + navHeight
|
|
33
|
+
});
|
|
34
|
+
},
|
|
35
|
+
|
|
36
|
+
onShow() {
|
|
37
|
+
this.getUnreadCounts(); // 每次显示页面刷新角标
|
|
38
|
+
},
|
|
39
|
+
|
|
40
|
+
// 获取未读数量
|
|
41
|
+
getUnreadCounts() {
|
|
42
|
+
queryUserNotRead().then(res => {
|
|
43
|
+
if (res.count && Array.isArray(res.count)) {
|
|
44
|
+
const [like = 0, fans = 0, comment = 0] = res.count;
|
|
45
|
+
this.setData({
|
|
46
|
+
unread: {
|
|
47
|
+
like,
|
|
48
|
+
fans,
|
|
49
|
+
comment
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
}).catch(err => {
|
|
54
|
+
console.error('获取未读消息失败', err);
|
|
55
|
+
});
|
|
56
|
+
},
|
|
57
|
+
|
|
58
|
+
// 切换顶部选项
|
|
59
|
+
selectOption(e) {
|
|
60
|
+
const type = e.currentTarget.dataset.type;
|
|
61
|
+
this.setData({
|
|
62
|
+
[`unread.${type}`]: 0
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
if (type === 'like') {
|
|
66
|
+
wx.navigateTo({
|
|
67
|
+
url: '/pages/message/messageLikeAndCollect/messageLikeAndCollect',
|
|
68
|
+
})
|
|
69
|
+
}
|
|
70
|
+
if (type === 'fans') {
|
|
71
|
+
wx.navigateTo({
|
|
72
|
+
url: '/pages/message/messageNewFans/messageNewFans',
|
|
73
|
+
})
|
|
74
|
+
}
|
|
75
|
+
if (type === 'comment') {
|
|
76
|
+
wx.navigateTo({
|
|
77
|
+
url: '/pages/message/messageCommentsAndAt/messageCommentsAndAt',
|
|
78
|
+
})
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
},
|
|
82
|
+
|
|
83
|
+
// 返回上一页
|
|
84
|
+
goBack() {
|
|
85
|
+
wx.navigateBack();
|
|
86
|
+
},
|
|
87
|
+
|
|
88
|
+
// 清空所有未读消息
|
|
89
|
+
clearAllMessages() {
|
|
90
|
+
cleanUserMessages(0).then(res => {
|
|
91
|
+
wx.showToast({
|
|
92
|
+
title: '已将所有消息标注为已读',
|
|
93
|
+
icon: 'success'
|
|
94
|
+
});
|
|
95
|
+
// 清空本地角标显示
|
|
96
|
+
this.setData({
|
|
97
|
+
unread: {
|
|
98
|
+
like: 0,
|
|
99
|
+
fans: 0,
|
|
100
|
+
comment: 0
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
}).catch(err => {
|
|
104
|
+
console.error('清空消息失败', err);
|
|
105
|
+
wx.showToast({
|
|
106
|
+
title: '清空失败',
|
|
107
|
+
icon: 'error'
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
});
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
<!-- 自定义导航栏 -->
|
|
2
|
+
<view class="custom-nav" style="height: {{navHeight}}px; padding-top: {{statusBarHeight}}px;">
|
|
3
|
+
<!-- 返回按钮 -->
|
|
4
|
+
<view class="back-btn" bindtap="goBack">
|
|
5
|
+
<van-icon name="arrow-left" size="24" />
|
|
6
|
+
</view>
|
|
7
|
+
|
|
8
|
+
<!-- 标题 -->
|
|
9
|
+
<view class="title">
|
|
10
|
+
<span>消息</span>
|
|
11
|
+
<image src="/assets/images/icons/clear.png" mode="" style="width: 25px;height: 25px;margin-left: 10px;color: #9e9e9e;" catch:tap="clearAllMessages" />
|
|
12
|
+
</view>
|
|
13
|
+
|
|
14
|
+
<view style="width: 30px;"></view>
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
</view>
|
|
18
|
+
|
|
19
|
+
<!-- 顶部三选项 -->
|
|
20
|
+
<view class="top-options" style="margin-top: {{topOffset}}px;">
|
|
21
|
+
<view class="option" bindtap="selectOption" data-type="like">
|
|
22
|
+
<view class="icon-wrapper" style="background-color: #ffebcd;">
|
|
23
|
+
<van-icon name="like" size="36" color="#ff9800" />
|
|
24
|
+
<view wx:if="{{unread.like > 0}}" class="badge">{{unread.like}}</view>
|
|
25
|
+
</view>
|
|
26
|
+
<text>赞和收藏</text>
|
|
27
|
+
</view>
|
|
28
|
+
|
|
29
|
+
<view class="option" bindtap="selectOption" data-type="fans">
|
|
30
|
+
<view class="icon-wrapper" style="background-color: #d3eafd;">
|
|
31
|
+
<van-icon name="friends" size="36" color="#2196f3" />
|
|
32
|
+
<view wx:if="{{unread.fans > 0}}" class="badge">{{unread.fans}}</view>
|
|
33
|
+
</view>
|
|
34
|
+
<text>新增粉丝</text>
|
|
35
|
+
</view>
|
|
36
|
+
|
|
37
|
+
<view class="option" bindtap="selectOption" data-type="comment">
|
|
38
|
+
<view class="icon-wrapper" style="background-color: #dcefdd;">
|
|
39
|
+
<van-icon name="comment" size="36" color="#4caf50" />
|
|
40
|
+
<view wx:if="{{unread.comment > 0}}" class="badge">{{unread.comment}}</view>
|
|
41
|
+
</view>
|
|
42
|
+
<text>评论和@</text>
|
|
43
|
+
</view>
|
|
44
|
+
</view>
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
/* =====================
|
|
2
|
+
自定义导航栏
|
|
3
|
+
===================== */
|
|
4
|
+
.custom-nav {
|
|
5
|
+
width: 100%;
|
|
6
|
+
background-color: #fff;
|
|
7
|
+
display: flex;
|
|
8
|
+
align-items: center;
|
|
9
|
+
justify-content: space-between;
|
|
10
|
+
padding-left: 10px;
|
|
11
|
+
padding-right: 10px;
|
|
12
|
+
box-shadow: 0 1px 0 #eaeaea;
|
|
13
|
+
position: fixed;
|
|
14
|
+
top: 0;
|
|
15
|
+
left: 0;
|
|
16
|
+
z-index: 100;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.back-btn {
|
|
20
|
+
width: 40px;
|
|
21
|
+
display: flex;
|
|
22
|
+
align-items: center;
|
|
23
|
+
justify-content: center;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
.title {
|
|
27
|
+
font-size: 18px;
|
|
28
|
+
align-self: center;
|
|
29
|
+
display: flex;
|
|
30
|
+
align-items: center;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.clear-icon {
|
|
34
|
+
font-size: 24px;
|
|
35
|
+
color: #333;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/* =====================
|
|
39
|
+
顶部选项
|
|
40
|
+
===================== */
|
|
41
|
+
.top-options {
|
|
42
|
+
display: flex;
|
|
43
|
+
justify-content: space-around;
|
|
44
|
+
background-color: #fff;
|
|
45
|
+
padding: 30px 0;
|
|
46
|
+
/* margin-top 由动态 topOffset 控制 */
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
.option {
|
|
50
|
+
display: flex;
|
|
51
|
+
flex-direction: column;
|
|
52
|
+
align-items: center;
|
|
53
|
+
cursor: pointer;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
.option text {
|
|
57
|
+
margin-top: 6px;
|
|
58
|
+
font-size: 13px;
|
|
59
|
+
font-weight: bold;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
/* 图标背景容器 */
|
|
63
|
+
.icon-wrapper {
|
|
64
|
+
position: relative;
|
|
65
|
+
width: 60px;
|
|
66
|
+
height: 60px;
|
|
67
|
+
border-radius: 8px;
|
|
68
|
+
/* 可改圆角 */
|
|
69
|
+
display: flex;
|
|
70
|
+
justify-content: center;
|
|
71
|
+
align-items: center;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
/* 角标放在背景右上角 */
|
|
75
|
+
.badge {
|
|
76
|
+
position: absolute;
|
|
77
|
+
top: -6px;
|
|
78
|
+
right: -6px;
|
|
79
|
+
background-color: red;
|
|
80
|
+
color: #fff;
|
|
81
|
+
font-size: 12px;
|
|
82
|
+
line-height: 18px;
|
|
83
|
+
width: 18px;
|
|
84
|
+
height: 18px;
|
|
85
|
+
border-radius: 50%;
|
|
86
|
+
text-align: center;
|
|
87
|
+
z-index: 2;
|
|
88
|
+
}
|