Fix Nginx y Boostrap

This commit is contained in:
2025-09-03 14:05:06 -03:00
parent a81f1fe894
commit 36a004a0b0
2 changed files with 37 additions and 25 deletions

View File

@@ -1,8 +1,9 @@
// public/bootstrap.js
(function() {
// --- CONFIGURACIÓN ---
// Cambie esto por el dominio final en producción
const WIDGETS_HOST = 'https://elecciones2025.eldia.com';
// --- LÓGICA DE DETECCIÓN AUTOMÁTICA DE LA RUTA BASE ---
// document.currentScript.src nos da la URL completa del propio script bootstrap.js
const scriptUrl = new URL(document.currentScript.src);
// La ruta base es el origen (ej. 'https://elecciones2025.eldia.com')
const WIDGETS_HOST = scriptUrl.origin;
// --- FUNCIONES AUXILIARES (sin cambios) ---
function loadScript(src) {
@@ -26,21 +27,23 @@
// --- LÓGICA PRINCIPAL ---
async function initWidgets() {
try {
// 1. Obtener el manifest.json
// 1. Obtener el manifest.json desde la ruta base detectada
const response = await fetch(`${WIDGETS_HOST}/manifest.json`);
if (!response.ok) throw new Error('No se pudo cargar el manifest.');
if (!response.ok) {
throw new Error('No se pudo cargar el manifest de los widgets. (404 Not Found)');
}
const manifest = await response.json();
// 2. Encontrar el punto de entrada principal (nuestro main.tsx)
// En modo 'lib', la entrada es el propio archivo de entrada.
const entryKey = 'src/main.tsx';
const entry = manifest[entryKey];
if (!entry) throw new Error('No se encontró el punto de entrada en el manifest.');
// 2. Encontrar el punto de entrada principal
const entryKey = Object.keys(manifest).find(key => manifest[key].isEntry);
if (!entryKey) {
throw new Error('No se encontró el punto de entrada en el manifest.');
}
const entry = manifest[entryKey];
const jsUrl = `${WIDGETS_HOST}/${entry.file}`;
// 3. Cargar el CSS asociado, si existe
// 3. Cargar el CSS
if (entry.css && entry.css.length > 0) {
entry.css.forEach(cssFile => {
const cssUrl = `${WIDGETS_HOST}/${cssFile}`;
@@ -48,14 +51,13 @@
});
}
// 4. Cargar el script principal de la librería
// 4. Cargar el JS principal
await loadScript(jsUrl);
// 5. Esperar a que la página esté completamente cargada
// y luego llamar a la función de renderizado.
// 5. El addEventListener ya no es necesario aquí, el consumidor lo añade.
// Si quiere que sea totalmente automático, puede añadirlo:
window.addEventListener('load', function () {
if (window.EleccionesWidgets && typeof window.EleccionesWidgets.render === 'function') {
console.log('Elecciones Widgets listos. Renderizando...');
window.EleccionesWidgets.render();
}
});
@@ -65,7 +67,6 @@
}
}
// Iniciar el proceso
initWidgets();
})();