oipage 0.3.0 → 1.0.0-alpha.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 (59) hide show
  1. package/CHANGELOG +15 -13
  2. package/README.md +1 -102
  3. package/bin/mineTypes.json +105 -0
  4. package/{nodejs/core → bin}/network.js +7 -4
  5. package/bin/resolve404.js +78 -0
  6. package/bin/run +8 -200
  7. package/bin/serve.js +64 -0
  8. package/images/file.png +0 -0
  9. package/images/folder.png +0 -0
  10. package/images/goback.png +0 -0
  11. package/{corejs → nodejs}/animation/index.js +8 -2
  12. package/nodejs/deeplog/index.d.ts +10 -0
  13. package/nodejs/deeplog/index.js +35 -0
  14. package/nodejs/linelog/index.d.ts +9 -0
  15. package/nodejs/{core/log.js → linelog/index.js} +12 -55
  16. package/{corejs → nodejs}/throttle/index.js +9 -3
  17. package/package.json +12 -5
  18. package/web/animation/index.d.ts +12 -0
  19. package/web/animation/index.js +108 -0
  20. package/{browserjs → web}/getStyle/index.js +8 -2
  21. package/{browserjs → web}/onReady/index.js +8 -2
  22. package/web/setStyle/index.js +11 -0
  23. package/web/throttle/index.d.ts +31 -0
  24. package/web/throttle/index.js +56 -0
  25. package/AUTHORS.txt +0 -6
  26. package/bin/options.js +0 -74
  27. package/browserjs/index.d.ts +0 -13
  28. package/browserjs/index.js +0 -9
  29. package/browserjs/setStyle/index.js +0 -5
  30. package/corejs/index.d.ts +0 -10
  31. package/corejs/index.js +0 -7
  32. package/nodejs/core/file.js +0 -163
  33. package/nodejs/core/image.js +0 -5
  34. package/nodejs/core/options.js +0 -49
  35. package/nodejs/core/remote.js +0 -60
  36. package/nodejs/core/responseFileList.js +0 -28
  37. package/nodejs/core/server.js +0 -190
  38. package/nodejs/data/404.js +0 -52
  39. package/nodejs/data/images/file.js +0 -1
  40. package/nodejs/data/images/folder.js +0 -1
  41. package/nodejs/data/mime.types.js +0 -112
  42. package/nodejs/form/common.js +0 -3
  43. package/nodejs/form/index.js +0 -80
  44. package/nodejs/form/select.js +0 -10
  45. package/nodejs/index.js +0 -58
  46. package/nodejs/loader/simpleScss.js +0 -248
  47. package/nodejs/loader/xhtml.js +0 -521
  48. package/nodejs/reader/plain.js +0 -20
  49. package/stylecss/index.css +0 -3
  50. package/stylecss/normalize.css +0 -94
  51. package/stylecss/rasterize.css +0 -318
  52. package/stylecss/skeleton.css +0 -16
  53. package/types/get-options.d.ts +0 -6
  54. package/types/index.d.ts +0 -187
  55. /package/{corejs → nodejs}/animation/index.d.ts +0 -0
  56. /package/{corejs → nodejs}/throttle/index.d.ts +0 -0
  57. /package/{browserjs → web}/getStyle/index.d.ts +0 -0
  58. /package/{browserjs → web}/onReady/index.d.ts +0 -0
  59. /package/{browserjs → web}/setStyle/index.d.ts +0 -0
