document.addEventListener('DOMContentLoaded', function () { const productForm = document.getElementById('productForm'); const productTable = document.getElementById('productTable').getElementsByTagName('tbody')[0]; const searchInput = document.getElementById('searchInput'); const cartTable = document.getElementById('cartTable').getElementsByTagName('tbody')[0]; const totalSoldElement = document.getElementById('totalSold'); const totalRevenueElement = document.getElementById('totalRevenue'); const totalProfitElement = document.getElementById('totalProfit'); let totalSold = 0; // Общее количество проданных товаров let totalRevenue = 0; // Общая выручка let totalProfit = 0; // Общая прибыль let cart = []; // Корзина // Загрузка данных из localStorage при загрузке страницы loadProducts(); loadStats(); loadCart(); // Обработка добавления товара productForm.addEventListener('submit', function (e) { e.preventDefault(); const productName = document.getElementById('productName').value; const purchasePrice = parseFloat(document.getElementById('purchasePrice').value); const salePrice = parseFloat(document.getElementById('salePrice').value); const quantity = parseInt(document.getElementById('quantity').value); const itemsPerPack = parseInt(document.getElementById('itemsPerPack').value); if (productName && !isNaN(purchasePrice) && !isNaN(salePrice) && !isNaN(quantity) && !isNaN(itemsPerPack)) { addProduct(productName, purchasePrice, salePrice, quantity, itemsPerPack); productForm.reset(); // Очистка формы после добавления } else { alert('Пожалуйста, заполните все поля корректно.'); } }); // Поиск по товарам searchInput.addEventListener('input', function () { const searchTerm = searchInput.value.toLowerCase(); const rows = productTable.getElementsByTagName('tr'); for (let row of rows) { const name = row.getElementsByTagName('td')[0]?.textContent.toLowerCase(); if (name) { row.style.display = name.includes(searchTerm) ? '' : 'none'; } } }); // Делегирование событий для кнопок в таблице товаров productTable.addEventListener('click', function (e) { const target = e.target; const row = target.closest('tr'); const productId = parseInt(row.getAttribute('data-id')); if (target.classList.contains('add-to-cart-btn')) { const quantityInput = row.querySelector('.quantity-input'); const quantity = parseInt(quantityInput.value); addToCart(productId, quantity); } else if (target.classList.contains('add-stock-btn')) { addStock(productId); } else if (target.classList.contains('delete-btn')) { deleteProduct(productId); } }); // Делегирование событий для кнопок в корзине cartTable.addEventListener('click', function (e) { const target = e.target; if (target.classList.contains('delete-btn')) { const row = target.closest('tr'); const productId = parseInt(row.getAttribute('data-id')); removeFromCart(productId); } }); // Функция добавления товара function addProduct(name, purchasePrice, salePrice, quantity, itemsPerPack) { const product = { id: Date.now(), // Уникальный ID на основе времени name, purchasePrice, salePrice, quantity, itemsPerPack }; // Получаем текущие товары из localStorage let products = JSON.parse(localStorage.getItem('products')) || []; products.push(product); // Добавляем новый товар localStorage.setItem('products', JSON.stringify(products)); // Сохраняем в localStorage // Добавляем товар в таблицу addProductToTable(product); } // Функция добавления товара в таблицу function addProductToTable(product) { const row = productTable.insertRow(); row.setAttribute('data-id', product.id); row.innerHTML = ` ${product.name} ${product.purchasePrice} ${product.salePrice} ${product.quantity} ${product.itemsPerPack} `; } // Функция загрузки товаров из localStorage function loadProducts() { const products = JSON.parse(localStorage.getItem('products')) || []; productTable.innerHTML = ''; // Очищаем таблицу перед загрузкой products.forEach(product => addProductToTable(product)); } // Функция загрузки статистики из localStorage function loadStats() { const stats = JSON.parse(localStorage.getItem('stats')) || { totalSold: 0, totalRevenue: 0, totalProfit: 0 }; totalSold = stats.totalSold; totalRevenue = stats.totalRevenue; totalProfit = stats.totalProfit; updateStatsDisplay(); } // Функция загрузки корзины из localStorage function loadCart() { cart = JSON.parse(localStorage.getItem('cart')) || []; updateCartDisplay(); } // Функция обновления отображения статистики function updateStatsDisplay() { totalSoldElement.textContent = totalSold; totalRevenueElement.textContent = totalRevenue.toFixed(2); totalProfitElement.textContent = totalProfit.toFixed(2); } // Функция обновления отображения корзины function updateCartDisplay() { cartTable.innerHTML = ''; // Очищаем корзину перед обновлением cart.forEach(item => { const row = cartTable.insertRow(); row.setAttribute('data-id', item.id); row.innerHTML = ` ${item.name} ${item.quantity} ${item.salePrice} ${item.quantity * item.salePrice} `; }); } // Функция добавления товара в корзину function addToCart(productId, quantity) { if (quantity && quantity > 0) { const products = JSON.parse(localStorage.getItem('products')) || []; const product = products.find(p => p.id === productId); if (product && product.quantity >= quantity) { const cartItem = cart.find(item => item.id === productId); if (cartItem) { cartItem.quantity += quantity; } else { cart.push({ id: productId, name: product.name, salePrice: product.salePrice, purchasePrice: product.purchasePrice, quantity: quantity }); } localStorage.setItem('cart', JSON.stringify(cart)); updateCartDisplay(); } else { alert('Недостаточно товара на складе.'); } } else { alert('Пожалуйста, введите корректное количество.'); } } // Функция удаления товара из корзины function removeFromCart(productId) { cart = cart.filter(item => item.id !== productId); localStorage.setItem('cart', JSON.stringify(cart)); updateCartDisplay(); } // Функция продажи товаров из корзины window.sellCart = function () { if (cart.length === 0) { alert('Корзина пуста.'); return; } const products = JSON.parse(localStorage.getItem('products')) || []; cart.forEach(cartItem => { const product = products.find(p => p.id === cartItem.id); if (product && product.quantity >= cartItem.quantity) { product.quantity -= cartItem.quantity; totalSold += cartItem.quantity; totalRevenue += cartItem.quantity * cartItem.salePrice; totalProfit += cartItem.quantity * (cartItem.salePrice - cartItem.purchasePrice); } else { alert(`Недостаточно товара "${cartItem.name}" на складе.`); } }); localStorage.setItem('products', JSON.stringify(products)); localStorage.setItem('stats', JSON.stringify({ totalSold, totalRevenue, totalProfit })); localStorage.removeItem('cart'); cart = []; updateCartDisplay(); productTable.innerHTML = ''; loadProducts(); updateStatsDisplay(); }; // Функция добавления остатков function addStock(productId) { const quantityToAdd = prompt('Введите количество для прихода:'); if (quantityToAdd && !isNaN(quantityToAdd) && quantityToAdd > 0) { let products = JSON.parse(localStorage.getItem('products')) || []; const productIndex = products.findIndex(p => p.id === productId); if (productIndex !== -1) { products[productIndex].quantity += parseInt(quantityToAdd); localStorage.setItem('products', JSON.stringify(products)); // Обновляем таблицу productTable.innerHTML = ''; loadProducts(); } } else { alert('Пожалуйста, введите корректное количество.'); } } // Функция удаления товара function deleteProduct(productId) { if (confirm('Вы уверены, что хотите удалить этот товар?')) { let products = JSON.parse(localStorage.getItem('products')) || []; products = products.filter(p => p.id !== productId); localStorage.setItem('products', JSON.stringify(products)); // Обновляем таблицу productTable.innerHTML = ''; loadProducts(); } } });