From 139d7ea33c5d03ec8b4c648539494c985247c8d6 Mon Sep 17 00:00:00 2001 From: Surya Paolo Date: Mon, 18 Dec 2023 08:02:28 +0100 Subject: [PATCH] Risolto problema blocco --- src/server/models/order.js | 10 ++++++++-- src/server/models/orderscart.js | 2 +- src/server/modules/Cart.js | 14 +++++++------- 3 files changed, 16 insertions(+), 10 deletions(-) diff --git a/src/server/models/order.js b/src/server/models/order.js index 4d59673..10583ca 100755 --- a/src/server/models/order.js +++ b/src/server/models/order.js @@ -28,7 +28,8 @@ const orderSchema = new Schema({ idScontisticas: [{ type: Schema.Types.ObjectId, ref: 'Scontistica' }], idProvider: { type: Schema.Types.ObjectId, ref: 'Provider' }, price: { - type: Number + type: Number, + default: 0, }, after_price: { type: String @@ -40,7 +41,12 @@ const orderSchema = new Schema({ type: String }, quantity: { - type: Number + type: Number, + default: 0, + }, + TotalPriceProduct: { + type: Number, + default: 0, }, evaso: { // e quindi è stato tolto dal magazzino (aggiornando il campo StockQty) type: Boolean, diff --git a/src/server/models/orderscart.js b/src/server/models/orderscart.js index bb085a7..8883e79 100755 --- a/src/server/models/orderscart.js +++ b/src/server/models/orderscart.js @@ -544,7 +544,7 @@ module.exports.getmsgorderTelegram = async function (ordersCart) { msg += '

Lista Prodotti:'; for (const ord of ordersCart.items) { msg += '
'; - msg += '✅ [' + ord.order.quantity + '] ' + ord.order.product.name + ' (' + ord.order.price + ' € ' + (ord.order.after_price ? ord.order.after_price : '') + ')'; + msg += '✅ [' + ord.order.quantity + '] ' + ord.order.product.name + ' (' + ord.order.price + ' € ' + (ord.order.after_price ? ord.order.after_price : '') + ' Tot=' + ord.order.TotalPriceProduct + '€ )'; } msg += '
'; diff --git a/src/server/modules/Cart.js b/src/server/modules/Cart.js index 31677e4..89b3660 100755 --- a/src/server/modules/Cart.js +++ b/src/server/modules/Cart.js @@ -38,8 +38,8 @@ class Cart { const myitem = this.items.find((rec) => rec.order._id.toString() === itemorder._id) if (!!myitem) { myitem.order.quantity++; - await Order.findOneAndUpdate({ _id: myitem.order._id }, { $set: myitem.order }, { new: false }); this.updatetotals(); + await Order.findOneAndUpdate({ _id: myitem.order._id }, { $set: myitem.order }, { new: false }); return myitem.order.quantity; } } @@ -49,8 +49,8 @@ class Cart { const myitem = this.items.find((rec) => rec.order._id.toString() === itemorder._id) if (!!myitem && myitem.order.quantity > 0) { myitem.order.quantity--; - await Order.findOneAndUpdate({ _id: myitem.order._id }, { $set: myitem.order }, { new: false }); this.updatetotals(); + await Order.findOneAndUpdate({ _id: myitem.order._id }, { $set: myitem.order }, { new: false }); return myitem.order.quantity; } } catch (e) { @@ -94,15 +94,17 @@ class Cart { this.totalQty = 0; this.totalPrice = 0; for (const rec in this.items) { + let mypricecalc = 0; + let order = this.items[rec].order; if (!order) { order = this.items[rec]; } + order.TotalPriceProduct = 0; this.totalQty += order.quantity; // Calcolo Sconto let sconti_da_applicare = []; - let mypricecalc = 0; if (order.scontisticas) { let qtadascontare = order.quantity @@ -131,10 +133,7 @@ class Cart { } }*/ - mypricecalc = order.price * order.quantity; - if (sconti_da_applicare.length > 0) { - mypricecalc = 0 for (const sconto of sconti_da_applicare) { if (sconto.perc_sconto > 0) { mypricecalc += (sconto.qtadascontare * order.price) * (1 - (sconto.perc_sconto / 100)) @@ -150,7 +149,8 @@ class Cart { } else { mypricecalc = order.price * order.quantity; } - this.totalPrice += mypricecalc; + order.TotalPriceProduct += mypricecalc; + this.totalPrice += order.TotalPriceProduct; } this.totalPrice = parseFloat(this.totalPrice.toFixed(2)) } catch (e) {