- Organizar 48 imágenes en public/assets/infografias/ por bloques - Adaptar MarkdownViewer para procesar rutas de imágenes automáticamente - Actualizar Service Worker para cachear imágenes (offline-first) - Configurar Vite para incluir imágenes en build - Crear documentación: guías de integración, sugerencias de medios, estado de imágenes - Scripts de organización automática de imágenes Cambios técnicos: - MarkdownViewer normaliza rutas de imágenes (relativas → absolutas) - Service Worker cachea /assets/infografias/ automáticamente - Vite config actualizado para mantener estructura de carpetas - 48 imágenes organizadas: bloque-0 (9), bloque-2 (27), bloque-3 (9), bloque-7 (1), bloque-12 (2) Documentación: - GUIA_INTEGRAR_IMAGENES_PWA.md - GUIA_RUTAS_IMAGENES_MARKDOWN.md - SUGERENCIAS_MEDIOS_VISUALES.md - IMAGENES_NECESARIAS.md - ESTADO_FINAL_IMAGENES_PWA.md - RESUMEN_ORGANIZACION_IMAGENES.md
86 lines
2.9 KiB
TypeScript
86 lines
2.9 KiB
TypeScript
import { defineConfig } from "vite";
|
|
import react from "@vitejs/plugin-react-swc";
|
|
import path from "path";
|
|
import { manifestPlugin } from "./vite-plugin-manifest";
|
|
|
|
// Detectar si estamos en GitHub Pages
|
|
// GitHub Pages usa el formato: https://username.github.io/repository-name/
|
|
const isGitHubPages = process.env.GITHUB_PAGES === 'true';
|
|
const repositoryName = process.env.GITHUB_REPOSITORY_NAME || 'guia-tes-digital';
|
|
const base = isGitHubPages ? `/${repositoryName}/` : '/';
|
|
|
|
// https://vitejs.dev/config/
|
|
export default defineConfig({
|
|
// Base path para GitHub Pages (necesario para rutas SPA)
|
|
base: base,
|
|
server: {
|
|
host: "::",
|
|
port: 8096,
|
|
fs: {
|
|
// Permitir acceso a archivos fuera del proyecto si es necesario
|
|
strict: true,
|
|
},
|
|
},
|
|
plugins: [
|
|
react(),
|
|
manifestPlugin(),
|
|
],
|
|
resolve: {
|
|
alias: {
|
|
"@": path.resolve(__dirname, "./src"),
|
|
},
|
|
},
|
|
// Configuración para procesar archivos .md e imágenes
|
|
assetsInclude: ["**/*.md", "**/*.png", "**/*.jpg", "**/*.jpeg", "**/*.svg", "**/*.gif"],
|
|
|
|
// Configuración de build para incluir archivos .md e imágenes
|
|
build: {
|
|
rollupOptions: {
|
|
// Asegurar que los archivos .md e imágenes se copien al build
|
|
output: {
|
|
assetFileNames: (assetInfo) => {
|
|
const name = assetInfo.name || '';
|
|
|
|
// Mantener estructura de carpetas para archivos .md en public/
|
|
if (name.endsWith('.md')) {
|
|
if (name.includes('manual')) {
|
|
return 'manual/[name][extname]';
|
|
}
|
|
return 'assets/[name]-[hash][extname]';
|
|
}
|
|
|
|
// Mantener estructura de carpetas para imágenes en public/assets/
|
|
if (name.match(/\.(png|jpg|jpeg|svg|gif)$/i)) {
|
|
// Si está en public/assets/infografias/, mantener estructura
|
|
if (assetInfo.source && typeof assetInfo.source === 'string') {
|
|
// Mantener estructura de carpetas para assets
|
|
if (assetInfo.source.includes('assets/infografias')) {
|
|
// Extraer ruta relativa desde public/
|
|
const relativePath = assetInfo.source.split('public/')[1] || name;
|
|
return relativePath;
|
|
}
|
|
}
|
|
return 'assets/[name]-[hash][extname]';
|
|
}
|
|
|
|
return 'assets/[name]-[hash][extname]';
|
|
},
|
|
},
|
|
},
|
|
// Incluir archivos .md e imágenes en el build
|
|
assetsInclude: ['**/*.md', '**/*.png', '**/*.jpg', '**/*.jpeg', '**/*.svg', '**/*.gif'],
|
|
// Copiar todo el directorio public/ a dist/ (incluye imágenes)
|
|
copyPublicDir: true,
|
|
},
|
|
// Configuración para PWA
|
|
// El service worker se copia automáticamente desde public/ con copyPublicDir
|
|
|
|
// Configuración para importar archivos .md como texto usando ?raw
|
|
// Ejemplo de uso:
|
|
// import content from './file.md?raw'
|
|
// Esto importará el contenido del archivo como string
|
|
optimizeDeps: {
|
|
exclude: [],
|
|
},
|
|
});
|