Difference between revisions of "User:Tark/common.js"
m |
m |
||
(16 intermediate revisions by the same user not shown) | |||
Line 158: | Line 158: | ||
// otfwiki links | // otfwiki links | ||
statusText += " Links: "; | statusText += " Links: "; | ||
− | statusText += "<a href=\"" + mw.config.get( "wgArticlePath" ).replace( "$1", "Special:Block/" + encodeURIComponent( user.name ) ) + "\">Block user</a>"; | + | statusText += "<a href=\"" + mw.config.get( "wgArticlePath" ).replace( "$1", "Special:Block/" + encodeURIComponent( user.name ) ) + "\">Block</a>"; |
+ | statusText += " | <a href=\"" + mw.config.get( "wgArticlePath" ).replace( "$1", "Special:RenameUser/" + encodeURIComponent( user.name ) ) + "\">Rename</a>"; | ||
+ | statusText += " | <a href=\"https://wikistats.espacore.de/user/tf/" + encodeURIComponent( user.name ) + "\">Wiki Stats</a>"; | ||
var ss = document.getElementById( "siteSub" ); | var ss = document.getElementById( "siteSub" ); | ||
ss.innerHTML = "<span>" + statusText + "</span>"; | ss.innerHTML = "<span>" + statusText + "</span>"; | ||
ss.style.display = "block"; | ss.style.display = "block"; | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
} ); | } ); | ||
} ); | } ); | ||
Line 192: | Line 169: | ||
} | } | ||
// End User info | // End User info | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
// Begin Delete link | // Begin Delete link | ||
Line 219: | Line 181: | ||
} | } | ||
// End Delete link | // End Delete link | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
mw.loader.load('https://en.wikipedia.org/w/index.php?title=User:BrandonXLF/TestWikitext.js&action=raw&ctype=text/javascript'); | mw.loader.load('https://en.wikipedia.org/w/index.php?title=User:BrandonXLF/TestWikitext.js&action=raw&ctype=text/javascript'); | ||
− | + | mw.loader.load("https://en.wikipedia.org/w/index.php?title=User:Awesome%20Aasim/savedraft.js&action=raw&ctype=text/javascript"); | |
− | |||
// Start addUploadsLink | // Start addUploadsLink | ||
Line 253: | Line 202: | ||
// End addUploadsLink | // End addUploadsLink | ||
+ | |||
+ | mw.util.addPortletLink('p-cactions', "javascript:spaiSappinMahWiki.hitItDoc()", '[CJS] Spai'); | ||
+ | mw.util.addPortletLink('p-cactions', "javascript:viewer3d.init()", '[CJS] 3D - Init'); | ||
+ | |||
+ | var prl = { | ||
+ | init: function () { | ||
+ | if (mw.config.get("wgIsArticle") && mw.config.get("wgNamespaceNumber") == 0) { | ||
+ | var links = document.querySelectorAll('a.new'); | ||
+ | for (var i = 0; i < links.length; i++) { | ||
+ | var link = links[i]; | ||
+ | var title = link.getAttribute('href').split('=')[1].split('&')[0].split("/").slice(0, -1); | ||
+ | link.href += "&preload=" + title; | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | |||
+ | $(prl.init); | ||
+ | |||
+ | var ddd = { | ||
+ | init: function () { | ||
+ | if (mw.config.get("wgIsArticle") && mw.config.get("wgNamespaceNumber") == 0 && mw.config.get("wgCategories").includes("Disambiguation")) { | ||
+ | var imgs = document.querySelectorAll(".mw-parser-output a img"); | ||
+ | for (var i = 0; i < imgs.length; i++) { | ||
+ | imgs[i].style.display = "none"; | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | |||
+ | $(ddd.init); | ||
+ | |||
+ | /* | ||
+ | Silly nuke delete button by User:Wookipan - feel free to copy but pls give credit, 'kay? | ||
+ | Demo: https://mt.berryos.net/tfwiki_nuke.mp4 | ||
+ | */ | ||
+ | var nukeBtnMod = { | ||
+ | init: function () { | ||
+ | var body = $('body'); | ||
+ | var delBtn = $('.menu #ca-delete'); | ||
+ | var audioUrl = 'https://files.catbox.moe/jv606w.ogg'; | ||
+ | var audioVol = 0.8; | ||
+ | var interval = {}; | ||
+ | var classes = { | ||
+ | nuke: 'ca-nuke', | ||
+ | shake: 'shake', | ||
+ | flash: 'flash' | ||
+ | }; | ||
+ | |||
+ | if (delBtn[0] && !delBtn.hasClass(classes.nuke)) { | ||
+ | var concat = classes.nuke + '--'; | ||
+ | var shakeDat = concat + classes.shake; | ||
+ | var alarmFlash = concat + classes.flash; | ||
+ | var sirens = initAudio(audioUrl); | ||
+ | |||
+ | delBtn.on('mouseover', function () { | ||
+ | $(this).addClass(classes.nuke); | ||
+ | setTimeout(function () { | ||
+ | if ($(this).hasClass(classes.nuke)) { | ||
+ | body.addClass(shakeDat); | ||
+ | sirens.play(); | ||
+ | runInterval(); | ||
+ | } else { | ||
+ | body.removeClass(shakeDat); | ||
+ | } | ||
+ | }.bind(this), 1000); | ||
+ | }); | ||
+ | |||
+ | delBtn.on('mouseleave', function () { | ||
+ | $(this).removeClass(classes.nuke); | ||
+ | body.removeClass(shakeDat); | ||
+ | sirens.pause(); | ||
+ | |||
+ | setTimeout(function () { | ||
+ | clearInterval(interval); | ||
+ | }, 1000); | ||
+ | }); | ||
+ | |||
+ | function initAudio(url) { | ||
+ | var audio = new Audio(url); | ||
+ | |||
+ | audio.addEventListener('canplaythrough', function () { | ||
+ | audio.volume = audioVol; | ||
+ | audio.loop = 1; | ||
+ | }); | ||
+ | |||
+ | return audio; | ||
+ | } | ||
+ | |||
+ | function runInterval() { | ||
+ | interval = setInterval(function () { | ||
+ | sirens.currentTime >= 85 && body.hasClass(shakeDat) ? | ||
+ | $(':root').addClass(alarmFlash) : | ||
+ | $(':root').removeClass(alarmFlash); | ||
+ | }, 1000); | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | $(nukeBtnMod.init); | ||
// ---- | // ---- | ||
+ | |||
+ | // Start Compare link | ||
+ | var compareLink = { | ||
+ | init: function () { | ||
+ | if (mw.config.get("wgIsArticle")) { | ||
+ | var article = mw.config.get("wgPageName"); | ||
+ | if (article.includes("/")) { | ||
+ | compareLink.plsCompare(article, "", "Compare with en article"); | ||
+ | var langs = { | ||
+ | "/pt": "/pt-br", | ||
+ | "/pt-br": "/pt", | ||
+ | "/zh-hans": "/zh-hant", | ||
+ | "/zh-hant": "/zh-hans" | ||
+ | }; | ||
+ | for (var lang in langs) { | ||
+ | if (article.endsWith(lang)) { | ||
+ | compareLink.plsCompare(article, langs[lang], "Compare with " + langs[lang].split("/").pop() + " article"); | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | }, | ||
+ | plsCompare: function (page, langCode, text) { | ||
+ | mw.util.addPortletLink("p-cactions", | ||
+ | mw.util.getUrl("Special:ComparePages", { | ||
+ | "page1": page, | ||
+ | "page2": page.split("/").slice(0, -1).join("/") + langCode // this is dumb, pls fix | ||
+ | }), | ||
+ | text | ||
+ | ); | ||
+ | } | ||
+ | }; | ||
+ | |||
+ | $(compareLink.init); | ||
+ | // End Compare link | ||
+ | |||
+ | // Begin Purge link | ||
+ | var purgeLinkv2 = { | ||
+ | init: function () { | ||
+ | if (mw.config.get("wgIsArticle")) { | ||
+ | var purgeBtn = mw.util.addPortletLink("p-cactions", | ||
+ | mw.util.wikiScript() + "?" + $.param({ title: mw.config.get("wgPageName"), action: "purge" }), | ||
+ | "Purge", | ||
+ | "ca-purge", | ||
+ | "Purge the server cache of this page" | ||
+ | ); | ||
+ | |||
+ | // Quick Purge | ||
+ | var qpurgeBtn = mw.util.addPortletLink("p-views", | ||
+ | "#", | ||
+ | "Quick Purge", | ||
+ | "ca-purge", | ||
+ | "Quickly purge the server cache of this page (skips confirmation)" | ||
+ | ); | ||
+ | |||
+ | qpurgeBtn.classList.add("collapsible"); | ||
+ | qpurgeBtn.addEventListener("click", purgeLinkv2.handleQpurge.bind(this)); | ||
+ | } | ||
+ | }, | ||
+ | handleQpurge: function (event) { | ||
+ | event.preventDefault(); | ||
+ | |||
+ | new mw.Api().post({ action: "purge", titles: mw.config.get("wgPageName") }).then(function (data) { | ||
+ | mw.notify("Quick Purge: Success!", { type: "success" }); | ||
+ | }).catch(function (error) { | ||
+ | mw.notify("Quick Purge: " + (error && error.info ? error.info : error), { type: "error" }); | ||
+ | }); | ||
+ | }, | ||
+ | }; | ||
+ | |||
+ | $(purgeLinkv2.init); | ||
+ | // End Purge link | ||
// Start WP pls review :^) | // Start WP pls review :^) | ||
// End WP pls review | // End WP pls review |
Latest revision as of 22:40, 7 November 2024
// Begin User info // Adapted from http://en.wikipedia.org/wiki/w:User:PleaseStand/User_info function UserinfoJsFormatQty( qty, singular, plural ) { return String( qty ).replace( /\d{1,3}(?=(\d{3})+(?!\d))/g, "$&," ) + "\u00a0" + ( qty == 1 ? singular : plural ); } function UserinfoJsFormatDateRel( old ) { // The code below requires the computer's clock to be set correctly. var age = Date.now() - old.getTime(); var ageNumber, ageRemainder, ageWordp if ( age < 60000 ) { // less than one minute old ageNumber = Math.floor( age / 1000 ); ageWords = UserinfoJsFormatQty( ageNumber, "second", "seconds" ); } else if ( age < 3600000 ) { // less than one hour old ageNumber = Math.floor( age / 60000 ); ageWords = UserinfoJsFormatQty( ageNumber, "minute", "minutes" ); } else if ( age < 86400000 ) { // less than one day old ageNumber = Math.floor( age / 3600000 ); ageWords = UserinfoJsFormatQty( ageNumber, "hour", "hours" ); ageRemainder = Math.floor( ( age - ageNumber * 3600000 ) / 60000 ); } else if ( age < 604800000 ) { // less than one week old ageNumber = Math.floor( age / 86400000 ); ageWords = UserinfoJsFormatQty( ageNumber, "day", "days" ); } else if ( age < 2592000000 ) { // less than one month old ageNumber = Math.floor( age / 604800000 ); ageWords = UserinfoJsFormatQty( ageNumber, "week", "weeks" ); } else if ( age < 31536000000 ) { // less than one year old ageNumber = Math.floor( age / 2592000000 ); ageWords = UserinfoJsFormatQty( ageNumber, "month", "months" ); } else { // one year or older ageNumber = Math.floor( age / 31536000000 ); ageWords = UserinfoJsFormatQty( ageNumber, "year", "years" ); ageRemainder = Math.floor( ( age - ageNumber * 31536000000 ) / 2592000000 ); if ( ageRemainder ) { ageWords += " " + UserinfoJsFormatQty( ageRemainder, "month", "months" ); } } return ageWords; } // If on a user or user talk page, and not a subpage... if ( mw.config.get( "wgNamespaceNumber" ) == 2 || mw.config.get( "wgNamespaceNumber" ) == 3 ) { // add a hook to... mw.loader.using( [ "mediawiki.util" ], function () { $( function () { // Request the user's information from the API. // Note that this is allowed to be up to 5 minutes old. var et = encodeURIComponent( mw.config.get( "wgTitle" ) ); $.getJSON( mw.config.get( "wgScriptPath" ) + "/api.php?format=json&action=query&list=users|usercontribs&usprop=blockinfo|editcount|gender|registration|groups&uclimit=1&ucprop=timestamp&ususers=" + et + "&ucuser=" + et + "&meta=allmessages&refix=grouppage-&amincludelocal=1" ).done( function ( query ) { // When response arrives extract the information we need. if ( !query.query ) { return; } // Suggested by Gary King to avoid JS errors --PS 2010-08-25 query = query.query; var blocked, editcount, groups, invalid, lastEdited, missing, registration, user; try { user = query.users[0]; invalid = typeof user.invalid !== "undefined"; missing = typeof user.missing !== "undefined"; groups = typeof user.groups === "object" ? user.groups : []; editcount = typeof user.editcount === "number" ? user.editcount : null; registration = typeof user.registration === "string" ? new Date( user.registration ) : null; blocked = typeof user.blockedby !== "undefined"; lastEdited = typeof query.usercontribs[0] === "object" && typeof query.usercontribs[0].timestamp === "string" ? new Date( query.usercontribs[0].timestamp ) : null; } catch ( e ) { return; // Not much to do if the server is returning an error (e.g. if the username is malformed). } // Format the information for on-screen display var statusText = ""; if ( blocked ) { statusText += "<a href=\"" + mw.config.get( "wgScriptPath" ) + "/index.php?title=Special:Log&page=" + encodeURIComponent( mw.config.get( "wgFormattedNamespaces" )[2] + ":" + user.name ) + "&type=block\">blocked</a> "; } if ( missing ) { statusText += "username not registered"; } else if ( invalid ) { statusText += "invalid username"; } else { var friendlyGroupNames = { "*": false, user: false, autoconfirmed: false, sysop: "administrator", suppress: "suppressor" }; var friendlyGroups = []; for ( var i = 0; i < groups.length; ++i ) { var s = groups[i]; var t = Object.prototype.hasOwnProperty.call( friendlyGroupNames, s ) ? friendlyGroupNames[s] : s; if ( t ) { friendlyGroups.push( t ); } } switch ( friendlyGroups.length ) { case 0: if ( blocked ) { statusText += "user"; } else { statusText += "registered user"; } break; case 1: statusText += friendlyGroups[0]; break; case 2: statusText += friendlyGroups[0] + " and " + friendlyGroups[1]; break; default: statusText += friendlyGroups.slice( 0, -1 ).join( ", " ) + ", and " + friendlyGroups[friendlyGroups.length - 1]; break; } } // Registration date if ( registration ) { var firstLoggedUser = new Date( "22:16, 7 September 2005" ); // When the [[Special:Log/newusers]] was first activated if ( registration >= firstLoggedUser ) { statusText += ", <a href='" + mw.config.get( "wgScriptPath" ) + "/index.php?title=Special:Log&type=newusers&dir=prev&limit=1&user=" + et + "'>" + UserinfoJsFormatDateRel( registration ) + "</a> old"; } else { statusText += ", <a href='" + mw.config.get( "wgScriptPath" ) + "/index.php?title=Special:ListUsers&limit=1&username=" + et + "'>" + UserinfoJsFormatDateRel( registration ) + "</a> old"; } } // Edit count if ( editcount !== null ) { statusText += ", with <a href=\"" + mw.config.get( "wgArticlePath" ).replace( "$1", "Special:Contributions/" + encodeURIComponent( user.name ) ) + "\">" + UserinfoJsFormatQty( editcount, "edit", "edits" ) + "</a>"; } // Prefix status text with correct article if ( "AEIOaeio".indexOf( statusText.charAt( statusText.indexOf( ">" ) + 1 ) ) >= 0 ) { statusText = "An " + statusText; } else { statusText = "A " + statusText; } if ( lastEdited ) { statusText += ". Last edited " + UserinfoJsFormatDateRel( lastEdited ) + " ago."; } // otfwiki links statusText += " Links: "; statusText += "<a href=\"" + mw.config.get( "wgArticlePath" ).replace( "$1", "Special:Block/" + encodeURIComponent( user.name ) ) + "\">Block</a>"; statusText += " | <a href=\"" + mw.config.get( "wgArticlePath" ).replace( "$1", "Special:RenameUser/" + encodeURIComponent( user.name ) ) + "\">Rename</a>"; statusText += " | <a href=\"https://wikistats.espacore.de/user/tf/" + encodeURIComponent( user.name ) + "\">Wiki Stats</a>"; var ss = document.getElementById( "siteSub" ); ss.innerHTML = "<span>" + statusText + "</span>"; ss.style.display = "block"; } ); } ); } ); } // End User info // Begin Delete link if ( mw.config.get( "wgIsArticle" ) ) { var dBtn = mw.util.addPortletLink( "p-views", mw.util.wikiScript() + "?" + $.param( { title: mw.config.get( "wgPageName" ), action: "delete" } ), "Deleto", "ca-delete", "Deleto!!!!" ); dBtn.classList.add("collapsible"); } // End Delete link mw.loader.load('https://en.wikipedia.org/w/index.php?title=User:BrandonXLF/TestWikitext.js&action=raw&ctype=text/javascript'); mw.loader.load("https://en.wikipedia.org/w/index.php?title=User:Awesome%20Aasim/savedraft.js&action=raw&ctype=text/javascript"); // Start addUploadsLink // Adapted from: https://en.wikipedia.org/wiki/User:Begoon/addUploadsLink.js mw.loader.using('mediawiki.util', function () { jQuery(function( $ ) { var wServerName = mw.config.get('wgServer'); if (document.getElementById("t-contributions")) { var rUser = mw.config.get('wgRelevantUserName'); var followNode = document.getElementById("t-contributions").nextSibling; mw.util.addPortletLink( 'p-tb', wServerName + '/wiki/Special:ListFiles?limit=500&user=' + rUser.replace(/ /g, '+') + '&ilshowall=1', 'User uploads', 't-userfileuploads', 'View list of files uploaded by ' + rUser,'', followNode ) } }); }); // End addUploadsLink mw.util.addPortletLink('p-cactions', "javascript:spaiSappinMahWiki.hitItDoc()", '[CJS] Spai'); mw.util.addPortletLink('p-cactions', "javascript:viewer3d.init()", '[CJS] 3D - Init'); var prl = { init: function () { if (mw.config.get("wgIsArticle") && mw.config.get("wgNamespaceNumber") == 0) { var links = document.querySelectorAll('a.new'); for (var i = 0; i < links.length; i++) { var link = links[i]; var title = link.getAttribute('href').split('=')[1].split('&')[0].split("/").slice(0, -1); link.href += "&preload=" + title; } } } } $(prl.init); var ddd = { init: function () { if (mw.config.get("wgIsArticle") && mw.config.get("wgNamespaceNumber") == 0 && mw.config.get("wgCategories").includes("Disambiguation")) { var imgs = document.querySelectorAll(".mw-parser-output a img"); for (var i = 0; i < imgs.length; i++) { imgs[i].style.display = "none"; } } } } $(ddd.init); /* Silly nuke delete button by User:Wookipan - feel free to copy but pls give credit, 'kay? Demo: https://mt.berryos.net/tfwiki_nuke.mp4 */ var nukeBtnMod = { init: function () { var body = $('body'); var delBtn = $('.menu #ca-delete'); var audioUrl = 'https://files.catbox.moe/jv606w.ogg'; var audioVol = 0.8; var interval = {}; var classes = { nuke: 'ca-nuke', shake: 'shake', flash: 'flash' }; if (delBtn[0] && !delBtn.hasClass(classes.nuke)) { var concat = classes.nuke + '--'; var shakeDat = concat + classes.shake; var alarmFlash = concat + classes.flash; var sirens = initAudio(audioUrl); delBtn.on('mouseover', function () { $(this).addClass(classes.nuke); setTimeout(function () { if ($(this).hasClass(classes.nuke)) { body.addClass(shakeDat); sirens.play(); runInterval(); } else { body.removeClass(shakeDat); } }.bind(this), 1000); }); delBtn.on('mouseleave', function () { $(this).removeClass(classes.nuke); body.removeClass(shakeDat); sirens.pause(); setTimeout(function () { clearInterval(interval); }, 1000); }); function initAudio(url) { var audio = new Audio(url); audio.addEventListener('canplaythrough', function () { audio.volume = audioVol; audio.loop = 1; }); return audio; } function runInterval() { interval = setInterval(function () { sirens.currentTime >= 85 && body.hasClass(shakeDat) ? $(':root').addClass(alarmFlash) : $(':root').removeClass(alarmFlash); }, 1000); } } } } $(nukeBtnMod.init); // ---- // Start Compare link var compareLink = { init: function () { if (mw.config.get("wgIsArticle")) { var article = mw.config.get("wgPageName"); if (article.includes("/")) { compareLink.plsCompare(article, "", "Compare with en article"); var langs = { "/pt": "/pt-br", "/pt-br": "/pt", "/zh-hans": "/zh-hant", "/zh-hant": "/zh-hans" }; for (var lang in langs) { if (article.endsWith(lang)) { compareLink.plsCompare(article, langs[lang], "Compare with " + langs[lang].split("/").pop() + " article"); } } } } }, plsCompare: function (page, langCode, text) { mw.util.addPortletLink("p-cactions", mw.util.getUrl("Special:ComparePages", { "page1": page, "page2": page.split("/").slice(0, -1).join("/") + langCode // this is dumb, pls fix }), text ); } }; $(compareLink.init); // End Compare link // Begin Purge link var purgeLinkv2 = { init: function () { if (mw.config.get("wgIsArticle")) { var purgeBtn = mw.util.addPortletLink("p-cactions", mw.util.wikiScript() + "?" + $.param({ title: mw.config.get("wgPageName"), action: "purge" }), "Purge", "ca-purge", "Purge the server cache of this page" ); // Quick Purge var qpurgeBtn = mw.util.addPortletLink("p-views", "#", "Quick Purge", "ca-purge", "Quickly purge the server cache of this page (skips confirmation)" ); qpurgeBtn.classList.add("collapsible"); qpurgeBtn.addEventListener("click", purgeLinkv2.handleQpurge.bind(this)); } }, handleQpurge: function (event) { event.preventDefault(); new mw.Api().post({ action: "purge", titles: mw.config.get("wgPageName") }).then(function (data) { mw.notify("Quick Purge: Success!", { type: "success" }); }).catch(function (error) { mw.notify("Quick Purge: " + (error && error.info ? error.info : error), { type: "error" }); }); }, }; $(purgeLinkv2.init); // End Purge link // Start WP pls review :^) // End WP pls review