base.html 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <!DOCTYPE html>
  2. <html lang="es">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>Calculadora Solar</title>
  7. <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
  8. {% block head %}{% endblock %}
  9. <script>
  10. // Inicialización del tema
  11. const getStoredTheme = () => localStorage.getItem('theme');
  12. const getPreferredTheme = () => {
  13. const storedTheme = getStoredTheme();
  14. if (storedTheme) return storedTheme;
  15. return window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';
  16. };
  17. document.documentElement.setAttribute('data-bs-theme', getPreferredTheme());
  18. </script>
  19. </head>
  20. <body>
  21. <nav class="navbar navbar-expand-lg navbar-dark bg-primary mb-4">
  22. <div class="container">
  23. <a class="navbar-brand" href="{{ url_for('main.index') }}">Calculadora de Viabilidad para Sistemas Fotovoltaicos Residenciales</a>
  24. <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarNav">
  25. <span class="navbar-toggler-icon"></span>
  26. </button>
  27. <div class="collapse navbar-collapse" id="navbarNav">
  28. <ul class="navbar-nav ms-auto">
  29. <li class="nav-item">
  30. <a class="nav-link" href="{{ url_for('main.casas') }}">Casas</a>
  31. </li>
  32. <li class="nav-item">
  33. <a class="nav-link" href="{{ url_for('main.proyectos') }}">Proyectos</a>
  34. </li>
  35. <li class="nav-item">
  36. <a class="nav-link" href="{{ url_for('main.metodologia') }}">Cómo Funciona</a>
  37. </li>
  38. <li class="nav-item">
  39. <a class="nav-link" href="{{ url_for('main.configuracion') }}">Configuración</a>
  40. </li>
  41. {% if current_user.is_authenticated %}
  42. <li class="nav-item">
  43. <a class="nav-link" href="{{ url_for('main.admin') }}">Admin</a>
  44. </li>
  45. <li class="nav-item">
  46. <a class="nav-link" href="{{ url_for('main.logout') }}">Salir</a>
  47. </li>
  48. {% endif %}
  49. <li class="nav-item">
  50. <button class="btn nav-link" id="theme-toggle" title="Cambiar tema">
  51. 🌓
  52. </button>
  53. </li>
  54. </ul>
  55. </div>
  56. </div>
  57. </nav>
  58. <div class="container">
  59. {% block content %}{% endblock %}
  60. </div>
  61. <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>
  62. <script>
  63. document.getElementById('theme-toggle').addEventListener('click', () => {
  64. const currentTheme = document.documentElement.getAttribute('data-bs-theme');
  65. const newTheme = currentTheme === 'dark' ? 'light' : 'dark';
  66. document.documentElement.setAttribute('data-bs-theme', newTheme);
  67. localStorage.setItem('theme', newTheme);
  68. });
  69. </script>
  70. {% block scripts %}{% endblock %}
  71. </body>
  72. </html>