mirror of
https://github.com/shadoll/sLogos.git
synced 2025-12-20 03:26:59 +00:00
feat: Update asset paths and add emblems collection for PWA caching
This commit is contained in:
5
.github/workflows/gh-pages.yml
vendored
5
.github/workflows/gh-pages.yml
vendored
@@ -55,10 +55,7 @@ jobs:
|
|||||||
cp public/manifest.json ./gh-pages-artifact/
|
cp public/manifest.json ./gh-pages-artifact/
|
||||||
cp public/sw.js ./gh-pages-artifact/
|
cp public/sw.js ./gh-pages-artifact/
|
||||||
cp -r public/data ./gh-pages-artifact/
|
cp -r public/data ./gh-pages-artifact/
|
||||||
cp -r public/logos ./gh-pages-artifact/
|
cp -r public/images ./gh-pages-artifact/
|
||||||
cp -r public/logos_gen ./gh-pages-artifact/
|
|
||||||
cp -r public/flags ./gh-pages-artifact/
|
|
||||||
cp -r public/flags_gen ./gh-pages-artifact/
|
|
||||||
cp public/pwa-files-to-cache.json ./gh-pages-artifact/
|
cp public/pwa-files-to-cache.json ./gh-pages-artifact/
|
||||||
if [ -f public/CNAME ]; then
|
if [ -f public/CNAME ]; then
|
||||||
cp public/CNAME ./gh-pages-artifact/CNAME
|
cp public/CNAME ./gh-pages-artifact/CNAME
|
||||||
|
|||||||
8
public/data/emblems.json
Normal file
8
public/data/emblems.json
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
[
|
||||||
|
{
|
||||||
|
"name": "Escudo De España",
|
||||||
|
"path": "images/emblems/Escudo_de_España.svg",
|
||||||
|
"format": "SVG",
|
||||||
|
"disable": false
|
||||||
|
}
|
||||||
|
]
|
||||||
@@ -34,8 +34,8 @@ self.addEventListener('fetch', event => {
|
|||||||
const url = new URL(event.request.url);
|
const url = new URL(event.request.url);
|
||||||
// Remove query params for cache matching for static files
|
// Remove query params for cache matching for static files
|
||||||
let cacheKey = url.pathname;
|
let cacheKey = url.pathname;
|
||||||
// Only do this for files we know are static (e.g., /data/, /logos/, /logos_gen/, /public/)
|
// Only do this for files we know are static (e.g., /data/, /images/)
|
||||||
if (cacheKey.startsWith('/data/') || cacheKey.startsWith('/logos/') || cacheKey.startsWith('/logos_gen/')) {
|
if (cacheKey.startsWith('/data/') || cacheKey.startsWith('/images/')) {
|
||||||
// ignore query params
|
// ignore query params
|
||||||
} else {
|
} else {
|
||||||
cacheKey = event.request.url;
|
cacheKey = event.request.url;
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
// Moved from project root to scripts directory for consistency
|
// Moved from project root to scripts directory for consistency
|
||||||
// Node.js script to generate a list of all files in public, logos, and logos_gen for PWA caching
|
// Node.js script to generate a list of all files in public and images for PWA caching
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
|
|
||||||
const projectRoot = path.join(__dirname, '..');
|
const projectRoot = path.join(__dirname, '..');
|
||||||
const publicDir = path.join(projectRoot, 'public');
|
const publicDir = path.join(projectRoot, 'public/images');
|
||||||
const logosDir = path.join(projectRoot, 'logos');
|
const logosDir = path.join(projectRoot, 'logos');
|
||||||
const logosGenDir = path.join(projectRoot, 'logos_gen');
|
const logosGenDir = path.join(projectRoot, 'logos_variants');
|
||||||
|
|
||||||
// List of files to ignore
|
// List of files to ignore
|
||||||
const IGNORED_FILES = ['.DS_Store', 'CNAME', 'pwa-files-to-cache.json', '.gitignore'];
|
const IGNORED_FILES = ['.DS_Store', 'CNAME', 'pwa-files-to-cache.json', '.gitignore'];
|
||||||
@@ -33,7 +33,7 @@ function safeWalkDir(dir, baseUrl = '') {
|
|||||||
|
|
||||||
const publicFiles = walkDir(publicDir, '').filter(f => !f.endsWith('sw.js'));
|
const publicFiles = walkDir(publicDir, '').filter(f => !f.endsWith('sw.js'));
|
||||||
const logosFiles = safeWalkDir(logosDir, 'logos');
|
const logosFiles = safeWalkDir(logosDir, 'logos');
|
||||||
const logosGenFiles = safeWalkDir(logosGenDir, 'logos_gen');
|
const logosGenFiles = safeWalkDir(logosGenDir, 'logos_variants');
|
||||||
|
|
||||||
const allFiles = Array.from(new Set([...publicFiles, ...logosFiles, ...logosGenFiles]));
|
const allFiles = Array.from(new Set([...publicFiles, ...logosFiles, ...logosGenFiles]));
|
||||||
|
|
||||||
|
|||||||
@@ -6,12 +6,12 @@ const path = require('path');
|
|||||||
const collections = [
|
const collections = [
|
||||||
{ name: 'logos', label: 'Logos',
|
{ name: 'logos', label: 'Logos',
|
||||||
baseDir: 'logos',
|
baseDir: 'logos',
|
||||||
genDir: 'logos_gen',
|
genDir: 'logos_variants',
|
||||||
dataFile: 'data/logos.json'
|
dataFile: 'data/logos.json'
|
||||||
},
|
},
|
||||||
{ name: 'flags', label: 'Flags',
|
{ name: 'flags', label: 'Flags',
|
||||||
baseDir: 'flags',
|
baseDir: 'flags',
|
||||||
genDir: 'flags_gen',
|
genDir: 'flags_variants',
|
||||||
dataFile: 'data/flags.json'
|
dataFile: 'data/flags.json'
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|||||||
@@ -126,15 +126,16 @@ function scanLogos() {
|
|||||||
/\.(svg|png|jpg|jpeg)$/i.test(file)
|
/\.(svg|png|jpg|jpeg)$/i.test(file)
|
||||||
);
|
);
|
||||||
|
|
||||||
console.log(`Found ${logoFiles.length} logo files`);
|
|
||||||
|
|
||||||
// Create a Set of all logo paths in the directory
|
// Create a Set of all logo paths in the directory
|
||||||
const logoPathsSet = new Set(logoFiles.map(file => `logos/${file}`));
|
const logoPathsSet = new Set(logoFiles.map(file => `${collection.baseDir}/${file}`));
|
||||||
|
|
||||||
// Mark existing records as disabled if they are not found in the directory
|
// Mark existing records as disabled if they are not found in the directory
|
||||||
for (const logo of existing) {
|
for (const logo of existing) {
|
||||||
if (!logoPathsSet.has(logo.path)) {
|
if (!logoPathsSet.has(logo.path)) {
|
||||||
logo.disable = true;
|
logo.disable = true;
|
||||||
|
} else if (logo.disable) {
|
||||||
|
// If file exists, re-enable if previously disabled
|
||||||
|
logo.disable = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -143,85 +144,22 @@ function scanLogos() {
|
|||||||
|
|
||||||
// Create new minimal logo objects for files that don't have records yet
|
// Create new minimal logo objects for files that don't have records yet
|
||||||
const newLogos = logoFiles
|
const newLogos = logoFiles
|
||||||
.filter(file => !existingPathsSet.has(`logos/${file}`))
|
.filter(file => !existingPathsSet.has(`${collection.baseDir}/${file}`))
|
||||||
.map(file => {
|
.map(file => {
|
||||||
const format = getFileExtension(file);
|
const format = getFileExtension(file);
|
||||||
const logoPath = `logos/${file}`;
|
const logoPath = `${collection.baseDir}/${file}`;
|
||||||
|
// Only add minimal fields for new files
|
||||||
// Create minimal object for new logos - just the essential fields
|
|
||||||
return {
|
return {
|
||||||
name: formatName(file),
|
name: formatName(file),
|
||||||
path: logoPath,
|
path: logoPath,
|
||||||
format: format,
|
format: format,
|
||||||
disable: false,
|
disable: false
|
||||||
brand: formatName(file)
|
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
.sort((a, b) => a.name.localeCompare(b.name));
|
.sort((a, b) => a.name.localeCompare(b.name));
|
||||||
|
|
||||||
// Merge existing and new logos
|
// Merge existing and new logos (add new at the end)
|
||||||
let merged = [...existing];
|
let merged = [...existing, ...newLogos];
|
||||||
|
|
||||||
// Add new logos in alphabetical order
|
|
||||||
for (const newLogo of newLogos) {
|
|
||||||
// Find the position to insert based on name
|
|
||||||
let insertIdx = merged.findIndex(l => newLogo.name.localeCompare(l.name) < 0);
|
|
||||||
if (insertIdx === -1) {
|
|
||||||
merged.push(newLogo);
|
|
||||||
} else {
|
|
||||||
merged.splice(insertIdx, 0, newLogo);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Force-upgrade SVGs with older colorConfig format to the new targets+sets format
|
|
||||||
// but ONLY if they have colors and either a target or selector defined
|
|
||||||
// Don't add empty objects to logos that don't need them
|
|
||||||
for (const logoObj of merged) {
|
|
||||||
// Only proceed if this is an SVG with existing color info that needs upgrading
|
|
||||||
if (logoObj.format?.toLowerCase() === 'svg' &&
|
|
||||||
logoObj.colors &&
|
|
||||||
Object.keys(logoObj.colors).length > 0 &&
|
|
||||||
logoObj.colorConfig &&
|
|
||||||
!logoObj.sets) {
|
|
||||||
|
|
||||||
// Initialize targets only if needed
|
|
||||||
if (!logoObj.targets) {
|
|
||||||
logoObj.targets = {};
|
|
||||||
|
|
||||||
if (logoObj.colorConfig.selector) {
|
|
||||||
// Split multiple selectors (e.g., "#text, #logo_int")
|
|
||||||
const selectors = logoObj.colorConfig.selector.split(',').map(s => s.trim());
|
|
||||||
|
|
||||||
// Create a target for each selector
|
|
||||||
selectors.forEach((selector, index) => {
|
|
||||||
logoObj.targets[`selector_${index + 1}`] = selector;
|
|
||||||
});
|
|
||||||
} else if (logoObj.colorConfig.target) {
|
|
||||||
logoObj.targets.main = logoObj.colorConfig.target;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize sets only if we have both colors and targets
|
|
||||||
if (logoObj.targets && Object.keys(logoObj.targets).length > 0) {
|
|
||||||
logoObj.sets = {};
|
|
||||||
let setIndex = 1;
|
|
||||||
|
|
||||||
// Create a set for each color
|
|
||||||
for (const [colorName, colorValue] of Object.entries(logoObj.colors)) {
|
|
||||||
const setName = `set_${setIndex}`;
|
|
||||||
logoObj.sets[setName] = {};
|
|
||||||
|
|
||||||
// Apply this color to all targets
|
|
||||||
Object.keys(logoObj.targets).forEach(targetName => {
|
|
||||||
logoObj.sets[setName][targetName] = colorName;
|
|
||||||
});
|
|
||||||
|
|
||||||
setIndex++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return merged;
|
return merged;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error('Error scanning logos directory:', error);
|
console.error('Error scanning logos directory:', error);
|
||||||
@@ -252,102 +190,47 @@ function main() {
|
|||||||
fs.mkdirSync(logosDir, { recursive: true });
|
fs.mkdirSync(logosDir, { recursive: true });
|
||||||
}
|
}
|
||||||
const files = fs.readdirSync(logosDir);
|
const files = fs.readdirSync(logosDir);
|
||||||
const logos = (function scanLogosForCol() {
|
// Only update/disable/add, do not overwrite existing keys
|
||||||
let existing = [];
|
let existing = [];
|
||||||
if (fs.existsSync(outputFile)) {
|
if (fs.existsSync(outputFile)) {
|
||||||
try {
|
|
||||||
existing = JSON.parse(fs.readFileSync(outputFile, 'utf8'));
|
|
||||||
} catch (e) {
|
|
||||||
console.error('Could not parse existing', col.dataFile + ':', e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
try {
|
try {
|
||||||
if (!fs.existsSync(logosDir)) {
|
existing = JSON.parse(fs.readFileSync(outputFile, 'utf8'));
|
||||||
console.error(`Directory does not exist: ${logosDir}`);
|
} catch (e) {
|
||||||
return [];
|
console.error('Could not parse existing', col.dataFile + ':', e);
|
||||||
}
|
|
||||||
// Filter for image files (svg, png, jpg, jpeg)
|
|
||||||
const logoFiles = files.filter(file =>
|
|
||||||
/\.(svg|png|jpg|jpeg)$/i.test(file)
|
|
||||||
);
|
|
||||||
// Create a Set of all logo paths in the directory
|
|
||||||
const logoPathsSet = new Set(logoFiles.map(file => `${col.baseDir}/${file}`));
|
|
||||||
// Mark existing records as disabled if they are not found in the directory
|
|
||||||
for (const logo of existing) {
|
|
||||||
if (!logoPathsSet.has(logo.path)) {
|
|
||||||
logo.disable = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Create a Set of existing paths to avoid duplication
|
|
||||||
const existingPathsSet = new Set(existing.map(logo => logo.path));
|
|
||||||
// Create new minimal logo objects for files that don't have records yet
|
|
||||||
const newLogos = logoFiles
|
|
||||||
.filter(file => !existingPathsSet.has(`${col.baseDir}/${file}`))
|
|
||||||
.map(file => {
|
|
||||||
const format = getFileExtension(file);
|
|
||||||
const logoPath = `${col.baseDir}/${file}`;
|
|
||||||
return {
|
|
||||||
name: formatName(file),
|
|
||||||
path: logoPath,
|
|
||||||
format: format,
|
|
||||||
disable: false,
|
|
||||||
brand: formatName(file)
|
|
||||||
};
|
|
||||||
})
|
|
||||||
.sort((a, b) => a.name.localeCompare(b.name));
|
|
||||||
let merged = [...existing];
|
|
||||||
for (const newLogo of newLogos) {
|
|
||||||
let insertIdx = merged.findIndex(l => newLogo.name.localeCompare(l.name) < 0);
|
|
||||||
if (insertIdx === -1) {
|
|
||||||
merged.push(newLogo);
|
|
||||||
} else {
|
|
||||||
merged.splice(insertIdx, 0, newLogo);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (const logoObj of merged) {
|
|
||||||
if (logoObj.format?.toLowerCase() === 'svg' &&
|
|
||||||
logoObj.colors &&
|
|
||||||
Object.keys(logoObj.colors).length > 0 &&
|
|
||||||
logoObj.colorConfig &&
|
|
||||||
!logoObj.sets) {
|
|
||||||
if (!logoObj.targets) {
|
|
||||||
logoObj.targets = {};
|
|
||||||
if (logoObj.colorConfig.selector) {
|
|
||||||
const selectors = logoObj.colorConfig.selector.split(',').map(s => s.trim());
|
|
||||||
selectors.forEach((selector, index) => {
|
|
||||||
logoObj.targets[`selector_${index + 1}`] = selector;
|
|
||||||
});
|
|
||||||
} else if (logoObj.colorConfig.target) {
|
|
||||||
logoObj.targets.main = logoObj.colorConfig.target;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (logoObj.targets && Object.keys(logoObj.targets).length > 0) {
|
|
||||||
logoObj.sets = {};
|
|
||||||
let setIndex = 1;
|
|
||||||
for (const [colorName, colorValue] of Object.entries(logoObj.colors)) {
|
|
||||||
const setName = `set_${setIndex}`;
|
|
||||||
logoObj.sets[setName] = {};
|
|
||||||
Object.keys(logoObj.targets).forEach(targetName => {
|
|
||||||
logoObj.sets[setName][targetName] = colorName;
|
|
||||||
});
|
|
||||||
setIndex++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return merged;
|
|
||||||
} catch (error) {
|
|
||||||
console.error('Error scanning directory:', logosDir, error);
|
|
||||||
return [];
|
|
||||||
}
|
}
|
||||||
})();
|
}
|
||||||
// Pregenerate PNG/JPG for all SVGs
|
// Filter for image files (svg, png, jpg, jpeg)
|
||||||
|
const logoFiles = files.filter(file =>
|
||||||
|
/\.(svg|png|jpg|jpeg)$/i.test(file)
|
||||||
|
);
|
||||||
|
const logoPathsSet = new Set(logoFiles.map(file => `${col.baseDir}/${file}`));
|
||||||
|
for (const logo of existing) {
|
||||||
|
if (!logoPathsSet.has(logo.path)) {
|
||||||
|
logo.disable = true;
|
||||||
|
} else if (logo.disable) {
|
||||||
|
logo.disable = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const existingPathsSet = new Set(existing.map(logo => logo.path));
|
||||||
|
const newLogos = logoFiles
|
||||||
|
.filter(file => !existingPathsSet.has(`${col.baseDir}/${file}`))
|
||||||
|
.map(file => {
|
||||||
|
const format = getFileExtension(file);
|
||||||
|
const logoPath = `${col.baseDir}/${file}`;
|
||||||
|
return {
|
||||||
|
name: formatName(file),
|
||||||
|
path: logoPath,
|
||||||
|
format: format,
|
||||||
|
disable: false
|
||||||
|
};
|
||||||
|
})
|
||||||
|
.sort((a, b) => a.name.localeCompare(b.name));
|
||||||
|
let merged = [...existing, ...newLogos];
|
||||||
pregenerateImages(files, logosDir, genDir);
|
pregenerateImages(files, logosDir, genDir);
|
||||||
// Save to JSON
|
|
||||||
try {
|
try {
|
||||||
const data = JSON.stringify(logos, null, 2);
|
const data = JSON.stringify(merged, null, 2);
|
||||||
fs.writeFileSync(outputFile, data);
|
fs.writeFileSync(outputFile, data);
|
||||||
console.log(`Successfully wrote ${logos.length} items to ${outputFile}`);
|
console.log(`Successfully wrote ${merged.length} items to ${outputFile}`);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error('Error writing data to file:', outputFile, error);
|
console.error('Error writing data to file:', outputFile, error);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,16 +3,23 @@ export const collections = [
|
|||||||
{
|
{
|
||||||
name: 'logos',
|
name: 'logos',
|
||||||
label: 'Logos',
|
label: 'Logos',
|
||||||
baseDir: 'logos',
|
baseDir: 'images/logos',
|
||||||
genDir: 'logos_gen',
|
genDir: 'images/logos_variants',
|
||||||
dataFile: 'data/logos.json'
|
dataFile: 'data/logos.json'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'flags',
|
name: 'flags',
|
||||||
label: 'Flags',
|
label: 'Flags',
|
||||||
baseDir: 'flags',
|
baseDir: 'images/flags',
|
||||||
genDir: 'flags_gen',
|
genDir: 'images/flags_variants',
|
||||||
dataFile: 'data/flags.json'
|
dataFile: 'data/flags.json'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'emblems',
|
||||||
|
label: 'Emblems',
|
||||||
|
baseDir: 'images/emblems',
|
||||||
|
genDir: 'images/emblems_variants',
|
||||||
|
dataFile: 'data/emblems.json'
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
if (typeof module !== 'undefined' && module.exports) {
|
if (typeof module !== 'undefined' && module.exports) {
|
||||||
|
|||||||
Reference in New Issue
Block a user