From b7633208507e3cd25ef7f7018759a0402c13a2f8 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Sun, 20 Nov 2022 14:31:17 -0400 Subject: htmlify upd8.js, remove fix-whitespace dependency --- package-lock.json | 11 -- package.json | 1 - src/upd8.js | 413 ++++++++++++++++++++++++++------------------------- src/util/replacer.js | 12 +- src/util/sugar.js | 6 - 5 files changed, 216 insertions(+), 227 deletions(-) diff --git a/package-lock.json b/package-lock.json index a2dd0ca9..4195eecf 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,7 +10,6 @@ "license": "GPL-3.0", "dependencies": { "command-exists": "^1.2.9", - "fix-whitespace": "^1.0.4", "he": "^1.2.0", "js-yaml": "^4.1.0" }, @@ -615,11 +614,6 @@ "node": "^10.12.0 || >=12.0.0" } }, - "node_modules/fix-whitespace": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/fix-whitespace/-/fix-whitespace-1.0.4.tgz", - "integrity": "sha512-TYJpw4orIgDpaINRkw1BVJQF8rPTNSUbW/s4mLYSApUt0MquGfI+iripYHibg9l9fe795VauuVCLTpDvy8KFWQ==" - }, "node_modules/flat-cache": { "version": "3.0.4", "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", @@ -2194,11 +2188,6 @@ "flat-cache": "^3.0.4" } }, - "fix-whitespace": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/fix-whitespace/-/fix-whitespace-1.0.4.tgz", - "integrity": "sha512-TYJpw4orIgDpaINRkw1BVJQF8rPTNSUbW/s4mLYSApUt0MquGfI+iripYHibg9l9fe795VauuVCLTpDvy8KFWQ==" - }, "flat-cache": { "version": "3.0.4", "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", diff --git a/package.json b/package.json index 2f44ab82..c4f1ce1f 100644 --- a/package.json +++ b/package.json @@ -13,7 +13,6 @@ }, "dependencies": { "command-exists": "^1.2.9", - "fix-whitespace": "^1.0.4", "he": "^1.2.0", "js-yaml": "^4.1.0" }, diff --git a/src/upd8.js b/src/upd8.js index 6cccabfa..44cbce05 100755 --- a/src/upd8.js +++ b/src/upd8.js @@ -35,12 +35,6 @@ import * as path from 'path'; import {fileURLToPath} from 'url'; -// I made this dependency myself! A long, long time ago. It is pro8a8ly my -// most useful li8rary ever. I'm not sure 8esides me actually uses it, though. -import fixWS from 'fix-whitespace'; -// Wait nevermind, I forgot a8out why-do-kids-love-the-taste-of-cinnamon-toast- -// crunch. THAT is my 8est li8rary. - // It stands for "HTML Entities", apparently. Cursed. import he from 'he'; @@ -136,7 +130,6 @@ import { import { bindOpts, - filterEmptyLines, queue, showAggregate, withEntries, @@ -232,7 +225,9 @@ const replacerSpec = { find: null, value: (ref) => new Date(ref), html: (date, {language}) => - ``, + html.tag('time', + {datetime: date.toString()}, + language.formatDate(date)), }, flash: { find: 'flash', @@ -642,32 +637,45 @@ function img({ const originalSrc = src; const thumbSrc = src && (thumbKey ? thumb[thumbKey](src) : src); - const imgAttributes = html.attributes({ + const imgAttributes = { id: link ? '' : id, class: className, alt, width, height, - }); + }; const noSrcHTML = - !src && wrap(`
${noSrcText}
`); - const nonlazyHTML = src && wrap(``); + !src && + wrap( + html.tag('div', + {class: 'image-text-area'}, + noSrcText)); + + const nonlazyHTML = + src && + wrap( + html.tag('img', { + ...imgAttributes, + src: thumbSrc, + })); + const lazyHTML = src && lazy && - wrap( - ``, - true - ); + wrap( + html.tag('img', + { + ...imgAttributes, + class: [className, 'lazy'], + 'data-original': thumbSrc, + }), + true); if (!src) { return noSrcHTML; } else if (lazy) { - return fixWS` - - ${lazyHTML} - `; + return html.tag('noscript', nonlazyHTML) + '\n' + lazyHTML; } else { return nonlazyHTML; } @@ -675,37 +683,31 @@ function img({ function wrap(input, hide = false) { let wrapped = input; - wrapped = `
${wrapped}
`; - wrapped = `
${wrapped}
`; + wrapped = html.tag('div', {class: 'image-inner-area'}, wrapped); + wrapped = html.tag('div', {class: 'image-container'}, wrapped); if (reveal) { - wrapped = fixWS` -
- ${wrapped} - ${reveal} -
- `; + wrapped = html.tag('div', {class: 'reveal'}, [ + wrapped, + html.tag('span', {class: 'reveal-text'}, reveal), + ]); } if (willSquare) { wrapped = html.tag('div', {class: 'square-content'}, wrapped); - wrapped = html.tag( - 'div', + wrapped = html.tag('div', {class: ['square', hide && !willLink && 'js-hide']}, - wrapped - ); + wrapped); } if (willLink) { - wrapped = html.tag( - 'a', + wrapped = html.tag('a', { id, class: ['box', hide && 'js-hide'], href: typeof link === 'string' ? link : originalSrc, }, - wrapped - ); + wrapped); } return wrapped; @@ -1210,141 +1212,140 @@ writePage.html = ( }), ].filter(Boolean).join('\n'); - return filterEmptyLines(fixWS` - - [['data-url-value' + i], v]) - ), - 'data-rebase-localized': to('localized.root'), - 'data-rebase-shared': to('shared.root'), - 'data-rebase-media': to('media.root'), - 'data-rebase-data': to('data.root'), - })}> - - - ${ - showWikiNameInTitle - ? language.formatString('misc.pageTitle.withWikiName', { - title, - wikiName: wikiInfo.nameShort, - }) - : language.formatString('misc.pageTitle', {title}) - } - - - ${Object.entries(meta) - .filter(([key, value]) => value) - .map( - ([key, value]) => - `` - ) - .join('\n')} - ${canonical && ``} - ${localizedCanonical - .map( - ({lang, href}) => - `` - ) - .join('\n')} - ${socialEmbedHTML} - - ${ - (theme || stylesheet) && - fixWS` - - ` - } - - - -
- ${ - mainHTML && - fixWS` -
- ${[ - [ - '#content', - language.$('misc.skippers.skipToContent'), - ], - sidebarLeftHTML && [ - '#sidebar-left', - sidebarRightHTML - ? language.$( - 'misc.skippers.skipToSidebar.left' - ) - : language.$('misc.skippers.skipToSidebar'), - ], - sidebarRightHTML && [ - '#sidebar-right', - sidebarLeftHTML - ? language.$( - 'misc.skippers.skipToSidebar.right' - ) - : language.$('misc.skippers.skipToSidebar'), - ], - footerHTML && [ - '#footer', - language.$('misc.skippers.skipToFooter'), - ], - ] - .filter(Boolean) - .map( - ([href, title]) => fixWS` - ${title} - ` - ) - .join('\n')} -
- ` - } - ${layoutHTML} -
- ${infoCardHTML} - - - - `); + return `\n` + html.tag('html', + { + lang: language.intlCode, + 'data-language-code': language.code, + 'data-url-key': paths.toPath[0], + ...Object.fromEntries( + paths.toPath.slice(1).map((v, i) => [['data-url-value' + i], v]) + ), + 'data-rebase-localized': to('localized.root'), + 'data-rebase-shared': to('shared.root'), + 'data-rebase-media': to('media.root'), + 'data-rebase-data': to('data.root'), + }, + [ + ``, + + html.tag('head', [ + html.tag('title', + showWikiNameInTitle + ? language.formatString('misc.pageTitle.withWikiName', { + title, + wikiName: wikiInfo.nameShort, + }) + : language.formatString('misc.pageTitle', {title})), + + html.tag('meta', {charset: 'utf-8'}), + html.tag('meta', { + name: 'viewport', + content: 'width=device-width, initial-scale=1', + }), + + ...( + Object.entries(meta) + .filter(([key, value]) => value) + .map(([key, value]) => html.tag('meta', {[key]: value}))), + + canonical && + html.tag('link', { + rel: 'canonical', + href: canonical, + }), + + ...( + localizedCanonical + .map(({lang, href}) => html.tag('link', { + rel: 'alternate', + hreflang: lang, + href, + }))), + + socialEmbedHTML, + + html.tag('link', { + rel: 'stylesheet', + href: to('shared.staticFile', `site2.css?${CACHEBUST}`), + }), + + html.tag('style', + {[html.onlyIfContent]: true}, + [ + theme, + stylesheet, + ]), + + html.tag('script', { + src: to('shared.staticFile', `lazy-loading.js?${CACHEBUST}`), + }), + ]), + + html.tag('body', + {style: body.style || ''}, + [ + html.tag('div', {id: 'page-container'}, [ + mainHTML && + html.tag('div', {id: 'skippers'}, + [ + ['#content', language.$('misc.skippers.skipToContent')], + sidebarLeftHTML && + [ + '#sidebar-left', + sidebarRightHTML + ? language.$('misc.skippers.skipToSidebar.left') + : language.$('misc.skippers.skipToSidebar'), + ], + sidebarRightHTML && + [ + '#sidebar-right', + sidebarLeftHTML + ? language.$('misc.skippers.skipToSidebar.right') + : language.$('misc.skippers.skipToSidebar'), + ], + footerHTML && + ['#footer', language.$('misc.skippers.skipToFooter')], + ] + .filter(Boolean) + .map(([href, title]) => + html.tag('span', {class: 'skipper'}, + html.tag('a', {href}, title)))), + layoutHTML, + ]), + + infoCardHTML, + + html.tag('script', { + type: 'module', + src: to('shared.staticFile', `client.js?${CACHEBUST}`), + }), + ]), + ]); }; writePage.oEmbedJSON = (pageInfo, {language, wikiData}) => { @@ -1513,42 +1514,50 @@ function writeSharedFilesAndPages({language, wikiData}) { writeFile( path.join(outputPath, 'data.json'), - fixWS` - { - "albumData": ${stringifyThings(wikiData.albumData)}, - ${ - wikiInfo.enableFlashesAndGames && - `"flashData": ${stringifyThings(wikiData.flashData)},` - } - "artistData": ${stringifyThings(wikiData.artistData)} - } - ` - ), + ( + '{\n' + + [ + `"albumData": ${stringifyThings(wikiData.albumData)},`, + wikiInfo.enableFlashesAndGames && + `"flashData": ${stringifyThings(wikiData.flashData)},`, + `"artistData": ${stringifyThings(wikiData.artistData)}`, + ] + .filter(Boolean) + .map(line => ' ' + line) + .join('\n') + + '\n}')), ].filter(Boolean) ); } function generateRedirectPage(title, target, {language}) { - return fixWS` - - - - ${language.$('redirectPage.title', {title})} - - - - - - -
-

