UserScript Automated Element Text Notifier

This script is intended to work with @require only. Provides class AutomatedElementTextNotifier

Questo script non dovrebbe essere installato direttamente. È una libreria per altri script da includere con la chiave // @require https://update.greasyfork.org/scripts/438801/1019653/UserScript%20Automated%20Element%20Text%20Notifier.js

Dovrai installare un'estensione come Tampermonkey, Greasemonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Userscripts per installare questo script.

Dovrai installare un'estensione come ad esempio Tampermonkey per installare questo script.

Dovrai installare un gestore di script utente per installare questo script.

(Ho già un gestore di script utente, lasciamelo installare!)

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

(Ho già un gestore di stile utente, lasciamelo installare!)

// ==UserScript==
// @namespace    Xortrox/UserScripts/AutomatedElementTextNotifier
// @name         UserScript Automated Element Text Notifier
// @version      0.7
// @description  This script is intended to work with @require only. Provides class AutomatedElementTextNotifier
// @author       Xortrox,
// @match        *
// @esversion:   6
// @license MIT
// ==/UserScript==

class AutomatedElementTextNotifier {
    constructor(options) {
        this.icon = options.icon || '';
        this.title = options.title || 'No Title Specified';

        this.selector = options.selector;

        /** How frequently to scan for changes on the website (in milliseconds) */
        this.notificationInterval = options.interval;


        /**
         * Every includes/excludes does a check for selector matched element's "innerText" value
         * Each entry will be checked in priority from top to bottom and only the first match will send its notification
         * All configs must have an includes entry, while exclusion is optional.
         * */
        this.scanConfiguration = options.config;

        if (!this.selector) {
            this.error('Error: No selector specified for AutomatedElementTextNotifier');
        }
    }

    async init() {
        await window.UserScript.Notifications.askPermission();

        this.interval = setInterval(this.scan, this.notificationInterval);
    }

    scan = () => {
        const notificationElements = document.querySelectorAll(this.selector);

        /** We send notification only once if any adventures are claimable */
        if (notificationElements && notificationElements.length > 0) {
            let notified = false;

            for (let element of notificationElements) {
                if (notified) {
                    break;
                }

                const text = element.innerText;

                const textLower = text.toLowerCase();

                for (const config of this.scanConfiguration) {
                    let includesText = false;
                    let excludesText = false;

                    for (const includeText of config.includes) {
                        if (textLower.includes(includeText)) {
                            includesText = true;
                            break;
                        }
                    }

                    if (config.excludes?.length > 0) {
                        for (const excludeText of config.excludes) {
                            if (!textLower.includes(excludeText)) {
                                excludesText = true;
                                break;
                            }
                        }
                    }

                    let canShowNotification = includesText;

                    if (config.excludes?.length > 0) {
                        canShowNotification = canShowNotification && excludesText;
                    }

                    if (canShowNotification) {
                        window.UserScript.Notifications.notify(this.title, config.notificationText, this.icon);
                        notified = true;
                        break;
                    }
                }
            }
        }
    }

    error(error) {
        alert(error);
        console.error(new Error(error));
    }
}