oipage 1.6.0 → 1.7.0-alpha.1

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 (96) hide show
  1. package/.github/FUNDING.yml +11 -11
  2. package/AUTHORS.txt +6 -6
  3. package/CHANGELOG +144 -137
  4. package/LICENSE +20 -20
  5. package/README.md +95 -95
  6. package/bin/WebSocket/decodeWsFrame.js +43 -43
  7. package/bin/WebSocket/encodeWsFrame.js +28 -28
  8. package/bin/WebSocket/headersToJSON.js +26 -26
  9. package/bin/WebSocket/index.js +80 -80
  10. package/bin/data/mineTypes.json +104 -104
  11. package/bin/disk.js +42 -42
  12. package/bin/help.js +43 -43
  13. package/bin/intercept.js +15 -15
  14. package/bin/network.js +21 -21
  15. package/bin/run +115 -115
  16. package/bin/serve.d.ts +55 -55
  17. package/bin/serve.js +158 -158
  18. package/bin/template/404.html +186 -186
  19. package/bin/tools/deleteEmptyFolder.js +23 -23
  20. package/bin/tools/format.js +75 -75
  21. package/bin/tools/network.js +42 -42
  22. package/bin/tools/resolve404.js +83 -83
  23. package/bin/tools/resolveImport.js +88 -88
  24. package/bin/website-htmls/components/ui-select-file/index.html +7 -7
  25. package/bin/website-htmls/components/ui-select-file/index.js +37 -37
  26. package/bin/website-htmls/components/ui-select-file/index.scss +44 -44
  27. package/bin/website-htmls/dialogs/imageSize/index.html +54 -54
  28. package/bin/website-htmls/dialogs/imageSize/index.js +53 -53
  29. package/bin/website-htmls/dialogs/imageSize/index.scss +138 -138
  30. package/bin/website-htmls/dialogs/index.js +52 -52
  31. package/bin/website-htmls/images/addFile.svg +1 -1
  32. package/bin/website-htmls/images/img-to-pdf.svg +1 -1
  33. package/bin/website-htmls/index.html +17 -17
  34. package/bin/website-htmls/main.js +13 -13
  35. package/bin/website-htmls/pages/App/index.html +6 -6
  36. package/bin/website-htmls/pages/App/index.js +22 -22
  37. package/bin/website-htmls/pages/App/index.scss +43 -43
  38. package/bin/website-htmls/pages/appStore/index.html +24 -24
  39. package/bin/website-htmls/pages/appStore/index.js +19 -19
  40. package/bin/website-htmls/pages/appStore/index.scss +41 -41
  41. package/bin/website-htmls/pages/chart/index.html +8 -8
  42. package/bin/website-htmls/pages/chart/index.js +72 -72
  43. package/bin/website-htmls/pages/chart/index.scss +72 -72
  44. package/bin/website-htmls/pages/image-editor/index.html +27 -27
  45. package/bin/website-htmls/pages/image-editor/index.js +106 -106
  46. package/bin/website-htmls/pages/image-editor/index.scss +45 -45
  47. package/bin/website-htmls/pages/img-to-pdf/index.html +3 -3
  48. package/bin/website-htmls/pages/img-to-pdf/index.js +44 -44
  49. package/bin/website-htmls/pages/img-to-pdf/index.scss +4 -4
  50. package/bin/website-htmls/router.config.js +19 -19
  51. package/bin/website-htmls/styles/normalize.css +94 -94
  52. package/bin/website-plugins/intercept/chart.js +33 -33
  53. package/bin/website-plugins/intercept/head.js +8 -8
  54. package/bin/website-plugins/intercept/index.js +8 -8
  55. package/bin/website-plugins/intercept/oipage-vislite-intercept.js +33 -33
  56. package/bin/website-plugins/intercept/oipage-zipaper-intercept.js +39 -39
  57. package/bin/website-plugins/loader/index.js +11 -11
  58. package/bin/website-plugins/loader/oipage-html-loader.js +7 -7
  59. package/bin/website-plugins/loader/oipage-scss-loader.js +149 -149
  60. package/nodejs/animation/index.d.ts +19 -19
  61. package/nodejs/animation/index.js +104 -104
  62. package/nodejs/cmdlog/index.d.ts +20 -20
  63. package/nodejs/cmdlog/index.js +75 -75
  64. package/nodejs/disk/index.d.ts +47 -47
  65. package/nodejs/disk/index.js +165 -165
  66. package/nodejs/format/index.d.ts +29 -29
  67. package/nodejs/format/index.js +107 -107
  68. package/nodejs/json/index.d.ts +9 -9
  69. package/nodejs/json/index.js +206 -206
  70. package/nodejs/logform/index.d.ts +18 -18
  71. package/nodejs/logform/index.js +94 -94
  72. package/nodejs/reader/index.d.ts +32 -32
  73. package/nodejs/reader/index.js +20 -20
  74. package/nodejs/remote/index.d.ts +32 -0
  75. package/nodejs/remote/index.js +71 -0
  76. package/nodejs/throttle/index.d.ts +30 -30
  77. package/nodejs/throttle/index.js +50 -50
  78. package/package.json +43 -43
  79. package/web/XMLHttpRequest/index.d.ts +17 -17
  80. package/web/XMLHttpRequest/index.js +60 -60
  81. package/web/animation/index.d.ts +19 -19
  82. package/web/animation/index.js +104 -104
  83. package/web/format/index.d.ts +29 -29
  84. package/web/format/index.js +107 -107
  85. package/web/json/index.d.ts +9 -9
  86. package/web/json/index.js +206 -206
  87. package/web/onReady/index.d.ts +7 -7
  88. package/web/onReady/index.js +8 -8
  89. package/web/performChunk/index.d.ts +4 -4
  90. package/web/performChunk/index.js +19 -19
  91. package/web/reader/index.d.ts +32 -32
  92. package/web/reader/index.js +20 -20
  93. package/web/style/index.d.ts +21 -21
  94. package/web/style/index.js +19 -19
  95. package/web/throttle/index.d.ts +30 -30
  96. package/web/throttle/index.js +50 -50
