-
Notifications
You must be signed in to change notification settings - Fork 137
/
Copy pathwebo.js
183 lines (168 loc) · 5.26 KB
/
webo.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
//
// iOS 桌面组件脚本 @「小件件」
// 开发说明:请从 Widget 类开始编写,注释请勿修改
// https://x.im3x.cn
//
// 添加require,是为了vscode中可以正确引入包,以获得自动补全等功能
// @组件代码开始
let w = new ListWidget();
if (typeof require === 'undefined') require = importModule; //
const { DmYY, Runing } = require('./DmYY');
class Widget extends DmYY {
constructor(arg) {
super(arg);
this.name = '微博热搜';
this.en = 'weiboresou';
if (config.runsInApp) {
this.registerAction('基础设置', this.setWidgetConfig);
this.registerAction('插件设置', this.actionSetting);
}
}
actionUrl(name = '', data = '') {
let u = URLScheme.forRunningScript();
let q = `act=${encodeURIComponent(name)}&data=${encodeURIComponent(
data,
)}&__arg=${encodeURIComponent(this.arg)}&__size=${this.widgetFamily}`;
let result = '';
if (u.includes('run?')) {
result = `${u}&${q}`;
} else {
result = `${u}?${q}`;
}
return result;
}
/**
* 渲染小尺寸组件
*/
async renderSmall() {
let res = await this.$request.get(
'https://m.weibo.cn/api/container/getIndex?containerid=106003%26filter_type%3Drealtimehot',
);
let data = res['data']['cards'][0]['card_group'];
// 去除第一条
data.shift();
let topic = data[0];
console.log(topic);
// 显示数据
w = await this.renderHeader(
w,
'https://ss2.bdstatic.com/70cFvnSh_Q1YnxGkpoWK1HF6hhy/it/u=2225458401,2104443747&fm=26&gp=0.jpg',
'微博热搜',
);
let body = w.addStack();
let txt = body.addText(topic['desc']);
body.addSpacer();
txt.leftAlignText();
txt.font = Font.lightSystemFont(14);
txt.textColor = this.widgetColor;
w.addSpacer();
let footer = w.addStack();
footer.centerAlignContent();
let img = footer.addImage(await this.$request.get(topic['pic'], 'IMG'));
img.imageSize = new Size(18, 18);
footer.addSpacer(5);
if (topic['icon']) {
let hot = footer.addImage(await this.$request.get(topic['icon'], 'IMG'));
hot.imageSize = new Size(18, 18);
footer.addSpacer(5);
}
let num = footer.addText(String(topic['desc_extr']));
num.font = Font.lightSystemFont(10);
num.textOpacity = 0.5;
num.textColor = this.widgetColor;
body.url = topic['scheme'];
return w;
}
/**
* 渲染中尺寸组件
*/
async renderMedium(count = 4) {
let res = await this.$request.get(
'https://m.weibo.cn/api/container/getIndex?containerid=106003%26filter_type%3Drealtimehot',
);
let data = res['data']['cards'][0]['card_group'];
// 去除第一条
data.shift();
// 显示数据
w = await this.renderHeader(
w,
'https://ss2.bdstatic.com/70cFvnSh_Q1YnxGkpoWK1HF6hhy/it/u=2225458401,2104443747&fm=26&gp=0.jpg',
'微博热搜',
);
// 布局:一行一个,左边顺序排序,中间标题,后边热/新
const body = w.addStack();
const bodyLeft = body.addStack();
bodyLeft.layoutVertically();
for (let i = 0; i < count; i++) {
let topic = data[i];
let dom = bodyLeft.addStack();
dom.centerAlignContent();
let pic = dom.addImage(await this.$request.get(topic['pic'], 'IMG'));
pic.imageSize = new Size(18, 18);
dom.addSpacer(5);
let title = dom.addText(topic['desc']);
title.lineLimit = 1;
title.font = Font.lightSystemFont(14);
title.textColor = this.widgetColor;
dom.addSpacer(5);
if (topic['icon']) {
let iconDom = dom.addStack();
let icon = iconDom.addImage(
await this.$request.get(topic['icon'], 'IMG'),
);
icon.imageSize = new Size(18, 18);
}
dom.addSpacer();
let extr = dom.addText(String(topic['desc_extr']));
extr.font = Font.lightSystemFont(12);
extr.textColor = this.widgetColor;
extr.textOpacity = 0.6;
dom.url = topic['scheme'];
bodyLeft.addSpacer(5);
}
body.addSpacer();
w.url = this.actionUrl('setting');
return w;
}
/**
* 渲染大尺寸组件
*/
async renderLarge() {
return await this.renderMedium(11);
}
async actionSetting() {
const settings = this.getSettings();
const arg = settings['type'] || '1';
let a = new Alert();
a.title = '打开方式';
a.message = '点击小组件浏览热点的方式';
a.addAction((arg === '0' ? '✅ ' : '') + '微博客户端');
a.addAction((arg === '1' ? '✅ ' : '') + 'Vvebo');
a.addCancelAction('取消设置');
let i = await a.presentSheet();
if (i === -1) return;
this.settings['type'] = String(i);
this.saveSettings();
}
async actionOpenUrl(url) {
const settings = this.getSettings();
if (settings['type'] === '1') {
Safari.openInApp(url, false);
} else {
let k = decodeURIComponent(url).split('q=')[1].split('&')[0];
Safari.open('vvebo://search?q=' + encodeURIComponent(k));
}
}
useBoxJS = false;
async render() {
await this.getWidgetBackgroundImage(w);
if (this.widgetFamily === 'medium') {
return this.renderMedium();
} else if (this.widgetFamily === 'large') {
return this.renderLarge();
} else {
return this.renderSmall();
}
}
}
await Runing(Widget);