From 4817bc388b9156c106d09478505697fd29eef7cc Mon Sep 17 00:00:00 2001 From: Andrey Smakotin Date: Thu, 4 Dec 2025 13:14:47 +0300 Subject: [PATCH] =?UTF-8?q?FIX:=20=D0=9E=D0=B1=D0=BD=D0=BE=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=D0=B8=D0=B5=20=D0=B1=D0=B0=D0=BB=D0=B0=D0=BD=D1=81?= =?UTF-8?q?=D0=B0=20=D0=BA=D0=BE=D1=88=D0=B5=D0=BB=D1=8C=D0=BA=D0=B0=20?= =?UTF-8?q?=D0=BF=D1=80=D0=B8=20=D1=81=D0=BC=D0=B5=D0=BD=D0=B5=20=D0=BA?= =?UTF-8?q?=D0=BB=D0=B8=D0=B5=D0=BD=D1=82=D0=B0=20=D0=B2=20=D0=BC=D0=BE?= =?UTF-8?q?=D0=B4=D0=B0=D0=BB=D1=8C=D0=BD=D0=BE=D0=BC=20=D0=BE=D0=BA=D0=BD?= =?UTF-8?q?=D0=B5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Проблема: - При сбросе клиента на системного в модальном окне продажи баланс кошелька оставался от предыдущего клиента и не обновлялся Исправления: - Добавлена функция updateCheckoutWalletBalance() для обновления баланса - Функция updateCustomerDisplay() теперь вызывает updateCheckoutWalletBalance() - Исправлены все кнопки сброса/выбора системного клиента - теперь передают wallet_balance Результат: При смене клиента баланс кошелька в модальном окне обновляется корректно 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude --- myproject/pos/static/pos/js/terminal.js | 29 ++++++++++++++++++++++--- 1 file changed, 26 insertions(+), 3 deletions(-) diff --git a/myproject/pos/static/pos/js/terminal.js b/myproject/pos/static/pos/js/terminal.js index 2390c11..7b3dab3 100644 --- a/myproject/pos/static/pos/js/terminal.js +++ b/myproject/pos/static/pos/js/terminal.js @@ -87,6 +87,7 @@ function formatMoney(v) { * - Кнопку "Выбрать клиента" в модалке продажи (показывает имя клиента) * - Видимость кнопок сброса в обоих местах (показываем только для не-системного клиента) * - Ссылку на анкету клиента (показываем только для не-системного клиента) + * - Баланс кошелька в модальном окне продажи (если оно открыто) */ function updateCustomerDisplay() { // Обновляем текст кнопки в корзине @@ -122,6 +123,28 @@ function updateCustomerDisplay() { profileLink.style.display = 'block'; } } + + // Обновляем баланс кошелька в модальном окне продажи (если оно открыто) + updateCheckoutWalletBalance(); +} + +/** + * Обновляет баланс кошелька клиента в модальном окне продажи + */ +function updateCheckoutWalletBalance() { + const walletDiv = document.getElementById('checkoutWalletBalance'); + if (!walletDiv) return; // Модалка еще не инициализирована + + const customer = selectedCustomer || SYSTEM_CUSTOMER; + const walletBalance = customer.wallet_balance || 0; + const isSystemCustomer = Number(customer.id) === Number(SYSTEM_CUSTOMER.id); + + if (!isSystemCustomer) { + document.getElementById('checkoutWalletBalanceAmount').textContent = walletBalance.toFixed(2); + walletDiv.style.display = 'block'; + } else { + walletDiv.style.display = 'none'; + } } /** @@ -1761,7 +1784,7 @@ document.getElementById('customerSelectBtn').addEventListener('click', () => { // Кнопка сброса клиента на системного (в корзине) document.getElementById('resetCustomerBtn').addEventListener('click', () => { - selectCustomer(SYSTEM_CUSTOMER.id, SYSTEM_CUSTOMER.name); + selectCustomer(SYSTEM_CUSTOMER.id, SYSTEM_CUSTOMER.name, SYSTEM_CUSTOMER.wallet_balance || 0); }); // Кнопка "Выбрать клиента" в модалке продажи @@ -1772,7 +1795,7 @@ document.getElementById('checkoutCustomerSelectBtn').addEventListener('click', ( // Кнопка сброса клиента на системного (в модалке продажи) document.getElementById('checkoutResetCustomerBtn').addEventListener('click', () => { - selectCustomer(SYSTEM_CUSTOMER.id, SYSTEM_CUSTOMER.name); + selectCustomer(SYSTEM_CUSTOMER.id, SYSTEM_CUSTOMER.name, SYSTEM_CUSTOMER.wallet_balance || 0); }); // Кнопка "Создать нового клиента" в модалке выбора @@ -1787,7 +1810,7 @@ document.getElementById('createNewCustomerBtn').addEventListener('click', () => // Кнопка "Выбрать системного клиента" document.getElementById('selectSystemCustomerBtn').addEventListener('click', () => { - selectCustomer(SYSTEM_CUSTOMER.id, SYSTEM_CUSTOMER.name); + selectCustomer(SYSTEM_CUSTOMER.id, SYSTEM_CUSTOMER.name, SYSTEM_CUSTOMER.wallet_balance || 0); // Закрываем модалку const modal = bootstrap.Modal.getInstance(document.getElementById('selectCustomerModal'));