package/bin/serve.js CHANGED
@@ -1,159 +1,159 @@
1
- const { join } = require("path");
2
- const { existsSync, lstatSync, statSync, createReadStream } = require("fs");
3
- const { createServer } = require('http');
4
- const packageValue = require("../package.json");
5
- const network = require("./tools/network.js");
6
- const mineTypes = require("./data/mineTypes.json");
7
- const resolve404 = require("./tools/resolve404.js");
8
- const resolveImportFactory = require("./tools/resolveImport.js");
9
- const { doIntercept } = require("./intercept.js");
10
-
11
- const websiteIntercept = require("./website-plugins/intercept/index.js");
12
- const websiteLoader = require("./website-plugins/loader/index.js");
13
-
14
- const WebSocketClass = require("./WebSocket/index.js");
15
-
16
- // 开发服务器
17
- module.exports = function (config) {
18
- let startTime = new Date().valueOf();
19
-
20
- const cache = "cache" in config.devServer ? config.devServer.cache : true;
21
- const port = +config.devServer.port; // 端口号
22
- const basePath = (/^\./.test(config.devServer.baseUrl)) ? join(process.cwd(), config.devServer.baseUrl) : config.devServer.baseUrl; // 服务器根路径
23
-
24
- const name = (config.name || "OIPage") + "-http-server";
25
- const version = config.version || packageValue.version;
26
-
27
- const wsHandler = WebSocketClass(port + 1, (config.name || "OIPage") + "-ws-server", version);
28
-
29
- let Server = createServer(function (request, response) {
30
- let headers = request.headers;
31
- let url = decodeURIComponent(request.url);
32
-
33
- let urlArray = url.split("?");
34
- url = urlArray[0];
35
-
36
- // 请求的文件路径
37
- let filePath;
38
-
39
- let isWebsite = /^\/_oipage_website_\//.test(url);
40
- if (isWebsite) {
41
- filePath = join(__dirname, "./website-htmls/", url.replace(/^\/_oipage_website_\//, ""));
42
- } else {
43
- filePath = join(basePath, url == "/" ? "index.html" : url.replace(/^\//, ""));
44
- }
45
-
46
- // 请求拦截
47
- if (doIntercept(url.replace(/^\/_oipage_website_/, "").replace(/^\/@modules\//, ""), isWebsite ? websiteIntercept : config.devServer.intercept, request, response, wsHandler)) {
48
- console.log("<i> \x1b[1m\x1b[32m[" + name + "] intercept: " + url + '\x1b[0m ' + new Date().toLocaleString());
49
- }
50
-
51
- // 如果存在且是文件
52
- else if (existsSync(filePath) && !lstatSync(filePath).isDirectory()) {
53
-
54
- // 判断是否是请求而无需进一步解析
55
- // 2025年12月5日 于南京
56
- let isXHR = headers["sec-fetch-dest"] === "empty";
57
-
58
- let dotName = /\./.test(filePath) ? filePath.match(/\.([^.]+)$/)[1] : "";
59
- let fileType = mineTypes[dotName]; // 文件类型
60
- let fileInfo = statSync(filePath);
61
-
62
- let fileModifiedTime = new Date(fileInfo.mtime).toGMTString();
63
-
64
- let responseHeader = {
65
- 'Content-Type': (fileType || "text/plain") + ";charset=utf-8",
66
- 'Access-Control-Allow-Origin': '*',
67
- 'Server': 'Powered by ' + name + '@' + version,
68
- 'Cache-Control': 'no-cache',
69
- // 'Content-Length': fileInfo.size, // 会导致拦截修改的文本内容不对
70
- 'Last-Modified': fileModifiedTime
71
- };
72
-
73
- if (cache && headers["if-modified-since"]) {
74
- let ifModifiedSince = new Date(headers["if-modified-since"]).valueOf()
75
- let lastModified = new Date(fileModifiedTime).valueOf()
76
- if (lastModified <= ifModifiedSince) {
77
- response.writeHead('304', responseHeader);
78
- response.end();
79
- console.log("<i> \x1b[1m\x1b[32m[" + name + "] Cache File: " + url + "\x1b[0m " + new Date().toLocaleString() + "\x1b[33m\x1b[1m 304" + (isXHR ? " 请求" : "") + "\x1b[0m");
80
- return;
81
- }
82
- }
83
-
84
- let sendType = "";
85
- let entry = headers.accept !== "*/*";
86
-
87
- // 如果文件小于10M,认为不大,直接读取
88
- if (fileInfo.size < 10 * 1024 * 1024) {
89
- let { source, resolveImport } = resolveImportFactory(basePath, filePath, entry, isWebsite ? websiteIntercept : config.devServer.intercept, urlArray[1] === "download", isWebsite)
90
-
91
- // 只处理非下载文件
92
- // 过大的也不进行处理
93
- // (对website无效)
94
- if (urlArray[1] !== "download") {
95
- let loaders = isWebsite ? websiteLoader : config.module;
96
-
97
- for (let i = 0; i < loaders.rules.length; i++) {
98
- if (loaders.rules[i].test.test(filePath)) {
99
- source = loaders.rules[i].use.call({
100
- root: basePath, // 服务器根路径
101
- path: filePath.replace(basePath, ""), // 文件相对路径
102
- entry, // 是否是浏览器地址栏直接访问
103
- setFileType(_fileType) { // 设置文件类型
104
- fileType = _fileType;
105
- responseHeader['Content-Type'] = _fileType + ";charset=utf-8";
106
- }
107
- }, source);
108
- break;
109
- }
110
- }
111
-
112
- }
113
-
114
- sendType = "Read";
115
- response.writeHead('200', responseHeader);
116
- response.write(isXHR ? source : resolveImport(source, fileType !== "application/javascript"));
117
- response.end();
118
- }
119
-
120
- // 对于大文件,使用流读取
121
- else {
122
- sendType = "Stream";
123
-
124
- responseHeader['Content-Length'] = fileInfo.size
125
-
126
- response.writeHead('200', responseHeader);
127
- createReadStream(filePath).pipe(response);
128
- }
129
-
130
- console.log("<i> \x1b[1m\x1b[32m[" + name + "] " + sendType + " File: " + url + '\x1b[0m ' + new Date().toLocaleString() + "\x1b[33m\x1b[1m" + (isXHR ? " 请求" : "") + "\x1b[0m");
131
- }
132
-
133
- // 否则就是404
134
- else {
135
- response.writeHead(404, {
136
- 'Content-Type': "text/html;charset=utf-8",
137
- 'Access-Control-Allow-Origin': '*',
138
- 'Server': 'Powered by ' + name + '@' + version
139
- });
140
- response.write(resolve404(filePath, url));
141
- response.end();
142
- }
143
-
144
- });
145
-
146
- Server.listen(port);
147
-
148
- // 获取网络信息
149
- let networkValue = network();
150
-
151
- // 打印成功提示
152
- console.log('<i> \x1b[1m\x1b[32m[' + name + '] Project is running at:\x1b[0m');
153
- console.log('<i> \x1b[1m\x1b[32m[' + name + '] Loopback: \x1b[36mhttp://localhost:' + port + '/\x1b[0m');
154
- for (let ipv4Item of networkValue.IPv4) console.log('<i> \x1b[1m\x1b[32m[' + name + '] On Your Network (IPv4):\x1b[36m http://' + ipv4Item.address + ':' + port + '/\x1b[0m');
155
- for (let ipv6Item of networkValue.IPv6) console.log('<i> \x1b[1m\x1b[32m[' + name + '] On Your Network (IPv6): \x1b[36mhttp://[' + ipv6Item.address + ']:' + port + '/\x1b[0m');
156
- console.log('<i> \x1b[1m\x1b[32m[' + name + '] Content not from ' + (config.name || "OIPage") + ' is served from \x1b[36m"' + basePath + '" \x1b[0mdirectory');
157
- if (!cache) console.log('<i> \x1b[1m\x1b[32m[' + name + '] Cancel 304 Cache!\x1b[0m');
158
- console.log('\n' + (config.name || "OIPage") + ' ' + version + ' compiled \x1b[1m\x1b[32msuccessfully\x1b[0m in ' + (new Date().valueOf() - startTime) + ' ms\n')
1
+ const { join } = require("path");
2
+ const { existsSync, lstatSync, statSync, createReadStream } = require("fs");
3
+ const { createServer } = require('http');
4
+ const packageValue = require("../package.json");
5
+ const network = require("./tools/network.js");
6
+ const mineTypes = require("./data/mineTypes.json");
7
+ const resolve404 = require("./tools/resolve404.js");
8
+ const resolveImportFactory = require("./tools/resolveImport.js");
9
+ const { doIntercept } = require("./intercept.js");
10
+
11
+ const websiteIntercept = require("./website-plugins/intercept/index.js");
12
+ const websiteLoader = require("./website-plugins/loader/index.js");
13
+
14
+ const WebSocketClass = require("./WebSocket/index.js");
15
+
16
+ // 开发服务器
17
+ module.exports = function (config) {
18
+ let startTime = new Date().valueOf();
19
+
20
+ const cache = "cache" in config.devServer ? config.devServer.cache : true;
21
+ const port = +config.devServer.port; // 端口号
22
+ const basePath = (/^\./.test(config.devServer.baseUrl)) ? join(process.cwd(), config.devServer.baseUrl) : config.devServer.baseUrl; // 服务器根路径
23
+
24
+ const name = (config.name || "OIPage") + "-http-server";
25
+ const version = config.version || packageValue.version;
26
+
27
+ const wsHandler = WebSocketClass(port + 1, (config.name || "OIPage") + "-ws-server", version);
28
+
29
+ let Server = createServer(function (request, response) {
30
+ let headers = request.headers;
31
+ let url = decodeURIComponent(request.url);
32
+
33
+ let urlArray = url.split("?");
34
+ url = urlArray[0];
35
+
36
+ // 请求的文件路径
37
+ let filePath;
38
+
39
+ let isWebsite = /^\/_oipage_website_\//.test(url);
40
+ if (isWebsite) {
41
+ filePath = join(__dirname, "./website-htmls/", url.replace(/^\/_oipage_website_\//, ""));
42
+ } else {
43
+ filePath = join(basePath, url == "/" ? "index.html" : url.replace(/^\//, ""));
44
+ }
45
+
46
+ // 请求拦截
47
+ if (doIntercept(url.replace(/^\/_oipage_website_/, "").replace(/^\/@modules\//, ""), isWebsite ? websiteIntercept : config.devServer.intercept, request, response, wsHandler)) {
48
+ console.log("<i> \x1b[1m\x1b[32m[" + name + "] intercept: " + url + '\x1b[0m ' + new Date().toLocaleString());
49
+ }
50
+
51
+ // 如果存在且是文件
52
+ else if (existsSync(filePath) && !lstatSync(filePath).isDirectory()) {
53
+
54
+ // 判断是否是请求而无需进一步解析
55
+ // 2025年12月5日 于南京
56
+ let isXHR = headers["sec-fetch-dest"] === "empty";
57
+
58
+ let dotName = /\./.test(filePath) ? filePath.match(/\.([^.]+)$/)[1] : "";
59
+ let fileType = mineTypes[dotName]; // 文件类型
60
+ let fileInfo = statSync(filePath);
61
+
62
+ let fileModifiedTime = new Date(fileInfo.mtime).toGMTString();
63
+
64
+ let responseHeader = {
65
+ 'Content-Type': (fileType || "text/plain") + ";charset=utf-8",
66
+ 'Access-Control-Allow-Origin': '*',
67
+ 'Server': 'Powered by ' + name + '@' + version,
68
+ 'Cache-Control': 'no-cache',
69
+ // 'Content-Length': fileInfo.size, // 会导致拦截修改的文本内容不对
70
+ 'Last-Modified': fileModifiedTime
71
+ };
72
+
73
+ if (cache && headers["if-modified-since"]) {
74
+ let ifModifiedSince = new Date(headers["if-modified-since"]).valueOf()
75
+ let lastModified = new Date(fileModifiedTime).valueOf()
76
+ if (lastModified <= ifModifiedSince) {
77
+ response.writeHead('304', responseHeader);
78
+ response.end();
79
+ console.log("<i> \x1b[1m\x1b[32m[" + name + "] Cache File: " + url + "\x1b[0m " + new Date().toLocaleString() + "\x1b[33m\x1b[1m 304" + (isXHR ? " 请求" : "") + "\x1b[0m");
80
+ return;
81
+ }
82
+ }
83
+
84
+ let sendType = "";
85
+ let entry = headers.accept !== "*/*";
86
+
87
+ // 如果文件小于10M,认为不大,直接读取
88
+ if (fileInfo.size < 10 * 1024 * 1024) {
89
+ let { source, resolveImport } = resolveImportFactory(basePath, filePath, entry, isWebsite ? websiteIntercept : config.devServer.intercept, urlArray[1] === "download", isWebsite)
90
+
91
+ // 只处理非下载文件
92
+ // 过大的也不进行处理
93
+ // (对website无效)
94
+ if (urlArray[1] !== "download") {
95
+ let loaders = isWebsite ? websiteLoader : config.module;
96
+
97
+ for (let i = 0; i < loaders.rules.length; i++) {
98
+ if (loaders.rules[i].test.test(filePath)) {
99
+ source = loaders.rules[i].use.call({
100
+ root: basePath, // 服务器根路径
101
+ path: filePath.replace(basePath, ""), // 文件相对路径
102
+ entry, // 是否是浏览器地址栏直接访问
103
+ setFileType(_fileType) { // 设置文件类型
104
+ fileType = _fileType;
105
+ responseHeader['Content-Type'] = _fileType + ";charset=utf-8";
106
+ }
107
+ }, source);
108
+ break;
109
+ }
110
+ }
111
+
112
+ }
113
+
114
+ sendType = "Read";
115
+ response.writeHead('200', responseHeader);
116
+ response.write(isXHR ? source : resolveImport(source, fileType !== "application/javascript"));
117
+ response.end();
118
+ }
119
+
120
+ // 对于大文件,使用流读取
121
+ else {
122
+ sendType = "Stream";
123
+
124
+ responseHeader['Content-Length'] = fileInfo.size
125
+
126
+ response.writeHead('200', responseHeader);
127
+ createReadStream(filePath).pipe(response);
128
+ }
129
+
130
+ console.log("<i> \x1b[1m\x1b[32m[" + name + "] " + sendType + " File: " + url + '\x1b[0m ' + new Date().toLocaleString() + "\x1b[33m\x1b[1m" + (isXHR ? " 请求" : "") + "\x1b[0m");
131
+ }
132
+
133
+ // 否则就是404
134
+ else {
135
+ response.writeHead(404, {
136
+ 'Content-Type': "text/html;charset=utf-8",
137
+ 'Access-Control-Allow-Origin': '*',
138
+ 'Server': 'Powered by ' + name + '@' + version
139
+ });
140
+ response.write(resolve404(filePath, url));
141
+ response.end();
142
+ }
143
+
144
+ });
145
+
146
+ Server.listen(port);
147
+
148
+ // 获取网络信息
149
+ let networkValue = network();
150
+
151
+ // 打印成功提示
152
+ console.log('<i> \x1b[1m\x1b[32m[' + name + '] Project is running at:\x1b[0m');
153
+ console.log('<i> \x1b[1m\x1b[32m[' + name + '] Loopback: \x1b[36mhttp://localhost:' + port + '/\x1b[0m');
154
+ for (let ipv4Item of networkValue.IPv4) console.log('<i> \x1b[1m\x1b[32m[' + name + '] On Your Network (IPv4):\x1b[36m http://' + ipv4Item.address + ':' + port + '/\x1b[0m');
155
+ for (let ipv6Item of networkValue.IPv6) console.log('<i> \x1b[1m\x1b[32m[' + name + '] On Your Network (IPv6): \x1b[36mhttp://[' + ipv6Item.address + ']:' + port + '/\x1b[0m');
156
+ console.log('<i> \x1b[1m\x1b[32m[' + name + '] Content not from ' + (config.name || "OIPage") + ' is served from \x1b[36m"' + basePath + '" \x1b[0mdirectory');
157
+ if (!cache) console.log('<i> \x1b[1m\x1b[32m[' + name + '] Cancel 304 Cache!\x1b[0m');
158
+ console.log('\n' + (config.name || "OIPage") + ' ' + version + ' compiled \x1b[1m\x1b[32msuccessfully\x1b[0m in ' + (new Date().valueOf() - startTime) + ' ms\n')
159
159
  };