@@ -1,163 +0,0 @@
1
- const fs = require('fs');
2
- const path = require('path');
3
-
4
- // 删除文件或文件夹
5
- function deleteSync(target) {
6
-
7
- // 如果文件夹不存在,直接返回即可
8
- if (!fs.existsSync(target)) return;
9
-
10
- // 如果是文件,直接删除即可
11
- if (!fs.lstatSync(target).isDirectory()) {
12
- fs.unlinkSync(target);
13
- } else {
14
-
15
- // 读取子文件
16
- const subFiles = fs.readdirSync(target);
17
-
18
- subFiles.forEach(function (file) {
19
-
20
- // 调用这个方法,删除子文件或文件夹
21
- const curPath = path.join(target, "./" + file);
22
- deleteSync(curPath);
23
-
24
- });
25
-
26
- // 等子文件或文件夹删除完毕以后,删除本文件夹
27
- fs.rmdirSync(target);
28
- }
29
-
30
- };
31
-
32
- // 复制文件或文件夹
33
- function copySync(source, target) {
34
-
35
- // 如果是文件,直接复制即可
36
- if (!fs.lstatSync(source).isDirectory()) {
37
- if (!fs.existsSync(path.join(target, "../"))) fs.mkdirSync(path.join(target, "../"), { recursive: true });
38
-
39
- fs.copyFileSync(source, target);
40
- } else {
41
-
42
- // 读取子文件
43
- const subFiles = fs.readdirSync(source);
44
-
45
- // 如果文件夹不存在,创建
46
- if (!fs.existsSync(target)) {
47
- fs.mkdirSync(target, { recursive: true });
48
- }
49
-
50
- // 复制子文件或文件夹
51
- subFiles.forEach(function (file) {
52
- copySync(path.join(source, "./" + file), path.join(target, "./" + file));
53
- });
54
-
55
- }
56
- };
57
-
58
- // 移动文件或文件夹
59
- function moveSync(source, target) {
60
-
61
- // 如果是文件,直接剪切即可
62
- if (!fs.lstatSync(source).isDirectory()) {
63
- if (!fs.existsSync(path.join(target, "../"))) fs.mkdirSync(path.join(target, "../"), { recursive: true });
64
-
65
- fs.copyFileSync(source, target);
66
- fs.unlinkSync(source);
67
- } else {
68
-
69
- // 读取子文件
70
- const subFiles = fs.readdirSync(source);
71
-
72
- // 如果文件夹不存在,创建
73
- if (!fs.existsSync(target)) {
74
- fs.mkdirSync(target, { recursive: true });
75
- }
76
-
77
- // 移动子文件或文件夹
78
- subFiles.forEach(function (file) {
79
- moveSync(path.join(source, "./" + file), path.join(target, "./" + file));
80
- });
81
-
82
- // 移动完子文件或文件夹以后(移动完毕也意味着子文件或文件夹被删除了)
83
- fs.rmdirSync(source);
84
- }
85
- }
86
-
87
- // 遍历文件或文件夹中所有文件
88
- function listFileSync(source, callback) {
89
- // 文件夹
90
- if (fs.lstatSync(source).isDirectory()) {
91
-
92
- // 读取子内容
93
- const subItems = fs.readdirSync(source);
94
- subItems.forEach(function (item) {
95
- listFileSync(path.join(source, "./" + item), callback);
96
- });
97
- }
98
-
99
- // 文件
100
- else {
101
- let folder = path.join(source, "../");
102
-
103
- callback({
104
- "name": source.replace(folder, ""),
105
- "path": source,
106
- "folder": folder
107
- });
108
- }
109
- }
110
-
111
- // 遍历文件夹中所有文件夹
112
- function listFolderSync(source, callback) {
113
- if (fs.lstatSync(source).isDirectory()) {
114
- (function doIt(source) {
115
-
116
- // 读取子内容
117
- const subItems = fs.readdirSync(source);
118
- subItems.forEach(function (item) {
119
- let itemPath = path.join(source, "./" + item);
120
-
121
- // 如果是文件夹
122
- if (fs.lstatSync(itemPath).isDirectory()) {
123
-
124
- let notDeep = callback({
125
- "name": item,
126
- "path": itemPath
127
- });
128
-
129
- // 深入
130
- if (!notDeep) {
131
- doIt(itemPath);
132
- }
133
-
134
- }
135
- });
136
-
137
- })(source);
138
- }
139
- }
140
-
141
- // 获取文件或文件夹的全路径
142
- function fullPathSync(pathString, contextPath) {
143
- if (/^\//.test(pathString) || /^[A-Za-z]:\\/.test(pathString)) {
144
- // 如果传递的就是全路径
145
- return pathString;
146
- }
147
-
148
- if (arguments.length <= 1) {
149
- // 默认把当前命令行作为上下文路径
150
- contextPath = process.cwd();
151
- }
152
-
153
- // 拼全路径
154
- return path.join(contextPath, pathString);
155
- }
156
-
157
- // 导出
158
- exports.deleteSync = deleteSync;
159
- exports.copySync = copySync;
160
- exports.moveSync = moveSync;
161
- exports.listFileSync = listFileSync;
162
- exports.listFolderSync = listFolderSync;
163
- exports.fullPathSync = fullPathSync;
@@ -1,5 +0,0 @@
1
- const fs = require('fs');
2
-
3
- exports.toBase64 = function (filepath) {
4
- return "data:image/png;base64," + fs.readFileSync(filepath).toString('base64');
5
- };
@@ -1,49 +0,0 @@
1
- /**
2
- *
3
- * 命令行参数解析
4
- *
5
- * @param {JSON} config 命令参数缩小到全写的映射
6
- * @param {Array} argv 需要判断类型的值
7
- *
8
- * @returns {JSON} 返回整理后的参数
9
- *
10
- */
11
- module.exports = function (config, argv) {
12
-
13
- let resultConfig = {
14
- __terminal__: []
15
- }, flag = null;
16
- for (let i = 2; i < argv.length; i++) {
17
-
18
- // 如果是新的配置
19
- if (/^--[0-9a-zA-Z]+$/.test(argv[i]) || /^-[0-9a-zA-Z]$/.test(argv[i])) {
20
- let key = argv[i];
21
-
22
- // 如果是缩写,需要映射
23
- if (key.length == 2) {
24
- key = config[key];
25
-
26
- // 如果是错误缩写
27
- if (!key) {
28
- flag = null;
29
- continue;
30
- }
31
- }
32
-
33
- flag = key.replace(/^--/, "");
34
- resultConfig[flag] = [];
35
- }
36
-
37
- // 如果是普通的参数
38
- else if (flag != null) {
39
- resultConfig[flag].push(argv[i]);
40
- }
41
-
42
- else {
43
- resultConfig.__terminal__.push(argv[i]);
44
- }
45
-
46
- }
47
-
48
- return resultConfig;
49
- };
@@ -1,60 +0,0 @@
1
- const https = require('https');
2
- const http = require('http');
3
-
4
- exports.get = function (url, options = {}) {
5
- return new Promise((resolve, reject) => {
6
-
7
- let handler = /^https/.test(url) ? https : http;
8
-
9
- handler.get(url, res => {
10
- res.on('data', (data) => {
11
- if (options.json) {
12
- resolve(JSON.parse(data.toString('utf8')));
13
- } else {
14
- resolve(data);
15
- }
16
- });
17
- }).on('error', (e) => {
18
- reject(e);
19
- });
20
- });
21
- };
22
-
23
- exports.post = function (url, options = {}) {
24
- return new Promise((resolve, reject) => {
25
-
26
- let handler = /^https/.test(url) ? https : http;
27
-
28
- let execArray = /https*:\/\/([^\/]+)(.+)?/.exec(url);
29
- let hostport = execArray[1].split(":");
30
-
31
- const req = handler.request({
32
- hostname: hostport[0],
33
- port: hostport[1] || 80,
34
- path: execArray[2] || "/",
35
- method: "POST",
36
- headers: options.header || {}
37
- }, (res) => {
38
- res.setEncoding('utf8');
39
-
40
- let data = "";
41
- res.on('data', (chunk) => {
42
- data += chunk;
43
- });
44
- res.on('end', () => {
45
- if (options.json) {
46
- resolve(JSON.parse(data.toString('utf8')));
47
- } else {
48
- resolve(data);
49
- }
50
- });
51
- });
52
-
53
- req.write(options.params || "{}");
54
-
55
- req.on('error', (e) => {
56
- reject(e);
57
- });
58
- req.end();
59
- });
60
- };
@@ -1,28 +0,0 @@
1
- const fs = require('fs');
2
- const path = require('path');
3
-
4
- const Template_404 = require('../data/404');
5
-
6
- // 读取当前路径下的文件,方便服务器404的时候导航
7
- module.exports = function (fullUrl) {
8
-
9
- let files, content = fullUrl;
10
- try {
11
- files = fs.readdirSync(fullUrl);
12
- } catch (e) {
13
- try {
14
- content = path.resolve(fullUrl, '../');
15
- files = fs.readdirSync(content);
16
- } catch (e) {
17
- files = [];
18
- }
19
- }
20
-
21
- let template = "<a href='../'>..</a>";
22
- for (let i in files) {
23
- let isDirectory = fs.lstatSync(path.join(content, files[i])).isDirectory();
24
- template += "<a class='" + (isDirectory ? "folder" : "file") + "' href='./" + files[i] + (isDirectory ? "/" : "") + "'>" + files[i] + "</a>";
25
- }
26
-
27
- return Template_404(template);
28
- };
@@ -1,190 +0,0 @@
1
- const http = require('http');
2
- const fs = require('fs');
3
-
4
- const mineTypes = require('../data/mime.types.js');
5
- const { log, warn, error } = require('./log.js');
6
- const responseFileList = require('./responseFileList.js');
7
- const path = require('path');
8
- const network = require('./network.js');
9
-
10
- const jsonfile = JSON.parse(fs.readFileSync(path.join(__dirname, '../../package.json')));
11
-
12
- module.exports = function (config = {}) {
13
-
14
- let port = config.port || 20000; // 端口号
15
- let handler = typeof config.handler == 'function' ? config.handler : function () { return false; };
16
- let suffixs = Array.isArray(config.suffix) ? config.suffix : [".html", ".htm", ".js", ".json", ".css"];
17
-
18
- let proxy = [];
19
- if (config.proxy) {
20
- for (let item of config.proxy) {
21
- let target = /(https*):\/\/([^/:]+):*(\d+)*(.*)/.exec(item.target) || [];
22
- proxy.push({
23
- test: item.test,
24
- target: {
25
- protocol: target[1], // 使用的协议
26
- hostname: target[2], // 请求发送至的服务器的域名或 IP 地址
27
- port: target[3] || 80, // 端口号
28
- path: target[4] || "", // 路径前缀
29
- }
30
- });
31
- }
32
- }
33
-
34
- let basePath = path.join(process.cwd(), config.basePath || "./"); // 服务器根路径
35
-
36
- let index = 0;
37
- let Server = http.createServer(function (request, response) {
38
- try {
39
- let requestData = "";
40
-
41
- request.on('data', (chunk) => {
42
- requestData += chunk;
43
- });
44
-
45
- request.on('end', () => {
46
- let url = decodeURIComponent(request.url);
47
-
48
- url = url.split("?")[0];
49
-
50
- // 请求的文件路径
51
- let filePath = path.join(basePath, url == "/" ? "index.html" : url.replace(/^\//, ""));
52
-
53
- log("[" + index++ + "]" + url);
54
-
55
- let getFileInfo = function (filePath) {
56
- let dotName = /\./.test(filePath) ? filePath.match(/\.([^.]+)$/)[1] : "";
57
- let type = mineTypes[dotName];
58
- if (fs.existsSync(filePath) && !fs.lstatSync(filePath).isDirectory()) {
59
- return {
60
- type,
61
- path: filePath
62
- };
63
- } else {
64
- for (let suffix of suffixs) {
65
- if (fs.existsSync(filePath + suffix) && !fs.lstatSync(filePath + suffix).isDirectory()) {
66
- type = mineTypes[suffix.replace(/^\./, "")];
67
- return {
68
- type,
69
- path: filePath + suffix
70
- };
71
- }
72
- }
73
- }
74
- };
75
-
76
- // 自定义拦截
77
- if (handler.call({
78
- data: requestData,
79
- base: basePath,
80
- getFileInfo,
81
- filePath
82
- }, request, response)) return;
83
-
84
- // proxy拦截
85
- for (let item of proxy) {
86
- if (item.test.test(url)) {
87
- let _path = item.target.path + (url.replace(item.test, ""));
88
-
89
- warn(" ↳ [" + request.method + "] " + item.target.protocol + "://" + item.target.hostname + ":" + item.target.port + _path);
90
-
91
- // https://www.nodeapp.cn/http.html#http_http_request_options_callback
92
- const req = http.request({
93
- hostname: item.target.hostname,
94
- port: item.target.port,
95
- path: _path,
96
- method: request.method,
97
- headers: request.headers
98
- }, (res) => {
99
- res.setEncoding('utf8');
100
-
101
- let responseData = "";
102
- res.on('data', (chunk) => {
103
- responseData += chunk;
104
- });
105
- res.on('end', () => {
106
- let responseHeaders = res.headers;
107
- responseHeaders['proxy-server'] = "Powered by OIPage@" + jsonfile.version;
108
- responseHeaders['Access-Control-Allow-Origin'] = '*';
109
- response.writeHead(res.statusCode, responseHeaders);
110
- response.write(responseData);
111
- response.end();
112
- });
113
- });
114
-
115
- req.on('error', (e) => {
116
- error(` 转发的时候遇到问题: ${e.message}`);
117
- response.writeHead('500', {
118
- 'Content-type': "text/plain;charset=utf-8",
119
- 'Access-Control-Allow-Origin': '*',
120
- "proxy-server": "Powered by OIPage@" + jsonfile.version
121
- });
122
- response.write(e + "");
123
- response.end();
124
- });
125
-
126
- req.write(requestData);
127
- req.end();
128
-
129
- return;
130
- }
131
- }
132
-
133
- let is404 = true;
134
- let doResponse = function (type, filePath) {
135
- response.writeHead(200, {
136
- 'Content-type': (type || "text/plain") + ";charset=utf-8",
137
- 'Access-Control-Allow-Origin': '*',
138
- 'Server': "Powered by OIPage@" + jsonfile.version
139
- });
140
- response.write(fs.readFileSync(filePath));
141
- is404 = false;
142
- };
143
-
144
- let fileInfo = getFileInfo(filePath);
145
- if (fileInfo) { // 如果文件存在
146
- doResponse(fileInfo.type, fileInfo.path);
147
- }
148
-
149
- if (is404) {
150
- response.writeHead(404, {
151
- 'Content-type': "text/html;charset=utf-8",
152
- 'Access-Control-Allow-Origin': '*',
153
- 'Server': "Powered by OIPage@" + jsonfile.version
154
- });
155
- response.write(responseFileList(filePath));
156
- }
157
-
158
- response.end();
159
- });
160
- } catch (e) {
161
- error(e);
162
-
163
- response.writeHead(500, {
164
- 'Content-type': "text/plain;charset=utf-8",
165
- 'Access-Control-Allow-Origin': '*',
166
- 'Server': "Powered by OIPage@" + jsonfile.version
167
- });
168
- response.write(e + "");
169
-
170
- response.end();
171
- }
172
-
173
- });
174
-
175
- Server.listen(port);
176
-
177
- // 打印启动成功信息
178
-
179
- log('\n<i> [OIPage-server] Project is running at:');
180
- log('<i> [OIPage-server] Loopback: http://localhost:' + port + '/');
181
-
182
- let networkInfo = network();
183
-
184
- // 打印IPv4地址
185
- for (let ipv4 of networkInfo.IPv4) {
186
- log('<i> [OIPage-server] On Your Network (IPv4): http://' + ipv4.address + ':' + port + '/');
187
- }
188
-
189
- log('\nOIPage Server compiled successfully\n');
190
- };
@@ -1,52 +0,0 @@
1
- const img_folder = require("./images/folder");
2
- const img_file = require("./images/file");
3
-
4
- module.exports = function (template) {
5
- return `<!DOCTYPE html>
6
- <html lang="zh-cn">
7
-
8
- <head>
9
- <meta charset="UTF-8">
10
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
11
- <meta http-equiv="X-UA-Compatible" content="ie=edge">
12
- <title>404 Not Found</title>
13
- <style>
14
- body{
15
- margin: 0px;
16
- background-color:#fcfcfc;
17
- display: flex;
18
- flex-wrap:wrap;
19
- padding:100px;
20
- }
21
- body>a{
22
- text-decoration: none;
23
- padding:10px;
24
- color:#000000;
25
- text-align:center;
26
- width:100px;
27
- background-repeat: no-repeat;
28
- background-position: center 0px;
29
- padding-top: 65px;
30
- margin-top: 50px;
31
- font-size:12px;
32
- }
33
- body>a:hover{
34
- outline:1px solid #55b9e6;
35
- }
36
- body>a.folder{
37
- background-image:url('${img_folder}');
38
- }
39
- body>a.file{
40
- background-image:url('${img_file}');
41
- }
42
- </style>
43
- </head>
44
-
45
- <body>
46
-
47
- ${template}
48
-
49
- </body>
50
-
51
- </html>`;
52
- };
@@ -1 +0,0 @@
1
- module.exports = "";
@@ -1 +0,0 @@
1
- module.exports = "";