summaryrefslogtreecommitdiff
path: root/addons/point_of_sale/wizard/pos_details.py
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/wizard/pos_details.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/point_of_sale/wizard/pos_details.py')
-rw-r--r--addons/point_of_sale/wizard/pos_details.py47
1 files changed, 47 insertions, 0 deletions
diff --git a/addons/point_of_sale/wizard/pos_details.py b/addons/point_of_sale/wizard/pos_details.py
new file mode 100644
index 00000000..9be4caa0
--- /dev/null
+++ b/addons/point_of_sale/wizard/pos_details.py
@@ -0,0 +1,47 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo import api, fields, models, _
+from odoo.exceptions import UserError
+
+
+class PosDetails(models.TransientModel):
+ _name = 'pos.details.wizard'
+ _description = 'Point of Sale Details Report'
+
+ def _default_start_date(self):
+ """ Find the earliest start_date of the latests sessions """
+ # restrict to configs available to the user
+ config_ids = self.env['pos.config'].search([]).ids
+ # exclude configs has not been opened for 2 days
+ self.env.cr.execute("""
+ SELECT
+ max(start_at) as start,
+ config_id
+ FROM pos_session
+ WHERE config_id = ANY(%s)
+ AND start_at > (NOW() - INTERVAL '2 DAYS')
+ GROUP BY config_id
+ """, (config_ids,))
+ latest_start_dates = [res['start'] for res in self.env.cr.dictfetchall()]
+ # earliest of the latest sessions
+ return latest_start_dates and min(latest_start_dates) or fields.Datetime.now()
+
+ start_date = fields.Datetime(required=True, default=_default_start_date)
+ end_date = fields.Datetime(required=True, default=fields.Datetime.now)
+ pos_config_ids = fields.Many2many('pos.config', 'pos_detail_configs',
+ default=lambda s: s.env['pos.config'].search([]))
+
+ @api.onchange('start_date')
+ def _onchange_start_date(self):
+ if self.start_date and self.end_date and self.end_date < self.start_date:
+ self.end_date = self.start_date
+
+ @api.onchange('end_date')
+ def _onchange_end_date(self):
+ if self.end_date and self.end_date < self.start_date:
+ self.start_date = self.end_date
+
+ def generate_report(self):
+ data = {'date_start': self.start_date, 'date_stop': self.end_date, 'config_ids': self.pos_config_ids.ids}
+ return self.env.ref('point_of_sale.sale_details_report').report_action([], data=data)