-
Notifications
You must be signed in to change notification settings - Fork 2.6k
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
iOS 11.3 fix #416
Merged
Merged
iOS 11.3 fix #416
Changes from 4 commits
Commits
Show all changes
9 commits
Select commit
Hold shift + click to select a range
74562f7
hack to fix iOS11.3
alexreardon b0794eb
refinements
alexreardon b016a7f
comment improvements
alexreardon bfe46e9
adding warning to docs
alexreardon 1dc957c
using a single event listener (pro hack mode)
alexreardon b2f17d7
cleanup
alexreardon 405bca6
improving naming and fixing for browsers based on iphone / ipad
alexreardon 361afa4
improving doc language
alexreardon 46487e5
simplification
alexreardon File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -135,10 +135,52 @@ export default ({ | |
kill(callbacks.onCancel); | ||
}; | ||
|
||
// Safari 11.3 hack | ||
// Safari does not allow event.preventDefault() in dynamically added handlers | ||
// So we add an always listening event handler to get around this :( | ||
// webkit bug: https://bugs.webkit.org/show_bug.cgi?id=184250 | ||
(() => { | ||
// Do nothing when server side rendering | ||
if (typeof window === 'undefined') { | ||
return; | ||
} | ||
|
||
const isUsingSafari11: RegExp = /AppleWebKit.*Version\/11/g; | ||
|
||
// Not using Safari 11 | ||
if (!isUsingSafari11.test(window.navigator.userAgent)) { | ||
return; | ||
} | ||
|
||
// Using Safari 11 with no touch support - no point adding the touch listeners | ||
if (!('ontouchstart' in window)) { | ||
return; | ||
} | ||
|
||
// Adding a persistent event handler | ||
window.addEventListener('touchmove', (event: TouchEvent) => { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Is there any part of the lifecycle where we would want to remove the event listener? E.g. on unmount? |
||
if (!state.isDragging) { | ||
return; | ||
} | ||
|
||
// Our normal event handler should have done this | ||
if (event.defaultPrevented) { | ||
return; | ||
} | ||
|
||
// Okay, now we need to step in and fix things | ||
event.preventDefault(); | ||
|
||
// Forcing this to be non-passive so we can get every touchmove | ||
// Not activating in the capture phase like the dynamic touchmove we add. | ||
// Technically it would not matter if we did this in the capture phase | ||
}, { passive: false, capture: false }); | ||
})(); | ||
|
||
const windowBindings: EventBinding[] = [ | ||
{ | ||
eventName: 'touchmove', | ||
// opting out of passive touchmove (default) so as to prevent scrolling while moving | ||
// Opting out of passive touchmove (default) so as to prevent scrolling while moving | ||
// Not worried about performance as effect of move is throttled in requestAnimationFrame | ||
options: { passive: false }, | ||
fn: (event: TouchEvent) => { | ||
|
@@ -163,7 +205,9 @@ export default ({ | |
y: clientY, | ||
}; | ||
|
||
// already dragging | ||
// We need to prevent the default event in order to block native scrolling | ||
// Also because we are using it as part of a drag we prevent the default action | ||
// as a sign that we are using the event | ||
event.preventDefault(); | ||
schedule.move(point); | ||
}, | ||
|
@@ -311,6 +355,7 @@ export default ({ | |
// We need to stop parents from responding to this event - which may cause a double lift | ||
// We also need to NOT call event.preventDefault() so as to maintain as much standard | ||
// browser interactions as possible. | ||
// This includes navigation on anchors which we want to preserve | ||
touchStartMarshal.handle(); | ||
|
||
startPendingDrag(event); | ||
|
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.
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.
You know it is a bad day when you need to do some browser sniffing 😢