ODOO-如何更新两个级别的o2m字段关系

如何解决ODOO-如何更新两个级别的o2m字段关系

Odoo社区版本11.0-20190311

我有一个父类(dt_tst001),其o2m字段(itens)与一个类(dt_tst002)相关,另一个o2m字段(tributos)与第三类(dt_tst003)相关。

在父类中还有另一个字段(seguro_total),并且当其值更改时,我需要在第二类中对字段(seguro)和第三类中的字段(base_calculo,valor_tributo)开始重新计算(_upd_seguro)。

第二类中的重新计算有效,但第三类中没有。

逐步调试值,但检查表单时会显示原始值,并将这些值发送到数据库。

示例代码:

class DT_TST001(models.Model):
    _name = "dt_tst001"
    _rec_name = "documento"

    documento = fields.Char(string = "Documento",size = 9,required = True)
    seguro_total = fields.Float(string = "Seguro total")
    itens = fields.One2many("dt_tst002",inverse_name = "documento_id",required = True)

    @api.onchange('seguro_total')
    def _upd_seguro(self):
        for item in self.itens:
            item.update({
                'seguro' : ((item.quantidade * item.valor_unitario) / item.valor_total) * self.seguro_total})

            for tributo in item.tributos:
                tributo.update({'base_calculo' : (item.valor_total + item.seguro)})
                tributo.update({'valor_tributo' : (item.valor_total + item.seguro) * tributo.aliquota / 100})


class DT_TST002(models.Model):
    _name = "dt_tst002"
    _rec_name = "documento_id"

    documento_id = fields.Many2one("dt_tst001",string = "Documento",required = True,ondelete='cascade')
    produto_id = fields.Char(string = "Produto",size = 15,required = True)
    quantidade = fields.Float(string="Quantidade",default = 0.00)
    valor_unitario = fields.Float(string="Valor unitário",default = 0.00)
    valor_total = fields.Float(string="Valor total",default = 0.00)
    seguro = fields.Float(string="Seguro",compute='_recalc_impostos',store=True)
    tributos = fields.One2many("dt_tst003",inverse_name = "item_id")

    @api.onchange('quantidade','valor_unitario','seguro')
    def _upd_valor_total(self):
        self.valor_total = (self.quantidade * self.valor_unitario) + self.seguro


class DT_TST003(models.Model):
    _name = "dt_tst003"

    item_id = fields.Many2one("dt_tst002",string = "Ítem",ondelete='cascade')
    tributo_id = fields.Char(string = "Tributo",required = True)
    base_calculo = fields.Float(string = "Base de cálculo")
    aliquota = fields.Float(string = "Alíquota")
    valor_tributo = fields.Float(string = "Valor do tributo")

    @api.multi
    def name_get(self):
        result = []
        for m_tst003 in self:
            name = m_tst003.item_id.documento_id._name + " - " + m_tst003.item_id._name + " - " + m_tst003.tributo_id._name
            result.append((m_tst003.id,name))
        return result

示例视图定义:

