add an about page
this is a simple static text page showing current version from the npm package and git commit hash at which the app was built. it's served at /about.html but i didn't link it from the root. not sure where the best place is.
parent
a7a2acfc0c
commit
69f7b6c2e0
@ -0,0 +1,24 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>about / nostr</title>
|
||||||
|
<link rel="stylesheet" href="main.css" type="text/css">
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<main class="text">
|
||||||
|
<h1>nostr: notes and other stuff transmitted by relays</h1>
|
||||||
|
this is a nostr web client.<br>
|
||||||
|
source code is at <a href="https://git.qcode.ch/nostr/nostrweb">git.qcode.ch/nostr/nostrweb</a>.
|
||||||
|
<p>
|
||||||
|
you are looking at version #[PKG_VERSION]#, built at git commit
|
||||||
|
<a href="https://git.qcode.ch/nostr/nostrweb/commit/#[GIT_COMMIT]#">#[GIT_COMMIT]#</a>.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
for more information about nostr protocol, check out
|
||||||
|
<a href="https://nostr.info/" target="_blank" rel="noopener noreferrer">nostr.info</a>.
|
||||||
|
</p>
|
||||||
|
</main>
|
||||||
|
</body>
|
||||||
|
</html>
|
@ -0,0 +1,47 @@
|
|||||||
|
import { readFile } from 'node:fs/promises';
|
||||||
|
import { execFile } from 'node:child_process';
|
||||||
|
import { promisify } from 'node:util';
|
||||||
|
const execFileAsync = promisify(execFile);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* replaceOnCopyPlugin is an esbuild plugin. it loads files as utf-8 text
|
||||||
|
* and replaces certain placeholders with their values computed on plugin setup.
|
||||||
|
* the fileFilter is a regexp matching names or extensions of the files to process,
|
||||||
|
* passed to esbuild's onLoad as is.
|
||||||
|
*
|
||||||
|
* the following placeholders are replaced:
|
||||||
|
*
|
||||||
|
* #[PKG_VERSION]# -> npm package version
|
||||||
|
* #[GIT_COMMIT]# -> short git commit at current HEAD
|
||||||
|
*/
|
||||||
|
export function replaceOnCopyPlugin(fileFilter) {
|
||||||
|
return {
|
||||||
|
name: 'replace-on-copy',
|
||||||
|
setup(build) {
|
||||||
|
const appVersion = sanitizedStr(process.env.npm_package_version);
|
||||||
|
const gitHeadCommit = gitRevParse('HEAD');
|
||||||
|
|
||||||
|
build.onLoad({filter: fileFilter}, async (args) => {
|
||||||
|
const gitCommitHash = await gitHeadCommit;
|
||||||
|
let text = await readFile(args.path, 'utf8');
|
||||||
|
text = text.replaceAll('#[PKG_VERSION]#', appVersion);
|
||||||
|
text = text.replaceAll('#[GIT_COMMIT]#', gitCommitHash);
|
||||||
|
return {
|
||||||
|
contents: text,
|
||||||
|
loader: 'copy',
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function gitRevParse(rev) {
|
||||||
|
rev = sanitizedStr(rev);
|
||||||
|
const { stdout } = await execFileAsync('git', ['rev-parse', '--short', rev]);
|
||||||
|
return sanitizedStr(stdout.trim());
|
||||||
|
}
|
||||||
|
|
||||||
|
function sanitizedStr(s) {
|
||||||
|
const notOk = /[^0-9a-z \.@-]/ig;
|
||||||
|
return s.replaceAll(notOk, '-');
|
||||||
|
}
|
Loading…
Reference in New Issue