nexa-runtime 0.1.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/component/asyncComponent.d.ts +10 -0
- package/dist/component/asyncComponent.d.ts.map +1 -0
- package/dist/component/asyncComponent.js +70 -0
- package/dist/component/asyncComponent.js.map +1 -0
- package/dist/component/defineComponent.d.ts +3 -0
- package/dist/component/defineComponent.d.ts.map +1 -0
- package/dist/component/defineComponent.js +4 -0
- package/dist/component/defineComponent.js.map +1 -0
- package/dist/component/errorBoundary.d.ts +7 -0
- package/dist/component/errorBoundary.d.ts.map +1 -0
- package/dist/component/errorBoundary.js +33 -0
- package/dist/component/errorBoundary.js.map +1 -0
- package/dist/component/index.d.ts +6 -0
- package/dist/component/index.d.ts.map +1 -0
- package/dist/component/index.js +6 -0
- package/dist/component/index.js.map +1 -0
- package/dist/component/lifecycle.d.ts +14 -0
- package/dist/component/lifecycle.d.ts.map +1 -0
- package/dist/component/lifecycle.js +32 -0
- package/dist/component/lifecycle.js.map +1 -0
- package/dist/component/suspense.d.ts +9 -0
- package/dist/component/suspense.d.ts.map +1 -0
- package/dist/component/suspense.js +41 -0
- package/dist/component/suspense.js.map +1 -0
- package/dist/directives/index.d.ts +7 -0
- package/dist/directives/index.d.ts.map +1 -0
- package/dist/directives/index.js +27 -0
- package/dist/directives/index.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8 -0
- package/dist/index.js.map +1 -0
- package/dist/scheduler.d.ts +2 -0
- package/dist/scheduler.d.ts.map +1 -0
- package/dist/scheduler.js +18 -0
- package/dist/scheduler.js.map +1 -0
- package/dist/ssr/hydrate.d.ts +3 -0
- package/dist/ssr/hydrate.d.ts.map +1 -0
- package/dist/ssr/hydrate.js +149 -0
- package/dist/ssr/hydrate.js.map +1 -0
- package/dist/ssr/renderToStream.d.ts +3 -0
- package/dist/ssr/renderToStream.d.ts.map +1 -0
- package/dist/ssr/renderToStream.js +138 -0
- package/dist/ssr/renderToStream.js.map +1 -0
- package/dist/ssr/renderToString.d.ts +3 -0
- package/dist/ssr/renderToString.d.ts.map +1 -0
- package/dist/ssr/renderToString.js +129 -0
- package/dist/ssr/renderToString.js.map +1 -0
- package/dist/vdom/diff.d.ts +10 -0
- package/dist/vdom/diff.d.ts.map +1 -0
- package/dist/vdom/diff.js +127 -0
- package/dist/vdom/diff.js.map +1 -0
- package/dist/vdom/h.d.ts +4 -0
- package/dist/vdom/h.d.ts.map +1 -0
- package/dist/vdom/h.js +62 -0
- package/dist/vdom/h.js.map +1 -0
- package/dist/vdom/index.d.ts +6 -0
- package/dist/vdom/index.d.ts.map +1 -0
- package/dist/vdom/index.js +5 -0
- package/dist/vdom/index.js.map +1 -0
- package/dist/vdom/patch.d.ts +4 -0
- package/dist/vdom/patch.d.ts.map +1 -0
- package/dist/vdom/patch.js +324 -0
- package/dist/vdom/patch.js.map +1 -0
- package/dist/vdom/transition.d.ts +9 -0
- package/dist/vdom/transition.d.ts.map +1 -0
- package/dist/vdom/transition.js +53 -0
- package/dist/vdom/transition.js.map +1 -0
- package/dist/vdom/types.d.ts +47 -0
- package/dist/vdom/types.d.ts.map +1 -0
- package/dist/vdom/types.js +2 -0
- package/dist/vdom/types.js.map +1 -0
- package/package.json +28 -0
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import { Fragment } from '../vdom/types';
|
|
2
|
+
const voidElements = new Set([
|
|
3
|
+
'area', 'base', 'br', 'col', 'embed', 'hr', 'img', 'input',
|
|
4
|
+
'link', 'meta', 'param', 'source', 'track', 'wbr',
|
|
5
|
+
]);
|
|
6
|
+
export function renderToStream(vnode) {
|
|
7
|
+
let cancelled = false;
|
|
8
|
+
return new ReadableStream({
|
|
9
|
+
start(controller) {
|
|
10
|
+
try {
|
|
11
|
+
renderSync(vnode, controller);
|
|
12
|
+
}
|
|
13
|
+
finally {
|
|
14
|
+
if (!cancelled)
|
|
15
|
+
controller.close();
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
cancel() {
|
|
19
|
+
cancelled = true;
|
|
20
|
+
},
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
function renderSync(vnode, controller) {
|
|
24
|
+
switch (vnode._type) {
|
|
25
|
+
case 'text':
|
|
26
|
+
controller.enqueue(escapeHtml(vnode.text ?? ''));
|
|
27
|
+
return;
|
|
28
|
+
case 'element':
|
|
29
|
+
return renderElementSync(vnode, controller);
|
|
30
|
+
case 'fragment':
|
|
31
|
+
for (const child of vnode.children ?? []) {
|
|
32
|
+
renderSync(child, controller);
|
|
33
|
+
}
|
|
34
|
+
return;
|
|
35
|
+
case 'component':
|
|
36
|
+
return renderComponentSync(vnode, controller);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
function renderElementSync(vnode, controller) {
|
|
40
|
+
const tag = vnode.tag;
|
|
41
|
+
const props = vnode.props ?? {};
|
|
42
|
+
const children = vnode.children ?? [];
|
|
43
|
+
const attrs = renderAttrs(props);
|
|
44
|
+
const tagName = tag.toLowerCase();
|
|
45
|
+
if (voidElements.has(tagName)) {
|
|
46
|
+
controller.enqueue(`<${tagName}${attrs}>`);
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
controller.enqueue(`<${tagName}${attrs}>`);
|
|
50
|
+
for (const child of children) {
|
|
51
|
+
renderSync(child, controller);
|
|
52
|
+
}
|
|
53
|
+
controller.enqueue(`</${tagName}>`);
|
|
54
|
+
}
|
|
55
|
+
function renderComponentSync(vnode, controller) {
|
|
56
|
+
if (vnode.tag === Fragment) {
|
|
57
|
+
for (const child of vnode.children ?? []) {
|
|
58
|
+
renderSync(child, controller);
|
|
59
|
+
}
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
const comp = vnode.tag;
|
|
63
|
+
const setupCtx = {
|
|
64
|
+
emit: () => { },
|
|
65
|
+
slots: {
|
|
66
|
+
default: () => {
|
|
67
|
+
const children = vnode.children ?? [];
|
|
68
|
+
return children.length > 0 ? children[0] : null;
|
|
69
|
+
},
|
|
70
|
+
},
|
|
71
|
+
};
|
|
72
|
+
let setupState = {};
|
|
73
|
+
if (comp.setup) {
|
|
74
|
+
setupState = comp.setup(vnode.props ?? {}, setupCtx);
|
|
75
|
+
}
|
|
76
|
+
let result = null;
|
|
77
|
+
if (comp.render) {
|
|
78
|
+
result = comp.render({ ...setupState, props: vnode.props, $slots: setupCtx.slots });
|
|
79
|
+
}
|
|
80
|
+
if (!result)
|
|
81
|
+
return;
|
|
82
|
+
renderSync(result, controller);
|
|
83
|
+
}
|
|
84
|
+
function renderAttrs(props) {
|
|
85
|
+
const parts = [];
|
|
86
|
+
for (const key of Object.keys(props)) {
|
|
87
|
+
if (key === 'key' || key.startsWith('_') || key.startsWith('on'))
|
|
88
|
+
continue;
|
|
89
|
+
const val = props[key];
|
|
90
|
+
if (key === 'class' || key === 'className') {
|
|
91
|
+
if (typeof val === 'string' && val) {
|
|
92
|
+
parts.push(` class="${escapeAttr(val)}"`);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
else if (key === 'style') {
|
|
96
|
+
if (typeof val === 'string' && val) {
|
|
97
|
+
parts.push(` style="${escapeAttr(val)}"`);
|
|
98
|
+
}
|
|
99
|
+
else if (val && typeof val === 'object') {
|
|
100
|
+
const styleStr = Object.entries(val)
|
|
101
|
+
.map(([k, v]) => `${k.replace(/[A-Z]/g, m => `-${m.toLowerCase()}`)}:${v}`)
|
|
102
|
+
.join(';');
|
|
103
|
+
if (styleStr)
|
|
104
|
+
parts.push(` style="${escapeAttr(styleStr)}"`);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
else if (key === 'htmlFor') {
|
|
108
|
+
parts.push(` for="${escapeAttr(String(val))}"`);
|
|
109
|
+
}
|
|
110
|
+
else if (key === 'value') {
|
|
111
|
+
parts.push(` value="${escapeAttr(String(val))}"`);
|
|
112
|
+
}
|
|
113
|
+
else if (typeof val === 'boolean') {
|
|
114
|
+
if (val)
|
|
115
|
+
parts.push(` ${key}`);
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
parts.push(` ${key}="${escapeAttr(String(val))}"`);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
return parts.join('');
|
|
122
|
+
}
|
|
123
|
+
function escapeHtml(str) {
|
|
124
|
+
return str
|
|
125
|
+
.replace(/&/g, '&')
|
|
126
|
+
.replace(/</g, '<')
|
|
127
|
+
.replace(/>/g, '>')
|
|
128
|
+
.replace(/"/g, '"')
|
|
129
|
+
.replace(/'/g, ''');
|
|
130
|
+
}
|
|
131
|
+
function escapeAttr(str) {
|
|
132
|
+
return str
|
|
133
|
+
.replace(/&/g, '&')
|
|
134
|
+
.replace(/"/g, '"')
|
|
135
|
+
.replace(/</g, '<')
|
|
136
|
+
.replace(/>/g, '>');
|
|
137
|
+
}
|
|
138
|
+
//# sourceMappingURL=renderToStream.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderToStream.js","sourceRoot":"","sources":["../../src/ssr/renderToStream.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderToString.d.ts","sourceRoot":"","sources":["../../src/ssr/renderToString.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,eAAe,CAAA;AAQ1C,wBAAgB,cAAc,CAAC,KAAK,EAAE,KAAK,GAAG,MAAM,CAWnD"}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { Fragment } from '../vdom/types';
|
|
2
|
+
const voidElements = new Set([
|
|
3
|
+
'area', 'base', 'br', 'col', 'embed', 'hr', 'img', 'input',
|
|
4
|
+
'link', 'meta', 'param', 'source', 'track', 'wbr',
|
|
5
|
+
]);
|
|
6
|
+
export function renderToString(vnode) {
|
|
7
|
+
switch (vnode._type) {
|
|
8
|
+
case 'text':
|
|
9
|
+
return escapeHtml(vnode.text ?? '');
|
|
10
|
+
case 'element':
|
|
11
|
+
return renderElement(vnode);
|
|
12
|
+
case 'fragment':
|
|
13
|
+
return (vnode.children ?? []).map(renderToString).join('');
|
|
14
|
+
case 'component':
|
|
15
|
+
return renderComponentToString(vnode);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
function renderElement(vnode) {
|
|
19
|
+
const tag = vnode.tag;
|
|
20
|
+
const props = vnode.props ?? {};
|
|
21
|
+
const children = vnode.children ?? [];
|
|
22
|
+
const attrs = renderAttrs(props);
|
|
23
|
+
const tagName = tag.toLowerCase();
|
|
24
|
+
if (voidElements.has(tagName)) {
|
|
25
|
+
return `<${tagName}${attrs}>`;
|
|
26
|
+
}
|
|
27
|
+
const inner = children.map(renderToString).join('');
|
|
28
|
+
return `<${tagName}${attrs}>${inner}</${tagName}>`;
|
|
29
|
+
}
|
|
30
|
+
function renderAttrs(props) {
|
|
31
|
+
const parts = [];
|
|
32
|
+
for (const key of Object.keys(props)) {
|
|
33
|
+
if (key === 'key')
|
|
34
|
+
continue;
|
|
35
|
+
if (key.startsWith('on'))
|
|
36
|
+
continue;
|
|
37
|
+
const val = props[key];
|
|
38
|
+
if (key === 'class' || key === 'className') {
|
|
39
|
+
if (typeof val === 'string' && val) {
|
|
40
|
+
parts.push(` class="${escapeAttr(val)}"`);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
else if (key === 'style') {
|
|
44
|
+
if (typeof val === 'string' && val) {
|
|
45
|
+
parts.push(` style="${escapeAttr(val)}"`);
|
|
46
|
+
}
|
|
47
|
+
else if (val && typeof val === 'object') {
|
|
48
|
+
const styleStr = Object.entries(val)
|
|
49
|
+
.map(([k, v]) => `${k.replace(/[A-Z]/g, m => `-${m.toLowerCase()}`)}:${v}`)
|
|
50
|
+
.join(';');
|
|
51
|
+
if (styleStr)
|
|
52
|
+
parts.push(` style="${escapeAttr(styleStr)}"`);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
else if (key === 'htmlFor') {
|
|
56
|
+
parts.push(` for="${escapeAttr(String(val))}"`);
|
|
57
|
+
}
|
|
58
|
+
else if (key === 'value') {
|
|
59
|
+
parts.push(` value="${escapeAttr(String(val))}"`);
|
|
60
|
+
}
|
|
61
|
+
else if (typeof val === 'boolean') {
|
|
62
|
+
if (val)
|
|
63
|
+
parts.push(` ${key}`);
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
parts.push(` ${key}="${escapeAttr(String(val))}"`);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
return parts.join('');
|
|
70
|
+
}
|
|
71
|
+
function renderComponentToString(vnode) {
|
|
72
|
+
if (vnode.tag === Fragment) {
|
|
73
|
+
return (vnode.children ?? []).map(renderToString).join('');
|
|
74
|
+
}
|
|
75
|
+
const comp = vnode.tag;
|
|
76
|
+
const instance = {
|
|
77
|
+
component: comp,
|
|
78
|
+
props: vnode.props ?? {},
|
|
79
|
+
setupState: {},
|
|
80
|
+
vnode: null,
|
|
81
|
+
mounted: false,
|
|
82
|
+
lifecycle: {
|
|
83
|
+
beforeMount: [],
|
|
84
|
+
mounted: [],
|
|
85
|
+
beforeUpdate: [],
|
|
86
|
+
updated: [],
|
|
87
|
+
beforeUnmount: [],
|
|
88
|
+
unmounted: [],
|
|
89
|
+
},
|
|
90
|
+
};
|
|
91
|
+
vnode.component = instance;
|
|
92
|
+
const setupCtx = {
|
|
93
|
+
emit: () => { },
|
|
94
|
+
slots: {
|
|
95
|
+
default: () => {
|
|
96
|
+
const children = vnode.children ?? [];
|
|
97
|
+
return children.length > 0 ? children[0] : null;
|
|
98
|
+
},
|
|
99
|
+
},
|
|
100
|
+
};
|
|
101
|
+
let setupState = {};
|
|
102
|
+
if (comp.setup) {
|
|
103
|
+
setupState = comp.setup(vnode.props ?? {}, setupCtx);
|
|
104
|
+
}
|
|
105
|
+
instance.setupState = setupState;
|
|
106
|
+
let result = null;
|
|
107
|
+
if (comp.render) {
|
|
108
|
+
result = comp.render({ ...setupState, props: vnode.props, $slots: setupCtx.slots });
|
|
109
|
+
}
|
|
110
|
+
if (!result)
|
|
111
|
+
return '';
|
|
112
|
+
return renderToString(result);
|
|
113
|
+
}
|
|
114
|
+
function escapeHtml(str) {
|
|
115
|
+
return str
|
|
116
|
+
.replace(/&/g, '&')
|
|
117
|
+
.replace(/</g, '<')
|
|
118
|
+
.replace(/>/g, '>')
|
|
119
|
+
.replace(/"/g, '"')
|
|
120
|
+
.replace(/'/g, ''');
|
|
121
|
+
}
|
|
122
|
+
function escapeAttr(str) {
|
|
123
|
+
return str
|
|
124
|
+
.replace(/&/g, '&')
|
|
125
|
+
.replace(/"/g, '"')
|
|
126
|
+
.replace(/</g, '<')
|
|
127
|
+
.replace(/>/g, '>');
|
|
128
|
+
}
|
|
129
|
+
//# sourceMappingURL=renderToString.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderToString.js","sourceRoot":"","sources":["../../src/ssr/renderToString.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAExC,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC;IAC3B,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO;IAC1D,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK;CAClD,CAAC,CAAA;AAEF,MAAM,UAAU,cAAc,CAAC,KAAY;IACzC,QAAQ,KAAK,CAAC,KAAK,EAAE,CAAC;QACpB,KAAK,MAAM;YACT,OAAO,UAAU,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC,CAAA;QACrC,KAAK,SAAS;YACZ,OAAO,aAAa,CAAC,KAAK,CAAC,CAAA;QAC7B,KAAK,UAAU;YACb,OAAO,CAAC,KAAK,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAC5D,KAAK,WAAW;YACd,OAAO,uBAAuB,CAAC,KAAK,CAAC,CAAA;IACzC,CAAC;AACH,CAAC;AAED,SAAS,aAAa,CAAC,KAAY;IACjC,MAAM,GAAG,GAAG,KAAK,CAAC,GAAa,CAAA;IAC/B,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,EAAE,CAAA;IAC/B,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,IAAI,EAAE,CAAA;IAErC,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,CAAA;IAChC,MAAM,OAAO,GAAG,GAAG,CAAC,WAAW,EAAE,CAAA;IAEjC,IAAI,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC;QAC9B,OAAO,IAAI,OAAO,GAAG,KAAK,GAAG,CAAA;IAC/B,CAAC;IAED,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;IACnD,OAAO,IAAI,OAAO,GAAG,KAAK,IAAI,KAAK,KAAK,OAAO,GAAG,CAAA;AACpD,CAAC;AAED,SAAS,WAAW,CAAC,KAA0B;IAC7C,MAAM,KAAK,GAAa,EAAE,CAAA;IAE1B,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QACrC,IAAI,GAAG,KAAK,KAAK;YAAE,SAAQ;QAC3B,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC;YAAE,SAAQ;QAElC,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,CAAA;QAEtB,IAAI,GAAG,KAAK,OAAO,IAAI,GAAG,KAAK,WAAW,EAAE,CAAC;YAC3C,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,EAAE,CAAC;gBACnC,KAAK,CAAC,IAAI,CAAC,WAAW,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;YAC3C,CAAC;QACH,CAAC;aAAM,IAAI,GAAG,KAAK,OAAO,EAAE,CAAC;YAC3B,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,EAAE,CAAC;gBACnC,KAAK,CAAC,IAAI,CAAC,WAAW,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;YAC3C,CAAC;iBAAM,IAAI,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;gBAC1C,MAAM,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC;qBACjC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;qBAC1E,IAAI,CAAC,GAAG,CAAC,CAAA;gBACZ,IAAI,QAAQ;oBAAE,KAAK,CAAC,IAAI,CAAC,WAAW,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;YAC9D,CAAC;QACH,CAAC;aAAM,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;YAC7B,KAAK,CAAC,IAAI,CAAC,SAAS,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAA;QACjD,CAAC;aAAM,IAAI,GAAG,KAAK,OAAO,EAAE,CAAC;YAC3B,KAAK,CAAC,IAAI,CAAC,WAAW,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAA;QACnD,CAAC;aAAM,IAAI,OAAO,GAAG,KAAK,SAAS,EAAE,CAAC;YACpC,IAAI,GAAG;gBAAE,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC,CAAA;QAChC,CAAC;aAAM,CAAC;YACN,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,KAAK,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAA;QACpD,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;AACvB,CAAC;AAED,SAAS,uBAAuB,CAAC,KAAY;IAC3C,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC3B,OAAO,CAAC,KAAK,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;IAC5D,CAAC;IAED,MAAM,IAAI,GAAG,KAAK,CAAC,GAAU,CAAA;IAE7B,MAAM,QAAQ,GAAG;QACf,SAAS,EAAE,IAAI;QACf,KAAK,EAAE,KAAK,CAAC,KAAK,IAAI,EAAE;QACxB,UAAU,EAAE,EAAE;QACd,KAAK,EAAE,IAAI;QACX,OAAO,EAAE,KAAK;QACd,SAAS,EAAE;YACT,WAAW,EAAE,EAAE;YACf,OAAO,EAAE,EAAE;YACX,YAAY,EAAE,EAAE;YAChB,OAAO,EAAE,EAAE;YACX,aAAa,EAAE,EAAE;YACjB,SAAS,EAAE,EAAE;SACd;KACF,CAAA;IAED,KAAK,CAAC,SAAS,GAAG,QAAQ,CAAA;IAE1B,MAAM,QAAQ,GAAG;QACf,IAAI,EAAE,GAAG,EAAE,GAAE,CAAC;QACd,KAAK,EAAE;YACL,OAAO,EAAE,GAAG,EAAE;gBACZ,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,IAAI,EAAE,CAAA;gBACrC,OAAO,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;YACjD,CAAC;SACF;KACF,CAAA;IAED,IAAI,UAAU,GAAwB,EAAE,CAAA;IACxC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE,EAAE,QAAQ,CAAC,CAAA;IACtD,CAAC;IAED,QAAQ,CAAC,UAAU,GAAG,UAAU,CAAA;IAEhC,IAAI,MAAM,GAAiB,IAAI,CAAA;IAC/B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAA;IACrF,CAAC;IAED,IAAI,CAAC,MAAM;QAAE,OAAO,EAAE,CAAA;IAEtB,OAAO,cAAc,CAAC,MAAM,CAAC,CAAA;AAC/B,CAAC;AAED,SAAS,UAAU,CAAC,GAAW;IAC7B,OAAO,GAAG;SACP,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC;SACtB,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC;SACrB,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC;SACrB,OAAO,CAAC,IAAI,EAAE,QAAQ,CAAC;SACvB,OAAO,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;AAC5B,CAAC;AAED,SAAS,UAAU,CAAC,GAAW;IAC7B,OAAO,GAAG;SACP,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC;SACtB,OAAO,CAAC,IAAI,EAAE,QAAQ,CAAC;SACvB,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC;SACrB,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;AAC1B,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type VNode } from './types';
|
|
2
|
+
export type PatchOp = {
|
|
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[];
|
|
10
|
+
//# sourceMappingURL=diff.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diff.d.ts","sourceRoot":"","sources":["../../src/vdom/diff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,SAAS,CAAA;AAEpC,MAAM,MAAM,OAAO,GAAG;IACpB,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,SAAS,GAAG,QAAQ,GAAG,MAAM,CAAA;IACzD,QAAQ,CAAC,EAAE,KAAK,GAAG,IAAI,CAAA;IACvB,QAAQ,CAAC,EAAE,KAAK,GAAG,IAAI,CAAA;IACvB,MAAM,EAAE,IAAI,CAAA;IACZ,MAAM,EAAE,IAAI,GAAG,IAAI,CAAA;CACpB,CAAA;AAED,wBAAgB,IAAI,CAAC,QAAQ,EAAE,KAAK,GAAG,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,GAAG,OAAO,EAAE,CAexF"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
export function diff(oldVNode, newVNode, container) {
|
|
2
|
+
const patches = [];
|
|
3
|
+
if (!oldVNode) {
|
|
4
|
+
patches.push({
|
|
5
|
+
type: 'create',
|
|
6
|
+
newVNode,
|
|
7
|
+
parent: container,
|
|
8
|
+
anchor: null,
|
|
9
|
+
});
|
|
10
|
+
return patches;
|
|
11
|
+
}
|
|
12
|
+
diffVNode(oldVNode, newVNode, container, patches);
|
|
13
|
+
return patches;
|
|
14
|
+
}
|
|
15
|
+
function diffVNode(oldV, newV, container, patches) {
|
|
16
|
+
if (oldV._type !== newV._type || oldV.tag !== newV.tag || oldV.key !== newV.key) {
|
|
17
|
+
patches.push({
|
|
18
|
+
type: 'replace',
|
|
19
|
+
oldVNode: oldV,
|
|
20
|
+
newVNode: newV,
|
|
21
|
+
parent: container,
|
|
22
|
+
anchor: oldV.el?.nextSibling ?? null,
|
|
23
|
+
});
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
newV.el = oldV.el;
|
|
27
|
+
if (oldV._type === 'text') {
|
|
28
|
+
if (oldV.text !== newV.text) {
|
|
29
|
+
patches.push({
|
|
30
|
+
type: 'update',
|
|
31
|
+
newVNode: newV,
|
|
32
|
+
parent: container,
|
|
33
|
+
anchor: null,
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
if (oldV._type === 'element') {
|
|
39
|
+
diffProps(oldV, newV, patches);
|
|
40
|
+
diffChildren(oldV, newV, patches);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
function diffProps(oldV, newV, _patches) {
|
|
44
|
+
const oldProps = oldV.props ?? {};
|
|
45
|
+
const newProps = newV.props ?? {};
|
|
46
|
+
const el = oldV.el;
|
|
47
|
+
if (!el)
|
|
48
|
+
return;
|
|
49
|
+
for (const key of Object.keys(oldProps)) {
|
|
50
|
+
if (key === 'key')
|
|
51
|
+
continue;
|
|
52
|
+
if (!(key in newProps)) {
|
|
53
|
+
if (key.startsWith('on')) {
|
|
54
|
+
const event = key.slice(2).toLowerCase();
|
|
55
|
+
el.removeEventListener(event, oldProps[key]);
|
|
56
|
+
}
|
|
57
|
+
else if (key === 'class' || key === 'className') {
|
|
58
|
+
el.removeAttribute('class');
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
el.removeAttribute(key);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
for (const key of Object.keys(newProps)) {
|
|
66
|
+
if (key === 'key')
|
|
67
|
+
continue;
|
|
68
|
+
const oldVal = oldProps[key];
|
|
69
|
+
const newVal = newProps[key];
|
|
70
|
+
if (oldVal !== newVal) {
|
|
71
|
+
if (key.startsWith('on')) {
|
|
72
|
+
const event = key.slice(2).toLowerCase();
|
|
73
|
+
if (oldVal)
|
|
74
|
+
el.removeEventListener(event, oldVal);
|
|
75
|
+
el.addEventListener(event, newVal);
|
|
76
|
+
}
|
|
77
|
+
else if (key === 'class' || key === 'className') {
|
|
78
|
+
if (typeof newVal === 'string') {
|
|
79
|
+
el.setAttribute('class', newVal);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
else if (key === 'style') {
|
|
83
|
+
if (typeof newVal === 'string') {
|
|
84
|
+
el.setAttribute('style', newVal);
|
|
85
|
+
}
|
|
86
|
+
else if (newVal && typeof newVal === 'object') {
|
|
87
|
+
Object.assign(el.style, newVal);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
el.setAttribute(key, String(newVal));
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
function diffChildren(oldV, newV, patches) {
|
|
97
|
+
const oldChildren = oldV.children ?? [];
|
|
98
|
+
const newChildren = newV.children ?? [];
|
|
99
|
+
const el = oldV.el;
|
|
100
|
+
if (!el)
|
|
101
|
+
return;
|
|
102
|
+
const maxLen = Math.max(oldChildren.length, newChildren.length);
|
|
103
|
+
for (let i = 0; i < maxLen; i++) {
|
|
104
|
+
const oldChild = oldChildren[i];
|
|
105
|
+
const newChild = newChildren[i];
|
|
106
|
+
if (!oldChild && newChild) {
|
|
107
|
+
patches.push({
|
|
108
|
+
type: 'create',
|
|
109
|
+
newVNode: newChild,
|
|
110
|
+
parent: el,
|
|
111
|
+
anchor: null,
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
else if (oldChild && !newChild) {
|
|
115
|
+
patches.push({
|
|
116
|
+
type: 'remove',
|
|
117
|
+
oldVNode: oldChild,
|
|
118
|
+
parent: el,
|
|
119
|
+
anchor: null,
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
else if (oldChild && newChild) {
|
|
123
|
+
diffVNode(oldChild, newChild, el, patches);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
//# sourceMappingURL=diff.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diff.js","sourceRoot":"","sources":["../../src/vdom/diff.ts"],"names":[],"mappings":"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"}
|
package/dist/vdom/h.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { type VNode, Fragment } from './types';
|
|
2
|
+
export declare function h(tag: string | Record<string, any> | typeof Fragment, props: Record<string, any> | null, children?: any): VNode;
|
|
3
|
+
export declare function hText(text: string): VNode;
|
|
4
|
+
//# sourceMappingURL=h.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"h.d.ts","sourceRoot":"","sources":["../../src/vdom/h.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAE9C,wBAAgB,CAAC,CACf,GAAG,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO,QAAQ,EACnD,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,IAAI,EACjC,QAAQ,CAAC,EAAE,GAAG,GACb,KAAK,CAwBP;AAED,wBAAgB,KAAK,CAAC,IAAI,EAAE,MAAM,GAAG,KAAK,CAWzC"}
|
package/dist/vdom/h.js
ADDED
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { Fragment } from './types';
|
|
2
|
+
export function h(tag, props, children) {
|
|
3
|
+
const flatChildren = normalizeChildren(children);
|
|
4
|
+
if (typeof tag === 'object' || tag === Fragment) {
|
|
5
|
+
return {
|
|
6
|
+
_type: tag === Fragment ? 'fragment' : 'component',
|
|
7
|
+
tag: tag === Fragment ? Fragment : tag,
|
|
8
|
+
props,
|
|
9
|
+
children: flatChildren,
|
|
10
|
+
el: null,
|
|
11
|
+
key: props?.key ?? null,
|
|
12
|
+
component: null,
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
return {
|
|
16
|
+
_type: 'element',
|
|
17
|
+
tag,
|
|
18
|
+
props,
|
|
19
|
+
children: flatChildren,
|
|
20
|
+
el: null,
|
|
21
|
+
key: props?.key ?? null,
|
|
22
|
+
component: null,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
export function hText(text) {
|
|
26
|
+
return {
|
|
27
|
+
_type: 'text',
|
|
28
|
+
tag: null,
|
|
29
|
+
props: null,
|
|
30
|
+
children: null,
|
|
31
|
+
el: null,
|
|
32
|
+
key: null,
|
|
33
|
+
component: null,
|
|
34
|
+
text,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
function normalizeChildren(children) {
|
|
38
|
+
if (children == null)
|
|
39
|
+
return null;
|
|
40
|
+
if (typeof children === 'string' || typeof children === 'number') {
|
|
41
|
+
return [hText(String(children))];
|
|
42
|
+
}
|
|
43
|
+
if (Array.isArray(children)) {
|
|
44
|
+
const result = [];
|
|
45
|
+
for (const child of children) {
|
|
46
|
+
if (child == null || child === false || child === true)
|
|
47
|
+
continue;
|
|
48
|
+
if (Array.isArray(child)) {
|
|
49
|
+
result.push(...normalizeChildren(child));
|
|
50
|
+
}
|
|
51
|
+
else if (typeof child === 'string' || typeof child === 'number') {
|
|
52
|
+
result.push(hText(String(child)));
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
result.push(child);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return result.length > 0 ? result : null;
|
|
59
|
+
}
|
|
60
|
+
return [children];
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=h.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"h.js","sourceRoot":"","sources":["../../src/vdom/h.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,QAAQ,EAAE,MAAM,SAAS,CAAA;AAE9C,MAAM,UAAU,CAAC,CACf,GAAmD,EACnD,KAAiC,EACjC,QAAc;IAEd,MAAM,YAAY,GAAG,iBAAiB,CAAC,QAAQ,CAAC,CAAA;IAEhD,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,KAAK,QAAQ,EAAE,CAAC;QAChD,OAAO;YACL,KAAK,EAAE,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW;YAClD,GAAG,EAAE,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAE,GAAW;YAC/C,KAAK;YACL,QAAQ,EAAE,YAAY;YACtB,EAAE,EAAE,IAAI;YACR,GAAG,EAAE,KAAK,EAAE,GAAG,IAAI,IAAI;YACvB,SAAS,EAAE,IAAI;SAChB,CAAA;IACH,CAAC;IAED,OAAO;QACL,KAAK,EAAE,SAAS;QAChB,GAAG;QACH,KAAK;QACL,QAAQ,EAAE,YAAY;QACtB,EAAE,EAAE,IAAI;QACR,GAAG,EAAE,KAAK,EAAE,GAAG,IAAI,IAAI;QACvB,SAAS,EAAE,IAAI;KAChB,CAAA;AACH,CAAC;AAED,MAAM,UAAU,KAAK,CAAC,IAAY;IAChC,OAAO;QACL,KAAK,EAAE,MAAM;QACb,GAAG,EAAE,IAAI;QACT,KAAK,EAAE,IAAI;QACX,QAAQ,EAAE,IAAI;QACd,EAAE,EAAE,IAAI;QACR,GAAG,EAAE,IAAI;QACT,SAAS,EAAE,IAAI;QACf,IAAI;KACL,CAAA;AACH,CAAC;AAED,SAAS,iBAAiB,CAAC,QAAa;IACtC,IAAI,QAAQ,IAAI,IAAI;QAAE,OAAO,IAAI,CAAA;IACjC,IAAI,OAAO,QAAQ,KAAK,QAAQ,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE,CAAC;QACjE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAA;IAClC,CAAC;IACD,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC5B,MAAM,MAAM,GAAY,EAAE,CAAA;QAC1B,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,KAAK,KAAK,IAAI,KAAK,KAAK,IAAI;gBAAE,SAAQ;YAChE,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;gBACzB,MAAM,CAAC,IAAI,CAAC,GAAG,iBAAiB,CAAC,KAAK,CAAE,CAAC,CAAA;YAC3C,CAAC;iBAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBAClE,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YACnC,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YACpB,CAAC;QACH,CAAC;QACD,OAAO,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAA;IAC1C,CAAC;IACD,OAAO,CAAC,QAAQ,CAAC,CAAA;AACnB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/vdom/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,KAAK,CAAA;AAC9B,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAA;AAC7B,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAC7C,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAClC,YAAY,EAAE,KAAK,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/vdom/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,KAAK,CAAA;AAC9B,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAA;AAC7B,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAC7C,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"patch.d.ts","sourceRoot":"","sources":["../../src/vdom/patch.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,OAAO,EAAyD,MAAM,SAAS,CAAA;AAmBzG,wBAAgB,YAAY,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,CAwBrD;AAED,wBAAgB,KAAK,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAE,IAAI,GAAG,IAAW,GAAG,IAAI,GAAG,IAAI,CAgCzF"}
|