MediaWiki:Common.js

提供:百科事典.com
2026年2月20日 (金) 10:25時点におけるAdmin (トーク | 投稿記録)による版 (メインページに「最近の更新(7件)」をタイトル+差分リンク付きで表示するための完全版コード)
(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
ナビゲーションに移動検索に移動

注意: 保存後、変更を確認するにはブラウザーのキャッシュを消去する必要がある場合があります。

  • Firefox / Safari: Shift を押しながら 再読み込み をクリックするか、Ctrl-F5 または Ctrl-R を押してください (Mac では ⌘-R)
  • Google Chrome: Ctrl-Shift-R を押してください (Mac では ⌘-Shift-R)
  • Internet Explorer / Microsoft Edge: Ctrl を押しながら 最新の情報に更新 をクリックするか、Ctrl-F5 を押してください
  • Opera: Ctrl-F5を押してください
/* ここにあるすべてのJavaScriptは、すべてのページ読み込みですべての利用者に対して読み込まれます */



/* ============================================================
   メインページに「最近の更新(7件)」を表示するスクリプト
   - タイトル+差分リンク付き
   - localStorage による5分キャッシュ
   - API の maxage/smaxage による HTTP キャッシュ
   - MediaWiki 1.39.3 で動作確認済み
   ============================================================ */

$(function () {

    // ▼ メインページ以外では実行しない(重要)
    if (mw.config.get('wgPageName') !== 'Main_Page' &&
        mw.config.get('wgPageName') !== 'メインページ') {
        return;
    }

    // ▼ localStorage 用のキー
    const key = 'recentchanges-cache';
    const keyTime = key + '-time';

    // ▼ キャッシュの有効期限(ミリ秒)→ 5分
    const ttl = 5 * 60 * 1000;
    const now = Date.now();

    // ▼ localStorage にキャッシュがあれば利用
    const cached = localStorage.getItem(key);
    const cachedTime = localStorage.getItem(keyTime);

    if (cached && cachedTime && now - cachedTime < ttl) {
        $('#recentchanges-container').html(cached);
        return; // API を叩かず終了
    }

    // ▼ MediaWiki API を呼び出して最近の更新を取得
    $.getJSON(mw.util.wikiScript('api'), {
        action: 'query',
        list: 'recentchanges',
        rclimit: 7,                     // 取得件数
        rcprop: 'title|timestamp|ids',  // タイトル・時刻・差分ID
        rcshow: '!bot',                 // Bot 編集を除外(不要なら削除)
        format: 'json',

        // ▼ HTTP キャッシュ(ブラウザ・CDN)
        maxage: 300,   // ブラウザキャッシュ 5分
        smaxage: 300   // CDNキャッシュ 5分
    }, function (data) {

        let html = '<ul>';

        data.query.recentchanges.forEach(rc => {

            // ▼ 差分リンクの生成
            const diffUrl = mw.util.getUrl(rc.title, {
                diff: rc.revid,
                oldid: rc.old_revid
            });

            // ▼ リスト項目の HTML
            html += `
                <li>
                    <a href="/wiki/${rc.title}">${rc.title}</a>
                    &nbsp;
                    <a href="${diffUrl}">差分</a>
                    &nbsp;
                    (${rc.timestamp})
                </li>
            `;
        });

        html += '</ul>';

        // ▼ localStorage にキャッシュ保存
        localStorage.setItem(key, html);
        localStorage.setItem(keyTime, now);

        // ▼ メインページに表示
        $('#recentchanges-container').html(html);
    });
});