MediaWiki:Common.js: Difference between revisions

From Roat Pkz
Jump to navigation Jump to search
No edit summary
No edit summary
Line 1: Line 1:
// COMMON.JS MINIMAL SAFE VERSION
document.addEventListener("DOMContentLoaded", function() {
document.addEventListener("DOMContentLoaded", function() {
     console.log("✅ Common.js Loaded");
     const container = document.getElementById("calcContainer");
    if (!container) return;


     // --- Tier Assignment ---
     container.innerHTML = `
    document.querySelectorAll('.tier-selector').forEach(function(sel) {
         <div style="margin:10px 0;">
         sel.addEventListener('change', function() {
             <label>Num1: <input type="number" id="num1" value="0" style="width:60px;"></label>
             const item = document.getElementById(this.id);
             <label>Num2: <input type="number" id="num2" value="0" style="width:60px;"></label>
             const targetTier = document.getElementById(this.value);
            <label>Operation:
             if (item && targetTier) targetTier.appendChild(item);
                <select id="op">
         });
                    <option value="+">+</option>
     });
                    <option value="-">-</option>
                    <option value="*">*</option>
                    <option value="/">/</option>
                </select>
             </label>
            <button id="calcButton">Calculate</button>
        </div>
         <div>Result: <span id="result">0</span></div>
     `;


    // --- Bingo ---
     document.getElementById("calcButton").addEventListener("click", function() {
     document.querySelectorAll(".bingo-table td .lighttable-cell").forEach(function(tile) {
         const a = parseFloat(document.getElementById("num1").value);
         const id = tile.dataset.key || tile.id;
         const b = parseFloat(document.getElementById("num2").value);
        if (!id) return;
        const op = document.getElementById("op").value;
         if (localStorage.getItem(id) === "selected") tile.classList.add("bingo-selected");
        let result;


         tile.addEventListener("click", function() {
         if (isNaN(a) || isNaN(b)) {
             tile.classList.toggle("bingo-selected");
             result = "Enter valid numbers";
             if (tile.classList.contains("bingo-selected")) {
        } else {
                 localStorage.setItem(id, "selected");
             switch(op) {
            } else {
                case "+": result = a + b; break;
                 localStorage.removeItem(id);
                case "-": result = a - b; break;
                 case "*": result = a * b; break;
                case "/": result = b !== 0 ? a / b : "∞"; break;
                 default: result = "Error";
             }
             }
         });
         }
    });
        document.getElementById("result").textContent = result;
 
    // --- Skill XP Calculator ---
    document.querySelectorAll(".skill-info-calc").forEach(function(table){
        const xpPerAction = parseInt(table.querySelector("span.total-xp").textContent);
        const numActionsElem = table.querySelector(".num-actions");
        const totalXPElem = table.querySelector(".total-xp");
 
        table.querySelector(".increase").addEventListener("click", function() {
            let actions = parseInt(numActionsElem.textContent) + 1;
            numActionsElem.textContent = actions;
            totalXPElem.textContent = actions * xpPerAction;
        });
 
        table.querySelector(".decrease").addEventListener("click", function() {
            let actions = parseInt(numActionsElem.textContent) - 1;
            if (actions < 0) actions = 0;
            numActionsElem.textContent = actions;
            totalXPElem.textContent = actions * xpPerAction;
        });
     });
     });
    // --- Simple Calculator ---
    const container = document.getElementById("calcContainer");
    if (container) {
        container.innerHTML = `
            <div style="margin:10px 0;">
                <label>Num1: <input type="number" id="num1" value="0" style="width:60px;"></label>
                <label>Num2: <input type="number" id="num2" value="0" style="width:60px;"></label>
                <label>Operation:
                    <select id="op">
                        <option value="+">+</option>
                        <option value="-">-</option>
                        <option value="*">*</option>
                        <option value="/">/</option>
                    </select>
                </label>
                <button id="calcButton">Calculate</button>
            </div>
            <div>Result: <span id="result">0</span></div>
        `;
        document.getElementById("calcButton").addEventListener("click", function() {
            const a = parseFloat(document.getElementById("num1").value);
            const b = parseFloat(document.getElementById("num2").value);
            const op = document.getElementById("op").value;
            let result;
            if (isNaN(a) || isNaN(b)) {
                result = "Enter valid numbers";
            } else {
                switch(op) {
                    case "+": result = a + b; break;
                    case "-": result = a - b; break;
                    case "*": result = a * b; break;
                    case "/": result = b !== 0 ? a / b : "∞"; break;
                    default: result = "Error";
                }
            }
            document.getElementById("result").textContent = result;
        });
    }
});
});

Revision as of 02:34, 5 March 2026

document.addEventListener("DOMContentLoaded", function() {
    const container = document.getElementById("calcContainer");
    if (!container) return;

    container.innerHTML = `
        <div style="margin:10px 0;">
            <label>Num1: <input type="number" id="num1" value="0" style="width:60px;"></label>
            <label>Num2: <input type="number" id="num2" value="0" style="width:60px;"></label>
            <label>Operation:
                <select id="op">
                    <option value="+">+</option>
                    <option value="-">-</option>
                    <option value="*">*</option>
                    <option value="/">/</option>
                </select>
            </label>
            <button id="calcButton">Calculate</button>
        </div>
        <div>Result: <span id="result">0</span></div>
    `;

    document.getElementById("calcButton").addEventListener("click", function() {
        const a = parseFloat(document.getElementById("num1").value);
        const b = parseFloat(document.getElementById("num2").value);
        const op = document.getElementById("op").value;
        let result;

        if (isNaN(a) || isNaN(b)) {
            result = "Enter valid numbers";
        } else {
            switch(op) {
                case "+": result = a + b; break;
                case "-": result = a - b; break;
                case "*": result = a * b; break;
                case "/": result = b !== 0 ? a / b : "∞"; break;
                default: result = "Error";
            }
        }
        document.getElementById("result").textContent = result;
    });
});