Browse Source

[IMP] mis_builder: improve eval context of query domain

Make it closer to the evaluation context available for server actions.

Conflicts:
	mis_builder/models/mis_builder.py

cherry-pick from v8
pull/90/head
Stéphane Bidoul 10 years ago
parent
commit
9ba019ce45
  1. 106
      mis_builder/models/mis_builder.py

106
mis_builder/models/mis_builder.py

@ -22,10 +22,16 @@
# #
############################################################################## ##############################################################################
<<<<<<< HEAD
from datetime import datetime, timedelta from datetime import datetime, timedelta
from dateutil import parser from dateutil import parser
=======
import datetime
import dateutil
>>>>>>> 09d69b9... [IMP] mis_builder: improve eval context of query domain
import logging import logging
import re import re
import time
import traceback import traceback
import pytz import pytz
@ -55,7 +61,11 @@ def _get_selection_label(selection, value):
def _utc_midnight(d, tz_name, add_day=0): def _utc_midnight(d, tz_name, add_day=0):
<<<<<<< HEAD
d = datetime.strptime(d, tools.DEFAULT_SERVER_DATE_FORMAT) d = datetime.strptime(d, tools.DEFAULT_SERVER_DATE_FORMAT)
=======
d = fields.Datetime.from_string(d) + datetime.timedelta(days=add_day)
>>>>>>> 09d69b9... [IMP] mis_builder: improve eval context of query domain
utc_tz = pytz.timezone('UTC') utc_tz = pytz.timezone('UTC')
if add_day: if add_day:
d = d + timedelta(days=add_day) d = d + timedelta(days=add_day)
@ -392,6 +402,7 @@ class MisReportInstancePeriod(orm.Model):
are defined as an offset relative to a pivot date. are defined as an offset relative to a pivot date.
""" """
<<<<<<< HEAD
def _get_dates(self, cr, uid, ids, field_names, arg, context=None): def _get_dates(self, cr, uid, ids, field_names, arg, context=None):
if isinstance(ids, (int, long)): if isinstance(ids, (int, long)):
ids = [ids] ids = [ids]
@ -417,6 +428,41 @@ class MisReportInstancePeriod(orm.Model):
period_obj = self.pool['account.period'] period_obj = self.pool['account.period']
current_period_ids = period_obj.search( current_period_ids = period_obj.search(
cr, uid, cr, uid,
=======
@api.one
@api.depends('report_instance_id.pivot_date', 'type', 'offset', 'duration')
def _compute_dates(self):
self.date_from = False
self.date_to = False
self.period_from = False
self.period_to = False
self.valid = False
d = fields.Date.from_string(self.report_instance_id.pivot_date)
if self.type == 'd':
date_from = d + datetime.timedelta(days=self.offset)
date_to = date_from + \
datetime.timedelta(days=self.duration - 1)
self.date_from = fields.Date.to_string(date_from)
self.date_to = fields.Date.to_string(date_to)
self.valid = True
elif self.type == 'w':
date_from = d - datetime.timedelta(d.weekday())
date_from = date_from + datetime.timedelta(days=self.offset * 7)
date_to = date_from + \
datetime.timedelta(days=(7 * self.duration) - 1)
self.date_from = fields.Date.to_string(date_from)
self.date_to = fields.Date.to_string(date_to)
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(
>>>>>>> 09d69b9... [IMP] mis_builder: improve eval context of query domain
[('special', '=', False), [('special', '=', False),
('date_start', '<=', d), ('date_start', '<=', d),
('date_stop', '>=', d), ('date_stop', '>=', d),
@ -551,10 +597,24 @@ class MisReportInstancePeriod(orm.Model):
======= =======
for query in self.report_instance_id.report_id.query_ids: for query in self.report_instance_id.report_id.query_ids:
model = self.env[query.model_id.model] model = self.env[query.model_id.model]
<<<<<<< HEAD
domain = query.domain and safe_eval( domain = query.domain and safe_eval(
query.domain, query.domain,
{'uid': self._uid, 'context': self._context}) or [] {'uid': self._uid, 'context': self._context}) or []
>>>>>>> 4bc6080... Add ability to use ('user_id', '=', uid) in a domain >>>>>>> 4bc6080... Add ability to use ('user_id', '=', uid) in a domain
=======
eval_context = {
'env': self.env,
'time': time,
'datetime': datetime,
'dateutil': dateutil,
# deprecated
'uid': self.env.uid,
'context': self.env.context,
}
domain = query.domain and \
safe_eval(query.domain, eval_context) or []
>>>>>>> 09d69b9... [IMP] mis_builder: improve eval context of query domain
if query.date_field.ttype == 'date': if query.date_field.ttype == 'date':
domain.extend([(query.date_field.name, '>=', c.date_from), domain.extend([(query.date_field.name, '>=', c.date_from),
(query.date_field.name, '<=', c.date_to)]) (query.date_field.name, '<=', c.date_to)])
@ -774,11 +834,57 @@ class MisReportInstance(orm.Model):
context=context) context=context)
return res return res
<<<<<<< HEAD
def preview(self, cr, uid, ids, context=None): def preview(self, cr, uid, ids, context=None):
assert len(ids) == 1 assert len(ids) == 1
view_id = self.pool['ir.model.data'].get_object_reference( view_id = self.pool['ir.model.data'].get_object_reference(
cr, uid, 'mis_builder', cr, uid, 'mis_builder',
'mis_report_instance_result_view_form')[1] 'mis_report_instance_result_view_form')[1]
=======
name = fields.Char(required=True,
string='Name', translate=True)
description = fields.Char(required=False,
string='Description', translate=True)
date = fields.Date(string='Base date',
help='Report base date '
'(leave empty to use current date)')
pivot_date = fields.Date(compute='_compute_pivot_date',
string="Pivot date")
report_id = fields.Many2one('mis.report',
required=True,
string='Report')
period_ids = fields.One2many('mis.report.instance.period',
'report_instance_id',
required=True,
string='Periods')
target_move = fields.Selection([('posted', 'All Posted Entries'),
('all', 'All Entries')],
string='Target Moves',
required=True,
default='posted')
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)
landscape_pdf = fields.Boolean(string='Landscape PDF')
def _format_date(self, lang_id, date):
# format date following user language
date_format = self.env['res.lang'].browse(lang_id).date_format
return datetime.datetime.strftime(
fields.Date.from_string(date), date_format)
@api.multi
def preview(self):
assert len(self) == 1
view_id = self.env.ref('mis_builder.'
'mis_report_instance_result_view_form')
>>>>>>> 09d69b9... [IMP] mis_builder: improve eval context of query domain
return { return {
'type': 'ir.actions.act_window', 'type': 'ir.actions.act_window',
'res_model': 'mis.report.instance', 'res_model': 'mis.report.instance',

Loading…
Cancel
Save