如何在odoo中为one2many字段编写域过滤器onchange函数?

时间:2015-11-27 08:24:08

标签: python openerp

在下面的例子中,我写了 def onchange_insp(self,cr,uid,id,folionum,context = None)函数,但在&strong>中的 inspec_type #39; feedback.tree' 无效。

    from openerp.osv import fields, osv
    from openerp import api
    import logging

    class feedback_form(osv.Model):
        _name = 'feedback.form'

        _columns = {
            'company_id111': fields.many2one('res.company', 'Substation', required=True),

            'folionum' : fields.many2one('calendar.event','Maintenance ID',),
            'folio_number' : fields.many2one('asset.asset','Folio number',),
            # this field is filtering properly
            'inspec_type' : fields.many2one('asset1.inspection','Inspection Type',),

            'frequency' : fields.char('Frequency'),
            'shutdown' : fields.char('Shut Down'),
            #'insp_msr1' : fields.many2one('results.measure','Result',),

            'insp_rslt' : fields.one2many('feedback.tree','insp_rsltts','Inspection Result',),

        }


        def onchange_insp(self, cr, uid, ids, folionum,context=None):
            dids = []
            res = {}
            for record in self.pool.get('calendar.event').browse(cr, uid, folionum, context=context):
                dids = [x.id for x in record.inspection_name]
            dids1 = []
            for record in self.pool.get('calendar.event').browse(cr, uid, folionum, context=context):
                dids1 = [x.id for x in record.folio_num1]
            res.update({'inspec_type':[('id','in',dids)]})

            res.update({'folio_number':[('id','in',dids1)]})

            return {'domain':res}


    feedback_form()

    class feedback_tree(osv.Model):
        _name = 'feedback.tree'


        _columns = {
            **# How to do this for this field please reply me soon**
            'inspec_type' : fields.many2one('asset1.inspection','Inspection Type',),
            'valuess' : fields.char('Values/Results'),
            'insp_rsltts': fields.many2one('feedback.form','Result Id'),
            'insp_msr1' : fields.many2one('results.measure','Result',),
        }



        def onchange_measure(self, cr, uid, ids, inspec_type, context=None):
            dids = []
            for record in self.pool.get('asset1.inspection').browse(cr, uid, inspec_type, context=context):
                dids = [x.id for x in record.msr_insp]
            return {'domain':{'insp_msr1':[('id','in',dids)]}}

    feedback_tree()

2 个答案:

答案 0 :(得分:1)

使用版本odoo 10.0

  

适用于one2many和many2many的解决方案:)

class res_partner(models.Model):     _inherit =“res.partner”

sb_sector_id = fields.Many2one('sb.business_sector',string="Business Sector" )
sb_categories_id = fields.Many2many('sb.business_categories','rel_sb_business_cates','confirm_id','status_id', string='Business Categories', required=False)

sb_activity_id = fields.Many2many('sb.business_activties','rel_sb_business_activties','confirm_id','status_id', string='Neclamenture of activities', required=False)


@api.onchange('sb_sector_id')
def onchange_sb_sector_id(self):
    return {'domain':{'sb_categories_id':[('sector_id','=',self.sb_sector_id.id if self.sb_sector_id else False)]}}

主要是作为回报,您必须使用字段编写域并提供域值。

return {'domain':{'sb_categories_id':[('sector_id','=',self.sb_sector_id.id if self.sb_sector_id else False)]}}

答案 1 :(得分:0)

您可以尝试this link

示例

'insp_rslt' : fields.one2many('feedback.tree','insp_rsltts','Inspection Result', domain=[('valuess', '=', 'as u like string')])