@lynx-js/react 0.111.2 → 0.112.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/CHANGELOG.md +19 -0
- package/components/lib/Page.js.map +1 -1
- package/components/src/Page.ts +2 -2
- package/package.json +10 -2
- package/refresh/.turbo/turbo-build.log +2 -2
- package/runtime/compat/index.d.ts +40 -0
- package/runtime/compat/index.js +15 -0
- package/runtime/lazy/compat.js +51 -0
- package/runtime/lazy/import.js +9 -0
- package/runtime/lazy/target.js +1 -0
- package/runtime/lib/debug/component-stack.js +2 -2
- package/runtime/lib/debug/component-stack.js.map +1 -1
- package/runtime/lib/debug/profile.js +2 -2
- package/runtime/lib/debug/profile.js.map +1 -1
- package/runtime/lib/index.js +3 -5
- package/runtime/lib/index.js.map +1 -1
- package/runtime/lib/lifecycle/patch/commit.js +2 -2
- package/runtime/lib/lifecycle/patch/commit.js.map +1 -1
- package/runtime/lib/lifecycle/patch/isMainThreadHydrating.d.ts +2 -0
- package/runtime/lib/lifecycle/patch/{isMainThreadHydrationFinished.js → isMainThreadHydrating.js} +5 -5
- package/runtime/lib/lifecycle/patch/isMainThreadHydrating.js.map +1 -0
- package/runtime/lib/lifecycle/patch/updateMainThread.js +20 -13
- package/runtime/lib/lifecycle/patch/updateMainThread.js.map +1 -1
- package/runtime/lib/lifecycle/reload.js +0 -2
- package/runtime/lib/lifecycle/reload.js.map +1 -1
- package/runtime/lib/lynx/lazy-bundle.js +0 -19
- package/runtime/lib/lynx/lazy-bundle.js.map +1 -1
- package/runtime/lib/lynx/performance.js +2 -2
- package/runtime/lib/lynx/performance.js.map +1 -1
- package/runtime/lib/lynx/runWithForce.js +2 -2
- package/runtime/lib/lynx/runWithForce.js.map +1 -1
- package/runtime/lib/lynx-api.js +17 -3
- package/runtime/lib/lynx-api.js.map +1 -1
- package/runtime/lib/lynx.js +7 -1
- package/runtime/lib/lynx.js.map +1 -1
- package/runtime/lib/renderToOpcodes/index.js +36 -11
- package/runtime/lib/renderToOpcodes/index.js.map +1 -1
- package/runtime/lib/snapshot/gesture.js +2 -2
- package/runtime/lib/snapshot/gesture.js.map +1 -1
- package/runtime/lib/snapshot/workletEvent.js +2 -2
- package/runtime/lib/snapshot/workletEvent.js.map +1 -1
- package/runtime/lib/snapshot/workletRef.js +2 -2
- package/runtime/lib/snapshot/workletRef.js.map +1 -1
- package/testing-library/dist/env/vitest.js +8 -6
- package/testing-library/dist/vitest-global-setup.js +0 -6
- package/testing-library/dist/vitest.config.js +1 -4
- package/transform/dist/wasm.cjs +1 -1
- package/runtime/lib/lifecycle/patch/isMainThreadHydrationFinished.d.ts +0 -2
- package/runtime/lib/lifecycle/patch/isMainThreadHydrationFinished.js.map +0 -1
package/runtime/lib/lynx-api.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
// Copyright 2024 The Lynx Authors. All rights reserved.
|
|
2
2
|
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
3
3
|
// LICENSE file in the root directory of this source tree.
|
|
4
|
-
import { render } from 'preact';
|
|
4
|
+
import { options, render } from 'preact';
|
|
5
5
|
import { createContext, createElement } from 'preact/compat';
|
|
6
6
|
import { useState } from 'preact/hooks';
|
|
7
7
|
import { factory, withInitDataInState } from './compat/initData.js';
|
|
@@ -20,13 +20,26 @@ import { __root } from './root.js';
|
|
|
20
20
|
*/
|
|
21
21
|
export const root = {
|
|
22
22
|
render: (jsx) => {
|
|
23
|
+
/* v8 ignore next 2 */
|
|
23
24
|
if (__MAIN_THREAD__) {
|
|
24
25
|
__root.__jsx = jsx;
|
|
25
26
|
}
|
|
26
27
|
else {
|
|
27
28
|
__root.__jsx = jsx;
|
|
28
|
-
|
|
29
|
-
|
|
29
|
+
let preactProcess = undefined;
|
|
30
|
+
// eslint-disable-next-line @typescript-eslint/unbound-method
|
|
31
|
+
const oldDebounceRendering = options.debounceRendering;
|
|
32
|
+
options.debounceRendering = (cb) => {
|
|
33
|
+
preactProcess = cb;
|
|
34
|
+
};
|
|
35
|
+
try {
|
|
36
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument
|
|
37
|
+
render(jsx, __root);
|
|
38
|
+
preactProcess?.();
|
|
39
|
+
}
|
|
40
|
+
finally {
|
|
41
|
+
options.debounceRendering = oldDebounceRendering;
|
|
42
|
+
}
|
|
30
43
|
if (__FIRST_SCREEN_SYNC_TIMING__ === 'immediately') {
|
|
31
44
|
// This is for cases where `root.render()` is called asynchronously,
|
|
32
45
|
// `firstScreen` message might have been reached.
|
|
@@ -37,6 +50,7 @@ export const root = {
|
|
|
37
50
|
}
|
|
38
51
|
}
|
|
39
52
|
},
|
|
53
|
+
/* v8 ignore next 3 */
|
|
40
54
|
registerDataProcessors: (dataProcessorDefinition) => {
|
|
41
55
|
lynx.registerDataProcessors(dataProcessorDefinition);
|
|
42
56
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lynx-api.js","sourceRoot":"","sources":["../src/lynx-api.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,yEAAyE;AACzE,0DAA0D;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;
|
|
1
|
+
{"version":3,"file":"lynx-api.js","sourceRoot":"","sources":["../src/lynx-api.ts"],"names":[],"mappings":"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"}
|
package/runtime/lib/lynx.js
CHANGED
|
@@ -45,8 +45,14 @@ if (typeof __ALOG__ !== 'undefined' && __ALOG__) {
|
|
|
45
45
|
}
|
|
46
46
|
if (__BACKGROUND__) {
|
|
47
47
|
// Trick Preact and TypeScript to accept our custom document adapter.
|
|
48
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
49
48
|
options.document = document;
|
|
49
|
+
if (lynx.queueMicrotask) {
|
|
50
|
+
options.requestAnimationFrame = callback => lynx.queueMicrotask(callback);
|
|
51
|
+
}
|
|
52
|
+
else if (globalThis.Promise) {
|
|
53
|
+
const realResolvedPromise = globalThis.Promise.resolve();
|
|
54
|
+
options.requestAnimationFrame = callback => void realResolvedPromise.then(callback);
|
|
55
|
+
}
|
|
50
56
|
setupBackgroundDocument();
|
|
51
57
|
injectTt();
|
|
52
58
|
addCtxNotFoundEventListener();
|
package/runtime/lib/lynx.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lynx.js","sourceRoot":"","sources":["../src/lynx.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,yEAAyE;AACzE,0DAA0D;AAC1D,OAAO,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AACjC,4DAA4D;AAC5D,OAAO,kBAAkB,CAAC;AAE1B,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAClE,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAE,2BAA2B,EAAE,MAAM,4BAA4B,CAAC;AACzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAC/E,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAExC,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAEtD,gHAAgH;AAChH,IAAI,eAAe,IAAI,OAAO,UAAU,CAAC,iBAAiB,KAAK,WAAW,EAAE,CAAC;IAC3E,gHAAgH;IAChH,UAAU,CAAC,iBAAiB,GAAG,CAAI,MAA2C,EAAE,MAAc,EAAE,EAAE;QAChG,OAAO,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC;IAC1B,CAAC,CAAC;AACJ,CAAC;AAED,IAAI,eAAe,EAAE,CAAC;IACpB,oBAAoB,EAAE,CAAC;IACvB,sBAAsB,EAAE,CAAC;IACzB,IAAI,OAAO,EAAE,CAAC;QACZ,kBAAkB,EAAE,CAAC;IACvB,CAAC;AACH,CAAC;AAED,IAAI,OAAO,EAAE,CAAC;IACZ,mBAAmB,EAAE,CAAC;AACxB,CAAC;AAED,sCAAsC;AACtC,IAAI,WAAW,EAAE,CAAC;IAChB,oDAAoD;IACpD,eAAe,EAAE,CAAC;AACpB,CAAC;AAED,IAAI,OAAO,QAAQ,KAAK,WAAW,IAAI,QAAQ,EAAE,CAAC;IAChD,kDAAkD;IAClD,QAAQ,EAAE,CAAC;AACb,CAAC;AAED,IAAI,cAAc,EAAE,CAAC;IACnB,qEAAqE;IACrE,
|
|
1
|
+
{"version":3,"file":"lynx.js","sourceRoot":"","sources":["../src/lynx.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,yEAAyE;AACzE,0DAA0D;AAC1D,OAAO,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AACjC,4DAA4D;AAC5D,OAAO,kBAAkB,CAAC;AAE1B,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAClE,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAE,2BAA2B,EAAE,MAAM,4BAA4B,CAAC;AACzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAC/E,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAExC,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAEtD,gHAAgH;AAChH,IAAI,eAAe,IAAI,OAAO,UAAU,CAAC,iBAAiB,KAAK,WAAW,EAAE,CAAC;IAC3E,gHAAgH;IAChH,UAAU,CAAC,iBAAiB,GAAG,CAAI,MAA2C,EAAE,MAAc,EAAE,EAAE;QAChG,OAAO,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC;IAC1B,CAAC,CAAC;AACJ,CAAC;AAED,IAAI,eAAe,EAAE,CAAC;IACpB,oBAAoB,EAAE,CAAC;IACvB,sBAAsB,EAAE,CAAC;IACzB,IAAI,OAAO,EAAE,CAAC;QACZ,kBAAkB,EAAE,CAAC;IACvB,CAAC;AACH,CAAC;AAED,IAAI,OAAO,EAAE,CAAC;IACZ,mBAAmB,EAAE,CAAC;AACxB,CAAC;AAED,sCAAsC;AACtC,IAAI,WAAW,EAAE,CAAC;IAChB,oDAAoD;IACpD,eAAe,EAAE,CAAC;AACpB,CAAC;AAED,IAAI,OAAO,QAAQ,KAAK,WAAW,IAAI,QAAQ,EAAE,CAAC;IAChD,kDAAkD;IAClD,QAAQ,EAAE,CAAC;AACb,CAAC;AAED,IAAI,cAAc,EAAE,CAAC;IACnB,qEAAqE;IACrE,OAAO,CAAC,QAAQ,GAAG,QAA+B,CAAC;IACnD,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;QACxB,OAAO,CAAC,qBAAqB,GAAG,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;IAC5E,CAAC;SAAM,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC;QAC9B,MAAM,mBAAmB,GAAG,UAAU,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;QACzD,OAAO,CAAC,qBAAqB,GAAG,QAAQ,CAAC,EAAE,CAAC,KAAK,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtF,CAAC;IACD,uBAAuB,EAAE,CAAC;IAC1B,QAAQ,EAAE,CAAC;IACX,2BAA2B,EAAE,CAAC;IAE9B,IAAI,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,MAAM,EAAE,CAAC,CAAA,CAAC;SACrC,CAAC;QACJ,iBAAiB,EAAE,CAAC;QACpB,aAAa,EAAE,CAAC;IAClB,CAAC;AACH,CAAC;AAED,YAAY,EAAE,CAAC"}
|
|
@@ -37,7 +37,7 @@ export function renderToString(vnode, context) {
|
|
|
37
37
|
parent[CHILDREN] = [vnode];
|
|
38
38
|
const opcodes = [];
|
|
39
39
|
try {
|
|
40
|
-
_renderToString(vnode, context || EMPTY_OBJ, false, undefined, parent, opcodes);
|
|
40
|
+
_renderToString(vnode, context || EMPTY_OBJ, false, undefined, parent, opcodes, 0);
|
|
41
41
|
}
|
|
42
42
|
finally {
|
|
43
43
|
// options._commit, we don't schedule any effects in this library right now,
|
|
@@ -64,7 +64,14 @@ export const __OpText = 3;
|
|
|
64
64
|
*/
|
|
65
65
|
function renderClassComponent(vnode, context) {
|
|
66
66
|
const type = /** @type {import("preact").ComponentClass<typeof vnode.props>} */ (vnode.type);
|
|
67
|
-
|
|
67
|
+
let c;
|
|
68
|
+
if (vnode[COMPONENT]) {
|
|
69
|
+
c = vnode[COMPONENT];
|
|
70
|
+
c.state = c[NEXT_STATE];
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
c = new type(vnode.props, context);
|
|
74
|
+
}
|
|
68
75
|
vnode[COMPONENT] = c;
|
|
69
76
|
c[VNODE] = vnode;
|
|
70
77
|
c.props = vnode.props;
|
|
@@ -92,7 +99,7 @@ function renderClassComponent(vnode, context) {
|
|
|
92
99
|
* @param {VNode} parent
|
|
93
100
|
* @param opcodes
|
|
94
101
|
*/
|
|
95
|
-
function _renderToString(vnode, context, isSvgMode, selectValue, parent, opcodes) {
|
|
102
|
+
function _renderToString(vnode, context, isSvgMode, selectValue, parent, opcodes, opcodesLength) {
|
|
96
103
|
// Ignore non-rendered VNodes/values
|
|
97
104
|
if (vnode == null || vnode === true || vnode === false || vnode === '') {
|
|
98
105
|
return;
|
|
@@ -111,7 +118,7 @@ function _renderToString(vnode, context, isSvgMode, selectValue, parent, opcodes
|
|
|
111
118
|
const child = vnode[i];
|
|
112
119
|
if (child == null || typeof child === 'boolean')
|
|
113
120
|
continue;
|
|
114
|
-
_renderToString(child, context, isSvgMode, selectValue, parent, opcodes);
|
|
121
|
+
_renderToString(child, context, isSvgMode, selectValue, parent, opcodes, opcodes.length);
|
|
115
122
|
}
|
|
116
123
|
return;
|
|
117
124
|
}
|
|
@@ -175,12 +182,30 @@ function _renderToString(vnode, context, isSvgMode, selectValue, parent, opcodes
|
|
|
175
182
|
&& rendered.key == null;
|
|
176
183
|
rendered = isTopLevelFragment ? rendered.props.children : rendered;
|
|
177
184
|
// Recurse into children before invoking the after-diff hook
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
185
|
+
try {
|
|
186
|
+
_renderToString(rendered, context, isSvgMode, selectValue, vnode, opcodes, opcodes.length);
|
|
187
|
+
}
|
|
188
|
+
catch (e) {
|
|
189
|
+
if (e && typeof e === 'object' && e.then && component && /* _childDidSuspend */ component.__c) {
|
|
190
|
+
component.setState({ /* _suspended */ __a: true });
|
|
191
|
+
if (component[DIRTY]) {
|
|
192
|
+
rendered = renderClassComponent(vnode, context);
|
|
193
|
+
component = vnode[COMPONENT];
|
|
194
|
+
opcodes.length = opcodesLength;
|
|
195
|
+
_renderToString(rendered, context, isSvgMode, selectValue, vnode, opcodes, opcodes.length);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
else {
|
|
199
|
+
throw e;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
finally {
|
|
203
|
+
if (afterDiff)
|
|
204
|
+
afterDiff(vnode);
|
|
205
|
+
vnode[PARENT] = undefined;
|
|
206
|
+
if (ummountHook)
|
|
207
|
+
ummountHook(vnode);
|
|
208
|
+
}
|
|
184
209
|
return;
|
|
185
210
|
}
|
|
186
211
|
let children;
|
|
@@ -211,7 +236,7 @@ function _renderToString(vnode, context, isSvgMode, selectValue, parent, opcodes
|
|
|
211
236
|
}
|
|
212
237
|
else if (children != null && children !== false && children !== true) {
|
|
213
238
|
// recurse into this element VNode's children
|
|
214
|
-
_renderToString(children, context, false, selectValue, vnode, opcodes);
|
|
239
|
+
_renderToString(children, context, false, selectValue, vnode, opcodes, opcodes.length);
|
|
215
240
|
}
|
|
216
241
|
if (afterDiff)
|
|
217
242
|
afterDiff(vnode);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/renderToOpcodes/index.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,yEAAyE;AACzE,0DAA0D;AAE1D;;;;GAIG;AAEH,cAAc;AAEd,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EACL,QAAQ,EACR,MAAM,EACN,SAAS,EACT,IAAI,EACJ,MAAM,EACN,KAAK,EACL,UAAU,EACV,MAAM,EACN,MAAM,EACN,YAAY,EACZ,KAAK,GACN,MAAM,gBAAgB,CAAC;AAExB,8CAA8C;AAE9C,MAAM,SAAS,GAAG,EAAE,CAAC;AACrB,MAAM,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,OAAO,CAAC;AAC9C,MAAM,MAAM,GAAG,eAAe,CAAC,MAAM,CAAC,MAAM,CAAC;AAE7C,2CAA2C;AAC3C,IAAI,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,CAAC;AAEnD;;;;GAIG;AACH,MAAM,UAAU,cAAc,CAAC,KAAU,EAAE,OAAY;IACrD,mEAAmE;IACnE,mEAAmE;IACnE,qEAAqE;IACrE,6DAA6D;IAC7D,sCAAsC;IACtC,MAAM,mBAAmB,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;IAClD,OAAO,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC;IAE7B,+DAA+D;IAC/D,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3B,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC5B,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC7B,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC;IAE9B,MAAM,MAAM,GAAG,CAAC,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IACjC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAE3B,MAAM,OAAO,GAAG,EAAE,CAAC;IAEnB,IAAI,CAAC;QACH,eAAe,CACb,KAAK,EACL,OAAO,IAAI,SAAS,EACpB,KAAK,EACL,SAAS,EACT,MAAM,EACN,OAAO,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/renderToOpcodes/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
3
3
|
// LICENSE file in the root directory of this source tree.
|
|
4
4
|
import { processGesture } from '../gesture/processGesture.js';
|
|
5
|
-
import {
|
|
5
|
+
import { isMainThreadHydrating } from '../lifecycle/patch/isMainThreadHydrating.js';
|
|
6
6
|
import { SnapshotInstance } from '../snapshot.js';
|
|
7
7
|
export function updateGesture(snapshot, expIndex, oldValue, elementIndex, workletType) {
|
|
8
8
|
if (!snapshot.__elements) {
|
|
@@ -13,7 +13,7 @@ export function updateGesture(snapshot, expIndex, oldValue, elementIndex, workle
|
|
|
13
13
|
}
|
|
14
14
|
const value = snapshot.__values[expIndex];
|
|
15
15
|
if (workletType === 'main-thread') {
|
|
16
|
-
processGesture(snapshot.__elements[elementIndex], value, oldValue,
|
|
16
|
+
processGesture(snapshot.__elements[elementIndex], value, oldValue, isMainThreadHydrating);
|
|
17
17
|
}
|
|
18
18
|
if (__PROFILE__) {
|
|
19
19
|
console.profileEnd();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"gesture.js","sourceRoot":"","sources":["../../src/snapshot/gesture.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,yEAAyE;AACzE,0DAA0D;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAE9D,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"gesture.js","sourceRoot":"","sources":["../../src/snapshot/gesture.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,yEAAyE;AACzE,0DAA0D;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAE9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,6CAA6C,CAAC;AACpF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,MAAM,UAAU,aAAa,CAC3B,QAA0B,EAC1B,QAAgB,EAChB,QAAa,EACb,YAAoB,EACpB,WAAmB;IAEnB,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC;QACzB,OAAO;IACT,CAAC;IACD,IAAI,WAAW,EAAE,CAAC;QAChB,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;IACnC,CAAC;IACD,MAAM,KAAK,GAAG,QAAQ,CAAC,QAAS,CAAC,QAAQ,CAAgB,CAAC;IAE1D,IAAI,WAAW,KAAK,aAAa,EAAE,CAAC;QAClC,cAAc,CAAC,QAAQ,CAAC,UAAU,CAAC,YAAY,CAAE,EAAE,KAAK,EAAE,QAAuB,EAAE,qBAAqB,CAAC,CAAC;IAC5G,CAAC;IACD,IAAI,WAAW,EAAE,CAAC;QAChB,OAAO,CAAC,UAAU,EAAE,CAAC;IACvB,CAAC;AACH,CAAC"}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
3
3
|
// LICENSE file in the root directory of this source tree.
|
|
4
4
|
import { onWorkletCtxUpdate } from '@lynx-js/react/worklet-runtime/bindings';
|
|
5
|
-
import {
|
|
5
|
+
import { isMainThreadHydrating } from '../lifecycle/patch/isMainThreadHydrating.js';
|
|
6
6
|
import { SnapshotInstance } from '../snapshot.js';
|
|
7
7
|
function updateWorkletEvent(snapshot, expIndex, oldValue, elementIndex, workletType, eventType, eventName) {
|
|
8
8
|
if (!snapshot.__elements) {
|
|
@@ -11,7 +11,7 @@ function updateWorkletEvent(snapshot, expIndex, oldValue, elementIndex, workletT
|
|
|
11
11
|
const value = (snapshot.__values[expIndex] || undefined) ?? {};
|
|
12
12
|
value._workletType = workletType;
|
|
13
13
|
if (workletType === 'main-thread') {
|
|
14
|
-
onWorkletCtxUpdate(value, oldValue,
|
|
14
|
+
onWorkletCtxUpdate(value, oldValue, isMainThreadHydrating, snapshot.__elements[elementIndex]);
|
|
15
15
|
const event = {
|
|
16
16
|
type: 'worklet',
|
|
17
17
|
value,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workletEvent.js","sourceRoot":"","sources":["../../src/snapshot/workletEvent.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,yEAAyE;AACzE,0DAA0D;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAG7E,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"workletEvent.js","sourceRoot":"","sources":["../../src/snapshot/workletEvent.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,yEAAyE;AACzE,0DAA0D;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAG7E,OAAO,EAAE,qBAAqB,EAAE,MAAM,6CAA6C,CAAC;AACpF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,SAAS,kBAAkB,CACzB,QAA0B,EAC1B,QAAgB,EAChB,QAAiB,EACjB,YAAoB,EACpB,WAAmB,EACnB,SAAiB,EACjB,SAAiB;IAEjB,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC;QACzB,OAAO;IACT,CAAC;IACD,MAAM,KAAK,GAAG,CAAC,QAAQ,CAAC,QAAS,CAAC,QAAQ,CAAY,IAAI,SAAS,CAAC,IAAI,EAAE,CAAC;IAC3E,KAAK,CAAC,YAAY,GAAG,WAAW,CAAC;IAEjC,IAAI,WAAW,KAAK,aAAa,EAAE,CAAC;QAClC,kBAAkB,CAAC,KAAK,EAAE,QAAQ,EAAE,qBAAqB,EAAE,QAAQ,CAAC,UAAU,CAAC,YAAY,CAAE,CAAC,CAAC;QAC/F,MAAM,KAAK,GAAG;YACZ,IAAI,EAAE,SAAS;YACf,KAAK;SACN,CAAC;QACF,UAAU,CAAC,QAAQ,CAAC,UAAU,CAAC,YAAY,CAAE,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;IAC9E,CAAC;AACH,CAAC;AAED,OAAO,EAAE,kBAAkB,EAAE,CAAC"}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
// Licensed under the Apache License Version 2.0 that can be found in the
|
|
3
3
|
// LICENSE file in the root directory of this source tree.
|
|
4
4
|
import { onWorkletCtxUpdate, runWorkletCtx, updateWorkletRef as update } from '@lynx-js/react/worklet-runtime/bindings';
|
|
5
|
-
import {
|
|
5
|
+
import { isMainThreadHydrating } from '../lifecycle/patch/isMainThreadHydrating.js';
|
|
6
6
|
let mtRefQueue = [];
|
|
7
7
|
export function applyRefQueue() {
|
|
8
8
|
const queue = mtRefQueue;
|
|
@@ -52,7 +52,7 @@ export function updateWorkletRef(snapshot, expIndex, oldValue, elementIndex, _wo
|
|
|
52
52
|
}
|
|
53
53
|
else if (value._wkltId) {
|
|
54
54
|
const element = snapshot.__elements[elementIndex];
|
|
55
|
-
onWorkletCtxUpdate(value, oldValue,
|
|
55
|
+
onWorkletCtxUpdate(value, oldValue, isMainThreadHydrating, element);
|
|
56
56
|
addToRefQueue(value, element);
|
|
57
57
|
/* v8 ignore next 3 */
|
|
58
58
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workletRef.js","sourceRoot":"","sources":["../../src/snapshot/workletRef.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,yEAAyE;AACzE,0DAA0D;AAE1D,OAAO,EAAE,kBAAkB,EAAE,aAAa,EAAE,gBAAgB,IAAI,MAAM,EAAE,MAAM,yCAAyC,CAAC;AAGxH,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"workletRef.js","sourceRoot":"","sources":["../../src/snapshot/workletRef.ts"],"names":[],"mappings":"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"}
|
|
@@ -327,21 +327,23 @@ function createPolyfills() {
|
|
|
327
327
|
};
|
|
328
328
|
const ee = new events();
|
|
329
329
|
ee.dispatchEvent = ({ type, data })=>{
|
|
330
|
-
const
|
|
331
|
-
lynxTestingEnv.switchToBackgroundThread();
|
|
330
|
+
const origin = __MAIN_THREAD__ ? 'CoreContext' : 'JSContext';
|
|
331
|
+
if ('CoreContext' === origin) lynxTestingEnv.switchToBackgroundThread();
|
|
332
|
+
else lynxTestingEnv.switchToMainThread();
|
|
332
333
|
ee.emit(type, {
|
|
333
|
-
data: data
|
|
334
|
+
data: data,
|
|
335
|
+
origin
|
|
334
336
|
});
|
|
335
|
-
if (
|
|
337
|
+
if ('CoreContext' === origin) lynxTestingEnv.switchToMainThread();
|
|
338
|
+
else lynxTestingEnv.switchToBackgroundThread();
|
|
336
339
|
};
|
|
337
340
|
ee.addEventListener = ee.addListener;
|
|
338
341
|
ee.removeEventListener = ee.removeListener;
|
|
339
342
|
const CoreContext = ee;
|
|
340
343
|
const JsContext = ee;
|
|
341
|
-
function __LoadLepusChunk(chunkName,
|
|
344
|
+
function __LoadLepusChunk(chunkName, _options) {
|
|
342
345
|
const isBackground = !__MAIN_THREAD__;
|
|
343
346
|
globalThis.lynxTestingEnv.switchToMainThread();
|
|
344
|
-
if (process.env['DEBUG']) console.log('__LoadLepusChunk', chunkName, options);
|
|
345
347
|
let ans;
|
|
346
348
|
if ('worklet-runtime' === chunkName) {
|
|
347
349
|
var _globalThis_onInitWorkletRuntime, _globalThis;
|
|
@@ -17,7 +17,6 @@ injectUpdateMainThread();
|
|
|
17
17
|
replaceCommitHook();
|
|
18
18
|
globalThis.onInitWorkletRuntime = ()=>{
|
|
19
19
|
if (onInitWorkletRuntime) onInitWorkletRuntime();
|
|
20
|
-
if (process.env.DEBUG) console.log('initWorkletRuntime');
|
|
21
20
|
lynx.setTimeout = setTimeout;
|
|
22
21
|
lynx.setInterval = setInterval;
|
|
23
22
|
lynx.clearTimeout = clearTimeout;
|
|
@@ -29,7 +28,6 @@ globalThis.onInitWorkletRuntime = ()=>{
|
|
|
29
28
|
};
|
|
30
29
|
globalThis.onInjectMainThreadGlobals = (target)=>{
|
|
31
30
|
if (onInjectMainThreadGlobals) onInjectMainThreadGlobals(target);
|
|
32
|
-
if (process.env.DEBUG) console.log('onInjectMainThreadGlobals');
|
|
33
31
|
snapshotInstanceManager.clear();
|
|
34
32
|
snapshotInstanceManager.nextId = 0;
|
|
35
33
|
target.__root = new SnapshotInstance('root');
|
|
@@ -57,7 +55,6 @@ globalThis.onInjectMainThreadGlobals = (target)=>{
|
|
|
57
55
|
};
|
|
58
56
|
globalThis.onInjectBackgroundThreadGlobals = (target)=>{
|
|
59
57
|
if (onInjectBackgroundThreadGlobals) onInjectBackgroundThreadGlobals(target);
|
|
60
|
-
if (process.env.DEBUG) console.log('onInjectBackgroundThreadGlobals');
|
|
61
58
|
backgroundSnapshotInstanceManager.clear();
|
|
62
59
|
backgroundSnapshotInstanceManager.nextId = 0;
|
|
63
60
|
target.__root = new BackgroundSnapshotInstance('root');
|
|
@@ -98,7 +95,6 @@ globalThis.onInjectBackgroundThreadGlobals = (target)=>{
|
|
|
98
95
|
};
|
|
99
96
|
globalThis.onResetLynxTestingEnv = ()=>{
|
|
100
97
|
if (onResetLynxTestingEnv) onResetLynxTestingEnv();
|
|
101
|
-
if (process.env.DEBUG) console.log('onResetLynxTestingEnv');
|
|
102
98
|
flushDelayedLifecycleEvents();
|
|
103
99
|
destroyWorklet();
|
|
104
100
|
lynxTestingEnv.switchToMainThread();
|
|
@@ -107,13 +103,11 @@ globalThis.onResetLynxTestingEnv = ()=>{
|
|
|
107
103
|
};
|
|
108
104
|
globalThis.onSwitchedToMainThread = ()=>{
|
|
109
105
|
if (onSwitchedToMainThread) onSwitchedToMainThread();
|
|
110
|
-
if (process.env.DEBUG) console.log('onSwitchedToMainThread');
|
|
111
106
|
setRoot(globalThis.__root);
|
|
112
107
|
options.document = globalThis._document;
|
|
113
108
|
};
|
|
114
109
|
globalThis.onSwitchedToBackgroundThread = ()=>{
|
|
115
110
|
if (onSwitchedToBackgroundThread) onSwitchedToBackgroundThread();
|
|
116
|
-
if (process.env.DEBUG) console.log('onSwitchedToBackgroundThread');
|
|
117
111
|
setRoot(globalThis.__root);
|
|
118
112
|
options.document = globalThis._document;
|
|
119
113
|
};
|
|
@@ -55,10 +55,7 @@ const createVitestConfig = async (options)=>{
|
|
|
55
55
|
enforce: 'pre',
|
|
56
56
|
transform (sourceText, sourcePath) {
|
|
57
57
|
const id = sourcePath;
|
|
58
|
-
if (id.endsWith('.css') || id.endsWith('.less') || id.endsWith('.scss'))
|
|
59
|
-
if (process.env['DEBUG']) console.log('ignoring css file', id);
|
|
60
|
-
return '';
|
|
61
|
-
}
|
|
58
|
+
if (id.endsWith('.css') || id.endsWith('.less') || id.endsWith('.scss')) return '';
|
|
62
59
|
const { transformReactLynxSync } = vitest_config_require('@lynx-js/react/transform');
|
|
63
60
|
const relativePath = normalizeSlashes(path.relative(vitest_config_dirname, sourcePath));
|
|
64
61
|
const basename = path.basename(sourcePath);
|