Files
nickpons666 48671dc88e Implementar tema claro/oscuro con Bootstrap 5
- Agregar atributo data-bs-theme al HTML
- Implementar botón toggle con íconos sol/luna en navegación
- Agregar estilos CSS para modo oscuro (variables, componentes, tablas)
- Implementar JavaScript para funcionalidad toggle con persistencia localStorage
- Agregar detección automática del tema del sistema
- Fix específico para columna "Contenido (Previo)" en sent_messages.php
- Mejorar Content Security Policy para archivos .map de Bootstrap
- Configuración de entorno automática para .env.pruebas

Características:
- Toggle claro/oscuro con persistencia
- Detección automática de preferencias del sistema
- Estilos personalizados para componentes en modo oscuro
- Compatibilidad con todas las páginas del sistema
2026-01-17 16:13:19 -06:00

151 lines
9.5 KiB
PHP
Executable File

<?php
// Incluir los helpers necesarios
require_once __DIR__ . '/../includes/url_helper.php';
require_once __DIR__ . '/../includes/translation_helper.php';
// Inicializar el idioma de la sesión si no está definido
if (!isset($_SESSION['language'])) {
$_SESSION['language'] = 'es'; // Idioma por defecto
}
?>
<!DOCTYPE html>
<html lang="es" data-bs-theme="light">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Bot Discord</title>
<!-- Bootstrap CSS -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-T3c6CoIi6uLrA9TneNEoa7RxnatzjcDSCmG1MXxSR1GAsXEV/Dwwykc2MPK8M2HN" crossorigin="anonymous">
<!-- Bootstrap Icons -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css" rel="stylesheet">
<!-- Estilos personalizados -->
<link rel="stylesheet" href="<?php echo asset('css/style.css'); ?>" type="text/css">
<!-- Contenido extra del head (opcional) -->
<?php if (isset($extraHead)) echo $extraHead; ?>
</head>
<body>
<!-- Top Navigation Bar -->
<nav class="navbar navbar-expand-lg navbar-dark bg-dark border-bottom">
<div class="container-fluid">
<!-- Logo y nombre -->
<a class="navbar-brand d-flex align-items-center" href="<?php echo site_url('index.php'); ?>">
<img src="<?php echo asset('images/logo.png'); ?>" alt="Logo" style="height: 30px; margin-right: 10px;">
<strong>Bot Discord</strong>
</a>
<!-- Toggle button para móvil -->
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarMenu" aria-controls="navbarMenu" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<!-- Menu items -->
<div class="collapse navbar-collapse" id="navbarMenu">
<ul class="navbar-nav me-auto">
<!-- Inicio -->
<li class="nav-item">
<a class="nav-link" href="<?php echo site_url('index.php'); ?>" data-translate="true">
<i class="bi bi-house-door-fill me-1"></i>Inicio
</a>
</li>
<!-- Mensajes -->
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navMensajes" role="button" data-bs-toggle="dropdown" aria-expanded="false" data-translate="true">
<i class="bi bi-chat-dots-fill me-1"></i>Mensajes
</a>
<ul class="dropdown-menu" aria-labelledby="navMensajes">
<li><a class="dropdown-item" href="<?php echo site_url('create_message.php'); ?>" data-translate="true"><i class="bi bi-plus-square-fill me-2"></i>Crear Mensaje</a></li>
<li><a class="dropdown-item" href="<?php echo site_url('scheduled_messages.php'); ?>" data-translate="true"><i class="bi bi-clock-fill me-2"></i>Programados</a></li>
<li><a class="dropdown-item" href="<?php echo site_url('recurrentes.php'); ?>" data-translate="true"><i class="bi bi-arrow-repeat me-2"></i>Plantillas</a></li>
<li><a class="dropdown-item" href="<?php echo site_url('sent_messages.php'); ?>" data-translate="true"><i class="bi bi-send-fill me-2"></i>Enviados</a></li>
</ul>
</li>
<!-- Recursos -->
<li class="nav-item">
<a class="nav-link" href="<?php echo site_url('gallery.php'); ?>" data-translate="true">
<i class="bi bi-images me-1"></i>Galería
</a>
</li>
<!-- Admin (solo si es admin) -->
<?php if ($_SESSION['role'] === 'admin'): ?>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navAdmin" role="button" data-bs-toggle="dropdown" aria-expanded="false" data-translate="true">
<i class="bi bi-gear-fill me-1"></i>Admin
</a>
<ul class="dropdown-menu" aria-labelledby="navAdmin">
<li><h6 class="dropdown-header">Gestión</h6></li>
<li><a class="dropdown-item" href="<?php echo site_url('admin/users.php'); ?>" data-translate="true"><i class="bi bi-people-fill me-2"></i>Usuarios</a></li>
<li><a class="dropdown-item" href="<?php echo site_url('admin/recipients.php'); ?>" data-translate="true"><i class="bi bi-person-rolodex me-2"></i>Destinatarios</a></li>
<li><hr class="dropdown-divider"></li>
<li><h6 class="dropdown-header">Configuración</h6></li>
<li><a class="dropdown-item" href="<?php echo site_url('admin/languages.php'); ?>" data-translate="true"><i class="bi bi-translate me-2"></i>Idiomas</a></li>
<li><a class="dropdown-item" href="<?php echo site_url('admin/comandos.php'); ?>" data-translate="true"><i class="bi bi-terminal-fill me-2"></i>Comandos</a></li>
<li><hr class="dropdown-divider"></li>
<li><h6 class="dropdown-header">Bots</h6></li>
<li><a class="dropdown-item" href="<?php echo site_url('telegram/admin/telegram_welcome.php'); ?>" data-translate="true"><i class="bi bi-telegram me-2"></i>Telegram Config</a></li>
<li><a class="dropdown-item" href="<?php echo site_url('telegram/admin/telegram_bot_interactions.php'); ?>" data-translate="true"><i class="bi bi-robot me-2"></i>Interacciones Bot</a></li>
<li><a class="dropdown-item" href="<?php echo site_url('telegram/admin/chat_telegram.php'); ?>" data-translate="true"><i class="bi bi-chat-dots-fill me-2"></i>Chat Telegram</a></li>
<li><hr class="dropdown-divider"></li>
<li><h6 class="dropdown-header">Monitoreo</h6></li>
<li><a class="dropdown-item" href="<?php echo site_url('admin/activity.php'); ?>" data-translate="true"><i class="bi bi-clipboard-data-fill me-2"></i>Actividad</a></li>
<li><a class="dropdown-item" href="<?php echo site_url('admin/test_discord_connection.php'); ?>" data-translate="true"><i class="bi bi-bug-fill me-2"></i>Test</a></li>
</ul>
</li>
<?php endif; ?>
<!-- User menu -->
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navUser" role="button" data-bs-toggle="dropdown" aria-expanded="false" style="cursor: pointer;">
<i class="bi bi-person-circle me-1"></i><?php echo htmlspecialchars($_SESSION['username']); ?>
</a>
<ul class="dropdown-menu" aria-labelledby="navUser">
<li><a class="dropdown-item" href="<?php echo site_url('profile.php'); ?>" data-translate="true"><i class="bi bi-person-circle me-2"></i>Perfil</a></li>
<li><hr class="dropdown-divider"></li>
<li><a class="dropdown-item" href="<?php echo site_url('logout.php'); ?>" data-translate="true"><i class="bi bi-box-arrow-right me-2"></i>Cerrar Sesión</a></li>
</ul>
</li>
</ul>
<!-- Right side: Theme toggle, Language selector, DB info -->
<div class="d-flex align-items-center gap-2 flex-wrap ms-auto">
<!-- Theme Toggle -->
<button class="btn btn-sm theme-toggle-btn" id="theme-toggle" title="Cambiar tema" aria-label="Cambiar tema claro/oscuro">
<i class="bi bi-sun-fill" id="theme-icon"></i>
</button>
<select class="form-select form-select-sm w-auto" id="language-selector" style="max-width: 120px;">
<!-- Options will be populated by translate_frontend.js -->
</select>
<?php if ($_SESSION['role'] === 'admin'): ?>
<div class="card border-secondary bg-dark text-light" style="width: 150px; box-shadow: 0 2px 6px rgba(0,0,0,0.3); margin: 0; flex-shrink: 0;">
<div class="card-body p-1 text-center" style="font-size: 0.8rem;">
<div class="mb-1">
<i class="bi bi-database text-info" style="font-size: 14px;"></i>
</div>
<div class="mb-1">
<small class="text-muted d-block" style="font-size: 8px;">BASE DE DATOS</small>
<strong class="d-block text-light" style="font-size: 11px;"><?php echo htmlspecialchars(DB_NAME); ?></strong>
</div>
<hr class="my-1" style="margin: 0.3rem 0;">
<div>
<small class="text-muted d-block" style="font-size: 8px;">SERVIDOR</small>
<code class="text-info" style="font-size: 10px;"><?php echo htmlspecialchars(DB_HOST); ?>:<?php echo htmlspecialchars(DB_PORT); ?></code>
</div>
</div>
</div>
<?php endif; ?>
</div>
</div>
</div>
</nav>
<!-- Main Content -->
<div id="page-content-wrapper">
<main class="container-fluid p-4">
<!-- Conflicting language script removed -->