如何使用函数过滤域视图?在 odoo 9
How to filter a domain view with a function? In odoo 9
我想用一个函数而不是一个变量来过滤一个域,以便在视图中只显示一些寄存器。
我这样做了:
class SaleOrderExt(models.Model):
_inherit = ['sale.order']
@api.multi
def custom_funct_date(self):
my_date = ... (some stuff)
return my_date
然后,在视图中,我过滤了域:
<?xml version="1.0"?>
<openerp>
<data>
<record id='action_menu_custom_date' model='ir.actions.act_window'>
<field name="name">This is a test</field>
<field name="res_model">sale.order</field>
<field name="view_type">form</field>
<field name="view_mode">tree,form</field>
<field name="domain">[('date_order','>=',custom_funct_date)]</field>
</record>
</data>
</openerp>
但这给我一个错误:
ValueError: "name 'custom_funct_date' is not defined" while evaluating
u"[('date_order','>=',custom_funct_date)]"
在域中,您需要传递一个字段而不是函数名。
为此,您可以创建一个计算字段。将您的方法分配给计算字段。
为计算字段指定搜索属性后。
Odoo 示例:
upper_name = field.Char(compute='_compute_upper', search='_search_upper')
def _search_upper(self, operator, value):
if operator == 'like':
operator = 'ilike'
return [('name', operator, value)]
你的情况:
class SaleOrderExt(models.Model):
_inherit = ['sale.order']
your_date = fields.Datetime(string="Computed date", compute="compute_your_date", search="_search_date")
@api.depends('date')
def compute_your_date(self):
my_date = ... (some stuff)
return my_date
def _search_date(self, operator, value):
return [('date', operator, value)]
编辑:
你的 xml 代码必须是这样的
<?xml version="1.0"?>
<openerp>
<data>
<record id='action_menu_custom_date' model='ir.actions.act_window'>
<field name="name">This is a test</field>
<field name="res_model">sale.order</field>
<field name="view_type">form</field>
<field name="view_mode">tree,form</field>
<field name="domain">[('date_order','>=',your_date)]</field>
</record>
</data>
</openerp>
而不是使用 ir.actions.act_window 使用 ir.actions.server 使用服务器操作
你可以调用你的函数和 return 一个动作来使用你的计算打开你的模型
域名。
<record id="action_menu_custom_dat" model="ir.actions.server">
<field name="name">Your Action</field>
<field name="model_id" ref="sale.model_sale_order"/>
<field name="state">code</field>
<field name="code">action = self.custom_funct_date(cr, uid, context=context)</field>
<field eval="True" name="condition"/>
</record>
并在您的模型中将方法更改为:
def custom_funct_date(self, cr, uid, context=None):
# print "make sure that this action is called from th server action "
# compute you date
my_date = ... (some stuff)
tree_id = self.env.ref("modul_name.view_tree_id")
form_id = self.env.ref("modul_name.view_form_id")
return {
'type': 'ir.actions.act_window',
'name': 'This is a test',
'view_type': 'form',
'view_mode': 'tree,form',
'res_model': 'sale.order',
'domain': [('date_order','>=',my_date)],
# if you don't want to specify form for example
# (False, 'form') just pass False
'views': [(tree_id.id, 'tree'), (form_id.id, 'form')],
'target': 'current',
'context': context,
}
自上次回答以来已经有很多次了,但它可能对其他人有用。
我在 res.partner 继承视图中遇到了类似的问题,我就是这样解决的。在这种情况下,我需要用户成为访问其数据的合作伙伴或管理员以在笔记本部分显示合作伙伴的数据。
型号:
class Partner(models.Model):
_inherit = 'res.partner'
@api.multi
def _get_domain(self):
# Remember that self returns a recordset, so we need to iterate over that
# dominio (domain in english) -boolean- store if the user is the partner or the admin
for rec in self:
rec.dominio = True if self.id == self.env.user.partner_id.id or self.env.user.has_group('cnae.group_cnae_manager') else False
dominio = fields.Boolean(string='Dominio', compute=_get_domain)
XML:
... ir.ui.view header record stuff ...
<!-- Hide notebook to other users -->
<xpath expr="//notebook" position="attributes">
<attribute name="attrs">{'invisible':[('dominio','=',False)]}</attribute>
</xpath>
我想用一个函数而不是一个变量来过滤一个域,以便在视图中只显示一些寄存器。 我这样做了:
class SaleOrderExt(models.Model):
_inherit = ['sale.order']
@api.multi
def custom_funct_date(self):
my_date = ... (some stuff)
return my_date
然后,在视图中,我过滤了域:
<?xml version="1.0"?>
<openerp>
<data>
<record id='action_menu_custom_date' model='ir.actions.act_window'>
<field name="name">This is a test</field>
<field name="res_model">sale.order</field>
<field name="view_type">form</field>
<field name="view_mode">tree,form</field>
<field name="domain">[('date_order','>=',custom_funct_date)]</field>
</record>
</data>
</openerp>
但这给我一个错误:
ValueError: "name 'custom_funct_date' is not defined" while evaluating
u"[('date_order','>=',custom_funct_date)]"
在域中,您需要传递一个字段而不是函数名。
为此,您可以创建一个计算字段。将您的方法分配给计算字段。
为计算字段指定搜索属性后。
Odoo 示例:
upper_name = field.Char(compute='_compute_upper', search='_search_upper')
def _search_upper(self, operator, value):
if operator == 'like':
operator = 'ilike'
return [('name', operator, value)]
你的情况:
class SaleOrderExt(models.Model):
_inherit = ['sale.order']
your_date = fields.Datetime(string="Computed date", compute="compute_your_date", search="_search_date")
@api.depends('date')
def compute_your_date(self):
my_date = ... (some stuff)
return my_date
def _search_date(self, operator, value):
return [('date', operator, value)]
编辑:
你的 xml 代码必须是这样的
<?xml version="1.0"?>
<openerp>
<data>
<record id='action_menu_custom_date' model='ir.actions.act_window'>
<field name="name">This is a test</field>
<field name="res_model">sale.order</field>
<field name="view_type">form</field>
<field name="view_mode">tree,form</field>
<field name="domain">[('date_order','>=',your_date)]</field>
</record>
</data>
</openerp>
而不是使用 ir.actions.act_window 使用 ir.actions.server 使用服务器操作 你可以调用你的函数和 return 一个动作来使用你的计算打开你的模型 域名。
<record id="action_menu_custom_dat" model="ir.actions.server">
<field name="name">Your Action</field>
<field name="model_id" ref="sale.model_sale_order"/>
<field name="state">code</field>
<field name="code">action = self.custom_funct_date(cr, uid, context=context)</field>
<field eval="True" name="condition"/>
</record>
并在您的模型中将方法更改为:
def custom_funct_date(self, cr, uid, context=None):
# print "make sure that this action is called from th server action "
# compute you date
my_date = ... (some stuff)
tree_id = self.env.ref("modul_name.view_tree_id")
form_id = self.env.ref("modul_name.view_form_id")
return {
'type': 'ir.actions.act_window',
'name': 'This is a test',
'view_type': 'form',
'view_mode': 'tree,form',
'res_model': 'sale.order',
'domain': [('date_order','>=',my_date)],
# if you don't want to specify form for example
# (False, 'form') just pass False
'views': [(tree_id.id, 'tree'), (form_id.id, 'form')],
'target': 'current',
'context': context,
}
自上次回答以来已经有很多次了,但它可能对其他人有用。
我在 res.partner 继承视图中遇到了类似的问题,我就是这样解决的。在这种情况下,我需要用户成为访问其数据的合作伙伴或管理员以在笔记本部分显示合作伙伴的数据。
型号:
class Partner(models.Model):
_inherit = 'res.partner'
@api.multi
def _get_domain(self):
# Remember that self returns a recordset, so we need to iterate over that
# dominio (domain in english) -boolean- store if the user is the partner or the admin
for rec in self:
rec.dominio = True if self.id == self.env.user.partner_id.id or self.env.user.has_group('cnae.group_cnae_manager') else False
dominio = fields.Boolean(string='Dominio', compute=_get_domain)
XML:
... ir.ui.view header record stuff ...
<!-- Hide notebook to other users -->
<xpath expr="//notebook" position="attributes">
<attribute name="attrs">{'invisible':[('dominio','=',False)]}</attribute>
</xpath>