NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name XHReload // @namespace i2p.schimon.xhreload // @description Reloading page with an XML HTTP Request type of it. Hotkey: Command + Shift + H. // @homepageURL https://openuserjs.org/scripts/sjehuda/XHReload // @supportURL https://openuserjs.org/scripts/sjehuda/XHReload/issues // @updateURL https://openuserjs.org/meta/sjehuda/XHReload.meta.js // @downloadURL https://openuserjs.org/install/sjehuda/XHReload.user.js // @copyright 2024, Schimon Jehudah (http://schimon.i2p) // @license MIT; https://opensource.org/licenses/MIT // @match *://*/* // @version 24.04 // @run-at document-start // @grant GM.registerMenuCommand // @icon  // ==/UserScript== function xhreload() { let request = new XMLHttpRequest(); request.open('GET', document.documentURI); request.onload = function() { if (request.status >= 200 && request.status < 300) { let domParser = new DOMParser(); //let htmlFile = domParser.parseFromString(request.response.trim(), 'text/html'); let htmlFile = domParser.parseFromString(request.responseText, 'text/html'); let newDocument = document.importNode(htmlFile.documentElement, true); let oldDocument = document.documentElement; document.replaceChild(newDocument, oldDocument); } else { let errorMessage = 'Request failed with status: ' + request.status; console.error(errorMessage); alert(errorMessage); } }; request.send(); } function infoBar() { let namespace = 'i2p-schimon-ruffle'; let bar = document.createElement(namespace); document.body.append(bar); bar.innerHTML = 'XHR Reload'; bar.title = 'Flash elements have been detected on this page. Click this bar to activate Ruffle player.'; bar.id = namespace; bar.style.backgroundColor = '#fff'; bar.style.color = '#000'; bar.style.fontFamily = 'system-ui'; bar.style.fontSize = 'larger'; bar.style.fontWeight = 'bold'; bar.style.right = 0; bar.style.left = 0; bar.style.top = 0; bar.style.zIndex = 10000000000; bar.style.padding = '6px'; //13px //15px //11px //9px //3px //1px bar.style.position = 'fixed'; bar.style.textAlign = 'center'; // justify bar.style.direction = 'ltr'; bar.style.userSelect = 'none'; // set bar behaviour bar.onclick = () => { bar.style.display = 'none'; xhreload(); }; } function loadAtPageLoad(){ document.addEventListener("DOMContentLoaded", async function() { infoBar(); } ); } function hotkey(e) { console.log(e) if (e.metaKey && e.shiftKey && e.which == 72) { xhreload(); } } (function() { document.addEventListener('keyup', hotkey, false); //document.documentURI //document.location.search //location.search if (location.search.includes('__cf_chl_rt_tk')) { loadAtPageLoad(); } })(); (async function registerMenuCommand(){ try { await GM.registerMenuCommand('Rough Reload Command + Shift + H', () => xhreload(), 'H'); } catch (err) { console.warn(err); console.info('API GM.registerMenuCommand does not seem to be available.'); } })(); (function() { document.addEventListener('DOMContentLoaded', function() { if (window.location.search.includes('__cf_chl_rt_tk')) { xhreload(); } }); })();