首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将瞬态模型的值传递给One2many - odoo 13 (值错误)

将瞬态模型的值传递给One2many - odoo 13 (值错误)
EN

Stack Overflow用户
提问于 2020-02-26 09:25:56
回答 1查看 1.8K关注 0票数 0

型号:

代码语言:javascript
复制
 class AjaxTimesheet(models.Model):

    _name = "ajax.timesheet" 

timesheet_id = fields.Many2one(comodel_name='ajax.timesheet',string='Timesheet', compute='_compute_timesheet_id')

 @api.depends('created_by')
    def _compute_timesheet_id(self):
        # Compute Timesheet Id for given Timesheet
        for rec in self:
            rec.timesheet_id = rec._origin.id

TransientModel:

代码语言:javascript
复制
 class TimesheetData(models.TransientModel):
        _name = "timesheet.data"
        _description = "Timesheet Data" 

time_task_ids = fields.One2many('ajax.timesheet','timesheet_id',string='Timesheet')



  @api.onchange('created_by','created_date')
            def on_change_created_by(self):

                # list the task in timesheet based on user
                task_ids = self.env['prj.task'].search([('task_assigned_to','=',self.created_by.id),
                                                        ('state','=','ongoing'),('child_ids','=',False)])
                task_list = []
                for task in task_ids:
                    timesheet = self.env['timesheet.timesheet'].search([('task_ids', '=', task.id)])
                    tot_time = 0
                    for i in timesheet:
                        tot_time += i.duration
                    tot_duration = task.task_planned_hours - tot_time
                    vals = {
                        'task_ids': task.id,
                        'created_date': self.created_date,
                        'created_by': self.created_by.id,
                        'prj_project_id':task.prj_project_id.id,
                        'planned_hour': task.task_planned_hours,
                        'task_deadline_date': task.task_deadline_date,
                        'balance_hour': tot_duration,
                        'ref_parent_id':  task.task_assigned_to.parent_id.id,
                    }
                    task_list.append((0, 0, vals))
                self.time_task_ids = task_list

这一行中的错误: self.time_task_ids = task_list ValueError: ajax.timesheet.timesheet_id: timesheet.data(,)的错误值

timesheet.data(,)-我猜对象ID应该是ajax.timesheet模型的,但是这里是来自timesheet.data(,)的,这就是为什么错误值是错误的。修复此错误的任何解决方案。

错误: Odoo Server错误

代码语言:javascript
复制
Traceback (most recent call last):
  File "/home/guru/Documents/odoo-13/odoo/http.py", line 619, in _handle_exception
    return super(JsonRequest, self)._handle_exception(exception)
  File "/home/guru/Documents/odoo-13/odoo/http.py", line 309, in _handle_exception
    raise pycompat.reraise(type(exception), exception, sys.exc_info()[2])
  File "/home/guru/Documents/odoo-13/odoo/tools/pycompat.py", line 14, in reraise
    raise value
  File "/home/guru/Documents/odoo-13/odoo/http.py", line 664, in dispatch
    result = self._call_function(**self.params)
  File "/home/guru/Documents/odoo-13/odoo/http.py", line 345, in _call_function
    return checked_call(self.db, *args, **kwargs)
  File "/home/guru/Documents/odoo-13/odoo/service/model.py", line 93, in wrapper
    return f(dbname, *args, **kwargs)
  File "/home/guru/Documents/odoo-13/odoo/http.py", line 338, in checked_call
    result = self.endpoint(*a, **kw)
  File "/home/guru/Documents/odoo-13/odoo/http.py", line 910, in __call__
    return self.method(*args, **kw)
  File "/home/guru/Documents/odoo-13/odoo/http.py", line 510, in response_wrap
    response = f(*args, **kw)
  File "/home/guru/Documents/odoo-13/addons/web/controllers/main.py", line 1320, in call_kw
    return self._call_kw(model, method, args, kwargs)
  File "/home/guru/Documents/odoo-13/addons/web/controllers/main.py", line 1312, in _call_kw
    return call_kw(request.env[model], method, args, kwargs)
  File "/home/guru/Documents/odoo-13/odoo/api.py", line 395, in call_kw
    result = _call_kw_multi(method, model, args, kwargs)
  File "/home/guru/Documents/odoo-13/odoo/api.py", line 382, in _call_kw_multi
    result = method(recs, *args, **kwargs)
  File "/home/guru/Documents/odoo-13/odoo/models.py", line 6056, in onchange
    record._onchange_eval(name, field_onchange[name], result)
  File "/home/guru/Documents/odoo-13/odoo/models.py", line 5857, in _onchange_eval
    method_res = method(self)
  File "/home/guru/Documents/odoo-13/addons/ajax_timesheet/wizard/wizard_timesheet.py", line 98, in on_change_created_by
    self.time_task_ids = task_list
  File "/home/guru/Documents/odoo-13/odoo/fields.py", line 1068, in __set__
    self.write(new_records, value)
  File "/home/guru/Documents/odoo-13/odoo/fields.py", line 2758, in write
    return self.write_batch([(records, value)])
  File "/home/guru/Documents/odoo-13/odoo/fields.py", line 2782, in write_batch
    return self.write_new(records_commands_list)
  File "/home/guru/Documents/odoo-13/odoo/fields.py", line 3002, in write_new
    line[inverse] = record
  File "/home/guru/Documents/odoo-13/odoo/models.py", line 5598, in __setitem__
    return self._fields[key].__set__(self, value)
  File "/home/guru/Documents/odoo-13/odoo/fields.py", line 1068, in __set__
    self.write(new_records, value)
  File "/home/guru/Documents/odoo-13/odoo/fields.py", line 2467, in write
    cache_value = self.convert_to_cache(value, records)
  File "/home/guru/Documents/odoo-13/odoo/fields.py", line 2400, in convert_to_cache
    raise ValueError("Wrong value for %s: %r" % (self, value))
ValueError: Wrong value for ajax.timesheet.timesheet_id: timesheet.data(<NewId 0x7f498243af98>,)
EN

回答 1

Stack Overflow用户

发布于 2020-02-26 10:16:22

你必须这样做:

代码语言:javascript
复制
new_record = self.env['ajax.timesheet'].create({
 //create record fields;
})

self.env.cr.commit()
task_list.append(new_record.id)

self.update({
    'time_task_ids': (6, 0, task_list)
})
self.env.cr.commit()

因为您正在更新此字段@api.onchange.的值。因此,当您想要更改模型字段的数据时,必须根据场景使用update或write方法。

这就是如何输入价值的方法。

(0,0,{value })链接到需要用给定值字典创建的新记录

(1,ID,{value })使用id = ID更新链接记录(在其上写入值)

(2,ID)用ID = id删除和删除链接的记录(调用ID上的unlink,这将完全删除对象,以及指向对象的链接)

(3,ID)使用id = ID切断链接到链接记录的链接(删除两个对象之间的关系,但不删除目标对象本身)

(4,ID)用id = ID链接到现有记录(添加关系)

(5)取消所有链接(如对所有链接记录使用(3,ID) )

(6,0,ID)替换链接ID列表(如对ID列表中的每个ID使用(5)然后(4,ID))

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60410581

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档