<odoo>
    <data>
        <!-- VIEWS PARA NOTAS DE ENTRADA -->
        <record model="ir.ui.view" id="tst001_form">
            <field name="model">dt_tst001</field>
            <field name="name">tst001_form</field>
            <field name="arch" type="xml">
                <form string="Documento de entrada">
                    <group colspan="1" style="margin: 0px">
                        <field name="documento" style="text-transform: uppercase;"/>
                        <field name="seguro_total"/>
                    </group>
                    <notebook>
                        <page string="Ítens">
                            <group>
                                <h6>
                                    <field name="itens" context="{'form_view_ref' : 'dt_tst.tst002_form','tree_view_ref' : 'dt_tst.tst002_tree','default_itens' : itens}" force_save="1" class="oe_horizontal_separator oe_clear"/>
                                </h6>
                            </group>
                        </page>
                    </notebook>
                </form>
            </field>
        </record>

        <record model="ir.ui.view" id="tst001_tree">
            <field name="model">dt_tst001</field>
            <field name="name">tst001_tree</field>
            <field name="arch" type="xml">
                <tree string="Documentos de entrada">
                    <field name="documento"/>
                    <field name="seguro_total"/>
                </tree>
            </field>
        </record>

        <!-- ITENS -->
        <record model="ir.ui.view" id="tst002_form">
            <field name="model">dt_tst002</field>
            <field name="name">tst002_form</field>
            <field name="arch" type="xml">
                <form string="Ítem de documento de entrada">
                    <group style="margin: 0px">
                        <group colspan="4" style="margin: 0px">
                            <field name="produto_id"/>
                        </group>
                        <group colspan="4" style="margin: 0px">
                            <group style="margin: 0px">
                                <field name="quantidade"/>
                            </group>
                            <group style="margin: 0px">
                                <field name="valor_unitario"/>
                            </group>
                            <group colspan="4" style="margin: 0px">
                                <field name="valor_total" readonly="1" options='{"always_reload": True}' />
                            </group>
                        </group>
                        <group colspan="4" style="margin: 0px">
                            <field name="seguro"/>
                        </group>
                        <field name="valor_total" invisible="1"/>
                    </group>
                    <notebook>
                        <page string="Tributos">
                            <group>
                                <h6>
                                    <field name="tributos" context="{'form_view_ref' : 'dt_test.tst003_form','tree_view_ref' : 'dt_test.tst003_tree','default_tributos' : tributos,'default_valor_total' : valor_total}" force_save="1" class="oe_horizontal_separator oe_clear"/>
                                </h6>
                            </group>
                        </page>
                    </notebook>
                </form>
            </field>
        </record>

        <record model="ir.ui.view" id="dt_fis.tst002_tree">
            <field name="model">dt_tst002</field>
            <field name="name">tst002_tree</field>
            <field name="arch" type="xml">
                <tree string="Ítens de documentos de entrada">
                    <field name="produto_id"/>
                    <field name="quantidade"/>
                    <field name="valor_unitario"/>

                    <!-- Enviar campos invisíveis para que seu conteúdo seja resgatado no formulário -->
                    <field name="seguro" invisible="1"/>
                    <field name="tributos" invisible="1"/>
                </tree>
            </field>
        </record>

        <!-- VIEWS PARA DOCUMENTOS DE ENTRADA E SAÍDA -->
        <record model="ir.ui.view" id="tst003_form">
            <field name="model">dt_tst003</field>
            <field name="name">tst003_form</field>
            <field name="arch" type="xml">
                <form string="Tributos de ítem de documento fiscal">
                    <sheet>
                        <group>
                            <field name="tributo_id"/>
                            <field name="base_calculo"/>
                            <field name="aliquota"/>
                            <field name="valor_tributo"/>
                        </group>
                    </sheet>
                </form>
            </field>
        </record>

        <record model="ir.ui.view" id="tst003_tree">
            <field name="model">dt_tst003</field>
            <field name="name">tst003_tree</field>
            <field name="arch" type="xml">
                <tree string="Tributos de ítem de documento fiscal">
                    <field name="tributo_id"/>
                    <field name="base_calculo"/>
                    <field name="aliquota"/>
                    <field name="valor_tributo"/>
                </tree>
            </field>
        </record>

        <record model="ir.actions.act_window" id="dt_test.tst001_action">
            <field name="name">Documentos de entrada - teste</field>
            <field name="res_model">dt_tst001</field>
            <field name="view_mode">tree,form</field>
            <field name="view_type">form</field>
            <field name="view_ids" eval="[(5,0),(0,{'view_mode': 'tree','view_id': ref('tst001_tree')}),{'view_mode': 'form','view_id': ref('tst001_form')})]"/>
            <field name="view_type">form</field>
        </record>

        <menuitem name="Documentos de entrada" id="dt_test.tst001_menu" parent="dt_test.tst_menu_registros" action="dt_test.tst001_action" sequence="10"/>
    </data>
</odoo>

谢谢!

解决方法

好吧,在第二个类中似乎起作用了,因为类seguro的{​​{1}}字段是基于DT_TST002函数计算的。它不使用_recalc_impostos。还有一点要注意,类 DT_TST001 DT_TST003 之间没有关系。

根据您的评论, on_change 方法如下:

on_change

另外,请注意,您可以按以下方式处理关系字段

@api.onchange('seguro_total')
    def _upd_seguro(self):
        for item in self.itens:
            seguro = ((item.quantidade * item.valor_unitario) / item.valor_total) * self.seguro_total
            tributes = []
            for tributo in item.tributos:
                base_calculo = (item.valor_total + item.seguro)
                valor_tributo = (item.valor_total + item.seguro) * tributo.aliquota / 100
                tributes.append((1,tributo.id,{'base_calculo' : base_calculo,'valor_tributo' : valor_tributo}))
            item.update({
                'seguro' : seguro
                'tributos' : tributes,})

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-