Smartschool premium

Vervang lokaal je naam en profielfoto in Smartschool

// ==UserScript==
// @name         Smartschool premium
// @namespace    http://tampermonkey.net/
// @icon         https://static1.smart-school.net/smsc/svg/favicon/favicon.svg
// @version      1.0
// @description  Vervang lokaal je naam en profielfoto in Smartschool
// @author       Kian
// @match        https://*.smartschool.be/*
// @grant        none
// @run-at       document-idle
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    // --- Pas hier je naam en profielfoto aan ---
    const NIEUWE_NAAM = "Peter Griffin";
    const NIEUWE_FOTO = ""; // vervang door jouw directe foto-URL

    // Wacht tot de pagina geladen is
    window.addEventListener("load", () => {
        // Naam aanpassen
        let nameElement = document.querySelector(".hlp-vert-box span");
        if (nameElement) {
            nameElement.textContent = NIEUWE_NAAM;
        }

        // Profielfoto aanpassen
        let imgElement = document.querySelector("img[alt='Profiel afbeelding']");
        if (imgElement) {
            imgElement.src = NIEUWE_FOTO;
        }
    });
    document.body.style.backgroundImage = "url('https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQ_QfG2o0Fgso99xsMvaT8-q9cpgQhR2y4ihw&s')";
document.body.style.backgroundSize = "cover";
    document.title = "Smartschool Premium";

    document.body.style.fontFamily = "Comic Sans MS, cursive, sans-serif";

let bar = document.createElement("div");
bar.innerHTML = `
  <a href="/planner/main/user/" style="margin:0 10px">Planner</a>
  <a href="/results/main/results/details/">Resultaten</a>
  <a href="https://app.lernova.be/nl-be/boekentas">Lernova</a>
  <a href="https://apps.plantyn.com/my/nl-be/bookshelf?redirectPath=%2F&redirectPlatform=sep">Scoodle</a>
  <a href="https://www.pelckmansportaal.be/dashboard">Pelckmans Portaal</a>
  <a href="https://platform.ididdit.be/">iDiddit</a>
`;
bar.style.cssText = "background:#222;color:#fff;padding:10px;text-align:center;";
document.body.prepend(bar);

    // selecteer de bovenste navigatiebalk
const topbar = document.querySelector(".topnav");
if (topbar) {
  topbar.style.backgroundColor = "yellow"; // kleur aanpassen
  topbar.style.borderBottom = "2px solid #c90001"; // optioneel: rood randje voor accent
}

// eventueel de tekstkleur aanpassen zodat het goed zichtbaar is
const topbarTexts = topbar.querySelectorAll(".topnav__btn, .topnav__menuitem");
topbarTexts.forEach(el => el.style.color = "black");

    // ==UserScript==
// @name         Matrix Regen Toggle
// @match        *://*/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    let matrixActive = false;
    let canvas, ctx, interval;
    let drops = [];
    const fontSize = 16;

    // normale achtergrondkleur onthouden
    const normalBackground = document.body.style.backgroundColor || "#fff";

    function startMatrix() {
        // canvas maken
        canvas = document.createElement("canvas");
        canvas.id = "matrixCanvas";
        canvas.style.position = "fixed";
        canvas.style.top = "0";
        canvas.style.left = "0";
        canvas.style.width = "100%";
        canvas.style.height = "100%";
        canvas.style.zIndex = "0";
        canvas.style.pointerEvents = "none"; // zodat je nog steeds kunt klikken
        document.body.appendChild(canvas);

        ctx = canvas.getContext("2d");
        canvas.width = window.innerWidth;
        canvas.height = window.innerHeight;

        const columns = Math.floor(canvas.width / fontSize);
        for (let i = 0; i < columns; i++) {
            drops[i] = 1;
        }

        interval = setInterval(drawMatrix, 50);

        window.addEventListener("resize", resizeCanvas);
    }

    function drawMatrix() {
        ctx.fillStyle = "rgba(0, 0, 0, 0.05)"; // lichte fade
        ctx.fillRect(0, 0, canvas.width, canvas.height);

        ctx.fillStyle = "#0F0"; // groen
        ctx.font = fontSize + "px monospace";

        for (let i = 0; i < drops.length; i++) {
            const text = String.fromCharCode(Math.floor(Math.random() * 128));
            ctx.fillText(text, i * fontSize, drops[i] * fontSize);

            if (drops[i] * fontSize > canvas.height && Math.random() > 0.975) {
                drops[i] = 0;
            }
            drops[i]++;
        }
    }

    function resizeCanvas() {
        canvas.width = window.innerWidth;
        canvas.height = window.innerHeight;
    }

    function stopMatrix() {
        clearInterval(interval);
        window.removeEventListener("resize", resizeCanvas);
        if (canvas) {
            canvas.remove();
        }
        document.body.style.backgroundColor = normalBackground;
    }

    // toggle bij Ctrl + Y
    document.addEventListener("keydown", function(e) {
        if (e.ctrlKey && e.key.toLowerCase() === "y") {
            matrixActive = !matrixActive;
            if (matrixActive) {
                startMatrix();
            } else {
                stopMatrix();
            }
        }
    });

})();

    // Maak het cirkeltje
    const cursorCircle = document.createElement('div');
    cursorCircle.id = 'cursor-circle';
    document.body.appendChild(cursorCircle);

    // Voeg CSS toe
    const style = document.createElement('style');
    style.textContent = `
        #cursor-circle {
            position: fixed;
            width: 20px;
            height: 20px;
            border: 2px solid lightblue;
            border-radius: 50%;
            pointer-events: none;
            transform: translate(-50%, -50%);
            z-index: 9999;
            transition: transform 0.05s linear;
        }
    `;
    document.head.appendChild(style);

    // Laat het cirkeltje de cursor volgen
    document.addEventListener('mousemove', (e) => {
        cursorCircle.style.left = e.clientX + 'px';
        cursorCircle.style.top = e.clientY + 'px';
    });

    (function() {
    'use strict';

    // ---- Playground venster ----
    let box = document.createElement("div");
    box.style.cssText = `
        position:fixed; top:50px; right:20px; width:700px; height:650px;
        background:#222; color:#fff; z-index:99999; display:flex; flex-direction:column;
        border-radius:10px; overflow:hidden; box-shadow:0 0 20px rgba(0,0,0,0.5);
        font-family:monospace;
    `;
    box.style.display = "none"; // start onzichtbaar
    document.body.appendChild(box);

    // Tabs
    let tabBar = document.createElement("div");
    tabBar.style.cssText = "display:flex;background:#111;";
    box.appendChild(tabBar);

    let tabs = ["HTML","CSS","JS"];
    let editors = {};
    let activeTab = "HTML";

    tabs.forEach(tab => {
        let btn = document.createElement("button");
        btn.textContent = tab;
        btn.style.cssText = "flex:1;padding:8px;border:none;background:#333;color:#fff;cursor:pointer;";
        btn.onclick = () => switchTab(tab);
        tabBar.appendChild(btn);

        let textarea = document.createElement("textarea");
        textarea.style.cssText = "flex:1;display:none;background:#000;color:#0f0;font-size:14px;padding:5px;";
        textarea.value = "";
        editors[tab] = textarea;
        box.appendChild(textarea);
    });

    // Buttons bar
    let btnBar = document.createElement("div");
    btnBar.style.cssText = "background:#111;padding:5px;text-align:right;display:flex;gap:5px;";
    box.insertBefore(btnBar, box.lastChild);

    let runBtn = document.createElement("button");
    runBtn.textContent = "▶ Run";
    runBtn.style.cssText = "padding:5px 10px;background:#28a745;color:#fff;border:none;cursor:pointer;";
    runBtn.onclick = runCode;
    btnBar.appendChild(runBtn);

    // Save buttons
    let saveHTML = document.createElement("button");
    saveHTML.textContent = "💾 Save HTML";
    saveHTML.onclick = () => downloadFile("index.html", editors["HTML"].value);
    btnBar.appendChild(saveHTML);

    let saveCSS = document.createElement("button");
    saveCSS.textContent = "💾 Save CSS";
    saveCSS.onclick = () => downloadFile("style.css", editors["CSS"].value);
    btnBar.appendChild(saveCSS);

    let saveJS = document.createElement("button");
    saveJS.textContent = "💾 Save JS";
    saveJS.onclick = () => downloadFile("script.js", editors["JS"].value);
    btnBar.appendChild(saveJS);

    // Output frame
    let output = document.createElement("iframe");
    output.style.cssText = "flex:1;background:#fff;border:none;";
    box.appendChild(output);

    // Functies
    function switchTab(tab) {
        activeTab = tab;
        tabs.forEach(t => editors[t].style.display = (t === tab) ? "block" : "none");
    }

    function runCode() {
        let html = editors["HTML"].value;
        let css = `<style>${editors["CSS"].value}</style>`;
        let js = `<script>${editors["JS"].value}<\/script>`;
        output.srcdoc = html + css + js;
    }

    function downloadFile(filename, content) {
        const blob = new Blob([content], { type: "text/plain" });
        const link = document.createElement("a");
        link.href = URL.createObjectURL(blob);
        link.download = filename;
        link.click();
        URL.revokeObjectURL(link.href);
    }

    switchTab("HTML"); // start met HTML open

    // ---- Knop in de linkerbalk ----
    function addSidebarButton() {
        let targetBlock = document.querySelector("#homepage__block--28881 .homepage__block__content"); // lokaalwissels
        if (!targetBlock) return;

        let newBtn = document.createElement("button");
        newBtn.textContent = "🌐 Open Website Maker";
        newBtn.style.cssText = `
            display:block;width:90%;margin:10px auto;padding:10px;
            background:#007bff;color:#fff;border:none;border-radius:6px;
            cursor:pointer;font-weight:bold;
        `;
        newBtn.onclick = () => {
            box.style.display = (box.style.display === "none") ? "flex" : "none";
        };

        targetBlock.appendChild(newBtn);
    }

    // Wacht tot de pagina geladen is
    window.addEventListener("load", addSidebarButton);

})();
})();