2024-03-26 16:28:28 +01:00
|
|
|
const fs = require("fs");
|
|
|
|
const path = require("path");
|
|
|
|
const themePath = path.join(__dirname, "data/theme.json");
|
|
|
|
const themeRead = fs.readFileSync(themePath, "utf8");
|
|
|
|
const theme = JSON.parse(themeRead);
|
|
|
|
|
|
|
|
let font_base = Number(theme.fonts.font_size.base.replace("px", ""));
|
|
|
|
let font_scale = Number(theme.fonts.font_size.scale);
|
|
|
|
let h6 = font_scale;
|
|
|
|
let h5 = h6 * font_scale;
|
|
|
|
let h4 = h5 * font_scale;
|
|
|
|
let h3 = h4 * font_scale;
|
|
|
|
let h2 = h3 * font_scale;
|
|
|
|
let h1 = h2 * font_scale;
|
|
|
|
let fontPrimary, fontPrimaryType, fontSecondary, fontSecondaryType;
|
|
|
|
if (theme.fonts.font_family.primary) {
|
|
|
|
fontPrimary = theme.fonts.font_family.primary
|
|
|
|
.replace(/\+/g, " ")
|
|
|
|
.replace(/:[ital,]*[ital@]*[wght@]*[0-9,;]+/gi, "");
|
|
|
|
fontPrimaryType = theme.fonts.font_family.primary_type;
|
|
|
|
}
|
|
|
|
if (theme.fonts.font_family.secondary) {
|
|
|
|
fontSecondary = theme.fonts.font_family.secondary
|
|
|
|
.replace(/\+/g, " ")
|
|
|
|
.replace(/:[ital,]*[ital@]*[wght@]*[0-9,;]+/gi, "");
|
|
|
|
fontSecondaryType = theme.fonts.font_family.secondary_type;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** @type {import('tailwindcss').Config} */
|
|
|
|
module.exports = {
|
|
|
|
content: ["./hugo_stats.json"],
|
|
|
|
safelist: [{ pattern: /^swiper-/ }],
|
|
|
|
darkMode: "class",
|
|
|
|
theme: {
|
|
|
|
screens: {
|
2024-10-14 16:44:36 +02:00
|
|
|
sm: "768px",
|
2024-03-26 16:28:28 +01:00
|
|
|
md: "768px",
|
|
|
|
lg: "1024px",
|
|
|
|
xl: "1280px",
|
|
|
|
"2xl": "1536px",
|
|
|
|
},
|
|
|
|
container: {
|
|
|
|
center: true,
|
|
|
|
padding: "2rem",
|
|
|
|
},
|
|
|
|
extend: {
|
|
|
|
colors: {
|
|
|
|
text: theme.colors.default.text_color.default,
|
|
|
|
light: theme.colors.default.text_color.light,
|
|
|
|
dark: theme.colors.default.text_color.dark,
|
|
|
|
primary: theme.colors.default.theme_color.primary,
|
|
|
|
secondary: theme.colors.default.theme_color.secondary,
|
|
|
|
body: theme.colors.default.theme_color.body,
|
|
|
|
border: theme.colors.default.theme_color.border,
|
|
|
|
"theme-light": theme.colors.default.theme_color.theme_light,
|
|
|
|
"theme-dark": theme.colors.default.theme_color.theme_dark,
|
|
|
|
darkmode: {
|
|
|
|
text: theme.colors.darkmode.text_color.default,
|
|
|
|
light: theme.colors.darkmode.text_color.light,
|
|
|
|
dark: theme.colors.darkmode.text_color.dark,
|
|
|
|
primary: theme.colors.darkmode.theme_color.primary,
|
|
|
|
secondary: theme.colors.darkmode.theme_color.secondary,
|
|
|
|
body: theme.colors.darkmode.theme_color.body,
|
|
|
|
border: theme.colors.darkmode.theme_color.border,
|
|
|
|
"theme-light": theme.colors.darkmode.theme_color.theme_light,
|
|
|
|
"theme-dark": theme.colors.darkmode.theme_color.theme_dark,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
fontSize: {
|
|
|
|
base: font_base + "px",
|
|
|
|
"base-sm": font_base * 0.8 + "px",
|
|
|
|
h1: h1 + "rem",
|
|
|
|
"h1-sm": h1 * 0.9 + "rem",
|
|
|
|
h2: h2 + "rem",
|
|
|
|
"h2-sm": h2 * 0.9 + "rem",
|
|
|
|
h3: h3 + "rem",
|
|
|
|
"h3-sm": h3 * 0.9 + "rem",
|
|
|
|
h4: h4 + "rem",
|
|
|
|
h5: h5 + "rem",
|
|
|
|
h6: h6 + "rem",
|
|
|
|
},
|
|
|
|
fontFamily: {
|
|
|
|
primary: [fontPrimary, fontPrimaryType],
|
|
|
|
secondary: [fontSecondary, fontSecondaryType],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
plugins: [
|
|
|
|
require("@tailwindcss/typography"),
|
|
|
|
require("@tailwindcss/forms"),
|
|
|
|
require("tailwind-bootstrap-grid")({
|
|
|
|
generateContainer: false,
|
|
|
|
gridGutterWidth: "2rem",
|
|
|
|
gridGutters: {
|
|
|
|
1: "0.25rem",
|
|
|
|
2: "0.5rem",
|
|
|
|
3: "1rem",
|
|
|
|
4: "1.5rem",
|
|
|
|
5: "3rem",
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
],
|
|
|
|
};
|