@modern-js/server 2.4.1-beta.0 → 2.5.1-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.
- package/CHANGELOG.md +23 -4
- package/dist/cjs/constants.js +42 -0
- package/dist/cjs/dev-tools/dev-middleware/hmr-client/createSocketUrl.js +65 -0
- package/dist/cjs/dev-tools/dev-middleware/hmr-client/index.js +155 -0
- package/dist/cjs/dev-tools/dev-middleware/index.js +86 -0
- package/dist/cjs/dev-tools/dev-middleware/socket-server.js +159 -0
- package/dist/cjs/dev-tools/https/index.js +52 -0
- package/dist/cjs/dev-tools/mock/getMockData.js +91 -0
- package/dist/cjs/dev-tools/mock/index.js +79 -0
- package/dist/cjs/dev-tools/register/index.js +125 -0
- package/dist/cjs/dev-tools/watcher/dependency-tree.js +89 -0
- package/dist/cjs/dev-tools/watcher/index.js +126 -0
- package/dist/cjs/dev-tools/watcher/stats-cache.js +87 -0
- package/dist/cjs/index.js +35 -0
- package/dist/cjs/server/dev-server.js +267 -0
- package/dist/cjs/server/index.js +39 -0
- package/dist/cjs/types.js +15 -0
- package/dist/esm/constants.js +21 -0
- package/dist/esm/dev-tools/dev-middleware/hmr-client/createSocketUrl.js +51 -0
- package/dist/esm/dev-tools/dev-middleware/hmr-client/index.js +162 -0
- package/dist/esm/dev-tools/dev-middleware/index.js +322 -0
- package/dist/esm/dev-tools/dev-middleware/socket-server.js +209 -0
- package/dist/esm/dev-tools/https/index.js +193 -0
- package/dist/esm/dev-tools/mock/getMockData.js +318 -0
- package/dist/esm/dev-tools/mock/index.js +207 -0
- package/dist/esm/dev-tools/register/index.js +154 -0
- package/dist/esm/dev-tools/watcher/dependency-tree.js +150 -0
- package/dist/esm/dev-tools/watcher/index.js +200 -0
- package/dist/esm/dev-tools/watcher/stats-cache.js +128 -0
- package/dist/esm/index.js +9 -0
- package/dist/esm/server/dev-server.js +800 -0
- package/dist/esm/server/index.js +92 -0
- package/dist/esm/types.js +1 -0
- package/dist/esm-node/constants.js +19 -0
- package/dist/esm-node/dev-tools/dev-middleware/hmr-client/createSocketUrl.js +41 -0
- package/dist/esm-node/dev-tools/dev-middleware/hmr-client/index.js +146 -0
- package/dist/esm-node/dev-tools/dev-middleware/index.js +59 -0
- package/dist/esm-node/dev-tools/dev-middleware/socket-server.js +132 -0
- package/dist/esm-node/dev-tools/https/index.js +29 -0
- package/dist/esm-node/dev-tools/mock/getMockData.js +68 -0
- package/dist/esm-node/dev-tools/mock/index.js +50 -0
- package/dist/esm-node/dev-tools/register/index.js +96 -0
- package/dist/esm-node/dev-tools/watcher/dependency-tree.js +59 -0
- package/dist/esm-node/dev-tools/watcher/index.js +95 -0
- package/dist/esm-node/dev-tools/watcher/stats-cache.js +58 -0
- package/dist/esm-node/index.js +12 -0
- package/dist/esm-node/server/dev-server.js +247 -0
- package/dist/esm-node/server/index.js +16 -0
- package/dist/esm-node/types.js +0 -0
- package/dist/js/modern/dev-tools/dev-middleware/hmr-client/index.js +3 -6
- package/dist/js/node/dev-tools/dev-middleware/hmr-client/index.js +3 -6
- package/dist/js/treeshaking/dev-tools/dev-middleware/hmr-client/index.js +1 -6
- package/dist/js/treeshaking/dev-tools/dev-middleware/index.js +2 -2
- package/dist/js/treeshaking/dev-tools/dev-middleware/socket-server.js +2 -2
- package/dist/js/treeshaking/dev-tools/register/index.js +6 -6
- package/dist/js/treeshaking/dev-tools/watcher/index.js +4 -4
- package/dist/js/treeshaking/dev-tools/watcher/stats-cache.js +3 -3
- package/dist/js/treeshaking/server/dev-server.js +10 -10
- package/dist/types/dev-tools/mock/getMockData.d.ts +1 -1
- package/package.json +15 -16
|
@@ -0,0 +1,267 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
21
|
+
mod
|
|
22
|
+
));
|
|
23
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
24
|
+
var dev_server_exports = {};
|
|
25
|
+
__export(dev_server_exports, {
|
|
26
|
+
ModernDevServer: () => ModernDevServer
|
|
27
|
+
});
|
|
28
|
+
module.exports = __toCommonJS(dev_server_exports);
|
|
29
|
+
var import_http = require("http");
|
|
30
|
+
var import_path = __toESM(require("path"));
|
|
31
|
+
var import_https = require("https");
|
|
32
|
+
var import_utils = require("@modern-js/utils");
|
|
33
|
+
var import_prod_server = require("@modern-js/prod-server");
|
|
34
|
+
var import_constants = require("@modern-js/utils/constants");
|
|
35
|
+
var import_constants2 = require("../constants");
|
|
36
|
+
var import_mock = require("../dev-tools/mock");
|
|
37
|
+
var import_register = require("../dev-tools/register");
|
|
38
|
+
var import_watcher = __toESM(require("../dev-tools/watcher"));
|
|
39
|
+
var import_dev_middleware = __toESM(require("../dev-tools/dev-middleware"));
|
|
40
|
+
class ModernDevServer extends import_prod_server.ModernServer {
|
|
41
|
+
constructor(options) {
|
|
42
|
+
super(options);
|
|
43
|
+
this.mockHandler = null;
|
|
44
|
+
this.workDir = this.pwd;
|
|
45
|
+
this.dev = this.getDevOptions(options);
|
|
46
|
+
this.devMiddleware = new import_dev_middleware.default({
|
|
47
|
+
dev: this.dev,
|
|
48
|
+
devMiddleware: options.devMiddleware
|
|
49
|
+
});
|
|
50
|
+
(0, import_register.enableRegister)(this.pwd, this.conf);
|
|
51
|
+
}
|
|
52
|
+
getDevOptions(options) {
|
|
53
|
+
const devOptions = typeof options.dev === "boolean" ? {} : options.dev;
|
|
54
|
+
const defaultOptions = (0, import_constants2.getDefaultDevOptions)();
|
|
55
|
+
return {
|
|
56
|
+
...defaultOptions,
|
|
57
|
+
...devOptions,
|
|
58
|
+
client: {
|
|
59
|
+
...defaultOptions.client,
|
|
60
|
+
...devOptions == null ? void 0 : devOptions.client
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
addMiddlewareHandler(handlers) {
|
|
65
|
+
handlers.forEach((handler) => {
|
|
66
|
+
this.addHandler((ctx, next) => {
|
|
67
|
+
const { req, res } = ctx;
|
|
68
|
+
return handler(req, res, next);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
applySetupMiddlewares() {
|
|
73
|
+
const setupMiddlewares = this.dev.setupMiddlewares || [];
|
|
74
|
+
const serverOptions = {
|
|
75
|
+
sockWrite: (type, data) => this.devMiddleware.sockWrite(type, data)
|
|
76
|
+
};
|
|
77
|
+
const befores = [];
|
|
78
|
+
const afters = [];
|
|
79
|
+
setupMiddlewares.forEach((handler) => {
|
|
80
|
+
handler(
|
|
81
|
+
{
|
|
82
|
+
unshift: (...handlers) => befores.unshift(...handlers),
|
|
83
|
+
push: (...handlers) => afters.push(...handlers)
|
|
84
|
+
},
|
|
85
|
+
serverOptions
|
|
86
|
+
);
|
|
87
|
+
});
|
|
88
|
+
return { befores, afters };
|
|
89
|
+
}
|
|
90
|
+
async onInit(runner, app) {
|
|
91
|
+
this.runner = runner;
|
|
92
|
+
const { dev } = this;
|
|
93
|
+
const { befores, afters } = this.applySetupMiddlewares();
|
|
94
|
+
const beforeHandlers = await this.setupBeforeDevMiddleware();
|
|
95
|
+
this.addMiddlewareHandler([...beforeHandlers, ...befores]);
|
|
96
|
+
await this.applyDefaultMiddlewares(app);
|
|
97
|
+
const afterHandlers = await this.setupAfterDevMiddleware();
|
|
98
|
+
this.addMiddlewareHandler([...afters, ...afterHandlers]);
|
|
99
|
+
await super.onInit(runner, app);
|
|
100
|
+
if (dev.watch) {
|
|
101
|
+
this.startWatcher();
|
|
102
|
+
app.on("close", async () => {
|
|
103
|
+
var _a;
|
|
104
|
+
await ((_a = this.watcher) == null ? void 0 : _a.close());
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
async applyDefaultMiddlewares(app) {
|
|
109
|
+
const { pwd, dev, devMiddleware } = this;
|
|
110
|
+
this.addHandler((ctx, next) => {
|
|
111
|
+
ctx.res.setHeader("Access-Control-Allow-Origin", "*");
|
|
112
|
+
if (ctx.path.includes("hot-update")) {
|
|
113
|
+
ctx.res.setHeader("Access-Control-Allow-Credentials", "false");
|
|
114
|
+
}
|
|
115
|
+
const confHeaders = dev.headers;
|
|
116
|
+
if (confHeaders) {
|
|
117
|
+
for (const [key, value] of Object.entries(confHeaders)) {
|
|
118
|
+
ctx.res.setHeader(key, value);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
next();
|
|
122
|
+
});
|
|
123
|
+
this.mockHandler = (0, import_mock.createMockHandler)({ pwd });
|
|
124
|
+
this.addHandler((ctx, next) => {
|
|
125
|
+
if (this.mockHandler) {
|
|
126
|
+
this.mockHandler(ctx, next);
|
|
127
|
+
} else {
|
|
128
|
+
next();
|
|
129
|
+
}
|
|
130
|
+
});
|
|
131
|
+
const proxyHandlers = (0, import_prod_server.createProxyHandler)(dev.proxy);
|
|
132
|
+
if (proxyHandlers) {
|
|
133
|
+
proxyHandlers.forEach((handler) => {
|
|
134
|
+
this.addHandler(handler);
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
devMiddleware.init(app);
|
|
138
|
+
devMiddleware.on("change", (stats) => {
|
|
139
|
+
if (stats.toJson({ all: false }).name === "client") {
|
|
140
|
+
this.onRepack({ routes: this.getRoutes() });
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
this.addHandler((ctx, next) => {
|
|
144
|
+
const { req, res } = ctx;
|
|
145
|
+
if (devMiddleware.middleware) {
|
|
146
|
+
devMiddleware.middleware(req, res, next);
|
|
147
|
+
} else {
|
|
148
|
+
next();
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
if (dev.historyApiFallback) {
|
|
152
|
+
const { default: connectHistoryApiFallback } = await Promise.resolve().then(() => __toESM(require("connect-history-api-fallback")));
|
|
153
|
+
const historyApiFallbackMiddleware = connectHistoryApiFallback(
|
|
154
|
+
typeof dev.historyApiFallback === "boolean" ? {} : dev.historyApiFallback
|
|
155
|
+
);
|
|
156
|
+
this.addHandler(
|
|
157
|
+
(ctx, next) => historyApiFallbackMiddleware(ctx.req, ctx.res, next)
|
|
158
|
+
);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
onRepack(options = {}) {
|
|
162
|
+
if (Array.isArray(options.routes)) {
|
|
163
|
+
this.router.reset(this.filterRoutes(options.routes));
|
|
164
|
+
}
|
|
165
|
+
this.cleanSSRCache();
|
|
166
|
+
this.reader.updateFile();
|
|
167
|
+
this.runner.repack();
|
|
168
|
+
super.onRepack(options);
|
|
169
|
+
}
|
|
170
|
+
async createHTTPServer(handler) {
|
|
171
|
+
const { dev } = this;
|
|
172
|
+
const devHttpsOption = typeof dev === "object" && dev.https;
|
|
173
|
+
if (devHttpsOption) {
|
|
174
|
+
const { genHttpsOptions } = require("../dev-tools/https");
|
|
175
|
+
const httpsOptions = await genHttpsOptions(devHttpsOption, this.pwd);
|
|
176
|
+
return (0, import_https.createServer)(httpsOptions, handler);
|
|
177
|
+
} else {
|
|
178
|
+
return (0, import_http.createServer)(handler);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
warmupSSRBundle() {
|
|
182
|
+
}
|
|
183
|
+
onServerChange({
|
|
184
|
+
filepath,
|
|
185
|
+
event
|
|
186
|
+
}) {
|
|
187
|
+
const { pwd } = this;
|
|
188
|
+
const { mock } = import_prod_server.AGGRED_DIR;
|
|
189
|
+
const mockPath = import_path.default.normalize(import_path.default.join(pwd, mock));
|
|
190
|
+
this.runner.reset();
|
|
191
|
+
if (filepath.startsWith(mockPath)) {
|
|
192
|
+
this.mockHandler = (0, import_mock.createMockHandler)({ pwd });
|
|
193
|
+
} else {
|
|
194
|
+
try {
|
|
195
|
+
const success = this.runner.onApiChange([
|
|
196
|
+
{ filename: filepath, event }
|
|
197
|
+
]);
|
|
198
|
+
if (success !== true) {
|
|
199
|
+
super.onServerChange({ filepath });
|
|
200
|
+
}
|
|
201
|
+
} catch (e) {
|
|
202
|
+
this.logger.error(e);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
createContext(req, res) {
|
|
207
|
+
return super.createContext(req, res, { etag: true });
|
|
208
|
+
}
|
|
209
|
+
async setupBeforeDevMiddleware() {
|
|
210
|
+
const { runner, conf, dev } = this;
|
|
211
|
+
const setupMids = dev.before || [];
|
|
212
|
+
const pluginMids = await runner.beforeDevServer(conf);
|
|
213
|
+
return [...setupMids, ...pluginMids].flat();
|
|
214
|
+
}
|
|
215
|
+
async setupAfterDevMiddleware() {
|
|
216
|
+
const { runner, conf, dev } = this;
|
|
217
|
+
const setupMids = dev.after || [];
|
|
218
|
+
const pluginMids = await runner.afterDevServer(conf);
|
|
219
|
+
return [...pluginMids, ...setupMids].flat();
|
|
220
|
+
}
|
|
221
|
+
cleanSSRCache() {
|
|
222
|
+
const { distDir } = this;
|
|
223
|
+
const bundles = this.router.getBundles();
|
|
224
|
+
bundles.forEach((bundle) => {
|
|
225
|
+
const filepath = import_path.default.join(distDir, bundle);
|
|
226
|
+
if (require.cache[filepath]) {
|
|
227
|
+
delete require.cache[filepath];
|
|
228
|
+
}
|
|
229
|
+
});
|
|
230
|
+
const loadable = import_path.default.join(distDir, import_constants.LOADABLE_STATS_FILE);
|
|
231
|
+
if (require.cache[loadable]) {
|
|
232
|
+
delete require.cache[loadable];
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
startWatcher() {
|
|
236
|
+
var _a;
|
|
237
|
+
const { pwd, distDir } = this;
|
|
238
|
+
const { mock } = import_prod_server.AGGRED_DIR;
|
|
239
|
+
const defaultWatched = [
|
|
240
|
+
`${mock}/**/*`,
|
|
241
|
+
`${import_utils.SERVER_DIR}/**/*`,
|
|
242
|
+
`${import_utils.API_DIR}/**`,
|
|
243
|
+
`${import_utils.SHARED_DIR}/**/*`,
|
|
244
|
+
`${distDir}/${import_utils.SERVER_BUNDLE_DIRECTORY}/*-server-loaders.js`
|
|
245
|
+
];
|
|
246
|
+
const watchOptions = (0, import_watcher.mergeWatchOptions)((_a = this.conf.server) == null ? void 0 : _a.watchOptions);
|
|
247
|
+
const defaultWatchedPaths = defaultWatched.map((p) => {
|
|
248
|
+
const finalPath = import_path.default.isAbsolute(p) ? p : import_path.default.join(pwd, p);
|
|
249
|
+
return import_path.default.normalize(finalPath);
|
|
250
|
+
});
|
|
251
|
+
const watcher = new import_watcher.default();
|
|
252
|
+
watcher.createDepTree();
|
|
253
|
+
watcher.listen(defaultWatchedPaths, watchOptions, (filepath, event) => {
|
|
254
|
+
watcher.updateDepTree();
|
|
255
|
+
watcher.cleanDepCache(filepath);
|
|
256
|
+
this.onServerChange({
|
|
257
|
+
filepath,
|
|
258
|
+
event
|
|
259
|
+
});
|
|
260
|
+
});
|
|
261
|
+
this.watcher = watcher;
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
265
|
+
0 && (module.exports = {
|
|
266
|
+
ModernDevServer
|
|
267
|
+
});
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all)
|
|
7
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
+
};
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
+
}
|
|
15
|
+
return to;
|
|
16
|
+
};
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
+
var server_exports = {};
|
|
19
|
+
__export(server_exports, {
|
|
20
|
+
DevServer: () => DevServer
|
|
21
|
+
});
|
|
22
|
+
module.exports = __toCommonJS(server_exports);
|
|
23
|
+
var import_prod_server = require("@modern-js/prod-server");
|
|
24
|
+
var import_dev_server = require("./dev-server");
|
|
25
|
+
const createDevServer = (options) => {
|
|
26
|
+
return new import_dev_server.ModernDevServer(options);
|
|
27
|
+
};
|
|
28
|
+
class DevServer extends import_prod_server.Server {
|
|
29
|
+
constructor(options) {
|
|
30
|
+
super(options);
|
|
31
|
+
if (options.dev) {
|
|
32
|
+
this.serverImpl = createDevServer;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
37
|
+
0 && (module.exports = {
|
|
38
|
+
DevServer
|
|
39
|
+
});
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __copyProps = (to, from, except, desc) => {
|
|
6
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
7
|
+
for (let key of __getOwnPropNames(from))
|
|
8
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
9
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
10
|
+
}
|
|
11
|
+
return to;
|
|
12
|
+
};
|
|
13
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
14
|
+
var types_exports = {};
|
|
15
|
+
module.exports = __toCommonJS(types_exports);
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { getIpv4Interfaces, HMR_SOCK_PATH } from "@modern-js/utils";
|
|
2
|
+
var getDefaultDevOptions = function() {
|
|
3
|
+
var network = getIpv4Interfaces().find(function(item) {
|
|
4
|
+
return !item.internal;
|
|
5
|
+
});
|
|
6
|
+
return {
|
|
7
|
+
client: {
|
|
8
|
+
port: "8080",
|
|
9
|
+
path: HMR_SOCK_PATH,
|
|
10
|
+
host: (network === null || network === void 0 ? void 0 : network.address) || "localhost"
|
|
11
|
+
},
|
|
12
|
+
https: false,
|
|
13
|
+
devMiddleware: {
|
|
14
|
+
writeToDisk: true
|
|
15
|
+
},
|
|
16
|
+
watch: true,
|
|
17
|
+
hot: true,
|
|
18
|
+
liveReload: true
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
export { getDefaultDevOptions };
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { HMR_SOCK_PATH } from "@modern-js/utils/constants";
|
|
2
|
+
function createSocketUrl(resourceQuery) {
|
|
3
|
+
var searchParams = resourceQuery.substr(1).split("&");
|
|
4
|
+
var options = {};
|
|
5
|
+
var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
|
|
6
|
+
try {
|
|
7
|
+
for(var _iterator = searchParams[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
|
|
8
|
+
var pair = _step.value;
|
|
9
|
+
var ary = pair.split("=");
|
|
10
|
+
options[ary[0]] = decodeURIComponent(ary[1]);
|
|
11
|
+
}
|
|
12
|
+
} catch (err) {
|
|
13
|
+
_didIteratorError = true;
|
|
14
|
+
_iteratorError = err;
|
|
15
|
+
} finally{
|
|
16
|
+
try {
|
|
17
|
+
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
18
|
+
_iterator.return();
|
|
19
|
+
}
|
|
20
|
+
} finally{
|
|
21
|
+
if (_didIteratorError) {
|
|
22
|
+
throw _iteratorError;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
var currentLocation = self.location;
|
|
27
|
+
return getSocketUrl(options, currentLocation);
|
|
28
|
+
}
|
|
29
|
+
function formatURL(param) {
|
|
30
|
+
var port = param.port, protocol = param.protocol, hostname = param.hostname, pathname = param.pathname;
|
|
31
|
+
if (window.URL) {
|
|
32
|
+
var url = new URL("http://localhost");
|
|
33
|
+
url.port = port;
|
|
34
|
+
url.hostname = hostname;
|
|
35
|
+
url.protocol = protocol;
|
|
36
|
+
url.pathname = pathname;
|
|
37
|
+
return url.toString();
|
|
38
|
+
}
|
|
39
|
+
var colon = protocol.indexOf(":") === -1 ? ":" : "";
|
|
40
|
+
return "".concat(protocol).concat(colon, "//").concat(hostname, ":").concat(port).concat(pathname);
|
|
41
|
+
}
|
|
42
|
+
function getSocketUrl(urlParts, location) {
|
|
43
|
+
var host = urlParts.host, port = urlParts.port, path = urlParts.path, protocol = urlParts.protocol;
|
|
44
|
+
return formatURL({
|
|
45
|
+
protocol: protocol || (location.protocol === "https:" ? "wss" : "ws"),
|
|
46
|
+
hostname: host || location.hostname,
|
|
47
|
+
port: port || location.port,
|
|
48
|
+
pathname: path || HMR_SOCK_PATH
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
export { createSocketUrl, formatURL };
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
2
|
+
var __commonJS = function(cb, mod) {
|
|
3
|
+
return function __require() {
|
|
4
|
+
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = {
|
|
5
|
+
exports: {}
|
|
6
|
+
}).exports, mod), mod.exports;
|
|
7
|
+
};
|
|
8
|
+
};
|
|
9
|
+
import stripAnsi from "@modern-js/utils/strip-ansi";
|
|
10
|
+
import { formatWebpackMessages } from "@modern-js/utils/format";
|
|
11
|
+
import { createSocketUrl } from "./createSocketUrl";
|
|
12
|
+
var require_hmr_client = __commonJS({
|
|
13
|
+
"src/dev-tools/dev-middleware/hmr-client/index.ts": function(exports, module) {
|
|
14
|
+
var clearOutdatedErrors = function clearOutdatedErrors() {
|
|
15
|
+
if (typeof console !== "undefined" && typeof console.clear === "function") {
|
|
16
|
+
if (hasCompileErrors) {
|
|
17
|
+
console.clear();
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
var handleSuccess = function handleSuccess() {
|
|
22
|
+
clearOutdatedErrors();
|
|
23
|
+
var isHotUpdate = !isFirstCompilation;
|
|
24
|
+
isFirstCompilation = false;
|
|
25
|
+
hasCompileErrors = false;
|
|
26
|
+
if (isHotUpdate) {
|
|
27
|
+
tryApplyUpdates();
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
var handleWarnings = function handleWarnings(warnings) {
|
|
31
|
+
clearOutdatedErrors();
|
|
32
|
+
var isHotUpdate = !isFirstCompilation;
|
|
33
|
+
isFirstCompilation = false;
|
|
34
|
+
hasCompileErrors = false;
|
|
35
|
+
function printWarnings() {
|
|
36
|
+
var formatted = formatWebpackMessages({
|
|
37
|
+
warnings: warnings,
|
|
38
|
+
errors: []
|
|
39
|
+
});
|
|
40
|
+
if (typeof console !== "undefined" && typeof console.warn === "function") {
|
|
41
|
+
for(var i = 0; i < formatted.warnings.length; i++){
|
|
42
|
+
if (i === 5) {
|
|
43
|
+
console.warn("There were more warnings in other files.\nYou can find a complete log in the terminal.");
|
|
44
|
+
break;
|
|
45
|
+
}
|
|
46
|
+
console.warn(stripAnsi(formatted.warnings[i]));
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
printWarnings();
|
|
51
|
+
if (isHotUpdate) {
|
|
52
|
+
tryApplyUpdates();
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
var handleErrors = function handleErrors(errors) {
|
|
56
|
+
clearOutdatedErrors();
|
|
57
|
+
isFirstCompilation = false;
|
|
58
|
+
hasCompileErrors = true;
|
|
59
|
+
var formatted = formatWebpackMessages({
|
|
60
|
+
errors: errors,
|
|
61
|
+
warnings: []
|
|
62
|
+
});
|
|
63
|
+
if (typeof console !== "undefined" && typeof console.error === "function") {
|
|
64
|
+
var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
|
|
65
|
+
try {
|
|
66
|
+
for(var _iterator = formatted.errors[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
|
|
67
|
+
var error = _step.value;
|
|
68
|
+
console.error(stripAnsi(error));
|
|
69
|
+
}
|
|
70
|
+
} catch (err) {
|
|
71
|
+
_didIteratorError = true;
|
|
72
|
+
_iteratorError = err;
|
|
73
|
+
} finally{
|
|
74
|
+
try {
|
|
75
|
+
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
76
|
+
_iterator.return();
|
|
77
|
+
}
|
|
78
|
+
} finally{
|
|
79
|
+
if (_didIteratorError) {
|
|
80
|
+
throw _iteratorError;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
var handleAvailableHash = function handleAvailableHash(hash) {
|
|
87
|
+
mostRecentCompilationHash = hash;
|
|
88
|
+
};
|
|
89
|
+
var isUpdateAvailable = function isUpdateAvailable() {
|
|
90
|
+
return mostRecentCompilationHash !== __webpack_hash__;
|
|
91
|
+
};
|
|
92
|
+
var canApplyUpdates = function canApplyUpdates() {
|
|
93
|
+
return module.hot.status() === "idle";
|
|
94
|
+
};
|
|
95
|
+
var hadRuntimeError = false;
|
|
96
|
+
var socketUrl = createSocketUrl(__resourceQuery);
|
|
97
|
+
var connection = new WebSocket(socketUrl);
|
|
98
|
+
connection.onopen = function() {
|
|
99
|
+
if (typeof console !== "undefined" && typeof console.debug === "function") {
|
|
100
|
+
console.debug("[HMR] connected.");
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
connection.onclose = function() {
|
|
104
|
+
if (typeof console !== "undefined" && typeof console.info === "function") {
|
|
105
|
+
console.debug("[HMR] disconnected. Refresh the page if necessary.");
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
var isFirstCompilation = true;
|
|
109
|
+
var mostRecentCompilationHash = null;
|
|
110
|
+
var hasCompileErrors = false;
|
|
111
|
+
connection.onmessage = function(e) {
|
|
112
|
+
var message = JSON.parse(e.data);
|
|
113
|
+
switch(message.type){
|
|
114
|
+
case "hash":
|
|
115
|
+
handleAvailableHash(message.data);
|
|
116
|
+
break;
|
|
117
|
+
case "still-ok":
|
|
118
|
+
case "ok":
|
|
119
|
+
handleSuccess();
|
|
120
|
+
break;
|
|
121
|
+
case "content-changed":
|
|
122
|
+
window.location.reload();
|
|
123
|
+
break;
|
|
124
|
+
case "warnings":
|
|
125
|
+
handleWarnings(message.data);
|
|
126
|
+
break;
|
|
127
|
+
case "errors":
|
|
128
|
+
handleErrors(message.data);
|
|
129
|
+
break;
|
|
130
|
+
default:
|
|
131
|
+
}
|
|
132
|
+
};
|
|
133
|
+
function tryApplyUpdates() {
|
|
134
|
+
if (!module.hot) {
|
|
135
|
+
window.location.reload();
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
if (!isUpdateAvailable() || !canApplyUpdates()) {
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
function handleApplyUpdates(err, updatedModules) {
|
|
142
|
+
var wantsForcedReload = err || !updatedModules || hadRuntimeError;
|
|
143
|
+
if (wantsForcedReload) {
|
|
144
|
+
window.location.reload();
|
|
145
|
+
return;
|
|
146
|
+
}
|
|
147
|
+
if (isUpdateAvailable()) {
|
|
148
|
+
tryApplyUpdates();
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
var result = module.hot.check(true, handleApplyUpdates);
|
|
152
|
+
if (result === null || result === void 0 ? void 0 : result.then) {
|
|
153
|
+
result.then(function(updatedModules) {
|
|
154
|
+
handleApplyUpdates(null, updatedModules);
|
|
155
|
+
}, function(err) {
|
|
156
|
+
handleApplyUpdates(err, null);
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
});
|
|
162
|
+
export default require_hmr_client();
|