Skip to content

Commit

Permalink
Merge branch 'main' into phlmn/nix-frontend-add-node
Browse files Browse the repository at this point in the history
  • Loading branch information
pajowu authored Dec 17, 2023
2 parents fb6cf2e + 651f145 commit b91078c
Show file tree
Hide file tree
Showing 5 changed files with 61 additions and 73 deletions.
67 changes: 20 additions & 47 deletions frontend/src/common/footer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -41,74 +41,47 @@ export function CommitPopup({ commit, text }: { commit: Commit; text: string })
}

export function ShortVersion() {
const lastCommit = version?.lastCommit;
const commit = version?.commit;

return (
<>
Version:{' '}
{lastCommit?.hash && (
{commit?.hash && (
<a
href={`https://github.com/bugbakery/transcribee/commit/${lastCommit.hash}`}
href={commit?.url}
target="_blank"
rel="noreferrer"
className="underline decoration-dashed"
title="View commit on GitHub"
>
{lastCommit.hash.substring(0, 10)} <IoMdOpen className="inline" />
{commit?.hash.substring(0, 7)} <IoMdOpen className="inline" />
</a>
)}{' '}
({lastCommit?.countSinceStart || 'unknown'})
)}
</>
);
}

export function LongVersion() {
return (
<>
Frontend built on {formatDate(version?.date)}.
{version?.lastCommitOnMain?.countSinceStart ? (
Frontend built on {formatDate(version?.buildDate)}.
{version?.commit?.hash && (
<>
{' '}
<CommitPopup
commit={version.lastCommitOnMain}
text={`${version.lastCommitOnMain.countSinceStart} commits on main`}
/>
{version?.branch != 'main' &&
version.lastCommit &&
version.lastCommit?.countSinceStart &&
version.lastCommitOnMain?.countSinceStart && (
<>
{' '}
+{' '}
<CommitPopup
commit={version.lastCommit}
text={`${
version.lastCommit?.countSinceStart - version.lastCommitOnMain?.countSinceStart
} commits on ${version.branch}`}
/>
</>
)}
{version.diffShort && <> + {version.diffShort}</>}
Last commit{' '}
{version.commit?.hash && (
<a
href={version.commit?.url}
target="_blank"
rel="noreferrer"
className="underline decoration-dashed"
title="View commit on GitHub"
>
{version.commit.hash.substring(0, 7)} <IoMdOpen className="inline" />
</a>
)}{' '}
on {formatDate(version.commit?.date)}.
</>
) : (
version?.lastCommit?.hash && (
<>
{' '}
Last commit{' '}
{version.lastCommit?.hash && (
<a
href={`https://github.com/bugbakery/transcribee/commit/${version.lastCommit.hash}`}
target="_blank"
rel="noreferrer"
className="underline decoration-dashed"
title="View commit on GitHub"
>
{version.lastCommit.hash.substring(0, 10)} <IoMdOpen className="inline" />
</a>
)}{' '}
on {formatDate(version.lastCommit?.date)}.
</>
)
)}
</>
);
Expand Down
12 changes: 5 additions & 7 deletions frontend/src/common/virtual:git-version.d.ts
Original file line number Diff line number Diff line change
@@ -1,16 +1,14 @@
declare module 'virtual:git-version' {
export interface Commit {
countSinceStart?: number;
date?: string;
hash?: string;
date?: string;
url?: string;
}

export interface Version {
branch?: string;
diffShort?: string;
lastCommit?: Commit;
lastCommitOnMain?: Commit;
date?: string;
name?: string;
buildDate?: string;
commit?: Commit;
}

let version: Version | undefined;
Expand Down
21 changes: 11 additions & 10 deletions frontend/vite.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import { execSync } from 'child_process';
import fs from 'fs';
import * as mime from 'mime-types';

import pkg from './package.json';

function gitVersionPlugin() {
const virtualModuleId = 'virtual:git-version';

Expand All @@ -27,22 +29,21 @@ function gitVersionPlugin() {
return stdout;
}

function commitInfo(ref) {
function commitInfo() {
const hash = process.env.COMMIT_HASH || git('rev-parse HEAD');

return {
hash: git(`rev-parse ${ref}`),
date: git(`show -s --format=%cI ${ref}`),
countSinceStart: parseInt(git(`rev-list --count ${ref}`)),
hash: hash,
date: process.env.COMMIT_DATE || git('show -s --format=%cI HEAD'),
url: process.env.COMMIT_URL || `https://github.com/bugbakery/transcribee/commit/${hash}`,
};
}

if (id === virtualModuleId) {
const lastCommitOnMain = git('merge-base origin/main HEAD');
const json = JSON.stringify({
diffShort: git('diff --shortstat HEAD'),
lastCommit: commitInfo('HEAD'),
lastCommitOnMain: commitInfo(lastCommitOnMain),
branch: git('rev-parse --abbrev-ref HEAD'),
date: new Date().toISOString(),
name: process.env.VERSION_NAME || pkg.version,
commit: commitInfo('HEAD'),
buildDate: new Date().toISOString(),
});
return `
const version = ${json};
Expand Down
31 changes: 22 additions & 9 deletions nix/pkgs/frontend.nix
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
{ pkgs, stdenv }:
{ pkgs
, stdenv
, versionInfo ? { }
}:
let
common = import ../common.nix;
package = builtins.fromJSON (builtins.readFile ../../frontend/package.json);
Expand All @@ -16,14 +19,24 @@ stdenv.mkDerivation {
cd frontend/
'';

installPhase = ''
# npm is used by some packages
export NPM_CONFIG_CACHE="$(mktemp -d)"
installPhase =
let
versionExports = ([ ]
++ (lib.optional versionInfo.commitHash "export COMMIT_HASH=\"${versionInfo.commitHash}\"")
++ (lib.optional versionInfo.commitDate "export COMMIT_DATE=\"${versionInfo.commitDate}\"")
++ (lib.optional versionInfo.commitUrl "export COMMIT_URL=\"${versionInfo.commitUrl}\"")
);
in
''
# npm is used by some packages
export NPM_CONFIG_CACHE="$(mktemp -d)"
pnpm install --frozen-lockfile
pnpm install --frozen-lockfile
pnpm build
${lib.concatStringsSep "\n" versionExports}
pnpm build
mkdir -p $out
cp -r dist/* dist/.* $out/
'';
mkdir -p $out
cp -r dist/* dist/.* $out/
'';
}
3 changes: 3 additions & 0 deletions shell.nix
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,9 @@ pkgs.mkShell {

nodePackages.pnpm

# nix tooling
nixpkgs-fmt

# required by whispercppy
cmake

Expand Down

0 comments on commit b91078c

Please sign in to comment.