@anansi/core 0.7.4 → 0.8.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 (48) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/server.js +27 -23
  3. package/dist/server.js.map +1 -1
  4. package/lib/floodSpouts.d.ts +6 -0
  5. package/lib/floodSpouts.d.ts.map +1 -0
  6. package/lib/index.d.ts +5 -0
  7. package/lib/index.d.ts.map +1 -0
  8. package/lib/index.server.d.ts +6 -0
  9. package/lib/index.server.d.ts.map +1 -0
  10. package/lib/laySpouts.d.ts +8 -0
  11. package/lib/laySpouts.d.ts.map +1 -0
  12. package/lib/scripts/index.d.ts +3 -0
  13. package/lib/scripts/index.d.ts.map +1 -0
  14. package/lib/scripts/index.js +15 -0
  15. package/lib/scripts/serve.d.ts +4 -0
  16. package/lib/scripts/serve.d.ts.map +1 -0
  17. package/lib/scripts/serve.js +162 -0
  18. package/lib/scripts/startDevserver.d.ts +4 -0
  19. package/lib/scripts/startDevserver.d.ts.map +1 -0
  20. package/lib/scripts/startDevserver.js +175 -164
  21. package/lib/scripts/types.d.ts +7 -0
  22. package/lib/scripts/types.d.ts.map +1 -0
  23. package/lib/spouts/DocumentComponent.d.ts +23 -0
  24. package/lib/spouts/DocumentComponent.d.ts.map +1 -0
  25. package/lib/spouts/DocumentComponent.js +10 -6
  26. package/lib/spouts/document.d.ts +13 -0
  27. package/lib/spouts/document.d.ts.map +1 -0
  28. package/lib/spouts/document.server.d.ts +18 -0
  29. package/lib/spouts/document.server.d.ts.map +1 -0
  30. package/lib/spouts/document.server.js +1 -1
  31. package/lib/spouts/prefetch.server.d.ts +8 -0
  32. package/lib/spouts/prefetch.server.d.ts.map +1 -0
  33. package/lib/spouts/restHooks.d.ts +8 -0
  34. package/lib/spouts/restHooks.d.ts.map +1 -0
  35. package/lib/spouts/restHooks.server.d.ts +9 -0
  36. package/lib/spouts/restHooks.server.d.ts.map +1 -0
  37. package/lib/spouts/router.d.ts +12 -0
  38. package/lib/spouts/router.d.ts.map +1 -0
  39. package/lib/spouts/router.server.d.ts +12 -0
  40. package/lib/spouts/router.server.d.ts.map +1 -0
  41. package/lib/spouts/types.d.ts +16 -0
  42. package/lib/spouts/types.d.ts.map +1 -0
  43. package/package.json +8 -3
  44. package/src/scripts/index.ts +2 -0
  45. package/src/scripts/serve.ts +168 -0
  46. package/src/scripts/startDevserver.ts +218 -202
  47. package/src/spouts/DocumentComponent.tsx +8 -2
  48. package/src/spouts/document.server.tsx +2 -0
@@ -3,6 +3,9 @@
3
3
 
4
4
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
5
 
6
+ exports.__esModule = true;
7
+ exports.default = startDevServer;
8
+
6
9
  var _util = require("util");
7
10
 
8
11
  var _fs = _interopRequireDefault(require("fs"));
@@ -29,204 +32,212 @@ var _runtime = _interopRequireDefault(require("webpack/lib/logging/runtime"));
29
32
 
30
33
  require("cross-fetch/polyfill");
31
34
 
