|
@ -304,8 +304,6 @@ class MisReportInstancePeriod(models.Model): |
|
|
def _compute_dates(self): |
|
|
def _compute_dates(self): |
|
|
self.date_from = False |
|
|
self.date_from = False |
|
|
self.date_to = False |
|
|
self.date_to = False |
|
|
self.period_from = False |
|
|
|
|
|
self.period_to = False |
|
|
|
|
|
self.valid = False |
|
|
self.valid = False |
|
|
d = fields.Date.from_string(self.report_instance_id.pivot_date) |
|
|
d = fields.Date.from_string(self.report_instance_id.pivot_date) |
|
|
if self.type == 'd': |
|
|
if self.type == 'd': |
|
@ -323,28 +321,6 @@ class MisReportInstancePeriod(models.Model): |
|
|
self.date_from = fields.Date.to_string(date_from) |
|
|
self.date_from = fields.Date.to_string(date_from) |
|
|
self.date_to = fields.Date.to_string(date_to) |
|
|
self.date_to = fields.Date.to_string(date_to) |
|
|
self.valid = True |
|
|
self.valid = True |
|
|
elif self.type == 'fp': |
|
|
|
|
|
current_periods = self.env['account.period'].search( |
|
|
|
|
|
[('special', '=', False), |
|
|
|
|
|
('date_start', '<=', d), |
|
|
|
|
|
('date_stop', '>=', d), |
|
|
|
|
|
('company_id', '=', |
|
|
|
|
|
self.report_instance_id.company_id.id)]) |
|
|
|
|
|
if current_periods: |
|
|
|
|
|
all_periods = self.env['account.period'].search( |
|
|
|
|
|
[('special', '=', False), |
|
|
|
|
|
('company_id', '=', |
|
|
|
|
|
self.report_instance_id.company_id.id)], |
|
|
|
|
|
order='date_start') |
|
|
|
|
|
all_period_ids = [p.id for p in all_periods] |
|
|
|
|
|
p = all_period_ids.index(current_periods[0].id) + self.offset |
|
|
|
|
|
if p >= 0 and p + self.duration <= len(all_period_ids): |
|
|
|
|
|
periods = all_periods[p:p + self.duration] |
|
|
|
|
|
self.date_from = periods[0].date_start |
|
|
|
|
|
self.date_to = periods[-1].date_stop |
|
|
|
|
|
self.period_from = periods[0] |
|
|
|
|
|
self.period_to = periods[-1] |
|
|
|
|
|
self.valid = True |
|
|
|
|
|
|
|
|
|
|
|
_name = 'mis.report.instance.period' |
|
|
_name = 'mis.report.instance.period' |
|
|
|
|
|
|
|
@ -352,7 +328,6 @@ class MisReportInstancePeriod(models.Model): |
|
|
string='Description', translate=True) |
|
|
string='Description', translate=True) |
|
|
type = fields.Selection([('d', _('Day')), |
|
|
type = fields.Selection([('d', _('Day')), |
|
|
('w', _('Week')), |
|
|
('w', _('Week')), |
|
|
('fp', _('Fiscal Period')), |
|
|
|
|
|
# ('fy', _('Fiscal Year')) |
|
|
# ('fy', _('Fiscal Year')) |
|
|
], |
|
|
], |
|
|
required=True, |
|
|
required=True, |
|
@ -365,12 +340,6 @@ class MisReportInstancePeriod(models.Model): |
|
|
default=1) |
|
|
default=1) |
|
|
date_from = fields.Date(compute='_compute_dates', string="From") |
|
|
date_from = fields.Date(compute='_compute_dates', string="From") |
|
|
date_to = fields.Date(compute='_compute_dates', string="To") |
|
|
date_to = fields.Date(compute='_compute_dates', string="To") |
|
|
period_from = fields.Many2one(compute='_compute_dates', |
|
|
|
|
|
comodel_name='account.period', |
|
|
|
|
|
string="From period") |
|
|
|
|
|
period_to = fields.Many2one(compute='_compute_dates', |
|
|
|
|
|
comodel_name='account.period', |
|
|
|
|
|
string="To period") |
|
|
|
|
|
valid = fields.Boolean(compute='_compute_dates', |
|
|
valid = fields.Boolean(compute='_compute_dates', |
|
|
type='boolean', |
|
|
type='boolean', |
|
|
string='Valid') |
|
|
string='Valid') |
|
@ -434,11 +403,10 @@ class MisReportInstancePeriod(models.Model): |
|
|
if AEP.has_account_var(expr): |
|
|
if AEP.has_account_var(expr): |
|
|
aep = AEP(self.env) |
|
|
aep = AEP(self.env) |
|
|
aep.parse_expr(expr) |
|
|
aep.parse_expr(expr) |
|
|
aep.done_parsing(self.report_instance_id.root_account) |
|
|
|
|
|
|
|
|
aep.done_parsing() |
|
|
domain = aep.get_aml_domain_for_expr( |
|
|
domain = aep.get_aml_domain_for_expr( |
|
|
expr, |
|
|
expr, |
|
|
self.date_from, self.date_to, |
|
|
self.date_from, self.date_to, |
|
|
self.period_from, self.period_to, |
|
|
|
|
|
self.report_instance_id.target_move) |
|
|
self.report_instance_id.target_move) |
|
|
domain.extend(self._get_additional_move_line_filter()) |
|
|
domain.extend(self._get_additional_move_line_filter()) |
|
|
return { |
|
|
return { |
|
@ -523,7 +491,6 @@ class MisReportInstancePeriod(models.Model): |
|
|
localdict.update(self._fetch_queries()) |
|
|
localdict.update(self._fetch_queries()) |
|
|
|
|
|
|
|
|
aep.do_queries(self.date_from, self.date_to, |
|
|
aep.do_queries(self.date_from, self.date_to, |
|
|
self.period_from, self.period_to, |
|
|
|
|
|
self.report_instance_id.target_move, |
|
|
self.report_instance_id.target_move, |
|
|
self._get_additional_move_line_filter()) |
|
|
self._get_additional_move_line_filter()) |
|
|
|
|
|
|
|
@ -628,14 +595,7 @@ class MisReportInstance(models.Model): |
|
|
required=True, |
|
|
required=True, |
|
|
default='posted') |
|
|
default='posted') |
|
|
company_id = fields.Many2one(comodel_name='res.company', |
|
|
company_id = fields.Many2one(comodel_name='res.company', |
|
|
string='Company', |
|
|
|
|
|
readonly=True, |
|
|
|
|
|
related='root_account.company_id', |
|
|
|
|
|
store=True) |
|
|
|
|
|
root_account = fields.Many2one(comodel_name='account.account', |
|
|
|
|
|
domain='[("parent_id", "=", False)]', |
|
|
|
|
|
string="Account chart", |
|
|
|
|
|
required=True) |
|
|
|
|
|
|
|
|
string='Company') |
|
|
landscape_pdf = fields.Boolean(string='Landscape PDF') |
|
|
landscape_pdf = fields.Boolean(string='Landscape PDF') |
|
|
|
|
|
|
|
|
def _format_date(self, lang_id, date): |
|
|
def _format_date(self, lang_id, date): |
|
@ -667,7 +627,7 @@ class MisReportInstance(models.Model): |
|
|
aep = AEP(self.env) |
|
|
aep = AEP(self.env) |
|
|
for kpi in self.report_id.kpi_ids: |
|
|
for kpi in self.report_id.kpi_ids: |
|
|
aep.parse_expr(kpi.expression) |
|
|
aep.parse_expr(kpi.expression) |
|
|
aep.done_parsing(self.root_account) |
|
|
|
|
|
|
|
|
aep.done_parsing() |
|
|
|
|
|
|
|
|
# fetch user language only once |
|
|
# fetch user language only once |
|
|
# TODO: is this necessary? |
|
|
# TODO: is this necessary? |
|
@ -707,19 +667,11 @@ class MisReportInstance(models.Model): |
|
|
# add the column header |
|
|
# add the column header |
|
|
if period.duration > 1 or period.type == 'w': |
|
|
if period.duration > 1 or period.type == 'w': |
|
|
# from, to |
|
|
# from, to |
|
|
if period.period_from and period.period_to: |
|
|
|
|
|
date_from = period.period_from.name |
|
|
|
|
|
date_to = period.period_to.name |
|
|
|
|
|
else: |
|
|
|
|
|
date_from = self._format_date(lang_id, period.date_from) |
|
|
|
|
|
date_to = self._format_date(lang_id, period.date_to) |
|
|
|
|
|
|
|
|
date_from = self._format_date(lang_id, period.date_from) |
|
|
|
|
|
date_to = self._format_date(lang_id, period.date_to) |
|
|
header_date = _('from %s to %s') % (date_from, date_to) |
|
|
header_date = _('from %s to %s') % (date_from, date_to) |
|
|
else: |
|
|
else: |
|
|
# one period or one day |
|
|
|
|
|
if period.period_from and period.period_to: |
|
|
|
|
|
header_date = period.period_from.name |
|
|
|
|
|
else: |
|
|
|
|
|
header_date = self._format_date(lang_id, period.date_from) |
|
|
|
|
|
|
|
|
header_date = self._format_date(lang_id, period.date_from) |
|
|
header[0]['cols'].append(dict(name=period.name, date=header_date)) |
|
|
header[0]['cols'].append(dict(name=period.name, date=header_date)) |
|
|
# add kpi values |
|
|
# add kpi values |
|
|
kpi_values = kpi_values_by_period_ids[period.id] |
|
|
kpi_values = kpi_values_by_period_ids[period.id] |
|
|