Skip to content

Instantly share code, notes, and snippets.

@mhingston
Last active January 14, 2023 09:26
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save mhingston/17f3cebf80ad74615e9db7d06a8576dc to your computer and use it in GitHub Desktop.
Save mhingston/17f3cebf80ad74615e9db7d06a8576dc to your computer and use it in GitHub Desktop.
Swipe to refresh for browsers
// ==UserScript==
// @name Swipe to Refresh
// @namespace https://jumpkick.io/
// @version 1.0.0
// @author Miles Hingston
// @include *
// @noframes
// @grant none
// ==/UserScript==
(function() {
'use strict';
const img = document.createElement('img');
img.src = ``;
img.style='width: 48px; height: 48px; z-index: 999; position: fixed; left: calc(50% - 24px); top: -48px; border: 0';
document.body.appendChild(img);
let startY, lastY, topOfPage;
window.addEventListener('touchstart', function(e)
{
if(e.changedTouches.length === 1)
{
startY = lastY = e.changedTouches[0].pageY;
topOfPage = window.scrollY === 0;
}
});
window.addEventListener('touchmove', function(e)
{
if(e.changedTouches.length === 1 && topOfPage && e.changedTouches[0].pageY > lastY)
{
lastY = e.changedTouches[0].pageY;
const pageY = -48 + (lastY - startY);
if(pageY <= 128)
{
img.style.top = `${pageY}px`;
}
}
});
window.addEventListener('touchend', function(e)
{
if(topOfPage && e.changedTouches.length === 1 && e.changedTouches[0].pageY - startY >= 128)
{
location.reload();
}
else
{
img.style.top = '-48px';
}
});
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment