summaryrefslogtreecommitdiff
path: root/addons/point_of_sale/static/src/js/ChromeWidgets/OrderManagementButton.js
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/point_of_sale/static/src/js/ChromeWidgets/OrderManagementButton.js
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/point_of_sale/static/src/js/ChromeWidgets/OrderManagementButton.js')
-rw-r--r--addons/point_of_sale/static/src/js/ChromeWidgets/OrderManagementButton.js36
1 files changed, 36 insertions, 0 deletions
diff --git a/addons/point_of_sale/static/src/js/ChromeWidgets/OrderManagementButton.js b/addons/point_of_sale/static/src/js/ChromeWidgets/OrderManagementButton.js
new file mode 100644
index 00000000..0bee8880
--- /dev/null
+++ b/addons/point_of_sale/static/src/js/ChromeWidgets/OrderManagementButton.js
@@ -0,0 +1,36 @@
+odoo.define('point_of_sale.OrderManagementButton', function (require) {
+ 'use strict';
+
+ const PosComponent = require('point_of_sale.PosComponent');
+ const Registries = require('point_of_sale.Registries');
+ const { isRpcError } = require('point_of_sale.utils');
+
+ class OrderManagementButton extends PosComponent {
+ async onClick() {
+ try {
+ // ping the server, if no error, show the screen
+ await this.rpc({
+ model: 'pos.order',
+ method: 'browse',
+ args: [[]],
+ kwargs: { context: this.env.session.user_context },
+ });
+ this.showScreen('OrderManagementScreen');
+ } catch (error) {
+ if (isRpcError(error) && error.message.code < 0) {
+ this.showPopup('ErrorPopup', {
+ title: this.env._t('Network Error'),
+ body: this.env._t('Cannot access order management screen if offline.'),
+ });
+ } else {
+ throw error;
+ }
+ }
+ }
+ }
+ OrderManagementButton.template = 'OrderManagementButton';
+
+ Registries.Component.add(OrderManagementButton);
+
+ return OrderManagementButton;
+});