メニューを切り替える
個人設定メニューを切り替える
個人メニューを切り替える
ログインしていません
編集を行うと、IPアドレスが公開されます。

「MediaWiki:Common.js」の版間の差分

MediaWikiインターフェイスページ
a
編集の要約なし
 
(同じ利用者による、間の11版が非表示)
32行目: 32行目:
     const pageTitle = mw.config.get('wgPageName')
     const pageTitle = mw.config.get('wgPageName')
     const pageNo = mw.config.get('wgRevisionId')
     const pageNo = mw.config.get('wgRevisionId')
     const url = `https://wiki.tmyt105.com/w/api.php?action=query&format=json&prop=revisions&formatversion=2&revids=${pageNo}&rvprop=user`;
     const url = `https://${location.hostname}/w/api.php?action=query&format=json&prop=revisions&formatversion=2&revids=${pageNo}&rvprop=user`;
     const updaterElement = document.getElementById('last-updater-name');
     const updaterElement = document.getElementById('last-updater-name');


70行目: 70行目:
/* beta2 ここまで */
/* beta2 ここまで */


/* お知らせよう */
/* スマホめにゅー */
$(function() {
(function() {
     var $notice = $('#wiki-origin-notice');
     function injectCustomMenu() {
    if (!$notice.length) return;
        if ($('#p-custom-links').length) return
        if (!(mw.config.get('skin') === "minerva")) return


    var contentId = $notice.data('content-id');
        var $navUl = $('#p-navigation');
    var cookieName = 'originnotice-' + contentId;
        var $personalUl = $('#p-personal');


    // Cookieがあるか確認
        if ($navUl.length && $personalUl.length) {
    if (document.cookie.indexOf(cookieName + '=true') > -1) {
            var items = [
        $notice.hide();
                { label: '方針', url: '/wiki/Wiki:方針', icon: 'expand' },
    }
                { label: '特別ページ一覧', url: '/wiki/特別:特別ページ一覧', icon: 'star' },
                { label: '全てのページ', url: '/wiki/特別:ページ一覧', icon: 'listBullet' },
                { label: '最近の更新', url: '/wiki/特別:最近の更新', icon: 'history' }
            ];


    $('#close-notice-btn').on('click', function() {
            var html = '<ul id="p-custom-links" class="toggle-list__list">';
        $notice.fadeOut();
           
        var date = new Date();
            items.forEach(function(item) {
        date.setTime(date.getTime() + (30 * 24 * 60 * 60 * 1000));
                html += '<li class="toggle-list-item">' +
        var expires = "; expires=" + date.toUTCString();
                            '<a href="' + item.url + '" class="toggle-list-item__anchor menu__item--' + item.icon + '">' +
        document.cookie = cookieName + "=true" + expires + "; path=/";
                                '<span class="minerva-icon minerva-icon--' + item.icon + '"></span>' +
    });
                                '<span class="toggle-list-item__label">' + item.label + '</span>' +
});
                            '</a>' +
                        '</li>';
            });
           
            html += '</ul>';


/* スマホめにゅー */
            $navUl.after(html);
/* Main function */
         }
var timer = setInterval(function() {
    }
    if ($('.menu ul:first').length) {
        console.log("mobile menu exists");
        clearInterval(timer);
 
         $('.menu ul:first').after(
            '<ul class="level1"> \
                <li> \
                    <a href="#" class="mw-ui-icon mw-ui-icon-before mw-ui-icon-mf-expand mw-ui-icon-small"> \
                        <span>Wikiリンク</span> \
                    </a> \
                </li> \
                <ul class="level2"> \
                    <li> \
                        <a href="/wiki/Wiki:方針" class="mw-ui-icon mw-ui-icon-before mw-ui-icon-notice"> \
                            <span>方針</span> \
                        </a> \
                    </li> \
                    <li> \
                        <a href="/wiki/特別:特別ページ一覧" class="mw-ui-icon mw-ui-icon-before mw-ui-icon-star"> \
                            <span>特別ページ一覧</span> \
                        </a> \
                    </li> \
                    <li> \
                        <a href="/wiki/特別:ページ一覧" class="mw-ui-icon mw-ui-icon-before mw-ui-icon-listBullet"> \
                            <span>全てのページ</span> \
                        </a> \
                    </li> \
                    <li> \
                        <a href="/wiki/特別:最近の更新" class="mw-ui-icon mw-ui-icon-before mw-ui-icon-recentChanges"> \
                            <span>最近の更新</span> \
                        </a> \
                    </li> \
                </ul> \
            </ul>'
        );
 
        $(".level2").hide();


        $(".level1").on('click', function(event) {
    $(document).ready(injectCustomMenu);
            event.preventDefault();
    var timer = setInterval(injectCustomMenu, 500);
            $(this).find(".level2").slideToggle(500);
    setTimeout(function() { clearInterval(timer); }, 5000);
        });
})();
    }
}, 100);


