跳转至内容
  • 版块
  • 标签
  • 热门
  • 用户
  • 群组
皮肤
  • 浅色
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • 深色
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • 默认(Flatly)
  • 不使用皮肤
折叠

Odoo 中文社区

  1. 主页
  2. 版块
  3. Odoo 开发与实施交流
  4. One2many字段domain实现, 并使用filter视图中的变量

One2many字段domain实现, 并使用filter视图中的变量

已定时 已固定 已锁定 已移动 Odoo 开发与实施交流
3 帖子 2 发布者 3.9k 浏览 1 关注中
  • 从旧到新
  • 从新到旧
  • 最多赞同
回复
  • 在新帖中回复
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • T 离线
    T 离线
    t11t11
    发表于 最后由 编辑
    #1

    [size=14pt]新类
    class my_model(osv.osv):
        _name = "my.model"
        _description = 'abc'
     
        _columns = {
            'product_id': fields.many2one('product.product', u'产品'),
            'move_in': fields.many2one('stock.move', u'入库记录'),
            'location_id': fields.many2one('stock.location', u'在库库位'),
          .........................
    }
    my_model()

    产品类
    class product_product(osv.Model):
        _inherit = 'product.product'   
        _columns = {
            'my_model': fields.one2many('my.model', 'product_id', u'my_model', domain=['&',('move_in','!=',False),('move_in.state','=','done')]),
        }
    product_product()
    [b]本站有贴子说有one2many的domain只能在py文件中实现, 不能在xml文件中实现.[/b]

    [b]视图文件不变, 现在再修改py文件如下:[/b]
    class product_product(osv.Model):
        _inherit = 'product.product'
        _columns = {
            'my_field': fields.function(_get_juan, method=True, string = u'分卷', type='one2many',relation='my_model'),
            }
    product_product()


        def _get_juan(self, cr, uid, ids, name, arg, context=None):
            res = {}
            jids = []
            obj = self.pool.get('my_model')

            for product in self.browse(cr,uid,ids):
                if context.get('location', False):
                        location_ids = [context['location']]
                else:
                      location_ids = ........

                args = [('product_id','=',product.id)]
                args += [('location_id','in',location_ids)]
                res[product.id] = obj.search(cr,uid,args)

            return res[/size]

    1 条回复 最后回复
    0
    • M 离线
      M 离线
      mrshelly
      发表于 最后由 编辑
      #2

      感谢分享............

      1 条回复 最后回复
      0

      你好!看起来您对这段对话很感兴趣,但您还没有一个账号。

      厌倦了每次访问都刷到同样的帖子?您注册账号后,您每次返回时都能精准定位到您上次浏览的位置,并可选择接收新回复通知(通过邮件或推送通知)。您还能收藏书签、为帖子顶,向社区成员表达您的欣赏。

      有了你的建议,这篇帖子会更精彩哦 💗

      注册 登录
      回复
      • 在新帖中回复
      登录后回复
      • 从旧到新
      • 从新到旧
      • 最多赞同


      • 登录

      • 没有帐号? 注册

      • 登录或注册以进行搜索。
      • 第一个帖子
        最后一个帖子
      0
      • 版块
      • 标签
      • 热门
      • 用户
      • 群组