Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

How "written in stone" is the rule about not changing state in $derived? #14793

Closed
webJose opened this issue Dec 21, 2024 · 6 comments
Closed

Comments

@webJose
Copy link
Contributor

webJose commented Dec 21, 2024

Describe the problem

My component @wjfe/dataview uses a $derived to calculate the necessary information to lay out the component's data columns. This is great. Actually, the entire component is driven by just this one computation.

However, at work there is this need: In data drilling scenarios where "row expansion" shows another table that describes in more detail the expanded row's data (see this page for a live data-drilling example), users want that certain columns of the "child" table be visually synchronized in position and width with the equivalent parent table's column.

To achieve this, I have been thinking about this long and hard and I finally came up with a very effective way of achieving this cross-table column synchronization feature. It is actually functional in this REPL.

The problem: The calculation of the filler columns require setting state! Setting state while calculating a derived is currently forbidden. This forced the REPL to redefine colDefs as $state which is updated in an $effect. The terrible part of this is: My component would no longer be able to nicely server-render because effects don't run in SSR.

Describe the proposed solution

Somehow allow state mutation from a $derived?? I have no other idea except allowing it. If anyone has a better solution, I'll welcome it.

Importance

would make my life easier

@Ocean-OS
Copy link
Contributor

Couldn't you use an $effect? I know it's not recommended for everything, but it seems necessary for this case.

@webJose
Copy link
Contributor Author

webJose commented Dec 21, 2024

It is using $effect.pre. This is exactly the problem: Effects don't run in SSR, so the columns cannot be rendered in SSR.

@Ocean-OS
Copy link
Contributor

Ah, I see, then #14784 would probably be the best solution, if it's merged.

@webJose
Copy link
Contributor Author

webJose commented Dec 21, 2024

Interesting. So the new unsafe() API function would allow me to mutate column.sync.expectedLeft inside a $derived, as I understood the PR. Yes, it is what I need!

@dummdidumm
Copy link
Member

It's "written in stone" insofar that the current behavior is there to ensure consistency of the reactive graph. Else mutations could produce subtle and indirect bugs which you would spend hours debugging. #14784 would certainly help with this, therefore closing.

@dummdidumm dummdidumm closed this as not planned Won't fix, can't repro, duplicate, stale Jan 7, 2025
@webJose
Copy link
Contributor Author

webJose commented Jan 7, 2025

Yes, thank you for the explanation. I'm impatiently waiting for that PR to go live. 😄

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants