MediaWiki:Gadget-Navbar.js

From ChaosZeroNightmareWiki
Revision as of 15:55, 17 April 2026 by 律Rhyme (talk | contribs) (Style Edit)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Note: After publishing, you may have to bypass your browser's cache to see the changes.

  • Firefox / Safari: Hold Shift while clicking Reload, or press either Ctrl-F5 or Ctrl-R (⌘-R on a Mac)
  • Google Chrome: Press Ctrl-Shift-R (⌘-Shift-R on a Mac)
  • Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5.
(function () {
    var style =
        /* ================= Base Navigation Styles ================= */
        '.czn-navbar{position:absolute;top:0;left:0;width:100%;height:70px;display:flex;align-items:center;justify-content:space-between;padding:0 40px;z-index:9999;border-bottom:1px solid rgba(255,255,255,0.05)}' +

        /* Three-section Flex Layout */
        '.czn-nav-left,.czn-nav-right{flex:1;display:flex;align-items:center}' +
        '.czn-nav-left{justify-content:flex-start;gap:0}' +
        '.czn-nav-center{display:flex;justify-content:center}' +
        '.czn-nav-right{justify-content:flex-end;gap:20px}' +

        /* ================= Left LOGO Area ================= */
        '.czn-logo-group{display:flex;align-items:center}' +
        '.czn-logo{height:40px;width:auto;object-fit:contain;display:block}' +

        /* ================= Right Search Box ================= */
        '.czn-search-box{position:relative}' +
        '.czn-search-box input{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);color:#fff;padding:8px 15px;border-radius:20px;width:200px;outline:none;transition:all 0.3s;font-size:14px}' +
        '.czn-search-box input::placeholder{color:rgba(255,255,255,0.4)}' +
        '.czn-search-box input:focus{border-color:#ff540c;background:rgba(255,255,255,0.15)}' +
        '.czn-search-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:#ff540c;color:#fff;border:none;padding:5px 12px;border-radius:16px;cursor:pointer;font-size:12px;font-weight:bold;transition:all 0.3s}' +
        '.czn-search-btn:hover{background:#ff6a2a}' +

        /* ================= Desktop Menu Styles ================= */
        '.czn-nav-menu{display:flex;list-style:none;gap:35px;margin:0;padding:0;height:100%;align-items:center}' +
        '.czn-nav-menu li{position:relative;list-style:none}' +
        '.czn-nav-menu>li>a{text-decoration:none!important;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 0;position:relative;transition:all 0.3s}' +

        /* Menu Item Text */
        '.czn-nav-menu li a .czn-text{color:#ffffff;font-size:15px;font-weight:600;letter-spacing:1px;text-transform:uppercase;transition:color 0.3s}' +

        /* Hover & Active States */
        '.czn-nav-menu>li:hover>a .czn-text,.czn-nav-menu>li.czn-active>a .czn-text{color:#ff540c}' +

        /* ================= Dropdown Menus ================= */
        '.czn-dropdown-2,.czn-dropdown-3{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(15px);background:rgba(0,0,0,0.9);border-radius:8px;min-width:160px;padding:10px 0;opacity:0;visibility:hidden;transition:all 0.3s ease;box-shadow:0 10px 30px rgba(0,0,0,0.5);list-style:none;margin:0}' +
        '.czn-dropdown-3{top:0;left:100%;transform:translateX(15px) translateY(0)}' +

        /* Show on Hover */
        '.czn-nav-menu li:hover>.czn-dropdown-2{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}' +
        '.czn-dropdown-2 li:hover>.czn-dropdown-3{opacity:1;visibility:visible;transform:translateX(0) translateY(0)}' +

        /* Dropdown Item Style */
        '.czn-dropdown-2 li a,.czn-dropdown-3 li a{padding:12px 20px;text-align:left;display:block;text-decoration:none!important}' +
        '.czn-dropdown-2 li a .czn-text,.czn-dropdown-3 li a .czn-text{font-size:13px;color:#fff;white-space:nowrap}' +
        '.czn-dropdown-2 li:hover>a .czn-text,.czn-dropdown-3 li:hover>a .czn-text{color:#ff540c}' +

        /* ================= Mobile Menu Toggle ================= */
        '.czn-menu-toggle{display:none;color:#fff;font-size:28px;cursor:pointer;z-index:10001;position:relative;background:none;border:none;padding:0;line-height:1}' +

        /* ================= Responsive Layout ================= */
        '@media(max-width:1024px){' +
            '.czn-navbar{padding:0 20px}' +
            '.czn-logo-group{display:none}' +
            '.czn-search-box{display:none}' +
            '.czn-menu-toggle{display:block}' +
            '.czn-nav-menu{position:fixed;top:0;left:-100%;width:260px;height:100vh;background:rgba(15,15,15,0.98);flex-direction:column;gap:0;padding-top:80px;transition:left 0.4s ease-in-out;overflow-y:auto;border-right:1px solid rgba(255,255,255,0.1);z-index:10000;margin:0}' +
            '.czn-nav-menu.czn-active{left:0}' +
            '.czn-nav-menu li{width:100%}' +
            '.czn-nav-menu>li>a{padding:15px 20px;align-items:flex-start;border-bottom:1px solid rgba(255,255,255,0.05)}' +
            '.czn-dropdown-2,.czn-dropdown-3{position:static;transform:none!important;opacity:1;visibility:visible;box-shadow:none;background:transparent;padding:0;width:100%}' +
            '.czn-dropdown-2 li a{padding-left:40px;background:rgba(255,255,255,0.02)}' +
            '.czn-dropdown-3{display:none;background:rgba(0,0,0,0.3)}' +
            '.czn-dropdown-3.czn-open{display:block}' +
            '.czn-dropdown-3 li a{padding-left:60px}' +
        '}';

    /* Base Wiki URL Configuration */
    var wikiBase = 'https://cznwiki.com/index.php?title=';

    function wikiUrl(title) {
        return wikiBase + encodeURIComponent(title).replace(/%2F/g, '/').replace(/%3A/g, ':');
    }

    var navHtml =
        '<nav class="czn-navbar">' +
            /* Left: Mobile Toggle & Single Logo */
            '<div class="czn-nav-left">' +
                '<button class="czn-menu-toggle" id="czn-mobile-menu-btn">☰</button>' +
                '<div class="czn-logo-group">' +
                    '<a href="https://cznwiki.com/">' +
                        '<img src="https://cznwiki.com/images/c/c9/Logo.png" alt="CZN WIKI" class="czn-logo">' +
                    '</a>' +
                '</div>' +
            '</div>' +

            /* Center: Navigation Menu */
            '<div class="czn-nav-center">' +
                '<ul class="czn-nav-menu" id="czn-nav-menu">' +

                    /* HOME Section */
                    '<li>' +
                        '<a href="https://cznwiki.com/">' +
                            '<span class="czn-text">HOME</span>' +
                        '</a>' +
                        '<ul class="czn-dropdown-2">' +
                            '<li><a href="' + wikiUrl('Main_Page') + '"><span class="czn-text">BACK</span></a></li>' +
                            '<li><a href="https://cznwiki.com/index.php?title=%E9%A6%96%E9%A1%B5&action=purge"><span class="czn-text">REFRESH</span></a></li>' +
                        '</ul>' +
                    '</li>' +

                    /* WIKI Section */
                    '<li>' +
                        '<a href="#"><span class="czn-text">WIKI</span></a>' +
                        '<ul class="czn-dropdown-2">' +
                            '<li><a href="' + wikiUrl('Combatant') + '"><span class="czn-text">Combatant</span></a></li>' +
                            '<li><a href="' + wikiUrl('Partner') + '"><span class="czn-text">Partner</span></a></li>' +
                            '<li><a href="' + wikiUrl('Card') + '"><span class="czn-text">Card</span></a></li>' +
                            '<li><a href="' + wikiUrl('Relic') + '"><span class="czn-text">Relic</span></a></li>' +
                            '<li><a href="' + wikiUrl('Encounter') + '"><span class="czn-text">Encounter</span></a></li>' +
                        '</ul>' +
                    '</li>' +

                    /* DATA Section */
                    '<li>' +
                        '<a href="#"><span class="czn-text">DATA</span></a>' +
                        '<ul class="czn-dropdown-2">' +
                            '<li><a href="' + wikiUrl('Item') + '"><span class="czn-text">Item</span></a></li>' +
                            '<li class="czn-has-level-3">' +
                                '<a href="#" class="czn-l3-toggle"><span class="czn-text">Art</span></a>' +
                                '<ul class="czn-dropdown-3">' +
                                    '<li><a href="' + wikiUrl('Official_Media') + '"><span class="czn-text">Official Media</span></a></li>' +
                                    '<li><a href="' + wikiUrl('Fanart') + '"><span class="czn-text">Fanart</span></a></li>' +
                                '</ul>' +
                            '</li>' +
                        '</ul>' +
                    '</li>' +

                    /* TOOLS Section */
                    '<li>' +
                        '<a href="#"><span class="czn-text">TOOLS</span></a>' +
                        '<ul class="czn-dropdown-2">' +
                            '<li><a href="' + wikiUrl('Deck_Builder') + '"><span class="czn-text">Deck Builder</span></a></li>' +
                        '</ul>' +
                    '</li>' +

                '</ul>' +
            '</div>' +

            /* Right: Search Box */
            '<div class="czn-nav-right">' +
                '<div class="czn-search-box">' +
                    '<form action="https://cznwiki.com/index.php" method="get" style="display:flex;align-items:center;margin:0">' +
                        '<input type="hidden" name="title" value="Special:Search">' +
                        '<input type="text" name="search" placeholder="Search Wiki...">' +
                        '<button type="submit" name="go" class="czn-search-btn">GO</button>' +
                    '</form>' +
                '</div>' +
            '</div>' +
        '</nav>';

    function q(s) { return document.querySelector(s); }

    var initNav = function () {
        if (q('.czn-navbar')) return;

        /* Inject CSS Styles */
        var styleTag = document.createElement('style');
        styleTag.type = 'text/css';
        if (styleTag.styleSheet) {
            styleTag.styleSheet.cssText = style;
        } else {
            styleTag.appendChild(document.createTextNode(style));
        }
        document.getElementsByTagName('head')[0].appendChild(styleTag);

        /* Inject Navigation HTML */
        var body = document.body || document.getElementsByTagName('body')[0];
        body.insertAdjacentHTML('afterbegin', navHtml);

        /* Mobile Sidebar Toggle Logic */
        var mobileBtn = document.getElementById('czn-mobile-menu-btn');
        var navMenu = document.getElementById('czn-nav-menu');

        if (mobileBtn && navMenu) {
            mobileBtn.addEventListener('click', function () {
                navMenu.classList.toggle('czn-active');
                mobileBtn.innerHTML = navMenu.classList.contains('czn-active') ? '✕' : '☰';
            });

            document.addEventListener('click', function (e) {
                if (window.innerWidth <= 1024) {
                    if (!navMenu.contains(e.target) && !mobileBtn.contains(e.target)) {
                        navMenu.classList.remove('czn-active');
                        mobileBtn.innerHTML = '☰';
                    }
                }
            });
        }

        /* Mobile Level-3 Menu Click Logic */
        var level3Toggles = document.querySelectorAll('.czn-l3-toggle');
        level3Toggles.forEach(function (toggle) {
            toggle.addEventListener('click', function (e) {
                if (window.innerWidth <= 1024) {
                    e.preventDefault();
                    var subMenu = this.nextElementSibling;
                    if (subMenu && subMenu.classList.contains('czn-dropdown-3')) {
                        subMenu.classList.toggle('czn-open');
                    }
                }
            });
        });
    };

    /* Start initialization */
    initNav();
})();