-
Notifications
You must be signed in to change notification settings - Fork 3.3k
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
Add property "isEmpty" #863
Conversation
src/models/state.js
Outdated
return (startOffset == endOffset) | ||
} | ||
|
||
return this.fragment.text.length == 0 |
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.
After checking that the selection is not collapsed, you can probably check if at least one of startOffset
or endOffset
equals 0
. It's a cheap check, but a condition for the selection to be empty. It could avoid computing a fragment in most cases.
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.
And continuing on this idea, you can afterward check if the other offset is at the end of its node.
Hey @SamyPesse and @Soreine I have a thought... this issue also comes up when people triple-click a block and then do something like So I'm wondering, do you think there's a way we can actually detect the double/triple-click scenario and instead tweak the selection to be what we expect it to? I feel like tweaking the selection itself might end up with covering more of the edge cases without as much complexity to keep track of elsewhere. I think Draft.js tweaks the selection, but I'm not sure how they do it. If so, I think that would be a better solution for us to reduce complexity. What do you think? |
I'm not sure I understand the tripe-click case. But I'm wondering if we can simply improve the @ianstormtaylor Will it work ? |
What Ian suggests is that we patch the few cases that can lead to such selections in a unintended way (double click, triple click, maybe some other cases?). We would detect when they happen and make sure to fix the selection there, instead of normalizing the selection everytime or checking everywhere for a Sounds simpler. As long as we have a way to detect these special cases. |
I disagree with your approach @Soreine. I think it makes more sense to always prevent this case of selection (Fake collapsed selection) whatever it has been caused by an user action or a transform from the application. Preventing this invalid selection in one spot ( We'll not need the |
Note, ignore everything between the horizontal rules in the end, I think after writing it all out I agree that going with My comment was what @Soreine mentioned, but I think both approaches have the potential to be viable, it depends on a few things... Detect Double/Triple-clickWith the approach @Soreine described, we'd try to somehow detect that we were double or triple-clicking and then adjust the selection, since we know that in the cases we've seen the user doesn't actually want the selection to extend to the adjacent nodes. This solution is nice because it seems like it most closely matches user intent for these specifics cases where the problem is, which will lead to reduced confusion. The potential downside is that I'm not sure if there is a way to detect it reliably, but I say that without having investigated at all so that would be the next step. Normalize Fake-collapsedThis is the approach @SamyPesse described. The problem with it, and why I didn't think to suggest it, is that there are certain situations where the "fake-collapsed" selection is actually valid, and normalizing them away would result in odd behavior. For example, if you shift + right arrow to extend the selection across a block, you pass through a point where you have a fake-collapsed selection. Although, having said that, I think that might be the only time that pass through happens, so we could decide to special-case that instead potentially. It seems like both might work? I think I'd rather go with the double/triple-click logic since it seems like it matches user intent closely, and eliminates us having to handle more edge cases with the core plugin transforms. Actually, after writing out both of the downsides, it seems like either case is going to result in us having to police too many edge cases that might not be what the user intended. So I think it would make sense to go with this PR and the How does that sound? Can you think of any problems that would result from |
@ianstormtaylor Yes it makes sense, I improved the PR with @Soreine's suggestion and it should be ready to be merged :) |
Thanks @SamyPesse! |
* Add property isEmpty to State * Update hovering menu example * Document isEmpty * Improve perf of isEmpty with @Soreine 's suggestion * Fix return of isEmpty
Fix #862 by adding a property
isEmpty
. The computation tries to be performant by not computingstate.fragment
when the selection is "simple".I've also updated the "Hovering menu", it works perfectly with it.
@ianstormtaylor I'm not sure where to put unit tests for this property.