From 2995710a3e4fcf634b5ae2de0fea3bc8a33edbb0 Mon Sep 17 00:00:00 2001 From: Andrey Smakotin Date: Fri, 2 Jan 2026 18:33:51 +0300 Subject: [PATCH] =?UTF-8?q?=D0=98=D1=81=D0=BF=D1=80=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=D0=B0=20=D0=BF=D0=B5=D1=80=D0=B5=D0=B4=D0=B0=D1=87?= =?UTF-8?q?=D0=B0=20=D0=B5=D0=B4=D0=B8=D0=BD=D0=B8=D1=86=20=D0=BF=D1=80?= =?UTF-8?q?=D0=BE=D0=B4=D0=B0=D0=B6=D0=B8=20=D0=BF=D1=80=D0=B8=20=D1=81?= =?UTF-8?q?=D0=BE=D0=B7=D0=B4=D0=B0=D0=BD=D0=B8=D0=B8=20=D0=BE=D1=82=D0=BB?= =?UTF-8?q?=D0=BE=D0=B6=D0=B5=D0=BD=D0=BD=D0=BE=D0=B3=D0=BE=20=D0=B7=D0=B0?= =?UTF-8?q?=D0=BA=D0=B0=D0=B7=D0=B0=20=D0=B8=D0=B7=20POS?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - В terminal.js добавлена передача sales_unit_id в данные черновика заказа - В order_form.html добавлено заполнение поля sales_unit при предзаполнении из черновика - Теперь при создании отложенного заказа с товаром в единицах продажи сохраняется корректная единица измерения --- .../orders/templates/orders/order_form.html | 13 +++++++++++ myproject/pos/static/pos/js/terminal.js | 23 ++++++++++++++----- 2 files changed, 30 insertions(+), 6 deletions(-) diff --git a/myproject/orders/templates/orders/order_form.html b/myproject/orders/templates/orders/order_form.html index f4b8e00..dedf67e 100644 --- a/myproject/orders/templates/orders/order_form.html +++ b/myproject/orders/templates/orders/order_form.html @@ -2042,6 +2042,7 @@ document.addEventListener('DOMContentLoaded', function() { // Находим форму по индексу const productField = document.querySelector(`[name="items-${index}-product"]`); const kitField = document.querySelector(`[name="items-${index}-product_kit"]`); + const salesUnitField = document.querySelector(`[name="items-${index}-sales_unit"]`); const quantityField = document.querySelector(`[name="items-${index}-quantity"]`); const priceField = document.querySelector(`[name="items-${index}-price"]`); @@ -2053,15 +2054,27 @@ document.addEventListener('DOMContentLoaded', function() { console.log(`[Draft Items] 🔍 Поля формы ${index}:`); console.log(` - productField:`, productField); console.log(` - kitField:`, kitField); + console.log(` - salesUnitField:`, salesUnitField); // Устанавливаем значения if (item.type === 'product') { productField.value = item.id; kitField.value = ''; console.log(`[Draft Items] ✅ Установлен product ID: ${item.id}`); + + // Устанавливаем sales_unit если есть + if (item.sales_unit_id && salesUnitField) { + salesUnitField.value = item.sales_unit_id; + console.log(`[Draft Items] ✅ Установлен sales_unit ID: ${item.sales_unit_id}`); + } else if (salesUnitField) { + salesUnitField.value = ''; + } } else if (item.type === 'kit' || item.type === 'showcase_kit') { kitField.value = item.id; productField.value = ''; + if (salesUnitField) { + salesUnitField.value = ''; + } console.log(`[Draft Items] ✅ Установлен kit ID: ${item.id}`); } diff --git a/myproject/pos/static/pos/js/terminal.js b/myproject/pos/static/pos/js/terminal.js index bd902a0..52af180 100644 --- a/myproject/pos/static/pos/js/terminal.js +++ b/myproject/pos/static/pos/js/terminal.js @@ -2679,12 +2679,23 @@ async function createDeferredOrder() { try { // Собираем данные для черновика - const items = Array.from(cart.values()).map(item => ({ - type: item.type, - id: item.id, - quantity: item.qty, - price: item.price - })); + const items = Array.from(cart.values()).map(item => { + const itemData = { + type: item.type, + id: item.id, + quantity: item.qty, + price: item.price + }; + // Для товаров с единицами продажи передаём sales_unit_id + if (item.sales_unit_id) { + itemData.sales_unit_id = item.sales_unit_id; + } + // Для витринных букетов передаём showcase_item_ids + if (item.type === 'showcase_kit' && item.showcase_item_ids) { + itemData.showcase_item_ids = item.showcase_item_ids; + } + return itemData; + }); const customer = selectedCustomer || SYSTEM_CUSTOMER;