mirror of
https://github.com/badlogic/pi-mono.git
synced 2026-05-22 19:56:57 +00:00
104 lines
2.8 KiB
TypeScript
104 lines
2.8 KiB
TypeScript
import { mkdirSync, mkdtempSync, readFileSync, rmSync, writeFileSync } from "fs";
|
|
import { tmpdir } from "os";
|
|
import { join } from "path";
|
|
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
import { getThemeExportColors } from "../src/modes/interactive/theme/theme.ts";
|
|
|
|
type ThemeFile = {
|
|
name: string;
|
|
vars?: Record<string, string | number>;
|
|
colors: Record<string, string | number>;
|
|
export?: {
|
|
pageBg?: string | number;
|
|
cardBg?: string | number;
|
|
infoBg?: string | number;
|
|
};
|
|
};
|
|
|
|
describe("getThemeExportColors", () => {
|
|
let tempRoot: string;
|
|
let previousAgentDir: string | undefined;
|
|
|
|
beforeEach(() => {
|
|
tempRoot = mkdtempSync(join(tmpdir(), "pi-theme-export-"));
|
|
previousAgentDir = process.env.PI_CODING_AGENT_DIR;
|
|
process.env.PI_CODING_AGENT_DIR = join(tempRoot, "agent");
|
|
mkdirSync(join(process.env.PI_CODING_AGENT_DIR, "themes"), { recursive: true });
|
|
});
|
|
|
|
afterEach(() => {
|
|
rmSync(tempRoot, { recursive: true, force: true });
|
|
if (previousAgentDir === undefined) {
|
|
delete process.env.PI_CODING_AGENT_DIR;
|
|
} else {
|
|
process.env.PI_CODING_AGENT_DIR = previousAgentDir;
|
|
}
|
|
});
|
|
|
|
it("resolves export variable references using the same syntax as colors", () => {
|
|
const darkTheme = JSON.parse(
|
|
readFileSync(new URL("../src/modes/interactive/theme/dark.json", import.meta.url), "utf-8"),
|
|
) as ThemeFile;
|
|
|
|
const customTheme: ThemeFile = {
|
|
...darkTheme,
|
|
name: "custom-export-vars",
|
|
vars: {
|
|
...(darkTheme.vars ?? {}),
|
|
pageBgVar: "#112233",
|
|
pageBgAlias: "pageBgVar",
|
|
infoBgVar: "#445566",
|
|
cardBgVar: "#223344",
|
|
},
|
|
export: {
|
|
pageBg: "pageBgAlias",
|
|
cardBg: "cardBgVar",
|
|
infoBg: "infoBgVar",
|
|
},
|
|
};
|
|
|
|
writeFileSync(
|
|
join(process.env.PI_CODING_AGENT_DIR!, "themes", "custom-export-vars.json"),
|
|
JSON.stringify(customTheme, null, 2),
|
|
);
|
|
|
|
expect(getThemeExportColors("custom-export-vars")).toEqual({
|
|
pageBg: "#112233",
|
|
cardBg: "#223344",
|
|
infoBg: "#445566",
|
|
});
|
|
});
|
|
|
|
it("resolves recursive vars and converts 256-color export values to hex", () => {
|
|
const darkTheme = JSON.parse(
|
|
readFileSync(new URL("../src/modes/interactive/theme/dark.json", import.meta.url), "utf-8"),
|
|
) as ThemeFile;
|
|
|
|
const customTheme: ThemeFile = {
|
|
...darkTheme,
|
|
name: "custom-export-recursive",
|
|
vars: {
|
|
...(darkTheme.vars ?? {}),
|
|
deepPageBg: "#abcdef",
|
|
pageBgAlias: "deepPageBg",
|
|
cardBgAnsi: 24,
|
|
},
|
|
export: {
|
|
pageBg: "pageBgAlias",
|
|
cardBg: "cardBgAnsi",
|
|
infoBg: "",
|
|
},
|
|
};
|
|
|
|
writeFileSync(
|
|
join(process.env.PI_CODING_AGENT_DIR!, "themes", "custom-export-recursive.json"),
|
|
JSON.stringify(customTheme, null, 2),
|
|
);
|
|
|
|
expect(getThemeExportColors("custom-export-recursive")).toEqual({
|
|
pageBg: "#abcdef",
|
|
cardBg: "#005f87",
|
|
infoBg: undefined,
|
|
});
|
|
});
|
|
});
|