- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的目的
我用 JavaScript 制作了一个带有按钮的小部件。我想修改一个单击此按钮后的 One2many 字段。我的小部件显示在sale.order
表单 View ,我想在点击后修改 O2M order_line
字段。
事实上,我正在尝试模拟 hr_timesheet_sheet 模块的一部分。此模块在 hr_timesheet_sheet.sheet
表单 View 中添加一个小部件,并且还有一个按钮,每次单击该按钮时,O2M timesheet_ids
都会发生变化。
源代码
所以我正在一步步复制该部分,但是我在update_sheets
方法。这是源代码:
update_sheets: function() {
if(this.querying) {
return;
}
this.updating = true;
var commands = [form_common.commands.delete_all()];
_.each(this.get("sheets"), function (_data) {
var data = _.clone(_data);
if(data.id) {
commands.push(form_common.commands.link_to(data.id));
commands.push(form_common.commands.update(data.id, data));
} else {
commands.push(form_common.commands.create(data));
}
});
var self = this;
this.field_manager.set_values({'timesheet_ids': commands}).done(function() {
self.updating = false;
});
},
我的代码:第一次尝试
这是我的:
update_order_line_js: function() {
if(this.querying) {
return;
}
this.updating = true;
var commands = [form_common.commands.delete_all()];
_.each(this.get('order_line_js'), function (_data) {
var data = _.clone(_data);
if(data.id) {
commands.push(form_common.commands.link_to(data.id));
commands.push(form_common.commands.update(data.id, data));
} else {
commands.push(form_common.commands.create(data));
}
});
var self = this;
this.field_manager.set_values({'order_line': commands}).done(function() {
self.updating = false;
});
},
错误
如您所见,我只更改了变量名称,order_line_js
包含 sale.order.line
数据,例如 sheets
包含account.analytic.line
数据。
但是当调用 update_order_line_js
时,以下行会失败:
this.field_manager.set_values({'order_line': commands}).done(function() {
self.updating = false;
});
并向我抛出这个错误:
Unknown field qty_invoiced in domain ["|",["qty_invoiced",">",0],["procurement_ids","!=",[]]]
注意:如果我删除 else
中的 commands.push(form_common.commands.create(data));
行> 语句后,错误消失。
示例
例如,我有一个只有销售订单行的销售订单。该行的 ID 为 28。当我手动向 O2M order_line
添加新行时,会调用 update_order_line_js
并返回错误之前的 commands
内容是下面这个:
[
[5, false, false],
[0, false, {
analytic_tag_ids: [],
customer_lead: 0,
discount: 0,
invoice_status: "no",
layout_category_id: false,
name: "[CONS_DEL03] Basic Computer Dvorak keyboard left-handed mouse",
price_unit: 23500,
procurement_ids: [],
product_id: 32,
product_uom: 1,
product_uom_qty: 1,
qty_delivered: 0,
qty_delivered_updateable: true,
sequence: 13,
state: "draft",
tax_id: []
}],
[4, 28, false],
[1, 28, {
analytic_tag_ids: [],
company_id: [1, "Anubía Soluciones en la Nube, S.L."],
create_date: "2018-10-30 09:03:34",
create_uid: [1, "Administrator"],
currency_id: [1, "EUR"],
customer_lead: 0,
discount: 0,
display_name: "Screen X555",
id: 28,
invoice_lines: [],
invoice_status: "to invoice",
layout_category_id: false,
layout_category_sequence: 0,
name: "Screen X555",
order_id: [11, "SO010"],
order_partner_id: [8, "Agrolait"],
price_reduce: 10,
price_reduce_taxexcl: 10,
price_reduce_taxinc: 12.1,
price_subtotal: 10,
price_tax: 2.1,
price_total: 12.1,
price_unit: 10,
procurement_ids: [],
product_id: [44, "Screen X555"],
product_uom: [1, "Unit(s)"],
product_uom_qty: 1,
qty_delivered: 0,
qty_delivered_updateable: true,
qty_invoiced: 0,
qty_to_invoice: 1,
salesman_id: [1, "Administrator"],
sequence: 12,
state: "sale",
tax_id: [1],
write_date: "2018-10-30 09:03:34",
write_uid: [1, "Administrator"]
}]
]
我猜问题是因为字段 qty_invoiced
位于现有行的字典内,但为什么它会抛出错误?我被这个问题困住了。
我的代码:第二次尝试
我还尝试了一种使用 Python 的方法,即从 JS on_click
调用 Python 方法来更新当前的 One2many 销售订单行:
JS on_click 内容
var sale_order_id = self.field_manager.datarecord.id;
var SaleOrder = new Model('sale.order');
SaleOrder.call(
'test', [sale_order_id],
).then(function(result) {
console.log(result);
});
调用的 Python 方法
@api.model
def test(self, id):
self = self.browse([id])
self.update({
'order_line': [(6, 0, [24, 27])],
})
return True
如您所见,我总是将当前行替换为 ID 为 24 和 27 的现有行(在我的测试数据库中),只是为了尝试该方法。问题是 One2many 字段 View 不会自动重新加载,因此单击 JS 按钮后,我仍然看到旧记录,但是当我单击 Save 按钮时,我看到记录 24 和 27此外,如果我单击放弃按钮,我会收到域错误,并且旧记录将被24和27覆盖,忽略放弃按钮功能。我猜想在 onchange 方法中使用 update
实际上可以实现 write
功能(我无法理解的是域错误)。
我的代码:第三次尝试
正因为如此,我也尝试过,直接在JS中更新O2M order_line
:
self.field_manager.fields['order_line'].viewmanager.views.list.controller.do_delete(
self.field_manager.fields['order_line'].dataset.ids
);
该行效果很好,但现在我需要使用我想要的新数据添加旧记录。我正在搜索如何使用 do_add_record
或 do_edit
,但我仍然不知道它们需要哪些参数,我想知道我是否使事情变得比它们更复杂。
任何人都可以向我推荐一些东西来实现我的需要,或者有人知道为什么我会收到 qty_invoiced
域错误吗?
最佳答案
终于,我找到了解决这个问题的方法,但我不太喜欢它:
update_order_line_js: function() {
var self = this;
if(self.querying) {
return;
}
self.updating = true;
setTimeout(function() {
var commands = [form_common.commands.delete_all()];
_.each(self.get('order_line_js'), function (_data) {
var data = _.clone(_data);
if(data.id) {
commands.push(form_common.commands.link_to(data.id));
commands.push(form_common.commands.update(data.id, data));
} else {
data['qty_invoiced'] = 0;
data['procurement_ids'] = [];
commands.push(form_common.commands.create(data));
}
});
self.field_manager.set_values({'order_line': commands}).done(function() {
self.updating = false;
});
}, 500)
},
如果该记录尚不存在,则生成该记录的数据必须包含字段qty_invoiced
。为什么?我不太清楚。添加该行后,问题就消失了,但随后我遇到了最难以理解的错误,即无法获取未定义的属性集......经过大量调查后,我发现异步JS 是一个问题,我必须添加 setTimeout
。之后,一切都运行正常,至少在我的电脑上是这样。但在某些特定情况下,我收到错误域中的未知字段采购_ids ["|",["qty_invoiced",">",0],["procurement_ids","!=",[]]],这与让我问这个问题的问题基本相似,所以我以同样的方式修复了它。
这三种解决方案都不适合我,但至少我能够继续我的工作。
关于javascript - 如何从 Odoo 10 中的 JS 函数更新 One2many 字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53154250/
在有些场景下,我们需要对我们的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 数据库来保存我的房地产经纪人的列表。我已经能够使用外键来识别每个代理的列表,但我想在每个代理的记录中创建一个列表;从代理商和列表之间的一对一关系转变为一对多关系。 看这里
我是一名优秀的程序员,十分优秀!