@anansi/core 0.20.15 → 0.20.16

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.
@@ -4,10 +4,9 @@ import Document from './DocumentComponent.js';
4
4
  import { jsx as _jsx } from "react/jsx-runtime";
5
5
  export default function DocumentSpout(options) {
6
6
  return next => async props => {
7
- var _props$clientManifest, _props$clientManifest2, _props$clientManifest3, _props$clientManifest4, _props$clientManifest5, _nextProps$title;
8
7
  const nextProps = await next(props);
9
8
  const publicPath = props.clientManifest.publicPath;
10
- 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');
9
+ if (Object.keys(props.clientManifest?.entrypoints ?? {}).length < 1 || publicPath === undefined) throw new Error('Manifest missing entries needed');
11
10
 
12
11
  // TODO: consider using this package for build stats in future:
13
12
  // https://github.com/facebook/react/tree/main/packages/react-server-dom-webpack
@@ -15,18 +14,14 @@ export default function DocumentSpout(options) {
15
14
  name
16
15
  }) => `${publicPath}${name}`);
17
16
  const assetList = [];
18
- Object.values((_props$clientManifest3 = (_props$clientManifest4 = props.clientManifest) == null ? void 0 : _props$clientManifest4.entrypoints) != null ? _props$clientManifest3 : {}).forEach(entrypoint => {
19
- var _entrypoint$assets;
20
- assetList.push(...assetMap((_entrypoint$assets = entrypoint.assets) != null ? _entrypoint$assets : []));
17
+ Object.values(props.clientManifest?.entrypoints ?? {}).forEach(entrypoint => {
18
+ assetList.push(...assetMap(entrypoint.assets ?? []));
21
19
  });
22
- new Set(assetMap(Object.values((_props$clientManifest5 = props.clientManifest.namedChunkGroups) != null ? _props$clientManifest5 : {}).filter(({
20
+ new Set(assetMap(Object.values(props.clientManifest.namedChunkGroups ?? {}).filter(({
23
21
  name
24
- }) => nextProps.matchedRoutes.some(route => name == null ? void 0 : name.includes(route.name))).flatMap(chunk => {
25
- var _chunk$assets;
26
- return [...((_chunk$assets = chunk.assets) != null ? _chunk$assets : []),
27
- // any chunk preloads
28
- ...childrenAssets(chunk)];
29
- }))).forEach(asset => assetList.push(asset));
22
+ }) => nextProps.matchedRoutes.some(route => name?.includes(route.name))).flatMap(chunk => [...(chunk.assets ?? []),
23
+ // any chunk preloads
24
+ ...childrenAssets(chunk)]))).forEach(asset => assetList.push(asset));
30
25
 
31
26
  // find additional assets to preload based on matched route
32
27
  const assets = assetList.filter(asset => !asset.endsWith('.hot-update.js')).map(asset => asset.endsWith('.css') ? {
@@ -47,7 +42,7 @@ export default function DocumentSpout(options) {
47
42
  app: /*#__PURE__*/_jsx(Document, {
48
43
  ...options,
49
44
  extraStyle: nextProps.extraStyle,
50
- title: (_nextProps$title = nextProps.title) != null ? _nextProps$title : options.title,
45
+ title: nextProps.title ?? options.title,
51
46
  assets: assets,
52
47
  rootId: options.rootId,
53
48
  scripts: nextProps.scripts,
@@ -57,9 +52,6 @@ export default function DocumentSpout(options) {
57
52
  };
58
53
  }
59
54
  function childrenAssets(chunk) {
60
- return chunk.children ? Object.values(chunk.children).flatMap(preload => preload.flatMap(c => {
61
- var _c$assets;
62
- return (_c$assets = c.assets) != null ? _c$assets : [];
63
- })) : [];
55
+ return chunk.children ? Object.values(chunk.children).flatMap(preload => preload.flatMap(c => c.assets ?? [])) : [];
64
56
  }
65
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","buildPolicy","joinNonce","Document","jsx","_jsx","DocumentSpout","options","next","props","_props$clientManifest","_props$clientManifest2","_props$clientManifest3","_props$clientManifest4","_props$clientManifest5","_nextProps$title","nextProps","publicPath","clientManifest","Object","keys","entrypoints","length","undefined","Error","assetMap","assets","map","name","assetList","values","forEach","entrypoint","_entrypoint$assets","push","Set","namedChunkGroups","filter","matchedRoutes","some","route","includes","flatMap","chunk","_chunk$assets","childrenAssets","asset","endsWith","href","rel","as","csPolicy","httpEquiv","process","env","NODE_ENV","res","setHeader","nonce","app","extraStyle","title","rootId","scripts","children","preload","c","_c$assets"],"sources":["../../../src/spouts/document.server.tsx"],"sourcesContent":["import type { Route } from '@anansi/router';\nimport { Request } from 'express';\nimport React from 'react';\nimport { StatsChunkGroup } from 'webpack';\n\nimport { buildPolicy, joinNonce, 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  lang?: 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') ? { href: asset, rel: 'stylesheet' }\n        : asset.endsWith('.js') ? { href: asset, as: 'script' }\n        : { href: asset },\n      );\n\n    if (options.csPolicy) {\n      const httpEquiv =\n        process.env.NODE_ENV === 'production' ?\n          'Content-Security-Policy'\n        : 'Content-Security-Policy-Report-Only';\n\n      props.res.setHeader(\n        httpEquiv,\n        buildPolicy(joinNonce(options.csPolicy, props.nonce)),\n      );\n    }\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          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"],"mappings":"AAEA,OAAOA,KAAK,MAAM,OAAO;AAGzB,SAASC,WAAW,EAAEC,SAAS,QAAgB,UAAU;AACzD,OAAOC,QAAQ,MAAM,wBAAwB;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAU9C,eAAe,SAASC,aAAaA,CAACC,OAOrC,EAA6E;EAC5E,OAAOC,IAAI,IAAI,MAAMC,KAAK,IAAI;IAAA,IAAAC,qBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,gBAAA;IAC5B,MAAMC,SAAS,GAAG,MAAMR,IAAI,CAACC,KAAK,CAAC;IAEnC,MAAMQ,UAAU,GAAGR,KAAK,CAACS,cAAc,CAACD,UAAU;IAElD,IACEE,MAAM,CAACC,IAAI,EAAAV,qBAAA,IAAAC,sBAAA,GAACF,KAAK,CAACS,cAAc,qBAApBP,sBAAA,CAAsBU,WAAW,YAAAX,qBAAA,GAAI,CAAC,CAAC,CAAC,CAACY,MAAM,GAAG,CAAC,IAC/DL,UAAU,KAAKM,SAAS,EAExB,MAAM,IAAIC,KAAK,CAAC,iCAAiC,CAAC;;IAEpD;IACA;IACA,MAAMC,QAAQ,GAAIC,MAAyC,IACzDA,MAAM,CAACC,GAAG,CAAC,CAAC;MAAEC;IAAK,CAAC,KAAK,GAAGX,UAAU,GAAGW,IAAI,EAAE,CAAC;IAElD,MAAMC,SAAmB,GAAG,EAAE;IAC9BV,MAAM,CAACW,MAAM,EAAAlB,sBAAA,IAAAC,sBAAA,GAACJ,KAAK,CAACS,cAAc,qBAApBL,sBAAA,CAAsBQ,WAAW,YAAAT,sBAAA,GAAI,CAAC,CAAC,CAAC,CAACmB,OAAO,CAC5DC,UAAU,IAAI;MAAA,IAAAC,kBAAA;MACZJ,SAAS,CAACK,IAAI,CAAC,GAAGT,QAAQ,EAAAQ,kBAAA,GAACD,UAAU,CAACN,MAAM,YAAAO,kBAAA,GAAI,EAAE,CAAC,CAAC;IACtD,CACF,CAAC;IACD,IAAIE,GAAG,CACLV,QAAQ,CACNN,MAAM,CAACW,MAAM,EAAAhB,sBAAA,GAACL,KAAK,CAACS,cAAc,CAACkB,gBAAgB,YAAAtB,sBAAA,GAAI,CAAC,CAAC,CAAC,CACvDuB,MAAM,CAAC,CAAC;MAAET;IAAK,CAAC,KACfZ,SAAS,CAACsB,aAAa,CAACC,IAAI,CAACC,KAAK,IAAIZ,IAAI,oBAAJA,IAAI,CAAEa,QAAQ,CAACD,KAAK,CAACZ,IAAI,CAAC,CAClE,CAAC,CACAc,OAAO,CAACC,KAAK;MAAA,IAAAC,aAAA;MAAA,OAAI,CAChB,KAAAA,aAAA,GAAID,KAAK,CAACjB,MAAM,YAAAkB,aAAA,GAAI,EAAE,CAAC;MACvB;MACA,GAAGC,cAAc,CAACF,KAAK,CAAC,CACzB;IAAA,EACL,CACF,CAAC,CAACZ,OAAO,CAACe,KAAK,IAAIjB,SAAS,CAACK,IAAI,CAACY,KAAK,CAAC,CAAC;;IAEzC;IACA,MAAMpB,MAIH,GAAGG,SAAS,CACZQ,MAAM,CAACS,KAAK,IAAI,CAACA,KAAK,CAACC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAClDpB,GAAG,CAACmB,KAAK,IACRA,KAAK,CAACC,QAAQ,CAAC,MAAM,CAAC,GAAG;MAAEC,IAAI,EAAEF,KAAK;MAAEG,GAAG,EAAE;IAAa,CAAC,GACzDH,KAAK,CAACC,QAAQ,CAAC,KAAK,CAAC,GAAG;MAAEC,IAAI,EAAEF,KAAK;MAAEI,EAAE,EAAE;IAAS,CAAC,GACrD;MAAEF,IAAI,EAAEF;IAAM,CAClB,CAAC;IAEH,IAAIvC,OAAO,CAAC4C,QAAQ,EAAE;MACpB,MAAMC,SAAS,GACbC,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,GACnC,yBAAyB,GACzB,qCAAqC;MAEzC9C,KAAK,CAAC+C,GAAG,CAACC,SAAS,CACjBL,SAAS,EACTnD,WAAW,CAACC,SAAS,CAACK,OAAO,CAAC4C,QAAQ,EAAE1C,KAAK,CAACiD,KAAK,CAAC,CACtD,CAAC;IACH;IAEA,OAAO;MACL,GAAG1C,SAAS;MACZ2C,GAAG,eACDtD,IAAA,CAACF,QAAQ;QAAA,GACHI,OAAO;QACXqD,UAAU,EAAE5C,SAAS,CAAC4C,UAAW;QACjCC,KAAK,GAAA9C,gBAAA,GAAEC,SAAS,CAAC6C,KAAK,YAAA9C,gBAAA,GAAIR,OAAO,CAACsD,KAAM;QACxCnC,MAAM,EAAEA,MAAO;QACfoC,MAAM,EAAEvD,OAAO,CAACuD,MAAO;QACvBC,OAAO,EAAE/C,SAAS,CAAC+C,OAAQ;QAAAC,QAAA,EAE1BhD,SAAS,CAAC2C;MAAG,CACN;IAEd,CAAC;EACH,CAAC;AACH;AAEA,SAASd,cAAcA,CAACF,KAAsB,EAAE;EAC9C,OAAOA,KAAK,CAACqB,QAAQ,GACjB7C,MAAM,CAACW,MAAM,CAACa,KAAK,CAACqB,QAAQ,CAAC,CAACtB,OAAO,CAACuB,OAAO,IAC3CA,OAAO,CAACvB,OAAO,CAACwB,CAAC;IAAA,IAAAC,SAAA;IAAA,QAAAA,SAAA,GAAID,CAAC,CAACxC,MAAM,YAAAyC,SAAA,GAAI,EAAE;EAAA,EACrC,CAAC,GACD,EAAE;AACR","ignoreList":[]}
57
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","buildPolicy","joinNonce","Document","jsx","_jsx","DocumentSpout","options","next","props","nextProps","publicPath","clientManifest","Object","keys","entrypoints","length","undefined","Error","assetMap","assets","map","name","assetList","values","forEach","entrypoint","push","Set","namedChunkGroups","filter","matchedRoutes","some","route","includes","flatMap","chunk","childrenAssets","asset","endsWith","href","rel","as","csPolicy","httpEquiv","process","env","NODE_ENV","res","setHeader","nonce","app","extraStyle","title","rootId","scripts","children","preload","c"],"sources":["../../../src/spouts/document.server.tsx"],"sourcesContent":["import type { Route } from '@anansi/router';\nimport { Request } from 'express';\nimport React from 'react';\nimport { StatsChunkGroup } from 'webpack';\n\nimport { buildPolicy, joinNonce, 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  lang?: 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') ? { href: asset, rel: 'stylesheet' }\n        : asset.endsWith('.js') ? { href: asset, as: 'script' }\n        : { href: asset },\n      );\n\n    if (options.csPolicy) {\n      const httpEquiv =\n        process.env.NODE_ENV === 'production' ?\n          'Content-Security-Policy'\n        : 'Content-Security-Policy-Report-Only';\n\n      props.res.setHeader(\n        httpEquiv,\n        buildPolicy(joinNonce(options.csPolicy, props.nonce)),\n      );\n    }\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          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"],"mappings":"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","ignoreList":[]}
@@ -29,6 +29,6 @@ function getDataFromEl(el, key) {
29
29
  if (el.text === undefined) {
30
30
  console.error(`#${key} is completely empty. This could be due to CSP issues.`);
31
31
  }
32
- return el != null && el.text ? JSON.parse(el == null ? void 0 : el.text) : undefined;
32
+ return el?.text ? JSON.parse(el?.text) : undefined;
33
33
  }
34
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJKU09OU3BvdXQiLCJpZCIsIm5leHQiLCJwcm9wcyIsImdldEluaXRpYWxEYXRhIiwia2V5IiwiZ2xvYmFsSWQiLCJQcm9taXNlIiwicmVzb2x2ZSIsInJlamVjdCIsImVsIiwiZG9jdW1lbnQiLCJnZXRFbGVtZW50QnlJZCIsImdldERhdGFGcm9tRWwiLCJhZGRFdmVudExpc3RlbmVyIiwiRXJyb3IiLCJ0ZXh0IiwidW5kZWZpbmVkIiwiY29uc29sZSIsImVycm9yIiwiSlNPTiIsInBhcnNlIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Nwb3V0cy9qc29uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENsaWVudFNwb3V0IH0gZnJvbSAnLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIEpTT05TcG91dCh7XG4gIGlkID0gJ2FuYW5zaS1qc29uJyxcbn06IHsgaWQ/OiBzdHJpbmcgfSA9IHt9KTogQ2xpZW50U3BvdXQ8XG4gIFJlY29yZDxzdHJpbmcsIHVua25vd24+LFxuICB7IGdldEluaXRpYWxEYXRhOiAoa2V5OiBzdHJpbmcpID0+IFByb21pc2U8YW55PiB9XG4+IHtcbiAgcmV0dXJuIG5leHQgPT4gYXN5bmMgcHJvcHMgPT4ge1xuICAgIGNvbnN0IGdldEluaXRpYWxEYXRhID0gKGtleTogc3RyaW5nKSA9PiB7XG4gICAgICBjb25zdCBnbG9iYWxJZCA9IGAke2lkfS4ke2tleX1gO1xuICAgICAgcmV0dXJuIG5ldyBQcm9taXNlPGFueT4oKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgICBsZXQgZWw6IEhUTUxTY3JpcHRFbGVtZW50IHwgbnVsbDtcbiAgICAgICAgaWYgKChlbCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKGdsb2JhbElkKSBhcyBhbnkpKSB7XG4gICAgICAgICAgcmVzb2x2ZShnZXREYXRhRnJvbUVsKGVsLCBnbG9iYWxJZCkpO1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBkb2N1bWVudC5hZGRFdmVudExpc3RlbmVyKCdET01Db250ZW50TG9hZGVkJywgKCkgPT4ge1xuICAgICAgICAgIGVsID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoZ2xvYmFsSWQpIGFzIGFueTtcbiAgICAgICAgICBpZiAoZWwpIHJlc29sdmUoZ2V0RGF0YUZyb21FbChlbCwgZ2xvYmFsSWQpKTtcbiAgICAgICAgICBlbHNlIHJlamVjdChuZXcgRXJyb3IoYGZhaWxlZCB0byBmaW5kIERPTSB3aXRoICR7a2V5fSBzdGF0ZWApKTtcbiAgICAgICAgfSk7XG4gICAgICB9KTtcbiAgICB9O1xuICAgIHJldHVybiB7IC4uLihhd2FpdCBuZXh0KHsgLi4ucHJvcHMsIGdldEluaXRpYWxEYXRhIH0pKSwgZ2V0SW5pdGlhbERhdGEgfTtcbiAgfTtcbn1cblxuZnVuY3Rpb24gZ2V0RGF0YUZyb21FbChlbDogSFRNTFNjcmlwdEVsZW1lbnQsIGtleTogc3RyaW5nKSB7XG4gIGlmIChlbC50ZXh0ID09PSB1bmRlZmluZWQpIHtcbiAgICBjb25zb2xlLmVycm9yKFxuICAgICAgYCMke2tleX0gaXMgY29tcGxldGVseSBlbXB0eS4gVGhpcyBjb3VsZCBiZSBkdWUgdG8gQ1NQIGlzc3Vlcy5gLFxuICAgICk7XG4gIH1cbiAgcmV0dXJuIGVsPy50ZXh0ID8gSlNPTi5wYXJzZShlbD8udGV4dCkgOiB1bmRlZmluZWQ7XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLGVBQWUsU0FBU0EsU0FBU0EsQ0FBQztFQUNoQ0MsRUFBRSxHQUFHO0FBQ1UsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUdyQjtFQUNBLE9BQU9DLElBQUksSUFBSSxNQUFNQyxLQUFLLElBQUk7SUFDNUIsTUFBTUMsY0FBYyxHQUFJQyxHQUFXLElBQUs7TUFDdEMsTUFBTUMsUUFBUSxHQUFHLEdBQUdMLEVBQUUsSUFBSUksR0FBRyxFQUFFO01BQy9CLE9BQU8sSUFBSUUsT0FBTyxDQUFNLENBQUNDLE9BQU8sRUFBRUMsTUFBTSxLQUFLO1FBQzNDLElBQUlDLEVBQTRCO1FBQ2hDLElBQUtBLEVBQUUsR0FBR0MsUUFBUSxDQUFDQyxjQUFjLENBQUNOLFFBQVEsQ0FBUSxFQUFHO1VBQ25ERSxPQUFPLENBQUNLLGFBQWEsQ0FBQ0gsRUFBRSxFQUFFSixRQUFRLENBQUMsQ0FBQztVQUNwQztRQUNGO1FBQ0FLLFFBQVEsQ0FBQ0csZ0JBQWdCLENBQUMsa0JBQWtCLEVBQUUsTUFBTTtVQUNsREosRUFBRSxHQUFHQyxRQUFRLENBQUNDLGNBQWMsQ0FBQ04sUUFBUSxDQUFRO1VBQzdDLElBQUlJLEVBQUUsRUFBRUYsT0FBTyxDQUFDSyxhQUFhLENBQUNILEVBQUUsRUFBRUosUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUN4Q0csTUFBTSxDQUFDLElBQUlNLEtBQUssQ0FBQywyQkFBMkJWLEdBQUcsUUFBUSxDQUFDLENBQUM7UUFDaEUsQ0FBQyxDQUFDO01BQ0osQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQUNELE9BQU87TUFBRSxJQUFJLE1BQU1ILElBQUksQ0FBQztRQUFFLEdBQUdDLEtBQUs7UUFBRUM7TUFBZSxDQUFDLENBQUMsQ0FBQztNQUFFQTtJQUFlLENBQUM7RUFDMUUsQ0FBQztBQUNIO0FBRUEsU0FBU1MsYUFBYUEsQ0FBQ0gsRUFBcUIsRUFBRUwsR0FBVyxFQUFFO0VBQ3pELElBQUlLLEVBQUUsQ0FBQ00sSUFBSSxLQUFLQyxTQUFTLEVBQUU7SUFDekJDLE9BQU8sQ0FBQ0MsS0FBSyxDQUNYLElBQUlkLEdBQUcsd0RBQ1QsQ0FBQztFQUNIO0VBQ0EsT0FBT0ssRUFBRSxZQUFGQSxFQUFFLENBQUVNLElBQUksR0FBR0ksSUFBSSxDQUFDQyxLQUFLLENBQUNYLEVBQUUsb0JBQUZBLEVBQUUsQ0FBRU0sSUFBSSxDQUFDLEdBQUdDLFNBQVM7QUFDcEQiLCJpZ25vcmVMaXN0IjpbXX0=
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJKU09OU3BvdXQiLCJpZCIsIm5leHQiLCJwcm9wcyIsImdldEluaXRpYWxEYXRhIiwia2V5IiwiZ2xvYmFsSWQiLCJQcm9taXNlIiwicmVzb2x2ZSIsInJlamVjdCIsImVsIiwiZG9jdW1lbnQiLCJnZXRFbGVtZW50QnlJZCIsImdldERhdGFGcm9tRWwiLCJhZGRFdmVudExpc3RlbmVyIiwiRXJyb3IiLCJ0ZXh0IiwidW5kZWZpbmVkIiwiY29uc29sZSIsImVycm9yIiwiSlNPTiIsInBhcnNlIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Nwb3V0cy9qc29uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENsaWVudFNwb3V0IH0gZnJvbSAnLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIEpTT05TcG91dCh7XG4gIGlkID0gJ2FuYW5zaS1qc29uJyxcbn06IHsgaWQ/OiBzdHJpbmcgfSA9IHt9KTogQ2xpZW50U3BvdXQ8XG4gIFJlY29yZDxzdHJpbmcsIHVua25vd24+LFxuICB7IGdldEluaXRpYWxEYXRhOiAoa2V5OiBzdHJpbmcpID0+IFByb21pc2U8YW55PiB9XG4+IHtcbiAgcmV0dXJuIG5leHQgPT4gYXN5bmMgcHJvcHMgPT4ge1xuICAgIGNvbnN0IGdldEluaXRpYWxEYXRhID0gKGtleTogc3RyaW5nKSA9PiB7XG4gICAgICBjb25zdCBnbG9iYWxJZCA9IGAke2lkfS4ke2tleX1gO1xuICAgICAgcmV0dXJuIG5ldyBQcm9taXNlPGFueT4oKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgICBsZXQgZWw6IEhUTUxTY3JpcHRFbGVtZW50IHwgbnVsbDtcbiAgICAgICAgaWYgKChlbCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKGdsb2JhbElkKSBhcyBhbnkpKSB7XG4gICAgICAgICAgcmVzb2x2ZShnZXREYXRhRnJvbUVsKGVsLCBnbG9iYWxJZCkpO1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBkb2N1bWVudC5hZGRFdmVudExpc3RlbmVyKCdET01Db250ZW50TG9hZGVkJywgKCkgPT4ge1xuICAgICAgICAgIGVsID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoZ2xvYmFsSWQpIGFzIGFueTtcbiAgICAgICAgICBpZiAoZWwpIHJlc29sdmUoZ2V0RGF0YUZyb21FbChlbCwgZ2xvYmFsSWQpKTtcbiAgICAgICAgICBlbHNlIHJlamVjdChuZXcgRXJyb3IoYGZhaWxlZCB0byBmaW5kIERPTSB3aXRoICR7a2V5fSBzdGF0ZWApKTtcbiAgICAgICAgfSk7XG4gICAgICB9KTtcbiAgICB9O1xuICAgIHJldHVybiB7IC4uLihhd2FpdCBuZXh0KHsgLi4ucHJvcHMsIGdldEluaXRpYWxEYXRhIH0pKSwgZ2V0SW5pdGlhbERhdGEgfTtcbiAgfTtcbn1cblxuZnVuY3Rpb24gZ2V0RGF0YUZyb21FbChlbDogSFRNTFNjcmlwdEVsZW1lbnQsIGtleTogc3RyaW5nKSB7XG4gIGlmIChlbC50ZXh0ID09PSB1bmRlZmluZWQpIHtcbiAgICBjb25zb2xlLmVycm9yKFxuICAgICAgYCMke2tleX0gaXMgY29tcGxldGVseSBlbXB0eS4gVGhpcyBjb3VsZCBiZSBkdWUgdG8gQ1NQIGlzc3Vlcy5gLFxuICAgICk7XG4gIH1cbiAgcmV0dXJuIGVsPy50ZXh0ID8gSlNPTi5wYXJzZShlbD8udGV4dCkgOiB1bmRlZmluZWQ7XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLGVBQWUsU0FBU0EsU0FBU0EsQ0FBQztFQUNoQ0MsRUFBRSxHQUFHO0FBQ1UsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUdyQjtFQUNBLE9BQU9DLElBQUksSUFBSSxNQUFNQyxLQUFLLElBQUk7SUFDNUIsTUFBTUMsY0FBYyxHQUFJQyxHQUFXLElBQUs7TUFDdEMsTUFBTUMsUUFBUSxHQUFHLEdBQUdMLEVBQUUsSUFBSUksR0FBRyxFQUFFO01BQy9CLE9BQU8sSUFBSUUsT0FBTyxDQUFNLENBQUNDLE9BQU8sRUFBRUMsTUFBTSxLQUFLO1FBQzNDLElBQUlDLEVBQTRCO1FBQ2hDLElBQUtBLEVBQUUsR0FBR0MsUUFBUSxDQUFDQyxjQUFjLENBQUNOLFFBQVEsQ0FBUSxFQUFHO1VBQ25ERSxPQUFPLENBQUNLLGFBQWEsQ0FBQ0gsRUFBRSxFQUFFSixRQUFRLENBQUMsQ0FBQztVQUNwQztRQUNGO1FBQ0FLLFFBQVEsQ0FBQ0csZ0JBQWdCLENBQUMsa0JBQWtCLEVBQUUsTUFBTTtVQUNsREosRUFBRSxHQUFHQyxRQUFRLENBQUNDLGNBQWMsQ0FBQ04sUUFBUSxDQUFRO1VBQzdDLElBQUlJLEVBQUUsRUFBRUYsT0FBTyxDQUFDSyxhQUFhLENBQUNILEVBQUUsRUFBRUosUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUN4Q0csTUFBTSxDQUFDLElBQUlNLEtBQUssQ0FBQywyQkFBMkJWLEdBQUcsUUFBUSxDQUFDLENBQUM7UUFDaEUsQ0FBQyxDQUFDO01BQ0osQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQUNELE9BQU87TUFBRSxJQUFJLE1BQU1ILElBQUksQ0FBQztRQUFFLEdBQUdDLEtBQUs7UUFBRUM7TUFBZSxDQUFDLENBQUMsQ0FBQztNQUFFQTtJQUFlLENBQUM7RUFDMUUsQ0FBQztBQUNIO0FBRUEsU0FBU1MsYUFBYUEsQ0FBQ0gsRUFBcUIsRUFBRUwsR0FBVyxFQUFFO0VBQ3pELElBQUlLLEVBQUUsQ0FBQ00sSUFBSSxLQUFLQyxTQUFTLEVBQUU7SUFDekJDLE9BQU8sQ0FBQ0MsS0FBSyxDQUNYLElBQUlkLEdBQUcsd0RBQ1QsQ0FBQztFQUNIO0VBQ0EsT0FBT0ssRUFBRSxFQUFFTSxJQUFJLEdBQUdJLElBQUksQ0FBQ0MsS0FBSyxDQUFDWCxFQUFFLEVBQUVNLElBQUksQ0FBQyxHQUFHQyxTQUFTO0FBQ3BEIiwiaWdub3JlTGlzdCI6W119
@@ -4,10 +4,9 @@ export default function JSONSpout({
4
4
  id = 'anansi-json'
5
5
  } = {}) {
6
6
  return next => async props => {
7
- var _nextProps$scripts, _nextProps$initData;
8
7
  const nextProps = await next(props);
9
- const scripts = (_nextProps$scripts = nextProps.scripts) != null ? _nextProps$scripts : [];
10
- Object.entries((_nextProps$initData = nextProps.initData) != null ? _nextProps$initData : {}).forEach(([key, useData]) => {
8
+ const scripts = nextProps.scripts ?? [];
9
+ Object.entries(nextProps.initData ?? {}).forEach(([key, useData]) => {
11
10
  const globalId = `${id}.${key}`;
12
11
  const Script = () => {
13
12
  const data = useData();
@@ -38,4 +37,4 @@ export default function JSONSpout({
38
37
  };
39
38
  };
40
39
  }
41
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsIlN1c3BlbnNlIiwianN4IiwiX2pzeCIsIkpTT05TcG91dCIsImlkIiwibmV4dCIsInByb3BzIiwiX25leHRQcm9wcyRzY3JpcHRzIiwiX25leHRQcm9wcyRpbml0RGF0YSIsIm5leHRQcm9wcyIsInNjcmlwdHMiLCJPYmplY3QiLCJlbnRyaWVzIiwiaW5pdERhdGEiLCJmb3JFYWNoIiwia2V5IiwidXNlRGF0YSIsImdsb2JhbElkIiwiU2NyaXB0IiwiZGF0YSIsImVuY29kZWQiLCJKU09OIiwic3RyaW5naWZ5IiwidHlwZSIsImRhbmdlcm91c2x5U2V0SW5uZXJIVE1MIiwiX19odG1sIiwibm9uY2UiLCJlIiwiY29uc29sZSIsImVycm9yIiwicHVzaCIsImNoaWxkcmVuIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Nwb3V0cy9qc29uLnNlcnZlci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IFN1c3BlbnNlIH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgdHlwZSB7IFNlcnZlclNwb3V0IH0gZnJvbSAnLi90eXBlcy5qcyc7XG5cbnR5cGUgTmVlZGVkTmV4dCA9IHtcbiAgaW5pdERhdGE/OiBSZWNvcmQ8c3RyaW5nLCAoKSA9PiB1bmtub3duPjtcbiAgc2NyaXB0cz86IFJlYWN0LlJlYWN0Tm9kZVtdO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gSlNPTlNwb3V0KHtcbiAgaWQgPSAnYW5hbnNpLWpzb24nLFxufTogeyBpZD86IHN0cmluZyB9ID0ge30pOiBTZXJ2ZXJTcG91dDxcbiAgUmVjb3JkPHN0cmluZywgdW5rbm93bj4sXG4gIFJlY29yZDxzdHJpbmcsIHVua25vd24+LFxuICBOZWVkZWROZXh0XG4+IHtcbiAgcmV0dXJuIG5leHQgPT4gYXN5bmMgcHJvcHMgPT4ge1xuICAgIGNvbnN0IG5leHRQcm9wcyA9IGF3YWl0IG5leHQocHJvcHMpO1xuXG4gICAgY29uc3Qgc2NyaXB0czogUmVhY3QuUmVhY3ROb2RlW10gPSBuZXh0UHJvcHMuc2NyaXB0cyA/PyBbXTtcblxuICAgIE9iamVjdC5lbnRyaWVzKG5leHRQcm9wcy5pbml0RGF0YSA/PyB7fSkuZm9yRWFjaCgoW2tleSwgdXNlRGF0YV0pID0+IHtcbiAgICAgIGNvbnN0IGdsb2JhbElkID0gYCR7aWR9LiR7a2V5fWA7XG4gICAgICBjb25zdCBTY3JpcHQgPSAoKSA9PiB7XG4gICAgICAgIGNvbnN0IGRhdGE6IGFueSA9IHVzZURhdGEoKTtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBjb25zdCBlbmNvZGVkID0gSlNPTi5zdHJpbmdpZnkoZGF0YSk7XG4gICAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICAgIDxzY3JpcHRcbiAgICAgICAgICAgICAgaWQ9e2dsb2JhbElkfVxuICAgICAgICAgICAgICB0eXBlPVwiYXBwbGljYXRpb24vanNvblwiXG4gICAgICAgICAgICAgIGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7XG4gICAgICAgICAgICAgICAgX19odG1sOiBlbmNvZGVkLFxuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICBub25jZT17cHJvcHMubm9uY2V9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICk7XG4gICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAvLyBUT0RPOiBVc2UgdW5pZmllZCBsb2dnaW5nXG4gICAgICAgICAgY29uc29sZS5lcnJvcihgRXJyb3Igc2VyaWFsaXppbmcganNvbiBmb3IgJHtrZXl9YCk7XG4gICAgICAgICAgY29uc29sZS5lcnJvcihlKTtcbiAgICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgICAgfVxuICAgICAgfTtcbiAgICAgIHNjcmlwdHMucHVzaChcbiAgICAgICAgPFN1c3BlbnNlIGtleT17Z2xvYmFsSWR9PlxuICAgICAgICAgIDxTY3JpcHQgLz5cbiAgICAgICAgPC9TdXNwZW5zZT4sXG4gICAgICApO1xuICAgIH0pO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLm5leHRQcm9wcyxcbiAgICAgIHNjcmlwdHMsXG4gICAgfTtcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsS0FBSyxJQUFJQyxRQUFRLFFBQVEsT0FBTztBQUFDLFNBQUFDLEdBQUEsSUFBQUMsSUFBQTtBQVN4QyxlQUFlLFNBQVNDLFNBQVNBLENBQUM7RUFDaENDLEVBQUUsR0FBRztBQUNVLENBQUMsR0FBRyxDQUFDLENBQUMsRUFJckI7RUFDQSxPQUFPQyxJQUFJLElBQUksTUFBTUMsS0FBSyxJQUFJO0lBQUEsSUFBQUMsa0JBQUEsRUFBQUMsbUJBQUE7SUFDNUIsTUFBTUMsU0FBUyxHQUFHLE1BQU1KLElBQUksQ0FBQ0MsS0FBSyxDQUFDO0lBRW5DLE1BQU1JLE9BQTBCLElBQUFILGtCQUFBLEdBQUdFLFNBQVMsQ0FBQ0MsT0FBTyxZQUFBSCxrQkFBQSxHQUFJLEVBQUU7SUFFMURJLE1BQU0sQ0FBQ0MsT0FBTyxFQUFBSixtQkFBQSxHQUFDQyxTQUFTLENBQUNJLFFBQVEsWUFBQUwsbUJBQUEsR0FBSSxDQUFDLENBQUMsQ0FBQyxDQUFDTSxPQUFPLENBQUMsQ0FBQyxDQUFDQyxHQUFHLEVBQUVDLE9BQU8sQ0FBQyxLQUFLO01BQ25FLE1BQU1DLFFBQVEsR0FBRyxHQUFHYixFQUFFLElBQUlXLEdBQUcsRUFBRTtNQUMvQixNQUFNRyxNQUFNLEdBQUdBLENBQUEsS0FBTTtRQUNuQixNQUFNQyxJQUFTLEdBQUdILE9BQU8sQ0FBQyxDQUFDO1FBQzNCLElBQUk7VUFDRixNQUFNSSxPQUFPLEdBQUdDLElBQUksQ0FBQ0MsU0FBUyxDQUFDSCxJQUFJLENBQUM7VUFDcEMsb0JBQ0VqQixJQUFBO1lBQ0VFLEVBQUUsRUFBRWEsUUFBUztZQUNiTSxJQUFJLEVBQUMsa0JBQWtCO1lBQ3ZCQyx1QkFBdUIsRUFBRTtjQUN2QkMsTUFBTSxFQUFFTDtZQUNWLENBQUU7WUFDRk0sS0FBSyxFQUFFcEIsS0FBSyxDQUFDb0I7VUFBTSxDQUNwQixDQUFDO1FBRU4sQ0FBQyxDQUFDLE9BQU9DLENBQUMsRUFBRTtVQUNWO1VBQ0FDLE9BQU8sQ0FBQ0MsS0FBSyxDQUFDLDhCQUE4QmQsR0FBRyxFQUFFLENBQUM7VUFDbERhLE9BQU8sQ0FBQ0MsS0FBSyxDQUFDRixDQUFDLENBQUM7VUFDaEIsT0FBTyxJQUFJO1FBQ2I7TUFDRixDQUFDO01BQ0RqQixPQUFPLENBQUNvQixJQUFJLGNBQ1Y1QixJQUFBLENBQUNGLFFBQVE7UUFBQStCLFFBQUEsZUFDUDdCLElBQUEsQ0FBQ2dCLE1BQU0sSUFBRTtNQUFDLEdBREdELFFBRUwsQ0FDWixDQUFDO0lBQ0gsQ0FBQyxDQUFDO0lBRUYsT0FBTztNQUNMLEdBQUdSLFNBQVM7TUFDWkM7SUFDRixDQUFDO0VBQ0gsQ0FBQztBQUNIIiwiaWdub3JlTGlzdCI6W119
40
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsIlN1c3BlbnNlIiwianN4IiwiX2pzeCIsIkpTT05TcG91dCIsImlkIiwibmV4dCIsInByb3BzIiwibmV4dFByb3BzIiwic2NyaXB0cyIsIk9iamVjdCIsImVudHJpZXMiLCJpbml0RGF0YSIsImZvckVhY2giLCJrZXkiLCJ1c2VEYXRhIiwiZ2xvYmFsSWQiLCJTY3JpcHQiLCJkYXRhIiwiZW5jb2RlZCIsIkpTT04iLCJzdHJpbmdpZnkiLCJ0eXBlIiwiZGFuZ2Vyb3VzbHlTZXRJbm5lckhUTUwiLCJfX2h0bWwiLCJub25jZSIsImUiLCJjb25zb2xlIiwiZXJyb3IiLCJwdXNoIiwiY2hpbGRyZW4iXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc3BvdXRzL2pzb24uc2VydmVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgU3VzcGVuc2UgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB0eXBlIHsgU2VydmVyU3BvdXQgfSBmcm9tICcuL3R5cGVzLmpzJztcblxudHlwZSBOZWVkZWROZXh0ID0ge1xuICBpbml0RGF0YT86IFJlY29yZDxzdHJpbmcsICgpID0+IHVua25vd24+O1xuICBzY3JpcHRzPzogUmVhY3QuUmVhY3ROb2RlW107XG59O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBKU09OU3BvdXQoe1xuICBpZCA9ICdhbmFuc2ktanNvbicsXG59OiB7IGlkPzogc3RyaW5nIH0gPSB7fSk6IFNlcnZlclNwb3V0PFxuICBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPixcbiAgUmVjb3JkPHN0cmluZywgdW5rbm93bj4sXG4gIE5lZWRlZE5leHRcbj4ge1xuICByZXR1cm4gbmV4dCA9PiBhc3luYyBwcm9wcyA9PiB7XG4gICAgY29uc3QgbmV4dFByb3BzID0gYXdhaXQgbmV4dChwcm9wcyk7XG5cbiAgICBjb25zdCBzY3JpcHRzOiBSZWFjdC5SZWFjdE5vZGVbXSA9IG5leHRQcm9wcy5zY3JpcHRzID8/IFtdO1xuXG4gICAgT2JqZWN0LmVudHJpZXMobmV4dFByb3BzLmluaXREYXRhID8/IHt9KS5mb3JFYWNoKChba2V5LCB1c2VEYXRhXSkgPT4ge1xuICAgICAgY29uc3QgZ2xvYmFsSWQgPSBgJHtpZH0uJHtrZXl9YDtcbiAgICAgIGNvbnN0IFNjcmlwdCA9ICgpID0+IHtcbiAgICAgICAgY29uc3QgZGF0YTogYW55ID0gdXNlRGF0YSgpO1xuICAgICAgICB0cnkge1xuICAgICAgICAgIGNvbnN0IGVuY29kZWQgPSBKU09OLnN0cmluZ2lmeShkYXRhKTtcbiAgICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgPHNjcmlwdFxuICAgICAgICAgICAgICBpZD17Z2xvYmFsSWR9XG4gICAgICAgICAgICAgIHR5cGU9XCJhcHBsaWNhdGlvbi9qc29uXCJcbiAgICAgICAgICAgICAgZGFuZ2Vyb3VzbHlTZXRJbm5lckhUTUw9e3tcbiAgICAgICAgICAgICAgICBfX2h0bWw6IGVuY29kZWQsXG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIG5vbmNlPXtwcm9wcy5ub25jZX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKTtcbiAgICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICAgIC8vIFRPRE86IFVzZSB1bmlmaWVkIGxvZ2dpbmdcbiAgICAgICAgICBjb25zb2xlLmVycm9yKGBFcnJvciBzZXJpYWxpemluZyBqc29uIGZvciAke2tleX1gKTtcbiAgICAgICAgICBjb25zb2xlLmVycm9yKGUpO1xuICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICB9XG4gICAgICB9O1xuICAgICAgc2NyaXB0cy5wdXNoKFxuICAgICAgICA8U3VzcGVuc2Uga2V5PXtnbG9iYWxJZH0+XG4gICAgICAgICAgPFNjcmlwdCAvPlxuICAgICAgICA8L1N1c3BlbnNlPixcbiAgICAgICk7XG4gICAgfSk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4ubmV4dFByb3BzLFxuICAgICAgc2NyaXB0cyxcbiAgICB9O1xuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxLQUFLLElBQUlDLFFBQVEsUUFBUSxPQUFPO0FBQUMsU0FBQUMsR0FBQSxJQUFBQyxJQUFBO0FBU3hDLGVBQWUsU0FBU0MsU0FBU0EsQ0FBQztFQUNoQ0MsRUFBRSxHQUFHO0FBQ1UsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUlyQjtFQUNBLE9BQU9DLElBQUksSUFBSSxNQUFNQyxLQUFLLElBQUk7SUFDNUIsTUFBTUMsU0FBUyxHQUFHLE1BQU1GLElBQUksQ0FBQ0MsS0FBSyxDQUFDO0lBRW5DLE1BQU1FLE9BQTBCLEdBQUdELFNBQVMsQ0FBQ0MsT0FBTyxJQUFJLEVBQUU7SUFFMURDLE1BQU0sQ0FBQ0MsT0FBTyxDQUFDSCxTQUFTLENBQUNJLFFBQVEsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDQyxPQUFPLENBQUMsQ0FBQyxDQUFDQyxHQUFHLEVBQUVDLE9BQU8sQ0FBQyxLQUFLO01BQ25FLE1BQU1DLFFBQVEsR0FBRyxHQUFHWCxFQUFFLElBQUlTLEdBQUcsRUFBRTtNQUMvQixNQUFNRyxNQUFNLEdBQUdBLENBQUEsS0FBTTtRQUNuQixNQUFNQyxJQUFTLEdBQUdILE9BQU8sQ0FBQyxDQUFDO1FBQzNCLElBQUk7VUFDRixNQUFNSSxPQUFPLEdBQUdDLElBQUksQ0FBQ0MsU0FBUyxDQUFDSCxJQUFJLENBQUM7VUFDcEMsb0JBQ0VmLElBQUE7WUFDRUUsRUFBRSxFQUFFVyxRQUFTO1lBQ2JNLElBQUksRUFBQyxrQkFBa0I7WUFDdkJDLHVCQUF1QixFQUFFO2NBQ3ZCQyxNQUFNLEVBQUVMO1lBQ1YsQ0FBRTtZQUNGTSxLQUFLLEVBQUVsQixLQUFLLENBQUNrQjtVQUFNLENBQ3BCLENBQUM7UUFFTixDQUFDLENBQUMsT0FBT0MsQ0FBQyxFQUFFO1VBQ1Y7VUFDQUMsT0FBTyxDQUFDQyxLQUFLLENBQUMsOEJBQThCZCxHQUFHLEVBQUUsQ0FBQztVQUNsRGEsT0FBTyxDQUFDQyxLQUFLLENBQUNGLENBQUMsQ0FBQztVQUNoQixPQUFPLElBQUk7UUFDYjtNQUNGLENBQUM7TUFDRGpCLE9BQU8sQ0FBQ29CLElBQUksY0FDVjFCLElBQUEsQ0FBQ0YsUUFBUTtRQUFBNkIsUUFBQSxlQUNQM0IsSUFBQSxDQUFDYyxNQUFNLElBQUU7TUFBQyxHQURHRCxRQUVMLENBQ1osQ0FBQztJQUNILENBQUMsQ0FBQztJQUVGLE9BQU87TUFDTCxHQUFHUixTQUFTO01BQ1pDO0lBQ0YsQ0FBQztFQUNILENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==
@@ -27,7 +27,6 @@ if ('main' in import.meta) {
27
27
  let serverFileContents = Promise.resolve('');
28
28
  let serverEntry = '';
29
29
  export default async function startDevServer(entrypoint, env = {}) {
30
- var _webpackConfigs$;
31
30
  const webpackConfig = await getWebpackConfig();
32
31
  const log = logging.getLogger('anansi-devserver');
33
32
 
@@ -79,11 +78,10 @@ export default async function startDevServer(entrypoint, env = {}) {
79
78
  hookRequire: true
80
79
  });
81
80
  function getServerBundle(serverStats) {
82
- var _serverJson$outputPat;
83
81
  const serverJson = serverStats.toJson({
84
82
  assets: true
85
83
  });
86
- return path.join((_serverJson$outputPat = serverJson.outputPath) != null ? _serverJson$outputPat : '', 'server.js');
84
+ return path.join(serverJson.outputPath ?? '', 'server.js');
87
85
  }
88
86
  function handleErrors(fn) {
89
87
  return async function (req, res, next) {
@@ -96,16 +94,14 @@ export default async function startDevServer(entrypoint, env = {}) {
96
94
  }
97
95
  let initRender = [];
98
96
  let render = (...args) => new Promise(resolve => {
99
- var _initRender;
100
- (_initRender = initRender) == null || _initRender.push({
97
+ initRender?.push({
101
98
  args,
102
99
  resolve
103
100
  });
104
101
  });
105
102
  function importRender(stats) {
106
- var _clientStats$compilat, _serverStats$compilat;
107
103
  const [clientStats, serverStats] = stats;
108
- if (clientStats != null && (_clientStats$compilat = clientStats.compilation) != null && (_clientStats$compilat = _clientStats$compilat.errors) != null && _clientStats$compilat.length || serverStats != null && (_serverStats$compilat = serverStats.compilation) != null && (_serverStats$compilat = _serverStats$compilat.errors) != null && _serverStats$compilat.length) {
104
+ if (clientStats?.compilation?.errors?.length || serverStats?.compilation?.errors?.length) {
109
105
  log.error('Errors for client build: ' + clientStats.compilation.errors);
110
106
  log.error('Errors for server build: ' + serverStats.compilation.errors);
111
107
  // first time, rather than re-render
@@ -147,20 +143,19 @@ export default async function startDevServer(entrypoint, env = {}) {
147
143
  {
148
144
  ...webpackConfigs[0].devServer,
149
145
  devMiddleware: {
150
- ...((_webpackConfigs$ = webpackConfigs[0]) == null || (_webpackConfigs$ = _webpackConfigs$.devServer) == null ? void 0 : _webpackConfigs$.devMiddleware),
146
+ ...webpackConfigs[0]?.devServer?.devMiddleware,
151
147
  outputFileSystem: {
152
148
  ...fs,
153
149
  join: path.join
154
150
  }
155
151
  },
156
152
  setupMiddlewares: (middlewares, devServer) => {
157
- var _webpackConfigs$0$dev, _webpackConfigs$0$dev2, _devServer$app, _webpackConfigs$0$dev3;
158
153
  if (!devServer) {
159
154
  throw new Error('webpack-dev-server is not defined');
160
155
  }
161
- const otherRoutes = [process.env.WEBPACK_PUBLIC_PATH, ...Object.keys((_webpackConfigs$0$dev = (_webpackConfigs$0$dev2 = webpackConfigs[0].devServer) == null ? void 0 : _webpackConfigs$0$dev2.proxy) != null ? _webpackConfigs$0$dev : {})];
156
+ const otherRoutes = [process.env.WEBPACK_PUBLIC_PATH, ...Object.keys(webpackConfigs[0].devServer?.proxy ?? {})];
162
157
  // serve SSR for non-WEBPACK_PUBLIC_PATH
163
- (_devServer$app = devServer.app) == null || _devServer$app.get(new RegExp(`^(?!${otherRoutes.join('|')})`), handleErrors(async function (req, res) {
158
+ devServer.app?.get(new RegExp(`^(?!${otherRoutes.join('|')})`), handleErrors(async function (req, res) {
164
159
  if (req.url.endsWith('favicon.ico')) {
165
160
  res.statusCode = 404;
166
161
  res.setHeader('Content-type', 'text/html');
@@ -175,7 +170,7 @@ export default async function startDevServer(entrypoint, env = {}) {
175
170
  });
176
171
  await render(req, res);
177
172
  }));
178
- if ((_webpackConfigs$0$dev3 = webpackConfigs[0].devServer) != null && _webpackConfigs$0$dev3.setupMiddlewares) {
173
+ if (webpackConfigs[0].devServer?.setupMiddlewares) {
179
174
  return webpackConfigs[0].devServer.setupMiddlewares(middlewares, devServer);
180
175
  }
181
176
  return middlewares;
@@ -198,8 +193,7 @@ export default async function startDevServer(entrypoint, env = {}) {
198
193
  serverFileContents.then(fileText => {
199
194
  const textRows = fileText.split('\n');
200
195
  log.error('>>> Stack Context [serve entrypoint] <<<');
201
- for (const match of (_e$stack$matchAll = e.stack.matchAll(finder)) != null ? _e$stack$matchAll : []) {
202
- var _e$stack$matchAll;
196
+ for (const match of e.stack.matchAll(finder) ?? []) {
203
197
  const row = Number.parseInt(match[1]);
204
198
  const col = Number.parseInt(match[2]);
205
199
  log.error(path.basename(serverEntry) + ' ' + row + ':' + col);
@@ -231,4 +225,4 @@ export default async function startDevServer(entrypoint, env = {}) {
231
225
  });
232
226
  runServer();
233
227
  }
234
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Object","hasOwn","it","key","prototype","hasOwnProperty","call","diskFs","createFsRequire","createFsFromVolume","Volume","path","sourceMapSupport","tmp","ufs","promisify","webpack","logging","WebpackDevServer","getWebpackConfig","import","meta","entrypoint","process","argv","console","log","exit","startDevServer","serverFileContents","Promise","resolve","serverEntry","env","_webpackConfigs$","webpackConfig","getLogger","volume","fs","use","fsRequire","readFile","server","hotEntry","entryPath","generatedEntrypoint","fileSync","postfix","writeSync","fd","cwd","webpackConfigs","entrypath","name","mode","replace","BROWSERSLIST_ENV","target","compiler","install","hookRequire","getServerBundle","serverStats","_serverJson$outputPat","serverJson","toJson","assets","join","outputPath","handleErrors","fn","req","res","next","x","initRender","render","args","_initRender","push","importRender","stats","_clientStats$compilat","_serverStats$compilat","clientStats","compilation","errors","length","error","Array","isArray","info","clientManifest","then","buf","toString","keys","cache","forEach","default","bind","undefined","init","e","devServer","devMiddleware","outputFileSystem","setupMiddlewares","middlewares","_webpackConfigs$0$dev","_webpackConfigs$0$dev2","_devServer$app","_webpackConfigs$0$dev3","Error","otherRoutes","WEBPACK_PUBLIC_PATH","proxy","app","get","RegExp","url","endsWith","statusCode","setHeader","send","socket","on","code","runServer","start","hooks","done","tap","multiStats","finder","fileText","textRows","split","match","_e$stack$matchAll","stack","matchAll","row","Number","parseInt","col","basename","writeFileSync","stopServer","stop","warn"],"sources":["../../src/scripts/startDevserver.ts"],"sourcesContent":["#!/usr/bin/env node\nObject.hasOwn =\n  Object.hasOwn ||\n  /* istanbul ignore next */ function hasOwn(it, key) {\n    return Object.prototype.hasOwnProperty.call(it, key);\n  };\nimport type { NextFunction } from 'express';\nimport diskFs from 'fs';\nimport { createFsRequire } from 'fs-require';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport { createFsFromVolume, Volume } from 'memfs';\nimport path from 'path';\nimport sourceMapSupport from 'source-map-support';\nimport tmp from 'tmp';\nimport { ufs } from 'unionfs';\nimport { promisify } from 'util';\nimport webpack, { MultiCompiler } from 'webpack';\nimport logging from 'webpack/lib/logging/runtime.js';\nimport WebpackDevServer from 'webpack-dev-server';\n\nimport 'cross-fetch/dist/node-polyfill.js';\nimport { getWebpackConfig } from './getWebpackConfig.js';\nimport { BoundRender } from './types.js';\n\n// run directly from node\nif ('main' in import.meta) {\n  const entrypoint = process.argv[2];\n\n  if (!entrypoint) {\n    console.log(`Usage: start-anansi <entrypoint-file>`);\n    process.exit(-1);\n  }\n\n  startDevServer(entrypoint);\n}\n\nlet serverFileContents: Promise<string> = Promise.resolve('');\nlet serverEntry = '';\n\nexport default async function startDevServer(\n  entrypoint: string,\n  env: Record<string, unknown> = {},\n) {\n  const webpackConfig = await getWebpackConfig();\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  const fsRequire = createFsRequire(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 (import.meta.webpackHot) {\n    import.meta.webpackHot.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\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  let 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      // first time, rather than re-render\n      if (Array.isArray(initRender)) {\n        process.exit(-1);\n      }\n      log.error('Above compiler errors blocking reload');\n      return;\n    } else {\n      log.info('Launching SSR');\n    }\n\n    // ASSETS\n    const clientManifest = clientStats.toJson();\n\n    serverEntry = getServerBundle(serverStats);\n    serverFileContents = readFile(serverEntry).then(buf => buf.toString());\n    // reload modules\n    Object.keys(fsRequire.cache).forEach(key => {\n      delete fsRequire.cache[key];\n    });\n    render = (fsRequire(serverEntry) as any).default.bind(\n      undefined,\n      clientManifest,\n    );\n    // SERVER SIDE ENTRYPOINT\n    if (Array.isArray(initRender)) {\n      initRender.forEach(async init => {\n        try {\n          log.info('Resolving queued requests');\n          await render(...init.args);\n          init.resolve();\n        } catch (e) {\n          log.error('Error when attempting to render queued requests');\n          log.error(e);\n        }\n      });\n      initRender = undefined;\n    }\n  }\n\n  const devServer = new WebpackDevServer(\n    // write to memory filesystem so we can import\n    {\n      ...webpackConfigs[0].devServer,\n      devMiddleware: {\n        ...webpackConfigs[0]?.devServer?.devMiddleware,\n        outputFileSystem: {\n          ...fs,\n          join: path.join as any,\n        } as any,\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              log.error('Fatal:', error);\n              if ((error as any).code === 'ECONNRESET') {\n                log.error(\n                  'ECONNRESET is usually due to browser closing the connection',\n                );\n              }\n            });\n\n            await render(req, res);\n          }),\n        );\n\n        if (webpackConfigs[0].devServer?.setupMiddlewares) {\n          return webpackConfigs[0].devServer.setupMiddlewares(\n            middlewares,\n            devServer,\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            const finder = new RegExp(`${serverEntry}:([\\\\d]+):([\\\\d]+)`, 'g');\n            serverFileContents.then(fileText => {\n              const textRows = fileText.split('\\n');\n              log.error('>>> Stack Context [serve entrypoint] <<<');\n              for (const match of e.stack.matchAll(finder) ?? []) {\n                const row = Number.parseInt(match[1]);\n                const col = Number.parseInt(match[2]);\n                log.error(path.basename(serverEntry) + ' ' + row + ':' + col);\n                log.error(textRows[row - 2]);\n                log.error(textRows[row - 1]);\n                log.error(Array(col).join(' ') + '^');\n                log.error(textRows[row]);\n                log.error(textRows[row + 1]);\n                log.error(textRows[row + 2]);\n              }\n              diskFs.writeFileSync(serverEntry, fileText);\n            });\n\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":"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","ignoreList":[]}
228
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Object","hasOwn","it","key","prototype","hasOwnProperty","call","diskFs","createFsRequire","createFsFromVolume","Volume","path","sourceMapSupport","tmp","ufs","promisify","webpack","logging","WebpackDevServer","getWebpackConfig","import","meta","entrypoint","process","argv","console","log","exit","startDevServer","serverFileContents","Promise","resolve","serverEntry","env","webpackConfig","getLogger","volume","fs","use","fsRequire","readFile","server","hotEntry","entryPath","generatedEntrypoint","fileSync","postfix","writeSync","fd","cwd","webpackConfigs","entrypath","name","mode","replace","BROWSERSLIST_ENV","target","compiler","install","hookRequire","getServerBundle","serverStats","serverJson","toJson","assets","join","outputPath","handleErrors","fn","req","res","next","x","initRender","render","args","push","importRender","stats","clientStats","compilation","errors","length","error","Array","isArray","info","clientManifest","then","buf","toString","keys","cache","forEach","default","bind","undefined","init","e","devServer","devMiddleware","outputFileSystem","setupMiddlewares","middlewares","Error","otherRoutes","WEBPACK_PUBLIC_PATH","proxy","app","get","RegExp","url","endsWith","statusCode","setHeader","send","socket","on","code","runServer","start","hooks","done","tap","multiStats","finder","fileText","textRows","split","match","stack","matchAll","row","Number","parseInt","col","basename","writeFileSync","stopServer","stop","warn"],"sources":["../../src/scripts/startDevserver.ts"],"sourcesContent":["#!/usr/bin/env node\nObject.hasOwn =\n  Object.hasOwn ||\n  /* istanbul ignore next */ function hasOwn(it, key) {\n    return Object.prototype.hasOwnProperty.call(it, key);\n  };\nimport type { NextFunction } from 'express';\nimport diskFs from 'fs';\nimport { createFsRequire } from 'fs-require';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport { createFsFromVolume, Volume } from 'memfs';\nimport path from 'path';\nimport sourceMapSupport from 'source-map-support';\nimport tmp from 'tmp';\nimport { ufs } from 'unionfs';\nimport { promisify } from 'util';\nimport webpack, { MultiCompiler } from 'webpack';\nimport logging from 'webpack/lib/logging/runtime.js';\nimport WebpackDevServer from 'webpack-dev-server';\n\nimport 'cross-fetch/dist/node-polyfill.js';\nimport { getWebpackConfig } from './getWebpackConfig.js';\nimport { BoundRender } from './types.js';\n\n// run directly from node\nif ('main' in import.meta) {\n  const entrypoint = process.argv[2];\n\n  if (!entrypoint) {\n    console.log(`Usage: start-anansi <entrypoint-file>`);\n    process.exit(-1);\n  }\n\n  startDevServer(entrypoint);\n}\n\nlet serverFileContents: Promise<string> = Promise.resolve('');\nlet serverEntry = '';\n\nexport default async function startDevServer(\n  entrypoint: string,\n  env: Record<string, unknown> = {},\n) {\n  const webpackConfig = await getWebpackConfig();\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  const fsRequire = createFsRequire(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 (import.meta.webpackHot) {\n    import.meta.webpackHot.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\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  let 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      // first time, rather than re-render\n      if (Array.isArray(initRender)) {\n        process.exit(-1);\n      }\n      log.error('Above compiler errors blocking reload');\n      return;\n    } else {\n      log.info('Launching SSR');\n    }\n\n    // ASSETS\n    const clientManifest = clientStats.toJson();\n\n    serverEntry = getServerBundle(serverStats);\n    serverFileContents = readFile(serverEntry).then(buf => buf.toString());\n    // reload modules\n    Object.keys(fsRequire.cache).forEach(key => {\n      delete fsRequire.cache[key];\n    });\n    render = (fsRequire(serverEntry) as any).default.bind(\n      undefined,\n      clientManifest,\n    );\n    // SERVER SIDE ENTRYPOINT\n    if (Array.isArray(initRender)) {\n      initRender.forEach(async init => {\n        try {\n          log.info('Resolving queued requests');\n          await render(...init.args);\n          init.resolve();\n        } catch (e) {\n          log.error('Error when attempting to render queued requests');\n          log.error(e);\n        }\n      });\n      initRender = undefined;\n    }\n  }\n\n  const devServer = new WebpackDevServer(\n    // write to memory filesystem so we can import\n    {\n      ...webpackConfigs[0].devServer,\n      devMiddleware: {\n        ...webpackConfigs[0]?.devServer?.devMiddleware,\n        outputFileSystem: {\n          ...fs,\n          join: path.join as any,\n        } as any,\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              log.error('Fatal:', error);\n              if ((error as any).code === 'ECONNRESET') {\n                log.error(\n                  'ECONNRESET is usually due to browser closing the connection',\n                );\n              }\n            });\n\n            await render(req, res);\n          }),\n        );\n\n        if (webpackConfigs[0].devServer?.setupMiddlewares) {\n          return webpackConfigs[0].devServer.setupMiddlewares(\n            middlewares,\n            devServer,\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            const finder = new RegExp(`${serverEntry}:([\\\\d]+):([\\\\d]+)`, 'g');\n            serverFileContents.then(fileText => {\n              const textRows = fileText.split('\\n');\n              log.error('>>> Stack Context [serve entrypoint] <<<');\n              for (const match of e.stack.matchAll(finder) ?? []) {\n                const row = Number.parseInt(match[1]);\n                const col = Number.parseInt(match[2]);\n                log.error(path.basename(serverEntry) + ' ' + row + ':' + col);\n                log.error(textRows[row - 2]);\n                log.error(textRows[row - 1]);\n                log.error(Array(col).join(' ') + '^');\n                log.error(textRows[row]);\n                log.error(textRows[row + 1]);\n                log.error(textRows[row + 2]);\n              }\n              diskFs.writeFileSync(serverEntry, fileText);\n            });\n\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":"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","ignoreList":[]}
@@ -7,7 +7,7 @@ export default function antdSpout() {
7
7
  createCache,
8
8
  extractStyle,
9
9
  StyleProvider
10
- } = await import('@ant-design/cssinjs');
10
+ } = await import(/* webpackIgnore: true */'@ant-design/cssinjs');
11
11
  const cache = createCache();
12
12
  const nextProps = await next(props);
13
13
  const scripts = (_nextProps$scripts = nextProps.scripts) != null ? _nextProps$scripts : [];
@@ -31,4 +31,4 @@ export default function antdSpout() {
31
31
  };
32
32
  };
33
33
  }
34
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImpzeCIsIl9qc3giLCJhbnRkU3BvdXQiLCJuZXh0IiwicHJvcHMiLCJfbmV4dFByb3BzJHNjcmlwdHMiLCJjcmVhdGVDYWNoZSIsImV4dHJhY3RTdHlsZSIsIlN0eWxlUHJvdmlkZXIiLCJjYWNoZSIsIm5leHRQcm9wcyIsInNjcmlwdHMiLCJBbnRkU2hlZXRzIiwiZGFuZ2Vyb3VzbHlTZXRJbm5lckhUTUwiLCJfX2h0bWwiLCJwdXNoIiwiYXBwIiwiY2hpbGRyZW4iXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BvdXRzL2FudGQuc2VydmVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdHlwZSBKU1ggfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB0eXBlIHsgU2VydmVyU3BvdXQgfSBmcm9tICcuL3R5cGVzLmpzJztcblxudHlwZSBOZWVkZWROZXh0ID0ge1xuICBpbml0RGF0YT86IFJlY29yZDxzdHJpbmcsICgpID0+IHVua25vd24+O1xuICBzY3JpcHRzPzogUmVhY3QuUmVhY3ROb2RlW107XG4gIGV4dHJhU3R5bGU/OiBSZWFjdC5SZWFjdE5vZGVbXTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFudGRTcG91dCgpOiBTZXJ2ZXJTcG91dDxcbiAgUmVjb3JkPHN0cmluZywgdW5rbm93bj4sXG4gIFJlY29yZDxzdHJpbmcsIHVua25vd24+LFxuICBOZWVkZWROZXh0XG4+IHtcbiAgcmV0dXJuIG5leHQgPT4gYXN5bmMgcHJvcHMgPT4ge1xuICAgIGNvbnN0IHsgY3JlYXRlQ2FjaGUsIGV4dHJhY3RTdHlsZSwgU3R5bGVQcm92aWRlciB9ID0gYXdhaXQgaW1wb3J0KFxuICAgICAgJ0BhbnQtZGVzaWduL2Nzc2luanMnXG4gICAgKTtcbiAgICBjb25zdCBjYWNoZSA9IGNyZWF0ZUNhY2hlKCk7XG5cbiAgICBjb25zdCBuZXh0UHJvcHMgPSBhd2FpdCBuZXh0KHByb3BzKTtcblxuICAgIGNvbnN0IHNjcmlwdHM6IFJlYWN0LlJlYWN0Tm9kZVtdID0gbmV4dFByb3BzLnNjcmlwdHMgPz8gW107XG5cbiAgICBjb25zdCBBbnRkU2hlZXRzID0gKCk6IEpTWC5FbGVtZW50ID0+IHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxzY3JpcHRcbiAgICAgICAgICBkYW5nZXJvdXNseVNldElubmVySFRNTD17e1xuICAgICAgICAgICAgX19odG1sOiBgPC9zY3JpcHQ+JHtleHRyYWN0U3R5bGUoY2FjaGUpfTxzY3JpcHQ+YCxcbiAgICAgICAgICB9fVxuICAgICAgICAvPlxuICAgICAgKTtcbiAgICB9O1xuICAgIC8vIHVuZm9ydHVuYXRlbHkgd2UgaGF2ZSB0byBpbmplY3QgdGhpcyBhZnRlciB0aGUgZW50aXJlIGNvbnRlbnQgaGFzIHN0cmVhbWVkIGluIG9yIGl0IGRvZXNuJ3QgY29ycmVjdGx5IHBvcHVsYXRlXG4gICAgLy8gc2VlOiBodHRwczovL2dpdGh1Yi5jb20vYW50LWRlc2lnbi9jc3NpbmpzL2lzc3Vlcy83OVxuICAgIHNjcmlwdHMucHVzaCg8QW50ZFNoZWV0cyAvPik7XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4ubmV4dFByb3BzLFxuICAgICAgYXBwOiA8U3R5bGVQcm92aWRlciBjYWNoZT17Y2FjaGV9PntuZXh0UHJvcHMuYXBwfTwvU3R5bGVQcm92aWRlcj4sXG4gICAgICBzY3JpcHRzLFxuICAgIH07XG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLEtBQUssTUFBb0IsT0FBTztBQUFDLFNBQUFDLEdBQUEsSUFBQUMsSUFBQTtBQVV4QyxlQUFlLFNBQVNDLFNBQVNBLENBQUEsRUFJL0I7RUFDQSxPQUFPQyxJQUFJLElBQUksTUFBTUMsS0FBSyxJQUFJO0lBQUEsSUFBQUMsa0JBQUE7SUFDNUIsTUFBTTtNQUFFQyxXQUFXO01BQUVDLFlBQVk7TUFBRUM7SUFBYyxDQUFDLEdBQUcsTUFBTSxNQUFNLENBQy9ELHFCQUNGLENBQUM7SUFDRCxNQUFNQyxLQUFLLEdBQUdILFdBQVcsQ0FBQyxDQUFDO0lBRTNCLE1BQU1JLFNBQVMsR0FBRyxNQUFNUCxJQUFJLENBQUNDLEtBQUssQ0FBQztJQUVuQyxNQUFNTyxPQUEwQixJQUFBTixrQkFBQSxHQUFHSyxTQUFTLENBQUNDLE9BQU8sWUFBQU4sa0JBQUEsR0FBSSxFQUFFO0lBRTFELE1BQU1PLFVBQVUsR0FBR0EsQ0FBQSxLQUFtQjtNQUNwQyxvQkFDRVgsSUFBQTtRQUNFWSx1QkFBdUIsRUFBRTtVQUN2QkMsTUFBTSxFQUFFLFlBQVlQLFlBQVksQ0FBQ0UsS0FBSyxDQUFDO1FBQ3pDO01BQUUsQ0FDSCxDQUFDO0lBRU4sQ0FBQztJQUNEO0lBQ0E7SUFDQUUsT0FBTyxDQUFDSSxJQUFJLGNBQUNkLElBQUEsQ0FBQ1csVUFBVSxJQUFFLENBQUMsQ0FBQztJQUU1QixPQUFPO01BQ0wsR0FBR0YsU0FBUztNQUNaTSxHQUFHLGVBQUVmLElBQUEsQ0FBQ08sYUFBYTtRQUFDQyxLQUFLLEVBQUVBLEtBQU07UUFBQVEsUUFBQSxFQUFFUCxTQUFTLENBQUNNO01BQUcsQ0FBZ0IsQ0FBQztNQUNqRUw7SUFDRixDQUFDO0VBQ0gsQ0FBQztBQUNIIiwiaWdub3JlTGlzdCI6W119
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImpzeCIsIl9qc3giLCJhbnRkU3BvdXQiLCJuZXh0IiwicHJvcHMiLCJfbmV4dFByb3BzJHNjcmlwdHMiLCJjcmVhdGVDYWNoZSIsImV4dHJhY3RTdHlsZSIsIlN0eWxlUHJvdmlkZXIiLCJjYWNoZSIsIm5leHRQcm9wcyIsInNjcmlwdHMiLCJBbnRkU2hlZXRzIiwiZGFuZ2Vyb3VzbHlTZXRJbm5lckhUTUwiLCJfX2h0bWwiLCJwdXNoIiwiYXBwIiwiY2hpbGRyZW4iXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BvdXRzL2FudGQuc2VydmVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdHlwZSBKU1ggfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB0eXBlIHsgU2VydmVyU3BvdXQgfSBmcm9tICcuL3R5cGVzLmpzJztcblxudHlwZSBOZWVkZWROZXh0ID0ge1xuICBpbml0RGF0YT86IFJlY29yZDxzdHJpbmcsICgpID0+IHVua25vd24+O1xuICBzY3JpcHRzPzogUmVhY3QuUmVhY3ROb2RlW107XG4gIGV4dHJhU3R5bGU/OiBSZWFjdC5SZWFjdE5vZGVbXTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFudGRTcG91dCgpOiBTZXJ2ZXJTcG91dDxcbiAgUmVjb3JkPHN0cmluZywgdW5rbm93bj4sXG4gIFJlY29yZDxzdHJpbmcsIHVua25vd24+LFxuICBOZWVkZWROZXh0XG4+IHtcbiAgcmV0dXJuIG5leHQgPT4gYXN5bmMgcHJvcHMgPT4ge1xuICAgIGNvbnN0IHsgY3JlYXRlQ2FjaGUsIGV4dHJhY3RTdHlsZSwgU3R5bGVQcm92aWRlciB9ID0gYXdhaXQgaW1wb3J0KFxuICAgICAgLyogd2VicGFja0lnbm9yZTogdHJ1ZSAqLyAnQGFudC1kZXNpZ24vY3NzaW5qcydcbiAgICApO1xuICAgIGNvbnN0IGNhY2hlID0gY3JlYXRlQ2FjaGUoKTtcblxuICAgIGNvbnN0IG5leHRQcm9wcyA9IGF3YWl0IG5leHQocHJvcHMpO1xuXG4gICAgY29uc3Qgc2NyaXB0czogUmVhY3QuUmVhY3ROb2RlW10gPSBuZXh0UHJvcHMuc2NyaXB0cyA/PyBbXTtcblxuICAgIGNvbnN0IEFudGRTaGVldHMgPSAoKTogSlNYLkVsZW1lbnQgPT4ge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPHNjcmlwdFxuICAgICAgICAgIGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7XG4gICAgICAgICAgICBfX2h0bWw6IGA8L3NjcmlwdD4ke2V4dHJhY3RTdHlsZShjYWNoZSl9PHNjcmlwdD5gLFxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICApO1xuICAgIH07XG4gICAgLy8gdW5mb3J0dW5hdGVseSB3ZSBoYXZlIHRvIGluamVjdCB0aGlzIGFmdGVyIHRoZSBlbnRpcmUgY29udGVudCBoYXMgc3RyZWFtZWQgaW4gb3IgaXQgZG9lc24ndCBjb3JyZWN0bHkgcG9wdWxhdGVcbiAgICAvLyBzZWU6IGh0dHBzOi8vZ2l0aHViLmNvbS9hbnQtZGVzaWduL2Nzc2luanMvaXNzdWVzLzc5XG4gICAgc2NyaXB0cy5wdXNoKDxBbnRkU2hlZXRzIC8+KTtcblxuICAgIHJldHVybiB7XG4gICAgICAuLi5uZXh0UHJvcHMsXG4gICAgICBhcHA6IDxTdHlsZVByb3ZpZGVyIGNhY2hlPXtjYWNoZX0+e25leHRQcm9wcy5hcHB9PC9TdHlsZVByb3ZpZGVyPixcbiAgICAgIHNjcmlwdHMsXG4gICAgfTtcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsS0FBSyxNQUFvQixPQUFPO0FBQUMsU0FBQUMsR0FBQSxJQUFBQyxJQUFBO0FBVXhDLGVBQWUsU0FBU0MsU0FBU0EsQ0FBQSxFQUkvQjtFQUNBLE9BQU9DLElBQUksSUFBSSxNQUFNQyxLQUFLLElBQUk7SUFBQSxJQUFBQyxrQkFBQTtJQUM1QixNQUFNO01BQUVDLFdBQVc7TUFBRUMsWUFBWTtNQUFFQztJQUFjLENBQUMsR0FBRyxNQUFNLE1BQU0sQ0FDL0QseUJBQTBCLHFCQUM1QixDQUFDO0lBQ0QsTUFBTUMsS0FBSyxHQUFHSCxXQUFXLENBQUMsQ0FBQztJQUUzQixNQUFNSSxTQUFTLEdBQUcsTUFBTVAsSUFBSSxDQUFDQyxLQUFLLENBQUM7SUFFbkMsTUFBTU8sT0FBMEIsSUFBQU4sa0JBQUEsR0FBR0ssU0FBUyxDQUFDQyxPQUFPLFlBQUFOLGtCQUFBLEdBQUksRUFBRTtJQUUxRCxNQUFNTyxVQUFVLEdBQUdBLENBQUEsS0FBbUI7TUFDcEMsb0JBQ0VYLElBQUE7UUFDRVksdUJBQXVCLEVBQUU7VUFDdkJDLE1BQU0sRUFBRSxZQUFZUCxZQUFZLENBQUNFLEtBQUssQ0FBQztRQUN6QztNQUFFLENBQ0gsQ0FBQztJQUVOLENBQUM7SUFDRDtJQUNBO0lBQ0FFLE9BQU8sQ0FBQ0ksSUFBSSxjQUFDZCxJQUFBLENBQUNXLFVBQVUsSUFBRSxDQUFDLENBQUM7SUFFNUIsT0FBTztNQUNMLEdBQUdGLFNBQVM7TUFDWk0sR0FBRyxlQUFFZixJQUFBLENBQUNPLGFBQWE7UUFBQ0MsS0FBSyxFQUFFQSxLQUFNO1FBQUFRLFFBQUEsRUFBRVAsU0FBUyxDQUFDTTtNQUFHLENBQWdCLENBQUM7TUFDakVMO0lBQ0YsQ0FBQztFQUNILENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@anansi/core",
3
- "version": "0.20.15",
3
+ "version": "0.20.16",
4
4
  "description": "React 18 Framework",
5
5
  "homepage": "https://github.com/ntucker/anansi/tree/master/packages/core#readme",
6
6
  "repository": {
@@ -71,8 +71,8 @@
71
71
  "@types/compression": "1.7.5",
72
72
  "@types/express": "^4.17.17",
73
73
  "@types/node": "^22.0.0",
74
- "@types/react": "npm:types-react@19.0.0-rc.1",
75
- "@types/react-dom": "npm:types-react-dom@19.0.0",
74
+ "@types/react": "19.0.2",
75
+ "@types/react-dom": "19.0.2",
76
76
  "@types/source-map-support": "0.5.10",
77
77
  "@types/tmp": "0.2.6",
78
78
  "@types/webpack-hot-middleware": "2.25.9",
@@ -85,7 +85,7 @@
85
85
  "@babel/runtime": "^7.17.0",
86
86
  "chalk": "^4.1.2",
87
87
  "compression": "^1.7.5",
88
- "cross-fetch": "^4.0.0",
88
+ "cross-fetch": "^4.1.0",
89
89
  "enhanced-resolve": "^5.18.0",
90
90
  "express": "^4.21.2",
91
91
  "fs-require": "^1.6.0",
@@ -104,8 +104,8 @@
104
104
  "@data-client/react": "^0.12.15 || ^0.13.0 || ^0.14.0",
105
105
  "@types/react": "*",
106
106
  "@types/react-dom": "*",
107
- "react": "^18.0.0 || ^19.0.0-0",
108
- "react-dom": "^18.0.0 || ^19.0.0-0",
107
+ "react": "^18.0.0 || ^19.0.0",
108
+ "react-dom": "^18.0.0 || ^19.0.0",
109
109
  "webpack": "^5.60.0"
110
110
  },
111
111
  "peerDependenciesMeta": {
@@ -133,8 +133,8 @@
133
133
  "test:type": "yarn g:tsc",
134
134
  "build": "run build:lib && run build:scripts && run build:bundle",
135
135
  "build:lib": "NODE_ENV=production BROWSERSLIST_ENV='2020' yarn g:babel --out-dir lib",
136
- "build:scripts": "NODE_ENV=production BROWSERSLIST_ENV='node12' yarn g:babel src/scripts --out-dir lib/scripts",
137
- "build:bundle": "BROWSERSLIST_ENV=node12 yarn g:webpack --mode=none --target=node && echo '{\"type\":\"commonjs\"}' > dist/package.json",
136
+ "build:scripts": "NODE_ENV=production BROWSERSLIST_ENV='node22' yarn g:babel src/scripts --out-dir lib/scripts",
137
+ "build:bundle": "BROWSERSLIST_ENV=node22 yarn g:webpack --mode=none --target=node && echo '{\"type\":\"commonjs\"}' > dist/package.json",
138
138
  "build:clean": "yarn g:clean",
139
139
  "prepack": "run build"
140
140
  }
@@ -15,7 +15,7 @@ export default function antdSpout(): ServerSpout<
15
15
  > {
16
16
  return next => async props => {
17
17
  const { createCache, extractStyle, StyleProvider } = await import(
18
- '@ant-design/cssinjs'
18
+ /* webpackIgnore: true */ '@ant-design/cssinjs'
19
19
  );
20
20
  const cache = createCache();
21
21