Browse Source

[WIP] sale_exception_by_domain

pull/1410/head
Mourad 7 years ago
committed by David Beal
parent
commit
7db7db8301
  1. 37
      base_exception/models/base_exception.py
  2. 8
      base_exception/views/base_exception_view.xml

37
base_exception/models/base_exception.py

@ -41,6 +41,11 @@ class ExceptionRule(models.Model):
model = fields.Selection( model = fields.Selection(
selection=[], selection=[],
string='Apply on', required=True) string='Apply on', required=True)
type = fields.Selection(
selection=[('by_domain', 'By domain'),
('by_py_code', 'By Python Code')],
string='Exception Type', required=True)
domain = fields.Char('Domain')
active = fields.Boolean('Active') active = fields.Boolean('Active')
code = fields.Text( code = fields.Text(
'Python Code', 'Python Code',
@ -65,6 +70,19 @@ class ExceptionRule(models.Model):
# - context: current context # - context: current context
""") """)
@api.multi
def _get_domain(self):
""" override me to customize domains according exceptions cases """
self.ensure_one()
return safe_eval(self.domain)
@api.onchange('type',)
def onchange_type(self):
if self.type == 'by_domain':
self.code = False
elif self.type == 'by_py_code':
self.domain = False
class BaseException(models.AbstractModel): class BaseException(models.AbstractModel):
_name = 'base.exception' _name = 'base.exception'
@ -141,6 +159,7 @@ class BaseException(models.AbstractModel):
def detect_exceptions(self): def detect_exceptions(self):
"""returns the list of exception_ids for all the considered base.exceptions """returns the list of exception_ids for all the considered base.exceptions
""" """
import pdb; pdb.set_trace()
if not self: if not self:
return [] return []
exception_obj = self.env['exception.rule'] exception_obj = self.env['exception.rule']
@ -195,9 +214,16 @@ class BaseException(models.AbstractModel):
def _detect_exceptions(self, model_exceptions, def _detect_exceptions(self, model_exceptions,
sub_exceptions): sub_exceptions):
self.ensure_one() self.ensure_one()
import pdb; pdb.set_trace()
exception_ids = [] exception_ids = []
for rule in model_exceptions: for rule in model_exceptions:
if self._rule_eval(rule, self.rule_group, self):
if rule.type == 'by_py_code' and self._rule_eval(
rule, self.rule_group, self):
exception_ids.append(rule.id)
elif rule.type == 'by_domain' and rule.domain:
domain = rule._get_domain()
domain.append(('id', '=', self.id))
if self.search(domain):
exception_ids.append(rule.id) exception_ids.append(rule.id)
if sub_exceptions: if sub_exceptions:
for obj_line in self._get_lines(): for obj_line in self._get_lines():
@ -208,8 +234,15 @@ class BaseException(models.AbstractModel):
# (ex sale order line if obj is sale order) # (ex sale order line if obj is sale order)
continue continue
group_line = self.rule_group + '_line' group_line = self.rule_group + '_line'
if self._rule_eval(rule, group_line, obj_line):
if rule.type == 'by_py_code' and self._rule_eval(
rule, group_line, obj_line):
exception_ids.append(rule.id)
elif rule.type == 'by_domain' and rule.domain:
domain = rule._get_domain()
domain.append(('id', '=', obj_line.id))
if obj_line.search(domain):
exception_ids.append(rule.id) exception_ids.append(rule.id)
return exception_ids return exception_ids
@implemented_by_base_exception @implemented_by_base_exception

8
base_exception/views/base_exception_view.xml

@ -31,7 +31,13 @@
<group colspan="4" col="2" groups="base.group_system"> <group colspan="4" col="2" groups="base.group_system">
<field name="rule_group"/> <field name="rule_group"/>
<field name="model"/> <field name="model"/>
<field name="code"/>
<field name="type"/>
<field name="domain"
attrs="{'invisible': [('type','!=','by_domain')]}
"/>
<field name="code"
attrs="{'invisible': [('type','!=','by_py_code')]}
"/>
</group> </group>
</form> </form>
</field> </field>

Loading…
Cancel
Save