X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/15582401f88c2e66457c1de4333b981650de3c11..6200f20ad733db0f13be5dc766249c3c1f500937:/writer.js diff --git a/writer.js b/writer.js index da8229a..5d3ad5e 100644 --- a/writer.js +++ b/writer.js @@ -2,6 +2,7 @@ document.addEventListener('DOMContentLoaded', () => { document.querySelectorAll('.multiinput > input[id]').forEach(el => { el.oninput = e => { if (e.target.value == '') return; + // insert another empty input element option let add = e.target.cloneNode(true); add.value = ''; add.oninput = e.target.oninput; @@ -19,6 +20,7 @@ document.addEventListener('DOMContentLoaded', () => { wpbutton.onclick = () => { let wptitle = wpinput.value || document.getElementById('form').value; let wplang = document.getElementById('lang').value; + if (wplang == 'la') wplang = 'en'; // most likely presence of scientific names let wpapi = `https://${wplang}.wikipedia.org/w/api.php`; let wppage = wpapi+'?action=parse&format=json&origin=*&prop=text|langlinks&page='+wptitle; fetch(wppage).then(res => res.json()).then(json => { @@ -30,13 +32,26 @@ document.addEventListener('DOMContentLoaded', () => { if (wplangs) wplangs.forEach(wptrans => { let transrow = document.getElementById('trans-' + wptrans.lang); if (!transrow || transrow.value) return; - transrow.value = wptrans['*']; + transrow.value = wptrans['*'].replace(/([^,(]*).*/, (link, short) => { + return short.toLocaleLowerCase(wptrans.lang).trimEnd() + ' [' + link + ']'; + }); }); + // copy first paragraph to story + let wptext = json.parse.text['*']; + let storyinput = document.getElementById('story'); + if (storyinput && wptext) { + storyinput.innerHTML = wptext + .replace(//sg, '') // ignore infobox + .match(/

(.*?)<\/p>/s)[0] // first paragraph + .replace(/<[^>]*>/g, '') // strip html tags + } + // list images in article html let imginput = document.getElementById('source'); if (!imginput || imginput.value) return; - let wpimages = json.parse.text['*'].match(/]+>/g); + let wpimages = wptext.match(/]+>/g); let wpselect = wpinput.parentNode.appendChild(document.createElement('ul')); wpselect.className = 'popup'; wpimages.forEach(img => { @@ -60,7 +75,9 @@ document.addEventListener('DOMContentLoaded', () => { wpbutton.onclick = () => { let wptitle = wpinput.value || document.getElementById('form').value; let wplang = document.getElementById('lang').value; - let wpurl = `https://${wplang}.wikipedia.org/wiki/${wptitle}`; + let wpurl = + wplang == 'la' ? `https://species.wikimedia.org/wiki/${wptitle}` : + `https://${wplang}.wikipedia.org/wiki/${wptitle}`; window.open(wpurl, 'sheet-wikipedia').focus(); return false; }; @@ -79,6 +96,29 @@ document.addEventListener('DOMContentLoaded', () => { }; } + let thumbpreview = document.getElementById('thumbpreview'); + if (thumbpreview && imgpreview) { + thumbpreview.onclick = e => { + let imgselect = imgpreview; /* TODO clone */ + imgselect.hidden = false; + imgselect.classList.add('popup'); + imgselect.onmousemove = e => { + let border = imgselect.getBoundingClientRect(); + let pos = [ + Math.round(1000 * (e.clientX - border.x) / border.width), + Math.round(1000 * (e.clientY - border.y) / border.height) + ]; + return pos; + }; + imgselect.onclick = e => { + let imgoption = document.getElementById('thumb'); + imgoption.value += (imgoption.value && '-') + imgselect.onmousemove(e); + imgselect.hidden = true; + imgselect.classList.remove('popup'); + }; + }; + } + let translist = document.getElementById('trans'); if (translist) { let langoptions = Array.prototype.filter.call(document.getElementById('lang').options, opt => {