@fictjs/runtime 0.7.0 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +46 -0
- package/dist/advanced.cjs +9 -9
- package/dist/advanced.d.cts +4 -4
- package/dist/advanced.d.ts +4 -4
- package/dist/advanced.js +4 -4
- package/dist/{effect-DAzpH7Mm.d.cts → binding-BWchH3Kp.d.cts} +33 -24
- package/dist/{effect-DAzpH7Mm.d.ts → binding-BWchH3Kp.d.ts} +33 -24
- package/dist/{chunk-7YQK3XKY.js → chunk-DXG3TARY.js} +520 -518
- package/dist/chunk-DXG3TARY.js.map +1 -0
- package/dist/{chunk-TLDT76RV.js → chunk-FVX77557.js} +3 -3
- package/dist/{chunk-WRU3IZOA.js → chunk-JVYH76ZX.js} +3 -3
- package/dist/chunk-LBE6DC3V.cjs +768 -0
- package/dist/chunk-LBE6DC3V.cjs.map +1 -0
- package/dist/chunk-N6ODUM2Y.js +768 -0
- package/dist/chunk-N6ODUM2Y.js.map +1 -0
- package/dist/{chunk-PRF4QG73.cjs → chunk-OAM7HABA.cjs} +423 -246
- package/dist/chunk-OAM7HABA.cjs.map +1 -0
- package/dist/{chunk-CEV6TO5U.cjs → chunk-PD6IQY2Y.cjs} +8 -8
- package/dist/{chunk-CEV6TO5U.cjs.map → chunk-PD6IQY2Y.cjs.map} +1 -1
- package/dist/{chunk-HHDHQGJY.cjs → chunk-PG4QX2I2.cjs} +17 -17
- package/dist/{chunk-HHDHQGJY.cjs.map → chunk-PG4QX2I2.cjs.map} +1 -1
- package/dist/{chunk-4LCHQ7U4.js → chunk-T2LNV5Q5.js} +271 -94
- package/dist/chunk-T2LNV5Q5.js.map +1 -0
- package/dist/{chunk-FSCBL7RI.cjs → chunk-UBFDB6OL.cjs} +521 -519
- package/dist/chunk-UBFDB6OL.cjs.map +1 -0
- package/dist/{context-C4vBQbb4.d.ts → devtools-5AipK9CX.d.cts} +35 -35
- package/dist/{context-BFbHf9nC.d.cts → devtools-BDp76luf.d.ts} +35 -35
- package/dist/index.cjs +42 -42
- package/dist/index.d.cts +4 -4
- package/dist/index.d.ts +4 -4
- package/dist/index.dev.js +3 -3
- package/dist/index.dev.js.map +1 -1
- package/dist/index.js +3 -3
- package/dist/internal-list.cjs +12 -0
- package/dist/internal-list.cjs.map +1 -0
- package/dist/internal-list.d.cts +2 -0
- package/dist/internal-list.d.ts +2 -0
- package/dist/internal-list.js +12 -0
- package/dist/internal-list.js.map +1 -0
- package/dist/internal.cjs +6 -746
- package/dist/internal.cjs.map +1 -1
- package/dist/internal.d.cts +6 -74
- package/dist/internal.d.ts +6 -74
- package/dist/internal.js +12 -752
- package/dist/internal.js.map +1 -1
- package/dist/list-DL5DOFcO.d.ts +71 -0
- package/dist/list-hP7hQ9Vk.d.cts +71 -0
- package/dist/loader.cjs +94 -15
- package/dist/loader.cjs.map +1 -1
- package/dist/loader.d.cts +16 -2
- package/dist/loader.d.ts +16 -2
- package/dist/loader.js +87 -8
- package/dist/loader.js.map +1 -1
- package/dist/{props-84UJeWO8.d.cts → props-BpZz0AOq.d.cts} +2 -2
- package/dist/{props-BRhFK50f.d.ts → props-CjLH0JE-.d.ts} +2 -2
- package/dist/{resume-i-A3EFox.d.cts → resume-BJ4oHLi_.d.cts} +3 -1
- package/dist/{resume-CqeQ3v_q.d.ts → resume-CuyJWXP_.d.ts} +3 -1
- package/dist/{scope-DlCBL1Ft.d.cts → scope-BJCtq8hJ.d.cts} +1 -1
- package/dist/{scope-D3DpsfoG.d.ts → scope-jPt5DHRT.d.ts} +1 -1
- package/package.json +8 -1
- package/src/binding.ts +113 -36
- package/src/cycle-guard.ts +3 -3
- package/src/internal/list.ts +7 -0
- package/src/internal.ts +1 -0
- package/src/list-helpers.ts +1 -1
- package/src/loader.ts +119 -9
- package/src/resume.ts +6 -3
- package/src/signal.ts +8 -1
- package/dist/chunk-4LCHQ7U4.js.map +0 -1
- package/dist/chunk-7YQK3XKY.js.map +0 -1
- package/dist/chunk-FSCBL7RI.cjs.map +0 -1
- package/dist/chunk-PRF4QG73.cjs.map +0 -1
- /package/dist/{chunk-TLDT76RV.js.map → chunk-FVX77557.js.map} +0 -0
- /package/dist/{chunk-WRU3IZOA.js.map → chunk-JVYH76ZX.js.map} +0 -0
package/dist/index.cjs
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
|
|
4
4
|
|
|
5
|
-
var
|
|
5
|
+
var _chunkPG4QX2I2cjs = require('./chunk-PG4QX2I2.cjs');
|
|
6
6
|
|
|
7
7
|
|
|
8
8
|
|
|
@@ -19,7 +19,7 @@ var _chunkHHDHQGJYcjs = require('./chunk-HHDHQGJY.cjs');
|
|
|
19
19
|
|
|
20
20
|
|
|
21
21
|
|
|
22
|
-
var
|
|
22
|
+
var _chunkOAM7HABAcjs = require('./chunk-OAM7HABA.cjs');
|
|
23
23
|
|
|
24
24
|
|
|
25
25
|
|
|
@@ -40,7 +40,7 @@ var _chunkPRF4QG73cjs = require('./chunk-PRF4QG73.cjs');
|
|
|
40
40
|
|
|
41
41
|
|
|
42
42
|
|
|
43
|
-
var
|
|
43
|
+
var _chunkUBFDB6OLcjs = require('./chunk-UBFDB6OL.cjs');
|
|
44
44
|
|
|
45
45
|
// src/ref.ts
|
|
46
46
|
function createRef() {
|
|
@@ -52,7 +52,7 @@ function ErrorBoundary(props) {
|
|
|
52
52
|
const fragment = document.createDocumentFragment();
|
|
53
53
|
const marker = document.createComment("fict:error-boundary");
|
|
54
54
|
fragment.appendChild(marker);
|
|
55
|
-
const hostRoot =
|
|
55
|
+
const hostRoot = _chunkUBFDB6OLcjs.getCurrentRoot.call(void 0, );
|
|
56
56
|
let cleanup;
|
|
57
57
|
let activeNodes = [];
|
|
58
58
|
let renderingFallback = false;
|
|
@@ -70,25 +70,25 @@ function ErrorBoundary(props) {
|
|
|
70
70
|
cleanup = void 0;
|
|
71
71
|
}
|
|
72
72
|
if (activeNodes.length) {
|
|
73
|
-
|
|
73
|
+
_chunkOAM7HABAcjs.removeNodes.call(void 0, activeNodes);
|
|
74
74
|
activeNodes = [];
|
|
75
75
|
}
|
|
76
76
|
if (value == null || value === false) {
|
|
77
77
|
return;
|
|
78
78
|
}
|
|
79
|
-
const root =
|
|
80
|
-
const prev =
|
|
79
|
+
const root = _chunkUBFDB6OLcjs.createRootContext.call(void 0, hostRoot);
|
|
80
|
+
const prev = _chunkUBFDB6OLcjs.pushRoot.call(void 0, root);
|
|
81
81
|
let nodes = [];
|
|
82
82
|
try {
|
|
83
|
-
const output =
|
|
84
|
-
nodes =
|
|
83
|
+
const output = _chunkOAM7HABAcjs.createElement.call(void 0, value);
|
|
84
|
+
nodes = _chunkOAM7HABAcjs.toNodeArray.call(void 0, output);
|
|
85
85
|
const parentNode = marker.parentNode;
|
|
86
86
|
if (parentNode) {
|
|
87
|
-
|
|
87
|
+
_chunkOAM7HABAcjs.insertNodesBefore.call(void 0, parentNode, nodes, marker);
|
|
88
88
|
}
|
|
89
89
|
} catch (err) {
|
|
90
|
-
|
|
91
|
-
|
|
90
|
+
_chunkUBFDB6OLcjs.popRoot.call(void 0, prev);
|
|
91
|
+
_chunkUBFDB6OLcjs.destroyRoot.call(void 0, root);
|
|
92
92
|
if (renderingFallback) {
|
|
93
93
|
throw err;
|
|
94
94
|
}
|
|
@@ -103,11 +103,11 @@ function ErrorBoundary(props) {
|
|
|
103
103
|
}
|
|
104
104
|
return;
|
|
105
105
|
}
|
|
106
|
-
|
|
107
|
-
|
|
106
|
+
_chunkUBFDB6OLcjs.popRoot.call(void 0, prev);
|
|
107
|
+
_chunkUBFDB6OLcjs.flushOnMount.call(void 0, root);
|
|
108
108
|
cleanup = () => {
|
|
109
|
-
|
|
110
|
-
|
|
109
|
+
_chunkUBFDB6OLcjs.destroyRoot.call(void 0, root);
|
|
110
|
+
_chunkOAM7HABAcjs.removeNodes.call(void 0, nodes);
|
|
111
111
|
};
|
|
112
112
|
activeNodes = nodes;
|
|
113
113
|
};
|
|
@@ -116,7 +116,7 @@ function ErrorBoundary(props) {
|
|
|
116
116
|
renderValue(toView(null));
|
|
117
117
|
};
|
|
118
118
|
renderValue(_nullishCoalesce(props.children, () => ( null)));
|
|
119
|
-
|
|
119
|
+
_chunkUBFDB6OLcjs.registerErrorHandler.call(void 0, (err) => {
|
|
120
120
|
renderValue(toView(err));
|
|
121
121
|
_optionalChain([props, 'access', _5 => _5.onError, 'optionalCall', _6 => _6(err)]);
|
|
122
122
|
return true;
|
|
@@ -125,7 +125,7 @@ function ErrorBoundary(props) {
|
|
|
125
125
|
const isGetter = typeof props.resetKeys === "function" && props.resetKeys.length === 0;
|
|
126
126
|
const getter = isGetter ? props.resetKeys : void 0;
|
|
127
127
|
let prev = isGetter ? getter() : props.resetKeys;
|
|
128
|
-
|
|
128
|
+
_chunkUBFDB6OLcjs.createEffect.call(void 0, () => {
|
|
129
129
|
const next = getter ? getter() : props.resetKeys;
|
|
130
130
|
if (prev !== next) {
|
|
131
131
|
prev = next;
|
|
@@ -154,11 +154,11 @@ function createSuspenseToken() {
|
|
|
154
154
|
}
|
|
155
155
|
var isThenable = (value) => typeof value === "object" && value !== null && typeof value.then === "function";
|
|
156
156
|
function Suspense(props) {
|
|
157
|
-
const streamHooks =
|
|
158
|
-
const pending =
|
|
157
|
+
const streamHooks = _chunkUBFDB6OLcjs.__fictGetSSRStreamHooks.call(void 0, );
|
|
158
|
+
const pending = _chunkUBFDB6OLcjs.signal.call(void 0, 0);
|
|
159
159
|
let resolvedOnce = false;
|
|
160
160
|
let epoch = 0;
|
|
161
|
-
const hostRoot =
|
|
161
|
+
const hostRoot = _chunkUBFDB6OLcjs.getCurrentRoot.call(void 0, );
|
|
162
162
|
const toFallback = (err) => typeof props.fallback === "function" ? props.fallback(err) : props.fallback;
|
|
163
163
|
const renderView = (view) => {
|
|
164
164
|
if (cleanup) {
|
|
@@ -166,50 +166,50 @@ function Suspense(props) {
|
|
|
166
166
|
cleanup = void 0;
|
|
167
167
|
}
|
|
168
168
|
if (activeNodes.length) {
|
|
169
|
-
|
|
169
|
+
_chunkOAM7HABAcjs.removeNodes.call(void 0, activeNodes);
|
|
170
170
|
activeNodes = [];
|
|
171
171
|
}
|
|
172
172
|
if (view == null || view === false) {
|
|
173
173
|
return;
|
|
174
174
|
}
|
|
175
|
-
const root =
|
|
176
|
-
const prev =
|
|
175
|
+
const root = _chunkUBFDB6OLcjs.createRootContext.call(void 0, hostRoot);
|
|
176
|
+
const prev = _chunkUBFDB6OLcjs.pushRoot.call(void 0, root);
|
|
177
177
|
let nodes = [];
|
|
178
178
|
let boundaryPushed = false;
|
|
179
179
|
try {
|
|
180
180
|
if (streamBoundaryId) {
|
|
181
|
-
|
|
181
|
+
_chunkUBFDB6OLcjs.__fictPushSSRBoundary.call(void 0, streamBoundaryId);
|
|
182
182
|
boundaryPushed = true;
|
|
183
183
|
}
|
|
184
|
-
const output =
|
|
185
|
-
nodes =
|
|
184
|
+
const output = _chunkOAM7HABAcjs.createElement.call(void 0, view);
|
|
185
|
+
nodes = _chunkOAM7HABAcjs.toNodeArray.call(void 0, output);
|
|
186
186
|
const suspendedAttempt = root.suspended || nodes.length > 0 && nodes.every((node) => node instanceof Comment && node.data === "fict:suspend");
|
|
187
187
|
if (suspendedAttempt) {
|
|
188
|
-
|
|
189
|
-
|
|
188
|
+
_chunkUBFDB6OLcjs.popRoot.call(void 0, prev);
|
|
189
|
+
_chunkUBFDB6OLcjs.destroyRoot.call(void 0, root);
|
|
190
190
|
return;
|
|
191
191
|
}
|
|
192
192
|
const parentNode = endMarker.parentNode;
|
|
193
193
|
if (parentNode) {
|
|
194
|
-
|
|
194
|
+
_chunkOAM7HABAcjs.insertNodesBefore.call(void 0, parentNode, nodes, endMarker);
|
|
195
195
|
}
|
|
196
196
|
} catch (err) {
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
if (!
|
|
197
|
+
_chunkUBFDB6OLcjs.popRoot.call(void 0, prev);
|
|
198
|
+
_chunkUBFDB6OLcjs.destroyRoot.call(void 0, root);
|
|
199
|
+
if (!_chunkUBFDB6OLcjs.handleError.call(void 0, err, { source: "render" }, hostRoot)) {
|
|
200
200
|
throw err;
|
|
201
201
|
}
|
|
202
202
|
return;
|
|
203
203
|
} finally {
|
|
204
204
|
if (boundaryPushed) {
|
|
205
|
-
|
|
205
|
+
_chunkUBFDB6OLcjs.__fictPopSSRBoundary.call(void 0, _nullishCoalesce(streamBoundaryId, () => ( void 0)));
|
|
206
206
|
}
|
|
207
207
|
}
|
|
208
|
-
|
|
209
|
-
|
|
208
|
+
_chunkUBFDB6OLcjs.popRoot.call(void 0, prev);
|
|
209
|
+
_chunkUBFDB6OLcjs.flushOnMount.call(void 0, root);
|
|
210
210
|
cleanup = () => {
|
|
211
|
-
|
|
212
|
-
|
|
211
|
+
_chunkUBFDB6OLcjs.destroyRoot.call(void 0, root);
|
|
212
|
+
_chunkOAM7HABAcjs.removeNodes.call(void 0, nodes);
|
|
213
213
|
};
|
|
214
214
|
activeNodes = nodes;
|
|
215
215
|
};
|
|
@@ -235,7 +235,7 @@ function Suspense(props) {
|
|
|
235
235
|
_optionalChain([props, 'access', _8 => _8.onResolve, 'optionalCall', _9 => _9()]);
|
|
236
236
|
}
|
|
237
237
|
};
|
|
238
|
-
|
|
238
|
+
_chunkUBFDB6OLcjs.registerSuspenseHandler.call(void 0, (token) => {
|
|
239
239
|
const tokenEpoch = epoch;
|
|
240
240
|
if (!streamPending && streamBoundaryId && _optionalChain([streamHooks, 'optionalAccess', _10 => _10.boundaryPending])) {
|
|
241
241
|
streamPending = true;
|
|
@@ -273,7 +273,7 @@ function Suspense(props) {
|
|
|
273
273
|
} catch (callbackError) {
|
|
274
274
|
rejectionError = callbackError;
|
|
275
275
|
}
|
|
276
|
-
const handled =
|
|
276
|
+
const handled = _chunkUBFDB6OLcjs.handleError.call(void 0, rejectionError, { source: "render" }, hostRoot);
|
|
277
277
|
if (!handled) {
|
|
278
278
|
if (_optionalChain([streamHooks, 'optionalAccess', _14 => _14.onError])) {
|
|
279
279
|
streamHooks.onError(rejectionError, _nullishCoalesce(streamBoundaryId, () => ( void 0)));
|
|
@@ -296,7 +296,7 @@ function Suspense(props) {
|
|
|
296
296
|
const isGetter = typeof props.resetKeys === "function" && props.resetKeys.length === 0;
|
|
297
297
|
const getter = isGetter ? props.resetKeys : void 0;
|
|
298
298
|
let prev = isGetter ? getter() : props.resetKeys;
|
|
299
|
-
|
|
299
|
+
_chunkUBFDB6OLcjs.createEffect.call(void 0, () => {
|
|
300
300
|
const next = getter ? getter() : props.resetKeys;
|
|
301
301
|
if (prev !== next) {
|
|
302
302
|
prev = next;
|
|
@@ -338,5 +338,5 @@ function Suspense(props) {
|
|
|
338
338
|
|
|
339
339
|
|
|
340
340
|
|
|
341
|
-
exports.ErrorBoundary = ErrorBoundary; exports.Fragment =
|
|
341
|
+
exports.ErrorBoundary = ErrorBoundary; exports.Fragment = _chunkOAM7HABAcjs.Fragment; exports.Suspense = Suspense; exports.batch = _chunkOAM7HABAcjs.batch; exports.createContext = _chunkPG4QX2I2cjs.createContext; exports.createEffect = _chunkUBFDB6OLcjs.createEffect; exports.createElement = _chunkOAM7HABAcjs.createElement; exports.createMemo = _chunkUBFDB6OLcjs.createMemo; exports.createPortal = _chunkOAM7HABAcjs.createPortal; exports.createRef = createRef; exports.createRoot = _chunkUBFDB6OLcjs.createRoot; exports.createSuspenseToken = createSuspenseToken; exports.hasContext = _chunkPG4QX2I2cjs.hasContext; exports.keyed = _chunkOAM7HABAcjs.keyed; exports.mergeProps = _chunkOAM7HABAcjs.mergeProps; exports.onCleanup = _chunkUBFDB6OLcjs.onCleanup; exports.onDestroy = _chunkUBFDB6OLcjs.onDestroy; exports.onMount = _chunkUBFDB6OLcjs.onMount; exports.prop = _chunkOAM7HABAcjs.prop; exports.render = _chunkOAM7HABAcjs.render; exports.startTransition = _chunkOAM7HABAcjs.startTransition; exports.untrack = _chunkOAM7HABAcjs.untrack; exports.useContext = _chunkPG4QX2I2cjs.useContext; exports.useDeferredValue = _chunkOAM7HABAcjs.useDeferredValue; exports.useTransition = _chunkOAM7HABAcjs.useTransition;
|
|
342
342
|
//# sourceMappingURL=index.cjs.map
|
package/dist/index.d.cts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
export { F as Fragment, J as JSX, M as Memo,
|
|
2
|
-
import {
|
|
3
|
-
export {
|
|
4
|
-
export { C as Context, F as FictDevtoolsHook, P as ProviderProps, c as createContext, h as hasContext, u as useContext } from './
|
|
1
|
+
export { F as Fragment, J as JSX, M as Memo, d as createElement, c as createMemo, k as keyed, m as mergeProps, p as prop, r as render } from './props-BpZz0AOq.cjs';
|
|
2
|
+
import { S as RefObject, B as BaseProps, F as FictNode, T as SuspenseToken } from './binding-BWchH3Kp.cjs';
|
|
3
|
+
export { a3 as ClassProp, Z as Cleanup, _ as Component, R as DOMElement, U as Effect, a5 as ErrorInfo, a4 as EventHandler, Y as FictVNode, $ as PropsWithChildren, a0 as Ref, a1 as RefCallback, a2 as StyleProp, j as createEffect, E as createPortal, X as createRoot, W as onCleanup, N as onDestroy, V as onMount } from './binding-BWchH3Kp.cjs';
|
|
4
|
+
export { C as Context, F as FictDevtoolsHook, P as ProviderProps, c as createContext, h as hasContext, u as useContext } from './devtools-5AipK9CX.cjs';
|
|
5
5
|
import './signal-C4ISF17w.cjs';
|
|
6
6
|
|
|
7
7
|
/**
|
package/dist/index.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
export { F as Fragment, J as JSX, M as Memo,
|
|
2
|
-
import {
|
|
3
|
-
export {
|
|
4
|
-
export { C as Context, F as FictDevtoolsHook, P as ProviderProps, c as createContext, h as hasContext, u as useContext } from './
|
|
1
|
+
export { F as Fragment, J as JSX, M as Memo, d as createElement, c as createMemo, k as keyed, m as mergeProps, p as prop, r as render } from './props-CjLH0JE-.js';
|
|
2
|
+
import { S as RefObject, B as BaseProps, F as FictNode, T as SuspenseToken } from './binding-BWchH3Kp.js';
|
|
3
|
+
export { a3 as ClassProp, Z as Cleanup, _ as Component, R as DOMElement, U as Effect, a5 as ErrorInfo, a4 as EventHandler, Y as FictVNode, $ as PropsWithChildren, a0 as Ref, a1 as RefCallback, a2 as StyleProp, j as createEffect, E as createPortal, X as createRoot, W as onCleanup, N as onDestroy, V as onMount } from './binding-BWchH3Kp.js';
|
|
4
|
+
export { C as Context, F as FictDevtoolsHook, P as ProviderProps, c as createContext, h as hasContext, u as useContext } from './devtools-BDp76luf.js';
|
|
5
5
|
import './signal-C4ISF17w.js';
|
|
6
6
|
|
|
7
7
|
/**
|
package/dist/index.dev.js
CHANGED
|
@@ -22,8 +22,8 @@ var enterRootGuard = () => true;
|
|
|
22
22
|
var exitRootGuard = () => {
|
|
23
23
|
};
|
|
24
24
|
var defaultOptions = {
|
|
25
|
-
//
|
|
26
|
-
enabled:
|
|
25
|
+
// DX-first in development, performance-first in production.
|
|
26
|
+
enabled: isDev,
|
|
27
27
|
maxFlushCyclesPerMicrotask: 1e4,
|
|
28
28
|
maxEffectRunsPerFlush: 2e4,
|
|
29
29
|
windowSize: 5,
|
|
@@ -1205,7 +1205,7 @@ var trackDependencyDevtools = () => {
|
|
|
1205
1205
|
};
|
|
1206
1206
|
var untrackDependencyDevtools = () => {
|
|
1207
1207
|
};
|
|
1208
|
-
if (
|
|
1208
|
+
if (true ? true : typeof process !== "undefined" && process.env?.NODE_ENV !== "production") {
|
|
1209
1209
|
let nextDevtoolsId = 0;
|
|
1210
1210
|
registerSignalDevtools = (node) => {
|
|
1211
1211
|
const hook = getDevtoolsHook();
|