
Odoo中文社区可以通过以下两个域名访问:shine-it.net , odoo.net.cn
由于系统升迁的原因,本论坛部分较早期的内容存在格式和链接损坏失效的问题,并非本论坛系统本身的缺陷,望谅解
本社区没有维护任何QQ群讨论组,任何与本社区同名的QQ群讨论组的言论与本社区无关!
开发人员可以登录gitter讨论组: http://gitter.im/odoo-china/Talk, 需要github账号
如果您登录系统碰到问题,请在微信公众号留言:
想实现一个根据产品作为BOM的原料而生成的所有产品列表的查询
-
需求:
在产品tree列表中添加一个按钮,选中一个点击该按钮,弹出新窗口,显示以选中的产品作为BOM中原料的产品列表。例如,产品A作为产品B的BOM中的原料,在产品列表中选中A,点击按钮,就列出所有以A作为原料的产品列表,最好还是用产品tree列表显示。看大家有什么思路? -
我打算实现在一个产品的form页面点击一个按钮,执行一个action,调出产品tree_view,显示用该产品作为Bom原料的所有产品的列表。
我的思路是,新建一个model,继承product.product,添加一个函数,负责查询当前产品id在mrp_bom里作为原料的所有产品的ids,继承product_tree_view来显示这些产品。但是怎样显示,大家能否提供思路 -
使用 Wizard 做了一个 demo 你下载去参考看看.
在产品页右边有个 "Relation Product" wizard , 点击后就可以看到使用这个产品的相关产品 -
mrshelly的wizard解法很有启发,感谢啊。我用function field的fnct_search实现了相同的功能。参见附件
想把mrshelly的wizard转成osv_memory的,想不出解法,哪位兄弟能提供思路,先谢了。 -
人来疯,再来一个解法,直接覆写search方法:
<br />from osv import osv, fields<br /><br />class product_product(osv.osv):<br /><br /> _inherit = 'product.product'<br /><br /> def search(self, cr, uid, args=None, offset=0, limit=None, order=None,<br /> context=None, count=False):<br /> if context is None:<br /> context = {}<br /><br /> if context.get('related_product') and context.get('active_ids'):<br /> bom_obj = self.pool.get('mrp.bom')<br /> product_bom = bom_obj.search(cr,uid, [('product_id', 'in', context['active_ids'])])<br /> parent_bom = [bom.bom_id.id for bom in<br /> bom_obj.browse(cr,uid, product_bom) if bom.bom_id.id]<br /> rel_ids = [bom.product_id.id for bom in bom_obj.browse(cr, uid, parent_bom)]<br /> args.append(('id', 'in', rel_ids))<br /> return super(product_product, self).search(cr,uid,args,offset,limit,<br /> order,context=context, count=count)<br /><br /> return super(product_product, self).search(cr,uid,args,offset,limit,<br /> order,context=context, count=count)<br />product_product()
``` <?xml version="1.0" encoding="utf-8"?>
<openerp>
<data>
<act_window name="Related Products"
context="{'related_product':1}"
res_model="product.product"
src_model="product.product"
view_mode="tree,form"
key2="client_action_multi"
id="action_related_products2"/>
</data>
</openerp>
``` -
Niubility
-
写代码没注释,看不懂。痛扁这个唐僧
-
看来使用 context 可以玩很多定制 检索的 查询显示... 8错, 8错....
Niubility! -
[quote author=digitalsatori link=topic=2059.msg6401#msg6401 date=1276075829]
mrshelly的wizard解法很有启发,感谢啊。我用function field的fnct_search实现了相同的功能。参见附件
想把mrshelly的wizard转成osv_memory的,想不出解法,哪位兄弟能提供思路,先谢了。
[/quote]
这个代码挺好的,谁能够详细解释下么,
特别是context['active_ids']
这个怎么使用的问题
不胜感激啊,新手需要指点
mrshelly的指点:tree view 中, 选中记录的 id 值会保存到 context['active_ids'] 中。 -
mark