Files
PIBD-23_Ivanov.D.A._Interne…/MyWebSite/basket.html
2025-05-14 14:22:49 +04:00

201 lines
10 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<!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>