I've created a small HTML5 web application for my company.
This application displays a list of items and everything works fine.
The application is mainly used on android phones and Chrome as browser. Also, the site is saved on the home screen so Android manage the whole thing as an app (using a WebView I guess).
Chrome Beta (and I think also the Android System WebView) has introduced a "pull down to refresh" feature (See this link for example).
This is an handy feature but I was wondering if it can be disabled with some meta tag (or javascript stuff) because the refresh can be easily triggered by the user while navigating the list and the whole app is reloaded.
Also this is a feature not needed by the application.
I know that this feature is still available only in Chrome beta, but I have the sensation that this is landing on the stable app, too.
Thank you!
Edit: I've uninstalled Chrome Beta and the link pinned to the home screen now opens with the stable Chrome. So the pinned links starts with Chrome and not with a webview.
Edit: today (2015-03-19) the pull-down-to-refresh has come to the stable chrome.
Edit: from @Evyn answer I follow this link and got this javascript/jquery code that work.
var lastTouchY = 0;
var preventPullToRefresh = false;
$('body').on('touchstart', function (e) {
if (e.originalEvent.touches.length != 1) { return; }
lastTouchY = e.originalEvent.touches[0].clientY;
preventPullToRefresh = window.pageYOffset == 0;
});
$('body').on('touchmove', function (e) {
var touchY = e.originalEvent.touches[0].clientY;
var touchYDelta = touchY - lastTouchY;
lastTouchY = touchY;
if (preventPullToRefresh) {
// To suppress pull-to-refresh it is sufficient to preventDefault the first overscrolling touchmove.
preventPullToRefresh = false;
if (touchYDelta > 0) {
e.preventDefault();
return;
}
}
});
As @bcintegrity pointed out, I hope for a site manifest solution (and/or a meta-tag) in the future.
Moreover suggestions for the code above are welcome.