tree
tree copied to clipboard
Tree freezes when used in controlled mode with `motion` and `expandAction="click"`
Hi,
When using rc-tree in controlled mode, with some animations (with the motion
prop), and with expandAction="click"
, then the Tree gets stuck whenever you click on a leaf.
When that happens, you can no longer expand or collapse the nodes.
The only way out is to trigger a re-render of the Tree by some external event, such as a drag-and-drop or clicking a button that changes the tree state.
This can be really troubling for the end user, as they think the app is broken.
Here is a codesandbox that reproduces the issue: https://codesandbox.io/s/lucid-frog-mks62z?file=/App.jsx
It is based on the basic-controlled example, to which I applied the following changes:
- Remove
onCheck
,checkedKeys
,onSelect
andselectedKeys
props - Add
expandAction="click"
- Add
motion={motion}
with some style (from the animation example)
Steps to reproduce:
- Expand all nodes until you come to a leaf
- Click on the leaf title
- Nodes can no longer be expanded nor collapsed
rc-tree version: 5.7.0
Thanks for your help!