User:Fbstj/gadget/history-test.js

From The Coppermind
< User:Fbstj
Revision as of 09:03, 22 July 2019 by Fbstj (talk | contribs) (try again)
Jump to navigation Jump to search

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, ' | ')
}

});