console.log("OK Common.js")
console.log("OK Common.js")

2026年3月15日 (日) 22:38時点における最新版

/* ここにあるすべてのJavaScriptは、すべてのページ読み込みですべての利用者に対して読み込まれます */

/* PCスキンでサブタイトルを消す処理 */
const targetNode = document.getElementById('contentSub');
const config = { childList: true, subtree: true };

const callback = function(mutationsList, observer) {
  for (const mutation of mutationsList) {
    if (mutation.type === 'childList') {
      const subtitleElement = document.getElementById('mw-content-subtitle');
      if (subtitleElement) {
        const childNodes = subtitleElement.childNodes;
        const lastChildNode = childNodes[childNodes.length - 1];
        if (lastChildNode && lastChildNode.nodeType === Node.TEXT_NODE) {
          lastChildNode.remove();
          observer.disconnect();
          return;
        }
      }
    }
  }
};

const observer = new MutationObserver(callback);
if (targetNode) {
  observer.observe(targetNode, config);
}

/* PCスキンでサブタイトルを消す処理 ここまで */

/* beta2 */
    const pageTitle = mw.config.get('wgPageName')
    const pageNo = mw.config.get('wgRevisionId')
    const url = `https://${location.hostname}/w/api.php?action=query&format=json&prop=revisions&formatversion=2&revids=${pageNo}&rvprop=user`;
    const updaterElement = document.getElementById('last-updater-name');

    fetch(url)
        .then(response => {
            if (!response.ok) {
                throw new Error(`HTTP${response.status}`);
            }
            return response.json();
        })
        .then(data => {
            if (!updaterElement) return;
            const pages = data.query.pages;
            const pageId = Object.keys(pages)[0];
            const pageData = pages[pageId];

            if (pageData.missing) {
                updaterElement.textContent = 'null';
                return;
            }

            const revisions = pageData.revisions;
            if (revisions && revisions.length > 0) {
                const lastUpdater = revisions[0].user;
                updaterElement.textContent = lastUpdater.charAt(0).toLowerCase() + lastUpdater.slice(1);
            } else {
                updaterElement.textContent = 'null';
            }
        })
        .catch(error => {
            console.error('エラー:', error);
            if (updaterElement) {
                updaterElement.textContent = '[取得エラー]';
            }
        });

/* beta2 ここまで */

/* スマホめにゅー */
(function() {
    function injectCustomMenu() {
        if ($('#p-custom-links').length) return
        if (!(mw.config.get('skin') === "minerva")) return

        var $navUl = $('#p-navigation');
        var $personalUl = $('#p-personal');

        if ($navUl.length && $personalUl.length) {
            var items = [
                { label: '方針', url: '/wiki/Wiki:方針', icon: 'expand' },
                { label: '特別ページ一覧', url: '/wiki/特別:特別ページ一覧', icon: 'star' },
                { label: '全てのページ', url: '/wiki/特別:ページ一覧', icon: 'listBullet' },
                { label: '最近の更新', url: '/wiki/特別:最近の更新', icon: 'history' }
            ];

            var html = '<ul id="p-custom-links" class="toggle-list__list">';
            
            items.forEach(function(item) {
                html += '<li class="toggle-list-item">' +
                            '<a href="' + item.url + '" class="toggle-list-item__anchor menu__item--' + item.icon + '">' +
                                '<span class="minerva-icon minerva-icon--' + item.icon + '"></span>' +
                                '<span class="toggle-list-item__label">' + item.label + '</span>' +
                            '</a>' +
                        '</li>';
            });
            
            html += '</ul>';

            $navUl.after(html);
        }
    }

    $(document).ready(injectCustomMenu);
    var timer = setInterval(injectCustomMenu, 500);
    setTimeout(function() { clearInterval(timer); }, 5000);
})();

console.log("OK Common.js")