odoo 中 many2one 字段的域过滤器?

domain filter for many2one fields in odoo?

下面的代码是资产继承class。在这里我将添加 'place' 字段 'Karn/Bang/Kengeri''karn/bang/malleshwaram' for 'Karn/Bang/Kengeri' 将添加 'asset_catg_id' 与 A 和 B. 然后 for 'karn/bang/malleshwaram' 与 Y 和 Z.

现在在calander继承class。如果我 select 'place''Karn/Bang/Kengeri' 那么下一个字段 'asset_catg_id' 我只需要 A 和 B 下拉列表。如果再次 'karn/bang/malleshwaram' 那么我只能得到 Y,Z 选项。和以前的 selected 'asset_catg_id' 值应该被删除。我尝试使用域过滤器选项得到 keyvalue error

class asset_asset(osv.osv):
    _inherit = "asset.asset"
    #_name = "asset_asset"
    _rec_name= "folio_num"
    _columns = {
        'name': fields.char('Asset Name', size=64),
        'place': fields.many2one('asset.parentlocation', 'Location'),
        'asset_catg_id' : fields.many2one('asset.catg', 'Asset Catg Selection', select=True, required=True),}

class asset_catg(osv.Model): 
    _name="asset.catg" 
    _rec_name='name1'
    _description="Define Asset Catgs" 
    _columns={ 'name1':fields.char('Asset Catg Names',size=64,required=True),}
asset_catg()
class asset_parentlocation(osv.osv):
    _name="asset.parentlocation"
    _rec_name="location_name"
    _columns = {
        'location_name' : fields.char('Asset Location', required=True),
        'parent_location' : fields.many2one('asset.parentlocation','Parent Location'),
        'nameee':fields.many2one('ir.attachment','Attachments'),}

    def name_get(self, cr, uid, ids, context=None):
        if context is None:
            context = {}
        if not ids:
            return []
        reads = self.read(cr, uid, ids, ['location_name','parent_location'], context=context)
        res = []
        for record in reads:
            name = record['location_name']
            if record['parent_location']:
                name = record['parent_location'][1]+' / '+name
            res.append((record['id'], name))
        return res



**Following code is calendar inherited class** 


class calendar_event(osv.osv):

    _inherit = "calendar.event"
    _rec_name = 'number'

    _columns = {
            'number' : fields.char('Meeting ID',readonly=1),
            #'place' : fields.many2one('stock.location','Substation Location',),

            'place' : fields.many2one('asset.parentlocation','Substation Location',),
            #'location' : fields.selection(STATUS_SELECTION,'Location',  default='Board A'),
            'asset_catg_id' : fields.many2one('asset.catg','Asset Catg Selection', domain="[('asset_catg_id', '=',place)]"),}

首先你的域在原则上是错误的。域是 "inside" 字段,换句话说在它的模型中(例如 asset.catg 模型中的字段 nameid)。所以你应该先修复那个。

如果域依赖于另一个字段,您可以使用 onchange 方法来 return 域(使用占位符 place_id)。像这样:

@api.onchange('place')
def onchange_place(self):
    res = {}
    if self.place:
        res['domain'] = {'asset_catg_id': [('place_id', '=', self.place.id)]}
    return res

P.S. 这是新 v8 api 的示例,但同样的原则适用于旧 api(你不需要需要使用装饰器,还要在方法上添加 cr, uid, ids 并通过您的视图调用它。新的 api 不需要所有这些)。看起来你还在开发旧的 api.

更新 对于旧 api:

def onchange_place(self,cr, uid, ids, place, context=None):
    res = {}
    if self.place: #on old api it will return id, instead of record
        res['domain'] = {'asset_catg_id': [('place_id', '=', self.place)]}
    return res

然后在你的视图中(不知道你用的是什么视图):

<field name="place" on_change="onchange_place(place)"/>

您仍然需要在 asset.catg 中定义一些字段,以便用于匹配 place 字段。例如:

'place_id': fields.many2one('asset.parentlocation', 'Place')

然后当你定义资产类别时,你设置它应该属于哪个地方。然后,当您选择地点 calendar.event 时,onchange 方法将在 asset_catg_id 字段上正确设置域。