From 04289c12de331b667a70a2f0f28b5c78e32d7ef0 Mon Sep 17 00:00:00 2001 From: Jose Zambudio Date: Thu, 26 Oct 2023 12:30:18 +0200 Subject: [PATCH] [14.0][FIX] pos_order_mgmt: Return with positive amounts The sign of a return is forced to be negative so that it does not give an error later when confirming the order. In addition, a confirmation message is added in the event of returning more than the quantity sold. --- pos_order_mgmt/static/src/js/ProductScreen.js | 42 +++++++++++++++++++ .../static/src/js/RefundOrderButton.js | 2 + pos_order_mgmt/static/src/js/models.js | 21 +++++++++- pos_order_mgmt/views/assets.xml | 4 ++ 4 files changed, 67 insertions(+), 2 deletions(-) create mode 100644 pos_order_mgmt/static/src/js/ProductScreen.js diff --git a/pos_order_mgmt/static/src/js/ProductScreen.js b/pos_order_mgmt/static/src/js/ProductScreen.js new file mode 100644 index 0000000000..19c9543ca3 --- /dev/null +++ b/pos_order_mgmt/static/src/js/ProductScreen.js @@ -0,0 +1,42 @@ +/* Copyright Aures Tic - Jose Zambudio + License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl) */ +odoo.define("pos_order_mgmt.ProductScreen", function (require) { + "use strict"; + + const ProductScreen = require("point_of_sale.ProductScreen"); + const Registries = require("point_of_sale.Registries"); + + const PosOrderMgmtProductScreen = (ProductScreen) => + class extends ProductScreen { + async _onClickPay() { + if ( + this.env.pos + .get_order() + .orderlines.any( + (line) => + line.returned_orderline_id && + Math.abs(line.quantity) > line.max_return_qty + ) + ) { + const {confirmed} = await this.showPopup("ConfirmPopup", { + title: this.env._t("Incorrect quantities"), + body: this.env._t( + `It is returning more than the quantity delivered. + Would you like to proceed anyway?` + ), + confirmText: this.env._t("Yes"), + cancelText: this.env._t("No"), + }); + if (confirmed) { + return super._onClickPay(...arguments); + } + } else { + return super._onClickPay(...arguments); + } + } + }; + + Registries.Component.extend(ProductScreen, PosOrderMgmtProductScreen); + + return PosOrderMgmtProductScreen; +}); diff --git a/pos_order_mgmt/static/src/js/RefundOrderButton.js b/pos_order_mgmt/static/src/js/RefundOrderButton.js index ae561ce695..a7ee9b51df 100644 --- a/pos_order_mgmt/static/src/js/RefundOrderButton.js +++ b/pos_order_mgmt/static/src/js/RefundOrderButton.js @@ -69,6 +69,8 @@ odoo.define("pos_order_mgmt.RefundOrderButton", function (require) { merge: false, extras: { return_pack_lot_names: orderline.pack_lot_names, + returned_orderline_id: orderline.id, + max_return_qty: quantity, }, }); }); diff --git a/pos_order_mgmt/static/src/js/models.js b/pos_order_mgmt/static/src/js/models.js index 1c36b8dfa7..bbdf942c71 100644 --- a/pos_order_mgmt/static/src/js/models.js +++ b/pos_order_mgmt/static/src/js/models.js @@ -5,9 +5,11 @@ odoo.define("pos_order_mgmt.models", function (require) { "use strict"; - var models = require("point_of_sale.models"); + const models = require("point_of_sale.models"); + const field_utils = require("web.field_utils"); - var _orderproto = models.Order.prototype; + const _orderproto = models.Order.prototype; + const _orderLineProto = models.Orderline.prototype; models.Order = models.Order.extend({ init_from_JSON: function (json) { @@ -25,4 +27,19 @@ odoo.define("pos_order_mgmt.models", function (require) { return res; }, }); + + models.Orderline = models.Orderline.extend({ + set_quantity: function (quantity, keep_price) { + if (quantity !== "remove") { + quantity = + typeof quantity === "number" + ? quantity + : field_utils.parse.float(String(quantity)) || 0; + if (this.returned_orderline_id) { + quantity = Math.abs(quantity) * -1; + } + } + return _orderLineProto.set_quantity.call(this, quantity, keep_price); + }, + }); }); diff --git a/pos_order_mgmt/views/assets.xml b/pos_order_mgmt/views/assets.xml index 3f570be4f8..49060d3494 100644 --- a/pos_order_mgmt/views/assets.xml +++ b/pos_order_mgmt/views/assets.xml @@ -10,6 +10,10 @@ type="text/javascript" src="/pos_order_mgmt/static/src/js/CopyOrderButton.js" /> +