-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
Fix for: focused input in dialog is scrolled out of viewport when soft keyboard appears #2413
Conversation
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.
I can admit that with this changes Androind behaves much better.
There are a couple of issues of this implementation:
Missing unit tests
Although I understand that is early PR so you have in mind to add appropriate tests.
Changing dialog size
When changing the dialog size scrollbars shows up:
It doesn't occur on master
.
iOS still bugged
Your changes don't fix iOS at all, it behaves the same before the fix. However, this bug was mostly annoying on Android and dialog works correctly on iOS around 80% of the time.
It would be nice to spend some time trying to fix iOS also, although I believe fixing it may consume a lot of time.
@jacekbogdanski this fix is meant for Android devices, but also affects all modern browsers (in positive way I think). Although it doesn't fix issues with iOS, it doesn't look worse in any way. Mobile browsers in general has some problems with focusing inputs, especially when page is zoomed and I think it works pretty good on iOS. |
600c839
to
9617dd1
Compare
I've added unit tests, changelog entry, styles for other skins and manuals for each skin. |
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.
@engineering-this referencing to #2413 (comment) - I see your point. However, I'm not sure if we have any real profit from additional condition thus you still have to calculate dialog position for Internet Explorer. After our F2F talk I thought that this code is called every time when the browser window is resized. Although now I see that this point is valid only for IE (correct me if I'm wrong). So we are introducing additional, misleading condition, however, the rest of the code smoothly handles this case.
Could you elaborate if you see any additional benefit (like performance etc. ) which I don't see? Note that layout have to still be recalculated if dialog has been moved.
The fix seems to work pretty good on mobiles, but since we don't have any way to detect mobile I don't see other way. On the other hand CSS role is to position elements. And centering an element in a view with absolute position calculated with JS and adjusting it on every resize event is an overkill. I don't know if there is benchmark that could compare rendering speed in our cases, but I bet just dropping resize listener for non IE browsers is good for performance. Theoretically we could completely drop listening for resize, as it is possible to center element in IE8+ with CSS only too, but that's a bit hacky, and requires additional wrapper. We could either keep 'flex' for modern browsers and use hax for IE or use haxy IE code for everything.
I don't like one thing tho: we are changing dom structure which leads risk of breaking things. So I'm for keeping old logic for IE as it works there perfectly fine. |
Changes:
@jacekbogdanski I have one concern. How do you think we should deal with following case:
Should we leave it as it is now (scrollbars appears once dialog is outside of viewport). Or move dialog into view on resize? |
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.
I think it would be nice to be consistent and update dialog position when resizing browser window. Currently it works fine with native 'flex` css option, but if you move dialog it will become static.
Also, I'm wondering if we shouldn't recalculate dialog position for newly opened dialog after window resize:
- Open dialog in a small browser window.
- Move it a little bit to mark it as
moved
. - Close dialog.
- Maximaze browser window.
- Open dialog again.
Expected
Dialog should be positioned at the center of the editor.
Actual
Dialog is placed at the same position before window resize.
Also, there is an issue on IE < 11:
- Open manual test.
- Click the link button.
- Click the close button.
- Repeat.
Expected
Dialog is showed up again.
Actual
Viewport is grey out. Dialog doesn't appear on second button click.
67de90c
to
d167527
Compare
Dialog still keeps its position when closing and opening again or resizing, but values are now in percentages, so resizing moves a bit dialog, keeping proportions. |
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.
I'm not sure if dropping resize event completely is a good way. Currently, the dialog is not fully responsive which is mostly visible on IE where it's not initially handled by flex
. If you start shrinking window you will see that at some point left margin starts to grow bigger than left.
Co-Authored-By: Krzysztof Krztoń <k.krzton@cksource.com>
Co-Authored-By: Krzysztof Krztoń <k.krzton@cksource.com>
…container is host of scrollbars when dialog doesn't fit.
Rebased onto latest |
I see this PR also fixes #453 🎉 |
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.
LGTM 👍 Good job 👏
What is the purpose of this pull request?
Bug fix
Does your PR contain necessary tests?
All patches which change the editor code must include tests. You can always read more
on PR testing,
how to set the testing environment and
how to create tests
in the official CKEditor documentation.
This PR contains
What changes did you make?
This is early PR with proposal of solution.
Current solution
When soft keyboard appears on touch devices it causes 'resize' event on which we were recalculating center position of fixed dialog. After that browser tried to scroll into view of input but it took wrong position, probably before moving it.
Such complex way of centering dialog is unnecessary, as dialog can't be dragged without mouse.
I have reworked how a dialog is styled:
position: fixed
withwidth
andheight
set to 100%.document.body
gets a class with 'overflow:hidden', and stylepadding-right
calculated from width of scrollbar.absolute
position calculated by script.absolute
positioned.After changes we won't adjust dialogs position once opened on the mobile devices, it will be positioned only by CSS and the way it's scrolled into view of focused inputs is only relying on browser implementation.
Unfortunately browsers implementation isn't perfect and sometimes it still scrolls it in wrong way, but that's rare. And it should be mentioned that this can happen even with fully static pages, with no js, and everything relative positioned.
Other solution
Adding
once( 'scroll' ...
insidefocus
listener and callingscrollIntoView
on currently focused input. This is much simpler, but creates visible flickering, so I dropped this idea for now.Todo
Closes #2395. Closes #3359. Closes #453.