gsd-pi 2.47.0 → 2.48.0-dev.2e7390c

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (174) hide show
  1. package/dist/resources/extensions/gsd/auto-start.js +8 -1
  2. package/dist/resources/extensions/gsd/forensics.js +292 -1
  3. package/dist/resources/extensions/gsd/guided-flow.js +85 -3
  4. package/dist/resources/extensions/gsd/prompts/forensics.md +37 -5
  5. package/dist/resources/extensions/gsd/session-forensics.js +10 -1
  6. package/dist/web/standalone/.next/BUILD_ID +1 -1
  7. package/dist/web/standalone/.next/app-path-routes-manifest.json +12 -12
  8. package/dist/web/standalone/.next/build-manifest.json +3 -3
  9. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  10. package/dist/web/standalone/.next/required-server-files.json +3 -3
  11. package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
  12. package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  13. package/dist/web/standalone/.next/server/app/_global-error.html +2 -2
  14. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  15. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  16. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  17. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  18. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  19. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  20. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  21. package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
  22. package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  23. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  24. package/dist/web/standalone/.next/server/app/_not-found.rsc +3 -3
  25. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
  26. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  27. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
  28. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  29. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  30. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  31. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  32. package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
  33. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  34. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
  35. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  36. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
  37. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
  38. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
  39. package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
  40. package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
  41. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  42. package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
  43. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  44. package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
  45. package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
  46. package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
  47. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  48. package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
  49. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  50. package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
  51. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  52. package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
  53. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  54. package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
  55. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  56. package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
  57. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  58. package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
  59. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  60. package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
  61. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  62. package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
  63. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  64. package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
  65. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  66. package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
  67. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  68. package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
  69. package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
  70. package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
  71. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  72. package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
  73. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  74. package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
  75. package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +5 -5
  76. package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
  77. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  78. package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
  79. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  80. package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
  81. package/dist/web/standalone/.next/server/app/api/session/events/route.js +2 -2
  82. package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
  83. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  84. package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
  85. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  86. package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
  87. package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
  88. package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  89. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  90. package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
  91. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  92. package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
  93. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
  94. package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -1
  95. package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +2 -2
  96. package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
  97. package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
  98. package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
  99. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +2 -2
  100. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
  101. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +4 -4
  102. package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
  103. package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
  104. package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
  105. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  106. package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
  107. package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
  108. package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
  109. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  110. package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
  111. package/dist/web/standalone/.next/server/app/index.html +1 -1
  112. package/dist/web/standalone/.next/server/app/index.rsc +4 -4
  113. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  114. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +4 -4
  115. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  116. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +3 -3
  117. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  118. package/dist/web/standalone/.next/server/app/page.js +2 -2
  119. package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  120. package/dist/web/standalone/.next/server/app-paths-manifest.json +12 -12
  121. package/dist/web/standalone/.next/server/chunks/229.js +1 -1
  122. package/dist/web/standalone/.next/server/chunks/471.js +3 -3
  123. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  124. package/dist/web/standalone/.next/server/middleware.js +2 -2
  125. package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
  126. package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
  127. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  128. package/dist/web/standalone/.next/server/pages/500.html +2 -2
  129. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  130. package/dist/web/standalone/.next/static/chunks/app/_not-found/{page-2f24283c162b6ab3.js → page-f2a7482d42a5614b.js} +1 -1
  131. package/dist/web/standalone/.next/static/chunks/app/{layout-9ecfd95f343793f0.js → layout-a16c7a7ecdf0c2cf.js} +1 -1
  132. package/dist/web/standalone/.next/static/chunks/app/page-6654a8cca61a3d1c.js +1 -0
  133. package/dist/web/standalone/.next/static/chunks/main-app-fdab67f7802d7832.js +1 -0
  134. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +1 -0
  135. package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
  136. package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
  137. package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
  138. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
  139. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
  140. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
  141. package/dist/web/standalone/server.js +1 -1
  142. package/package.json +1 -1
  143. package/packages/pi-agent-core/dist/agent-loop.js +3 -2
  144. package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
  145. package/packages/pi-agent-core/src/agent-loop.ts +3 -2
  146. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +43 -0
  147. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -1
  148. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  149. package/packages/pi-coding-agent/dist/core/model-registry.js +26 -3
  150. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  151. package/packages/pi-coding-agent/package.json +1 -1
  152. package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +70 -0
  153. package/packages/pi-coding-agent/src/core/model-registry.ts +29 -2
  154. package/packages/pi-tui/dist/components/box.d.ts +1 -0
  155. package/packages/pi-tui/dist/components/box.d.ts.map +1 -1
  156. package/packages/pi-tui/dist/components/box.js +10 -0
  157. package/packages/pi-tui/dist/components/box.js.map +1 -1
  158. package/packages/pi-tui/src/components/box.ts +10 -0
  159. package/pkg/package.json +1 -1
  160. package/src/resources/extensions/gsd/auto-start.ts +7 -1
  161. package/src/resources/extensions/gsd/forensics.ts +329 -2
  162. package/src/resources/extensions/gsd/guided-flow.ts +105 -3
  163. package/src/resources/extensions/gsd/prompts/forensics.md +37 -5
  164. package/src/resources/extensions/gsd/session-forensics.ts +11 -1
  165. package/src/resources/extensions/gsd/tests/discuss-queued-milestones.test.ts +241 -0
  166. package/src/resources/extensions/gsd/tests/forensics-error-filter.test.ts +121 -0
  167. package/src/resources/extensions/gsd/tests/forensics-journal.test.ts +162 -0
  168. package/src/resources/extensions/gsd/tests/preflight-context-draft-filter.test.ts +115 -0
  169. package/src/resources/extensions/gsd/tests/stale-milestone-id-reservation.test.ts +79 -0
  170. package/dist/web/standalone/.next/static/chunks/app/page-12dd5ece0df4badc.js +0 -1
  171. package/dist/web/standalone/.next/static/chunks/main-app-d3d4c336195465f9.js +0 -1
  172. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-ab5a8926e07ec673.js +0 -1
  173. /package/dist/web/standalone/.next/static/{VPcLnRF4BL8VoJEilBwlB → uTZ196cPUij3KcIDCweR6}/_buildManifest.js +0 -0
  174. /package/dist/web/standalone/.next/static/{VPcLnRF4BL8VoJEilBwlB → uTZ196cPUij3KcIDCweR6}/_ssgManifest.js +0 -0
