- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想在 Odoo 8 中的 Many2one 字段上进行过滤。这是用于库存模块的。
我创建了额外的字段,用户可以在其中输入附加信息。现在我们要过滤下拉列表中显示的可用字段,或者单击“更多”按钮时仅显示该产品的附加字段。
这是stock.Production.lot模型的代码当product_id更新时,应该更改域过滤器。
class StockProductionLot(models.Model):
_inherit = "stock.production.lot"
lot_lot_additional_fields = fields.One2many("lot.lot.additional.fields", "stock_production_lot")
@api.onchange("product_id")
def onchange_product_id(self):
res = {}
cat_fields = self.product_id.categ_id.lot_fields_category.lot_additional_fields
ids = []
for item in cat_fields:
ids.append(item.id)
if self.product_id:
res["domain"] = {"lot_additional_fields": [("id", "in", "ids")]}
return res
这是将附加字段模型连接到批号模型的模型。lot_additional_fields 应在此处更新。
class LotLotAdditionalFields(models.Model):
_name = "lot.lot.additional.fields"
value = fields.Char("Value")
stock_production_lot = fields.Many2one("stock.production.lot", string="Lot/Serial Number")
lot_additional_fields = fields.Many2one("lot.additional.fields", string="Additional field")
如果有人能帮助我解决这个问题,我将非常感激。
========================编辑====================== ======
我已将代码添加到 stock.Production.lot
class StockProductionLot(models.Model):
_inherit = "stock.production.lot"
lot_lot_additional_fields = fields.One2many("lot.lot.additional.fields", "stock_production_lot")
lot_additional_fields = fields.Many2one("lot.additional.fields", string="Lot additional fields")
remarks = fields.Html("General remarks")
@api.onchange('product_id')
def onchange_product_id(self):
res = {}
if self.product_id:
ids = self.product_id.categ_id.lot_fields_category.lot_additional_fields.mapped('id')
res['domain'] = {'lot_lot_additional_fields': [('lot_additional_fields', 'in', ids)]}
return res
在lot.additional.fields中我添加了product_id:
class LotAdditionalFields(models.Model):
_name = "lot.additional.fields"
name = fields.Char("Name", required=True)
type = fields.Selection(
[("int", "Numerical"), ("string", "Alfanumerical"), ("boolean", "Checkbox"), ("date", "Date")], required=True)
mandatory = fields.Boolean("Mandatory field")
display_order = fields.Integer("Display Order")
lot_field_category = fields.Many2many("lot.field.category", string="Field Category", required=True)
lot_lot_additional_fields = fields.One2many("lot.lot.additional.fields", "lot_additional_fields")
product_id = fields.Many2one("product.product", string="Product ID")
lot_lot_additional_fields 我留下了相同的:
class LotLotAdditionalFields(models.Model):
_name = "lot.lot.additional.fields"
value = fields.Char("Value")
stock_production_lot = fields.Many2one("stock.production.lot", string="Lot/Serial Number")
lot_additional_fields = fields.Many2one("lot.additional.fields", string="Additional field")
我还将添加 xml 代码:
<record id="view_production_lot_form" model="ir.ui.view">
<field name="name">Stock Production Lot Form</field>
<field name="model">stock.production.lot</field>
<field name="inherit_id" ref="stock.view_production_lot_form"/>
<field name="arch" type="xml">
<page string="Products" position="after">
<page string="Additional Fields">
<field name="lot_lot_additional_fields" >
<tree editable="bottom">
<field name="lot_additional_fields" />
<field name="value"/>
</tree>
</field>
<h3>General remarks</h3>
<field name="remarks"/>
</page>
</page>
</field>
</record>
最佳答案
您必须考虑到 res["domain"] = {"lot_additional_fields": [("id", "in", "ids")]}
行中的内容您正在更改模型的域 stock.production.lot
,顺便说一句,似乎没有任何名为 lot_additional_fields
的字段(它有一个名为 lot_lot_additional_fields
的字段)。
@api.onchange('product_id')
def onchange_product_id(self):
res = {}
if self.product_id:
ids = self.product_id.categ_id.lot_fields_category.lot_additional_fields.mapped('id')
res['domain'] = {'lot_lot_additional_fields': [('lot_additional_fields', 'in', ids)]}
return res
我正在阅读您的代码,现在我确信我在这里编写的代码是您想要在尝试中获得的正确代码。但是,我没有任何有关 View 和类的信息 lot.additional.fields
,仅关于stock.production.lot
和lot.lot.additional.fields
,我想(如果我很好地理解你想要什么)这不会起作用(修改 View 中的域不会修改其他不同 View 的域),除非你有 Many2one
字段指向 product_id
在 lot.additional.fields
类(我在这里看不到)。
编辑
好的,如果我错了,请先纠正我:在你的 stock_production_lot
中表单 View 中,您看到字段lot_lot_additional_fields
的树。在这里,如果您打开字段 lot_additional_fields
的下拉菜单,您只希望能够选择那些 lot_additional_fields
属于同一个lot_fields_category
categ_id
的product_id
的当前stock_production_lot
,不是吗?
在这种情况下,请尝试以下代码:
Python(将此 onchange 放入您的 lot.lot.additional.fields
类中)
@api.onchange('stock_production_lot')
def onchange_stock_production_lot(self):
res = {}
if stock_production_lot:
ids = self.stock_production_lot.product_id.categ_id.lot_fields_category.lot_additional_fields.mapped('id')
res['domain'] = {
'lot_additional_fields': [('id', 'in', ids)]}
}
return res
XML(修改您的 view_production_lot_form
代码并编写此代码)
<record id="view_production_lot_form" model="ir.ui.view">
<field name="name">Stock Production Lot Form</field>
<field name="model">stock.production.lot</field>
<field name="inherit_id" ref="stock.view_production_lot_form"/>
<field name="arch" type="xml">
<page string="Products" position="after">
<page string="Additional Fields">
<field name="lot_lot_additional_fields" widget="one2many_list" context="{'default_stock_production_lot': active_id}">
<tree editable="bottom">
<field name="stock_production_lot" invisible="1"/>
<field name="lot_additional_fields"/>
<field name="value"/>
</tree>
</field>
<h3>General remarks</h3>
<field name="remarks"/>
</page>
</page>
</field>
</record>
关于python - Many2one 字段上的 Odoo 8 域过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32068611/
在有些场景下,我们需要对我们的varchar类型的字段做修改,而修改的结果为两个字段的拼接或者一个字段+字符串的拼接。 如下所示,我们希望将xx_role表中的name修改为name+id。
SELECT incMonth as Month, SUM( IF(item_type IN('typ1', 'typ2') AND incMonth = Month, 1, 0 ) )AS
我最近读到 volatile 字段是线程安全的,因为 When we use volatile keyword with a variable, all the threads read its va
我在一些模型中添加了一个 UUID 字段,然后使用 South 进行了迁移。我创建的任何新对象都正确填充了 UUID 字段。但是,我所有旧数据的 UUID 字段为空。 有没有办法为现有数据填充 UUI
刚刚将我的网站从 mysql_ 更新为 mysqli,并破坏了之前正常运行的查询。 我试图从旋转中提取 id,因为它每次都会增加 1,但我不断获取玩家 id,有人可以告诉我我做错了什么吗?我尝试了将
我在 Mac OS X 上使用带有 Sequel Pro 的 MySQL。我想将一个表中的一个字段(即名为“GAME_DY”的列)复制到另一个名为“DAY_ID”的表的空字段中。两个表都是同一数据库的
问题: 是否有可能有一个字段被 JPA 保留但被序列化跳过? 可以实现相反的效果(JPA 跳过字段而序列化则不会),如果使用此功能,那么相反的操作肯定会很有用。 类似这样的事情: @Entity cl
假设我有一个名为“dp”的表 Year | Month | Payment| Payer_ID | Payment_Recipient | 2008/2009 | July
我将尝试通过我的 Raspberry Pi 接入点保证一些 QoS。 开始之前,我先动手:我阅读了有关 tcp、udp 和 ip header 的内容。在IP header description我看
如果你能弄清楚如何重命名这个问题,我愿意接受建议。 在 Dart 语言中,可以编写一个带有 final 字段的类。这些是只能设置的字段构造函数前 body 跑。这可以在声明中(通常用于类中的静态常量)
你怎么样? 我有两个带有两个字段的日期选择器 我希望当用户选择 (From) 时,第二个字段 (TO) 将是 next day 。比如 booking.com 例如:当用户选择From 01-01-2
我想我已经看到了这个问题的一些答案,这些答案可能与我需要的相差不远,但我对 mysql 的了解还不够确定,所以我会根据我的具体情况提出问题。 我有一个包含多个表的数据库,为此,如果“image”表上的
我在 mySQL 数据库中有 2 个表: customers ============ customer_id (1, 2 ) customer_name (john, mark) orders ==
我正在开发一个员工目标 Web 应用程序。 领导/经理在与团队成员讨论后为他们设定目标。这是一年/半年/季度,具体取决于组织遵循的评估周期。 现在的问题是添加基于时间段的字段或存档上一季度/年度数据的
我正在寻找允许内容编辑器从媒体库中选择多个文件的东西,这些文件将在渲染中列出。他们还需要能够上传文件和搜索。它必须在页面编辑器(版本 8 中称为体验编辑器)中工作。 到目前为止我所考虑的: 一堆文件字
现在,我有以下由 original.df %.% group_by(Category) %.% tally() %.% arrange(desc(n)) 创建的 data.frame。 DF 5),
我想知道是否有一些步骤/解决方案可以处理错误消息并将它们放入 Pentaho 工具中的某个字符串或字段中?例如,如果连接到数据库时发生某些错误,则将该消息从登录到字符串/字段。 最佳答案 我们在作业的
如何制作像短信应用程序一样的“收件人”字段?例如,右侧有一个“+”按钮,当添加某人时,名称将突出显示并可单击,如圆角矩形等。有没有内置的框架? 最佳答案 不,但请参阅 Three20 的 TTMess
是否可以获取记录的元素或字段的列表 通过类型信息类似于类的已发布属性的列表吗? 谢谢 ! 最佳答案 取决于您的delphi版本,如果您使用的是delphi 2010或更高版本,则可以使用“新rtti”
我正在构建一个 SQLite 数据库来保存我的房地产经纪人的列表。我已经能够使用外键来识别每个代理的列表,但我想在每个代理的记录中创建一个列表;从代理商和列表之间的一对一关系转变为一对多关系。 看这里
我是一名优秀的程序员,十分优秀!