📌 Contenido de esta Guía - PARTE 2
Esta es la continuación de la PARTE 1. Aquí encontrarás:
- ✅ Todos los templates HTML (base, dashboard, crear, editar, listar, etc.)
- ✅ Código completo de views.py con todas las funciones
- ✅ Configuración completa de urls.py
- ✅ Código de models.py con el modelo Libro
- ✅ Código de admin.py personalizado
- ✅ Utilidades de MongoDB (mongo_utils.py)
- ✅ Scripts auxiliares y configuraciones finales
📄 SECCIÓN 9: TEMPLATES HTML COMPLETOS
📂 Estructura de Carpetas para Templates:
biblioteca_project/
└── biblioteca/
└── templates/
└── biblioteca/
├── base.html
├── inicio.html
├── dashboard.html
├── listar_libros.html
├── crear_libro.html
├── editar_libro.html
├── detalle_libro.html
├── confirmar_eliminacion.html
└── estadisticas.html
9.1 Template Base (base.html)
📄 biblioteca/templates/biblioteca/base.html
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>{% block title %}Sistema Biblioteca{% endblock %}</title>
<!-- Bootstrap CSS -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
<!-- Chart.js para gráficas -->
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
<style>
:root {
--primary-color: #f093fb;
--secondary-color: #f5576c;
--dark-color: #2c3e50;
--light-bg: #f8f9fa;
}
body {
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);
min-height: 100vh;
}
.navbar {
background: linear-gradient(90deg, var(--primary-color), var(--secondary-color)) !important;
box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}
.navbar-brand {
font-weight: bold;
font-size: 1.5em;
}
.main-container {
background: white;
border-radius: 15px;
box-shadow: 0 10px 30px rgba(0,0,0,0.2);
margin: 30px auto;
padding: 40px;
max-width: 1200px;
}
.card {
border: none;
border-radius: 12px;
box-shadow: 0 4px 12px rgba(0,0,0,0.1);
transition: transform 0.3s;
}
.card:hover {
transform: translateY(-5px);
box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}
.btn-primary {
background: linear-gradient(90deg, var(--primary-color), var(--secondary-color));
border: none;
padding: 10px 25px;
border-radius: 8px;
font-weight: 600;
transition: 0.3s;
}
.btn-primary:hover {
transform: scale(1.05);
box-shadow: 0 5px 15px rgba(240, 147, 251, 0.4);
}
footer {
background: var(--dark-color);
color: white;
padding: 30px 0;
margin-top: 50px;
text-align: center;
}
</style>
{% block extra_css %}{% endblock %}
</head>
<body>
<!-- Navbar -->
<nav class="navbar navbar-expand-lg navbar-dark">
<div class="container-fluid">
<a class="navbar-brand" href="{% url 'inicio' %}">
📚 Biblioteca UTH
</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarNav">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarNav">
<ul class="navbar-nav ms-auto">
<li class="nav-item">
<a class="nav-link" href="{% url 'inicio' %}">🏠 Inicio</a>
</li>
<li class="nav-item">
<a class="nav-link" href="{% url 'listar_libros' %}">📖 Catálogo</a>
</li>
<li class="nav-item">
<a class="nav-link" href="{% url 'crear_libro' %}">➕ Agregar Libro</a>
</li>
<li class="nav-item">
<a class="nav-link" href="{% url 'estadisticas' %}">📊 Estadísticas</a>
</li>
</ul>
</div>
</div>
</nav>
<!-- Mensajes de Django -->
{% if messages %}
<div class="container mt-4">
{% for message in messages %}
<div class="alert alert-{{ message.tags }} alert-dismissible fade show" role="alert">
{{ message }}
<button type="button" class="btn-close" data-bs-dismiss="alert"></button>
</div>
{% endfor %}
</div>
{% endif %}
<!-- Contenido principal -->
<div class="main-container">
{% block content %}{% endblock %}
</div>
<!-- Footer -->
<footer>
<div class="container">
<p><strong>Universidad Tecnológica de Hermosillo</strong></p>
<p>Sistema Híbrido de Biblioteca - MySQL + MongoDB</p>
<p style="opacity: 0.7; margin-top: 15px;">© 2026 UTH - Servicios Web</p>
</div>
</footer>
<!-- Bootstrap JS -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>
{% block extra_js %}{% endblock %}
</body>
</html>