Mobile Pull to Refresh

Adds pull-to-refresh functionality to Funny Junk mobile

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey, Greasemonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Userscripts.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een gebruikersscriptbeheerder nodig.

(Ik heb al een user script manager, laat me het downloaden!)

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

(Ik heb al een beheerder - laat me doorgaan met de installatie!)

// ==UserScript==
// @name         Mobile Pull to Refresh
// @namespace    http://tampermonkey.net/
// @version      1.0
// @description  Adds pull-to-refresh functionality to Funny Junk mobile
// @author       EMANON
// @match        *://funnyjunk.com/*
// @grant        none
// @license MIT
// ==/UserScript==

(function() {
    'use strict';

    let startY = 0;
    const threshold = 150; // Distance in pixels to trigger refresh

    // 1. Capture the starting point of the touch
    window.addEventListener('touchstart', (e) => {
        if (window.scrollY === 0) {
            startY = e.touches[0].pageY;
        }
    }, { passive: true });

    // 2. Track the movement
    window.addEventListener('touchmove', (e) => {
        const touchY = e.touches[0].pageY;
        const pullDistance = touchY - startY;

        // If user pulls down more than the threshold at the top of the page
        if (window.scrollY === 0 && pullDistance > threshold) {
            // Optional: You could add a visual CSS transform here
            console.log("Release to refresh...");
        }
    }, { passive: true });

    // 3. Trigger action on release
    window.addEventListener('touchend', (e) => {
        const touchY = e.changedTouches[0].pageY;
        const pullDistance = touchY - startY;

        if (window.scrollY === 0 && pullDistance > threshold) {
            // Perform the refresh
            location.reload();
        }
        // Reset startY
        startY = 0;
    });
})();