@anansi/core 0.16.6 → 0.16.8
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 -0
- package/dist/2.chunk.js +20 -0
- package/dist/client.js +233 -285
- package/dist/package.json +1 -0
- package/dist/server.js +358 -496
- package/lib/floodSpouts.js +4 -8
- package/lib/index.d.ts +8 -8
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +7 -18
- package/lib/index.server.d.ts +10 -10
- package/lib/index.server.d.ts.map +1 -1
- package/lib/index.server.js +9 -22
- package/lib/laySpouts.d.ts +2 -2
- package/lib/laySpouts.d.ts.map +1 -1
- package/lib/laySpouts.js +6 -11
- package/lib/scripts/getProxyMiddlewares.js +1 -1
- package/lib/scripts/getWebpackConfig.d.ts +3 -0
- package/lib/scripts/getWebpackConfig.d.ts.map +1 -0
- package/lib/scripts/getWebpackConfig.js +22 -0
- package/lib/scripts/index.d.ts +2 -2
- package/lib/scripts/index.d.ts.map +1 -1
- package/lib/scripts/index.js +3 -3
- package/lib/scripts/package.json +1 -0
- package/lib/scripts/serve.d.ts +1 -1
- package/lib/scripts/serve.d.ts.map +1 -1
- package/lib/scripts/serve.js +8 -6
- package/lib/scripts/startDevserver.d.ts +1 -1
- package/lib/scripts/startDevserver.d.ts.map +1 -1
- package/lib/scripts/startDevserver.js +4 -6
- package/lib/spouts/DocumentComponent.d.ts +1 -1
- package/lib/spouts/DocumentComponent.d.ts.map +1 -1
- package/lib/spouts/DocumentComponent.js +14 -21
- package/lib/spouts/antd.server.d.ts +1 -1
- package/lib/spouts/antd.server.d.ts.map +1 -1
- package/lib/spouts/antd.server.js +8 -14
- package/lib/spouts/app.js +2 -7
- package/lib/spouts/app.server.d.ts +1 -1
- package/lib/spouts/app.server.d.ts.map +1 -1
- package/lib/spouts/app.server.js +2 -7
- package/lib/spouts/csp.js +2 -6
- package/lib/spouts/document.d.ts +1 -1
- package/lib/spouts/document.d.ts.map +1 -1
- package/lib/spouts/document.js +2 -6
- package/lib/spouts/document.server.d.ts +2 -2
- package/lib/spouts/document.server.d.ts.map +1 -1
- package/lib/spouts/document.server.js +10 -12
- package/lib/spouts/json.d.ts +1 -1
- package/lib/spouts/json.d.ts.map +1 -1
- package/lib/spouts/json.js +2 -6
- package/lib/spouts/json.server.d.ts +1 -1
- package/lib/spouts/json.server.d.ts.map +1 -1
- package/lib/spouts/json.server.js +6 -12
- package/lib/spouts/prefetch.server.d.ts +1 -1
- package/lib/spouts/prefetch.server.d.ts.map +1 -1
- package/lib/spouts/prefetch.server.js +2 -6
- package/lib/spouts/restHooks.d.ts +1 -1
- package/lib/spouts/restHooks.d.ts.map +1 -1
- package/lib/spouts/restHooks.js +6 -12
- package/lib/spouts/restHooks.provider.js +2 -7
- package/lib/spouts/restHooks.server.d.ts +1 -1
- package/lib/spouts/restHooks.server.d.ts.map +1 -1
- package/lib/spouts/restHooks.server.js +7 -13
- package/lib/spouts/router.d.ts +1 -1
- package/lib/spouts/router.d.ts.map +1 -1
- package/lib/spouts/router.js +9 -14
- package/lib/spouts/router.server.d.ts +1 -1
- package/lib/spouts/router.server.d.ts.map +1 -1
- package/lib/spouts/router.server.js +9 -14
- package/lib/spouts/types.js +1 -3
- package/package.json +14 -11
- package/src/index.server.ts +10 -10
- package/src/index.ts +8 -8
- package/src/laySpouts.tsx +2 -2
- package/src/scripts/getWebpackConfig.ts +22 -0
- package/src/scripts/index.ts +2 -2
- package/src/scripts/package.json +1 -0
- package/src/scripts/serve.ts +15 -12
- package/src/scripts/startDevserver.ts +5 -8
- package/src/spouts/DocumentComponent.tsx +3 -7
- package/src/spouts/antd.server.tsx +1 -1
- package/src/spouts/app.server.tsx +1 -1
- package/src/spouts/document.server.tsx +12 -4
- package/src/spouts/document.tsx +1 -2
- package/src/spouts/json.server.tsx +1 -1
- package/src/spouts/json.tsx +1 -1
- package/src/spouts/prefetch.server.tsx +1 -1
- package/src/spouts/restHooks.server.tsx +1 -1
- package/src/spouts/restHooks.tsx +2 -2
- package/src/spouts/router.server.tsx +1 -1
- package/src/spouts/router.tsx +1 -1
- package/dist/client.js.map +0 -1
- package/dist/server.js.map +0 -1
package/dist/server.js
CHANGED
|
@@ -1,23 +1,156 @@
|
|
|
1
1
|
/******/ (() => { // webpackBootstrap
|
|
2
|
-
/******/
|
|
2
|
+
/******/ "use strict";
|
|
3
|
+
/******/ var __webpack_modules__ = ([
|
|
4
|
+
/* 0 */,
|
|
5
|
+
/* 1 */,
|
|
6
|
+
/* 2 */
|
|
7
|
+
/***/ ((module) => {
|
|
8
|
+
|
|
9
|
+
module.exports = require("@rest-hooks/react");
|
|
10
|
+
|
|
11
|
+
/***/ }),
|
|
12
|
+
/* 3 */
|
|
13
|
+
/***/ ((module) => {
|
|
14
|
+
|
|
15
|
+
module.exports = require("@rest-hooks/ssr");
|
|
3
16
|
|
|
4
|
-
/***/
|
|
5
|
-
|
|
17
|
+
/***/ }),
|
|
18
|
+
/* 4 */
|
|
19
|
+
/***/ ((module) => {
|
|
20
|
+
|
|
21
|
+
module.exports = require("@ant-design/cssinjs");
|
|
22
|
+
|
|
23
|
+
/***/ })
|
|
24
|
+
/******/ ]);
|
|
25
|
+
/************************************************************************/
|
|
26
|
+
/******/ // The module cache
|
|
27
|
+
/******/ var __webpack_module_cache__ = {};
|
|
28
|
+
/******/
|
|
29
|
+
/******/ // The require function
|
|
30
|
+
/******/ function __webpack_require__(moduleId) {
|
|
31
|
+
/******/ // Check if module is in cache
|
|
32
|
+
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
|
33
|
+
/******/ if (cachedModule !== undefined) {
|
|
34
|
+
/******/ return cachedModule.exports;
|
|
35
|
+
/******/ }
|
|
36
|
+
/******/ // Create a new module (and put it into the cache)
|
|
37
|
+
/******/ var module = __webpack_module_cache__[moduleId] = {
|
|
38
|
+
/******/ // no module.id needed
|
|
39
|
+
/******/ // no module.loaded needed
|
|
40
|
+
/******/ exports: {}
|
|
41
|
+
/******/ };
|
|
42
|
+
/******/
|
|
43
|
+
/******/ // Execute the module function
|
|
44
|
+
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
|
45
|
+
/******/
|
|
46
|
+
/******/ // Return the exports of the module
|
|
47
|
+
/******/ return module.exports;
|
|
48
|
+
/******/ }
|
|
49
|
+
/******/
|
|
50
|
+
/************************************************************************/
|
|
51
|
+
/******/ /* webpack/runtime/compat get default export */
|
|
52
|
+
/******/ (() => {
|
|
53
|
+
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
|
54
|
+
/******/ __webpack_require__.n = (module) => {
|
|
55
|
+
/******/ var getter = module && module.__esModule ?
|
|
56
|
+
/******/ () => (module['default']) :
|
|
57
|
+
/******/ () => (module);
|
|
58
|
+
/******/ __webpack_require__.d(getter, { a: getter });
|
|
59
|
+
/******/ return getter;
|
|
60
|
+
/******/ };
|
|
61
|
+
/******/ })();
|
|
62
|
+
/******/
|
|
63
|
+
/******/ /* webpack/runtime/create fake namespace object */
|
|
64
|
+
/******/ (() => {
|
|
65
|
+
/******/ var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);
|
|
66
|
+
/******/ var leafPrototypes;
|
|
67
|
+
/******/ // create a fake namespace object
|
|
68
|
+
/******/ // mode & 1: value is a module id, require it
|
|
69
|
+
/******/ // mode & 2: merge all properties of value into the ns
|
|
70
|
+
/******/ // mode & 4: return value when already ns object
|
|
71
|
+
/******/ // mode & 16: return value when it's Promise-like
|
|
72
|
+
/******/ // mode & 8|1: behave like require
|
|
73
|
+
/******/ __webpack_require__.t = function(value, mode) {
|
|
74
|
+
/******/ if(mode & 1) value = this(value);
|
|
75
|
+
/******/ if(mode & 8) return value;
|
|
76
|
+
/******/ if(typeof value === 'object' && value) {
|
|
77
|
+
/******/ if((mode & 4) && value.__esModule) return value;
|
|
78
|
+
/******/ if((mode & 16) && typeof value.then === 'function') return value;
|
|
79
|
+
/******/ }
|
|
80
|
+
/******/ var ns = Object.create(null);
|
|
81
|
+
/******/ __webpack_require__.r(ns);
|
|
82
|
+
/******/ var def = {};
|
|
83
|
+
/******/ leafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];
|
|
84
|
+
/******/ for(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {
|
|
85
|
+
/******/ Object.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key])));
|
|
86
|
+
/******/ }
|
|
87
|
+
/******/ def['default'] = () => (value);
|
|
88
|
+
/******/ __webpack_require__.d(ns, def);
|
|
89
|
+
/******/ return ns;
|
|
90
|
+
/******/ };
|
|
91
|
+
/******/ })();
|
|
92
|
+
/******/
|
|
93
|
+
/******/ /* webpack/runtime/define property getters */
|
|
94
|
+
/******/ (() => {
|
|
95
|
+
/******/ // define getter functions for harmony exports
|
|
96
|
+
/******/ __webpack_require__.d = (exports, definition) => {
|
|
97
|
+
/******/ for(var key in definition) {
|
|
98
|
+
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
|
99
|
+
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
|
100
|
+
/******/ }
|
|
101
|
+
/******/ }
|
|
102
|
+
/******/ };
|
|
103
|
+
/******/ })();
|
|
104
|
+
/******/
|
|
105
|
+
/******/ /* webpack/runtime/hasOwnProperty shorthand */
|
|
106
|
+
/******/ (() => {
|
|
107
|
+
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
|
|
108
|
+
/******/ })();
|
|
109
|
+
/******/
|
|
110
|
+
/******/ /* webpack/runtime/make namespace object */
|
|
111
|
+
/******/ (() => {
|
|
112
|
+
/******/ // define __esModule on exports
|
|
113
|
+
/******/ __webpack_require__.r = (exports) => {
|
|
114
|
+
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|
115
|
+
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
116
|
+
/******/ }
|
|
117
|
+
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
|
118
|
+
/******/ };
|
|
119
|
+
/******/ })();
|
|
120
|
+
/******/
|
|
121
|
+
/************************************************************************/
|
|
122
|
+
var __webpack_exports__ = {};
|
|
123
|
+
// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
|
|
124
|
+
(() => {
|
|
125
|
+
// ESM COMPAT FLAG
|
|
126
|
+
__webpack_require__.r(__webpack_exports__);
|
|
127
|
+
|
|
128
|
+
// EXPORTS
|
|
129
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
130
|
+
"JSONSpout": () => (/* reexport */ JSONSpout),
|
|
131
|
+
"antdSpout": () => (/* reexport */ antdSpout),
|
|
132
|
+
"appSpout": () => (/* reexport */ app_server),
|
|
133
|
+
"documentSpout": () => (/* reexport */ DocumentSpout),
|
|
134
|
+
"laySpouts": () => (/* reexport */ laySpouts),
|
|
135
|
+
"prefetchSpout": () => (/* reexport */ prefetchSpout),
|
|
136
|
+
"restHooksSpout": () => (/* reexport */ restHooksSpout),
|
|
137
|
+
"routerSpout": () => (/* reexport */ routerSpout)
|
|
138
|
+
});
|
|
6
139
|
|
|
7
|
-
|
|
140
|
+
;// CONCATENATED MODULE: external "crypto"
|
|
141
|
+
const external_crypto_namespaceObject = require("crypto");
|
|
142
|
+
var external_crypto_default = /*#__PURE__*/__webpack_require__.n(external_crypto_namespaceObject);
|
|
143
|
+
;// CONCATENATED MODULE: external "react-dom/server"
|
|
144
|
+
const server_namespaceObject = require("react-dom/server");
|
|
145
|
+
;// CONCATENATED MODULE: ./src/laySpouts.tsx
|
|
8
146
|
|
|
9
147
|
|
|
10
|
-
var _interopRequireDefault = (__webpack_require__("../../node_modules/@babel/runtime/helpers/interopRequireDefault.js")["default"]);
|
|
11
|
-
exports.__esModule = true;
|
|
12
|
-
exports["default"] = laySpouts;
|
|
13
|
-
var _crypto = _interopRequireDefault(__webpack_require__("crypto"));
|
|
14
|
-
var _server = __webpack_require__("react-dom/server");
|
|
15
148
|
function laySpouts(spouts, {
|
|
16
149
|
timeoutMS = 10000,
|
|
17
150
|
onError
|
|
18
151
|
} = {}) {
|
|
19
152
|
const render = async (clientManifest, req, res) => {
|
|
20
|
-
const nonce =
|
|
153
|
+
const nonce = external_crypto_default().randomBytes(16).toString('base64');
|
|
21
154
|
try {
|
|
22
155
|
const {
|
|
23
156
|
app
|
|
@@ -31,7 +164,7 @@ function laySpouts(spouts, {
|
|
|
31
164
|
const {
|
|
32
165
|
pipe,
|
|
33
166
|
abort
|
|
34
|
-
} = (0,
|
|
167
|
+
} = (0,server_namespaceObject.renderToPipeableStream)(app, {
|
|
35
168
|
nonce,
|
|
36
169
|
//bootstrapScripts: assets.filter(asset => asset.endsWith('.js')),
|
|
37
170
|
onShellReady() {
|
|
@@ -64,22 +197,29 @@ function laySpouts(spouts, {
|
|
|
64
197
|
};
|
|
65
198
|
return render;
|
|
66
199
|
}
|
|
200
|
+
;// CONCATENATED MODULE: external "react"
|
|
201
|
+
const external_react_namespaceObject = require("react");
|
|
202
|
+
var external_react_default = /*#__PURE__*/__webpack_require__.n(external_react_namespaceObject);
|
|
203
|
+
;// CONCATENATED MODULE: ./src/spouts/csp.ts
|
|
204
|
+
// TODO: memoize this
|
|
205
|
+
function buildPolicy(policyObj) {
|
|
206
|
+
return Object.keys(policyObj).map(key => {
|
|
207
|
+
const val = Array.isArray(policyObj[key]) ? [...new Set(policyObj[key]).values()].filter(v => v).join(' ') : policyObj[key];
|
|
67
208
|
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
exports["default"] = Document;
|
|
79
|
-
var _react = _interopRequireDefault(__webpack_require__("react"));
|
|
80
|
-
var _csp = __webpack_require__("./src/spouts/csp.ts");
|
|
209
|
+
// move strict dynamic to the end of the policy if it exists to be backwards compatible with csp2
|
|
210
|
+
// https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy/script-src#strict-dynamic
|
|
211
|
+
if (typeof val === 'string' && val.includes("'strict-dynamic'")) {
|
|
212
|
+
const newVal = `${val.replace(/\s?'strict-dynamic'\s?/gi, ' ').trim()} 'strict-dynamic'`;
|
|
213
|
+
return `${key} ${newVal}`;
|
|
214
|
+
}
|
|
215
|
+
return `${key} ${val}`;
|
|
216
|
+
}).join('; ');
|
|
217
|
+
}
|
|
218
|
+
;// CONCATENATED MODULE: ./src/spouts/DocumentComponent.tsx
|
|
81
219
|
var _jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/DocumentComponent.tsx",
|
|
82
220
|
_process$env$WEBPACK_;
|
|
221
|
+
|
|
222
|
+
|
|
83
223
|
function Document({
|
|
84
224
|
assets,
|
|
85
225
|
head,
|
|
@@ -98,107 +238,111 @@ function Document({
|
|
|
98
238
|
const policy = {
|
|
99
239
|
...csPolicy
|
|
100
240
|
};
|
|
101
|
-
if (nonce
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
241
|
+
if (nonce) {
|
|
242
|
+
if (typeof policy['script-src'] === 'string') {
|
|
243
|
+
policy['script-src'] = [policy['script-src'], `'nonce-${nonce}'`];
|
|
244
|
+
} else {
|
|
245
|
+
policy['script-src'] = [...policy['script-src'], `'nonce-${nonce}'`];
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
cspMeta = /*#__PURE__*/external_react_default().createElement("meta", {
|
|
105
249
|
httpEquiv: "Content-Security-Policy",
|
|
106
|
-
content:
|
|
250
|
+
content: buildPolicy(policy),
|
|
107
251
|
__self: this,
|
|
108
252
|
__source: {
|
|
109
253
|
fileName: _jsxFileName,
|
|
110
|
-
lineNumber:
|
|
254
|
+
lineNumber: 43,
|
|
111
255
|
columnNumber: 7
|
|
112
256
|
}
|
|
113
257
|
});
|
|
114
258
|
}
|
|
115
|
-
return /*#__PURE__*/
|
|
259
|
+
return /*#__PURE__*/external_react_default().createElement("html", {
|
|
116
260
|
__self: this,
|
|
117
261
|
__source: {
|
|
118
262
|
fileName: _jsxFileName,
|
|
119
|
-
lineNumber:
|
|
263
|
+
lineNumber: 47,
|
|
120
264
|
columnNumber: 5
|
|
121
265
|
}
|
|
122
|
-
}, /*#__PURE__*/
|
|
266
|
+
}, /*#__PURE__*/external_react_default().createElement("head", {
|
|
123
267
|
__self: this,
|
|
124
268
|
__source: {
|
|
125
269
|
fileName: _jsxFileName,
|
|
126
|
-
lineNumber:
|
|
270
|
+
lineNumber: 48,
|
|
127
271
|
columnNumber: 7
|
|
128
272
|
}
|
|
129
|
-
}, /*#__PURE__*/
|
|
273
|
+
}, /*#__PURE__*/external_react_default().createElement("meta", {
|
|
130
274
|
charSet: charSet,
|
|
131
275
|
__self: this,
|
|
132
276
|
__source: {
|
|
133
277
|
fileName: _jsxFileName,
|
|
134
|
-
lineNumber:
|
|
278
|
+
lineNumber: 49,
|
|
135
279
|
columnNumber: 9
|
|
136
280
|
}
|
|
137
|
-
}), cspMeta, head, extraStyle, assets.map((asset, i) => /*#__PURE__*/
|
|
281
|
+
}), cspMeta, head, extraStyle, assets.map((asset, i) => /*#__PURE__*/external_react_default().createElement("link", {
|
|
138
282
|
key: i,
|
|
139
283
|
rel: "preload",
|
|
140
284
|
...asset,
|
|
141
285
|
__self: this,
|
|
142
286
|
__source: {
|
|
143
287
|
fileName: _jsxFileName,
|
|
144
|
-
lineNumber:
|
|
288
|
+
lineNumber: 54,
|
|
145
289
|
columnNumber: 11
|
|
146
290
|
}
|
|
147
|
-
})), /*#__PURE__*/
|
|
291
|
+
})), /*#__PURE__*/external_react_default().createElement("title", {
|
|
148
292
|
__self: this,
|
|
149
293
|
__source: {
|
|
150
294
|
fileName: _jsxFileName,
|
|
151
|
-
lineNumber:
|
|
295
|
+
lineNumber: 56,
|
|
152
296
|
columnNumber: 9
|
|
153
297
|
}
|
|
154
|
-
}, title)), /*#__PURE__*/
|
|
298
|
+
}, title)), /*#__PURE__*/external_react_default().createElement("body", {
|
|
155
299
|
__self: this,
|
|
156
300
|
__source: {
|
|
157
301
|
fileName: _jsxFileName,
|
|
158
|
-
lineNumber:
|
|
302
|
+
lineNumber: 58,
|
|
159
303
|
columnNumber: 7
|
|
160
304
|
}
|
|
161
|
-
}, /*#__PURE__*/
|
|
305
|
+
}, /*#__PURE__*/external_react_default().createElement("div", {
|
|
162
306
|
id: rootId,
|
|
163
307
|
__self: this,
|
|
164
308
|
__source: {
|
|
165
309
|
fileName: _jsxFileName,
|
|
166
|
-
lineNumber:
|
|
310
|
+
lineNumber: 59,
|
|
167
311
|
columnNumber: 9
|
|
168
312
|
}
|
|
169
313
|
}, children), scripts, assets.filter(({
|
|
170
314
|
href
|
|
171
315
|
}) => href.endsWith('.js')).map(({
|
|
172
316
|
href
|
|
173
|
-
}, i) => /*#__PURE__*/
|
|
317
|
+
}, i) => /*#__PURE__*/external_react_default().createElement("script", {
|
|
174
318
|
key: i,
|
|
175
319
|
src: href,
|
|
176
320
|
async: true,
|
|
177
321
|
__self: this,
|
|
178
322
|
__source: {
|
|
179
323
|
fileName: _jsxFileName,
|
|
180
|
-
lineNumber:
|
|
324
|
+
lineNumber: 64,
|
|
181
325
|
columnNumber: 13
|
|
182
326
|
}
|
|
183
327
|
}))));
|
|
184
328
|
}
|
|
185
329
|
Document.defaultProps = {
|
|
186
|
-
head: /*#__PURE__*/
|
|
330
|
+
head: /*#__PURE__*/external_react_default().createElement((external_react_default()).Fragment, null, /*#__PURE__*/external_react_default().createElement("meta", {
|
|
187
331
|
name: "viewport",
|
|
188
332
|
content: "width=device-width, initial-scale=1",
|
|
189
|
-
__self:
|
|
333
|
+
__self: undefined,
|
|
190
334
|
__source: {
|
|
191
335
|
fileName: _jsxFileName,
|
|
192
|
-
lineNumber:
|
|
336
|
+
lineNumber: 73,
|
|
193
337
|
columnNumber: 7
|
|
194
338
|
}
|
|
195
|
-
}), /*#__PURE__*/
|
|
339
|
+
}), /*#__PURE__*/external_react_default().createElement("link", {
|
|
196
340
|
rel: "shortcut icon",
|
|
197
341
|
href: `${(_process$env$WEBPACK_ = process.env.WEBPACK_PUBLIC_PATH) != null ? _process$env$WEBPACK_ : '/'}favicon.ico`,
|
|
198
|
-
__self:
|
|
342
|
+
__self: undefined,
|
|
199
343
|
__source: {
|
|
200
344
|
fileName: _jsxFileName,
|
|
201
|
-
lineNumber:
|
|
345
|
+
lineNumber: 74,
|
|
202
346
|
columnNumber: 7
|
|
203
347
|
}
|
|
204
348
|
})),
|
|
@@ -206,130 +350,13 @@ Document.defaultProps = {
|
|
|
206
350
|
rootId: 'anansi-root',
|
|
207
351
|
scripts: null
|
|
208
352
|
};
|
|
353
|
+
;// CONCATENATED MODULE: ./src/spouts/document.server.tsx
|
|
354
|
+
var document_server_jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/document.server.tsx";
|
|
209
355
|
|
|
210
|
-
/***/ }),
|
|
211
|
-
|
|
212
|
-
/***/ "./src/spouts/antd.server.tsx":
|
|
213
|
-
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
214
|
-
|
|
215
|
-
"use strict";
|
|
216
356
|
|
|
217
|
-
|
|
218
|
-
var _interopRequireDefault = (__webpack_require__("../../node_modules/@babel/runtime/helpers/interopRequireDefault.js")["default"]);
|
|
219
|
-
exports.__esModule = true;
|
|
220
|
-
exports["default"] = antdSpout;
|
|
221
|
-
var _interopRequireWildcard2 = _interopRequireDefault(__webpack_require__("../../node_modules/@babel/runtime/helpers/interopRequireWildcard.js"));
|
|
222
|
-
var _react = _interopRequireDefault(__webpack_require__("react"));
|
|
223
|
-
var _jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/antd.server.tsx";
|
|
224
|
-
function antdSpout() {
|
|
225
|
-
return next => async props => {
|
|
226
|
-
var _nextProps$scripts;
|
|
227
|
-
const {
|
|
228
|
-
createCache,
|
|
229
|
-
extractStyle,
|
|
230
|
-
StyleProvider
|
|
231
|
-
} = await Promise.resolve().then(() => (0, _interopRequireWildcard2.default)(__webpack_require__("@ant-design/cssinjs")));
|
|
232
|
-
const cache = createCache();
|
|
233
|
-
const nextProps = await next(props);
|
|
234
|
-
const scripts = (_nextProps$scripts = nextProps.scripts) != null ? _nextProps$scripts : [];
|
|
235
|
-
const AntdSheets = () => {
|
|
236
|
-
return /*#__PURE__*/_react.default.createElement("script", {
|
|
237
|
-
dangerouslySetInnerHTML: {
|
|
238
|
-
__html: `</script>${extractStyle(cache)}<script>`
|
|
239
|
-
},
|
|
240
|
-
__self: this,
|
|
241
|
-
__source: {
|
|
242
|
-
fileName: _jsxFileName,
|
|
243
|
-
lineNumber: 28,
|
|
244
|
-
columnNumber: 9
|
|
245
|
-
}
|
|
246
|
-
});
|
|
247
|
-
};
|
|
248
|
-
// unfortunately we have to inject this after the entire content has streamed in or it doesn't correctly populate
|
|
249
|
-
// see: https://github.com/ant-design/cssinjs/issues/79
|
|
250
|
-
scripts.push( /*#__PURE__*/_react.default.createElement(AntdSheets, {
|
|
251
|
-
__self: this,
|
|
252
|
-
__source: {
|
|
253
|
-
fileName: _jsxFileName,
|
|
254
|
-
lineNumber: 37,
|
|
255
|
-
columnNumber: 18
|
|
256
|
-
}
|
|
257
|
-
}));
|
|
258
|
-
return {
|
|
259
|
-
...nextProps,
|
|
260
|
-
app: /*#__PURE__*/_react.default.createElement(StyleProvider, {
|
|
261
|
-
cache: cache,
|
|
262
|
-
__self: this,
|
|
263
|
-
__source: {
|
|
264
|
-
fileName: _jsxFileName,
|
|
265
|
-
lineNumber: 41,
|
|
266
|
-
columnNumber: 12
|
|
267
|
-
}
|
|
268
|
-
}, nextProps.app),
|
|
269
|
-
scripts
|
|
270
|
-
};
|
|
271
|
-
};
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
/***/ }),
|
|
275
|
-
|
|
276
|
-
/***/ "./src/spouts/app.server.tsx":
|
|
277
|
-
/***/ ((__unused_webpack_module, exports) => {
|
|
278
|
-
|
|
279
|
-
"use strict";
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
exports.__esModule = true;
|
|
283
|
-
exports["default"] = void 0;
|
|
284
|
-
const appSpout = app => props => Promise.resolve({
|
|
285
|
-
...props,
|
|
286
|
-
app
|
|
287
|
-
});
|
|
288
|
-
var _default = appSpout;
|
|
289
|
-
exports["default"] = _default;
|
|
290
|
-
|
|
291
|
-
/***/ }),
|
|
292
|
-
|
|
293
|
-
/***/ "./src/spouts/csp.ts":
|
|
294
|
-
/***/ ((__unused_webpack_module, exports) => {
|
|
295
|
-
|
|
296
|
-
"use strict";
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
exports.__esModule = true;
|
|
300
|
-
exports.buildPolicy = buildPolicy;
|
|
301
|
-
// TODO: memoize this
|
|
302
|
-
function buildPolicy(policyObj) {
|
|
303
|
-
return Object.keys(policyObj).map(key => {
|
|
304
|
-
const val = Array.isArray(policyObj[key]) ? [...new Set(policyObj[key]).values()].filter(v => v).join(' ') : policyObj[key];
|
|
305
|
-
|
|
306
|
-
// move strict dynamic to the end of the policy if it exists to be backwards compatible with csp2
|
|
307
|
-
// https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy/script-src#strict-dynamic
|
|
308
|
-
if (typeof val === 'string' && val.includes("'strict-dynamic'")) {
|
|
309
|
-
const newVal = `${val.replace(/\s?'strict-dynamic'\s?/gi, ' ').trim()} 'strict-dynamic'`;
|
|
310
|
-
return `${key} ${newVal}`;
|
|
311
|
-
}
|
|
312
|
-
return `${key} ${val}`;
|
|
313
|
-
}).join('; ');
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
/***/ }),
|
|
317
|
-
|
|
318
|
-
/***/ "./src/spouts/document.server.tsx":
|
|
319
|
-
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
320
|
-
|
|
321
|
-
"use strict";
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
var _interopRequireDefault = (__webpack_require__("../../node_modules/@babel/runtime/helpers/interopRequireDefault.js")["default"]);
|
|
325
|
-
exports.__esModule = true;
|
|
326
|
-
exports["default"] = DocumentSpout;
|
|
327
|
-
var _react = _interopRequireDefault(__webpack_require__("react"));
|
|
328
|
-
var _DocumentComponent = _interopRequireDefault(__webpack_require__("./src/spouts/DocumentComponent.tsx"));
|
|
329
|
-
var _jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/document.server.tsx";
|
|
330
357
|
function DocumentSpout(options) {
|
|
331
358
|
return next => async props => {
|
|
332
|
-
var _props$clientManifest, _props$clientManifest2, _props$clientManifest3, _props$clientManifest4, _props$clientManifest5, _nextProps$title;
|
|
359
|
+
var _props$clientManifest, _props$clientManifest2, _props$clientManifest3, _props$clientManifest4, _props$clientManifest5, _props$req, _nextProps$title;
|
|
333
360
|
const nextProps = await next(props);
|
|
334
361
|
const publicPath = props.clientManifest.publicPath;
|
|
335
362
|
if (Object.keys((_props$clientManifest = (_props$clientManifest2 = props.clientManifest) == null ? void 0 : _props$clientManifest2.entrypoints) != null ? _props$clientManifest : {}).length < 1 || publicPath === undefined) throw new Error('Manifest missing entries needed');
|
|
@@ -363,21 +390,24 @@ function DocumentSpout(options) {
|
|
|
363
390
|
} : {
|
|
364
391
|
href: asset
|
|
365
392
|
});
|
|
393
|
+
const nonce =
|
|
394
|
+
// nonces negate 'unsafe-inline' so do not add it in development to keep things easier
|
|
395
|
+
props.nonce && (process.env.NODE_ENV === 'production' || ((_props$req = props.req) == null ? void 0 : _props$req.protocol) !== 'http') ? props.nonce : undefined;
|
|
366
396
|
return {
|
|
367
397
|
...nextProps,
|
|
368
|
-
app: /*#__PURE__*/
|
|
398
|
+
app: /*#__PURE__*/external_react_default().createElement(Document, {
|
|
369
399
|
...options,
|
|
370
400
|
extraStyle: nextProps.extraStyle,
|
|
371
401
|
title: (_nextProps$title = nextProps.title) != null ? _nextProps$title : options.title,
|
|
372
402
|
assets: assets,
|
|
373
403
|
rootId: options.rootId,
|
|
374
|
-
nonce:
|
|
404
|
+
nonce: nonce,
|
|
375
405
|
csPolicy: options.csPolicy,
|
|
376
406
|
scripts: nextProps.scripts,
|
|
377
407
|
__self: this,
|
|
378
408
|
__source: {
|
|
379
|
-
fileName:
|
|
380
|
-
lineNumber:
|
|
409
|
+
fileName: document_server_jsxFileName,
|
|
410
|
+
lineNumber: 85,
|
|
381
411
|
columnNumber: 9
|
|
382
412
|
}
|
|
383
413
|
}, nextProps.app)
|
|
@@ -390,129 +420,16 @@ function childrenAssets(chunk) {
|
|
|
390
420
|
return (_c$assets = c.assets) != null ? _c$assets : [];
|
|
391
421
|
})) : [];
|
|
392
422
|
}
|
|
423
|
+
;// CONCATENATED MODULE: ./src/spouts/restHooks.server.tsx
|
|
424
|
+
var restHooks_server_jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/restHooks.server.tsx";
|
|
393
425
|
|
|
394
|
-
/***/ }),
|
|
395
|
-
|
|
396
|
-
/***/ "./src/spouts/json.server.tsx":
|
|
397
|
-
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
398
|
-
|
|
399
|
-
"use strict";
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
var _interopRequireWildcard = (__webpack_require__("../../node_modules/@babel/runtime/helpers/interopRequireWildcard.js")["default"]);
|
|
403
|
-
exports.__esModule = true;
|
|
404
|
-
exports["default"] = JSONSpout;
|
|
405
|
-
var _react = _interopRequireWildcard(__webpack_require__("react"));
|
|
406
|
-
var _jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/json.server.tsx";
|
|
407
|
-
function JSONSpout({
|
|
408
|
-
id = 'anansi-json'
|
|
409
|
-
} = {}) {
|
|
410
|
-
return next => async props => {
|
|
411
|
-
var _nextProps$scripts, _nextProps$initData;
|
|
412
|
-
const nextProps = await next(props);
|
|
413
|
-
const scripts = (_nextProps$scripts = nextProps.scripts) != null ? _nextProps$scripts : [];
|
|
414
|
-
Object.entries((_nextProps$initData = nextProps.initData) != null ? _nextProps$initData : {}).forEach(([key, useData]) => {
|
|
415
|
-
const globalId = `${id}.${key}`;
|
|
416
|
-
const Script = () => {
|
|
417
|
-
const data = useData();
|
|
418
|
-
try {
|
|
419
|
-
const encoded = JSON.stringify(data);
|
|
420
|
-
return /*#__PURE__*/_react.default.createElement("script", {
|
|
421
|
-
id: globalId,
|
|
422
|
-
type: "application/json",
|
|
423
|
-
dangerouslySetInnerHTML: {
|
|
424
|
-
__html: encoded
|
|
425
|
-
},
|
|
426
|
-
nonce: props.nonce,
|
|
427
|
-
__self: this,
|
|
428
|
-
__source: {
|
|
429
|
-
fileName: _jsxFileName,
|
|
430
|
-
lineNumber: 29,
|
|
431
|
-
columnNumber: 13
|
|
432
|
-
}
|
|
433
|
-
});
|
|
434
|
-
} catch (e) {
|
|
435
|
-
// TODO: Use unified logging
|
|
436
|
-
console.error(`Error serializing json for ${key}`);
|
|
437
|
-
console.error(e);
|
|
438
|
-
return null;
|
|
439
|
-
}
|
|
440
|
-
};
|
|
441
|
-
scripts.push( /*#__PURE__*/_react.default.createElement(_react.Suspense, {
|
|
442
|
-
key: globalId,
|
|
443
|
-
__self: this,
|
|
444
|
-
__source: {
|
|
445
|
-
fileName: _jsxFileName,
|
|
446
|
-
lineNumber: 46,
|
|
447
|
-
columnNumber: 9
|
|
448
|
-
}
|
|
449
|
-
}, /*#__PURE__*/_react.default.createElement(Script, {
|
|
450
|
-
__self: this,
|
|
451
|
-
__source: {
|
|
452
|
-
fileName: _jsxFileName,
|
|
453
|
-
lineNumber: 47,
|
|
454
|
-
columnNumber: 11
|
|
455
|
-
}
|
|
456
|
-
})));
|
|
457
|
-
});
|
|
458
|
-
return {
|
|
459
|
-
...nextProps,
|
|
460
|
-
scripts
|
|
461
|
-
};
|
|
462
|
-
};
|
|
463
|
-
}
|
|
464
|
-
|
|
465
|
-
/***/ }),
|
|
466
|
-
|
|
467
|
-
/***/ "./src/spouts/prefetch.server.tsx":
|
|
468
|
-
/***/ ((__unused_webpack_module, exports) => {
|
|
469
|
-
|
|
470
|
-
"use strict";
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
exports.__esModule = true;
|
|
474
|
-
exports["default"] = prefetchSpout;
|
|
475
|
-
function prefetchSpout(field) {
|
|
476
|
-
return function (next) {
|
|
477
|
-
return async props => {
|
|
478
|
-
const nextProps = await next(props);
|
|
479
|
-
try {
|
|
480
|
-
const toFetch = [];
|
|
481
|
-
nextProps.matchedRoutes.forEach(route => {
|
|
482
|
-
if (typeof route.resolveData === 'function') {
|
|
483
|
-
toFetch.push(route.resolveData(nextProps[field], route));
|
|
484
|
-
}
|
|
485
|
-
});
|
|
486
|
-
await Promise.all(toFetch);
|
|
487
|
-
} catch (e) {
|
|
488
|
-
console.error(e);
|
|
489
|
-
}
|
|
490
|
-
return nextProps;
|
|
491
|
-
};
|
|
492
|
-
};
|
|
493
|
-
}
|
|
494
|
-
|
|
495
|
-
/***/ }),
|
|
496
|
-
|
|
497
|
-
/***/ "./src/spouts/restHooks.server.tsx":
|
|
498
|
-
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
499
|
-
|
|
500
|
-
"use strict";
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
var _interopRequireDefault = (__webpack_require__("../../node_modules/@babel/runtime/helpers/interopRequireDefault.js")["default"]);
|
|
504
|
-
exports.__esModule = true;
|
|
505
|
-
exports["default"] = restHooksSpout;
|
|
506
|
-
var _interopRequireWildcard2 = _interopRequireDefault(__webpack_require__("../../node_modules/@babel/runtime/helpers/interopRequireWildcard.js"));
|
|
507
|
-
var _react = _interopRequireDefault(__webpack_require__("react"));
|
|
508
|
-
var _jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/restHooks.server.tsx";
|
|
509
426
|
function restHooksSpout(options = {}) {
|
|
510
427
|
return next => async props => {
|
|
511
428
|
var _options$getManagers;
|
|
512
|
-
const managers = (_options$getManagers = options == null ? void 0 : options.getManagers == null ? void 0 : options.getManagers()) != null ? _options$getManagers : [new (await Promise.resolve().then((
|
|
429
|
+
const managers = (_options$getManagers = options == null ? void 0 : options.getManagers == null ? void 0 : options.getManagers()) != null ? _options$getManagers : [new (await Promise.resolve(/* import() */).then(__webpack_require__.t.bind(__webpack_require__, 2, 23))).NetworkManager()];
|
|
513
430
|
const {
|
|
514
431
|
createPersistedStore
|
|
515
|
-
} = await Promise.resolve().then((
|
|
432
|
+
} = await Promise.resolve(/* import() */).then(__webpack_require__.t.bind(__webpack_require__, 3, 23));
|
|
516
433
|
const [ServerCacheProvider, useReadyCacheState, controller, store] = createPersistedStore(managers);
|
|
517
434
|
const nextProps = await next({
|
|
518
435
|
...props,
|
|
@@ -525,10 +442,10 @@ function restHooksSpout(options = {}) {
|
|
|
525
442
|
...nextProps.initData,
|
|
526
443
|
resthooks: useReadyCacheState
|
|
527
444
|
},
|
|
528
|
-
app: /*#__PURE__*/
|
|
445
|
+
app: /*#__PURE__*/external_react_default().createElement(ServerCacheProvider, {
|
|
529
446
|
__self: this,
|
|
530
447
|
__source: {
|
|
531
|
-
fileName:
|
|
448
|
+
fileName: restHooks_server_jsxFileName,
|
|
532
449
|
lineNumber: 34,
|
|
533
450
|
columnNumber: 12
|
|
534
451
|
}
|
|
@@ -539,33 +456,78 @@ function restHooksSpout(options = {}) {
|
|
|
539
456
|
};
|
|
540
457
|
};
|
|
541
458
|
}
|
|
459
|
+
;// CONCATENATED MODULE: ./src/spouts/antd.server.tsx
|
|
460
|
+
var antd_server_jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/antd.server.tsx";
|
|
542
461
|
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
462
|
+
function antdSpout() {
|
|
463
|
+
return next => async props => {
|
|
464
|
+
var _nextProps$scripts;
|
|
465
|
+
const {
|
|
466
|
+
createCache,
|
|
467
|
+
extractStyle,
|
|
468
|
+
StyleProvider
|
|
469
|
+
} = await Promise.resolve(/* import() */).then(__webpack_require__.t.bind(__webpack_require__, 4, 23));
|
|
470
|
+
const cache = createCache();
|
|
471
|
+
const nextProps = await next(props);
|
|
472
|
+
const scripts = (_nextProps$scripts = nextProps.scripts) != null ? _nextProps$scripts : [];
|
|
473
|
+
const AntdSheets = () => {
|
|
474
|
+
return /*#__PURE__*/external_react_default().createElement("script", {
|
|
475
|
+
dangerouslySetInnerHTML: {
|
|
476
|
+
__html: `</script>${extractStyle(cache)}<script>`
|
|
477
|
+
},
|
|
478
|
+
__self: this,
|
|
479
|
+
__source: {
|
|
480
|
+
fileName: antd_server_jsxFileName,
|
|
481
|
+
lineNumber: 28,
|
|
482
|
+
columnNumber: 9
|
|
483
|
+
}
|
|
484
|
+
});
|
|
485
|
+
};
|
|
486
|
+
// unfortunately we have to inject this after the entire content has streamed in or it doesn't correctly populate
|
|
487
|
+
// see: https://github.com/ant-design/cssinjs/issues/79
|
|
488
|
+
scripts.push( /*#__PURE__*/external_react_default().createElement(AntdSheets, {
|
|
489
|
+
__self: this,
|
|
490
|
+
__source: {
|
|
491
|
+
fileName: antd_server_jsxFileName,
|
|
492
|
+
lineNumber: 37,
|
|
493
|
+
columnNumber: 18
|
|
494
|
+
}
|
|
495
|
+
}));
|
|
496
|
+
return {
|
|
497
|
+
...nextProps,
|
|
498
|
+
app: /*#__PURE__*/external_react_default().createElement(StyleProvider, {
|
|
499
|
+
cache: cache,
|
|
500
|
+
__self: this,
|
|
501
|
+
__source: {
|
|
502
|
+
fileName: antd_server_jsxFileName,
|
|
503
|
+
lineNumber: 41,
|
|
504
|
+
columnNumber: 12
|
|
505
|
+
}
|
|
506
|
+
}, nextProps.app),
|
|
507
|
+
scripts
|
|
508
|
+
};
|
|
509
|
+
};
|
|
510
|
+
}
|
|
511
|
+
;// CONCATENATED MODULE: external "@anansi/router"
|
|
512
|
+
const router_namespaceObject = require("@anansi/router");
|
|
513
|
+
;// CONCATENATED MODULE: external "history"
|
|
514
|
+
const external_history_namespaceObject = require("history");
|
|
515
|
+
;// CONCATENATED MODULE: ./src/spouts/router.server.tsx
|
|
516
|
+
var router_server_jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/router.server.tsx";
|
|
547
517
|
|
|
548
|
-
"use strict";
|
|
549
518
|
|
|
550
519
|
|
|
551
|
-
var _interopRequireDefault = (__webpack_require__("../../node_modules/@babel/runtime/helpers/interopRequireDefault.js")["default"]);
|
|
552
|
-
exports.__esModule = true;
|
|
553
|
-
exports["default"] = routerSpout;
|
|
554
|
-
var _router = __webpack_require__("@anansi/router");
|
|
555
|
-
var _history = __webpack_require__("history");
|
|
556
|
-
var _react = _interopRequireDefault(__webpack_require__("react"));
|
|
557
|
-
var _jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/router.server.tsx";
|
|
558
520
|
function routerSpout(options) {
|
|
559
521
|
const createRouteComponent = router => function Router({
|
|
560
522
|
children
|
|
561
523
|
}) {
|
|
562
524
|
const resolveWith = options.useResolveWith();
|
|
563
|
-
return /*#__PURE__*/
|
|
525
|
+
return /*#__PURE__*/external_react_default().createElement(router_namespaceObject.RouteProvider, {
|
|
564
526
|
router: router,
|
|
565
527
|
resolveWith: resolveWith,
|
|
566
528
|
__self: this,
|
|
567
529
|
__source: {
|
|
568
|
-
fileName:
|
|
530
|
+
fileName: router_server_jsxFileName,
|
|
569
531
|
lineNumber: 26,
|
|
570
532
|
columnNumber: 9
|
|
571
533
|
}
|
|
@@ -573,7 +535,7 @@ function routerSpout(options) {
|
|
|
573
535
|
};
|
|
574
536
|
return next => async props => {
|
|
575
537
|
const url = props.req.url || '';
|
|
576
|
-
const router = options.createRouter((0,
|
|
538
|
+
const router = options.createRouter((0,external_history_namespaceObject.createMemoryHistory)({
|
|
577
539
|
initialEntries: [url]
|
|
578
540
|
}));
|
|
579
541
|
const matchedRoutes = router.getMatchedRoutes(url);
|
|
@@ -585,10 +547,10 @@ function routerSpout(options) {
|
|
|
585
547
|
const Router = createRouteComponent(router);
|
|
586
548
|
return {
|
|
587
549
|
...nextProps,
|
|
588
|
-
app: /*#__PURE__*/
|
|
550
|
+
app: /*#__PURE__*/external_react_default().createElement(Router, {
|
|
589
551
|
__self: this,
|
|
590
552
|
__source: {
|
|
591
|
-
fileName:
|
|
553
|
+
fileName: router_server_jsxFileName,
|
|
592
554
|
lineNumber: 49,
|
|
593
555
|
columnNumber: 12
|
|
594
556
|
}
|
|
@@ -599,204 +561,104 @@ function routerSpout(options) {
|
|
|
599
561
|
};
|
|
600
562
|
};
|
|
601
563
|
}
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
/***/ "@rest-hooks/react":
|
|
622
|
-
/***/ ((module) => {
|
|
623
|
-
|
|
624
|
-
"use strict";
|
|
625
|
-
module.exports = require("@rest-hooks/react");
|
|
626
|
-
|
|
627
|
-
/***/ }),
|
|
628
|
-
|
|
629
|
-
/***/ "@rest-hooks/ssr":
|
|
630
|
-
/***/ ((module) => {
|
|
631
|
-
|
|
632
|
-
"use strict";
|
|
633
|
-
module.exports = require("@rest-hooks/ssr");
|
|
634
|
-
|
|
635
|
-
/***/ }),
|
|
636
|
-
|
|
637
|
-
/***/ "history":
|
|
638
|
-
/***/ ((module) => {
|
|
639
|
-
|
|
640
|
-
"use strict";
|
|
641
|
-
module.exports = require("history");
|
|
642
|
-
|
|
643
|
-
/***/ }),
|
|
644
|
-
|
|
645
|
-
/***/ "react":
|
|
646
|
-
/***/ ((module) => {
|
|
647
|
-
|
|
648
|
-
"use strict";
|
|
649
|
-
module.exports = require("react");
|
|
650
|
-
|
|
651
|
-
/***/ }),
|
|
652
|
-
|
|
653
|
-
/***/ "react-dom/server":
|
|
654
|
-
/***/ ((module) => {
|
|
655
|
-
|
|
656
|
-
"use strict";
|
|
657
|
-
module.exports = require("react-dom/server");
|
|
658
|
-
|
|
659
|
-
/***/ }),
|
|
660
|
-
|
|
661
|
-
/***/ "crypto":
|
|
662
|
-
/***/ ((module) => {
|
|
663
|
-
|
|
664
|
-
"use strict";
|
|
665
|
-
module.exports = require("crypto");
|
|
666
|
-
|
|
667
|
-
/***/ }),
|
|
668
|
-
|
|
669
|
-
/***/ "../../node_modules/@babel/runtime/helpers/interopRequireDefault.js":
|
|
670
|
-
/***/ ((module) => {
|
|
671
|
-
|
|
672
|
-
function _interopRequireDefault(obj) {
|
|
673
|
-
return obj && obj.__esModule ? obj : {
|
|
674
|
-
"default": obj
|
|
564
|
+
;// CONCATENATED MODULE: ./src/spouts/prefetch.server.tsx
|
|
565
|
+
function prefetchSpout(field) {
|
|
566
|
+
return function (next) {
|
|
567
|
+
return async props => {
|
|
568
|
+
const nextProps = await next(props);
|
|
569
|
+
try {
|
|
570
|
+
const toFetch = [];
|
|
571
|
+
nextProps.matchedRoutes.forEach(route => {
|
|
572
|
+
if (typeof route.resolveData === 'function') {
|
|
573
|
+
toFetch.push(route.resolveData(nextProps[field], route));
|
|
574
|
+
}
|
|
575
|
+
});
|
|
576
|
+
await Promise.all(toFetch);
|
|
577
|
+
} catch (e) {
|
|
578
|
+
console.error(e);
|
|
579
|
+
}
|
|
580
|
+
return nextProps;
|
|
581
|
+
};
|
|
675
582
|
};
|
|
676
583
|
}
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
/***/ }),
|
|
584
|
+
;// CONCATENATED MODULE: ./src/spouts/json.server.tsx
|
|
585
|
+
var json_server_jsxFileName = "/home/ntucker/src/anansi/packages/core/src/spouts/json.server.tsx";
|
|
680
586
|
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
587
|
+
function JSONSpout({
|
|
588
|
+
id = 'anansi-json'
|
|
589
|
+
} = {}) {
|
|
590
|
+
return next => async props => {
|
|
591
|
+
var _nextProps$scripts, _nextProps$initData;
|
|
592
|
+
const nextProps = await next(props);
|
|
593
|
+
const scripts = (_nextProps$scripts = nextProps.scripts) != null ? _nextProps$scripts : [];
|
|
594
|
+
Object.entries((_nextProps$initData = nextProps.initData) != null ? _nextProps$initData : {}).forEach(([key, useData]) => {
|
|
595
|
+
const globalId = `${id}.${key}`;
|
|
596
|
+
const Script = () => {
|
|
597
|
+
const data = useData();
|
|
598
|
+
try {
|
|
599
|
+
const encoded = JSON.stringify(data);
|
|
600
|
+
return /*#__PURE__*/external_react_default().createElement("script", {
|
|
601
|
+
id: globalId,
|
|
602
|
+
type: "application/json",
|
|
603
|
+
dangerouslySetInnerHTML: {
|
|
604
|
+
__html: encoded
|
|
605
|
+
},
|
|
606
|
+
nonce: props.nonce,
|
|
607
|
+
__self: this,
|
|
608
|
+
__source: {
|
|
609
|
+
fileName: json_server_jsxFileName,
|
|
610
|
+
lineNumber: 29,
|
|
611
|
+
columnNumber: 13
|
|
612
|
+
}
|
|
613
|
+
});
|
|
614
|
+
} catch (e) {
|
|
615
|
+
// TODO: Use unified logging
|
|
616
|
+
console.error(`Error serializing json for ${key}`);
|
|
617
|
+
console.error(e);
|
|
618
|
+
return null;
|
|
619
|
+
}
|
|
620
|
+
};
|
|
621
|
+
scripts.push( /*#__PURE__*/external_react_default().createElement(external_react_namespaceObject.Suspense, {
|
|
622
|
+
key: globalId,
|
|
623
|
+
__self: this,
|
|
624
|
+
__source: {
|
|
625
|
+
fileName: json_server_jsxFileName,
|
|
626
|
+
lineNumber: 46,
|
|
627
|
+
columnNumber: 9
|
|
628
|
+
}
|
|
629
|
+
}, /*#__PURE__*/external_react_default().createElement(Script, {
|
|
630
|
+
__self: this,
|
|
631
|
+
__source: {
|
|
632
|
+
fileName: json_server_jsxFileName,
|
|
633
|
+
lineNumber: 47,
|
|
634
|
+
columnNumber: 11
|
|
635
|
+
}
|
|
636
|
+
})));
|
|
637
|
+
});
|
|
698
638
|
return {
|
|
699
|
-
|
|
639
|
+
...nextProps,
|
|
640
|
+
scripts
|
|
700
641
|
};
|
|
701
|
-
}
|
|
702
|
-
var cache = _getRequireWildcardCache(nodeInterop);
|
|
703
|
-
if (cache && cache.has(obj)) {
|
|
704
|
-
return cache.get(obj);
|
|
705
|
-
}
|
|
706
|
-
var newObj = {};
|
|
707
|
-
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
|
|
708
|
-
for (var key in obj) {
|
|
709
|
-
if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
710
|
-
var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
|
|
711
|
-
if (desc && (desc.get || desc.set)) {
|
|
712
|
-
Object.defineProperty(newObj, key, desc);
|
|
713
|
-
} else {
|
|
714
|
-
newObj[key] = obj[key];
|
|
715
|
-
}
|
|
716
|
-
}
|
|
717
|
-
}
|
|
718
|
-
newObj["default"] = obj;
|
|
719
|
-
if (cache) {
|
|
720
|
-
cache.set(obj, newObj);
|
|
721
|
-
}
|
|
722
|
-
return newObj;
|
|
642
|
+
};
|
|
723
643
|
}
|
|
724
|
-
|
|
644
|
+
;// CONCATENATED MODULE: ./src/spouts/app.server.tsx
|
|
645
|
+
const appSpout = app => props => Promise.resolve({
|
|
646
|
+
...props,
|
|
647
|
+
app
|
|
648
|
+
});
|
|
649
|
+
/* harmony default export */ const app_server = (appSpout);
|
|
650
|
+
;// CONCATENATED MODULE: ./src/index.server.ts
|
|
651
|
+
|
|
652
|
+
|
|
725
653
|
|
|
726
|
-
/***/ }),
|
|
727
654
|
|
|
728
|
-
/***/ "../../node_modules/@babel/runtime/helpers/typeof.js":
|
|
729
|
-
/***/ ((module) => {
|
|
730
655
|
|
|
731
|
-
function _typeof(obj) {
|
|
732
|
-
"@babel/helpers - typeof";
|
|
733
656
|
|
|
734
|
-
return (module.exports = _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) {
|
|
735
|
-
return typeof obj;
|
|
736
|
-
} : function (obj) {
|
|
737
|
-
return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
|
|
738
|
-
}, module.exports.__esModule = true, module.exports["default"] = module.exports), _typeof(obj);
|
|
739
|
-
}
|
|
740
|
-
module.exports = _typeof, module.exports.__esModule = true, module.exports["default"] = module.exports;
|
|
741
657
|
|
|
742
|
-
/***/ })
|
|
743
658
|
|
|
744
|
-
/******/ });
|
|
745
|
-
/************************************************************************/
|
|
746
|
-
/******/ // The module cache
|
|
747
|
-
/******/ var __webpack_module_cache__ = {};
|
|
748
|
-
/******/
|
|
749
|
-
/******/ // The require function
|
|
750
|
-
/******/ function __webpack_require__(moduleId) {
|
|
751
|
-
/******/ // Check if module is in cache
|
|
752
|
-
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
|
753
|
-
/******/ if (cachedModule !== undefined) {
|
|
754
|
-
/******/ return cachedModule.exports;
|
|
755
|
-
/******/ }
|
|
756
|
-
/******/ // Create a new module (and put it into the cache)
|
|
757
|
-
/******/ var module = __webpack_module_cache__[moduleId] = {
|
|
758
|
-
/******/ // no module.id needed
|
|
759
|
-
/******/ // no module.loaded needed
|
|
760
|
-
/******/ exports: {}
|
|
761
|
-
/******/ };
|
|
762
|
-
/******/
|
|
763
|
-
/******/ // Execute the module function
|
|
764
|
-
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
|
765
|
-
/******/
|
|
766
|
-
/******/ // Return the exports of the module
|
|
767
|
-
/******/ return module.exports;
|
|
768
|
-
/******/ }
|
|
769
|
-
/******/
|
|
770
|
-
/************************************************************************/
|
|
771
|
-
var __webpack_exports__ = {};
|
|
772
|
-
// This entry need to be wrapped in an IIFE because it need to be in strict mode.
|
|
773
|
-
(() => {
|
|
774
|
-
"use strict";
|
|
775
|
-
var exports = __webpack_exports__;
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
var _interopRequireDefault = (__webpack_require__("../../node_modules/@babel/runtime/helpers/interopRequireDefault.js")["default"]);
|
|
779
|
-
exports.__esModule = true;
|
|
780
|
-
exports.routerSpout = exports.restHooksSpout = exports.prefetchSpout = exports.laySpouts = exports.documentSpout = exports.appSpout = exports.antdSpout = exports.JSONSpout = void 0;
|
|
781
|
-
var _laySpouts = _interopRequireDefault(__webpack_require__("./src/laySpouts.tsx"));
|
|
782
|
-
exports.laySpouts = _laySpouts.default;
|
|
783
|
-
var _document = _interopRequireDefault(__webpack_require__("./src/spouts/document.server.tsx"));
|
|
784
|
-
exports.documentSpout = _document.default;
|
|
785
|
-
var _restHooks = _interopRequireDefault(__webpack_require__("./src/spouts/restHooks.server.tsx"));
|
|
786
|
-
exports.restHooksSpout = _restHooks.default;
|
|
787
|
-
var _antd = _interopRequireDefault(__webpack_require__("./src/spouts/antd.server.tsx"));
|
|
788
|
-
exports.antdSpout = _antd.default;
|
|
789
|
-
var _router = _interopRequireDefault(__webpack_require__("./src/spouts/router.server.tsx"));
|
|
790
|
-
exports.routerSpout = _router.default;
|
|
791
|
-
var _prefetch = _interopRequireDefault(__webpack_require__("./src/spouts/prefetch.server.tsx"));
|
|
792
|
-
exports.prefetchSpout = _prefetch.default;
|
|
793
|
-
var _json = _interopRequireDefault(__webpack_require__("./src/spouts/json.server.tsx"));
|
|
794
|
-
exports.JSONSpout = _json.default;
|
|
795
|
-
var _app = _interopRequireDefault(__webpack_require__("./src/spouts/app.server.tsx"));
|
|
796
|
-
exports.appSpout = _app.default;
|
|
797
659
|
})();
|
|
798
660
|
|
|
799
661
|
module.exports = __webpack_exports__;
|
|
800
662
|
/******/ })()
|
|
801
663
|
;
|
|
802
|
-
//# sourceMappingURL=server.js.map
|
|
664
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"server.js","mappings":"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","sources":["webpack://@anansi/core/external commonjs \"@rest-hooks/react\"","webpack://@anansi/core/external commonjs \"@rest-hooks/ssr\"","webpack://@anansi/core/external commonjs \"@ant-design/cssinjs\"","webpack://@anansi/core/webpack/bootstrap","webpack://@anansi/core/webpack/runtime/compat get default export","webpack://@anansi/core/webpack/runtime/create fake namespace object","webpack://@anansi/core/webpack/runtime/define property getters","webpack://@anansi/core/webpack/runtime/hasOwnProperty shorthand","webpack://@anansi/core/webpack/runtime/make namespace object","webpack://@anansi/core/external node-commonjs \"crypto\"","webpack://@anansi/core/external commonjs \"react-dom/server\"","webpack://@anansi/core/./src/laySpouts.tsx","webpack://@anansi/core/external commonjs \"react\"","webpack://@anansi/core/./src/spouts/csp.ts","webpack://@anansi/core/./src/spouts/DocumentComponent.tsx","webpack://@anansi/core/./src/spouts/document.server.tsx","webpack://@anansi/core/./src/spouts/restHooks.server.tsx","webpack://@anansi/core/./src/spouts/antd.server.tsx","webpack://@anansi/core/external commonjs \"@anansi/router\"","webpack://@anansi/core/external commonjs \"history\"","webpack://@anansi/core/./src/spouts/router.server.tsx","webpack://@anansi/core/./src/spouts/prefetch.server.tsx","webpack://@anansi/core/./src/spouts/json.server.tsx","webpack://@anansi/core/./src/spouts/app.server.tsx","webpack://@anansi/core/./src/index.server.ts"],"sourcesContent":["module.exports = require(\"@rest-hooks/react\");","module.exports = require(\"@rest-hooks/ssr\");","module.exports = require(\"@ant-design/cssinjs\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key])));\n\t}\n\tdef['default'] = () => (value);\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"react-dom/server\");","import crypto from 'crypto';\nimport { renderToPipeableStream as reactRender } from 'react-dom/server';\n\nimport type { Render } from './scripts/types.js';\nimport type { ServerProps } from './spouts/types.js';\n\nexport default function laySpouts(\n  spouts: (props: ServerProps) => Promise<{\n    app: JSX.Element;\n  }>,\n  {\n    timeoutMS = 10000,\n    onError,\n  }: { timeoutMS?: number; onError?: (error: unknown) => void } = {},\n) {\n  const render: Render = async (clientManifest, req, res) => {\n    const nonce = crypto.randomBytes(16).toString('base64');\n\n    try {\n      const { app } = await spouts({ clientManifest, req, res, nonce });\n\n      let didError = false;\n      const { pipe, abort } = reactRender(app, {\n        nonce,\n        //bootstrapScripts: assets.filter(asset => asset.endsWith('.js')),\n        onShellReady() {\n          //managers.forEach(manager => manager.cleanup());\n          // If something errored before we started streaming, we set the error code appropriately.\n          res.statusCode = didError ? 500 : 200;\n          res.setHeader('Content-type', 'text/html');\n          pipe(res);\n        },\n        onShellError() {\n          didError = true;\n          res.statusCode = 500;\n          pipe(res);\n        },\n        onError(e: any) {\n          didError = true;\n          console.error(e);\n          res.statusCode = 500;\n          //pipe(res); Removing this avoids, \"React currently only supports piping to one writable stream.\"\n          if (onError) onError(e);\n        },\n      });\n      // Abandon and switch to client rendering if enough time passes.\n      // Try lowering this to see the client recover.\n      setTimeout(\n        () => (abort as any)(`Timeout of ${timeoutMS}ms exceeded`),\n        timeoutMS,\n      );\n    } catch (e: unknown) {\n      if (onError) onError(e);\n      throw e;\n    }\n  };\n  return render;\n}\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"react\");","export interface Policy {\n  [directive: string]: string | string[];\n}\n\n// TODO: memoize this\nexport function buildPolicy(policyObj: Policy) {\n  return Object.keys(policyObj)\n    .map(key => {\n      const val = Array.isArray(policyObj[key])\n        ? [...new Set(policyObj[key]).values()].filter(v => v).join(' ')\n        : policyObj[key];\n\n      // move strict dynamic to the end of the policy if it exists to be backwards compatible with csp2\n      // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy/script-src#strict-dynamic\n      if (typeof val === 'string' && val.includes(\"'strict-dynamic'\")) {\n        const newVal = `${val\n          .replace(/\\s?'strict-dynamic'\\s?/gi, ' ')\n          .trim()} 'strict-dynamic'`;\n        return `${key} ${newVal}`;\n      }\n\n      return `${key} ${val}`;\n    })\n    .join('; ');\n}\n","import type { Policy } from './csp.js';\nimport { buildPolicy } from './csp.js';\n\ntype Props = {\n  children: React.ReactNode;\n  assets: { href: string; as?: string; rel?: string }[];\n  head: React.ReactNode;\n  extraStyle: React.ReactNode;\n  scripts: React.ReactNode;\n  title: string;\n  rootId: string;\n  charSet: string;\n  csPolicy?: Policy;\n  nonce?: string | undefined;\n};\n\nexport default function Document({\n  assets,\n  head,\n  children,\n  title,\n  rootId,\n  charSet,\n  csPolicy,\n  nonce,\n  scripts,\n  extraStyle,\n}: Props) {\n  let cspMeta: null | React.ReactNode = null;\n  if (csPolicy) {\n    // add nonce to policy\n    const policy = {\n      ...csPolicy,\n    };\n    if (nonce) {\n      if (typeof policy['script-src'] === 'string') {\n        policy['script-src'] = [policy['script-src'], `'nonce-${nonce}'`];\n      } else {\n        policy['script-src'] = [...policy['script-src'], `'nonce-${nonce}'`];\n      }\n    }\n    cspMeta = (\n      <meta httpEquiv=\"Content-Security-Policy\" content={buildPolicy(policy)} />\n    );\n  }\n  return (\n    <html>\n      <head>\n        <meta charSet={charSet} />\n        {cspMeta}\n        {head}\n        {extraStyle}\n        {assets.map((asset, i) => (\n          <link key={i} rel=\"preload\" {...asset} />\n        ))}\n        <title>{title}</title>\n      </head>\n      <body>\n        <div id={rootId}>{children}</div>\n        {scripts}\n        {assets\n          .filter(({ href }) => href.endsWith('.js'))\n          .map(({ href }, i) => (\n            <script key={i} src={href} async />\n          ))}\n      </body>\n    </html>\n  );\n}\nDocument.defaultProps = {\n  head: (\n    <>\n      <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />\n      <link\n        rel=\"shortcut icon\"\n        href={`${process.env.WEBPACK_PUBLIC_PATH ?? '/'}favicon.ico`}\n      />\n    </>\n  ),\n  charSet: 'utf-8',\n  rootId: 'anansi-root',\n  scripts: null,\n};\n","import type { Route } from '@anansi/router';\nimport { Request } from 'express';\nimport React from 'react';\nimport { StatsChunkGroup } from 'webpack';\n\nimport type { Policy } from './csp.js';\nimport Document from './DocumentComponent.js';\nimport type { ServerSpout } from './types.js';\n\ntype NeededNext = {\n  matchedRoutes: Route<any>[];\n  title?: string;\n  scripts?: React.ReactNode[];\n  extraStyle?: React.ReactNode[];\n};\n\nexport default function DocumentSpout(options: {\n  head?: React.ReactNode;\n  title: string;\n  rootId?: string;\n  charSet?: string;\n  csPolicy?: Policy;\n}): ServerSpout<Record<string, unknown>, Record<string, unknown>, NeededNext> {\n  return next => async props => {\n    const nextProps = await next(props);\n\n    const publicPath = props.clientManifest.publicPath;\n\n    if (\n      Object.keys(props.clientManifest?.entrypoints ?? {}).length < 1 ||\n      publicPath === undefined\n    )\n      throw new Error('Manifest missing entries needed');\n\n    // TODO: consider using this package for build stats in future:\n    // https://github.com/facebook/react/tree/main/packages/react-server-dom-webpack\n    const assetMap = (assets: { name: string; size?: number }[]) =>\n      assets.map(({ name }) => `${publicPath}${name}`);\n\n    const assetList: string[] = [];\n    Object.values(props.clientManifest?.entrypoints ?? {}).forEach(\n      entrypoint => {\n        assetList.push(...assetMap(entrypoint.assets ?? []));\n      },\n    );\n    new Set(\n      assetMap(\n        Object.values(props.clientManifest.namedChunkGroups ?? {})\n          .filter(({ name }) =>\n            nextProps.matchedRoutes.some(route => name?.includes(route.name)),\n          )\n          .flatMap(chunk => [\n            ...(chunk.assets ?? []),\n            // any chunk preloads\n            ...childrenAssets(chunk),\n          ]),\n      ),\n    ).forEach(asset => assetList.push(asset));\n\n    // find additional assets to preload based on matched route\n    const assets: {\n      href: string;\n      as?: string | undefined;\n      rel?: string | undefined;\n    }[] = assetList\n      .filter(asset => !asset.endsWith('.hot-update.js'))\n      .map(asset =>\n        asset.endsWith('.css')\n          ? { href: asset, rel: 'stylesheet' }\n          : asset.endsWith('.js')\n          ? { href: asset, as: 'script' }\n          : { href: asset },\n      );\n    const nonce =\n      // nonces negate 'unsafe-inline' so do not add it in development to keep things easier\n      props.nonce &&\n      (process.env.NODE_ENV === 'production' ||\n        (props.req as Request)?.protocol !== 'http')\n        ? props.nonce\n        : undefined;\n\n    return {\n      ...nextProps,\n      app: (\n        <Document\n          {...options}\n          extraStyle={nextProps.extraStyle}\n          title={nextProps.title ?? options.title}\n          assets={assets}\n          rootId={options.rootId}\n          nonce={nonce}\n          csPolicy={options.csPolicy}\n          scripts={nextProps.scripts}\n        >\n          {nextProps.app}\n        </Document>\n      ),\n    };\n  };\n}\n\nfunction childrenAssets(chunk: StatsChunkGroup) {\n  return chunk.children\n    ? Object.values(chunk.children).flatMap(preload =>\n        preload.flatMap(c => c.assets ?? []),\n      )\n    : [];\n}\n","import { type Controller, type Manager, type State } from '@rest-hooks/react';\nimport type { Store } from 'redux';\n\nimport type { ServerSpout } from './types.js';\n\nexport default function restHooksSpout(\n  options: {\n    getManagers?: () => Manager[];\n  } = {},\n): ServerSpout<\n  Record<string, unknown>,\n  { controller: Controller } & { store: Store<State<unknown>> },\n  { initData?: Record<string, () => unknown>; scripts?: React.ReactNode[] }\n> {\n  return next => async props => {\n    const managers = options?.getManagers?.() ?? [\n      new (await import('@rest-hooks/react')).NetworkManager(),\n    ];\n    const { createPersistedStore } = await import('@rest-hooks/ssr');\n    const [ServerCacheProvider, useReadyCacheState, controller, store] =\n      createPersistedStore(managers);\n\n    const nextProps = await next({\n      ...props,\n      controller,\n      store,\n    });\n    return {\n      ...nextProps,\n      initData: {\n        ...nextProps.initData,\n        resthooks: useReadyCacheState,\n      },\n      app: <ServerCacheProvider>{nextProps.app}</ServerCacheProvider>,\n      // TODO: figure out how to only inject in next and not have to also put here\n      controller,\n      store,\n    };\n  };\n}\n","import React from 'react';\n\nimport type { ServerSpout } from './types.js';\n\ntype NeededNext = {\n  initData?: Record<string, () => unknown>;\n  scripts?: React.ReactNode[];\n  extraStyle?: React.ReactNode[];\n};\n\nexport default function antdSpout(): ServerSpout<\n  Record<string, unknown>,\n  Record<string, unknown>,\n  NeededNext\n> {\n  return next => async props => {\n    const { createCache, extractStyle, StyleProvider } = await import(\n      '@ant-design/cssinjs'\n    );\n    const cache = createCache();\n\n    const nextProps = await next(props);\n\n    const scripts: React.ReactNode[] = nextProps.scripts ?? [];\n\n    const AntdSheets = (): JSX.Element => {\n      return (\n        <script\n          dangerouslySetInnerHTML={{\n            __html: `</script>${extractStyle(cache)}<script>`,\n          }}\n        />\n      );\n    };\n    // unfortunately we have to inject this after the entire content has streamed in or it doesn't correctly populate\n    // see: https://github.com/ant-design/cssinjs/issues/79\n    scripts.push(<AntdSheets />);\n\n    return {\n      ...nextProps,\n      app: <StyleProvider cache={cache}>{nextProps.app}</StyleProvider>,\n      scripts,\n    };\n  };\n}\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"@anansi/router\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"history\");","import { Route, RouteProvider, RouteController } from '@anansi/router';\nimport { createMemoryHistory } from 'history';\nimport React from 'react';\n\nimport type { CreateRouter, ServerSpout } from './types.js';\n\nexport default function routerSpout<ResolveWith>(options: {\n  resolveWith?: any;\n  useResolveWith: () => ResolveWith;\n  createRouter: CreateRouter<ResolveWith>;\n}): ServerSpout<\n  Record<string, unknown>,\n  {\n    matchedRoutes: Route<ResolveWith>[];\n  } & {\n    router: RouteController<Route<ResolveWith, any>>;\n  }\n> {\n  const createRouteComponent = (\n    router: RouteController<Route<ResolveWith, any>>,\n  ) =>\n    function Router({ children }: { children: React.ReactNode }) {\n      const resolveWith = options.useResolveWith();\n\n      return (\n        <RouteProvider router={router} resolveWith={resolveWith}>\n          {children}\n        </RouteProvider>\n      );\n    };\n\n  return next => async props => {\n    const url = props.req.url || '';\n    const router = options.createRouter(\n      createMemoryHistory({ initialEntries: [url] }),\n    );\n    const matchedRoutes: Route<ResolveWith>[] = router.getMatchedRoutes(url);\n\n    const nextProps = await next({\n      ...props,\n      matchedRoutes,\n      router,\n    });\n\n    const Router = createRouteComponent(router);\n\n    return {\n      ...nextProps,\n      app: <Router>{nextProps.app}</Router>,\n      // TODO: figure out how to only inject in next and not have to also put here\n      matchedRoutes,\n      router,\n    };\n  };\n}\n","import { Route } from '@anansi/router';\n\nimport type { ResolveProps, ServerProps } from './types.js';\n\ntype NeededProps<RouteWith> = {\n  matchedRoutes: Route<RouteWith>[];\n} & ResolveProps;\n\nexport default function prefetchSpout<F extends string>(field: F) {\n  return function <\n    RouteWith,\n    N extends NeededProps<RouteWith>,\n    I extends ServerProps,\n  >(\n    next: (props: I) => Promise<\n      {\n        [K in F]: RouteWith;\n      } & N\n    >,\n  ) {\n    return async (props: I) => {\n      const nextProps = await next(props);\n\n      try {\n        const toFetch: Promise<unknown>[] = [];\n        nextProps.matchedRoutes.forEach(route => {\n          if (typeof route.resolveData === 'function') {\n            toFetch.push(route.resolveData(nextProps[field], route));\n          }\n        });\n        await Promise.all(toFetch);\n      } catch (e) {\n        console.error(e);\n      }\n      return nextProps;\n    };\n  };\n}\n","import React, { Suspense } from 'react';\n\nimport type { ServerSpout } from './types.js';\n\ntype NeededNext = {\n  initData?: Record<string, () => unknown>;\n  scripts?: React.ReactNode[];\n};\n\nexport default function JSONSpout({\n  id = 'anansi-json',\n}: { id?: string } = {}): ServerSpout<\n  Record<string, unknown>,\n  Record<string, unknown>,\n  NeededNext\n> {\n  return next => async props => {\n    const nextProps = await next(props);\n\n    const scripts: React.ReactNode[] = nextProps.scripts ?? [];\n\n    Object.entries(nextProps.initData ?? {}).forEach(([key, useData]) => {\n      const globalId = `${id}.${key}`;\n      const Script = () => {\n        const data: any = useData();\n        try {\n          const encoded = JSON.stringify(data);\n          return (\n            <script\n              id={globalId}\n              type=\"application/json\"\n              dangerouslySetInnerHTML={{\n                __html: encoded,\n              }}\n              nonce={props.nonce}\n            />\n          );\n        } catch (e) {\n          // TODO: Use unified logging\n          console.error(`Error serializing json for ${key}`);\n          console.error(e);\n          return null;\n        }\n      };\n      scripts.push(\n        <Suspense key={globalId}>\n          <Script />\n        </Suspense>,\n      );\n    });\n\n    return {\n      ...nextProps,\n      scripts,\n    };\n  };\n}\n","import { ServerProps } from './types.js';\n\nconst appSpout =\n  (app: JSX.Element) =>\n  <P extends ServerProps>(props: P) =>\n    Promise.resolve({ ...props, app });\n\nexport default appSpout;\n","export { default as laySpouts } from './laySpouts.js';\nexport { default as documentSpout } from './spouts/document.server.js';\nexport { default as restHooksSpout } from './spouts/restHooks.server.js';\nexport { default as antdSpout } from './spouts/antd.server.js';\nexport { default as routerSpout } from './spouts/router.server.js';\nexport { default as prefetchSpout } from './spouts/prefetch.server.js';\nexport { default as JSONSpout } from './spouts/json.server.js';\nexport { default as appSpout } from './spouts/app.server.js';\nexport type { ServerProps } from './spouts/types.js';\nexport type { ServerSpout as Spout } from './spouts/types.js';\n"],"names":["crypto","renderToPipeableStream","reactRender","laySpouts","spouts","timeoutMS","onError","render","clientManifest","req","res","nonce","randomBytes","toString","app","didError","pipe","abort","onShellReady","statusCode","setHeader","onShellError","e","console","error","setTimeout","buildPolicy","policyObj","Object","keys","map","key","val","Array","isArray","Set","values","filter","v","join","includes","newVal","replace","trim","Document","assets","head","children","title","rootId","charSet","csPolicy","scripts","extraStyle","cspMeta","policy","React","createElement","httpEquiv","content","__self","__source","fileName","_jsxFileName","lineNumber","columnNumber","asset","i","rel","id","href","endsWith","src","async","defaultProps","Fragment","name","_process$env$WEBPACK_","process","env","WEBPACK_PUBLIC_PATH","DocumentSpout","options","next","props","_props$clientManifest","_props$clientManifest2","_props$clientManifest3","_props$clientManifest4","_props$clientManifest5","_props$req","_nextProps$title","nextProps","publicPath","entrypoints","length","undefined","Error","assetMap","assetList","forEach","entrypoint","_entrypoint$assets","push","namedChunkGroups","matchedRoutes","some","route","flatMap","chunk","_chunk$assets","childrenAssets","as","NODE_ENV","protocol","preload","c","_c$assets","restHooksSpout","_options$getManagers","managers","getManagers","NetworkManager","createPersistedStore","ServerCacheProvider","useReadyCacheState","controller","store","initData","resthooks","antdSpout","_nextProps$scripts","createCache","extractStyle","StyleProvider","cache","AntdSheets","dangerouslySetInnerHTML","__html","RouteProvider","createMemoryHistory","routerSpout","createRouteComponent","router","Router","resolveWith","useResolveWith","url","createRouter","initialEntries","getMatchedRoutes","prefetchSpout","field","toFetch","resolveData","Promise","all","Suspense","JSONSpout","_nextProps$initData","entries","useData","globalId","Script","data","encoded","JSON","stringify","type","appSpout","resolve","default","documentSpout"],"sourceRoot":""}
|