odoo-054 one2many 字段新增时检查上一行某个字段是否填写

文章目录

需求描述

客户要求在 one2many 字段 job_lines 新增一行记录的时候要检查,上一行记录中的 datetime 字段 in_dt 是否填写,没有填写就警告不允许新增。

实现方法

一、在write()保存的时候检查

python 复制代码
def check_job_lines(self, job_lines):
    exist_in_dt = {}
    for i in self.job_lines:
        if str(i.id) not in exist_in_dt and i.in_dt:
            exist_in_dt[str(i.id)] = i.in_dt
    exist_create_date = False
    del_line = 0
    for w in job_lines:
        crud = w[0]
        if crud == 0:  # create
            exist_create_date = True
        elif crud == 1:  # update
            update_id = w[1]
            if 'in_dt' in w[2]:
                in_dt = w[2].get('in_dt', False)
                # 如果修改 in_dt 置空
                if in_dt:
                    exist_in_dt[str(update_id)] = in_dt
                else:
                    exist_in_dt.pop(str(update_id), None)
        elif crud == 2:  # delete
            update_id = w[1]
            # 如果删除 line 处理
            exist_in_dt.pop(str(update_id), None)
            del_line += 1
    if exist_create_date:
        if len(exist_in_dt.keys()) != (len(self.job_lines) - del_line):
            raise UserError(_('Please write  job order\'s In Datetime first!'))

然后在 write 方法中调用该方法。

二、onchange 在点击的时候直接提示

python 复制代码
@api.onchange('job_lines')
def onchange_job_lines(self):
    old_lines = []
    new_lines = []
    for i in self.job_lines:
        if not i._origin.id:
            new_lines.append(i)
        else:
            old_lines.append(i)
    if not old_lines:  # create lines first
        return True

    if len(new_lines) == 1:
        recent_lines = old_lines[-1]
        if not recent_lines.in_dt:
            return {
                'warning': {
                    'title': "Warning",
                    'message': "Please fill in the in_dt of the previous record first!",
                },
                'value': {'job_lines': [(6, 0, self.warranty_job_lines.ids)]}
            }
    else:
        for n in new_lines[1:]:
            if not n.in_dt:
                return {
                    'warning': {
                        'title': "Warning",
                        'message': "Please fill in the in_dt of the previous record first!",
                    },
                    'value': {'job_lines': [(6, 0, self.job_lines.ids)]}
                }

此方法有个bug

如果是同时添加两条记录的时候,同时第一条记录的 in_dt 没有填写,这时候应该是保留第一条记录,但是现在是会把新增的都给清空,这个是不是js才能解决。

相关推荐
AI视觉网奇44 分钟前
麒麟系统播放图片 速度比较
开发语言·python·pygame
言之。1 小时前
Django REST框架核心:GenericAPIView详解
数据库·python·django
这里有鱼汤1 小时前
别傻了,这些量化策略AI 10 秒就能帮你写好
后端·python
胡耀超1 小时前
机器学习数学基础与商业实践指南:从统计显著性到预测能力的认知升级
人工智能·python·机器学习·数据挖掘·数据分析·数据科学·统计学
杨荧2 小时前
基于Python的反诈知识科普平台 Python+Django+Vue.js
大数据·前端·vue.js·python·数据分析
大模型真好玩2 小时前
深入浅出LangChain AI Agent智能体开发教程(九)—LangChain从0到1搭建知识库
人工智能·python·mcp
MZ_ZXD0017 小时前
springboot汽车租赁服务管理系统-计算机毕业设计源码58196
java·c++·spring boot·python·django·flask·php
A 计算机毕业设计-小途7 小时前
大四零基础用Vue+ElementUI一周做完化妆品推荐系统?
java·大数据·hadoop·python·spark·毕业设计·毕设
念念010711 小时前
数学建模竞赛中评价类相关模型
python·数学建模·因子分析·topsis
云天徽上12 小时前
【数据可视化-94】2025 亚洲杯总决赛数据可视化分析:澳大利亚队 vs 中国队
python·信息可视化·数据挖掘·数据分析·数据可视化·pyecharts