From 98adeba6e5a74ffaa7401947c5b0eae10448d8be Mon Sep 17 00:00:00 2001 From: David Vidal Date: Wed, 10 Oct 2018 09:43:25 +0200 Subject: [PATCH] [FIX] web_decimal_numpad: float_time format (#1068) Recover functionality from https://github.com/OCA/web/pull/720, which was lost in migration to Odoo v11. --- web_decimal_numpad_dot/__manifest__.py | 2 +- .../static/src/js/numpad_dot.js | 18 ++++++++++-------- 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/web_decimal_numpad_dot/__manifest__.py b/web_decimal_numpad_dot/__manifest__.py index 7d895998..271a45c4 100644 --- a/web_decimal_numpad_dot/__manifest__.py +++ b/web_decimal_numpad_dot/__manifest__.py @@ -8,7 +8,7 @@ { "name": "Web - Numpad Dot as decimal separator", - "version": "11.0.1.0.2", + "version": "11.0.1.0.3", "license": "AGPL-3", "summary": "Allows using numpad dot to enter period decimal separator", "depends": [ diff --git a/web_decimal_numpad_dot/static/src/js/numpad_dot.js b/web_decimal_numpad_dot/static/src/js/numpad_dot.js index 5d6c2ab4..82775b71 100644 --- a/web_decimal_numpad_dot/static/src/js/numpad_dot.js +++ b/web_decimal_numpad_dot/static/src/js/numpad_dot.js @@ -15,17 +15,19 @@ odoo.define("web_decimal_numpad_dot.FieldFloat", function (require) { }, l10n_decimal_point: function () { - return this.widget == "float_time" + return this.formatType === "float_time" ? ":" : translation._t.database.parameters.decimal_point; }, + _replaceAt: function (cur_val, index, replacement) { + return cur_val.substr(0, index) + replacement + + cur_val.substr(index + replacement.length); + }, + numpad_dot_replace: function (event) { - String.prototype.replaceAt=function(index, replacement) { - return this.substr(0, index) + replacement + this.substr(index + replacement.length); - } // Only act on numpad dot key - event.stopPropagation() - if (event.keyCode != 110) { + event.stopPropagation(); + if (event.keyCode !== 110) { return; } event.preventDefault(); @@ -33,10 +35,10 @@ odoo.define("web_decimal_numpad_dot.FieldFloat", function (require) { to = this.$input.prop("selectionEnd"), cur_val = this.$input.val(), point = this.l10n_decimal_point(); - var new_val = cur_val.replaceAt(from-1, point) + var new_val = this._replaceAt(cur_val, from-1, point); this.$input.val(new_val); // Put user caret in place - to = from + point.length + to = from + point.length; this.$input.prop("selectionStart", to).prop("selectionEnd", to); }, };