Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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
Mark parent directory as viewed when all files are viewed #33958
base: main
Are you sure you want to change the base?
Mark parent directory as viewed when all files are viewed #33958
Changes from 5 commits
facb60b
1df14bf
927a6a1
c3baa0b
9344407
07715a2
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Batching the update sounds like over-engineering to me.
After all, if I read the code correctly, there's a chance of flickering for a frame.
Why not simply
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The code(
props.item.isFile ? props.item.file.IsViewed : (props.item as DirItem).children.every(child => child.file.IsViewed);
) fails to accurately retrieve folder statuses in deeply nested folder hierarchies, as the isViewed state isn't backend-maintained but dynamically computed on the fly.This explains why I initially implemented it this way:
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, right.
However, that difference should be mainly for historical reasons:
Prior to this PR, the
Viewed
state didn't make sense on directories, soDirItem
didn't have the attribute.Now, it does make sense.
So we should be able to move the attribute one layer up into
FileItem
andDirItem
and convert it from computed on demand into an actual attribute we update.Then, every tree item has this attribute and we can use this approach.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As discussed, moving the folder status calculation logic to the backend would require:
1. Backend complexity increase: Implementing similar computational logic as in this PR, adding architectural overhead
2. Frontend adaptation: Introducing new logic to synchronize folder read status updates
In contrast, the current PR's approach:
1. Zero backend changes: Maintains existing backend architecture
2. Frontend-driven computation: Handles folder status calculation entirely on the client-side
The biggest difference between the two is that the front - end needs to add a new logic of "reading the folder status from the back - end". The reason why the file status doesn't need to be read separately is that the interaction is initiated by the front - end, so the front - end can directly read its own status. However, if the folder status is calculated by the back - end, a new logic has to be added for reading.
I’m not sure if I’ve made myself clear.