X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/56665a20823025810a7d37ba54c855d0cf726da5..5e4c37b26db8009a1104b7784fe4520d228aa7ff:/writer.js diff --git a/writer.js b/writer.js index f05559f..5d3ad5e 100644 --- a/writer.js +++ b/writer.js @@ -1,4 +1,17 @@ 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; + e.target.parentNode.appendChild(add); + e.target.oninput = undefined; + e.target.removeAttribute('id'); + }; + }); + let wpinput = document.getElementById('wptitle'); if (wpinput) { let wpbutton = wpinput.parentNode.appendChild(document.createElement('button')); @@ -7,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 => { @@ -18,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(/
(.*?)<\/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 => {
@@ -48,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;
};
@@ -67,13 +96,42 @@ 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 => {
+ if (document.getElementById('trans-' + opt.value)) return;
+ if (document.getElementById('lang').value == opt.value) return;
+ return true;
+ });
+ if (!langoptions.length) return;
+
let transadd = translist.appendChild(document.createElement('li'));
let transselect = transadd.appendChild(document.createElement('select'));
transselect.appendChild(document.createElement('option'));
- for (let langoption of document.getElementById('lang').options) {
- if (document.getElementById('trans-'+langoption.value)) continue;
+ for (let langoption of langoptions) {
let transoption = document.createElement('option');
transoption.value = langoption.value;
transoption.append(langoption.label);