feat: port all template categories to JSON format

- Ported Minimalist templates to JSON (Swiss Grid, Brutalist, etc.)
- Ported Tech templates to JSON (SaaS, Terminal, Cyberpunk, etc.)
- Ported Creative templates to JSON (Art Gallery, Zine, Pop Art, etc.)
- Ported Industrial templates to JSON (Blueprint, Factory, Schematic, etc.)
- Ported Nature templates to JSON (Botanical, Ocean, Mountain, etc.)
- Ported Lifestyle templates to JSON (Cookbook, Travel, Coffee House, etc.)
- Ported Vintage templates to JSON (Art Deco, Medieval, Retro 80s, etc.)
- Updated README.md to reflect the new JSON-based style system (example configuration and contribution workflow)
- Completed migration of over 150 styles to the new architecture
This commit is contained in:
TypoGenie
2026-02-01 18:51:43 +02:00
parent a2631ac473
commit 60f39ed961
405 changed files with 69134 additions and 5936 deletions

50
fix_templates.cjs Normal file
View File

@@ -0,0 +1,50 @@
const fs = require('fs');
const path = require('path');
const rootDir = 'd:\\gdfhbfgdbnbdfbdf\\typogenie\\src-tauri\\templates';
function walk(dir) {
const files = fs.readdirSync(dir, { withFileTypes: true });
files.forEach(dirent => {
const fullPath = path.join(dir, dirent.name);
if (dirent.isDirectory()) {
walk(fullPath);
} else if (dirent.name.endsWith('.json')) {
let content = fs.readFileSync(fullPath, 'utf8');
let changed = false;
// Fix invalid "white" color
if (content.includes('"color": "white"')) {
content = content.replace(/"color": "white"/g, '"color": "background"');
changed = true;
}
if (content.includes('"background": "white"')) {
content = content.replace(/"background": "white"/g, '"background": "background"');
changed = true;
}
// Fix border alignment from nested "border": { "bottom": ... } to "borderBottom": ...
// This is a bit tricky with regex but let's try a simple one for the common cases
const borderSides = ['top', 'bottom', 'left', 'right'];
borderSides.forEach(side => {
const searchStr = new RegExp(`"border":\\s*{\\s*"${side}":\\s*{([^}]*)}`, 'g');
// Capture the content inside the side object
if (searchStr.test(content)) {
content = content.replace(searchStr, (match, p1) => {
const capitalizedSide = side.charAt(0).toUpperCase() + side.slice(1);
return `"border${capitalizedSide}": {${p1}}`;
});
changed = true;
}
});
if (changed) {
fs.writeFileSync(fullPath, content, { encoding: 'utf8' });
console.log(`Updated: ${fullPath}`);
}
}
});
}
walk(rootDir);
console.log('Finished mass-correction of templates.');