${language.$('redirectPage.title', {title})}

-

${language.$('redirectPage.infoLine', { - target: `${target}`, - })}

-
- - - `; + return `\n` + html.tag('html', [ + html.tag('head', [ + html.tag('title', language.$('redirectPage.title', {title})), + html.tag('meta', {charset: 'utf-8'}), + + html.tag('meta', { + 'http-equiv': 'refresh', + content: `0;url=${target}`, + }), + + // TODO: Is this OK for localized pages? + html.tag('link', { + rel: 'canonical', + href: target, + }), + ]), + + html.tag('body', + html.tag('main', [ + html.tag('h1', + language.$('redirectPage.title', {title})), + html.tag('p', + language.$('redirectPage.infoLine', { + target: html.tag('a', {href: target}, target), + })), + ])), + ]); } async function processLanguageFile(file) { diff --git a/src/util/replacer.js b/src/util/replacer.js index 70c17e5f..ea5a674d 100644 --- a/src/util/replacer.js +++ b/src/util/replacer.js @@ -1,7 +1,5 @@ /** @format */ -import fixWS from 'fix-whitespace'; - import {logError, logWarn} from './cli.js'; import {escapeRegex} from './sugar.js'; @@ -331,11 +329,11 @@ export function parseInput(input) { const cursor = i - lineStart; - throw new SyntaxError(fixWS` - Parse error (at pos ${i}): ${message} - ${line} - ${'-'.repeat(cursor) + '^'} - `); + throw new SyntaxError([ + `Parse error (at pos ${i}): ${message}`, + line, + '-'.repeat(cursor) + '^', + ].join('\n')); } } diff --git a/src/util/sugar.js b/src/util/sugar.js index 8b59deef..c836d0ce 100644 --- a/src/util/sugar.js +++ b/src/util/sugar.js @@ -47,12 +47,6 @@ export function accumulateSum(array, fn = x => x) { export const mapInPlace = (array, fn) => array.splice(0, array.length, ...array.map(fn)); -export const filterEmptyLines = (string) => - string - .split('\n') - .filter((line) => line.trim()) - .join('\n'); - export const unique = (arr) => Array.from(new Set(arr)); export const compareArrays = (arr1, arr2, {checkOrder = true} = {}) => -- cgit 1.3.0-6-gf8a5