User:Fbstj/gadget/history-test.js
Note: After saving, 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)
- Internet Explorer / Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5
- Opera: Go to Menu → Settings (Opera → Preferences on a Mac) and then to Privacy & security → Clear browsing data → Cached images and files.
/* Add edit link to templates */ $(function () { // 2019-04-24 remove the prefix from such links document.querySelectorAll('[href*="Coppermind:Artists/"]').forEach(function(el){ el.textContent = el.textContent.replace('Coppermind:Artists/', String.fromCodePoint(0x1f150, 0x20) ) }) // 2019-04-13 thumbs up for thanks document.querySelectorAll('.mw-thanks-thank-link').forEach(function(el){ el.textContent = String.fromCodePoint(0x1F44D); }) function add_editsection_link(box) { if (!box.id) return; // FIXME: what does this do? const id = box.id.replace(/\.(\d+)/, '%$1') // generate an edit link const el = make_editsection_link('/edit/Template:'+ id) // get the title element const title = box.querySelector('.title') title.appendChild(el) } document.querySelectorAll('.infobox,.navbar').forEach(add_editsection_link) function enable_link(el) { el.style['pointer-events'] = 'auto' } document.querySelectorAll('.patrollink').forEach(enable_link) // move notices above infobox while (true) { // don't do things on edit page const edit_box = document.querySelector('.editButtons') if (!!edit_box) break if (location.search != '') break // find {{notice}} after {{infobox}} var el = document.querySelector('.infobox+.notice') if (!el) { // check first child of #mw-content-text is a notice const txt = document.querySelector('#mw-content-text') if (txt.firstElementChild.classList.contains('notice')) el = txt.firstElementChild } if (!el) break const infobox = document.querySelector('.infobox.side') if (!infobox) { // move above the title on non-infobox pages const ind = document.querySelector('.mw-indicators') ind.parentElement.insertBefore(el, ind) } else { const row = infobox.insertRow(0) const cell = row.insertCell() cell.setAttribute('colspan','2') cell.appendChild(el) } } }) $(function () { // 2018-11-05 move the bottom patrol link to the top const patrols = document.querySelectorAll('.patrollink') if (patrols.length == 1) { const first_edit_link = document.querySelector('.mw-editsection') first_edit_link.appendChild(patrols[0]) patrols[0].style['font-size'] = 'inherit' } }) // 2019-03-03 autofill artist pages ;mw.hook('wikipage.editform').add(function () { const page_name = mw.config.get('wgPageName') if (!page_name.startsWith('Coppermind:Artists/')) { return; } const edit = document.querySelector('textarea') // show pending progress mw.notify('scanning for new files linking to '+ page_name).then(function(note) { // perform API query ;(new mw.Api()).get({ action: "query", format: "json", prop: "linkshere", titles: page_name, lhnamespace: "6", // File: namespace only "lhlimit": "max", // don't limit to 10 }).then(function(resp) { const pid = Object.keys(resp.query.pages)[0] const new_files = [] // hide progress notification note.close() // determine which new files link here if (!resp.query.pages[pid].linkshere) { mw.notify('no files link to '+ page_name); return; } const pages = resp.query.pages[pid].linkshere.map(function(page) { return page.title.split(':')[1] }) for (var i in pages) { const page = pages[i] if (edit.value.includes(page)) { continue; } new_files.push(pages[i] + ' | ') } // don't change the page if there's nothing to change if (new_files.length == 0) { mw.notify('no new files link to '+ page_name); return; } mw.notify(new_files.length +' new files link to '+ page_name); if (edit.value.includes('</gallery>')) { // add the lines to the end of the current gallery edit.value = edit.value.replace('</gallery>', new_files.join("\n") +"\n</gallery>") } else { // create a gallery at the bottom of the page edit.value += "\n\n<gallery>\n"+ new_files.join("\n") +"\n</gallery>\n" // TODO: don't add galleries to article section edits } }) // api.get.then }) // note.close }); // 2019-04-13 try to make buttons from links ; mw.hook('wikipage.diff').add(function(){ // load the notify function mw.loader.load('mediawiki.notification'); const to_secs = 5 // create an api client const api = new mw.Api() // the old "button" const old = document.querySelector('.patrollink') if (!old) { return } // fetch the current RC id for the later request const rcid = mw.util.getParamValue('rcid', old.firstElementChild.href) // setup the new button const btn = document.createElement('button') btn.textContent = 'Patrol' btn.addEventListener('click', function() { // progress spinnner const spin = ($.createSpinner({ size: 'small', display: 'inline', }))[0] btn.replaceWith(spin) api.postWithToken('patrol', { formatversion: 2, action: 'patrol', rcid: rcid, }).done(function (data) { if (data.patrol !== undefined) { const title = new mw.Title(data.patrol.title); mw.notify(mw.msg('markedaspatrollednotify', title.toText())); spin.remove() } else { mw.notify(mw.msg('markedaspatrollederrornotify'), { type: 'error' }); spin.replaceWith(btn) } }).fail(function (error) { console.warn('patrol:', error) if (error === 'noautopatrol') { mw.notify(mw.msg('markedaspatrollederror-noautopatrol'), { type: 'warn' }); } else { mw.notify(mw.msg('markedaspatrollederrornotify'), { type: 'error' }); } spin.replaceWith(btn) }) }) // hide old button and show new one old.replaceWith(btn) }); // 2019-07-22 make "new" links better $(function () { for (const row = document.querySelectorAll('.mw-changeslist-src-mw-new')) { const link = document.createElement('a') link.innerText = 'new' link.href = '' row.firstChild.replaceWith('(', link, ' | ') } });