WME Reload - Refresh

Make the refresh button to refresh the browser

// ==UserScript==
// @name         WME Reload - Refresh
// @description  Make the refresh button to refresh the browser
// @namespace    https://greasyfork.org/users/gad_m/wme_reload_refresh
// @version      1.0.10
// @author       gad_m
// @license      MIT
// @include 	 /^https:\/\/(www|beta)\.waze\.com\/(?!user\/)(.{2,6}\/)?editor.*$/
// @exclude      https://www.waze.com/user/*editor/*
// @exclude      https://www.waze.com/*/user/*editor/*
// @grant        GM_openInTab
// @icon         
// ==/UserScript==

/* global W */
/* global jQuery */

(function() {

    'use strict';
    console.info('wme-reload-refresh: loaded');

    if (typeof W !== 'undefined' && W['userscripts'] && W['userscripts']['state'] && W['userscripts']['state']['isInitialized']) {
        console.debug('wme-reload-refresh: WME is initialized.');
        init();
    } else {
        console.debug('wme-reload-refresh: WME is not initialized. adding event listener.');
        document.addEventListener("wme-logged-in", init, {
            once: true,
        });
    }

    function init() {
        console.debug('wme-reload-refresh: init()');
        addUI();
        addSaveEvent();
    }

    function addUI() {
        console.debug('wme-reload-refresh: addUI()');
        addRefreshButton();
        addReloadClickEvent();
    }

    function addSaveEvent() {
        console.debug('wme-reload-refresh: addSaveEvent()...');
        waitForElementConnected("#save-button", 10000).then((saveButton) => {
            jQuery(saveButton).on('click', () => {
                console.debug("wme-reload-refresh: 'Save' button clicked...");
                addUI();
            });
        });
    }

    function addRefreshButton() {
        console.debug('wme-reload-refresh: addRefreshButton()...');
        waitForElementConnected(".reload-button", 10000).then((reloadButton) => {
            let exiting = jQuery("#reload-refresh-button").length;
            if (!exiting) {
                let buttonsContainer = jQuery(".overlay-buttons-container.top");
                let clonedButton = jQuery(reloadButton).clone();
                clonedButton.removeClass('reload-button');
                clonedButton.addClass('refresh-button');
                clonedButton.attr("id", "reload-refresh-button");
                clonedButton.removeAttr('disabled');
                buttonsContainer.append(clonedButton);
                console.debug('wme-reload-refresh: addRefreshButton() done.');
            } else {
                console.debug('wme-reload-refresh: addRefreshButton() button exits.');
            }
        }).catch((error) => {
            console.error(error);
        });
    }

    function addReloadClickEvent() {
        console.debug('wme-reload-refresh: addReloadClickEvent()...');
        waitForElementConnected("#reload-refresh-button").then((element) => {
            let reloadRefreshButton = jQuery(element);
            reloadRefreshButton.attr('title', 'Refresh browser with current permalink');
            reloadRefreshButton.on('click', refreshButtonClicked);
            console.debug('wme-reload-refresh: addReloadClickEvent() done.');
            return false;
        }).catch((error) => {
            console.error(error);
        });
    }

    function refreshButtonClicked(evt) {
        console.debug('wme-reload-refresh: refreshButtonClicked() refresh button clicked');
        let permalink = jQuery(".permalink");
        let href = (permalink && permalink[0])?permalink[0].getAttribute("href"):null;
        href = enrichWithLayersBitmask(href);
        console.info('wme-reload-refresh: refreshButtonClicked() setting browser URL to: ' + href);
        if (evt && evt.shiftKey) {
            window.open(href);
        } else if (evt && (evt.metaKey || evt.shiftKey)) {
            GM_openInTab(href);
        } else {
            document.location = href;
        }
    }

    function enrichWithLayersBitmask(href) {
        console.debug('wme-reload-refresh: enrichWithLayersBitmask() href: ' + href);
        if (href) {
            let hasLayersBitmask = getLayersBitmask(href);
            if (!hasLayersBitmask) {
                let layersBitmask = W.map.getLayersBitmask();
                console.debug('wme-reload-refresh: enrichWithLayersBitmask() adding LayersBitmask: ' + layersBitmask);
                href += "&s=" + layersBitmask;
            } else {
                console.debug('wme-reload-refresh: enrichWithLayersBitmask() no need to add LayersBitmask');
            }
        }
        console.debug('wme-reload-refresh: enrichWithLayersBitmask() returning: ' + href);
        return href;
    }

    function getLayersBitmask(href) {
        let urlSearchParams = new URLSearchParams(href);
        return urlSearchParams.get('s');
    }

    function waitForElementConnected(selector, timeout = 2000) {
        console.debug("wme-reload-refresh: waitForElementConnected() selector: '" + selector + "'...");
        return new Promise((resolve, reject) => {
            const element = document.querySelector(selector);
            if (element && document.body.contains(element)) {
                resolve(element);
                return;
            }

            const observer = new MutationObserver((mutations, obs) => {
                const element = document.querySelector(selector);
                if (element && document.body.contains(element)) {
                    resolve(element);
                    obs.disconnect();
                }
            });

            observer.observe(document.body, {
                childList: true,
                subtree: true
            });

            setTimeout(() => {
                observer.disconnect();
                reject(new Error("wme-reload-refresh: Element '" + selector + "' not found within the timeout period"));
            }, timeout);
        });
    }


}.call(this));