mirror of
https://github.com/bringout/oca-ocb-sale.git
synced 2026-04-27 15:52:01 +02:00
39 lines
1.6 KiB
Python
39 lines
1.6 KiB
Python
# -*- coding: utf-8 -*-
|
|
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
|
|
|
from datetime import timedelta
|
|
|
|
from odoo import api, fields, models
|
|
|
|
|
|
class PosDetailsWizard(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 """
|
|
values = self.env['pos.session']._read_group([
|
|
('config_id', '!=', False),
|
|
('start_at', '>', self.env.cr.now() - timedelta(days=2))
|
|
], groupby=['config_id'], aggregates=['start_at:max'])
|
|
mapping = dict(values)
|
|
return (mapping and min(mapping.values())) or self.env.cr.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.start_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)
|