@@ -0,0 +1,79 @@
1
+ /**
2
+ * Regression test for #2488: Stale milestone ID reservations inflate next ID
3
+ * after cancelled /gsd sessions.
4
+ *
5
+ * The module-level `reservedMilestoneIds` Set persists across /gsd invocations
6
+ * within the same Node process. Without clearReservedMilestoneIds() at session
7
+ * start, each cancelled session permanently bumps the counter by 1.
8
+ */
9
+ import { describe, test, beforeEach } from "node:test";
10
+ import assert from "node:assert/strict";
11
+
12
+ import {
13
+ nextMilestoneId,
14
+ reserveMilestoneId,
15
+ getReservedMilestoneIds,
16
+ clearReservedMilestoneIds,
17
+ } from "../milestone-ids.ts";
18
+
19
+ describe("stale milestone ID reservation cleanup (#2488)", () => {
20
+ beforeEach(() => {
21
+ clearReservedMilestoneIds();
22
+ });
23
+
24
+ test("without cleanup, cancelled sessions inflate the next ID", () => {
25
+ const diskIds = ["M001", "M002", "M003"];
26
+
27
+ // Session 1: user starts /gsd, ID is previewed and reserved, then cancelled
28
+ const allIds1 = [...new Set([...diskIds, ...getReservedMilestoneIds()])];
29
+ const preview1 = nextMilestoneId(allIds1);
30
+ reserveMilestoneId(preview1);
31
+ assert.equal(preview1, "M004");
32
+
33
+ // Session 2: user starts /gsd again — stale reservation still in Set
34
+ // WITHOUT clearing, the next ID skips M004 (reserved) and goes to M005
35
+ const allIds2 = [...new Set([...diskIds, ...getReservedMilestoneIds()])];
36
+ const preview2 = nextMilestoneId(allIds2);
37
+ assert.equal(preview2, "M005", "without cleanup, ID inflates to M005");
38
+ });
39
+
40
+ test("with cleanup at session start, next ID is correct", () => {
41
+ const diskIds = ["M001", "M002", "M003"];
42
+
43
+ // Session 1: user starts /gsd, ID is previewed and reserved, then cancelled
44
+ const allIds1 = [...new Set([...diskIds, ...getReservedMilestoneIds()])];
45
+ const preview1 = nextMilestoneId(allIds1);
46
+ reserveMilestoneId(preview1);
47
+ assert.equal(preview1, "M004");
48
+
49
+ // Session 2: clear stale reservations first (the fix)
50
+ clearReservedMilestoneIds();
51
+
52
+ // Now the next ID correctly returns M004 again
53
+ const allIds2 = [...new Set([...diskIds, ...getReservedMilestoneIds()])];
54
+ const preview2 = nextMilestoneId(allIds2);
55
+ assert.equal(preview2, "M004", "after cleanup, ID is correctly M004");
56
+ });
57
+
58
+ test("multiple cancelled sessions compound the inflation without cleanup", () => {
59
+ const diskIds = ["M001", "M002", "M003"];
60
+
61
+ // 3 cancelled sessions without cleanup
62
+ for (let i = 0; i < 3; i++) {
63
+ const allIds = [...new Set([...diskIds, ...getReservedMilestoneIds()])];
64
+ const preview = nextMilestoneId(allIds);
65
+ reserveMilestoneId(preview);
66
+ }
67
+
68
+ // Without cleanup, we're now at M007 instead of M004
69
+ const allIds = [...new Set([...diskIds, ...getReservedMilestoneIds()])];
70
+ const next = nextMilestoneId(allIds);
71
+ assert.equal(next, "M007", "3 cancelled sessions inflate ID by 3");
72
+
73
+ // With cleanup, we're back to M004
74
+ clearReservedMilestoneIds();
75
+ const allIdsClean = [...new Set([...diskIds, ...getReservedMilestoneIds()])];
76
+ const nextClean = nextMilestoneId(allIdsClean);
77
+ assert.equal(nextClean, "M004", "cleanup restores correct next ID");
78
+ });
79
+ });
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[8974],{5214:(e,t,n)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"workAsyncStorage",{enumerable:!0,get:function(){return r.workAsyncStorageInstance}});let r=n(17828)},15726:(e,t,n)=>{Promise.resolve().then(n.bind(n,66919))},17828:(e,t,n)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"workAsyncStorageInstance",{enumerable:!0,get:function(){return r}});let r=(0,n(64054).createAsyncLocalStorage)()},21957:(e,t,n)=>{"use strict";function r({moduleIds:e}){return null}Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"PreloadChunks",{enumerable:!0,get:function(){return r}}),n(95155),n(47650),n(5214),n(2451),n(53887)},37206:(e,t,n)=>{"use strict";n.d(t,{default:()=>u.a});var r=n(75707),u=n.n(r)},41112:(e,t,n)=>{"use strict";function r({reason:e,children:t}){return t}Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"BailoutToCSR",{enumerable:!0,get:function(){return r}}),n(1980)},64054:(e,t)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0});var n={bindSnapshot:function(){return s},createAsyncLocalStorage:function(){return a},createSnapshot:function(){return i}};for(var r in n)Object.defineProperty(t,r,{enumerable:!0,get:n[r]});let u=Object.defineProperty(Error("Invariant: AsyncLocalStorage accessed in runtime where it is not available"),"__NEXT_ERROR_CODE",{value:"E504",enumerable:!1,configurable:!0});class l{disable(){throw u}getStore(){}run(){throw u}exit(){throw u}enterWith(){throw u}static bind(e){return e}}let o="u">typeof globalThis&&globalThis.AsyncLocalStorage;function a(){return o?new o:new l}function s(e){return o?o.bind(e):l.bind(e)}function i(){return o?o.snapshot():function(e,...t){return e(...t)}}},66919:(e,t,n)=>{"use strict";n.r(t),n.d(t,{default:()=>l});var r=n(95155);let u=(0,n(37206).default)(()=>Promise.all([n.e(1838),n.e(6079),n.e(4986),n.e(485),n.e(4024)]).then(n.bind(n,4024)).then(e=>e.GSDAppShell),{loadableGenerated:{webpack:()=>[4024]},ssr:!1,loading:()=>(0,r.jsx)("div",{className:"flex h-screen items-center justify-center bg-background text-sm text-muted-foreground",children:"Loading workspace…"})});function l(){return(0,r.jsx)(u,{})}},68635:(e,t,n)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"default",{enumerable:!0,get:function(){return s}});let r=n(95155),u=n(12115),l=n(41112);function o(e){return{default:e&&"default"in e?e.default:e}}n(21957);let a={loader:()=>Promise.resolve(o(()=>null)),loading:null,ssr:!0},s=function(e){let t={...a,...e},n=(0,u.lazy)(()=>t.loader().then(o)),s=t.loading;function i(e){let o=s?(0,r.jsx)(s,{isLoading:!0,pastDelay:!0,error:null}):null,a=!t.ssr||!!t.loading,i=a?u.Suspense:u.Fragment,c=t.ssr?(0,r.jsxs)(r.Fragment,{children:[null,(0,r.jsx)(n,{...e})]}):(0,r.jsx)(l.BailoutToCSR,{reason:"next/dynamic",children:(0,r.jsx)(n,{...e})});return(0,r.jsx)(i,{...a?{fallback:o}:{},children:c})}return i.displayName="LoadableComponent",i}},75707:(e,t,n)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"default",{enumerable:!0,get:function(){return u}});let r=n(73623)._(n(68635));function u(e,t){let n={};"function"==typeof e&&(n.loader=e);let u={...n,...t};return(0,r.default)({...u,modules:u.loadableGenerated?.modules})}("function"==typeof t.default||"object"==typeof t.default&&null!==t.default)&&void 0===t.default.__esModule&&(Object.defineProperty(t.default,"__esModule",{value:!0}),Object.assign(t.default,t),e.exports=t.default)}},e=>{e.O(0,[8441,3794,7358],()=>e(e.s=15726)),_N_E=e.O()}]);
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[7358],{2852:(e,s,n)=>{Promise.resolve().then(n.t.bind(n,27123,23)),Promise.resolve().then(n.t.bind(n,61304,23)),Promise.resolve().then(n.t.bind(n,78616,23)),Promise.resolve().then(n.t.bind(n,64777,23)),Promise.resolve().then(n.t.bind(n,57121,23)),Promise.resolve().then(n.t.bind(n,74581,23)),Promise.resolve().then(n.t.bind(n,90484,23)),Promise.resolve().then(n.bind(n,86869))},19393:()=>{}},e=>{var s=s=>e(e.s=s);e.O(0,[8441,3794],()=>(s(83861),s(2852))),_N_E=e.O()}]);
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[9337],{52560:(e,s,_)=>{Promise.resolve().then(_.t.bind(_,27123,23))}},e=>{e.O(0,[8441,3794,7358],()=>e(e.s=52560)),_N_E=e.O()}]);