调整代码结构以支持多种风格

This commit is contained in:
lutinglt
2025-02-21 21:47:54 +08:00
parent ba895a3f31
commit 8def32e5b9
33 changed files with 50 additions and 26 deletions

View File

@@ -12,6 +12,9 @@ end_of_line = lf
insert_final_newline = true
trim_trailing_whitespace = true
[*.{css,scss,ts}]
max_line_length = 120
# documentation, utils
[*.{md,mdx,diff}]
trim_trailing_whitespace = false

29
build.js Normal file
View File

@@ -0,0 +1,29 @@
import * as process from "node:process";
import * as fs from "node:fs";
import * as sass from "sass";
import * as yaml from "js-yaml";
async function generateTheme(themePath) {
try {
const fileContent = fs.readFileSync(themePath);
const data = yaml.load(fileContent);
console.log(data.gitea.version);
fs.mkdirSync("dist", { recursive: true });
for (const theme of data.gitea.themes) {
const inputFile = `src/themes/theme-github-${theme}.scss`;
const outputFile = `dist/theme-github-${theme}.css`;
const result = await sass.compileAsync(inputFile, { sourceMap: false, style: "compressed" });
fs.writeFileSync(outputFile, result.css);
}
} catch (error) {
let e = error;
if (error instanceof Error) {
e = error.message;
}
console.error("Build failed:", e);
process.exit(1);
}
}
generateTheme("theme.yml");

View File

@@ -5,6 +5,7 @@ import * as yaml from "npm:js-yaml";
interface Gitea {
version: string;
themes: [string];
}
interface ThemeInfo {
@@ -13,16 +14,17 @@ interface ThemeInfo {
async function generateTheme(themePath: string) {
try {
const inputFile = "src/theme-github.scss";
const outputFile = "dist/theme-github.css";
const result = await sass.compileAsync(inputFile, { sourceMap: false, style: "compressed" });
await Deno.mkdir("dist", { recursive: true });
await Deno.writeTextFile(outputFile, result.css);
const fileContent = await Deno.readTextFile(themePath);
const data: ThemeInfo = yaml.load(fileContent);
console.log(data.gitea.version);
await Deno.mkdir("dist", { recursive: true });
for (const theme of data.gitea.themes) {
const inputFile = `src/themes/theme-github-${theme}.scss`;
const outputFile = `dist/theme-github-${theme}.css`;
const result = await sass.compileAsync(inputFile, { sourceMap: false, style: "compressed" });
await Deno.writeTextFile(outputFile, result.css);
}
} catch (error) {
let e = error;
if (error instanceof Error) {

View File

@@ -6,6 +6,6 @@
}
},
"tasks": {
"build": "./build.ts"
"build": "deno -A --allow-scripts build.ts"
}
}

View File

@@ -1,19 +1,8 @@
{
"name": "gitea-github-theme",
"description": "尽量保持与 GitHub Dark 相同样式的 Gitea 主题",
"type": "module",
"scripts": {
"export": "sass src/theme-github.scss:dist/theme-github.css --no-source-map",
"build": "npm run export -- --style=compressed",
"watch": "npm run export -- --watch"
"build": "node build.js"
},
"repository": {
"type": "git",
"url": "git+https://github.com/lutinglt/gitea-github-theme.git"
},
"bugs": {
"url": "https://github.com/lutinglt/gitea-github-theme/issues"
},
"homepage": "https://github.com/lutinglt/gitea-github-theme#readme",
"devDependencies": {
"js-yaml": "^4.1.0",
"sass": "^1.83.0"

View File

@@ -1,4 +1,3 @@
/* Made by Luting ^-^ */
@use "styles";
@use "public";
@use "components";

View File

@@ -1,3 +0,0 @@
// Made by Luting ^-^
@use "styles/github.css"; // GitHub 变量(仅主题内部使用的变量)
@use "styles/gitea.css"; // Gitea 变量(元素默认使用的变量)

View File

@@ -0,0 +1,4 @@
// Made by Luting ^-^
@use "../sass/theme-github";
@use "../styles/dark/github-dark.css"; // GitHub 变量(仅主题内部使用的变量)
@use "../styles/dark/gitea-dark.css"; // Gitea 变量(元素默认使用的变量)

View File

@@ -1,2 +1,3 @@
gitea:
version: 1.23.3
themes: [dark]