201 lines
10 KiB
HTML
201 lines
10 KiB
HTML
<!doctype html>
|
||
<html lang="ru">
|
||
<head>
|
||
<meta charset="utf-8" />
|
||
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
||
<title>Корзина | Книжный интернет-магазин "Тома"</title>
|
||
<!-- Bootstrap CSS -->
|
||
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" rel="stylesheet" />
|
||
<!-- Bootstrap Icons -->
|
||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.1/font/bootstrap-icons.css" />
|
||
<!-- Ваш CSS -->
|
||
<link rel="stylesheet" href="style.css" />
|
||
</head>
|
||
<body>
|
||
<!-- Навигация -->
|
||
<nav class="navbar navbar-expand-lg navbar-light bg-light fixed-top shadow-sm">
|
||
<div class="container">
|
||
<a class="navbar-brand d-flex align-items-center" href="index.html">
|
||
<img src="logo.png" alt="Логотип" class="logo me-2" />
|
||
<span class="d-none d-lg-block">Книжный магазин "Тома"</span>
|
||
<span class="d-lg-none">"Тома"</span>
|
||
</a>
|
||
|
||
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarContent">
|
||
<span class="navbar-toggler-icon"></span>
|
||
</button>
|
||
|
||
<div class="collapse navbar-collapse" id="navbarContent">
|
||
<ul class="navbar-nav ms-auto">
|
||
<li class="nav-item dropdown">
|
||
<a
|
||
class="nav-link dropdown-toggle"
|
||
href="#"
|
||
id="navbarDropdown"
|
||
role="button"
|
||
data-bs-toggle="dropdown"
|
||
aria-expanded="false"
|
||
>
|
||
Страницы
|
||
</a>
|
||
<ul class="dropdown-menu" aria-labelledby="navbarDropdown">
|
||
<li><a class="dropdown-item" href="index.html">Главная</a></li>
|
||
<li><a class="dropdown-item" href="catalog.html">Каталог</a></li>
|
||
<li><a class="dropdown-item" href="discounts.html">Скидки</a></li>
|
||
<li><a class="dropdown-item" href="basket.html">Корзина</a></li>
|
||
<li><a class="dropdown-item" href="contactUs.html">Контакты</a></li>
|
||
</ul>
|
||
</li>
|
||
<li class="nav-item">
|
||
<a class="nav-link position-relative show-cart-btn" href="#">
|
||
<i class="bi bi-cart3"></i>
|
||
<span
|
||
class="cart-count badge bg-danger rounded-pill position-absolute top-0 start-100 translate-middle"
|
||
style="display: none"
|
||
></span>
|
||
</a>
|
||
</li>
|
||
</ul>
|
||
</div>
|
||
</div>
|
||
</nav>
|
||
|
||
<!-- Основной контент -->
|
||
<main class="container mt-5 pt-5">
|
||
<div class="row justify-content-center">
|
||
<div class="col-lg-10">
|
||
<h2 class="text-center mb-4">Ваша корзина</h2>
|
||
|
||
<!-- Список товаров -->
|
||
<div id="cartItemsContainer">
|
||
<!-- Товары будут загружены через JavaScript -->
|
||
</div>
|
||
|
||
<!-- Итоговая информация -->
|
||
<div class="card mb-4 border-danger">
|
||
<div class="card-body">
|
||
<div class="d-flex justify-content-between align-items-center">
|
||
<h4 class="mb-0">Общая стоимость:</h4>
|
||
<h4 class="mb-0" id="cartTotal">0 руб.</h4>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<!-- Кнопки действий -->
|
||
<div class="d-flex justify-content-between mb-5">
|
||
<a href="catalog.html" class="btn btn-outline-primary">
|
||
<i class="bi bi-arrow-left me-2"></i>Продолжить покупки
|
||
</a>
|
||
<div>
|
||
<button id="clearCartBtn" class="btn btn-outline-danger me-2">
|
||
<i class="bi bi-trash me-2"></i>Очистить корзину
|
||
</button>
|
||
<button id="checkoutBtn" class="btn btn-success btn-lg px-4">
|
||
<i class="bi bi-credit-card me-2"></i>Оформить заказ
|
||
</button>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</main>
|
||
|
||
<!-- Подвал -->
|
||
<footer class="bg-light py-4 mt-5">
|
||
<div class="container">
|
||
<div class="row">
|
||
<div class="col-md-6 mb-4 mb-md-0">
|
||
<h5 class="mb-3">Контакты</h5>
|
||
<ul class="list-unstyled">
|
||
<li><i class="bi bi-envelope me-2"></i> info@toma.ru</li>
|
||
<li><i class="bi bi-phone me-2"></i> +7 (123) 456-78-90</li>
|
||
<li><i class="bi bi-clock me-2"></i> Пн-Пт 9:00-18:00</li>
|
||
<li><i class="bi bi-geo-alt me-2"></i> г. Москва, ул. Литераторов, д. 1</li>
|
||
</ul>
|
||
</div>
|
||
|
||
<div class="col-md-6 text-md-end">
|
||
<h5 class="mb-3">Социальные сети</h5>
|
||
<div class="social-media">
|
||
<a href="#" class="text-decoration-none me-3"><i class="bi bi-facebook fs-3"></i></a>
|
||
<a href="#" class="text-decoration-none me-3"><i class="bi bi-vk fs-3"></i></a>
|
||
<a href="#" class="text-decoration-none"><i class="bi bi-telegram fs-3"></i></a>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</footer>
|
||
|
||
<!-- Bootstrap JS -->
|
||
<script src="https://cdn.jsdelivr.net/npm/@popperjs/core@2.11.6/dist/umd/popper.min.js"></script>
|
||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.min.js"></script>
|
||
|
||
<!-- Наш компонент -->
|
||
<script src="bookComponent.js"></script>
|
||
|
||
<script>
|
||
// Инициализация корзины на странице basket.html
|
||
document.addEventListener("DOMContentLoaded", async () => {
|
||
const model = new BookModel();
|
||
const view = new BookView();
|
||
const controller = new BookController(model, view);
|
||
|
||
// Загружаем и отображаем корзину при загрузке страницы
|
||
const cartItems = await model.fetchCartItems();
|
||
view.renderCart(cartItems);
|
||
|
||
// Обновляем счетчик в навигации
|
||
await controller.updateCartCount();
|
||
|
||
// Обработчики для кнопок на странице корзины
|
||
document.getElementById("clearCartBtn").addEventListener("click", async () => {
|
||
if (confirm("Вы уверены, что хотите очистить корзину?")) {
|
||
await model.clearCart();
|
||
view.renderCart([]);
|
||
await controller.updateCartCount();
|
||
}
|
||
});
|
||
|
||
document.getElementById("checkoutBtn").addEventListener("click", () => {
|
||
alert("Заказ оформлен! Спасибо за покупку!");
|
||
model.clearCart();
|
||
view.renderCart([]);
|
||
controller.updateCartCount();
|
||
});
|
||
|
||
// Обработчик изменения количества товаров
|
||
document.addEventListener("change", async (event) => {
|
||
if (event.target.classList.contains("cart-item-quantity")) {
|
||
const id = parseInt(event.target.dataset.id);
|
||
const quantity = parseInt(event.target.value);
|
||
|
||
if (quantity > 0) {
|
||
await model.updateCartItem(id, { quantity });
|
||
const cartItems = await model.fetchCartItems();
|
||
view.renderCart(cartItems);
|
||
await controller.updateCartCount();
|
||
} else {
|
||
event.target.value = 1;
|
||
}
|
||
}
|
||
});
|
||
|
||
// Обработчик удаления товаров
|
||
document.addEventListener("click", async (event) => {
|
||
if (
|
||
event.target.classList.contains("remove-from-cart") ||
|
||
event.target.closest(".remove-from-cart")
|
||
) {
|
||
const id = parseInt(
|
||
event.target.dataset.id || event.target.closest(".remove-from-cart").dataset.id
|
||
);
|
||
await model.removeFromCart(id);
|
||
const cartItems = await model.fetchCartItems();
|
||
view.renderCart(cartItems);
|
||
await controller.updateCartCount();
|
||
}
|
||
});
|
||
});
|
||
</script>
|
||
</body>
|
||
</html>
|