Commit 48eca22
authored
Fix: Re-parent pulled-up directory children to ensure proper checkbox refresh (#8679)
* Fix: Re-parent pulled-up directory children to ensure proper checkbox refresh
When the tree has multiple top-level directories, a temporary DirectoryTreeNode
is created to build the tree, then its children are pulled up to the parent.
However, the children's parent pointers still referenced the phantom root,
causing processCheckboxUpdates to refresh an invisible node, so checkbox state
never updated visually.
Re-parent all pulled-up children to the actual container node (FilesCategoryNode,
PullRequestNode, or CommitNode) so ancestor walks target visible tree nodes.
* test: add regression tests for parent pointer invariant after tree building
Add tests to verify that pulled-up directory children are correctly re-parented
to the container node, not the phantom root. This ensures processCheckboxUpdates
can walk ancestors and find visible tree nodes for refresh() calls.
Tests cover:
- getParent() correctly returns undefined after re-parenting
- ancestor walk stops at topmost visible directory, not phantom root1 parent 35bb21b commit 48eca22
4 files changed
Lines changed: 56 additions & 0 deletions
File tree
- src
- test/view/treeNodes
- view/treeNodes
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
206 | 206 | | |
207 | 207 | | |
208 | 208 | | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
209 | 262 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
111 | 111 | | |
112 | 112 | | |
113 | 113 | | |
| 114 | + | |
114 | 115 | | |
115 | 116 | | |
116 | 117 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
93 | 93 | | |
94 | 94 | | |
95 | 95 | | |
| 96 | + | |
96 | 97 | | |
97 | 98 | | |
98 | 99 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
105 | 105 | | |
106 | 106 | | |
107 | 107 | | |
| 108 | + | |
108 | 109 | | |
109 | 110 | | |
110 | 111 | | |
| |||
0 commit comments