Difference between revisions of "User:Fbstj/gadget/history-test.js"
Jump to navigation
Jump to search
m (for now) |
m (Fbstj moved page User:Fbstj/common.js to User:Fbstj/gadget/history-test.js without leaving a redirect) |
||
(107 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
+ | mw.hook('wikipage.content').add(function revs_gadget() { |
||
− | /* Add edit link to templates */ |
||
− | $(function () { |
||
⚫ | |||
− | function add_editsection_link(box) { |
||
+ | const query = { |
||
− | if (!box.id) return; |
||
− | + | // request the history of this page |
|
+ | pageids: [pageid], |
||
− | const id = box.id.replace(/\.(\d+)/, '%$1') |
||
+ | prop: 'revisions', |
||
− | // generate an edit link |
||
+ | // request the oldest edits first |
||
− | const el = make_editsection_link('/edit/Template:'+ id) |
||
+ | rvdir: 'newer', |
||
− | // get the title element |
||
+ | // request as many as you can at once |
||
− | const title = box.querySelector('.title') |
||
+ | rvlimit: 'max', |
||
− | title.appendChild(el) |
||
+ | // properties to fetch: |
||
+ | rvprop: [ 'ids', 'user', 'timestamp', 'size', 'tags', ], |
||
} |
} |
||
+ | const api = new mw.Api({ parameters: query, }) |
||
⚫ | |||
− | document.querySelectorAll('.infobox,.navbar').forEach(add_editsection_link) |
||
+ | const page = resp.query.pages[pageid] |
||
− | function enable_link(el) { el.style['pointer-events'] = 'auto' } |
||
+ | page.revisions.forEach(console.log) |
||
− | |||
− | document.querySelectorAll('.patrollink').forEach(enable_link) |
||
− | |||
− | // move notices above indicators |
||
− | while (true) { |
||
− | const edit_box = document.querySelector('.editButtons') |
||
− | if (!!edit_box) break |
||
− | if (location.search != '') break |
||
− | 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 ind = document.querySelector('.mw-indicators') |
||
− | ind.parentElement.insertBefore(el, ind) |
||
− | } |
||
}) |
}) |
||
− | /* 2018-09-16 display Arcanum entry on Cite:Arcanum-X page */ |
||
− | $(function () { |
||
− | // check that there is an edit box |
||
− | if (!mw.config.get('wgCanonicalNamespace') !== 'Cite') return -1; |
||
− | // check that it's an Arcanum page |
||
⚫ | |||
− | if (!page_name.startsWith('Cite:Arcanum-')) return -3; |
||
− | // work out the api url |
||
− | const entry = page_name.split('-')[1]; |
||
− | const url = 'https://wob.coppermind.net/api/entry/'+ entry +'/'; |
||
− | // start fetching from Arcanum |
||
− | fetch(url) |
||
− | .then(function(resp) { return resp.json() }) |
||
⚫ | |||
− | // debugging: |
||
− | console.log('Entry '+ entry, json); |
||
− | // create containing element |
||
− | const entry = document.createElement('article'); |
||
− | entry.classList.add('arcanum-entry'); |
||
− | // add lines |
||
− | json.lines.forEach(line => { |
||
− | // create speaker element |
||
− | const speaker = document.createElement('h4') |
||
− | speaker.innerText = line.speaker |
||
− | // append the speaker and html from the line |
||
− | entry.appendChild(entry) |
||
− | entry.innerText += line.text |
||
− | }) |
||
− | // place container on page |
||
− | console.log(entry) |
||
− | }) |
||
}) |
}) |
Latest revision as of 19:54, 20 August 2019
mw.hook('wikipage.content').add(function revs_gadget() { const pageid = mw.config.get('wgArticleId') const query = { // request the history of this page pageids: [pageid], prop: 'revisions', // request the oldest edits first rvdir: 'newer', // request as many as you can at once rvlimit: 'max', // properties to fetch: rvprop: [ 'ids', 'user', 'timestamp', 'size', 'tags', ], } const api = new mw.Api({ parameters: query, }) api.get().then(function old_hist(resp) { const page = resp.query.pages[pageid] page.revisions.forEach(console.log) }) })