nexa-runtime 0.4.21 → 0.5.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/dist/index.d.ts +14 -10
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +24 -9
- package/dist/index.js.map +1 -1
- package/dist/ssr/hydrate.js +5 -5
- package/dist/ssr/hydrate.js.map +1 -1
- package/dist/vdom/diff.d.ts +2 -9
- package/dist/vdom/diff.d.ts.map +1 -1
- package/dist/vdom/diff.js +18 -54
- package/dist/vdom/diff.js.map +1 -1
- package/dist/vdom/dom.d.ts +3 -0
- package/dist/vdom/dom.d.ts.map +1 -0
- package/dist/vdom/dom.js +114 -0
- package/dist/vdom/dom.js.map +1 -0
- package/dist/vdom/hmr.d.ts.map +1 -1
- package/dist/vdom/hmr.js +0 -1
- package/dist/vdom/hmr.js.map +1 -1
- package/dist/vdom/mountComponent.d.ts +2 -1
- package/dist/vdom/mountComponent.d.ts.map +1 -1
- package/dist/vdom/mountComponent.js +14 -7
- package/dist/vdom/mountComponent.js.map +1 -1
- package/dist/vdom/patch.d.ts +3 -2
- package/dist/vdom/patch.d.ts.map +1 -1
- package/dist/vdom/patch.js +47 -36
- package/dist/vdom/patch.js.map +1 -1
- package/dist/vdom/renderer.d.ts +30 -0
- package/dist/vdom/renderer.d.ts.map +1 -0
- package/dist/vdom/renderer.js +18 -0
- package/dist/vdom/renderer.js.map +1 -0
- package/dist/vdom/types.d.ts +8 -3
- package/dist/vdom/types.d.ts.map +1 -1
- package/dist/vdom/types.js.map +1 -1
- package/dist/vdom/unmount.d.ts +3 -2
- package/dist/vdom/unmount.d.ts.map +1 -1
- package/dist/vdom/unmount.js +12 -14
- package/dist/vdom/unmount.js.map +1 -1
- package/package.json +2 -2
package/dist/index.d.ts
CHANGED
|
@@ -1,11 +1,15 @@
|
|
|
1
|
-
export
|
|
2
|
-
export
|
|
3
|
-
export
|
|
4
|
-
export
|
|
5
|
-
export
|
|
6
|
-
export
|
|
7
|
-
export
|
|
8
|
-
export
|
|
9
|
-
export
|
|
10
|
-
export
|
|
1
|
+
export * from './vdom/h';
|
|
2
|
+
export * from './vdom/types';
|
|
3
|
+
export * from './vdom/renderer';
|
|
4
|
+
export * from './vdom/dom';
|
|
5
|
+
export * from './vdom/hmr';
|
|
6
|
+
export * from './vdom/scope';
|
|
7
|
+
export * from './vdom/transition';
|
|
8
|
+
export * from './component';
|
|
9
|
+
export * from './scheduler';
|
|
10
|
+
export * from './ssr/renderToString';
|
|
11
|
+
export * from './ssr/renderToStream';
|
|
12
|
+
export * from './ssr/hydrate';
|
|
13
|
+
export * from './directives';
|
|
14
|
+
export declare function mount(vnode: any, containerOrSelector: any): any;
|
|
11
15
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAA;AACxB,cAAc,cAAc,CAAA;AAC5B,cAAc,iBAAiB,CAAA;AAC/B,cAAc,YAAY,CAAA;AAC1B,cAAc,YAAY,CAAA;AAC1B,cAAc,cAAc,CAAA;AAC5B,cAAc,mBAAmB,CAAA;AACjC,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,sBAAsB,CAAA;AACpC,cAAc,sBAAsB,CAAA;AACpC,cAAc,eAAe,CAAA;AAC7B,cAAc,cAAc,CAAA;AAK5B,wBAAgB,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,mBAAmB,EAAE,GAAG,GAAG,GAAG,CAU/D"}
|
package/dist/index.js
CHANGED
|
@@ -1,10 +1,25 @@
|
|
|
1
|
-
export
|
|
2
|
-
export
|
|
3
|
-
export
|
|
4
|
-
export
|
|
5
|
-
export
|
|
6
|
-
export
|
|
7
|
-
export
|
|
8
|
-
export
|
|
9
|
-
export
|
|
1
|
+
export * from './vdom/h';
|
|
2
|
+
export * from './vdom/types';
|
|
3
|
+
export * from './vdom/renderer';
|
|
4
|
+
export * from './vdom/dom';
|
|
5
|
+
export * from './vdom/hmr';
|
|
6
|
+
export * from './vdom/scope';
|
|
7
|
+
export * from './vdom/transition';
|
|
8
|
+
export * from './component';
|
|
9
|
+
export * from './scheduler';
|
|
10
|
+
export * from './ssr/renderToString';
|
|
11
|
+
export * from './ssr/renderToStream';
|
|
12
|
+
export * from './ssr/hydrate';
|
|
13
|
+
export * from './directives';
|
|
14
|
+
import { mount as baseMount } from './vdom/patch';
|
|
15
|
+
import { domOptions } from './vdom/dom';
|
|
16
|
+
export function mount(vnode, containerOrSelector) {
|
|
17
|
+
const container = typeof containerOrSelector === 'string'
|
|
18
|
+
? domOptions.querySelector(containerOrSelector)
|
|
19
|
+
: containerOrSelector;
|
|
20
|
+
if (!container) {
|
|
21
|
+
throw new Error(`Target container not found: ${containerOrSelector}`);
|
|
22
|
+
}
|
|
23
|
+
return baseMount(vnode, container, domOptions);
|
|
24
|
+
}
|
|
10
25
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAA;AACxB,cAAc,cAAc,CAAA;AAC5B,cAAc,iBAAiB,CAAA;AAC/B,cAAc,YAAY,CAAA;AAC1B,cAAc,YAAY,CAAA;AAC1B,cAAc,cAAc,CAAA;AAC5B,cAAc,mBAAmB,CAAA;AACjC,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,sBAAsB,CAAA;AACpC,cAAc,sBAAsB,CAAA;AACpC,cAAc,eAAe,CAAA;AAC7B,cAAc,cAAc,CAAA;AAE5B,OAAO,EAAE,KAAK,IAAI,SAAS,EAAE,MAAM,cAAc,CAAA;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AAEvC,MAAM,UAAU,KAAK,CAAC,KAAU,EAAE,mBAAwB;IACxD,MAAM,SAAS,GAAG,OAAO,mBAAmB,KAAK,QAAQ;QACvD,CAAC,CAAC,UAAU,CAAC,aAAa,CAAC,mBAAmB,CAAC;QAC/C,CAAC,CAAC,mBAAmB,CAAA;IAEvB,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,+BAA+B,mBAAmB,EAAE,CAAC,CAAA;IACvE,CAAC;IAED,OAAO,SAAS,CAAC,KAAK,EAAE,SAAS,EAAE,UAAU,CAAC,CAAA;AAChD,CAAC"}
|
package/dist/ssr/hydrate.js
CHANGED
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
import { effect, signal } from 'nexa-reactivity';
|
|
2
2
|
import { Fragment } from '../vdom/types';
|
|
3
3
|
import { setCurrentInstance } from '../component/lifecycle';
|
|
4
|
-
import { mount } from '../vdom/patch';
|
|
4
|
+
import { mount, applyPatches } from '../vdom/patch';
|
|
5
5
|
import { diff } from '../vdom/diff';
|
|
6
|
-
import {
|
|
6
|
+
import { domOptions } from '../vdom/dom';
|
|
7
7
|
export function hydrate(vnode, container) {
|
|
8
8
|
const firstChild = container.firstChild;
|
|
9
9
|
if (firstChild) {
|
|
10
10
|
const result = hydrateNode(vnode, container, firstChild);
|
|
11
11
|
if (!result) {
|
|
12
12
|
container.innerHTML = '';
|
|
13
|
-
mount(vnode, container);
|
|
13
|
+
mount(vnode, container, domOptions);
|
|
14
14
|
}
|
|
15
15
|
}
|
|
16
16
|
else {
|
|
17
|
-
mount(vnode, container);
|
|
17
|
+
mount(vnode, container, domOptions);
|
|
18
18
|
}
|
|
19
19
|
}
|
|
20
20
|
function hydrateNode(vnode, parent, anchor) {
|
|
@@ -151,7 +151,7 @@ function hydrateComponent(vnode, parent, anchor) {
|
|
|
151
151
|
}
|
|
152
152
|
else {
|
|
153
153
|
const patches = diff(oldVNode, newVNode, parent);
|
|
154
|
-
applyPatches(patches);
|
|
154
|
+
applyPatches(patches, domOptions);
|
|
155
155
|
instance.vnode = newVNode;
|
|
156
156
|
}
|
|
157
157
|
oldVNode = newVNode;
|
package/dist/ssr/hydrate.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hydrate.js","sourceRoot":"","sources":["../../src/ssr/hydrate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAc,QAAQ,EAA0B,MAAM,eAAe,CAAA;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAA;AAC3D,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;
|
|
1
|
+
{"version":3,"file":"hydrate.js","sourceRoot":"","sources":["../../src/ssr/hydrate.ts"],"names":[],"mappings":"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"}
|
package/dist/vdom/diff.d.ts
CHANGED
|
@@ -1,10 +1,3 @@
|
|
|
1
|
-
import { type VNode } from './types';
|
|
2
|
-
export
|
|
3
|
-
type: 'create' | 'remove' | 'replace' | 'update' | 'move';
|
|
4
|
-
oldVNode?: VNode | null;
|
|
5
|
-
newVNode?: VNode | null;
|
|
6
|
-
parent: Node;
|
|
7
|
-
anchor: Node | null;
|
|
8
|
-
};
|
|
9
|
-
export declare function diff(oldVNode: VNode | null, newVNode: VNode, container: Node): PatchOp[];
|
|
1
|
+
import { type VNode, type PatchOp } from './types';
|
|
2
|
+
export declare function diff(oldVNode: VNode | null, newVNode: VNode, container: any): PatchOp[];
|
|
10
3
|
//# sourceMappingURL=diff.d.ts.map
|
package/dist/vdom/diff.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"diff.d.ts","sourceRoot":"","sources":["../../src/vdom/diff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"diff.d.ts","sourceRoot":"","sources":["../../src/vdom/diff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,OAAO,EAAE,MAAM,SAAS,CAAA;AAElD,wBAAgB,IAAI,CAAC,QAAQ,EAAE,KAAK,GAAG,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,GAAG,OAAO,EAAE,CAcvF"}
|
package/dist/vdom/diff.js
CHANGED
|
@@ -37,11 +37,19 @@ function diffVNode(oldV, newV, container, patches) {
|
|
|
37
37
|
return;
|
|
38
38
|
}
|
|
39
39
|
if (oldV._type === 'element') {
|
|
40
|
-
diffProps(oldV, newV
|
|
40
|
+
const propPatches = diffProps(oldV, newV);
|
|
41
|
+
if (propPatches.length > 0) {
|
|
42
|
+
patches.push({
|
|
43
|
+
type: 'patchProps',
|
|
44
|
+
newVNode: newV,
|
|
45
|
+
parent: container,
|
|
46
|
+
anchor: null,
|
|
47
|
+
props: propPatches
|
|
48
|
+
});
|
|
49
|
+
}
|
|
41
50
|
diffChildren(oldV, newV, patches);
|
|
42
51
|
}
|
|
43
52
|
else if (oldV._type === 'component') {
|
|
44
|
-
// Update component props and trigger update if needed
|
|
45
53
|
patches.push({
|
|
46
54
|
type: 'update',
|
|
47
55
|
oldVNode: oldV,
|
|
@@ -54,69 +62,25 @@ function diffVNode(oldV, newV, container, patches) {
|
|
|
54
62
|
diffChildren(oldV, newV, patches);
|
|
55
63
|
}
|
|
56
64
|
}
|
|
57
|
-
function diffProps(oldV, newV
|
|
65
|
+
function diffProps(oldV, newV) {
|
|
58
66
|
const oldProps = oldV.props ?? {};
|
|
59
67
|
const newProps = newV.props ?? {};
|
|
60
|
-
const
|
|
61
|
-
|
|
62
|
-
return;
|
|
63
|
-
for (const key of Object.keys(oldProps)) {
|
|
68
|
+
const patches = [];
|
|
69
|
+
for (const key in oldProps) {
|
|
64
70
|
if (key === 'key')
|
|
65
71
|
continue;
|
|
66
72
|
if (!(key in newProps)) {
|
|
67
|
-
|
|
68
|
-
const event = key.slice(2).toLowerCase();
|
|
69
|
-
el.removeEventListener(event, oldProps[key]);
|
|
70
|
-
}
|
|
71
|
-
else if (key === 'class' || key === 'className') {
|
|
72
|
-
el.removeAttribute('class');
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
el.removeAttribute(key);
|
|
76
|
-
}
|
|
73
|
+
patches.push({ key, prevValue: oldProps[key], nextValue: null });
|
|
77
74
|
}
|
|
78
75
|
}
|
|
79
|
-
for (const key
|
|
76
|
+
for (const key in newProps) {
|
|
80
77
|
if (key === 'key')
|
|
81
78
|
continue;
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
if (oldVal !== newVal) {
|
|
85
|
-
if (key.startsWith('on')) {
|
|
86
|
-
const event = key.slice(2).toLowerCase();
|
|
87
|
-
if (oldVal)
|
|
88
|
-
el.removeEventListener(event, oldVal);
|
|
89
|
-
el.addEventListener(event, newVal);
|
|
90
|
-
}
|
|
91
|
-
else if (key === 'class' || key === 'className') {
|
|
92
|
-
if (typeof newVal === 'string') {
|
|
93
|
-
el.setAttribute('class', newVal);
|
|
94
|
-
}
|
|
95
|
-
else if (newVal && typeof newVal === 'object') {
|
|
96
|
-
const classes = Array.isArray(newVal)
|
|
97
|
-
? newVal.filter(Boolean)
|
|
98
|
-
: Object.keys(newVal).filter(k => newVal[k]);
|
|
99
|
-
el.setAttribute('class', classes.join(' '));
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
else if (key === 'style') {
|
|
103
|
-
if (typeof newVal === 'string') {
|
|
104
|
-
el.setAttribute('style', newVal);
|
|
105
|
-
}
|
|
106
|
-
else if (newVal && typeof newVal === 'object') {
|
|
107
|
-
// Clear old styles first if it was an object
|
|
108
|
-
if (oldVal && typeof oldVal === 'object') {
|
|
109
|
-
for (const k of Object.keys(oldVal))
|
|
110
|
-
el.style[k] = '';
|
|
111
|
-
}
|
|
112
|
-
Object.assign(el.style, newVal);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
else {
|
|
116
|
-
el.setAttribute(key, String(newVal));
|
|
117
|
-
}
|
|
79
|
+
if (newProps[key] !== oldProps[key]) {
|
|
80
|
+
patches.push({ key, prevValue: oldProps[key], nextValue: newProps[key] });
|
|
118
81
|
}
|
|
119
82
|
}
|
|
83
|
+
return patches;
|
|
120
84
|
}
|
|
121
85
|
function diffChildren(oldV, newV, patches) {
|
|
122
86
|
const oldChildren = oldV.children ?? [];
|
package/dist/vdom/diff.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"diff.js","sourceRoot":"","sources":["../../src/vdom/diff.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"diff.js","sourceRoot":"","sources":["../../src/vdom/diff.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dom.d.ts","sourceRoot":"","sources":["../../src/vdom/dom.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,YAAY,CAAA;AAGjD,eAAO,MAAM,UAAU,EAAE,eAAe,CAAC,IAAI,EAAE,OAAO,CA4GrD,CAAA"}
|
package/dist/vdom/dom.js
ADDED
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { effect } from 'nexa-reactivity';
|
|
2
|
+
export const domOptions = {
|
|
3
|
+
patchProp(el, key, prevValue, nextValue) {
|
|
4
|
+
if (key === 'key')
|
|
5
|
+
return;
|
|
6
|
+
if (key === '_enter') {
|
|
7
|
+
const name = typeof nextValue === 'string' ? nextValue : 'v';
|
|
8
|
+
el.classList.add(`${name}-enter-from`, `${name}-enter-active`);
|
|
9
|
+
let ended = false;
|
|
10
|
+
const onEnd = () => {
|
|
11
|
+
if (ended)
|
|
12
|
+
return;
|
|
13
|
+
ended = true;
|
|
14
|
+
el.classList.remove(`${name}-enter-from`, `${name}-enter-to`, `${name}-enter-active`);
|
|
15
|
+
};
|
|
16
|
+
el.addEventListener('animationend', onEnd, { once: true });
|
|
17
|
+
el.addEventListener('transitionend', onEnd, { once: true });
|
|
18
|
+
setTimeout(onEnd, 300);
|
|
19
|
+
requestAnimationFrame(() => {
|
|
20
|
+
el.classList.remove(`${name}-enter-from`);
|
|
21
|
+
if (!ended)
|
|
22
|
+
el.classList.add(`${name}-enter-to`);
|
|
23
|
+
});
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
if (key.startsWith('on')) {
|
|
27
|
+
const event = key.slice(2).toLowerCase();
|
|
28
|
+
if (prevValue) {
|
|
29
|
+
el.removeEventListener(event, prevValue);
|
|
30
|
+
}
|
|
31
|
+
if (nextValue) {
|
|
32
|
+
el.addEventListener(event, nextValue);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
else if (key === 'class' || key === 'className') {
|
|
36
|
+
if (typeof nextValue === 'string') {
|
|
37
|
+
el.setAttribute('class', nextValue || '');
|
|
38
|
+
}
|
|
39
|
+
else if (nextValue && typeof nextValue === 'object') {
|
|
40
|
+
const classes = Array.isArray(nextValue)
|
|
41
|
+
? nextValue.filter(Boolean)
|
|
42
|
+
: Object.keys(nextValue).filter(k => nextValue[k]);
|
|
43
|
+
el.setAttribute('class', classes.join(' '));
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
else if (key === 'style') {
|
|
47
|
+
if (typeof nextValue === 'string') {
|
|
48
|
+
el.setAttribute('style', nextValue);
|
|
49
|
+
}
|
|
50
|
+
else if (nextValue && typeof nextValue === 'object') {
|
|
51
|
+
Object.assign(el.style, nextValue);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
else if (key === 'vShow') {
|
|
55
|
+
effect(() => {
|
|
56
|
+
el.style.display = nextValue.value ? '' : 'none';
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
else if (key === 'value') {
|
|
60
|
+
el.value = String(nextValue);
|
|
61
|
+
}
|
|
62
|
+
else if (key === 'htmlFor') {
|
|
63
|
+
el.setAttribute('for', String(nextValue));
|
|
64
|
+
}
|
|
65
|
+
else if (typeof nextValue === 'boolean') {
|
|
66
|
+
if (nextValue)
|
|
67
|
+
el.setAttribute(key, '');
|
|
68
|
+
else
|
|
69
|
+
el.removeAttribute(key);
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
if (nextValue == null) {
|
|
73
|
+
el.removeAttribute(key);
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
el.setAttribute(key, String(nextValue));
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
insert(el, parent, anchor = null) {
|
|
81
|
+
parent.insertBefore(el, anchor);
|
|
82
|
+
},
|
|
83
|
+
remove(el) {
|
|
84
|
+
const parent = el.parentNode;
|
|
85
|
+
if (parent) {
|
|
86
|
+
parent.removeChild(el);
|
|
87
|
+
}
|
|
88
|
+
},
|
|
89
|
+
createElement(tag) {
|
|
90
|
+
return document.createElement(tag);
|
|
91
|
+
},
|
|
92
|
+
createText(text) {
|
|
93
|
+
return document.createTextNode(text);
|
|
94
|
+
},
|
|
95
|
+
createComment(text) {
|
|
96
|
+
return document.createComment(text);
|
|
97
|
+
},
|
|
98
|
+
setText(node, text) {
|
|
99
|
+
node.nodeValue = text;
|
|
100
|
+
},
|
|
101
|
+
setElementText(el, text) {
|
|
102
|
+
el.textContent = text;
|
|
103
|
+
},
|
|
104
|
+
parentNode(node) {
|
|
105
|
+
return node.parentNode;
|
|
106
|
+
},
|
|
107
|
+
nextSibling(node) {
|
|
108
|
+
return node.nextSibling;
|
|
109
|
+
},
|
|
110
|
+
querySelector(selector) {
|
|
111
|
+
return document.querySelector(selector);
|
|
112
|
+
}
|
|
113
|
+
};
|
|
114
|
+
//# sourceMappingURL=dom.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dom.js","sourceRoot":"","sources":["../../src/vdom/dom.ts"],"names":[],"mappings":"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"}
|
package/dist/vdom/hmr.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hmr.d.ts","sourceRoot":"","sources":["../../src/vdom/hmr.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,iBAAiB,EAAE,MAAM,SAAS,CAAA;AAKhE,wBAAgB,iBAAiB,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,GAAG,IAAI,CAEnE;AAED,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,iBAAiB,GAAG,IAAI,CAUlE;AAED,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,iBAAiB,GAAG,IAAI,CAQpE;AAED,wBAAgB,eAAe,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,GAAG,IAAI,
|
|
1
|
+
{"version":3,"file":"hmr.d.ts","sourceRoot":"","sources":["../../src/vdom/hmr.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,iBAAiB,EAAE,MAAM,SAAS,CAAA;AAKhE,wBAAgB,iBAAiB,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,GAAG,IAAI,CAEnE;AAED,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,iBAAiB,GAAG,IAAI,CAUlE;AAED,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,iBAAiB,GAAG,IAAI,CAQpE;AAED,wBAAgB,eAAe,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,GAAG,IAAI,CAW9D"}
|
package/dist/vdom/hmr.js
CHANGED
|
@@ -29,7 +29,6 @@ export function reloadComponent(id, newComp) {
|
|
|
29
29
|
return;
|
|
30
30
|
for (const instance of instances) {
|
|
31
31
|
// Update the component definition
|
|
32
|
-
// Note: for SFCs, we mainly care about updating render()
|
|
33
32
|
instance.component.render = newComp.render;
|
|
34
33
|
// Trigger update
|
|
35
34
|
instance.update();
|
package/dist/vdom/hmr.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hmr.js","sourceRoot":"","sources":["../../src/vdom/hmr.ts"],"names":[],"mappings":"AAEA,MAAM,kBAAkB,GAAG,IAAI,GAAG,EAAkC,CAAA;AACpE,MAAM,cAAc,GAAG,IAAI,GAAG,EAAqB,CAAA;AAEnD,MAAM,UAAU,iBAAiB,CAAC,EAAU,EAAE,IAAe;IAC3D,cAAc,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,CAAA;AAC9B,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,QAA2B;IAC1D,MAAM,EAAE,GAAG,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;IACjD,IAAI,CAAC,EAAE;QAAE,OAAM;IAEf,IAAI,SAAS,GAAG,kBAAkB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IAC1C,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,SAAS,GAAG,IAAI,GAAG,EAAE,CAAA;QACrB,kBAAkB,CAAC,GAAG,CAAC,EAAE,EAAE,SAAS,CAAC,CAAA;IACvC,CAAC;IACD,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;AACzB,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,QAA2B;IAC5D,MAAM,EAAE,GAAG,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;IACjD,IAAI,CAAC,EAAE;QAAE,OAAM;IAEf,MAAM,SAAS,GAAG,kBAAkB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IAC5C,IAAI,SAAS,EAAE,CAAC;QACd,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;IAC5B,CAAC;AACH,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,OAAY;IACtD,MAAM,SAAS,GAAG,kBAAkB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IAC5C,IAAI,CAAC,SAAS;QAAE,OAAM;IAEtB,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;QACjC,kCAAkC;QAClC,
|
|
1
|
+
{"version":3,"file":"hmr.js","sourceRoot":"","sources":["../../src/vdom/hmr.ts"],"names":[],"mappings":"AAEA,MAAM,kBAAkB,GAAG,IAAI,GAAG,EAAkC,CAAA;AACpE,MAAM,cAAc,GAAG,IAAI,GAAG,EAAqB,CAAA;AAEnD,MAAM,UAAU,iBAAiB,CAAC,EAAU,EAAE,IAAe;IAC3D,cAAc,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,CAAA;AAC9B,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,QAA2B;IAC1D,MAAM,EAAE,GAAG,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;IACjD,IAAI,CAAC,EAAE;QAAE,OAAM;IAEf,IAAI,SAAS,GAAG,kBAAkB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IAC1C,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,SAAS,GAAG,IAAI,GAAG,EAAE,CAAA;QACrB,kBAAkB,CAAC,GAAG,CAAC,EAAE,EAAE,SAAS,CAAC,CAAA;IACvC,CAAC;IACD,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;AACzB,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,QAA2B;IAC5D,MAAM,EAAE,GAAG,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;IACjD,IAAI,CAAC,EAAE;QAAE,OAAM;IAEf,MAAM,SAAS,GAAG,kBAAkB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IAC5C,IAAI,SAAS,EAAE,CAAC;QACd,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;IAC5B,CAAC;AACH,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,OAAY;IACtD,MAAM,SAAS,GAAG,kBAAkB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IAC5C,IAAI,CAAC,SAAS;QAAE,OAAM;IAEtB,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;QACjC,kCAAkC;QAClC,QAAQ,CAAC,SAAS,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAA;QAE1C,iBAAiB;QACjB,QAAQ,CAAC,MAAM,EAAE,CAAA;IACnB,CAAC;AACH,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
import { type VNode } from './types';
|
|
2
|
-
|
|
2
|
+
import { type RendererOptions } from './renderer';
|
|
3
|
+
export declare function mountComponent(vnode: VNode, parent: any, options: RendererOptions, anchor?: any): any;
|
|
3
4
|
//# sourceMappingURL=mountComponent.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mountComponent.d.ts","sourceRoot":"","sources":["../../src/vdom/mountComponent.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,KAAK,EAAoC,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"mountComponent.d.ts","sourceRoot":"","sources":["../../src/vdom/mountComponent.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,KAAK,EAAoC,MAAM,SAAS,CAAA;AAOtE,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,YAAY,CAAA;AAIjD,wBAAgB,cAAc,CAC5B,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,GAAG,EACX,OAAO,EAAE,eAAe,EACxB,MAAM,GAAE,GAAU,GACjB,GAAG,CAoJL"}
|
|
@@ -7,7 +7,7 @@ import { mount, applyPatches } from './patch';
|
|
|
7
7
|
import { diff } from './diff';
|
|
8
8
|
import { registerInstance } from './hmr';
|
|
9
9
|
let currentComponent = null;
|
|
10
|
-
export function mountComponent(vnode, parent, anchor = null) {
|
|
10
|
+
export function mountComponent(vnode, parent, options, anchor = null) {
|
|
11
11
|
const comp = vnode.tag;
|
|
12
12
|
const prevComponent = currentComponent;
|
|
13
13
|
const hmrTrigger = signal(0);
|
|
@@ -73,10 +73,12 @@ export function mountComponent(vnode, parent, anchor = null) {
|
|
|
73
73
|
};
|
|
74
74
|
let setupState = {};
|
|
75
75
|
let renderFn = comp.render;
|
|
76
|
+
let setupReturnedRender = false;
|
|
76
77
|
if (comp.setup) {
|
|
77
78
|
const result = comp.setup(vnode.props ?? {}, setupCtx);
|
|
78
79
|
if (typeof result === 'function') {
|
|
79
80
|
renderFn = result;
|
|
81
|
+
setupReturnedRender = true;
|
|
80
82
|
}
|
|
81
83
|
else {
|
|
82
84
|
setupState = result;
|
|
@@ -85,7 +87,7 @@ export function mountComponent(vnode, parent, anchor = null) {
|
|
|
85
87
|
instance.setupState = setupState;
|
|
86
88
|
runLifecycle(instance, 'beforeMount');
|
|
87
89
|
let el = null;
|
|
88
|
-
if (renderFn) {
|
|
90
|
+
if (renderFn || comp.render) {
|
|
89
91
|
const ctx = {
|
|
90
92
|
...setupState,
|
|
91
93
|
get props() { return instance.props.value; },
|
|
@@ -97,13 +99,16 @@ export function mountComponent(vnode, parent, anchor = null) {
|
|
|
97
99
|
hmrTrigger.value; // Track HMR signal
|
|
98
100
|
try {
|
|
99
101
|
pushScope(comp.__scopeId);
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
102
|
+
// Use latest render function (setup return overrides definition render)
|
|
103
|
+
const currentRender = setupReturnedRender ? renderFn : instance.component.render;
|
|
104
|
+
const newVNode = currentRender(ctx);
|
|
105
|
+
if (!newVNode) {
|
|
106
|
+
popScope(comp.__scopeId);
|
|
103
107
|
return;
|
|
108
|
+
}
|
|
104
109
|
if (isFirstRender) {
|
|
105
110
|
instance.vnode = newVNode;
|
|
106
|
-
el = mount(newVNode, parent, anchor);
|
|
111
|
+
el = mount(newVNode, parent, options, anchor);
|
|
107
112
|
instance.mounted = true;
|
|
108
113
|
isFirstRender = false;
|
|
109
114
|
runLifecycle(instance, 'mounted');
|
|
@@ -111,13 +116,15 @@ export function mountComponent(vnode, parent, anchor = null) {
|
|
|
111
116
|
else {
|
|
112
117
|
runLifecycle(instance, 'beforeUpdate');
|
|
113
118
|
const patches = diff(oldVNode, newVNode, parent);
|
|
114
|
-
applyPatches(patches);
|
|
119
|
+
applyPatches(patches, options);
|
|
115
120
|
instance.vnode = newVNode;
|
|
116
121
|
runLifecycle(instance, 'updated');
|
|
117
122
|
}
|
|
123
|
+
popScope(comp.__scopeId);
|
|
118
124
|
oldVNode = newVNode;
|
|
119
125
|
}
|
|
120
126
|
catch (err) {
|
|
127
|
+
popScope(comp.__scopeId);
|
|
121
128
|
const boundary = getCurrentErrorBoundary();
|
|
122
129
|
if (boundary) {
|
|
123
130
|
boundary.handleError(err instanceof Error ? err : new Error(String(err)));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mountComponent.js","sourceRoot":"","sources":["../../src/vdom/mountComponent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAsC,QAAQ,EAAE,MAAM,SAAS,CAAA;AACtE,OAAO,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACzE,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AACpE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAC7C,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAC7C,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAA;AAC7B,OAAO,EAAE,gBAAgB,EAAE,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"mountComponent.js","sourceRoot":"","sources":["../../src/vdom/mountComponent.ts"],"names":[],"mappings":"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"}
|
package/dist/vdom/patch.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { type VNode, type PatchOp } from './types';
|
|
2
|
-
|
|
3
|
-
export declare function
|
|
2
|
+
import { type RendererOptions } from './renderer';
|
|
3
|
+
export declare function applyPatches(patches: PatchOp[], options: RendererOptions): void;
|
|
4
|
+
export declare function mount(vnode: VNode | any, parent: any, options: RendererOptions, anchor?: any): any;
|
|
4
5
|
//# sourceMappingURL=patch.d.ts.map
|
package/dist/vdom/patch.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"patch.d.ts","sourceRoot":"","sources":["../../src/vdom/patch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,OAAO,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"patch.d.ts","sourceRoot":"","sources":["../../src/vdom/patch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,OAAO,EAAE,MAAM,SAAS,CAAA;AAOlD,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,YAAY,CAAA;AAEjD,wBAAgB,YAAY,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,eAAe,GAAG,IAAI,CA+B/E;AAED,wBAAgB,KAAK,CACnB,KAAK,EAAE,KAAK,GAAG,GAAG,EAClB,MAAM,EAAE,GAAG,EACX,OAAO,EAAE,eAAe,EACxB,MAAM,GAAE,GAAU,GACjB,GAAG,CAuFL"}
|
package/dist/vdom/patch.js
CHANGED
|
@@ -1,66 +1,77 @@
|
|
|
1
1
|
import { h } from './h';
|
|
2
|
-
import { mountProps } from './mountProps';
|
|
3
2
|
import { mountComponent } from './mountComponent';
|
|
4
3
|
import { unmount, animateLeave } from './unmount';
|
|
5
4
|
import { applyEnterClasses } from './transition';
|
|
6
5
|
import { effect, batch } from 'nexa-reactivity';
|
|
7
6
|
import { currentScope } from './scope';
|
|
8
|
-
export function applyPatches(patches) {
|
|
7
|
+
export function applyPatches(patches, options) {
|
|
9
8
|
for (const patch of patches) {
|
|
10
9
|
switch (patch.type) {
|
|
11
10
|
case 'create':
|
|
12
|
-
mount(patch.newVNode, patch.parent, patch.anchor);
|
|
11
|
+
mount(patch.newVNode, patch.parent, options, patch.anchor);
|
|
13
12
|
break;
|
|
14
13
|
case 'remove': {
|
|
15
14
|
const vnode = patch.oldVNode;
|
|
16
15
|
const leave = vnode.props?._leave;
|
|
17
16
|
if (leave) {
|
|
18
|
-
animateLeave(vnode, patch.parent, leave);
|
|
17
|
+
animateLeave(vnode, patch.parent, leave, options);
|
|
19
18
|
}
|
|
20
19
|
else {
|
|
21
|
-
unmount(vnode, patch.parent);
|
|
20
|
+
unmount(vnode, patch.parent, options);
|
|
22
21
|
}
|
|
23
22
|
break;
|
|
24
23
|
}
|
|
25
24
|
case 'replace':
|
|
26
|
-
replaceNode(patch.oldVNode, patch.newVNode, patch.parent, patch.anchor);
|
|
25
|
+
replaceNode(patch.oldVNode, patch.newVNode, patch.parent, options, patch.anchor);
|
|
27
26
|
break;
|
|
28
27
|
case 'update':
|
|
29
|
-
updateNode(patch.newVNode);
|
|
28
|
+
updateNode(patch.newVNode, options);
|
|
29
|
+
break;
|
|
30
|
+
case 'patchProps':
|
|
31
|
+
if (patch.newVNode?.el && patch.props) {
|
|
32
|
+
for (const prop of patch.props) {
|
|
33
|
+
options.patchProp(patch.newVNode.el, prop.key, prop.prevValue, prop.nextValue);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
30
36
|
break;
|
|
31
37
|
}
|
|
32
38
|
}
|
|
33
39
|
}
|
|
34
|
-
export function mount(vnode, parent, anchor = null) {
|
|
40
|
+
export function mount(vnode, parent, options, anchor = null) {
|
|
35
41
|
if (!vnode)
|
|
36
42
|
return null;
|
|
37
43
|
if (vnode && !vnode._type && (typeof vnode === 'object' || typeof vnode === 'function')) {
|
|
38
44
|
vnode = h(vnode, null);
|
|
39
45
|
}
|
|
46
|
+
const { createElement, createText, createComment, insert, patchProp, setText, querySelector } = options;
|
|
40
47
|
switch (vnode._type) {
|
|
41
48
|
case 'text': {
|
|
42
|
-
const el =
|
|
49
|
+
const el = createText('');
|
|
43
50
|
vnode.el = el;
|
|
44
51
|
if (typeof vnode.text === 'function') {
|
|
45
52
|
effect(() => {
|
|
46
|
-
el
|
|
53
|
+
setText(el, String(vnode.text()));
|
|
47
54
|
});
|
|
48
55
|
}
|
|
49
56
|
else {
|
|
50
|
-
el
|
|
57
|
+
setText(el, vnode.text ?? '');
|
|
51
58
|
}
|
|
52
|
-
|
|
59
|
+
insert(el, parent, anchor);
|
|
53
60
|
return el;
|
|
54
61
|
}
|
|
55
62
|
case 'element': {
|
|
56
|
-
const el =
|
|
63
|
+
const el = createElement(vnode.tag);
|
|
57
64
|
vnode.el = el;
|
|
58
65
|
const scope = currentScope();
|
|
59
66
|
if (scope)
|
|
60
|
-
el
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
67
|
+
patchProp(el, scope, null, '');
|
|
68
|
+
if (vnode.props) {
|
|
69
|
+
for (const key in vnode.props) {
|
|
70
|
+
patchProp(el, key, null, vnode.props[key]);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
mountChildren(vnode, el, options);
|
|
74
|
+
insert(el, parent, anchor);
|
|
64
75
|
if (vnode.props?._transition) {
|
|
65
76
|
applyEnterClasses(vnode, vnode.props._transitionName || 'v');
|
|
66
77
|
}
|
|
@@ -70,29 +81,29 @@ export function mount(vnode, parent, anchor = null) {
|
|
|
70
81
|
const children = vnode.children ?? [];
|
|
71
82
|
let firstEl = null;
|
|
72
83
|
for (const child of children) {
|
|
73
|
-
const childEl = mount(child, parent, anchor);
|
|
84
|
+
const childEl = mount(child, parent, options, anchor);
|
|
74
85
|
if (!firstEl)
|
|
75
86
|
firstEl = childEl;
|
|
76
87
|
}
|
|
77
88
|
return firstEl;
|
|
78
89
|
}
|
|
79
90
|
case 'component': {
|
|
80
|
-
const el = mountComponent(vnode, parent, anchor);
|
|
91
|
+
const el = mountComponent(vnode, parent, options, anchor);
|
|
81
92
|
vnode.el = el;
|
|
82
93
|
return el;
|
|
83
94
|
}
|
|
84
95
|
case 'teleport': {
|
|
85
96
|
const targetSelector = vnode.props?.to;
|
|
86
97
|
const target = typeof targetSelector === 'string'
|
|
87
|
-
?
|
|
98
|
+
? querySelector(targetSelector)
|
|
88
99
|
: targetSelector;
|
|
89
100
|
if (target) {
|
|
90
|
-
const placeholder =
|
|
101
|
+
const placeholder = createComment('teleport');
|
|
91
102
|
vnode.el = placeholder;
|
|
92
|
-
|
|
103
|
+
insert(placeholder, parent, anchor);
|
|
93
104
|
const children = vnode.children ?? [];
|
|
94
105
|
for (const child of children) {
|
|
95
|
-
mount(child, target);
|
|
106
|
+
mount(child, target, options);
|
|
96
107
|
}
|
|
97
108
|
return placeholder;
|
|
98
109
|
}
|
|
@@ -101,24 +112,29 @@ export function mount(vnode, parent, anchor = null) {
|
|
|
101
112
|
}
|
|
102
113
|
return null;
|
|
103
114
|
}
|
|
104
|
-
function mountChildren(vnode, parent) {
|
|
115
|
+
function mountChildren(vnode, parent, options) {
|
|
105
116
|
const children = vnode.children ?? [];
|
|
106
117
|
for (const child of children) {
|
|
107
|
-
mount(child, parent);
|
|
118
|
+
mount(child, parent, options);
|
|
108
119
|
}
|
|
109
120
|
}
|
|
110
|
-
function replaceNode(oldV, newV, parent, anchor) {
|
|
121
|
+
function replaceNode(oldV, newV, parent, options, anchor) {
|
|
111
122
|
if (oldV.el) {
|
|
112
|
-
unmount(oldV, parent);
|
|
123
|
+
unmount(oldV, parent, options);
|
|
113
124
|
}
|
|
114
|
-
mount(newV, parent, anchor);
|
|
125
|
+
mount(newV, parent, options, anchor);
|
|
115
126
|
}
|
|
116
|
-
function updateNode(vnode) {
|
|
127
|
+
function updateNode(vnode, options) {
|
|
128
|
+
const { patchProp, setText } = options;
|
|
117
129
|
if (vnode._type === 'text' && vnode.el) {
|
|
118
|
-
vnode.el
|
|
130
|
+
setText(vnode.el, vnode.text ?? '');
|
|
119
131
|
}
|
|
120
132
|
else if (vnode._type === 'element' && vnode.el) {
|
|
121
|
-
|
|
133
|
+
if (vnode.props) {
|
|
134
|
+
for (const key in vnode.props) {
|
|
135
|
+
patchProp(vnode.el, key, null, vnode.props[key]);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
122
138
|
}
|
|
123
139
|
else if (vnode._type === 'component') {
|
|
124
140
|
const instance = vnode.component;
|
|
@@ -128,10 +144,5 @@ function updateNode(vnode) {
|
|
|
128
144
|
});
|
|
129
145
|
}
|
|
130
146
|
}
|
|
131
|
-
else if (vnode._type === 'teleport') {
|
|
132
|
-
// Handling teleport target changes is complex,
|
|
133
|
-
// usually we just diff children in the existing target.
|
|
134
|
-
// The diffing happens in applyPatches via Component updates.
|
|
135
|
-
}
|
|
136
147
|
}
|
|
137
148
|
//# sourceMappingURL=patch.js.map
|
package/dist/vdom/patch.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"patch.js","sourceRoot":"","sources":["../../src/vdom/patch.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AACvB,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"patch.js","sourceRoot":"","sources":["../../src/vdom/patch.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { type VNode } from './types';
|
|
2
|
+
export interface RendererOptions<HostNode = any, HostElement = any> {
|
|
3
|
+
patchProp(el: HostElement, key: string, prevValue: any, nextValue: any): void;
|
|
4
|
+
insert(el: HostNode, parent: HostElement, anchor?: HostNode | null): void;
|
|
5
|
+
remove(el: HostNode): void;
|
|
6
|
+
createElement(tag: string): HostElement;
|
|
7
|
+
createText(text: string): HostNode;
|
|
8
|
+
createComment(text: string): HostNode;
|
|
9
|
+
setText(node: HostNode, text: string): void;
|
|
10
|
+
setElementText(el: HostElement, text: string): void;
|
|
11
|
+
parentNode(node: HostNode): HostElement | null;
|
|
12
|
+
nextSibling(node: HostNode): HostNode | null;
|
|
13
|
+
querySelector(selector: string): HostElement | null;
|
|
14
|
+
}
|
|
15
|
+
export interface Renderer<HostElement = any> {
|
|
16
|
+
render(vnode: VNode | null, container: HostElement): void;
|
|
17
|
+
createApp(rootComponent: any): App<HostElement>;
|
|
18
|
+
}
|
|
19
|
+
export interface App<HostElement = any> {
|
|
20
|
+
mount(containerOrSelector: HostElement | string): void;
|
|
21
|
+
unmount(): void;
|
|
22
|
+
}
|
|
23
|
+
export declare function createRenderer<HostNode = any, HostElement = any>(_options: RendererOptions<HostNode, HostElement>): {
|
|
24
|
+
render: (_vnode: VNode | null, _container: HostElement) => void;
|
|
25
|
+
createApp: (_rootComponent: any) => {
|
|
26
|
+
mount: (_containerOrSelector: HostElement | string) => void;
|
|
27
|
+
unmount: () => void;
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=renderer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderer.d.ts","sourceRoot":"","sources":["../../src/vdom/renderer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,SAAS,CAAA;AAEpC,MAAM,WAAW,eAAe,CAAC,QAAQ,GAAG,GAAG,EAAE,WAAW,GAAG,GAAG;IAChE,SAAS,CACP,EAAE,EAAE,WAAW,EACf,GAAG,EAAE,MAAM,EACX,SAAS,EAAE,GAAG,EACd,SAAS,EAAE,GAAG,GACb,IAAI,CAAA;IACP,MAAM,CAAC,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,CAAC,EAAE,QAAQ,GAAG,IAAI,GAAG,IAAI,CAAA;IACzE,MAAM,CAAC,EAAE,EAAE,QAAQ,GAAG,IAAI,CAAA;IAC1B,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,WAAW,CAAA;IACvC,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAAA;IAClC,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAAA;IACrC,OAAO,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;IAC3C,cAAc,CAAC,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;IACnD,UAAU,CAAC,IAAI,EAAE,QAAQ,GAAG,WAAW,GAAG,IAAI,CAAA;IAC9C,WAAW,CAAC,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,IAAI,CAAA;IAC5C,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI,CAAA;CACpD;AAED,MAAM,WAAW,QAAQ,CAAC,WAAW,GAAG,GAAG;IACzC,MAAM,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI,EAAE,SAAS,EAAE,WAAW,GAAG,IAAI,CAAA;IACzD,SAAS,CAAC,aAAa,EAAE,GAAG,GAAG,GAAG,CAAC,WAAW,CAAC,CAAA;CAChD;AAED,MAAM,WAAW,GAAG,CAAC,WAAW,GAAG,GAAG;IACpC,KAAK,CAAC,mBAAmB,EAAE,WAAW,GAAG,MAAM,GAAG,IAAI,CAAA;IACtD,OAAO,IAAI,IAAI,CAAA;CAChB;AAED,wBAAgB,cAAc,CAAC,QAAQ,GAAG,GAAG,EAAE,WAAW,GAAG,GAAG,EAC9D,QAAQ,EAAE,eAAe,CAAC,QAAQ,EAAE,WAAW,CAAC;qBAG7B,KAAK,GAAG,IAAI,cAAc,WAAW;gCAG1B,GAAG;sCAEG,WAAW,GAAG,MAAM;;;EASzD"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export function createRenderer(_options) {
|
|
2
|
+
return {
|
|
3
|
+
render: (_vnode, _container) => {
|
|
4
|
+
// implementation provided by patch.ts functions for now
|
|
5
|
+
},
|
|
6
|
+
createApp: (_rootComponent) => {
|
|
7
|
+
return {
|
|
8
|
+
mount: (_containerOrSelector) => {
|
|
9
|
+
// ...
|
|
10
|
+
},
|
|
11
|
+
unmount: () => {
|
|
12
|
+
// ...
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=renderer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../src/vdom/renderer.ts"],"names":[],"mappings":"AA+BA,MAAM,UAAU,cAAc,CAC5B,QAAgD;IAEhD,OAAO;QACL,MAAM,EAAE,CAAC,MAAoB,EAAE,UAAuB,EAAE,EAAE;YACxD,wDAAwD;QAC1D,CAAC;QACD,SAAS,EAAE,CAAC,cAAmB,EAAE,EAAE;YACjC,OAAO;gBACL,KAAK,EAAE,CAAC,oBAA0C,EAAE,EAAE;oBACpD,MAAM;gBACR,CAAC;gBACD,OAAO,EAAE,GAAG,EAAE;oBACZ,MAAM;gBACR,CAAC;aACF,CAAA;QACH,CAAC;KACF,CAAA;AACH,CAAC"}
|
package/dist/vdom/types.d.ts
CHANGED
|
@@ -29,11 +29,16 @@ export type LifecycleHooks = {
|
|
|
29
29
|
unmounted: (() => void)[];
|
|
30
30
|
};
|
|
31
31
|
export type PatchOp = {
|
|
32
|
-
type: 'create' | 'remove' | 'replace' | 'update' | 'move';
|
|
32
|
+
type: 'create' | 'remove' | 'replace' | 'update' | 'move' | 'patchProps';
|
|
33
33
|
oldVNode?: VNode | null;
|
|
34
34
|
newVNode?: VNode | null;
|
|
35
|
-
parent:
|
|
36
|
-
anchor:
|
|
35
|
+
parent: any;
|
|
36
|
+
anchor: any | null;
|
|
37
|
+
props?: {
|
|
38
|
+
key: string;
|
|
39
|
+
prevValue: any;
|
|
40
|
+
nextValue: any;
|
|
41
|
+
}[];
|
|
37
42
|
};
|
|
38
43
|
export type VNode = {
|
|
39
44
|
_type: VNodeTypes;
|
package/dist/vdom/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/vdom/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG,SAAS,GAAG,MAAM,GAAG,UAAU,GAAG,WAAW,GAAG,UAAU,CAAA;AAEnF,MAAM,MAAM,SAAS,GAAG;IACtB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAC3B,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,YAAY,KAAK,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAC9E,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,KAAK,GAAG,IAAI,CAAA;IACnD,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,CAAA;IAC7C,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,KAAK,GAAG,IAAI,CAAC,CAAA;CACrE,CAAA;AAED,MAAM,MAAM,iBAAiB,GAAG;IAC9B,SAAS,EAAE,SAAS,CAAA;IACpB,KAAK,EAAE,GAAG,CAAA;IACV,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAC/B,KAAK,EAAE,KAAK,GAAG,IAAI,CAAA;IACnB,OAAO,EAAE,OAAO,CAAA;IAChB,SAAS,EAAE,cAAc,CAAA;IACzB,MAAM,EAAE,MAAM,IAAI,CAAA;CACnB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG;IAC3B,WAAW,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAA;IAC3B,OAAO,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAA;IACvB,YAAY,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAA;IAC5B,OAAO,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAA;IACvB,aAAa,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAA;IAC7B,SAAS,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAA;CAC1B,CAAA;AAED,MAAM,MAAM,OAAO,GAAG;IACpB,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,SAAS,GAAG,QAAQ,GAAG,MAAM,CAAA;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/vdom/types.ts"],"names":[],"mappings":"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"}
|
package/dist/vdom/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/vdom/types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/vdom/types.ts"],"names":[],"mappings":"AA2DA,MAAM,CAAC,MAAM,QAAQ,GAAkB,MAAM,CAAC,UAAU,CAAC,CAAA;AACzD,MAAM,CAAC,MAAM,QAAQ,GAAkB,MAAM,CAAC,UAAU,CAAC,CAAA"}
|
package/dist/vdom/unmount.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { type VNode } from './types';
|
|
2
|
-
|
|
3
|
-
export declare function
|
|
2
|
+
import { type RendererOptions } from './renderer';
|
|
3
|
+
export declare function unmount(vnode: VNode, parent: any, options: RendererOptions): void;
|
|
4
|
+
export declare function animateLeave(vnode: VNode, _parent: any, nameOrTrue: string | true, options: RendererOptions): void;
|
|
4
5
|
//# sourceMappingURL=unmount.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"unmount.d.ts","sourceRoot":"","sources":["../../src/vdom/unmount.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"unmount.d.ts","sourceRoot":"","sources":["../../src/vdom/unmount.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,SAAS,CAAA;AAGpC,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,YAAY,CAAA;AAEjD,wBAAgB,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,eAAe,GAAG,IAAI,CAoCjF;AAED,wBAAgB,YAAY,CAC1B,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,GAAG,EACZ,UAAU,EAAE,MAAM,GAAG,IAAI,EACzB,OAAO,EAAE,eAAe,GACvB,IAAI,CAsBN"}
|
package/dist/vdom/unmount.js
CHANGED
|
@@ -1,45 +1,43 @@
|
|
|
1
1
|
import { runLifecycle } from '../component/lifecycle';
|
|
2
2
|
import { unregisterInstance } from './hmr';
|
|
3
|
-
export function unmount(vnode, parent) {
|
|
3
|
+
export function unmount(vnode, parent, options) {
|
|
4
4
|
if (vnode._type === 'component') {
|
|
5
5
|
runLifecycle(vnode.component, 'beforeUnmount');
|
|
6
6
|
}
|
|
7
7
|
if (vnode.el) {
|
|
8
8
|
if (vnode._type === 'text' || vnode._type === 'element') {
|
|
9
|
-
|
|
10
|
-
vnode.el.parentNode.removeChild(vnode.el);
|
|
11
|
-
}
|
|
9
|
+
options.remove(vnode.el);
|
|
12
10
|
}
|
|
13
11
|
}
|
|
14
12
|
const children = vnode.children ?? [];
|
|
15
13
|
if (vnode._type === 'teleport') {
|
|
16
14
|
const targetSelector = vnode.props?.to;
|
|
17
|
-
const target =
|
|
18
|
-
?
|
|
19
|
-
: targetSelector
|
|
15
|
+
const target = typeof targetSelector === 'string'
|
|
16
|
+
? options.querySelector(targetSelector)
|
|
17
|
+
: targetSelector;
|
|
20
18
|
for (const child of children) {
|
|
21
|
-
unmount(child, target || parent);
|
|
19
|
+
unmount(child, target || parent, options);
|
|
22
20
|
}
|
|
23
21
|
}
|
|
24
22
|
else {
|
|
25
23
|
for (const child of children) {
|
|
26
|
-
unmount(child, parent);
|
|
24
|
+
unmount(child, parent, options);
|
|
27
25
|
}
|
|
28
26
|
}
|
|
29
27
|
if (vnode._type === 'component') {
|
|
30
28
|
const instance = vnode.component;
|
|
31
29
|
if (instance.vnode) {
|
|
32
|
-
unmount(instance.vnode, parent);
|
|
30
|
+
unmount(instance.vnode, parent, options);
|
|
33
31
|
}
|
|
34
32
|
unregisterInstance(instance);
|
|
35
33
|
runLifecycle(instance, 'unmounted');
|
|
36
34
|
vnode.component = null;
|
|
37
35
|
}
|
|
38
36
|
}
|
|
39
|
-
export function animateLeave(vnode, _parent, nameOrTrue) {
|
|
37
|
+
export function animateLeave(vnode, _parent, nameOrTrue, options) {
|
|
40
38
|
const el = vnode.el;
|
|
41
|
-
if (!el) {
|
|
42
|
-
unmount(vnode, _parent);
|
|
39
|
+
if (!el || typeof el.classList === 'undefined') {
|
|
40
|
+
unmount(vnode, _parent, options);
|
|
43
41
|
return;
|
|
44
42
|
}
|
|
45
43
|
const name = typeof nameOrTrue === 'string' ? nameOrTrue : 'v';
|
|
@@ -50,7 +48,7 @@ export function animateLeave(vnode, _parent, nameOrTrue) {
|
|
|
50
48
|
return;
|
|
51
49
|
ended = true;
|
|
52
50
|
el.classList.remove(`${name}-leave-from`, `${name}-leave-to`, `${name}-leave-active`);
|
|
53
|
-
unmount(vnode, _parent);
|
|
51
|
+
unmount(vnode, _parent, options);
|
|
54
52
|
};
|
|
55
53
|
el.addEventListener('animationend', onEnd, { once: true });
|
|
56
54
|
el.addEventListener('transitionend', onEnd, { once: true });
|
package/dist/vdom/unmount.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"unmount.js","sourceRoot":"","sources":["../../src/vdom/unmount.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"unmount.js","sourceRoot":"","sources":["../../src/vdom/unmount.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "nexa-runtime",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.5.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "./dist/index.js",
|
|
6
6
|
"module": "./dist/index.js",
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
"access": "public"
|
|
21
21
|
},
|
|
22
22
|
"peerDependencies": {
|
|
23
|
-
"nexa-reactivity": "0.
|
|
23
|
+
"nexa-reactivity": "0.5.0"
|
|
24
24
|
},
|
|
25
25
|
"scripts": {
|
|
26
26
|
"build": "tsc",
|