neo.mjs 4.0.76 → 4.0.77
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/package.json +1 -1
- package/src/component/Base.mjs +14 -16
- package/src/vdom/Helper.mjs +2 -5
package/package.json
CHANGED
package/src/component/Base.mjs
CHANGED
@@ -410,7 +410,7 @@ class Base extends CoreBase {
|
|
410
410
|
app.un('mounted', listenerId);
|
411
411
|
|
412
412
|
setTimeout(() => {
|
413
|
-
me.updateVdom(me.vdom, me.vnode);
|
413
|
+
me.vnode && me.updateVdom(me.vdom, me.vnode);
|
414
414
|
}, 50);
|
415
415
|
});
|
416
416
|
} else if (me.mounted) {
|
@@ -1567,24 +1567,22 @@ class Base extends CoreBase {
|
|
1567
1567
|
|
1568
1568
|
// keep the vnode parent tree in sync
|
1569
1569
|
ComponentManager.getParents(me).forEach((component, index) => {
|
1570
|
-
if (
|
1571
|
-
if (!me.
|
1572
|
-
|
1573
|
-
|
1574
|
-
// console.warn('syncVnodeTree: Could not remove the parent vnode for', me.id, component);
|
1575
|
-
}
|
1570
|
+
if (!me.vnode) {
|
1571
|
+
if (index === 0 && !VNodeUtil.removeChildVnode(component.vnode, me.id)) {
|
1572
|
+
// This can fail, in case the vnode is already removed (not an issue, better safe than sorry)
|
1573
|
+
// console.warn('syncVnodeTree: Could not remove the parent vnode for', me.id, component);
|
1576
1574
|
}
|
1575
|
+
}
|
1577
1576
|
|
1578
|
-
|
1579
|
-
|
1580
|
-
|
1581
|
-
|
1582
|
-
|
1577
|
+
// check for dynamically rendered components which get inserted into the component tree
|
1578
|
+
else if (index === 0 && me.vnode.outerHTML) {
|
1579
|
+
// console.log('dyn item', me.vnode, me.parentIndex);
|
1580
|
+
component.vnode.childNodes.splice(me.parentIndex || 0, 0, me.vnode);
|
1581
|
+
}
|
1583
1582
|
|
1584
|
-
|
1585
|
-
|
1586
|
-
|
1587
|
-
}
|
1583
|
+
else if (!VNodeUtil.replaceChildVnode(component.vnode, me.vnode.id, me.vnode)) {
|
1584
|
+
// todo: can happen for dynamically inserted container items
|
1585
|
+
// console.warn('syncVnodeTree: Could not replace the parent vnode for', me.vnode.id, component);
|
1588
1586
|
}
|
1589
1587
|
});
|
1590
1588
|
|
package/src/vdom/Helper.mjs
CHANGED
@@ -167,9 +167,6 @@ class Helper extends Base {
|
|
167
167
|
// use case: calendar week view => move an event into a column on the right side
|
168
168
|
|
169
169
|
if (movedNode) {
|
170
|
-
|
171
|
-
// todo: check if there is a real index change
|
172
|
-
|
173
170
|
deltas.push({
|
174
171
|
action: 'moveNode',
|
175
172
|
id : oldVnode.id,
|
@@ -786,8 +783,8 @@ class Helper extends Base {
|
|
786
783
|
* @returns {Object|Promise<Object>}
|
787
784
|
*/
|
788
785
|
update(opts) {
|
789
|
-
let me
|
790
|
-
node
|
786
|
+
let me = this,
|
787
|
+
node = me.parseHelper(opts.vdom),
|
791
788
|
|
792
789
|
deltas = me.createDeltas({
|
793
790
|
newVnode: node,
|