This was already addressed here originally in PR #44 . but then taken out to simplify that PR. To paraphrase:
We use our own custom onBeforeElUpdated function for memoizing sub-components, but then lose the ability to copy events. We'd need to be able to use both, ideally running the user function before the copier (since the user returning false immediately would make the event copier operations redundant).
I've seen the memoization example from the "choo stateful playground" example (though we aren't using choo directly), but it would be better at least for our purposes to have the isSameNode check internalized once in our main node comparison, rather than needing to include customElement.isSameNode = () => true; comparisons externally at the root of every one of our memoized sub-components (though only after the first update, which again adds more closure boilerplate if the same component is being used multiple times).
If there would be a way to get in @kristoferjoseph s work via this issue that would be great :)
This was already addressed here originally in PR #44 . but then taken out to simplify that PR. To paraphrase:
We use our own custom
onBeforeElUpdatedfunction for memoizing sub-components, but then lose the ability to copy events. We'd need to be able to use both, ideally running the user function before thecopier(since the user returningfalseimmediately would make the event copier operations redundant).I've seen the memoization example from the "choo stateful playground" example (though we aren't using choo directly), but it would be better at least for our purposes to have the
isSameNodecheck internalized once in our main node comparison, rather than needing to includecustomElement.isSameNode = () => true;comparisons externally at the root of every one of our memoized sub-components (though only after the first update, which again adds more closure boilerplate if the same component is being used multiple times).If there would be a way to get in @kristoferjoseph s work via this issue that would be great :)