MediaWiki:Common.js
跳至導覽
跳至搜尋
注意:在您儲存之後您必須清除瀏覽器快取才可看到最新的變更。
- Firefox / Safari:按住 Shift 時點選 重新整理,或按 Ctrl-F5 或 Ctrl-R (Mac 則為 ⌘-R)
- Google Chrome:按 Ctrl-Shift-R (Mac 則為 ⌘-Shift-R)
- Internet Explorer / Edge:按住 Ctrl 時點選 重新整理,或按 Ctrl-F5
- Opera:按 Ctrl-F5。
$(function(){ console.log('into plugin '); if($("#p-recentchanges").length == 0){ return } var NAMESPACES = { // 所有 namespace (命名空間)清單 "(主要)":"0", "討論":"1", "使用者":"2", "使用者討論":"3", "檔案":"6", "檔案討論":"7", "MediaWiki":"8", "MediaWiki討論":"9", "模板":"10", "模板討論":"11", "使用說明":"12", "使用說明討論":"13", "分類":"14", "分類討論":"15", "Gadget":"2300", "Gadget talk":"2301", "Gadget definition":"2302", "Gadget definition talk":"2303" } var storage = localStorage || {} var frequency = 20 // 更新頻率,以秒為單位 // 設為 20 表示每 20 秒更新一次 sidebar 清單 // 由於會用在數學除法上,所以請不要設置為 0 或數字以外的值 var numOfPageLoad = 20 // 要讀取多少最新變更 var wikiURL = location.origin // Wiki 的 URL var apiURL = location.origin + "/api.php" // Wiki 的 api 的 url // 詳見 特殊:版本#入口 URL var namespaceUsed = [ // 所有使用的 namespace (命名空間) NAMESPACES["(主要)"], NAMESPACES["討論"], NAMESPACES["使用者討論"], NAMESPACES["檔案討論"], NAMESPACES["模板"], NAMESPACES["模板討論"], NAMESPACES["分類討論"] ] function loadCallback(data){ console.log('into js my add loadCallback') console.log(data); var list = $("<ul>") $($("#p-recentchanges").find(".body, .pBody")[0]) .after( $("<div class='body'>").append(list) ) .after( $("<h3></h3>") .css({"font-style": "italic"}) .html("最新 " + numOfPageLoad + " 筆變動") ) for(var i in data){ var rc = data[i] list.append( $("<li>") .append( $("<a>") .attr("href", wikiURL + "/?curid=" + rc.pageid) .html(rc.title) ) ) } } var lastUpdateTime = parseInt(new Date().getTime() / 1000 / frequency) * 1000 * frequency if(storage.lastUpdateTime && storage.lastUpdateTime >= lastUpdateTime){ loadCallback(JSON.parse(storage.recentchanges)) return } $.ajax({ url: apiURL, data: { action: "query", list: "recentchanges", format: "json", rcshow: "!redirect", rcnamespace: namespaceUsed.join("|"), rclimit: numOfPageLoad, rctoponly: true // 只列出最新編輯 }, dataType: "json", success: function(data){ storage.lastUpdateTime = lastUpdateTime storage.recentchanges = JSON.stringify(data.query.recentchanges) loadCallback(data.query.recentchanges) } }) })