From 7ddefc6e44791397b9aadac781dbfa7c1536bdd5 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Tue, 8 Aug 2023 10:43:48 -0300 Subject: bulid: static-build: restore generateRedirectHTML, touch up redirect code --- src/write/build-modes/static-build.js | 78 +++++++++++++++++++++++------------ 1 file changed, 51 insertions(+), 27 deletions(-) (limited to 'src/write') diff --git a/src/write/build-modes/static-build.js b/src/write/build-modes/static-build.js index bf722bff..8fb60cdd 100644 --- a/src/write/build-modes/static-build.js +++ b/src/write/build-modes/static-build.js @@ -78,6 +78,36 @@ export function getCLIOptions() { }; } +function generateRedirectHTML(title, target, {language}) { + 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), + })), + ])), + ]); +} + export async function go({ cliOptions, _dataPath, @@ -323,7 +353,6 @@ export async function go({ }); }), - /* ...redirectWrites.map(({fromPath, toPath, title: titleFn}) => () => { const title = titleFn({ language, @@ -348,7 +377,6 @@ export async function go({ })), }); }), - */ ], queueSize)); }; @@ -473,31 +501,26 @@ async function writeSharedFilesAndPages({ const {groupData, wikiInfo} = wikiData; return progressPromiseAll(`Writing files & pages shared across languages.`, [ - /* groupData?.some((group) => group.directory === 'fandom') && - redirect( - 'Fandom - Gallery', - 'albums/fandom', - 'localized.groupGallery', - 'fandom' - ), + redirect({ + title: 'Fandom - Gallery', + from: 'albums/fandom', + to: ['localized.groupGallery', 'fandom'], + }), groupData?.some((group) => group.directory === 'official') && - redirect( - 'Official - Gallery', - 'albums/official', - 'localized.groupGallery', - 'official' - ), + redirect({ + title: 'Official - Gallery', + from: 'albums/official', + to: ['localized.groupGallery', 'official'], + }), wikiInfo.enableListings && - redirect( - 'Album Commentary', - 'list/all-commentary', - 'localized.commentaryIndex', - '' - ), - */ + redirect({ + title: 'Album Commentary', + from: 'list/all-commentary', + to: ['localized.commentaryIndex'], + }), wikiDataJSON && writeFile( @@ -505,11 +528,12 @@ async function writeSharedFilesAndPages({ wikiDataJSON), ].filter(Boolean)); - async function redirect(title, from, urlKey, directory) { - const target = path.relative( - from, - urls.from('shared.root').to(urlKey, directory) - ); + async function redirect({title, from, to: toPath}) { + const target = + path.relative( + from, + urls.from('shared.root').to(...toPath)); + const content = generateRedirectHTML(title, target, {language}); await mkdir(path.join(outputPath, from), {recursive: true}); await writeFile(path.join(outputPath, from, 'index.html'), content); -- cgit 1.3.0-6-gf8a5 From f2e6da9c339b9b4b862d9070188f4b0ba07baf45 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Tue, 8 Aug 2023 10:44:06 -0300 Subject: write: static-build: ensure output directory exists first of all --- src/write/build-modes/static-build.js | 2 ++ 1 file changed, 2 insertions(+) (limited to 'src/write') diff --git a/src/write/build-modes/static-build.js b/src/write/build-modes/static-build.js index 8fb60cdd..60614c29 100644 --- a/src/write/build-modes/static-build.js +++ b/src/write/build-modes/static-build.js @@ -154,6 +154,8 @@ export async function go({ const writeAll = empty(selectedPageFlags) || selectedPageFlags.includes('all'); logInfo`Writing site pages: ${writeAll ? 'all' : selectedPageFlags.join(', ')}`; + await mkdir(outputPath, {recursive: true}); + await writeSymlinks({ srcRootPath, mediaPath, -- cgit 1.3.0-6-gf8a5 From 8f39a21ef27f8b66cd49c01e38937d133f13859d Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Tue, 8 Aug 2023 11:03:25 -0300 Subject: content: move hard-coded redirects into page files --- src/write/build-modes/static-build.js | 32 -------------------------------- 1 file changed, 32 deletions(-) (limited to 'src/write') diff --git a/src/write/build-modes/static-build.js b/src/write/build-modes/static-build.js index 60614c29..dc2bb2c0 100644 --- a/src/write/build-modes/static-build.js +++ b/src/write/build-modes/static-build.js @@ -503,41 +503,9 @@ async function writeSharedFilesAndPages({ const {groupData, wikiInfo} = wikiData; return progressPromiseAll(`Writing files & pages shared across languages.`, [ - groupData?.some((group) => group.directory === 'fandom') && - redirect({ - title: 'Fandom - Gallery', - from: 'albums/fandom', - to: ['localized.groupGallery', 'fandom'], - }), - - groupData?.some((group) => group.directory === 'official') && - redirect({ - title: 'Official - Gallery', - from: 'albums/official', - to: ['localized.groupGallery', 'official'], - }), - - wikiInfo.enableListings && - redirect({ - title: 'Album Commentary', - from: 'list/all-commentary', - to: ['localized.commentaryIndex'], - }), - wikiDataJSON && writeFile( path.join(outputPath, 'data.json'), wikiDataJSON), ].filter(Boolean)); - - async function redirect({title, from, to: toPath}) { - const target = - path.relative( - from, - urls.from('shared.root').to(...toPath)); - - const content = generateRedirectHTML(title, target, {language}); - await mkdir(path.join(outputPath, from), {recursive: true}); - await writeFile(path.join(outputPath, from, 'index.html'), content); - } } -- cgit 1.3.0-6-gf8a5 From 725482638dcc96632c3a9cf2b885f4128c50a1c1 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Tue, 8 Aug 2023 11:46:44 -0300 Subject: write, content: restore & handle redirect titles properly --- src/write/build-modes/live-dev-server.js | 6 +++++- src/write/build-modes/static-build.js | 6 ++---- 2 files changed, 7 insertions(+), 5 deletions(-) (limited to 'src/write') diff --git a/src/write/build-modes/live-dev-server.js b/src/write/build-modes/live-dev-server.js index a87da27b..edee3267 100644 --- a/src/write/build-modes/live-dev-server.js +++ b/src/write/build-modes/live-dev-server.js @@ -321,6 +321,10 @@ export async function go({ try { if (page.type === 'redirect') { + const title = + page.title ?? + page.getTitle?.({language}); + const target = to('localized.' + page.toPath[0], ...page.toPath.slice(1)); response.writeHead(301, { @@ -328,7 +332,7 @@ export async function go({ 'Location': target, }); - const redirectHTML = generateRedirectHTML(page.title, target, {language}); + const redirectHTML = generateRedirectHTML(title, target, {language}); response.end(redirectHTML); diff --git a/src/write/build-modes/static-build.js b/src/write/build-modes/static-build.js index dc2bb2c0..4f074058 100644 --- a/src/write/build-modes/static-build.js +++ b/src/write/build-modes/static-build.js @@ -355,10 +355,8 @@ export async function go({ }); }), - ...redirectWrites.map(({fromPath, toPath, title: titleFn}) => () => { - const title = titleFn({ - language, - }); + ...redirectWrites.map(({fromPath, toPath, title, getTitle}) => () => { + title ??= getTitle?.({language}); const to = getURLsFrom({ baseDirectory, -- cgit 1.3.0-6-gf8a5