You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Some rules that were good ideas before but become crucial with Plotly.react so that we recognize a non-change correctly:
Never create new arrays in the supplyDefaults step - for example reshaping 1D to 2D arrays. That should be done in a calc step and NOT pushed back into _fullData.
Don't modify attributes after finishing supplyDefaults, unless you're going to push the results back to the input (data/layout) as well, like autorange/range.
When you're stashing things on _full*, always make _private attributes.
Most of the instances of this are taken care of in #2341, but a few are open:
tick0, dtick -> default filled in late (After SD) - also for tickmode=array, not needed at all
camera doesn’t push back into _fullLlayout after drag, only layout?
tests for scatter3d with uneven or missing x/y/z
tests for surface with uneven, missing, or ragged x/y/z
think we should try and find a way to help the user access the recommendations we would make with impliedEdits and clearAxisTypes, but leave it up to them whether to follow those recommendations.
Perhaps all we need is to (under a certain config option) log whenever we mutate user data or user layout. Alternatively, Plotly.validate could be use here e.g.
could log something like: increasing range detected, range values ignored under autorange. Then together with #1741, it should make it fairly easy for plotly.js users to debug.
Hi - this issue has been sitting for a while, so as part of our effort to tidy up our public repositories I'm going to close it. If it's still a concern, we'd be grateful if you could open a new issue (with a short reproducible example if appropriate) so that we can add it to our stack. Cheers - @gvwilson
Some rules that were good ideas before but become crucial with
Plotly.react
so that we recognize a non-change correctly:supplyDefaults
step - for example reshaping 1D to 2D arrays. That should be done in acalc
step and NOT pushed back into_fullData
.supplyDefaults
, unless you're going to push the results back to the input (data
/layout
) as well, likeautorange
/range
._full*
, always make_private
attributes.Most of the instances of this are taken care of in #2341, but a few are open:
tick0
,dtick
-> default filled in late (After SD) - also for tickmode=array, not needed at allcamera
doesn’t push back into_fullLlayout
after drag, onlylayout
?scatter3d
with uneven or missing x/y/zsurface
with uneven, missing, or ragged x/y/zautocolorscale
: first time it gets set on, second time off - is that intentional? cauto sometimes shows a similar effect… seegl3d_scatter-color-mono-and-palette
resolved in: Don't mutate colorscale, cmin/cmax and zmin/zmax into user traces #3341contourcarpet
:zmin
/zmax
get filled in (aftersupplyDefaults
) but they aren't actually attributes ofcontourcarpet
. They should be!autorange: 'reversed'
should get replaced inlayout
once it has been acted on. There's a polar mock where this doesn't happen until the second draw.The text was updated successfully, but these errors were encountered: