-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathmetaHeader.ts
165 lines (155 loc) · 5.98 KB
/
metaHeader.ts
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
import fs from 'fs';
import { resolve, dirname } from 'path';
import { fileURLToPath } from 'url';
import pkg from './package.json' assert { type: 'json' };
import zh from './locales/zh.json' assert { type: 'json' };
import en from './locales/en.json' assert { type: 'json' };
import ru from './locales/ru.json' assert { type: 'json' };
const __dirname = dirname(fileURLToPath(import.meta.url));
/**
* 脚本依赖库与对应的 cdn url
* 数组里的第一个 url 是生产模式下使用的,第二个是开发模式下使用的
* 只有一个 url 表示不区分生产开发模式
*/
const resourceList: Record<string, [string, string] | [string]> = {
'solid-js': [
'https://unpkg.com/[email protected]/dist/solid.cjs',
'https://unpkg.com/[email protected]/dist/dev.cjs',
],
'solid-js/store': [
'https://unpkg.com/[email protected]/store/dist/store.cjs',
'https://unpkg.com/[email protected]/store/dist/dev.cjs',
],
'solid-js/web': [
'https://unpkg.com/[email protected]/web/dist/web.cjs',
'https://unpkg.com/[email protected]/web/dist/dev.cjs',
],
fflate: ['https://unpkg.com/[email protected]/umd/index.js'],
dmzjDecrypt: [
'https://greasyfork.org/scripts/467177-dmzjdecrypt/code/dmzjDecrypt.js?version=1207199',
],
};
const resource = {
prod: Object.fromEntries(
Object.entries(resourceList).map(([k, v]) => [k, v.at(0)]),
),
dev: Object.fromEntries(
Object.entries(resourceList).map(([k, v]) => [k, v.at(-1)]),
),
};
/** 根据 index.ts 的注释获取支持站点列表 */
const getSupportSiteList = () => {
const indexCode = fs.readFileSync(resolve(__dirname, 'src/index.ts'), 'utf8');
/** 支持站点列表 */
return [...indexCode.matchAll(/(?<=\n\s+\/\/\s#).+(?=\n)/g)].map((e) => e[0]);
};
/** 更新 README 上的支持站点列表 */
export const updateReadme = () => {
const readmePath = resolve(__dirname, 'README.md');
const readmeMd = fs.readFileSync(readmePath, 'utf8');
const newMd = readmeMd.replace(
/(?<=<!-- supportSiteList -->\n\n).+(?=\n\n<!-- supportSiteList -->)/s,
getSupportSiteList()
.slice(5)
.map((siteText) => `- ${siteText}`)
.join('\n'),
);
if (newMd !== readmeMd) fs.writeFileSync(readmePath, newMd);
// 生成 README-out.md 文件,把相对链接改成 jsdelivr cdn 的链接,方便在其他站点显示图片
const outMdPath = resolve(__dirname, 'docs/README-out.md');
const outMd = fs.readFileSync(outMdPath, 'utf8');
const newOutMd = newMd.replaceAll(
/(?<=]\()\/.+\.(md)?.+\)/g,
'https://cdn.jsdelivr.net/gh/hymbz/ComicReadScript$&',
);
if (newOutMd !== outMd) fs.writeFileSync(outMdPath, newOutMd);
};
/** 脚本头部注释 */
export const getMetaData = (isDevMode: boolean) => {
const meta = {
name: pkg.name,
namespace: pkg.name,
version: pkg.version,
description: `${zh.description}${getSupportSiteList().join('、')}`,
'description:en': en.description,
'description:ru': ru.description,
author: pkg.author,
license: pkg.license,
noframes: true,
match: '*://*/*',
connect: [
'cdn.jsdelivr.net',
'yamibo.com',
'dmzj.com',
'idmzj.com',
'exhentai.org',
'e-hentai.org',
'hath.network',
'nhentai.net',
'hypergryph.com',
'mangabz.com',
'copymanga.site',
'copymanga.info',
'copymanga.net',
'copymanga.org',
'copymanga.tv',
'mangacopy.com',
'xsskc.com',
'self',
'127.0.0.1',
'*',
],
grant: [
'GM_addElement',
'GM_getResourceText',
'GM_xmlhttpRequest',
'GM.addValueChangeListener',
'GM.removeValueChangeListener',
'GM.getResourceText',
'GM.addStyle',
'GM.getValue',
'GM.setValue',
'GM.listValues',
'GM.deleteValue',
'GM.registerMenuCommand',
'GM.unregisterMenuCommand',
'unsafeWindow',
],
icon: '',
resource: resource[isDevMode ? 'dev' : 'prod'],
supportURL: 'https://github.com/hymbz/ComicReadScript/issues',
updateURL:
'https://github.com/hymbz/ComicReadScript/raw/master/ComicRead.user.js',
downloadURL:
'https://github.com/hymbz/ComicReadScript/raw/master/ComicRead.user.js',
};
const keyLength = Math.max(...Object.keys(meta).map((key) => key.length)) + 1;
const createMetaHeader = (metaData: Record<string, any>) => {
const metaText = Object.entries(metaData)
.filter(([, val]) => val)
.map(([key, val]) => {
switch (typeof val) {
case 'boolean':
return `// @${key}`;
case 'object':
return Array.isArray(val)
? val
.map((v) => `// @${key.padEnd(keyLength, ' ')} ${v}`)
.join('\n')
: Object.entries(val)
.map(
([k, v]) => `// @${key.padEnd(keyLength, ' ')} ${k} ${v}`,
)
.join('\n');
default:
return `// @${key.padEnd(keyLength, ' ')} ${val}`;
}
})
.join('\n');
return `// ==UserScript==\n${metaText}\n// ==/UserScript==\n\n`;
};
return {
meta,
createMetaHeader,
};
};