32
- var _webpackConfigs$, _webpackConfigs$$devS;
33
-
34
- // eslint-disable-next-line @typescript-eslint/no-var-requires
35
- const webpackConfig = require(require.resolve( // TODO: use normal resolution algorithm to find webpack file
36
- _path.default.join(process.cwd(), 'webpack.config')));
35
+ // run directly from node
36
+ if (require.main === module) {
37
+ const entrypoint = process.argv[2]; //process.env.WEBPACK_PUBLIC_HOST = `http://localhost:${PORT}`; this breaks compatibility with stackblitz
37
38
 
38
- const entrypoint = process.argv[2]; //process.env.WEBPACK_PUBLIC_HOST = `http://localhost:${PORT}`; this breaks compatibility with stackblitz
39
+ process.env.WEBPACK_PUBLIC_PATH = '/assets/';
39
40
 
40
- process.env.WEBPACK_PUBLIC_PATH = '/assets/';
41
+ if (!entrypoint) {
42
+ console.log(`Usage: start-anansi <entrypoint-file>`);
43
+ process.exit(-1);
44
+ }
41
45
 
42
- if (!entrypoint) {
43
- console.log(`Usage: start-anansi <entrypoint-file>`);
44
- process.exit(-1);
46
+ startDevServer(entrypoint);
45
47
  }
46
48
 
47
- const log = _runtime.default.getLogger('anansi-devserver'); // Set up in memory filesystem
49
+ function startDevServer(entrypoint, env = {}) {
50
+ var _webpackConfigs$, _webpackConfigs$$devS;
48
51
 
52
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
53
+ const webpackConfig = require(require.resolve( // TODO: use normal resolution algorithm to find webpack file
54
+ _path.default.join(process.cwd(), 'webpack.config')));
49
55
 
50
- const volume = new _memfs.Volume();
51
- const fs = (0, _memfs.createFsFromVolume)(volume);
56
+ const log = _runtime.default.getLogger('anansi-devserver'); // Set up in memory filesystem
52
57
 
53
- _unionfs.ufs.use(_fs.default).use(fs);
54
58
 
55
- (0, _fsMonkey.patchRequire)(_unionfs.ufs);
56
- const readFile = (0, _util.promisify)(_unionfs.ufs.readFile);
57
- let server; // Generate a temporary file so we can hot reload from the root of the application
59
+ const volume = new _memfs.Volume();
60
+ const fs = (0, _memfs.createFsFromVolume)(volume);
58
61
 
59
- function hotEntry(entryPath) {
60
- // eslint-disable-next-line
61
- // @ts-ignore for some reason it's not picking up that other options are optional
62
- const generatedEntrypoint = _tmp.default.fileSync({
63
- postfix: '.js'
64
- });
62
+ _unionfs.ufs.use(_fs.default).use(fs);
65
63
 
66
- _fs.default.writeSync(generatedEntrypoint.fd, `
67
- import entry from "${_path.default.resolve(process.cwd(), entryPath)}";
64
+ (0, _fsMonkey.patchRequire)(_unionfs.ufs);
65
+ const readFile = (0, _util.promisify)(_unionfs.ufs.readFile);
66
+ let server; // Generate a temporary file so we can hot reload from the root of the application
68
67
 
69
- if (module.hot) {
70
- module.hot.accept();
71
- }
68
+ function hotEntry(entryPath) {
69
+ // eslint-disable-next-line
70
+ // @ts-ignore for some reason it's not picking up that other options are optional
71
+ const generatedEntrypoint = _tmp.default.fileSync({
72
+ postfix: '.js'
73
+ });
72
74
 
73
- export default entry;
74
- `);
75
+ _fs.default.writeSync(generatedEntrypoint.fd, `
76
+ import entry from "${_path.default.resolve(process.cwd(), entryPath)}";
75
77
 
76
- return generatedEntrypoint;
77
- }
78
+ if (module.hot) {
79
+ module.hot.accept();
80
+ }
78
81
 
79
- const webpackConfigs = [webpackConfig({
80
- entrypath: hotEntry(entrypoint).name,
81
- name: 'client'
82
- }, {
83
- mode: 'development'
84
- }), webpackConfig({
85
- entrypath: entrypoint.replace('.tsx', '.server.tsx'),
86
- name: 'server',
87
- BROWSERSLIST_ENV: 'current node'
88
- }, {
89
- mode: 'development',
90
- target: 'node'
91
- })]; // only have one output for server so we can avoid cached modules
92
-
93
- webpackConfigs[1].plugins.push(new _webpack.default.optimize.LimitChunkCountPlugin({
94
- maxChunks: 1
95
- })); // initialize the webpack compiler
96
-
97
- const compiler = (0, _webpack.default)(webpackConfigs);
98
-
99
- _sourceMapSupport.default.install({
100
- hookRequire: true
101
- });
102
-
103
- function getServerBundle(serverStats) {
104
- var _serverJson$outputPat;
105
-
106
- const serverJson = serverStats.toJson({
107
- assets: true
108
- });
109
- return _path.default.join((_serverJson$outputPat = serverJson.outputPath) != null ? _serverJson$outputPat : '', 'server.js');
110
- }
82
+ export default entry;
83
+ `);
111
84
 
112
- function handleErrors(fn) {
113
- return async function (req, res, next) {
114
- try {
115
- return await fn(req, res);
116
- } catch (x) {
117
- next(x);
118
- }
119
- };
120
- }
121
-
122
- const initRender = [];
85
+ return generatedEntrypoint;
86
+ }
123
87
 
124
- let render = (...args) => new Promise(resolve => {
125
- initRender.push({
126
- args,
127
- resolve
88
+ const webpackConfigs = [webpackConfig({ ...env,
89
+ entrypath: hotEntry(entrypoint).name,
90
+ name: 'client'
91
+ }, {
92
+ mode: 'development'
93
+ }), webpackConfig({ ...env,
94
+ entrypath: entrypoint.replace('.tsx', '.server.tsx'),
95
+ name: 'server',
96
+ BROWSERSLIST_ENV: 'current node'
97
+ }, {
98
+ mode: 'development',
99
+ target: 'node'
100
+ })]; // only have one output for server so we can avoid cached modules
101
+
102
+ webpackConfigs[1].plugins.push(new _webpack.default.optimize.LimitChunkCountPlugin({
103
+ maxChunks: 1
104
+ })); // initialize the webpack compiler
105
+
106
+ const compiler = (0, _webpack.default)(webpackConfigs);
107
+
108
+ _sourceMapSupport.default.install({
109
+ hookRequire: true
128
110
  });
129
- });
130
111
 
131
- function importRender(stats) {
132
- var _clientStats$compilat, _clientStats$compilat2, _serverStats$compilat, _serverStats$compilat2;
112
+ function getServerBundle(serverStats) {
113
+ var _serverJson$outputPat;
133
114
 
134
- const [clientStats, serverStats] = stats;
115
+ const serverJson = serverStats.toJson({
116
+ assets: true
117
+ });
118
+ return _path.default.join((_serverJson$outputPat = serverJson.outputPath) != null ? _serverJson$outputPat : '', 'server.js');
119
+ }
135
120
 
136
- if (clientStats !== null && clientStats !== void 0 && (_clientStats$compilat = clientStats.compilation) !== null && _clientStats$compilat !== void 0 && (_clientStats$compilat2 = _clientStats$compilat.errors) !== null && _clientStats$compilat2 !== void 0 && _clientStats$compilat2.length || serverStats !== null && serverStats !== void 0 && (_serverStats$compilat = serverStats.compilation) !== null && _serverStats$compilat !== void 0 && (_serverStats$compilat2 = _serverStats$compilat.errors) !== null && _serverStats$compilat2 !== void 0 && _serverStats$compilat2.length) {
137
- log.error('Errors for client build: ' + clientStats.compilation.errors);
138
- log.error('Errors for server build: ' + serverStats.compilation.errors); // TODO: handle more gracefully
121
+ function handleErrors(fn) {
122
+ return async function (req, res, next) {
123
+ try {
124
+ return await fn(req, res);
125
+ } catch (x) {
126
+ next(x);
127
+ }
128
+ };
129
+ }
139
130
 
140
- process.exit(-1);
141
- } else {
142
- log.info('Launching SSR');
143
- } // ASSETS
131
+ const initRender = [];
144
132
 
133
+ let render = (...args) => new Promise(resolve => {
134
+ initRender.push({
135
+ args,
136
+ resolve
137
+ });
138
+ });
145
139
 
146
- const clientManifest = clientStats.toJson(); // SERVER SIDE ENTRYPOINT
140
+ function importRender(stats) {
141
+ var _clientStats$compilat, _clientStats$compilat2, _serverStats$compilat, _serverStats$compilat2;
147
142
 
148
- if (Array.isArray(initRender)) {
149
- // eslint-disable-next-line @typescript-eslint/no-var-requires
150
- render = require(getServerBundle(serverStats)).default.bind(undefined, clientManifest);
151
- initRender.forEach(init => render(...init.args).then(init.resolve));
152
- } else {
153
- render = (0, _importFresh.default)(getServerBundle(serverStats)).default.bind(undefined, clientManifest);
154
- }
155
- }
143
+ const [clientStats, serverStats] = stats;
156
144
 
157
- const devServer = new _webpackDevServer.default( // write to memory filesystem so we can import
158
- { ...webpackConfigs[0].devServer,
145
+ if (clientStats !== null && clientStats !== void 0 && (_clientStats$compilat = clientStats.compilation) !== null && _clientStats$compilat !== void 0 && (_clientStats$compilat2 = _clientStats$compilat.errors) !== null && _clientStats$compilat2 !== void 0 && _clientStats$compilat2.length || serverStats !== null && serverStats !== void 0 && (_serverStats$compilat = serverStats.compilation) !== null && _serverStats$compilat !== void 0 && (_serverStats$compilat2 = _serverStats$compilat.errors) !== null && _serverStats$compilat2 !== void 0 && _serverStats$compilat2.length) {
146
+ log.error('Errors for client build: ' + clientStats.compilation.errors);
147
+ log.error('Errors for server build: ' + serverStats.compilation.errors); // TODO: handle more gracefully
148
+
149
+ process.exit(-1);
150
+ } else {
151
+ log.info('Launching SSR');
152
+ } // ASSETS
159
153
 
160
- /*client: {
161
- ...webpackConfigs[0].devServer?.client,
162
- webSocketURL: {
163
- ...webpackConfigs[0].devServer?.client.webSocketURL,
164
- port: 8080,
165
- },
166
- },*/
167
- devMiddleware: { ...((_webpackConfigs$ = webpackConfigs[0]) === null || _webpackConfigs$ === void 0 ? void 0 : (_webpackConfigs$$devS = _webpackConfigs$.devServer) === null || _webpackConfigs$$devS === void 0 ? void 0 : _webpackConfigs$$devS.devMiddleware),
168
- outputFileSystem: { ...fs,
169
- join: _path.default.join
170
- }
171
- },
172
- setupMiddlewares: (middlewares, devServer) => {
173
- var _devServer$app;
174
154
 
175
- if (!devServer) {
176
- throw new Error('webpack-dev-server is not defined');
177
- } // serve SSR for non-WEBPACK_PUBLIC_PATH
155
+ const clientManifest = clientStats.toJson(); // SERVER SIDE ENTRYPOINT
178
156
 
157
+ if (Array.isArray(initRender)) {
158
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
159
+ render = require(getServerBundle(serverStats)).default.bind(undefined, clientManifest);
160
+ initRender.forEach(init => render(...init.args).then(init.resolve));
161
+ } else {
162
+ render = (0, _importFresh.default)(getServerBundle(serverStats)).default.bind(undefined, clientManifest);
163
+ }
164
+ }
179
165
 
180
- (_devServer$app = devServer.app) === null || _devServer$app === void 0 ? void 0 : _devServer$app.get(new RegExp(`^(?!${process.env.WEBPACK_PUBLIC_PATH})`), handleErrors(async function (req, res) {
181
- if (req.url.endsWith('favicon.ico')) {
182
- res.statusCode = 404;
183
- res.setHeader('Content-type', 'text/html');
184
- res.send('not found');
185
- return;
166
+ const devServer = new _webpackDevServer.default( // write to memory filesystem so we can import
167
+ { ...webpackConfigs[0].devServer,
168
+
169
+ /*client: {
170
+ ...webpackConfigs[0].devServer?.client,
171
+ webSocketURL: {
172
+ ...webpackConfigs[0].devServer?.client.webSocketURL,
173
+ port: 8080,
174
+ },
175
+ },*/
176
+ devMiddleware: { ...((_webpackConfigs$ = webpackConfigs[0]) === null || _webpackConfigs$ === void 0 ? void 0 : (_webpackConfigs$$devS = _webpackConfigs$.devServer) === null || _webpackConfigs$$devS === void 0 ? void 0 : _webpackConfigs$$devS.devMiddleware),
177
+ outputFileSystem: { ...fs,
178
+ join: _path.default.join
186
179
  }
180
+ },
181
+ setupMiddlewares: (middlewares, devServer) => {
182
+ var _webpackConfigs$0$dev, _webpackConfigs$0$dev2, _devServer$app;
187
183
 
188
- res.socket.on('error', error => {
189
- console.error('Fatal', error);
190
- });
191
- await render(req, res);
192
- }));
193
- return middlewares;
194
- }
195
- }, compiler);
184
+ if (!devServer) {
185
+ throw new Error('webpack-dev-server is not defined');
186
+ }
196
187
 
197
- const runServer = async () => {
198
- await devServer.start();
199
- devServer.compiler.hooks.done.tap('Anansi Server', multiStats => {
200
- if (!multiStats) {
201
- log.error('stats not send');
202
- process.exit(-1);
188
+ const otherRoutes = [process.env.WEBPACK_PUBLIC_PATH, ...Object.keys((_webpackConfigs$0$dev = (_webpackConfigs$0$dev2 = webpackConfigs[0].devServer) === null || _webpackConfigs$0$dev2 === void 0 ? void 0 : _webpackConfigs$0$dev2.proxy) != null ? _webpackConfigs$0$dev : {})]; // serve SSR for non-WEBPACK_PUBLIC_PATH
189
+
190
+ (_devServer$app = devServer.app) === null || _devServer$app === void 0 ? void 0 : _devServer$app.get(new RegExp(`^(?!${otherRoutes.join('|')})`), handleErrors(async function (req, res) {
191
+ if (req.url.endsWith('favicon.ico')) {
192
+ res.statusCode = 404;
193
+ res.setHeader('Content-type', 'text/html');
194
+ res.send('not found');
195
+ return;
196
+ }
197
+
198
+ res.socket.on('error', error => {
199
+ console.error('Fatal', error);
200
+ });
201
+ await render(req, res);
202
+ }));
203
+ return middlewares;
203
204
  }
205
+ }, compiler);
206
+
207
+ const runServer = async () => {
208
+ await devServer.start();
209
+ devServer.compiler.hooks.done.tap('Anansi Server', multiStats => {
210
+ if (!multiStats) {
211
+ log.error('stats not send');
212
+ process.exit(-1);
213
+ }
204
214
 
205
- if (!Object.hasOwn(multiStats, 'stats')) return;
206
-
207
- if (multiStats.stats.length > 1) {
208
- try {
209
- importRender(multiStats.stats);
210
- } catch (e) {
211
- log.error('Failed to load serve entrypoint');
212
- throw e;
215
+ if (!Object.hasOwn(multiStats, 'stats')) return;
216
+
217
+ if (multiStats.stats.length > 1) {
218
+ try {
219
+ importRender(multiStats.stats);
220
+ } catch (e) {
221
+ log.error('Failed to load serve entrypoint');
222
+ throw e;
223
+ }
224
+ } else {
225
+ log.error('Only compiler one stat');
213
226
  }
214
- } else {
215
- log.error('Only compiler one stat');
216
- }
227
+ });
228
+ };
229
+
230
+ const stopServer = async () => {
231
+ log.info('Stopping server...');
232
+ await devServer.stop();
233
+ log.info('Server closed');
234
+ };
235
+
236
+ process.on('SIGINT', () => {
237
+ log.warn('Received SIGINT, devserver shutting down');
238
+ stopServer();
239
+ process.exit(-1);
217
240
  });
218
- };
219
-
220
- const stopServer = async () => {
221
- log.info('Stopping server...');
222
- await devServer.stop();
223
- log.info('Server closed');
224
- };
225
-
226
- process.on('SIGINT', () => {
227
- log.warn('Received SIGINT, devserver shutting down');
228
- stopServer();
229
- process.exit(-1);
230
- });
231
- runServer();
232
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["webpackConfig","require","resolve","path","join","process","cwd","entrypoint","argv","env","WEBPACK_PUBLIC_PATH","console","log","exit","logging","getLogger","volume","Volume","fs","createFsFromVolume","ufs","use","diskFs","patchRequire","readFile","promisify","server","hotEntry","entryPath","generatedEntrypoint","tmp","fileSync","postfix","writeSync","fd","webpackConfigs","entrypath","name","mode","replace","BROWSERSLIST_ENV","target","plugins","push","webpack","optimize","LimitChunkCountPlugin","maxChunks","compiler","sourceMapSupport","install","hookRequire","getServerBundle","serverStats","serverJson","toJson","assets","outputPath","handleErrors","fn","req","res","next","x","initRender","render","args","Promise","importRender","stats","clientStats","compilation","errors","length","error","info","clientManifest","Array","isArray","default","bind","undefined","forEach","init","then","importFresh","devServer","WebpackDevServer","devMiddleware","outputFileSystem","setupMiddlewares","middlewares","Error","app","get","RegExp","url","endsWith","statusCode","setHeader","send","socket","on","runServer","start","hooks","done","tap","multiStats","Object","hasOwn","e","stopServer","stop","warn"],"sources":["../../src/scripts/startDevserver.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { promisify } from 'util';\nimport diskFs from 'fs';\nimport path from 'path';\nimport webpack, { MultiCompiler } from 'webpack';\nimport { createFsFromVolume, Volume } from 'memfs';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport type { NextFunction } from 'express';\nimport { patchRequire } from 'fs-monkey';\nimport tmp from 'tmp';\nimport sourceMapSupport from 'source-map-support';\nimport { ufs } from 'unionfs';\nimport WebpackDevServer from 'webpack-dev-server';\nimport importFresh from 'import-fresh';\nimport logging from 'webpack/lib/logging/runtime';\n\nimport 'cross-fetch/polyfill';\nimport { BoundRender } from './types';\n\n// eslint-disable-next-line @typescript-eslint/no-var-requires\nconst webpackConfig = require(require.resolve(\n  // TODO: use normal resolution algorithm to find webpack file\n  path.join(process.cwd(), 'webpack.config'),\n));\n\nconst entrypoint = process.argv[2];\n//process.env.WEBPACK_PUBLIC_HOST = `http://localhost:${PORT}`; this breaks compatibility with stackblitz\nprocess.env.WEBPACK_PUBLIC_PATH = '/assets/';\n\nif (!entrypoint) {\n  console.log(`Usage: start-anansi <entrypoint-file>`);\n  process.exit(-1);\n}\n\nconst log = logging.getLogger('anansi-devserver');\n\n// Set up in memory filesystem\nconst volume = new Volume();\nconst fs = createFsFromVolume(volume);\nufs.use(diskFs).use(fs as any);\n\npatchRequire(ufs);\nconst readFile = promisify(ufs.readFile);\nlet server: Server | undefined;\n\n// Generate a temporary file so we can hot reload from the root of the application\nfunction hotEntry(entryPath: string) {\n  // eslint-disable-next-line\n  // @ts-ignore for some reason it's not picking up that other options are optional\n  const generatedEntrypoint = tmp.fileSync({ postfix: '.js' });\n  diskFs.writeSync(\n    generatedEntrypoint.fd,\n    `\nimport entry from \"${path.resolve(process.cwd(), entryPath)}\";\n\nif (module.hot) {\n  module.hot.accept();\n}\n\nexport default entry;\n  `,\n  );\n  return generatedEntrypoint;\n}\n\nconst webpackConfigs = [\n  webpackConfig(\n    {\n      entrypath: hotEntry(entrypoint).name,\n      name: 'client',\n    },\n    { mode: 'development' },\n  ),\n  webpackConfig(\n    {\n      entrypath: entrypoint.replace('.tsx', '.server.tsx'),\n      name: 'server',\n      BROWSERSLIST_ENV: 'current node',\n    },\n    { mode: 'development', target: 'node' },\n  ),\n] as const;\n// only have one output for server so we can avoid cached modules\nwebpackConfigs[1].plugins.push(\n  new webpack.optimize.LimitChunkCountPlugin({ maxChunks: 1 }),\n);\n// initialize the webpack compiler\nconst compiler: MultiCompiler = webpack(webpackConfigs);\n\nsourceMapSupport.install({ hookRequire: true });\n\nfunction getServerBundle(serverStats: webpack.Stats) {\n  const serverJson = serverStats.toJson({ assets: true });\n  return path.join(serverJson.outputPath ?? '', 'server.js');\n}\nfunction handleErrors<\n  F extends (\n    req: Request | IncomingMessage,\n    res: Response | ServerResponse,\n  ) => Promise<void>,\n>(fn: F) {\n  return async function (\n    req: Request | IncomingMessage,\n    res: Response | ServerResponse,\n    next: NextFunction,\n  ) {\n    try {\n      return await fn(req, res);\n    } catch (x) {\n      next(x);\n    }\n  };\n}\n\nconst initRender:\n  | { args: Parameters<BoundRender>; resolve: () => void }[]\n  | undefined = [];\nlet render: BoundRender = (...args) =>\n  new Promise(resolve => {\n    initRender.push({ args, resolve });\n  });\n\nfunction importRender(stats: webpack.Stats[]) {\n  const [clientStats, serverStats] = stats;\n  if (\n    clientStats?.compilation?.errors?.length ||\n    serverStats?.compilation?.errors?.length\n  ) {\n    log.error('Errors for client build: ' + clientStats.compilation.errors);\n    log.error('Errors for server build: ' + serverStats.compilation.errors);\n    // TODO: handle more gracefully\n    process.exit(-1);\n  } else {\n    log.info('Launching SSR');\n  }\n\n  // ASSETS\n  const clientManifest = clientStats.toJson();\n\n  // SERVER SIDE ENTRYPOINT\n  if (Array.isArray(initRender)) {\n    // eslint-disable-next-line @typescript-eslint/no-var-requires\n    render = (require(getServerBundle(serverStats)) as any).default.bind(\n      undefined,\n      clientManifest,\n    );\n    initRender.forEach(init => render(...init.args).then(init.resolve));\n  } else {\n    render = (importFresh(getServerBundle(serverStats)) as any).default.bind(\n      undefined,\n      clientManifest,\n    );\n  }\n}\n\nconst devServer = new WebpackDevServer(\n  // write to memory filesystem so we can import\n  {\n    ...webpackConfigs[0].devServer,\n    /*client: {\n      ...webpackConfigs[0].devServer?.client,\n      webSocketURL: {\n        ...webpackConfigs[0].devServer?.client.webSocketURL,\n        port: 8080,\n      },\n    },*/\n    devMiddleware: {\n      ...webpackConfigs[0]?.devServer?.devMiddleware,\n      outputFileSystem: {\n        ...fs,\n        join: path.join as any,\n      } as any as typeof fs,\n    },\n    setupMiddlewares: (middlewares, devServer) => {\n      if (!devServer) {\n        throw new Error('webpack-dev-server is not defined');\n      }\n\n      // serve SSR for non-WEBPACK_PUBLIC_PATH\n      devServer.app?.get(\n        new RegExp(`^(?!${process.env.WEBPACK_PUBLIC_PATH})`),\n        handleErrors(async function (req: any, res: any) {\n          if (req.url.endsWith('favicon.ico')) {\n            res.statusCode = 404;\n            res.setHeader('Content-type', 'text/html');\n            res.send('not found');\n            return;\n          }\n          res.socket.on('error', (error: unknown) => {\n            console.error('Fatal', error);\n          });\n\n          await render(req, res);\n        }),\n      );\n\n      return middlewares;\n    },\n  },\n  compiler,\n);\nconst runServer = async () => {\n  await devServer.start();\n  devServer.compiler.hooks.done.tap(\n    'Anansi Server',\n    (multiStats: webpack.MultiStats | webpack.Stats) => {\n      if (!multiStats) {\n        log.error('stats not send');\n        process.exit(-1);\n      }\n\n      if (!Object.hasOwn(multiStats, 'stats')) return;\n      if ((multiStats as webpack.MultiStats).stats.length > 1) {\n        try {\n          importRender((multiStats as webpack.MultiStats).stats);\n        } catch (e: any) {\n          log.error('Failed to load serve entrypoint');\n          throw e;\n        }\n      } else {\n        log.error('Only compiler one stat');\n      }\n    },\n  );\n};\nconst stopServer = async () => {\n  log.info('Stopping server...');\n  await devServer.stop();\n  log.info('Server closed');\n};\n\nprocess.on('SIGINT', () => {\n  log.warn('Received SIGINT, devserver shutting down');\n  stopServer();\n  process.exit(-1);\n});\n\nrunServer();\n"],"mappings":"AAAA;;;;;AAEA;;AACA;;AACA;;AACA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;AAGA;AACA,MAAMA,aAAa,GAAGC,OAAO,CAACA,OAAO,CAACC,OAAR,EAC5B;AACAC,aAAA,CAAKC,IAAL,CAAUC,OAAO,CAACC,GAAR,EAAV,EAAyB,gBAAzB,CAF4B,CAAD,CAA7B;;AAKA,MAAMC,UAAU,GAAGF,OAAO,CAACG,IAAR,CAAa,CAAb,CAAnB,C,CACA;;AACAH,OAAO,CAACI,GAAR,CAAYC,mBAAZ,GAAkC,UAAlC;;AAEA,IAAI,CAACH,UAAL,EAAiB;EACfI,OAAO,CAACC,GAAR,CAAa,uCAAb;EACAP,OAAO,CAACQ,IAAR,CAAa,CAAC,CAAd;AACD;;AAED,MAAMD,GAAG,GAAGE,gBAAA,CAAQC,SAAR,CAAkB,kBAAlB,CAAZ,C,CAEA;;;AACA,MAAMC,MAAM,GAAG,IAAIC,aAAJ,EAAf;AACA,MAAMC,EAAE,GAAG,IAAAC,yBAAA,EAAmBH,MAAnB,CAAX;;AACAI,YAAA,CAAIC,GAAJ,CAAQC,WAAR,EAAgBD,GAAhB,CAAoBH,EAApB;;AAEA,IAAAK,sBAAA,EAAaH,YAAb;AACA,MAAMI,QAAQ,GAAG,IAAAC,eAAA,EAAUL,YAAA,CAAII,QAAd,CAAjB;AACA,IAAIE,MAAJ,C,CAEA;;AACA,SAASC,QAAT,CAAkBC,SAAlB,EAAqC;EACnC;EACA;EACA,MAAMC,mBAAmB,GAAGC,YAAA,CAAIC,QAAJ,CAAa;IAAEC,OAAO,EAAE;EAAX,CAAb,CAA5B;;EACAV,WAAA,CAAOW,SAAP,CACEJ,mBAAmB,CAACK,EADtB,EAEG;AACL,qBAAqB/B,aAAA,CAAKD,OAAL,CAAaG,OAAO,CAACC,GAAR,EAAb,EAA4BsB,SAA5B,CAAuC;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA,GAVE;;EAYA,OAAOC,mBAAP;AACD;;AAED,MAAMM,cAAc,GAAG,CACrBnC,aAAa,CACX;EACEoC,SAAS,EAAET,QAAQ,CAACpB,UAAD,CAAR,CAAqB8B,IADlC;EAEEA,IAAI,EAAE;AAFR,CADW,EAKX;EAAEC,IAAI,EAAE;AAAR,CALW,CADQ,EAQrBtC,aAAa,CACX;EACEoC,SAAS,EAAE7B,UAAU,CAACgC,OAAX,CAAmB,MAAnB,EAA2B,aAA3B,CADb;EAEEF,IAAI,EAAE,QAFR;EAGEG,gBAAgB,EAAE;AAHpB,CADW,EAMX;EAAEF,IAAI,EAAE,aAAR;EAAuBG,MAAM,EAAE;AAA/B,CANW,CARQ,CAAvB,C,CAiBA;;AACAN,cAAc,CAAC,CAAD,CAAd,CAAkBO,OAAlB,CAA0BC,IAA1B,CACE,IAAIC,gBAAA,CAAQC,QAAR,CAAiBC,qBAArB,CAA2C;EAAEC,SAAS,EAAE;AAAb,CAA3C,CADF,E,CAGA;;AACA,MAAMC,QAAuB,GAAG,IAAAJ,gBAAA,EAAQT,cAAR,CAAhC;;AAEAc,yBAAA,CAAiBC,OAAjB,CAAyB;EAAEC,WAAW,EAAE;AAAf,CAAzB;;AAEA,SAASC,eAAT,CAAyBC,WAAzB,EAAqD;EAAA;;EACnD,MAAMC,UAAU,GAAGD,WAAW,CAACE,MAAZ,CAAmB;IAAEC,MAAM,EAAE;EAAV,CAAnB,CAAnB;EACA,OAAOrD,aAAA,CAAKC,IAAL,0BAAUkD,UAAU,CAACG,UAArB,oCAAmC,EAAnC,EAAuC,WAAvC,CAAP;AACD;;AACD,SAASC,YAAT,CAKEC,EALF,EAKS;EACP,OAAO,gBACLC,GADK,EAELC,GAFK,EAGLC,IAHK,EAIL;IACA,IAAI;MACF,OAAO,MAAMH,EAAE,CAACC,GAAD,EAAMC,GAAN,CAAf;IACD,CAFD,CAEE,OAAOE,CAAP,EAAU;MACVD,IAAI,CAACC,CAAD,CAAJ;IACD;EACF,CAVD;AAWD;;AAED,MAAMC,UAEO,GAAG,EAFhB;;AAGA,IAAIC,MAAmB,GAAG,CAAC,GAAGC,IAAJ,KACxB,IAAIC,OAAJ,CAAYjE,OAAO,IAAI;EACrB8D,UAAU,CAACrB,IAAX,CAAgB;IAAEuB,IAAF;IAAQhE;EAAR,CAAhB;AACD,CAFD,CADF;;AAKA,SAASkE,YAAT,CAAsBC,KAAtB,EAA8C;EAAA;;EAC5C,MAAM,CAACC,WAAD,EAAcjB,WAAd,IAA6BgB,KAAnC;;EACA,IACEC,WAAW,SAAX,IAAAA,WAAW,WAAX,6BAAAA,WAAW,CAAEC,WAAb,kGAA0BC,MAA1B,0EAAkCC,MAAlC,IACApB,WADA,aACAA,WADA,wCACAA,WAAW,CAAEkB,WADb,4EACA,sBAA0BC,MAD1B,mDACA,uBAAkCC,MAFpC,EAGE;IACA7D,GAAG,CAAC8D,KAAJ,CAAU,8BAA8BJ,WAAW,CAACC,WAAZ,CAAwBC,MAAhE;IACA5D,GAAG,CAAC8D,KAAJ,CAAU,8BAA8BrB,WAAW,CAACkB,WAAZ,CAAwBC,MAAhE,EAFA,CAGA;;IACAnE,OAAO,CAACQ,IAAR,CAAa,CAAC,CAAd;EACD,CARD,MAQO;IACLD,GAAG,CAAC+D,IAAJ,CAAS,eAAT;EACD,CAZ2C,CAc5C;;;EACA,MAAMC,cAAc,GAAGN,WAAW,CAACf,MAAZ,EAAvB,CAf4C,CAiB5C;;EACA,IAAIsB,KAAK,CAACC,OAAN,CAAcd,UAAd,CAAJ,EAA+B;IAC7B;IACAC,MAAM,GAAIhE,OAAO,CAACmD,eAAe,CAACC,WAAD,CAAhB,CAAR,CAA+C0B,OAA/C,CAAuDC,IAAvD,CACPC,SADO,EAEPL,cAFO,CAAT;IAIAZ,UAAU,CAACkB,OAAX,CAAmBC,IAAI,IAAIlB,MAAM,CAAC,GAAGkB,IAAI,CAACjB,IAAT,CAAN,CAAqBkB,IAArB,CAA0BD,IAAI,CAACjF,OAA/B,CAA3B;EACD,CAPD,MAOO;IACL+D,MAAM,GAAI,IAAAoB,oBAAA,EAAYjC,eAAe,CAACC,WAAD,CAA3B,CAAD,CAAmD0B,OAAnD,CAA2DC,IAA3D,CACPC,SADO,EAEPL,cAFO,CAAT;EAID;AACF;;AAED,MAAMU,SAAS,GAAG,IAAIC,yBAAJ,EAChB;AACA,EACE,GAAGpD,cAAc,CAAC,CAAD,CAAd,CAAkBmD,SADvB;;EAEE;AACJ;AACA;AACA;AACA;AACA;AACA;EACIE,aAAa,EAAE,EACb,wBAAGrD,cAAc,CAAC,CAAD,CAAjB,8EAAG,iBAAmBmD,SAAtB,0DAAG,sBAA8BE,aAAjC,CADa;IAEbC,gBAAgB,EAAE,EAChB,GAAGvE,EADa;MAEhBd,IAAI,EAAED,aAAA,CAAKC;IAFK;EAFL,CATjB;EAgBEsF,gBAAgB,EAAE,CAACC,WAAD,EAAcL,SAAd,KAA4B;IAAA;;IAC5C,IAAI,CAACA,SAAL,EAAgB;MACd,MAAM,IAAIM,KAAJ,CAAU,mCAAV,CAAN;IACD,CAH2C,CAK5C;;;IACA,kBAAAN,SAAS,CAACO,GAAV,kEAAeC,GAAf,CACE,IAAIC,MAAJ,CAAY,OAAM1F,OAAO,CAACI,GAAR,CAAYC,mBAAoB,GAAlD,CADF,EAEEgD,YAAY,CAAC,gBAAgBE,GAAhB,EAA0BC,GAA1B,EAAoC;MAC/C,IAAID,GAAG,CAACoC,GAAJ,CAAQC,QAAR,CAAiB,aAAjB,CAAJ,EAAqC;QACnCpC,GAAG,CAACqC,UAAJ,GAAiB,GAAjB;QACArC,GAAG,CAACsC,SAAJ,CAAc,cAAd,EAA8B,WAA9B;QACAtC,GAAG,CAACuC,IAAJ,CAAS,WAAT;QACA;MACD;;MACDvC,GAAG,CAACwC,MAAJ,CAAWC,EAAX,CAAc,OAAd,EAAwB5B,KAAD,IAAoB;QACzC/D,OAAO,CAAC+D,KAAR,CAAc,OAAd,EAAuBA,KAAvB;MACD,CAFD;MAIA,MAAMT,MAAM,CAACL,GAAD,EAAMC,GAAN,CAAZ;IACD,CAZW,CAFd;IAiBA,OAAO8B,WAAP;EACD;AAxCH,CAFgB,EA4ChB3C,QA5CgB,CAAlB;;AA8CA,MAAMuD,SAAS,GAAG,YAAY;EAC5B,MAAMjB,SAAS,CAACkB,KAAV,EAAN;EACAlB,SAAS,CAACtC,QAAV,CAAmByD,KAAnB,CAAyBC,IAAzB,CAA8BC,GAA9B,CACE,eADF,EAEGC,UAAD,IAAoD;IAClD,IAAI,CAACA,UAAL,EAAiB;MACfhG,GAAG,CAAC8D,KAAJ,CAAU,gBAAV;MACArE,OAAO,CAACQ,IAAR,CAAa,CAAC,CAAd;IACD;;IAED,IAAI,CAACgG,MAAM,CAACC,MAAP,CAAcF,UAAd,EAA0B,OAA1B,CAAL,EAAyC;;IACzC,IAAKA,UAAD,CAAmCvC,KAAnC,CAAyCI,MAAzC,GAAkD,CAAtD,EAAyD;MACvD,IAAI;QACFL,YAAY,CAAEwC,UAAD,CAAmCvC,KAApC,CAAZ;MACD,CAFD,CAEE,OAAO0C,CAAP,EAAe;QACfnG,GAAG,CAAC8D,KAAJ,CAAU,iCAAV;QACA,MAAMqC,CAAN;MACD;IACF,CAPD,MAOO;MACLnG,GAAG,CAAC8D,KAAJ,CAAU,wBAAV;IACD;EACF,CAnBH;AAqBD,CAvBD;;AAwBA,MAAMsC,UAAU,GAAG,YAAY;EAC7BpG,GAAG,CAAC+D,IAAJ,CAAS,oBAAT;EACA,MAAMW,SAAS,CAAC2B,IAAV,EAAN;EACArG,GAAG,CAAC+D,IAAJ,CAAS,eAAT;AACD,CAJD;;AAMAtE,OAAO,CAACiG,EAAR,CAAW,QAAX,EAAqB,MAAM;EACzB1F,GAAG,CAACsG,IAAJ,CAAS,0CAAT;EACAF,UAAU;EACV3G,OAAO,CAACQ,IAAR,CAAa,CAAC,CAAd;AACD,CAJD;AAMA0F,SAAS"}
241
+ runServer();
242
+ }
243
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","main","module","entrypoint","process","argv","env","WEBPACK_PUBLIC_PATH","console","log","exit","startDevServer","webpackConfig","resolve","path","join","cwd","logging","getLogger","volume","Volume","fs","createFsFromVolume","ufs","use","diskFs","patchRequire","readFile","promisify","server","hotEntry","entryPath","generatedEntrypoint","tmp","fileSync","postfix","writeSync","fd","webpackConfigs","entrypath","name","mode","replace","BROWSERSLIST_ENV","target","plugins","push","webpack","optimize","LimitChunkCountPlugin","maxChunks","compiler","sourceMapSupport","install","hookRequire","getServerBundle","serverStats","serverJson","toJson","assets","outputPath","handleErrors","fn","req","res","next","x","initRender","render","args","Promise","importRender","stats","clientStats","compilation","errors","length","error","info","clientManifest","Array","isArray","default","bind","undefined","forEach","init","then","importFresh","devServer","WebpackDevServer","devMiddleware","outputFileSystem","setupMiddlewares","middlewares","Error","otherRoutes","Object","keys","proxy","app","get","RegExp","url","endsWith","statusCode","setHeader","send","socket","on","runServer","start","hooks","done","tap","multiStats","hasOwn","e","stopServer","stop","warn"],"sources":["../../src/scripts/startDevserver.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { promisify } from 'util';\nimport diskFs from 'fs';\nimport path from 'path';\nimport webpack, { MultiCompiler } from 'webpack';\nimport { createFsFromVolume, Volume } from 'memfs';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport type { NextFunction } from 'express';\nimport { patchRequire } from 'fs-monkey';\nimport tmp from 'tmp';\nimport sourceMapSupport from 'source-map-support';\nimport { ufs } from 'unionfs';\nimport WebpackDevServer from 'webpack-dev-server';\nimport importFresh from 'import-fresh';\nimport logging from 'webpack/lib/logging/runtime';\n\nimport 'cross-fetch/polyfill';\nimport { BoundRender } from './types';\n\n// run directly from node\nif (require.main === module) {\n  const entrypoint = process.argv[2];\n  //process.env.WEBPACK_PUBLIC_HOST = `http://localhost:${PORT}`; this breaks compatibility with stackblitz\n  process.env.WEBPACK_PUBLIC_PATH = '/assets/';\n\n  if (!entrypoint) {\n    console.log(`Usage: start-anansi <entrypoint-file>`);\n    process.exit(-1);\n  }\n\n  startDevServer(entrypoint);\n}\n\nexport default function startDevServer(\n  entrypoint: string,\n  env: Record<string, unknown> = {},\n) {\n  // eslint-disable-next-line @typescript-eslint/no-var-requires\n  const webpackConfig = require(require.resolve(\n    // TODO: use normal resolution algorithm to find webpack file\n    path.join(process.cwd(), 'webpack.config'),\n  ));\n\n  const log = logging.getLogger('anansi-devserver');\n\n  // Set up in memory filesystem\n  const volume = new Volume();\n  const fs = createFsFromVolume(volume);\n  ufs.use(diskFs).use(fs as any);\n\n  patchRequire(ufs);\n  const readFile = promisify(ufs.readFile);\n  let server: Server | undefined;\n\n  // Generate a temporary file so we can hot reload from the root of the application\n  function hotEntry(entryPath: string) {\n    // eslint-disable-next-line\n    // @ts-ignore for some reason it's not picking up that other options are optional\n    const generatedEntrypoint = tmp.fileSync({ postfix: '.js' });\n    diskFs.writeSync(\n      generatedEntrypoint.fd,\n      `\n  import entry from \"${path.resolve(process.cwd(), entryPath)}\";\n\n  if (module.hot) {\n    module.hot.accept();\n  }\n\n  export default entry;\n    `,\n    );\n    return generatedEntrypoint;\n  }\n\n  const webpackConfigs = [\n    webpackConfig(\n      {\n        ...env,\n        entrypath: hotEntry(entrypoint).name,\n        name: 'client',\n      },\n      { mode: 'development' },\n    ),\n    webpackConfig(\n      {\n        ...env,\n        entrypath: entrypoint.replace('.tsx', '.server.tsx'),\n        name: 'server',\n        BROWSERSLIST_ENV: 'current node',\n      },\n      { mode: 'development', target: 'node' },\n    ),\n  ] as const;\n  // only have one output for server so we can avoid cached modules\n  webpackConfigs[1].plugins.push(\n    new webpack.optimize.LimitChunkCountPlugin({ maxChunks: 1 }),\n  );\n  // initialize the webpack compiler\n  const compiler: MultiCompiler = webpack(webpackConfigs);\n\n  sourceMapSupport.install({ hookRequire: true });\n\n  function getServerBundle(serverStats: webpack.Stats) {\n    const serverJson = serverStats.toJson({ assets: true });\n    return path.join(serverJson.outputPath ?? '', 'server.js');\n  }\n  function handleErrors<\n    F extends (\n      req: Request | IncomingMessage,\n      res: Response | ServerResponse,\n    ) => Promise<void>,\n  >(fn: F) {\n    return async function (\n      req: Request | IncomingMessage,\n      res: Response | ServerResponse,\n      next: NextFunction,\n    ) {\n      try {\n        return await fn(req, res);\n      } catch (x) {\n        next(x);\n      }\n    };\n  }\n\n  const initRender:\n    | { args: Parameters<BoundRender>; resolve: () => void }[]\n    | undefined = [];\n  let render: BoundRender = (...args) =>\n    new Promise(resolve => {\n      initRender.push({ args, resolve });\n    });\n\n  function importRender(stats: webpack.Stats[]) {\n    const [clientStats, serverStats] = stats;\n    if (\n      clientStats?.compilation?.errors?.length ||\n      serverStats?.compilation?.errors?.length\n    ) {\n      log.error('Errors for client build: ' + clientStats.compilation.errors);\n      log.error('Errors for server build: ' + serverStats.compilation.errors);\n      // TODO: handle more gracefully\n      process.exit(-1);\n    } else {\n      log.info('Launching SSR');\n    }\n\n    // ASSETS\n    const clientManifest = clientStats.toJson();\n\n    // SERVER SIDE ENTRYPOINT\n    if (Array.isArray(initRender)) {\n      // eslint-disable-next-line @typescript-eslint/no-var-requires\n      render = (require(getServerBundle(serverStats)) as any).default.bind(\n        undefined,\n        clientManifest,\n      );\n      initRender.forEach(init => render(...init.args).then(init.resolve));\n    } else {\n      render = (importFresh(getServerBundle(serverStats)) as any).default.bind(\n        undefined,\n        clientManifest,\n      );\n    }\n  }\n\n  const devServer = new WebpackDevServer(\n    // write to memory filesystem so we can import\n    {\n      ...webpackConfigs[0].devServer,\n      /*client: {\n        ...webpackConfigs[0].devServer?.client,\n        webSocketURL: {\n          ...webpackConfigs[0].devServer?.client.webSocketURL,\n          port: 8080,\n        },\n      },*/\n      devMiddleware: {\n        ...webpackConfigs[0]?.devServer?.devMiddleware,\n        outputFileSystem: {\n          ...fs,\n          join: path.join as any,\n        } as any as typeof fs,\n      },\n      setupMiddlewares: (middlewares, devServer) => {\n        if (!devServer) {\n          throw new Error('webpack-dev-server is not defined');\n        }\n\n        const otherRoutes = [\n          process.env.WEBPACK_PUBLIC_PATH,\n          ...Object.keys(webpackConfigs[0].devServer?.proxy ?? {}),\n        ];\n        // serve SSR for non-WEBPACK_PUBLIC_PATH\n        devServer.app?.get(\n          new RegExp(`^(?!${otherRoutes.join('|')})`),\n          handleErrors(async function (req: any, res: any) {\n            if (req.url.endsWith('favicon.ico')) {\n              res.statusCode = 404;\n              res.setHeader('Content-type', 'text/html');\n              res.send('not found');\n              return;\n            }\n            res.socket.on('error', (error: unknown) => {\n              console.error('Fatal', error);\n            });\n\n            await render(req, res);\n          }),\n        );\n\n        return middlewares;\n      },\n    },\n    compiler,\n  );\n  const runServer = async () => {\n    await devServer.start();\n    devServer.compiler.hooks.done.tap(\n      'Anansi Server',\n      (multiStats: webpack.MultiStats | webpack.Stats) => {\n        if (!multiStats) {\n          log.error('stats not send');\n          process.exit(-1);\n        }\n\n        if (!Object.hasOwn(multiStats, 'stats')) return;\n        if ((multiStats as webpack.MultiStats).stats.length > 1) {\n          try {\n            importRender((multiStats as webpack.MultiStats).stats);\n          } catch (e: any) {\n            log.error('Failed to load serve entrypoint');\n            throw e;\n          }\n        } else {\n          log.error('Only compiler one stat');\n        }\n      },\n    );\n  };\n  const stopServer = async () => {\n    log.info('Stopping server...');\n    await devServer.stop();\n    log.info('Server closed');\n  };\n\n  process.on('SIGINT', () => {\n    log.warn('Received SIGINT, devserver shutting down');\n    stopServer();\n    process.exit(-1);\n  });\n\n  runServer();\n}\n"],"mappings":"AAAA;;;;;;;;AAEA;;AACA;;AACA;;AACA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AAGA;AACA,IAAIA,OAAO,CAACC,IAAR,KAAiBC,MAArB,EAA6B;EAC3B,MAAMC,UAAU,GAAGC,OAAO,CAACC,IAAR,CAAa,CAAb,CAAnB,CAD2B,CAE3B;;EACAD,OAAO,CAACE,GAAR,CAAYC,mBAAZ,GAAkC,UAAlC;;EAEA,IAAI,CAACJ,UAAL,EAAiB;IACfK,OAAO,CAACC,GAAR,CAAa,uCAAb;IACAL,OAAO,CAACM,IAAR,CAAa,CAAC,CAAd;EACD;;EAEDC,cAAc,CAACR,UAAD,CAAd;AACD;;AAEc,SAASQ,cAAT,CACbR,UADa,EAEbG,GAA4B,GAAG,EAFlB,EAGb;EAAA;;EACA;EACA,MAAMM,aAAa,GAAGZ,OAAO,CAACA,OAAO,CAACa,OAAR,EAC5B;EACAC,aAAA,CAAKC,IAAL,CAAUX,OAAO,CAACY,GAAR,EAAV,EAAyB,gBAAzB,CAF4B,CAAD,CAA7B;;EAKA,MAAMP,GAAG,GAAGQ,gBAAA,CAAQC,SAAR,CAAkB,kBAAlB,CAAZ,CAPA,CASA;;;EACA,MAAMC,MAAM,GAAG,IAAIC,aAAJ,EAAf;EACA,MAAMC,EAAE,GAAG,IAAAC,yBAAA,EAAmBH,MAAnB,CAAX;;EACAI,YAAA,CAAIC,GAAJ,CAAQC,WAAR,EAAgBD,GAAhB,CAAoBH,EAApB;;EAEA,IAAAK,sBAAA,EAAaH,YAAb;EACA,MAAMI,QAAQ,GAAG,IAAAC,eAAA,EAAUL,YAAA,CAAII,QAAd,CAAjB;EACA,IAAIE,MAAJ,CAhBA,CAkBA;;EACA,SAASC,QAAT,CAAkBC,SAAlB,EAAqC;IACnC;IACA;IACA,MAAMC,mBAAmB,GAAGC,YAAA,CAAIC,QAAJ,CAAa;MAAEC,OAAO,EAAE;IAAX,CAAb,CAA5B;;IACAV,WAAA,CAAOW,SAAP,CACEJ,mBAAmB,CAACK,EADtB,EAEG;AACP,uBAAuBvB,aAAA,CAAKD,OAAL,CAAaT,OAAO,CAACY,GAAR,EAAb,EAA4Be,SAA5B,CAAuC;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA,KAVI;;IAYA,OAAOC,mBAAP;EACD;;EAED,MAAMM,cAAc,GAAG,CACrB1B,aAAa,CACX,EACE,GAAGN,GADL;IAEEiC,SAAS,EAAET,QAAQ,CAAC3B,UAAD,CAAR,CAAqBqC,IAFlC;IAGEA,IAAI,EAAE;EAHR,CADW,EAMX;IAAEC,IAAI,EAAE;EAAR,CANW,CADQ,EASrB7B,aAAa,CACX,EACE,GAAGN,GADL;IAEEiC,SAAS,EAAEpC,UAAU,CAACuC,OAAX,CAAmB,MAAnB,EAA2B,aAA3B,CAFb;IAGEF,IAAI,EAAE,QAHR;IAIEG,gBAAgB,EAAE;EAJpB,CADW,EAOX;IAAEF,IAAI,EAAE,aAAR;IAAuBG,MAAM,EAAE;EAA/B,CAPW,CATQ,CAAvB,CAtCA,CAyDA;;EACAN,cAAc,CAAC,CAAD,CAAd,CAAkBO,OAAlB,CAA0BC,IAA1B,CACE,IAAIC,gBAAA,CAAQC,QAAR,CAAiBC,qBAArB,CAA2C;IAAEC,SAAS,EAAE;EAAb,CAA3C,CADF,EA1DA,CA6DA;;EACA,MAAMC,QAAuB,GAAG,IAAAJ,gBAAA,EAAQT,cAAR,CAAhC;;EAEAc,yBAAA,CAAiBC,OAAjB,CAAyB;IAAEC,WAAW,EAAE;EAAf,CAAzB;;EAEA,SAASC,eAAT,CAAyBC,WAAzB,EAAqD;IAAA;;IACnD,MAAMC,UAAU,GAAGD,WAAW,CAACE,MAAZ,CAAmB;MAAEC,MAAM,EAAE;IAAV,CAAnB,CAAnB;IACA,OAAO7C,aAAA,CAAKC,IAAL,0BAAU0C,UAAU,CAACG,UAArB,oCAAmC,EAAnC,EAAuC,WAAvC,CAAP;EACD;;EACD,SAASC,YAAT,CAKEC,EALF,EAKS;IACP,OAAO,gBACLC,GADK,EAELC,GAFK,EAGLC,IAHK,EAIL;MACA,IAAI;QACF,OAAO,MAAMH,EAAE,CAACC,GAAD,EAAMC,GAAN,CAAf;MACD,CAFD,CAEE,OAAOE,CAAP,EAAU;QACVD,IAAI,CAACC,CAAD,CAAJ;MACD;IACF,CAVD;EAWD;;EAED,MAAMC,UAEO,GAAG,EAFhB;;EAGA,IAAIC,MAAmB,GAAG,CAAC,GAAGC,IAAJ,KACxB,IAAIC,OAAJ,CAAYzD,OAAO,IAAI;IACrBsD,UAAU,CAACrB,IAAX,CAAgB;MAAEuB,IAAF;MAAQxD;IAAR,CAAhB;EACD,CAFD,CADF;;EAKA,SAAS0D,YAAT,CAAsBC,KAAtB,EAA8C;IAAA;;IAC5C,MAAM,CAACC,WAAD,EAAcjB,WAAd,IAA6BgB,KAAnC;;IACA,IACEC,WAAW,SAAX,IAAAA,WAAW,WAAX,6BAAAA,WAAW,CAAEC,WAAb,kGAA0BC,MAA1B,0EAAkCC,MAAlC,IACApB,WADA,aACAA,WADA,wCACAA,WAAW,CAAEkB,WADb,4EACA,sBAA0BC,MAD1B,mDACA,uBAAkCC,MAFpC,EAGE;MACAnE,GAAG,CAACoE,KAAJ,CAAU,8BAA8BJ,WAAW,CAACC,WAAZ,CAAwBC,MAAhE;MACAlE,GAAG,CAACoE,KAAJ,CAAU,8BAA8BrB,WAAW,CAACkB,WAAZ,CAAwBC,MAAhE,EAFA,CAGA;;MACAvE,OAAO,CAACM,IAAR,CAAa,CAAC,CAAd;IACD,CARD,MAQO;MACLD,GAAG,CAACqE,IAAJ,CAAS,eAAT;IACD,CAZ2C,CAc5C;;;IACA,MAAMC,cAAc,GAAGN,WAAW,CAACf,MAAZ,EAAvB,CAf4C,CAiB5C;;IACA,IAAIsB,KAAK,CAACC,OAAN,CAAcd,UAAd,CAAJ,EAA+B;MAC7B;MACAC,MAAM,GAAIpE,OAAO,CAACuD,eAAe,CAACC,WAAD,CAAhB,CAAR,CAA+C0B,OAA/C,CAAuDC,IAAvD,CACPC,SADO,EAEPL,cAFO,CAAT;MAIAZ,UAAU,CAACkB,OAAX,CAAmBC,IAAI,IAAIlB,MAAM,CAAC,GAAGkB,IAAI,CAACjB,IAAT,CAAN,CAAqBkB,IAArB,CAA0BD,IAAI,CAACzE,OAA/B,CAA3B;IACD,CAPD,MAOO;MACLuD,MAAM,GAAI,IAAAoB,oBAAA,EAAYjC,eAAe,CAACC,WAAD,CAA3B,CAAD,CAAmD0B,OAAnD,CAA2DC,IAA3D,CACPC,SADO,EAEPL,cAFO,CAAT;IAID;EACF;;EAED,MAAMU,SAAS,GAAG,IAAIC,yBAAJ,EAChB;EACA,EACE,GAAGpD,cAAc,CAAC,CAAD,CAAd,CAAkBmD,SADvB;;IAEE;AACN;AACA;AACA;AACA;AACA;AACA;IACME,aAAa,EAAE,EACb,wBAAGrD,cAAc,CAAC,CAAD,CAAjB,8EAAG,iBAAmBmD,SAAtB,0DAAG,sBAA8BE,aAAjC,CADa;MAEbC,gBAAgB,EAAE,EAChB,GAAGvE,EADa;QAEhBN,IAAI,EAAED,aAAA,CAAKC;MAFK;IAFL,CATjB;IAgBE8E,gBAAgB,EAAE,CAACC,WAAD,EAAcL,SAAd,KAA4B;MAAA;;MAC5C,IAAI,CAACA,SAAL,EAAgB;QACd,MAAM,IAAIM,KAAJ,CAAU,mCAAV,CAAN;MACD;;MAED,MAAMC,WAAW,GAAG,CAClB5F,OAAO,CAACE,GAAR,CAAYC,mBADM,EAElB,GAAG0F,MAAM,CAACC,IAAP,oDAAY5D,cAAc,CAAC,CAAD,CAAd,CAAkBmD,SAA9B,2DAAY,uBAA6BU,KAAzC,oCAAkD,EAAlD,CAFe,CAApB,CAL4C,CAS5C;;MACA,kBAAAV,SAAS,CAACW,GAAV,kEAAeC,GAAf,CACE,IAAIC,MAAJ,CAAY,OAAMN,WAAW,CAACjF,IAAZ,CAAiB,GAAjB,CAAsB,GAAxC,CADF,EAEE8C,YAAY,CAAC,gBAAgBE,GAAhB,EAA0BC,GAA1B,EAAoC;QAC/C,IAAID,GAAG,CAACwC,GAAJ,CAAQC,QAAR,CAAiB,aAAjB,CAAJ,EAAqC;UACnCxC,GAAG,CAACyC,UAAJ,GAAiB,GAAjB;UACAzC,GAAG,CAAC0C,SAAJ,CAAc,cAAd,EAA8B,WAA9B;UACA1C,GAAG,CAAC2C,IAAJ,CAAS,WAAT;UACA;QACD;;QACD3C,GAAG,CAAC4C,MAAJ,CAAWC,EAAX,CAAc,OAAd,EAAwBhC,KAAD,IAAoB;UACzCrE,OAAO,CAACqE,KAAR,CAAc,OAAd,EAAuBA,KAAvB;QACD,CAFD;QAIA,MAAMT,MAAM,CAACL,GAAD,EAAMC,GAAN,CAAZ;MACD,CAZW,CAFd;MAiBA,OAAO8B,WAAP;IACD;EA5CH,CAFgB,EAgDhB3C,QAhDgB,CAAlB;;EAkDA,MAAM2D,SAAS,GAAG,YAAY;IAC5B,MAAMrB,SAAS,CAACsB,KAAV,EAAN;IACAtB,SAAS,CAACtC,QAAV,CAAmB6D,KAAnB,CAAyBC,IAAzB,CAA8BC,GAA9B,CACE,eADF,EAEGC,UAAD,IAAoD;MAClD,IAAI,CAACA,UAAL,EAAiB;QACf1G,GAAG,CAACoE,KAAJ,CAAU,gBAAV;QACAzE,OAAO,CAACM,IAAR,CAAa,CAAC,CAAd;MACD;;MAED,IAAI,CAACuF,MAAM,CAACmB,MAAP,CAAcD,UAAd,EAA0B,OAA1B,CAAL,EAAyC;;MACzC,IAAKA,UAAD,CAAmC3C,KAAnC,CAAyCI,MAAzC,GAAkD,CAAtD,EAAyD;QACvD,IAAI;UACFL,YAAY,CAAE4C,UAAD,CAAmC3C,KAApC,CAAZ;QACD,CAFD,CAEE,OAAO6C,CAAP,EAAe;UACf5G,GAAG,CAACoE,KAAJ,CAAU,iCAAV;UACA,MAAMwC,CAAN;QACD;MACF,CAPD,MAOO;QACL5G,GAAG,CAACoE,KAAJ,CAAU,wBAAV;MACD;IACF,CAnBH;EAqBD,CAvBD;;EAwBA,MAAMyC,UAAU,GAAG,YAAY;IAC7B7G,GAAG,CAACqE,IAAJ,CAAS,oBAAT;IACA,MAAMW,SAAS,CAAC8B,IAAV,EAAN;IACA9G,GAAG,CAACqE,IAAJ,CAAS,eAAT;EACD,CAJD;;EAMA1E,OAAO,CAACyG,EAAR,CAAW,QAAX,EAAqB,MAAM;IACzBpG,GAAG,CAAC+G,IAAJ,CAAS,0CAAT;IACAF,UAAU;IACVlH,OAAO,CAACM,IAAR,CAAa,CAAC,CAAd;EACD,CAJD;EAMAoG,SAAS;AACV"}
@@ -0,0 +1,7 @@
1
+ /// <reference types="node" />
2
+ import { ServerResponse, IncomingMessage } from 'http';
3
+ import { StatsCompilation } from 'webpack';
4
+ import { Request, Response } from 'express';
5
+ export declare type Render = (clientManifest: StatsCompilation, req: Request | IncomingMessage, res: Response | ServerResponse) => Promise<void>;
6
+ export declare type BoundRender = (req: Request | IncomingMessage, res: Response | ServerResponse) => Promise<void>;
7
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/scripts/types.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAE5C,oBAAY,MAAM,GAAG,CACnB,cAAc,EAAE,gBAAgB,EAChC,GAAG,EAAE,OAAO,GAAG,eAAe,EAC9B,GAAG,EAAE,QAAQ,GAAG,cAAc,KAC3B,OAAO,CAAC,IAAI,CAAC,CAAC;AAEnB,oBAAY,WAAW,GAAG,CACxB,GAAG,EAAE,OAAO,GAAG,eAAe,EAC9B,GAAG,EAAE,QAAQ,GAAG,cAAc,KAC3B,OAAO,CAAC,IAAI,CAAC,CAAC"}
@@ -0,0 +1,23 @@
1
+ /// <reference types="react" />
2
+ declare type Props = {
3
+ children: React.ReactNode;
4
+ assets: {
5
+ href: string;
6
+ as?: string;
7
+ rel?: string;
8
+ }[];
9
+ head: React.ReactNode;
10
+ title: string;
11
+ rootId: string;
12
+ charSet: string;
13
+ };
14
+ declare function Document({ assets, head, children, title, rootId, charSet, }: Props): JSX.Element;
15
+ declare namespace Document {
16
+ var defaultProps: {
17
+ head: JSX.Element;
18
+ charSet: string;
19
+ rootId: string;
20
+ };
21
+ }
22
+ export default Document;
23
+ //# sourceMappingURL=DocumentComponent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DocumentComponent.d.ts","sourceRoot":"","sources":["../../src/spouts/DocumentComponent.tsx"],"names":[],"mappings":";AAAA,aAAK,KAAK,GAAG;IACX,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,MAAM,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,EAAE,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IACtD,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,iBAAwB,QAAQ,CAAC,EAC/B,MAAM,EACN,IAAI,EACJ,QAAQ,EACR,KAAK,EACL,MAAM,EACN,OAAO,GACR,EAAE,KAAK,eA2BP;kBAlCuB,QAAQ;;;;;;;eAAR,QAAQ"}
@@ -9,14 +9,19 @@ var _jsx2 = _interopRequireDefault(require("@babel/runtime/helpers/jsx"));
9
9
 
10
10
  var _react = _interopRequireDefault(require("react"));
11
11
 
12
+ var _process$env$WEBPACK_;
13
+
12
14
  function Document({
13
15
  assets,
14
16
  head,
15
17
  children,
16
18
  title,
17
- rootId
19
+ rootId,
20
+ charSet
18
21
  }) {
19
- return /*#__PURE__*/(0, _jsx2.default)("html", {}, void 0, /*#__PURE__*/(0, _jsx2.default)("head", {}, void 0, head, assets.map((asset, i) => /*#__PURE__*/_react.default.createElement("link", {
22
+ return /*#__PURE__*/(0, _jsx2.default)("html", {}, void 0, /*#__PURE__*/(0, _jsx2.default)("head", {}, void 0, /*#__PURE__*/(0, _jsx2.default)("meta", {
23
+ charSet: charSet
24
+ }), head, assets.map((asset, i) => /*#__PURE__*/_react.default.createElement("link", {
20
25
  key: i,
21
26
  rel: "preload",
22
27
  ...asset
@@ -38,14 +43,13 @@ function Document({
38
43
 
39
44
  Document.defaultProps = {
40
45
  head: /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/(0, _jsx2.default)("meta", {
41
- charSet: "utf-8"
42
- }), /*#__PURE__*/(0, _jsx2.default)("meta", {
43
46
  name: "viewport",
44
47
  content: "width=device-width, initial-scale=1"
45
48
  }), /*#__PURE__*/(0, _jsx2.default)("link", {
46
49
  rel: "shortcut icon",
47
- href: "/assets/favicon.ico"
50
+ href: `${(_process$env$WEBPACK_ = process.env.WEBPACK_PUBLIC_PATH) != null ? _process$env$WEBPACK_ : '/'}favicon.ico`
48
51
  })),
52
+ charSet: 'utf-8',
49
53
  rootId: 'anansi-root'
50
54
  };
51
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJEb2N1bWVudCIsImFzc2V0cyIsImhlYWQiLCJjaGlsZHJlbiIsInRpdGxlIiwicm9vdElkIiwibWFwIiwiYXNzZXQiLCJpIiwiX19odG1sIiwiSlNPTiIsInN0cmluZ2lmeSIsImZpbHRlciIsImhyZWYiLCJlbmRzV2l0aCIsImRlZmF1bHRQcm9wcyJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zcG91dHMvRG9jdW1lbnRDb21wb25lbnQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbInR5cGUgUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGU7XG4gIGFzc2V0czogeyBocmVmOiBzdHJpbmc7IGFzPzogc3RyaW5nOyByZWw/OiBzdHJpbmcgfVtdO1xuICBoZWFkOiBSZWFjdC5SZWFjdE5vZGU7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIHJvb3RJZDogc3RyaW5nO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gRG9jdW1lbnQoe1xuICBhc3NldHMsXG4gIGhlYWQsXG4gIGNoaWxkcmVuLFxuICB0aXRsZSxcbiAgcm9vdElkLFxufTogUHJvcHMpIHtcbiAgcmV0dXJuIChcbiAgICA8aHRtbD5cbiAgICAgIDxoZWFkPlxuICAgICAgICB7aGVhZH1cbiAgICAgICAge2Fzc2V0cy5tYXAoKGFzc2V0LCBpKSA9PiAoXG4gICAgICAgICAgPGxpbmsga2V5PXtpfSByZWw9XCJwcmVsb2FkXCIgey4uLmFzc2V0fSAvPlxuICAgICAgICApKX1cbiAgICAgICAgPHRpdGxlPnt0aXRsZX08L3RpdGxlPlxuICAgICAgPC9oZWFkPlxuICAgICAgPGJvZHk+XG4gICAgICAgIDxkaXYgaWQ9e3Jvb3RJZH0+e2NoaWxkcmVufTwvZGl2PlxuICAgICAgICB7LyogdGhpcyBlbnN1cmVzIHRoZSBjbGllbnQgY2FuIGh5ZHJhdGUgdGhlIGFzc2V0cyBwcm9wICovfVxuICAgICAgICA8c2NyaXB0XG4gICAgICAgICAgZGFuZ2Vyb3VzbHlTZXRJbm5lckhUTUw9e3tcbiAgICAgICAgICAgIF9faHRtbDogYGFzc2V0TWFuaWZlc3QgPSAke0pTT04uc3RyaW5naWZ5KGFzc2V0cyl9O2AsXG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICAge2Fzc2V0c1xuICAgICAgICAgIC5maWx0ZXIoKHsgaHJlZiB9KSA9PiBocmVmLmVuZHNXaXRoKCcuanMnKSlcbiAgICAgICAgICAubWFwKCh7IGhyZWYgfSwgaSkgPT4gKFxuICAgICAgICAgICAgPHNjcmlwdCBrZXk9e2l9IHNyYz17aHJlZn0gYXN5bmMgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvYm9keT5cbiAgICA8L2h0bWw+XG4gICk7XG59XG5Eb2N1bWVudC5kZWZhdWx0UHJvcHMgPSB7XG4gIGhlYWQ6IChcbiAgICA8PlxuICAgICAgPG1ldGEgY2hhclNldD1cInV0Zi04XCIgLz5cbiAgICAgIDxtZXRhIG5hbWU9XCJ2aWV3cG9ydFwiIGNvbnRlbnQ9XCJ3aWR0aD1kZXZpY2Utd2lkdGgsIGluaXRpYWwtc2NhbGU9MVwiIC8+XG4gICAgICA8bGluayByZWw9XCJzaG9ydGN1dCBpY29uXCIgaHJlZj1cIi9hc3NldHMvZmF2aWNvbi5pY29cIiAvPlxuICAgIDwvPlxuICApLFxuICByb290SWQ6ICdhbmFuc2ktcm9vdCcsXG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQVFlLFNBQVNBLFFBQVQsQ0FBa0I7RUFDL0JDLE1BRCtCO0VBRS9CQyxJQUYrQjtFQUcvQkMsUUFIK0I7RUFJL0JDLEtBSitCO0VBSy9CQztBQUwrQixDQUFsQixFQU1MO0VBQ1Isb0JBQ0Usb0RBQ0UsdUNBQ0dILElBREgsRUFFR0QsTUFBTSxDQUFDSyxHQUFQLENBQVcsQ0FBQ0MsS0FBRCxFQUFRQyxDQUFSLGtCQUNWO0lBQU0sR0FBRyxFQUFFQSxDQUFYO0lBQWMsR0FBRyxFQUFDLFNBQWxCO0lBQUEsR0FBZ0NEO0VBQWhDLEVBREQsQ0FGSCxlQUtFLHdDQUFRSCxLQUFSLENBTEYsQ0FERixlQVFFLG9EQUNFO0lBQUssRUFBRSxFQUFFQztFQUFULFdBQWtCRixRQUFsQixDQURGLGVBR0U7SUFDRSx1QkFBdUIsRUFBRTtNQUN2Qk0sTUFBTSxFQUFHLG1CQUFrQkMsSUFBSSxDQUFDQyxTQUFMLENBQWVWLE1BQWYsQ0FBdUI7SUFEM0I7RUFEM0IsRUFIRixFQVFHQSxNQUFNLENBQ0pXLE1BREYsQ0FDUyxDQUFDO0lBQUVDO0VBQUYsQ0FBRCxLQUFjQSxJQUFJLENBQUNDLFFBQUwsQ0FBYyxLQUFkLENBRHZCLEVBRUVSLEdBRkYsQ0FFTSxDQUFDO0lBQUVPO0VBQUYsQ0FBRCxFQUFXTCxDQUFYLGtCQUNIO0lBQWdCLEdBQUcsRUFBRUssSUFBckI7SUFBMkIsS0FBSztFQUFoQyxHQUFhTCxDQUFiLENBSEgsQ0FSSCxDQVJGLENBREY7QUF5QkQ7O0FBQ0RSLFFBQVEsQ0FBQ2UsWUFBVCxHQUF3QjtFQUN0QmIsSUFBSSxlQUNGLHlFQUNFO0lBQU0sT0FBTyxFQUFDO0VBQWQsRUFERixlQUVFO0lBQU0sSUFBSSxFQUFDLFVBQVg7SUFBc0IsT0FBTyxFQUFDO0VBQTlCLEVBRkYsZUFHRTtJQUFNLEdBQUcsRUFBQyxlQUFWO0lBQTBCLElBQUksRUFBQztFQUEvQixFQUhGLENBRm9CO0VBUXRCRyxNQUFNLEVBQUU7QUFSYyxDQUF4QiJ9
55
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJEb2N1bWVudCIsImFzc2V0cyIsImhlYWQiLCJjaGlsZHJlbiIsInRpdGxlIiwicm9vdElkIiwiY2hhclNldCIsIm1hcCIsImFzc2V0IiwiaSIsIl9faHRtbCIsIkpTT04iLCJzdHJpbmdpZnkiLCJmaWx0ZXIiLCJocmVmIiwiZW5kc1dpdGgiLCJkZWZhdWx0UHJvcHMiLCJwcm9jZXNzIiwiZW52IiwiV0VCUEFDS19QVUJMSUNfUEFUSCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zcG91dHMvRG9jdW1lbnRDb21wb25lbnQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbInR5cGUgUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGU7XG4gIGFzc2V0czogeyBocmVmOiBzdHJpbmc7IGFzPzogc3RyaW5nOyByZWw/OiBzdHJpbmcgfVtdO1xuICBoZWFkOiBSZWFjdC5SZWFjdE5vZGU7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIHJvb3RJZDogc3RyaW5nO1xuICBjaGFyU2V0OiBzdHJpbmc7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBEb2N1bWVudCh7XG4gIGFzc2V0cyxcbiAgaGVhZCxcbiAgY2hpbGRyZW4sXG4gIHRpdGxlLFxuICByb290SWQsXG4gIGNoYXJTZXQsXG59OiBQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDxodG1sPlxuICAgICAgPGhlYWQ+XG4gICAgICAgIDxtZXRhIGNoYXJTZXQ9e2NoYXJTZXR9IC8+XG4gICAgICAgIHtoZWFkfVxuICAgICAgICB7YXNzZXRzLm1hcCgoYXNzZXQsIGkpID0+IChcbiAgICAgICAgICA8bGluayBrZXk9e2l9IHJlbD1cInByZWxvYWRcIiB7Li4uYXNzZXR9IC8+XG4gICAgICAgICkpfVxuICAgICAgICA8dGl0bGU+e3RpdGxlfTwvdGl0bGU+XG4gICAgICA8L2hlYWQ+XG4gICAgICA8Ym9keT5cbiAgICAgICAgPGRpdiBpZD17cm9vdElkfT57Y2hpbGRyZW59PC9kaXY+XG4gICAgICAgIHsvKiB0aGlzIGVuc3VyZXMgdGhlIGNsaWVudCBjYW4gaHlkcmF0ZSB0aGUgYXNzZXRzIHByb3AgKi99XG4gICAgICAgIDxzY3JpcHRcbiAgICAgICAgICBkYW5nZXJvdXNseVNldElubmVySFRNTD17e1xuICAgICAgICAgICAgX19odG1sOiBgYXNzZXRNYW5pZmVzdCA9ICR7SlNPTi5zdHJpbmdpZnkoYXNzZXRzKX07YCxcbiAgICAgICAgICB9fVxuICAgICAgICAvPlxuICAgICAgICB7YXNzZXRzXG4gICAgICAgICAgLmZpbHRlcigoeyBocmVmIH0pID0+IGhyZWYuZW5kc1dpdGgoJy5qcycpKVxuICAgICAgICAgIC5tYXAoKHsgaHJlZiB9LCBpKSA9PiAoXG4gICAgICAgICAgICA8c2NyaXB0IGtleT17aX0gc3JjPXtocmVmfSBhc3luYyAvPlxuICAgICAgICAgICkpfVxuICAgICAgPC9ib2R5PlxuICAgIDwvaHRtbD5cbiAgKTtcbn1cbkRvY3VtZW50LmRlZmF1bHRQcm9wcyA9IHtcbiAgaGVhZDogKFxuICAgIDw+XG4gICAgICA8bWV0YSBuYW1lPVwidmlld3BvcnRcIiBjb250ZW50PVwid2lkdGg9ZGV2aWNlLXdpZHRoLCBpbml0aWFsLXNjYWxlPTFcIiAvPlxuICAgICAgPGxpbmtcbiAgICAgICAgcmVsPVwic2hvcnRjdXQgaWNvblwiXG4gICAgICAgIGhyZWY9e2Ake3Byb2Nlc3MuZW52LldFQlBBQ0tfUFVCTElDX1BBVEggPz8gJy8nfWZhdmljb24uaWNvYH1cbiAgICAgIC8+XG4gICAgPC8+XG4gICksXG4gIGNoYXJTZXQ6ICd1dGYtOCcsXG4gIHJvb3RJZDogJ2FuYW5zaS1yb290Jyxcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7QUFTZSxTQUFTQSxRQUFULENBQWtCO0VBQy9CQyxNQUQrQjtFQUUvQkMsSUFGK0I7RUFHL0JDLFFBSCtCO0VBSS9CQyxLQUorQjtFQUsvQkMsTUFMK0I7RUFNL0JDO0FBTitCLENBQWxCLEVBT0w7RUFDUixvQkFDRSxvREFDRSxvREFDRTtJQUFNLE9BQU8sRUFBRUE7RUFBZixFQURGLEVBRUdKLElBRkgsRUFHR0QsTUFBTSxDQUFDTSxHQUFQLENBQVcsQ0FBQ0MsS0FBRCxFQUFRQyxDQUFSLGtCQUNWO0lBQU0sR0FBRyxFQUFFQSxDQUFYO0lBQWMsR0FBRyxFQUFDLFNBQWxCO0lBQUEsR0FBZ0NEO0VBQWhDLEVBREQsQ0FISCxlQU1FLHdDQUFRSixLQUFSLENBTkYsQ0FERixlQVNFLG9EQUNFO0lBQUssRUFBRSxFQUFFQztFQUFULFdBQWtCRixRQUFsQixDQURGLGVBR0U7SUFDRSx1QkFBdUIsRUFBRTtNQUN2Qk8sTUFBTSxFQUFHLG1CQUFrQkMsSUFBSSxDQUFDQyxTQUFMLENBQWVYLE1BQWYsQ0FBdUI7SUFEM0I7RUFEM0IsRUFIRixFQVFHQSxNQUFNLENBQ0pZLE1BREYsQ0FDUyxDQUFDO0lBQUVDO0VBQUYsQ0FBRCxLQUFjQSxJQUFJLENBQUNDLFFBQUwsQ0FBYyxLQUFkLENBRHZCLEVBRUVSLEdBRkYsQ0FFTSxDQUFDO0lBQUVPO0VBQUYsQ0FBRCxFQUFXTCxDQUFYLGtCQUNIO0lBQWdCLEdBQUcsRUFBRUssSUFBckI7SUFBMkIsS0FBSztFQUFoQyxHQUFhTCxDQUFiLENBSEgsQ0FSSCxDQVRGLENBREY7QUEwQkQ7O0FBQ0RULFFBQVEsQ0FBQ2dCLFlBQVQsR0FBd0I7RUFDdEJkLElBQUksZUFDRix5RUFDRTtJQUFNLElBQUksRUFBQyxVQUFYO0lBQXNCLE9BQU8sRUFBQztFQUE5QixFQURGLGVBRUU7SUFDRSxHQUFHLEVBQUMsZUFETjtJQUVFLElBQUksRUFBRyxHQUFELHlCQUFHZSxPQUFPLENBQUNDLEdBQVIsQ0FBWUMsbUJBQWYsb0NBQXNDLEdBQUk7RUFGbEQsRUFGRixDQUZvQjtFQVV0QmIsT0FBTyxFQUFFLE9BVmE7RUFXdEJELE1BQU0sRUFBRTtBQVhjLENBQXhCIn0=
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import type { Route } from '@anansi/router';
3
+ import type { ResolveProps } from './types';
4
+ declare type NeededProps = {
5
+ matchedRoutes: Route<any>[];
6
+ title?: string;
7
+ } & ResolveProps;
8
+ export default function documentSpout(options: {
9
+ head?: React.ReactNode;
10
+ title: string;
11
+ }): <T extends NeededProps>(next: () => Promise<T>) => () => Promise<T>;
12
+ export {};
13
+ //# sourceMappingURL=document.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"document.d.ts","sourceRoot":"","sources":["../../src/spouts/document.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAE5C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE5C,aAAK,WAAW,GAAG;IACjB,aAAa,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,GAAG,YAAY,CAAC;AAEjB,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,OAAO,EAAE;IAC7C,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,KAAK,EAAE,MAAM,CAAC;CACf,uEAQA"}
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ import type { Route } from '@anansi/router';
3
+ import type { ServerProps, ResolveProps } from './types';
4
+ declare type NeededProps = {
5
+ matchedRoutes: Route<any>[];
6
+ title?: string;
7
+ charSet?: string;
8
+ } & ResolveProps;
9
+ export default function DocumentSpout(options: {
10
+ head?: React.ReactNode;
11
+ title: string;
12
+ rootId: string;
13
+ charSet: string;
14
+ }): <T extends NeededProps>(next: (props: ServerProps) => Promise<T>) => (props: ServerProps) => Promise<T & {
15
+ app: JSX.Element;
16
+ }>;
17
+ export {};
18
+ //# sourceMappingURL=document.server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"document.server.d.ts","sourceRoot":"","sources":["../../src/spouts/document.server.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAG5C,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAGzD,aAAK,WAAW,GAAG;IACjB,aAAa,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,GAAG,YAAY,CAAC;AAEjB,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,OAAO,EAAE;IAC7C,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;CACjB,yCAEiB,WAAW,4BAEJ,WAAW;;GAkEnC"}