1

我在列表视图中遇到了 Odoo 向导的一些问题,该向导会从选定(选中)列表项中获取一个值来更新另一条记录。例如,我在 res_partner 中添加了一个名为 related_pa​​rtner_id 的列。基本上,它用于对主帐户(合作伙伴)进行分类。添加新客户时,我设置了一个可以分配主帐户的下拉菜单。数据库从 res_partner 将related_pa​​rtner_id 更新为子账户的id。

这是我正在使用的视图。

<?xml version="1.0" encoding="utf-8"?>
<openerp>
    <data>
        <!--Wizard view to assign new master account-->
        <record model="ir.ui.view" id="view_master_wizard_form">
            <field name="name">master.wizard.form</field>
            <field name="model">master.wizard</field>
            <field name="arch" type="xml">
                <form string="Assign New Parent">
                    <separator colspan="4" string="Update Parent"/>
                    <newline/>
                    <field name="related_partner_id"/>
                    <field name="parent_id" invisible="1"/>
                    <group col="4" colspan="4">
                        <button icon="gtk-cancel" special="cancel" string="Cancel"/>
                        <button icon="gtk-ok" name="change_master" string="Update" type="object"/>
                    </group>
                </form>
        </field>
    </record>
    <!--Add option to More dropdown in customer list viewt-->
    <act_window id="launch_res_partner" name="Assign New Master"
                src_model="res.partner"
                res_model="master.wizard"
                view_mode="form"
                view_type="form"
                target="new"
                key2="client_action_multi"/>
    <!--Action to change selected customers to the new master account-->
    <record id="action_change_master" model="ir.actions.act_window">
        <field name="name">Assign New Master Account</field>
        <field name="type">ir.actions.act_window</field>
        <field name="src_model">res.partner</field>
        <field name="res_model">master.wizard</field>
        <field name="view_type">form</field>
        <field name="view_mode">form</field>
        <field name="target">new</field>
    </record>
</data>

我在此处遵循/基于 Odoo 向导指南。我可以看到它在数据库中的 master_wizard 表中写入条目(尽管无论我检查多少都只有一个),但它不会更新 res_partner 表。

4

1 回答 1

1

这是使用上述 XML 的模型类。只需要遍历 ids 并将值从 self 值设置为向导到 res.partner 表。这就是所有新的 API。它可能需要稍微修饰一下,但现在可以正常工作。我必须设置 parent_id 因为它也需要更改。

from openerp import models, fields, api


class master_wizard(models.TransientModel):
    _name = 'master.wizard'

    related_partner_id = fields.Many2one('res.partner', 'Master Account')
    parent_id = fields.Many2one('res.partner')
    related_partner_ids = fields.One2many('res.partner', 'related_partner_id')

    @api.multi
    def change_master(self):
        related_partner_ids = self.env['res.partner'].browse(self._context.get('active_ids'))
        for partner in related_partner_ids:
            partner.related_partner_id = self.related_partner_id
            partner.parent_id = self.related_partner_id
        return {}
于 2015-04-06T07:44:00.043 回答