如何在OpenERP中创建动态视图

5 投票
3 回答
14159 浏览
提问于 2025-04-16 20:47

我需要帮助来创建一个动态视图。让我来解释一下:我有两个视图,Form1和Form2。Form1里有一个expression字段和一个extract按钮。Form2则用来显示从Form1提取出来的表达式元素。比如,当你在Form1的表达式字段里输入(a+b)*c-d*0,5时,Form2应该提取并显示这些内容:

( - open brace
a - variable
+ - addition
b - variable
) - close brace
* - multiplication
c - variable
- - subtraction
d - variable
* - multiplication
0,5 - constant number

现在,这是我的类:

class wz_formula(osv.osv_memory):
    """
        Formula Wizard
    """
    _name = "wz.formula"
    _inherit = "ir.wizard.screen"
    _description = "Formula Wizard"

    _columns = {
            'name': fields.char('Formula name', required=True, size=64)
            , 'expression': fields.char('expression', required=True, size=64)
            , 'state': fields.selection([('init','init'),('done','done')], 'state', readonly=True)
    }

    _defaults = {
            'state': 'init'
    }

    def next(self, cr, uid, ids, context=None):
        if context is None:
            context = {}
        formula_obj = self.browse(cr, uid, ids)[0]
        formula_name = formula_obj.name
        infix = formula_obj.expression
        if formula_name and expression:
            modobj = self.pool.get('ir.module.module')
            mids = modobj.search(cr, uid, [('state', '=', 'installed')])
            modobj.update_translations(cr, uid, mids, [formula_name, expression], context or {})
            self.write(cr, uid, ids, {'state': 'done'}, context=context)
        return {
            'name': _('Formula')
            , 'view_type': 'form'
            , 'view_mode': 'form'
            , 'view_id': False
            , 'res_model': 'wz.formula'
            , 'domain': []
            , 'context': dict(context, active_ids=ids)
            , 'type': 'ir.actions.act_window'
            , 'target': 'new'
            , 'res_id': ids and ids[0] or False
        }

# create an object
wz_formula()

这是我的xml:

<?xml version="1.0" encoding="utf-8"?>
<openerp>
    <data>

        <record id="view_wz_formula" model="ir.ui.view">
            <field name="name">Formula</field>
            <field name="model">wz.formula</field>
            <field name="type">form</field>
            <field name="arch" type="xml">
                <form string="Formula">
                    <group colspan="8" col="8" states="init">
                        <separator string="Formula" colspan="8"/>
                        <field name="state" invisible="1"/>
                        <field name="name"/>
                        <field name="expression" width="220"/>
                        <button special="cancel" string="Cancel" icon="gtk-cancel" colspan="1"/>
                        <button name="next" string="Next" type="object" icon="gtk-ok" colspan="1"/>
                    </group>
                    <group colspan="8" col="8" states="done">
                        <separator string="Done" colspan="8"/>
                        <button special="cancel" string="Close" icon="gtk-cancel"/>
                    </group>
                </form>
           </field>
        </record>

        <record id="action_view_wz_formula" model="ir.actions.act_window">
            <field name="name">Formula</field>
            <field name="type">ir.actions.act_window</field>
            <field name="res_model">wz.formula</field>
            <field name="view_type">form</field>
            <field name="view_mode">form</field>
            <field name="target">new</field>
        </record>

        <menuitem
            name="Create a formula"
            action="action_view_wz_formula"
            id="menu_view_wz_formula"
            parent="menu_fs_root" sequence="2"/>

    </data>
</openerp>

到目前为止,它只是简单地在Form1和Form2之间切换。我该如何像上面那样提取表达式呢?

3 个回答

-1

我不太确定你具体在问什么,不过如果你只是想解析用户的表达式,那么这个关于Python表达式解析器的问题可能会对你有帮助。

1

一种更简单的方法是... 首先从第一个表单(表单1)获取表达式,然后根据你的需要进行评估。接着在第二个表单中保留一个“文本”字段,把这个数据按照你想要的格式放在那个字段里。

7

要在openerp v6中添加一个动态视图,你需要重写一个叫做 fields_view_get() 的函数。

def fields_view_get(self, cr, uid, view_id=None, view_type='form', context={}, toolbar=False):
    result = super(<your_class_name>, self).fields_view_get(cr, uid, view_id, view_type, context=context, toolbar=toolbar)
    # your modification in the view
    # result['fields'] will give you the fields. modify it if needed
    # result['arch'] will give you the xml architecture. modify it if needed
    return result

result 是一个字典,里面主要包含两样东西:Xml结构和字段。你需要把Xml结构以字符串的形式放在 result['arch'] 中,把字段以字典的字典形式放在 result['fields'] 中。然后返回这个结果。这样,你就能根据你提供的字段和结构得到一个视图。

撰写回答